:root{color:#f8fafc;font-synthesis:none;text-rendering:optimizelegibility;background:#020617;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body{background:#020617;width:100%;min-width:320px;min-height:100%;margin:0}body{min-height:100vh;overflow:hidden}h1,h2,p{margin-top:0}.dashboard{background:radial-gradient(circle at 10% 0,#38bdf81f,#0000 32%),radial-gradient(circle at 100% 100%,#10b98114,#0000 34%),#020617;grid-template-rows:auto 1fr auto;gap:clamp(16px,1.5vw,28px);width:100vw;height:100vh;padding:clamp(20px,2vw,40px);display:grid}.dashboard-header{justify-content:space-between;align-items:flex-start;gap:24px;display:flex}.brand-tools{flex-direction:column;align-items:flex-start;gap:14px;display:flex}.eyebrow,.section-label{color:#38bdf8;letter-spacing:.16em;text-transform:uppercase;margin:0 0 6px;font-size:clamp(.72rem,.8vw,1rem);font-weight:800}h1{letter-spacing:-.04em;margin-bottom:0;font-size:clamp(2.2rem,3.3vw,5rem);line-height:.98}h2{margin-bottom:0;font-size:clamp(1.35rem,1.55vw,2.3rem);line-height:1.1}.status{color:#cbd5e1;white-space:nowrap;background:#0f172ac7;border:1px solid #94a3b82e;border-radius:999px;align-items:center;gap:12px;padding:12px 18px;font-size:clamp(.82rem,.9vw,1.1rem);display:flex}.status-indicator{background:#f59e0b;border-radius:50%;width:11px;height:11px;box-shadow:0 0 14px #f59e0bb3}.status-indicator.is-online{background:#22c55e;box-shadow:0 0 14px #22c55eb3}.status-indicator.is-cached{background:#f59e0b;box-shadow:0 0 14px #f59e0bb3}.status-indicator.is-error{background:#ef4444;box-shadow:0 0 14px #ef4444b3}.dashboard-grid{grid-template-columns:minmax(0,38fr) minmax(0,62fr);gap:clamp(18px,1.5vw,28px);min-height:0;display:grid}.weather-panel,.markets-panel{border:1px solid #94a3b824;border-radius:28px;min-width:0;min-height:0;overflow:hidden;box-shadow:0 24px 70px #02061780,inset 0 1px #ffffff08}.weather-panel{background:linear-gradient(155deg,#0e749057,#0f172af0 55%),radial-gradient(circle at 20% 15%,#7dd3fc33,#0000 42%);grid-template-rows:minmax(0,1fr) auto;display:grid}.weather-hero{flex-direction:column;justify-content:space-between;gap:28px;padding:clamp(24px,2.2vw,42px);display:flex}.panel-header{justify-content:space-between;align-items:flex-start;gap:20px;display:flex}.timestamp{color:#94a3b8;text-align:right;margin-bottom:0;font-size:clamp(.72rem,.78vw,.95rem);line-height:1.4}.weather-condition{color:#cbd5e1;margin:10px 0 0;font-size:clamp(.95rem,1vw,1.25rem)}.weather-main{grid-template-columns:minmax(0,1.1fr) minmax(210px,.9fr);align-items:end;gap:clamp(22px,2vw,38px);display:grid}.temperature{letter-spacing:-.09em;margin:0;font-size:clamp(7rem,12vw,13rem);font-weight:750;line-height:.8}.weather-metrics{gap:14px;padding-bottom:8px;display:grid}.metric{color:#94a3b8;border-bottom:1px solid #94a3b81f;justify-content:space-between;gap:20px;padding-bottom:12px;font-size:clamp(.95rem,1vw,1.2rem);display:flex}.metric:last-child{border-bottom:0}.metric strong{color:#f8fafc;text-align:right;font-weight:700}.weather-secondary{background:#0f172a57;border-top:1px solid #94a3b81f}.weather-forecast-card{min-width:0;padding:clamp(20px,1.5vw,28px)}.forecast-header{justify-content:space-between;align-items:flex-start;gap:18px;display:flex}.detail-label{color:#7dd3fc;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px;font-size:.75rem;font-weight:800}.detail-value{color:#f8fafc;margin-bottom:0;font-size:clamp(1rem,1.1vw,1.35rem);font-weight:650}.forecast-updated{color:#94a3b8;text-align:right;white-space:nowrap;margin-bottom:0;font-size:clamp(.72rem,.78vw,.92rem);line-height:1.35}.forecast-updated span{color:#e2e8f0;font-weight:700;display:block}.forecast-graph-wrap{height:clamp(96px,8vw,140px);margin-top:14px}.forecast-graph{width:100%;height:100%;overflow:visible}.forecast-gridline{stroke:#94a3b829;stroke-width:1px}.forecast-line{fill:none;stroke:#38bdf8;stroke-linecap:round;stroke-linejoin:round;stroke-width:5px}.forecast-point{fill:#f8fafc;stroke:#38bdf8;stroke-width:3px}.forecast-graph-label{fill:#e0f2fe;text-anchor:middle;font-size:18px;font-weight:800}.forecast-list{grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;margin-top:8px;display:grid}.forecast-hour{border-top:1px solid #94a3b81f;min-width:0;padding-top:10px}.forecast-hour p{text-overflow:ellipsis;white-space:nowrap;margin-bottom:0;overflow:hidden}.forecast-time{color:#7dd3fc;font-size:clamp(.75rem,.8vw,.95rem);font-weight:800}.forecast-condition{color:#cbd5e1;margin-top:4px;font-size:clamp(.68rem,.72vw,.86rem)}.forecast-temp{color:#f8fafc;font-variant-numeric:tabular-nums;margin-top:8px;font-size:clamp(1.05rem,1.15vw,1.35rem);font-weight:800}.forecast-precipitation{color:#94a3b8;font-variant-numeric:tabular-nums;margin-top:2px;font-size:clamp(.72rem,.78vw,.92rem);font-weight:700}.forecast-precipitation:before{content:"Rain ";color:#64748b;font-weight:650}.markets-panel{background:linear-gradient(145deg,#0f172afa,#020617f2);grid-template-rows:auto minmax(0,1fr);padding:clamp(24px,2vw,38px);display:grid}.markets-header{padding-bottom:20px}.market-table{grid-template-rows:auto minmax(0,1fr);min-height:0;display:grid}.market-table-header,.stock-row{grid-template-columns:minmax(180px,1.45fr) minmax(95px,.8fr) minmax(95px,.8fr) minmax(105px,.85fr) minmax(95px,.8fr) minmax(95px,.8fr) minmax(95px,.8fr);align-items:center;gap:18px;display:grid}.market-table-header{color:#64748b;letter-spacing:.04em;text-transform:uppercase;border-top:1px solid #94a3b81f;border-bottom:1px solid #94a3b82e;padding:14px 18px;font-size:clamp(.72rem,.78vw,.95rem);font-weight:700}.market-table-header span:not(:first-child){text-align:right}.stock-list{grid-auto-rows:minmax(82px,1fr);min-height:0;display:grid}.stock-row{border-bottom:1px solid #94a3b81f;padding:16px 18px}.stock-row:last-child{border-bottom:0}.stock-row:hover{background:#1e293b61}.stock-name{min-width:0}.stock-symbol{color:#f8fafc;margin-bottom:4px;font-size:clamp(1rem,1.1vw,1.35rem);font-weight:800}.stock-company{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;margin-bottom:0;font-size:clamp(.75rem,.82vw,1rem);overflow:hidden}.stock-cell{color:#e2e8f0;text-align:right;font-variant-numeric:tabular-nums;margin-bottom:0;font-size:clamp(.95rem,1vw,1.2rem)}.stock-price{color:#f8fafc;font-weight:800}.stock-change{font-weight:700}.stock-change.is-positive{color:#34d399}.stock-change.is-negative{color:#fb7185}.stock-change.is-neutral{color:#cbd5e1}.empty-state{color:#94a3b8;place-self:center;margin:0;font-size:1rem}.dashboard-footer{color:#64748b;justify-content:flex-end;font-size:clamp(.72rem,.75vw,.9rem);display:flex}.dashboard-footer p{margin-bottom:0}html[data-view=admin] body{overflow:auto}.admin-dashboard{background:#020617;min-height:100vh;padding:clamp(20px,2vw,40px)}.admin-header,.admin-section-header,.admin-actions,.admin-auth{justify-content:space-between;align-items:center;gap:18px;display:flex}.admin-header{margin-bottom:28px}.admin-header h1{font-size:clamp(2rem,3vw,4rem)}.admin-link,.admin-auth button,.admin-section-header button,.admin-actions button,.admin-icon-button{color:#e0f2fe;cursor:pointer;font:inherit;background:#0e74902e;border:1px solid #7dd3fc52;border-radius:8px;font-weight:800;text-decoration:none}.admin-link,.admin-auth button,.admin-section-header button,.admin-actions button{padding:10px 14px}.admin-icon-button{color:#fecdd3;background:#7f1d1d38;border-color:#fb718552;padding:8px 10px;font-size:.85rem}.admin-auth,.admin-section,.admin-actions{background:#0f172ab8;border:1px solid #94a3b824;border-radius:8px;padding:18px}.admin-auth{margin-bottom:18px}.admin-form{gap:18px;display:grid}.admin-section{gap:16px;display:grid}.admin-list{gap:12px;display:grid}.admin-item{background:#02061766;border:1px solid #94a3b81f;border-radius:8px;gap:14px;padding:16px;display:grid}.admin-stock-item{grid-template-columns:minmax(0,1fr) auto;align-items:end}.admin-item-actions{align-items:center;gap:8px;display:flex}.admin-item-header{justify-content:space-between;align-items:center;gap:16px;display:flex}.admin-item h3{margin:0;font-size:1rem}.admin-field-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;display:grid}.admin-stock-item .admin-field-grid{grid-template-columns:minmax(120px,.5fr) minmax(180px,1fr)}.admin-field{color:#94a3b8;letter-spacing:.08em;text-transform:uppercase;gap:6px;min-width:0;font-size:.78rem;font-weight:800;display:grid}.admin-field input{color:#f8fafc;width:100%;min-width:0;font:inherit;letter-spacing:0;text-transform:none;background:#020617bd;border:1px solid #94a3b833;border-radius:8px;padding:10px 12px;font-size:.95rem;font-weight:650}#admin-status{color:#94a3b8;margin:0}#admin-status[data-state=success]{color:#34d399}#admin-status[data-state=error]{color:#fb7185}@media (width<=1100px){body{overflow:auto}.dashboard{height:auto;min-height:100vh}.dashboard-grid{grid-template-columns:1fr}.weather-panel,.markets-panel{min-height:540px}}@media (width<=760px){.dashboard-header,.panel-header{flex-direction:column}.status{justify-content:center;width:100%}.weather-main{grid-template-columns:1fr}html:not([data-view=wallboard]) .forecast-header{flex-direction:column}html:not([data-view=wallboard]) .forecast-updated{text-align:left}html:not([data-view=wallboard]) .forecast-list{grid-template-columns:repeat(3,minmax(0,1fr));row-gap:14px}.market-table{overflow-x:auto}.market-table-header,.stock-row{min-width:900px}.admin-section-header,.admin-actions,.admin-auth{flex-direction:column;align-items:stretch}.admin-field-grid,.admin-stock-item,.admin-stock-item .admin-field-grid{grid-template-columns:1fr}.admin-item-actions{justify-content:flex-start}}html[data-view=wallboard],html[data-view=wallboard] body{width:100%;height:100%;overflow:hidden}html[data-view=wallboard] .dashboard{width:1920px;height:1080px;min-height:1080px;transform:translate(var(--wallboard-offset-x,0), var(--wallboard-offset-y,0)) scale(var(--wallboard-scale,1));transform-origin:0 0;position:fixed;top:0;left:0}html[data-view=wallboard] .clock-panel{padding:0}html[data-view=wallboard] .clock-date{font-size:.9rem}html[data-view=wallboard] #clock-time{font-size:2.35rem}html[data-view=wallboard] .clock-period{font-size:.9rem}html[data-view=wallboard] .weather-panel{grid-template-rows:minmax(0,1fr) minmax(0,1fr)}html[data-view=wallboard] .weather-hero{justify-content:space-between;gap:28px;padding:42px;overflow:hidden}html[data-view=wallboard] .weather-main{grid-template-columns:minmax(0,1.1fr) minmax(210px,.9fr);align-items:end;gap:32px;margin-top:0}html[data-view=wallboard] .temperature{letter-spacing:-.08em;font-size:11rem;line-height:.8}html[data-view=wallboard] .weather-metrics{gap:12px;padding-bottom:0}html[data-view=wallboard] .metric{gap:14px;padding-bottom:10px;font-size:1rem}html[data-view=wallboard] .forecast-graph-wrap{height:124px}@media (width<=1100px){html[data-view=wallboard] body{overflow:hidden}html[data-view=wallboard] .dashboard{height:1080px;min-height:1080px}html[data-view=wallboard] .dashboard-grid{grid-template-columns:minmax(0,38fr) minmax(0,62fr)}html[data-view=wallboard] .weather-panel,html[data-view=wallboard] .markets-panel{min-height:0}}@media (width<=760px){html[data-view=wallboard] .dashboard-header,html[data-view=wallboard] .panel-header{flex-direction:row}html[data-view=wallboard] .status{width:auto}html[data-view=wallboard] .weather-main{grid-template-columns:minmax(0,1.1fr) minmax(210px,.9fr)}html[data-view=wallboard] .market-table{overflow:hidden}html[data-view=wallboard] .market-table-header,html[data-view=wallboard] .stock-row{min-width:0}}@media (width<=1800px){html:not([data-view=wallboard]) .dashboard-grid{grid-template-columns:minmax(0,34fr) minmax(0,66fr)}html:not([data-view=wallboard]) .weather-main{grid-template-columns:minmax(0,.9fr) minmax(185px,1.1fr);gap:18px}html:not([data-view=wallboard]) .temperature{font-size:clamp(5.5rem,8vw,9rem)}html:not([data-view=wallboard]) .metric{gap:12px;font-size:clamp(.85rem,.9vw,1.05rem)}html:not([data-view=wallboard]) .market-table-header,html:not([data-view=wallboard]) .stock-row{grid-template-columns:minmax(125px,1.25fr) minmax(78px,.8fr) minmax(72px,.72fr) minmax(82px,.78fr) minmax(78px,.75fr) minmax(78px,.75fr) minmax(78px,.75fr);gap:10px;padding-left:12px;padding-right:12px}html:not([data-view=wallboard]) .stock-cell{font-size:clamp(.82rem,.9vw,1.05rem)}html:not([data-view=wallboard]) .stock-symbol{font-size:clamp(.92rem,1vw,1.15rem)}html:not([data-view=wallboard]) .timestamp{white-space:normal;max-width:190px}}@media (width<=1350px){html:not([data-view=wallboard]) body{overflow:auto}html:not([data-view=wallboard]) .dashboard{width:100%;height:auto;min-height:100vh}html:not([data-view=wallboard]) .dashboard-grid{grid-template-columns:1fr}html:not([data-view=wallboard]) .weather-panel,html:not([data-view=wallboard]) .markets-panel{min-height:560px}html:not([data-view=wallboard]) .weather-main{grid-template-columns:minmax(0,1fr) minmax(220px,.8fr)}html:not([data-view=wallboard]) .market-table{overflow-x:auto}html:not([data-view=wallboard]) .market-table-header,html:not([data-view=wallboard]) .stock-row{min-width:900px}}.clock-panel{color:#f8fafc;text-align:right;flex-direction:column;align-items:flex-end;gap:6px;display:flex}.clock-date{color:#cbd5e1;margin:0;font-size:clamp(.78rem,.82vw,1rem);font-weight:650}.clock-display{font-variant-numeric:tabular-nums;white-space:nowrap;align-items:baseline;gap:10px;display:flex}#clock-time{letter-spacing:-.06em;font-size:clamp(1.5rem,1.8vw,2.5rem);font-weight:800;line-height:.9}.clock-period{color:#7dd3fc;letter-spacing:.08em;font-size:clamp(.75rem,.78vw,.95rem);font-weight:800}.weather-hero{min-height:0}@media (width<=1350px){html:not([data-view=wallboard]) #clock-time{font-size:clamp(1.5rem,3vw,2.3rem)}}@media (width<=760px){html:not([data-view=wallboard]) .dashboard-header{align-items:stretch}html:not([data-view=wallboard]) .clock-panel{text-align:left;align-items:flex-start}}
