:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f3f6f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0}button,input{font:inherit}button:focus-visible,a:focus-visible{outline-offset:2px;outline:3px solid #26a69a57}.auth-page{color:#f8fafc;background:linear-gradient(90deg,#0b1f2fe0,#0b1f2fb8),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-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{max-width:720px;font-size:clamp(2.3rem,5vw,5rem);line-height:.98}.auth-hero p{color:#f8fafcc7;max-width:610px;margin-top:22px;font-size:1.05rem}.hero-actions{flex-wrap:wrap;gap:10px;margin-top:34px;display:flex}.hero-actions span{background:#ffffff14;border:1px solid #ffffff3d;border-radius:999px;align-items:center;gap:8px;padding:9px 13px;display:inline-flex}.brand{color:inherit;align-items:center;gap:12px;text-decoration:none;display:inline-flex}.brand.large{margin-bottom:54px}.brand strong,.brand small{display:block}.brand small{color:currentColor;opacity:.68;margin-top:2px;font-size:.78rem}.brand-mark{color:#fff;background:#26a69a;border-radius:8px;place-items:center;width:42px;height:42px;display:grid}.auth-card{color:#172033;background:#fffffff5;border:1px solid #e2e8f0c7;border-radius:8px;align-self:center;margin:32px 48px 32px 0;padding:30px;box-shadow:0 24px 70px #0f172a47}.auth-card-header,.panel-header,.topbar{justify-content:space-between;align-items:center;gap:16px;display:flex}.auth-card-header{justify-content:flex-start;margin-bottom:26px}.auth-icon{color:#0f766e;background:#dff7f3;border-radius:8px;place-items:center;width:46px;height:46px;display:grid}.eyebrow{color:#0f766e;letter-spacing:0;text-transform:uppercase;margin:0 0 5px;font-size:.74rem;font-weight:800}.auth-card h2,.panel h2,.tenant-link-panel h2{color:#172033;margin:0}form{gap:16px;display:grid}label{color:#344054;gap:8px;font-size:.92rem;font-weight:700;display:grid}input{box-sizing:border-box;color:#101828;width:100%;font:inherit;background:#fff;border:1px solid #d0d5dd;border-radius:7px;padding:13px 14px}input:focus{border-color:#0f766e;outline:3px solid #0f766e29}.primary-button,.small-button,.icon-button,.icon-only,.auth-switch button{font:inherit;cursor:pointer;border:0;border-radius:7px;justify-content:center;align-items:center;gap:8px;font-weight:800;display:inline-flex}.primary-button{color:#fff;background:#0f766e;min-height:48px;margin-top:4px}.primary-button:disabled{cursor:wait;opacity:.72}.auth-switch{justify-content:space-between;gap:12px;margin-top:18px;display:flex}.auth-switch button{color:#0f766e;background:0 0;padding:0}.form-error,.form-message,.setup-note{border-radius:7px;margin:0;padding:11px 12px;font-size:.9rem}.form-error{color:#9f1239;background:#fff1f2}.form-message{color:#166534;background:#ecfdf3}.setup-note{color:#475467;background:#f2f4f7;gap:9px;margin-top:22px;display:flex}.app-shell{color:#172033;background:#f3f6f8;grid-template-columns:276px minmax(0,1fr);min-height:100svh;display:grid}.sidebar{color:#fff;background:#0b1f2f;flex-direction:column;gap:24px;padding:24px;display:flex}.nav-list{gap:7px;display:grid}.nav-list a,.account-box{color:#ffffffc2;border-radius:7px;align-items:center;gap:10px;padding:11px 12px;text-decoration:none;display:flex}.nav-list a.active,.nav-list a:hover{color:#fff;background:#ffffff1c}.account-box{background:#ffffff14;min-width:0;margin-top:auto}.account-box span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.workspace{padding:28px}.topbar{margin-bottom:24px}.topbar h1{font-size:2rem}.icon-button,.small-button{color:#172033;background:#fff;border:1px solid #d8dee7;padding:10px 13px}.metric-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:18px;display:grid}.metric,.panel,.tenant-link-panel{background:#fff;border:1px solid #d8dee7;border-radius:8px}.metric{gap:8px;padding:18px;display:grid}.metric svg{color:#0f766e}.metric span,.invoice span,.room-row span{color:#667085}.metric strong{font-size:1.35rem}.content-grid{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:18px;display:grid}.panel{padding:20px}.room-table,.invoice-list{gap:10px;margin-top:18px;display:grid}.room-row{border-bottom:1px solid #edf0f5;grid-template-columns:64px 1fr 120px 110px;align-items:center;gap:12px;padding:12px 0;display:grid}.status{border-radius:999px;justify-self:start;padding:4px 9px;font-size:.78rem;font-weight:800}.status.available{color:#047857;background:#d1fae5}.status.occupied{color:#155e75;background:#cffafe}.status.due{color:#b45309;background:#fef3c7}.status.moving{color:#9f1239;background:#ffe4e6}.invoice{border:1px solid #edf0f5;border-radius:7px;justify-content:space-between;align-items:center;gap:16px;padding:14px;display:flex}.invoice div{gap:3px;display:grid}.invoice div:last-child{text-align:right}.empty-state{color:#475467;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:7px;gap:6px;padding:22px;display:grid}.empty-state strong{color:#172033}.empty-state.compact{padding:18px}.tenant-link-panel{grid-template-columns:minmax(0,1fr) minmax(320px,.8fr);align-items:center;gap:18px;margin-top:18px;padding:20px;display:grid}.tenant-link-panel p{color:#667085;margin:8px 0 0}.copy-preview{background:#f8fafc;border:1px solid #d8dee7;border-radius:7px;align-items:center;gap:8px;min-width:0;padding:8px;display:flex}code{color:#344054;text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.icon-only{color:#fff;background:#0f766e;flex:none;width:38px;height:38px}@media (width<=980px){.auth-page,.app-shell,.content-grid,.tenant-link-panel{grid-template-columns:1fr}.auth-hero{padding:36px 22px}.brand.large{margin-bottom:32px}.auth-card{margin:0 16px 24px}.sidebar{gap:14px;padding:16px 18px;position:static}.nav-list{scrollbar-width:thin;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.nav-list a{white-space:nowrap;flex:none;min-height:44px}.account-box{margin-top:0}.metric-grid{grid-template-columns:1fr}.workspace{padding:18px}.topbar,.panel-header{flex-direction:column;align-items:flex-start}.topbar .icon-button,.panel-header .small-button{width:100%;min-height:44px}}@media (width<=640px){.auth-page{background:linear-gradient(#0b1f2fe8,#0b1f2fc7),url(https://images.unsplash.com/photo-1494526585095-c41746248156?auto=format&fit=crop&w=900&q=80) 50%/cover}.auth-hero{min-height:auto;padding:28px 18px 18px}.auth-hero h1{font-size:2rem;line-height:1.05}.auth-hero p{margin-top:16px;font-size:.98rem}.hero-actions{gap:8px;margin-top:22px;display:grid}.hero-actions span{justify-content:flex-start;min-height:42px}.auth-card{margin:0 10px 18px;padding:20px}.auth-card-header{margin-bottom:20px}.auth-switch{flex-direction:column;align-items:flex-start}.auth-switch button{justify-content:flex-start;min-height:36px}.primary-button{width:100%}.setup-note{align-items:flex-start;line-height:1.45}.sidebar .brand{width:100%}.brand small{font-size:.72rem}.workspace{padding:14px 10px 18px}.topbar{margin-bottom:16px}.topbar h1{font-size:1.7rem}.metric{grid-template-columns:auto 1fr;align-items:center;padding:15px}.metric strong{grid-column:1/-1}.panel,.tenant-link-panel{padding:16px}.room-row{border:1px solid #edf0f5;border-radius:7px;grid-template-columns:54px minmax(0,1fr);padding:12px}.room-row .status{grid-column:1/2}.room-row span:last-child{justify-self:end}.invoice{flex-direction:column;align-items:flex-start}.invoice div:last-child{text-align:left}.tenant-link-panel{gap:14px}.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}}@media (width<=390px){.auth-hero h1{font-size:1.78rem}.brand-mark{width:38px;height:38px}.nav-list a{padding:10px}.room-row{grid-template-columns:1fr}.room-row .status,.room-row span:last-child{grid-column:auto;justify-self:start}}
