@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Manrope:wght@500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#070b12;--surface:#ffffff0b;--surface-h:#ffffff14;--line:#ffffff1a;--line-h:#fff3;--text:#e2e8f0;--muted:#64748b;--accent:#4db3ff;--locked-fg:#60a5fa;--locked-bg:#60a5fa14;--locked-border:#60a5fa38;--unlocked-fg:#fb923c;--unlocked-bg:#fb923c14;--unlocked-border:#fb923c38;--unknown-fg:#475569;--unknown-bg:#47556914;--unknown-border:#4755692e;--radius:16px;--ease:cubic-bezier(.2, .65, .2, 1);--t:.16s}html,body,#root{height:100%}body{color:var(--text);-webkit-font-smoothing:antialiased;background:radial-gradient(900px 600px at 80% -10%,#4db3ff21,#0000 60%) fixed,radial-gradient(700px 500px at -15% 110%,#fb923c12,#0000 65%) fixed,#070b12 fixed;min-height:100vh;font-family:Space Grotesk,system-ui,sans-serif;font-size:14px}body:before{content:"";pointer-events:none;z-index:0;background-image:linear-gradient(#ffffff07 1px,#0000 1px),linear-gradient(90deg,#ffffff07 1px,#0000 1px);background-size:52px 52px;position:fixed;inset:0}.app{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}.auth-shell{z-index:1;place-items:center;min-height:100vh;padding:20px;display:grid;position:relative}.auth-card{border:1px solid var(--line-h);width:min(420px,100%);animation:rise .34s var(--ease) both;background:#090e18e6;border-radius:18px;flex-direction:column;gap:10px;padding:26px;display:flex;box-shadow:0 24px 48px #00000073}.auth-card.loading{text-align:center;align-items:center;gap:8px}.auth-card.loading .spinner{margin-bottom:4px}.auth-brand{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);align-items:center;gap:8px;font-size:12px;font-weight:700;display:flex}.auth-card h1{letter-spacing:-.02em;margin-top:4px;font-size:26px;line-height:1.15}.auth-card p{color:#94a3b8;font-size:13px;line-height:1.5}.auth-label{color:#cbd5e1;letter-spacing:.06em;text-transform:uppercase;margin-top:4px;font-size:11.5px;font-weight:650}.auth-input{border:1px solid var(--line-h);color:var(--text);height:42px;transition:border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);background:#ffffff0d;border-radius:10px;outline:none;padding:0 12px;font:600 14px/1 Space Grotesk,sans-serif}.auth-input:focus{border-color:#4db3ff99;box-shadow:0 0 0 3px #4db3ff1f}.auth-error{color:#fb7185;font-size:12.5px;font-weight:600}.auth-submit{border-radius:11px;min-height:42px;margin-top:8px}.spinner{border:2px solid;border-right-color:#0000;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}.header{z-index:50;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);background:#070b12e0;justify-content:space-between;align-items:center;gap:12px;height:58px;padding:0 24px;display:flex;position:sticky;top:0}.brand{letter-spacing:.16em;text-transform:uppercase;color:var(--muted);flex-shrink:0;align-items:center;gap:8px;font-size:11px;font-weight:600;display:flex}.brand em{color:var(--accent);margin:0 3px;font-style:normal}.header-right{flex-shrink:0;align-items:center;gap:8px;display:flex;position:relative}.house-trigger{background:var(--surface);border:1px solid var(--line-h);height:36px;color:var(--text);cursor:pointer;transition:border-color var(--t) var(--ease), background var(--t) var(--ease);white-space:nowrap;border-radius:999px;align-items:center;gap:7px;padding:0 14px;font:600 12.5px/1 Space Grotesk,sans-serif;display:flex}.house-trigger:hover{background:var(--surface-h);border-color:#4db3ff8c}.house-trigger.open{border-color:var(--accent);background:#4db3ff1a}.house-trigger svg{transition:transform .2s var(--ease);flex-shrink:0}.house-trigger.open svg{transform:rotate(180deg)}.house-dropdown{z-index:100;background:#0b1120;border:1px solid #ffffff2e;border-radius:14px;width:230px;padding:7px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 24px 56px #000c}.house-option{text-align:left;color:#e2e8f0;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff12;border-radius:10px;width:100%;margin-bottom:4px;padding:10px 12px;font:600 14px/1.3 Space Grotesk,sans-serif;display:block}.house-option.selected{background:#4db3ff1f;border-color:#4db3ff8c}.house-option:last-child{margin-bottom:0}.house-option span{color:#64748b;margin-top:3px;font-size:11px;font-weight:500;display:block}.hdr-btn{border:1px solid var(--line-h);background:var(--surface);color:var(--text);cursor:pointer;height:34px;transition:background var(--t) var(--ease), border-color var(--t) var(--ease);white-space:nowrap;border-radius:10px;padding:0 12px;font:600 11.5px/1 Space Grotesk,sans-serif}.hdr-btn:hover:not(:disabled){background:var(--surface-h);border-color:#ffffff4d}.hdr-btn:disabled{opacity:.4;cursor:not-allowed}main{flex:1;padding:20px 24px 32px}.door-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.door-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);transition:border-color var(--t) var(--ease), transform var(--t) var(--ease), box-shadow var(--t) var(--ease), opacity var(--t) var(--ease);animation:rise .32s var(--ease) both;flex-direction:column;gap:12px;padding:16px;display:flex}.door-card:hover{border-color:var(--line-h);transform:translateY(-2px)}.door-card.locked{border-color:var(--locked-border);background:var(--locked-bg);box-shadow:0 6px 24px #60a5fa12}.door-card.unlocked{border-color:var(--unlocked-border);background:var(--unlocked-bg);box-shadow:0 6px 24px #fb923c12}.door-card.unknown{border-color:var(--unknown-border)}.card-top{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.door-info{flex:1;min-width:0}.door-name{letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:650;overflow:hidden}.door-note{color:var(--muted);margin-top:3px;font-size:12px}.state-badge{letter-spacing:.07em;text-transform:uppercase;border:1px solid #0000;border-radius:999px;flex-shrink:0;align-items:center;gap:5px;padding:4px 9px;font-size:10.5px;font-weight:700;display:flex}.state-badge .dot{border-radius:50%;flex-shrink:0;width:5px;height:5px}.state-badge .spinner{border:1.8px solid;border-right-color:#0000;border-radius:50%;flex-shrink:0;width:11px;height:11px;animation:.7s linear infinite spin}.door-card.locked .state-badge{color:var(--locked-fg);border-color:var(--locked-border)}.door-card.locked .state-badge .dot{background:var(--locked-fg)}.door-card.unlocked .state-badge{color:var(--unlocked-fg);border-color:var(--unlocked-border)}.door-card.unlocked .state-badge .dot{background:var(--unlocked-fg)}.door-card.unknown .state-badge{color:var(--unknown-fg);border-color:var(--unknown-border)}.door-card.unknown .state-badge .dot{background:var(--unknown-fg)}.door-actions{gap:8px;margin-top:auto;display:flex}.btn{border:1px solid var(--line-h);color:var(--text);cursor:pointer;min-height:44px;transition:background var(--t) var(--ease), border-color var(--t) var(--ease), opacity var(--t) var(--ease);background:#ffffff08;border-radius:10px;flex:1;padding:10px 8px;font:600 13px/1 Space Grotesk,sans-serif}.btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff4d}.btn:disabled{opacity:.28;cursor:not-allowed}.btn.action-toggle{color:var(--text);background:#ffffff0d;border-color:#ffffff24}.btn.action-toggle:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff42}.footer{border-top:1px solid var(--line);color:var(--muted);justify-content:space-between;align-items:center;padding:12px 24px;font-size:11.5px;display:flex}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=600px){.header{height:54px;padding:0 14px}main{padding:14px 14px 32px}.footer,.hdr-btn{display:none}.door-grid{grid-template-columns:1fr}.auth-card{padding:20px}}
