/* ══════════════════════════════════════════════
   SKYVIEW STYLES
══════════════════════════════════════════════ */

/* ── Theme Tokens ── */
:root{
  --bg:        #0a0e17;
  --bg2:       #0d1320;
  --bg3:       #111a2e;
  --bg4:       #152238;
  --card:      #131d2e;
  --card2:     #182536;
  --border:    rgba(255,255,255,0.06);
  --border2:   rgba(255,255,255,0.10);
  --txt:       #e0eaff;
  --txt2:      #6b8fb8;
  --txt3:      #3d5a7a;
  --blue:      #4aa8ff;
  --blue2:     #2d8ad4;
  --green:     #22d3a0;
  --purple:    #9d78fb;
  --orange:    #fb923c;
  --yellow:    #f7c948;
  --red:       #f87171;
  --r:         14px;
  --rs:        9px;
  --topbar-h:  62px;
  --shadow:    0 16px 48px rgba(0,0,0,.7);
  --chart-grid: rgba(255,255,255,0.06);
  --chart-tick: #3d5a7a;
}

[data-theme="light"]{
  --bg:        #f7fafc;
  --bg2:       #edf2f7;
  --bg3:       #e2e8f0;
  --bg4:       #cbd5e0;
  --card:      #ffffff;
  --card2:     #f7fafc;
  --border:    rgba(0,0,0,0.06);
  --border2:   rgba(0,0,0,0.10);
  --txt:       #1a202c;
  --txt2:      #4a5568;
  --txt3:      #a0aec0;
  --blue:      #3182ce;
  --blue2:     #2b6cb0;
  --green:     #38a169;
  --purple:    #805ad5;
  --orange:    #dd6b20;
  --yellow:    #d69e2e;
  --red:       #e53e3e;
  --shadow:    0 16px 48px rgba(0,0,0,.12);
  --chart-grid: rgba(0,0,0,0.06);
  --chart-tick: #a0aec0;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--txt);min-height:100vh;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .3s,color .3s;
}
@supports(padding: max(0px)){
  .topbar{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));}
  .app{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));}
}

/* ══ LOADING SPINNER ══ */
@keyframes spin{to{transform:rotate(360deg);}}
.globe-loader{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:10;
  background:var(--bg);border-radius:50%;
  transition:opacity .6s;
}
.globe-loader.fade{opacity:0;pointer-events:none;}
.globe-loader div{
  width:36px;height:36px;border:2.5px solid rgba(74,168,255,0.12);
  border-top-color:var(--blue);border-radius:50%;animation:spin .9s linear infinite;
}

