*{box-sizing:border-box}html{--app-canvas-w:1320px;--app-gutter-x:clamp(8px, 2.6vw, 32px);--app-gutter-y:clamp(10px, 2.2vw, 32px)}html,body{min-height:100%;margin:0;overflow-x:hidden}body{font-family:var(--sans);color:var(--ink);background-color:var(--cream);background-image:radial-gradient(circle at 1px 1px, var(--body-dot) 1px, transparent 0);background-size:3px 3px}#root{flex-direction:column;min-width:0;max-width:100%;min-height:100vh;display:flex;overflow-x:hidden}html[data-app-theme=ozone]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--tk-primary:#a8e020;--ink:#0a0a0f;--ink-soft:#1a1a22;--ink-mute:#4a4a55;--lime:#c7ff3d;--lime-deep:#a8e020;--lime-soft:#e8ffaa;--lime-tint:#f4ffe0;--brand-twin:#0468d7;--theme-select-fill:var(--lime-deep);--theme-select-label:var(--ink);--theme-select-border:var(--ink);--theme-select-sheen:inset 0 0 0 1px #ffffff59;--cream:#f4f0e6;--cream-deep:#ede7d7;--paper:#faf7ee;--coral:#ff5436;--chart-pm40:#0f766e;--smog:#6b6e70;--whisper:#9a9a9f;--serif:"Noto Sans KR", "Pretendard Variable", Pretendard, "SUITE Variable", SUITE, -apple-system, BlinkMacSystemFont, sans-serif;--sans:"Noto Sans KR", "Pretendard Variable", Pretendard, "SUITE Variable", SUITE, -apple-system, BlinkMacSystemFont, sans-serif;--display:"Noto Sans KR", "Pretendard Variable", Pretendard, "SUITE Variable", SUITE, -apple-system, BlinkMacSystemFont, sans-serif;--mono:ui-monospace, "SF Mono", Menlo, Consolas, monospace;--live-dashboard:"Noto Sans KR", "Pretendard Variable", Pretendard, "SUITE Variable", SUITE, -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--body-dot:#0a0a0f06;font-family:var(--sans);color:var(--ink);background-color:var(--cream);-webkit-font-smoothing:antialiased;font-weight:400;line-height:1.5}html[data-app-theme=studio]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--ink:#0f172a;--ink-soft:#1e293b;--ink-mute:#64748b;--lime:#38bdf8;--lime-deep:#0284c7;--lime-soft:#bae6fd;--lime-tint:#e0f2fe;--brand-twin:#2563eb;--theme-select-fill:var(--brand-twin);--theme-select-label:#fff;--theme-select-border:color-mix(in srgb, var(--brand-twin) 72%, var(--ink) 28%);--theme-select-sheen:inset 0 0 0 1px #ffffff24;--cream:#f1f5f9;--cream-deep:#e2e8f0;--paper:#f8fafc;--coral:#dc2626;--chart-pm40:#0d9488;--smog:#64748b;--whisper:#94a3b8;--serif:"Noto Sans KR", "Pretendard Variable", Pretendard, "SUITE Variable", SUITE, -apple-system, BlinkMacSystemFont, sans-serif;--sans:"Noto Sans KR", "Pretendard Variable", Pretendard, "SUITE Variable", SUITE, -apple-system, BlinkMacSystemFont, sans-serif;--display:"Noto Sans KR", "Pretendard Variable", Pretendard, "SUITE Variable", SUITE, system-ui, sans-serif;--mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--live-dashboard:"Noto Sans KR", "Pretendard Variable", Pretendard, "SUITE Variable", SUITE, system-ui, sans-serif;--body-dot:#0f172a0b;font-family:var(--sans);color:var(--ink);background-color:var(--cream);-webkit-font-smoothing:antialiased;font-weight:400;line-height:1.5}.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}.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-filter-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:14px;display:grid}.admin-page .admin-filter-grid label{flex-direction:column;gap:6px;min-width:0;display:flex}.admin-page .admin-filter-grid label span{font-size:11px;font-weight:700;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute)}.admin-page .admin-filter-grid input,.admin-page .admin-filter-grid select{box-sizing:border-box;width:100%;min-width:0;max-width:100%}.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-edit-modal{margin-top:16px}.admin-edit-actions{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.admin-user-pick{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px;display:flex}.admin-user-pick label{flex-direction:column;align-items:flex-start;gap:6px;min-width:0;display:flex}.admin-user-select{width:min(260px,92vw);min-width:0;max-width:260px}.admin-user-search-input{width:min(260px,92vw);min-width:0;max-width:260px;margin-bottom:8px}.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{border:1.5px solid var(--ink);background:var(--cream);background-image:none;border-radius:0;width:100%;height:320px}.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}.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-pm40{stroke:var(--chart-pm40)}.line.pm-field-pm100{stroke:var(--coral)}.line.humidity{stroke:var(--ink-soft)}.line.temperature{stroke:#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;display:inline-flex;box-shadow:3px 3px #0a0a0f1f}.legend-item.off{opacity:.42;box-shadow:none}.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-pm40:before{background:var(--chart-pm40)}.legend-item.pm-field-pm100:before{background:var(--coral)}.legend-item.humidity:before{background:var(--ink-soft)}.legend-item.temperature:before{background:#c2410c}.line.voc-index{stroke:#6d28d9}.line.nox-index{stroke:#0f766e}.legend-item.voc-index:before{background:#6d28d9}.legend-item.nox-index:before{background:#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{-webkit-overflow-scrolling:touch;flex-direction:row;flex:auto;justify-content:center;align-items:flex-start;min-width:0;min-height:0;display:flex;overflow:hidden auto}.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}.app-root--with-bottom-nav .app-frame{align-items:stretch}.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{-webkit-overflow-scrolling:touch;flex:auto;min-width:0;min-height:0;overflow:hidden 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}.live-dashboard .panel h2,.live-dashboard .live-dash-section__h{font-family:var(--live-dashboard)}.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{flex:auto;min-width:0}.live-header-chrome{flex-flow:row;flex-shrink:0;align-items:center;gap:8px;margin-left:auto;display:flex}.live-header-icon-btn{min-width:var(--chrome-control-h,40px);height:var(--chrome-control-h,40px);border:2px solid var(--ink);background:var(--paper);color:var(--ink);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 6px;font-size:17px;font-weight:700;line-height:1;display:inline-flex}.live-header-layout-btn{letter-spacing:.04em;text-transform:uppercase;max-width:72px;font-size:10px;font-weight:700}.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__head{flex-flow:row;align-items:stretch;gap:10px;width:100%;min-width:0;display:flex}.live-dash-section__toggle{text-align:left;border:1.5px solid var(--ink);background:var(--cream-deep);width:auto;min-width:0;color:var(--ink);font:inherit;letter-spacing:-.02em;cursor:pointer;box-shadow:2px 2px 0 var(--ink);box-sizing:border-box;border-radius:10px;flex-flow:row;flex:auto;justify-content:space-between;align-items:center;gap:10px;margin:0;padding:6px 10px;font-size:clamp(15px,2vw,18px);font-weight:700;display:flex}.live-dash-section__toggle:hover{background:var(--paper)}.live-dash-section__title{flex:auto;min-width:0}.live-dash-section__chevron{opacity:.75;flex-shrink:0;font-size:12px}.live-dash-section__body{margin-top:4px}.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-intro{margin:0 0 14px}.live-panel-layout-list{flex-direction:column;gap:10px;margin:0 0 16px;padding:0;list-style:none;display:flex}.live-panel-layout-chart-section{border-top:1px solid #0a0a0f1f;margin:0 0 16px;padding-top:4px}.live-panel-layout-section-heading{font-size:.95rem;font-weight:700;font-family:var(--live-dashboard);margin:12px 0 6px}.live-panel-layout-chart-note{margin:0 0 10px}.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-row{cursor:pointer;flex-direction:row;align-items:flex-start;gap:10px;font-size:14px;font-weight:700;display:flex}.live-panel-layout-row input{flex-shrink:0;margin-top:3px}.live-panel-layout-actions{justify-content:flex-end;gap:10px;display:flex}.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-grid{grid-template-columns:repeat(auto-fill,minmax(min(220px,100%),1fr));justify-content:space-between;gap:clamp(4px,1.2vw,14px);min-width:0;margin-top:12px;display:grid}.explorer-field{font-size:12px;font-weight:700;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);flex-direction:column;gap:6px;display:flex}.explorer-field span{font-size:11px}.explorer-field input,.explorer-field select{min-width:0;font-weight:400;font-family:var(--sans);text-transform:none;letter-spacing:0}.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{margin-top:16px}.explorer-hint{margin-top:12px;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{margin-top:0;padding:0;overflow:visible}.live-app-status{min-width:0;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);border-bottom:1px solid var(--ink);background:var(--cream);scrollbar-width:thin;flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:clamp(6px,1.5vw,16px);padding:clamp(10px,1.8vw,16px) clamp(10px,2vw,20px) clamp(5px,1.4vw,9px);font-size:10px;display:flex;overflow-x:auto}.live-app-status-loc{flex-shrink:1;align-items:center;gap:clamp(4px,1vw,8px);min-width:0;display:flex}.live-app-status-right{flex-shrink:0;align-items:center;gap:8px;display:inline-flex}.live-hero-detail-hint{border-radius:999px;width:22px;min-width:22px;height:22px;padding:0;font-size:12px;line-height:1}.live-live-dot{background:var(--whisper);border:1.2px solid var(--ink);border-radius:50%;flex-shrink:0;width:11px;height:11px}.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:12px 20px 20px}.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(--serif);letter-spacing:-.03em;margin:0 0 20px;font-size:clamp(26px,4vw,38px);font-weight:700;line-height:1.05}.live-hero-headline em{color:var(--lime-deep);font-style:italic;display:inline-block;position:relative}.live-hero-headline em:after{content:"";background:var(--lime);z-index:-1;height:11px;position:absolute;bottom:3px;left:-2px;right:-2px;transform:skew(-4deg)}.live-hero-headline.tier-moderate em{color:#b45309}.live-hero-headline.tier-moderate em:after{background:#fcd34d}.live-hero-headline.tier-bad em,.live-hero-headline.tier-veryBad em{color:var(--coral)}.live-hero-headline.tier-bad em:after,.live-hero-headline.tier-veryBad em:after{background:#ff54366b}.live-hero-headline.tier-unknown em{color:var(--ink-mute)}.live-hero-headline.tier-unknown em:after{background:var(--cream-deep)}.live-hero-twinkeep-line{max-width:40rem;color:var(--ink-mute);margin:0 0 .5rem;font-size:12px;line-height:1.4}.live-hero-who-pm25{max-width:40rem;color:var(--ink);flex-wrap:wrap;align-items:baseline;gap:.25rem .5rem;margin:.4rem 0 .75rem;font-size:12.5px;line-height:1.4;display:flex}.live-hero-who-pm25-k{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);font-size:10px}.live-hero-who-pm25-v{color:var(--ink);border-bottom:1.5px dotted var(--ink-soft);cursor:help;font-weight:700}.live-hero-num-row{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:10px;display:flex}.live-hero-num{font-family:var(--display);letter-spacing:-.06em;color:var(--ink);font-size:clamp(72px,14vw,140px);line-height:.82}.live-hero-num-side{text-align:right;flex-shrink:0;padding-top:8px}.live-hero-unit{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:4px;font-size:10px}.live-hero-trend{font-family:var(--serif);font-size:20px;font-style:italic;font-weight:700}.live-hero-trend.up{color:var(--coral)}.live-hero-trend.down{color:var(--lime-deep)}.live-hero-trend.flat{color:var(--ink-mute)}.live-hero-divider{border-top:1px solid var(--ink);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;justify-content:space-between;padding-top:12px;font-size:10px;display:flex}.live-hero-divider-right{color:var(--ink-mute)}.live-aqi-section{border-top:1px solid var(--ink);background:var(--paper);padding:20px}.live-aqi-label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);justify-content:space-between;margin-bottom:12px;font-size:10px;display:flex}.live-aqi-label--who{text-transform:none;flex-direction:column;align-items:stretch;gap:6px}.live-aqi-title-row{justify-content:space-between;align-items:baseline;gap:8px;width:100%;display:flex}.live-aqi-who-title{font-family:var(--serif);letter-spacing:-.02em;color:var(--ink);font-size:clamp(14px,1.1rem + .5cqi,18px);font-weight:700}.live-aqi-who-metric{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);font-size:9px;font-weight:700}.live-aqi-who-sub{color:var(--ink-mute);margin:0;font-size:11px;line-height:1.45;display:block}.live-aqi-bar{background:linear-gradient(90deg, var(--lime) 0%, var(--lime) 28%, #ffd93d 52%, var(--coral) 76%, var(--ink-soft) 100%);border:1.5px solid var(--ink);height:48px;margin-bottom:8px;position:relative}.live-aqi-bar:after{content:"";pointer-events:none;background-image:linear-gradient(90deg, transparent 20%, var(--ink) 20.25%, var(--ink) 20.5%, transparent 20.75%), linear-gradient(90deg, transparent 33.2%, var(--ink) 33.4%, var(--ink) 33.6%, transparent 33.8%), linear-gradient(90deg, transparent 49.8%, var(--ink) 50%, var(--ink) 50.2%, transparent 50.4%), linear-gradient(90deg, transparent 66.4%, var(--ink) 66.6%, var(--ink) 66.8%, transparent 67%);position:absolute;inset:0}.live-aqi-marker{background:var(--ink);color:var(--lime);font-family:var(--mono);letter-spacing:.08em;white-space:nowrap;padding:4px 8px;font-size:10px;font-weight:700;position:absolute;top:-8px;left:50%;transform:translate(-50%)}.live-aqi-marker-inner{flex-direction:column;align-items:center;gap:0;line-height:1.05;display:inline-flex}.live-aqi-marker-val{font-size:11px}.live-aqi-marker-unit{letter-spacing:.04em;opacity:.95;font-size:7px;font-weight:700;display:block}.live-aqi-marker:after{content:"";border-left:5px solid #0000;border-right:5px solid #0000;border-top:6px solid var(--ink);width:0;height:0;position:absolute;bottom:-6px;left:50%;transform:translate(-50%)}.live-aqi-scale{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);justify-content:space-between;font-size:9px;display:flex}.live-aqi-scale--who{text-transform:none;letter-spacing:.04em;flex-wrap:nowrap;gap:2px;min-width:0;font-size:8.5px}.live-aqi-scale--who>span{text-align:center;flex:1 1 0;min-width:0}.live-aqi-footnote{max-width:42rem;color:var(--ink-soft);text-transform:none;letter-spacing:.02em;margin:10px 0 0;font-size:11px;line-height:1.45}.live-insight{background:var(--ink);color:var(--cream);border:1.5px solid var(--ink);box-shadow:6px 6px 0 var(--lime-deep);margin-top:20px;padding:28px 24px 32px;position:relative}.live-insight-quote-mark{font-family:var(--display);color:var(--lime);font-size:72px;line-height:.65;position:absolute;top:12px;left:20px}.live-insight-tag{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;background:var(--lime);color:var(--ink);margin-bottom:14px;margin-left:56px;padding:4px 10px;font-size:9px;font-weight:700;display:inline-block}.live-insight-text{font-family:var(--serif);letter-spacing:-.02em;margin:0 0 12px 56px;font-size:clamp(18px,2.4vw,22px);font-weight:700;line-height:1.3}.live-insight-meta{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;opacity:.55;margin:0 0 0 56px;font-size:10px}.live-insight.live-insight--merged{box-shadow:4px 4px 0 var(--lime-deep);margin-top:0;margin-bottom:14px;padding:22px 20px 26px}.live-poll-section.panel{margin-top:14px}.live-poll-title{font-family:var(--serif);letter-spacing:-.02em;margin:0 0 14px;font-size:22px;font-weight:700}.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:2px solid var(--ink);--live-poll-name-track:clamp(7.25rem, 24vw, calc(12.75rem * .7));--live-poll-status-track:44px;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) minmax(0, 1fr) minmax(5.5rem, .42fr);font-family:var(--serif);letter-spacing:-.01em;text-transform:none;color:var(--ink-mute);border-bottom:1px solid var(--ink);box-sizing:border-box;align-items:center;gap:6px clamp(4px,1vw,12px);width:100%;min-width:0;max-width:100%;padding:10px 0 8px;font-size:12px;font-weight:700;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(6.25rem,max-content);align-items:center;column-gap:clamp(4px,1vw,12px);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>span:nth-child(4){text-align:left;justify-content:flex-start;align-items:center;min-height:0;padding-left:clamp(4px,1vw,12px);display:flex}.live-poll-head>span:first-child,.live-poll-head>span:nth-child(2),.live-poll-head>.live-poll-head-val,.live-poll-head>span:nth-child(4){align-self:stretch}.live-poll-row{grid-template-columns:var(--live-poll-name-track) var(--live-poll-status-track) minmax(0, 1fr) minmax(5.5rem, .42fr);border-bottom:1px solid var(--cream-deep);box-sizing:border-box;align-items:center;gap:8px clamp(4px,1vw,12px);width:100%;min-width:0;max-width:100%;padding:12px 0;display:grid}.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-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 var(--ink-mute);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(--serif);letter-spacing:-.02em;color:var(--ink);text-underline-offset:4px;white-space:nowrap;text-overflow:ellipsis;border-radius:10px;margin:0;padding:9px 14px;font-size:14px;font-weight:700;text-decoration:underline;text-decoration-thickness:1px;display:block;overflow-x:hidden}.live-poll-name-btn:hover:not(:disabled){color:var(--ink-soft);border-color:var(--ink-soft);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-glyph{--status-stroke:var(--ink);--status-feature:var(--ink);justify-content:center;align-items:center;display:flex}.live-poll-status-glyph.good{--status-fill:color-mix(in srgb, var(--lime-deep) 22%, #fffef6 78%);--status-stroke:color-mix(in srgb, var(--ink) 72%, var(--lime-deep) 28%);--status-feature:color-mix(in srgb, var(--ink) 55%, #2d4a1a 45%)}.live-poll-status-glyph.warn{--status-fill:#f7dd96;--status-stroke:color-mix(in srgb, var(--ink) 78%, #b8860b 22%);--status-feature:color-mix(in srgb, var(--ink) 62%, #7a5200 38%)}.live-poll-status-glyph.bad{--status-fill:color-mix(in srgb, var(--coral) 50%, #7a2e24 50%);--status-stroke:color-mix(in srgb, var(--ink) 75%, #4a1814 25%);--status-feature:color-mix(in srgb, #2c1010 55%, var(--ink) 45%)}.live-poll-status-glyph.neutral{--status-fill:color-mix(in srgb, var(--smog) 42%, #d6d6da 58%);--status-stroke:color-mix(in srgb, var(--ink) 58%, var(--smog) 42%);--status-feature:color-mix(in srgb, var(--ink) 68%, #5c5c64 32%)}.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(6.25rem,max-content);align-items:center;column-gap:clamp(4px,1vw,12px);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(--display);letter-spacing:-.04em;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(14px,.85rem + 1.15cqi,22px);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-mute);text-transform:none;letter-spacing:.02em;text-align:left;white-space:nowrap;text-overflow:ellipsis;justify-self:start;min-width:0;font-size:10px;font-weight:700;overflow:hidden}.live-poll-delta{width:100%;min-width:0;max-width:100%;font-family:var(--sans);color:var(--ink-soft);justify-content:flex-start;align-items:center;padding-left:clamp(4px,1vw,12px);font-size:11px;font-weight:700;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{flex-flow:row;justify-content:flex-start;align-items:center;gap:clamp(2px,.8vw,8px);min-width:0;max-width:100%;display:inline-flex}.live-poll-delta-glyph{flex-shrink:0;align-items:center;line-height:0;display:flex}.live-poll-delta-num{font-family:var(--mono);font-variant-numeric:tabular-nums;text-align:left;min-width:0;color:var(--ink-soft)}.live-poll-delta-arrow{flex-shrink:0;display:block}.live-poll-delta-arrow--up{color:color-mix(in srgb, #e6b800 52%, var(--ink) 48%)}.live-poll-delta-arrow--down{color:color-mix(in srgb, var(--lime-deep) 22%, #fffef6 78%)}.live-poll-delta-arrow--flat{color:var(--ink-mute)}.intro-screen{background:var(--cream);background-image:none;flex-direction:column;min-height:100vh;display:flex}.intro-screen-top{border-bottom:2px solid var(--ink);justify-content:space-between;align-items:center;padding:20px 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:18px;max-width:620px;margin:0 auto;padding:34px 28px 72px;display:flex;position:relative;overflow:hidden}.intro-screen-copy{z-index:1;flex-direction:column;max-width:540px;padding-right:clamp(44px,7vw,108px);display:flex;position:relative;transform:translate(-4px,-8px)}.intro-screen-title{font-family:var(--serif);letter-spacing:-.03em;margin:0 0 16px;font-size:clamp(32px,5vw,44px);font-weight:700;line-height:1.08}.twinkeep-wordmark{white-space:nowrap;letter-spacing:-.03em;font-size:clamp(32px,5vw,44px);font-weight:500;display:inline}.twinkeep-wordmark__twin{color:var(--brand-twin);letter-spacing:-.04em;text-shadow:0 0 .5px #0468d773,0 1px #ffffff59}.twinkeep-wordmark__keep{color:var(--lime);letter-spacing:-.04em;-webkit-text-stroke:1.2px #000;paint-order:stroke fill}.intro-screen-lead{font-family:var(--sans);color:var(--ink);margin:0 0 14px;font-size:clamp(17px,2.2vw,20px);font-weight:700;line-height:1.45}.intro-screen-lead--ko{margin-bottom:28px}.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-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.intro-screen-skip{min-width:120px}.intro-screen-cta{border:2px solid var(--ink);background:var(--lime);color:var(--ink);cursor:pointer;font-weight:700;font-family:var(--serif);letter-spacing:-.02em;box-shadow:4px 4px 0 var(--ink);border-radius:12px;padding:12px 22px;font-size:16px}.intro-screen-cta:hover{filter:brightness(1.03)}.intro-screen-cta:active{box-shadow:2px 2px 0 var(--ink);transform:translate(2px,2px)}.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:.23;--intro-mascot-filter:saturate(.82) brightness(1.03);--intro-mascot-mask:radial-gradient(circle at 44% 46%, #000 55%, #000000b8 72%, transparent 100%);opacity:0;z-index:0;pointer-events:none;width:clamp(150px,24vw,236px);height:auto;filter:var(--intro-mascot-filter);-webkit-mask-image:var(--intro-mascot-mask);-webkit-mask-image:var(--intro-mascot-mask);mask-image:var(--intro-mascot-mask);animation:.45s ease-out 80ms forwards intro-mascot-fade-in;position:absolute;bottom:22px;right:26px}html[data-app-theme=ozone] .intro-screen-mascot{--intro-mascot-opacity-target:.24;--intro-mascot-filter:saturate(.9) brightness(1.02);--intro-mascot-mask:radial-gradient(circle at 45% 46%, #000 57%, #000000bd 74%, transparent 100%)}html[data-app-theme=studio] .intro-screen-mascot{--intro-mascot-opacity-target:.18;--intro-mascot-filter:saturate(.72) brightness(1.04);--intro-mascot-mask:radial-gradient(circle at 43% 45%, #000 52%, #000000a8 70%, transparent 100%)}.live-empty-state{align-items:center;min-height:240px;padding:24px 22px;display:flex;position:relative;overflow:hidden}.live-empty-state__copy{z-index:1;max-width:460px;position:relative}.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{pointer-events:none;opacity:.2;filter:saturate(.82)brightness(1.03);width:clamp(132px,20vw,188px);height:auto;position:absolute;bottom:8px;right:14px;-webkit-mask-image:radial-gradient(circle at 44% 46%,#000 56%,#000000b8 72%,#0000 100%);mask-image:radial-gradient(circle at 44% 46%,#000 56%,#000000b8 72%,#0000 100%)}.auth-gate-screen{background:var(--cream);background-image:none;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-title{font-family:var(--serif);letter-spacing:-.02em;margin:0 0 10px;font-size:clamp(24px,4vw,30px);font-weight:700;line-height:1.15}.auth-gate-sub{font-family:var(--sans);color:var(--ink-mute);margin:0 0 24px;font-size:14px;line-height:1.5}.auth-gate-oauth-buttons{flex-direction:column;gap:12px;width:100%;max-width:320px;margin:0 auto 12px;display:flex}.auth-gate-google,.auth-gate-kakao{justify-content:center;align-items:center;width:100%;display:inline-flex}.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,.auth-gate-title{color:var(--tk-text-strong);letter-spacing:-.01em;font-weight:700}.sub,.auth-gate-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-header-icon-btn,.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-google,.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:14px;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-insight{color:#e2e8f0;box-shadow:var(--tk-shadow);background:#0f172a;border:1px solid #0f172a}.live-insight-tag{background:var(--tk-ozone);color:#fff}.live-live-dot.on{background:var(--tk-ozone)}.status,.chart,.live-hero-inner,.intro-screen,.auth-gate-screen{background-image:none}.explorer-grid{grid-template-columns:repeat(1,minmax(0,1fr));gap:10px;display:grid}.twinkeep-wordmark{white-space:nowrap;font-size:inherit;align-items:baseline;gap:2px;font-family:Georgia,Times New Roman,Times,serif;line-height:1.05;display:inline-flex}.twinkeep-wordmark__twin{color:var(--brand-twin);letter-spacing:-.04em;text-shadow:0 0 .5px #0468d773,0 1px #ffffff59;font-weight:500}.twinkeep-wordmark__keep{color:var(--lime);letter-spacing:-.04em;-webkit-text-stroke:.8px #000;paint-order:stroke fill;font-weight:500}html[data-app-theme=ozone] .twinkeep-wordmark__keep,html[data-app-theme=studio] .twinkeep-wordmark__keep{-webkit-text-stroke:.8px #000}.intro-screen-title{word-break:keep-all;font-size:clamp(28px,4.6vw,42px);line-height:1.25}.intro-screen-title .twinkeep-wordmark{margin-right:.06em;font-size:1.12em}.intro-screen-brand .twinkeep-wordmark{font-size:20px}@media (width<=640px){.intro-screen-copy{max-width:100%;padding-right:clamp(18px,5vw,34px);transform:translateY(-4px)}.intro-screen-mascot{--intro-mascot-opacity-target:.16;--intro-mascot-mask:radial-gradient(circle at 42% 44%, #000 52%, #000000a6 70%, transparent 100%);width:clamp(108px,29vw,150px);bottom:10px;right:6px}.live-empty-state{min-height:210px;padding:18px 14px}.live-empty-state__copy{max-width:100%;padding-right:68px}.live-empty-state__mascot{opacity:.16;width:clamp(96px,28vw,132px);bottom:4px;right:4px}}@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,.live-dash-section__toggle{border:1px solid var(--tk-border);box-shadow:none;background:var(--tk-surface-soft);color:var(--tk-text)}.live-poll-row,.live-poll-head{grid-template-columns:minmax(7.25rem, var(--live-poll-name-track)) var(--live-poll-status-track) minmax(11.25rem, 1.2fr) minmax(5.5rem, .45fr);column-gap:8px}@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}}
