body{margin:0;padding:0;overflow-x:hidden}.hostel-container{min-height:100vh;background-color:#f8fafc;display:flex;flex-direction:column}.hostel-header{background-color:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px 0 rgba(0,0,0,.1)}.hostel-header-content{max-width:1200px;margin:0 auto;padding:16px;width:100%;box-sizing:border-box}.hostel-header-flex{display:flex;align-items:center;justify-content:space-between}.hostel-logo-section{display:flex;align-items:center;gap:16px}.hostel-logo{height:40px;width:40px;background-color:#0891b2;border-radius:8px;display:flex;align-items:center;justify-content:center}.hostel-logo-text{color:#fff;font-weight:700;font-size:18px}.hostel-title{font-size:24px;font-weight:700;color:#0891b2;margin:0}.hostel-nav{display:flex;align-items:center;gap:16px}.hostel-welcome-text{color:#64748b}.hostel-btn{display:flex;align-items:center;padding:8px 12px;font-size:14px;border:1px solid #e2e8f0;border-radius:6px;background-color:#fff;cursor:pointer;transition:background-color .2s}.hostel-btn:hover{background-color:#f1f5f9}.hostel-btn-primary{padding:8px 16px;font-size:14px;background-color:#0891b2;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s}.hostel-btn-primary:hover{background-color:#0e7490}.hostel-btn-large{padding:12px 24px;font-size:18px;border-radius:8px}.hostel-btn-success{background-color:#10b981;color:#fff;border:none;display:flex;align-items:center;padding:12px 20px;font-size:16px;border-radius:8px;cursor:pointer;transition:all .2s}.hostel-btn-success:hover{background-color:#059669;transform:translateY(-1px)}.hostel-btn-rounded{border-radius:12px;font-weight:600}.hostel-btn-danger{display:flex;align-items:center;padding:8px 16px;background-color:#ef4444;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s}.hostel-btn-danger:hover{background-color:#dc2626}.hostel-main{max-width:1200px;width:100%;margin:0 auto;padding:32px 16px;flex:1;box-sizing:border-box}.hostel-demo-banner{text-align:center;margin-bottom:48px}.hostel-demo-title{font-size:36px;font-weight:700;color:#1e293b;margin:0}.hostel-demo-description{font-size:20px;color:#64748b;max-width:600px;margin:16px auto 24px}.hostel-demo-buttons{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}.hostel-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px;max-width:100%;width:100%;padding:0 16px;box-sizing:border-box}.hostel-section-title{font-size:30px;font-weight:700;color:#1e293b;margin:0}.hostel-legend{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:32px;padding:16px;background-color:#fff;border-radius:8px;border:1px solid #e2e8f0;max-width:100%;width:100%;box-sizing:border-box}.hostel-legend-item{display:flex;align-items:center;gap:8px;flex:0 0 auto;min-width:auto}.hostel-legend-color{width:16px;height:16px;border-radius:4px}.hostel-legend-label{font-size:14px;color:#1e293b}.hostel-rooms-grid{display:grid;gap:16px;justify-content:center;max-width:100%;width:100%;margin:0 auto;padding:0 16px;box-sizing:border-box;grid-template-columns:repeat(6,180px)}@media (max-width:1024px){.hostel-rooms-grid{grid-template-columns:repeat(4,180px)}}@media (max-width:768px){.hostel-rooms-grid{grid-template-columns:repeat(3,180px)}}@media (max-width:540px){.hostel-rooms-grid{grid-template-columns:repeat(2,180px)}}.hostel-room-card{cursor:pointer;transition:all .2s;color:#fff;box-shadow:0 4px 6px -1px rgba(0,0,0,.1);border-radius:8px;padding:16px;text-align:center;min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center}.hostel-room-card:hover{transform:scale(1.05)}.hostel-room-content{display:flex;flex-direction:column;align-items:center;gap:8px}.hostel-room-number{font-weight:700;font-size:18px}.hostel-room-tenant{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.hostel-room-payment,.hostel-room-tenant{font-size:16px;opacity:.9;font-weight:500}.hostel-room-beds{font-size:15px;opacity:.9;font-weight:500}.hostel-room-date{font-size:16px;opacity:.9;font-weight:500}.hostel-room-overdue{animation:room-flash 1s infinite}@keyframes room-flash{0%,50%{background-color:inherit}51%,to{background-color:#fff!important;color:#000!important}}.hostel-room-available{background-color:#10b981}.hostel-room-available:hover{background-color:#059669}.hostel-room-occupied{background-color:#ef4444}.hostel-room-occupied:hover{background-color:#dc2626}.hostel-room-reserved{background-color:#3b82f6}.hostel-room-reserved:hover{background-color:#2563eb}.hostel-room-maintenance{background-color:#8b5cf6}.hostel-room-maintenance:hover{background-color:#7c3aed}.hostel-room-cleaning{background-color:#f59e0b}.hostel-room-cleaning:hover{background-color:#d97706}.hostel-modal-overlay{position:fixed;inset:0;background-color:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.hostel-modal-overlay-blur{backdrop-filter:blur(4px);background-color:rgba(0,0,0,.6)}.hostel-modal{background-color:#fff;border-radius:8px;padding:24px;width:100%;max-width:400px;box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}.hostel-modal-large{max-width:600px;max-height:90vh;overflow-y:auto;border:1px solid #e5e7eb}.hostel-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.hostel-modal-title{font-size:20px;font-weight:700;margin:0;color:#111827}.hostel-modal-subtitle{font-size:14px;color:#6b7280;margin:4px 0 0}.hostel-modal-close{background:none;border:none;cursor:pointer;color:#64748b}.hostel-form{display:flex;flex-direction:column;gap:16px}.hostel-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.hostel-form-group{display:flex;flex-direction:column;gap:24px}.hostel-label{display:block;font-size:14px;font-weight:500;margin-bottom:4px;color:#374151}.hostel-input,.hostel-textarea{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background-color:#fff;color:#111827;box-sizing:border-box}.hostel-textarea{min-height:160px;resize:vertical}.hostel-select{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background-color:#fff;color:#111827;box-sizing:border-box}.hostel-alert{background-color:#f1f5f9;padding:12px;border-radius:6px;margin-bottom:16px}.hostel-alert-text{font-size:14px;margin:0}.hostel-alert-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.hostel-button-group{display:flex;gap:8px}.hostel-button-group-end{display:flex;justify-content:flex-end;gap:8px}.hostel-btn-secondary{border:1px solid #d1d5db;border-radius:6px;background-color:#fff;color:#374151}.hostel-btn-blue,.hostel-btn-secondary{padding:8px 16px;cursor:pointer;font-size:14px}.hostel-btn-blue{background-color:#3b82f6;color:#fff;border:none;border-radius:6px}.hostel-btn-full{width:100%;padding:8px;border-radius:6px;cursor:pointer;font-size:14px}.hostel-btn-flex{flex:1}.hostel-footer{background-color:#1e293b;color:#e2e8f0;margin-top:64px;padding:48px 0 24px}.hostel-footer-content{max-width:1200px;margin:0 auto;padding:0 16px;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px}.hostel-footer-section{display:flex;flex-direction:column;gap:16px}.hostel-footer-title{font-size:18px;font-weight:600;color:#fff;margin:0 0 8px}.hostel-footer-text{font-size:14px;line-height:1.6;color:#cbd5e1;margin:0}.hostel-footer-links{display:flex;flex-direction:column;gap:8px}.hostel-footer-link{color:#60a5fa;text-decoration:none;font-size:14px;transition:color .2s;background:none;border:none;cursor:pointer;text-align:left;padding:0}.hostel-footer-link:hover{color:#93c5fd;text-decoration:underline}.hostel-footer-delete-btn{background-color:#dc2626;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s;align-self:flex-start}.hostel-footer-delete-btn:hover{background-color:#b91c1c}.hostel-footer-contact{font-size:14px;line-height:1.6}.hostel-footer-contact p{margin:0 0 8px;color:#cbd5e1}.hostel-footer-bottom{border-top:1px solid #374151;margin-top:32px;padding-top:24px;text-align:center}.hostel-footer-bottom p{margin:0;font-size:14px;color:#9ca3af}.hostel-blink{animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.3}}.hostel-policy-modal{max-width:700px;max-height:80vh;overflow-y:auto}.hostel-policy-content{padding:16px 0;line-height:1.6}.hostel-policy-content h4{color:#1f2937;font-size:16px;font-weight:600;margin:24px 0 12px}.hostel-policy-content h4:first-child{margin-top:0}.hostel-policy-content p{color:#4b5563;font-size:14px;margin:0 0 16px;line-height:1.6}.hostel-policy-content strong{color:#1f2937;font-weight:600}@media (max-width:600px){.hostel-header-flex{flex-direction:column;align-items:flex-start;gap:8px}.hostel-nav{flex-wrap:wrap;gap:8px}.hostel-form-grid{grid-template-columns:1fr}.hostel-demo-buttons{flex-direction:column;align-items:center}.hostel-btn-large{width:100%;max-width:300px}.hostel-footer-content{grid-template-columns:1fr;gap:24px}}@media (max-width:500px){.hostel-demo-title{font-size:24px}.hostel-demo-description{font-size:16px}.hostel-section-title{font-size:20px}.hostel-room-beds,.hostel-room-date,.hostel-room-number,.hostel-room-payment,.hostel-room-tenant{font-size:14px}.hostel-title{font-size:20px}.hostel-modal{padding:16px}.hostel-modal-title{font-size:18px}.hostel-main{padding:16px}.hostel-section-header{padding:0;margin-bottom:16px}.hostel-legend{padding:12px;margin-bottom:16px}.hostel-rooms-grid{padding:0}}