/* ══ TOPBAR ══ */
.topbar{
  position:-webkit-sticky;position:sticky;top:0;z-index:100;
  background:rgba(var(--bg-rgb,10,14,23),0.92);
  -webkit-backdrop-filter:blur(20px) saturate(1.8);
  backdrop-filter:blur(20px) saturate(1.8);
  border-bottom:1px solid var(--border);
  padding:10px 16px;
  padding-top:max(10px,env(safe-area-inset-top));
  transition:background .3s;
}
[data-theme="light"] .topbar{
  background:rgba(255,255,255,0.85);
}
.topbar-inner{max-width:960px;margin:0 auto;display:flex;align-items:center;gap:10px;}
.brand{font-size:16px;font-weight:700;color:var(--txt);letter-spacing:-.3px;white-space:nowrap;flex-shrink:0}
.brand span{color:var(--blue)}
.search-wrap{position:relative;flex:1;min-width:0;}
.search-row{
  display:flex;align-items:center;gap:8px;
  background:var(--card2);border:1px solid var(--border2);
  border-radius:99px;padding:0 6px 0 14px;
  transition:border-color .2s,box-shadow .2s,background .3s;
}
.search-row:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(49,130,206,.12);}
.search-icon{font-size:14px;color:var(--txt2);flex-shrink:0;pointer-events:none}
.search-input{flex:1;height:40px;background:none;border:none;outline:none;font-size:15px;color:var(--txt);min-width:0;}
.search-input::placeholder{color:var(--txt3)}
@media screen and (-webkit-min-device-pixel-ratio:0){.search-input{font-size:16px;}}
.search-clear{
  -webkit-appearance:none;background:none;border:none;cursor:pointer;
  color:var(--txt2);font-size:18px;padding:6px 8px;border-radius:50%;
  transition:color .15s;display:none;touch-action:manipulation;line-height:1;
}
.search-clear:hover,.search-clear:active{color:var(--txt)}
.search-clear.visible{display:block}
.gps-btn,.settings-btn{
  -webkit-appearance:none;flex-shrink:0;width:40px;height:40px;border-radius:50%;
  border:1px solid var(--border2);background:var(--card2);cursor:pointer;font-size:18px;color:var(--txt2);
  display:flex;align-items:center;justify-content:center;transition:all .2s;touch-action:manipulation;
}
.gps-btn:hover,.gps-btn:active,.settings-btn:hover,.settings-btn:active{border-color:var(--blue);color:var(--blue);background:rgba(49,130,206,.1)}
.gps-btn.locating{animation:pulse 1.2s infinite;color:var(--blue);border-color:var(--blue)}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(49,130,206,.4)}50%{box-shadow:0 0 0 8px rgba(49,130,206,0)}}
.autocomplete{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  background:var(--card2);border:1px solid var(--border2);border-radius:var(--r);
  overflow:hidden;-webkit-overflow-scrolling:touch;
  box-shadow:var(--shadow);display:none;z-index:200;max-height:320px;overflow-y:auto;
  transition:background .3s;
}
.autocomplete.open{display:block}
.ac-item{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--border);touch-action:manipulation;}
.ac-item:last-child{border-bottom:none}
.ac-item:hover,.ac-item:active,.ac-item.focused{background:rgba(49,130,206,.08)}
.ac-flag{font-size:20px;flex-shrink:0;width:28px;text-align:center}
.ac-name{font-size:14px;font-weight:500;color:var(--txt)}
.ac-sub{font-size:12px;color:var(--txt2);margin-top:1px}
.ac-loading{padding:14px 16px;font-size:13px;color:var(--txt2);text-align:center}
.ac-empty{padding:14px 16px;font-size:13px;color:var(--txt3);text-align:center}
.status-chip{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--txt2);background:var(--card2);border:1px solid var(--border);border-radius:99px;padding:5px 10px;white-space:nowrap;flex-shrink:0;}
@media(max-width:480px){.status-chip{display:none}}
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot.ok{background:var(--green)}.dot.loading{background:var(--yellow)}.dot.err{background:var(--red)}

/* ══ ALERT BANNER ══ */
.alert-banner{
  position:sticky;top:var(--topbar-h);z-index:90;
  background:rgba(248,113,113,0.10);
  border-bottom:1px solid rgba(248,113,113,0.25);
  color:var(--red);padding:10px 16px;font-size:13px;font-weight:500;
  display:none;align-items:center;justify-content:space-between;gap:12px;
}
.alert-banner.visible{display:flex}
.alert-banner.warning{background:rgba(247,201,72,0.10);border-color:rgba(247,201,72,0.25);color:var(--yellow);}
.alert-banner.info{background:rgba(74,168,255,0.10);border-color:rgba(74,168,255,0.25);color:var(--blue);}
.alert-banner button{
  -webkit-appearance:none;background:none;border:none;color:inherit;cursor:pointer;
  font-size:16px;padding:4px;touch-action:manipulation;opacity:.7;
}
.alert-banner button:hover{opacity:1}

/* ══ TOASTS ══ */
.toast-container{
  position:fixed;bottom:20px;right:16px;z-index:2000;
  display:flex;flex-direction:column;gap:8px;pointer-events:none;
}
.toast{
  background:var(--card2);border:1px solid var(--border2);border-radius:var(--rs);
  padding:12px 16px;font-size:13px;color:var(--txt);display:flex;align-items:center;gap:10px;
  box-shadow:0 8px 32px rgba(0,0,0,0.5);transform:translateY(20px);opacity:0;
  transition:all .3s ease;pointer-events:auto;max-width:min(320px,80vw);
}
[data-theme="light"] .toast{box-shadow:0 8px 32px rgba(0,0,0,0.15);}
.toast.show{transform:translateY(0);opacity:1}
.toast.danger{border-left:3px solid var(--red)}
.toast.warning{border-left:3px solid var(--yellow)}
.toast.info{border-left:3px solid var(--blue)}

