:root{color:#0f172a;--primary:#1e293b;--secondary:#14b8a6;--accent:#f59e0b;--danger:#dc2626;--success:#16a34a;--warning:#d97706;--muted:#64748b;--border:#e2e8f0;--background:#fff;--surface:#f8fafc;background:radial-gradient(circle at 0 0,#14b8a614,#0000 30%),radial-gradient(circle at 100% 0,#1e293b0f,#0000 30%),linear-gradient(#f8fafc 0%,#f1f5f9 100%);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}*{box-sizing:border-box}body{overscroll-behavior-y:contain;min-width:320px;margin:0}button,input,select{font:inherit}button{background:0 0;border:0;padding:0}input,select{color:#0f172a;background:#fff;border:1px solid #d7dfeb;border-radius:12px;width:100%;min-height:46px;padding:12px 14px;box-shadow:inset 0 1px #fffc}input:focus,select:focus{border-color:var(--secondary);outline:none;box-shadow:0 0 0 4px #14b8a61f}.app-shell{min-height:100dvh}.topbar{z-index:6;background:linear-gradient(180deg, #ffffff0f, #ffffff05), linear-gradient(120deg, var(--primary), #2d3748 52%, #4a5568);color:#fff;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);padding:18px 28px;position:sticky;top:0;box-shadow:inset 0 -1px #ffffff14,0 18px 38px #0f172a38}.topbar-main{align-items:center;gap:18px;min-height:76px;display:flex}.brand-block{flex:none}.eyebrow{text-transform:uppercase;letter-spacing:.12em;opacity:.66;font-size:11px}.logo{letter-spacing:0;margin-top:3px;font-size:25px;font-weight:700}.topbar-tabs{background:#ffffff0f;border:1px solid #ffffff14;border-radius:18px;flex:auto;min-width:0;padding:8px;display:flex}.tabs-container{scrollbar-width:none;-ms-overflow-style:none;gap:4px;display:flex;overflow-x:auto}.tabs-container::-webkit-scrollbar{display:none}.topbar-actions{color:#e2e8f0;background:#ffffff1f;border:1px solid #ffffff1a;border-radius:999px;align-items:center;gap:10px;margin-left:auto;padding:8px 12px;display:flex}.user-info{flex-direction:column;align-items:flex-end;display:flex}.user-email{color:#e2e8f0;font-size:12px;font-weight:600}.sync-state{text-transform:uppercase;letter-spacing:.08em;opacity:.8;font-size:11px;font-weight:500}.nav-item{color:#ffffffd1;white-space:nowrap;cursor:pointer;border:1px solid #0000;border-radius:12px;flex-shrink:0;min-height:36px;padding:8px 12px;font-size:13px;font-weight:600;transition:background .16s,color .16s,transform .16s,box-shadow .16s}.nav-item:hover{color:#fff;background:#ffffff1a}.nav-item.active{color:#0f172a;background:#fffffff5;border-color:#fffffff2;box-shadow:0 10px 22px #0f172a33}.main-content{padding:24px}.stack{gap:22px;display:grid}.panel{background:#fffffff0;border:1px solid #94a3b829;border-radius:18px;padding:22px;box-shadow:0 10px 26px #0f172a0f,inset 0 1px #ffffffd9}.page-panel{overflow:hidden}.hero-panel{background:linear-gradient(#fffffff0,#f8fafcfa),#fff}.section-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.section-header h2,.section-header h3,.panel h2,.panel h3{margin:0 0 6px;font-size:22px;line-height:1.2}.section-header h3,.panel h3{font-size:18px}.section-header p,.panel p,.modal-copy{color:#64748b;margin:0;font-size:14px;line-height:1.55}.dashboard-grid,.finance-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;display:grid}.card{background:linear-gradient(135deg,#fff,#f5f8ff);border:1px solid #e2e8f0b8;border-radius:16px;padding:12px 16px;box-shadow:0 8px 24px #0f172a14}.stat-card{align-content:space-between;gap:8px;min-height:110px;display:grid}.stat-card span{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:11px;font-weight:600;display:block}.stat-card strong{font-size:34px;line-height:1.05}.highlight{border:1.5px solid var(--accent);background:linear-gradient(135deg,#fffbeb,#fef9e7);box-shadow:0 12px 24px #f59e0b1a}.highlight strong{color:var(--accent)}.finance-charts{gap:20px;display:grid}.chart-panel{overflow:hidden}.compact-header{margin-bottom:18px}.monthly-chart{border-top:1px solid var(--border);background:repeating-linear-gradient(0deg,#0000 0 63px,#94a3b829 64px);grid-template-columns:repeat(12,minmax(42px,1fr));gap:12px;min-height:320px;padding:18px 6px 4px;display:grid}.month-bar-item{grid-template-rows:1fr auto;gap:10px;min-width:0;display:grid}.month-bar-track{justify-content:center;align-items:flex-end;min-height:260px;display:flex;position:relative}.month-bar{background:linear-gradient(#38bdf8d9,#2563ebd1);border-radius:8px 8px 2px 2px;width:min(54px,76%);min-height:3px;box-shadow:0 10px 20px #2563eb29}.bar-value{bottom:var(--bar-bottom,0);border:1px solid var(--border);color:var(--primary);white-space:nowrap;background:#fff;border-radius:999px;padding:4px 7px;font-size:11px;font-weight:700;position:absolute;left:50%;translate:-50%;box-shadow:0 8px 16px #0f172a14}.chart-label{color:var(--muted);text-align:center;font-size:12px;font-weight:700}.daily-chart{border-top:1px solid var(--border);padding-top:10px;overflow-x:auto}.daily-chart svg{width:100%;min-width:860px;height:auto;display:block}.chart-grid-line,.chart-day-line{stroke:#94a3b847;stroke-width:1px}.chart-day-line{stroke:#94a3b829}.chart-axis-label{fill:var(--muted);font-size:12px;font-weight:600}.revenue-line-fill{fill:#38bdf81f}.revenue-line{fill:none;stroke:#2563eb;stroke-width:4px;stroke-linecap:round;stroke-linejoin:round}.revenue-point{fill:#fff;stroke:#2563eb;stroke-width:3px}.room-grid{grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:12px;display:grid}.room{color:#fff;border-radius:16px;place-items:center;min-height:70px;padding:14px 8px;font-size:15px;font-weight:700;display:grid;box-shadow:inset 0 1px #fff3}.available{background:linear-gradient(#22c55e,#16a34a)}.occupied{background:linear-gradient(#ef4444,#dc2626)}.checkout{background:linear-gradient(#f59e0b,#d97706)}.dirty{background:linear-gradient(#7c3aed,#6d28d9)}.alert-panel{border-left:4px solid var(--danger);box-shadow:0 12px 24px rgba(220, 38, ff5f5, #fffaf7);border:1px solid #fccacadb;border-left:4px solid var(--danger);background:linear-gradient(135deg,#fff5f5,#fffaf7);border:1px solid #fccacadb;border-radius:20px;box-shadow:0 12px 24px #dc262614}.alert-panel .section-header h3{color:var(--danger)}.alert-panel .section-header p{color:var(--muted)}.alert-list{gap:12px;display:grid}.alert-row{background:#fef3f3d9;border:1px solid #fccacae6;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;transition:background .18s,transform .18s;display:flex}.alert-row:hover{background:#fee2e2f2;transform:translateY(-1px)}.overdue-row{font-size:13px;font-weight:600}.overdue-row span:first-child{color:var(--primary);min-width:90px}.overdue-row span:last-child{color:var(--danger);font-weight:700}.stat-pill{background:#fef3f3e6;border:1px solid #fccacae6;border-radius:16px;flex-direction:column;align-items:flex-end;gap:6px;padding:14px 18px;display:flex}.stat-pill span{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:11px}.stat-pill strong{color:var(--danger);font-size:24px;font-weight:700}.form-card{background:linear-gradient(#fff,#f8fbff);border:1px solid #e2e8f0;border-radius:16px;padding:18px}.booking-stage{gap:24px;display:grid}.booking-hero-card{background:linear-gradient(#fff,#f8fbff);border:1px solid #e2e8f0db;border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px 20px;display:flex;box-shadow:0 18px 36px #0f172a14}.booking-left span{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:600;display:block}.booking-left h2{color:var(--primary);margin:4px 0 0;font-size:24px}.booking-right{align-items:center;gap:16px;display:flex}.booking-right div{color:var(--primary);font-size:14px;font-weight:600}.booking-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.booking-form-section{background:#fff;border:1px solid #e2e8f0e6;border-radius:18px;gap:14px;padding:18px 20px;display:grid}.booking-section-head{letter-spacing:.1em;text-transform:uppercase;color:var(--primary);border-bottom:1px solid #e2e8f0e6;padding-bottom:10px;font-size:12px;font-weight:700}.form-field{gap:8px;display:grid}.form-field label{color:var(--primary);font-size:13px;font-weight:700}.booking-form-actions{grid-column:1/-1;display:grid}.booking-panel .btn{min-height:44px;padding:12px 16px}@media (width<=900px){.booking-hero{grid-template-columns:1fr}}@media (width<=700px){.booking-form-grid{grid-template-columns:1fr}}.inline-form,.button-row,.subsection,.control-strip,.action-row{flex-wrap:wrap;gap:12px;display:flex}.control-strip{background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;align-items:center;padding:14px}.control-strip>*{flex:160px;min-width:140px}.feature-block{margin:0}.feature-block h3,.card h3{text-transform:uppercase;letter-spacing:.04em;color:var(--primary);margin:0 0 12px;font-size:14px;font-weight:700}.subsection{flex-direction:column}.button-row{align-items:center}.search-box{width:100%;max-width:420px;min-height:46px;color:var(--primary);background:#fff;border:1px solid #e2e8f0eb;border-radius:14px;padding:12px 16px;box-shadow:inset 0 1px 2px #0f172a0f}.table-container{background:#fff;border:1px solid #e2e8f0f5;border-radius:20px;width:100%;overflow:auto;box-shadow:0 12px 30px #0f172a0f}table{border-collapse:collapse;table-layout:fixed;width:100%}th{color:#fff;text-align:center;letter-spacing:.02em;background:linear-gradient(#1e40af,#2563eb);padding:12px 10px;font-size:12px;font-weight:700}td{text-align:center;vertical-align:top;white-space:normal;overflow-wrap:anywhere;border-bottom:1px solid #e8eef5;padding:12px 10px;font-size:13px}tbody tr:hover{background:#14b8a60a}.expense-row{transition:background .2s}.expense-row:hover{background:#14b8a60f}.expense-row td:first-child{color:var(--primary);font-weight:500}tfoot td{background:#f8fafc;font-weight:700}.occupied-table{border-collapse:separate;border-spacing:0;border-radius:12px;width:100%;font-size:13px;overflow:hidden;box-shadow:0 4px 6px #0000000d}.occupied-mobile-list{display:none}.occupied-table th{background:linear-gradient(135deg, var(--primary), #334155);color:#fff;text-align:center;border-bottom:1px solid var(--border);padding:16px 12px;font-weight:600}.occupied-table th:first-child{width:5%}.occupied-table th:nth-child(2),.occupied-table th:nth-child(3){width:12%}.occupied-table th:nth-child(4){width:8%}.occupied-table th:nth-child(5){width:10%}.occupied-table th:nth-child(6){width:12%}.occupied-table th:nth-child(7){width:10%}.occupied-table th:nth-child(8){width:22%}.occupied-table th:nth-child(9){width:10%}.occupied-table th:nth-child(10){width:12%}.occupied-table th:nth-child(11){width:11%}.occupied-table td{border-bottom:1px solid var(--border);background:var(--background);text-align:center;padding:16px 12px}.occupied-table tr:hover td{background:var(--surface)}.occupied-table tfoot td{background:var(--surface);border-top:2px solid var(--border);font-weight:700}.table-input{border:1px solid var(--border);background:var(--background);border-radius:8px;width:100%;max-width:140px;min-height:40px;padding:8px 12px;font-size:12px}.cell-stack{flex-direction:column;align-items:center;gap:6px;display:flex}.cell-stack.compact{gap:4px}.cell-stack strong{color:var(--primary);font-size:13px}.cell-stack span{color:var(--muted);font-size:11px}.payments-cell{align-items:stretch}.payment-history{flex-direction:column;gap:6px;width:100%;display:flex}.payment-entry{background:var(--surface);border:1px solid var(--border);border-radius:8px;justify-content:space-between;padding:8px 12px;font-size:11px;display:flex}.payment-entry.muted{color:var(--muted)}.action-stack{justify-items:stretch;gap:8px;display:grid}.action-row{justify-content:center}.history-table{min-width:1040px}.history-col-room{width:72px}.history-col-date{width:150px}.history-col-days{width:70px}.history-col-money{width:110px}.history-col-agent{width:150px}.history-col-actions{width:230px}.history-table th:last-child,.history-table td:last-child{text-align:center}.history-actions{grid-template-columns:repeat(3,minmax(62px,1fr));align-items:center;gap:8px;width:100%;display:grid}.history-actions .btn{white-space:nowrap;width:100%;min-width:0}.action-stack .btn{white-space:nowrap;width:100%}.status{border-radius:999px;align-items:center;min-height:34px;padding:8px 12px;font-size:12px;font-weight:700;line-height:1.2;display:inline-flex}.status-paid{color:var(--success);background:#dcfce7}.status-warning{color:var(--warning);background:#fef3c7}.status-danger{color:var(--danger);background:#fee2e2}.paid{background:#16a34a0f}.paid:hover{background:#16a34a1a}.unpaid{background:#f59e0b0f}.unpaid:hover{background:#f59e0b1a}.ledger-summary{border:1px solid var(--border);background:linear-gradient(135deg,#f8fafc,#eef4ff);border-radius:12px;margin-bottom:18px;padding:20px;box-shadow:0 4px 8px #0000000a}.split-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;display:grid}.empty-state{color:#64748b;justify-items:center;gap:6px;padding:18px 12px;display:grid}.empty-state strong{color:#334155;font-size:14px}.modal{z-index:15;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a7a;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border:1px solid #94a3b82e;border-radius:20px;gap:14px;width:min(440px,100%);padding:24px;display:grid;box-shadow:0 26px 60px #0f172a38}.modal-actions{gap:12px;display:flex}.login-page{place-items:center;min-height:100vh;padding:36px 20px;display:grid}.login-card{background:linear-gradient(#fff,#f8fbff);border:1px solid #e2e8f0f5;border-radius:28px;width:min(520px,100%);padding:32px;box-shadow:0 24px 60px #0f172a1f}.login-header{gap:14px;margin-bottom:24px;display:grid}.login-badge{color:var(--secondary);text-transform:uppercase;letter-spacing:.08em;background:#14b8a61f;border-radius:999px;align-items:center;padding:8px 14px;font-size:12px;font-weight:700;display:inline-flex}.login-header h2{color:var(--primary);margin:0;font-size:30px}.login-header p{color:var(--muted);margin:0;line-height:1.7}.login-form{gap:16px;display:grid}.login-form label{color:var(--primary);gap:8px;font-size:13px;font-weight:700;display:grid}.login-form input{border:1px solid #e2e8f0f2;border-radius:14px;min-height:46px;box-shadow:inset 0 1px 2px #0f172a0f}.login-form .btn{min-height:46px}.screen-message{color:#334155;place-items:center;min-height:100vh;padding:24px;font-size:16px;font-weight:600;display:grid}.btn{letter-spacing:.01em;cursor:pointer;border:1px solid #0000;border-radius:12px;min-height:44px;padding:10px 16px;font-size:13px;font-weight:700;transition:transform .16s,box-shadow .16s,background .16s,border-color .16s,color .16s}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(180deg, var(--secondary), #0f766e);color:#fff;box-shadow:0 14px 28px #14b8a62e}.btn-secondary{background:var(--surface);color:var(--primary);border-color:var(--border);box-shadow:0 6px 16px #0f172a0d}.btn-danger{color:#fff;background:#ef4444;box-shadow:0 6px 16px #ef444433}.btn-danger:hover{background:#dc2626}.btn-small{min-height:32px;padding:8px 12px;font-size:12px}.btn-small{border-radius:12px;min-height:32px;padding:8px 12px;font-size:12px}.button-row .btn{min-height:38px;padding:10px 16px}.btn:disabled{opacity:.58;cursor:not-allowed;box-shadow:none;transform:none}.toast-viewport{z-index:30;gap:10px;max-width:min(360px,100vw - 32px);display:grid;position:fixed;bottom:20px;right:20px}.toast{color:#0f172a;text-align:left;cursor:pointer;background:#fffffff5;border:1px solid #dbeafe;border-radius:16px;grid-template-columns:10px 1fr;align-items:center;gap:12px;width:100%;padding:14px 16px;display:grid;box-shadow:0 18px 36px #0f172a24}.toast-success .toast-dot{background:#16a34a}.toast-error .toast-dot{background:#dc2626}.toast-dot{border-radius:999px;width:10px;height:10px}@media (width<=1080px){.topbar-main{flex-wrap:wrap;align-items:flex-start}.topbar-actions{margin-left:0}.booking-hero{flex-direction:column}.booking-aside{flex:auto;grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=900px){.split-grid{grid-template-columns:1fr}}@media (width<=720px){body{-webkit-tap-highlight-color:transparent;touch-action:manipulation;background:#f8fafc}.main-content,.topbar{padding-left:max(14px, env(safe-area-inset-left));padding-right:max(14px, env(safe-area-inset-right))}.main-content{padding-top:12px;padding-bottom:calc(96px + env(safe-area-inset-bottom))}.topbar{padding-top:calc(14px + env(safe-area-inset-top));-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:0 0 20px 20px;padding-bottom:12px;position:static;box-shadow:0 10px 24px #0f172a2e}.section-header{flex-direction:column;align-items:flex-start;gap:10px}.section-header h2,.section-header h3,.panel h2,.panel h3{font-size:20px}.section-header p,.panel p{font-size:13px}.topbar-main{flex-direction:column;align-items:flex-start;gap:10px;min-height:0}.eyebrow{font-size:10px}.logo{max-width:14ch;font-size:clamp(24px,7vw,32px);line-height:1.12}.topbar-tabs{left:max(10px, env(safe-area-inset-left));right:max(10px, env(safe-area-inset-right));bottom:calc(10px + env(safe-area-inset-bottom));z-index:20;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0f172af0;border:1px solid #ffffff1f;border-radius:20px;width:auto;padding:7px;position:fixed;box-shadow:0 18px 38px #0f172a47}.tabs-container{overscroll-behavior-x:contain;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:5px;width:100%;overflow-x:auto}.nav-item{scroll-snap-align:start;white-space:nowrap;touch-action:manipulation;border-radius:15px;min-width:92px;min-height:44px;padding:8px 12px;transition:background 80ms,color 80ms}.nav-item:hover,.btn:hover{transform:none}.nav-item.active{box-shadow:none}.topbar-actions{border-radius:14px;justify-content:space-between;width:100%;padding:9px 10px}.user-info{align-items:flex-start;min-width:0}.user-email{text-overflow:ellipsis;white-space:nowrap;max-width:58vw;overflow:hidden}.panel,.page-panel{border-radius:16px;padding:14px;box-shadow:0 8px 18px #0f172a0d}.stack{gap:14px}.dashboard-grid,.finance-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.stat-card{min-height:92px;padding:12px}.stat-card strong{overflow-wrap:anywhere;font-size:clamp(21px,6vw,28px)}.room-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.room{border-radius:12px;min-height:54px;font-size:13px}.search-box{border-radius:13px;max-width:none;min-height:44px;font-size:14px}input,select{min-height:44px;font-size:16px}.button-row,.inline-form,.control-strip{gap:10px}.button-row .btn,.inline-form .btn,.control-strip .btn{width:100%}.booking-form{grid-template-columns:1fr}.booking-hero-card{flex-direction:column;align-items:flex-start;gap:10px;padding:14px}.booking-right{justify-content:space-between;gap:10px;width:100%}.booking-form-section{border-radius:16px;padding:14px}.booking-copy{padding:22px 20px}.booking-copy h2{font-size:26px}.booking-aside{grid-template-columns:1fr}.control-strip>*{flex-basis:100%}.occupied-table-shell{display:none}.occupied-mobile-list{gap:14px;display:grid}.occupied-card{background:#fff;border:1px solid #e2e8f0f5;border-radius:18px;gap:14px;padding:14px;display:grid;box-shadow:0 12px 26px #0f172a12}.occupied-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.occupied-card-kicker,.occupied-card-grid span,.occupied-card-total span,.occupied-card-dates label{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:700}.occupied-card-head strong{color:var(--primary);margin-top:2px;font-size:32px;line-height:1;display:block}.occupied-card .status{text-align:center;border-radius:14px;justify-content:center;max-width:56%}.occupied-card-dates{gap:10px;display:grid}.occupied-card-dates label{gap:7px;display:grid}.occupied-card-dates input{min-height:42px;font-size:13px}.occupied-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.occupied-card-grid>div,.occupied-card-total{background:var(--surface);border:1px solid var(--border);border-radius:14px;align-content:start;gap:7px;min-width:0;padding:12px;display:grid}.occupied-card-grid strong,.occupied-card-total strong{min-width:0;color:var(--primary);overflow-wrap:anywhere;font-size:16px}.occupied-card-grid .btn{min-height:34px}.occupied-card-payment{grid-template-columns:1fr;gap:10px;display:grid}.occupied-card-total.due{background:#fff7ed;border-color:#fed7aa}.mobile-payment-history{gap:8px}.occupied-card-actions{grid-template-columns:1fr;gap:10px;display:grid}.occupied-card-actions .btn{white-space:nowrap;min-width:0;padding-left:10px;padding-right:10px}.occupied-mobile-empty{border:1px solid var(--border);background:#fff;border-radius:18px}.table-input,.nav-item,.btn{font-size:12px}.table-container{box-shadow:none;border-radius:16px}.history-table,table{min-width:760px}.monthly-chart{grid-template-columns:repeat(6,minmax(38px,1fr));gap:8px;min-height:260px;padding-top:12px}.month-bar-track{min-height:200px}.bar-value{display:none}.daily-chart svg{min-width:720px}.modal{align-items:flex-end;padding:12px}.modal-box{border-radius:20px;width:100%;max-height:calc(100dvh - 32px);padding:18px;overflow:auto}.modal-actions{grid-template-columns:1fr;display:grid}.toast-viewport{left:14px;right:14px;bottom:calc(82px + env(safe-area-inset-bottom));max-width:none}}
