/* ============================================================
   kumanokodo-now.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;}
/* 支援技術・クローラ向けの見出し（視覚的に隠すが DOM/アクセシビリティツリーには存在） */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
/* JS無効時のフォールバック表示（実コンテンツ＋内部リンク） */
.noscript-seo{position:fixed;left:0;right:0;top:var(--nav-h);bottom:0;overflow:auto;background:#fff;z-index:600;padding:26px 20px;color:#23284a;font-family:var(--sans);}
.noscript-seo h2{font-size:24px;color:var(--navy);margin:0 0 12px;}
.noscript-seo p{font-size:15px;line-height:1.7;max-width:60ch;margin:0 0 16px;}
.noscript-seo a{color:var(--accent-deep);}
.noscript-seo ul{line-height:2;padding-left:20px;}
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;order:1;}
.rk .rn{font-size:12.5px;color:var(--ink);font-weight:500;order:2;}
.rk .rj{font-size:11px;color:var(--ink-soft);margin-left:auto;font-family:var(--mono);order:3;}

.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:flex;flex-direction:column;gap:11px;transition:bottom .28s cubic-bezier(.4,0,.2,1);}
/* デスクトップ: Post/LIVE は出すが、Layers は専用パネルがあるのでFABは隠す */
#fabLayers{display:none;}
.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;}
/* 公式投稿件数バッジ（LIVE FAB） */
.fab.live .fab-count{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;
  background:var(--accent);color:#fff;font-family:var(--mono);font-size:10px;font-weight:700;line-height:18px;
  text-align:center;border:2px solid #fff;box-shadow:0 2px 5px rgba(0,0,0,.3);z-index:2;}
@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);}}

