:root{--color-primary:#0f766e;--color-primary-hover:#0d6460;--color-primary-light:#14b8a6;--color-primary-muted:#ccfbf1;--color-primary-bg:#f0fdfa;--color-surface:#fff;--color-bg:#f1f5f9;--color-sidebar:#0c1e2e;--color-sidebar-hover:#ffffff17;--color-sidebar-active:#14b8a629;--color-text:#0f172a;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--color-label:#334155;--color-border:#e2e8f0;--color-border-subtle:#f1f5f9;--shadow-sm:0 1px 3px #0f172a0f, 0 1px 2px #0f172a0a;--shadow-md:0 4px 12px #0f172a14, 0 2px 4px #0f172a0a;--shadow-lg:0 10px 30px #0f172a1a, 0 4px 8px #0f172a0d;--shadow-xl:0 24px 64px #0f172a33, 0 8px 16px #0f172a14;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-pill:999px;--transition:.15s ease;color:var(--color-text);background:var(--color-bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;font-family:Sarabun,ui-sans-serif,system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.6}:root[data-theme=dark]{--color-primary:#2dd4bf;--color-primary-hover:#5eead4;--color-primary-light:#5eead4;--color-primary-muted:#2dd4bf2e;--color-primary-bg:#14b8a61f;--color-surface:#111827;--color-bg:#07111f;--color-sidebar:#050c16;--color-sidebar-hover:#ffffff14;--color-sidebar-active:#2dd4bf29;--color-text:#e5eefb;--color-text-secondary:#9fb0c7;--color-text-muted:#718198;--color-label:#cbd5e1;--color-border:#263449;--color-border-subtle:#172235;--shadow-sm:0 1px 3px #00000038, 0 1px 2px #00000029;--shadow-md:0 4px 12px #00000047, 0 2px 4px #0000002e;--shadow-lg:0 10px 30px #00000052, 0 4px 8px #00000038;--shadow-xl:0 24px 64px #00000073, 0 8px 16px #00000047}*,:before,:after{box-sizing:border-box}body{background:var(--color-bg);margin:0;overflow-x:hidden}button,input,select,textarea{font:inherit}button:focus-visible,a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}.auth-page{color:#f8fafc;background:linear-gradient(135deg,#071423f2 0%,#0c2837cc 100%),url(https://images.unsplash.com/photo-1494526585095-c41746248156?auto=format&fit=crop&w=1600&q=80) 50%/cover;grid-template-columns:minmax(0,1.1fr) minmax(360px,440px);min-height:100svh;display:grid}.auth-theme-toggle{top:calc(18px + env(safe-area-inset-top,0px));right:calc(18px + env(safe-area-inset-right,0px));z-index:20;color:#f8fafc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;background:#0f172a85;border:1px solid #ffffff2e;border-radius:999px;align-items:center;gap:7px;min-height:38px;padding:0 12px;display:inline-flex;position:fixed;box-shadow:0 10px 30px #0000003d}.auth-hero{flex-direction:column;justify-content:center;max-width:760px;padding:64px;display:flex}.auth-hero h1,.workspace h1{color:inherit;margin:0}.auth-hero h1{letter-spacing:-.02em;max-width:720px;font-size:clamp(2.2rem,5vw,4.5rem);font-weight:800;line-height:1.05}.auth-hero p{color:#f8fafcb8;max-width:580px;margin-top:20px;font-size:1.05rem;line-height:1.75}.auth-cta-row{flex-wrap:wrap;gap:12px;margin-top:28px;display:flex}.hero-primary-button,.hero-secondary-button{min-height:46px;font:inherit;cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:0 18px;font-weight:800;display:inline-flex}.hero-primary-button{color:#08312d;background:#5eead4;border:0;box-shadow:0 16px 34px #14b8a640}.hero-secondary-button{color:#f8fafc;background:#ffffff14;border:1px solid #ffffff47}.hero-actions{flex-wrap:wrap;gap:10px;margin-top:36px;display:flex}.hero-actions span{border-radius:var(--radius-pill);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff12;border:1px solid #fff3;align-items:center;gap:8px;padding:9px 16px;font-size:.88rem;font-weight:600;display:inline-flex}.brand{color:inherit;align-items:center;gap:12px;text-decoration:none;display:inline-flex}.brand.large{margin-bottom:52px}.brand strong,.brand small{display:block}.brand strong{font-size:1.05rem;font-weight:800;line-height:1.2}.brand small{color:currentColor;opacity:.55;margin-top:2px;font-size:.75rem;font-weight:400}.brand-mark{color:#fff;background:linear-gradient(145deg,#2dd4bf 0%,#0f766e 60%,#0c5f58 100%);border-radius:12px;flex-shrink:0;place-items:center;width:44px;height:44px;display:grid;box-shadow:0 4px 16px #0f766e80,inset 0 1px #ffffff26}.auth-card{color:var(--color-text);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff7;border:1px solid #e2e8f080;border-radius:18px;align-self:center;margin:32px 48px 32px 0;padding:34px;box-shadow:0 32px 80px #07142359,0 8px 24px #07142326}.auth-card-header,.panel-header,.topbar{justify-content:space-between;align-items:center;gap:16px;display:flex}.auth-card-header{justify-content:flex-start;gap:14px;margin-bottom:28px}.auth-icon{width:50px;height:50px;color:var(--color-primary);background:var(--color-primary-bg);border-radius:12px;flex-shrink:0;place-items:center;display:grid}.eyebrow{color:var(--color-primary);letter-spacing:.1em;text-transform:uppercase;margin:0 0 4px;font-size:.7rem;font-weight:800}.auth-card h2,.panel h2,.tenant-link-panel h2{color:var(--color-text);margin:0;font-size:1.2rem;font-weight:800}form{gap:16px;display:grid}label{color:var(--color-label);gap:6px;font-size:.88rem;font-weight:700;display:grid}input,select,textarea{box-sizing:border-box;width:100%;min-width:0;color:var(--color-text);font:inherit;transition:border-color var(--transition), box-shadow var(--transition), background var(--transition);background:#fafbfc;border:1.5px solid #dde3ed;border-radius:8px;padding:11px 13px}textarea{resize:vertical}input::placeholder,select::placeholder,textarea::placeholder{color:var(--color-text-muted)}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);background:#fff;outline:none;box-shadow:0 0 0 3px #0f766e1a}input:hover:not(:focus),select:hover:not(:focus),textarea:hover:not(:focus){background:#fff;border-color:#a0aec0}.primary-button,.ghost-button,.small-button,.icon-button,.icon-only,.auth-switch button{font:inherit;cursor:pointer;transition:background var(--transition), box-shadow var(--transition), transform .1s ease;border:0;border-radius:8px;justify-content:center;align-items:center;gap:7px;font-weight:700;display:inline-flex}.primary-button{color:#fff;background:linear-gradient(135deg,#14b8a6 0%,#0f766e 100%);min-height:46px;margin-top:6px;padding:0 22px;box-shadow:0 3px 12px #0f766e59,inset 0 1px #ffffff26}.primary-button:hover:not(:disabled){background:linear-gradient(135deg,#0d9488 0%,#0c6b63 100%);transform:translateY(-1px);box-shadow:0 5px 20px #0f766e80}.ghost-button{color:#475569;background:#fff;border:1.5px solid #dbe3ee;min-height:46px;padding:0 18px}.ghost-button:hover{background:#f8fafc;border-color:#94a3b8}.primary-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #0f766e4d}.qr-modal{text-align:center;max-width:320px}.qr-modal-header{text-align:left;justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.qr-modal-header strong{font-size:1.1rem}.qr-modal-body{flex-direction:column;align-items:center;gap:14px;display:flex}.qr-modal-body svg{background:#fff;border-radius:10px;padding:10px;box-shadow:0 2px 12px #0000001a}.qr-instruction{color:var(--text-secondary);margin:0;font-size:.82rem;line-height:1.5}.qr-actions{flex-wrap:wrap;gap:8px;width:100%;display:flex}.qr-actions>*{flex:1;justify-content:center;min-height:38px;font-size:.85rem;text-decoration:none}.btn-line{color:#fff;font:inherit;cursor:pointer;transition:background var(--transition);background:#06c755;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-line:hover{background:#05b34c}.line-toast{z-index:1000;white-space:nowrap;border-radius:10px;align-items:center;gap:8px;padding:12px 20px;font-size:.9rem;font-weight:600;animation:.2s toast-in;display:flex;position:fixed;bottom:80px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #0003}.line-toast.ok{color:#fff;background:#06c755}.line-toast.err{color:#fff;background:#dc2626}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.line-integration-section{color:var(--color-text);border:1px solid var(--color-border);background:#f8fafcb8;border-radius:12px;flex-direction:column;gap:12px;margin-top:20px;padding:16px;display:flex}.line-integration-header{align-items:center;gap:10px;min-width:0;display:flex}.line-integration-header .line-icon{color:#06c755;flex-shrink:0}.line-integration-header>div{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.line-integration-header strong{color:var(--color-text);font-size:.9rem}.line-integration-header span{color:var(--color-text-secondary);overflow-wrap:anywhere;font-size:.78rem}.line-status-badge{color:var(--color-text-secondary);white-space:nowrap;background:#0f172a0f;border-radius:20px;padding:3px 10px;font-size:.75rem}.line-status-badge.active{color:#059652;background:#06c7551f}.line-linked-chip,.line-unlinked-chip{vertical-align:middle;white-space:nowrap;border-radius:10px;align-items:center;gap:3px;margin-left:4px;padding:1px 6px;font-size:.68rem;font-weight:500;display:inline-flex}.line-linked-chip{color:#059652;background:#06c7551f}.line-unlinked-chip{color:var(--text-secondary);background:#64748b14}.line-status-row{min-width:0;color:var(--color-text-secondary);background:var(--color-border-subtle);border-radius:8px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.82rem;display:flex}.line-token-form{flex-direction:column;gap:10px;min-width:0;display:flex}.line-token-form label{flex-direction:column;gap:5px;min-width:0;font-size:.82rem;font-weight:500;display:flex}.label-optional{color:var(--color-text-secondary);font-weight:400}.line-webhook-info{background:var(--color-border-subtle);border-radius:8px;padding:10px 12px;font-size:.78rem}.line-webhook-info p{color:var(--color-text-secondary);margin-bottom:4px}.line-webhook-info code{word-break:break-all;color:var(--color-text);font-family:monospace;font-size:.72rem;display:block}.form-success{color:#059652;font-size:.83rem}.mini-button.line-btn{color:#06c755;border-color:#06c7554d}.mini-button.line-btn:hover{background:#06c75514}.mini-button.line-btn.sent{color:#059652;background:#06c7551a}.danger-zone{background:#fff5f5;border:1.5px solid #fecaca;border-radius:10px;justify-content:space-between;align-items:flex-start;gap:16px;margin-top:24px;padding:16px;display:flex}.danger-zone-title{color:#dc2626;text-transform:uppercase;letter-spacing:.08em;margin:0 0 4px;font-size:.72rem;font-weight:800}.danger-zone-desc{color:#64748b;margin:0;font-size:.82rem}.delete-confirm-box{gap:10px;min-width:260px;display:grid}.delete-confirm-box p{color:#64748b;margin:0;font-size:.85rem}.delete-confirm-actions{flex-wrap:wrap;gap:8px;display:flex}.primary-button:disabled{cursor:wait;opacity:.6;transform:none}.auth-switch{justify-content:space-between;gap:12px;margin-top:16px;display:flex}.auth-switch button{color:var(--color-primary);text-underline-offset:3px;transition:text-decoration-color var(--transition), color var(--transition);background:0 0;padding:4px 0;font-size:.9rem;font-weight:600;-webkit-text-decoration:underline #0000;text-decoration:underline #0000}.auth-switch button:hover{-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary);color:var(--color-primary-hover)}.form-error,.form-message,.setup-note{border-radius:8px;margin:0;padding:10px 13px;font-size:.88rem;line-height:1.55}.form-error{color:#991b1b;background:#fff1f2;border:1px solid #fecaca}.form-message{color:#14532d;background:#f0fdf4;border:1px solid #bbf7d0}.setup-note{color:#4a5568;background:#f7f9fc;border:1px solid #e2e8f0;align-items:flex-start;gap:9px;margin-top:20px;font-size:.83rem;display:flex}.app-shell{min-height:100svh;color:var(--color-text);background:#f0f4f8;grid-template-columns:256px minmax(0,1fr);display:grid}.sidebar{color:#fff;background:linear-gradient(170deg,#0d2137 0%,#0a1a2b 60%,#091623 100%);border-right:1px solid #ffffff0a;flex-direction:column;gap:8px;height:100svh;padding:20px 12px;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar .brand{border-bottom:1px solid #ffffff12;margin-bottom:4px;padding:6px 8px 16px}.dorm-switcher{border-bottom:1px solid #ffffff12;gap:2px;margin-bottom:4px;padding-bottom:10px;display:grid}.dorm-switcher-item{color:#fff9;font:inherit;cursor:pointer;text-align:left;transition:color var(--transition), background var(--transition);background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:.88rem;font-weight:500;display:flex}.dorm-switcher-item span{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.dorm-switcher-item.active{color:#fff;background:#2dd4bf26;font-weight:700}.dorm-switcher-item:hover:not(.active){color:#ffffffe0;background:#ffffff0f}.dorm-switcher-item.add{color:#2dd4bfb3;margin-top:2px;font-size:.82rem}.dorm-switcher-item.add:hover{color:#2dd4bf;background:#2dd4bf14}.dorm-switcher-row{align-items:center;gap:2px;display:flex}.dorm-switcher-row .dorm-switcher-item{flex:1;min-width:0}.dorm-delete-btn{color:#ffffff40;cursor:pointer;width:28px;height:28px;transition:color var(--transition), background var(--transition);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.dorm-delete-btn:hover{color:#f87171;background:#f871711f}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999;background:#0000008c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;width:100%;max-width:400px;padding:24px;box-shadow:0 20px 60px #0000004d}.btn-danger{color:#fff;font:inherit;cursor:pointer;transition:background var(--transition);background:#dc2626;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-size:.9rem;font-weight:600;display:inline-flex}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.45;cursor:not-allowed}.btn-outline{border:1px solid var(--border);color:var(--text-secondary);font:inherit;cursor:pointer;transition:background var(--transition), color var(--transition);background:0 0;border-radius:8px;align-items:center;gap:6px;padding:9px 18px;font-size:.9rem;font-weight:500;display:inline-flex}.btn-outline:hover{background:var(--bg-hover,#0000000d);color:var(--text-primary)}.nav-label{color:#ffffff4d;letter-spacing:.1em;text-transform:uppercase;margin:12px 0 4px;padding:0 10px;font-size:.68rem;font-weight:800}.nav-list{gap:2px;display:grid}.nav-list a{color:#fff9;transition:color var(--transition), background var(--transition);border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:.92rem;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-list a:before{content:"";opacity:0;width:3px;transition:opacity var(--transition);background:#2dd4bf;border-radius:0 3px 3px 0;position:absolute;top:8px;bottom:8px;left:0}.nav-list a.active{color:#fff;background:#2dd4bf1f;font-weight:700}.nav-list a.active:before{opacity:1}.nav-list a:hover:not(.active){color:#ffffffe0;background:#ffffff0f}.account-box{color:#ffffff80;background:#ffffff0a;border:1px solid #ffffff0f;border-radius:8px;align-items:center;gap:10px;min-width:0;margin-top:auto;padding:10px 12px;font-size:.82rem;display:flex}.account-box span{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.workspace{background:radial-gradient(80% 50% at 50% -20%,#0f766e0f 0%,#0000 70%),#f0f4f8;min-width:0;padding:0 28px 36px}.workspace[data-active-section=rooms] .metric-grid,.workspace[data-active-section=rooms] .dorm-settings-summary,.workspace[data-active-section=rooms] .dorm-settings-edit,.workspace[data-active-section=rooms] #billing,.workspace[data-active-section=rooms] .report-panel,.workspace[data-active-section=rooms] .tenant-link-panel,.workspace[data-active-section=meter] .metric-grid,.workspace[data-active-section=meter] .dorm-settings-summary,.workspace[data-active-section=meter] .dorm-settings-edit,.workspace[data-active-section=meter] #rooms,.workspace[data-active-section=meter] .report-panel,.workspace[data-active-section=meter] .tenant-link-panel,.workspace[data-active-section=billing] .metric-grid,.workspace[data-active-section=billing] .dorm-settings-summary,.workspace[data-active-section=billing] .dorm-settings-edit,.workspace[data-active-section=billing] #rooms,.workspace[data-active-section=billing] .report-panel,.workspace[data-active-section=reports] .metric-grid,.workspace[data-active-section=reports] .dorm-settings-summary,.workspace[data-active-section=reports] .dorm-settings-edit,.workspace[data-active-section=reports] .content-grid,.workspace[data-active-section=reports] .tenant-link-panel,.workspace[data-active-section=settings] .metric-grid,.workspace[data-active-section=settings] .content-grid,.workspace[data-active-section=settings] .report-panel,.workspace[data-active-section=settings] .tenant-link-panel,.workspace[data-active-section=dashboard] .dorm-settings-summary,.workspace[data-active-section=dashboard] .dorm-settings-edit,.workspace[data-active-section=dashboard] .report-panel,.workspace[data-active-section=meter] .invoice-tools,.workspace[data-active-section=meter] .invoice-list{display:none}.topbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffd9;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;gap:16px;margin:0 -28px 28px;padding:16px 28px;display:flex;box-shadow:0 1px 8px #0f172a0f}.topbar h1{letter-spacing:-.025em;color:var(--color-text);margin:0;font-size:1.5rem;font-weight:800;line-height:1.2}.topbar-actions{align-items:center;gap:10px;display:flex}.month-filter{min-width:160px;color:var(--color-label);gap:4px;font-size:.72rem;font-weight:800;display:grid}.month-filter input{background:#fff;min-height:40px;padding:0 12px}.icon-button,.small-button{color:var(--color-text);background:#fff;border:1.5px solid #dde3ed;border-radius:8px;padding:9px 14px;font-size:.88rem;font-weight:600;box-shadow:0 1px 3px #0f172a0f}.icon-button:hover,.small-button:hover{background:#f8fafc;border-color:#94a3b8;transform:translateY(-1px);box-shadow:0 3px 10px #0f172a1a}.small-button.active{color:#0f766e;background:#ccfbf1;border-color:#14b8a6}.icon-button.compact{width:38px;height:38px;padding:0}.mini-button{color:var(--color-text);font:inherit;cursor:pointer;transition:all var(--transition);background:#fff;border:1.5px solid #dde3ed;border-radius:6px;align-items:center;gap:5px;padding:4px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.mini-button:hover{border-color:#94a3b8;box-shadow:0 2px 6px #0f172a14}.mini-button.success{color:#065f46;background:#f0fdf4;border-color:#6ee7b7}.mini-button.success:hover{background:#d1fae5;border-color:#34d399}.mini-button.danger{color:#b91c1c;background:#fff1f2;border-color:#fecaca}.mini-button.danger:hover{background:#ffe4e6;border-color:#fca5a5}.extra-charge-section{border:1px solid var(--color-border);border-radius:var(--radius-md);background:#fff;grid-column:1/-1;gap:10px;padding:12px;display:grid}.extra-charge-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.extra-charge-header strong{font-size:.92rem}.extra-charge-list{gap:8px;display:grid}.extra-charge-row{grid-template-columns:minmax(0,1.3fr) minmax(120px,.7fr) auto;gap:8px;display:grid}.field-hint{color:var(--color-text-secondary);margin:0;font-size:.84rem}.tenant-history{border-top:1px solid var(--color-border);margin-top:12px;padding-top:12px}.tenant-history summary{cursor:pointer;color:var(--color-text);justify-content:space-between;align-items:center;gap:10px;font-weight:700;list-style:none;display:flex}.tenant-history summary::-webkit-details-marker{display:none}.tenant-history summary strong{color:var(--color-text-secondary);font-size:.8rem}.tenant-history-list{gap:6px;margin-top:10px;display:grid}.tenant-history-row{border:1px solid var(--color-border);color:var(--color-text-secondary);background:#fff;border-radius:10px;grid-template-columns:minmax(0,1.3fr) minmax(80px,.7fr) minmax(110px,.8fr);align-items:center;gap:8px;padding:8px 10px;font-size:.84rem;display:grid}.tenant-history-row strong{color:var(--color-text)}.metric-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:18px;margin-bottom:22px;display:grid}.metric{background:#fff;border:1px solid #fffc;border-radius:16px;flex-direction:column;gap:10px;padding:22px 24px;transition:box-shadow .2s,transform .2s;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #0f172a0f,0 1px 3px #0f172a0a}.metric:after{content:"";height:4px;position:absolute;top:0;left:0;right:0}.metric:first-child:after{background:linear-gradient(90deg,#0f766e,#2dd4bf)}.metric:nth-child(2):after{background:linear-gradient(90deg,#1d4ed8,#60a5fa)}.metric:nth-child(3):after{background:linear-gradient(90deg,#d97706,#fbbf24)}.metric:nth-child(4):after{background:linear-gradient(90deg,#be123c,#fb7185)}.metric:nth-child(5):after{background:linear-gradient(90deg,#15803d,#4ade80)}.metric:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0f172a1a,0 3px 8px #0f172a0f}.metric-icon{border-radius:12px;place-items:center;width:46px;height:46px;display:grid}.metric-icon.teal{color:#0f766e;background:linear-gradient(135deg,#ccfbf1,#99f6e4)}.metric-icon.blue{color:#1d4ed8;background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.metric-icon.amber{color:#b45309;background:linear-gradient(135deg,#fef3c7,#fde68a)}.metric-icon.rose{color:#be123c;background:linear-gradient(135deg,#ffe4e6,#fecdd3)}.metric-icon.green{color:#15803d;background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.metric-body{flex-direction:column;gap:4px;display:flex}.metric span{color:#64748b;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:700}.metric strong{letter-spacing:-.03em;color:#0f172a;font-size:1.9rem;font-weight:800;line-height:1}.onboarding-panel{background:linear-gradient(135deg,#f0fdfaf5,#fffffffa);border:1px solid #0f766e2e;border-radius:16px;grid-template-columns:minmax(220px,.6fr) minmax(0,1.4fr);gap:18px;margin-bottom:22px;padding:22px;display:grid;box-shadow:0 2px 8px #0f172a0f,0 1px 3px #0f172a0a}.onboarding-copy h2{color:var(--color-text);margin:0;font-size:1.35rem;font-weight:800}.onboarding-copy p:not(.eyebrow){color:var(--color-text-secondary);margin:8px 0 0;line-height:1.55}.onboarding-steps{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;display:grid}.onboarding-step{background:#fff;border:1px solid #dbe3ee;border-radius:12px;align-content:start;gap:10px;min-height:190px;padding:14px;display:grid}.step-number{color:#0f766e;background:#ccfbf1;border-radius:10px;place-items:center;width:34px;height:34px;font-weight:800;display:grid}.onboarding-step.done .step-number{color:#166534;background:#dcfce7}.step-content{gap:4px;display:grid}.step-content strong{color:var(--color-text);font-size:1rem}.step-content span{color:var(--color-text-secondary);font-size:.86rem;line-height:1.5}.onboarding-step .small-button{width:100%;margin-top:auto}.content-grid{grid-template-columns:minmax(0,1.3fr) minmax(300px,.7fr);gap:18px;display:grid}.panel{background:#fff;border:1px solid #e2e8f0cc;border-radius:16px;padding:24px;box-shadow:0 2px 8px #0f172a0f,0 1px 3px #0f172a0a}.panel-header{border-bottom:1px solid #f1f5f9;margin-bottom:4px;padding-bottom:16px}.panel-header h2{color:#0f172a;margin:0;font-size:1rem;font-weight:800}.panel-header .eyebrow{font-size:.65rem}.panel-actions{flex-shrink:0;gap:8px;display:flex}.setup-panel{background:#fff;border:1px solid #e2e8f0cc;border-radius:16px;grid-template-columns:minmax(0,.9fr) minmax(340px,1.1fr);gap:32px;max-width:960px;padding:32px;display:grid;box-shadow:0 2px 8px #0f172a0f}.setup-copy{align-self:start;padding-top:4px}.setup-copy h2{color:var(--color-text);letter-spacing:-.025em;margin:0;font-size:1.5rem;font-weight:800}.setup-copy p:not(.eyebrow){color:var(--color-text-secondary);margin:10px 0 0;line-height:1.65}.setup-form{gap:14px}.dorm-settings-panel{max-width:none;margin-bottom:20px}.dorm-settings-edit{background:#fff;border:1px solid #e2e8f0cc;border-radius:16px;gap:16px;min-width:0;margin-bottom:20px;padding:20px 24px;display:grid;box-shadow:0 2px 8px #0f172a0f}.dorm-settings-edit-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:12px;padding-bottom:14px;display:flex}.dorm-settings-edit-header strong{color:var(--color-text);font-size:1rem;font-weight:700;display:block}.dorm-settings-form{grid-template-columns:1fr 1fr;gap:12px;min-width:0;display:grid}.dorm-settings-form label{min-width:0}.dorm-settings-summary{box-shadow:var(--shadow-sm);background:#fff;border:1px solid #e2e8f0e6;border-radius:12px;justify-content:space-between;align-items:center;gap:14px;margin-bottom:20px;padding:14px 16px;display:flex}.dorm-settings-summary div{gap:2px;min-width:0;display:grid}.dorm-settings-summary strong{color:var(--color-text)}.dorm-settings-summary span{color:var(--color-text-secondary);font-size:.86rem}.filter-summary{color:var(--color-text-secondary);margin:8px 0 0;font-size:.82rem}.room-form,.tenant-form,.move-out-form,.edit-room-form,.edit-tenant-form,.utility-form{background:#f8fafc;border:2px dashed #e2e8f0;border-radius:12px;align-items:end;gap:12px;margin-top:16px;padding:18px}.room-form{grid-template-columns:repeat(3,minmax(0,1fr)) auto}.tenant-form,.move-out-form,.edit-room-form,.edit-tenant-form,.utility-form{grid-template-columns:repeat(3,minmax(0,1fr))}.room-form .primary-button{min-width:120px;margin-top:0}.tenant-form .primary-button,.move-out-form .primary-button,.edit-room-form .primary-button,.edit-tenant-form .primary-button,.utility-form .primary-button{margin-top:0}.room-form .form-error,.tenant-form .form-error,.move-out-form .form-error,.edit-room-form .form-error,.edit-tenant-form .form-error,.utility-form .form-error,.tenant-form .form-message,.move-out-form .form-message,.utility-form .form-message{grid-column:1/-1}.bulk-meter-form{background:#f8fafc;border:2px dashed #ccfbf1;border-radius:12px;gap:14px;margin-top:16px;padding:16px;display:grid}.bulk-meter-header{grid-template-columns:minmax(180px,.35fr) minmax(0,1fr);align-items:end;gap:12px;display:grid}.bulk-meter-header div{gap:2px;display:grid}.bulk-meter-header span{color:var(--color-text-secondary);font-size:.82rem}.bulk-meter-list{gap:8px;display:grid}.bulk-meter-row{border:1px solid var(--color-border);background:#fff;border-radius:10px;grid-template-columns:minmax(120px,1fr) repeat(2,minmax(140px,.75fr)) minmax(96px,.5fr) minmax(108px,.5fr);align-items:center;gap:8px;padding:10px;display:grid}.bulk-meter-room,.bulk-meter-input{gap:4px;display:grid}.bulk-meter-row span{color:var(--color-text-secondary);font-size:.76rem}.bulk-meter-input small{color:var(--color-text-secondary);font-size:.72rem}.bulk-meter-row input{min-height:40px}.bulk-meter-form>.primary-button{background:linear-gradient(135deg,#10b981 0%,#0f766e 100%);box-shadow:0 8px 18px #10b98140}.bulk-meter-form>.primary-button:hover:not(:disabled){background:linear-gradient(135deg,#059669 0%,#0f766e 100%);box-shadow:0 10px 24px #10b98159}.bulk-meter-save-button{color:#fff;font:inherit;cursor:pointer;min-height:40px;transition:background var(--transition), box-shadow var(--transition), transform .1s ease;background:linear-gradient(135deg,#38bdf8 0%,#2563eb 100%);border:0;border-radius:8px;justify-content:center;align-items:center;gap:7px;padding-inline:10px;font-weight:800;display:inline-flex;box-shadow:0 6px 16px #2563eb38}.bulk-meter-save-button:hover:not(:disabled){background:linear-gradient(135deg,#0ea5e9 0%,#1d4ed8 100%);transform:translateY(-1px);box-shadow:0 9px 22px #2563eb52}.bulk-meter-save-button:disabled{color:#94a3b8;box-shadow:none;cursor:not-allowed;background:#e2e8f0}.move-out-summary{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;grid-column:1/-1;gap:8px;padding:14px 16px;display:grid}.move-out-summary-title{color:var(--color-label);text-transform:uppercase;letter-spacing:.06em;margin:0 0 4px;font-size:.78rem;font-weight:800}.move-out-deductions{background:var(--bg-subtle,#00000005);border:1px dashed var(--border);border-radius:8px;flex-direction:column;gap:6px;margin-bottom:4px;padding:10px 12px;display:flex}.move-out-deductions-header{color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:.78rem;font-weight:700;display:flex}.move-out-deduction-row{align-items:center;gap:6px;display:flex}.move-out-deduction-row input{flex:1;min-height:36px;padding:0 10px;font-size:.85rem}.move-out-deduction-row input:last-of-type{flex:0 0 100px}.move-out-deduction-row .icon-button.danger{border-radius:7px;flex-shrink:0;width:32px;height:32px;padding:0}.move-out-invoice-note{color:#b45309;background:#fbbf241f;border:1px solid #fbbf244d;border-radius:6px;margin-bottom:6px;padding:5px 10px;font-size:.78rem}.move-out-summary-row{color:var(--color-text);justify-content:space-between;align-items:center;font-size:.88rem;display:flex}.move-out-summary-row span{color:#64748b}.move-out-summary-row.total{border-top:1px solid #e2e8f0;margin-top:2px;padding-top:8px;font-weight:700}.move-out-summary-row.total strong{font-size:1rem}.move-out-summary-row.deposit strong{color:#0f766e}.move-out-summary-row.result{border-top:1.5px dashed #cbd5e1;margin-top:2px;padding-top:8px;font-weight:700}.move-out-summary-row.result.refund strong{color:#059669;font-size:1.05rem}.move-out-summary-row.result.extra strong{color:#dc2626;font-size:1.05rem}.move-out-summary-actions{flex-wrap:wrap;gap:8px;padding-top:4px;display:flex}.move-out-result{border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;font-size:.9rem;font-weight:600;display:flex}.move-out-result p{margin:0}.move-out-result.refund{color:#065f46;background:#f0fdf4;border:1.5px solid #6ee7b7}.move-out-result.extra{color:#9a3412;background:#fff7ed;border:1.5px solid #fed7aa}.edit-room-actions{align-items:center;gap:10px;display:flex}.meter-baseline{grid-column:1/-1;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.meter-baseline div{background:#eff6ff;border:1px solid #dbeafe;border-radius:10px;gap:2px;padding:10px 12px;display:grid}.meter-baseline span,.meter-baseline small{color:#64748b;font-size:.76rem}.meter-baseline strong{color:#0f172a;font-size:1.05rem}.meter-estimate{grid-column:1/-1;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.meter-estimate div{background:#f0fdfa;border:1px solid #ccfbf1;border-radius:10px;gap:2px;padding:10px 12px;display:grid}.meter-estimate span,.meter-estimate small,.room-rate-note{color:#64748b;font-size:.76rem}.meter-estimate strong{color:#0f172a;font-size:1.02rem}.room-row-wrap{border-bottom:1px solid #f1f5f9}.room-row-wrap:last-child,.room-row-wrap .room-row{border-bottom:none}.room-inline-form{background:#f8fafc;border-top:1px dashed #e2e8f0;border-radius:0 0 8px 8px;padding:14px 10px 16px}.room-rate-note{margin-top:3px;display:block}.room-invoice-chips{flex-wrap:wrap;gap:5px;margin-top:5px;display:flex}.room-inv-chip{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:7px;flex-direction:column;gap:1px;padding:4px 8px;font-size:.72rem;line-height:1.3;display:inline-flex}.room-inv-chip span{color:#64748b;font-size:.68rem}.room-inv-chip strong{color:#0f172a;font-size:.82rem;font-weight:700}.room-inv-chip small{color:#94a3b8;font-size:.65rem}:root[data-theme=dark] .room-inv-chip{background:#ffffff0f;border-color:#ffffff1a}:root[data-theme=dark] .room-inv-chip strong{color:#f1f5f9}.room-due-amount{color:#92400e;background:#fef3c7;border-radius:4px;margin-left:6px;padding:1px 7px;font-size:.72rem;font-weight:700;display:inline-block}.room-table{gap:0;margin-top:8px;display:grid}.room-tools{grid-template-columns:minmax(0,1fr) 170px;gap:10px;margin-top:14px;margin-bottom:10px;display:grid}.room-row{border-bottom:1px solid #f1f5f9;border-radius:8px;grid-template-columns:56px minmax(0,1fr) 100px auto;align-items:center;gap:8px;padding:13px 6px;transition:background .12s;display:grid}.room-row:last-child{border-bottom:none}.room-row:hover{background:#f8fafc}.room-row strong{color:#065f46;background:linear-gradient(135deg,#ccfbf1,#a7f3d0);border-radius:8px;justify-content:center;align-items:center;min-width:46px;height:34px;padding:0 8px;font-size:.88rem;font-weight:800;display:inline-flex}.room-row span{color:#64748b;font-size:.88rem}.room-row-actions{justify-self:end;gap:6px;display:flex}.room-row .icon-button{justify-self:end}.icon-button.danger{color:#991b1b;background:#fff1f2;border-color:#fecaca}.icon-button.danger:hover{background:#ffe4e6;border-color:#fca5a5}.status{letter-spacing:.01em;border-radius:999px;justify-self:start;padding:4px 10px;font-size:.76rem;font-weight:800}.status.available{color:#065f46;background:#d1fae5}.status.occupied{color:#1e3a5f;background:#dbeafe}.status.due{color:#78350f;background:#fef3c7}.status.moving{color:#881337;background:#ffe4e6}.invoice-list{gap:8px;margin-top:12px;display:grid}.invoice-tools{grid-template-columns:minmax(0,1fr) 170px;gap:10px;margin-top:14px;display:grid}.search-field{color:#64748b;align-items:center;gap:8px;min-width:0;display:flex;position:relative}.search-field svg{pointer-events:none;position:absolute;left:12px}.search-field input{width:100%;padding-left:38px}.invoice{background:#fafbfc;border:1.5px solid #e8edf4;border-radius:12px;grid-template-columns:minmax(0,1fr) auto;align-items:flex-start;gap:12px;padding:14px 16px;transition:box-shadow .15s,border-color .15s,background .15s;display:grid}.invoice:hover{background:#fff;border-color:#c7d7e8;box-shadow:0 3px 12px #0f172a14}.invoice div{gap:3px;display:grid}.invoice-summary{text-align:right;align-items:flex-end}.invoice-actions{grid-template-columns:repeat(2,minmax(86px,1fr));justify-content:flex-end;gap:6px;width:min(100%,190px);margin-top:4px;display:grid}.invoice-more-actions{border-top:1px solid #eef2f7;grid-template-columns:repeat(2,minmax(86px,1fr));gap:6px;width:min(100%,190px);margin-top:8px;padding-top:8px;display:grid}.invoice strong{color:#0f172a;font-size:.95rem;font-weight:800}.invoice span{color:#64748b;font-size:.8rem}.invoice-status{letter-spacing:.02em;border-radius:999px;align-items:center;margin-top:2px;padding:2px 10px;font-size:.73rem;font-weight:800;display:inline-flex}.invoice-status.paid{color:#065f46;background:#d1fae5}.invoice-status.unpaid{color:#991b1b;background:#fee2e2}.invoice-status.pending_slip{color:#78350f;background:#fef3c7}.invoice-status.cancelled{color:#475569;background:#e2e8f0}.invoice-detail{border-top:1px solid #e2e8f0;grid-column:1/-1;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:4px;padding-top:12px;display:grid}.invoice-detail div{background:#fff;border:1px solid #eef2f7;border-radius:10px;gap:3px;padding:10px;display:grid}.invoice-detail small{color:#64748b;font-size:.72rem;line-height:1.35}.invoice-edit-form{border-top:1px solid #e2e8f0;grid-column:1/-1;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:4px;padding-top:12px;display:grid}.invoice-edit-total{color:#0f766e;background:#ecfdf9;border:1px solid #b5f2e6;border-radius:10px;align-content:center;gap:2px;padding:10px 12px;display:grid}.invoice-edit-actions{grid-column:1/-1;justify-content:flex-end;gap:10px;display:flex}.empty-state{color:#64748b;text-align:center;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:12px;gap:6px;padding:28px 24px;display:grid}.empty-state strong{color:#334155;font-size:.95rem;font-weight:700}.empty-state span{font-size:.84rem;line-height:1.55}.empty-state.compact{padding:20px}.tenant-link-panel{background:#fff;border:1px solid #e2e8f0cc;border-radius:16px;grid-template-columns:minmax(0,1fr) minmax(300px,.8fr);align-items:center;gap:20px;margin-top:20px;padding:24px;display:grid;box-shadow:0 2px 8px #0f172a0f}.tenant-link-panel h2{font-size:1rem;font-weight:800}.tenant-link-panel p{color:#64748b;margin:8px 0 0;font-size:.88rem;line-height:1.65}.copy-preview{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;align-items:center;gap:8px;min-width:0;padding:10px 12px;display:flex}code{color:#334155;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.8rem;overflow:hidden}.icon-only{color:#fff;width:38px;height:38px;transition:transform var(--transition), box-shadow var(--transition);background:linear-gradient(135deg,#14b8a6,#0f766e);border:none;border-radius:8px;flex:none;box-shadow:0 2px 8px #0f766e59}.icon-only:hover{transform:translateY(-1px);box-shadow:0 4px 14px #0f766e73}.public-pay-page{background:linear-gradient(#071f2dc2,#071f2dc2),url(/assets/hero-CLDdwZDr.png) 50%/cover;place-items:center;min-height:100vh;padding:24px;display:grid}.public-pay-card{background:#fffffff5;border:1px solid #e2e8f0db;border-radius:16px;width:min(100%,520px);padding:24px;box-shadow:0 18px 50px #02061747}.public-pay-header{gap:6px;margin-bottom:18px;display:grid}.public-pay-header h1{font-size:2rem;line-height:1.1}.public-pay-header>span:not(.invoice-status){color:#64748b;font-size:.9rem}.public-total{color:#fff;background:linear-gradient(135deg,#0f766e,#14b8a6);border-radius:12px;justify-content:space-between;align-items:end;gap:16px;margin-bottom:14px;padding:18px;display:flex}.public-total span{opacity:.9;font-size:.9rem}.public-total strong{font-size:2rem;line-height:1}.public-line-items{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px;display:grid}.public-line-items div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;gap:4px;padding:12px;display:grid}.public-bank-box{background:#ecfdf9;border:1px solid #b5f2e6;border-radius:10px;gap:3px;margin-bottom:16px;padding:14px;display:grid}.public-bank-box span,.public-bank-box small{color:#0f766e}.public-bank-box strong{color:#0f172a}.public-payment-form{border-top:1px solid #e2e8f0;gap:10px;margin-top:14px;padding-top:14px}.public-payment-state{color:#78350f;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;gap:2px;margin-top:14px;padding:12px 14px;display:grid}.public-payment-state span{font-size:.86rem}.public-slip-link{color:var(--color-primary);justify-content:center;margin-top:10px;font-weight:800;text-decoration:none;display:inline-flex}.report-panel{box-shadow:var(--shadow-sm);background:#fff;border:1px solid #e2e8f0cc;border-radius:16px;margin-top:20px;padding:24px}.report-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:16px;display:grid}.report-summary-grid div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;gap:2px;padding:12px;display:grid}.report-summary-grid span{color:var(--color-text-secondary);font-size:.78rem}.report-table-wrap{margin-top:14px;overflow-x:auto}.report-table{border-collapse:collapse;width:100%;font-size:.88rem}.report-table th,.report-table td{text-align:left;border-bottom:1px solid #e2e8f0;padding:10px}.report-table th{color:var(--color-text-secondary);text-transform:uppercase;font-size:.76rem}.public-line-items span,.public-line-items small,.public-contact{color:#64748b}.public-contact{text-align:center;margin-top:12px;font-size:.88rem}:root[data-theme=dark] .app-shell{background:#07111f}:root[data-theme=dark] .workspace{background:radial-gradient(80% 50% at 50% -20%,#2dd4bf14 0%,#0000 70%),#07111f}:root[data-theme=dark] .topbar,:root[data-theme=dark] .auth-card,:root[data-theme=dark] .dashboard-card,:root[data-theme=dark] .onboarding-panel,:root[data-theme=dark] .onboarding-step,:root[data-theme=dark] .panel,:root[data-theme=dark] .setup-panel,:root[data-theme=dark] .tenant-link-panel,:root[data-theme=dark] .dorm-settings-summary,:root[data-theme=dark] .report-panel,:root[data-theme=dark] .public-pay-card,:root[data-theme=dark] .invoice,:root[data-theme=dark] .room-row,:root[data-theme=dark] .copy-preview,:root[data-theme=dark] .empty-state,:root[data-theme=dark] .print-sheet{color:var(--color-text);border-color:var(--color-border);box-shadow:var(--shadow-md);background:#111827f5}:root[data-theme=dark] .topbar{background:#07111fdb}:root[data-theme=dark] .sidebar,:root[data-theme=dark] .bottom-nav{background:linear-gradient(170deg,#06101d 0%,#040a12 100%)}:root[data-theme=dark] input,:root[data-theme=dark] select,:root[data-theme=dark] textarea{color:var(--color-text);background:#0b1424;border-color:#263449}:root[data-theme=dark] input::placeholder,:root[data-theme=dark] textarea::placeholder{color:#718198}:root[data-theme=dark] label,:root[data-theme=dark] .month-filter{color:var(--color-label)}:root[data-theme=dark] .icon-button,:root[data-theme=dark] .small-button,:root[data-theme=dark] .ghost-button,:root[data-theme=dark] .mini-button{color:var(--color-text);background:#101a2b;border-color:#263449}:root[data-theme=dark] .icon-button:hover,:root[data-theme=dark] .small-button:hover,:root[data-theme=dark] .ghost-button:hover,:root[data-theme=dark] .mini-button:hover{background:#172235;border-color:#33445f}:root[data-theme=dark] .eyebrow,:root[data-theme=dark] .dashboard-card span,:root[data-theme=dark] .invoice span,:root[data-theme=dark] .tenant-link-panel p,:root[data-theme=dark] .public-line-items span,:root[data-theme=dark] .public-line-items small,:root[data-theme=dark] .public-contact,:root[data-theme=dark] code,:root[data-theme=dark] .empty-state span{color:var(--color-text-secondary)}:root[data-theme=dark] .invoice-detail div,:root[data-theme=dark] .invoice-edit-total,:root[data-theme=dark] .invoice-more-actions,:root[data-theme=dark] .report-summary-grid div,:root[data-theme=dark] .onboarding-step,:root[data-theme=dark] .line-integration-section,:root[data-theme=dark] .line-status-row,:root[data-theme=dark] .line-webhook-info,:root[data-theme=dark] .tenant-history-row,:root[data-theme=dark] .bulk-meter-row,:root[data-theme=dark] .public-line-items div,:root[data-theme=dark] .public-bank-box,:root[data-theme=dark] .public-payment-state,:root[data-theme=dark] .setup-note,:root[data-theme=dark] .meter-estimate-card,:root[data-theme=dark] .extra-charges,:root[data-theme=dark] .form-message{color:var(--color-text);background:#0b1424;border-color:#263449}:root[data-theme=dark] .room-number,:root[data-theme=dark] .public-pay-header h1,:root[data-theme=dark] .topbar h1,:root[data-theme=dark] .onboarding-copy h2,:root[data-theme=dark] .step-content strong,:root[data-theme=dark] .line-integration-header strong,:root[data-theme=dark] .line-webhook-info code,:root[data-theme=dark] .panel h2,:root[data-theme=dark] .auth-card h2{color:var(--color-text)}:root[data-theme=dark] .public-total{background:linear-gradient(135deg,#0f766e,#0d9488)}:root[data-theme=dark] .public-bank-box span,:root[data-theme=dark] .public-bank-box small,:root[data-theme=dark] .public-bank-box strong,:root[data-theme=dark] .public-payment-state,:root[data-theme=dark] .public-payment-state span{color:var(--color-text)}.bottom-nav{display:none}@media (width<=640px){.bottom-nav{z-index:100;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0px);background:linear-gradient(170deg,#0d2137 0%,#091623 100%);border-top:1px solid #ffffff0f;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -6px 24px #07142340}.bottom-nav-item{color:#ffffff73;letter-spacing:.02em;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:10px 4px 12px;font-size:.66rem;font-weight:700;text-decoration:none;transition:color .12s;display:flex}.bottom-nav-item.active{color:#2dd4bf}.bottom-nav-item:hover:not(.active){color:#fffc}.bottom-nav-signout{color:#ffffff59}.bottom-nav-signout:hover{color:#f87171}}@media (width<=980px){.auth-page,.content-grid,.setup-panel,.tenant-link-panel{grid-template-columns:1fr}.dorm-settings-summary{flex-direction:column;align-items:stretch}.report-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.app-shell{grid-template-columns:1fr}.auth-hero{padding:36px 22px}.brand.large{margin-bottom:32px}.auth-card{margin:0 16px 24px}.sidebar{flex-flow:wrap;align-items:center;gap:10px;height:auto;padding:14px 16px;position:static}.sidebar .brand{border-bottom:none;margin-bottom:0;padding-bottom:0}.nav-label{display:none}.nav-list{scrollbar-width:thin;flex:1;gap:4px;padding-bottom:2px;display:flex;overflow-x:auto}.nav-list a:before{display:none}.nav-list a{white-space:nowrap;flex:none;min-height:40px;font-size:.86rem}.account-box{margin-top:0;font-size:.8rem}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.workspace{padding:0 18px 24px}.topbar{margin:0 -18px 22px;padding:16px 18px}.topbar,.panel-header{flex-direction:column;align-items:flex-start}.topbar-actions{flex-wrap:wrap;align-items:stretch;gap:8px;width:100%;display:flex}.topbar-actions .icon-button{flex:auto}.topbar-actions .month-filter{flex:160px;min-width:0}.panel-actions{flex-direction:row;width:100%}.topbar .icon-button,.panel-header .small-button{min-height:44px}.room-form,.tenant-form,.move-out-form,.edit-room-form,.edit-tenant-form,.utility-form{grid-template-columns:1fr}.edit-room-actions{flex-direction:column;align-items:stretch}.extra-charge-row{grid-template-columns:1fr}}@media (width<=640px){.sidebar{display:none}.app-shell{grid-template-columns:1fr}.workspace{padding:0 14px calc(74px + env(safe-area-inset-bottom,0px) + 16px);background:#f0f4f8}.topbar{padding:calc(14px + env(safe-area-inset-top,0px)) 16px 14px;margin:0 -14px 20px}.auth-page{background:linear-gradient(#071423f2 0%,#0c2837cc 100%),url(https://images.unsplash.com/photo-1494526585095-c41746248156?auto=format&fit=crop&w=900&q=80) 50%/cover}.auth-hero{min-height:auto;padding:calc(28px + env(safe-area-inset-top,0px)) 18px 18px}.auth-hero h1{font-size:2rem;line-height:1.1}.auth-hero p{margin-top:14px;font-size:.95rem}.hero-actions{gap:8px;margin-top:22px;display:grid}.auth-cta-row{gap:8px;margin-top:20px;display:grid}.hero-primary-button,.hero-secondary-button{width:100%}.hero-actions span{justify-content:flex-start;min-height:42px}.auth-card{border-radius:14px;margin:0 10px 20px;padding:22px}.auth-card-header{margin-bottom:22px}.auth-switch{flex-direction:column;align-items:flex-start;gap:8px}.primary-button{width:100%}.topbar h1{font-size:1.3rem}.metric{border-radius:12px;flex-direction:row;align-items:center;gap:10px;padding:12px}.metric:after{display:none}.metric:before{content:"";border-radius:12px 0 0 12px;width:4px;position:absolute;top:0;bottom:0;left:0}.metric:first-child:before{background:linear-gradient(#0f766e,#2dd4bf)}.metric:nth-child(2):before{background:linear-gradient(#1d4ed8,#60a5fa)}.metric:nth-child(3):before{background:linear-gradient(#d97706,#fbbf24)}.metric:nth-child(4):before{background:linear-gradient(#be123c,#fb7185)}.metric:nth-child(5):before{background:linear-gradient(#15803d,#4ade80)}.metric-icon{border-radius:10px;flex-shrink:0;width:34px;height:34px}.metric-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.metric strong{font-size:1.08rem}.onboarding-panel{border-radius:12px;grid-template-columns:1fr;gap:14px;padding:14px}.onboarding-copy h2{font-size:1.05rem}.onboarding-copy p:not(.eyebrow){font-size:.86rem}.onboarding-steps{grid-template-columns:1fr;gap:8px}.onboarding-step{grid-template-columns:34px minmax(0,1fr);align-items:center;min-height:0;padding:10px}.onboarding-step .small-button{grid-column:1/-1;min-height:40px}.panel,.setup-panel,.tenant-link-panel{border-radius:12px;padding:16px;overflow-x:hidden}.workspace{overflow-x:hidden}.dorm-settings-form,.line-integration-section,.move-out-summary,.invoice-edit-form{max-width:100%}.dorm-settings-edit{border-radius:12px;padding:16px;overflow-x:hidden}.dorm-settings-edit-header{flex-direction:column;align-items:stretch}.dorm-settings-form{grid-template-columns:1fr}.line-integration-section{padding:14px;overflow-x:hidden}.line-integration-header{flex-wrap:wrap;align-items:flex-start}.line-integration-header .line-status-badge{margin-left:32px}.line-status-row{flex-direction:column;align-items:stretch;gap:8px}.line-status-row .ghost-button{width:100%}.delete-confirm-actions{flex-direction:column}.line-webhook-info code{overflow-wrap:anywhere;font-size:.65rem}.modal-box{max-width:calc(100vw - 32px);margin:0}.panel-header{padding-bottom:12px}.room-form,.tenant-form,.move-out-form,.edit-room-form,.edit-tenant-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px;padding:12px}.room-form label,.tenant-form label,.move-out-form label,.edit-room-form label,.edit-tenant-form label{gap:4px;font-size:.76rem}.room-form input,.room-form select,.tenant-form input,.tenant-form select,.move-out-form input,.move-out-form select,.edit-room-form input,.edit-room-form select,.edit-tenant-form input,.edit-tenant-form select{min-height:44px;padding:0 12px;font-size:1rem}.tenant-form label:first-child,.move-out-form label:first-child,.edit-room-form label:nth-child(2),.edit-room-actions,.tenant-history{grid-column:1/-1}.tenant-history-row{grid-template-columns:minmax(0,1fr) auto}.tenant-history-row span:last-child{grid-column:1/-1;font-size:.76rem}.utility-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px;padding:12px}.utility-form label:first-of-type,.utility-form label:nth-of-type(2),.utility-form label:nth-of-type(5),.utility-form .extra-charge-section,.utility-form .meter-estimate,.utility-form .primary-button,.utility-form .form-error,.utility-form .form-message{grid-column:1/-1}.utility-form label{gap:4px;font-size:.76rem}.utility-form input,.utility-form select{min-height:44px;padding:0 12px;font-size:1rem}input,select,textarea{font-size:16px}.extra-charge-section{gap:8px;padding:10px}.extra-charge-header{flex-direction:column;align-items:stretch}.meter-baseline,.meter-estimate{gap:8px}.meter-baseline div,.meter-estimate div{padding:8px 10px}.meter-estimate{grid-template-columns:repeat(2,minmax(0,1fr))}.meter-estimate div:last-child{grid-column:1/-1}.room-row{border:1px solid #e8edf4;border-radius:9px;grid-template-columns:44px minmax(0,1fr) auto auto;gap:6px;min-height:64px;margin-bottom:5px;padding:8px}.room-row:hover{background:0 0}.room-row strong{grid-row:1/3;width:40px;min-width:40px;height:40px;font-size:.84rem}.room-row .status{grid-area:1/3/2/4;justify-self:end;padding:3px 8px;font-size:.68rem}.room-row>span:first-of-type{min-width:0;font-size:.86rem;line-height:1.25}.room-rate-note{white-space:normal;word-break:break-word;overflow-wrap:anywhere;margin-top:1px;font-size:.68rem;line-height:1.4}.room-row-actions{flex-direction:column;grid-area:1/4/3/5;place-self:center end;gap:4px}.room-row .icon-button.compact{border-radius:7px;width:30px;height:30px}.room-row .icon-button.compact svg{width:14px;height:14px}.invoice{grid-template-columns:minmax(0,1fr) auto;gap:8px 10px;padding:12px}.invoice-detail{grid-template-columns:repeat(2,minmax(0,1fr))}.invoice-edit-form{border-top:1px solid #e2e8f0;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;padding-top:8px}.invoice-tools,.room-tools{grid-template-columns:1fr}.invoice-summary{text-align:right;align-items:flex-end}.invoice-actions{grid-column:1/-1;grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch;width:100%;margin-top:6px;display:grid}.invoice-actions .mini-button{justify-content:center;min-height:36px;padding:6px 8px}.invoice-more-actions{grid-column:1/-1;grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch;width:100%}.invoice-more-actions .mini-button{justify-content:center;min-height:36px;padding:6px 8px}.invoice-actions:not(.expanded)>:nth-child(n+3){display:none}.bulk-meter-form{gap:10px;margin-top:12px;padding:12px}.bulk-meter-header{grid-template-columns:1fr}.bulk-meter-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;padding:10px}.bulk-meter-row>div,.bulk-meter-row>strong,.bulk-meter-save-button{grid-column:1/-1}.invoice-detail div{background:0 0;border:0;border-bottom:1px solid #eef2f7;border-radius:0;padding:8px 6px}.invoice-detail div:nth-last-child(-n+2){border-bottom:0}.invoice-detail strong{font-size:.9rem}.invoice-detail small{font-size:.68rem}.invoice-status{align-self:start;width:max-content;max-width:100%}.copy-preview{align-items:stretch}.copy-preview code{white-space:normal;word-break:break-all;align-content:center}.icon-only{width:44px;height:auto;min-height:44px}.public-pay-page{align-items:start;padding:14px}.public-pay-card{border-radius:12px;padding:16px}.public-total{flex-direction:column;align-items:start}.public-line-items{grid-template-columns:1fr}}@media (width<=390px){.auth-hero h1{font-size:1.75rem}.brand-mark{width:38px;height:38px}.nav-list a{padding:9px 10px}.room-row{grid-template-columns:38px minmax(0,1fr) auto}.room-row .status,.room-row span:nth-of-type(3){grid-column:3/4;justify-self:end}.room-row-actions{flex-direction:row;grid-area:auto/1/auto/-1;justify-self:stretch}.room-row .icon-button.compact{flex:1}.invoice-detail{grid-template-columns:repeat(2,minmax(0,1fr))}}.print-area{display:none}.print-sheet{color:#0f172a;background:#fff}.print-header{border-bottom:2px solid #0f172a;justify-content:space-between;gap:24px;padding-bottom:16px;display:flex}.print-header div{gap:4px;display:grid}.print-header div:last-child{text-align:right}.print-header strong{font-size:1.45rem}.print-meta{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 20px;margin:18px 0;font-size:.95rem;display:grid}.print-table{border-collapse:collapse;width:100%;font-size:.95rem}.print-table td{border:1px solid #cbd5e1;padding:10px 12px}.print-table td:last-child{text-align:right}.print-table tfoot td{background:#f1f5f9;font-size:1.1rem;font-weight:800}.print-footer{justify-content:space-between;gap:24px;margin-top:42px;font-size:.9rem;display:flex}@media print{body{background:#fff}.app-shell>:not(.workspace),.workspace>:not(.print-area){display:none!important}.app-shell,.workspace{background:#fff;padding:0;display:block}.print-area{padding:24px;display:block}}.invoice.pending-slip-highlight{border-left:3px solid var(--warning,#f59e0b);background:color-mix(in srgb, var(--warning,#f59e0b) 6%, var(--surface))}.mini-button.verify-btn{color:#0369a1;background:#e0f2fe;border-color:#7dd3fc}.mini-button.verify-btn:hover{background:#bae6fd}.slip-verify-badge{border-radius:6px;padding:2px 8px;font-size:.78rem;font-weight:500;display:inline-block}.slip-verify-badge.ok{color:#15803d;background:#dcfce7}.slip-verify-badge.err{color:#b91c1c;background:#fee2e2}.slip-preview-modal{background:var(--surface);border-radius:14px;flex-direction:column;width:min(480px,94vw);max-height:90vh;display:flex;overflow:hidden;box-shadow:0 8px 40px #0000002e}.slip-preview-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.slip-preview-body{background:var(--bg);flex:1;justify-content:center;padding:16px;display:flex;overflow-y:auto}.slip-preview-body img{object-fit:contain;border-radius:8px;max-width:100%}.slip-preview-footer{border-top:1px solid var(--border);justify-content:flex-end;padding:12px 18px;display:flex}.dashboard-stats-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;display:grid}@media (width<=480px){.dashboard-stats-grid{grid-template-columns:1fr 1fr}.dashboard-stats-grid .stat-card:last-child{grid-column:1/-1}}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:2px;padding:14px 16px;display:flex}.stat-card span{color:var(--text-secondary);font-size:.78rem}.stat-card strong{color:var(--text-primary);font-size:1.25rem;font-weight:700;line-height:1.2}.stat-card small{color:var(--text-secondary);font-size:.72rem}.stat-card.accent{border-color:var(--color-primary)}.stat-card.accent strong{color:var(--color-primary)}.stat-card.warn{border-color:var(--danger)}.stat-card.warn strong{color:var(--danger)}.onboarding-panel summary::-webkit-details-marker{display:none}.onboarding-panel summary{-webkit-user-select:none;user-select:none}.public-qr-box{background:var(--card);border:1px solid var(--border);text-align:center;border-radius:12px;margin-bottom:12px;padding:14px 16px}.public-qr-box span{color:var(--text-secondary);margin-bottom:4px;font-size:.82rem;display:block}.public-qr-box small{color:var(--text-secondary);margin-top:4px;font-size:.75rem;display:block}.tenant-invoice-history{background:var(--bg);border-top:1px solid var(--border);border-radius:0 0 10px 10px;padding:12px 14px}.dorm-feature-toggle{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;flex-direction:column;gap:4px;padding:12px 14px;display:flex}.dorm-feature-toggle-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.dorm-feature-toggle-header strong{color:var(--text-primary);font-size:.9rem}.toggle-switch{cursor:pointer;flex-shrink:0;width:44px;height:24px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-track{background:#cbd5e1;border-radius:24px;transition:background .18s;position:absolute;inset:0}.toggle-track:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .18s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0000002e}.toggle-switch input:checked+.toggle-track{background:#14b8a6}.toggle-switch input:checked+.toggle-track:after{transform:translate(20px)}.overdue-badge{color:#dc2626;white-space:nowrap;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;padding:2px 7px;font-size:.7rem;font-weight:700;display:inline-block}.small-button.warn{color:#dc2626;background:#fef2f2;border-color:#fca5a5}.small-button.warn:hover{background:#fee2e2;border-color:#ef4444}:root[data-theme=dark] .dorm-feature-toggle{background:var(--card)}:root[data-theme=dark] .overdue-badge,:root[data-theme=dark] .small-button.warn{color:#f87171;background:#3b1a1a;border-color:#7f1d1d}:root[data-theme=dark] .toggle-track{background:#475569}
