: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 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}.maintenance-panel{gap:18px;display:grid}.maintenance-progress{background:var(--surface);border:1px solid var(--border);border-radius:14px;justify-items:end;gap:4px;padding:10px 14px;display:grid}.maintenance-progress span{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:700}.maintenance-progress strong{color:var(--secondary);font-size:26px;line-height:1}.maintenance-bar{background:#e2e8f0;border-radius:999px;height:12px;overflow:hidden}.maintenance-bar span{border-radius:inherit;background:linear-gradient(90deg, var(--secondary), #0f766e);height:100%;transition:width .2s;display:block}.maintenance-list{gap:12px;display:grid}.maintenance-item{border:1px solid var(--border);background:#fff;border-radius:16px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;min-height:58px;padding:12px 14px;display:grid}.maintenance-item input{width:22px;min-height:22px;accent-color:var(--secondary);box-shadow:none}.maintenance-item span{color:var(--primary);font-size:15px;font-weight:700}.maintenance-item.checked{background:#14b8a614;border-color:#14b8a647}.maintenance-item.checked span{color:#0f766e;text-decoration:line-through}.maintenance-delete{min-height:34px;color:var(--danger);background:#fff1f2;border-radius:10px;padding:8px 10px;font-size:12px;font-weight:800}.maintenance-add{grid-template-columns:minmax(0,1fr) auto auto;gap:10px;display:grid}.login-page{color:#172033;background:radial-gradient(circle at 0 0,#b2853929,#0000 28%),radial-gradient(circle,#0f766e14,#0000 34%),linear-gradient(120deg,#f4efe5,#fbf8f0 45%,#eee6d8);grid-template-rows:minmax(0,1fr) auto;grid-template-columns:minmax(500px,660px) minmax(420px,560px);justify-content:center;align-items:center;gap:22px 48px;min-height:100dvh;padding:28px 44px 24px;display:grid}.login-showcase{background:linear-gradient(90deg,#f4efe5fa,#f4efe5a3),linear-gradient(130deg,#0f766e0d,#1e293b1f);border-radius:30px;grid-template-rows:auto auto 1fr auto;align-content:stretch;justify-items:center;gap:16px;width:100%;height:min(690px,100dvh - 108px);min-height:0;padding:24px;display:grid;position:relative;overflow:hidden;box-shadow:0 30px 80px #332b1f1f}.login-building-photo{object-fit:contain;object-position:center;opacity:.54;filter:saturate(.9)contrast(.96);width:52%;height:auto;position:absolute;top:70px;bottom:92px;right:12px;-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 26% 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 26% 100%)}.login-showcase:after{content:"";background:linear-gradient(#05534b00,#05534bf5 42%);height:128px;position:absolute;bottom:0;left:0;right:0}.login-brand-mark,.login-building-photo,.login-contact-card,.login-founder,.login-tribute{z-index:1;position:relative}.login-brand-mark{text-align:center;color:#3b3429;align-self:start;justify-items:center;display:grid}.login-crest{color:#3b3429;background:#ffffff94;border:2px solid #b28439;border-radius:999px;place-items:center;width:74px;height:74px;font-family:Georgia,serif;font-size:46px;display:grid;box-shadow:0 10px 30px #b2843929}.login-brand-mark h1{letter-spacing:.08em;text-transform:uppercase;margin:10px 0 4px;font-family:Georgia,serif;font-size:clamp(28px,3vw,42px);line-height:1.05}.login-brand-mark p,.login-founder span{color:#6b5d48;margin:0;font-family:Georgia,serif;font-style:italic}.login-contact-card{color:#3b3429;background:#ffffff61;border:1px solid #b2843961;border-radius:12px;justify-self:start;gap:12px;width:min(360px,58%);padding:14px 16px;font-family:Georgia,serif;font-size:14px;display:grid}.login-contact-card div{gap:14px;display:flex}.login-contact-icon{color:#b28439;font-family:inherit;font-weight:800}.login-founder{text-align:center;color:#b28439;align-self:end;justify-items:center;margin-bottom:88px;font-family:Georgia,serif;display:grid}.founder-photo{object-fit:cover;object-position:center top;border:2px solid #b28439b8;border-radius:999px;width:92px;height:92px;margin-bottom:10px;box-shadow:0 16px 34px #332b1f2e}.login-tribute{color:#fff;text-align:center;z-index:2;align-self:end;place-items:center;width:min(620px,100% - 20px);min-height:94px;margin:0;padding:20px 24px;font-family:Georgia,serif;font-size:16px;line-height:1.45;display:grid}.login-tribute em{color:#f3c96d;margin-top:16px;display:block}.login-card{background:#ffffffeb;border:1px solid #fffc;border-radius:20px;justify-self:center;gap:16px;width:min(620px,100%);padding:32px;display:grid;box-shadow:0 28px 70px #332b1f38}.login-card-top{justify-content:space-between;align-items:flex-start;gap:18px;display:flex}.login-building-icon{color:#0f766e;background:#f8faf8;border-radius:999px;place-items:center;width:54px;height:54px;font-size:28px;display:grid;box-shadow:0 10px 24px #0f172a1f}.login-secure-badge{color:#0f4f48;border:1px solid #0f766e59;border-radius:999px;align-items:center;min-height:38px;padding:8px 14px;font-size:13px;display:inline-flex}.login-header{gap:10px;display:grid}.login-header h2{color:#06443e;margin:0;font-family:Georgia,serif;font-size:clamp(32px,3vw,44px);line-height:1.05}.login-divider{background:linear-gradient(90deg,#0000,#b28439,#0000);width:min(320px,100%);height:1px}.login-header p{color:#475569;margin:0;font-size:16px}.login-form{gap:14px;display:grid}.login-form label{color:var(--primary);gap:8px;font-size:14px;font-weight:800;display:grid}.login-input-wrap{background:#fff;border:1px solid #d7dfeb;border-radius:10px;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;min-height:54px;padding:0 14px;display:grid;box-shadow:0 4px 14px #0f172a0a}.login-input-wrap>span{color:#64748b}.login-input-wrap input{min-height:50px;box-shadow:none;border:0;border-radius:0;padding:0}.login-input-wrap button{color:#0f766e;cursor:pointer;font-weight:800}.login-options{color:#0f4f48;justify-content:space-between;align-items:center;gap:14px;font-size:14px;display:flex}.remember-option{align-items:center;grid-template-columns:none!important;gap:10px!important;font-weight:500!important;display:inline-flex!important}.remember-option input{accent-color:#0f766e;width:18px;min-height:18px;box-shadow:none}.login-card .btn-primary{background:linear-gradient(#0f766e,#07554f);min-height:54px;font-size:16px}.login-or{color:#334155;grid-template-columns:1fr auto 1fr;align-items:center;gap:16px;font-size:13px;display:grid}.login-or span{background:#cbd5e1;height:1px}.login-google,.login-trust{color:#172033;background:#fff;border:1px solid #d7dfeb;border-radius:10px;min-height:48px;font-weight:800}.login-trust{color:#0f4f48;background:#0f766e12;place-items:center;font-weight:600;display:grid}.login-dashboard-preview{background:linear-gradient(135deg,#0f766e14,#ffffffc7);border:1px solid #0f766e24;border-radius:16px;grid-template-columns:150px 1fr;gap:12px;padding:12px;display:grid}.login-preview-sidebar{background:#0f172aeb;border-radius:12px;gap:8px;padding:10px;display:grid}.login-preview-sidebar span{color:#ffffffbd;border-radius:10px;padding:8px 10px;font-size:12px;font-weight:800}.login-preview-sidebar .active{color:#0f172a;background:#fff}.login-preview-content{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.preview-card{background:#ffffffc7;border:1px solid #e2e8f0e6;border-radius:14px;align-content:center;gap:8px;min-height:78px;padding:12px;display:grid}.preview-card span{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:800}.preview-card strong{color:#0f4f48;font-size:20px}.login-footer-bar{color:#3b3429;background:#ffffff85;border:1px solid #b2843938;border-radius:18px;flex-wrap:wrap;grid-column:1/-1;justify-content:center;gap:18px;padding:14px 18px;font-size:14px;display:flex;box-shadow:0 10px 30px #332b1f14}.login-page{background:radial-gradient(circle at 0 0,#14b8a61f,#0000 28%),linear-gradient(135deg,#f8fafc 0%,#f3f0e8 52%,#e9eef0 100%);grid-template-rows:minmax(0,1fr) auto;grid-template-columns:minmax(420px,620px) minmax(380px,520px);gap:22px 28px;padding:28px}.login-hero-panel{background:linear-gradient(145deg, #1e293bfa, #0f766edb), var(--primary);border-radius:26px;grid-template-rows:auto minmax(0,1fr) auto;gap:18px;width:100%;height:min(690px,100dvh - 112px);min-height:0;padding:22px;display:grid;overflow:hidden;box-shadow:0 28px 70px #0f172a38}.login-brand-row{color:#fff;align-items:center;gap:16px;display:flex}.login-brand-row .login-crest{color:#f8fafc;background:#ffffff14;border-color:#f59e0bb8;flex:none;width:62px;height:62px}.login-brand-row span{color:#e2e8f0b8;letter-spacing:.14em;text-transform:uppercase;font-size:12px;font-weight:800;display:block}.login-brand-row h1{color:#fff;margin:4px 0;font-size:clamp(28px,3.4vw,42px);line-height:1.06}.login-brand-row p{color:#e2e8f0d1;margin:0}.login-photo-frame{background:#ffffff14;border:1px solid #ffffff29;border-radius:22px;min-height:0;position:relative;overflow:hidden}.login-photo-frame:after{content:"";pointer-events:none;background:linear-gradient(#0f172a0f,#0f172a6b),linear-gradient(90deg,#0f766e2e,#0000 54%);position:absolute;inset:0}.login-photo-frame .login-building-photo{object-fit:contain;object-position:center;opacity:1;filter:none;background:#f8fafc1f;width:100%;height:100%;display:block;position:static;-webkit-mask-image:none;mask-image:none}.login-photo-caption{z-index:1;color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f172ac2;border:1px solid #ffffff24;border-radius:16px;gap:4px;padding:14px 16px;display:grid;position:absolute;bottom:18px;left:18px;right:18px}.login-photo-caption span{color:#fbbf24;letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:800}.login-photo-caption strong{font-size:15px}.login-memorial-card{color:#fff;background:#ffffff1a;border:1px solid #ffffff26;border-radius:20px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:14px;padding:14px;display:grid}.login-memorial-card .founder-photo{border-color:#f59e0bd6;width:82px;height:82px;margin:0}.login-memorial-card strong{color:#fbbf24;margin-bottom:4px;display:block}.login-memorial-card span{color:#f1f5f9e6;font-size:13px;line-height:1.45;display:block}.login-card{background:#fffffff5;border-radius:24px;align-self:center;box-shadow:0 28px 70px #0f172a2e}@media (width<=1080px){.login-page{grid-template-columns:minmax(360px,1fr) minmax(380px,520px);gap:24px;padding:22px}.login-showcase{height:min(650px,100dvh - 96px)}.login-contact-card{width:min(330px,62%)}.login-card{padding:26px}.login-dashboard-preview{grid-template-columns:1fr}.login-preview-sidebar{grid-template-columns:repeat(3,minmax(0,1fr))}.login-preview-sidebar span{text-align:center;padding:8px 6px}.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(132px + 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(8px, env(safe-area-inset-left));right:max(8px, env(safe-area-inset-right));bottom:max(0px, 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:104px;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(96px + env(safe-area-inset-bottom));max-width:none}.maintenance-progress{justify-items:start;width:100%}.maintenance-item{grid-template-columns:auto minmax(0,1fr)}.maintenance-delete{grid-column:2;justify-self:start}.maintenance-add{grid-template-columns:1fr}.login-page{padding:max(16px, env(safe-area-inset-top)) 14px 18px;background:linear-gradient(#f4efe5d1,#f8fafcfa),#f8fafc;grid-template-rows:auto auto auto;grid-template-columns:1fr;align-items:stretch;gap:16px;display:grid}.login-hero-panel{border-radius:22px;gap:14px;height:auto;min-height:0;padding:16px}.login-brand-row{align-items:flex-start}.login-brand-row .login-crest{width:52px;height:52px;font-size:32px}.login-brand-row h1{font-size:26px}.login-brand-row p{font-size:13px}.login-photo-frame{height:260px}.login-photo-caption{padding:10px 12px;bottom:10px;left:10px;right:10px}.login-memorial-card{text-align:center;grid-template-columns:1fr;justify-items:center}.login-memorial-card .founder-photo{width:76px;height:76px}.login-showcase{border-radius:22px;gap:12px;height:auto;min-height:420px;padding:20px 16px}.login-building-photo{opacity:.34;width:52%;height:auto;inset:92px 0 98px auto}.login-showcase:after,.login-contact-card{display:none}.login-founder,.login-tribute{display:grid}.founder-photo{width:82px;height:82px}.login-tribute{background:#05534be6;border-radius:16px;margin-top:0;padding:14px;font-size:14px}.login-crest{width:68px;height:68px;font-size:40px}.login-brand-mark h1{letter-spacing:.04em;font-size:28px}.login-card{border-radius:22px;gap:16px;width:100%;padding:22px 16px}.login-card-top{align-items:center}.login-building-icon{width:52px;height:52px;font-size:28px}.login-secure-badge{min-height:34px;font-size:12px}.login-header h2{font-size:34px}.login-header p{font-size:14px}.login-options{align-items:flex-start;font-size:13px}.login-dashboard-preview{grid-template-columns:1fr}.login-preview-sidebar{grid-template-columns:repeat(3,minmax(0,1fr))}.login-preview-sidebar span{text-align:center;padding:8px 6px}.login-footer-bar{text-align:center;gap:8px;font-size:12px}}.login-exact-page{background:#041f1c;place-items:center;min-height:100dvh;padding:24px;display:grid}.login-exact-frame{aspect-ratio:3/2;background:#041f1c;border-radius:28px;width:clamp(900px,92vw,1320px);max-width:100%;min-height:680px;max-height:calc(100vh - 48px);position:relative;overflow:hidden;box-shadow:0 28px 80px #00000040}.login-exact-image{object-fit:cover;object-position:center;-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:100%;display:block;position:absolute;inset:0}.login-exact-form{font-family:inherit;position:absolute;inset:0}.login-exact-grid{align-items:stretch;height:100%;display:flex}.login-exact-left{background-image:url(/login-page-exact.png);background-position:0;background-repeat:no-repeat;background-size:cover;border-top-left-radius:28px;border-bottom-left-radius:28px;flex:52%;min-width:320px;max-width:760px;display:block;overflow:hidden}.login-exact-right{z-index:10;flex:0 0 420px;justify-content:center;align-items:center;min-width:300px;padding:36px 28px;display:flex}.login-exact-card{width:100%;max-width:420px;color:var(--primary);background:#fff;border-radius:20px;padding:28px;box-shadow:0 20px 40px #02061733}.login-card-header h2{margin:0 0 8px;font-size:26px}.login-sub{color:var(--muted);margin:0 0 18px;font-size:13px}.login-card-body .field{margin-bottom:12px;display:block}.login-card-body .field-label{color:#0f172a;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.login-exact-card .login-exact-email,.login-exact-card .login-exact-password{color:#0f172a;width:100%;min-height:46px;box-shadow:none;background:#fff;border:1px solid #e6eef6;border-radius:12px;padding:12px 14px;position:relative}.password-row{align-items:center;gap:8px;display:flex}.login-exact-show{color:var(--secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 10px;font-weight:700}.login-exact-remember{color:var(--muted);align-items:center;gap:10px;margin:8px 0 18px;font-size:14px;display:flex}.login-exact-submit{color:#fff;cursor:pointer;background:#064f46;border:none;border-radius:12px;width:100%;padding:12px 16px;font-weight:800}@media (width<=900px){.login-exact-frame{aspect-ratio:4/5;width:min(100vw,760px);max-height:none}.login-exact-left{min-width:360px}}@media (width<=700px){.login-exact-grid{flex-direction:column;gap:12px}.login-exact-left{display:none}.login-exact-right{width:100%;padding:18px}}.login-exact-email,.login-exact-password{width:35%;height:6.5%;min-height:0;box-shadow:none;color:#0f172a;background:0 0;border:0;border-radius:0;padding:0 4.3%;font-size:clamp(12px,1.05vw,16px);font-weight:600;position:absolute;left:59.8%}.login-exact-email{top:32.8%}.login-exact-password{width:31%;padding-right:1%;top:45.8%}.login-exact-email:focus,.login-exact-password:focus{outline-offset:-2px;box-shadow:none;outline:2px solid #0f766e4d}.login-exact-show{color:#064f46;cursor:pointer;width:auto;padding:0 8px;font-size:clamp(11px,.95vw,15px);font-weight:800;position:absolute;top:46.9%;left:91%}.login-exact-remember{color:#12312e;cursor:pointer;align-items:center;gap:.7vw;font-size:clamp(11px,.98vw,15px);display:flex;position:absolute;top:54%;left:59.8%}.login-exact-remember input{accent-color:#0f766e;width:clamp(14px,1.35vw,20px);min-height:clamp(14px,1.35vw,20px);box-shadow:none}.login-exact-submit{color:#fff;cursor:pointer;background:#064f46;border-radius:.9vw;width:35%;height:6.1%;font-size:clamp(13px,1.15vw,18px);font-weight:800;position:absolute;top:60.5%;left:59.8%}.login-exact-submit:disabled{opacity:.7}@media (width<=900px){.login-exact-frame{aspect-ratio:4/5;width:min(100vw,760px);max-height:none}}@media (width<=700px){.login-exact-frame{aspect-ratio:auto;width:min(100vw,520px);max-height:none}.login-exact-image{display:none}.login-exact-form{background:#fff;border-radius:24px;gap:14px;height:auto;min-height:100%;padding:24px 20px;display:grid;position:relative;inset:auto}.login-exact-email,.login-exact-password,.login-exact-submit{color:#0f172a;background:#fff;border:1px solid #d7dfeb;border-radius:16px;width:100%;height:auto;min-height:46px;padding:12px 14px;position:relative;top:auto;left:auto}.login-exact-password{width:100%;padding-right:14px}.login-exact-show{background:#0f172a0d;border-radius:999px;align-self:flex-end;width:auto;height:auto;padding:10px 14px;position:relative;top:auto;left:auto}.login-exact-remember{color:#0f172a;justify-self:start;gap:10px;padding:0;font-size:14px;position:relative;top:auto;left:auto}.login-exact-submit{color:#fff;background:#064f46;border-radius:16px;padding:14px;font-size:15px}}@media (aspect-ratio<=3/2){.login-exact-frame{width:100vw;height:auto}}
