@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--green-dark: #1A3D2B;--green-mid: #2D5A3D;--green-light: #4A7C59;--gold: #C9973A;--gold-light: #E0B86A;--vacant-bg: #FFFFFF;--vacant-border: #16A34A;--booked-bg: #FFF7ED;--booked-border: #F97316;--checkin-bg: #F0FDF4;--checkin-border: #16A34A;--dirty-bg: #FEF2F2;--dirty-border: #DC2626;--dirty-urgent-border: #F97316;--dirty-critical-border: #DC2626;--ooo-bg: #F9FAFB;--ooo-border: #6B7280;--sidebar-width: 220px;--radius: 12px;--border: #E5E7EB}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;color:#111827;background:#f9fafb}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--green-dark);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.main-content{flex:1;overflow-y:auto;display:flex;flex-direction:column}.sidebar-logo{padding:20px 16px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo h2{color:var(--gold-light);font-size:15px;font-weight:700;line-height:1.2}.sidebar-logo p{color:#ffffff80;font-size:11px;margin-top:2px}.sidebar-nav{padding:8px 0;flex:1}.sidebar-nav a{display:flex;align-items:center;gap:10px;padding:10px 16px;color:#ffffffb3;font-size:13.5px;font-weight:500;transition:background .15s,color .15s;border-radius:0}.sidebar-nav a:hover{background:#ffffff0f;color:#fff}.sidebar-nav a.active{background:#c9973a26;color:var(--gold);font-weight:600}.sidebar-nav .nav-icon{font-size:16px;width:20px;flex-shrink:0}.sidebar-footer{padding:12px 16px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-user{color:#ffffffb3;font-size:12px}.sidebar-user strong{color:#fff;display:block;font-size:13px}.topbar{background:#fff;border-bottom:1px solid var(--border);padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.topbar-title{font-size:16px;font-weight:600}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px}.stat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:4px}.stat-card .stat-label{font-size:12px;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-card .stat-value{font-size:28px;font-weight:700;color:#111827}.stat-card .stat-sub{font-size:12px;color:#6b7280}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13.5px;font-weight:600;border:none;transition:opacity .15s,background .15s}.btn:hover{opacity:.88}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--green-dark);color:#fff}.btn-secondary{background:#f3f4f6;color:#374151}.btn-danger{background:#dc2626;color:#fff}.btn-gold{background:var(--gold);color:#fff}.btn-outline{background:transparent;border:1.5px solid var(--border);color:#374151}.btn-sm{padding:5px 10px;font-size:12px;border-radius:6px}.btn-lg{padding:12px 24px;font-size:15px;border-radius:10px}.btn-block{width:100%}.rooms-page{display:flex;flex-direction:column;height:100%}.rooms-toolbar{padding:12px 16px;background:#fff;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:8px;align-items:center}.rooms-body{flex:1;overflow:auto;padding:16px}.rooms-with-panel{display:flex;gap:0;height:100%}.rooms-grid-container{flex:1;overflow:auto}.floor-group{margin-bottom:24px}.floor-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#9ca3af;margin-bottom:10px;display:flex;align-items:center;gap:8px}.floor-label:after{content:"";flex:1;height:1px;background:var(--border)}.room-cards{display:flex;flex-wrap:wrap;gap:10px}.room-card{width:160px;min-height:110px;border-radius:10px;border:1px solid var(--border);border-left:4px solid #ccc;padding:10px 12px;cursor:pointer;position:relative;transition:box-shadow .15s}.room-card:hover{box-shadow:0 4px 12px #00000014}.room-card.selected{box-shadow:0 0 0 2px var(--green-dark)}.room-card.vacant{background:var(--vacant-bg);border-left-color:var(--vacant-border)}.room-card.booked{background:var(--booked-bg);border-left-color:var(--booked-border)}.room-card.checked_in{background:var(--checkin-bg);border-left-color:var(--checkin-border)}.room-card.dirty{background:var(--dirty-bg);border-left-color:var(--dirty-border)}.room-card.dirty.urgent{border-left-color:var(--dirty-urgent-border)}.room-card.dirty.critical{border-left-color:var(--dirty-critical-border)}.room-card.out_of_order{background:var(--ooo-bg);border-left-color:var(--ooo-border)}.room-card .rc-number{font-size:15px;font-weight:700;color:#111827}.room-card .rc-price{font-size:11px;color:#6b7280;position:absolute;top:10px;right:10px}.room-card .rc-type{font-size:11px;color:#6b7280;margin-top:1px}.room-card .rc-status{font-size:11px;font-weight:600;margin-top:6px}.room-card .rc-guest{font-size:12px;color:#374151;margin-top:2px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-card .rc-dates{font-size:10.5px;color:#6b7280;margin-top:2px}.room-card .rc-urgency{font-size:10px;font-weight:600;margin-top:4px}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:9999px;font-size:11px;font-weight:600;text-transform:capitalize}.status-badge.vacant{background:#d1fae5;color:#065f46}.status-badge.booked{background:#fef3c7;color:#92400e}.status-badge.checked_in{background:#d1fae5;color:#065f46}.status-badge.dirty{background:#fee2e2;color:#991b1b}.status-badge.out_of_order{background:#f3f4f6;color:#6b7280}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.cancelled{background:#f3f4f6;color:#6b7280}.status-badge.checked_out{background:#dbeafe;color:#1e40af}.status-badge.paid{background:#d1fae5;color:#065f46}.status-badge.partial{background:#fef3c7;color:#92400e}.status-badge.unpaid{background:#fee2e2;color:#991b1b}.status-legend{display:flex;gap:10px;flex-wrap:wrap}.legend-pill{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:9999px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:border-color .15s}.legend-pill:hover,.legend-pill.active{border-color:currentColor}.legend-pill.vacant{background:#d1fae5;color:#065f46}.legend-pill.booked{background:#fef3c7;color:#92400e}.legend-pill.checked_in{background:#d1fae5;color:#065f46}.legend-pill.dirty{background:#fee2e2;color:#991b1b}.legend-pill.out_of_order{background:#f3f4f6;color:#6b7280}.live-dot{display:flex;align-items:center;gap:5px;font-size:11px;color:#16a34a;font-weight:500}.live-dot:before{content:"";width:7px;height:7px;border-radius:50%;background:#16a34a;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.filter-chip{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;border:1.5px solid var(--border);background:#fff;color:#374151;cursor:pointer;transition:all .15s}.filter-chip:hover{border-color:#9ca3af}.filter-chip.active{background:var(--green-dark);color:#fff;border-color:var(--green-dark)}.room-panel{width:320px;background:#fff;border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.room-panel-header{padding:16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between}.room-panel-header h3{font-size:16px;font-weight:700}.room-panel-header .close-btn{background:none;border:none;font-size:20px;color:#6b7280}.room-panel-body{padding:16px;flex:1}.action-btns{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.panel-info-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #F3F4F6;font-size:13px}.panel-info-row .label{color:#6b7280}.panel-info-row .value{font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:#fff;border-radius:var(--radius);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-lg{max-width:680px}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff;z-index:1}.modal-header h2{font-size:17px;font-weight:700}.modal-close{background:none;border:none;font-size:22px;color:#6b7280}.modal-body{padding:20px 24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;position:sticky;bottom:0;background:#fff}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:12.5px;font-weight:600;color:#374151;margin-bottom:5px}.form-control{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:13.5px;transition:border-color .15s;background:#fff}.form-control:focus{outline:none;border-color:var(--green-light)}.form-control[type=number]::-webkit-inner-spin-button,.form-control[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.form-control[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table th{text-align:left;padding:10px 12px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#6b7280;background:#f9fafb;border-bottom:1px solid var(--border)}.data-table td{padding:12px;border-bottom:1px solid #F3F4F6;vertical-align:middle}.data-table tr:hover td{background:#f9fafb}.data-table tr:last-child td{border-bottom:none}.page-container{padding:24px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h1{font-size:20px;font-weight:700}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.tab-bar{display:flex;border-bottom:2px solid var(--border);margin-bottom:16px;gap:0}.tab-btn{padding:10px 16px;background:none;border:none;font-size:13.5px;font-weight:500;color:#6b7280;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.tab-btn.active{color:var(--green-dark);border-bottom-color:var(--green-dark);font-weight:600}.alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:12px}.alert-warning{background:#fef3c7;color:#92400e;border:1px solid #FDE68A}.alert-danger{background:#fee2e2;color:#991b1b;border:1px solid #FECACA}.alert-success{background:#d1fae5;color:#065f46;border:1px solid #A7F3D0}.alert-info{background:#dbeafe;color:#1e40af;border:1px solid #BFDBFE}.wa-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#25d366;color:#fff;border-radius:6px;font-size:12px;font-weight:600;border:none;cursor:pointer}.guest-card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;align-items:flex-start;gap:12px;cursor:pointer;transition:box-shadow .15s}.guest-card:hover{box-shadow:0 2px 8px #00000014}.guest-avatar{width:44px;height:44px;border-radius:50%;background:var(--green-dark);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.guest-tag{display:inline-block;padding:2px 7px;background:#f3f4f6;border-radius:4px;font-size:11px;font-weight:500;color:#374151;margin-right:4px}.bill-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13.5px}.bill-row.total{font-weight:700;font-size:15px;border-top:2px solid #E5E7EB;padding-top:10px;margin-top:4px}.bill-row.balance{font-weight:700;font-size:16px;color:#dc2626}.payment-mode-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:12px 0}.payment-mode-btn{padding:8px;border:2px solid var(--border);border-radius:8px;background:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}.payment-mode-btn.active{border-color:var(--green-dark);background:#f0fdf4;color:var(--green-dark)}.revenue-strip{background:linear-gradient(135deg,var(--green-dark) 0%,var(--green-mid) 100%);color:#fff;border-radius:var(--radius);padding:20px 24px;display:flex;gap:32px;align-items:center;flex-wrap:wrap}.revenue-strip .rs-label{font-size:11px;opacity:.7;text-transform:uppercase;letter-spacing:.5px}.revenue-strip .rs-value{font-size:24px;font-weight:700}.hk-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}.hk-room-badge{width:44px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.hk-row.normal .hk-room-badge{background:#fee2e2;color:#dc2626}.hk-row.high .hk-room-badge{background:#fef3c7;color:#d97706}.hk-row.critical .hk-room-badge{background:#dc2626;color:#fff}.divider{height:1px;background:var(--border);margin:12px 0}.text-muted{color:#6b7280}.text-sm{font-size:12px}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-center{display:flex;align-items:center;gap:8px}.gap-8{gap:8px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-4{margin-bottom:4px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.fw-600{font-weight:600}.fw-700{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-input-wrap{position:relative}.search-input-wrap input{padding-left:32px}.search-input-wrap:before{content:"🔍";position:absolute;left:9px;top:50%;transform:translateY(-50%);font-size:12px;pointer-events:none}.login-page{min-height:100vh;background:var(--green-dark);display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 24px 80px #0000004d}.login-card h1{font-size:24px;font-weight:800;color:var(--green-dark);margin-bottom:4px}.login-card p{color:#6b7280;font-size:13.5px;margin-bottom:28px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:20px;height:20px;border:2.5px solid #E5E7EB;border-top-color:var(--green-dark);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@media (max-width: 768px){.sidebar{display:none}.room-cards{gap:8px}.room-card{width:calc(50% - 4px);min-height:100px}.room-panel{position:fixed;right:0;top:0;height:100%;z-index:500;box-shadow:-4px 0 20px #00000026}.grid-4,.grid-3{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.room-card{width:calc(50% - 4px)}.form-row{grid-template-columns:1fr}}@media print{*{-webkit-print-color-adjust:exact;print-color-adjust:exact}body{font-family:Arial,sans-serif;font-size:12px;color:#000;background:#fff}.sidebar,.topbar,.rooms-toolbar,.no-print,button,.modal-footer{display:none!important}.print-bill{max-width:210mm;margin:0 auto;padding:20px}.bill-header{text-align:center;margin-bottom:20px;border-bottom:2px solid #000;padding-bottom:12px}.bill-header h1{font-size:20px;font-weight:800}.bill-header p{font-size:12px;color:#444}.bill-guest-info{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px;font-size:12px}.bill-table{width:100%;border-collapse:collapse;margin-bottom:16px}.bill-table th,.bill-table td{border:1px solid #ccc;padding:6px 10px;text-align:left;font-size:12px}.bill-table th{background:#f0f0f0;font-weight:700}.bill-table .amount{text-align:right}.bill-totals{margin-left:auto;width:240px}.bill-total-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px;border-bottom:1px solid #eee}.bill-total-row.grand{font-weight:800;font-size:15px;border-top:2px solid #000;padding-top:6px}.bill-footer{margin-top:20px;text-align:center;font-size:11px;color:#666;border-top:1px solid #ccc;padding-top:12px}@page{size:A4;margin:15mm 15mm 20mm}}
