:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f5f7f9;--surface:#fff;--surface-raised:#fff;--surface-sunken:#eef1f4;--border:#e4e8eb;--border-strong:#c8d0d6;--text:#1f2429;--text-dim:#5a6470;--text-faint:#6f7882;--accent:#3b6fa4;--accent-soft:#e6eef6;--success:#3aa28b;--success-soft:#e4f1ec;--warn:#c79a4a;--warn-soft:#f7eedc;--danger:#c25b48;--danger-soft:#f7e1dc;--font-display:"Pretendard Variable", Pretendard, "Noto Sans KR", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Pretendard Variable", Pretendard, "Noto Sans KR", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--text-display:32px;--text-title:18px;--text-body:14px;--text-caption:12px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--page-gutter-x:clamp(12px, 2.4vw, 24px);--page-gutter-y:clamp(12px, 2vw, 24px);--app-canvas-w:1200px;--radius-input:8px;--radius-panel:12px;--radius-pill:999px;--shadow-rest:0 1px 2px #0f172a0a;--shadow-raise:0 8px 24px #0f172a14;--shadow-focus:0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent);--motion-fast:.12s cubic-bezier(.2, 0, 0, 1);--motion-base:.18s cubic-bezier(.2, 0, 0, 1);--ink:var(--text);--ink-soft:var(--text);--ink-mute:var(--text-dim);--cream:var(--bg);--cream-deep:var(--surface-sunken);--paper:var(--surface);--lime:#b4cde2;--lime-deep:var(--accent);--lime-soft:var(--accent-soft);--lime-tint:#f1f5f9;--brand-twin:var(--accent);--coral:var(--danger);--smog:var(--text-dim);--whisper:var(--text-faint);--pollutant-particles:var(--smog);--pollutant-voc:var(--chart-voc);--pollutant-nox:var(--chart-nox);--chart-temp:#c2410c;--chart-voc:#6d28d9;--chart-nox:#0f766e;--tk-bg:var(--bg);--tk-surface:var(--surface);--tk-surface-soft:var(--surface-sunken);--tk-border:var(--border);--tk-text-strong:var(--text);--tk-text:var(--text);--tk-text-muted:var(--text-dim);--tk-primary:var(--accent);--tk-ozone:var(--success);--tk-danger:var(--danger);--tk-success:var(--success);--tk-radius:var(--radius-panel);--tk-shadow:var(--shadow-rest);--tk-field-h:38px;--body-dot:#0f172a06;--body-dot-size:24px;--live-dashboard:var(--font-body);--serif:var(--font-display);--sans:var(--font-body);--display:var(--font-display);--mono:var(--font-mono);--theme-select-fill:var(--accent);--theme-select-label:#fff;--theme-select-border:var(--border-strong);--theme-select-sheen:inset 0 0 0 1px #ffffff2e;font-family:var(--font-body);color:var(--text);background-color:var(--bg)}@media (width>=768px){:root{--text-display:40px}}*{box-sizing:border-box}html{--app-gutter-x:var(--page-gutter-x);--app-gutter-y:var(--page-gutter-y)}html,body{min-height:100%;margin:0;overflow-x:hidden}body{font-family:var(--font-body);color:var(--text);background-color:var(--bg);background-image:radial-gradient(circle at 1px 1px, var(--body-dot) 1px, transparent 0);background-size:var(--body-dot-size) var(--body-dot-size);-webkit-font-smoothing:antialiased;font-weight:400;line-height:1.55}#root{flex-direction:column;min-width:0;max-width:100%;min-height:100vh;display:flex;overflow-x:hidden}:lang(ko){word-break:keep-all;line-height:1.62}:lang(ko) input,:lang(ko) select,:lang(ko) textarea,:lang(ko) button{line-height:inherit}:focus-visible,button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible{box-shadow:var(--shadow-focus);outline:none}@media (prefers-reduced-motion:reduce){:root{--motion-fast:1ms linear;--motion-base:1ms linear}*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important}}.app{width:100%;max-width:none;padding:var(--app-gutter-y) var(--app-gutter-x) clamp(20px, 3.5vw, 48px);color:var(--ink);box-sizing:border-box;margin:0}.header{border-bottom:1px solid var(--ink);min-width:0;max-width:100%;margin-bottom:0;padding-bottom:24px}.header>div:first-child{min-width:0;max-width:100%}.header h1{font-family:var(--serif);letter-spacing:-.03em;font-size:clamp(28px,4vw,42px);font-weight:700;line-height:1.05}.sub{color:var(--ink-mute);margin:0;font-weight:400}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.live-device-strip{box-sizing:border-box;width:100%;min-width:0;max-width:100%;margin:0}.live-device-strip-inner{box-sizing:border-box;flex-flow:row;justify-content:flex-end;align-items:center;width:100%;min-width:0;max-width:100%;padding:clamp(8px,1.5vw,12px) clamp(10px,2.4vw,20px);display:flex;overflow-x:hidden;container:livedev/inline-size}input{border:1.5px solid var(--ink);background:var(--paper);min-width:190px;color:var(--ink);font-family:var(--sans);border-radius:12px;padding:11px 12px}input::placeholder{color:var(--whisper)}input:focus-visible{outline:2px solid var(--lime);outline-offset:2px}select{border:1.5px solid var(--ink);box-sizing:border-box;background:var(--paper);min-width:190px;max-width:420px;color:var(--ink);font-family:var(--sans);border-radius:12px;padding:10px 12px}select:focus-visible{outline:2px solid var(--lime);outline-offset:2px}.controls-row.live-device-row{flex-wrap:nowrap;flex:0 auto;justify-content:flex-end;align-items:stretch;gap:clamp(4px,1.4vw,12px);width:auto;min-width:0;max-width:100%;display:flex}.live-device-select-label{flex-flow:row;flex:auto;justify-content:flex-start;align-items:stretch;gap:clamp(4px,1.4vw,12px);min-width:0;max-width:100%;display:flex}.live-device-select-heading{font-family:var(--serif);letter-spacing:-.03em;text-transform:none;color:var(--ink);flex-shrink:0;align-self:center;font-size:clamp(14px,1.35vw,17px);font-weight:700;line-height:1.15}.live-device-select-wrap{flex:12rem;align-items:stretch;width:auto;min-width:0;max-width:min(420px,100%);display:flex}.live-device-select-wrap select{box-sizing:border-box;text-overflow:ellipsis;align-self:stretch;width:100%;min-width:0;max-width:100%;height:100%;min-height:44px;overflow:hidden}@container livedev (width<=520px){.live-device-select-heading{display:none}}.controls-row.live-device-row>button.live-device-load-btn{white-space:nowrap;box-sizing:border-box;flex-shrink:0;justify-content:center;align-self:stretch;align-items:center;height:auto;min-height:44px;padding:10px 14px;display:inline-flex}.admin-page{--admin-field-h:38px}.admin-page .panel input[type=text],.admin-page .panel input[type=number],.admin-page .panel input[type=password],.admin-page .panel input[type=search],.admin-page .panel input[type=email],.admin-page .panel input:not([type]),.admin-page .panel select,.admin-page .panel textarea{box-sizing:border-box;width:100%;min-width:0;max-width:100%;height:var(--admin-field-h);font-size:13px;font-family:var(--sans);color:var(--tk-text-strong);background:var(--tk-surface);border:1px solid var(--tk-border);box-shadow:none;border-radius:8px;padding:0 12px;transition:border-color .12s,box-shadow .12s}.admin-page .panel textarea{resize:vertical;height:auto;min-height:120px;padding:10px 12px;line-height:1.4}.admin-page .panel input:focus-visible,.admin-page .panel select:focus-visible,.admin-page .panel textarea:focus-visible{border-color:var(--tk-primary);box-shadow:0 0 0 3px color-mix(in srgb, var(--tk-primary) 22%, transparent);outline:none}.admin-page .panel input::placeholder,.admin-page .panel textarea::placeholder{color:var(--tk-text-muted)}.admin-page .panel input:disabled,.admin-page .panel select:disabled,.admin-page .panel textarea:disabled{background:var(--tk-surface-soft);color:var(--tk-text-muted);cursor:not-allowed}.admin-page .admin-filter-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));align-items:end;gap:14px 12px;margin-bottom:14px;display:grid}.admin-page .admin-filter-grid label,.admin-page .admin-address-block label{flex-direction:column;gap:6px;min-width:0;display:flex}.admin-page .admin-filter-grid label span,.admin-page .admin-address-block label span{font-size:11px;font-weight:700;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--tk-text-muted)}.admin-page .admin-panel-actions{border-top:1px solid var(--tk-border);flex-wrap:wrap;align-items:center;gap:10px;margin-top:16px;padding-top:14px;display:flex}.admin-page .admin-edit-actions{border-top:1px solid var(--tk-border);margin-top:16px;padding-top:14px}:root{--tk-field-h:38px}button.btn-primary,.btn-primary{height:var(--tk-field-h);background:var(--tk-primary);color:#fff;border:1px solid var(--tk-primary);cursor:pointer;border-radius:8px;padding:0 20px;font-size:13px;font-weight:700;transition:filter .12s,transform 80ms}button.btn-primary:hover:not(:disabled),.btn-primary:hover:not(:disabled){filter:brightness(.94)}button.btn-primary:disabled,.btn-primary:disabled{opacity:.5;cursor:not-allowed}button.btn-ghost,.btn-ghost{height:var(--tk-field-h);color:var(--tk-text-strong);border:1px solid var(--tk-border);cursor:pointer;background:0 0;border-radius:8px;padding:0 16px;font-size:13px;font-weight:700}button.btn-ghost:hover:not(:disabled),.btn-ghost:hover:not(:disabled){background:var(--tk-surface-soft)}button.btn-ghost:disabled,.btn-ghost:disabled{opacity:.5;cursor:not-allowed}button.btn-danger,.btn-danger{height:var(--tk-field-h);background:var(--tk-danger);color:#fff;border:1px solid var(--tk-danger);cursor:pointer;border-radius:8px;padding:0 20px;font-size:13px;font-weight:700;transition:filter .12s}button.btn-danger:hover:not(:disabled),.btn-danger:hover:not(:disabled){filter:brightness(.94)}button.btn-danger:disabled,.btn-danger:disabled{opacity:.5;cursor:not-allowed}.admin-table-wrap{border:1.5px solid var(--ink);background:var(--paper);overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:13px;font-family:var(--sans)}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--ink);vertical-align:top;padding:10px 12px}.admin-table th{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);background:var(--cream-deep);font-size:10px}.admin-table tr:last-child td{border-bottom:none}.admin-table td.row-actions-cell{white-space:nowrap}.admin-table .row-actions{flex-wrap:wrap;align-items:center;gap:8px;min-width:0;display:flex}.admin-table .row-act{border:1px solid var(--tk-border);background:var(--tk-surface-soft);height:30px;color:var(--tk-text-strong);white-space:nowrap;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0 12px;font-size:12px;font-weight:600;line-height:1;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.admin-table .row-act:hover:not(:disabled){background:var(--cream-deep,var(--tk-surface))}.admin-table .row-act:disabled{opacity:.5;cursor:not-allowed}.admin-table .row-act-group{border:1px solid var(--tk-border);background:#00000005;border-radius:10px;align-items:center;gap:4px;padding:3px;display:inline-flex}.admin-table .row-act-group .row-act{background:0 0;border-color:#0000;height:26px;padding:0 10px}.admin-table .row-act-group .row-act:hover:not(:disabled){background:var(--tk-surface);border-color:var(--tk-border)}.admin-table .row-act-primary{background:var(--lime,var(--tk-primary));color:var(--ink,#111);border-color:var(--lime,var(--tk-primary))}.admin-table .row-act-group .row-act.row-act-primary{background:var(--lime,var(--tk-primary));border-color:var(--lime,var(--tk-primary));color:var(--ink,#111)}.admin-table .row-act-primary:hover:not(:disabled),.admin-table .row-act-group .row-act.row-act-primary:hover:not(:disabled){filter:brightness(.95)}.admin-table .row-act-danger{color:#b4281e;background:0 0;border-color:#b4281e59;margin-inline-start:auto}.admin-table .row-act-danger:hover:not(:disabled){background:#b4281e14;border-color:#b4281e8c}.admin-table .row-act-danger:disabled{color:var(--tk-text-mute,#888);border-color:var(--tk-border)}.admin-table .firmware-badge{background:var(--lime,#d4f57a);color:var(--ink,#111);border:1px solid var(--lime,#c5e85f);border-radius:999px;margin-top:4px;padding:1px 8px;font-size:11px;font-weight:600;line-height:1.5;display:inline-block}.admin-edit-modal{margin-top:16px}.admin-edit-actions{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.admin-user-pick{grid-template-columns:minmax(0,480px);gap:8px;margin-bottom:12px;display:grid}.admin-user-pick label{flex-direction:column;align-items:stretch;gap:6px;min-width:0;display:flex}.admin-user-pick label span{font-size:11px;font-weight:700;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--tk-text-muted)}.admin-user-select,.admin-user-search-input{width:100%;min-width:0}.admin-address-block{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;width:100%;margin:14px 0 16px;display:grid}.admin-address-block label{flex-direction:column;gap:6px;min-width:0;display:flex}.admin-address-block label span{font-size:11px;font-weight:700;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute)}.admin-address-select,.admin-address-detail-input{width:100%;min-width:0;max-width:100%}.admin-address-detail{grid-column:1/-1}@media (width>=720px){.admin-address-detail{grid-column:span 2}}.admin-assign-text{width:100%;min-height:120px;font-family:var(--mono);font-size:12px;line-height:1.4}.admin-user-list{margin:12px 0 0;padding:0;list-style:none}.admin-user-list li{border-bottom:1px solid var(--ink);padding:8px 0;font-size:13px}button{border:2px solid var(--ink);background:var(--lime);color:var(--ink);cursor:pointer;font-weight:700;font-family:var(--serif);letter-spacing:-.01em;box-shadow:4px 4px 0 var(--ink);border-radius:12px;padding:11px 15px;transition:transform .15s cubic-bezier(.4,0,.2,1),box-shadow .15s cubic-bezier(.4,0,.2,1)}button:hover:not(:disabled){filter:brightness(1.03)}button:active:not(:disabled){box-shadow:2px 2px 0 var(--ink);transform:translate(2px,2px)}button:focus-visible{outline:2px solid var(--lime-deep);outline-offset:3px}button:disabled{opacity:.55;cursor:not-allowed;box-shadow:2px 2px 0 var(--smog)}button.btn-secondary{background:var(--cream-deep);color:var(--ink);box-shadow:3px 3px 0 var(--ink)}.controls-row-narrow input{flex:1;min-width:280px}.live-status-admin-footer{margin-top:32px}.live-status-admin-footer .live-status-toggle-row{margin-top:0}.live-status-toggle-row{margin-top:14px}.live-status-toggle{font-size:14px}.status{scrollbar-width:thin;min-width:0;font-size:14px;font-family:var(--sans);letter-spacing:-.01em;text-transform:none;color:var(--ink);border:1.5px solid var(--ink);background:var(--cream-deep);font-variant-numeric:tabular-nums;background-image:none;border-radius:0;flex-wrap:nowrap;align-items:baseline;gap:clamp(6px,1.2vw,12px) clamp(8px,1.5vw,16px);margin-top:10px;padding:14px 16px;font-weight:700;line-height:1.45;display:flex;overflow-x:auto}.ok{color:var(--lime-deep)}.warn{color:#b45309}.error{color:var(--coral)}.cards{flex-wrap:nowrap;justify-content:space-between;gap:clamp(4px,1.4vw,14px);width:100%;min-width:0;margin-top:20px;display:flex}.cards>*{box-sizing:border-box;flex:1 1 0;width:auto;min-width:0;max-width:none}.card{border:1.5px solid var(--ink);background:var(--paper);border-radius:0;min-width:0;padding:clamp(10px,1.8vw,16px);box-shadow:4px 4px #0a0a0f14}.card.tone-good{border-color:var(--lime-deep);background:var(--lime-tint)}.card.tone-warn{background:#fff9e6;border-color:#e6b800}.card.tone-danger{border-color:var(--coral);background:#ffe8e4}.card h3{font-size:10px;font-family:var(--mono);color:var(--ink-mute);letter-spacing:.12em;text-transform:uppercase;margin:0 0 8px;font-weight:700}.card p{font-size:clamp(26px,4vw,34px);font-family:var(--display);letter-spacing:-.04em;color:var(--ink);margin:0;font-weight:400;line-height:1}.card small{color:var(--ink-mute);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;font-size:10px}.card .meta{margin-top:4px;margin-bottom:2px}.card .meta small{text-transform:none;letter-spacing:.02em;font-size:11px}.panel{border:1.5px solid var(--ink);background:var(--paper);box-shadow:6px 6px 0 var(--ink);border-radius:0;margin-top:16px;padding:clamp(12px,2.2vw,20px)}.panel h2{font-family:var(--serif);letter-spacing:-.02em;font-weight:700}.chart-wrap{min-width:0;margin-top:8px}.chart{box-sizing:border-box;border:1.5px solid var(--ink);background:var(--cream);background-image:none;border-radius:0;width:100%;height:320px;display:block}.chart.chart-with-axes{aspect-ratio:1000/332;height:auto;max-height:380px}.chart-axes .chart-axis-line{stroke:var(--ink);stroke-width:1px;opacity:.28}.chart-axes .chart-axis-y,.chart-axes .chart-axis-x{fill:var(--ink-soft);font-family:var(--sans);letter-spacing:.01em;font-size:11px;font-weight:700}.chart-axes .chart-axis-x{font-size:10px}.chart-axes .chart-axis-x--hint{opacity:.72;letter-spacing:.04em;font-size:9px;font-weight:700}.chart-aq-standard__line{stroke:var(--chart-aq-stroke,var(--coral));stroke-width:2px;stroke-dasharray:8 4;opacity:.95;vector-effect:non-scaling-stroke}.chart-aq-standard--pm25,.chart-aq-standard--pm10,.chart-aq-standard--voc,.chart-aq-standard--nox{--chart-aq-stroke:var(--coral)}.chart-aq-standard__pill{transform-box:border-box;font-family:var(--sans);letter-spacing:.02em;color:var(--chart-aq-stroke,var(--coral));background:var(--paper);border:1.5px solid var(--chart-aq-stroke,var(--coral));box-shadow:0 0 0 2px color-mix(in srgb, var(--paper) 80%, transparent);white-space:nowrap;pointer-events:none;z-index:1;border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:800;line-height:1;display:inline-flex;position:absolute;right:clamp(56px,6%,80px);transform:translateY(-50%)}.chart-aq-standard__pill-value{letter-spacing:.01em;color:var(--ink);vertical-align:baseline;margin:0 1px;font-family:inherit;font-size:1.3em;font-style:normal;font-weight:900}.chart-aq-standard__pill.chart-aq-standard--hero{left:clamp(56px,6%,80px);right:auto}.chart-aq-standard__pill--stack-above{transform:translateY(-130%)}.chart-aq-standard__pill--stack-below{transform:translateY(30%)}.chart-axis-break__symbol{fill:var(--ink);font-family:var(--sans);letter-spacing:0;paint-order:stroke;stroke:var(--paper);stroke-width:10px;stroke-linejoin:round;font-size:20px;font-weight:900}.live-hero-sparkline__axis-break{font-family:var(--sans);letter-spacing:0;color:var(--ink);background:var(--paper);pointer-events:none;z-index:2;box-shadow:0 0 0 4px var(--paper);border-radius:4px;padding:0 2px;font-size:18px;font-weight:900;line-height:1;position:absolute;transform:translate(-50%,-50%)}.legend-tiles{flex-wrap:nowrap;justify-content:space-between;align-items:stretch;gap:clamp(4px,1vw,10px);width:100%;min-width:0;display:flex}.legend-tiles .legend-item{flex:1 1 0;justify-content:center;min-width:0}.legend-item-label{text-overflow:ellipsis;white-space:nowrap;text-align:center;width:100%;min-width:0;display:block;overflow:hidden}.line{fill:none;stroke-width:3px}.line.pm-field-pm10{stroke:var(--smog)}.line.pm25{stroke:var(--lime-deep)}.line.pm-field-pm100{stroke:var(--coral)}.line.humidity{stroke:var(--ink-soft)}.line.temperature{stroke:var(--chart-temp,#c2410c)}.legend{flex-wrap:nowrap;align-items:center;gap:clamp(4px,1vw,10px);min-width:0;margin-top:12px;display:flex}.legend-item{border:1.5px solid var(--ink);background:var(--paper);font-size:12px;font-family:var(--sans);letter-spacing:.02em;text-transform:none;color:var(--ink);cursor:pointer;align-items:center;gap:clamp(4px,.9vw,8px);padding:clamp(5px,1vw,8px) clamp(6px,1.2vw,12px);font-weight:700;transition:transform .14s,box-shadow .14s,background-color .14s,border-color .14s,opacity .14s;display:inline-flex;transform:translate(0);box-shadow:3px 3px #0a0a0f1f}.legend-item.off{opacity:.42;box-shadow:none}.legend-item:hover:not(.off){transform:translate(-2px,-2px);box-shadow:5px 5px #0a0a0f2e}.legend-item.off:hover{opacity:.7;box-shadow:2px 2px #0a0a0f1f}.legend-item:active:not(.off){transform:translate(1px,1px);box-shadow:1px 1px #0a0a0f2e}.legend-item:focus-visible{outline:2px solid var(--lime-deep);outline-offset:2px}.legend-item:before{content:"";border-radius:2px;flex-shrink:0;width:22px;height:5px}.legend-item.pm-field-pm10:before{background:var(--smog)}.legend-item.pm25:before{background:var(--lime-deep)}.legend-item.pm-field-pm100:before{background:var(--coral)}.legend-item.humidity:before{background:var(--ink-soft)}.legend-item.temperature:before{background:var(--chart-temp,#c2410c)}.line.voc-index{stroke:var(--chart-voc,#6d28d9)}.line.nox-index{stroke:var(--chart-nox,#0f766e)}.legend-item.voc-index:before{background:var(--chart-voc,#6d28d9)}.legend-item.nox-index:before{background:var(--chart-nox,#0f766e)}.chart-canvas{aspect-ratio:1000/332;width:100%;min-width:0;position:relative;container:chartcanvas/inline-size}.live-env-gas-charts{gap:var(--space-2);flex-direction:column;min-width:0;display:flex}.live-env-gas-charts .chart-canvas--voc .chart.chart-with-axes,.live-env-gas-charts .chart-canvas--nox .chart.chart-with-axes{aspect-ratio:1000/220;max-height:240px}@container chartcanvas (width<=520px){.chart-aq-standard__pill-label-text{display:none}}.chart-markers-overlay{pointer-events:none;position:absolute;inset:0;overflow:visible}.chart-marker-dot{border:1.6px solid var(--paper);box-sizing:content-box;pointer-events:none;z-index:1;border-radius:50%;width:12px;height:12px;position:absolute;transform:translate(-50%,-50%)}.chart-marker-dot--prev{border-width:2.4px;background:var(--paper)!important}.chart-marker-tag{font-family:var(--sans);color:var(--ink);white-space:nowrap;pointer-events:none;font-variant-numeric:tabular-nums;letter-spacing:.005em;text-shadow:0 0 1px var(--paper), 0 0 2px var(--paper), 0 0 5px color-mix(in srgb, var(--paper) 92%, transparent);z-index:2;font-size:14px;font-weight:900;position:absolute}.chart-marker-tag--max{transform:translate(-50%,calc(-100% - 12px))}.chart-marker-tag--min{transform:translate(-50%,12px)}.chart-marker-tag--prev{transform:translate(12px,-50%)}.chart-marker-tag--placement-above{transform:translate(-50%,calc(-100% - 12px))}.chart-marker-tag--placement-below{transform:translate(-50%,12px)}.chart-marker-tag--placement-side{transform:translate(12px,-50%)}.chart-marker-dot--pm-field-pm10{background:var(--smog);border-color:var(--paper)}.chart-marker-dot--prev.chart-marker-dot--pm-field-pm10{border-color:var(--smog)}.chart-marker-tag--pm-field-pm10{color:color-mix(in srgb, var(--smog) 70%, #000)}.chart-marker-dot--pm25{background:var(--lime-deep);border-color:var(--paper)}.chart-marker-dot--prev.chart-marker-dot--pm25{border-color:var(--lime-deep)}.chart-marker-tag--pm25{color:color-mix(in srgb, var(--lime-deep) 65%, #000)}.chart-marker-dot--pm-field-pm100{background:var(--coral);border-color:var(--paper)}.chart-marker-dot--prev.chart-marker-dot--pm-field-pm100{border-color:var(--coral)}.chart-marker-tag--pm-field-pm100{color:color-mix(in srgb, var(--coral) 65%, #000)}.chart-marker-dot--humidity{background:var(--ink-soft);border-color:var(--paper)}.chart-marker-dot--prev.chart-marker-dot--humidity{border-color:var(--ink-soft)}.chart-marker-tag--humidity{color:var(--ink)}.chart-marker-dot--temperature{background:var(--chart-temp,#c2410c);border-color:var(--paper)}.chart-marker-dot--prev.chart-marker-dot--temperature{border-color:var(--chart-temp,#c2410c)}.chart-marker-tag--temperature{color:var(--chart-temp,#c2410c)}.chart-marker-dot--voc-index{background:var(--chart-voc,#6d28d9);border-color:var(--paper)}.chart-marker-dot--prev.chart-marker-dot--voc-index{border-color:var(--chart-voc,#6d28d9)}.chart-marker-tag--voc-index{color:var(--chart-voc,#6d28d9)}.chart-marker-dot--nox-index{background:var(--chart-nox,#0f766e);border-color:var(--paper)}.chart-marker-dot--prev.chart-marker-dot--nox-index{border-color:var(--chart-nox,#0f766e)}.chart-marker-tag--nox-index{color:var(--chart-nox,#0f766e)}.health-grid{flex-wrap:nowrap;justify-content:space-between;gap:clamp(4px,1.2vw,12px);width:100%;min-width:0;margin-top:12px;display:flex}.health-grid>*{box-sizing:border-box;flex:1 1 0;width:auto;min-width:0;max-width:none}.controls-stack{flex-direction:column;align-items:stretch;gap:10px}.controls-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.tabs{gap:6px;display:flex}.tab{background:var(--cream-deep);color:var(--ink);border:1px solid var(--ink);border-radius:10px;padding:8px 14px;font-weight:700}.tab-active{background:var(--lime);color:var(--ink);box-shadow:3px 3px 0 var(--ink)}.storage-panel{margin-top:16px}.storage-toolbar h2{font-size:20px;font-family:var(--serif);margin:0 0 6px;font-weight:700}.storage-toolbar-row{flex-wrap:wrap;align-items:center;gap:12px;margin-top:10px;display:flex}.storage-allowlists{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px;font-size:13px;display:grid}.storage-allowlists ul{margin:6px 0 0;padding-left:18px}.storage-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:16px;display:grid}.storage-card{border:1.5px solid var(--ink);background:var(--paper);border-radius:0;flex-direction:column;gap:10px;padding:14px;display:flex;box-shadow:4px 4px #0a0a0f1f}.storage-card h3{color:var(--ink);font-size:15px;font-family:var(--serif);margin:0;font-weight:700}.field{color:var(--ink-mute);flex-direction:column;gap:4px;font-size:13px;display:flex}.field.checkbox{flex-direction:row;align-items:center;gap:8px}.field input,.field textarea{width:100%;min-width:0}.storage-pre{border:1px solid var(--ink-mute);background:var(--ink);max-height:220px;color:var(--cream);white-space:pre-wrap;word-break:break-word;font-size:12px;line-height:1.45;font-family:var(--mono);border-radius:0;margin:0;padding:10px;overflow:auto}.storage-hr{border:none;border-top:1px solid var(--cream-deep);margin:4px 0}.sub.small{font-size:12px}button.danger{background:var(--coral);color:var(--cream)}.app-root{flex-direction:column;flex:auto;width:100%;min-width:0;min-height:100vh;display:flex}.app-frame{flex-direction:row;flex:auto;justify-content:center;align-items:flex-start;min-width:0;display:flex;overflow-x:hidden}.app-frame-inner{width:100%;max-width:var(--app-canvas-w);box-sizing:border-box;flex-direction:column;flex:auto;min-width:0;display:flex}.app-frame-inner--with-bottom-nav{min-height:100vh}@media (width<=767px){.app-root--with-bottom-nav .app-frame{-webkit-overflow-scrolling:touch;align-items:stretch;min-height:0;overflow-y:auto}.app-root--with-bottom-nav .app-frame-inner{max-height:100vh}}.app-panel--top,.app-panel--nav,.app-panel--main{box-sizing:border-box;flex-shrink:0;width:100%}.app-panel--main{flex:auto;min-width:0;overflow-x:hidden}@media (width<=767px){.app-root--with-bottom-nav .app-panel--main{-webkit-overflow-scrolling:touch;min-height:0;overflow-y:auto}}.app-frame-inner--with-bottom-nav .app-panel--main{padding-bottom:8px}.auth-toolbar{width:100%;max-width:none;padding:clamp(12px, 2vw, 20px) var(--app-gutter-x) clamp(10px, 1.6vw, 16px);border-top:3px solid var(--ink);border-bottom:1px solid var(--ink);background:var(--cream);margin:0}.auth-toolbar-bar{--chrome-control-h:40px;flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:clamp(6px,1.4vw,16px);min-width:0;display:flex;overflow-x:hidden;container:authbar/inline-size}.auth-toolbar-left{flex-shrink:0;align-items:center;gap:clamp(6px,1.2vw,12px);display:flex}.theme-lang-controls{--chrome-control-h:40px;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:clamp(6px,1.2vw,12px);min-width:0;display:inline-flex}.intro-screen-top .theme-lang-controls,.auth-gate-top .theme-lang-controls{align-items:center}.theme-select{height:var(--chrome-control-h,40px);min-height:var(--chrome-control-h,40px);box-sizing:border-box;font-family:var(--sans);letter-spacing:-.01em;border:1.5px solid var(--theme-select-border,var(--ink));background:var(--theme-select-fill,var(--brand-twin));color:var(--theme-select-label,#fff);cursor:pointer;text-align:center;width:auto;min-width:5.25rem;max-width:min(7.25rem,38vw);box-shadow:var(--theme-select-sheen,inset 0 0 0 1px #ffffff24);border-radius:999px;justify-content:center;align-items:center;padding:0 9px;font-size:12px;font-weight:700;line-height:1.2;display:inline-flex}.theme-select:hover{filter:brightness(1.05)}.theme-select option{background:var(--paper);color:var(--ink)}.theme-select:focus{outline:2px solid var(--theme-select-fill,var(--brand-twin));outline-offset:2px}.auth-toolbar-right{flex:auto;justify-content:flex-end;align-items:center;min-width:0;display:flex}.auth-toolbar-label{font-size:10px;font-weight:700;font-family:var(--mono);color:var(--ink-mute);text-transform:uppercase;letter-spacing:.14em}.auth-toolbar-api{font-size:11px;font-family:var(--mono);color:var(--ink);background:var(--paper);border:1.5px solid var(--ink);border-radius:0;padding:6px 10px}.auth-oauth-hint{color:var(--ink-mute);font-size:12px;font-family:var(--sans);max-width:640px;margin:0;line-height:1.45}.btn-google{border:2px solid var(--ink);background:var(--paper);color:var(--ink);cursor:pointer;font-weight:700;font-family:var(--sans);letter-spacing:-.02em;box-shadow:3px 3px 0 var(--ink);border-radius:12px;padding:10px 18px;font-size:14px;transition:transform .15s cubic-bezier(.4,0,.2,1),box-shadow .15s cubic-bezier(.4,0,.2,1)}.btn-google:hover:not(:disabled){filter:brightness(1.02)}.btn-google:active:not(:disabled){box-shadow:1px 1px 0 var(--ink);transform:translate(2px,2px)}.btn-google:disabled{opacity:.55;cursor:wait;box-shadow:2px 2px 0 var(--smog)}.auth-session-chip{border:1.5px solid var(--ink);background:var(--lime-tint);font-size:13px;font-family:var(--sans);border-radius:12px;flex-wrap:nowrap;align-items:center;gap:12px;min-width:0;max-width:100%;padding:8px 12px;display:flex}.auth-toolbar-bar .auth-session-chip{height:var(--chrome-control-h,40px);min-height:var(--chrome-control-h,40px);box-sizing:border-box;border-radius:999px;align-items:center;gap:8px;padding:0 10px}.auth-toolbar-bar .auth-session-user{gap:8px}.auth-session-user{flex:0 auto;align-items:center;gap:10px;min-width:0;display:flex}.auth-avatar-wrap{flex-shrink:0;width:40px;height:40px;position:relative}.auth-toolbar-bar .auth-avatar-wrap{width:32px;height:32px}.auth-avatar-img{border:1.5px solid var(--ink);object-fit:cover;background:var(--paper);border-radius:50%;width:40px;height:40px;display:block}.auth-toolbar-bar .auth-avatar-img{width:32px;height:32px}.auth-avatar-fallback{border:1.5px solid var(--ink);background:var(--paper);width:40px;height:40px;font-family:var(--serif);color:var(--ink);border-radius:50%;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex}.auth-toolbar-bar .auth-avatar-fallback{width:32px;height:32px;font-size:14px}.auth-avatar-admin-mark{border:1.5px solid var(--ink);background:var(--lime);width:20px;height:20px;color:var(--ink);box-shadow:0 0 0 1px var(--cream);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;bottom:-4px;right:-4px}.auth-toolbar-bar .auth-avatar-admin-mark{width:17px;height:17px;bottom:-3px;right:-3px}.auth-avatar-admin-mark svg{display:block}.auth-toolbar-bar .auth-avatar-admin-mark svg{width:11px;height:11px}.auth-session-name{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:min(280px,52vw);font-weight:700;overflow:hidden}@container authbar (width<=560px){.auth-session-name{display:none}}.btn-signout{white-space:nowrap;flex-shrink:0;margin-left:auto;padding:8px 12px;font-size:12px}.auth-toolbar-bar .btn-signout{height:var(--chrome-control-h,40px);min-height:var(--chrome-control-h,40px);box-shadow:2px 2px 0 var(--ink);font-size:11px;line-height:1.2;font-family:var(--sans);box-sizing:border-box;border-radius:999px;justify-content:center;align-items:center;margin-left:auto;padding:0 14px;font-weight:700;display:inline-flex}.auth-toolbar-bar .auth-session-name{font-size:12px;line-height:1.2}.auth-toolbar-bar .lang-toggle{margin-left:0}.lang-toggle{height:var(--chrome-control-h,40px);min-height:var(--chrome-control-h,40px);box-sizing:border-box;border:1.5px solid var(--ink);background:var(--cream-deep);border-radius:999px;align-items:stretch;gap:2px;padding:2px;display:inline-flex;overflow:hidden}.lang-toggle-opt{color:var(--ink-mute);cursor:pointer;font-size:12px;font-weight:700;line-height:1.2;font-family:var(--sans);box-shadow:none;background:0 0;border:none;border-radius:999px;flex:auto;justify-content:center;align-self:stretch;align-items:center;min-width:0;margin:0;padding:0 12px;transition:background .15s;display:flex}.lang-toggle-opt:hover:not(.active){color:var(--ink)}.lang-toggle-opt.active{background:var(--lime);color:var(--ink)}.app-nav{padding:clamp(12px, 2vw, 18px) var(--app-gutter-x) 0;box-sizing:border-box;flex-flow:column;align-items:stretch;gap:12px;width:100%;min-width:0;max-width:none;margin:0;display:flex}.nav-tab{border:2px solid var(--ink);background:var(--cream-deep);color:var(--ink-mute);cursor:pointer;font-weight:700;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;box-shadow:3px 3px 0 var(--ink);white-space:nowrap;border-radius:999px;flex:0 auto;min-width:0;padding:clamp(6px,1.2vw,10px) clamp(8px,1.8vw,20px);font-size:10px}.nav-tab:hover:not(.active){color:var(--ink)}.nav-tab.active{background:var(--ink);color:var(--lime);box-shadow:4px 4px 0 var(--lime-deep)}.app-nav__main{flex-wrap:wrap;flex:auto;align-items:center;gap:clamp(8px,1.4vw,14px);min-width:0;display:flex}.app-nav__group{flex-wrap:nowrap;align-items:center;gap:6px;display:flex}.app-nav__hint{border:2px solid var(--ink);background:var(--paper);width:30px;height:30px;color:var(--ink);cursor:pointer;box-shadow:2px 2px 0 var(--ink);border-radius:999px;flex-shrink:0;margin:0;padding:0;font-size:14px;font-weight:700;line-height:1}.app-nav__hint:hover{color:var(--ink-soft)}.app-nav__tip{border:1.5px solid var(--ink);background:var(--paper);min-width:0;max-width:100%;font-family:var(--sans);color:var(--ink);box-sizing:border-box;border-radius:10px;flex:none;align-self:flex-start;margin:0;padding:12px 14px;font-size:13px;font-weight:400;line-height:1.45}.app-nav--bottom{padding:0;padding-bottom:env(safe-area-inset-bottom,0px);border-top:2px solid var(--ink);background:var(--cream);z-index:20;flex-flow:column;align-items:stretch;gap:0;margin-top:auto;position:sticky;bottom:0;box-shadow:0 -6px 18px #0f172a14}.app-nav--bottom .app-nav__tabs{flex-direction:row;align-items:stretch;gap:0;width:100%;min-width:0;display:flex}.app-nav--bottom .nav-tab{min-width:0;min-height:56px;box-shadow:none;color:var(--ink-mute);font-family:var(--sans);letter-spacing:0;text-transform:none;white-space:normal;text-align:center;background:0 0;border:none;border-top:3px solid #0000;border-radius:0;flex:1 1 0;justify-content:center;align-items:center;padding:8px 6px 10px;font-size:11px;font-weight:700;line-height:1.25;display:flex}.app-nav--bottom .nav-tab:hover:not(.active){color:var(--ink);background:color-mix(in srgb, var(--cream-deep) 70%, transparent 30%)}.app-nav--bottom .nav-tab.active{color:var(--ink);background:var(--paper);border-top-color:var(--lime-deep);box-shadow:none}.app-nav--bottom .app-nav__label{text-overflow:ellipsis;max-width:100%;display:block;overflow:hidden}.live-dashboard{--chrome-control-h:40px;font-family:var(--live-dashboard);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1, "lnum" 1}.app.live-dashboard{padding-top:var(--space-2);--live-dash-gutter:6px;--live-panel-tint:color-mix(in srgb, var(--accent) 6%, transparent)}.app.live-dashboard .live-hero-row .panel,.app.live-dashboard .live-dash-rail .panel,.app.live-dashboard .live-dash-panels .panel,.app.live-dashboard .live-health-details{background:var(--live-panel-tint);border:1px solid var(--ink);box-shadow:0 1px 2px #0f172a0d}.app.live-dashboard .live-dash-rail-row,.app.live-dashboard .live-health-details__card{border:1px solid var(--ink)}.app.live-dashboard .live-magazine-panel .live-hero-inner,.app.live-dashboard .live-magazine-panel .live-aqi-section,.app.live-dashboard .live-magazine-panel .live-health-strip{background:0 0}.app.live-dashboard .live-app-status,.app.live-dashboard .chart{background:var(--live-panel-tint)}.live-dashboard .panel h2,.live-dashboard .live-dash-section__h{font-family:var(--live-dashboard)}.header.header--live-dash{padding-bottom:var(--space-1);border-bottom:0}.header--live-dash .live-header-row{flex-flow:wrap;align-items:flex-start;gap:12px;min-width:0;display:flex}.header--live-dash .live-header-titles{flex-wrap:nowrap;flex:auto;align-items:center;gap:10px;min-width:0;max-width:100%;display:flex}.header--live-dash .live-header-titles h1{white-space:nowrap;flex-wrap:nowrap;flex:auto;align-items:baseline;gap:.3em;min-width:0;margin-block:0;display:flex;overflow:hidden;container:livetitle/inline-size}@container livetitle (width<=520px){.app-brand-heading__word--0{display:none}}@container livetitle (width<=360px){.app-brand-heading__word--1{display:none}}.header.header--live-dash{padding-top:0;padding-bottom:var(--space-2)}.live-header-chrome{flex-flow:row;flex-shrink:0;align-items:center;gap:8px;margin-left:auto;display:flex;position:relative}.live-header-chip-slot{pointer-events:none;flex:0 0 36px;width:36px;height:36px}.live-header-icon-btn{width:clamp(48px,5vw,56px);height:clamp(48px,5vw,56px);color:var(--ink);cursor:pointer;background:0 0;border:0;flex-shrink:0;justify-content:center;align-items:center;padding:0;line-height:1;transition:color .12s,transform .12s;display:inline-flex}.live-header-icon-btn:hover{color:color-mix(in srgb, var(--ink) 70%, var(--accent) 30%)}.live-header-icon-btn:focus-visible{outline:2px solid var(--brand-twin,var(--accent));outline-offset:2px;border-radius:6px}.live-header-icon-btn:active{transform:scale(.94)}.live-header-layout-btn__icon{flex-shrink:0;display:block}.live-header-info{padding:0;font-size:17px}.live-header-desc{flex:260px;align-self:flex-start;min-width:min(100%,220px);max-width:min(720px,100%);margin:0}.live-dash-section__h{margin:0 0 12px}.live-dash-section__h.live-poll-title{margin:0 0 10px}.live-dash-section:has(.live-dash-section__toggle[aria-expanded=false])>.live-dash-section__h{margin-bottom:0}.live-dash-section__head{flex-flow:wrap;align-items:center;gap:6px 10px;width:100%;min-width:0;display:flex}.live-dash-section__head:has(.live-dash-section__summary){flex-direction:column;align-items:flex-start;gap:2px}.live-dash-section--health .live-dash-section__head:has(.live-dash-section__summary){flex-flow:wrap;justify-content:space-between;align-items:center;gap:6px 14px}.live-dash-section--health .live-dash-section__head:has(.live-dash-section__summary) .live-dash-section__summary{margin-left:auto}.live-dash-section--health .live-dash-section__head:has(.live-dash-section__summary) .live-dash-section__toggle{align-self:center}.live-dash-section__toggle{text-align:left;border:1px solid color-mix(in srgb, var(--ink) 22%, transparent);width:auto;min-width:0;box-shadow:none;appearance:none;font-family:var(--font-display);letter-spacing:.01em;color:var(--ink);cursor:pointer;box-sizing:border-box;background:0 0;border-radius:6px;flex-flow:row;flex:none;align-items:baseline;gap:8px;margin:0;padding:4px 10px;font-size:clamp(18px,2.1vw,22px);font-weight:700;line-height:1.15;transition:color .16s;display:inline-flex}.live-dash-section__toggle:hover{color:var(--accent);border-color:color-mix(in srgb, var(--accent) 65%, transparent)}.live-dash-section__toggle:focus-visible{outline:2px solid var(--accent,var(--ink));outline-offset:4px}.live-dash-section__title{white-space:normal;overflow-wrap:anywhere;flex:0 auto;min-width:0;line-height:1.2}.live-dash-section__title--button{appearance:none;font:inherit;color:inherit;letter-spacing:inherit;text-align:left;cursor:pointer;background:0 0;border:0;margin:0;padding:0}.live-dash-section__title--button:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}.live-dash-section__title-metric--particles{color:var(--pollutant-particles)}.live-dash-section__title-metric--temp{color:var(--chart-temp)}.live-dash-section__title-metric--humidity{color:var(--accent)}.live-dash-section__title-metric--voc{color:var(--pollutant-voc)}.live-dash-section__title-metric--nox{color:var(--pollutant-nox)}.live-dash-section__title-metric--risk-good{color:var(--success)}.live-dash-section__title-metric--risk-warn{color:var(--warn)}.live-dash-section__title-metric--risk-bad{color:var(--danger)}.live-dash-section__title-metric--risk-neutral{color:var(--text-dim,var(--ink-mute))}.live-dash-section__chevron{opacity:1;color:var(--ink-mute);flex-shrink:0;justify-content:center;align-items:center;font-size:.62em;line-height:1;transition:color .16s;display:inline-flex}.live-dash-section__toggle:hover .live-dash-section__chevron{color:var(--accent)}.live-dash-section__head:has(.live-dash-section__summary) .live-dash-section__toggle{flex:none;align-self:flex-end}.live-dash-section__head:has(.live-dash-section__summary) .live-dash-section__summary{flex:none;align-content:flex-start}.live-dash-section__summary{min-width:0;color:var(--tk-text,var(--ink));font-family:var(--mono);letter-spacing:.01em;pointer-events:none;-webkit-user-select:text;user-select:text;flex-wrap:wrap;flex:220px;align-items:baseline;gap:6px clamp(28px,3.4vw,40px);padding:0;font-size:clamp(18px,1.9vw,22px);font-weight:700;line-height:1.25;display:inline-flex}.live-dash-section__summary>*{white-space:nowrap;flex-shrink:0}.live-dash-section__summary-pair{color:var(--summary-color,var(--tk-text,var(--ink)));align-items:baseline;gap:6px;display:inline-flex}.live-dash-section__summary-pair--particles{--summary-color:var(--pollutant-particles)}.live-dash-section__summary-pair--temp{--summary-color:var(--chart-temp)}.live-dash-section__summary-pair--humidity{--summary-color:var(--accent)}.live-dash-section__summary-pair--voc{--summary-color:var(--pollutant-voc)}.live-dash-section__summary-pair--nox{--summary-color:var(--pollutant-nox)}.live-dash-section__summary-pair--neutral{--summary-color:var(--tk-text,var(--ink))}.live-dash-section__summary-pair--risk-good{--summary-color:var(--success)}.live-dash-section__summary-pair--risk-warn{--summary-color:var(--warn)}.live-dash-section__summary-pair--risk-bad{--summary-color:var(--danger)}.live-dash-section__summary-pair--risk-neutral{--summary-color:var(--text-dim,var(--ink-mute))}.live-dash-section__summary-label,.live-dash-section__summary-value,.live-dash-section__summary-unit{color:currentColor;paint-order:stroke fill}.live-dash-section__summary-label{font-family:var(--mono);letter-spacing:.02em;font-size:1em;font-weight:700}.live-dash-section__summary-value{font-variant-numeric:tabular-nums;font-weight:500}.live-dash-section__summary-unit{margin-left:4px;font-size:.82em;font-weight:500}.live-dash-section__body{margin-top:4px}.live-dash-panels{gap:var(--live-dash-gutter);margin-top:var(--live-dash-gutter);grid-template-columns:repeat(auto-fit,minmax(360px,1fr));display:grid}.live-dash-panels:empty{margin-top:0;display:none}.live-dash-panels>.panel{margin-top:0}.live-dash-panels>.live-dash-section{grid-column:1/-1}.live-panel-desc-hint-row--in-header{flex-shrink:0;align-self:stretch;align-items:center;display:flex}.live-panel-desc-hint{width:var(--chrome-control-h,40px);height:var(--chrome-control-h,40px);border:2px solid var(--ink);background:var(--paper);color:var(--ink);font-size:17px;font-weight:700;line-height:1;font-family:var(--sans);cursor:pointer;box-shadow:2px 2px 0 var(--ink);box-sizing:border-box;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.live-panel-desc-hint:focus-visible{outline:2px solid var(--brand-twin);outline-offset:2px}.live-panel-layout-root{z-index:80;box-sizing:border-box;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.live-panel-layout-backdrop{cursor:pointer;background:#0a0a0f73;border:none;margin:0;padding:0;position:absolute;inset:0}.live-panel-layout-dialog{z-index:1;border:2px solid var(--ink);background:var(--paper);box-sizing:border-box;border-radius:14px;width:min(420px,100%);max-height:min(88vh,640px);padding:18px 18px 16px;position:relative;overflow:auto;box-shadow:6px 6px #0a0a0f2e}.live-panel-layout-title{font-size:1.1rem;font-family:var(--live-dashboard);margin:0 0 8px}.live-panel-layout-chart-section{margin:0 0 12px}.live-panel-layout-venue-section{border-bottom:1px solid color-mix(in srgb, var(--ink,#1f2937) 8%, transparent);padding-bottom:12px}.live-panel-layout-section-title{letter-spacing:.02em;color:color-mix(in srgb, var(--ink,#1f2937) 78%, transparent);text-transform:uppercase;margin:0 0 8px;font-size:.85rem;font-weight:700}.live-panel-layout-sensitive-grid{flex-wrap:wrap;gap:6px;margin:6px 0 4px;display:flex}.live-panel-layout-sensitive-chip{border:1px solid color-mix(in srgb, var(--ink,#1f2937) 18%, transparent);background:color-mix(in srgb, var(--surface,#fff) 88%, transparent);color:color-mix(in srgb, var(--ink,#1f2937) 82%, transparent);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:.85rem;line-height:1.2;transition:background-color .12s,border-color .12s,color .12s;display:inline-flex}.live-panel-layout-sensitive-chip input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent,#5b8def);margin:0}.live-panel-layout-sensitive-chip:hover{border-color:color-mix(in srgb, var(--accent,#5b8def) 50%, transparent)}.live-panel-layout-sensitive-chip--on{background:color-mix(in srgb, var(--accent,#5b8def) 14%, transparent);border-color:color-mix(in srgb, var(--accent,#5b8def) 60%, transparent);color:color-mix(in srgb, var(--ink,#1f2937) 95%, transparent)}.live-panel-layout-admin-section{border-top:1px solid #0a0a0f1f;margin:0 0 12px;padding-top:12px}.live-panel-layout-chart-fields{flex-direction:column;gap:12px;margin-bottom:10px;display:flex}.live-panel-layout-field{font-size:14px;font-weight:700;font-family:var(--live-dashboard);flex-direction:column;align-items:stretch;gap:6px;display:flex}.live-panel-layout-field-label{color:var(--ink-muted,#4a4a55);font-size:13px}.live-panel-layout-field select{box-sizing:border-box;border:1px solid var(--ink);background:var(--paper);width:100%;max-width:100%;font:inherit;border-radius:8px;padding:8px 10px}.live-panel-layout-chart-hint{margin:6px 0 0}.live-panel-layout-field-hint{color:var(--ink-muted,#4a4a55);margin:4px 0 0;font-size:12px;font-weight:500;line-height:1.4}.live-panel-layout-row{cursor:pointer;flex-direction:row;align-items:flex-start;gap:10px;font-size:14px;font-weight:700;display:flex}.live-panel-layout-row--field{margin:0}.live-panel-layout-row input{flex-shrink:0;margin-top:3px}.live-panel-layout-actions{justify-content:flex-end;gap:10px;display:flex}.live-advisory-catalog-root{z-index:80;box-sizing:border-box;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.live-advisory-catalog-backdrop{cursor:pointer;background:#0a0a0f73;border:none;margin:0;padding:0;position:absolute;inset:0}.live-advisory-catalog-dialog{z-index:1;border:2px solid var(--ink);background:var(--paper);box-sizing:border-box;border-radius:14px;flex-direction:column;gap:12px;width:min(560px,100%);max-height:min(88vh,720px);padding:20px 22px 18px;display:flex;position:relative;overflow:auto;box-shadow:6px 6px #0a0a0f2e}.live-advisory-catalog-header{flex-direction:column;gap:4px;display:flex}.live-advisory-catalog-title{font-size:1.15rem;font-family:var(--live-dashboard);color:var(--ink);margin:0}.live-advisory-catalog-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.live-advisory-catalog-item{--catalog-tone-color:var(--ink-mute);border:1px solid color-mix(in srgb, var(--ink) 12%, transparent);border-left:4px solid var(--catalog-tone-color);background:color-mix(in srgb, var(--paper) 92%, var(--ink) 6%);border-radius:8px;flex-direction:column;gap:6px;padding:10px 12px 12px;display:flex}.live-advisory-catalog-item--good{--catalog-tone-color:var(--success,#1f9d62)}.live-advisory-catalog-item--moderate{--catalog-tone-color:var(--warning,#c97c10)}.live-advisory-catalog-item--bad{--catalog-tone-color:var(--danger,#c43c3c)}.live-advisory-catalog-item--veryBad{--catalog-tone-color:var(--accent,#8b1a1a)}.live-advisory-catalog-item--neutral{--catalog-tone-color:color-mix(in srgb, var(--ink) 35%, transparent)}.live-advisory-catalog-item--active{border-color:var(--ink);background:var(--paper);box-shadow:2px 2px 0 color-mix(in srgb, var(--catalog-tone-color) 55%, transparent)}.live-advisory-catalog-item__head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.live-advisory-catalog-item__title{color:var(--ink);margin:0;font-size:clamp(14px,1.25vw,16px);font-weight:700}.live-advisory-catalog-item__badge{letter-spacing:.04em;text-transform:uppercase;background:var(--catalog-tone-color);color:var(--paper);white-space:nowrap;border-radius:999px;padding:2px 8px;font-size:clamp(10px,.9vw,12px);font-weight:700}.live-advisory-catalog-item__body{grid-template-columns:clamp(56px,6vw,72px) minmax(0,1fr);gap:4px 10px;margin:0;font-size:clamp(12px,1.05vw,14px);line-height:1.5;display:grid}.live-advisory-catalog-item__row{display:contents}.live-advisory-catalog-item__row dt{color:var(--ink-mute);letter-spacing:.02em;text-transform:uppercase;align-self:start;padding-top:2px;font-size:clamp(11px,1vw,13px);font-weight:700}.live-advisory-catalog-item__row dd{color:var(--ink);margin:0}.live-advisory-catalog-actions{justify-content:flex-end;gap:10px;padding-top:4px;display:flex}.live-hero-explanation__more{justify-content:flex-end;margin-top:2px;display:flex}.live-hero-explanation__more-btn{border:1px solid color-mix(in srgb, var(--ink) 20%, transparent);color:var(--ink);font-family:var(--font-display);letter-spacing:0;cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:4px;margin:0;padding:4px 8px;font-size:clamp(11px,1vw,13px);font-weight:600;transition:background-color .12s,border-color .12s,color .12s;display:inline-flex}.live-hero-explanation__more-btn:hover{background:color-mix(in srgb, var(--paper) 75%, var(--accent) 25%);border-color:var(--ink)}.live-hero-explanation__more-btn:focus-visible{outline:2px solid var(--brand-twin,var(--accent));outline-offset:2px}.live-hero-explanation__more-btn svg{opacity:.85;flex-shrink:0;margin-top:1px;display:block}.live-panel-desc-region--in-body{box-sizing:border-box;width:100%;max-width:100%;margin:0 0 8px}.live-panel-desc-region .live-poll-name-tip{margin-top:0}.live-dashboard .live-panel-desc-hint{font-family:var(--live-dashboard)}.explorer-panel{margin-top:8px}.explorer-panel input[type=text],.explorer-panel input[type=number],.explorer-panel input[type=datetime-local],.explorer-panel input[type=search],.explorer-panel input:not([type]),.explorer-panel select{box-sizing:border-box;width:100%;min-width:0;max-width:100%;height:var(--tk-field-h);font-size:13px;font-family:var(--sans);color:var(--tk-text-strong);background:var(--tk-surface);border:1px solid var(--tk-border);box-shadow:none;letter-spacing:0;text-transform:none;border-radius:8px;padding:0 12px;font-weight:400;transition:border-color .12s,box-shadow .12s}.explorer-panel input:focus-visible,.explorer-panel select:focus-visible{border-color:var(--tk-primary);box-shadow:0 0 0 3px color-mix(in srgb, var(--tk-primary) 22%, transparent);outline:none}.explorer-panel input::placeholder{color:var(--tk-text-muted)}.explorer-grid{grid-template-columns:repeat(auto-fill,minmax(min(220px,100%),1fr));align-items:end;gap:14px 12px;min-width:0;margin-top:12px;display:grid}.explorer-field{font-size:11px;font-weight:700;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--tk-text-muted);flex-direction:column;gap:6px;min-width:0;display:flex}.explorer-field span{font-size:11px}.explorer-field.explorer-field--device{flex-flow:row;grid-column:1/-1;align-items:center;gap:clamp(4px,1.2vw,12px);min-width:0;container:explorerdev/inline-size}.explorer-field.explorer-field--device>span{font-family:var(--serif);letter-spacing:-.03em;text-transform:none;color:var(--ink);flex-shrink:0;font-size:clamp(14px,1.35vw,17px);font-weight:700;line-height:1.15}.explorer-field.explorer-field--device select{flex:auto;min-width:0;max-width:100%}@container explorerdev (width<=480px){.explorer-field.explorer-field--device>span{display:none}}.explorer-actions{border-top:1px solid var(--tk-border);flex-wrap:wrap;align-items:center;gap:10px;margin-top:16px;padding-top:14px;display:flex}.explorer-hint{margin-top:10px;margin-bottom:0}.explorer-table-wrap{border:1.5px solid var(--ink);background:var(--paper);border-radius:0;margin-top:10px;overflow-x:auto}.explorer-table{border-collapse:collapse;width:100%;font-size:13px;font-family:var(--sans)}.explorer-table th,.explorer-table td{text-align:right;border-bottom:1px solid var(--cream-deep);white-space:nowrap;padding:10px 12px}.explorer-table th:first-child,.explorer-table td:first-child{text-align:left}.explorer-table th{background:var(--ink);color:var(--cream);font-weight:700;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;font-size:10px;position:sticky;top:0}.explorer-table tbody tr:hover{background:var(--lime-tint)}.panel .sub{font-size:14px}.live-magazine-panel{flex-direction:column;margin-top:0;padding:0;display:flex;overflow:visible}.live-hero-row{align-items:stretch;gap:var(--live-dash-gutter);flex-flow:row;min-width:0;display:flex}.live-hero-row>.live-magazine-panel{flex:auto;min-width:0;margin-top:0;padding:0}.live-dash-rail{gap:var(--live-dash-gutter);flex-direction:column;flex:0 0 clamp(280px,28vw,360px);min-width:0;margin:0;padding:0;display:flex}.live-dash-rail-grid{row-gap:var(--live-dash-gutter);flex:auto;grid-template-columns:clamp(100px,10.55vw,128px) minmax(0,1fr);grid-auto-rows:1fr;align-content:stretch;column-gap:clamp(18px,3vw,28px);width:100%;min-height:0;display:grid}.live-dash-rail-grid--details{grid-template-columns:max-content minmax(0,1fr)}.live-dash-rail-grid--details .live-dash-rail-row__value{justify-content:flex-end}.live-dash-rail-row{grid-template-columns:subgrid;appearance:none;background:var(--live-panel-tint,color-mix(in srgb, var(--accent) 6%, transparent));border:1px solid color-mix(in srgb, var(--ink) 14%, transparent);text-align:left;cursor:pointer;color:inherit;--row-color:var(--ink);border-radius:8px;grid-column:1/-1;align-items:center;margin:0;padding:8px clamp(14px,1.4vw,18px);font-family:inherit;transition:background-color .16s,border-color .16s,transform .16s,box-shadow .16s;display:grid;box-shadow:0 0 #0000}.live-dash-rail-row--particles{--row-color:var(--pollutant-particles)}.live-dash-rail-row--voc{--row-color:var(--pollutant-voc)}.live-dash-rail-row--nox{--row-color:var(--pollutant-nox)}.live-dash-rail-row--temp{--row-color:var(--chart-temp)}.live-dash-rail-row--humidity{--row-color:var(--accent)}.live-dash-rail-row--risk-good{--row-color:var(--success)}.live-dash-rail-row--risk-warn{--row-color:var(--warn)}.live-dash-rail-row--risk-bad{--row-color:var(--danger)}.live-dash-rail-row--risk-neutral{--row-color:var(--text-dim,var(--ink-mute))}.live-dash-rail-row--neutral{--row-color:var(--ink-mute)}.live-dash-rail-row--event-warn{background:var(--warn-soft);border-color:color-mix(in srgb, var(--warn) 55%, var(--border));--row-color:color-mix(in srgb, var(--warn) 78%, #000)}.live-dash-rail-row--event-warn:hover{background:color-mix(in srgb, var(--warn-soft) 80%, var(--warn));border-color:var(--warn)}.live-dash-rail-row--event-bad{background:var(--danger-soft);border-color:color-mix(in srgb, var(--danger) 55%, var(--border));--row-color:color-mix(in srgb, var(--danger) 80%, #000)}.live-dash-rail-row--event-bad:hover{background:color-mix(in srgb, var(--danger-soft) 75%, var(--danger));border-color:var(--danger)}.live-dash-rail-row--event-veryBad{background:color-mix(in srgb, var(--danger) 18%, var(--surface));border-color:var(--danger);--row-color:color-mix(in srgb, var(--danger) 90%, #000);animation:2.4s ease-in-out infinite live-dash-rail-row-event-pulse}.live-dash-rail-row--event-veryBad:hover{background:color-mix(in srgb, var(--danger) 28%, var(--surface))}@keyframes live-dash-rail-row-event-pulse{0%,to{box-shadow:0 0 0 0 color-mix(in srgb, var(--danger) 40%, transparent)}50%{box-shadow:0 0 0 6px color-mix(in srgb, var(--danger) 0%, transparent)}}.live-dash-section--event-warn{background:var(--warn-soft);border-color:color-mix(in srgb, var(--warn) 55%, var(--border))}.live-dash-section--event-bad{background:var(--danger-soft);border-color:color-mix(in srgb, var(--danger) 55%, var(--border))}.live-dash-section--event-veryBad{background:color-mix(in srgb, var(--danger) 18%, var(--surface));border-color:var(--danger)}.live-dash-rail-row__caption{font-family:var(--font-display);letter-spacing:0;color:var(--ink-mute);white-space:normal;text-align:start;grid-column:1/-1;margin-top:4px;font-size:clamp(11px,1.05vw,13px);font-weight:500;line-height:1.4;display:block}.live-dash-rail-row__caption-name,.live-dash-rail-row__caption-trend{display:block}.live-dash-rail-row__caption-name{color:var(--row-color);font-family:var(--font-display);letter-spacing:-.005em;font-size:clamp(16px,1.6vw,20px);font-weight:700}.live-dash-rail-row--voc .live-dash-rail-row__caption,.live-dash-rail-row--nox .live-dash-rail-row__caption{grid-template-columns:subgrid;display:grid}.live-dash-rail-row--voc .live-dash-rail-row__caption-name,.live-dash-rail-row--nox .live-dash-rail-row__caption-name{white-space:nowrap;text-align:justify;text-align-last:justify;text-justify:inter-character;grid-column:1;width:100%;min-width:0;display:block}.live-dash-rail-row--voc .live-dash-rail-row__caption-trend,.live-dash-rail-row--nox .live-dash-rail-row__caption-trend{grid-column:1/-1}.live-dash-rail-row__caption-trend{color:color-mix(in srgb, var(--ink-mute) 85%, transparent);margin-top:2px;font-size:.92em;font-weight:400}.live-dash-rail-row__label{color:var(--row-color);font-family:var(--font-display);letter-spacing:-.005em;white-space:nowrap;text-align:justify;text-align-last:justify;text-justify:inter-character;width:100%;min-width:0;font-size:clamp(18px,1.92vw,23px);font-weight:800;display:block}.live-dash-rail-row__value{color:var(--ink);font-family:var(--font-mono);letter-spacing:.01em;font-variant-numeric:tabular-nums;white-space:normal;overflow-wrap:anywhere;flex-wrap:wrap;align-items:baseline;gap:4px;min-width:0;max-width:100%;font-size:clamp(18px,1.92vw,23px);font-weight:800;display:flex}.live-dash-rail-row__unit{color:var(--ink-mute);font-family:var(--font-mono);letter-spacing:.02em;font-size:.86em;font-weight:600}.live-dash-rail-row--risk-good .live-dash-rail-row__value,.live-dash-rail-row--risk-warn .live-dash-rail-row__value,.live-dash-rail-row--risk-bad .live-dash-rail-row__value,.live-dash-rail-row--risk-neutral .live-dash-rail-row__value,.live-dash-rail-row--neutral .live-dash-rail-row__value,.live-dash-rail-row--risk-good .live-dash-rail-row__unit,.live-dash-rail-row--risk-warn .live-dash-rail-row__unit,.live-dash-rail-row--risk-bad .live-dash-rail-row__unit,.live-dash-rail-row--risk-neutral .live-dash-rail-row__unit,.live-dash-rail-row--neutral .live-dash-rail-row__unit{font-family:var(--sans);letter-spacing:.005em}.live-dash-rail-row__delta{border:1.25px solid color-mix(in srgb, var(--ink) 45%, transparent);background:var(--paper);font-family:var(--sans);letter-spacing:.01em;font-variant-numeric:tabular-nums;color:var(--ink);white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;gap:4px;margin-left:8px;padding:2px 9px;font-size:.78em;font-weight:800;display:inline-flex}.live-dash-rail-row__delta-glyph{flex-shrink:0;align-items:center;line-height:0;display:inline-flex}.live-dash-rail-row__delta--up .live-dash-rail-row__delta-glyph{color:var(--warn)}.live-dash-rail-row__delta--down .live-dash-rail-row__delta-glyph{color:var(--success)}.live-dash-rail-row__delta-num{font:inherit;color:inherit}.live-dash-rail-row:hover{background:color-mix(in srgb, var(--accent) 10%, transparent);border-color:color-mix(in srgb, var(--accent) 45%, transparent);box-shadow:0 10px 18px -10px color-mix(in srgb, var(--ink) 38%, transparent);transform:translateY(-2px)}.live-dash-rail-row:focus-visible{outline:2px solid var(--accent,var(--ink));outline-offset:2px;box-shadow:0 10px 18px -10px color-mix(in srgb, var(--ink) 38%, transparent);transform:translateY(-2px)}.live-dash-rail-row:active{box-shadow:0 1px 3px -1px color-mix(in srgb, var(--ink) 24%, transparent);transform:translateY(1px)}.live-dash-rail-row.is-active{background:color-mix(in srgb, var(--accent) 14%, transparent);border-color:color-mix(in srgb, var(--accent) 55%, transparent)}.live-dash-section__close{appearance:none;border:1.5px solid var(--ink);background:var(--paper);height:clamp(34px,3.4vw,40px);color:var(--ink);cursor:pointer;line-height:1;font-family:var(--font-display);letter-spacing:0;text-transform:none;box-shadow:2px 2px 0 var(--ink);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;gap:clamp(6px,.6vw,8px);margin-left:auto;padding:0 clamp(10px,1.1vw,14px);font-size:clamp(13px,1.2vw,15px);font-weight:700;transition:background-color .12s,color .12s,transform .12s,box-shadow .12s;display:inline-flex}.live-dash-section__close:hover{background:color-mix(in srgb, var(--paper) 70%, var(--accent) 30%)}.live-dash-section__close:focus-visible{outline:2px solid var(--brand-twin,var(--accent));outline-offset:2px}.live-dash-section__close:active{box-shadow:1px 1px 0 var(--ink);transform:translate(1px,1px)}.live-dash-section__close-chevron{opacity:.85;flex-shrink:0;margin-top:1px;display:block}.live-dash-section__close-text{white-space:nowrap;display:inline-block}.live-dash-rail:empty{display:none}.live-dash-rail>.panel{margin-top:0}@media (width<=920px){.live-hero-row{flex-direction:column;align-items:stretch}.live-dash-rail{gap:var(--live-dash-gutter);flex:none;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:start;display:grid}}.live-app-status{min-width:0;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink);border:1px solid var(--ink);background:var(--cream);margin-bottom:var(--live-dash-gutter);border-radius:10px;flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:clamp(14px,1.6vw,18px);padding:clamp(5px,.7vw,7px) clamp(12px,1.6vw,18px);font-size:clamp(20px,2.1vw,28px);line-height:1.2;display:flex;overflow:hidden;container:livestrip/inline-size}@container livestrip (width<=560px){.live-app-status-label{display:none}}.live-app-status-loc{flex-shrink:1;align-items:center;gap:clamp(10px,1.1vw,12px);min-width:0;display:flex}.live-app-status-label{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.live-app-status-right{flex-shrink:0;align-items:center;gap:10px;display:inline-flex}.live-app-status-time-label{color:var(--ink-mute);font-weight:600}.live-app-status-time{font-variant-numeric:tabular-nums;letter-spacing:.08em;color:var(--ink);font-weight:600}.live-hero-detail-btn{border:1.5px solid var(--ink);background:var(--paper);height:clamp(34px,3.4vw,40px);color:var(--ink);cursor:pointer;line-height:1;font-family:var(--font-display);letter-spacing:0;text-transform:none;box-shadow:2px 2px 0 var(--ink);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;gap:clamp(6px,.6vw,8px);padding:0 clamp(10px,1.1vw,14px);font-size:clamp(13px,1.2vw,15px);font-weight:700;transition:background-color .12s,color .12s,transform .12s,box-shadow .12s;display:inline-flex}.live-hero-detail-btn:hover{background:color-mix(in srgb, var(--paper) 70%, var(--accent) 30%)}.live-hero-detail-btn:focus-visible{outline:2px solid var(--brand-twin,var(--accent));outline-offset:2px}.live-hero-detail-btn:active{box-shadow:1px 1px 0 var(--ink);transform:translate(1px,1px)}.live-hero-detail-btn[aria-expanded=true]{background:var(--accent);color:var(--paper)}.live-hero-detail-btn[aria-expanded=true]:hover{background:color-mix(in srgb, var(--accent) 85%, var(--ink) 15%)}.live-hero-detail-btn__label{white-space:nowrap;display:inline-block}.live-hero-detail-btn__chevron{opacity:.85;flex-shrink:0;margin-top:1px;display:block}.live-live-dot{background:var(--whisper);border:1.4px solid var(--ink);border-radius:50%;flex-shrink:0;width:clamp(14px,1.6vw,20px);height:clamp(14px,1.6vw,20px)}.live-live-dot.on{background:var(--lime);animation:1.6s ease-in-out infinite live-pulse}@keyframes live-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.35)}}.live-hero-inner{background:var(--paper);background-image:none;padding:6px 20px 8px}.live-hero-kicker{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:8px;font-size:10px}.live-hero-headline{font-family:var(--font-display);letter-spacing:-.015em;color:var(--text);margin:0 0 var(--space-1);font-size:clamp(20px,2.4vw,26px);font-weight:600;line-height:1.15}.live-hero-headline em{color:var(--accent);font-style:normal;font-weight:700}.pollutant{font-family:var(--font-display);letter-spacing:-.005em;font-weight:700}.pollutant--particles{color:var(--pollutant-particles)}.pollutant--voc{color:var(--pollutant-voc)}.pollutant--nox{color:var(--pollutant-nox)}.live-hero-headline.tier-moderate em{color:var(--warn)}.live-hero-headline.tier-bad em,.live-hero-headline.tier-veryBad em{color:var(--danger)}.live-hero-headline.tier-unknown em{color:var(--text-dim)}.live-hero-num-row{margin-bottom:var(--space-2)}.live-hero-overlay{gap:var(--space-1);margin:2px 0 var(--space-1);flex-wrap:wrap;display:flex}.live-hero-overlay__chip{border:1px solid var(--ink-light);background:color-mix(in srgb, var(--paper) 92%, var(--ink) 8%);color:var(--ink);border-radius:999px;align-items:center;gap:6px;max-width:100%;padding:2px 10px;font-size:clamp(11px,.84vw,13px);font-weight:500;line-height:1.3;display:inline-flex}.live-hero-overlay__chip-label{text-transform:uppercase;letter-spacing:.02em;color:var(--text-dim);font-size:.85em;font-weight:600}.live-hero-overlay__chip-text{font-weight:500}.live-hero-overlay__chip--event-voc_spike{border-color:color-mix(in srgb, var(--warn) 55%, transparent);background:color-mix(in srgb, var(--warn) 12%, var(--paper) 88%)}.live-hero-overlay__chip--event-cooking_start{border-color:color-mix(in srgb, var(--danger) 55%, transparent);background:color-mix(in srgb, var(--danger) 12%, var(--paper) 88%)}.live-hero-overlay__chip--comfort-humidity_high,.live-hero-overlay__chip--comfort-humidity_low,.live-hero-overlay__chip--comfort-temp_high,.live-hero-overlay__chip--comfort-temp_low{border-color:color-mix(in srgb, var(--ink) 25%, transparent);background:color-mix(in srgb, var(--paper) 88%, var(--ink) 12%)}.live-hero-overlay__chip--warmup{color:var(--text-dim);background:0 0;border-style:dashed}.live-hero-divider{border-top:1px solid var(--ink);font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);justify-content:flex-start;padding-top:12px;font-size:11px;display:flex}.live-aqi-section{padding:var(--space-3) var(--space-4) 0;border-top:1px solid var(--border);background:var(--surface)}.live-aqi-label{font-family:var(--font-mono);font-size:var(--text-caption);letter-spacing:.04em;color:var(--text-dim);margin-bottom:var(--space-3);justify-content:space-between;display:flex}.live-aqi-label--who{text-transform:none;margin-top:var(--space-2);flex-direction:column;align-items:stretch;gap:6px;margin-bottom:0}.live-aqi-title-row{justify-content:space-between;align-items:baseline;gap:var(--space-2);width:100%;display:flex}.live-aqi-who-title{font-family:var(--font-display);letter-spacing:-.005em;color:var(--text);font-size:clamp(13px,.95rem + .3cqi,15px);font-weight:500}.live-aqi-who-title__value{letter-spacing:0;color:var(--text);font-family:inherit;font-size:1.25em;font-style:normal;font-weight:800}.live-aqi-who-metric{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);font-size:11px;font-weight:500}.live-aqi-who-sub{font-size:var(--text-caption);color:var(--text-dim);margin:0;line-height:1.45;display:block}.live-aqi-bar{background:linear-gradient(90deg, var(--success) 0%, var(--success) 18%, var(--warn) 42%, var(--danger) 68%, color-mix(in srgb, var(--danger) 78%, #000) 100%);border:1px solid var(--border);border-radius:var(--radius-input);height:28px;margin-bottom:var(--space-1);position:relative}.live-aqi-bar:after{content:"";border-radius:inherit;pointer-events:none;background-image:linear-gradient(90deg,#0000 19.7%,#ffffff73 20% 20.4%,#0000 20.7%),linear-gradient(90deg,#0000 33%,#ffffff73 33.3% 33.7%,#0000 34%),linear-gradient(90deg,#0000 49.7%,#ffffff73 50% 50.4%,#0000 50.7%),linear-gradient(90deg,#0000 66.4%,#ffffff73 66.7% 67.1%,#0000 67.4%);position:absolute;inset:0}.live-aqi-marker{background:var(--text);color:#fff;border-radius:var(--radius-input);font-family:var(--font-mono);letter-spacing:.04em;white-space:nowrap;box-shadow:var(--shadow-rest);padding:4px 8px;font-size:10px;font-weight:500;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.live-aqi-marker--icon{color:var(--text);box-shadow:none;pointer-events:none;filter:drop-shadow(0 2px 3px #0000004d);background:0 0;border-radius:0;padding:0;line-height:0;transition:left .32s cubic-bezier(.4,0,.2,1),color .24s;top:-46px}.live-aqi-marker--icon svg{transform-origin:50% 100%;width:clamp(60px,7.2vw,72px);height:auto;display:block;transform:scale(.7)}.live-aqi-marker--band-0,.live-aqi-marker--band-1{color:color-mix(in srgb, var(--success) 82%, #000)}.live-aqi-marker--band-2{color:color-mix(in srgb, var(--warn) 86%, #000)}.live-aqi-marker--band-3{color:color-mix(in srgb, color-mix(in srgb, var(--warn) 40%, var(--danger)) 88%, #000)}.live-aqi-marker--band-4,.live-aqi-marker--band-5{color:color-mix(in srgb, var(--danger) 85%, #000)}.live-aqi-marker--icon:after{content:none}.live-aqi-marker__trend{background:var(--paper);font-family:var(--font-display);letter-spacing:-.01em;white-space:nowrap;pointer-events:auto;border:1.6px solid;border-radius:999px;align-items:baseline;gap:4px;margin-bottom:6px;padding:4px 10px 4px 8px;font-size:clamp(16px,1.8vw,20px);font-weight:800;line-height:1;display:inline-flex;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 2px 4px #0000002e}.live-aqi-marker__trend-arrow{color:currentColor;font-size:.95em;font-weight:900}.live-aqi-marker__trend-val{color:var(--ink);font-variant-numeric:tabular-nums}.live-aqi-marker__trend--below{margin-top:4px;margin-bottom:0;top:100%;bottom:auto}.live-aqi-scale{height:clamp(20px,2vw,26px);font-family:var(--font-mono);letter-spacing:.02em;color:var(--ink);font-variant-numeric:tabular-nums;margin-top:6px;font-size:clamp(14px,1.3vw,17px);font-weight:700;display:block;position:relative}.live-aqi-scale--who{text-transform:none;letter-spacing:.01em;min-width:0;font-size:clamp(14px,1.3vw,17px)}.live-aqi-scale__tick{white-space:nowrap;pointer-events:auto;position:absolute;top:0;transform:translate(-50%)}.live-aqi-scale__tick--start{transform:none}.live-aqi-scale__tick--end{transform:translate(-100%)}.live-aqi-footnote{margin:var(--space-3) 0 0;max-width:42rem;font-size:var(--text-caption);color:var(--text-dim);text-transform:none;letter-spacing:0;line-height:1.45}.live-hero-explanation{border:1px solid color-mix(in srgb, var(--ink) 14%, transparent);background:color-mix(in srgb, var(--paper) 88%, var(--ink) 6%);color:var(--ink-mute);font-family:var(--font-display);border-radius:8px;flex-direction:column;gap:clamp(4px,.5vw,6px);margin:clamp(8px,1vw,12px) 0 0;padding:clamp(10px,1.3vw,14px) clamp(12px,1.4vw,16px);font-size:clamp(12px,1.05vw,14px);line-height:1.5;display:flex}.live-hero-explanation__why{color:var(--ink);margin:0;font-weight:500}.live-hero-explanation__signals{flex-wrap:wrap;align-items:baseline;gap:4px 10px;margin:2px 0 0;display:flex}.live-hero-explanation__signals dt{letter-spacing:.02em;text-transform:uppercase;color:var(--ink-mute);font-size:clamp(11px,1vw,13px);font-weight:600}.live-hero-explanation__signals dd{font-variant-numeric:tabular-nums;flex-wrap:wrap;align-items:baseline;gap:4px 8px;margin:0;display:inline-flex}.live-hero-explanation__signals dd>span{color:var(--ink);align-items:baseline;gap:4px;display:inline-flex}.live-hero-explanation__signals dd>span>strong{color:var(--ink-mute);letter-spacing:.01em;font-weight:700}.live-hero-sparkline{margin-top:var(--space-1);padding:var(--space-1) 12px 10px;border-top:1px solid color-mix(in srgb, var(--ink) 12%, transparent);flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.live-hero-sparkline__head{font-family:var(--font-display);flex-wrap:wrap;align-items:baseline;gap:6px 14px;font-size:clamp(14px,1.5vw,17px);display:flex}.live-hero-sparkline__metric{color:var(--ink);letter-spacing:-.005em;min-width:0;font-weight:800}.live-hero-sparkline__metric-code{font-family:var(--font-mono);color:var(--ink-mute);letter-spacing:.02em;white-space:nowrap;font-size:.86em;font-weight:600}.live-hero-sparkline__plot{flex-direction:column;flex:1;justify-content:flex-end;width:100%;min-height:160px;display:flex;position:relative}.live-hero-sparkline__canvas{flex:0 0 200px;width:100%;min-height:200px;max-height:200px;position:relative}.live-hero-sparkline__svg{width:100%;height:100%;display:block;overflow:visible}.live-hero-sparkline__axis{stroke:color-mix(in srgb, var(--ink) 26%, transparent);stroke-width:1px;fill:none;vector-effect:non-scaling-stroke}.live-hero-sparkline__line{fill:none;stroke:var(--accent);stroke-width:3px;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke}.live-hero-sparkline__dot{background:var(--accent);width:14px;height:14px;box-shadow:0 0 0 2px var(--paper);pointer-events:none;border-radius:50%;position:absolute;transform:translate(-50%,-50%)}.live-hero-sparkline__dot--min{background:var(--success)}.live-hero-sparkline__dot--max{background:var(--danger)}.live-hero-sparkline__dot--prev{background:var(--ink-mute)}.live-hero-sparkline__pin{font-variant-numeric:tabular-nums;letter-spacing:.005em;color:var(--ink);white-space:nowrap;pointer-events:none;text-shadow:0 0 1px var(--paper), 0 0 3px var(--paper), 0 0 6px color-mix(in srgb, var(--paper) 92%, transparent);font-family:inherit;font-size:16px;font-weight:900;position:absolute}.live-hero-sparkline__pin--above{transform:translate(-50%,calc(-100% - 10px))}.live-hero-sparkline__pin--below{transform:translate(-50%,10px)}.live-hero-sparkline__pin--max{color:color-mix(in srgb, var(--danger) 80%, #000)}.live-hero-sparkline__pin--min{color:color-mix(in srgb, var(--success) 78%, #000)}.live-hero-sparkline__pin--prev{color:var(--ink-mute)}.live-hero-sparkline__y-unit-html{transform-origin:0;font-family:var(--font-mono);color:var(--ink-mute);letter-spacing:.04em;pointer-events:none;font-size:12px;font-weight:700;position:absolute;top:50%;left:max(4px,9% - 14px);transform:translateY(-50%)rotate(-90deg)}.live-hero-sparkline__x-axis{pointer-events:none;flex:none;justify-content:space-between;align-items:center;width:100%;padding:4px 6% 0 9%;display:flex;position:relative}.live-hero-sparkline__x-tick{font-family:var(--sans);color:var(--ink);letter-spacing:.005em;white-space:nowrap;font-size:14px;font-weight:900}.live-hero-sparkline__x-tick--mid{text-transform:none;letter-spacing:0}.live-hero-sparkline--empty{font-size:var(--text-caption);flex-direction:row;align-items:baseline;gap:12px}.live-hero-sparkline--empty .live-hero-sparkline__empty-msg{color:var(--ink-mute)}.live-health-strip{padding:var(--space-2) var(--space-4);border-top:1px solid var(--border);background:var(--surface);font-family:var(--font-mono);color:var(--text);letter-spacing:.02em;flex-wrap:wrap;align-items:center;gap:8px 12px;font-size:13px;display:flex}.live-health-strip__tag{box-shadow:none;appearance:none;font-family:var(--font-display);letter-spacing:.01em;text-transform:none;color:var(--ink);cursor:pointer;text-align:left;background:0 0;border:0;flex:none;align-self:center;align-items:baseline;gap:8px;margin:0;padding:2px 0;font-size:clamp(18px,2.2vw,24px);font-weight:900;line-height:1.15;transition:color .16s;display:inline-flex}.live-health-strip__tag-label{text-decoration:none}.live-health-strip__tag-chevron{color:var(--ink-mute);justify-content:center;align-items:center;font-size:.62em;line-height:1;transition:transform .16s,color .16s;display:inline-flex;transform:translateY(0)}.live-health-strip__tag:hover{color:var(--accent)}.live-health-strip__tag:hover .live-health-strip__tag-chevron{color:var(--accent);transform:translateY(1px)}.live-health-strip__tag:active .live-health-strip__tag-chevron{transform:translateY(2px)}.live-health-strip__tag:focus-visible{outline:2px solid var(--accent,var(--ink));outline-offset:4px;border-radius:4px}.live-health-details{margin-top:var(--live-dash-gutter);padding:clamp(14px,1.6vw,20px)}.live-health-details__summary{flex:auto;gap:8px clamp(28px,3.4vw,44px)}.live-health-details__cards{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:clamp(10px,1.2vw,14px);width:100%;display:grid}.live-health-details__gas-row{border:1px dashed color-mix(in srgb, var(--ink) 18%, transparent);border-radius:var(--radius-sm,8px);background:color-mix(in srgb, var(--paper) 96%, var(--ink) 4%);flex-wrap:wrap;align-items:center;gap:clamp(10px,1.2vw,16px);margin:clamp(10px,1.2vw,14px) 0 0;padding:clamp(10px,1.1vw,14px) clamp(12px,1.3vw,16px);display:flex}.live-health-details__gas-row-label{font-family:var(--mono);letter-spacing:.02em;color:var(--text);font-size:clamp(13px,1.1vw,15px);font-weight:700}.live-health-details__gas-chips{flex-wrap:wrap;flex:auto;gap:clamp(8px,.9vw,12px);display:flex}.live-health-details__gas-chip{border:1px solid var(--ink-light);background:color-mix(in srgb, var(--paper) 92%, var(--ink) 8%);white-space:nowrap;border-radius:999px;align-items:baseline;gap:10px;padding:7px 16px;font-size:clamp(14px,1.15vw,16px);line-height:1.4;display:inline-flex}.live-health-details__gas-chip-name,.live-health-details__gas-chip-level{color:var(--ink);font-weight:600}.live-health-details__gas-chip--tone-good{border-color:color-mix(in srgb, var(--success) 50%, transparent);background:color-mix(in srgb, var(--success) 10%, var(--paper) 90%)}.live-health-details__gas-chip--tone-good .live-health-details__gas-chip-level{color:color-mix(in srgb, var(--success) 75%, var(--ink) 25%)}.live-health-details__gas-chip--tone-warn{border-color:color-mix(in srgb, var(--warn) 55%, transparent);background:color-mix(in srgb, var(--warn) 12%, var(--paper) 88%)}.live-health-details__gas-chip--tone-warn .live-health-details__gas-chip-level{color:color-mix(in srgb, var(--warn) 80%, var(--ink) 20%)}.live-health-details__gas-chip--tone-bad{border-color:color-mix(in srgb, var(--danger) 55%, transparent);background:color-mix(in srgb, var(--danger) 12%, var(--paper) 88%)}.live-health-details__gas-chip--tone-bad .live-health-details__gas-chip-level{color:color-mix(in srgb, var(--danger) 80%, var(--ink) 20%)}.live-health-details__gas-chip--tone-critical{border-color:var(--danger);background:color-mix(in srgb, var(--danger) 22%, var(--paper) 78%);font-weight:600}.live-health-details__gas-chip--tone-critical .live-health-details__gas-chip-level{color:var(--danger);font-weight:600}.live-health-details__gas-chip--tone-neutral{border-color:color-mix(in srgb, var(--ink) 18%, transparent);background:color-mix(in srgb, var(--paper) 88%, var(--ink) 12%)}.live-health-details__gas-chip--warmup{border-style:dashed}.live-health-details__gas-chip--warmup .live-health-details__gas-chip-level{color:var(--text-dim);font-style:italic}.live-health-details__action{border-left:4px solid var(--ink);background:color-mix(in srgb, var(--paper) 92%, transparent);border-radius:4px;grid-template-columns:max-content 1fr;align-items:start;gap:clamp(6px,.9vw,12px);margin:clamp(12px,1.4vw,16px) 0 0;padding:clamp(10px,1.2vw,14px) clamp(12px,1.4vw,16px);display:grid}.live-health-details__action-label{font-family:var(--sans);letter-spacing:.02em;text-transform:none;color:var(--ink);white-space:nowrap;border:1.5px solid;border-radius:999px;padding:2px 8px;font-size:clamp(11px,1vw,12px);font-weight:800}.live-health-details__action-text{font-family:var(--font-display);letter-spacing:0;color:var(--ink);font-size:clamp(13px,1.2vw,15px);font-weight:600;line-height:1.5}.live-health-details__action--good{border-left-color:var(--success)}.live-health-details__action--good .live-health-details__action-label{color:var(--success)}.live-health-details__action--warn{border-left-color:var(--warn)}.live-health-details__action--warn .live-health-details__action-label{color:var(--warn)}.live-health-details__action--bad{border-left-color:var(--danger)}.live-health-details__action--bad .live-health-details__action-label{color:var(--danger)}.live-health-details__action--critical{border-left-color:color-mix(in srgb, var(--danger) 78%, var(--ink) 22%);background:var(--danger-soft,color-mix(in srgb, var(--danger) 10%, var(--paper) 90%))}.live-health-details__action--critical .live-health-details__action-label{color:color-mix(in srgb, var(--danger) 78%, var(--ink) 22%)}.live-health-details__card--tone-good{background:var(--success-soft,color-mix(in srgb, var(--success) 12%, var(--paper) 88%))}.live-health-details__card--tone-warn{background:var(--warn-soft,color-mix(in srgb, var(--warn) 14%, var(--paper) 86%))}.live-health-details__card--tone-bad{background:var(--danger-soft,color-mix(in srgb, var(--danger) 12%, var(--paper) 88%))}.live-health-details__card--tone-critical{background:color-mix(in srgb, var(--danger) 20%, var(--paper) 80%)}.live-health-details__card{border:1px solid color-mix(in srgb, var(--ink) 14%, transparent);background:var(--live-panel-tint,color-mix(in srgb, var(--accent) 6%, transparent));border-radius:8px;flex-direction:column;align-items:flex-start;gap:4px;padding:10px 12px;display:flex}.live-health-strip__score{font-family:var(--font-display);color:var(--text);letter-spacing:0;text-transform:none;align-items:baseline;gap:clamp(14px,1.8vw,22px);font-size:clamp(18px,2.3vw,26px);font-weight:700;line-height:1.2;display:inline-flex}.live-health-strip__risk{font-weight:900}.live-health-strip__risk--good{color:var(--success)}.live-health-strip__risk--warn{color:var(--warn)}.live-health-strip__risk--bad{color:var(--danger)}.live-health-strip__risk--neutral{color:var(--text-dim)}.live-health-strip__score-value{color:var(--text);font-variant-numeric:tabular-nums;font-weight:800}.live-health-strip__sep{color:var(--text-faint);opacity:.5;-webkit-user-select:none;user-select:none}.live-health-strip__item{white-space:nowrap;align-items:baseline;gap:4px;display:inline-flex}.live-health-strip__label{color:var(--text-faint)}.live-health-strip__value{color:var(--text);font-weight:500}.live-poll-derived-strip{align-items:baseline;gap:var(--space-2) var(--space-3);padding:var(--space-3) var(--space-4);margin-top:var(--space-2);border-top:1px dashed var(--border);font-family:var(--font-mono);font-size:var(--text-caption);color:var(--text-dim);letter-spacing:.02em;flex-wrap:wrap;display:flex}.live-poll-derived-strip__tag{flex:none;align-self:center}.live-poll-derived-strip__sep{color:var(--text-faint);opacity:.5;-webkit-user-select:none;user-select:none}.live-poll-derived-strip__item{white-space:nowrap;align-items:baseline;gap:4px;display:inline-flex}.live-poll-derived-strip__label{color:var(--text-faint)}.live-poll-derived-strip__value{font-family:var(--font-display);color:var(--text);letter-spacing:0;align-items:baseline;gap:3px;font-size:14px;font-weight:500;display:inline-flex}.live-poll-derived-strip__unit{font-family:var(--font-mono);color:var(--text-faint);font-size:10px;font-weight:500}.live-poll-derived-strip__delta{font-family:var(--font-mono);color:var(--text-dim);align-items:center;gap:2px;font-size:10px;font-weight:500;display:inline-flex}.live-poll-derived-strip__delta--up{color:var(--coral,#c62828)}.live-poll-derived-strip__delta--down{color:var(--azure,#1565c0)}.auth-corner-chip{top:var(--space-2);right:var(--space-2);z-index:30;border:1px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-rest);transition:transform var(--motion-fast) ease-out, box-shadow var(--motion-fast) ease-out, border-color var(--motion-fast) ease-out;border-radius:50%;justify-content:center;align-items:center;margin:0;padding:0;display:inline-flex;position:fixed}.auth-corner-chip:active{cursor:grabbing;transform:none}.auth-corner-chip:hover,.auth-corner-chip:focus-visible{box-shadow:var(--shadow-raise);border-color:var(--border-strong);outline:none;transform:translateY(-1px)}.auth-corner-chip:focus-visible{box-shadow:var(--shadow-focus)}.auth-corner-chip.is-open{box-shadow:var(--shadow-raise);border-color:var(--border-strong)}.auth-corner-chip__avatar{border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex;position:relative}.auth-corner-chip__avatar-img{object-fit:cover;border-radius:50%;width:28px;height:28px;display:block}.auth-corner-chip__avatar-fallback{background:var(--accent-soft);width:28px;height:28px;color:var(--accent);font-family:var(--font-display);letter-spacing:0;border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:inline-flex}.auth-corner-chip__admin-mark{background:var(--success);width:14px;height:14px;color:var(--surface);box-shadow:0 0 0 1.5px var(--surface);border-radius:50%;justify-content:center;align-items:center;display:inline-flex;position:absolute;bottom:-3px;right:-3px}.auth-corner-chip__admin-mark svg{width:8px;height:8px;display:block}.auth-corner-chip__popover{top:calc(var(--space-2) + 36px + var(--space-2));right:var(--space-2);z-index:30;width:240px;max-width:calc(100vw - var(--space-3));padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface-raised);box-shadow:var(--shadow-raise);gap:var(--space-3);animation:auth-corner-chip-pop var(--motion-base) ease-out;transform-origin:100% 0;flex-direction:column;display:flex;position:fixed}@keyframes auth-corner-chip-pop{0%{opacity:0;transform:translateY(-4px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-corner-chip__user{flex-direction:column;gap:2px;min-width:0;display:flex}.auth-corner-chip__user-name{font-family:var(--font-display);font-size:var(--text-body);color:var(--text);word-break:break-word;font-weight:600}.auth-corner-chip__user-email{font-family:var(--font-mono);font-size:var(--text-caption);color:var(--text-dim);word-break:break-all}.auth-corner-chip__user-role{font-family:var(--font-mono);color:var(--success);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:10px}.auth-corner-chip__divider{background:var(--border);height:1px;margin:0}.auth-corner-chip__section{gap:var(--space-1);flex-direction:column;display:flex}.auth-corner-chip__section-label{font-family:var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.auth-corner-chip__signout,.auth-corner-chip__reset{justify-content:center;width:100%}.sensor-picker-chip{align-items:center;gap:var(--space-2);height:36px;padding:0 var(--space-3);border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface);max-width:clamp(160px,30vw,320px);color:var(--text);font-family:var(--font-mono);font-size:var(--text-caption);letter-spacing:.01em;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-rest);transition:transform var(--motion-fast) ease-out, box-shadow var(--motion-fast) ease-out, border-color var(--motion-fast) ease-out;display:inline-flex}.sensor-picker-chip:active{cursor:grabbing;transform:none}.sensor-picker-chip:hover,.sensor-picker-chip:focus-visible{box-shadow:var(--shadow-raise);border-color:var(--border-strong);outline:none;transform:translateY(-1px)}.sensor-picker-chip:focus-visible{box-shadow:var(--shadow-focus)}.sensor-picker-chip.is-open{box-shadow:var(--shadow-raise);border-color:var(--border-strong)}.sensor-picker-chip.is-positioned{z-index:30;margin:0;position:fixed}.sensor-picker-chip__icon{color:var(--accent);flex:none;justify-content:center;align-items:center;display:inline-flex}.sensor-picker-chip__icon svg{display:block}.sensor-picker-chip__label{text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;overflow:hidden}.sensor-picker-chip__caret{color:var(--text-faint);transition:transform var(--motion-fast) ease-out;flex:none;justify-content:center;align-items:center;display:inline-flex}.sensor-picker-chip.is-open .sensor-picker-chip__caret{color:var(--text-dim);transform:rotate(180deg)}.sensor-picker-chip__popover{top:60px;right:var(--space-3);z-index:30;width:320px;max-width:calc(100vw - var(--space-3));padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius-panel);background:var(--surface-raised);box-shadow:var(--shadow-raise);gap:var(--space-3);animation:sensor-picker-chip-pop var(--motion-base) ease-out;transform-origin:0 0;flex-direction:column;display:flex;position:fixed;left:auto}@keyframes sensor-picker-chip-pop{0%{opacity:0;transform:translateY(-4px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.sensor-picker-chip__section{gap:var(--space-2);flex-direction:column;display:flex}.sensor-picker-chip__section-label{font-family:var(--font-mono);color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.sensor-picker-chip__search,.sensor-picker-chip__select{box-sizing:border-box;border:1.5px solid var(--text-faint);border-radius:var(--radius-input);background:var(--surface);width:100%;min-height:36px;color:var(--text);font-family:var(--font-body);font-size:var(--text-body);padding:8px 10px;line-height:1.2}.sensor-picker-chip__search:focus-visible,.sensor-picker-chip__select:focus-visible{border-color:var(--accent);box-shadow:var(--shadow-focus);outline:none}.sensor-picker-chip__select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--text) 50%), linear-gradient(135deg, var(--text) 50%, transparent 50%);background-position:calc(100% - 16px) calc(50% - 2px),calc(100% - 11px) calc(50% - 2px);background-repeat:no-repeat;background-size:5px 5px,5px 5px;padding-right:28px;box-shadow:0 1px 2px #1f24290f}.sensor-picker-chip__load{border:1px solid var(--accent);border-radius:var(--radius-input);background:var(--accent);width:100%;min-height:40px;color:var(--surface);font-family:var(--font-display);font-weight:600;font-size:var(--text-body);cursor:pointer;transition:background var(--motion-fast) ease-out, box-shadow var(--motion-fast) ease-out, transform var(--motion-fast) ease-out;padding:10px 14px;line-height:1.2}.sensor-picker-chip__load:hover:not(:disabled){box-shadow:var(--shadow-raise);transform:translateY(-1px)}.sensor-picker-chip__load:focus-visible{box-shadow:var(--shadow-focus);outline:none}.sensor-picker-chip__load:disabled{opacity:.5;cursor:not-allowed}.sensor-picker-chip__reset{border:1px solid var(--border);border-radius:var(--radius-input);width:100%;min-height:36px;color:var(--text-dim);font-family:var(--font-body);font-weight:500;font-size:var(--text-caption);cursor:pointer;transition:background var(--motion-fast) ease-out, color var(--motion-fast) ease-out, border-color var(--motion-fast) ease-out;background:0 0;padding:8px 12px;line-height:1.2}.sensor-picker-chip__reset:hover{background:var(--surface-sunken);color:var(--text);border-color:var(--border-strong)}.sensor-picker-chip__reset:focus-visible{box-shadow:var(--shadow-focus);outline:none}.app-root--with-bottom-nav .auth-corner-chip:not(.is-positioned),.app-root--with-bottom-nav .auth-corner-chip__popover{right:calc(max(var(--space-2), (100vw - var(--app-canvas-w)) / 2 + var(--space-2)) + var(--space-3))}.live-poll-section.panel{margin-top:var(--space-3)}.live-poll-title{font-family:var(--font-display);font-size:var(--text-title);letter-spacing:-.005em;color:var(--text);margin:0 0 var(--space-3);font-weight:600}.live-poll-name-tip{margin:-6px 0 12px;font-size:12px}.live-chart-legend-hint{margin-top:6px;font-size:12px}.live-poll-table{border-top:1px solid var(--border);--live-poll-name-track:clamp(7.25rem, 24vw, calc(12.75rem * .7));--live-poll-status-track:40px;--live-poll-status-name-track:clamp(3rem, 9vw, 5rem);--live-poll-trend-track:clamp(5.5rem, 12vw, 8rem);--live-poll-distribution-track:clamp(5.5rem, 11vw, 8rem);--live-poll-mean-track:clamp(8rem, 10vw, 11rem);box-sizing:border-box;width:100%;min-width:0;max-width:100%;padding-inline:clamp(8px,2vw,14px);overflow-x:hidden;container:livepoll/inline-size}.live-poll-section .live-dash-section__body>.live-panel-desc-region--in-body{box-sizing:border-box;padding-inline:clamp(8px,2vw,14px)}.live-poll-head{grid-template-columns:var(--live-poll-name-track) var(--live-poll-status-track) var(--live-poll-status-name-track) minmax(var(--live-poll-trend-track), 1fr) var(--live-poll-mean-track) clamp(11rem, 13vw, 13rem) clamp(4.5rem, 6vw, 6rem);padding:var(--space-2) 0;font-family:var(--sans);letter-spacing:.02em;text-transform:none;color:var(--ink-soft);border-bottom:1px solid var(--border-strong);box-sizing:border-box;align-items:center;gap:6px clamp(4px,1vw,12px);width:100%;min-width:0;max-width:100%;font-size:14px;font-weight:800;display:grid}.live-poll-head-val{justify-content:flex-end;align-self:stretch;align-items:center;width:100%;min-width:0;display:flex}.live-poll-head-val-inner{grid-template-columns:minmax(0,1fr) minmax(3rem,max-content);align-items:center;column-gap:clamp(4px,1vw,8px);width:100%;min-width:0;max-width:100%;display:grid}.live-poll-head-val-label{text-align:right;font-variant-numeric:tabular-nums;justify-self:end;width:100%;min-width:0}.live-poll-head-val-sizer,.live-poll-head>*{min-width:0}.live-poll-head>span:first-child{align-items:center;min-height:0;display:flex}.live-poll-head>span:nth-child(2){text-align:center;justify-content:center;align-items:center;min-height:0;display:flex}.live-poll-head>.live-poll-head-status-name,.live-poll-head>.live-poll-head-trend{text-align:left;justify-content:flex-start;align-items:center;min-height:0;display:flex}.live-poll-head>.live-poll-head-delta{text-align:left;justify-content:flex-start;align-items:center;min-height:0;padding-left:clamp(4px,1vw,12px);display:flex}.live-poll-head>.live-poll-head-metric,.live-poll-head>.live-poll-head-status,.live-poll-head>.live-poll-head-status-name,.live-poll-head>.live-poll-head-trend,.live-poll-head>.live-poll-head-distribution,.live-poll-head>.live-poll-head-mean,.live-poll-head>.live-poll-head-val,.live-poll-head>.live-poll-head-delta{align-self:stretch}.live-poll-head>.live-poll-head-distribution{text-align:left;justify-content:flex-start;align-items:center;min-height:0;display:flex}.live-poll-head>.live-poll-head-mean{text-align:right;justify-content:flex-end;align-items:center;min-height:0;display:flex}.live-poll-row{grid-template-columns:var(--live-poll-name-track) var(--live-poll-status-track) var(--live-poll-status-name-track) minmax(var(--live-poll-trend-track), 1fr) var(--live-poll-mean-track) clamp(11rem, 13vw, 13rem) clamp(4.5rem, 6vw, 6rem);column-gap:clamp(4px,1vw,12px);row-gap:var(--space-2);padding:var(--space-3) 0;border-bottom:1px solid var(--border);box-sizing:border-box;--row-color:var(--ink);align-items:center;width:100%;min-width:0;max-width:100%;display:grid}.live-poll-row--particles{--row-color:var(--pollutant-particles)}.live-poll-row--temp{--row-color:var(--chart-temp)}.live-poll-row--humidity{--row-color:var(--accent)}.live-poll-row--voc{--row-color:var(--pollutant-voc)}.live-poll-row--nox{--row-color:var(--pollutant-nox)}.live-poll-row>*{min-width:0}.live-poll-row>.live-poll-name-cell,.live-poll-row>.live-poll-status-cell,.live-poll-row>.live-poll-status-name,.live-poll-row>.live-poll-trend,.live-poll-row>.live-poll-distribution,.live-poll-row>.live-poll-mean,.live-poll-row>.live-poll-val,.live-poll-row>.live-poll-delta{align-self:stretch}.live-poll-name-cell{flex-direction:column;justify-content:center;width:100%;min-width:0;max-width:100%;display:flex}.live-poll-name-btn{border:1.5px solid color-mix(in srgb, var(--row-color) 55%, transparent);background:color-mix(in srgb, var(--paper) 88%, var(--cream-deep) 12%);box-sizing:border-box;width:100%;max-width:100%;box-shadow:none;cursor:pointer;text-align:left;font-family:var(--sans);letter-spacing:0;color:var(--row-color);white-space:nowrap;text-overflow:ellipsis;text-align:center;border-radius:10px;margin:0;padding:10px 14px;font-size:16px;font-weight:700;text-decoration:none;display:block;overflow-x:hidden}.live-poll-name-btn:hover:not(:disabled){color:var(--row-color);border-color:var(--row-color);background:var(--paper);filter:none}.live-poll-name-btn:active:not(:disabled){box-shadow:none;transform:none}.live-poll-name-btn:focus-visible{outline:2px solid var(--lime-deep);outline-offset:3px}.live-poll-tip{border:1px solid var(--ink);background:var(--paper);font-family:var(--sans);color:var(--ink-soft);white-space:normal;margin-top:6px;padding:8px 10px;font-size:11px;line-height:1.45}.live-poll-status-cell{justify-content:center;align-items:center;min-width:0;max-width:100%;display:flex}.live-poll-status-name{min-width:0;max-width:100%;font-family:var(--sans);letter-spacing:.01em;color:var(--ink-soft);white-space:nowrap;justify-content:flex-start;align-items:center;font-size:16px;font-weight:800;display:flex}.live-poll-status-name--good{color:var(--success)}.live-poll-status-name--warn{color:var(--warn)}.live-poll-status-name--bad{color:var(--danger)}.live-poll-status-name--neutral{color:var(--text-faint)}.live-poll-trend{min-width:0;color:var(--text-dim);flex-direction:column;justify-content:center;align-items:stretch;gap:2px;display:flex}.live-poll-trend--good{color:var(--success)}.live-poll-trend--warn{color:var(--warn)}.live-poll-trend--bad{color:var(--danger)}.live-poll-trend--neutral{color:var(--text-faint)}.live-poll-trend-spark{width:100%;height:28px;max-height:28px;display:block}.live-poll-trend-range{font-family:var(--sans);letter-spacing:.01em;color:var(--ink-soft);text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;overflow:hidden}.live-poll-trend-dash{font-family:var(--font-mono);color:var(--text-faint);align-self:center;font-size:12px}.live-poll-distribution{flex-direction:column;justify-content:center;align-items:stretch;gap:4px;min-width:0;display:flex}.live-poll-distribution-bar{background:var(--surface-soft,#f1f3f5);border:1px solid var(--border,#e4e8eb);border-radius:4px;width:100%;height:8px;display:flex;overflow:hidden}.live-poll-distribution-seg{min-width:1px;height:100%;display:block}.live-poll-distribution-seg--good{background:var(--success)}.live-poll-distribution-seg--warn{background:var(--warn)}.live-poll-distribution-seg--bad{background:var(--danger)}.live-poll-distribution-seg--neutral{background:var(--text-faint);opacity:.35}.live-poll-distribution-label{font-family:var(--font-mono);letter-spacing:.02em;color:var(--text-faint);text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;text-overflow:ellipsis;font-size:10px;font-weight:500;overflow:hidden}.live-poll-distribution-label--good{color:var(--success)}.live-poll-distribution-label--warn{color:var(--warn)}.live-poll-distribution-label--bad{color:var(--danger)}.live-poll-distribution-label--neutral{color:var(--text-faint)}.live-poll-distribution-dash{font-family:var(--font-mono);color:var(--text-faint);align-self:center;font-size:12px}.live-poll-mean{justify-content:flex-end;align-items:center;min-width:0;display:flex}.live-poll-mean-inner{perspective:640px;perspective-origin:50% 0;justify-content:flex-end;align-items:baseline;gap:4px;min-width:0;display:inline-flex}.live-poll-mean-num{font-family:var(--font-display);letter-spacing:-.01em;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;transform-origin:50% 0;transform-style:preserve-3d;border-radius:6px;margin:-1px -4px;padding:1px 4px;font-size:20px;font-weight:800}.live-poll-mean-num--cal-flip-up{animation:.52s ease-in-out both live-poll-cal-flip-up}.live-poll-mean-num--cal-flip-down{animation:.52s ease-in-out both live-poll-cal-flip-down}.live-poll-mean-unit{font-family:var(--sans);color:var(--ink-soft);white-space:nowrap;font-size:13px;font-weight:700}.live-poll-mean-dash{font-family:var(--font-mono);color:var(--text-faint);align-self:center;font-size:12px}@container livepoll (width<=1079px){.live-poll-table .live-poll-head,.live-poll-table .live-poll-row{grid-template-columns:var(--live-poll-name-track) var(--live-poll-status-track) var(--live-poll-status-name-track) var(--live-poll-trend-track) minmax(0, 1fr) minmax(5.5rem, .42fr);column-gap:12px}.live-poll-table .live-poll-head>.live-poll-head-distribution,.live-poll-table .live-poll-row>.live-poll-distribution,.live-poll-table .live-poll-head>.live-poll-head-mean,.live-poll-table .live-poll-row>.live-poll-mean{display:none}}@container livepoll (width<=720px){.live-poll-table .live-poll-head,.live-poll-table .live-poll-row{grid-template-columns:var(--live-poll-name-track) var(--live-poll-status-track) var(--live-poll-status-name-track) minmax(0, 1fr) minmax(5.5rem, .42fr);column-gap:10px}.live-poll-table .live-poll-head>.live-poll-head-trend,.live-poll-table .live-poll-row>.live-poll-trend,.live-poll-table .live-poll-head>.live-poll-head-distribution,.live-poll-table .live-poll-row>.live-poll-distribution,.live-poll-table .live-poll-head>.live-poll-head-mean,.live-poll-table .live-poll-row>.live-poll-mean{display:none}}@container livepoll (width<=519px){.live-poll-table{padding-inline:0}.live-poll-table .live-poll-head,.live-poll-table .live-poll-row{grid-template-columns:minmax(5.5rem, 7rem) var(--live-poll-status-track) minmax(2.75rem, 3.5rem) minmax(0, 1fr);column-gap:6px}.live-poll-table .live-poll-head>.live-poll-head-trend,.live-poll-table .live-poll-row>.live-poll-trend,.live-poll-table .live-poll-head>.live-poll-head-distribution,.live-poll-table .live-poll-row>.live-poll-distribution,.live-poll-table .live-poll-head>.live-poll-head-mean,.live-poll-table .live-poll-row>.live-poll-mean,.live-poll-table .live-poll-head>.live-poll-head-delta,.live-poll-table .live-poll-row>.live-poll-delta{display:none}.live-poll-table .live-poll-name-btn{padding:8px 10px;font-size:13px}.live-poll-table .live-poll-val-inner{justify-content:flex-end;align-items:baseline;gap:4px;display:flex}.live-poll-table .live-poll-val-num{text-align:right;width:auto;max-width:none;font-size:16px}.live-poll-table .live-poll-val-unit{flex:none}.live-poll-table .live-poll-head-val-inner{justify-content:flex-end;align-items:center;gap:4px;display:flex}.live-poll-table .live-poll-head-val-label{white-space:nowrap;width:auto}.live-poll-table .live-poll-head-val-sizer{display:none}}.live-poll-status-glyph{flex:none;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.live-poll-status-glyph--good{color:var(--success)}.live-poll-status-glyph--warn{color:var(--warn)}.live-poll-status-glyph--bad{color:var(--danger)}.live-poll-status-glyph--neutral{color:var(--text-faint)}.live-poll-val{justify-content:flex-end;align-items:center;width:100%;min-width:0;display:flex}.live-poll-val-dash{font-family:var(--display);color:var(--ink-mute);text-align:right;width:100%;font-size:clamp(14px,3.8vw,18px)}.live-poll-val-inner{grid-template-columns:minmax(0,1fr) minmax(3rem,max-content);align-items:center;column-gap:clamp(4px,1vw,8px);width:100%;min-width:0;max-width:100%;display:grid}.live-poll-val-flip-scene{perspective:640px;perspective-origin:50% 0;text-align:right;justify-self:stretch;width:100%;min-width:0;display:block}.live-poll-val-num{width:100%;max-width:100%;font-family:var(--font-display);letter-spacing:-.02em;color:var(--ink);text-align:right;font-variant-numeric:tabular-nums;box-sizing:border-box;white-space:nowrap;text-overflow:ellipsis;transform-origin:50% 0;min-width:0;transform-style:preserve-3d;border-radius:6px;place-self:center stretch;margin:-1px -4px;padding:1px 4px;font-size:clamp(18px,.95rem + 1.3cqi,28px);font-weight:900;display:inline-block;overflow:hidden}.live-poll-val-num--cal-flip-up{animation:.52s ease-in-out both live-poll-cal-flip-up}.live-poll-val-num--cal-flip-down{animation:.52s ease-in-out both live-poll-cal-flip-down}@keyframes live-poll-cal-flip-up{0%{box-shadow:none;background-color:#0000;transform:rotateX(0)}48%{background-color:color-mix(in srgb, #c62828 28%, var(--paper) 72%);transform:rotateX(-86deg);box-shadow:0 10px #c6282838}52%{background-color:color-mix(in srgb, #c62828 22%, var(--paper) 78%);transform:rotateX(86deg);box-shadow:0 -8px #c6282829}to{box-shadow:none;background-color:#0000;transform:rotateX(0)}}@keyframes live-poll-cal-flip-down{0%{box-shadow:none;background-color:#0000;transform:rotateX(0)}48%{background-color:color-mix(in srgb, #1565c0 28%, var(--paper) 72%);transform:rotateX(-86deg);box-shadow:0 10px #1565c038}52%{background-color:color-mix(in srgb, #1565c0 22%, var(--paper) 78%);transform:rotateX(86deg);box-shadow:0 -8px #1565c029}to{box-shadow:none;background-color:#0000;transform:rotateX(0)}}@media (prefers-reduced-motion:reduce){.live-poll-val-num--cal-flip-up,.live-poll-val-num--cal-flip-down{animation:none}}.live-poll-val-unit{font-family:var(--sans);color:var(--ink-soft);text-transform:none;letter-spacing:0;text-align:left;white-space:nowrap;text-overflow:ellipsis;justify-self:start;min-width:0;font-size:13px;font-weight:700;overflow:hidden}.live-poll-delta{width:100%;min-width:0;max-width:100%;font-family:var(--sans);color:var(--ink);justify-content:flex-start;align-items:center;padding-left:clamp(4px,1vw,12px);font-size:15px;font-weight:800;display:flex}.live-poll-delta-dash{text-align:left;justify-content:flex-start;align-items:center;width:100%;min-height:0;display:flex}.live-poll-delta-inner{border:1.25px solid color-mix(in srgb, var(--ink) 45%, transparent);background:var(--paper);border-radius:999px;flex-flow:row;justify-content:center;align-items:center;gap:6px;min-width:0;max-width:100%;padding:3px 12px;display:inline-flex}.live-poll-delta-glyph{flex-shrink:0;align-items:center;line-height:0;display:flex}.live-poll-delta-num{font-family:inherit;font-weight:inherit;font-variant-numeric:tabular-nums;text-align:left;min-width:0;color:inherit}.live-poll-delta-arrow{font-family:inherit;font-weight:inherit;flex-shrink:0;justify-content:center;align-items:center;font-size:1.15em;line-height:1;display:inline-flex}.live-poll-delta-arrow--up{color:var(--warn)}.live-poll-delta-arrow--down{color:var(--success)}.intro-screen{background:linear-gradient(180deg, var(--accent-soft) 0%, color-mix(in srgb, var(--accent-soft) 72%, var(--accent) 22%) 100%);flex-direction:column;min-height:100svh;display:flex}.intro-screen-top{border-bottom:2px solid var(--ink);justify-content:space-between;align-items:center;padding:12px 28px;display:flex}.intro-screen-brand{font-family:var(--serif);letter-spacing:-.03em;font-size:clamp(20px,3vw,28px);font-weight:700}.intro-screen-inner{flex-direction:column;flex:1;justify-content:center;gap:20px;max-width:620px;margin:0 auto;padding:20px 28px 28px;display:flex;position:relative}.intro-screen-copy{flex-direction:column;min-width:0;display:flex;transform:translate(-4px,-4px)}.intro-screen-eyebrow{font-family:var(--font-display);letter-spacing:-.005em;color:var(--text);text-transform:none;margin:0 0 12px;font-size:clamp(16px,1.9vw,19px);font-weight:600;line-height:1.4}.intro-screen-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text);margin:0 0 10px;font-size:clamp(22px,3.2vw,30px);font-weight:600;line-height:1.2}.intro-screen-lead{font-family:var(--sans);color:var(--text);margin:0 0 14px;font-size:clamp(15px,1.7vw,17px);font-weight:600;line-height:1.5}.intro-screen-lead--ko{margin-bottom:16px}.intro-screen-body{font-family:var(--sans);color:var(--ink-mute);margin:0 0 14px;font-size:15px;line-height:1.55}.intro-screen-tagline{font-family:var(--serif);color:var(--ink);letter-spacing:-.02em;margin:0 0 28px;font-size:clamp(17px,2.4vw,20px);font-weight:700}.intro-screen-steps{grid-template-columns:max-content minmax(0,1fr);gap:8px 18px;margin:0 0 14px;padding:0;list-style:none;display:grid}.intro-screen-step{grid-template-columns:subgrid;grid-column:1/-1;align-items:baseline;display:grid}.intro-screen-step__title{font-family:var(--sans);color:var(--text);letter-spacing:-.01em;margin:0;font-size:15px;font-weight:700;line-height:1.4}.intro-screen-step__body{font-family:var(--sans);color:var(--text);margin:0;font-size:14px;font-weight:400;line-height:1.55}.intro-screen-start{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:clamp(12px,2vw,24px) clamp(16px,3vw,32px);display:flex}.intro-screen-trust{font-family:var(--font-body);letter-spacing:-.01em;color:var(--text);margin:0;font-size:16px;font-weight:700;line-height:1.4}.intro-screen-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.intro-screen-skip{min-width:120px}.intro-screen-cta{min-width:168px}.intro-screen-footnote{color:var(--ink-mute);font-size:12px;line-height:1.5;font-family:var(--sans);margin:18px 0 0}.intro-screen-mascot{--intro-mascot-opacity-target:1;aspect-ratio:1055/720;opacity:0;pointer-events:none;align-self:center;width:clamp(240px,70vw,360px);animation:.5s ease-out .1s forwards intro-mascot-fade-in;position:relative}.intro-screen-mascot__primary,.intro-screen-mascot__partner,.live-empty-state__mascot__primary,.live-empty-state__mascot__partner,.auth-gate-pair__primary,.auth-gate-pair__partner{pointer-events:none;-webkit-user-select:none;user-select:none;height:auto;position:absolute}.intro-screen-mascot__primary,.live-empty-state__mascot__primary{filter:drop-shadow(0 10px 22px #0f172a2e);width:70%;bottom:0;right:0}.intro-screen-mascot__partner,.live-empty-state__mascot__partner{filter:drop-shadow(0 6px 14px #0f172a1f);width:44%;bottom:3%;left:0}.live-empty-state{align-items:center;min-height:240px;padding:24px 22px;display:flex;position:relative;overflow:hidden}.live-empty-state--loading{z-index:21;text-align:center;width:clamp(280px,70vw,460px);max-width:calc(100dvw - 32px);min-height:clamp(260px,38vh,320px);max-height:calc(100dvh - 32px);margin:0;padding:0;display:block;position:fixed;top:50%;left:50%;overflow:visible;transform:translate(-50%,-50%)}.live-empty-state--loading .live-empty-state__copy{box-sizing:border-box;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:clamp(14px,1.4vw,18px);width:100%;max-width:420px;padding:clamp(28px,4vw,44px) clamp(20px,3vw,28px);display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.live-loading-overlay{z-index:20;background:var(--cream,var(--paper));position:fixed;inset:0}.live-empty-state__copy{z-index:1;max-width:460px;position:relative}.tk-spinner{width:clamp(44px,5vw,56px);height:clamp(44px,5vw,56px);color:var(--ink);position:relative}.tk-spinner>span{transform-origin:50% 178.5%;background:currentColor;border-radius:999px;width:8%;height:28%;margin-left:-4%;animation:1.1s linear infinite tk-spinner-fade;display:block;position:absolute;top:0;left:50%}.tk-spinner>span:first-child{animation-delay:-1.0083s;transform:rotate(0)}.tk-spinner>span:nth-child(2){animation-delay:-.9166s;transform:rotate(30deg)}.tk-spinner>span:nth-child(3){animation-delay:-.825s;transform:rotate(60deg)}.tk-spinner>span:nth-child(4){animation-delay:-.7333s;transform:rotate(90deg)}.tk-spinner>span:nth-child(5){animation-delay:-.6416s;transform:rotate(120deg)}.tk-spinner>span:nth-child(6){animation-delay:-.55s;transform:rotate(150deg)}.tk-spinner>span:nth-child(7){animation-delay:-.4583s;transform:rotate(180deg)}.tk-spinner>span:nth-child(8){animation-delay:-.3666s;transform:rotate(210deg)}.tk-spinner>span:nth-child(9){animation-delay:-.275s;transform:rotate(240deg)}.tk-spinner>span:nth-child(10){animation-delay:-.1833s;transform:rotate(270deg)}.tk-spinner>span:nth-child(11){animation-delay:-.0916s;transform:rotate(300deg)}.tk-spinner>span:nth-child(12){animation-delay:0s;transform:rotate(330deg)}@keyframes tk-spinner-fade{0%{opacity:1}to{opacity:.18}}@media (prefers-reduced-motion:reduce){.tk-spinner>span{opacity:.4;animation:none}}.live-empty-state__copy h2{font-family:var(--serif);letter-spacing:-.02em;margin:0 0 10px;font-size:clamp(24px,3.6vw,30px);line-height:1.2}.live-empty-state__copy p{font-family:var(--sans);color:var(--ink-mute);margin:0 0 8px;line-height:1.5}.live-empty-state__mascot{aspect-ratio:320/230;pointer-events:none;opacity:.22;filter:saturate(.82)brightness(1.03);width:clamp(190px,28vw,270px);position:absolute;bottom:6px;right:10px;-webkit-mask-image:radial-gradient(78% 70% at 62% 56%,#000 56%,#000000b8 74%,#0000 100%);mask-image:radial-gradient(78% 70% at 62% 56%,#000 56%,#000000b8 74%,#0000 100%)}.auth-gate-screen{background:linear-gradient(180deg, var(--accent-soft) 0%, color-mix(in srgb, var(--accent-soft) 72%, var(--accent) 22%) 100%);flex-direction:column;min-height:100vh;display:flex}.auth-gate-top{border-bottom:2px solid var(--ink);justify-content:space-between;align-items:center;padding:20px 28px;display:flex}.auth-gate-brand{font-family:var(--serif);letter-spacing:-.03em;font-size:clamp(20px,3vw,28px);font-weight:700}.auth-gate-center{flex:1;justify-content:center;align-items:center;padding:32px 20px 60px;display:flex}.auth-gate-card{border:2px solid var(--ink);background:var(--paper);width:100%;max-width:420px;box-shadow:8px 8px 0 var(--ink);padding:36px 32px 32px}.auth-gate-pair{aspect-ratio:320/230;width:clamp(160px,24vw,210px);margin:-12px auto 14px;display:block;position:relative}.auth-gate-pair__primary{filter:drop-shadow(0 8px 16px #0f172a24);width:70%;bottom:0;right:2%}.auth-gate-pair__partner{filter:drop-shadow(0 4px 10px #0f172a1a);width:46%;bottom:5%;left:0}@media (width<=480px){.auth-gate-pair{width:clamp(150px,40vw,188px);margin-top:-6px}}.auth-gate-oauth-buttons{flex-direction:column;align-items:center;gap:12px;width:100%;max-width:400px;margin:0 auto 12px;display:flex}.auth-gate-google-slot{flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:44px;display:flex}.auth-gate-google-slot__host{border-radius:999px;justify-content:center;align-items:center;width:max-content;max-width:280px;margin:0 auto;display:inline-flex;overflow:hidden}.auth-gate-google-slot__placeholder{color:var(--smog,#8a8a8a);text-align:center;margin:6px 0 0;font-size:12px}.auth-gate-kakao{width:var(--auth-gate-button-width,100%);background:var(--tk-primary);color:#fff;max-width:280px;height:40px;font-family:var(--sans,inherit);letter-spacing:.25px;cursor:pointer;box-shadow:none;border:none;border-radius:999px;justify-content:center;align-items:center;gap:12px;padding:0 12px;font-size:14px;font-weight:500;transition:filter .15s,transform .15s,opacity .15s;display:inline-flex}.auth-gate-kakao:hover:not(:disabled){filter:brightness(1.04)}.auth-gate-kakao:active:not(:disabled){filter:brightness(.96);transform:scale(.98)}.auth-gate-kakao:disabled{opacity:.55;cursor:wait}.auth-gate-kakao__icon{color:#fff;flex:none;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.auth-gate-kakao__icon>svg{width:18px;height:18px;display:block}.auth-gate-kakao__label{line-height:1;display:inline-block}.btn-kakao{border:2px solid var(--ink);color:var(--ink);cursor:pointer;font-weight:700;font-family:var(--sans);letter-spacing:-.02em;box-shadow:3px 3px 0 var(--ink);background:#fee500;border-radius:12px;padding:10px 18px;font-size:14px;transition:transform .15s cubic-bezier(.4,0,.2,1),box-shadow .15s cubic-bezier(.4,0,.2,1)}.btn-kakao:hover:not(:disabled){filter:brightness(1.02)}.btn-kakao:active:not(:disabled){box-shadow:1px 1px 0 var(--ink);transform:translate(2px,2px)}.btn-kakao:disabled{opacity:.55;cursor:wait;box-shadow:2px 2px 0 var(--smog)}.auth-gate-notice{margin:14px 0 0;font-size:13px}.auth-gate-replay{font-family:var(--sans);color:var(--ink-mute);cursor:pointer;background:0 0;border:none;margin-top:22px;padding:0;font-size:13px;font-weight:700;text-decoration:underline}.auth-gate-replay:hover{color:var(--ink)}:root{--tk-primary:#35c5f0;--tk-ozone:#2bb9a9;--tk-bg:#f7f9fc;--tk-surface:#fff;--tk-surface-soft:#f4f7fb;--tk-border:#e6ecf2;--tk-text-strong:#111827;--tk-text:#334155;--tk-text-muted:#64748b;--tk-danger:#dc2626;--tk-success:#16a34a;--tk-radius:12px;--tk-shadow:0 1px 3px #0f172a14, 0 8px 20px #0f172a0f}html,body{background:var(--tk-bg);color:var(--tk-text);font-family:Noto Sans KR,Pretendard Variable,Pretendard,SUITE Variable,SUITE,-apple-system,BlinkMacSystemFont,sans-serif}body{background-image:none}.app-frame-inner{width:100%;max-width:min(1200px,100vw);margin:0 auto}.app{width:100%;max-width:none;color:var(--tk-text);margin:0;padding:clamp(12px,2vw,20px) clamp(12px,2vw,24px) clamp(20px,3vw,36px)}.header{border-bottom:1px solid var(--tk-border);padding-bottom:16px}.header h1,.live-dash-section__h,.storage-toolbar h2,.live-poll-title{color:var(--tk-text-strong);letter-spacing:-.01em;font-weight:700}.sub,.live-aqi-footnote,.intro-screen-body{color:var(--tk-text-muted);font-size:13px;font-weight:400}.auth-toolbar{border-top:none;border-bottom:1px solid var(--tk-border);background:var(--tk-surface);width:100%;max-width:none;margin:0;padding:clamp(10px,1.8vw,18px) clamp(12px,2vw,24px)}.auth-toolbar-bar{--chrome-control-h:44px;flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:clamp(8px,1.6vw,16px);min-width:0;display:flex}.theme-lang-controls{--chrome-control-h:46px}.theme-select{border:1.5px solid var(--tk-border);height:44px;min-height:44px}.auth-toolbar-left,.auth-toolbar-right{min-width:0}.auth-toolbar-right{flex:auto;justify-content:flex-end;display:flex}.auth-session-chip{border:1px solid var(--tk-border);background:var(--tk-surface-soft);box-shadow:none;border-radius:999px;min-width:0;max-width:100%}.auth-toolbar-bar .auth-session-chip{border-width:1.5px;height:46px;min-height:46px;padding:0 11px}.auth-toolbar-bar .btn-signout{height:36px;min-height:36px;padding:0 12px}.lang-toggle{border:1.5px solid var(--tk-border);background:var(--tk-surface-soft);height:46px;min-height:46px;box-shadow:none}.auth-session-name{color:var(--tk-text-strong);font-weight:700}.btn-signout{flex-shrink:0;margin-left:8px}.app-nav:not(.app-nav--bottom){flex-flow:column;align-items:stretch;gap:10px;width:100%;min-width:0;padding:clamp(10px,1.8vw,16px) clamp(12px,2vw,24px) 0;display:flex}.app-nav--bottom{padding-inline:0;display:flex}.app-nav__main{flex-wrap:wrap;align-items:center;gap:10px;width:100%;min-width:0;display:flex}.nav-tab{border:1px solid var(--tk-border);color:var(--tk-text);box-shadow:none;text-transform:none;letter-spacing:0;background:0 0;border-radius:999px;min-height:40px;padding:0 14px;font-size:13px;font-weight:700}.nav-tab.active{background:color-mix(in srgb, var(--tk-primary) 18%, var(--tk-surface) 82%);color:#0f172a;border-color:color-mix(in srgb, var(--tk-primary) 55%, var(--tk-border) 45%)}.app-nav--bottom{border-top:1px solid var(--tk-border);background:var(--tk-surface);box-shadow:0 -4px 16px #0f172a0f}.app-nav--bottom .nav-tab{box-shadow:none;text-transform:none;letter-spacing:0;background:0 0;border:none;border-top:3px solid #0000;border-radius:0;min-height:56px;font-size:11px;font-weight:600}.app-nav--bottom .nav-tab.active{background:color-mix(in srgb, var(--tk-primary) 12%, var(--tk-surface) 88%);color:var(--tk-text-strong);border-top-color:var(--tk-primary)}.app-nav__hint,.live-panel-desc-hint{border:1px solid var(--tk-border);box-shadow:none;background:var(--tk-surface);color:var(--tk-text)}button,.btn-google,.btn-kakao,.btn-secondary{border:1px solid var(--tk-border);box-shadow:none;background:var(--tk-surface-soft);color:var(--tk-text-strong);border-radius:10px;font-size:13px;font-weight:700}.auth-gate-replay{box-shadow:none;background:0 0;border:none}.lang-toggle .lang-toggle-opt{box-shadow:none;background:0 0}.lang-toggle .lang-toggle-opt.active{background:var(--lime);color:var(--ink)}.intro-screen-cta,.live-device-load-btn,.auth-gate-kakao,.tab-active{background:var(--tk-primary);color:#fff;border-color:var(--tk-primary)}button:active,.btn-google:active:not(:disabled),.btn-kakao:active:not(:disabled),.intro-screen-cta:active,.live-poll-name-btn:active:not(:disabled){transform:scale(.97)}.panel,.card,.storage-card,.auth-gate-card,.live-panel-layout-dialog,.chart,.explorer-table-wrap,.admin-table-wrap,.live-poll-table,.status{border:1px solid var(--tk-border);border-radius:var(--tk-radius);background:var(--tk-surface);box-shadow:var(--tk-shadow)}.panel{margin-top:var(--space-3);padding:12px}.card{box-shadow:var(--tk-shadow);border:none;padding:10px}.card h3{color:var(--tk-text-muted);letter-spacing:0;text-transform:none;font-size:11px;font-weight:400}.card p{color:var(--tk-text-strong);font-size:14px;font-weight:700}.live-live-dot.on{background:var(--tk-ozone)}.status,.chart,.live-hero-inner{background-image:none}.explorer-grid{grid-template-columns:repeat(1,minmax(0,1fr));gap:10px;display:grid}.twinkeep-wordmark{white-space:nowrap;font-family:var(--font-display);font-size:inherit;letter-spacing:-.025em;align-items:baseline;font-weight:600;line-height:1.05;display:inline-flex}.twinkeep-wordmark__twin{color:var(--text)}.twinkeep-wordmark__keep{color:var(--accent)}.twinkeep-wordmark__air{color:var(--text);margin-left:.22em}.twinkeep-wordmark__sm{letter-spacing:0;vertical-align:baseline;color:var(--ink-mute,var(--text));opacity:.78;margin-left:.05em;font-size:.48em;font-weight:500;display:inline-block;transform:translateY(-.6em)}.intro-screen-title{word-break:keep-all}.intro-screen-title .twinkeep-wordmark{margin-right:.06em;font-size:1.05em}.intro-screen-brand .twinkeep-wordmark{font-size:20px}@media (width>=960px){.intro-screen-inner{grid-template-columns:minmax(0,1fr) clamp(280px,28vw,360px);align-items:center;gap:clamp(28px,4vw,56px);max-width:1120px;padding-block:clamp(20px,3vw,40px);display:grid}.intro-screen-copy{max-width:560px;transform:none}.intro-screen-mascot{width:100%;margin:0}}@media (width<=640px){.intro-screen-copy{max-width:100%;transform:none}.intro-screen-mascot{width:clamp(220px,78vw,320px)}.live-empty-state{min-height:210px;padding:18px 14px}.live-empty-state__copy{max-width:100%;padding-right:120px}.live-empty-state__mascot{opacity:.9;filter:none;width:clamp(146px,40vw,196px);bottom:4px;right:4px;-webkit-mask-image:none;mask-image:none}}@media (prefers-reduced-motion:reduce){.intro-screen-mascot{opacity:var(--intro-mascot-opacity-target);animation:none}}@keyframes intro-mascot-fade-in{0%{opacity:0}to{opacity:var(--intro-mascot-opacity-target)}}.live-device-strip-inner,.controls-row.live-device-row{width:100%;min-width:0}.controls-row.live-device-row{flex-wrap:wrap;justify-content:flex-start}.live-device-select-label{min-width:min(100%,280px)}.live-device-select-wrap,.live-device-select-wrap select{min-width:0;max-width:100%}.live-poll-name-btn,.legend-item{border:1.5px solid color-mix(in srgb, var(--row-color,var(--text-faint)) 55%, transparent);background:var(--tk-surface-soft);color:var(--row-color,var(--tk-text));box-shadow:0 1px 2px #1f242914}.live-poll-row,.live-poll-head{grid-template-columns:minmax(7.25rem, var(--live-poll-name-track)) var(--live-poll-status-track) var(--live-poll-status-name-track) minmax(var(--live-poll-trend-track), 1fr) var(--live-poll-mean-track) clamp(11rem, 13vw, 13rem) clamp(4.5rem, 6vw, 6rem);column-gap:14px}@media (width>=768px){.explorer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.panel{padding:14px}}@media (width<=640px){.auth-toolbar{padding-inline:12px}.auth-toolbar-bar .auth-session-chip{padding-inline:6px}.auth-toolbar-bar .btn-signout{padding-inline:10px}.app-nav{padding-inline:12px}}.tk-surface{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-panel);box-shadow:var(--shadow-rest);padding:var(--space-4);color:var(--text)}.tk-surface--inset{background:var(--surface-sunken);box-shadow:none;border-color:#0000}.tk-surface--padding-lg{padding:var(--space-5)}.tk-surface--padding-none{padding:0}.tk-field{gap:var(--space-1);flex-direction:column;min-width:0;display:flex}.tk-field__label{font-family:var(--font-mono);font-size:var(--text-caption);letter-spacing:.04em;text-transform:uppercase;color:var(--text-dim);font-weight:500}.tk-field__label-required{color:var(--danger);margin-inline-start:2px}.tk-field__hint,.tk-field__error{font-size:var(--text-caption);margin:0;line-height:1.4}.tk-field__hint{color:var(--text-faint)}.tk-field__error{color:var(--danger)}.tk-field__control,.tk-field__textarea,.tk-field__select{box-sizing:border-box;background:var(--surface);width:100%;min-width:0;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-input);padding:0 var(--space-3);height:38px;font-family:var(--font-body);font-size:var(--text-body);transition:border-color var(--motion-fast), box-shadow var(--motion-fast);line-height:1.4}.tk-field__textarea{height:auto;min-height:96px;padding:var(--space-2) var(--space-3);resize:vertical;line-height:1.5}.tk-field__select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--text-dim) 50%), linear-gradient(135deg, var(--text-dim) 50%, transparent 50%);background-position:calc(100% - 16px),calc(100% - 11px);background-repeat:no-repeat;background-size:5px 5px,5px 5px;padding-inline-end:var(--space-6)}.tk-field__control::placeholder,.tk-field__textarea::placeholder{color:var(--text-faint)}.tk-field__control:focus-visible,.tk-field__textarea:focus-visible,.tk-field__select:focus-visible{border-color:var(--accent);box-shadow:var(--shadow-focus);outline:none}.tk-field--error .tk-field__control,.tk-field--error .tk-field__textarea,.tk-field--error .tk-field__select{border-color:var(--danger)}.tk-field--error .tk-field__control:focus-visible,.tk-field--error .tk-field__textarea:focus-visible,.tk-field--error .tk-field__select:focus-visible{box-shadow:0 0 0 3px color-mix(in srgb, var(--danger) 22%, transparent)}.tk-field__control:disabled,.tk-field__textarea:disabled,.tk-field__select:disabled{background:var(--surface-sunken);color:var(--text-dim);cursor:not-allowed}.tk-btn{justify-content:center;align-items:center;gap:var(--space-2);font-family:var(--font-body);letter-spacing:0;border-radius:var(--radius-input);cursor:pointer;transition:background-color var(--motion-fast), border-color var(--motion-fast), color var(--motion-fast), box-shadow var(--motion-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;font-weight:500;line-height:1;text-decoration:none;display:inline-flex}.tk-btn:focus-visible{box-shadow:var(--shadow-focus);outline:none}.tk-btn:disabled,.tk-btn[aria-disabled=true],.tk-btn--loading{cursor:not-allowed;opacity:.55;pointer-events:none}.tk-btn--md{height:38px;padding:0 var(--space-4);font-size:var(--text-body)}.tk-btn--sm{height:30px;padding:0 var(--space-3);font-size:var(--text-caption)}.tk-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.tk-btn--primary:hover{background:color-mix(in srgb, var(--accent) 88%, #000);border-color:color-mix(in srgb, var(--accent) 88%, #000)}.tk-btn--ghost{background:var(--surface);color:var(--text);border-color:var(--border)}.tk-btn--ghost:hover{background:var(--surface-sunken);border-color:var(--border-strong)}.tk-btn--danger{background:var(--danger);color:#fff;border-color:var(--danger)}.tk-btn--danger:hover{background:color-mix(in srgb, var(--danger) 88%, #000);border-color:color-mix(in srgb, var(--danger) 88%, #000)}.tk-btn__icon{flex:none;justify-content:center;align-items:center;width:14px;height:14px;display:inline-flex}.tk-btn__spinner{border-radius:var(--radius-pill);border:1.5px solid;border-right-color:#0000;width:12px;height:12px;animation:.72s linear infinite tk-btn-spin}@keyframes tk-btn-spin{to{transform:rotate(360deg)}}.tk-badge{align-items:center;gap:var(--space-1);border-radius:var(--radius-pill);height:22px;font-family:var(--font-mono);letter-spacing:.03em;white-space:nowrap;border:1px solid #0000;padding:0 10px;font-size:11px;font-weight:500;line-height:1;display:inline-flex}.tk-badge__glyph{flex:none;justify-content:center;align-items:center;width:10px;height:10px;font-size:9px;line-height:1;display:inline-flex}.tk-badge--success{background:var(--success-soft);color:var(--success);border-color:color-mix(in srgb, var(--success) 38%, var(--border))}.tk-badge--warn{background:var(--warn-soft);color:var(--warn);border-color:color-mix(in srgb, var(--warn) 38%, var(--border))}.tk-badge--danger{background:var(--danger-soft);color:var(--danger);border-color:color-mix(in srgb, var(--danger) 38%, var(--border))}.tk-badge--neutral{background:var(--surface-sunken);color:var(--text-dim);border-color:var(--border)}.tk-data{align-items:baseline;gap:var(--space-1);color:var(--text);flex-direction:column;display:inline-flex}.tk-data__row{align-items:baseline;gap:var(--space-2);display:inline-flex}.tk-data__value{font-family:var(--font-display);font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--text);font-weight:600;line-height:1}.tk-data--xl .tk-data__value{letter-spacing:-.04em;font-size:56px}@media (width>=768px){.tk-data--xl .tk-data__value{font-size:60px}}.tk-data--lg .tk-data__value{letter-spacing:-.03em;font-size:32px}.tk-data--md .tk-data__value{letter-spacing:-.01em;font-size:18px}.tk-data__unit{font-family:var(--font-mono);color:var(--text-faint);letter-spacing:0;font-weight:500;line-height:1}.tk-data--xl .tk-data__unit{color:var(--text);font-size:14px;font-weight:600}.tk-data--lg .tk-data__unit{font-size:12px}.tk-data--md .tk-data__unit{font-size:10px}.tk-data__trend{font-family:var(--font-mono);align-items:baseline;gap:4px;font-weight:600;line-height:1;display:inline-flex}.tk-data__trend-glyph{font-family:var(--font-mono);line-height:1}.tk-data__trend-delta{font-family:var(--font-mono);font-variant-numeric:tabular-nums;letter-spacing:0;font-weight:600}.tk-data--xl .tk-data__trend{font-size:16px}.tk-data--lg .tk-data__trend{font-size:13px}.tk-data--md .tk-data__trend{font-size:11px}.tk-data__trend--up{color:var(--success)}.tk-data__trend--down{color:var(--danger)}.tk-data__trend--flat{color:var(--text-dim)}.tk-data__caption{font-family:var(--font-mono);font-size:var(--text-caption);letter-spacing:.03em;text-transform:uppercase;color:var(--text-faint);font-weight:500}
