/* ============================================================
   kumaphone.com — /map/  hi-fi
   "Companion on the ancient trail"
   Theme: #081174 (deep indigo, main) + shades · #FF7700 (orange accent)
   Map engine: Leaflet + GSI raster tiles
   ============================================================ */

:root{
  /* main — indigo shades */
  --navy:#081174;
  --navy-deep:#050b4d;
  --navy-2:#1b2486;
  --navy-3:#3a429d;
  --navy-soft:#6a72c0;
  --navy-faint:#e7e9f5;
  --navy-mist:#f2f3fa;

  /* accent — orange */
  --accent:#ff7700;
  --accent-deep:#e06600;
  --accent-soft:#ff9a40;
  --accent-faint:#fff1e4;

  /* neutrals */
  --paper:#f6f7fb;
  --paper-2:#eceef6;
  --ink:#161a3a;
  --ink-soft:#5a608a;
  --line:#d9dcec;
  --line-2:#c2c6df;
  --cream:#f1f2f9;

  /* route colors (indigo family + orange accent) */
  --r-naka:#ff7700;
  --r-kohe:#081174;
  --r-ohe:#4a9bd4;
  --r-kii:#8a6fc4;
  --r-ise:#c04000;
  --r-omine:#2a6b2a;

  --shadow-card:0 18px 40px -22px rgba(8,17,116,.45);
  --shadow-float:0 8px 22px -12px rgba(8,17,116,.4);

  --sans:"Hanken Grotesk","Noto Sans JP",system-ui,sans-serif;
  --serif:"Spectral","Noto Serif JP",Georgia,serif;
  --mono:"SF Mono",ui-monospace,"Roboto Mono",Menlo,monospace;

  --nav-h:64px;
}
:root[lang="ja"]{ --sans:"Noto Sans JP","Hanken Grotesk",system-ui,sans-serif; --serif:"Noto Serif JP","Spectral",serif; }