/* ---------------- NOW post composer (渦P2) ---------------- */
.fab.post{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-deep));border-color:transparent;}
.fab.post .fl{color:rgba(255,255,255,.9);}
/* 雨雲レーダーFAB: ON のときアクセント色で状態を表示（OFFは通常のグレー） */
.fab.rain.on{color:#fff;background:linear-gradient(135deg,#2f7fe0,#1f54d6);border-color:transparent;}
.fab.rain.on .fl{color:rgba(255,255,255,.9);}
/* 現在地FAB: 取得中は薄く、表示中は青 */
.fab.busy{opacity:.55;}
.fab.locate.on{color:#fff;background:linear-gradient(135deg,#2f7fe0,#1f54d6);border-color:transparent;}
.fab.locate.on .fl{color:rgba(255,255,255,.9);}
/* 現在地マーカー（青い点＋脈動） */
.mk-loc{position:relative;width:24px;height:24px;}
.mk-loc .dot{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;
  background:#2f7fe0;border:2.5px solid #fff;box-shadow:0 1px 5px rgba(0,0,0,.45);z-index:2;}
.mk-loc .pulse{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;
  box-shadow:0 0 0 0 rgba(47,127,224,.5);animation:locpulse 2s infinite;}
@keyframes locpulse{0%{box-shadow:0 0 0 0 rgba(47,127,224,.5);}70%{box-shadow:0 0 0 16px rgba(47,127,224,0);}100%{box-shadow:0 0 0 0 rgba(47,127,224,0);}}
body.posting .leaflet-container{cursor:crosshair;}

.post-hint{position:fixed;left:50%;transform:translateX(-50%) translateY(-12px);top:calc(var(--nav-h) + 12px);z-index:560;
  display:none;align-items:center;gap:9px;background:rgba(8,17,76,.94);backdrop-filter:blur(6px);color:#fff;
  border-radius:30px;padding:9px 12px 9px 14px;font-size:13px;box-shadow:var(--shadow-card);opacity:0;transition:opacity .25s,transform .25s;}
.post-hint.show{display:flex;opacity:1;transform:translateX(-50%) translateY(0);}
.post-hint svg{width:16px;height:16px;color:var(--accent-soft);}
.post-hint .ph-x{border:none;background:transparent;color:rgba(255,255,255,.6);font-size:15px;margin-left:4px;cursor:pointer;}

.composer{position:fixed;left:50%;transform:translateX(-50%) translateY(16px);bottom:24px;z-index:600;
  width:min(460px,calc(100vw - 28px));background:rgba(255,255,255,.98);backdrop-filter:blur(8px);
  border:1px solid var(--line);border-radius:18px;padding:14px 16px 13px;box-shadow:var(--shadow-card);
  opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;}
.composer.open{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);}
.cps-head{display:flex;align-items:center;justify-content:space-between;}
.cps-head b{font-size:15px;font-weight:700;color:var(--navy);}
.cps-x{border:none;background:transparent;color:var(--ink-soft);font-size:17px;cursor:pointer;}
/* 位置案内（目立たせる・押した瞬間に何をすればよいか一目で分かる） */
.cps-loc{display:flex;align-items:center;gap:7px;margin:7px 0 9px;padding:7px 10px;border-radius:10px;
  background:var(--accent-faint,rgba(255,119,0,.1));border:1px solid rgba(255,119,0,.28);
  font-size:12px;font-weight:600;color:var(--accent-deep);line-height:1.4;}
.cps-loc svg{width:16px;height:16px;flex:none;color:var(--accent);}
.cps-sub{font-size:10.5px;color:var(--ink-soft);margin:8px 0 0;line-height:1.5;}
.cps-board-link{color:var(--accent-deep);font-weight:600;text-decoration:none;white-space:nowrap;}
.cps-board-link:hover{text-decoration:underline;}
.cps-ta{width:100%;border:1px solid var(--line-2);border-radius:12px;padding:10px 12px;font-family:var(--sans);
  font-size:14px;color:var(--navy);resize:none;outline:none;box-sizing:border-box;}
.cps-ta:focus{border-color:var(--accent);}
.cps-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;}
.cps-foot{display:flex;align-items:center;justify-content:space-between;margin-top:9px;}
.cps-count{font-family:var(--mono);font-size:11px;color:var(--ink-soft);}
.cps-send{border:none;border-radius:11px;background:var(--accent);color:#fff;font-weight:700;font-size:13.5px;
  padding:9px 20px;cursor:pointer;box-shadow:0 4px 12px -4px rgba(255,119,0,.8);}
.cps-send:hover{background:var(--accent-deep);}
.cps-send:disabled{opacity:.6;cursor:default;}
.cps-msg{font-size:12px;color:var(--accent-deep);margin-top:7px;min-height:1em;}
/* 投稿前の確認ステップ（投稿は削除できないため） */
.cps-confirm{margin-top:10px;padding:11px 12px;border-radius:12px;background:rgba(255,119,0,.08);border:1px solid rgba(255,119,0,.3);}
.cps-confirm-warn{font-size:12.5px;line-height:1.55;color:var(--accent-deep);font-weight:600;margin:0 0 10px;}
.cps-confirm-btns{display:flex;gap:9px;}
.cps-cancel{flex:none;border:1px solid var(--line-2);background:#fff;color:var(--ink-soft);border-radius:11px;padding:9px 16px;font-size:13px;cursor:pointer;}
.cps-do{flex:1;border:none;border-radius:11px;background:var(--accent);color:#fff;font-weight:700;font-size:13.5px;padding:9px 16px;cursor:pointer;box-shadow:0 4px 12px -4px rgba(255,119,0,.8);}
.cps-do:hover{background:var(--accent-deep);}
.cps-do:disabled{opacity:.6;cursor:default;}

.mk-now{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;border:2px solid #fff;
  background:linear-gradient(135deg,#ff7700,#b3631f);box-shadow:0 3px 9px -2px rgba(8,17,76,.5);}
.mk-now i{font-size:13px;color:#fff;}
.mk-now-new{width:30px;height:34px;border-radius:50% 50% 50% 3px;transform:rotate(45deg);animation:nowdrop .3s;}
.mk-now-new i{transform:rotate(-45deg);}
@keyframes nowdrop{0%{transform:rotate(45deg) translateY(-10px);opacity:.4;}100%{transform:rotate(45deg) translateY(0);opacity:1;}}

.kp-toast{position:fixed;left:50%;transform:translateX(-50%) translateY(20px);bottom:96px;z-index:700;
  background:rgba(8,17,76,.96);color:#fff;border-radius:30px;padding:11px 20px;font-size:13.5px;font-weight:600;
  box-shadow:var(--shadow-card);opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;max-width:calc(100vw - 32px);text-align:center;}
.kp-toast.show{opacity:1;transform:translateX(-50%) translateY(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;}
/* 写真ヒーローは廃止。PCは閉じ×ボタン(右上)を避けるため上余白を確保 */
.detail-body{padding:46px 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:30px;height:30px;border-radius:50% 50% 50% 4px;transform:rotate(45deg);
  border:2.5px solid #fff;display:grid;place-items:center;
  background:linear-gradient(135deg,#ffac33,#e35a00);
  box-shadow:0 5px 16px -3px rgba(227,90,0,.8), 0 0 0 4px rgba(255,140,0,.18);}
.mk-cond .body span{transform:rotate(-45deg);font-size:12px;line-height:1;}
/* 認証バッジ（✓）: 公式である証 */
.mk-cond .badge{position:absolute;top:-5px;right:-5px;width:15px;height:15px;border-radius:50%;
  background:#fff;border:1.5px solid #e35a00;display:grid;place-items:center;z-index:3;box-shadow:0 1px 3px rgba(0,0,0,.3);}
.mk-cond .badge svg{width:9px;height:9px;color:#e35a00;}
/* 目を引く脈動ハロー */
.mk-cond::before{content:"";position:absolute;left:50%;top:11px;width:30px;height:30px;border-radius:50%;
  transform:translate(-50%,-50%);box-shadow:0 0 0 0 rgba(255,140,0,.5);animation:condpulse 2.6s infinite;pointer-events:none;}
@keyframes condpulse{0%{box-shadow:0 0 0 0 rgba(255,140,0,.45);}70%{box-shadow:0 0 0 13px rgba(255,140,0,0);}100%{box-shadow:0 0 0 0 rgba(255,140,0,0);}}
.mk-cond::after{content:"";position:absolute;left:50%;bottom:-3px;transform:translateX(-50%);width:12px;height:4px;border-radius:50%;background:rgba(0,0,0,.24);filter:blur(1px);}
.mk-cond.sel .body{transform:rotate(45deg) scale(1.16);box-shadow:0 12px 24px -8px rgba(227,90,0,.9), 0 0 0 5px rgba(255,140,0,.25);}
.mk-oji{width:22px;height:22px;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:12px;color:#fff;
  display:flex;align-items:center;justify-content:center;
}
/* FA icon inside oji marker */
.mk-oji i{font-size:11px;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:20px;height:20px;border-radius:50%;border:2px solid #fff;
  box-shadow:0 1px 4px rgba(0,0,0,.35);display:grid;place-items:center;}
.fac-toilet{background:var(--navy-soft);}
.fac-bus{background:var(--r-ohe);}
.fac-toilet i,.fac-bus i{font-size:10px;line-height:1;color:#fff;}

/* ---------------- community (local voices) markers ---------------- */
.mk-voice{width:24px;height:24px;border-radius:50% 50% 50% 3px;transform:rotate(45deg);
  display:grid;place-items:center;border:2px solid #fff;box-shadow:0 3px 9px -2px rgba(8,17,76,.5);
  background:linear-gradient(135deg,#2aa7a0,#176e69);transition:transform .15s;}
.mk-voice i{transform:rotate(-45deg);font-size:11px;line-height:1;color:#fff;}
.mk-voice:hover{transform:rotate(45deg) scale(1.12);}
.mk-voice-food{background:linear-gradient(135deg,#f08a3c,#c25f15);}
.mk-voice-event{background:linear-gradient(135deg,#c065c0,#7e3a8a);}
.mk-voice-sight{background:linear-gradient(135deg,#4a9bd4,#2a6aa8);}

/* ---------------- 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-retry{display:inline-flex;align-items:center;gap:7px;margin:0 14px 14px;padding:8px 12px;
  border:1px solid var(--accent);background:var(--accent-faint);color:var(--accent-deep);
  border-radius:9px;font-size:12px;font-weight:600;font-family:var(--sans);}
.wx-retry:hover{background:var(--accent);color:#fff;}
.wx-retry svg{flex:none;}

.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 (Yahoo zoom-radar style) ---------------- */
.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:12px 16px 11px;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-head{display:flex;align-items:center;gap:13px;}
.radar-play{width:40px;height:40px;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);cursor:pointer;}
.radar-play:hover{background:var(--accent-deep);}
.radar-readout{flex:1;display:flex;align-items:baseline;gap:9px;min-width:0;}
.radar-bigtime{font-family:var(--mono);font-size:22px;font-weight:600;line-height:1;letter-spacing:.01em;}
.radar-tag{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.05em;
  padding:2px 8px;border-radius:20px;line-height:1.5;white-space:nowrap;}
.radar-tag.is-live{background:rgba(255,119,0,.24);color:#ffb277;}
.radar-tag.is-fc{background:rgba(120,170,255,.2);color:#9fc4ff;}
.radar-tag.is-past{background:rgba(255,255,255,.12);color:rgba(255,255,255,.72);}
.radar-head .rl-src{flex:none;align-self:flex-start;font-family:var(--mono);font-size:9px;
  color:rgba(255,255,255,.5);text-decoration:none;}
.radar-head .rl-src:hover{color:rgba(255,255,255,.85);text-decoration:underline;}

/* 中段: スライダー + 実況マーカー（過去=白 / 予報=オレンジのグラデ） */
.radar-track{position:relative;margin-top:16px;padding-top:4px;}
.radar-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:4px;outline:none;cursor:pointer;
  background:linear-gradient(90deg,rgba(255,255,255,.38) 0 var(--nowpct,75%),rgba(255,119,0,.5) var(--nowpct,75%) 100%);}
.radar-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;
  border:3px solid var(--accent);cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.45);}
.radar-slider::-moz-range-thumb{width:15px;height:15px;border-radius:50%;background:#fff;border:3px solid var(--accent);cursor:pointer;}
/* 実況マーカー: スライダーを貫く縦線 + 上に「実況」ラベル */
.radar-nowtick{position:absolute;top:-14px;left:var(--nowpct,75%);transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;pointer-events:none;}
.radar-nowtick em{font-family:var(--mono);font-size:8.5px;font-style:normal;font-weight:600;letter-spacing:.1em;
  color:#ffb277;white-space:nowrap;margin-bottom:1px;}
.radar-nowtick i{width:2px;height:22px;background:#ffb277;border-radius:2px;box-shadow:0 0 4px rgba(255,119,0,.6);}

/* 下段: 時間スケール（過去の最古 … 予報の最後） */
.radar-scale{display:flex;justify-content:space-between;margin-top:8px;
  font-family:var(--mono);font-size:9px;letter-spacing:.03em;}
.radar-scale .rs-past{color:rgba(255,255,255,.55);}
.radar-scale .rs-fc{color:rgba(255,178,119,.85);}

.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);}}

/* ---------------- 投稿リスト「このエリアの投稿」 ---------------- */
.posts{position:fixed;z-index:540;background:var(--paper);box-shadow:var(--shadow-card);
  display:flex;flex-direction:column;transform:translateY(120%);opacity:0;pointer-events:none;
  transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .2s;
  left:22px;bottom:22px;width:360px;max-height:min(60vh,520px);border:1px solid var(--line);border-radius:16px;overflow:hidden;}
.posts.open{transform:none;opacity:1;pointer-events:auto;}
.posts-grab{display:none;}
.posts-head{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--line);flex:none;}
.posts-title{display:flex;align-items:center;gap:7px;font-weight:600;font-size:14.5px;color:var(--navy);}
.posts-title svg{width:16px;height:16px;color:var(--accent-deep);flex:none;}
.posts-count{font-family:var(--mono);font-size:12px;background:var(--accent-faint);color:var(--accent-deep);border-radius:20px;padding:2px 9px;font-weight:600;}
.posts-x{margin-left:auto;border:none;background:transparent;color:var(--ink-soft);font-size:17px;width:30px;height:30px;border-radius:8px;flex:none;}
.posts-x:hover{background:var(--navy-mist);}
.posts-list{overflow-y:auto;-webkit-overflow-scrolling:touch;flex:1;overscroll-behavior:contain;}
.posts-empty{padding:26px 16px;color:var(--ink-soft);font-size:13px;line-height:1.6;text-align:center;}
.post-row{display:flex;gap:11px;width:100%;text-align:left;border:none;background:transparent;
  padding:12px 14px;border-bottom:1px solid var(--line);cursor:pointer;align-items:flex-start;font-family:var(--sans);}
.post-row:hover{background:var(--navy-mist);}
.post-row.active{background:var(--accent-faint);}
.post-row.flash{animation:prflash 1.5s ease;}
@keyframes prflash{0%,100%{background:transparent;}18%,40%{background:var(--accent-faint);}}
.pr-ic{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:12px;}
.pr-ic.off{background:linear-gradient(135deg,#f0a500,#e06600);}
.pr-ic.now{background:linear-gradient(135deg,#ff7700,#b3631f);}
.pr-ic.v-food{background:linear-gradient(135deg,#f08a3c,#c25f15);}
.pr-ic.v-event{background:linear-gradient(135deg,#c065c0,#7e3a8a);}
.pr-ic.v-sight{background:linear-gradient(135deg,#4a9bd4,#2a6aa8);}
.pr-ic.v-voice{background:linear-gradient(135deg,#2aa7a0,#176e69);}
.pr-main{flex:1;min-width:0;}
.pr-top{display:flex;align-items:center;gap:6px;margin-bottom:3px;}
.pr-nm{font-weight:600;font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pr-badge{flex:none;font-family:var(--mono);font-size:8.5px;letter-spacing:.04em;text-transform:uppercase;background:#e6a100;color:#fff;border-radius:5px;padding:1px 5px;font-weight:700;}
.pr-tm{flex:none;margin-left:auto;font-family:var(--mono);font-size:10.5px;color:var(--ink-soft);}
.pr-tx{font-size:13px;line-height:1.5;color:#3a4066;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1;}
.post-row.expanded .pr-tx{display:block;-webkit-line-clamp:unset;}
.pr-place{margin-top:7px;font-size:11px;color:var(--ink-soft);display:flex;align-items:center;gap:5px;}
.pr-img{margin-top:9px;border-radius:10px;overflow:hidden;max-height:220px;}
.pr-img img{width:100%;height:auto;display:block;}
/* 選択中マーカーの強調（voice/now） */
.mk-voice.sel{transform:rotate(45deg) scale(1.22);box-shadow:0 10px 22px -7px rgba(0,0,0,.5),0 0 0 4px rgba(255,140,0,.3);z-index:5;}
.mk-now.sel{transform:scale(1.2);box-shadow:0 0 0 4px rgba(255,140,0,.35);}
/* 投稿シート表示中は下部のレーダーバーと重ならないよう隠す */
body.posts-open .radar{display:none !important;}

/* ---------------- 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;}
  /* FABは常にレーダーバーの上の固定位置（動かすと下端でブラウザ下部バーに隠れるため） */
  .fabs{display:flex;bottom:calc(env(safe-area-inset-bottom,0px) + 112px);}
  #fabLayers{display:flex;}  /* モバイルは Layers FAB を出す（パネルの代わり） */

  .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;}
  /* スマホでは「Live trail reports」ピルは天気ウィジェットと被るため非表示（INFO FABで代替） */
  .statuspill{display:none !important;}

  /* 投稿リスト: モバイルは全幅ボトムシート */
  .posts{left:0;right:0;bottom:0;width:auto;max-height:62vh;border-radius:18px 18px 0 0;border-left:none;border-right:none;border-bottom:none;}
  .posts-grab{display:block;width:44px;height:5px;border-radius:3px;background:var(--line-2);margin:8px auto 0;flex:none;}
  .posts-head{padding:8px 14px 10px;}
  body.posts-open .fabs{display:none !important;}  /* シート表示中はFAB群を隠す（被り回避・閉じるは×で） */

  /* weather widget: compact, collapsible */
  .wx{right:12px;top:calc(var(--nav-h) + 10px);width:auto;min-width:0;max-width:calc(100vw - 24px);}
  .wx-exp{display:block;padding:0;}
  .wx-body{display:none;}
  .wx.open{width:300px;max-width:calc(100vw - 24px);}
  .wx.open .wx-body{display:block;}
  .wx-head{padding:6px 9px;gap:6px;}
  .wx-loc{font-size:12.5px;gap:3px;}
  .wx-loc svg{width:13px;height:13px;}
  .wx-now{gap:5px;}
  .wx-ic svg{width:18px;height:18px;}
  .wx-temp{font-size:17px;}
  .wx-skel{width:46px;height:18px;}

  /* radar timeline: full-width bottom — モバイルは高さを約半分に圧縮してマップを広く */
  .radar{left:12px;right:12px;width:auto;transform:translateY(14px);
    bottom:calc(env(safe-area-inset-bottom,0px) + 16px);padding:6px 12px 7px;border-radius:12px;}
  .radar.show{transform:translateY(0);}
  .radar-head{gap:10px;}
  .radar-play{width:30px;height:30px;}
  .radar-play svg{width:14px;height:14px;}
  .radar-bigtime{font-size:15px;}
  .radar-tag{font-size:8.5px;padding:1px 6px;}
  .radar-head .rl-src{font-size:8px;}
  .radar-track{margin-top:6px;padding-top:0;}
  /* 実況マーカーの時刻ラベルは読み取り部と重複するのでモバイルでは隠す（縦詰め）*/
  .radar-nowtick{top:-3px;}
  .radar-nowtick em{display:none;}
  .radar-nowtick i{height:13px;}
  .radar-slider{height:5px;}
  .radar-scale{margin-top:4px;font-size:8px;}
  /* 凡例（降水強度の色スケール）はモバイルでは隠してマップ視認性を優先 */
  .radar-legend{display:none;}

  .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;}

  /* scrim needs position:fixed to actually cover the screen */
  .layers-scrim{position:fixed;inset:0;background:rgba(5,11,40,.45);z-index:910;
    display:none;pointer-events:none;}
  .layers-scrim.open{display:block;pointer-events:auto;}

  /* bottom sheet peek: show a larger handle so it's easier to dismiss */
  .detail.peek{transform:translateY(calc(100% - 160px));}
}
@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;}
}

/* ============================================================
   JA mode — language-priority overrides
   When lang="ja" is set by setLang(), Japanese text becomes
   the primary (larger/bolder) label; English becomes the
   secondary (smaller/muted) subordinate label.
   ============================================================ */

/* Layers panel — route key: JA時は日本語名を主、英語名を副に */
:root[lang="ja"] .rk .rn{
  /* EN mode: primary label (12.5px bold). JA mode: demote to secondary */
  font-size:11px;color:var(--ink-soft);font-weight:400;font-family:var(--mono);
  order:3;margin-left:auto;
}
:root[lang="ja"] .rk .rj{
  /* EN mode: secondary label (11px muted right-edge). JA mode: promote to primary */
  font-size:12.5px;color:var(--ink);font-weight:600;
  order:2;margin-left:0;font-family:var(--sans);letter-spacing:0;
}

/* Town milestone markers — map-app.js rebuilds markers on setLang(), so
   the text content is already correct. These rules ensure that if the DOM
   ever preserves old nodes (e.g. back/forward cache), font sizes are right. */
:root[lang="ja"] .mk-town-name{font-size:12px;}
:root[lang="ja"] .mk-town-role{font-size:9.5px;}

/* Sanzan shrine markers */
:root[lang="ja"] .mk-sanzan-name{font-size:13px;}
:root[lang="ja"] .mk-sanzan-sub{font-size:9.5px;}

/* Segment detail sheet — h3 holds the segment name (already localized via Lz).
   Japanese text is denser so a slightly larger size improves readability. */
:root[lang="ja"] .detail-body h3{font-size:22px;letter-spacing:.01em;}
