:root {
  --bg: #0B1620; --sf: #101E2C; --sf2: #152334;
  --bd: rgba(255,255,255,.07); --bd2: rgba(255,255,255,.12);
  --txt: #e2eaf4; --dim: #8299A8; --faint: rgba(255,255,255,.03);
  --acc: #6FA85A; --gold: #c8a96e;
  --shadow: 0 4px 24px rgba(0,0,0,.6);
}
*{margin:0;padding:0;box-sizing:border-box}
html{font-size:18px}
html,body{width:100%;height:100%;overflow:hidden;font-family:'Space Grotesk',sans-serif;background:var(--bg);color:var(--txt)}
#map{position:fixed;top:48px;left:0;right:30vw;bottom:0;z-index:1;transition:bottom .3s}

/* ── TOP BAR ── */
#topbar{position:fixed;top:0;left:0;right:0;height:48px;z-index:900;background:rgba(11,22,32,.97);border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:10px;padding:0 14px;backdrop-filter:blur(12px)}
#topbar h1{font-size:.98rem;font-weight:700;letter-spacing:-.02em;white-space:nowrap;color:var(--acc)}
#topbar h1 span{color:var(--gold)}
.tb-sep{width:1px;height:28px;background:var(--bd2);flex-shrink:0}

/* GPX Drop Zone */
#gpx-zone{display:flex;align-items:center;gap:8px;padding:5px 12px;background:var(--sf);border:1.5px dashed var(--bd2);border-radius:7px;cursor:pointer;transition:all .2s;min-width:140px}
#gpx-zone:hover,#gpx-zone.drag{border-color:var(--acc);background:rgba(111,168,90,.06)}
#gpx-zone.loaded{border-style:solid;border-color:rgba(111,168,90,.5);background:rgba(111,168,90,.06)}
#gpx-zone span{font-family:'JetBrains Mono',monospace;font-size:.5rem;color:var(--dim);white-space:nowrap}
#gpx-zone .icon{font-size:1.02rem}
#gpx-input{display:none}

/* Controls */
.tb-ctrl{display:flex;flex-direction:column;gap:1px}
.tb-ctrl label{font-family:'JetBrains Mono',monospace;font-size:.64rem;color:var(--dim);letter-spacing:.08em}
.tb-ctrl input[type=date],.tb-ctrl input[type=number]{background:var(--sf);border:1px solid var(--bd2);color:var(--txt);font-family:'JetBrains Mono',monospace;font-size:.73rem;padding:3px 7px;border-radius:5px;outline:none;width:110px;transition:border-color .15s}
.tb-ctrl input[type=number]{width:70px}
.tb-ctrl input:focus{border-color:var(--acc)}

#btn-plan{padding:7px 18px;background:var(--acc);color:#fff;border:none;border-radius:7px;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.7rem;cursor:pointer;letter-spacing:.02em;transition:all .2s;white-space:nowrap;box-shadow:0 2px 12px rgba(111,168,90,.3)}
#btn-plan:hover{background:#7EC462;box-shadow:0 4px 18px rgba(111,168,90,.4)}
#btn-plan:disabled{opacity:.4;cursor:default}
#topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}
#track-info{font-family:'JetBrains Mono',monospace;font-size:.59rem;color:var(--dim);line-height:1.6}
#track-info b{color:var(--txt)}

/* ── BOTTOM ÉTAPES BAR ── */
/* ── RIGHT PANEL ── */
#right-panel{position:fixed;top:48px;right:0;width:30vw;min-width:260px;bottom:0;z-index:900;background:rgba(11,22,32,.97);border-left:1px solid var(--bd);display:flex;flex-direction:column;overflow:hidden;transition:transform .3s}
#right-panel-scroll{flex:1;overflow-y:auto;overflow-x:hidden;width:100%;container-type:inline-size}
#right-panel-scroll::-webkit-scrollbar{width:3px}
#right-panel-scroll::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px}
#etapes-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:8px;color:var(--dim);font-size:.62rem;font-family:'JetBrains Mono',monospace;padding:20px;text-align:center}
#etapes-empty .big{font-size:2rem}
/* ── ELEVATION PANEL ── */
#elev-panel{position:fixed;bottom:0;left:0;right:270px;height:148px;z-index:860;background:rgba(11,22,32,.96);border-top:1px solid var(--bd);transform:translateY(100%);transition:transform .3s;overflow:visible}
#elev-panel.show{transform:translateY(0)}
#elev-canvas{width:100%;height:100%;display:block}
#elev-toggle{position:fixed;bottom:0;right:30vw;z-index:870;background:rgba(11,22,32,.95);border:1px solid var(--bd2);border-radius:6px 0 0 0;color:var(--dim);font-family:'JetBrains Mono',monospace;font-size:.55rem;padding:4px 10px;cursor:pointer;transition:all .15s;border-bottom:none;border-right:none}
#elev-toggle:hover{color:var(--acc)}
#elev-toggle.on{color:var(--acc);border-color:rgba(111,168,90,.4)}

/* Summary card */
.et-summary{width:100%;padding:10px 12px;border-bottom:1px solid var(--bd2);display:flex;flex-direction:column;gap:3px;background:var(--sf);flex-shrink:0}
.et-summary .s-title{font-size:.77rem;font-family:'JetBrains Mono',monospace;color:var(--acc);letter-spacing:.1em;font-weight:600}
.et-summary .s-val{font-size:.94rem;font-weight:700;color:var(--txt)}
.et-summary .s-sub{font-size:.86rem;font-family:'JetBrains Mono',monospace;color:var(--dim)}