*{box-sizing:border-box;}
html,body{height:100%;margin:0;}
body{
  font-family:var(--sans);color:var(--ink);background:var(--navy-deep);
  overflow:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
button{font-family:inherit;cursor:pointer;}

/* ---------------- map ---------------- */
#map{position:fixed;inset:0;background:#e7eaf2;z-index:0;}
.leaflet-container{font-family:var(--sans);background:#e7eaf2;}
.leaflet-control-attribution{font-family:var(--sans);font-size:10px;background:rgba(246,247,251,.8)!important;}
.leaflet-tile-pane{filter:saturate(.82) contrast(.97);}
.leaflet-bar a{color:var(--navy)!important;border-color:var(--line)!important;}
.leaflet-bar a:hover{background:var(--navy-mist)!important;}

/* subtle vignette so floating chrome reads */
#map::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:401;
  box-shadow:inset 0 90px 70px -60px rgba(8,17,76,.5), inset 0 -120px 90px -80px rgba(8,17,76,.3);}

/* ---------------- top nav ---------------- */
.chrome{position:fixed;top:0;left:0;right:0;z-index:500;height:var(--nav-h);
  display:flex;align-items:center;gap:22px;padding:0 22px;
  background:linear-gradient(180deg,rgba(8,17,76,.94) 0%,rgba(8,17,76,.55) 55%,rgba(8,17,76,0) 100%);
}
.logo{display:flex;align-items:center;color:#fff;text-decoration:none;white-space:nowrap;}
.logo-img{height:44px;width:auto;display:block;object-fit:contain;}
.logo-img-drawer{height:54px;}

.nav-links{display:flex;align-items:center;gap:4px;}
.nav-links a{color:rgba(255,255,255,.82);text-decoration:none;font-size:14px;font-weight:500;
  padding:8px 12px;border-radius:8px;transition:background .15s,color .15s;}
.nav-links a:hover{background:rgba(255,255,255,.12);color:#fff;}
.nav-links a.on{color:#fff;}
.nav-links a.on::after{content:"";display:block;height:2px;border-radius:2px;background:var(--accent);margin:5px 6px -1px;}

.chrome .spacer{flex:1;}

.lang{display:inline-flex;border:1px solid rgba(255,255,255,.4);border-radius:9px;overflow:hidden;
  font-family:var(--mono);font-size:11px;background:rgba(8,17,76,.3);backdrop-filter:blur(4px);}
.lang button{background:transparent;border:none;color:rgba(255,255,255,.72);padding:8px 11px;font-family:inherit;font-size:11px;letter-spacing:.04em;}
.lang button.on{background:#fff;color:var(--navy);font-weight:600;}

.cta{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border:none;border-radius:9px;font-size:14px;font-weight:600;
  padding:10px 16px;white-space:nowrap;box-shadow:0 6px 16px -8px rgba(255,119,0,.85);transition:transform .12s,background .15s;}
.cta:hover{background:var(--accent-deep);transform:translateY(-1px);}
.cta .ph{font-size:13px;}

.burger{display:none;width:42px;height:42px;border-radius:10px;border:1px solid rgba(255,255,255,.4);
  background:rgba(8,17,76,.3);backdrop-filter:blur(4px);flex-direction:column;justify-content:center;align-items:center;gap:4px;}
.burger i{width:18px;height:2px;background:#fff;border-radius:2px;}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:900;display:none;}
.drawer.open{display:block;}
.drawer .scrim{position:absolute;inset:0;background:rgba(5,11,40,.55);backdrop-filter:blur(2px);}
.drawer .sheet{position:absolute;top:0;right:0;bottom:0;width:min(82vw,340px);background:var(--navy);
  padding:18px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-card);
  transform:translateX(100%);transition:transform .28s cubic-bezier(.4,0,.2,1);overflow-y:auto;}
.drawer.open .sheet{transform:none;}
.drawer .sheet .dhead{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.drawer .sheet .x{width:38px;height:38px;border-radius:9px;border:1px solid rgba(255,255,255,.3);background:transparent;color:#fff;font-size:18px;}
.drawer .sheet a{color:#fff;text-decoration:none;font-family:var(--sans);font-size:22px;font-weight:500;padding:11px 4px;border-bottom:1px solid rgba(255,255,255,.12);}
.drawer .sheet a .sub{display:block;font-family:var(--mono);font-size:10px;color:var(--accent-soft);letter-spacing:.1em;text-transform:uppercase;margin-top:2px;}
.drawer .sheet .cta{margin-top:18px;justify-content:center;padding:14px;font-size:16px;}

/* ---------------- floating controls ---------------- */
.panel{background:rgba(246,247,251,.97);backdrop-filter:blur(8px);border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow-card);}

/* ---------------- desktop layers button + dropdown ---------------- */
.layers-btn{display:none;position:fixed;left:22px;top:calc(var(--nav-h) + 14px);z-index:486;
  align-items:center;gap:8px;background:rgba(246,247,251,.97);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:11px;padding:9px 14px;
  font-size:13px;font-weight:600;color:var(--navy);box-shadow:var(--shadow-float);
  transition:background .15s;}
.layers-btn:hover{background:#fff;}
.layers-btn svg{width:18px;height:18px;flex:none;color:var(--navy);}
.layers-btn.on{background:var(--navy);color:#fff;border-color:var(--navy);}
.layers-btn.on svg{color:#fff;}

/* layers panel (desktop: dropdown below the button) */
.layers{position:fixed;left:22px;top:calc(var(--nav-h) + 62px);z-index:485;width:236px;padding:6px;
  opacity:0;pointer-events:none;transform:translateY(-6px);
  transition:opacity .22s,transform .22s;}
.layers.open{opacity:1;pointer-events:auto;transform:none;}
.layers .lhead{display:flex;align-items:center;justify-content:space-between;padding:10px 12px 8px;}
.layers .lhead h2{margin:0;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);}
.layers .lhead .min{display:none;border:none;background:transparent;color:var(--ink-soft);font-size:15px;}
.lyr{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;}
.lyr:hover{background:var(--navy-mist);}
.lyr .ic{width:26px;height:26px;border-radius:7px;background:var(--paper-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--navy);flex:none;}
.lyr .ic svg{width:15px;height:15px;}
.lyr .nm{flex:1;font-size:13.5px;font-weight:500;color:var(--ink);}
.tg{width:38px;height:22px;border-radius:12px;background:var(--accent);position:relative;flex:none;
  border:none;padding:0;transition:background .18s;}
.tg.off{background:var(--line-2);}
.tg::after{content:"";position:absolute;top:2.5px;width:17px;height:17px;border-radius:50%;background:#fff;right:2.5px;
  box-shadow:0 1px 3px rgba(0,0,0,.3);transition:all .18s;}
.tg.off::after{right:auto;left:2.5px;}

.routekey{padding:4px 12px 10px;display:grid;gap:7px;
  max-height:140px;overflow:hidden;transition:max-height .25s,opacity .2s,padding .2s;}
.routekey.hide{max-height:0;opacity:0;padding-top:0;padding-bottom:0;pointer-events:none;}
.rk{display:flex;align-items:center;gap:10px;background:none;border:none;padding:2px 0;text-align:left;width:100%;cursor:default;}
.rk i{width:22px;height:4px;border-radius:3px;flex:none;}
.rk .rn{font-size:12.5px;color:var(--ink);font-weight:500;}
.rk .rj{font-size:11px;color:var(--ink-soft);margin-left:auto;font-family:var(--mono);}

.divider{height:1px;background:var(--line);margin:4px 10px;}

/* FABs (mobile) */
.fabs{position:fixed;right:16px;bottom:calc(env(safe-area-inset-bottom,0px) + 92px);z-index:480;
  display:none;flex-direction:column;gap:11px;}
.fab{width:50px;height:50px;border-radius:14px;background:rgba(246,247,251,.98);border:1px solid var(--line);
  box-shadow:var(--shadow-float);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--navy);}
.fab svg{width:20px;height:20px;}
.fab .fl{font-family:var(--mono);font-size:7px;letter-spacing:.06em;color:var(--ink-soft);text-transform:uppercase;}
.fab.live{position:relative;}
.fab.live .pulse{position:absolute;top:7px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 0 0 rgba(255,119,0,.6);animation:pulse 2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,119,0,.55);}70%{box-shadow:0 0 0 8px rgba(255,119,0,0);}100%{box-shadow:0 0 0 0 rgba(255,119,0,0);}}

/* ---------------- detail surface (rail / sheet) ---------------- */
.detail{position:fixed;z-index:600;background:var(--paper);box-shadow:var(--shadow-card);}
/* desktop: right rail */
.detail{top:0;right:0;bottom:0;width:376px;border-left:1px solid var(--line);
  transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;}
.detail.open{transform:none;}

.detail .dclose{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:9px;border:1px solid var(--line);
  background:rgba(255,255,255,.8);color:var(--ink-soft);font-size:16px;z-index:5;}
.detail .grab{display:none;}

.detail-scroll{overflow-y:auto;padding:0;flex:1;}
.detail-hero{height:150px;background:var(--paper-2);position:relative;overflow:hidden;
  display:grid;place-items:center;border-bottom:1px solid var(--line);}
.detail-hero .ph{font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:rgba(255,255,255,.9);text-transform:uppercase;z-index:1;text-shadow:0 1px 4px rgba(0,0,0,.35);}
.detail-hero .gr{position:absolute;inset:0;background:
  linear-gradient(135deg,rgba(8,17,116,.35),rgba(255,119,0,.28)),
  repeating-linear-gradient(48deg,rgba(255,255,255,.05) 0 11px,transparent 11px 22px);}

.detail-body{padding:20px 22px 28px;display:flex;flex-direction:column;gap:16px;}
.eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-deep);}
.detail-body h3{font-family:var(--sans);font-size:24px;font-weight:600;margin:0;letter-spacing:-.01em;line-height:1.12;color:var(--navy);}
.routebadge{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-soft);}
.routebadge i{width:18px;height:4px;border-radius:3px;background:var(--r-naka);}

.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;}
.stat{background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 12px;}
.stat .k{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);}
.stat .v{font-family:var(--sans);font-size:21px;font-weight:600;color:var(--navy);margin-top:4px;line-height:1;}
.stat .v small{font-family:var(--sans);font-size:11px;font-weight:500;color:var(--ink-soft);}

.chart-wrap{background:#fff;border:1px solid var(--line);border-radius:11px;padding:12px 12px 8px;}
.chart-wrap .ct{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px;}
.chart-wrap .ct .k{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);}
.chart-wrap .ct .rng{font-size:11px;color:var(--ink-soft);}
.elev{width:100%;height:84px;display:block;}

.signal{display:flex;gap:12px;align-items:flex-start;background:linear-gradient(120deg,var(--accent-faint),rgba(255,119,0,.04));
  border:1px solid rgba(255,119,0,.32);border-radius:12px;padding:13px 14px;}
.signal .si{width:30px;height:30px;border-radius:8px;background:rgba(255,119,0,.14);display:grid;place-items:center;color:var(--accent-deep);flex:none;}
.signal .si svg{width:17px;height:17px;}
.signal .st{font-size:12.5px;line-height:1.55;color:#8a4a12;}
.signal .st b{display:block;color:var(--accent-deep);font-size:13px;margin-bottom:3px;}
.signal .kp{display:inline-flex;align-items:center;gap:5px;margin-top:9px;font-weight:600;color:#fff;background:var(--accent);
  border:none;border-radius:8px;padding:8px 12px;font-size:12px;text-decoration:none;}
.signal .kp:hover{background:var(--accent-deep);}

.detail .ghost{display:flex;align-items:center;justify-content:center;gap:7px;border:1.5px solid var(--navy);color:var(--navy);
  background:var(--navy-mist);border-radius:10px;padding:12px;font-size:13.5px;font-weight:600;text-decoration:none;}
.detail .ghost:hover{background:var(--navy-faint);}

/* ---------------- condition popup (Leaflet) ---------------- */
.leaflet-popup{z-index:550;}
.leaflet-popup-content-wrapper{padding:0;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-card);
  border:1px solid var(--line);background:var(--paper);}
.leaflet-popup-content{margin:0;width:248px!important;font-family:var(--sans);}
.leaflet-popup-tip{background:var(--paper);box-shadow:var(--shadow-card);}
.leaflet-popup-close-button{font-size:20px!important;color:#fff!important;right:6px!important;top:5px!important;z-index:3;text-shadow:0 1px 3px rgba(0,0,0,.5);width:auto!important;height:auto!important;}
.cpop .cimg{height:118px;background:var(--paper-2);position:relative;display:grid;place-items:center;}
.cpop .cimg .gr{position:absolute;inset:0;}
.cpop .cimg .ph{font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:rgba(255,255,255,.85);text-transform:uppercase;z-index:1;text-shadow:0 1px 4px rgba(0,0,0,.4);}
.cpop .ctag{position:absolute;left:11px;top:11px;z-index:2;font-family:var(--mono);font-size:8.5px;letter-spacing:.07em;text-transform:uppercase;
  color:#fff;border-radius:20px;padding:4px 9px;backdrop-filter:blur(3px);}
.cpop .cbody{padding:12px 14px 14px;}
.cpop .cwho{display:flex;align-items:center;gap:9px;margin-bottom:9px;}
.cpop .cav{width:30px;height:30px;border-radius:50%;flex:none;background:linear-gradient(140deg,var(--navy-soft),var(--navy));border:1.5px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.cpop .cnm{font-size:12.5px;font-weight:600;color:var(--navy);line-height:1.15;}
.cpop .crl{font-family:var(--mono);font-size:9.5px;color:var(--accent-deep);margin-top:1px;}
.cpop .ctx{font-size:12.5px;line-height:1.55;color:#3a3f63;margin:0;}
.cpop .cmeta{display:flex;align-items:center;gap:6px;margin-top:10px;font-family:var(--mono);font-size:9.5px;color:var(--ink-soft);}
.cpop .cmeta svg{width:11px;height:11px;}

/* HTML markers (divIcon) */
.mk-cond{position:relative;}
.mk-cond .body{width:26px;height:26px;border-radius:50% 50% 50% 3px;transform:rotate(45deg);
  border:2.5px solid #fff;box-shadow:var(--shadow-float);display:grid;place-items:center;}
.mk-cond .body span{transform:rotate(-45deg);font-size:12px;line-height:1;}
.mk-cond::after{content:"";position:absolute;left:50%;bottom:-3px;transform:translateX(-50%);width:10px;height:4px;border-radius:50%;background:rgba(0,0,0,.22);filter:blur(1px);}
.mk-cond.sel .body{transform:rotate(45deg) scale(1.14);box-shadow:0 10px 22px -8px rgba(8,17,76,.7);}
.mk-oji{width:26px;height:26px;border-radius:50%;background:rgba(246,247,251,.98);border:2px solid var(--navy);
  display:grid;place-items:center;color:var(--navy);box-shadow:var(--shadow-float);}
/* FA icon inside condition diamond marker */
.mk-cond .body i{
  transform:rotate(-45deg);font-size:10px;color:#fff;
  display:flex;align-items:center;justify-content:center;
}
/* FA icon inside oji marker */
.mk-oji i{font-size:13px;color:var(--navy);}
/* ---------------- town milestone markers ---------------- */
.mk-town{position:relative;display:flex;align-items:center;gap:8px;pointer-events:none;}
.mk-town-dot{width:11px;height:11px;border-radius:50%;background:var(--accent);border:2.5px solid #fff;
  box-shadow:0 2px 6px -1px rgba(255,119,0,.6);flex:none;}
.mk-town.sanzan .mk-town-dot{background:var(--navy);border-color:#fff;box-shadow:0 2px 6px -1px rgba(8,17,76,.5);}
.mk-town.first .mk-town-dot,.mk-town.last .mk-town-dot{width:13px;height:13px;border-width:3px;}
.mk-town-label{display:flex;flex-direction:column;white-space:nowrap;}
.mk-town-name{font-family:var(--sans);font-size:11.5px;font-weight:700;color:var(--navy);
  text-shadow:0 1px 3px rgba(255,255,255,.95),0 0 6px rgba(255,255,255,.8);line-height:1.2;}
.mk-town-role{font-family:var(--mono);font-size:9px;color:var(--ink-soft);letter-spacing:.06em;
  text-shadow:0 1px 3px rgba(255,255,255,.9);}

/* ---------------- sanzan shrine markers ---------------- */
.mk-sanzan{position:relative;display:flex;align-items:flex-start;gap:9px;pointer-events:none;}
.mk-sanzan-ring{width:30px;height:30px;border-radius:50%;background:var(--navy);border:2.5px solid #fff;
  display:grid;place-items:center;flex:none;
  box-shadow:0 3px 10px -3px rgba(8,17,76,.7),0 0 0 3px rgba(8,17,76,.18);}
.mk-sanzan-ring i{font-size:13px;color:#fff;}
.mk-sanzan-label{display:flex;flex-direction:column;margin-top:4px;white-space:nowrap;}
.mk-sanzan-name{font-family:var(--sans);font-size:12.5px;font-weight:600;color:var(--navy);
  text-shadow:0 1px 4px rgba(255,255,255,.98),0 0 8px rgba(255,255,255,.85);line-height:1.2;}
.mk-sanzan-sub{font-family:var(--mono);font-size:9px;color:var(--ink-soft);letter-spacing:.06em;
  text-shadow:0 1px 3px rgba(255,255,255,.9);}

.fac-toilet,.fac-bus{width:14px;height:14px;border-radius:50%;border:2px solid #fff;box-shadow:0 1px 4px rgba(0,0,0,.35);}
.fac-toilet{background:var(--navy-soft);}
.fac-bus{background:var(--r-ohe);}

/* ---------------- weather widget ---------------- */
.wx{position:fixed;right:22px;top:calc(var(--nav-h) + 16px);z-index:485;width:278px;padding:0;overflow:hidden;}
.wx-head{display:flex;align-items:center;gap:10px;padding:12px 14px;}
.wx-loc{display:inline-flex;align-items:center;gap:4px;border:none;background:transparent;font-family:var(--sans);
  font-size:16px;font-weight:600;color:var(--navy);padding:2px 0;}
.wx-loc svg{color:var(--ink-soft);margin-top:1px;}
.wx-now{margin-left:auto;display:flex;align-items:center;gap:7px;}
.wx-ic{color:var(--accent-deep);display:flex;}
.wx-ic svg{width:24px;height:24px;}
.wx-temp{font-family:var(--sans);font-size:24px;font-weight:600;color:var(--navy);line-height:1;}
.wx-exp{display:none;border:none;background:transparent;color:var(--ink-soft);padding:2px;transition:transform .25s;}
.wx.open .wx-exp{transform:rotate(180deg);}
.wx-skel{margin-left:auto;width:60px;height:24px;border-radius:7px;background:linear-gradient(90deg,var(--paper-2),#fff,var(--paper-2));background-size:200% 100%;animation:sk 1.2s infinite;}
@keyframes sk{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
.wx-loadtxt{padding:0 14px 14px;font-size:12px;color:var(--ink-soft);font-family:var(--mono);}

.wx-menu{display:none;flex-direction:column;padding:4px 8px 8px;gap:2px;border-top:1px solid var(--line);}
.wx-menu.open{display:flex;}
.wx-mi{text-align:left;border:none;background:transparent;font-size:13.5px;color:var(--ink);padding:8px 8px;border-radius:8px;font-family:var(--sans);}
.wx-mi:hover{background:var(--navy-mist);}
.wx-mi.on{color:var(--accent-deep);font-weight:600;background:var(--accent-faint);}

.wx-body{border-top:1px solid var(--line);padding:12px 14px 12px;}
.wx-cond{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:10px;}
.wx-cond span:first-child{font-size:13.5px;font-weight:600;color:var(--ink);}
.wx-feels{font-family:var(--mono);font-size:10.5px;color:var(--ink-soft);}
.wx-alert{display:flex;align-items:center;gap:6px;background:rgba(74,155,212,.12);border:1px solid rgba(74,155,212,.35);
  color:#1f5b80;border-radius:9px;padding:7px 10px;font-size:11.5px;font-weight:500;margin-bottom:11px;}
.wx-alert .tiny{width:14px;height:14px;color:#3f6d8a;}
.wx-fc-lab{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:7px;}
.wx-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:12px;}
.wx-day{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 0;border-radius:8px;}
.wx-day.on{background:var(--navy-mist);}
.wx-day .wd{font-family:var(--mono);font-size:9px;color:var(--ink-soft);text-transform:uppercase;}
.wx-day .wi{color:var(--navy);}
.wx-day .wi svg{width:18px;height:18px;}
.wx-day .wp{font-size:9px;font-family:var(--mono);color:var(--navy-soft);}
.wx-day .wp.hi{color:var(--r-ohe);font-weight:600;}
.wx-day .wt{font-size:9.5px;text-align:center;line-height:1.25;}
.wx-day .wt b{font-weight:600;color:var(--ink);}
.wx-day .wt s{display:block;text-decoration:none;color:var(--ink-soft);}

.wx-radar{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;
  border:1.5px solid var(--accent);background:var(--accent-faint);color:var(--accent-deep);
  border-radius:10px;padding:10px 12px;font-size:13px;font-weight:600;}
.wx-radar.on{background:var(--accent);color:#fff;border-color:var(--accent);}
.wx-radar-l{display:inline-flex;align-items:center;gap:8px;}
.wx-radar-l svg{width:16px;height:16px;}
.wx-sw{width:34px;height:20px;border-radius:11px;background:#fff;position:relative;flex:none;border:1px solid var(--accent);}
.wx-sw::after{content:"";position:absolute;top:2px;width:14px;height:14px;border-radius:50%;background:var(--accent);right:2px;transition:all .18s;}
.wx-sw.off{background:rgba(255,119,0,.18);}
.wx-sw.off::after{right:auto;left:2px;background:var(--accent-soft);}
.wx-radar.on .wx-sw{border-color:#fff;}

.wx-foot{display:flex;align-items:center;justify-content:space-between;margin-top:10px;font-family:var(--mono);font-size:9px;color:var(--ink-soft);}
.wx-src.live{color:#1e8e4a;}
.wx-src.sample{color:var(--ink-soft);}

/* ---------------- rain radar timeline ---------------- */
.radar{position:fixed;left:50%;transform:translateX(-50%) translateY(14px);bottom:24px;z-index:470;
  width:min(540px,calc(100vw - 44px));background:rgba(8,17,76,.93);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:11px 14px 10px;color:#fff;
  box-shadow:var(--shadow-card);opacity:0;pointer-events:none;transition:opacity .28s,transform .28s;}
.radar.show{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);}
.radar-row{display:flex;align-items:center;gap:13px;}
.radar-play{width:38px;height:38px;flex:none;border-radius:50%;border:none;background:var(--accent);color:#fff;
  display:grid;place-items:center;box-shadow:0 4px 12px -4px rgba(255,119,0,.8);}
.radar-play:hover{background:var(--accent-deep);}
.radar-track{position:relative;flex:1;display:flex;align-items:center;}
.radar-slider{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:4px;outline:none;
  background:linear-gradient(90deg,rgba(255,255,255,.35) 0 var(--nowpct,80%),rgba(255,119,0,.55) var(--nowpct,80%) 100%);}
.radar-slider::-webkit-slider-thumb{-webkit-appearance:none;width:17px;height:17px;border-radius:50%;background:#fff;
  border:3px solid var(--accent);cursor:pointer;box-shadow:0 2px 5px rgba(0,0,0,.4);}
.radar-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--accent);cursor:pointer;}
.radar-nowtick{position:absolute;top:-4px;width:2px;height:13px;background:rgba(255,255,255,.7);border-radius:2px;transform:translateX(-1px);pointer-events:none;}
.radar-time{flex:none;text-align:right;min-width:74px;display:flex;flex-direction:column;gap:1px;}
.radar-time b{font-family:var(--mono);font-size:15px;font-weight:600;line-height:1;}
.radar-time span{font-family:var(--mono);font-size:9px;color:rgba(255,255,255,.7);letter-spacing:.04em;}
.radar-time span.fc{color:var(--accent-soft);}

.radar-legend{display:flex;align-items:center;gap:8px;margin-top:9px;padding-top:9px;border-top:1px solid rgba(255,255,255,.12);}
.radar-legend .rl-cap{font-family:var(--mono);font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6);}
.radar-legend .rl-lab{font-family:var(--mono);font-size:9px;color:rgba(255,255,255,.8);}
.radar-legend .rl-bar{flex:1;height:7px;border-radius:4px;
  background:linear-gradient(90deg,#cfe7ff,#7cc0ff,#3f8df0,#1f54d6,#6a2fc4);}
.radar-legend .rl-src{font-family:var(--mono);font-size:8.5px;color:rgba(255,255,255,.45);}
.radar-nodata{display:flex;align-items:center;gap:9px;font-size:12.5px;color:rgba(255,255,255,.92);}
.radar-nodata svg{color:var(--accent-soft);flex:none;}

/* ---------------- status pill ---------------- */
.statuspill{position:fixed;left:50%;transform:translateX(-50%);top:calc(var(--nav-h) + 12px);z-index:560;
  display:flex;align-items:center;gap:9px;background:rgba(8,17,76,.94);backdrop-filter:blur(6px);
  color:#fff;border-radius:30px;padding:9px 16px 9px 12px;font-size:12.5px;box-shadow:var(--shadow-card);
  transition:opacity .3s,transform .3s;}
.statuspill .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(255,119,0,.6);animation:pulse 2s infinite;}
.statuspill b{font-weight:600;}
.statuspill .x{margin-left:4px;border:none;background:transparent;color:rgba(255,255,255,.6);font-size:15px;}

  .layers-btn{display:flex;}
  .layers{display:block;}
.loader{position:fixed;inset:0;z-index:1000;background:var(--navy-deep);display:grid;place-items:center;transition:opacity .5s;}
.loader.hide{opacity:0;pointer-events:none;}
.loader .l{display:flex;flex-direction:column;align-items:center;gap:16px;color:#fff;}
.loader .ring{width:34px;height:34px;border-radius:50%;border:3px solid rgba(255,255,255,.2);border-top-color:var(--accent);animation:spin 1s linear infinite;}
.loader .lt{font-family:var(--sans);font-size:17px;letter-spacing:.02em;}
.loader .ls{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-soft);}
@keyframes spin{to{transform:rotate(360deg);}}

/* ---------------- responsive ---------------- */
@media (max-width:920px){
  .nav-links{display:none;}
  .chrome .cta{display:none;}
  .burger{display:flex;}
  .layers-btn{display:none !important;}
  .layers{display:none;opacity:0;pointer-events:none;}
  .fabs{display:flex;}

  .detail{top:auto;left:0;right:0;bottom:0;width:auto;max-height:78vh;border-left:none;border-top:1px solid var(--line);
    border-radius:20px 20px 0 0;transform:translateY(100%);}
  .detail.open{transform:none;}
  .detail.peek{transform:translateY(calc(100% - 134px));}
  .detail .dclose{display:none;}
  .detail .grab{display:block;width:44px;height:5px;border-radius:3px;background:var(--line-2);margin:9px auto 2px;flex:none;}
  .detail-hero{height:120px;}
  .statuspill{bottom:auto;top:calc(var(--nav-h) + 12px);left:14px;right:auto;transform:none;font-size:11.5px;padding:7px 12px 7px 10px;}
  .statuspill .x{display:none;}

  /* weather widget: compact, collapsible */
  .wx{right:12px;top:calc(var(--nav-h) + 10px);width:auto;min-width:128px;max-width:calc(100vw - 24px);}
  .wx-exp{display:block;}
  .wx-body{display:none;}
  .wx.open{width:300px;max-width:calc(100vw - 24px);}
  .wx.open .wx-body{display:block;}
  .wx-head{padding:10px 12px;}
  .wx-loc{font-size:14px;}
  .wx-temp{font-size:20px;}

  /* radar timeline: full-width bottom */
  .radar{left:12px;right:12px;width:auto;transform:translateY(14px);
    bottom:calc(env(safe-area-inset-bottom,0px) + 16px);}
  .radar.show{transform:translateY(0);}

  .layers.assheet{display:block;position:fixed;left:0;right:0;bottom:0;top:auto;width:auto;
    border-radius:20px 20px 0 0;padding:8px 8px 24px;transform:translateY(100%);transition:transform .3s;z-index:920;}
  .layers.assheet.open{transform:none;}
  .layers.assheet .lhead{padding:14px 14px 10px;}
  .layers.assheet .lhead .min{display:block;}
  .layers.assheet .lhead h2{font-size:13px;}
  .layers-scrim{background:rgba(5,11,40,.45);z-index:910;}
}
@media (max-width:420px){
  .chrome{padding:0 14px;gap:12px;}
  .detail-body{padding:18px 18px 26px;}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001s !important;transition-duration:.12s !important;}
}
