.auth-background{background:linear-gradient(135deg,#001d3d 0%,#0057b8 50%,#00a3e0 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{text-align:center;background:#fff;border-radius:24px;width:100%;max-width:420px;padding:40px;box-shadow:0 20px 60px #0000004d}.auth-logo{height:40px;margin-bottom:24px}.auth-title{color:#0f172a;margin-bottom:4px;font-size:22px;font-weight:800}.auth-subtitle{color:#64748b;margin-bottom:28px;font-size:13px}.auth-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;text-align:left;margin-bottom:6px;font-size:12px;font-weight:700;display:block}.auth-hint{color:#64748b;margin-bottom:12px;font-size:12px}.auth-input{color:#0f172a;-webkit-appearance:none;border:2px solid #e2e8f0;border-radius:12px;outline:none;width:100%;margin-bottom:16px;padding:12px 16px;font-family:inherit;font-size:16px;transition:border-color .2s}.auth-input:focus{border-color:#0057b8;box-shadow:0 0 0 4px #0057b81a}.pin-inputs,.code-inputs{justify-content:center;gap:12px;margin-bottom:24px;display:flex}.pin-input{text-align:center;color:#0f172a;-webkit-appearance:none;border:2px solid #e2e8f0;border-radius:16px;outline:none;width:56px;height:64px;font-family:inherit;font-size:28px;font-weight:800}.pin-input:focus{border-color:#0057b8;box-shadow:0 0 0 4px #0057b81a}.code-input{text-align:center;color:#0f172a;-webkit-appearance:none;border:2px solid #e2e8f0;border-radius:12px;outline:none;width:48px;height:56px;padding:0;font-family:inherit;font-size:24px;font-weight:800}.code-input:focus{border-color:#0057b8;box-shadow:0 0 0 4px #0057b81a}.auth-button{color:#fff;cursor:pointer;background:#0057b8;border:none;border-radius:14px;width:100%;margin-bottom:8px;padding:14px;font-family:inherit;font-size:15px;font-weight:700;transition:all .2s}.auth-button:hover{background:#003d82;transform:translateY(-1px)}.auth-button:disabled{opacity:.5;cursor:not-allowed}.auth-button-outline{color:#0057b8;cursor:pointer;background:0 0;border:2px solid #0057b8;border-radius:14px;width:100%;margin-top:4px;padding:12px;font-family:inherit;font-size:14px;font-weight:600}.auth-button-outline:hover{background:#e8f0fe}.auth-error{color:#ef4444;margin-top:12px;font-size:13px;font-weight:600}.auth-success{color:#10b981;margin-top:12px;font-size:13px;font-weight:600}.auth-links{color:#64748b;flex-direction:column;gap:8px;margin-top:20px;font-size:13px;display:flex}.auth-links a{color:#0057b8;font-weight:700;text-decoration:none}.auth-step{text-align:left}.step-dots{justify-content:center;gap:8px;margin-bottom:24px;display:flex}.step-dot{background:#e2e8f0;border-radius:50%;width:10px;height:10px;transition:all .3s}.step-dot.active{background:#0057b8;border-radius:5px;width:24px}.step-dot.done{background:#10b981}.auth-register-btn{text-align:center;color:#0057b8;background:linear-gradient(135deg,#e8f0fe,#f0f4f8);border:2px solid #0057b8;border-radius:14px;width:100%;margin-top:16px;padding:14px;font-size:14px;text-decoration:none;transition:all .2s;display:block}.auth-register-btn:hover{color:#fff;background:#0057b8;transform:translateY(-1px);box-shadow:0 4px 16px #0057b84d}.auth-register-btn strong{font-weight:800}.login-teaser{text-align:center;background:linear-gradient(135deg,#e8f0fe,#f0f8ff);border:1px solid #d0e2f7;border-radius:14px;flex-direction:column;align-items:center;gap:8px;margin-bottom:20px;padding:14px 18px;display:flex}.teaser-icon{font-size:32px}.teaser-temp{color:#0057b8;font-size:22px;font-weight:900}.teaser-detail{color:#64748b;font-size:12px;font-weight:600}.teaser-location{color:#94a3b8;margin-top:2px;font-size:10px}:root{--blue:#0057b8;--blue-light:#e8f0fe;--blue-dark:#003d82;--accent:#00a3e0;--bg:#f0f4f8;--card:#fff;--text:#0f172a;--text-light:#64748b;--border:#e2e8f0;--green:#10b981;--red:#ef4444;--orange:#f59e0b;--purple:#8b5cf6;--radius:20px;--shadow:0 1px 3px #0000000a,0 6px 24px #0057b80f}[data-theme=dark]{--bg:#0b1120;--card:#151e31;--text:#e2e8f0;--text-light:#94a3b8;--border:#1e293b;--blue-light:#1a2744;--shadow:0 1px 3px #0003,0 6px 24px #0000004d}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;transition:background .3s,color .3s}.header{background:linear-gradient(135deg,#001d3d 0%,var(--blue-dark) 30%,var(--blue) 60%,var(--accent) 100%);color:#fff;z-index:100;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;min-height:68px;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 4px 30px #00398240}.header-left{align-items:center;gap:16px;display:flex}.header-logo{filter:brightness(0)invert();height:32px}.header-partner-logo{object-fit:contain;background:#ffffffe6;border-radius:8px;max-width:100px;height:28px;padding:4px 8px}.header-divider{background:#fff3;width:1px;height:28px}.header-spacex{flex-direction:column;align-items:flex-start;line-height:1;display:flex}.spacex-powered{text-transform:uppercase;letter-spacing:1.5px;opacity:.5;font-size:8px;font-weight:600}.spacex-brand{letter-spacing:3px;font-family:Arial Black,sans-serif;font-size:16px;font-weight:900}.spacex-x{font-style:italic}.spacex-dtc{text-transform:uppercase;letter-spacing:2px;opacity:.6;font-size:8px;font-weight:700}.header-title{font-size:14px;font-weight:600}.header-title span{opacity:.6;font-size:12px;font-weight:400;display:block}.header-right{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.header-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff1f;border-radius:12px;align-items:center;gap:5px;padding:6px 12px;font-family:inherit;font-size:14px;line-height:1;text-decoration:none;transition:all .2s;display:flex;position:relative}.header-btn span{letter-spacing:.3px;font-size:11px;font-weight:700}.header-btn:hover{background:#ffffff38;border-color:#ffffff40;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.header-btn:active{transform:translateY(0)}.logout-btn{background:#ef44441a;border-color:#ef444433}.logout-btn:hover{background:#ef444440;border-color:#ef444466}.header-sep{background:#ffffff1f;width:1px;height:20px;margin:0 2px}.header-status{opacity:.7;font-size:11px}.header-user-pill{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border:1px solid #ffffff26;border-radius:20px;align-items:center;gap:8px;margin:0 2px;padding:3px 14px 3px 3px;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#00a3e0,#0057b8);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:900;display:flex;box-shadow:0 2px 8px #0003}.user-name{color:#ffffffe6;font-size:12px;font-weight:700}.sensor-select{color:#fff;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;padding:5px 10px;font-family:inherit;font-size:11px}.conn-badge{border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:11px;font-weight:700;display:flex}.conn-badge.live{background:#10b98126;border:1px solid #10b9814d}.conn-badge.stale{background:#f59e0b26;border:1px solid #f59e0b4d}.conn-badge.offline{background:#ef444426;border:1px solid #ef44444d}.conn-dot{border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}.conn-badge.live .conn-dot{background:var(--green)}.conn-badge.stale .conn-dot{background:var(--orange)}.conn-badge.offline .conn-dot{background:var(--red)}@keyframes pulse{0%,to{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 8px #10b98100}}.alerts-banner{border-bottom:2px solid var(--orange);background:linear-gradient(90deg,#fef3c7,#fde68a);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 28px;display:flex}.alerts-banner.danger{border-color:var(--red);background:linear-gradient(90deg,#fee2e2,#fecaca)}.alert-item{background:#0000000d;border-radius:8px;padding:4px 12px;font-size:12px;font-weight:700}.condition-bar{background:var(--card);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 28px;font-size:13px;transition:background .3s;display:flex}.condition-icon{font-size:28px}.condition-text{color:var(--text);font-weight:600}.condition-sub{color:var(--text-light);font-size:11px}.hero{background:var(--card);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:36px;padding:18px 28px;transition:background .3s;display:flex}.hero-stat{align-items:baseline;gap:6px;display:flex}.hero-val{letter-spacing:-1.5px;font-size:36px;font-weight:900}.hero-meta{color:var(--text-light);font-size:11px}.hero-unit{color:var(--text);font-size:12px;font-weight:700}.hero-stat.temp .hero-val{background:linear-gradient(135deg,#dc2626,#f97316);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.hero-stat.hum .hero-val{background:linear-gradient(135deg,#0284c7,#06b6d4);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.hero-stat.pres .hero-val{color:var(--green)}.hero-stat.aqi .hero-val{background:linear-gradient(135deg,#8b5cf6,#ec4899);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.hero-time-block{text-align:right;color:var(--text-light);margin-left:auto;font-size:11px}.hero-clock{color:var(--text);font-size:22px;font-weight:900}.hero-uptime{margin-top:2px;font-size:10px}.hero-device-status{border-left:1px solid var(--border);flex-direction:column;gap:8px;padding-left:20px;display:flex}.sat-countdown{border-left:1px solid var(--border);align-items:center;gap:16px;padding-left:20px;display:flex}.sat-ring-wrap{flex-shrink:0;width:80px;height:80px;position:relative}.sat-ring-wrap svg{width:100%;height:100%}.sat-ring-center{flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex;position:absolute;inset:0}.sat-ring-emoji{font-size:22px;line-height:1}.sat-ring-time{color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.5px;font-size:16px;font-weight:900}.sat-ring-time.synced{color:var(--green)}.sat-ping{pointer-events:none;position:absolute;inset:0}.sat-ping-ring{border:2px solid var(--green);opacity:0;border-radius:50%;animation:2s ease-out infinite pingOut;position:absolute;inset:15%}.sat-ping-ring.d2{animation-delay:.6s}.sat-ping-ring.d3{animation-delay:1.2s}@keyframes pingOut{0%{opacity:.7;inset:25%}to{opacity:0;inset:-5%}}.sat-text{flex-direction:column;gap:2px;display:flex}.sat-text-sub{color:var(--text-light);font-size:11px}.device-battery{grid-template-columns:auto auto auto;align-items:center;gap:4px 8px;display:grid}.battery-icon{align-items:center;display:flex}.battery-body{border:2px solid var(--text-light);border-radius:3px;width:32px;height:16px;padding:2px;position:relative;overflow:hidden}.battery-fill{background:var(--green);border-radius:1px;height:100%;transition:width 1s}.battery-tip{background:var(--text-light);border-radius:0 2px 2px 0;width:3px;height:8px;margin-left:1px}.battery-heartbeat{width:60px;height:24px;overflow:hidden}.heartbeat-svg{width:100%;height:100%;color:var(--green);animation:1.5s ease-in-out infinite heartPulse}.battery-val{color:var(--text);font-size:12px;font-weight:800}.device-signal{grid-template-columns:auto auto;align-items:center;gap:4px 8px;display:grid}.device-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-light);opacity:.6;grid-column:1/-1;margin-bottom:-2px;font-size:8px;font-weight:800}.signal-bars{align-items:flex-end;gap:2px;height:24px;display:flex}.signal-bar{background:var(--border);border-radius:1px;width:5px;transition:background .5s}.signal-bar.active{background:var(--green);animation:2s ease-in-out infinite signalGlow}.signal-val{color:var(--text);min-width:60px;font-size:12px;font-weight:800}@keyframes heartPulse{0%,to{opacity:.4;transform:scaleX(1)}30%{opacity:1;transform:scaleX(1.05)}60%{opacity:.6}}@keyframes signalGlow{0%,to{opacity:.8}50%{opacity:1}}.summary-bar{background:linear-gradient(135deg,var(--blue-light),var(--card));border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:28px;padding:12px 28px;font-size:12px;transition:background .3s;display:flex}.container{max-width:1440px;margin:0 auto;padding:20px 24px;overflow-x:hidden}.section{margin-bottom:20px}.section-title{color:var(--blue);text-transform:uppercase;letter-spacing:1.5px;align-items:center;gap:8px;margin-bottom:12px;font-size:11px;font-weight:800;display:flex}.section-title:before{content:"";background:linear-gradient(180deg,var(--blue),var(--accent));border-radius:2px;width:4px;height:14px}.grid-4{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.grid-2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.grid-wind{grid-template-columns:220px 1fr;gap:14px;display:grid}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:20px;transition:all .3s;position:relative;overflow:hidden}.card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0057b81f}.card.clickable{cursor:pointer}.card-glow{opacity:.03;pointer-events:none;border-radius:50%;width:100%;height:100%;position:absolute;top:-50%;right:-50%}.card-icon{margin-bottom:8px;font-size:24px}.card-label{color:var(--text-light);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;font-size:10px;font-weight:700}.card-value{letter-spacing:-1.5px;font-size:38px;font-weight:900;line-height:1}.card-unit{color:var(--text-light);margin-left:3px;font-size:13px;font-weight:500}.card-minmax{color:var(--text-light);gap:12px;margin-top:10px;font-size:10px;font-weight:600;display:flex}.card-minmax .lo{color:var(--blue)}.card-minmax .hi{color:var(--red)}.card-bar{height:3px;transition:width .8s;position:absolute;bottom:0;left:0}.card-trend{border-radius:6px;padding:3px 8px;font-size:10px;font-weight:700;position:absolute;top:16px;right:16px}.card-trend.up{color:var(--red);background:#ef444414}.card-trend.down{color:var(--blue);background:#0057b814}.card-trend.stable{color:var(--green);background:#10b98114}.card-timestamp{color:var(--text-light);margin-top:6px;font-size:9px}.sparkline{width:100%;height:32px;margin-top:8px;display:block}.beaufort-label{color:var(--text-light);margin-top:2px;font-size:10px;font-weight:600}.v-temp{color:#dc2626}.v-hum{color:#0891b2}.v-pres{color:var(--green)}.v-wind{color:var(--blue)}.v-pm{color:var(--purple)}.bar-temp{background:linear-gradient(90deg,#3b82f6,#f59e0b,#ef4444)}.bar-hum{background:linear-gradient(90deg,#f59e0b,#06b6d4)}.bar-pm{background:linear-gradient(90deg,#10b981,#f59e0b,#ef4444)}.compass-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);flex-direction:column;justify-content:center;align-items:center;padding:16px;display:flex}.compass{width:210px;height:210px}.compass-label-n{fill:var(--blue);text-anchor:middle;font-size:14px;font-weight:900}.compass-label-dir{fill:var(--text-light);text-anchor:middle;font-size:13px;font-weight:800}.compass-center-text{fill:var(--blue);text-anchor:middle;font-size:11px;font-weight:900}.compass-dir-text{fill:var(--text-light);text-anchor:middle;font-size:10px;font-weight:600}.beaufort-text{color:var(--text-light);margin-top:4px;font-size:11px;font-weight:700}.derived-grid{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.derived-card{background:linear-gradient(135deg,var(--blue-light),var(--card));border-radius:var(--radius);border:1px solid var(--border);padding:18px;transition:all .3s}.derived-card:hover{transform:translateY(-2px)}.derived-value{color:var(--blue-dark);font-size:30px;font-weight:900}[data-theme=dark] .derived-value{color:var(--accent)}.aqi-gauge{align-items:center;gap:12px;padding:6px 0;display:flex}.aqi-value{text-align:right;min-width:50px;color:var(--purple);font-size:22px;font-weight:900}.aqi-bar-wrap{background:var(--border);border-radius:4px;flex:1;height:8px;overflow:hidden}.aqi-bar{background:linear-gradient(90deg,#10b981,#f59e0b,#ef4444,#7c3aed);border-radius:4px;height:100%;transition:width .8s}.aqi-status{border-radius:6px;padding:3px 10px;font-size:10px;font-weight:700}.aqi-status.good{color:#10b981;background:#10b9811a}.aqi-status.moderate{color:#f59e0b;background:#f59e0b1a}.aqi-status.bad{color:#ef4444;background:#ef44441a}.footer{text-align:center;color:var(--text-light);border-top:1px solid var(--border);background:var(--card);margin-top:12px;padding:24px;font-size:11px}.footer a{color:var(--blue);font-weight:700;text-decoration:none}.footer-logo{vertical-align:middle;opacity:.5;height:18px;margin-right:8px}.footer-version{opacity:.6;margin-top:4px;font-size:10px}.loading-screen{min-height:100vh;color:var(--text-light);justify-content:center;align-items:center;font-size:16px;display:flex}@media (width<=1100px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-wind{grid-template-columns:1fr}.derived-grid{grid-template-columns:1fr 1fr}}@media (width<=768px){.grid-4,.grid-3{grid-template-columns:1fr 1fr}.grid-2{grid-template-columns:1fr}.hero{flex-wrap:wrap;gap:20px}.card-value{font-size:30px}.hero-val{font-size:28px}.hide-mobile{display:none!important}.show-mobile,.hamburger{display:flex!important}.hero-device-status{border-left:none;flex-direction:row;gap:16px;padding-left:0}.extras-strip{padding:10px 16px}.extras-cards{flex-wrap:wrap}.extras-card{min-width:calc(50% - 6px)}.summary-bar{flex-wrap:wrap;gap:4px;padding:8px 16px;font-size:12px}.condition-bar{flex-wrap:wrap;gap:8px;padding:12px 16px}.condition-updated{text-align:center;width:100%;font-size:11px}.dual-clock{gap:8px;padding:6px 16px}.clock-label{min-width:40px;font-size:9px}.clock-time{font-size:12px}.section{padding:16px}.section-title{font-size:18px}.hero-stat{padding:8px 12px}.hero-stat .hero-val{font-size:24px}}@media (width<=480px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.header{height:auto;padding:12px 16px}.derived-grid{grid-template-columns:1fr}.extras-cards{flex-direction:column}.extras-card{min-width:100%}.extras-timeline{gap:0}.timeline-hour{min-width:44px;padding:3px 4px}.hero{padding:16px}.hero-stat{padding:6px 8px}.hero-stat .hero-val{font-size:20px}.hero-stat .hero-unit{font-size:10px}.condition-spark{display:none}}@media (width<=1400px){.header-btn{padding:5px 8px;font-size:13px}.header-btn span{font-size:10px}.header-right{gap:4px}.header-user-pill{padding:2px 10px 2px 2px}}@media (width>=769px){.show-mobile{display:none!important}}.section-title-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title-row .section-title{margin-bottom:0}.range-selector{gap:4px;display:flex}.range-btn{background:var(--card);border:1px solid var(--border);color:var(--text-light);cursor:pointer;border-radius:8px;padding:5px 14px;font-family:inherit;font-size:11px;font-weight:700;transition:all .2s}.range-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.range-btn:hover:not(.active){background:var(--blue-light)}.range-sep{background:var(--border);width:1px;height:20px}.range-date{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:8px;max-width:150px;padding:4px 8px;font-family:inherit;font-size:10px}.range-to{color:var(--text-light);font-size:11px;font-weight:700}.charts-grid{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}.chart-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:16px}.chart-card.forecast-chart{grid-column:1/-1}.chart-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.chart-label{color:var(--text);font-size:12px;font-weight:700}.chart-unit{color:var(--text-light);font-size:10px;font-weight:600}.forecast-legend{gap:16px;display:flex}.legend-item{color:var(--text-light);align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.legend-line{border-radius:1px;width:20px;height:2px;display:inline-block}.legend-line.dashed{border-top:2px dashed}.legend-line.blue{border-color:#3b82f6}.legend-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.legend-dot.red{background:#dc2626}.chart-wrap{height:180px;position:relative}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--card);border-radius:var(--radius);width:90%;max-width:560px;max-height:90vh;padding:32px;animation:.3s slideUp;position:relative;overflow-y:auto;box-shadow:0 24px 80px #0003}.modal-content.detail-modal{max-width:700px}.modal-close{cursor:pointer;color:var(--text-light);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:18px;position:absolute;top:16px;right:16px}.modal-close:hover{background:var(--border)}.modal-content h2{margin-bottom:8px;font-size:18px;font-weight:800}.modal-desc{color:var(--text-light);margin-bottom:16px;font-size:13px}.modal-input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:12px;margin-bottom:12px;padding:12px 16px;font-family:inherit;font-size:14px}.modal-actions{gap:8px;display:flex}.modal-btn{border:1px solid var(--border);background:var(--card);color:var(--text);cursor:pointer;border-radius:12px;padding:10px 20px;font-family:inherit;font-size:13px;font-weight:700;transition:all .2s}.modal-btn.primary{background:var(--blue);color:#fff;border-color:var(--blue)}.modal-btn.primary:hover{background:var(--blue-dark)}.modal-status{margin-top:8px;font-size:12px;font-weight:600}.modal-status.success{color:var(--green)}.modal-status.error{color:var(--red)}.detail-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.detail-value{color:var(--blue);font-size:42px;font-weight:900}.detail-unit{color:var(--text-light);margin-left:4px;font-size:14px}.detail-stats{gap:16px;margin-bottom:16px;display:flex}.detail-stat{background:var(--bg);text-align:center;border-radius:12px;flex:1;padding:12px}.detail-stat .stat-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:700}.detail-stat .stat-val{margin-top:4px;font-size:20px;font-weight:900;display:block}.detail-stat .stat-val.lo{color:var(--blue)}.detail-stat .stat-val.hi{color:var(--red)}.detail-range{gap:4px;margin-bottom:16px;display:flex}.welcome-modal{text-align:center}.welcome-logos{justify-content:center;align-items:center;gap:16px;margin-bottom:20px;display:flex}.welcome-logo{height:40px}.welcome-logo.partner-logo{object-fit:contain;max-width:140px;max-height:40px}.welcome-x{color:var(--text-light);font-size:18px;font-weight:300}.welcome-text{color:var(--text-light);margin-bottom:8px;font-size:13px;line-height:1.6}.welcome-credit{color:var(--text-light);opacity:.6;margin-top:12px;margin-bottom:4px;font-size:11px;font-style:italic}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.charts-grid{grid-template-columns:1fr}.detail-stats{flex-direction:column}}.floating-dots{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.dot{aspect-ratio:1;background:var(--blue);opacity:.06;border-radius:50%;animation:linear infinite floatUp;position:absolute;bottom:-20px}@keyframes floatUp{0%{opacity:.06;transform:translateY(0)scale(1)}50%{opacity:.1}to{opacity:0;transform:translateY(-110vh)scale(.3)}}.tour-overlay{z-index:2000;cursor:pointer;position:fixed;inset:0}.tour-tooltip{z-index:2002;background:var(--card);border-radius:16px;width:320px;padding:20px 24px;animation:.3s slideUp;position:fixed;box-shadow:0 16px 48px #0003}.tour-step-count{color:var(--blue);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-size:10px;font-weight:700}.tour-title{color:var(--text);margin-bottom:6px;font-size:16px;font-weight:800}.tour-text{color:var(--text-light);margin-bottom:16px;font-size:13px;line-height:1.5}.tour-actions{justify-content:space-between;align-items:center;gap:8px;display:flex}.tour-actions div{gap:6px;display:flex}.tour-btn{border:1px solid var(--border);background:var(--card);color:var(--text);cursor:pointer;border-radius:10px;padding:7px 16px;font-family:inherit;font-size:12px;font-weight:700}.tour-btn.primary{background:var(--blue);color:#fff;border-color:var(--blue)}.tour-btn.skip{opacity:.5;background:0 0;border:none}.tour-btn.skip:hover{opacity:1}.hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:8px;display:none}.hamburger-line{background:#fff;border-radius:2px;width:24px;height:2px;transition:all .3s;display:block}.hamburger-line.open:first-child{transform:rotate(45deg)translate(5px,5px)}.hamburger-line.open:nth-child(2){opacity:0}.hamburger-line.open:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.mobile-menu{background:linear-gradient(135deg,#001d3d,var(--blue));z-index:99;flex-wrap:wrap;gap:8px;padding:16px;display:none;position:absolute;top:100%;left:0;right:0;box-shadow:0 8px 32px #0000004d}.csv-dropdown{position:relative}.csv-menu{background:var(--card);border:1px solid var(--border);z-index:50;border-radius:12px;min-width:140px;margin-top:6px;padding:6px;position:absolute;top:100%;right:0;box-shadow:0 8px 24px #00000026}.csv-option{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:12px;font-weight:600;display:block}.csv-option:hover{background:var(--blue-light)}.location-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden}.location-map-wrap{height:300px;position:relative;overflow:hidden}.location-map-iframe{border:none;width:100%;height:100%}.location-overlay{color:#fff;pointer-events:none;background:linear-gradient(#0000,#000000b3);padding:12px 20px;position:absolute;bottom:0;left:0;right:0}.location-overlay-name{font-size:14px;font-weight:800}.location-overlay-coords{opacity:.8;font-variant-numeric:tabular-nums;font-size:11px}.skeleton-header{background:linear-gradient(135deg,#001d3d,#0057b8);justify-content:space-between;align-items:center;height:68px;padding:0 28px;display:flex}.skeleton-hero{background:var(--card);border-bottom:1px solid var(--border);gap:36px;padding:24px 28px;display:flex}.skeleton-block{background:var(--border);border-radius:12px;width:120px;height:50px;animation:1.5s infinite shimmer}.skeleton-body{max-width:1440px;margin:0 auto;padding:20px 24px}.skeleton-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-top:12px;display:grid}.skeleton-card{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);height:160px;animation:1.5s infinite shimmer}.skeleton-bar{background:var(--border);border-radius:7px;height:14px;animation:1.5s infinite shimmer}.skeleton-bar.w40{width:40%}.skeleton-bar.w30{width:30%}.skeleton-bar.w20{width:20%}@keyframes shimmer{0%{opacity:.6}50%{opacity:.3}to{opacity:.6}}.condition-updated{color:var(--text-light);white-space:nowrap;margin-left:auto;font-size:11px;font-weight:600}.chat-fab{background:linear-gradient(135deg,var(--blue),var(--accent));color:#fff;cursor:pointer;z-index:900;border:none;border-radius:50%;width:56px;height:56px;font-size:24px;transition:all .3s;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 20px #0057b866}.chat-fab:hover{transform:scale(1.1);box-shadow:0 6px 28px #0057b880}.chat-panel{background:var(--card);z-index:900;border:1px solid var(--border);border-radius:20px;flex-direction:column;width:380px;max-height:520px;animation:.3s slideUp;display:flex;position:fixed;bottom:92px;right:24px;overflow:hidden;box-shadow:0 12px 48px #0000002e}.chat-header{background:linear-gradient(135deg,#001d3d,var(--blue));color:#fff;align-items:center;gap:12px;padding:16px 20px;display:flex}.chat-header-icon{font-size:28px}.chat-header-title{font-size:14px;font-weight:800}.chat-header-sub{opacity:.7;font-size:10px}.chat-messages{flex-direction:column;flex:1;gap:10px;max-height:340px;padding:16px;display:flex;overflow-y:auto}.chat-msg{align-items:flex-start;gap:8px;display:flex}.chat-msg.user{flex-direction:row-reverse}.chat-avatar{flex-shrink:0;margin-top:2px;font-size:20px}.chat-bubble{white-space:pre-line;border-radius:16px;max-width:85%;padding:10px 14px;font-size:13px;line-height:1.5}.chat-msg.bot .chat-bubble{background:var(--bg);color:var(--text);border-bottom-left-radius:4px}.chat-msg.user .chat-bubble{background:var(--blue);color:#fff;border-bottom-right-radius:4px}.chat-typing{gap:4px;padding:12px 18px;display:flex}.chat-typing span{background:var(--text-light);border-radius:50%;width:6px;height:6px;animation:1.2s infinite typingDot}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}.chat-input-row{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:12px 16px;display:flex}.chat-prompts{flex-wrap:wrap;gap:6px;display:flex}.chat-prompt{border:1px solid var(--blue);color:var(--blue);cursor:pointer;white-space:nowrap;background:0 0;border-radius:20px;padding:6px 12px;font-family:inherit;font-size:11px;font-weight:700;transition:all .2s}.chat-prompt:hover{background:var(--blue);color:#fff}.chat-input-wrap{gap:8px;display:flex}.chat-input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:12px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:13px}.chat-input:focus{border-color:var(--blue)}.chat-send{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:12px;width:40px;height:40px;font-size:16px;transition:background .2s}.chat-send:hover{background:var(--blue-dark)}.chat-send:disabled{opacity:.5}@media (width<=480px){.chat-panel{width:auto;bottom:84px;left:8px;right:8px}}.extras-strip{background:var(--card);border-bottom:1px solid var(--border);max-width:100%;padding:12px 28px;transition:background .3s;overflow:hidden}.extras-timeline{border-bottom:1px solid var(--border);-webkit-overflow-scrolling:touch;touch-action:pan-x;gap:2px;margin-bottom:8px;padding-bottom:8px;display:flex;overflow-x:auto}.timeline-hour{border-radius:10px;flex-direction:column;align-items:center;min-width:52px;padding:4px 6px;transition:background .2s;display:flex}.timeline-hour:hover{background:var(--blue-light)}.timeline-icon{font-size:18px}.timeline-temp{color:var(--text);font-size:12px;font-weight:800}.timeline-time{color:var(--text-light);font-size:9px;font-weight:600}.extras-cards{touch-action:pan-x;gap:12px;max-width:100%;display:flex;overflow-x:auto}.extras-card{background:var(--bg);border-radius:14px;flex:1;min-width:140px;padding:12px 16px}.extras-card-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-light);margin-bottom:6px;font-size:9px;font-weight:800}.comfort-gauge{text-align:center}.comfort-score{font-size:28px;font-weight:900}.comfort-bar-wrap{background:var(--border);border-radius:2px;height:4px;margin:4px 0;overflow:hidden}.comfort-bar-fill{border-radius:2px;height:100%;transition:width .8s}.comfort-label{font-size:11px;font-weight:800}.sun-times{color:var(--text);justify-content:space-between;font-size:13px;font-weight:700;display:flex}.sun-remaining{color:var(--text-light);margin-top:4px;font-size:11px}.records-grid{color:var(--text);grid-template-columns:1fr 1fr;gap:4px;font-size:12px;font-weight:700;display:grid}.health-pct{font-size:24px;font-weight:900}.health-detail{color:var(--text-light);font-size:11px}.vs-grid{flex-direction:column;gap:2px;font-size:12px;font-weight:700;display:flex}.vs-up{color:#10b981}.vs-down{color:#0057b8}.notif-dropdown{position:relative}.notif-badge{color:#fff;background:#ef4444;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;font-weight:900;display:flex;position:absolute;top:-4px;right:-4px}.notif-menu{background:var(--card);border:1px solid var(--border);z-index:50;border-radius:14px;min-width:280px;max-height:300px;margin-top:6px;padding:8px;position:absolute;top:100%;right:0;overflow-y:auto;box-shadow:0 8px 24px #00000026}.notif-item{color:var(--text);border-left:3px solid var(--orange);background:var(--bg);border-radius:8px;margin-bottom:4px;padding:8px 12px;font-size:12px;font-weight:600}.notif-item.danger{border-color:var(--red)}.notif-time{color:var(--text-light);margin-right:8px;font-size:10px}.notif-empty{text-align:center;color:var(--text-light);padding:16px;font-size:12px}.animated-icon{animation:3s ease-in-out infinite iconBounce}@keyframes iconBounce{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.condition-spark{vertical-align:middle;width:80px;height:20px;margin-left:8px}.uv-val{font-size:24px;font-weight:900}.uv-bar-wrap{background:linear-gradient(90deg,#10b981,#f59e0b,#ef4444,#7c3aed);border-radius:3px;height:6px;margin:4px 0;position:relative;overflow:hidden}.uv-bar-fill{background:#ffffff80;height:100%;position:absolute;top:0;right:0}.best-time-val{color:var(--blue);font-size:22px;font-weight:900}.clothing-val{text-align:center;font-size:28px}.clothing-text{color:var(--text);text-align:center;margin-top:2px;font-size:12px;font-weight:700}.health-note{color:var(--orange);margin-top:4px;font-size:9px;font-weight:600;line-height:1.3}.grid-4 .card,.grid-3 .card,.derived-card,.extras-card,.chart-card{animation:.5s ease-out both cardIn}.grid-4 .card:first-child,.derived-card:first-child{animation-delay:0s}.grid-4 .card:nth-child(2),.derived-card:nth-child(2){animation-delay:80ms}.grid-4 .card:nth-child(3),.derived-card:nth-child(3){animation-delay:.16s}.grid-4 .card:nth-child(4),.derived-card:nth-child(4){animation-delay:.24s}.grid-3 .card:first-child{animation-delay:0s}.grid-3 .card:nth-child(2){animation-delay:80ms}.grid-3 .card:nth-child(3){animation-delay:.16s}.grid-3 .card:nth-child(4){animation-delay:.24s}.grid-3 .card:nth-child(5){animation-delay:.32s}.grid-3 .card:nth-child(6){animation-delay:.4s}@keyframes cardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.card-value,.hero-val,.derived-value{transition:text-shadow .3s}.card-value:not(:empty),.hero-val:not(:empty){animation:.6s ease-out valueFlash}@keyframes valueFlash{0%{text-shadow:0 0 8px #0057b84d}to{text-shadow:none}}.bar-fill,.battery-fill,.comfort-bar-fill,.sat-progress-fill{transition:width .8s cubic-bezier(.34,1.56,.64,1)}.compass svg g[style*=rotate]{filter:drop-shadow(0 0 3px #0057b833)}.compass svg g[style*=rotate] path:first-child{filter:drop-shadow(2px 2px 4px #0057b826)}.conn-badge.live .conn-dot{animation:1.5s ease-in-out infinite heartbeatDot}@keyframes heartbeatDot{0%,to{transform:scale(1);box-shadow:0 0 #10b98166}25%{transform:scale(1.3);box-shadow:0 0 0 4px #10b98133}50%{transform:scale(1);box-shadow:0 0 #10b98100}75%{transform:scale(1.15);box-shadow:0 0 0 2px #10b98126}}.ethernet-badge{color:var(--green);text-align:center;background:#10b9811a;border-radius:8px;padding:3px 10px;font-size:9px;font-weight:800;animation:.5s ease-out cardIn}.dual-clock{background:var(--card);border-bottom:1px solid var(--border);justify-content:center;align-items:center;gap:12px;padding:8px 28px;font-family:monospace;display:flex}.clock-item{align-items:center;gap:6px;display:flex}.clock-flag{font-size:16px}.clock-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-light);min-width:60px;font-size:10px;font-weight:800}.clock-time{color:var(--text);letter-spacing:1px;font-size:14px;font-weight:900}.clock-divider{color:var(--border);font-weight:300}.local-wx-card{border:1px solid var(--blue-light);background:linear-gradient(135deg,var(--bg),#0057b80a)}.local-wx-icon{text-align:center;font-size:24px}.local-wx-temp{text-align:center;color:var(--text);font-size:20px;font-weight:900}.local-wx-detail{color:var(--text-light);text-align:center;margin-top:2px;font-size:11px}.extras-card:first-child{animation-delay:0s}.extras-card:nth-child(2){animation-delay:60ms}.extras-card:nth-child(3){animation-delay:.12s}.extras-card:nth-child(4){animation-delay:.18s}.extras-card:nth-child(5){animation-delay:.24s}.extras-card:nth-child(6){animation-delay:.3s}.extras-card:nth-child(7){animation-delay:.36s}.extras-card:nth-child(8){animation-delay:.42s}.extras-card:nth-child(9){animation-delay:.48s}.section{animation:.6s ease-out both sectionIn}@keyframes sectionIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.sat-ring.synced{filter:drop-shadow(0 0 8px #0057b84d);transition:filter .5s}.stat-val,.health-pct,.comfort-score,.uv-val{transition:color .3s,transform .2s}.timeline-hour:hover{transition:transform .2s;transform:translateY(-2px)}.local-wx-card{background-size:200% 100%;transition:background-position .5s}.local-wx-card:hover{background-position:100%}.coffee-btn{font-weight:600;color:#fff!important;background:linear-gradient(135deg,#ffb347 0%,#ff7a59 100%)!important;border-color:#ffffff40!important}.coffee-btn:hover{filter:brightness(1.08);box-shadow:0 4px 14px #ff7a5959}.coffee-toast{left:50%;bottom:calc(24px + env(safe-area-inset-bottom));z-index:900;color:#f9fafb;background:linear-gradient(135deg,#111827 0%,#1f2937 100%);border:1px solid #ffffff14;border-radius:14px;align-items:center;gap:12px;max-width:min(560px,100vw - 24px);padding:12px 14px;font-family:inherit;animation:.28s ease-out both coffeeToastSlideIn;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 12px 40px #00000059}@keyframes coffeeToastSlideIn{0%{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%)}}.coffee-toast-icon{flex:none;font-size:28px;line-height:1}.coffee-toast-body{flex:auto;min-width:0}.coffee-toast-title{color:#fff;font-size:14px;font-weight:600}.coffee-toast-text{color:#d1d5db;font-size:13px;line-height:1.3}.coffee-toast-cta{color:#111827;white-space:nowrap;background:linear-gradient(135deg,#ffb347 0%,#ff7a59 100%);border-radius:10px;flex:none;justify-content:center;align-items:center;padding:8px 14px;font-size:13px;font-weight:700;text-decoration:none;transition:filter .15s,transform .15s;display:inline-flex}.coffee-toast-cta:hover{filter:brightness(1.05)}.coffee-toast-cta:active{transform:translateY(1px)}.coffee-toast-close{color:#9ca3af;cursor:pointer;background:0 0;border:0;border-radius:8px;flex:none;padding:4px 8px;font-size:20px;line-height:1}.coffee-toast-close:hover{color:#fff;background:#ffffff14}@media (width<=480px){.coffee-toast{max-width:none;left:12px;right:12px;bottom:calc(88px + env(safe-area-inset-bottom));gap:10px;padding:10px 12px;transform:none}@keyframes coffeeToastSlideIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.coffee-toast-icon{font-size:24px}.coffee-toast-title{font-size:13px}.coffee-toast-text{font-size:12px}.coffee-toast-cta{padding:7px 12px;font-size:12px}}@keyframes coffeeFlash{0%,to{box-shadow:0 0 8px #ffa80066}50%{box-shadow:0 0 20px #ffa800e6}}.coffee-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff9500,#ff6b00);border:none;border-radius:12px;align-items:center;gap:8px;padding:12px 20px;font-size:.95rem;font-weight:600;text-decoration:none;transition:transform .2s;animation:1.5s ease-in-out infinite coffeeFlash;display:inline-flex}.coffee-btn:hover{transform:scale(1.05)}.coffee-btn .coffee-icon{font-size:1.2em}.tools-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:flex-end;align-items:flex-start;padding-top:56px;display:flex;position:fixed;inset:0}.tools-panel{background:var(--card);border:1px solid var(--border);border-radius:16px;width:280px;max-width:85vw;max-height:80vh;margin:8px 12px;padding:20px;animation:.2s ease-out slideUp;overflow-y:auto;box-shadow:0 16px 48px #0003}.tools-header{color:var(--text-h);justify-content:space-between;align-items:center;margin-bottom:14px;font-size:.9rem;font-weight:700;display:flex}.tools-close{cursor:pointer;color:var(--text-light);background:0 0;border:none;padding:4px;font-size:1.1rem;line-height:1}.tools-close:hover{color:var(--text-h)}.tools-grid{grid-template-columns:1fr 1fr;gap:6px;margin-bottom:14px;display:grid}.tool-btn{cursor:pointer;text-align:left;color:#1e293b;background:#f1f5f9;border:none;border-radius:8px;padding:10px 12px;font-size:.8rem;font-weight:600;transition:background .15s}.tool-btn:hover{color:#fff;background:#0057b8}.tools-section{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;padding-top:12px;display:flex}.tools-section-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.8px;width:100%;margin-bottom:2px;font-size:.65rem;font-weight:700}.tools-row{flex-wrap:wrap;gap:4px;display:flex}.tool-btn-sm{cursor:pointer;color:#1e293b;background:#f1f5f9;border:none;border-radius:6px;padding:6px 10px;font-size:.75rem;font-weight:700;transition:background .15s}.tool-btn-sm:hover{color:#fff;background:#0057b8}.rain-stats{gap:16px;margin-top:16px;display:flex}.rain-stat{text-align:center;flex:1}.rain-value{color:var(--text-h);font-size:1.6rem;font-weight:900}.rain-value .rain-unit{color:var(--text-light);margin-left:2px;font-size:.7rem;font-weight:500}.rain-period{color:var(--text-light);margin:4px 0 8px;font-size:.7rem;font-weight:600}.rain-bar{background:var(--border);border-radius:4px;height:4px;overflow:hidden}.rain-bar-fill{background:linear-gradient(90deg,#06b6d4,#0057b8);border-radius:4px;height:100%;transition:width .5s}.week-comp{flex-direction:column;gap:8px;margin-top:12px;display:flex}.week-row{background:var(--bg);border:1px solid var(--border);border-radius:10px;align-items:center;gap:8px;padding:8px 12px;display:flex}.week-icon{font-size:1.1rem}.week-label{color:var(--text-light);flex:1;font-size:.8rem;font-weight:600}.week-this{color:var(--text-h);font-size:.9rem;font-weight:800}.week-diff{text-align:right;min-width:50px;color:var(--text-light);font-size:.75rem;font-weight:700}.week-diff.up{color:#ef4444}.week-diff.down{color:#0057b8}.temp-heatmap{pointer-events:none;z-index:0;transition:background 3s;position:fixed;inset:0}.dashboard{z-index:1;position:relative}.skyline-bg{border-radius:0 0 16px 16px;height:80px;margin:-20px -24px 20px;transition:background 2s;position:relative;overflow:hidden}.sky-body{font-size:24px;transition:all 2s;position:absolute}.skyline-svg{width:100%;height:60px;position:absolute;bottom:0;left:0}.stars{background:radial-gradient(1px 1px at 20% 30%,#fff,#0000),radial-gradient(1px 1px at 60% 20%,#fff,#0000),radial-gradient(1px 1px at 80% 60%,#fff,#0000),radial-gradient(1px 1px at 40% 70%,#fff,#0000),radial-gradient(1px 1px at 10% 80%,#fff,#0000);position:absolute;inset:0}.ambient-btn{border:1px solid var(--border);background:var(--card);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:.85rem;transition:all .15s;display:inline-flex}.ambient-btn:hover{color:#fff;background:#0057b8;border-color:#0057b8}.viz-card{flex-direction:column;align-items:center;min-height:260px;display:flex}.viz-card canvas{flex:1;max-width:100%}.station-selector{border:1px solid var(--border);background:var(--card);color:var(--text-h);cursor:pointer;border-radius:8px;max-width:220px;padding:6px 12px;font-size:.85rem;font-weight:600}.station-selector-empty{color:#dc2626;cursor:not-allowed;background:#fef2f2;border-color:#fecaca}.station-selector-single{cursor:default;background:var(--bg);color:var(--text-light)}select.station-selector{appearance:menulist}.no-access-wrap{background:linear-gradient(135deg,#f0f4f8,#fff);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.no-access-card{text-align:center;border:1px solid var(--border);background:#fff;border-radius:20px;max-width:480px;padding:40px;box-shadow:0 16px 48px #00000014}.no-access-icon{margin-bottom:16px;font-size:48px}.no-access-card h2{color:var(--text-h);margin-bottom:12px;font-size:1.4rem}.no-access-card p{color:var(--text);line-height:1.6}.no-access-logout{color:#fff;background:#0057b8;border-radius:10px;margin-top:24px;padding:10px 24px;font-size:.9rem;font-weight:600;text-decoration:none;display:inline-block}.no-access-logout:hover{background:#003d82}.no-access-footer{color:var(--text-light);margin-top:24px;font-size:.8rem}.no-access-footer a{color:#0057b8;font-weight:600;text-decoration:none}.admin-page{max-width:1200px;margin:0 auto;padding:24px;font-family:-apple-system,sans-serif}.admin-header{border-bottom:2px solid var(--border);justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;display:flex}.admin-header h1{color:var(--text-h);margin-bottom:4px;font-size:1.6rem}.admin-subtitle{color:var(--text-light);font-size:.9rem}.admin-nav{gap:8px;display:flex}.admin-nav button{background:var(--bg);border:1px solid var(--border);cursor:pointer;color:var(--text-h);border-radius:8px;padding:8px 16px;font-weight:600}.admin-nav button:hover{color:#fff;background:#0057b8;border-color:#0057b8}.admin-section{background:var(--card);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;padding:20px}.admin-section h2{color:var(--text-h);margin-bottom:12px;font-size:1.1rem}.admin-warning{color:#78350f;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:0 8px 8px 0;margin-bottom:20px;padding:12px 16px;font-size:.9rem;line-height:1.6}.admin-msg{color:#1e40af;background:#dbeafe;border:1px solid #93c5fd;border-radius:8px;margin-bottom:16px;padding:10px 16px;font-weight:600}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th{text-align:left;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:#f8fafc;padding:10px;font-size:.8rem}.admin-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px}.admin-table button{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:6px;margin-right:6px;padding:4px 10px;font-size:.8rem;font-weight:600}.admin-table button:hover{color:#fff;background:#0057b8}.admin-table button.btn-danger{color:#dc2626;border-color:#fecaca}.admin-table button.btn-danger:hover{color:#fff;background:#dc2626;border-color:#dc2626}.admin-table select,.admin-table input{border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:.85rem}.admin-form{border:1px dashed var(--border);background:#f8fafc;border-radius:10px;margin-top:20px;padding:16px}.admin-form h3{color:var(--text-h);margin-bottom:10px;font-size:.95rem}.form-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.form-row input{border:1px solid var(--border);border-radius:8px;flex:1;min-width:140px;padding:8px 12px;font-size:.85rem}.form-row button{color:#fff;cursor:pointer;background:#0057b8;border:none;border-radius:8px;padding:8px 20px;font-size:.85rem;font-weight:600}.form-row button:hover:not(:disabled){background:#003d82}.form-row button:disabled{opacity:.5;cursor:not-allowed}.station-chips{flex-wrap:wrap;gap:4px;display:flex}.station-chips .chip{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:16px;padding:4px 10px;font-size:.75rem;font-weight:600;transition:all .15s}.station-chips .chip.active{color:#fff;background:#0057b8;border-color:#0057b8}.station-chips .chip:hover{border-color:#0057b8}.station-select-lg{border:1px solid var(--border);background:var(--card);border-radius:10px;width:100%;padding:12px 16px;font-size:.95rem}.offset-current{background:linear-gradient(135deg,#f0f4f8,#fff);border-radius:12px;align-items:center;gap:20px;padding:20px;display:flex}.offset-big{color:#0057b8;font-size:3rem;font-weight:900}.offset-big span{margin-left:4px;font-size:1.5rem}.offset-meta{flex:1}.offset-form{flex-direction:column;gap:14px;display:flex}.offset-form label{flex-direction:column;gap:6px;display:flex}.offset-form label span{color:var(--text-h);font-size:.85rem;font-weight:700}.offset-form input,.offset-form textarea{border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-family:inherit;font-size:.95rem}.offset-form textarea{resize:vertical}.offset-confirm{background:#fef3c7;border-left:4px solid #f59e0b;border-radius:10px;padding:16px}.offset-confirm button{border:1px solid var(--border);background:var(--bg);cursor:pointer;border-radius:8px;margin:8px 8px 0 0;padding:10px 20px;font-weight:600}.offset-confirm button.btn-primary{color:#fff;background:#0057b8;border-color:#0057b8}.offset-form .btn-primary{color:#fff;cursor:pointer;background:#0057b8;border:none;border-radius:10px;align-self:flex-start;padding:12px 28px;font-size:.95rem;font-weight:700}.offset-form .btn-primary:disabled{opacity:.4;cursor:not-allowed}.condition-updated{text-align:right;line-height:1.35}.condition-updated-sub{text-transform:uppercase;letter-spacing:.6px;color:var(--blue);opacity:.85;font-size:9px;font-weight:700}.conn-badge.satlink{background:#0057b81f;border:1px solid #0057b84d}.conn-badge.satlink .conn-dot{background:var(--blue);animation:none}body{background:radial-gradient(1200px 600px at 15% -5%, #0057b80d, transparent 60%), radial-gradient(1000px 500px at 110% 0%, #00a3e00d, transparent 55%), var(--bg);background-attachment:fixed}[data-theme=dark] body{background:radial-gradient(1200px 600px at 15% -5%, #0057b82e, transparent 60%), radial-gradient(1000px 500px at 110% 0%, #00a3e01a, transparent 55%), var(--bg);background-attachment:fixed}.header{-webkit-backdrop-filter:saturate(1.1);backdrop-filter:saturate(1.1);box-shadow:0 6px 30px #00286447,inset 0 -1px #ffffff0f}.header-btn{border-radius:11px}.card{border-radius:18px;transition:transform .28s cubic-bezier(.22,1,.36,1),box-shadow .28s,border-color .28s;box-shadow:0 1px 2px #1028500d,0 8px 24px #00398212}.card:after{content:"";opacity:.5;pointer-events:none;background:linear-gradient(90deg,#0000,#fff9,#0000);height:1px;position:absolute;inset:0 0 auto}[data-theme=dark] .card:after{background:linear-gradient(90deg,#0000,#ffffff14,#0000)}.card:hover{border-color:#0057b840;transform:translateY(-5px);box-shadow:0 18px 50px #00398229}.card.clickable:active{transform:translateY(-2px)}.card-icon{filter:drop-shadow(0 2px 4px #00000014)}.section-title{letter-spacing:1.6px;padding-left:11px;font-size:11.5px;position:relative}.section-title:before{content:"";background:linear-gradient(180deg,var(--accent),var(--blue));border-radius:3px;width:4px;height:14px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.hero{background:linear-gradient(180deg,var(--card),color-mix(in srgb,var(--card) 92%,var(--blue)));box-shadow:inset 0 -1px 0 var(--border)}.hero-val{font-size:38px}.hero-clock{font-variant-numeric:tabular-nums}.sat-ring-wrap{filter:drop-shadow(0 4px 10px #0039821a)}.sat-ring-time{font-size:17px}.sat-text-label{color:var(--text);font-size:11px;font-weight:800}.sat-text-sub{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.conn-badge{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 1px 3px #0000000f}.conn-badge.satlink .conn-dot{box-shadow:0 0 0 3px #0057b81f}.summary-bar{gap:10px 22px}.summary-bar span{align-items:center;gap:5px;display:inline-flex}.summary-bar strong{color:var(--text)}.derived-card{border-radius:18px;box-shadow:0 6px 20px #0039820f}.derived-card:hover{transform:translateY(-4px);box-shadow:0 14px 36px #0039821f}.range-btn{transition:all .2s cubic-bezier(.22,1,.36,1)}.range-btn:hover{transform:translateY(-1px)}.chart-card{border-radius:18px;transition:transform .28s,box-shadow .28s;box-shadow:0 6px 20px #0039820f}.chart-card:hover{transform:translateY(-3px);box-shadow:0 14px 36px #0039821f}@media (prefers-reduced-motion:reduce){.section,.card,.derived-card,.extras-card,.chart-card{animation:none!important}.card:hover,.derived-card:hover,.chart-card:hover{transform:none}}.admin-page{background:#f0f4f8;min-height:100vh}.admin-header{color:#fff;background:linear-gradient(135deg,#001d3d,#0057b8,#00a3e0);justify-content:space-between;align-items:center;padding:16px 28px;display:flex}.admin-header-left{align-items:center;gap:16px;display:flex}.admin-logo{filter:brightness(0)invert();height:28px}.admin-header h1{font-size:18px;font-weight:800}.admin-header-right{gap:8px;display:flex}.admin-btn{color:#fff;cursor:pointer;background:#ffffff1f;border:1px solid #fff3;border-radius:10px;padding:8px 16px;font-family:inherit;font-size:12px;font-weight:600;text-decoration:none}.admin-container{max-width:900px;margin:0 auto;padding:24px}.admin-stats{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px;display:grid}.admin-stat{text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:16px}.stat-val{color:#0057b8;font-size:28px;font-weight:900}.stat-label{color:#64748b;text-transform:uppercase;margin-top:4px;font-size:11px;font-weight:600}.admin-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;margin-bottom:20px;padding:24px;box-shadow:0 2px 16px #0057b80f}.admin-card h2{color:#0057b8;margin-bottom:16px;font-size:16px;font-weight:800}.admin-table{border-collapse:collapse;width:100%}.admin-table th{text-align:left;color:#64748b;text-transform:uppercase;border-bottom:2px solid #e2e8f0;padding:10px 12px;font-size:11px;font-weight:700}.admin-table td{border-bottom:1px solid #f1f5f9;padding:12px;font-size:14px}.admin-table tr:hover td{background:#f8fafc}.badge{border-radius:6px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.badge-admin{color:#0057b8;background:#0057b81a}.badge-user{color:#10b981;background:#10b9811a}.badge-available{color:#0057b8;background:#0057b81a}.badge-used{color:#ef4444;background:#ef44441a}.delete-btn{color:#ef4444;cursor:pointer;background:#fee2e2;border:none;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:700}.invite-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.invite-input{border:1px solid #e2e8f0;border-radius:10px;flex:1;min-width:200px;padding:10px 16px;font-family:inherit;font-size:13px}.invite-btn{color:#fff;cursor:pointer;background:#0057b8;border:none;border-radius:10px;padding:10px 20px;font-family:inherit;font-size:13px;font-weight:700}.invite-result{color:#166534;background:#f0fdf4;border:1px solid #10b981;border-radius:10px;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:600}.code-cell{letter-spacing:2px;font-family:monospace;font-weight:800}.clickable-row{cursor:pointer;transition:background .2s}.clickable-row:hover{background:#0057b80a}.user-modal-overlay{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.user-modal{background:#fff;border-radius:20px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.user-modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-start;padding:28px 32px 20px;display:flex}.user-modal-header h2{color:#0f172a;font-size:22px;font-weight:900}.user-modal-email{color:#64748b;margin:4px 0 8px;font-size:13px}.user-modal-close{cursor:pointer;color:#94a3b8;background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:20px}.user-modal-close:hover{color:#0f172a;background:#f1f5f9}.user-modal-map{padding:20px 32px}.user-modal-map-label{text-transform:uppercase;letter-spacing:1.5px;color:#0057b8;margin-bottom:12px;font-size:11px;font-weight:800}.user-modal-locations{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.location-chip{color:#334155;background:#f0f4f8;border-radius:8px;padding:4px 12px;font-size:11px;font-weight:600}.user-modal-log{padding:20px 32px 28px}