/* Étape card */
.et-card{width:100%;padding:9px 12px;border-bottom:1px solid var(--bd);display:flex;flex-direction:column;gap:2px;cursor:pointer;transition:background .15s;position:relative;background:var(--bg)}
.et-card:hover{background:var(--sf)}
.et-card.active{background:var(--sf)}
.et-card .et-day{font-family:'JetBrains Mono',monospace;font-size:.54rem;letter-spacing:.06em;font-weight:600;display:flex;align-items:center;gap:5px}
.et-card .et-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.et-card .et-row2{display:flex;align-items:baseline;gap:8px;min-width:0}
.et-card .et-city{font-size:1rem;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0}
.et-card .et-city.loading{color:var(--dim);font-style:italic}
.et-card .et-stats{font-family:'JetBrains Mono',monospace;font-size:.52rem;color:var(--dim);white-space:nowrap;margin-left:auto;flex-shrink:0;display:flex;align-items:baseline;gap:4px}
.et-card .et-km{font-family:'JetBrains Mono',monospace;font-size:.86rem;color:var(--dim);margin-top:0}
.et-card .et-wx{margin-top:4px;padding-top:4px;border-top:1px solid var(--bd);display:flex;align-items:center;gap:4px;flex-wrap:wrap;width:100%}
/* Unified weather row type scale */
.wx-row{display:flex;align-items:center;gap:5px;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.04);width:100%}
.wx-lbl{font-family:'JetBrains Mono',monospace;font-size:.45rem;color:var(--dim);width:26px;flex-shrink:0}
.wx-ico{font-size:.65rem;flex-shrink:0}
.wx-tmp{font-family:'JetBrains Mono',monospace;font-size:.68rem;color:#fff;font-weight:600;width:30px;flex-shrink:0}
.wx-wnd{font-family:'JetBrains Mono',monospace;font-size:.45rem;color:rgba(180,210,240,.8)}
.wx-rn{font-family:'JetBrains Mono',monospace;font-size:.43rem;color:#7ab8e8}
.wx-big{font-size:1.2rem;flex-shrink:0;margin-top:3px;line-height:1}
.et-card .et-adj{position:absolute;top:8px;right:6px;display:flex;gap:2px;opacity:0;transition:opacity .15s}
.et-card:hover .et-adj{opacity:1}
.et-card .et-adj button{background:var(--bd);border:1px solid var(--bd2);color:var(--dim);font-family:monospace;font-size:.86rem;padding:1px 5px;border-radius:3px;cursor:pointer;line-height:1.4}
.et-card .et-adj button:hover{color:var(--acc);border-color:var(--acc)}

/* ── Stage Drag ── */
/* Leaflet 1.9.4 already sets .leaflet-marker-icon to position:absolute.
   The transform:translate3d() Leaflet adds to each icon also creates a containing block
   for our position:absolute dot/card children — no override needed here.
   (A previous position:relative override caused all icons to re-enter normal flow,
   so icons added after POI cluster icons inherited their accumulated heights → ~100px shift.) */
.stage-drag-handle:hover{opacity:.88;border-color:rgba(255,255,255,.25) !important}
.stage-drag-handle:active{cursor:grabbing !important}
.et-slider{padding:5px 0 1px;border-top:1px solid var(--bd);margin-top:4px}
.et-slider input[type=range]{width:100%;accent-color:var(--acc);cursor:pointer;height:3px;margin:3px 0;display:block}
.et-slider-vals{display:flex;justify-content:space-between;font-family:'JetBrains Mono',monospace;font-size:.38rem;color:var(--dim)}
body.sliders-hidden .et-slider{display:none}
/* ── WX / POI side-by-side layout ── */
.et-wx-poi-row{display:flex;flex-direction:column}
.et-wx-col{min-width:0}
.et-poi-col{margin-top:5px;padding-top:5px;border-top:1px solid rgba(255,255,255,.07)}
.et-poi-row{display:flex;align-items:flex-start;gap:4px;padding:2px 3px;cursor:pointer;border-radius:4px;margin-bottom:1px;transition:background .1s}
.et-poi-icon{font-size:.65rem;flex-shrink:0;line-height:1.5;display:inline-flex;align-items:center;min-width:16px}
.et-poi-mid{flex:1;min-width:0}
.et-poi-name{font-family:'JetBrains Mono',monospace;font-size:.47rem;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.et-poi-sub{font-family:'JetBrains Mono',monospace;font-size:.42rem;color:var(--dim);word-break:break-word;margin-top:1px;line-height:1.4}
.et-poi-dist{font-family:'JetBrains Mono',monospace;font-size:.41rem;color:rgba(180,210,240,.65);flex-shrink:0;margin-top:3px;min-width:28px;text-align:right}
.et-poi-km{font-family:'JetBrains Mono',monospace;font-size:.41rem;color:var(--dim);flex-shrink:0;margin-top:3px;min-width:32px;text-align:right}
@container (min-width:340px){
  .et-wx-poi-row{flex-direction:row;align-items:flex-start;gap:8px}
  .et-wx-col{flex:0 0 auto}
  .et-card .et-wx-poi-row .et-wx{width:auto}
  .et-poi-col{flex:1;min-width:0;margin-top:0;padding-top:0;border-top:none;border-left:1px solid rgba(255,255,255,.07);padding-left:8px;align-self:stretch}
}

.sp{display:inline-block;width:7px;height:7px;border:1.5px solid rgba(111,168,90,.2);border-top-color:var(--acc);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:.2;transform:translate(-50%,-50%) scale(1.4)}}

/* ── MAP POPUPS ── */
.leaflet-popup-content-wrapper{background:#0d1320!important;border:1px solid rgba(111,168,90,.3)!important;border-radius:8px!important;box-shadow:0 4px 20px rgba(0,0,0,.7)!important}
.leaflet-popup-tip{background:#0d1320!important}
.pu-t{font-weight:700;font-size:1.04rem;margin-bottom:2px}
.pu-s{font-family:'JetBrains Mono',monospace;font-size:.71rem;color:#7a8fa8;line-height:1.6}

/* ── DROP OVERLAY ── */
#drop-overlay{position:fixed;inset:0;z-index:9999;background:rgba(11,22,32,.92);display:none;align-items:center;justify-content:center;flex-direction:column;gap:10px;backdrop-filter:blur(4px)}
#drop-overlay.show{display:flex}
#drop-overlay .dob{border:3px dashed var(--acc);border-radius:16px;padding:40px 60px;text-align:center}
#drop-overlay .dob span{font-size:2rem;display:block;margin-bottom:8px}
#drop-overlay .dob p{font-size:.8rem;color:var(--acc);font-weight:600}

/* ── MOBILE ───────────────────────────── */
@media(max-width:700px){
  #map-empty{right:0 !important}
  #left-panel{z-index:1600;width:72vw;max-width:280px}
  /* Elevation full width on mobile */
  #elev-panel{right:0 !important;height:130px}
  #elev-toggle{right:0 !important;border-radius:6px 6px 0 0;font-size:.52rem;padding:4px 10px}
  #toast-stack{right:10px;bottom:10px}


  #topbar{flex-wrap:wrap;height:auto;padding:6px 10px;gap:6px}
  #topbar h1{font-size:.75rem}
  .tb-sep{display:none}
  #info-btn{width:22px;height:22px;font-size:.7rem}
  .tb-ctrl label{font-size:.36rem}
  .tb-ctrl input,.tb-ctrl select{font-size:.55rem;padding:3px 5px}
  .tb-ctrl input[type=date]{width:95px}
  .tb-ctrl input[type=number]{width:52px}
  #btn-plan{padding:5px 12px;font-size:.62rem}
  #track-info{display:none}

  /* Map: full width, panel overlays */
  #map{top:auto;top:0;left:0;right:0;bottom:0;margin-top:0}
  #map-wrap{position:fixed;top:96px;left:0;right:0;bottom:0;z-index:1}
  #map{top:96px !important;right:0 !important}

  /* Right panel: slide-in overlay from right */
  #right-panel{
    width:88vw !important;max-width:88vw !important;min-width:0 !important;
    top:0 !important;bottom:0 !important;z-index:1500;
    transform:translateX(110%);box-shadow:-4px 0 30px rgba(0,0,0,.8)
  }
  #right-panel.mobile-open{transform:translateX(0)}

  /* Elevation: full width */
  #elev-panel{right:0 !important}
  #elev-toggle{right:0 !important;border-radius:6px 6px 0 0}

  /* Mobile toggle button */
  #mobile-panel-btn{display:flex}
}
@media(min-width:701px){
  #mobile-panel-btn{display:none}
  #mobile-close-btn{display:none}
}


/* ── LANDSCAPE HINT ── */
#landscape-hint{display:none;position:fixed;inset:0;z-index:10000;background:rgba(11,22,32,.95);align-items:center;justify-content:center;flex-direction:column;gap:14px;text-align:center;backdrop-filter:blur(6px)}
#landscape-hint .lh-icon{font-size:3rem;animation:lh-rotate 1.5s ease-in-out infinite}
#landscape-hint .lh-text{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:#6FA85A;max-width:260px;line-height:1.7}
#landscape-hint .lh-sub{font-family:'JetBrains Mono',monospace;font-size:.48rem;color:#7a8fa8;margin-top:4px}
#landscape-hint .lh-close{margin-top:10px;background:rgba(111,168,90,.12);border:1px solid rgba(111,168,90,.3);color:#6FA85A;font-family:'JetBrains Mono',monospace;font-size:.52rem;padding:6px 20px;border-radius:6px;cursor:pointer}
@keyframes lh-rotate{0%,100%{transform:rotate(0deg)}50%{transform:rotate(90deg)}}
@media(max-width:700px) and (orientation:portrait){
  #landscape-hint.active{display:flex}
}

/* ── RESIZE HANDLE ── */
#resize-handle{position:fixed;top:48px;width:6px;bottom:0;z-index:950;cursor:col-resize;background:transparent;transition:background .15s}
#resize-handle:hover,#resize-handle.active{background:rgba(111,168,90,.3)}
#resize-handle::after{content:'';position:absolute;top:50%;left:1px;transform:translateY(-50%);width:4px;height:40px;border-radius:2px;background:rgba(111,168,90,.2);transition:background .15s}
#resize-handle:hover::after,#resize-handle.active::after{background:rgba(111,168,90,.6)}

/* ── MAP LAYER SWITCHER ── */


/* ── TRACK CURSOR ── */
#elev-cursor{position:absolute;pointer-events:none;z-index:5}
#elev-cursor-line{position:absolute;width:1px;background:rgba(255,255,255,.4);pointer-events:none}
#elev-cursor-dot{position:absolute;width:8px;height:8px;border-radius:50%;background:#6FA85A;border:2px solid #fff;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 8px rgba(111,168,90,.6)}
#elev-cursor-label{position:absolute;background:rgba(11,22,32,.92);border:1px solid rgba(111,168,90,.3);border-radius:4px;padding:2px 6px;font-family:'JetBrains Mono',monospace;font-size:.42rem;color:#b8daf5;white-space:nowrap;pointer-events:none;transform:translateX(-50%)}

/* ── LEFT LAYER PANEL ── */
#left-panel{position:fixed;top:48px;left:0;width:240px;bottom:0;z-index:850;background:rgba(11,22,32,.97);border-right:1px solid var(--bd);transform:translateX(-100%);transition:transform .3s;overflow-y:auto;overflow-x:hidden;backdrop-filter:blur(10px)}
#left-panel.open{transform:translateX(0)}
#left-panel::-webkit-scrollbar{width:3px}
#left-panel::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px}
.lp-section{padding:10px 12px;border-bottom:1px solid var(--bd)}
.lp-title{font-family:'JetBrains Mono',monospace;font-size:.44rem;color:var(--acc);letter-spacing:.12em;font-weight:600;margin-bottom:8px}
.lp-row{display:flex;align-items:center;gap:7px;margin:4px 0;cursor:pointer;user-select:none}
.lp-row input[type=checkbox]{accent-color:var(--acc);width:13px;height:13px;cursor:pointer;flex-shrink:0}
.lp-row label{font-family:'JetBrains Mono',monospace;font-size:.48rem;color:#ccc;cursor:pointer;flex:1}
.lp-row .lp-buf{font-family:'JetBrains Mono',monospace;font-size:.38rem;color:var(--dim);width:32px;text-align:right;flex-shrink:0}
.lp-row input[type=range]{width:50px;height:3px;accent-color:var(--acc);cursor:pointer;flex-shrink:0}
.lp-map-btns{display:flex;flex-direction:column;gap:5px;margin-bottom:4px}
.lp-map-btn{background:rgba(255,255,255,.04);border:1px solid var(--bd2);color:var(--txt);font-family:'JetBrains Mono',monospace;font-size:.58rem;padding:9px 12px;border-radius:6px;cursor:pointer;transition:all .15s;text-align:left;width:100%}
.lp-map-btn:hover,.lp-map-btn.active{color:var(--acc);background:rgba(111,168,90,.1);border-color:rgba(111,168,90,.3)}
.lp-shortcut{display:inline-block;font-family:monospace;font-size:.4rem;background:rgba(111,168,90,.1);border:1px solid rgba(111,168,90,.2);border-radius:3px;padding:1px 5px;color:var(--acc);margin-right:4px}
.lp-key-row{display:flex;align-items:center;gap:6px;margin:3px 0;font-family:'JetBrains Mono',monospace;font-size:.44rem;color:var(--dim)}

/* ── PLANNING SECTION in right panel ── */
.plan-section{padding:10px 12px;border-bottom:1px solid var(--bd);background:var(--sf)}
.plan-row{display:flex;align-items:center;gap:6px;margin:5px 0}
.plan-row label{font-family:'JetBrains Mono',monospace;font-size:.4rem;color:var(--dim);width:52px;flex-shrink:0;letter-spacing:.06em}
.plan-row input,.plan-row select{background:var(--bg);border:1px solid var(--bd2);color:var(--txt);font-family:'JetBrains Mono',monospace;font-size:.55rem;padding:4px 7px;border-radius:5px;outline:none;flex:1;min-width:0;transition:border-color .15s}
.plan-row input:focus,.plan-row select:focus{border-color:var(--acc)}
.mode-dropdown{position:relative;flex:1;cursor:pointer;user-select:none}
.mode-dropdown-val{display:flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--bd2);border-radius:5px;padding:4px 7px;font-family:'JetBrains Mono',monospace;font-size:.55rem;color:var(--txt);transition:border-color .15s}
.mode-dropdown-val img{width:16px;height:16px;flex-shrink:0}
.mode-dropdown-arrow{margin-left:auto;color:var(--dim);font-size:.48rem;transition:transform .15s}
.mode-dropdown.open .mode-dropdown-arrow{transform:rotate(180deg)}
.mode-dropdown:hover .mode-dropdown-val,.mode-dropdown.open .mode-dropdown-val{border-color:var(--acc)}
.mode-dropdown-list{display:none;position:absolute;top:calc(100% + 3px);left:0;right:0;background:var(--sf2);border:1px solid var(--bd2);border-radius:5px;overflow:hidden;z-index:600;box-shadow:0 4px 16px rgba(0,0,0,.45)}
.mode-dropdown-list.open{display:block}
.mode-dropdown-item{display:flex;align-items:center;gap:7px;padding:6px 8px;font-family:'JetBrains Mono',monospace;font-size:.52rem;color:var(--txt);cursor:pointer;transition:background .1s}
.mode-dropdown-item img{width:16px;height:16px;flex-shrink:0}
.mode-dropdown-item:hover{background:rgba(111,168,90,.12)}
.mode-dropdown-item.active{color:var(--acc);background:rgba(111,168,90,.08)}
.plan-buttons{display:flex;gap:5px;margin-top:6px}
.plan-buttons button{flex:1;padding:6px 0;border-radius:5px;font-family:'JetBrains Mono',monospace;font-size:.52rem;cursor:pointer;transition:all .15s}
#plan-btn2{background:var(--acc);color:#fff;border:none;font-weight:700;box-shadow:0 2px 8px rgba(111,168,90,.3)}
#plan-btn2:hover{background:#5aaee0}
#wx-refresh-btn2{background:rgba(111,168,90,.1);border:1px solid rgba(111,168,90,.25);color:var(--acc)}
#wx-refresh-btn2:hover{background:rgba(111,168,90,.2)}

/* ── HAMBURGER BUTTON ── */
#ham-btn{background:rgba(111,168,90,.08);border:1px solid rgba(111,168,90,.3);color:#6FA85A;height:34px;border-radius:6px;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;padding:0 10px;font-weight:600;gap:4px;font-family:'JetBrains Mono',monospace}
#ham-btn:hover{background:rgba(111,168,90,.18);border-color:rgba(111,168,90,.5);color:#7ac8ee}
#ham-btn.active{background:rgba(111,168,90,.25);border-color:#6FA85A;color:#7ac8ee;box-shadow:0 0 0 2px rgba(111,168,90,.15)}

/* ── UPDATED TOPBAR (slimmer) ── */
#topbar{height:48px;padding:0 12px;gap:8px}
#topbar h1{margin-left:auto}

/* ── POI LOADING ── */
.marker-cluster-small,.marker-cluster-medium,.marker-cluster-large{background:none !important}
.marker-cluster div{background:none !important}
.leaflet-cluster-anim .leaflet-marker-icon,.leaflet-cluster-anim .leaflet-marker-shadow{transition:transform .3s ease-out,opacity .3s ease-in}
/* ── Toast Stack (bottom-right) ── */
#toast-stack{position:fixed;bottom:48px;right:calc(30vw + 10px);z-index:1100;display:flex;flex-direction:column;gap:6px;align-items:flex-end;pointer-events:none;transition:bottom .3s}
body:has(#elev-panel.show) #toast-stack{bottom:calc(148px + 12px)}
.tst{background:rgba(11,22,32,.96);border:1px solid rgba(111,168,90,.25);border-radius:8px;padding:8px 12px;font-family:'JetBrains Mono',monospace;min-width:190px;max-width:250px;animation:tst-in .18s ease;transition:opacity .25s,transform .25s}
.tst.closing{opacity:0;transform:translateX(18px)}
.tst-cat{font-size:.36rem;color:#7a8fa8;letter-spacing:.1em;text-transform:uppercase;margin-bottom:3px;font-weight:600}
.tst-detail{font-size:.44rem;color:#6FA85A}
.tst-bar{width:100%;height:3px;background:rgba(111,168,90,.12);border-radius:2px;margin-top:6px;overflow:hidden}
.tst-fill{height:100%;background:linear-gradient(90deg,#6FA85A,#8FCC78);border-radius:2px;transition:width .3s}
@keyframes tst-in{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:translateX(0)}}

/* ── POI Groups (collapsible) ── */
.poi-group{margin-bottom:2px}
.poi-group-header{display:flex;align-items:center;gap:4px;padding:5px 0;cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:.48rem;color:#9ab;user-select:none;transition:color .15s}
.poi-group-header:hover{color:#fff}
.poi-group-arrow{display:inline-block;width:10px;font-size:.42rem;transition:transform .2s;color:var(--acc)}
.poi-group.open>.poi-group-header .poi-group-arrow{transform:rotate(90deg)}
.poi-group-count{color:var(--dim);font-size:.38rem;margin-left:auto}
.poi-group-body{display:none;padding-left:4px;border-left:1px solid var(--bd)}
.poi-group.open>.poi-group-body{display:block}

/* ── On-Demand Badge ── */
.od-badge{font-family:'JetBrains Mono',monospace;font-size:.34rem;color:#7a8fa8;background:rgba(122,143,168,.08);border:1px solid rgba(122,143,168,.15);border-radius:3px;padding:1px 5px;margin-left:auto;white-space:nowrap;flex-shrink:0}

/* ── ABOUT ROUTECAST ── */
html.about-html{min-height:100%;height:auto;overflow:auto}
body.about-page{min-height:100%;height:auto;overflow:auto;background:#0B1620;color:var(--txt)}
.about-topbar{position:sticky;top:0;z-index:10;height:58px;background:rgba(11,22,32,.96);border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;padding:0 clamp(16px,4vw,54px);backdrop-filter:blur(12px)}
.about-brand{display:flex;align-items:center;gap:9px;color:var(--txt);text-decoration:none;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.08rem}
.about-brand span span{color:var(--acc)}
.about-back,.about-mail{font-family:'JetBrains Mono',monospace;font-size:.52rem;color:var(--acc);text-decoration:none;border:1px solid rgba(111,168,90,.28);background:rgba(111,168,90,.08);border-radius:6px;padding:7px 11px}
.about-back:hover,.about-mail:hover{background:rgba(111,168,90,.16);border-color:rgba(111,168,90,.45)}
.about-mail-btn{cursor:pointer}
.about-mail-fallback{display:block;font-family:'JetBrains Mono',monospace;font-size:.46rem;color:var(--dim);margin-top:8px}
.about-wrap{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:28px 0 54px}
.about-hero{display:grid;grid-template-columns:minmax(0,.9fr) minmax(360px,1.25fr);gap:26px;align-items:start;margin-bottom:24px}
.about-hero-copy{padding:38px 0;display:flex;flex-direction:column;justify-content:center}
.about-tabs{display:flex;flex-wrap:nowrap;gap:5px;margin-bottom:18px;overflow-x:auto;scrollbar-width:none}
.about-tabs::-webkit-scrollbar{display:none}
.about-tab{font-family:'JetBrains Mono',monospace;font-size:.46rem;color:var(--dim);background:rgba(255,255,255,.035);border:1px solid var(--bd2);border-radius:6px;padding:7px 9px;cursor:pointer;transition:all .15s;white-space:nowrap;flex:0 0 auto}
.about-tab:hover,.about-tab.active{color:var(--acc);background:rgba(111,168,90,.1);border-color:rgba(111,168,90,.35)}
.about-kicker,.about-label{font-family:'JetBrains Mono',monospace;font-size:.48rem;letter-spacing:.12em;text-transform:uppercase;color:var(--acc);font-weight:600;margin-bottom:8px}
.about-hero-text{display:none}
.about-hero-text.active{display:block}
.about-hero h1{font-size:clamp(1.8rem,4.2vw,3.15rem);line-height:1.05;letter-spacing:0;color:#fff;margin-bottom:16px}
.about-hero p{font-size:.78rem;line-height:1.75;color:#bfd0dd;max-width:650px}
.about-hero-media,.about-hero-visual{display:none;border:1px solid var(--bd2);border-radius:8px;overflow:hidden;background:var(--sf);box-shadow:var(--shadow);min-height:320px;height:320px;margin-top:54px}
.about-hero-media.active,.about-hero-visual.active{display:block}
.about-hero-media img{width:100%;height:100%;object-fit:cover;display:block}
.about-hero-visual{padding:22px;background:linear-gradient(135deg,rgba(16,30,44,.94),rgba(11,22,32,.98));align-content:center}
.about-visual-card{background:rgba(255,255,255,.04);border:1px solid var(--bd);border-radius:8px;padding:16px;margin-bottom:12px}
.about-flow{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;align-items:center}
.about-flow span{font-family:'JetBrains Mono',monospace;font-size:.58rem;color:#fff;text-align:center;border:1px solid rgba(111,168,90,.3);background:rgba(111,168,90,.09);border-radius:8px;padding:18px 8px;position:relative}
.about-flow span:not(:last-child)::after{content:'›';position:absolute;right:-8px;top:50%;transform:translateY(-50%);color:var(--gold)}
.about-warning{height:100%;display:flex;flex-direction:column;justify-content:center;gap:12px;border:1px solid rgba(200,169,110,.3);background:rgba(200,169,110,.08);border-radius:8px;padding:26px}
.about-warning strong{font-size:1.1rem;color:var(--gold)}
.about-warning span{font-family:'JetBrains Mono',monospace;font-size:.56rem;line-height:1.8;color:#d5c7a6}
.about-source-cloud{display:flex;flex-wrap:wrap;gap:10px;align-content:center;min-height:310px}
.about-source-cloud span{font-family:'JetBrains Mono',monospace;font-size:.54rem;color:var(--acc);background:rgba(111,168,90,.09);border:1px solid rgba(111,168,90,.25);border-radius:999px;padding:9px 12px}
.about-license-list{display:grid;gap:10px}
.about-license-list div{display:flex;justify-content:space-between;gap:16px;background:rgba(255,255,255,.04);border:1px solid var(--bd);border-radius:7px;padding:13px}
.about-license-list strong{font-size:.7rem;color:#fff}
.about-license-list span{font-family:'JetBrains Mono',monospace;font-size:.56rem;color:var(--dim)}
.about-faq-preview{height:100%;display:flex;flex-direction:column;justify-content:center;gap:12px}
.about-faq-preview>strong{font-size:1.2rem;color:#fff;margin-bottom:4px}
.faq-nav{display:grid;gap:7px}
.faq-nav a{display:block;text-decoration:none;border:1px solid var(--bd);background:rgba(255,255,255,.035);border-radius:7px;padding:10px 12px;transition:all .15s}
.faq-nav a:hover,.faq-nav a.active{border-color:rgba(111,168,90,.35);background:rgba(111,168,90,.08)}
.faq-nav strong{display:block;font-size:.58rem;color:#fff;margin-bottom:3px}
.faq-nav span{display:block;font-family:'JetBrains Mono',monospace;font-size:.42rem;line-height:1.5;color:var(--dim)}
.about-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.about-tab-panel{display:none}
.about-tab-panel.active{display:block}
.about-panel{background:rgba(16,30,44,.82);border:1px solid var(--bd);border-radius:8px;padding:20px 22px;box-shadow:0 2px 18px rgba(0,0,0,.22)}
.about-wide{grid-column:1/-1}
.about-panel h2{font-size:1.08rem;line-height:1.25;color:#fff;margin-bottom:10px}
.about-panel p{font-size:.66rem;line-height:1.78;color:#bdcedc}
.about-steps,.about-license-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.about-steps div,.about-license-grid div{background:rgba(255,255,255,.035);border:1px solid var(--bd);border-radius:7px;padding:12px}
.about-steps strong,.about-license-grid strong{display:block;font-size:.64rem;color:#fff;margin-bottom:5px}
.about-steps span,.about-license-grid span{display:block;font-family:'JetBrains Mono',monospace;font-size:.48rem;line-height:1.65;color:var(--dim)}
.about-list{list-style:none;display:flex;flex-direction:column;gap:8px}
.about-list li{font-size:.62rem;line-height:1.6;color:#bdcedc;position:relative;padding-left:18px}
.about-list.good li::before{content:'✓';position:absolute;left:0;color:var(--acc)}
.about-list.muted li::before{content:'×';position:absolute;left:0;color:var(--gold)}
.about-private{border-color:rgba(200,169,110,.28);background:rgba(36,31,24,.46)}
.about-private .about-label{color:var(--gold)}
.about-faq{display:grid;gap:14px}
.faq-section{scroll-margin-top:76px;transition:border-color .2s,background .2s}
.faq-section.active{border-color:rgba(111,168,90,.35);background:rgba(16,34,44,.9)}
.about-faq details{border-top:1px solid var(--bd);padding:10px 0}
.about-faq details:first-of-type{border-top:0}
.about-faq summary{font-size:.66rem;color:#fff;font-weight:600;cursor:pointer;line-height:1.45}
.about-faq summary:hover{color:var(--acc)}
.about-faq details p{font-size:.58rem;margin-top:7px;color:#bdcedc}
.ui-chip{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.42rem;color:var(--acc);background:rgba(111,168,90,.1);border:1px solid rgba(111,168,90,.25);border-radius:5px;padding:2px 6px;margin:0 4px 2px 0;white-space:nowrap}
.faq-shot{font-family:'JetBrains Mono',monospace;font-size:.48rem;line-height:1.6;color:var(--dim);border:1px dashed rgba(200,169,110,.32);background:rgba(200,169,110,.055);border-radius:8px;padding:14px;margin-top:12px}
@media(max-width:820px){
  .about-topbar{height:auto;min-height:56px;padding:10px 16px;gap:12px}
  .about-brand{font-size:.94rem}
  .about-wrap{width:min(100% - 24px,680px);padding-top:18px}
  .about-hero,.about-grid,.about-steps,.about-license-grid{grid-template-columns:1fr}
  .about-flow{grid-template-columns:1fr}
  .about-flow span:not(:last-child)::after{content:'↓';right:auto;left:50%;top:auto;bottom:-12px;transform:translateX(-50%)}
  .about-hero-copy{padding:12px 0 0}
  .about-hero-media,.about-hero-visual{min-height:240px;height:auto;margin-top:0}
  .about-panel{padding:17px 16px}
}

/* ══════════════════════════════════════════
   WAFFLE BUTTON
══════════════════════════════════════════ */
#waffle-btn{background:rgba(111,168,90,.08);border:1px solid rgba(111,168,90,.3);color:#6FA85A;height:34px;width:36px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;padding:0}
#waffle-btn:hover{background:rgba(111,168,90,.18);border-color:rgba(111,168,90,.5)}
#waffle-btn.active{background:rgba(111,168,90,.25);border-color:#6FA85A;box-shadow:0 0 0 2px rgba(111,168,90,.15)}
.wf-dots{display:grid;grid-template-columns:repeat(3,4px);gap:2.5px}
.wf-dots i{display:block;width:4px;height:4px;background:currentColor;border-radius:1px;font-style:normal}

/* ══════════════════════════════════════════
   WAFFLE DROPDOWN
══════════════════════════════════════════ */
#waffle-menu{position:fixed;top:56px;left:12px;z-index:1050;background:rgba(10,18,28,.98);border:1px solid var(--bd2);border-radius:13px;padding:8px;display:none;grid-template-columns:1fr;gap:4px;backdrop-filter:blur(20px);box-shadow:0 12px 48px rgba(0,0,0,.8);min-width:200px}
#waffle-menu.open{display:grid;animation:wf-in .15s ease}
@keyframes wf-in{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}
.wf-tile{display:flex;flex-direction:row;align-items:center;gap:11px;padding:9px 13px;border:1px solid transparent;border-radius:8px;cursor:pointer;transition:all .15s;background:rgba(255,255,255,.02);user-select:none}
.wf-tile:hover{background:rgba(111,168,90,.08);border-color:rgba(111,168,90,.3)}
.wf-tile.active{background:rgba(111,168,90,.14);border-color:rgba(111,168,90,.5)}
.wf-tile-icon{font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;width:22px;flex-shrink:0}
.wf-tile-label{font-family:'JetBrains Mono',monospace;font-size:.46rem;color:var(--dim);letter-spacing:.06em;text-transform:uppercase}
.wf-tile:hover .wf-tile-label,.wf-tile.active .wf-tile-label{color:var(--acc)}
.wf-key{color:var(--acc);font-weight:700}
.wf-tile:hover .wf-key,.wf-tile.active .wf-key{color:#fff}

/* ══════════════════════════════════════════
   SHORTCUT SWITCHES
══════════════════════════════════════════ */
.lp-switch-row{display:flex;align-items:center;gap:8px;padding:5px 4px;cursor:pointer;border-radius:5px;transition:background .1s}
.lp-switch-row:hover{background:rgba(255,255,255,.04)}
.lp-switch-label{flex:1;font-family:'JetBrains Mono',monospace;font-size:.44rem;color:var(--txt)}
.lp-key-inline{font-family:'JetBrains Mono',monospace;font-size:.37rem;color:var(--dim);background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);padding:1px 5px;border-radius:3px;min-width:14px;text-align:center;flex-shrink:0}
.lp-sw{position:relative;width:28px;height:15px;border-radius:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);transition:background .2s,border-color .2s;flex-shrink:0}
.lp-sw::after{content:'';position:absolute;left:2px;top:50%;transform:translateY(-50%);width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.35);transition:left .2s,background .2s}
.lp-sw.on{background:rgba(111,168,90,.3);border-color:rgba(111,168,90,.55)}
.lp-sw.on::after{left:15px;background:#6FA85A}

/* ══════════════════════════════════════════
   SAVED POI LIST
══════════════════════════════════════════ */
.saved-list-row{display:flex;align-items:center;gap:8px;padding:5px 4px;cursor:pointer;border-radius:5px;transition:background .1s}
.saved-list-row:hover{background:rgba(255,255,255,.05)}
.saved-list-icon{flex-shrink:0;display:flex;align-items:center;min-width:16px;line-height:1}
.saved-list-name{flex:1;font-family:'JetBrains Mono',monospace;font-size:.44rem;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.saved-list-km{font-family:'JetBrains Mono',monospace;font-size:.38rem;color:var(--dim);flex-shrink:0}
#saved-list-content{margin-bottom:6px}

/* ══════════════════════════════════════════
   LEFT PANEL — flex column + scrollable body
══════════════════════════════════════════ */
#left-panel{display:flex;flex-direction:column;overflow:hidden}
#lp-content{flex:1;overflow-y:auto;overflow-x:hidden}
#lp-content::-webkit-scrollbar{width:3px}
#lp-content::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px}
#lp-header{display:none;align-items:center;gap:6px;padding:9px 12px;border-bottom:1px solid var(--bd2);flex-shrink:0;background:var(--sf2)}
#lp-header.show{display:flex}
#lp-title{font-family:'JetBrains Mono',monospace;font-size:.44rem;color:var(--acc);letter-spacing:.12em;font-weight:600;flex:1}
#lp-back{background:none;border:none;color:var(--dim);cursor:pointer;font-size:1.1rem;padding:0 4px;line-height:1;border-radius:4px;transition:color .15s}
#lp-back:hover{color:var(--acc)}
#lp-close-x{background:none;border:none;color:var(--dim);cursor:pointer;font-size:.8rem;padding:2px 5px;border-radius:4px;transition:color .15s;line-height:1}
#lp-close-x:hover{color:#e74c3c}
.lp-section[data-panel]{display:none !important}
.lp-section[data-panel].panel-active{display:block !important}

/* ══════════════════════════════════════════
   PLANNING PANEL HEADER + CLOSE
══════════════════════════════════════════ */
.plan-header{display:flex;align-items:center;margin-bottom:8px}
.plan-header .lp-title{margin-bottom:0;flex:1}
#plan-close-btn{background:none;border:none;color:var(--dim);cursor:pointer;font-size:.75rem;padding:2px 6px;border-radius:4px;transition:color .15s;line-height:1;flex-shrink:0}
#plan-close-btn:hover{color:#e74c3c}

/* ══════════════════════════════════════════
   PLAN-CLOSED BODY STATE
══════════════════════════════════════════ */
#right-panel{transition:transform .35s cubic-bezier(.4,0,.2,1)}
body.plan-closed #right-panel{transform:translateX(100%)}
body.plan-closed #resize-handle{display:none}
#map{transition:right .35s cubic-bezier(.4,0,.2,1),bottom .3s}
#elev-panel{transition:transform .3s,right .35s cubic-bezier(.4,0,.2,1)}
#elev-toggle{transition:right .35s cubic-bezier(.4,0,.2,1),color .15s}

/* Plan-reopen button in topbar */
#plan-open-btn{display:none;align-items:center;gap:5px;background:rgba(111,168,90,.08);border:1px solid rgba(111,168,90,.3);color:#6FA85A;height:28px;border-radius:6px;font-family:'JetBrains Mono',monospace;font-size:.43rem;cursor:pointer;padding:0 10px;transition:all .15s;white-space:nowrap;flex-shrink:0}
#plan-open-btn:hover{background:rgba(111,168,90,.18)}
body.plan-closed #plan-open-btn{display:flex}

/* Plan-closed: collapse map to full width on desktop */
@media(min-width:701px){
  body.plan-closed #map{right:0 !important}
  body.plan-closed #elev-panel{right:0 !important}
  body.plan-closed #elev-toggle{right:0 !important}
}

/* ══════════════════════════════════════════
   POI SEARCH — integrated in #left-panel
══════════════════════════════════════════ */
/* Make lp-content a flex column when poi-search is active so the section fills height */
#lp-content.psp-active{overflow:hidden;display:flex;flex-direction:column}
.lp-section[data-panel="poi-search"]{padding:0}
.lp-section[data-panel="poi-search"].panel-active{display:flex !important;flex-direction:column;flex:1;min-height:0}

/* Scope buttons */
.psp-scope-row{display:flex;gap:3px;padding:6px 8px;border-bottom:1px solid var(--bd);flex-shrink:0}
.psp-scope-btn{flex:1;background:var(--bg);border:1px solid var(--bd2);border-radius:4px;color:var(--dim);cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:.42rem;padding:4px 2px;transition:all .15s;white-space:nowrap}
.psp-scope-btn:hover{color:var(--fg);border-color:var(--acc)}
.psp-scope-btn.active{background:rgba(111,168,90,.12);border-color:var(--acc);color:var(--acc)}

/* Search input */
.psp-input-row{display:flex;align-items:center;gap:6px;padding:6px 8px;border-bottom:1px solid var(--bd);flex-shrink:0}
.psp-input-icon{width:14px;height:14px;color:var(--dim);flex-shrink:0}
.psp-input{flex:1;background:none;border:none;outline:none;color:var(--fg);font-family:'JetBrains Mono',monospace;font-size:.58rem}
.psp-input::placeholder{color:var(--dim)}
.psp-spinner{width:12px;height:12px;border-radius:50%;border:2px solid var(--bd2);border-top-color:var(--acc);flex-shrink:0;display:none}
.psp-spinner.active{display:block;animation:psp-spin .65s linear infinite}
@keyframes psp-spin{to{transform:rotate(360deg)}}

/* Scrollable results area */
#psp-results{flex:1;overflow-y:auto;min-height:0;padding:4px 0}
#psp-results::-webkit-scrollbar{width:3px}
#psp-results::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px}
.psp-hint{padding:10px 12px;font-size:.52rem;color:var(--dim);font-style:italic}
.psp-err{color:#e74c3c}

/* Type group header */
.psp-group{margin-bottom:2px}
.psp-group-head{display:flex;align-items:center;gap:6px;padding:4px 8px;font-size:.46rem;font-weight:700;color:var(--dim);text-transform:uppercase;letter-spacing:.05em;background:var(--bg);border-top:1px solid var(--bd);border-bottom:1px solid var(--bd)}
.psp-gh-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.psp-count{font-weight:400;opacity:.6;flex-shrink:0}

/* Colored dot for group header and items */
.psp-dot{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;flex-shrink:0;box-shadow:0 1px 3px rgba(0,0,0,.35)}
.psp-dot img{display:block}

/* Individual item — same pattern as saved-list-row */
.psp-item{display:flex;align-items:center;gap:8px;padding:5px 8px;cursor:pointer;transition:background .12s;border-bottom:1px solid rgba(255,255,255,.04)}
.psp-item:hover{background:var(--sf2)}
.psp-item-dot{width:18px;height:18px;flex-shrink:0}
.psp-item-text{flex:1;min-width:0;overflow:hidden}
.psp-item-name{display:block;font-family:'JetBrains Mono',monospace;font-size:.46rem;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.psp-item-meta{display:block;font-family:'JetBrains Mono',monospace;font-size:.4rem;color:var(--dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}

/* Footer show-all button */
.psp-footer{padding:7px 8px;border-top:1px solid var(--bd);flex-shrink:0}
.psp-show-all{width:100%;background:rgba(111,168,90,.08);border:1px solid rgba(111,168,90,.3);border-radius:4px;color:#6FA85A;cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:.5rem;padding:5px 8px;transition:all .15s}
.psp-show-all:hover{background:rgba(111,168,90,.18)}
