:root{--bg: #ffffff;--fg: #000000;--muted: #6b6b6b;--line: #e3e3e3;--track: #e6e6e6;color-scheme:light dark}@media(prefers-color-scheme:dark){:root{--bg: #000000;--fg: #d0d0d0;--muted: #7a7a7a;--line: #1d1d1d;--track: #262626}}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{background:var(--bg);color:var(--fg);font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.4;-webkit-font-smoothing:antialiased;overflow:hidden;overscroll-behavior:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}input,textarea{user-select:text;-webkit-user-select:text}.app{height:100%;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0)}.topbar{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}.brand{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em}.badge{display:inline-flex;align-items:center;gap:8px;font-size:.66rem;font-weight:500;text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}.badge:before{content:"";width:7px;height:7px;background:var(--muted)}.badge--lan,.badge--relay{color:var(--fg)}.badge--lan:before,.badge--relay:before{background:var(--fg)}.banner{flex:0 0 auto;margin:16px 20px 0;padding:12px 14px;border:1px solid var(--fg);font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em}.empty{margin:auto;color:var(--muted);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem}.pager-wrap{flex:1;display:flex;flex-direction:column;min-height:0}.pager{flex:1;min-height:0;display:flex;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.pager::-webkit-scrollbar{display:none}.room-screen{flex:0 0 100%;width:100%;min-height:0;scroll-snap-align:start;display:flex;flex-direction:column;padding:28px 24px 16px}.room-screen-title{flex:0 0 auto;text-align:center;font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;margin:0 0 32px}.shades-row{flex:1;min-height:0;display:grid;grid-auto-flow:column;grid-auto-columns:1fr;justify-content:center;column-gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.shade{background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:24px 12px}.shade--unavailable{opacity:.4}.shade-readout{flex:0 0 auto;font-size:1.5rem;font-weight:400;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.shade-bar{position:relative;flex:1;min-height:200px;width:64px;margin:18px 0;background:var(--track);border-radius:6px;overflow:hidden;touch-action:pan-x;cursor:pointer}.shade-bar:focus-visible{outline:1px solid var(--fg);outline-offset:3px}.bar-fill{position:absolute;top:0;left:0;right:0;background:var(--fg);transition:height .25s ease}.shade-bar--dragging .bar-fill{transition:none}.bar-current{position:absolute;left:0;right:0;height:3px;transform:translateY(-50%);background:var(--bg);outline:1px solid var(--fg);transition:top .25s ease}.shade-name{flex:0 0 auto;font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.14em}.shade-substate{flex:0 0 auto;margin-top:4px;color:var(--muted);font-size:.62rem;text-transform:uppercase;letter-spacing:.12em}.dots{flex:0 0 auto;display:flex;justify-content:center;gap:10px;padding:18px 0 20px}.dot{width:8px;height:8px;border:1px solid var(--fg);border-radius:50%;padding:0;background:transparent;cursor:pointer}.dot--active{background:var(--fg)}.passcode{height:100%;display:grid;place-items:center;padding:24px}.passcode-card{width:100%;max-width:300px;display:flex;flex-direction:column;gap:20px}.passcode-card h1{margin:0;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em}.passcode-card p{margin:0;color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.14em}.passcode-card input{background:transparent;border:none;border-bottom:1px solid var(--fg);border-radius:0;padding:10px 2px;color:var(--fg);font-size:1.4rem;text-align:center;letter-spacing:.4em}.passcode-card input:focus{outline:none;border-bottom-width:2px}.passcode-card button{background:var(--fg);color:var(--bg);font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;border:none;border-radius:0;padding:14px;cursor:pointer}.passcode-card button:disabled{opacity:.4;cursor:default}.passcode-error{color:var(--fg);font-size:.66rem;text-transform:uppercase;letter-spacing:.1em}