/* ══ SETTINGS DRAWER ══ */
.settings-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:999;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.settings-overlay.open{opacity:1;pointer-events:auto}
.settings-drawer{
  position:fixed;top:0;right:0;width:min(400px,90vw);height:100vh;
  background:var(--bg2);border-left:1px solid var(--border);z-index:1000;
  transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;
}
.settings-drawer.open{transform:translateX(0)}
.settings-header{
  position:sticky;top:0;background:var(--bg2);border-bottom:1px solid var(--border);
  padding:16px;display:flex;align-items:center;justify-content:space-between;z-index:5;
}
.settings-header h3{font-size:16px;font-weight:600;color:var(--txt)}
.settings-close{
  -webkit-appearance:none;background:none;border:none;color:var(--txt2);
  font-size:20px;cursor:pointer;padding:4px;touch-action:manipulation;
}
.settings-body{padding:20px 16px 40px;display:flex;flex-direction:column;gap:20px;}
.settings-section h4{font-size:12px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
.setting-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.setting-label{font-size:13px;color:var(--txt);flex:1}
.setting-control{display:flex;align-items:center;gap:10px}
.setting-value{font-size:12px;color:var(--txt2);min-width:40px;text-align:right;font-variant-numeric:tabular-nums}
.toggle-switch{
  position:relative;width:44px;height:24px;background:var(--bg3);border-radius:12px;
  cursor:pointer;transition:background .2s;flex-shrink:0;
}
.toggle-switch.on{background:var(--green)}
.toggle-switch::after{
  content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;
  background:white;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.3);
}
.toggle-switch.on::after{transform:translateX(20px)}
input[type=range]{
  -webkit-appearance:none;width:120px;height:4px;background:var(--bg3);border-radius:2px;outline:none;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--blue);cursor:pointer;
}
.settings-btn-row{display:flex;gap:10px;margin-top:10px}
.settings-btn-row button{
  flex:1;-webkit-appearance:none;background:var(--card2);border:1px solid var(--border2);
  border-radius:var(--rs);padding:10px;font-size:13px;color:var(--txt2);cursor:pointer;transition:all .2s;
}
.settings-btn-row button.primary{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:600;}
.settings-btn-row button:hover{border-color:var(--blue);color:var(--blue)}
.settings-btn-row button.primary:hover{background:var(--blue2);border-color:var(--blue2);color:#fff}

/* ══ MAIN ══ */
.app{max-width:960px;margin:0 auto;padding:20px 16px 80px}
.loc-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(49,130,206,.08);border:1px solid rgba(49,130,206,.2);border-radius:99px;padding:6px 14px;margin-bottom:16px;max-width:100%;overflow:hidden;}
.loc-pin{font-size:15px;flex-shrink:0}
.loc-text{font-size:13px;font-weight:600;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.loc-coords{font-size:11px;color:var(--txt2);margin-left:4px;white-space:nowrap;flex-shrink:0}
@media(max-width:480px){.loc-coords{display:none}}
.hero{background:linear-gradient(140deg,var(--bg3) 0%,var(--bg4) 100%);border:1px solid var(--border2);border-radius:var(--r);padding:24px 22px 20px;margin-bottom:12px;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:-60px;right:-60px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(49,130,206,.1) 0%,transparent 65%);pointer-events:none;}
.hero::after{content:'';position:absolute;bottom:-40px;left:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(34,211,160,.06) 0%,transparent 65%);pointer-events:none;}
.hero-day-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--blue);background:rgba(49,130,206,.12);padding:3px 12px;border-radius:99px;margin-bottom:12px;letter-spacing:.05em;text-transform:uppercase;}
.hero-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.hero-num{font-size:80px;font-weight:200;line-height:1;color:var(--txt);display:flex;align-items:flex-start;gap:4px;}
.hero-num sup{font-size:24px;margin-top:12px;color:var(--txt2)}
.unit-toggle{display:flex;align-items:center;gap:2px;margin-top:-2px;}
.unit-btn{-webkit-appearance:none;background:none;border:none;cursor:pointer;font-size:20px;color:var(--txt3);padding:4px 5px;border-radius:5px;transition:color .15s;font-weight:500;touch-action:manipulation;}
.unit-btn.active{color:var(--txt)}
.unit-sep{font-size:18px;color:var(--txt3)}
.hero-cond{font-size:19px;font-weight:500;color:var(--txt);margin-top:8px}
.hero-hl{font-size:13px;color:var(--txt2);margin-top:4px}
.hero-hl b{color:var(--txt);font-weight:600}
.hero-icon-wrap{flex-shrink:0;text-align:center}
.hero-icon{font-size:80px;line-height:1;filter:drop-shadow(0 6px 18px rgba(0,0,0,.4))}
.hero-feels{font-size:12px;color:var(--txt2);margin-top:6px}
.alerts{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.abadge{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,0.05);border:1px solid var(--border2);border-radius:99px;padding:5px 13px;font-size:12px;color:var(--txt2);}
.abadge .ai{font-size:14px}
.qgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px}
@media(max-width:600px){.qgrid{grid-template-columns:repeat(2,1fr)}}
.qcard{background:var(--card);border:1px solid var(--border);border-radius:var(--rs);padding:14px;}
.ql{font-size:10px;color:var(--txt2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.qv{font-size:21px;font-weight:500;color:var(--txt)}
.qu{font-size:12px;color:var(--txt2);margin-left:2px}
.qs{font-size:11px;color:var(--txt3);margin-top:3px}
.tabs-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);margin-bottom:12px;overflow:hidden;}
.tabs-bar{display:flex;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;border-bottom:1px solid var(--border);padding:0 12px;gap:2px;}
.tabs-bar::-webkit-scrollbar{display:none}
.tab-btn{-webkit-appearance:none;flex-shrink:0;padding:12px 13px;font-size:12px;font-weight:500;color:var(--txt2);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s;white-space:nowrap;touch-action:manipulation;}
.tab-btn:hover,.tab-btn:active{color:var(--txt)}
.tab-btn.active{color:var(--blue);border-bottom-color:var(--blue)}
.tab-panel{display:none;padding:16px}
.tab-panel.active{display:block}
.leg{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:10px;font-size:11px;color:var(--txt2)}
.ldot{width:10px;height:10px;border-radius:2px;display:inline-block;margin-right:4px}
.chart-wrap{position:relative;width:100%;height:200px}
@media(max-width:480px){.chart-wrap{height:170px}}
.rnote{font-size:11px;color:var(--txt3);margin-top:8px}
.aq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:500px){.aq-grid{grid-template-columns:repeat(2,1fr)}}
.aq-cell{background:var(--bg3);border-radius:var(--rs);padding:12px}
.aq-lbl{font-size:11px;color:var(--txt2);margin-bottom:4px}
.aq-val{font-size:19px;font-weight:500}
.aq-u{font-size:11px;color:var(--txt2);margin-left:2px}
.aq-big{background:var(--bg3);border-radius:var(--rs);padding:16px;grid-column:span 3;display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
@media(max-width:500px){.aq-big{grid-column:span 2}}
.aqi-num{font-size:44px;font-weight:200;line-height:1}
.aqi-label{font-size:14px;font-weight:600}
.aqi-sub{font-size:12px;color:var(--txt2);margin-top:2px}
.aqi-bar-wrap{flex:1;min-width:140px}
.aqi-scale{display:flex;justify-content:space-between;font-size:9px;color:var(--txt3);margin-bottom:6px}
.aqi-track{height:8px;border-radius:99px;background:linear-gradient(to right,#22d3a0,#a3e635,#f7c948,#fb923c,#f87171);position:relative}
.aqi-pin{position:absolute;top:-5px;width:18px;height:18px;border-radius:50%;border:3px solid var(--bg);transform:translateX(-50%);transition:left .6s ease,background .4s}
.fc-strip{background:var(--card);border:1px solid var(--border);border-radius:var(--r);margin-bottom:12px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
.fc-strip::-webkit-scrollbar{display:none}
.fc-inner{display:flex;min-width:max-content}
.fc-day{flex:0 0 auto;min-width:100px;padding:14px 10px;border-right:1px solid var(--border);cursor:pointer;transition:background .15s,box-shadow .15s;position:relative;touch-action:manipulation;user-select:none;-webkit-user-select:none;}
.fc-day:last-child{border-right:none}
.fc-day:hover{background:var(--bg3)}
.fc-day:active{background:var(--bg4)}
.fc-day.today{background:var(--bg4)}
.fc-day.selected{background:rgba(49,130,206,.1);box-shadow:inset 0 0 0 2px rgba(49,130,206,.4);}
.fc-dn{font-size:13px;font-weight:700;color:var(--txt)}
.fc-dow{font-size:11px;color:var(--txt2);margin-bottom:8px}
.fc-ic{font-size:28px;margin-bottom:8px;line-height:1}
.fc-hi{font-size:14px;font-weight:600;color:var(--txt)}
.fc-lo{font-size:12px;color:var(--txt2);margin-top:2px}
.fc-rain{font-size:10px;color:#7ab8ff;margin-top:3px}
.fc-tag{position:absolute;top:6px;right:6px;font-size:9px;font-weight:700;color:var(--blue);background:rgba(49,130,206,.12);padding:2px 6px;border-radius:99px;}
.fc-view-tag{position:absolute;top:6px;right:6px;font-size:9px;font-weight:700;color:var(--green);background:rgba(34,211,160,.12);padding:2px 6px;border-radius:99px;}
.sec-hd{font-size:11px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:.08em;margin:22px 0 12px;display:flex;align-items:center;gap:8px;}
.sec-hd::after{content:'';flex:1;height:1px;background:var(--border)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
@media(max-width:640px){.two-col{grid-template-columns:1fr}}
.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:16px}
.ptitle{font-size:11px;font-weight:700;color:var(--txt2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}
.lrow{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.llbl{font-size:12px;color:var(--txt2);width:110px;flex-shrink:0}
.btrack{flex:1;height:9px;background:var(--bg3);border-radius:99px;overflow:hidden}
.bfill{height:100%;border-radius:99px;transition:width .5s ease}
.bval{font-size:12px;font-weight:600;color:var(--txt);width:36px;text-align:right;flex-shrink:0}
.rbox{display:flex;flex-direction:column;align-items:center;padding-top:6px}
.rring{position:relative;width:100px;height:100px}
.rring svg{width:100px;height:100px}
.rbg{fill:none;stroke:var(--bg3);stroke-width:10}
.rfg{fill:none;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset .6s ease,stroke .4s}
.rcenter{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.rpct{font-size:20px;font-weight:600;color:var(--txt);line-height:1}
.rsub{font-size:10px;color:var(--txt2);margin-top:2px}
.rlbl{font-size:12px;color:var(--txt2);margin-top:8px;text-align:center}
.rbadge{margin-top:6px;font-size:11px;font-weight:700;padding:3px 12px;border-radius:99px;letter-spacing:.05em}
.cwrap{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.donut-wrap{position:relative;flex-shrink:0;width:100px;height:100px}
.donut-wrap svg{width:100px;height:100px}
.dc{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.dtot{font-size:17px;font-weight:600;color:var(--txt)}
.dlbl{font-size:10px;color:var(--txt2)}
.cleg{flex:1;min-width:100px}
.ci{display:flex;align-items:center;gap:7px;margin-bottom:8px}
.cid{width:9px;height:9px;border-radius:3px;flex-shrink:0}
.cin{font-size:11px;color:var(--txt2);flex:1;line-height:1.4}
.cip{font-size:12px;font-weight:700;color:var(--txt)}
.divider{height:1px;background:var(--border);margin:12px 0}
.obs{padding:10px 14px;border-radius:var(--rs);font-size:12px;font-weight:500;margin-bottom:8px;border-left:3px solid}
.obs.hi{background:rgba(74,168,255,.1);color:#7ec8ff;border-color:var(--blue)}
.obs.ok{background:rgba(34,211,160,.1);color:var(--green);border-color:var(--green)}
.obs.md{background:rgba(247,201,72,.1);color:var(--yellow);border-color:var(--yellow)}
.obs.sd{background:rgba(251,146,60,.08);color:var(--orange);border-color:var(--orange);font-size:11.5px;font-weight:400}
.day-view-banner{display:none;background:rgba(49,130,206,.08);border:1px solid rgba(49,130,206,.2);border-radius:var(--rs);padding:10px 14px;margin-bottom:12px;font-size:12.5px;color:var(--txt2);align-items:center;justify-content:space-between;gap:12px;}
.day-view-banner.visible{display:flex}
.day-view-banner strong{color:var(--txt)}
.back-today-btn{-webkit-appearance:none;background:rgba(49,130,206,.12);border:1px solid rgba(49,130,206,.25);border-radius:99px;padding:5px 13px;font-size:12px;color:var(--blue);cursor:pointer;white-space:nowrap;flex-shrink:0;touch-action:manipulation;transition:all .15s;}
.back-today-btn:hover,.back-today-btn:active{background:rgba(49,130,206,.22)}
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:14px;padding:20px;background:radial-gradient(ellipse at 50% 0%, rgba(20,60,120,.12) 0%, transparent 60%),radial-gradient(ellipse at center, rgba(10,14,23,0) 0%, var(--bg) 70%);padding-top:8vh;}
@media(max-width:480px){.empty{padding-top:4vh}}
.empty-title{font-size:20px;font-weight:600;color:var(--txt)}
.empty-sub{font-size:14px;color:var(--txt2);max-width:300px;line-height:1.6}
.empty-hint{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap;justify-content:center;}
.hint-btn{-webkit-appearance:none;background:var(--card2);border:1px solid var(--border2);border-radius:99px;padding:8px 15px;font-size:13px;color:var(--txt2);cursor:pointer;transition:all .2s;touch-action:manipulation;}
.hint-btn:hover,.hint-btn:active{border-color:var(--blue);color:var(--blue)}
@media(max-width:480px){.hero-num{font-size:62px}.hero-icon{font-size:62px}.topbar-inner{gap:8px}.hero{padding:18px 16px 16px}}
@media(max-width:360px){.hero-num{font-size:52px}.hero-icon{font-size:52px}}

/* ══ Globe ══ */
#globe-container{
  width:min(340px,85vw);height:min(340px,85vw);max-width:380px;max-height:380px;
  margin:0 auto;position:relative;touch-action:none;
  -webkit-touch-callout:none;-webkit-user-select:none;user-select:none;
  border-radius:50%;overflow:hidden;
  box-shadow:0 0 80px rgba(49,130,206,.15),0 0 160px rgba(49,130,206,.06),0 24px 80px rgba(0,0,0,.4),inset 0 0 60px rgba(0,0,0,.25);
}
[data-theme="light"] #globe-container{
  box-shadow:0 0 60px rgba(49,130,206,.10),0 0 120px rgba(49,130,206,.04),0 16px 48px rgba(0,0,0,.15),inset 0 0 40px rgba(0,0,0,.08);
}
#globe-container canvas{display:block;width:100% !important;height:100% !important;border-radius:50%;outline:none;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;}
#globe-container canvas:active{cursor:grabbing}
@media(max-width:480px){#globe-container{width:min(300px,80vw);height:min(300px,80vw)}}
@media(max-width:360px){#globe-container{width:min(260px,75vw);height:min(260px,75vw)}}

/* ══ Globe hint ══ */
.globe-hint{font-size:12px;color:var(--txt2);margin-top:14px;text-align:center;letter-spacing:.04em;line-height:1.6;min-height:38px;}
.globe-hint span{color:var(--blue);font-weight:600}
.globe-hint .dot{display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--blue);margin:0 6px;vertical-align:middle;opacity:.6}

/* ══════════════════════════════════════════════
   PLACE NAME CARD
══════════════════════════════════════════════ */
#globe-place-card{
  position:relative;margin:12px auto 0;max-width:min(340px,90vw);
  background:var(--card2);border:1px solid var(--border2);border-radius:14px;
  padding:14px 18px;display:flex;align-items:center;gap:14px;
  opacity:0;transform:translateY(10px) scale(0.97);
  transition:opacity .35s ease, transform .35s ease;
  pointer-events:none;overflow:hidden;
}
#globe-place-card.visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto;}
#globe-place-card.loading::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(49,130,206,.07) 50%,transparent 100%);
  background-size:200% 100%;animation:shimmer 1.4s infinite;
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
#globe-place-card.resolved{
  border-color:rgba(49,130,206,.4);
  box-shadow:0 0 0 1px rgba(49,130,206,.15), 0 8px 32px rgba(0,0,0,.35);
}
[data-theme="light"] #globe-place-card.resolved{
  box-shadow:0 0 0 1px rgba(49,130,206,.15), 0 8px 32px rgba(0,0,0,.12);
}
.gpc-pin{
  width:40px;height:40px;border-radius:50%;background:rgba(49,130,206,.12);
  border:1px solid rgba(49,130,206,.25);display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;transition:background .3s;
}
#globe-place-card.resolved .gpc-pin{background:rgba(34,211,160,.12);border-color:rgba(34,211,160,.3);}
.gpc-body{flex:1;min-width:0;}
.gpc-coords{font-size:11px;color:var(--txt3);margin-bottom:3px;font-variant-numeric:tabular-nums;transition:color .3s;}
#globe-place-card.resolved .gpc-coords{color:var(--txt2)}
.gpc-name{font-size:17px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:24px;}
.gpc-country{font-size:12px;color:var(--txt2);margin-top:2px;min-height:16px;}
.gpc-status{
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--txt3);margin-top:5px;display:flex;align-items:center;gap:5px;
  transition:color .3s;
}
#globe-place-card.resolved .gpc-status{color:var(--green)}
.gpc-pulse{
  width:6px;height:6px;border-radius:50%;background:var(--txt3);
  animation:gpc-blink 1s infinite;transition:background .3s;flex-shrink:0;
}
@keyframes gpc-blink{0%,100%{opacity:1}50%{opacity:.25}}
#globe-place-card.resolved .gpc-pulse{background:var(--green);animation:none;opacity:1;}
.gpc-load-btn{
  -webkit-appearance:none;background:rgba(49,130,206,.12);border:1px solid rgba(49,130,206,.25);
  border-radius:99px;padding:7px 16px;font-size:12px;font-weight:600;color:var(--blue);
  cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .2s;display:none;touch-action:manipulation;
}
#globe-place-card.resolved .gpc-load-btn{display:block}
.gpc-load-btn:hover,.gpc-load-btn:active{background:rgba(49,130,206,.22);border-color:rgba(49,130,206,.5)}

/* ══ Science extras ══ */
.science-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:12px}
@media(max-width:500px){.science-grid{grid-template-columns:1fr}}
.science-cell{background:var(--bg3);border-radius:var(--rs);padding:12px;display:flex;flex-direction:column;gap:4px}
.science-lbl{font-size:10px;color:var(--txt2);text-transform:uppercase;letter-spacing:.06em}
.science-val{font-size:18px;font-weight:600;color:var(--txt)}
.science-sub{font-size:11px;color:var(--txt3)}
.science-severe{display:flex;align-items:center;gap:8px;margin-top:2px}
.severe-bar{flex:1;height:6px;background:var(--bg4);border-radius:99px;overflow:hidden}
.severe-fill{height:100%;border-radius:99px;transition:width .5s ease}
.severe-text{font-size:11px;font-weight:700}
.spaghetti-wrap{margin-top:10px}
.spaghetti-label{font-size:10px;color:var(--txt2);margin-bottom:4px;display:flex;justify-content:space-between}
.spaghetti-bar{display:flex;height:10px;border-radius:5px;overflow:hidden;gap:1px;background:var(--bg3)}
.spaghetti-seg{flex:1;height:100%;transition:background .2s}
.pollen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}
@media(max-width:500px){.pollen-grid{grid-template-columns:repeat(2,1fr)}}
.pollen-cell{background:var(--bg3);border-radius:var(--rs);padding:10px;text-align:center}
.pollen-name{font-size:10px;color:var(--txt2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.pollen-val{font-size:16px;font-weight:600;color:var(--txt)}
.pollen-level{font-size:10px;margin-top:2px;font-weight:500}

/* Hidden sections */
.section-hidden{display:none !important}
