*{box-sizing:border-box;margin:0;padding:0}:root{--accent:#3b6fe0;--accent-soft:#3b6fe01f;--accent-2:#3b6fe033;--bg:#f4f6fa;--bg-alt:#eef1f6;--surface:#fff;--surface-2:#fbfcfe;--ink:#0c111c;--ink-muted:#5b667a;--ink-faint:#94a0b4;--border:#e3e8ef;--border-strong:#cdd5e0;--ok:#16a34a;--danger:#dc2626;--warn:#d97706;--sidebar-w:232px;--pad:28px;--gap:18px;--radius:14px;--field-h:46px}html,body{background:var(--bg);height:100%;color:var(--ink);font-family:var(--font-geist-sans,"Geist"), ui-sans-serif, system-ui, sans-serif;font-feature-settings:"ss01", "cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14.5px;line-height:1.5}#root,body>div{height:100%}.mono{font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, "SF Mono", Menlo, monospace;font-feature-settings:"ss01", "ss02"}button{cursor:pointer;font-family:inherit}input,select,textarea{color:inherit;font-family:inherit}a{color:inherit;text-decoration:none}.app{background:var(--bg);grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;color:var(--ink);display:grid}.app--compact{--pad:22px;--gap:14px}.sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:20;flex-direction:column;height:100vh;display:flex;position:sticky;top:0}.sidebar__head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:22px 20px 18px;display:flex}.brand{align-items:center;gap:11px;min-width:0;display:flex}.brand__txt{min-width:0}.brand__eyebrow{letter-spacing:.16em;color:var(--ink-faint);font-size:10px;font-weight:500}.brand__title{letter-spacing:-.01em;font-size:13.5px;font-weight:600}.sidebar__close{color:var(--ink-muted);background:0 0;border:0;border-radius:6px;padding:6px;display:none}.sidebar__close:hover{background:var(--bg-alt);color:var(--ink)}.sidebar__nav{flex-direction:column;flex:1;gap:2px;padding:16px 14px;display:flex;overflow-y:auto}.sidebar__group{letter-spacing:.18em;color:var(--ink-faint);padding:8px 8px 6px;font-size:10px;font-weight:500}.sidebar__link{color:var(--ink-muted);border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:13.5px;transition:background .15s,color .15s;display:flex;position:relative}.sidebar__link-dot{background:var(--border-strong);border-radius:999px;flex-shrink:0;width:5px;height:5px;transition:background .15s}.sidebar__link:hover{background:var(--bg-alt);color:var(--ink)}.sidebar__link:hover .sidebar__link-dot{background:var(--ink-faint)}.sidebar__link.is-active{background:var(--accent-soft);color:var(--accent);font-weight:500}.sidebar__link.is-active .sidebar__link-dot{background:var(--accent);box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 22%, transparent)}.sidebar__foot{border-top:1px solid var(--border);padding:14px}.user{align-items:center;gap:10px;display:flex}.user__avatar{background:var(--ink);width:32px;height:32px;color:var(--surface);border-radius:8px;flex-shrink:0;place-items:center;font-size:13px;font-weight:600;display:grid}.user__txt{flex:1;min-width:0}.user__email{white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:500;overflow:hidden}.user__role{letter-spacing:.14em;color:var(--ink-faint);margin-top:2px;font-size:9.5px}.user__signout{border:1px solid var(--border);color:var(--ink-muted);background:0 0;border-radius:8px;flex-shrink:0;place-items:center;padding:6px;transition:all .15s;display:grid}.user__signout:hover{border-color:var(--danger);color:var(--danger);background:color-mix(in oklab, var(--danger) 5%, transparent)}.main{flex-direction:column;min-width:0;display:flex}.topbar{background:var(--bg);z-index:10;padding:18px var(--pad);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);align-items:center;gap:16px;display:flex;position:sticky;top:0}.topbar--detail{padding:16px var(--pad) 18px;align-items:flex-start;gap:16px}.topbar--detail .topbar__title{flex-direction:column;gap:6px;display:flex}.topbar__menu{border:1px solid var(--border-strong);background:var(--surface);width:34px;height:34px;color:var(--ink-muted);border-radius:8px;justify-content:center;align-items:center;display:none}.topbar__title{flex:1;min-width:0}.topbar__title h1{letter-spacing:-.02em;font-size:22px;font-weight:600;line-height:1.2}.topbar__title-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.topbar__title-row h1{letter-spacing:-.025em;font-size:24px;font-weight:600;line-height:1.15}.topbar__sub{color:var(--ink-faint);letter-spacing:.02em;margin-top:4px;font-size:11.5px}.topbar__time{color:var(--ink-muted);font-variant-numeric:tabular-nums}.topbar__actions{align-items:center;gap:8px;display:flex}.breadcrumb{letter-spacing:.14em;color:var(--ink-faint);align-items:center;gap:6px;width:fit-content;font-size:10.5px;font-weight:500;text-decoration:none;display:inline-flex}.breadcrumb:hover{color:var(--ink)}.breadcrumb__dot{background:var(--accent);border-radius:999px;width:5px;height:5px}.live-indicator{letter-spacing:.14em;background:color-mix(in oklab, var(--accent) 10%, var(--surface));border:1px solid color-mix(in oklab, var(--accent) 30%, transparent);color:var(--accent);border-radius:999px;align-items:center;gap:7px;padding:6px 10px;font-size:10.5px;font-weight:600;display:inline-flex}.live-indicator__dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 25%, transparent);border-radius:999px;animation:1.6s ease-in-out infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}.btn-icon{border:1px solid var(--border-strong);background:var(--surface);width:34px;height:34px;color:var(--ink-muted);border-radius:8px;place-items:center;transition:all .15s;display:grid}.btn-icon:hover{border-color:var(--ink);color:var(--ink)}.btn-primary{background:var(--ink);height:40px;color:var(--surface);letter-spacing:-.005em;cursor:pointer;white-space:nowrap;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:0 16px;font-family:inherit;font-size:13.5px;font-weight:500;transition:background-color .15s,transform 60ms,opacity .15s;display:inline-flex;position:relative;overflow:hidden}.btn-primary:before{content:"";background:linear-gradient(90deg, transparent, color-mix(in oklab, var(--accent) 40%, transparent), transparent);transition:transform .6s;position:absolute;inset:0;transform:translate(-100%)}.btn-primary:hover:before{transform:translate(100%)}.btn-primary:hover{background:color-mix(in oklab, var(--accent) 28%, var(--ink))}.btn-primary:active{transform:translateY(1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-primary>span,.btn-primary>svg{z-index:1;position:relative}.btn-ghost{border:1px solid var(--border-strong);background:var(--surface);color:var(--ink);white-space:nowrap;cursor:pointer;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.btn-ghost:hover{border-color:var(--ink);background:var(--bg-alt)}.btn-ghost--sm{border-radius:7px;padding:6px 11px;font-size:12.5px}.btn-ghost:disabled{opacity:.4;cursor:not-allowed}.btn-danger{background:var(--danger);color:#fff;cursor:pointer;border:0;border-radius:8px;padding:10px 16px;font-family:inherit;font-size:13.5px;font-weight:500;transition:opacity .15s,transform 60ms}.btn-danger:hover{opacity:.92}.btn-danger:active{transform:translateY(1px)}.content{padding:var(--pad);gap:var(--gap);flex-direction:column;width:100%;max-width:1400px;display:flex}.stats{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(3,1fr);display:grid;overflow:hidden}.stats--4{grid-template-columns:repeat(4,1fr)}.stat{border-right:1px solid var(--border);flex-direction:column;gap:6px;min-width:0;padding:16px 18px;display:flex;position:relative}.stat:last-child{border-right:0}.stat__label{letter-spacing:.14em;color:var(--ink-faint);font-size:10px;font-weight:500}.stat__value{letter-spacing:-.025em;font-variant-numeric:tabular-nums;font-size:26px;font-weight:600}.stat--ok .stat__value{color:var(--ok)}.stat--danger .stat__value{color:var(--danger)}.stat--warn .stat__value{color:var(--warn)}.stat__sub{color:var(--ink-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.stat--danger:before,.stat--warn:before,.stat--ok:before{content:"";width:100%;height:2px;position:absolute;top:0;left:0}.stat--ok:before{background:var(--ok)}.stat--danger:before{background:var(--danger)}.stat--warn:before{background:var(--warn)}.timeline{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px 14px}.timeline__head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.timeline__title{letter-spacing:-.005em;white-space:nowrap;font-size:13px;font-weight:600}.timeline__legend{color:var(--ink-muted);letter-spacing:.04em;gap:14px;font-size:10.5px;display:flex}.timeline__legend span{white-space:nowrap;align-items:center;gap:5px;display:inline-flex}.dot{border-radius:2px;width:8px;height:8px;display:inline-block}.dot--door{background:var(--accent)}.dot--breach-door{background:var(--warn)}.dot--breach-temp{background:var(--danger)}.timeline__grid{gap:8px;padding-top:20px;display:grid;position:relative}.timeline__hours{height:14px;color:var(--ink-faint);font-size:10px;position:absolute;top:0;left:140px;right:0}.timeline__hours span{letter-spacing:.04em;position:absolute;transform:translate(-50%)}.timeline__row{grid-template-columns:140px 1fr;align-items:center;gap:12px;display:grid}.timeline__row-label{flex-direction:column;gap:2px;min-width:0;display:flex}.timeline__row-name{white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:500;overflow:hidden}.timeline__row-id{color:var(--ink-faint);font-size:10px}.timeline__row-track{background:var(--bg-alt);border:1px solid var(--border);border-radius:6px;height:22px;position:relative;overflow:hidden}.timeline__row-tick{background:var(--border);opacity:.7;width:1px;height:100%;position:absolute;top:0}.evt{border-radius:3px;min-width:3px;position:absolute;top:3px;bottom:3px}.evt--door{background:var(--accent);opacity:.85}.evt--breach-door{background:var(--warn);box-shadow:0 0 0 1px color-mix(in oklab, var(--warn) 40%, transparent)}.evt--breach-temp{background:var(--danger);box-shadow:0 0 0 1px color-mix(in oklab, var(--danger) 40%, transparent)}.timeline__now{background:var(--ink);z-index:2;border-radius:2px;width:2px;position:absolute;top:-2px;bottom:-2px}.timeline__now:after{content:"";background:var(--ink);border-radius:999px;width:6px;height:6px;position:absolute;top:-3px;left:50%;transform:translate(-50%)}.rooms-section{flex-direction:column;gap:14px;display:flex}.rooms-section__head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.rooms-section__title{letter-spacing:-.005em;font-size:15px;font-weight:600}.rooms-section__filter{flex-wrap:wrap;gap:6px;display:flex}.chip{background:var(--surface);border:1px solid var(--border-strong);letter-spacing:.12em;color:var(--ink-muted);white-space:nowrap;cursor:pointer;border-radius:999px;padding:5px 11px;font-size:10px;font-weight:500;transition:all .15s}.chip:hover{border-color:var(--ink);color:var(--ink)}.chip--active{background:var(--ink);border-color:var(--ink);color:var(--surface)}.rooms-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:14px;display:grid}.rooms-empty{text-align:center;color:var(--ink-muted);background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);padding:48px 24px}.room{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;flex-direction:column;gap:16px;padding:18px;transition:transform .15s,border-color .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden}.room:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:0 1px 2px #0c111c0a,0 10px 24px -16px #0c111c2e}.room.is-breach{border-color:color-mix(in oklab, var(--danger) 55%, var(--border));background:linear-gradient(0deg, color-mix(in oklab, var(--danger) 4%, var(--surface)), var(--surface))}.room.is-breach:before{content:"";background:var(--danger);height:3px;position:absolute;top:0;left:0;right:0}.room__head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.room__name{letter-spacing:-.01em;font-size:15px;font-weight:600}.room__loc{color:var(--ink-faint);letter-spacing:.02em;margin-top:3px;font-size:10.5px}.room__core{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;display:grid}.room__metric{flex-direction:column;gap:4px;display:flex}.room__temp{font-size:36px;font-weight:600;font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;letter-spacing:-.03em;font-variant-numeric:tabular-nums;line-height:1}.room__unit{color:var(--ink-muted);margin-left:2px;font-size:18px}.room__setpoint{color:var(--ink-faint);letter-spacing:.02em;font-size:10.5px}.room__chart{flex-shrink:0;width:200px}.room__chart-axis{color:var(--ink-faint);letter-spacing:.04em;justify-content:space-between;margin-top:4px;font-size:9px;display:flex}.room__foot{border-top:1px dashed var(--border);justify-content:space-between;align-items:center;gap:10px;padding-top:14px;display:flex}.door-chip{border:1px solid var(--border-strong);background:var(--surface);letter-spacing:.06em;color:var(--ink-muted);white-space:nowrap;border-radius:999px;align-items:center;gap:7px;padding:5px 10px;font-size:10.5px;font-weight:500;display:inline-flex}.door-chip__dot{background:var(--ok);width:6px;height:6px;box-shadow:0 0 0 3px color-mix(in oklab, var(--ok) 20%, transparent);border-radius:999px}.door-chip__label{letter-spacing:.08em}.door-chip__since{color:var(--ink-faint);letter-spacing:.02em;margin-left:2px;font-weight:400}.door-chip--closed{color:var(--ok)}.door-chip--closed .door-chip__dot{background:var(--ok)}.door-chip--open{border-color:color-mix(in oklab, var(--danger) 50%, var(--border));background:color-mix(in oklab, var(--danger) 7%, var(--surface));color:var(--danger)}.door-chip--open .door-chip__dot{background:var(--danger);box-shadow:0 0 0 3px color-mix(in oklab, var(--danger) 22%, transparent);animation:1.4s ease-in-out infinite blink}.door-chip--open .door-chip__since{color:color-mix(in oklab, var(--danger) 70%, var(--ink-faint))}.door-chip--na{color:var(--ink-faint);border-style:dashed}.door-chip--na .door-chip__dot{background:var(--ink-faint);box-shadow:none}.breach-pill{letter-spacing:.12em;color:var(--danger);background:color-mix(in oklab, var(--danger) 10%, transparent);border:1px solid color-mix(in oklab, var(--danger) 30%, transparent);white-space:nowrap;border-radius:4px;align-items:center;gap:6px;padding:4px 9px;font-size:10px;font-weight:600;display:inline-flex}.breach-pill__pulse{background:var(--danger);width:6px;height:6px;box-shadow:0 0 0 3px color-mix(in oklab, var(--danger) 25%, transparent);border-radius:999px;flex-shrink:0;animation:1.3s ease-in-out infinite blink}.room__ping{color:var(--ink-faint);letter-spacing:.02em;white-space:nowrap;align-items:center;gap:6px;font-size:10.5px;display:inline-flex}.room__ping-dot{background:var(--ok);width:5px;height:5px;box-shadow:0 0 0 2px color-mix(in oklab, var(--ok) 20%, transparent);border-radius:999px;animation:2s ease-in-out infinite blink}.sensor-chip{letter-spacing:.12em;background:var(--bg-alt);color:var(--ink-muted);border:1px solid var(--border);white-space:nowrap;border-radius:4px;align-items:center;gap:6px;padding:4px 8px;font-size:9.5px;font-weight:500;display:inline-flex}.sensor-chip__dot{background:currentColor;border-radius:999px;width:5px;height:5px}.sensor-chip--temp{color:var(--accent);background:color-mix(in oklab, var(--accent) 8%, var(--surface));border-color:color-mix(in oklab, var(--accent) 30%, transparent)}.sensor-chip--door{color:var(--warn);background:color-mix(in oklab, var(--warn) 8%, var(--surface));border-color:color-mix(in oklab, var(--warn) 30%, transparent)}.status-badge{letter-spacing:.12em;background:var(--bg-alt);border:1px solid var(--border);color:var(--ink-muted);white-space:nowrap;border-radius:4px;align-items:center;gap:6px;padding:4px 9px;font-size:10px;font-weight:500;display:inline-flex}.status-badge__dot{background:currentColor;border-radius:999px;width:5px;height:5px}.status-badge--ok{color:var(--ok);background:color-mix(in oklab, var(--ok) 9%, var(--surface));border-color:color-mix(in oklab, var(--ok) 25%, transparent)}.status-badge--danger{color:var(--danger);background:color-mix(in oklab, var(--danger) 9%, var(--surface));border-color:color-mix(in oklab, var(--danger) 25%, transparent)}.status-badge--danger .status-badge__dot{box-shadow:0 0 0 3px color-mix(in oklab, var(--danger) 22%, transparent);animation:1.4s ease-in-out infinite blink}.status-badge--warn{color:var(--warn);background:color-mix(in oklab, var(--warn) 9%, var(--surface));border-color:color-mix(in oklab, var(--warn) 25%, transparent)}.status-dot{border-radius:999px;flex-shrink:0;width:8px;height:8px}.status-dot--ok{background:var(--ok);box-shadow:0 0 0 3px color-mix(in oklab, var(--ok) 22%, transparent)}.status-dot--danger{background:var(--danger);box-shadow:0 0 0 3px color-mix(in oklab, var(--danger) 22%, transparent);animation:1.4s ease-in-out infinite blink}.room__core--door{flex-direction:column;gap:16px;display:flex}.door-state{flex-direction:column;gap:6px;display:flex}.door-state__label{font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace}.door-state__meta{flex-wrap:wrap;align-items:baseline;gap:10px;display:flex}.door-state__time{color:var(--ink);font-variant-numeric:tabular-nums;font-size:13px;font-weight:500}.door-state__since{color:var(--ink-faint);letter-spacing:.02em;font-size:10.5px}.door-state__value{font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;letter-spacing:-.02em;align-items:center;gap:10px;font-size:32px;font-weight:600;line-height:1;display:inline-flex}.door-state__value--open{color:var(--danger)}.door-state__value--closed{color:var(--ok)}.door-today__stat{flex-direction:column;gap:2px;display:flex}.door-today__row{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px;display:grid}.door-today__num{font-size:17px;font-weight:600;font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.door-today__lbl{letter-spacing:.14em;color:var(--ink-faint);font-size:9px;font-weight:500}.door-strip{background:var(--bg-alt);border:1px solid var(--border);border-radius:4px;height:18px;position:relative;overflow:hidden}.door-strip__now{background:var(--ink);border-radius:2px;width:2px;position:absolute;top:-2px;bottom:-2px;right:0}.door-strip__axis{color:var(--ink-faint);letter-spacing:.04em;justify-content:space-between;margin-top:4px;font-size:9px;display:flex}.rooms-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.rooms-list__header{letter-spacing:.16em;color:var(--ink-faint);border-bottom:1px solid var(--border);background:var(--bg-alt);grid-template-columns:minmax(0,2fr) 90px 180px 200px 140px;align-items:center;gap:16px;padding:12px 18px;font-size:9.5px;font-weight:500;display:grid}.room-row{border-bottom:1px solid var(--border);cursor:pointer;grid-template-columns:minmax(0,2fr) 90px 180px 200px 140px;align-items:center;gap:16px;padding:14px 18px;transition:background .12s;display:grid}.room-row:last-child{border-bottom:0}.room-row:hover{background:var(--bg-alt)}.room-row.is-breach{background:linear-gradient(90deg, color-mix(in oklab, var(--danger) 5%, var(--surface)), var(--surface));border-left:3px solid var(--danger);padding-left:15px}.room-row__cell{align-items:center;gap:10px;min-width:0;display:flex}.room-row__cell--name{gap:12px}.room-row__cell--chart{align-items:center;display:flex}.room-row__cell--ping{justify-content:flex-end}.room-row__name{font-size:13.5px;font-weight:500}.room-row__loc{color:var(--ink-faint);margin-top:2px;font-size:10.5px}.room-row__temp{font-size:17px;font-weight:600;font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;font-variant-numeric:tabular-nums}.room-row__target{color:var(--ink-faint);font-size:10.5px}.room-row__door{font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;letter-spacing:-.005em;font-size:14px;font-weight:600}.room-row__door--open{color:var(--danger)}.room-row__door--closed{color:var(--ok)}.dim{color:var(--ink-faint)}.scrim{z-index:15;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#080c1473;animation:.15s scrim-in;position:fixed;inset:0}@keyframes scrim-in{0%{opacity:0}to{opacity:1}}.hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:24px;padding:22px 24px;display:grid;position:relative;overflow:hidden}.hero.is-breach{border-color:color-mix(in oklab, var(--danger) 50%, var(--border))}.hero.is-breach:before{content:"";background:var(--danger);height:3px;position:absolute;top:0;left:0;right:0}.hero__metric{flex-direction:column;gap:6px;min-width:0;display:flex}.hero__label{letter-spacing:.16em;color:var(--ink-faint);font-size:10.5px;font-weight:500}.hero__value{font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;letter-spacing:-.035em;font-variant-numeric:tabular-nums;align-items:baseline;font-size:60px;font-weight:600;line-height:1;display:inline-flex}.hero__value--door{align-items:center;gap:12px;font-size:48px;display:inline-flex}.hero__unit{color:var(--ink-muted);margin-left:4px;font-size:28px}.hero__meta{color:var(--ink-muted);letter-spacing:.02em;flex-wrap:wrap;align-items:baseline;gap:8px;font-size:12px;display:inline-flex}.hero__meta strong{color:var(--ink);font-weight:500}.hero__breach-since{color:var(--ink-faint)}.hero__breach{background:color-mix(in oklab, var(--danger) 8%, var(--surface));border:1px solid color-mix(in oklab, var(--danger) 30%, transparent);color:var(--danger);letter-spacing:.08em;white-space:nowrap;border-radius:8px;align-items:center;gap:8px;width:fit-content;margin-top:10px;padding:8px 12px;font-size:11px;font-weight:600;display:inline-flex}.hero__stats{border-left:1px solid var(--border);grid-template-columns:repeat(3,minmax(80px,auto));gap:0;padding-left:24px;display:grid}.hero--door .hero__stats{grid-template-columns:repeat(4,minmax(80px,auto))}.hero-stat{border-right:1px dashed var(--border);flex-direction:column;gap:4px;min-width:0;padding:4px 18px;display:flex}.hero-stat:last-child{border-right:0}.hero-stat__lbl{letter-spacing:.14em;color:var(--ink-faint);white-space:nowrap;font-size:9.5px;font-weight:500}.hero-stat__val{font-size:20px;font-weight:600;font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;letter-spacing:-.015em;font-variant-numeric:tabular-nums}.tabs{border-bottom:1px solid var(--border);gap:4px;padding:0 4px;display:flex}.tabs__btn{color:var(--ink-muted);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;align-items:center;gap:8px;margin-bottom:-1px;padding:10px 14px 12px;font-family:inherit;font-size:13.5px;font-weight:500;transition:color .15s,border-color .15s;display:inline-flex}.tabs__btn:hover{color:var(--ink)}.tabs__btn.is-active{color:var(--ink);border-bottom-color:var(--ink)}.tabs__count{letter-spacing:.06em;color:var(--ink-faint);background:var(--bg-alt);border:1px solid var(--border);border-radius:999px;padding:2px 6px;font-size:10px}.tabs__btn.is-active .tabs__count{color:var(--ink-muted);border-color:var(--border-strong)}.tab-content{margin-top:4px}.tab-grid{grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:14px;display:grid}.tab-grid--door{grid-template-columns:1fr}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:14px;padding:18px 20px;display:flex}.panel--span{grid-column:1}.panel--breach{border-color:color-mix(in oklab, var(--danger) 40%, var(--border))}.panel__head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.panel__title{letter-spacing:-.005em;font-size:14px;font-weight:600}.panel__title-wrap{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.panel__id,.panel__sub{color:var(--ink-faint);letter-spacing:.02em;font-size:11px}.panel__head-actions{align-items:center;gap:4px;display:flex}.time-pill{border:1px solid var(--border);color:var(--ink-muted);letter-spacing:.08em;cursor:pointer;background:0 0;border-radius:5px;padding:4px 9px;font-family:inherit;font-size:10.5px;font-weight:500;transition:all .15s}.time-pill:hover{border-color:var(--ink);color:var(--ink)}.time-pill.is-active{background:var(--ink);border-color:var(--ink);color:var(--surface)}.link{color:var(--accent);font-size:12.5px;font-weight:500;text-decoration:none}.link:hover{text-decoration:underline}.chart-card{margin-left:0;padding-left:0;position:relative}.chart-card__y{pointer-events:none;width:36px;position:absolute;top:0;bottom:28px;left:0}.chart-card__y span{color:var(--ink-faint);letter-spacing:.02em;font-variant-numeric:tabular-nums;font-size:9.5px;position:absolute;right:4px;transform:translateY(-50%)}.chart-card__x{pointer-events:none;height:16px;margin-top:2px;position:relative}.chart-card__x span{color:var(--ink-faint);letter-spacing:.02em;font-variant-numeric:tabular-nums;font-size:9.5px;position:absolute;transform:translate(-50%)}.chart-legend{color:var(--ink-muted);letter-spacing:.04em;flex-wrap:wrap;gap:18px;font-size:10.5px;display:flex}.chart-legend span{align-items:center;gap:6px;display:inline-flex}.chart-legend .dot{border-radius:2px;width:10px;height:3px}.chart-stack{flex-direction:column;gap:14px;display:flex}.rooms-summary{flex-direction:column;gap:10px;display:flex}.room-summary{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:12px;flex-direction:column;gap:10px;padding:16px 18px;transition:border-color .15s;display:flex}.room-summary:hover{border-color:var(--border-strong)}.room-summary__head{justify-content:space-between;align-items:center;gap:12px;display:flex}.room-summary__name-wrap{align-items:center;gap:10px;display:flex}.room-summary__color{border-radius:3px;flex-shrink:0;width:10px;height:10px}.room-summary__name{letter-spacing:-.01em;font-size:14px;font-weight:600}.room-summary__loc{color:var(--ink-faint);letter-spacing:.02em;margin-top:2px;font-size:10.5px}.room-summary__metrics{flex-wrap:wrap;align-items:baseline;gap:12px;display:flex}.room-summary__cur{font-size:26px;font-weight:600;font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;letter-spacing:-.025em;font-variant-numeric:tabular-nums;line-height:1}.room-summary__unit{color:var(--ink-muted);margin-left:2px;font-size:16px}.room-summary__stats{color:var(--ink-muted);flex-wrap:wrap;gap:6px;font-size:11px;display:flex}.room-summary__setpoint{color:var(--ink-faint);letter-spacing:.02em;font-size:10.5px}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table thead th{text-align:left;letter-spacing:.14em;color:var(--ink-faint);border-bottom:1px solid var(--border);font-size:9.5px;font-weight:500;font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;padding:8px 12px}.data-table tbody td{border-bottom:1px solid var(--border);color:var(--ink);vertical-align:middle;padding:11px 12px}.data-table tbody tr:last-child td{border-bottom:0}.data-table tbody tr:hover{background:var(--bg-alt)}.data-table--compact tbody td{padding:8px 12px}.data-table .dim{color:var(--ink-faint)}.breach-type-badge{letter-spacing:.12em;border:1px solid var(--border);background:var(--bg-alt);color:var(--ink-muted);white-space:nowrap;border-radius:4px;padding:3px 7px;font-size:9.5px;font-weight:500;display:inline-block}.breach-type-badge.is-high{color:var(--danger);background:color-mix(in oklab, var(--danger) 8%, var(--surface));border-color:color-mix(in oklab, var(--danger) 30%, transparent)}.breach-type-badge.is-low{color:var(--accent);background:color-mix(in oklab, var(--accent) 8%, var(--surface));border-color:color-mix(in oklab, var(--accent) 30%, transparent)}.breach-type-badge.is-door{color:var(--warn);background:color-mix(in oklab, var(--warn) 8%, var(--surface));border-color:color-mix(in oklab, var(--warn) 30%, transparent)}.pagination{justify-content:flex-end;align-items:center;gap:12px;margin-top:6px;display:flex}.pagination__btn{border:1px solid var(--border-strong);background:var(--surface);font-size:12px;font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;letter-spacing:.04em;color:var(--ink);cursor:pointer;border-radius:8px;padding:6px 14px;transition:all .15s}.pagination__btn:hover:not(:disabled){background:var(--bg-alt)}.pagination__btn:disabled{opacity:.4;cursor:default}.pagination__info{color:var(--ink-muted);letter-spacing:.04em;font-size:11.5px}.dx-rooms{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;display:grid}.dx-room{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;flex-direction:column;gap:12px;padding:16px 18px;transition:border-color .15s;display:flex}.dx-room:hover{border-color:var(--border-strong)}.dx-room__head{justify-content:space-between;align-items:center;gap:12px;display:flex}.dx-room__name-wrap{align-items:center;gap:10px;display:flex}.dx-room__icon{align-items:center;display:flex}.dx-room__name{letter-spacing:-.01em;font-size:14px;font-weight:600}.dx-room__loc{color:var(--ink-faint);letter-spacing:.02em;margin-top:2px;font-size:10.5px}.dx-room__state{align-items:baseline;gap:8px;display:flex}.dx-room__door{font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;letter-spacing:-.02em;font-size:24px;font-weight:600;line-height:1}.dx-room__door--open{color:var(--danger)}.dx-room__door--closed{color:var(--ok)}.dx-room__time{color:var(--ink-faint);letter-spacing:.02em;font-size:12px}.dx-room__stats{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.dx-room__num{font-size:15px;font-weight:600;font-family:var(--font-geist-mono,"Geist Mono"), ui-monospace, monospace;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.dx-room__lbl{letter-spacing:.14em;color:var(--ink-faint);margin-top:2px;font-size:9px;font-weight:500}.dx-table-room{align-items:center;gap:10px;display:flex}.dx-table-room__dot{background:var(--accent);border-radius:999px;flex-shrink:0;width:6px;height:6px}.dx-table-room__name{font-size:13px;font-weight:500}.dx-table-room__id{color:var(--ink-faint);letter-spacing:.02em;margin-top:1px;font-size:10.5px}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.filter-select{border:1px solid var(--border-strong);background:var(--surface);color:var(--ink);letter-spacing:.06em;cursor:pointer;border-radius:8px;padding:7px 10px;font-family:inherit;font-size:11px;transition:all .15s}.filter-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 14%, transparent);outline:none}.range-pills{background:var(--bg-alt);border:1px solid var(--border);border-radius:8px;gap:2px;padding:3px;display:flex}.range-pill{letter-spacing:.08em;color:var(--ink-muted);cursor:pointer;background:0 0;border:0;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:10.5px;font-weight:500;transition:all .15s}.range-pill.is-active{background:var(--surface);color:var(--ink);box-shadow:0 1px 3px #0c111c14}.filter-toggle{border:1px solid var(--border-strong);background:var(--surface);letter-spacing:.1em;color:var(--ink-muted);cursor:pointer;border-radius:8px;align-items:center;gap:7px;padding:6px 11px;font-family:inherit;font-size:10.5px;font-weight:500;transition:all .15s;display:inline-flex}.filter-toggle.is-active{background:var(--ink);border-color:var(--ink);color:var(--surface)}.filter-toggle__dot{background:var(--ink-faint);border-radius:999px;flex-shrink:0;width:7px;height:7px;transition:background .15s}.filter-toggle.is-active .filter-toggle__dot{background:var(--danger);box-shadow:0 0 0 2px color-mix(in oklab, var(--danger) 25%, transparent)}.overlay-note{color:var(--ink-faint);letter-spacing:.04em;border-top:1px dashed var(--border);padding-top:4px;font-size:10.5px}.login-wrapper{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative}.login-wrapper:before{content:"";pointer-events:none;background-image:linear-gradient(#0c111c0a 1px,#0000 1px),linear-gradient(90deg,#0c111c0a 1px,#0000 1px);background-size:28px 28px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(at 50% 30%,#000 25%,#0000 70%);mask-image:radial-gradient(at 50% 30%,#000 25%,#0000 70%)}.login-wrapper:after{content:"";background:radial-gradient(ellipse 60% 50% at 50% 40%, color-mix(in oklab, var(--accent) 10%, transparent), transparent 70%);pointer-events:none;position:absolute;inset:0}.chrome{z-index:5;pointer-events:none;color:var(--ink-faint);letter-spacing:.04em;white-space:nowrap;align-items:center;gap:10px;font-size:11px;display:none;position:fixed}.chrome--tl{align-items:center;top:28px;left:32px}.chrome--tr{top:28px;right:32px}.chrome__sep{color:var(--ink-faint);opacity:.5}.chrome__status{color:var(--ok);letter-spacing:.08em;font-weight:500}.chrome__time{font-variant-numeric:tabular-nums}.ping-dot-static{background:var(--ok);width:6px;height:6px;box-shadow:0 0 0 3px color-mix(in oklab, var(--ok) 22%, transparent);border-radius:999px;flex-shrink:0;animation:1.8s ease-in-out infinite blink}.login{z-index:1;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:48px 36px;display:flex;position:relative}.login__inner{background:var(--surface);border:1px solid var(--border);z-index:1;border-radius:16px;flex-direction:column;gap:24px;width:100%;max-width:400px;padding:36px 32px;display:flex;position:relative;box-shadow:0 1px 2px #0c111c0a,0 20px 48px -20px #0c111c2e}.login__mobile-brand{align-items:center;gap:12px;margin-bottom:4px;display:flex}.login__head{flex-direction:column;gap:10px;display:flex}.login__eyebrow{letter-spacing:.14em;color:var(--accent);white-space:nowrap;align-items:center;gap:8px;width:fit-content;font-size:10.5px;font-weight:500;display:inline-flex}.login__eyebrow-dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 22%, transparent);border-radius:999px}.login__title{letter-spacing:-.025em;font-size:28px;font-weight:600;line-height:1.15}.login__sub{color:var(--ink-muted);font-size:14.5px}.form{flex-direction:column;gap:14px;margin-top:4px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field__label{letter-spacing:.16em;color:var(--ink-muted);font-size:10px;font-weight:500}.field__wrap{border:1px solid var(--border-strong);background:var(--surface);height:var(--field-h);border-radius:10px;align-items:stretch;transition:border-color .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden}.field.is-focused .field__wrap{border-color:var(--accent);box-shadow:0 0 0 4px color-mix(in oklab, var(--accent) 14%, transparent)}.field__input{min-width:0;color:var(--ink);background:0 0;border:0;outline:0;flex:1;padding:0 14px;font-family:inherit;font-size:14.5px}.field__input::placeholder{color:var(--ink-faint)}.field__trailing{align-items:center;padding-right:10px;display:flex}.field__toggle{letter-spacing:.14em;color:var(--ink-muted);cursor:pointer;background:0 0;border:0;border-radius:6px;padding:4px 8px;font-family:inherit;font-size:10px;font-weight:500}.field__toggle:hover{background:var(--bg-alt);color:var(--ink)}.login .btn-primary{width:100%;height:var(--field-h);border-radius:10px;font-size:14px}.form__error{color:var(--danger);background:color-mix(in oklab, var(--danger) 7%, var(--surface));border:1px solid;border-color:color-mix(in oklab, var(--danger) 30%, transparent);border-radius:10px;align-items:center;gap:10px;padding:10px 12px;font-size:13px;display:flex}.form__error-dot{background:var(--danger);border-radius:999px;flex-shrink:0;width:8px;height:8px}.login__footnote{background:var(--bg-alt);border:1px dashed var(--border-strong);color:var(--ink-muted);border-radius:10px;padding:10px 12px;font-size:11px}.login__bottom{text-align:center;color:var(--ink-faint);letter-spacing:.04em;font-size:11px}.invite-card{background:var(--bg-alt);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:12px;padding:14px 16px;display:flex}.invite-card__row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:18px;display:grid}.invite-card__col{min-width:0}.invite-card__lbl{letter-spacing:.16em;color:var(--ink-faint);margin-bottom:4px;font-size:9.5px;font-weight:500}.invite-card__val{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:500;overflow:hidden}.invite-card__foot{color:var(--ink-faint);letter-spacing:.02em;border-top:1px dashed var(--border-strong);padding-top:10px;font-size:11px}.invite-card__foot strong{color:var(--ink-muted);font-weight:500}.role-badge{letter-spacing:.14em;background:var(--bg-alt);color:var(--ink-muted);border:1px solid var(--border-strong);border-radius:4px;padding:3px 8px;font-size:10px;font-weight:600;display:inline-block}.role-badge--admin{color:var(--accent);background:color-mix(in oklab, var(--accent) 8%, var(--surface));border-color:color-mix(in oklab, var(--accent) 30%, transparent)}.role-badge--viewer{color:var(--ink-muted)}.strength{align-items:center;gap:10px;margin-top:-8px;display:flex}.strength__bars{flex:1;gap:4px;min-width:0;display:flex}.strength__bar{background:var(--border);border-radius:2px;flex:1;height:4px;transition:background .2s}.strength__bar.is-on{background:var(--ink-muted)}.strength--1 .strength__bar.is-on{background:var(--danger)}.strength--2 .strength__bar.is-on{background:var(--warn)}.strength--3 .strength__bar.is-on{background:color-mix(in oklab, var(--accent) 50%, var(--ok))}.strength--4 .strength__bar.is-on{background:var(--ok)}.strength__label{letter-spacing:.14em;white-space:nowrap;color:var(--ink-muted);font-size:10px;font-weight:600}.strength--1 .strength__label{color:var(--danger)}.strength--2 .strength__label{color:var(--warn)}.strength--3 .strength__label{color:var(--ink-muted)}.strength--4 .strength__label{color:var(--ok)}.reqs{color:var(--ink-faint);letter-spacing:.02em;grid-template-columns:1fr 1fr;gap:6px 16px;font-size:11px;list-style:none;display:grid}.reqs li{align-items:center;gap:8px;transition:color .15s;display:flex}.reqs li.is-met{color:var(--ok)}.reqs__icon{background:var(--bg-alt);border:1px solid var(--border);color:currentColor;border-radius:4px;flex-shrink:0;place-items:center;width:14px;height:14px;display:inline-grid}.reqs li.is-met .reqs__icon{background:color-mix(in oklab, var(--ok) 12%, var(--surface));border-color:color-mix(in oklab, var(--ok) 30%, transparent)}.reqs__dot{background:var(--ink-faint);border-radius:999px;width:4px;height:4px}.invite-success{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:12px 4px 4px;display:flex}.invite-success__icon{background:color-mix(in oklab, var(--ok) 12%, var(--surface));width:56px;height:56px;color:var(--ok);border-radius:999px;place-items:center;margin-bottom:8px;display:grid}.invite-success__title{letter-spacing:-.02em;font-size:22px;font-weight:600}.invite-success__sub{color:var(--ink-muted);font-size:13.5px}.invite-success__progress{background:var(--bg-alt);border:1px solid var(--border);border-radius:2px;width:100%;height:3px;margin-top:12px;overflow:hidden}.invite-success__progress span{background:var(--accent);width:0;height:100%;animation:2.4s linear forwards invite-progress;display:block}@keyframes invite-progress{to{width:100%}}.content--cfg{gap:18px;max-width:880px}.cfg-nav{background:var(--surface);border:1px solid var(--border);scrollbar-width:none;border-radius:999px;align-self:flex-start;gap:4px;padding:4px;display:flex;overflow-x:auto}.cfg-nav::-webkit-scrollbar{display:none}.cfg-nav__item{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);white-space:nowrap;border-radius:999px;padding:6px 12px;font-size:11px;font-weight:500;text-decoration:none;transition:all .15s}.cfg-nav__item:hover{color:var(--ink);background:var(--bg-alt)}.cfg-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;scroll-margin-top:90px}.cfg-section__head{border-bottom:1px solid var(--border);align-items:flex-start;gap:14px;margin-bottom:4px;padding-bottom:18px;display:flex}.cfg-section__icon{background:var(--bg-alt);border:1px solid var(--border);width:38px;height:38px;color:var(--ink-muted);border-radius:10px;flex-shrink:0;place-items:center;display:grid}.cfg-section__title-wrap{flex:1;min-width:0}.cfg-section__title{letter-spacing:-.012em;margin-bottom:4px;font-size:16px;font-weight:600}.cfg-section__desc{color:var(--ink-muted);max-width:56ch;font-size:13px;line-height:1.5}.cfg-section__body{flex-direction:column;margin-top:6px;display:flex}.cfg-section__foot{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:14px;margin-top:12px;padding-top:18px;display:flex}.cfg-section--dense{padding:20px 22px}.cfg-section--dense .cfg-section__head{margin-bottom:14px;padding-bottom:14px}.cfg-row{border-bottom:1px dashed var(--border);grid-template-columns:minmax(0,1fr) minmax(220px,auto);align-items:center;gap:24px;padding:18px 0;display:grid}.cfg-row:last-child{border-bottom:0}.cfg-row__lbl{min-width:0}.cfg-row__label{letter-spacing:-.005em;color:var(--ink);font-size:13.5px;font-weight:500}.cfg-row__hint{color:var(--ink-muted);max-width:60ch;margin-top:4px;font-size:12px;line-height:1.45}.cfg-row__ctrl{justify-content:flex-end;align-items:center;display:flex}.cfg-row-pair{border-bottom:1px dashed var(--border);grid-template-columns:1fr 1fr;gap:18px;padding:0;display:grid}.cfg-row-pair .cfg-row{border-bottom:0;padding:18px 0}.cfg-row-pair .cfg-row:first-child{border-right:1px dashed var(--border);padding-right:18px}.cfg-row-pair .cfg-row:last-child{padding-left:18px}.cfg-input-wrap{border:1px solid var(--border-strong);background:var(--surface);border-radius:8px;align-items:stretch;transition:all .15s;display:inline-flex;overflow:hidden}.cfg-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 14%, transparent)}.cfg-input{color:var(--ink);text-align:right;font-variant-numeric:tabular-nums;background:0 0;border:0;outline:0;width:120px;padding:9px 12px;font-family:inherit;font-size:13.5px}.cfg-input[type=time]{text-align:left;width:110px}.cfg-input[type=email],.cfg-input[type=text]{text-align:left}.cfg-input--wide{width:240px}.cfg-input::placeholder{color:var(--ink-faint)}.cfg-input-suffix{letter-spacing:.14em;color:var(--ink-faint);background:var(--bg-alt);border-left:1px solid var(--border);align-items:center;padding:0 12px;font-size:10px;font-weight:500;display:inline-flex}.cfg-switch{background:var(--border-strong);cursor:pointer;border:0;border-radius:999px;flex-shrink:0;width:38px;height:22px;padding:0;transition:background .18s;position:relative}.cfg-switch__thumb{background:var(--surface);border-radius:999px;width:18px;height:18px;transition:transform .18s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0000002e}.cfg-switch.is-on{background:var(--accent)}.cfg-switch.is-on .cfg-switch__thumb{transform:translate(16px)}.cfg-saved{letter-spacing:.12em;color:var(--ok);align-items:center;gap:7px;font-size:10.5px;font-weight:600;display:inline-flex}.cfg-saved__dot{background:var(--ok);width:7px;height:7px;box-shadow:0 0 0 3px color-mix(in oklab, var(--ok) 22%, transparent);border-radius:999px}.cfg-rooms{flex-direction:column;gap:12px;padding:14px 0;display:flex}.cfg-room{background:var(--bg-alt);border:1px solid var(--border);border-radius:10px;grid-template-columns:200px minmax(0,1fr) auto;align-items:center;gap:16px;padding:14px 16px;display:grid}.cfg-room__sensor{align-items:center;gap:8px;display:flex}.cfg-room__id{color:var(--ink-faint);letter-spacing:.02em;font-size:11px}.cfg-room__fields{grid-template-columns:1fr 1fr;gap:10px;display:grid}.cfg-room__field{flex-direction:column;gap:4px;min-width:0;display:flex}.cfg-room__field-lbl{letter-spacing:.16em;color:var(--ink-faint);font-size:9px;font-weight:500}.cfg-room .cfg-input{border:1px solid var(--border-strong);background:var(--surface);text-align:left;border-radius:7px;width:100%;padding:7px 10px;font-size:13px}.cfg-room__meta{color:var(--ink-faint);letter-spacing:.04em;white-space:nowrap;align-items:center;gap:6px;font-size:10.5px;display:flex}.cfg-room__sensor-id{color:var(--ink-muted)}.pp-counters{align-self:center;gap:8px;margin-left:auto;display:flex}.pp-counter{letter-spacing:.12em;border-radius:999px;align-items:center;gap:6px;padding:4px 9px;font-size:10px;font-weight:600;display:inline-flex}.pp-counter .dot{background:currentColor;border-radius:999px;width:6px;height:6px}.pp-counter--ok{color:var(--ok);background:color-mix(in oklab, var(--ok) 10%, var(--surface));border:1px solid color-mix(in oklab, var(--ok) 25%, transparent)}.pp-counter--warn{color:var(--warn);background:color-mix(in oklab, var(--warn) 10%, var(--surface));border:1px solid color-mix(in oklab, var(--warn) 25%, transparent)}.pp-avatar{background:var(--bg-alt);border:1px solid var(--border-strong);width:34px;height:34px;color:var(--ink);border-radius:10px;flex-shrink:0;place-items:center;font-size:14px;font-weight:600;display:grid}.pp-avatar--admin{background:var(--ink);color:var(--surface);border-color:var(--ink)}.pp-table-wrap{margin:-4px 0}.pp-table thead th{padding:12px}.pp-table tbody td{padding:14px 12px}.pp-user{align-items:center;gap:12px;display:flex}.pp-user__txt{min-width:0}.pp-user__email{align-items:center;gap:8px;font-size:13.5px;font-weight:500;display:inline-flex}.pp-you{letter-spacing:.18em;background:var(--ink);color:var(--surface);border-radius:4px;padding:2px 6px;font-size:9px;font-weight:600}.pp-user__last{color:var(--ink-faint);letter-spacing:.02em;margin-top:3px;font-size:10.5px}.pp-actions{justify-content:flex-end;align-items:center;gap:12px;display:inline-flex}.pp-action-link{color:var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border:0;padding:4px 0;font-family:inherit;font-size:12.5px;font-weight:500}.pp-action-link:hover{text-decoration:underline}.pp-remove{color:var(--danger);cursor:pointer;background:0 0;border:0;padding:4px 0;font-family:inherit;font-size:12.5px;font-weight:500;transition:opacity .15s}.pp-remove:hover{opacity:.7;text-decoration:underline}.pp-self{color:var(--ink-faint);font-size:14px}.pp-table tbody tr.is-pending{background:color-mix(in oklab, var(--warn) 3%, transparent)}.pp-table tbody tr.is-pending:hover{background:color-mix(in oklab, var(--warn) 6%, var(--bg-alt))}.pp-twocol{grid-template-columns:1fr 1fr;gap:18px;display:grid}.pp-form{flex-direction:column;gap:14px;display:flex}.pp-field{flex-direction:column;gap:5px;display:flex}.pp-field__lbl{letter-spacing:.16em;color:var(--ink-muted);font-size:10px;font-weight:500}.pp-input{border:1px solid var(--border-strong);background:var(--surface);width:100%;color:var(--ink);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:13.5px;transition:all .15s}.pp-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 14%, transparent);outline:0}.pp-input::placeholder{color:var(--ink-faint)}.pp-form__foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:6px;display:flex}.pp-note{color:var(--ink-faint);letter-spacing:.02em;flex:1;min-width:0;max-width:30ch;font-size:11px}.pp-msg{border:1px solid;border-radius:8px;align-items:center;gap:8px;padding:9px 12px;font-size:12.5px;font-weight:500;display:inline-flex}.pp-msg__dot{background:currentColor;border-radius:999px;flex-shrink:0;width:7px;height:7px}.pp-msg--ok{color:var(--ok);background:color-mix(in oklab, var(--ok) 8%, var(--surface));border-color:color-mix(in oklab, var(--ok) 25%, transparent)}.pp-msg--error{color:var(--danger);background:color-mix(in oklab, var(--danger) 8%, var(--surface));border-color:color-mix(in oklab, var(--danger) 25%, transparent)}.pp-modal-scrim{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:40;background:#080c148c;place-items:center;padding:24px;animation:.15s scrim-in;display:grid;position:fixed;inset:0}.pp-modal{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:16px;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:420px;padding:28px;animation:.18s modal-in;display:flex;box-shadow:0 24px 60px -16px #00000059}@keyframes modal-in{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:none}}.pp-modal__icon{background:color-mix(in oklab, var(--danger) 12%, var(--surface));width:48px;height:48px;color:var(--danger);border-radius:999px;place-items:center;margin-bottom:4px;display:grid}.pp-modal__title{letter-spacing:-.015em;font-size:18px;font-weight:600}.pp-modal__desc{color:var(--ink-muted);max-width:38ch;font-size:13.5px;line-height:1.5}.pp-modal__actions{gap:8px;width:100%;margin-top:12px;display:flex}.pp-modal__actions>*{flex:1}@media (min-width:700px){.chrome{display:inline-flex}.login__mobile-brand{display:none!important}}@media (max-width:1180px){.rooms-list__header,.room-row{grid-template-columns:minmax(0,2fr) 80px 160px 170px 130px;gap:12px}}@media (max-width:980px){:root{--sidebar-w:0px}.app{grid-template-columns:1fr}.sidebar{width:280px;height:100vh;transition:transform .22s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:0 24px 64px -16px #0003}.sidebar.is-open{transform:translate(0)}.sidebar__close{place-items:center;display:grid}.topbar__menu{display:inline-flex}.stats,.stats--4{grid-template-columns:repeat(2,1fr)}.stat:nth-child(2){border-right:0}.stat:first-child,.stat:nth-child(2){border-bottom:1px solid var(--border)}.rooms-list__header{display:none}.room-row{grid-template-columns:1fr;gap:8px;padding:14px 18px}.room-row__cell--chart{display:none}.room-row__cell--ping{justify-content:flex-start}.hero{grid-template-columns:1fr;gap:18px;padding:20px}.hero__stats{border-left:0;border-top:1px solid var(--border);grid-template-columns:repeat(3,1fr);padding-top:16px;padding-left:0}.hero--door .hero__stats{grid-template-columns:repeat(2,1fr)}.hero-stat{border-right:0;padding:4px 0}.tab-grid,.pp-twocol{grid-template-columns:1fr}.pp-counters{flex-wrap:wrap;align-self:flex-start;margin-left:0}}@media (max-width:880px){.cfg-row{grid-template-columns:1fr;gap:10px}.cfg-row__ctrl{justify-content:flex-start}.cfg-row-pair{border-bottom:0;grid-template-columns:1fr}.cfg-row-pair .cfg-row{border-bottom:1px dashed var(--border);padding:16px 0}.cfg-row-pair .cfg-row:first-child{border-right:0;padding-right:0}.cfg-row-pair .cfg-row:last-child{border-bottom:0;padding-left:0}}@media (max-width:720px){.topbar__sub{display:none}.topbar{padding:14px 16px}.content{padding:16px}.rooms-grid,.stats{grid-template-columns:1fr}.stat{border-bottom:1px solid var(--border);border-right:0!important}.stat:last-child{border-bottom:0}.room__core{grid-template-columns:1fr;gap:12px}.room__chart{width:100%}.hero__value{font-size:44px}.hero__value--door{font-size:36px}.hero__stats{grid-template-columns:repeat(2,1fr)!important}.tabs{scrollbar-width:none;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tabs__btn{white-space:nowrap;flex-shrink:0}.panel{padding:14px}.data-table{font-size:12px}.data-table thead th{padding:8px}.data-table tbody td{padding:10px 8px}.cfg-section{padding:18px}.cfg-section__icon{width:32px;height:32px}.cfg-room{grid-template-columns:1fr;gap:12px}.pp-user__last{display:none}.topbar--detail .topbar__title-row h1{font-size:21px}.login__inner{padding:28px 24px}}@media (max-width:520px){.pp-table thead th:nth-child(3),.pp-table tbody td:nth-child(3){display:none}}@media (max-width:480px){.topbar__title h1{font-size:18px}.live-indicator{display:none}.reqs{grid-template-columns:1fr}.invite-card__row{grid-template-columns:1fr;gap:10px}.cfg-room__fields{grid-template-columns:1fr}.topbar__actions .btn-ghost{display:none}}
@font-face{font-family:GeistSans;src:url(../media/Geist_Variable-s.p.0-te~ja_gpvcf.woff2)format("woff2");font-display:swap;font-weight:100 900}@font-face{font-family:GeistSans Fallback;src:local(Arial);ascent-override:94.56%;descent-override:27.76%;line-gap-override:0.0%;size-adjust:106.28%}.geistsans_d5a4f12f-module__Ur3q_a__className{font-family:GeistSans,GeistSans Fallback}.geistsans_d5a4f12f-module__Ur3q_a__variable{--font-geist-sans:"GeistSans", "GeistSans Fallback"}
@font-face{font-family:GeistMono;src:url(../media/GeistMono_Variable.p.17jn9btb_52pq.woff2)format("woff2");font-display:swap;font-weight:100 900}.geistmono_157ca88a-module__iaM1Ya__className{font-family:GeistMono,ui-monospace,SFMono-Regular,Roboto Mono,Menlo,Monaco,Liberation Mono,DejaVu Sans Mono,Courier New,monospace}.geistmono_157ca88a-module__iaM1Ya__variable{--font-geist-mono:"GeistMono", ui-monospace, SFMono-Regular, Roboto Mono, Menlo, Monaco, Liberation Mono, DejaVu Sans Mono, Courier New, monospace}
