/* Single dark theme. Extracted verbatim from index.html's <style> block
   (the 1,491-line stylesheet) so the page is smaller to read/edit. Loaded via
   <link> in the same <head> position, so cascade order is unchanged. The :root
   hex here remain the no-JS fallbacks; shared/tokens.js + conditions.js still
   override the CSS vars at runtime. See CLAUDE.md “UI / design system”. */
  :root{
    /* surfaces/borders/text/accent come from shared/tokens.js (that script overrides these at
       runtime); condition colors come from shared/conditions.js. Both blocks below are kept only as
       no-JS fallbacks — edit the shared module, not these, and keep them in sync. */
    --bg:#0a0d11; --panel:#121821; --panel2:#19212c; --elev:#1f2935;
    --line:#222c38; --line2:#2c3744; --txt:#eef3f8; --muted:#8b98a8; --faint:#5d6a79;
    --accent:#5ab0ff; --good:#2bbf6a; --hero:#13a85a; --tacky:#39c47a;
    --dusty:#c4b045; --soft:#e3973a; --muddy:#e0524a; --frozen:#e0824a;
    --snowfree:#37b3a8; --snow:#5b8def; --shadow:0 6px 24px rgba(0,0,0,.35);
  }
  *{box-sizing:border-box}
  html,body{margin:0}
  body{background:
      radial-gradient(1200px 600px at 80% -10%, #14202c 0%, transparent 60%),
      radial-gradient(900px 500px at -10% 0%, #161f1a 0%, transparent 55%), var(--bg);
    color:var(--txt);min-height:100vh;
    font:15px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
    -webkit-font-smoothing:antialiased}
  header{position:sticky;top:0;z-index:30;background:rgba(10,13,17,.82);
    backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--line);padding:12px 16px}
  .hwrap{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
  .toprow{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
  .brand{display:flex;align-items:center;gap:10px;min-width:0}
  .brand .logo{font-size:22px}
  .btxt{min-width:0}
  h1{font-size:17px;margin:0;font-weight:700;letter-spacing:.2px}
  .sub{color:var(--muted);font-size:12px;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .deskonly{display:inline-flex}
  .seg{display:flex;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:3px}
  .seg button{border:0;background:transparent;color:var(--muted);padding:6px 12px;border-radius:7px;
    cursor:pointer;font-size:13px;font-weight:600;transition:.15s}
  .seg button.on{background:var(--elev);color:var(--txt);box-shadow:0 1px 0 rgba(255,255,255,.03)}
  .controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
  .search{flex:1;min-width:180px;position:relative}
  .search input{width:100%;background:var(--panel);border:1px solid var(--line);border-radius:10px;
    color:var(--txt);padding:9px 12px 9px 34px;font-size:14px;outline:none;transition:.15s}
  .search input:focus{border-color:var(--accent);background:var(--panel2)}
  .search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);opacity:.5}
  .chips{display:flex;gap:6px;flex-wrap:wrap}
  .chip{padding:7px 13px;border:1px solid var(--line);border-radius:999px;background:var(--panel);
    color:var(--muted);cursor:pointer;font-size:13px;font-weight:600;user-select:none;transition:.15s;white-space:nowrap}
  .chip:hover{border-color:var(--line2);color:var(--txt)}
  .chip.on{background:var(--accent);border-color:var(--accent);color:#04121f}
  .selwrap select{background:var(--panel);border:1px solid var(--line);border-radius:10px;color:var(--txt);
    padding:8px 10px;font-size:13px;font-weight:600;cursor:pointer;outline:none}
  main{padding:16px;max-width:1180px;margin:0 auto}
  .countbar{display:flex;justify-content:space-between;align-items:baseline;color:var(--muted);
    font-size:12.5px;margin:0 2px 10px}
  .grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:13px}

  .card{background:var(--panel);border:1px solid var(--line);border-radius:14px;
    padding:14px 15px 13px 17px;cursor:pointer;position:relative;overflow:hidden;
    transition:transform .14s,border-color .14s,box-shadow .14s}
  .card:hover{transform:translateY(-1px);border-color:var(--line2);box-shadow:var(--shadow)}
  .card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--cc,#444)}
  .cname{font-size:16.5px;font-weight:700;letter-spacing:.1px;margin:0;line-height:1.25}
  .cmeta{display:flex;gap:8px;flex-wrap:wrap;align-items:center;color:var(--muted);font-size:12px;margin-top:5px}
  .zchip{padding:2px 7px;border-radius:6px;font-weight:800;font-size:10px;text-transform:uppercase;letter-spacing:.5px}
  .cstatus{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:12px}
  .cbest{font-size:12px;color:var(--muted);font-weight:600;display:inline-flex;gap:4px;align-items:center}
  /* M3 drying countdown chip (color set inline, like .cond) */
  .dry{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;
    border-radius:8px;padding:4px 9px;white-space:nowrap}
  .dry.lg{font-size:13px;padding:6px 12px}
  .dcountdown{margin-top:9px}
  .windnote{margin:0 0 12px;padding:9px 12px;border-radius:9px;font-size:12.5px;line-height:1.4;
    color:#cdd8e4;background:#8aa6c91b;border:1px solid #8aa6c93a}
  .why{color:#aeb9c6;font-size:12.5px;line-height:1.45;margin:10px 0 0;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .cfoot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:13px}
  .conf{display:inline-flex;align-items:center;gap:6px;color:var(--faint);font-size:11px;font-weight:600}
  .dot{width:8px;height:8px;border-radius:50%;display:inline-block}
  .week{display:flex;gap:3px;align-items:flex-end;height:28px}
  .week .wd{width:6px;border-radius:2px;opacity:.9;position:relative}
  .week .wd.today{outline:1.5px solid rgba(255,255,255,.5);outline-offset:1px}

  /* score ring */
  .ring{position:relative;width:60px;height:60px;flex:none}
  .ring svg{transform:rotate(-90deg)}
  .ring .num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
    font-size:19px;font-weight:800}
  /* condition chip — calm, tinted, readable (no gradient/glow) */
  .cond{display:inline-flex;align-items:center;gap:6px;border-radius:8px;padding:5px 11px;
    font-weight:700;font-size:13px;white-space:nowrap}
  .cond .se{font-size:13px;line-height:1}
  .cond.lg{font-size:15px;padding:7px 14px;gap:7px}
  .cond.lg .se{font-size:16px}
  .cond.sm{font-size:11.5px;padding:4px 9px}

  /* overlay */
  /* desktop: the sheet is a side panel, so keep the rest of the map clearly readable behind it
     (light dim, no blur) — the selected trail stays visible. Mobile overrides this to a heavier
     dim below, where the bottom sheet covers most of the map anyway. */
  .overlay{position:fixed;inset:0;background:rgba(4,7,10,.3);z-index:50;display:none}
  .overlay.on{display:block;animation:fade .15s ease}
  @keyframes fade{from{opacity:0}to{opacity:1}}
  .sheet{position:absolute;right:0;top:0;bottom:0;width:min(580px,100%);
    background:linear-gradient(180deg,#121821,#0c1117);border-left:1px solid var(--line);
    overflow-y:auto;padding:0;box-shadow:-20px 0 50px rgba(0,0,0,.5);animation:slide .22s cubic-bezier(.2,.7,.2,1)}
  @keyframes slide{from{transform:translateX(30px);opacity:.4}to{transform:none;opacity:1}}
  .shead{position:sticky;top:0;z-index:5;padding:18px 20px 14px;
    background:linear-gradient(180deg,rgba(18,24,33,.97),rgba(18,24,33,.0));backdrop-filter:blur(6px)}
  .sbody{padding:4px 20px 28px}
  .shead-row{display:flex;align-items:center;gap:10px}
  .close{flex:none;width:32px;height:32px;border-radius:50%;
    border:1px solid var(--line);background:var(--panel);color:var(--muted);font-size:18px;cursor:pointer;
    display:flex;align-items:center;justify-content:center}
  .close:hover{color:var(--txt);border-color:var(--line2)}
  .unitbtn{flex:none;height:32px;padding:0 12px;border-radius:999px;
    border:1px solid var(--line);background:var(--panel);color:var(--muted);font-size:12px;font-weight:700;
    cursor:pointer;display:flex;align-items:center;gap:5px}
  .unitbtn:hover{color:var(--txt);border-color:var(--line2)}
  /* save/favorite heart (detail header) — visible to everyone; entitlement enforced on tap */
  .favbtn,.dsharebtn{flex:none;width:32px;height:32px;border-radius:50%;cursor:pointer;
    border:1px solid var(--line);background:var(--panel);color:var(--muted);
    display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s,transform .12s}
  .favbtn svg,.dsharebtn svg{width:17px;height:17px}
  .favbtn:hover{color:var(--hero);border-color:var(--line2)}
  .dsharebtn:hover{color:var(--accent);border-color:var(--line2)}
  .favbtn.on{color:var(--hero);border-color:rgba(19,168,90,.45);background:rgba(19,168,90,.12)}
  .favbtn.on svg{fill:var(--hero)}
  .favbtn:active,.dsharebtn:active{transform:scale(.9)}
  .favbtn:disabled{opacity:.5;cursor:default}
  /* aha share nudge — appears under the verdict only when a trail is genuinely firing (hero/tacky)
     or freshly melted out, at most once per ~month, dismissible. Rides the stoke of a great read into
     the G2 share loop. Uses the ACCENT (interactive) color, never a condition color as chrome — the
     green condition is already carried by the stoke chip above it. */
  .aha{display:flex;align-items:center;gap:9px;margin:0 0 14px;padding:9px 11px;border-radius:14px;
    background:rgba(90,176,255,.10);border:1px solid rgba(90,176,255,.30)}
  .aha-ic{flex:none;font-size:17px;line-height:1}
  .aha-tx{flex:1;font-size:12.5px;line-height:1.38;color:var(--txt)}
  .aha-tx b{font-weight:800}
  .aha-share{flex:none;display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#04121f;
    border:0;border-radius:11px;padding:7px 11px;font-weight:800;font-size:12.5px;cursor:pointer;white-space:nowrap;
    transition:filter .14s,transform .12s}
  .aha-share:hover{filter:brightness(1.06)}
  .aha-share:active{transform:scale(.95)}
  .aha-share svg{width:14px;height:14px}
  .aha-x{flex:none;width:22px;height:22px;border:0;background:none;color:var(--faint);font-size:16px;
    line-height:1;cursor:pointer;border-radius:999px}
  .aha-x:hover{color:var(--muted)}
  /* Dirt Report opt-in card (in-app email capture, bottom of the trail detail) — reuses .acct-card */
  .dirtopt-card{position:relative}
  .dirtopt-hub{margin-top:12px}
  .dirtopt-x{position:absolute;top:7px;right:9px;width:24px;height:24px;border:0;background:none;
    color:var(--faint);font-size:18px;line-height:1;cursor:pointer;border-radius:999px}
  .dirtopt-x:hover{color:var(--muted)}
  /* My-trails filter chip (list view controls) */
  .favfilter{flex:none;border:1px solid var(--line);background:var(--panel);color:var(--muted);
    border-radius:10px;padding:7px 11px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}
  .favfilter:hover{border-color:var(--line2);color:var(--txt)}
  .favfilter.on{background:rgba(19,168,90,.14);border-color:rgba(19,168,90,.4);color:var(--hero)}
  /* transient toast (save confirmations + gating prompts) */
  #toast{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom,0px) + 100px);
    transform:translateX(-50%) translateY(12px);background:var(--elev);color:var(--txt);
    border:1px solid var(--line2);border-radius:12px;padding:11px 16px;font-size:13px;font-weight:600;
    z-index:60;opacity:0;pointer-events:none;max-width:86vw;text-align:center;
    box-shadow:0 10px 34px rgba(0,0,0,.45);transition:opacity .2s,transform .2s}
  #toast.on{opacity:1;transform:translateX(-50%) translateY(0)}
  /* MTB "roost" celebration — a dirt-spray burst + a 🚵 wheelie pop for delight moments (report,
     subscribe). Earthy roost tones (NOT condition colors, not generic confetti). Reduced-motion: JS-gated. */
  .mtb-cel{position:fixed;inset:0;z-index:100000;pointer-events:none;overflow:hidden}
  .mtb-cel .mtb-rider{position:absolute;font-size:42px;line-height:1;will-change:transform,opacity;
    animation:mtb-pop 1s cubic-bezier(.2,.7,.3,1) forwards;filter:drop-shadow(0 6px 10px rgba(0,0,0,.45))}
  .mtb-cel .mtb-clod{position:absolute;will-change:transform,opacity;box-shadow:0 1px 2px rgba(0,0,0,.35);
    animation:mtb-roost 1.05s cubic-bezier(.25,.6,.35,1) forwards}
  .mtb-cel .mtb-dust{position:absolute;width:14px;height:14px;border-radius:50%;will-change:transform,opacity;
    background:radial-gradient(circle,rgba(184,145,80,.5),rgba(184,145,80,0) 70%);animation:mtb-dust .9s ease-out forwards}
  @keyframes mtb-pop{0%{transform:translate(-50%,-50%) scale(0) rotate(0);opacity:0}
    28%{transform:translate(-50%,-160%) scale(1.16) rotate(-17deg);opacity:1}
    55%{transform:translate(-50%,-150%) scale(1) rotate(-6deg);opacity:1}
    100%{transform:translate(-50%,-110%) scale(.95) rotate(0);opacity:0}}
  @keyframes mtb-roost{0%{transform:translate(-50%,-50%) scale(.4) rotate(0);opacity:0}
    12%{opacity:1}
    42%{transform:translate(calc(-50% + var(--ux)),calc(-50% + var(--uy))) rotate(calc(var(--rot)*.5)) scale(1);opacity:1}
    100%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) rotate(var(--rot)) scale(.85);opacity:0}}
  @keyframes mtb-dust{0%{transform:translate(-50%,-50%) scale(.3);opacity:.55}
    100%{transform:translate(-50%,-50%) scale(2.6);opacity:0}}
  /* "saved trails are part of the Season Pass" gate modal (shown when a non-entitled user taps ♥) */
  #favGate{position:fixed;inset:0;z-index:70;display:none}
  #favGate.on{display:block}
  #favGate .fg-backdrop{position:absolute;inset:0;background:rgba(4,7,10,.66)}
  #favGate .fg-card{position:absolute;left:50%;top:50%;transform:translate(-50%,-46%);
    width:min(360px,calc(100vw - 40px));background:var(--panel);border:1px solid var(--line2);
    border-radius:18px;padding:24px 22px 20px;text-align:center;box-shadow:0 24px 60px rgba(0,0,0,.5);
    opacity:0;transition:opacity .2s,transform .2s}
  #favGate.on .fg-card{opacity:1;transform:translate(-50%,-50%)}
  #favGate .fg-icon{width:48px;height:48px;margin:0 auto 12px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;font-size:22px;
    color:var(--hero);background:rgba(19,168,90,.13);border:1px solid rgba(19,168,90,.4)}
  #favGate h3{margin:0 0 8px;font-size:19px;font-weight:800}
  #favGate p{margin:0 0 14px;color:var(--muted);font-size:13.5px;line-height:1.55}
  /* Season Pass payment modal (reused by ♥ gate, account panel, post-login) */
  #payModal,#welcomeModal{position:fixed;inset:0;z-index:72;display:none}
  #payModal.on,#welcomeModal.on{display:block}
  #payModal .pm-backdrop,#welcomeModal .pm-backdrop{position:absolute;inset:0;background:rgba(4,7,10,.66)}
  #payModal .pm-card,#welcomeModal .pm-card{position:absolute;left:50%;top:50%;transform:translate(-50%,-46%);
    width:min(392px,calc(100vw - 36px));max-height:92vh;overflow:auto;
    background:radial-gradient(135% 180px at 50% -6%, rgba(90,176,255,.16), transparent 68%), var(--panel);
    border:1px solid var(--line2);border-radius:18px;padding:24px 22px 20px;
    box-shadow:0 24px 60px rgba(0,0,0,.5);opacity:0;transition:opacity .2s,transform .2s}
  #payModal.on .pm-card,#welcomeModal.on .pm-card{opacity:1;transform:translate(-50%,-50%)}
  #payModal h3,#welcomeModal h3{margin:0 0 6px;font-size:20px;font-weight:800;text-align:center}
  #payModal .pm-sub,#welcomeModal .pm-sub{color:var(--muted);font-size:13px;line-height:1.55;text-align:center;margin:0 0 16px}
  #payModal .pm-perks{list-style:none;padding:0;margin:0 0 16px;display:grid;gap:8px}
  #payModal .pm-perks li{font-size:13px;color:#cdd8e4;display:flex;gap:9px;align-items:flex-start;line-height:1.4}
  #payModal .pm-perks li::before{content:"✓";color:var(--hero);font-weight:800;flex:none}
  /* post-purchase referral invite (thanks modal) — the high-affinity moment to bring a crew */
  #payModal .pm-invite{background:var(--panel2);border:1px solid var(--line);border-radius:14px;
    padding:13px 14px;margin:0 0 14px;text-align:left}
  #payModal .pm-invite b{display:block;font-size:13.5px;color:var(--txt);margin-bottom:3px}
  #payModal .pm-invite span{display:block;font-size:12px;color:var(--muted);line-height:1.45;margin-bottom:10px}
  #payModal .pm-invite .acct-btn{margin-top:0}
  .pay-plans{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:6px}
  .pay-plan{position:relative;text-align:left;background:var(--panel2);border:1px solid var(--line);
    border-radius:14px;padding:14px 13px 12px;cursor:pointer;display:flex;flex-direction:column;gap:2px;
    transition:border-color .15s,background .15s}
  .pay-plan:hover{border-color:var(--line2)}
  .pay-plan.sel{border-color:var(--accent);background:rgba(90,176,255,.09)}
  .pay-plan .pp-name{font-weight:800;font-size:13.5px;color:var(--txt)}
  .pay-plan .pp-price{font-size:23px;font-weight:800;color:var(--txt);margin-top:1px}
  .pay-plan .pp-price span{font-size:12px;font-weight:600;color:var(--muted)}
  .pay-plan .pp-sub{font-size:11.5px;color:var(--muted)}
  .pay-plan .pp-badge{position:absolute;top:-9px;right:10px;background:var(--accent);color:#04121f;
    font-size:9.5px;font-weight:800;padding:2px 7px;border-radius:999px;text-transform:uppercase;letter-spacing:.4px}
  #payModal .pm-note{font-size:11.5px;color:var(--faint);text-align:center;margin:12px 2px 0;line-height:1.5}
  /* P0.1 — embeddable conditions badge generator modal. A UTILITY (not an upsell), so a clean 14px
     card on the design tokens, NO accent glow. Reused from the region/area sheets (+ detail later). */
  #embedModal{position:fixed;inset:0;z-index:74;display:none}
  #embedModal.on{display:block}
  #embedModal .pm-backdrop{position:absolute;inset:0;background:rgba(4,7,10,.66)}
  #embedModal .pm-card{position:absolute;left:50%;top:50%;transform:translate(-50%,-46%);
    width:min(420px,calc(100vw - 36px));max-height:92vh;overflow:auto;background:var(--panel);
    border:1px solid var(--line2);border-radius:14px;padding:22px 20px 18px;
    box-shadow:0 24px 60px rgba(0,0,0,.5);opacity:0;transition:opacity .2s,transform .2s}
  #embedModal.on .pm-card{opacity:1;transform:translate(-50%,-50%)}
  #embedModal h3{margin:0 0 6px;font-size:19px;font-weight:800;text-align:center}
  #embedModal .pm-sub{color:var(--muted);font-size:13px;line-height:1.5;text-align:center;margin:0 0 16px}
  #embedModal .pm-note{font-size:11.5px;color:var(--faint);text-align:center;margin:12px 2px 0;line-height:1.5}
  /* free local-partner pin popup — themed dark to match (default MapLibre popup is white) */
  .lp-popup .maplibregl-popup-content{background:var(--elev);border:1px solid var(--line2);border-radius:14px;padding:0;overflow:hidden;box-shadow:0 18px 46px rgba(0,0,0,.6)}
  .lp-popup .maplibregl-popup-tip{border-top-color:var(--elev);border-bottom-color:var(--elev)}
  .lp-pop{display:flex;flex-direction:column;width:232px}
  .lp-pop .lp-logo{background:#fff;padding:14px;display:flex;align-items:center;justify-content:center;min-height:44px}
  .lp-pop .lp-logo img{max-height:46px;max-width:200px;object-fit:contain;display:block;
    filter:drop-shadow(0 0 1px rgba(0,0,0,.5)) drop-shadow(0 0 2px rgba(0,0,0,.3))}   /* keep white-knockout logos legible on the white tile */
  .lp-pop .lp-body{padding:13px 14px 14px}
  .lp-pop .lp-name{font-size:15.5px;font-weight:800;color:var(--txt);line-height:1.25}
  .lp-pop .lp-cat{display:inline-flex;align-items:center;gap:4px;margin-top:7px;font-size:10.5px;font-weight:800;letter-spacing:.3px;color:var(--muted);background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:3px 9px}
  .lp-pop .lp-blurb{margin:10px 0 0;font-size:12.5px;color:var(--muted);line-height:1.5}
  .lp-pop .lp-actions{display:flex;gap:8px;margin-top:13px}
  .lp-pop a.lp-go,.lp-pop a.lp-dir{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:12.5px;border-radius:11px;padding:9px 8px;text-decoration:none;white-space:nowrap}
  .lp-pop a.lp-go{background:var(--accent);color:#04121f;font-weight:800}
  .lp-pop a.lp-dir{background:var(--panel2);color:var(--txt);font-weight:700;border:1px solid var(--line2)}
  .lp-pop a.lp-go svg{width:14px;height:14px}
  .lp-pop a.lp-dir svg{width:14px;height:14px;color:var(--accent)}
  #embedModal .emb-prev{display:flex;align-items:center;justify-content:center;background:var(--panel2);
    border:1px solid var(--line);border-radius:14px;padding:18px 14px;margin:0 0 14px;min-height:92px}
  #embedModal .emb-prev img{max-width:100%;height:auto;display:block}
  #embedModal .emb-prev.emb-prev-frame{padding:6px;overflow:hidden}
  #embedModal .emb-prev iframe{width:100%;border:0;border-radius:10px;display:block}
  #embedModal .emb-seg-row{display:flex;gap:22px;margin:0 0 14px}
  #embedModal .emb-seg-l{display:block;font-size:11px;font-weight:800;color:var(--muted);
    text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}
  #embedModal .emb-chips{display:flex;gap:6px}
  #embedModal .emb-chip{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
    border-radius:999px;padding:5px 13px;font-size:12px;font-weight:700;cursor:pointer}
  #embedModal .emb-chip.sel{border-color:var(--accent);color:var(--accent);background:rgba(90,176,255,.10)}
  #embedModal .emb-snip{width:100%;box-sizing:border-box;background:var(--panel2);border:1px solid var(--line);
    border-radius:11px;color:var(--txt);font:12px/1.5 ui-monospace,SFMono-Regular,Menlo,monospace;
    padding:11px 12px;resize:none;margin:0}
  /* sponsor / partner "who is this?" modal — opened from the map chip + the "presented by" cards.
     Mirrors the local-pin popup (.lp-pop): a white logo banner up top, then a tinted body with the
     name, a kind pill, the blurb, and matching action buttons — just a bigger, centered modal. */
  #sponsorModal{position:fixed;inset:0;z-index:74;display:none}
  #sponsorModal.on{display:block}
  #sponsorModal .pm-backdrop{position:absolute;inset:0;background:rgba(4,7,10,.66)}
  #sponsorModal .spm-card{position:absolute;left:50%;top:50%;transform:translate(-50%,-46%);
    width:min(360px,calc(100vw - 36px));max-height:92vh;overflow:hidden;background:var(--elev);
    border:1px solid var(--line2);border-radius:14px;padding:0;
    box-shadow:0 24px 60px rgba(0,0,0,.5);opacity:0;transition:opacity .2s,transform .2s}
  #sponsorModal.on .spm-card{opacity:1;transform:translate(-50%,-50%)}
  #sponsorModal .spm-x{position:absolute;top:9px;right:9px;width:28px;height:28px;border:0;border-radius:999px;
    background:rgba(12,18,26,.55);color:#fff;font-size:12px;font-weight:700;cursor:pointer;z-index:2;
    display:flex;align-items:center;justify-content:center}
  #sponsorModal .spm-banner{background:#fff;padding:22px 20px;display:flex;align-items:center;justify-content:center;min-height:58px}
  /* drop-shadow follows the logo's alpha → a thin dark halo round every opaque pixel, so a white-
     knockout logo (white text on transparency, made for dark backgrounds) stays legible on white;
     near-invisible on dark/coloured logos. Same idea the canvas map markers use. */
  #sponsorModal .spm-banner img{max-height:66px;max-width:80%;object-fit:contain;display:block;
    filter:drop-shadow(0 0 1px rgba(0,0,0,.55)) drop-shadow(0 0 2.5px rgba(0,0,0,.34))}
  #sponsorModal .spm-body{padding:16px 18px 18px}
  #sponsorModal .spm-name{font-size:19px;font-weight:800;color:var(--txt);line-height:1.25}
  #sponsorModal .spm-status{display:inline-flex;align-items:center;gap:5px;margin-top:9px;font-size:10.5px;
    font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);background:var(--panel2);
    border:1px solid var(--line);border-radius:999px;padding:4px 10px}
  #sponsorModal .spm-status.partner{color:var(--accent);background:rgba(90,176,255,.10);border-color:rgba(90,176,255,.4)}
  #sponsorModal .spm-blurb{margin:12px 0 0;font-size:13px;color:var(--muted);line-height:1.55}
  #sponsorModal .spm-actions{display:flex;gap:8px;margin-top:16px}
  #sponsorModal .spm-actions a{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;
    font-size:13px;border-radius:11px;padding:10px 10px;text-decoration:none;white-space:nowrap}
  #sponsorModal .spm-go{background:var(--accent);color:#04121f;font-weight:800}
  #sponsorModal .spm-donate{background:var(--panel2);color:var(--txt);font-weight:700;border:1px solid var(--line2)}
  #sponsorModal .spm-go svg{width:14px;height:14px}
  #sponsorModal .spm-donate svg{width:14px;height:14px;color:var(--accent)}
  /* Season Pass upsell — a HERO perk (the native app) over a lighter supporting list, on ONE
     cohesive surface (the accent glow lives on .pm-card above, so it's clipped to the rounded
     corners — no rectangular seam). The thanks modal keeps the plain .pm-perks checklist above. */
  #payModal .pm-hero{text-align:center;margin-bottom:16px}
  #payModal .pm-chip,#welcomeModal .pm-chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:800;
    color:#04121f;background:var(--accent);border-radius:999px;padding:4px 11px;letter-spacing:.3px;
    margin-bottom:12px;box-shadow:0 5px 16px -5px rgba(90,176,255,.65)}
  /* the native-app HERO — the marquee perk, deliberately dominant */
  #payModal .pm-hero-feat{display:flex;align-items:flex-start;gap:13px;text-align:left;margin-bottom:16px;
    border:1px solid rgba(90,176,255,.42);border-radius:14px;padding:15px 15px 16px;
    background:linear-gradient(160deg,rgba(90,176,255,.17),rgba(90,176,255,.02) 72%)}
  #payModal .pm-hero-feat .pm-pic{width:44px;height:44px;border-radius:12px;
    background:rgba(90,176,255,.2);border-color:rgba(90,176,255,.42)}
  #payModal .pm-hero-feat .pm-pic svg{width:23px;height:23px}
  #payModal .pm-hero-feat .pm-tx b{font-size:15px}
  #payModal .pm-hero-feat .pm-tx span{font-size:12.5px}
  /* the supporting list (alerts, plan) — lighter, so the hierarchy reads hero-then-rest */
  #payModal .pm-list-label{font-size:10px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;
    color:var(--faint);margin:0 2px 7px}
  #payModal .pm-list{margin:0 0 16px}
  #payModal .pm-row{display:flex;align-items:flex-start;gap:12px;text-align:left;padding:10px 2px}
  #payModal .pm-row + .pm-row{border-top:1px solid var(--line)}
  /* shared icon tile + text used by the hero + the rows */
  #payModal .pm-pic{flex:none;display:flex;align-items:center;justify-content:center;
    width:38px;height:38px;border-radius:11px;color:var(--accent);
    background:rgba(90,176,255,.12);border:1px solid rgba(90,176,255,.28)}
  #payModal .pm-pic svg{width:20px;height:20px}
  #payModal .pm-tx{flex:1;min-width:0}
  #payModal .pm-tx b{display:flex;flex-wrap:wrap;align-items:center;gap:5px 7px;font-size:13.5px;
    font-weight:800;color:#eaf1f8;margin-bottom:3px;letter-spacing:-.1px}
  #payModal .pm-tx span{display:block;font-size:12px;color:#9fb0c0;line-height:1.5}
  #payModal .pm-tag{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;
    color:var(--accent);background:rgba(90,176,255,.15);border:1px solid rgba(90,176,255,.34);
    border-radius:999px;padding:2px 7px;flex:none}
  #payModal .pm-trust{font-size:11.5px;color:var(--faint);text-align:center;margin:0 0 14px;line-height:1.5}
  /* account sheet */
  .acct-title{font-size:21px;font-weight:800;margin:0;line-height:1.2}
  .acct-sub{color:var(--muted);font-size:13px;margin:8px 0 0;line-height:1.5}
  .acct-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px;margin-top:14px}
  .acct-card h4{margin:0 0 4px;font-size:13px;font-weight:800;letter-spacing:.2px;text-transform:uppercase;color:var(--muted)}
  .acct-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
  .acct-field{width:100%;background:var(--panel2);border:1px solid var(--line);border-radius:11px;
    color:var(--txt);padding:11px 13px;font-size:14px;outline:none;transition:.15s;margin-top:10px}
  .acct-field:focus{border-color:var(--accent);background:var(--elev)}
  .acct-btn{width:100%;margin-top:10px;background:var(--accent);color:#04121f;border:0;border-radius:11px;
    padding:12px;font-weight:800;font-size:14px;cursor:pointer;transition:.14s}
  .acct-btn:hover{filter:brightness(1.06)} .acct-btn:disabled{opacity:.55;cursor:default}
  .acct-btn.ghost{background:var(--panel2);color:var(--txt);border:1px solid var(--line)}
  .acct-btn.ghost:hover{border-color:var(--line2);filter:none}
  .acct-btn.row{width:auto;margin-top:0;padding:9px 14px;font-size:13px}
  .acct-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;
    font-size:12px;font-weight:800;letter-spacing:.2px}
  .acct-pill.ent{color:var(--hero);background:rgba(19,168,90,.14);border:1px solid rgba(19,168,90,.4)}
  .acct-pill.free{color:var(--muted);background:var(--panel2);border:1px solid var(--line)}
  .acct-note{color:var(--muted);font-size:12.5px;line-height:1.5;margin-top:10px}
  .acct-org{border-top:1px solid var(--line);padding:12px 0 2px;margin-top:4px}
  .acct-org:first-of-type{border-top:0}
  .acct-orgname{font-weight:700;font-size:14.5px}
  .acct-orgmeta{color:var(--muted);font-size:12px;margin-top:2px}
  .acct-alerts{margin-top:12px}
  /* Alerts: account-level pref toggles (trail/weekly × email/push). One switch shape. */
  .alt-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-top:1px solid var(--line)}
  .alt-row:first-child{border-top:0}
  .alt-grow{flex:1;min-width:0}
  .alt-t{font-weight:800;font-size:13.5px;color:var(--txt)}
  .alt-d{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.45}
  .alt-sub{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--faint);margin:14px 0 0}
  .alt-sw{flex:none;width:44px;height:26px;border-radius:999px;border:1px solid var(--line2);
    background:var(--panel2);position:relative;cursor:pointer;padding:0;transition:background .15s,border-color .15s}
  .alt-sw::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:999px;
    background:var(--muted);transition:transform .15s,background .15s}
  .alt-sw.on{background:var(--accent);border-color:var(--accent)}
  .alt-sw.on::after{transform:translateX(18px);background:#06121f}
  .alt-sw[disabled]{opacity:.5;cursor:default}
  /* Recommendation schedule: day-of-week chips + a morning/evening segment. */
  .alt-sched{margin:10px 0 2px;padding:13px;background:var(--panel2);border:1px solid var(--line);border-radius:11px}
  .alt-lbl{font-size:11px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:var(--faint);margin:0 0 8px}
  .alt-days{display:flex;gap:6px;flex-wrap:wrap}
  .alt-day{width:32px;height:32px;border-radius:999px;border:1px solid var(--line2);background:transparent;
    color:var(--muted);font-weight:800;font-size:12px;cursor:pointer;padding:0;transition:background .12s,color .12s}
  .alt-day.on{background:var(--accent);border-color:var(--accent);color:#06121f}
  .alt-day[disabled]{opacity:.5;cursor:default}
  .alt-presets{display:flex;gap:14px;margin-top:11px}
  .alt-preset{font-size:11.5px;font-weight:700;color:var(--accent);background:transparent;border:0;cursor:pointer;padding:0;text-decoration:underline}
  .alt-seg{display:inline-flex;margin-top:4px;border:1px solid var(--line2);border-radius:11px;overflow:hidden}
  .alt-seg button{border:0;background:transparent;color:var(--muted);font-weight:700;font-size:12.5px;padding:8px 15px;cursor:pointer}
  .alt-seg button.on{background:var(--accent);color:#06121f}
  .acct-member{display:flex;justify-content:space-between;gap:8px;font-size:13px;color:#cdd8e4;padding:5px 0}
  .acct-member .role{color:var(--faint);font-size:11.5px;text-transform:uppercase;letter-spacing:.3px}
  .acct-msg{font-size:13px;margin-top:10px;line-height:1.5}
  .acct-msg.ok{color:var(--hero)} .acct-msg.err{color:var(--muddy)}
  .acct-inline{display:flex;gap:8px;margin-top:10px}
  .acct-inline .acct-field{margin-top:0}
  /* O1: org "Manage trail status" panel */
  .org-verified{color:var(--hero);font-weight:800}
  .cls-item{align-items:flex-start}
  .cls-off{opacity:.55}
  .cls-tgtrow{display:flex;gap:8px;margin-top:10px}
  .cls-tgt-btn{flex:1;background:var(--panel2);color:var(--txt);border:1px solid var(--line);
    border-radius:11px;padding:9px;font-weight:700;font-size:13px;cursor:pointer}
  .cls-tgt-btn.on{background:var(--accent);color:#04121f;border-color:var(--accent)}
  .cls-results{border:1px solid var(--line);border-radius:11px;margin-top:6px;overflow:hidden}
  .cls-res{padding:9px 12px;font-size:13px;cursor:pointer;border-top:1px solid var(--line)}
  .cls-res:first-child{border-top:0}
  .cls-res:hover{background:var(--panel2)}
  /* O1 slice 3: rider-facing closure banner (detail) + chip (board card). A distinct hazard
     look (slate + amber stripe) — deliberately OUTSIDE the green→red condition palette. */
  .closure-banner{display:flex;gap:11px;align-items:flex-start;border:1px solid #4d3c1d;
    border-left:4px solid #e7a93a;border-radius:14px;padding:12px 14px;margin:2px 0 14px;
    background-color:#241d12;
    background-image:repeating-linear-gradient(45deg,transparent 0 9px,rgba(231,169,58,.05) 9px 18px)}
  .closure-banner .cb-ic{font-size:19px;line-height:1.15}
  .closure-banner .cb-t{font-weight:800;font-size:13px;color:#f1d8a3;letter-spacing:.2px;text-transform:uppercase}
  .closure-banner .cb-msg{color:var(--txt);font-size:13.5px;margin-top:3px;line-height:1.45}
  .closure-banner .cb-org{color:var(--muted);font-size:11.5px;margin-top:5px}
  .closure-chip{display:inline-flex;align-items:center;gap:5px;background:#2a2114;border:1px solid #5a4620;
    color:#ecc474;font-weight:800;font-size:11px;padding:3px 9px;border-radius:999px;
    letter-spacing:.2px;margin:7px 0 1px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  /* admin gravel-lens chip on board cards (gravel mode only) */
  .disc-chip{display:inline-flex;align-items:center;gap:5px;border:1px solid;border-radius:999px;
    font-size:10.5px;font-weight:800;padding:3px 9px;margin:6px 0 1px;max-width:100%;overflow:hidden;
    text-overflow:ellipsis;white-space:nowrap}
  /* O5: trail-curation search results (show/hide). */
  .tr-res{display:flex;justify-content:space-between;align-items:center;gap:10px}
  .gpx-card{border:1px dashed var(--line2);border-radius:14px;padding:13px 14px;margin-top:14px}
  /* O1: inline "Trail org tools" card on the trail page (verified-org admins). */
  .manage-card{background:var(--panel);border:1px solid var(--line2);border-radius:14px;padding:13px 15px;margin:2px 0 14px}
  .manage-h{font-size:12.5px;font-weight:800;letter-spacing:.2px;color:var(--txt);margin-bottom:4px}
  .manage-card .acct-field{margin-top:8px}
  .manage-card .tm-publish{margin-top:10px}
  /* O1 slice 4: "Support <org>" give-back card (detail + region sheet). Goodwill, not data. */
  .support-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-top:14px}
  .support-h{font-size:13px;font-weight:800;letter-spacing:.2px;text-transform:uppercase;color:var(--muted)}
  .support-sub{color:var(--muted);font-size:12.5px;line-height:1.5;margin-top:4px}
  .support-link{display:inline-block;margin:10px 8px 0 0;background:var(--panel2);border:1px solid var(--line2);
    color:var(--accent);border-radius:11px;padding:9px 13px;font-weight:800;font-size:13px;text-decoration:none}
  .support-link:hover{border-color:var(--accent);filter:brightness(1.06)}
  /* O2: "✓ Verified by <org>" curated metadata card (detail). Authoritative descriptive facts. */
  .curated-card{background:var(--panel);border:1px solid rgba(19,168,90,.35);border-radius:14px;padding:13px 15px;margin:2px 0 14px}
  .curated-h{font-size:12.5px;font-weight:800;letter-spacing:.2px;color:var(--hero);margin-bottom:6px}
  .curated-row{display:flex;justify-content:space-between;gap:12px;padding:4px 0;font-size:13px;border-top:1px solid var(--line)}
  .curated-row:first-of-type{border-top:0}
  .curated-k{color:var(--muted)} .curated-v{color:var(--txt);font-weight:600;text-align:right}
  /* O4: labeled "presented by" sponsor placement (region sheet). Clearly sponsorship, not data. */
  .sponsor-card{display:block;text-decoration:none;background:var(--panel2);border:1px dashed var(--line2);
    border-radius:14px;padding:12px 15px;margin-top:14px;cursor:pointer}
  .sponsor-card:hover{border-color:var(--accent)}
  /* a trail-data partner gets a solid, lightly accented frame — a touch more "official" than a commercial sponsor */
  .sponsor-card.partner{border-style:solid;border-color:rgba(90,176,255,.32)}
  .sponsor-card.partner:hover{border-color:var(--accent)}
  .sp-tag{font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--faint)}
  .sp-row{display:flex;align-items:center;gap:11px;margin-top:6px}
  .sp-logo{width:38px;height:38px;border-radius:9px;object-fit:contain;background:#fff1}
  .sp-name{font-weight:800;font-size:14.5px;color:var(--txt)}
  .sp-blurb{color:var(--muted);font-size:12px;margin-top:2px}
  /* O3: org dashboard — grant-ready engagement numbers. */
  .dash-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-top:12px}
  .dash-stat{background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:11px 8px;text-align:center}
  .dash-n{font-size:20px;font-weight:800;color:var(--txt)}
  .dash-l{font-size:10.5px;color:var(--muted);margin-top:2px;line-height:1.2}
  /* P1.3: Season Impact Report — a printable, board/grant-ready one-pager over api_org_dashboard.
     A white "paper" document on a dark backdrop; the @media print block isolates it to a clean PDF
     (the $0 export path — browser "Save as PDF", no PDF lib, principle #6). */
  #impactOverlay{position:fixed;inset:0;z-index:130;background:rgba(6,9,14,.86);
    -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:none;overflow:auto;padding:22px 14px 60px}
  #impactOverlay.on{display:block}
  .ir-bar{max-width:760px;margin:0 auto 13px;display:flex;justify-content:space-between;align-items:center;gap:10px}
  .ir-bar .ir-ttl{font-size:13px;font-weight:800;color:#fff;letter-spacing:.3px}
  .ir-bar .right{display:flex;gap:8px}
  .ir-paper{max-width:760px;margin:0 auto;background:#fff;color:#10202f;border-radius:14px;overflow:hidden;
    box-shadow:0 30px 80px -30px rgba(0,0,0,.6);
    font:14px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
  .ir-head{padding:26px 30px 22px;background:linear-gradient(120deg,#0e1320,#16233a);color:#fff}
  .ir-brand{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:#9fb4c9}
  .ir-brand b{background:linear-gradient(120deg,#5ee0a0,#5ab8ff);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
  .ir-kick{margin:14px 0 3px;font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:#5ee0a0}
  .ir-h1{margin:0;font-size:28px;font-weight:800;line-height:1.12}
  .ir-period{margin:9px 0 0;font-size:12.5px;color:#9fb4c9}
  .ir-body{padding:24px 30px 28px}
  .ir-lead{font-size:15.5px;line-height:1.5;color:#27384a;margin:0 0 22px}
  .ir-lead b{color:#10202f}
  .ir-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0 0 26px}
  .ir-stat{border:1px solid #e6ebf1;border-radius:11px;padding:14px 10px;text-align:center;background:#f8fafc}
  .ir-n{font-size:26px;font-weight:800;color:#10202f;line-height:1}
  .ir-l{margin-top:6px;font-size:11px;font-weight:700;color:#5b6b7a;line-height:1.3}
  .ir-sec{margin:0 0 22px}
  .ir-sech{font-size:12px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:#5b6b7a;
    border-bottom:1px solid #eef2f6;padding-bottom:7px;margin:0 0 9px}
  .ir-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:7px 0;border-bottom:1px solid #f2f5f8}
  .ir-row:last-child{border-bottom:0}
  .ir-row .nm{font-weight:600;color:#1c2c3a;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .ir-row .vv{font-weight:800;color:#10202f;white-space:nowrap}
  .ir-note{font-size:13px;color:#5b6b7a;line-height:1.5}
  .ir-foot{border-top:1px solid #eef2f6;margin-top:6px;padding-top:14px;font-size:11.5px;color:#7a8896;line-height:1.55}
  @media (max-width:560px){.ir-grid{grid-template-columns:repeat(2,1fr)}.ir-head{padding:22px 18px 18px}.ir-body{padding:20px 18px 24px}.ir-h1{font-size:23px}}
  @media print{
    body>*{display:none!important}
    #impactOverlay{display:block!important;position:static;background:#fff;padding:0;overflow:visible}
    #impactOverlay .ir-bar{display:none!important}
    .ir-paper{max-width:none;margin:0;box-shadow:none;border-radius:0}
    .ir-stat{background:#fff}
    .ir-head{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  }
  /* admin panel (site admins only) */
  .admin-back{background:none;border:0;color:var(--muted);font-size:26px;line-height:1;cursor:pointer;
    padding:0 4px;margin-left:-4px}
  .admin-back:hover{color:var(--txt)}
  .adm-link{display:block;border:1px solid var(--line);background:var(--panel2)}
  .adm-link:hover{border-color:var(--line2)}
  .adm-dim{color:var(--faint);font-weight:600;font-size:11.5px;text-transform:none;letter-spacing:0}
  .adm-btnrow{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
  .adm-dev{border-top:1px solid var(--line);padding:13px 0 4px}
  .adm-dev:first-child{border-top:0}
  .adm-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
  .adm-badge{font-size:11px;font-weight:700;color:var(--muted);background:var(--panel2);
    border:1px solid var(--line);border-radius:999px;padding:3px 9px;letter-spacing:.2px}
  .adm-badge.ok{color:var(--hero);background:rgba(19,168,90,.12);border-color:rgba(19,168,90,.4)}
  .adm-badge.warn{color:var(--dusty);background:rgba(214,158,46,.1);border-color:rgba(214,158,46,.4)}
  .adm-ua{color:var(--faint);font-size:11px;margin-top:7px;word-break:break-all;line-height:1.4}
  .adm-result{margin-top:8px}
  .adm-result:empty{display:none}
  /* admin → organizations */
  .admo-row{display:block;width:100%;text-align:left;cursor:pointer;background:none;border:0;
    border-top:1px solid var(--line);padding:13px 2px}
  .admo-row:first-child{border-top:0}
  .admo-row:hover{background:var(--panel2)}
  .admo-check{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:13px;color:var(--txt)}
  .admo-role{background:var(--panel2);border:1px solid var(--line);border-radius:8px;color:var(--txt);
    padding:4px 6px;font-size:12px}
  .admo-x,.admo-cancel,.admo-jx{background:none;border:0;color:var(--muted);cursor:pointer;
    font-size:15px;line-height:1;padding:0 4px}
  .admo-x:hover,.admo-cancel:hover,.admo-jx:hover{color:var(--muddy)}
  /* Admin → Backlog (internal task list). Priority pills are MONOCHROME by intensity (label
     carries the meaning) so they never borrow a rider-facing condition color. */
  .tk-row{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-top:1px solid var(--line)}
  .tk-row:first-child{border-top:0}
  .tk-main{flex:1;min-width:0}
  .tk-title{font-size:13.5px;color:var(--txt);line-height:1.35;word-break:break-word}
  .tk-row.done .tk-title{color:var(--faint);text-decoration:line-through}
  .tk-tags{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap;align-items:center}
  .tk-check{flex:none;width:20px;height:20px;border-radius:999px;border:1.5px solid var(--line2);
    background:none;color:var(--accent);cursor:pointer;font-size:11px;line-height:17px;padding:0;text-align:center;margin-top:1px}
  .tk-check:hover{border-color:var(--accent)}
  .tk-row.done .tk-check{border-color:var(--accent);background:rgba(99,160,255,.12)}
  .tk-pri{font-size:10.5px;font-weight:800;letter-spacing:.3px;border-radius:999px;padding:2px 9px;border:1px solid;text-transform:uppercase}
  .pri-high{color:var(--txt);background:var(--elev);border-color:var(--line2)}
  .pri-med{color:var(--muted);background:var(--panel2);border-color:var(--line)}
  .pri-low{color:var(--faint);background:none;border-color:var(--line)}
  .dtop{display:flex;gap:14px;align-items:center}
  .dname{font-size:21px;font-weight:800;margin:0;line-height:1.15;flex:1}
  .dvibe{display:flex;align-items:center;gap:12px;margin-top:10px;flex-wrap:wrap}
  .dwhy{color:#cdd8e4;font-size:13px;margin-top:9px}
  .kv{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
  .kv span{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:5px 9px;
    font-size:12px;color:var(--muted)}
  .kv b{color:var(--txt);font-weight:700}
  .section{margin-top:22px}
  .section h4{margin:0 0 10px;font-size:11.5px;color:var(--muted);text-transform:uppercase;
    letter-spacing:.8px;font-weight:700}
  /* "blown out? ride here instead" — alternatives block */
  .altsec h4{color:#39c47a}
  .alts{display:flex;flex-direction:column;gap:8px}
  .altcard{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;
    text-align:left;cursor:pointer;background:linear-gradient(180deg,var(--panel2),#0f151c);
    border:1px solid var(--line);border-radius:13px;padding:11px 13px;color:var(--txt)}
  .altcard:hover{border-color:var(--line2)}
  .altcard .altname{font-weight:800;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .altcard .altmeta{display:flex;align-items:center;gap:9px;flex:0 0 auto}
  .altcard .cpill{font-size:10px;font-weight:800;border-radius:7px;padding:3px 7px;white-space:nowrap}
  .altcard .altdist{color:var(--muted);font-size:11.5px;font-weight:700;white-space:nowrap}
  .strip{display:flex;gap:8px;overflow-x:auto;padding:2px 1px 10px;scroll-snap-type:x proximity}
  .strip::-webkit-scrollbar{height:6px}
  .strip::-webkit-scrollbar-thumb{background:var(--line2);border-radius:3px}
  .day{flex:0 0 86px;scroll-snap-align:start;text-align:center;position:relative;overflow:hidden;
    background:linear-gradient(180deg,var(--panel2),#0f151c);border:1px solid var(--line);
    border-radius:15px;padding:9px 7px 11px}
  .day::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--c)}
  .day.today{border-color:var(--c);box-shadow:0 0 0 1px var(--c) inset, 0 6px 18px -8px var(--c)}
  .day .d{font-size:11.5px;font-weight:800;letter-spacing:.2px}
  .day .dn{font-size:9.5px;color:var(--faint);margin-top:1px}
  .day .ic{height:38px;display:flex;align-items:center;justify-content:center;margin:5px 0 3px}
  .day .tmp{font-size:13px;font-weight:800}
  .day .tmp small{color:var(--faint);font-weight:700;font-size:11px}
  .day .rain{font-size:10px;color:#6aa6e6;font-weight:700;height:1.25em;margin-top:1px}
  .day .cpill{margin-top:8px;font-size:9.5px;font-weight:800;border-radius:7px;padding:4px 2px;
    line-height:1.12;min-height:2.6em;display:flex;align-items:center;justify-content:center;text-align:center}
  .day .sc{font-size:18px;font-weight:900;margin-top:6px;letter-spacing:.3px}
  .day{cursor:pointer;transition:transform .12s,border-color .12s}
  .day:hover{transform:translateY(-2px)}
  .day.sel{border-color:var(--c);box-shadow:0 0 0 1.5px var(--c) inset,0 8px 22px -10px var(--c)}
  .day .caret{position:absolute;bottom:2px;left:50%;transform:translateX(-50%);
    color:var(--c);font-size:9px;opacity:0;transition:.12s}
  .day.sel .caret{opacity:1}
  /* extended-outlook (web freemium): days 6-10 are a Season Pass perk. Entitled see them slightly
     muted ("outlook, lower confidence"); non-entitled see the REAL cells blurred behind an unlock
     CTA — the same visible-but-gated pattern as the gravel lens, never hides the honest near read. */
  .ext-wrap{margin-top:12px;border-top:1px dashed var(--line2);padding-top:11px}
  .ext-h{font-size:10.5px;font-weight:800;color:var(--faint);letter-spacing:.4px;text-transform:uppercase;margin-bottom:8px}
  .ext-strip .day{opacity:.82}
  .ext-teaser{position:relative}
  .ext-blur{filter:blur(4px) saturate(.85);opacity:.6;pointer-events:none;user-select:none}
  .ext-cta{position:absolute;inset:0;margin:auto;height:fit-content;display:flex;flex-direction:column;
    align-items:center;justify-content:center;gap:3px;background:transparent;border:none;cursor:pointer}
  .ext-cta span{font-size:13px;font-weight:800;background:var(--accent);color:#08121f;
    padding:9px 15px;border-radius:999px;box-shadow:0 6px 20px -6px rgba(0,0,0,.6)}
  .ext-cta small{font-size:10.5px;color:var(--txt);font-weight:700}
  /* day-slider "extended outlook" zone (days 6-10). Shown to EVERYONE so the range is visible:
     free riders see it hatched/locked (gold teaser); Season Pass riders see it solid gold. A
     boundary lock glyph marks where the free 5-day forecast ends (closed for free, open for paid). */
  .sl-zone{position:absolute;height:6px;border-radius:0 3px 3px 0;pointer-events:none}
  .sl-zone.locked{background:repeating-linear-gradient(45deg,rgba(255,212,121,.24) 0 6px,rgba(255,212,121,.06) 6px 12px)}
  .sl-zone.ext{background:rgba(255,212,121,.30)}
  /* day "steps" — subtle ruler ticks at each forecast day, so the track reads as a timeline */
  .sl-ticks{position:absolute;left:0;right:0;top:50%;pointer-events:none}
  .sl-ticks i{position:absolute;top:0;width:2px;height:8px;border-radius:1px;
    background:rgba(255,255,255,.22);transform:translate(-50%,-50%)}
  /* the free→paid boundary LOCK: a bare gold glyph UNDER the track at the divide (no circle).
     Closed for free, open for paid. Gold = the "extended outlook" premium tier (matches .sl-zone);
     kept subtle — it marks the divide, doesn't shout. */
  .sl-lock{position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%);
    color:#ffd479;line-height:0;pointer-events:none}
  .sl-lock svg{width:13px;height:13px;display:block}
  .sl-lock .lk-open{display:none}
  .sl-lock.unlocked{color:rgba(255,212,121,.8)}
  .sl-lock.unlocked .lk-closed{display:none}
  .sl-lock.unlocked .lk-open{display:block}
  .dayexp{margin-top:10px;border:1px solid var(--line);border-radius:14px;overflow:hidden;
    background:linear-gradient(180deg,var(--panel2),#0f151c)}
  .dayexp .eh{display:flex;align-items:center;justify-content:space-between;gap:10px;
    padding:12px 14px;border-bottom:1px solid var(--line)}
  .dayexp .when{display:flex;align-items:center;gap:9px}
  .dayexp .clock{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;
    justify-content:center;font-size:17px;flex:none}
  .dayexp .wlab{font-size:15px;font-weight:800;line-height:1.1}
  .dayexp .wsub{font-size:11.5px;color:var(--muted);margin-top:2px}
  .dayexp .ebody{padding:10px 12px 6px}
  .dayexp .reason{font-size:12.5px;color:#cdd8e4;padding:0 14px 12px}
  .bt{margin-top:9px;font-size:11.5px;color:#bfe3cf;font-weight:700;display:inline-flex;gap:5px;align-items:center}
  /* report modal */
  .rep-trigger{width:100%;padding:11px;border-radius:11px;border:1px solid var(--line);
    background:var(--panel2);color:var(--txt);cursor:pointer;font-size:13.5px;font-weight:700;text-align:center}
  .rep-trigger:hover{border-color:var(--accent)}
  /* near-trail check — proximity-gated "is today's read right?" (only when you're at the trail) */
  #trailCheckSlot{display:none}
  #trailCheckSlot.on{display:block}
  .tcheck{position:relative;background:var(--panel2);border:1px solid var(--accent);border-radius:14px;padding:13px 14px 12px;margin:0 0 12px}
  .tcheck .tc-q{font-size:13.5px;color:var(--txt);line-height:1.45;padding-right:20px}
  .tcheck .tc-q b{font-weight:800}
  .tcheck .tc-row{display:flex;gap:8px;margin-top:11px;flex-wrap:wrap}
  .tcheck .tc-yes,.tcheck .tc-no{flex:1 1 0;min-width:120px;font-size:13px;font-weight:800;border-radius:11px;padding:9px 10px;cursor:pointer;border:1px solid var(--line2);background:var(--elev);color:var(--txt)}
  .tcheck .tc-yes{background:var(--accent);color:#04121f;border-color:transparent}
  .tcheck .tc-chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
  .tcheck .tc-chips[hidden]{display:none}
  .tcheck .tc-chips button{font-size:12px;font-weight:700;border-radius:999px;padding:6px 11px;cursor:pointer;border:1px solid var(--line2);background:var(--elev);color:var(--txt)}
  .tcheck .tc-chips button:hover{border-color:var(--accent)}
  .tcheck .tc-x{position:absolute;top:7px;right:8px;width:24px;height:24px;border:0;background:transparent;color:var(--muted);font-size:13px;cursor:pointer;border-radius:8px}
  .tcheck .tc-x:hover{color:var(--txt)}
  .rep-modal{display:none;margin-top:10px;border:1px solid var(--line);border-radius:14px;
    padding:14px;background:var(--panel2)}
  .rep-modal.open{display:block}
  .rep{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:10px}
  .rep button{flex:1 1 0;min-width:88px;padding:9px 6px;border-radius:10px;border:1px solid var(--line);
    background:var(--bg);color:var(--txt);cursor:pointer;font-size:12px;font-weight:600;transition:.15s}
  .rep button:hover,.rep button.sel{border-color:var(--accent);background:var(--elev)}
  .rep button.sel{font-weight:800}
  .rep-note{width:100%;box-sizing:border-box;background:var(--bg);border:1px solid var(--line);
    border-radius:10px;color:var(--txt);font-size:13px;padding:9px 11px;resize:vertical;min-height:60px;
    font-family:inherit;margin-bottom:10px}
  .rep-note:focus{outline:none;border-color:var(--accent)}
  .rep-submit{width:100%;padding:11px;border-radius:11px;border:0;
    background:linear-gradient(120deg,#5ab0ff,#37b3a8);color:#04121f;font-weight:800;
    cursor:pointer;font-size:13.5px}
  .rep-submit:disabled{opacity:.5;cursor:default}
  .elnote{color:var(--muted);font-size:11.5px;margin:-4px 0 10px}
  /* community feedback feed (last 7 days) + supporter badge */
  .gt-feed{margin-bottom:12px;display:flex;flex-direction:column;gap:9px}
  .gt-feed-h{font-size:11.5px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;
    color:var(--muted);margin-bottom:2px}
  .gt-item{border:1px solid var(--line);border-radius:12px;padding:10px 12px;background:var(--panel2)}
  .gt-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .gt-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--txt)}
  .gt-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
  .gt-by{font-size:12px;color:var(--muted);margin-left:auto;display:inline-flex;align-items:center;gap:6px}
  .gt-auth{color:#cdd8e4;font-weight:700;background:none;border:0;padding:0;cursor:pointer;font-size:12px}
  .gt-auth:hover{color:var(--accent);text-decoration:underline}
  .gt-when{color:var(--faint)}
  .gt-note{font-size:12.5px;color:#cdd8e4;margin-top:7px;line-height:1.4}
  /* avatar (image or initial-letter circle) */
  .av{border-radius:50%;flex:0 0 auto;object-fit:cover;vertical-align:middle}
  .av-i{display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:800;line-height:1}
  /* delete (trash) on own/admin reports */
  .gt-del{background:none;border:0;cursor:pointer;font-size:12.5px;opacity:.5;padding:0 2px;line-height:1}
  .gt-del:hover{opacity:1;filter:saturate(1.4)}
  .gt-del:disabled{opacity:.25;cursor:default}
  .sup-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:800;
    color:#04121f;background:var(--accent);border-radius:6px;padding:1px 6px;letter-spacing:.02em;line-height:1.5}
  /* "posting as" context above the report button */
  .posting-as{font-size:11.5px;color:var(--muted);margin-bottom:9px}
  .posting-as b{color:#cdd8e4}
  .posting-as .pa-link{color:var(--accent);background:none;border:0;padding:0;cursor:pointer;font:inherit}
  .pa-name{display:flex;gap:7px;margin-top:7px}
  .pa-name input{flex:1;min-width:0;background:var(--bg);border:1px solid var(--line);border-radius:9px;
    color:var(--txt);font-size:12.5px;padding:7px 10px}
  .pa-name input:focus{outline:none;border-color:var(--accent)}
  .pa-name button{border:0;border-radius:9px;background:var(--accent);color:#04121f;font-weight:800;
    font-size:12px;padding:7px 12px;cursor:pointer;white-space:nowrap}
  /* profile panel: header + report list */
  .prof-head{display:flex;align-items:center;gap:12px;margin-bottom:4px}
  .prof-meta{color:var(--muted);font-size:12.5px;margin:6px 0 2px}
  .prof-rep{display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:11px;
    padding:10px 12px;background:var(--panel2);color:var(--txt)}
  .prof-rep + .prof-rep{margin-top:8px}
  .prof-rep .pr-main{min-width:0;flex:1;display:flex;align-items:center;gap:9px;cursor:pointer}
  .prof-rep .pr-main:hover .pr-trail{color:var(--accent)}
  .prof-rep .pr-trail{font-size:13px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .prof-rep .pr-sub{font-size:11.5px;color:var(--muted);margin-top:2px}
  /* account avatar card */
  .acct-avwrap{display:flex;align-items:center;gap:12px;margin-top:10px}
  /* trail preview card (lives inside the morphing dock) */
  .dock-card{padding:0}
  #dock.open .dock-card{padding:14px 16px 15px;cursor:pointer}
  .dock-card .mc-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
  .dock-card h3{margin:0;font-size:16px;font-weight:800;line-height:1.2}
  .dock-card .mc-meta{color:var(--muted);font-size:12px;margin-top:3px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
  .dock-card .mc-why{color:#cdd8e4;font-size:12.5px;margin:9px 0 12px}
  .dock-card .mc-tag{margin-left:8px;font-size:11px;font-weight:700;color:var(--accent);
    background:rgba(90,176,255,.14);border-radius:6px;padding:3px 8px}
  .dock-card .mc-actions{display:flex;gap:8px}
  .dock-card .mc-open{flex:1;background:var(--accent);color:#04121f;border:0;border-radius:11px;padding:11px;
    font-weight:800;cursor:pointer;font-size:13.5px}
  .dock-card .mc-x{width:38px;border:1px solid var(--line);background:var(--panel2);color:var(--muted);
    border-radius:11px;cursor:pointer;font-size:16px}
  /* closed trail: the whole card reads as closed (red wash + a red header), not an extra pill */
  .dock-card.closed{background:linear-gradient(180deg,rgba(224,82,74,.22),rgba(224,82,74,.06))}
  .dock-card .mc-closed{display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:800;
    letter-spacing:.4px;text-transform:uppercase;color:#ff7468;margin-bottom:9px}
  .dock-card .mc-closed-msg{color:#ecc7c2;font-size:12.5px;margin-top:9px;line-height:1.45}
  /* comfort histogram (popular-times style) */
  .histo{padding:2px 2px 0}
  .hread{display:flex;align-items:baseline;gap:9px;margin-bottom:9px;min-height:22px}
  .hread .ht{font-size:17px;font-weight:800}
  .hread .hf{font-size:12.5px;color:var(--muted);font-weight:600}
  .hread .hw{margin-left:auto;font-size:11.5px;font-weight:800;padding:3px 10px;border-radius:999px}
  .hbars{display:flex;gap:3px;align-items:flex-end;height:86px;touch-action:none;cursor:ew-resize}
  .hbar{flex:1;height:100%;display:flex;align-items:flex-end;position:relative}
  .hbar .hfill{width:100%;border-radius:4px 4px 2px 2px;min-height:5px;opacity:.42;transition:opacity .08s}
  .hbar.sel .hfill{opacity:1;outline:2px solid #fff;outline-offset:1px}
  .hbar.inwin::after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;
    background:#5ab0ff;opacity:.55;border-radius:2px}
  .hlabels{display:flex;justify-content:space-between;color:var(--faint);font-size:10px;margin-top:11px}
  .hhint{color:var(--faint);font-size:10.5px;margin-top:7px;text-align:center}
  /* M5a shade clock: sun/heat ribbon aligned under the comfort bars + summary line */
  .heatrow{display:flex;gap:3px;height:9px;margin-top:8px}
  .heatrow .hseg{flex:1;border-radius:3px}
  .shadesum{font-size:12.5px;color:#cdd8e4;padding:9px 14px 0}
  .shadesum b{color:#fff;font-weight:800}
  .chart{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:12px 12px 8px}
  .trackmap{position:relative;height:210px;border-radius:14px;overflow:hidden;border:1px solid var(--line2);
    cursor:pointer;background:#10151c}
  .trackmap .tm-hint{position:absolute;right:10px;bottom:10px;z-index:2;background:rgba(14,18,24,.85);
    backdrop-filter:blur(6px);border:1px solid var(--line2);border-radius:999px;padding:6px 12px;
    font-size:12px;font-weight:800;color:var(--accent);pointer-events:none}
  .trackmap .maplibregl-canvas{cursor:pointer}
  .clegend{display:flex;gap:14px;margin-top:6px;font-size:11px;color:var(--muted);flex-wrap:wrap}
  .clegend i{width:18px;height:3px;border-radius:2px;display:inline-block;vertical-align:middle;margin-right:5px}
  .snowline{display:flex;align-items:center;gap:8px;background:var(--panel2);border:1px solid var(--line);
    border-radius:10px;padding:10px 12px;font-size:13px;color:var(--muted)}
  .rep{display:flex;gap:7px;flex-wrap:wrap}
  .rep button{flex:1 1 0;min-width:88px;padding:9px 6px;border-radius:10px;border:1px solid var(--line);
    background:var(--panel2);color:var(--txt);cursor:pointer;font-size:12px;font-weight:600;transition:.15s}
  .rep button:hover{border-color:var(--accent);background:var(--elev)}
  .rep button:disabled{opacity:.7;border-color:var(--good)}
  .gpxrow{display:flex;gap:8px;flex-wrap:wrap}
  .gpx{display:inline-flex;align-items:center;gap:7px;color:var(--accent);text-decoration:none;font-size:13px;
    font-weight:700;border:1px solid var(--line);border-radius:10px;padding:10px 14px;background:var(--panel2);
    cursor:pointer}
  .gpx:hover{border-color:var(--accent)}
  .gpx.openapp{flex:1;justify-content:center;background:linear-gradient(120deg,#5ab0ff,#37b3a8);
    color:#04121f;border:0}
  #mapView{position:relative}
  #map{height:72vh;border-radius:14px;overflow:hidden;border:1px solid var(--line)}  /* JS sets exact height */
  .maplegend{position:absolute;left:12px;top:12px;z-index:5;display:flex;gap:9px;flex-wrap:wrap;
    font-size:10.5px;color:var(--muted);background:rgba(11,14,18,.82);border:1px solid var(--line);
    border-radius:10px;padding:6px 10px;backdrop-filter:blur(6px);max-width:66%}
  .hidden{display:none}
  .note{color:var(--muted);padding:40px;text-align:center}
  svg text{fill:var(--faint);font-size:10px}
  .skel{height:150px;border-radius:16px;background:linear-gradient(90deg,#121821,#172029,#121821);
    background-size:200% 100%;animation:sh 1.2s infinite}
  @keyframes sh{0%{background-position:200% 0}100%{background-position:-200% 0}}
  /* grab handle (mobile bottom-sheet affordance) */
  .grab{display:none}
  /* bottom nav (mobile) */
  #bottomnav{display:none}

  @media(max-width:640px){
    header{padding:calc(6px + env(safe-area-inset-top)) 12px 8px}
    .hwrap{gap:8px}
    .brand .logo{font-size:18px}
    h1{font-size:15px}
    .sub{font-size:10.5px;max-width:74vw}
    .deskonly{display:none}            /* tier toggle lives in the bottom nav on mobile */
    .seg{display:none}                 /* replaced by bottom nav */
    main{padding:11px 12px calc(84px + env(safe-area-inset-bottom))}
    .grid{grid-template-columns:1fr;gap:11px}
    /* one compact filter row: search on top, chips scroll + sort beneath */
    .controls{gap:7px}
    .search{order:-1;flex:1 1 100%}
    .search input{padding:8px 12px 8px 32px}
    .chips{flex:1 1 0;min-width:0;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}
    .chips::-webkit-scrollbar{display:none}
    .chip{padding:7px 13px;flex:0 0 auto}
    .selwrap{flex:0 0 auto}
    .selwrap select{padding:7px 9px;font-size:12px}
    /* map fills the screen; nothing below it to scroll to */
    body.mapmode main{padding-bottom:0;overflow:hidden}
    .maplegend{left:10px;top:10px;font-size:10px;padding:5px 8px;max-width:72%}
    /* detail becomes a bottom sheet; restore a heavier dim+blur (the sheet covers most of the map) */
    .overlay{background:rgba(4,7,10,.6);backdrop-filter:blur(3px)}
    .overlay.on{display:block}
    .sheet{left:0;right:0;top:auto;bottom:0;width:100%;
      max-height:calc(100dvh - 28px - env(safe-area-inset-top,0px));
      border-left:0;border-top:1px solid var(--line2);border-radius:22px 22px 0 0;
      box-shadow:0 -16px 50px rgba(0,0,0,.55);animation:sheetup .26s cubic-bezier(.2,.7,.2,1)}
    @keyframes sheetup{from{transform:translateY(60px);opacity:.4}to{transform:none;opacity:1}}
    .shead{border-radius:22px 22px 0 0;padding-top:8px}
    .grab{display:block;width:38px;height:4px;border-radius:3px;background:#39434e;
      margin:2px auto 12px}
    .close{top:16px}
    .sbody{padding-bottom:calc(28px + env(safe-area-inset-bottom))}
    /* bottom nav bar */
    #bottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:35;
      background:rgba(11,14,18,.94);backdrop-filter:saturate(160%) blur(14px);
      border-top:1px solid var(--line);gap:4px;
      padding:7px 12px calc(7px + env(safe-area-inset-bottom))}
    #bottomnav button{flex:1;background:transparent;border:0;color:var(--muted);font-weight:700;
      font-size:11px;padding:6px 4px;border-radius:12px;display:flex;flex-direction:column;
      align-items:center;gap:3px;cursor:pointer}
    #bottomnav button span{font-size:18px;line-height:1}
    #bottomnav button.on{color:var(--accent)}
  }
  @media(max-width:380px){ .ctop .ring{width:52px;height:52px} }

  /* Inline Share glyph used in the iOS variant of the install tutorial slide. */
  .mt-share{display:inline-flex;vertical-align:-3px;width:15px;height:15px;color:var(--accent)}

  /* ===== immersive map-first shell ===== */
  body.app-open{overflow:hidden}                 /* map is the base; only the list scrolls */
  #map{position:fixed;inset:0;width:100%;height:100%;border:0;border-radius:0;z-index:0}

  /* floating top bar — single horizontal-scroll row of pills over the map */
  #topbar{position:fixed;top:0;left:0;right:0;z-index:20;
    padding:calc(9px + env(safe-area-inset-top)) 10px 6px;overflow-x:clip;
    /* the bar spans full width but is mostly transparent (brand pill left, search right);
       don't let the empty band swallow map clicks — only the real targets opt back in */
    pointer-events:none}  /* clip the row's negative-margin bleed; overflow-y stays visible so shadows show */
  #brandBtn,#searchBtn,#searchWrap,#navMenu,#searchResults{pointer-events:auto}
  .tb-row{display:flex;gap:8px;align-items:center;overflow-x:auto;scrollbar-width:none;
    /* padding + matching negative margin = room for the pills' drop-shadow inside the
       overflow-x clip box (so it isn't sliced into a straight line), without moving the pills */
    padding:14px 22px 30px;margin:-12px -20px -28px}
  .tb-row::-webkit-scrollbar{display:none}
  .tb-pill{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;height:40px;padding:0 15px;
    border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(14,18,24,.95);
    backdrop-filter:saturate(180%) blur(20px);color:var(--txt);font-weight:700;font-size:13.5px;
    cursor:pointer;white-space:nowrap;box-shadow:0 8px 22px rgba(0,0,0,.45)}
  .tb-icon{font-size:19px;padding:0 11px}
  .tb-loc span{opacity:.85}
  .tb-srch{padding:0 13px;color:var(--muted)}
  .tb-div{flex:0 0 auto;width:1px;height:22px;background:rgba(255,255,255,.15);margin:0 1px}
  .tb-pill.chip{color:var(--muted)}
  .tb-pill.chip.on{background:var(--accent);border-color:var(--accent);color:#04121f}
  .tb-searchbar{display:flex;align-items:center;gap:9px;height:40px;padding:0 13px;min-width:0;
    border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(14,18,24,.95);
    backdrop-filter:saturate(180%) blur(20px);color:var(--muted);box-shadow:0 8px 22px rgba(0,0,0,.45)}
  .tb-searchbar.hidden{display:none}
  .tb-searchbar input{flex:1;min-width:0;background:none;border:0;outline:0;color:var(--txt);font-size:15px}
  .tb-searchbar button{flex:0 0 auto;background:none;border:0;color:var(--muted);font-size:15px;cursor:pointer}
  /* search icon that expands horizontally inline within the top row */
  #searchContainer{flex:1 1 auto;min-width:0;display:flex;justify-content:flex-end;align-items:center}
  #searchBtn{flex:0 0 auto;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;
    border:1px solid rgba(255,255,255,.12);background:rgba(14,18,24,.95);
    backdrop-filter:saturate(180%) blur(20px);color:var(--muted);cursor:pointer;
    box-shadow:0 8px 22px rgba(0,0,0,.45);transition:color .15s,border-color .15s}
  #searchBtn:hover{color:var(--txt)}
  #searchContainer .tb-searchbar{flex:1 1 auto;min-width:0}
  /* when the bar is open, the round trigger collapses away */
  #searchContainer:has(.tb-searchbar:not(.hidden)) #searchBtn{display:none}
  /* search results dropdown (trails + regions) */
  #searchResults{margin:8px 2px 0;border-radius:15px;border:1px solid rgba(255,255,255,.12);
    background:rgba(14,18,24,.97);backdrop-filter:saturate(180%) blur(20px);overflow:hidden;max-height:64vh;
    overflow-y:auto;box-shadow:0 16px 40px rgba(0,0,0,.5)}
  #searchResults.hidden{display:none}
  .sr-h{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);
    padding:10px 14px 4px}
  .sr-row{display:flex;align-items:stretch;border-top:1px solid rgba(255,255,255,.05)}
  .sr-row:first-of-type{border-top:0}
  .sr-go{flex:1;display:flex;align-items:center;gap:11px;background:none;border:0;color:var(--txt);
    padding:11px 14px;cursor:pointer;text-align:left;min-width:0}
  .sr-go:hover{background:rgba(255,255,255,.05)}
  .sr-ic{flex:0 0 auto;width:18px;text-align:center;font-size:14px}
  .sr-tx{display:flex;flex-direction:column;min-width:0}
  .sr-tx b{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .sr-sub{font-size:12px;color:var(--muted)}
  .sr-info{flex:0 0 auto;display:flex;align-items:center;padding:0 16px;color:var(--muted);
    font-size:18px;text-decoration:none;border-left:1px solid rgba(255,255,255,.07)}
  .sr-info:hover{color:var(--txt);background:rgba(255,255,255,.05)}
  .sr-empty{padding:14px;color:var(--muted);font-size:14px}

  /* map-linked list sheet — same sheet UI as a detail item, results follow the map */
  #listSheet{position:fixed;left:0;right:0;bottom:0;z-index:20;height:var(--lh,60vh);
    display:flex;flex-direction:column;background:linear-gradient(180deg,#141a22,#0b1016);
    border-top:1px solid var(--line2);border-radius:22px 22px 0 0;box-shadow:0 -18px 50px rgba(0,0,0,.55);
    transform:translateY(106%);transition:transform .3s cubic-bezier(.2,.7,.2,1)}
  body.listopen #listSheet{transform:none}
  .ls-grab{width:40px;height:5px;border-radius:3px;background:#39434e;margin:8px auto 4px;flex:none;
    cursor:grab;touch-action:none}
  .ls-head{display:flex;justify-content:space-between;align-items:flex-end;gap:10px 12px;flex-wrap:wrap;
    padding:4px 16px 12px;flex:none}
  .ls-title{font-size:19px;font-weight:800;letter-spacing:.2px}
  .ls-head .sub{font-size:12px;color:var(--muted);margin-top:2px}
  .lv-controls{display:flex;gap:8px;align-items:center;margin-left:auto}
  #listSheet .grid{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;
    align-content:start;grid-auto-rows:max-content;
    padding:2px 14px calc(84px + env(safe-area-inset-bottom))}
  /* the timeline/plan fabs are map controls — tuck them away when the list is up */
  body.listopen #fabTime,body.listopen #fabLocate{opacity:0;transform:scale(.5);width:0;margin:0;pointer-events:none}

  /* floating dock row: round fabs flank the morphing nav dock */
  #dockbar{position:fixed;left:0;right:0;bottom:calc(15px + env(safe-area-inset-bottom));z-index:25;
    display:flex;justify-content:center;align-items:center;gap:10px;pointer-events:none}
  #dockbar>*{pointer-events:auto}
  .fab{flex:none;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;
    background:rgba(14,18,24,.95);backdrop-filter:saturate(180%) blur(20px);border:1px solid rgba(255,255,255,.1);
    box-shadow:0 14px 40px rgba(0,0,0,.5);color:var(--muted);cursor:pointer;
    transition:opacity .25s,transform .25s,width .28s,margin .28s,color .15s,border-color .15s}
  .fab svg{width:21px;height:21px}
  /* the timeline clock's minute hand — rotated (one full hour-sweep) on load + on an idle cadence to
     draw the eye; the transform-box/origin pin the spin to the clock centre (12,13 in viewBox units). */
  #fabTime .clk-min{transform-box:view-box;transform-origin:12px 13px}
  .fab.on{color:var(--accent);border-color:rgba(90,176,255,.5);background:rgba(20,30,44,.96)}
  .fab:hover{color:var(--txt)}
  #dockbar.cardopen .fab{opacity:0;transform:scale(.5);width:0;margin-left:-10px;pointer-events:none}
  #dock{position:relative;width:208px;border-radius:25px;overflow:hidden;
    background:rgba(14,18,24,.95);backdrop-filter:saturate(180%) blur(20px);
    border:1px solid rgba(255,255,255,.1);box-shadow:0 14px 40px rgba(0,0,0,.5);
    transition:width .32s cubic-bezier(.2,.7,.2,1),border-radius .3s}
  #dock.open{width:min(440px,calc(100vw - 28px));border-radius:20px}
  .dock-tabs{display:flex;gap:4px;padding:5px;transition:max-height .26s,opacity .18s,padding .26s}
  /* icon ABOVE label (compact bottom-nav) so three tabs (Map · List · Layers) fit the dock width
     on a narrow phone without clipping the labels. */
  .dock-tabs button{flex:1;background:transparent;border:0;color:var(--muted);font-weight:700;font-size:10.5px;
    padding:6px 6px;border-radius:15px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
    cursor:pointer;transition:.14s;letter-spacing:.2px;white-space:nowrap}
  .dock-tabs button svg{width:18px;height:18px;flex:none}
  .dock-tabs button.on{color:var(--accent);background:rgba(90,176,255,.12)}
  #dock.open .dock-tabs{max-height:0;opacity:0;padding:0;pointer-events:none}
  .dock-card{max-height:0;opacity:0;transition:max-height .32s cubic-bezier(.2,.7,.2,1),opacity .24s}
  #dock.open .dock-card{max-height:320px;opacity:1}

  /* ---- P1a ride planner (overlay sheet) ---- */
  .plan-tag{color:var(--muted);font-size:13px;margin-top:6px;line-height:1.4}
  .plan-body{padding-top:4px}
  .plan-form{display:flex;flex-direction:column;gap:14px;margin-bottom:6px}
  .pf-row{display:flex;flex-direction:column;gap:7px}
  .pf-row>label{font-size:11px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--muted)}
  .pf-val{color:var(--accent);text-transform:none;letter-spacing:0;font-weight:700;margin-left:6px}
  .seg{display:flex;gap:5px;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:4px}
  .seg button{flex:1;background:transparent;border:0;color:var(--muted);font-weight:700;font-size:13px;
    padding:9px 6px;border-radius:9px;cursor:pointer;transition:.14s;text-transform:capitalize}
  .seg button.on{background:var(--accent);color:#04121f}
  .pf-dist{display:flex;align-items:center;gap:10px}
  .pf-dist input[type=range]{flex:1;accent-color:var(--accent)}
  .pf-dist input[type=range].muted{opacity:.45;accent-color:var(--muted)}
  .pf-any{background:var(--panel2);border:1px solid var(--line);color:var(--muted);font-weight:700;
    font-size:12px;padding:7px 12px;border-radius:9px;cursor:pointer}
  .pf-any.on{background:var(--accent);color:#04121f;border-color:var(--accent)}
  .pf-day,.pf-region{width:100%;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
    border-radius:10px;padding:9px 11px;font-size:13px;font-weight:600}
  .pf-geostatus{color:var(--muted);font-size:12px;display:flex;align-items:center;gap:7px}
  .plan-results{margin-top:18px;border-top:1px solid var(--line);padding-top:14px}
  .plan-when{font-size:12px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
  /* planner intelligence: the plain-language lead + the "what we considered" panel */
  .plan-lead{font-size:16px;font-weight:800;color:var(--txt);line-height:1.4;margin:2px 0 11px}
  .plan-lead b{color:var(--accent)}
  .plan-lead-sub{font-weight:600;color:var(--muted)}
  .pcon{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin:0 0 14px}
  .pcon-head{font-size:13.5px;line-height:1.5;color:var(--muted)}
  .pcon-head b{color:var(--txt);font-weight:800}
  .pcon-facs{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
  .pcon-tick{font-size:11px;font-weight:700;color:var(--hero);background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:3px 9px;white-space:nowrap}
  .pcon-ruled{margin-top:10px;font-size:12px;color:var(--muted)}
  /* best-day strip: per-day riding quality, chosen day highlighted */
  .pdays-lbl{font-size:12px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:var(--muted);margin:2px 0 7px}
  .pdays-sub{font-weight:600;text-transform:none;letter-spacing:0;color:var(--faint)}
  .pdays{display:flex;gap:5px;margin:0 0 14px}
  .pday{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;
    background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:7px 3px 6px}
  .pday.on{border-color:var(--accent);background:var(--elev)}
  .pday-d{font-size:11px;font-weight:700;color:var(--muted)}
  .pday.on .pday-d{color:var(--txt)}
  .pday-bar{display:flex;align-items:flex-end;width:14px;height:34px;background:var(--line);border-radius:4px;overflow:hidden}
  .pday-bar>span{display:block;width:100%;border-radius:4px}
  .pday-n{font-size:11px;font-weight:800;color:var(--txt)}
  /* trip mode: Local/Trip toggle + destination cards */
  .plan-mode{margin:10px 0 2px}
  /* destination cards — a region "postcard" (3D terrain framed to the hub) with rank + match overlaid */
  .tripcard .tcard-hero{height:158px}
  .tc-state{font-size:11px;font-weight:700;color:var(--faint);margin-left:3px}
  .tripcard-verdict{display:block;font-size:13px;font-weight:700;line-height:1.35;margin-top:4px}
  .tripcard-rank{position:absolute;top:9px;left:9px;z-index:2;min-width:24px;height:24px;padding:0 6px;border-radius:999px;
    background:rgba(10,14,22,.55);backdrop-filter:blur(3px);border:1px solid rgba(255,255,255,.28);
    color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center}
  .tripcard-score{position:absolute;top:9px;right:9px;z-index:2;display:flex;align-items:baseline;gap:3px;
    background:rgba(10,14,22,.55);backdrop-filter:blur(3px);border:1px solid rgba(255,255,255,.28);
    border-radius:999px;padding:4px 10px;color:#fff;font-size:15px;font-weight:800}
  .tripcard-score small{font-size:8.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;opacity:.8}
  .trip-alt{margin-top:14px}
  .trip-alt-lbl{font-size:12px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:var(--accent);margin:0 0 7px}
  .itin-list{display:flex;flex-direction:column;gap:7px}
  .itin-row{display:flex;align-items:center;gap:11px;width:100%;text-align:left;cursor:pointer;
    background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--cc);border-radius:11px;padding:9px 12px}
  .itin-row:hover{border-color:var(--line2)}
  .itin-day{flex:0 0 46px;font-size:11px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:var(--muted)}
  .itin-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
  .itin-name{font-size:14px;font-weight:700;color:var(--txt)}
  .itin-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
  .plan-hedge{font-size:12.5px;color:#ffd479;background:rgba(255,212,121,.1);border:1px solid rgba(255,212,121,.25);
    border-radius:10px;padding:8px 11px;margin-bottom:12px}
  .plan-list{display:flex;flex-direction:column;gap:9px}
  .plancard{display:flex;align-items:center;gap:11px;width:100%;text-align:left;cursor:pointer;
    background:var(--panel2);border:1px solid var(--line);border-left:3px solid var(--cc);
    border-radius:13px;padding:11px 13px;transition:.14s}
  .plancard:hover{border-color:var(--cc);background:rgba(255,255,255,.03)}
  .pc-rank{flex:none;width:22px;height:22px;border-radius:50%;background:var(--cc);color:#04121f;
    font-weight:800;font-size:12px;display:flex;align-items:center;justify-content:center}
  .pc-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}
  .pc-name{font-weight:800;font-size:15px;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .pc-chips{display:flex;flex-wrap:wrap;align-items:center;gap:6px}
  .pc-diff{text-transform:capitalize;font-size:11px;font-weight:700;color:var(--muted);
    background:rgba(255,255,255,.06);border-radius:6px;padding:2px 7px}
  .pc-meta{font-size:11.5px;color:var(--muted)}
  .pc-reason{font-size:12.5px;color:var(--muted);line-height:1.35}
  .pc-fit{flex:none;display:flex;flex-direction:column;align-items:center;gap:1px;width:38px}
  .pc-fitnum{font-weight:800;font-size:18px;color:var(--cc)}
  .pc-fitlbl{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
  .seg-tod button{padding:8px 4px;font-size:12px}
  .plancard.lead{border-width:1px 1px 1px 3px;box-shadow:0 0 0 1px var(--cc)33,0 6px 18px rgba(0,0,0,.35)}
  .pc-lead{font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--cc)}
  /* top-pick factor breakdown (the three weighted pillars) + air/wind status + "why over #2" */
  .pf-factors{display:flex;flex-direction:column;gap:5px;margin-top:10px}
  .pf-fac{display:flex;align-items:center;gap:8px;font-size:11px}
  .pf-faclab{width:58px;flex:none;color:var(--muted);font-weight:700}
  .pf-facbar{flex:1;height:6px;border-radius:3px;background:rgba(255,255,255,.1);overflow:hidden}
  .pf-facbar>span{display:block;height:100%;border-radius:3px}
  .pf-facval{width:22px;flex:none;text-align:right;color:var(--muted);font-variant-numeric:tabular-nums}
  .pf-status{display:flex;flex-wrap:wrap;gap:5px 12px;margin-top:8px;font-size:11.5px;color:var(--muted)}
  .pc-edge{display:block;margin-top:9px;font-size:12.5px;line-height:1.4;color:var(--txt);
    background:rgba(255,255,255,.045);border-radius:9px;padding:7px 10px}
  .pc-edge b{color:var(--cc);font-weight:700}
  /* ---- Airbnb-style trail card (the redesign) ---- */
  .tcard{display:flex;flex-direction:column;width:100%;text-align:left;cursor:pointer;overflow:hidden;
    background:var(--panel);border:1px solid var(--line);border-radius:16px;transition:transform .12s ease,border-color .12s ease}
  .tcard:hover{border-color:var(--line2);transform:translateY(-2px)}
  .tcard-hero{position:relative;height:150px;overflow:hidden;background:#0c1117}
  .tcard.feature .tcard-hero{height:194px}
  .ah-svg{position:absolute;inset:0;width:100%;height:100%;display:block}
  /* V3 thumbnail: the 3D satellite-terrain render fades in over a condition-tinted placeholder */
  .athumb{position:absolute;inset:0;width:100%;height:100%;display:block;background-size:cover;background-position:center;
    opacity:.62;transform:scale(1.02);transition:opacity .5s ease,transform .5s ease}
  .athumb.on{opacity:1;transform:none}
  /* loading indicator while the 3D thumbnail renders/uploads (founder: "no loading indicator") */
  .athumb.rendering::after{content:"";position:absolute;top:50%;left:50%;width:22px;height:22px;margin:-11px 0 0 -11px;
    border-radius:999px;border:2.5px solid rgba(255,255,255,.25);border-top-color:rgba(255,255,255,.92);
    animation:thumbSpin .8s linear infinite}
  @keyframes thumbSpin{to{transform:rotate(360deg)}}
  @media (prefers-reduced-motion:reduce){.athumb.rendering::after{animation:none}}
  .card-shape{position:relative;width:100%;height:100%;display:block;z-index:1;
    filter:drop-shadow(0 1px 3px rgba(0,0,0,.4))}
  .tcard-noshape{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;
    height:100%;font-size:40px;opacity:.6}
  .tcard-cond{position:absolute;left:10px;bottom:10px;z-index:2}
  .tcard-save{position:absolute;top:9px;right:9px;z-index:2;width:32px;height:32px;border-radius:999px;
    display:flex;align-items:center;justify-content:center;background:rgba(10,14,22,.42);backdrop-filter:blur(3px);
    border:1px solid rgba(255,255,255,.25);cursor:pointer}
  .tcard-save svg{width:16px;height:16px;fill:none;stroke:#fff;stroke-width:2}
  .tcard-save.on svg{fill:var(--muddy);stroke:var(--muddy)}
  .tcard-body{padding:12px 14px 14px}
  .tcard-toptag{display:block;font-size:11px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:var(--accent);margin-bottom:5px}
  .tcard-head{display:flex;align-items:baseline;gap:10px}
  .tcard-name{flex:1;min-width:0;font-size:16px;font-weight:800;color:var(--txt);line-height:1.25}
  .tcard.feature .tcard-name{font-size:18px}
  .tcard-match{flex:none;display:flex;flex-direction:column;align-items:center;line-height:1}
  .tcard-match b{font-size:18px;font-weight:800;color:var(--txt)}
  .tcard-match small{font-size:8.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--faint);margin-top:2px}
  .tcard-sub{display:block;font-size:12.5px;color:var(--muted);margin-top:3px}
  .tcard-why{display:block;font-size:13.5px;line-height:1.5;color:var(--txt);margin-top:8px}
  .tcard-factors{display:block;margin-top:11px}
  /* ---- V3 Adventure Home: inspiration rails ---- */
  .plan-back{display:inline-flex;align-items:center;gap:5px;cursor:pointer;margin:0 0 12px;
    background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:6px 13px;
    font-size:12px;font-weight:800;color:var(--accent)}
  .adv-fresh{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:700;color:var(--muted);margin:0 0 16px}
  .adv-dot{width:7px;height:7px;border-radius:999px;background:var(--hero);box-shadow:0 0 0 0 var(--hero);animation:advPulse 2s ease-out infinite}
  @keyframes advPulse{0%{box-shadow:0 0 0 0 rgba(63,196,122,.5)}70%{box-shadow:0 0 0 6px rgba(63,196,122,0)}100%{box-shadow:0 0 0 0 rgba(63,196,122,0)}}
  @media (prefers-reduced-motion:reduce){.adv-dot{animation:none}}
  .arail-scarce{position:absolute;top:8px;right:8px;z-index:2;font-size:10.5px;font-weight:800;
    color:#1a1206;background:#f0b53f;border-radius:999px;padding:3px 8px;white-space:nowrap;box-shadow:0 1px 4px rgba(0,0,0,.3)}
  /* V3 "make it happen" operator zone — labeled, §7-safe (panel-tinted, never a condition color) */
  .op-zone h4{display:flex;align-items:center;gap:8px}
  .op-admin{font-size:10px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:#f0b53f;
    background:rgba(240,181,63,.14);border:1px solid rgba(240,181,63,.4);border-radius:999px;padding:2px 8px}
  .op-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}
  .op-row{display:flex;align-items:center;gap:11px;text-decoration:none;cursor:pointer;
    background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:11px 13px}
  .op-row:hover{border-color:var(--line2)}
  .op-ic{flex:none;width:34px;height:34px;border-radius:10px;background:var(--elev);border:1px solid var(--line);
    display:flex;align-items:center;justify-content:center;font-size:17px}
  .op-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
  .op-name{font-size:14px;font-weight:800;color:var(--txt)}
  .op-blurb{font-size:12px;color:var(--muted);line-height:1.35}
  .op-cat{flex:none;font-size:10.5px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:var(--muted);
    background:var(--elev);border:1px solid var(--line);border-radius:999px;padding:3px 9px}
  .op-note{margin-top:9px;font-size:11px;color:var(--faint);line-height:1.4}
  /* vertical inspiration sections — a responsive grid, capped to a couple rows, most-relevant first */
  .adv-sec{margin:0 0 26px}
  .adv-sec-head{display:flex;align-items:baseline;flex-wrap:wrap;gap:8px;margin:0 0 12px}
  .adv-sec-head b{font-size:17px;font-weight:800;color:var(--txt);line-height:1.2}
  .adv-sec.dim .adv-sec-head b{font-size:15.5px}
  .adv-sec-head small{font-size:12.5px;color:var(--muted)}
  .adv-sec-more{margin-left:auto;font-size:11px;font-weight:800;color:var(--faint);
    background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:3px 9px;white-space:nowrap}
  .adv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px}
  .acard .tcard-hero{height:140px}
  .acard .tcard-body{padding:11px 13px 13px}
  .acard .tcard-name{font-size:15px}
  .acard.skel .tcard-hero{animation:skelPulse 1.2s ease-in-out infinite}
  .adv-grid .acard{animation:tcardIn .34s ease both}
  /* results-first: the slim filter chip bar + the inline refine control */
  .plan-chips{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:2px 0 4px;
    scrollbar-width:none}
  .plan-chips::-webkit-scrollbar{display:none}
  .pchip{flex:0 0 auto;display:inline-flex;align-items:center;gap:5px;cursor:pointer;
    background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:8px 13px;
    font-size:13px;font-weight:700;color:var(--txt);white-space:nowrap}
  .pchip:hover{border-color:var(--line2)}
  .pchip.on{border-color:var(--accent);background:var(--elev);color:var(--accent)}
  .pchip-c{font-size:9px;opacity:.6}
  .plan-refine{margin:0}
  .plan-refine.on{margin:10px 0 4px;padding:12px;background:var(--panel2);border:1px solid var(--line);border-radius:14px}
  .pf-distval{margin-top:8px;font-size:12.5px;color:var(--muted);text-align:center}
  /* delight: cards rise + fade in, lightly staggered */
  @keyframes tcardIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
  .plan-list .tcard{animation:tcardIn .34s ease both}
  .plan-list .tcard:nth-child(2){animation-delay:.05s}
  .plan-list .tcard:nth-child(3){animation-delay:.10s}
  .plan-list .tcard:nth-child(4){animation-delay:.15s}
  .plan-list .tcard:nth-child(n+5){animation-delay:.20s}
  /* skeleton loading */
  .tcard.skel{pointer-events:none}
  .skel-line{height:11px;border-radius:6px;background:var(--panel2);margin:9px 0}
  .skel-line.w40{width:40%}.skel-line.w60{width:60%}.skel-line.w80{width:80%}
  .tcard.skel .tcard-hero,.skel-line{animation:skelPulse 1.2s ease-in-out infinite}
  @keyframes skelPulse{0%,100%{opacity:.45}50%{opacity:.85}}
  @media (prefers-reduced-motion:reduce){
    .plan-list .tcard{animation:none}
    .tcard.skel .tcard-hero,.skel-line{animation:none}}
  .plan-list{gap:13px}
  .plan-contrast{display:block;width:100%;margin-top:10px;text-align:center;cursor:pointer;
    background:transparent;border:1px dashed var(--line);border-radius:11px;padding:10px 12px;
    color:var(--muted);font-size:13px;font-weight:600}
  .plan-contrast:hover{border-color:var(--accent);color:var(--txt)}
  .plan-contrast b{color:var(--accent);font-weight:800}
  .plan-upsell{margin-top:14px;background:rgba(255,212,121,.08);border:1px solid rgba(255,212,121,.28);
    border-radius:14px;padding:14px}
  .plan-upsell p{margin:0 0 10px;font-size:13.5px;color:var(--txt);line-height:1.45}
  .rp-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
  .rp-field{display:flex;flex-direction:column;gap:5px;font-size:10.5px;font-weight:800;
    letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
  .rp-field select{text-transform:none;letter-spacing:0}

  /* floating panel (timeline slider + inline legend) above the dock */
  #timePanel{position:fixed;left:50%;transform:translateX(-50%);
    bottom:calc(82px + env(safe-area-inset-bottom));z-index:24;display:none;
    background:rgba(14,18,24,.96);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.1);
    box-shadow:0 14px 40px rgba(0,0,0,.5);border-radius:18px}
  #timePanel.on{display:block;animation:tpin .2s ease}
  @keyframes tpin{from{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%,0)}}
  #timePanel{width:min(440px,calc(100vw - 28px));padding:12px 16px 13px}
  .tp-head{display:flex;align-items:baseline;gap:8px;margin-bottom:10px}
  .tp-head b{font-size:16px;font-weight:800}
  .tp-head small{color:var(--muted);font-size:12px}
  .slider{position:relative;height:24px;display:flex;align-items:center;touch-action:none;cursor:pointer}
  .sl-track{position:absolute;left:0;right:0;height:6px;border-radius:3px;background:rgba(255,255,255,.13)}
  .sl-fill{position:absolute;left:0;height:6px;border-radius:3px;background:var(--accent);
    transition:width .19s cubic-bezier(.22,.68,.3,1)}
  /* the thumb is a little bike wheel — it ROLLS (spins) as you scrub (see spinWheel + the
     #slThumb/#hrThumb SVG). Position lives on .sl-thumb; rotation on the inner .sl-wheel so the
     two never fight. While HELD (.dragging) the thumb tracks the finger 1:1 (transitions off); on
     release the transitions below roll + glide it into the nearest day/hour. */
  .sl-thumb{position:absolute;left:0;width:25px;height:25px;transform:translateX(-50%);
    pointer-events:none;filter:drop-shadow(0 2px 5px rgba(0,0,0,.6));
    transition:left .19s cubic-bezier(.22,.68,.3,1)}
  .sl-wheel{display:block;width:100%;height:100%;transform-origin:50% 50%;
    transform:rotate(var(--spin,0deg));transition:transform .19s cubic-bezier(.22,.68,.3,1);will-change:transform}
  .slider.dragging .sl-fill,.slider.dragging .sl-thumb,.slider.dragging .sl-wheel{transition:none}
  .sw-tire{fill:none;stroke:#fff;stroke-width:11;stroke-dasharray:10.5 7.7;stroke-linecap:butt}
  .sw-rim{fill:none;stroke:#fff;stroke-width:2.3}
  .sw-spokes line{stroke:#fff;stroke-width:2.4;stroke-linecap:round}
  .sw-spokes line.sw-mark{stroke:var(--accent);stroke-width:3.2}
  .sw-hub{fill:#fff}
  .sw-axle{fill:var(--accent)}
  .sl-ends{display:flex;justify-content:space-between;color:var(--faint);font-size:10.5px;margin-top:8px}
  /* legend sits at the bottom of the timeline panel, divided from the slider; a compact
     horizontal list of swatches that wraps to as many lines as it needs, layer-aware */
  #legendInline{margin-top:12px;padding-top:11px;border-top:1px solid rgba(255,255,255,.09)}
  .lg-list{display:flex;flex-wrap:wrap;gap:6px 13px}
  .lg-item{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--txt);white-space:nowrap}
  .lg-item i{width:12px;height:12px;border-radius:3px;flex:none}
  .lg-item.lg-flags{color:var(--muted);font-weight:700;letter-spacing:.2px}

  /* map layer switcher: a round button under the search icon + a popover menu */
  /* the layer panel now opens from the dock's "Layers" tab — bottom-centred above the dock (like the
     timeline), not a small top-right button. Mutually exclusive with the timeline (handled in JS). */
  #layerCtl{position:fixed;left:50%;transform:translateX(-50%);
    bottom:calc(82px + env(safe-area-inset-bottom));z-index:24;display:none;width:min(440px,calc(100vw - 28px))}
  body.app-open #layerCtl{display:block}
  body.listopen #layerCtl{display:none}
  body:has(#overlay.on) #layerCtl{display:none}
  body:has(#searchWrap:not(.hidden)) #layerCtl{display:none}
  #layerMenu{max-height:62vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px;border-radius:16px;
    background:rgba(14,18,24,.97);backdrop-filter:saturate(180%) blur(20px);
    border:1px solid rgba(255,255,255,.12);box-shadow:0 14px 40px rgba(0,0,0,.5);animation:panelpop .2s ease}
  /* the menu is centred by its PARENT (#layerCtl translateX(-50%)), so its own pop-in must only move
     vertically — tpin bakes in translate(-50%,…) for SELF-centred panels and would slide it from the left. */
  @keyframes panelpop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
  #layerMenu.hidden{display:none}
  #legendLayers{padding:3px 8px 5px}
  /* the Layers dock tab tints accent when a non-default layer (comfort/aqi/smoke) is live */
  #layersTab.active-layer,#layersTab.active-layer svg{color:var(--accent)}
  #layerMenu button{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:0;cursor:pointer;
    background:transparent;color:var(--txt);padding:10px 11px;border-radius:11px;transition:.13s}
  #layerMenu button svg{width:20px;height:20px;flex:none;color:var(--muted)}
  #layerMenu button span{display:flex;flex-direction:column;gap:1px;min-width:0}
  #layerMenu button b{font-size:13.5px;font-weight:700}
  #layerMenu button small{font-size:11px;color:var(--muted)}
  #layerMenu button:hover{background:rgba(255,255,255,.05)}
  #layerMenu button.on{background:rgba(90,176,255,.13)}
  #layerMenu button.on b{color:var(--accent)}#layerMenu button.on svg{color:var(--accent)}
  #layerMenu .lm-div{height:1px;background:var(--line);margin:6px 4px}
  #layerMenu .lm-sect{font-size:10px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--faint);padding:2px 8px 5px}
  /* "Preview" pill on the gravel lens (in-development perk, not a hard paywall) + the lock a
     non-Season-Pass rider sees. Pill is a subtle accent tint; lock is faint and right-aligned. */
  #layerMenu .lm-tag{display:inline-block;margin-left:5px;padding:1px 6px;border-radius:999px;font-size:8.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;vertical-align:middle;background:rgba(90,176,255,.16);color:var(--accent)}
  #layerMenu .lm-lock{width:15px;height:15px;color:var(--faint);margin-left:auto;flex:none;display:none}
  #discSect.locked .lm-lock{display:block}
  /* item 3: admin-only trailhead POI toggles — compact lines, each a small switch (never a
     condition color; the accent = "on"). Hidden entirely for non-admins. */
  #poiSect.hidden{display:none}
  /* the single combined "Trailhead POIs" toggle — sized like a layer card (icon · title+subtitle ·
     switch), muted when off, brightens + accent switch when on. */
  #poiSect button.poi-tog{gap:11px;padding:9px 11px;color:var(--txt)}
  #poiSect button.poi-tog:hover{background:rgba(255,255,255,.05)}
  #poiSect button.poi-tog.on{color:var(--txt);background:none}
  #poiSect button.poi-tog b,#poiSect button.poi-tog.on b{color:var(--txt)}
  #poiSect .pt-em{font-size:17px;width:22px;text-align:center;flex:none}
  #poiSect .pt-txt{display:flex;flex-direction:column;gap:1px;min-width:0}
  #poiSect .pt-txt small{font-size:11px;color:var(--muted);font-weight:400}
  #poiSect .pt-sw{margin-left:auto;width:26px;height:15px;border-radius:999px;background:var(--line2);position:relative;flex:none;transition:background .15s}
  #poiSect .pt-sw::after{content:"";position:absolute;top:2px;left:2px;width:11px;height:11px;border-radius:50%;background:#fff;transition:transform .15s}
  #poiSect button.poi-tog.on .pt-sw{background:var(--accent)}
  #poiSect button.poi-tog.on .pt-sw::after{transform:translateX(11px)}

  /* AQI coverage hint (only shown in the AQI layer) — honest "no forecast this far out" line */
  #aqiHint{display:none;margin-top:11px;font-size:11.5px;line-height:1.4;color:var(--muted)}
  body.layer-aqi #aqiHint{display:block}
  /* comfort time-of-day section inside the timeline panel (only shown in comfort mode) */
  #hourSect{display:none;margin-top:12px;padding-top:11px;border-top:1px solid rgba(255,255,255,.09)}
  body.layer-comfort #hourSect{display:block}
  /* ADMIN smoke playback row (only shown in the smoke layer): Play/Pause · Now · a forecast note */
  #smokeCtl{display:none;margin-top:12px;padding-top:11px;border-top:1px solid rgba(255,255,255,.09);
    align-items:center;gap:8px}
  body.layer-smoke #smokeCtl{display:flex}
  #smokeCtl .sk-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:999px;
    border:1px solid var(--accent);background:var(--accent);color:#06223a;font-weight:800;font-size:12px;cursor:pointer}
  #smokeCtl .sk-btn.ghost{background:transparent;color:var(--txt);border-color:var(--line2)}
  #smokeCtl .sk-btn.playing{background:transparent;color:var(--accent);border-color:var(--accent)}
  #smokeCtl .sk-note{margin-left:auto;font-size:10.5px;color:var(--muted);text-align:right}
  .hr-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:9px}
  .hr-lab{font-size:10px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.6px}
  .hr-head b{font-size:15px;font-weight:800}

  /* region pill — bottom-center, same slot as the timeline (mutually exclusive) */
  #regionPill{position:fixed;left:50%;transform:translateX(-50%);
    bottom:calc(82px + env(safe-area-inset-bottom));z-index:23;display:flex;align-items:center;gap:8px;
    background:rgba(14,18,24,.94);backdrop-filter:saturate(160%) blur(16px);
    border:1px solid rgba(255,255,255,.12);box-shadow:0 10px 30px rgba(0,0,0,.45);
    border-radius:999px;padding:8px 13px;cursor:pointer;color:var(--txt);font-weight:700;font-size:13.5px;
    max-width:calc(100vw - 28px);animation:tpin .2s ease}
  #regionPill.hidden{display:none}
  #regionPill:hover{border-color:rgba(255,255,255,.22)}
  #regionPill .rp-dot{width:8px;height:8px;border-radius:50%;background:var(--hero);flex:none;
    box-shadow:0 0 0 4px rgba(19,168,90,.18)}
  #regionPill.soon .rp-dot{background:var(--soft);box-shadow:0 0 0 4px rgba(227,161,58,.18)}
  #regionPill.soon{color:var(--muted);font-weight:600}
  #regionPill .rp-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  #regionPill .rp-ic{width:16px;height:16px;color:var(--muted);flex:none}
  body:not(.app-open) #regionPill{display:none}
  /* P0.2 — sponsor "Presented by" chip on the map, tied to the focused region (§7: a labeled brand
     mark, panel-tinted, NEVER a condition color or a closure mark; only over a SPONSORED hub). */
  /* Smaller + lighter than #regionPill (the primary control) so it doesn't dominate, but kept SOLID
     and READABLE over a busy map: a solid dark panel, full-opacity text, and a two-line STACKED label
     (narrow → the sponsor name never crops). Subtlety comes from size, not from dimming. */
  #sponsorMapChip{position:fixed;left:50%;transform:translateX(-50%);
    bottom:calc(124px + env(safe-area-inset-bottom));z-index:23;display:flex;align-items:center;gap:8px;
    background:rgba(14,18,24,.9);backdrop-filter:saturate(150%) blur(12px);
    border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 14px rgba(0,0,0,.32);
    border-radius:999px;padding:4px 13px 4px 5px;cursor:pointer;max-width:calc(100vw - 28px);
    transition:border-color .18s ease;animation:tpin .2s ease}
  #sponsorMapChip.hidden{display:none}
  #sponsorMapChip:hover,#sponsorMapChip:focus-visible{border-color:rgba(255,255,255,.2);outline:none}
  #sponsorMapChip .smc-logo{width:22px;height:22px;border-radius:50%;object-fit:cover;background:#fff;flex:none}
  #sponsorMapChip .smc-ic{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--panel2);color:var(--muted);font-size:12px;flex:none}
  #sponsorMapChip .smc-tx{display:flex;flex-direction:column;min-width:0;line-height:1.15;text-align:left}
  #sponsorMapChip .smc-pb{font-size:8px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--faint)}
  #sponsorMapChip .smc-nm{font-size:12px;font-weight:700;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  body:not(.app-open) #sponsorMapChip{display:none}
  /* web mobile — a touch smaller on a narrow viewport, still solid + readable */
  @media(max-width:640px){
    #sponsorMapChip{gap:7px;padding:4px 12px 4px 5px}
    #sponsorMapChip .smc-logo,#sponsorMapChip .smc-ic{width:20px;height:20px}
    #sponsorMapChip .smc-ic{font-size:11px}
    #sponsorMapChip .smc-nm{font-size:11.5px}
  }

  /* region sheet wrapper — the glance cards themselves come from the shared gl-* CSS,
     injected by shared/conditions.js (same styles as the static SEO pages) */
  .rg-body{display:flex;flex-direction:column;gap:0}
  .rg-blurb{color:var(--muted);font-size:13.5px;line-height:1.55;margin:0 0 12px}
  .rg-meta{display:flex;flex-wrap:wrap;gap:6px 16px;color:var(--muted);font-size:13px;margin:0 0 16px}
  .rg-meta b{color:var(--txt)}
  .rg-explore{width:100%;margin-top:11px;padding:12px;border-radius:12px;border:0;cursor:pointer;
    font-weight:700;font-size:14px;background:linear-gradient(90deg,#3aa0ff,#7fd0ff);color:#06223a}
  /* region sheet → trail networks directory */
  .rg-nets{margin-top:16px}
  .rg-nets-h{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 8px}
  .rg-nets-list{display:flex;flex-wrap:wrap;gap:8px}
  .rg-net{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;cursor:pointer;
    background:#121a26;border:1px solid #1f2a38;color:var(--txt);font-size:13px;font-weight:600}
  .rg-net:hover{background:#17202e;border-color:#2a3850}
  .rg-net-c{font-size:11px;font-weight:700;color:var(--muted);background:#0c121b;border-radius:999px;padding:1px 7px}
  /* area (trail network) sheet */
  .ar-crumb{font-size:12px;font-weight:600;color:var(--muted);margin:0 0 4px}
  .ar-board-h{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:18px 0 8px}
  .ar-board{display:flex;flex-direction:column;gap:1px;border-radius:12px;overflow:hidden;background:#0e1620}
  .ar-trail{display:flex;align-items:center;gap:10px;width:100%;padding:11px 12px;border:0;cursor:pointer;
    background:#121a26;color:var(--txt);text-align:left;font-size:13.5px}
  .ar-trail:hover{background:#17202e}
  .ar-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
  .ar-tn{flex:1 1 auto;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .ar-meta{display:flex;align-items:center;gap:10px;flex:0 0 auto;color:var(--muted);font-size:12px}
  .ar-lab{font-weight:600;color:var(--txt)}

  @media(min-width:641px){
    #listSheet .grid{padding-left:max(14px,calc(50vw - 560px));padding-right:max(14px,calc(50vw - 560px))}
  }

  /* ===== landing layer — the homepage, layered over the live map so the product
         breathes faintly behind the glass. Desktop scrolls a short narrative; mobile is
         a single screen that hands the full viewport to the app on "enter". ===== */
  /* height tracks the *visible* viewport (dvh), not the layout viewport — otherwise on
     Android the fixed panel extends below the fold under the URL bar and its lower content
     (email form + note) can't be scrolled into view. */
  #landing{position:fixed;top:0;left:0;right:0;height:100vh;height:100dvh;
    z-index:40;overflow-y:auto;-webkit-overflow-scrolling:touch;background:transparent}
  body.app-open #landing{display:none}
  /* the live condition map IS the hero — it renders full-bleed behind the landing (booted on
     load). On the landing it's non-interactive so taps/scroll hit the overlay; it becomes
     interactive on enter. .lz-herobg is a fixed scrim that keeps the overlaid text legible;
     .lz-below carries an opaque bg so the story/FAQ cover the map as you scroll past the hero. */
  /* on the landing, darken the (light) basemap so the glowing condition blobs pop and the
     overlaid light text stays legible — the "dark map, bright data" look. saturate keeps the
     condition colours vivid through the dimming. The app itself keeps the bright pastel map. */
  body:not(.app-open) #map{pointer-events:none;filter:brightness(.52) saturate(1.35)}
  .lz-herobg{position:fixed;inset:0;z-index:0;pointer-events:none;background:
    linear-gradient(180deg, rgba(6,9,13,.8) 0%, rgba(6,9,13,.34) 30%, rgba(6,9,13,.14) 54%,
      rgba(6,9,13,.46) 80%, rgba(6,9,13,.9) 100%)}
  body.app-open .lz-herobg{display:none}
  /* the scrim is position:fixed (positioned) so without this it paints ABOVE the static hero
     content and greys it out — keep all content above the scrim with relative + z-index. */
  .lz-inner,.lz-below{position:relative;z-index:1}
  .lz-below{background:
    radial-gradient(1100px 620px at 78% -8%, rgba(20,40,54,.60) 0%, transparent 62%),
    linear-gradient(180deg, #0a0e13 0%, #080b10 48%, #06090d 100%)}
  body:not(.app-open) #topbar,
  body:not(.app-open) #dockbar,
  body:not(.app-open) #listSheet{opacity:0;pointer-events:none}

  /* map boot loader (visible only while app mode is opening and initial data is loading) */
  #mapLoading{position:fixed;inset:0;z-index:26;display:none;align-items:center;justify-content:center;
    background:radial-gradient(1000px 620px at 78% -12%, rgba(20,34,48,.72) 0%, transparent 58%),
      radial-gradient(860px 500px at -8% 0%, rgba(24,36,28,.62) 0%, transparent 54%),
      rgba(9,12,16,.78);backdrop-filter:saturate(130%) blur(4px);}
  body.app-open.map-loading #mapLoading{display:flex;animation:fade .16s ease}
  .ml-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 22px;border-radius:14px;
    border:1px solid rgba(255,255,255,.11);background:rgba(14,19,25,.78);box-shadow:0 16px 42px rgba(0,0,0,.48)}
  .ml-spin{width:36px;height:36px;border-radius:50%;border:3px solid rgba(255,255,255,.16);
    border-top-color:var(--accent);animation:mlspin .9s linear infinite}
  .ml-text{font-size:13px;color:var(--txt);font-weight:700;letter-spacing:.2px}
  .ml-sub{font-size:11.5px;color:var(--muted)}
  @keyframes mlspin{to{transform:rotate(360deg)}}
  /* SUBTLE mode: basemap is up, conditions still streaming → a small NON-blocking pill at top-center,
     just below the topbar row. No backdrop, no blur, no pointer capture — the map shows through and
     stays fully interactive underneath while the heat field fades in. */
  body.map-loading.map-loading-subtle #mapLoading{background:none;backdrop-filter:none;
    align-items:flex-start;justify-content:center;pointer-events:none}
  body.map-loading-subtle #mapLoading .ml-wrap{flex-direction:row;gap:9px;padding:8px 13px;border-radius:999px;
    margin-top:calc(env(safe-area-inset-top,0px) + 60px);background:rgba(14,19,25,.92);
    backdrop-filter:saturate(160%) blur(14px)}   /* clear the topbar (brand + search) */
  body.map-loading-subtle #mapLoading .ml-spin{width:15px;height:15px;border-width:2px}
  body.map-loading-subtle #mapLoading .ml-text{font-size:12px;font-weight:700}
  body.map-loading-subtle #mapLoading .ml-sub{display:none}

  /* first-time map tutorial */
  #mapTour{position:fixed;inset:0;z-index:27;display:none}
  #mapTour.on{display:block;animation:fade .16s ease}
  .mt-shade{position:absolute;inset:0;
    background:radial-gradient(980px 620px at 78% -10%, rgba(20,34,48,.56) 0%, transparent 58%),
      radial-gradient(840px 520px at -8% 0%, rgba(24,36,28,.48) 0%, transparent 54%),
      rgba(9,12,16,.72);backdrop-filter:saturate(130%) blur(4px)}
  .mt-card{position:absolute;max-width:min(360px,calc(100vw - 24px));
    border:1px solid rgba(255,255,255,.11);background:rgba(14,19,25,.8);border-radius:14px;
    box-shadow:0 16px 42px rgba(0,0,0,.48);padding:14px 14px 12px;color:var(--txt)}
  .mt-step{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:800}
  .mt-title{margin:7px 0 4px;font-size:17px;line-height:1.2;font-weight:800}
  .mt-copy{margin:0;color:#c9d6e4;font-size:13px;line-height:1.45}
  .mt-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}
  .mt-btn{border-radius:10px;padding:8px 11px;font-size:12.5px;font-weight:700;cursor:pointer}
  .mt-btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--line2)}
  .mt-btn.ghost:hover{color:var(--txt);border-color:var(--line)}
  .mt-btn.go{border:0;color:#04121f;background:linear-gradient(120deg,#5ab0ff,#37b3a8)}
  .mt-spot{position:fixed;width:66px;height:66px;display:none;pointer-events:none;z-index:1;
    border-radius:999px;border:2px solid rgba(90,176,255,.96);transform:translate(-50%,-50%);
    box-shadow:0 0 0 10px rgba(90,176,255,.12),0 0 0 22px rgba(90,176,255,.06);animation:mtpulse 1.6s ease-in-out infinite}
  #mapTour.s2 .mt-spot{display:block}
  #mapTour.s2 .mt-card::after{content:"";position:absolute;left:var(--arrx,28px);bottom:-9px;
    width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;
    border-top:9px solid rgba(14,19,25,.95)}
  #mapTour.s2 .mt-card.below::after{top:-9px;bottom:auto;
    border-top:0;border-left:9px solid transparent;border-right:9px solid transparent;
    border-bottom:9px solid rgba(14,19,25,.95)}
  @keyframes mtpulse{0%,100%{box-shadow:0 0 0 10px rgba(90,176,255,.12),0 0 0 22px rgba(90,176,255,.06)}
    50%{box-shadow:0 0 0 14px rgba(90,176,255,.08),0 0 0 30px rgba(90,176,255,.03)}}

  .lz-inner{max-width:680px;margin:0 auto;width:100%;padding:40px 22px 0;
    min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;
    text-align:center}
  .lz-brand{display:inline-flex;align-items:center;gap:12px;color:var(--txt);margin-bottom:34px}
  .lz-mark{width:46px;height:46px;flex:none;font-size:36px;line-height:1;display:flex;align-items:center;justify-content:center}
  .lz-word{font-size:27px;font-weight:800;letter-spacing:-.4px;line-height:1;color:#fff;
    text-shadow:0 1px 3px rgba(0,0,0,.9),0 2px 16px rgba(0,0,0,.6)}
  /* the gradient is background-clip:text with a transparent fill — an inherited text-shadow (or a
     filter) paints dark shapes INSIDE the letters, so the gradient text gets neither. */
  .lz-word b{font-weight:800;background:linear-gradient(120deg,#5ee0a0,#5ab8ff);
    -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;
    text-shadow:none}
  .tb-mark{font-size:17px;line-height:1}
  /* brand → menu toggle: tri-colour hamburger that becomes a red cross when the menu is open */
  .tb-burger{display:inline-flex;width:19px;height:19px;flex:none;position:relative}
  .tb-burger svg{position:absolute;inset:0;width:19px;height:19px}
  .tb-burger .ic-x{opacity:0;transform:rotate(-90deg);transition:opacity .2s,transform .2s}
  .tb-burger .ic-bars{opacity:1;transition:opacity .2s,transform .2s}
  #brandBtn.open .tb-burger .ic-bars{opacity:0;transform:rotate(90deg)}
  #brandBtn.open .tb-burger .ic-x{opacity:1;transform:rotate(0)}
  #brandBtn.signedin{position:relative}
  #brandBtn.signedin::after{content:"";position:absolute;top:7px;right:9px;width:6px;height:6px;
    border-radius:50%;background:var(--accent);box-shadow:0 0 0 2px rgba(15,20,27,.9)}
  /* the pill-stack menu: floats over the map, no scrim; click-outside dismisses */
  #navMenu{position:absolute;top:calc(9px + env(safe-area-inset-top) + 48px);left:12px;z-index:30;
    display:flex;flex-direction:column;align-items:flex-start;gap:8px;
    max-height:calc(100vh - 140px);overflow-y:auto;scrollbar-width:none;padding:2px}
  #navMenu::-webkit-scrollbar{display:none}
  #navMenu.hidden{display:none}
  .nav-item{display:inline-flex;align-items:center;gap:10px;height:42px;padding:0 17px;border-radius:21px;
    border:1px solid rgba(255,255,255,.13);background:rgba(15,20,27,.92);
    backdrop-filter:saturate(170%) blur(14px);color:var(--txt);font-weight:700;font-size:14px;
    cursor:pointer;white-space:nowrap;box-shadow:0 6px 22px rgba(0,0,0,.4);
    animation:navIn .24s cubic-bezier(.2,.8,.3,1) backwards}
  .nav-item:hover{border-color:var(--accent);transform:translateX(2px)}
  .nav-item svg{width:17px;height:17px;flex:none;color:var(--muted)}
  .nav-item.accent{color:var(--hero)} .nav-item.accent svg{color:var(--hero)}
  @keyframes navIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
  .lz-h1{font-size:clamp(34px,6.2vw,58px);line-height:1.03;font-weight:800;margin:0;letter-spacing:-.6px;
    color:#fff;filter:drop-shadow(0 2px 14px rgba(0,0,0,.62))}
  .lz-sub{font-size:clamp(15px,2.2vw,18.5px);color:#f3f7fb;max-width:30em;margin:18px auto 0;line-height:1.5;
    text-shadow:0 1px 3px rgba(0,0,0,.92),0 2px 14px rgba(0,0,0,.6)}
  /* ===== map-hero overlay controls (the map itself is the full-bleed background) ===== */
  .lz-livechip{display:inline-flex;align-items:center;gap:7px;margin:26px auto 0;white-space:nowrap;
    font-size:11.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:#cfe6d8;
    background:rgba(8,12,18,.5);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);
    border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:6px 13px}
  .lz-livechip i{width:7px;height:7px;border-radius:50%;background:var(--hero);flex:none;animation:lzlive 1.9s infinite}
  @keyframes lzlive{0%{box-shadow:0 0 0 0 rgba(43,191,106,.6)}70%{box-shadow:0 0 0 7px rgba(43,191,106,0)}
    100%{box-shadow:0 0 0 0 rgba(43,191,106,0)}}
  .lz-search{display:flex;align-items:center;gap:9px;width:100%;max-width:430px;margin:18px auto 0;
    background:rgba(13,18,26,.72);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
    border:1px solid rgba(255,255,255,.16);border-radius:14px;padding:0 8px 0 15px;
    box-shadow:0 16px 40px -18px rgba(0,0,0,.8);transition:border-color .15s}
  .lz-search:focus-within{border-color:rgba(90,176,255,.6)}
  .lz-search svg{width:19px;height:19px;color:var(--muted);flex:none}
  .lz-search input{flex:1;min-width:0;background:none;border:0;outline:none;color:var(--txt);
    font-size:15.5px;padding:14px 4px}
  .lz-search input::placeholder{color:#8b98a8}
  .lz-explore{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:0;cursor:pointer;
    margin:14px auto 0;border-radius:14px;padding:14px 26px;font-size:15.5px;font-weight:800;
    color:#04121f;background:linear-gradient(120deg,#5ab0ff,#37b3a8);
    box-shadow:0 14px 36px -12px rgba(90,176,255,.7);transition:transform .14s,box-shadow .14s}
  .lz-explore:hover{transform:translateY(-1px);box-shadow:0 18px 44px -12px rgba(90,176,255,.85)}
  .lz-explore .lz-arr{transition:transform .15s}.lz-explore:hover .lz-arr{transform:translateX(4px)}
  .lz-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 16px;margin:22px auto 0;
    font-size:12px;font-weight:700;color:#e6eef6;letter-spacing:.2px;text-shadow:0 1px 3px rgba(0,0,0,.92),0 1px 10px rgba(0,0,0,.6)}
  .lz-legend span{display:inline-flex;align-items:center;gap:6px}
  .lz-legend i{width:10px;height:10px;border-radius:3px;flex:none}
  /* the "window into the product": a see-through porthole into the map (drop-in clip),
     click to enter. The animated SVG placeholder shows until a real clip is provided. */
  .lz-window{display:block;width:100%;max-width:460px;margin:30px auto 0;text-align:left;padding:0;
    background:var(--panel);border:1px solid var(--line2);border-radius:20px;overflow:hidden;cursor:pointer;
    box-shadow:0 26px 64px -24px rgba(0,0,0,.85), 0 0 0 1px rgba(255,255,255,.03) inset;
    transition:transform .16s,box-shadow .16s,border-color .16s}
  .lz-window:hover{transform:translateY(-2px);border-color:rgba(90,176,255,.42);
    box-shadow:0 32px 74px -24px rgba(0,0,0,.9), 0 0 0 1px rgba(90,176,255,.2) inset}
  .lz-port{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:#cdd6c2}
  .lz-clip,.lz-port-ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
  .lz-clip{z-index:2;background:#cdd6c2;opacity:0;transition:opacity .4s}
  .lz-clip.is-ready{opacity:1}                 /* revealed by JS once a real clip loads */
  .lz-port-ph{z-index:1}
  .lz-ph-flow path{stroke-dasharray:5 13;animation:phflow 1.25s linear infinite}
  @keyframes phflow{to{stroke-dashoffset:-18}}
  .lz-port::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
    box-shadow:0 0 70px 10px rgba(7,10,13,.4) inset}
  .lz-port-chip{position:absolute;left:11px;bottom:11px;z-index:4;display:inline-flex;align-items:center;gap:6px;
    font-size:11px;font-weight:800;letter-spacing:.3px;color:#fff;
    background:rgba(8,12,18,.6);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
    border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:5px 11px}
  .lz-port-chip i{width:7px;height:7px;border-radius:50%;background:var(--hero);flex:none;animation:lzlive 1.9s infinite}
  @keyframes lzlive{0%{box-shadow:0 0 0 0 rgba(43,191,106,.6)}70%{box-shadow:0 0 0 7px rgba(43,191,106,0)}
    100%{box-shadow:0 0 0 0 rgba(43,191,106,0)}}
  .lz-win-cta{display:flex;align-items:center;justify-content:center;gap:9px;padding:14px;
    font-size:15px;font-weight:800;color:#04121f;background:linear-gradient(120deg,#5ab0ff,#37b3a8);letter-spacing:.2px}
  .lz-win-arrow{transition:transform .16s}
  .lz-window:hover .lz-win-arrow{transform:translateX(4px)}
  .lz-cta{margin-top:30px}
  .lz-enter{border:0;border-radius:14px;padding:15px 30px;font-size:16px;font-weight:800;cursor:pointer;
    color:#04121f;background:linear-gradient(120deg,#5ab0ff,#37b3a8);
    box-shadow:0 12px 34px -10px rgba(90,176,255,.7);transition:transform .14s,box-shadow .14s}
  .lz-enter:hover{transform:translateY(-1px);box-shadow:0 16px 42px -10px rgba(90,176,255,.85)}
  .lz-form{margin:28px auto 0;display:flex;flex-direction:column;gap:8px;width:100%;max-width:430px}
  .lz-formrow{display:flex;gap:8px;width:100%}
  .lz-form input{flex:1;min-width:0;background:rgba(11,15,22,.92);border:1px solid rgba(255,255,255,.18);
    border-radius:12px;color:var(--txt);padding:13px 15px;font-size:15px;outline:none;transition:.15s}
  .lz-form input::placeholder{color:#9fb0c0}
  .lz-form input:focus{border-color:var(--accent);background:rgba(16,22,30,.96)}
  .lz-form input:disabled{opacity:.6}
  /* hub picker on the hero: match the glass inputs (the shared trigger keeps its panel look elsewhere).
     Reserve the collapsed trigger height so the picker mounting async (when REGIONS lands) doesn't grow
     the vertically-centered hero column and jolt everything up/down. */
  .lz-hub{min-height:46px}
  .lz-hub .hubpick-trig{background:rgba(11,15,22,.92);border:1px solid rgba(255,255,255,.18);
    border-radius:12px;color:#9fb0c0;padding:13px 15px;font-size:15px}
  .lz-hub.has-val .hubpick-trig{border-color:var(--accent)}
  .lz-form button{flex:0 0 auto;border:1px solid var(--line2);background:var(--panel2);color:var(--txt);
    border-radius:12px;padding:0 18px;font-size:14px;font-weight:700;cursor:pointer;transition:.15s;
    white-space:nowrap}
  .lz-form button:hover{border-color:var(--accent);color:#fff}
  .lz-form button:disabled{opacity:.55;cursor:not-allowed}
  .lz-form button:disabled:hover{border-color:var(--line2);color:var(--txt)}
  .lz-formnote{margin-top:11px;font-size:12.5px;color:#dde7f1;min-height:1.2em;text-shadow:0 1px 3px rgba(0,0,0,.92),0 1px 10px rgba(0,0,0,.6)}
  .lz-formnote.ok{color:var(--hero)}
  .lz-formnote.err{color:var(--soft)}
  .lz-more{margin:36px auto 44px;color:#dde7f1;font-size:11.5px;font-weight:700;letter-spacing:.5px;
    text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;
    animation:lzbob 2.4s infinite;background:none;border:0;text-shadow:0 1px 3px rgba(0,0,0,.92),0 1px 10px rgba(0,0,0,.6)}
  .lz-more svg{width:18px;height:18px}
  @keyframes lzbob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

  .lz-story{max-width:780px;margin:0 auto;padding:46px 22px 0;width:100%}
  .lz-story h2{text-align:center;font-size:clamp(27px,4.6vw,42px);font-weight:800;margin:0 0 6px;
    letter-spacing:-.7px;line-height:1.04;color:#fff}
  .lz-story h2 b{font-weight:800;background:linear-gradient(120deg,#5ee0a0,#5ab8ff);
    -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
  .lz-story .lz-h2sub{text-align:center;color:#9fb0c0;font-size:14px;margin:0 auto 26px;max-width:34em}
  .lz-prob{display:flex;flex-wrap:wrap;justify-content:center;gap:13px;text-align:left}
  .lz-card{position:relative;border:1px solid var(--line);border-radius:18px;overflow:hidden;
    background:linear-gradient(180deg,rgba(18,24,33,.74),rgba(12,17,24,.74));
    transition:transform .15s,border-color .15s,box-shadow .15s;
    flex:1 1 220px;max-width:310px}
  .lz-card:hover{transform:translateY(-3px);border-color:var(--line2);box-shadow:0 18px 40px -20px rgba(0,0,0,.7)}
  .lz-card::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--ac)}
  .lz-card-top{height:80px;display:flex;align-items:center;justify-content:center;gap:9px;
    background:radial-gradient(130% 130% at 50% -16%, var(--acsoft) 0%, transparent 68%);
    border-bottom:1px solid var(--line)}
  .lz-card-bd{padding:14px 16px 17px}
  .lz-card h3{margin:0 0 5px;font-size:15px;font-weight:800}
  .lz-card p{margin:0;font-size:12.7px;color:#9fb0c0;line-height:1.5}
  .lz-c-hero{--ac:#13a85a;--acsoft:rgba(19,168,90,.16)}
  .lz-c-mud{--ac:#e0524a;--acsoft:rgba(224,82,74,.15)}
  .lz-c-snow{--ac:#37b3a8;--acsoft:rgba(55,179,168,.16)}
  .lz-c-swap{--ac:#5ab0ff;--acsoft:rgba(90,176,255,.15)}
  .lz-c-time{--ac:#e3a13a;--acsoft:rgba(227,161,58,.16)}
  .lz-vchip{font-size:12.5px;font-weight:800;padding:6px 12px;border-radius:9px}
  .lz-vscore{font-size:22px;font-weight:900;color:var(--ac)}
  .lz-vbar{display:inline-flex;gap:3px;align-items:center}
  .lz-vbar i{width:9px;height:20px;border-radius:3px;background:var(--snow);opacity:.38}
  .lz-vbar i.on{opacity:1;background:var(--snowfree)}
  .lz-vbar small{margin-left:7px;font-size:11px;font-weight:800;color:var(--snowfree);text-transform:uppercase;letter-spacing:.5px}
  .lz-vswap{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800}
  .lz-vswap .x{color:var(--muddy)} .lz-vswap .y{color:var(--tacky)} .lz-vswap .ar{color:var(--muted);font-size:14px}
  .lz-vclock{display:inline-flex;align-items:center;gap:6px;font-size:14px}
  .lz-vclock b{font-size:15px;font-weight:900;color:var(--ac)}
  .lz-vcomfort{display:inline-flex;gap:3px;margin-left:9px}
  .lz-vcomfort i{width:8px;height:18px;border-radius:2px}
  .lz-how{margin:30px auto 0;text-align:center;color:#8b98a8;font-size:12.5px;line-height:1.6;max-width:40em}
  .lz-how b{color:#bcd0e0;font-weight:700}
  .lz-story .lz-cta{margin-top:34px;text-align:center}

  /* mobile app announcement — leads the scroll below the hero, NO card: an exciting "take it on
     the go" moment (offline · on-trail · alerts). A soft accent glow sets it apart with no box.
     Badges flip from "coming soon" to live download links when APP_LINKS are set (initAppBadges). */
  /* full-bleed section: the band spans the viewport (glow is full-width); the content inside stays
     centered + readable via each child's own max-width. */
  .lz-app{position:relative;text-align:center;padding:54px 22px 50px;
    background:radial-gradient(80vw 360px at 50% 4%, rgba(90,176,255,.12), transparent 70%)}
  .lz-app-tag{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:800;
    letter-spacing:.5px;text-transform:uppercase;color:var(--accent);background:rgba(90,176,255,.13);
    border:1px solid rgba(90,176,255,.4);border-radius:999px;padding:5px 13px}
  .lz-app-tag i{width:6px;height:6px;border-radius:50%;background:var(--accent);flex:none}
  .lz-app-tag.live{color:var(--hero);background:rgba(19,168,90,.14);border-color:rgba(19,168,90,.4)}
  .lz-app-tag.live i{background:var(--hero)}
  .lz-app-h{font-size:clamp(27px,4.6vw,42px);font-weight:800;letter-spacing:-.7px;line-height:1.04;
    color:#fff;margin:16px auto 0;max-width:15ch}
  .lz-app-h b{font-weight:800;background:linear-gradient(120deg,#5ee0a0,#5ab8ff);
    -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}
  .lz-app-sub{font-size:clamp(14px,1.9vw,16.5px);color:#cdd8e4;line-height:1.55;margin:15px auto 0;max-width:33em}
  .lz-app-feats{display:flex;flex-wrap:wrap;justify-content:center;gap:16px 30px;margin:30px auto 4px;max-width:680px}
  .lz-app-feat{display:flex;align-items:flex-start;gap:11px;text-align:left;flex:1 1 185px;max-width:215px}
  .lz-app-feat .fic{width:36px;height:36px;flex:none;border-radius:10px;display:flex;align-items:center;
    justify-content:center;color:var(--accent);background:rgba(90,176,255,.12);border:1px solid rgba(90,176,255,.28)}
  .lz-app-feat .fic svg{width:19px;height:19px}
  .lz-app-feat b{display:block;font-size:13.5px;font-weight:800;color:#eaf1f8;margin-bottom:3px;letter-spacing:-.1px}
  .lz-app-feat>div span{display:block;font-size:11.7px;color:#90a0b2;line-height:1.42}
  /* the tier line — makes the web-free / app-paid model explicit: the native app is the marquee
     Season Pass perk. Reuses the ★ Season Pass chip from supporterBadge(); links to the supporter modal. */
  .lz-app-tier{margin:22px auto 0;max-width:38em;font-size:13.5px;color:#cdd8e4;line-height:1.55}
  .lz-app-tier .sup-tag{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:800;
    color:#04121f;background:var(--accent);border-radius:999px;padding:2px 9px;letter-spacing:.02em;vertical-align:middle}
  .lz-app-tier button{background:none;border:0;color:#7fc8ff;font-weight:700;cursor:pointer;padding:0;
    font-size:13.5px;white-space:nowrap}
  .lz-app-tier button:hover{text-decoration:underline}
  .lz-app-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:20px}
  .lz-store{display:inline-flex;align-items:center;gap:11px;text-decoration:none;color:#fff;background:#000;
    border:1px solid rgba(255,255,255,.3);border-radius:11px;padding:9px 17px;min-width:170px;
    transition:transform .14s,border-color .14s,box-shadow .14s,opacity .14s}
  .lz-store-ic{width:26px;height:26px;flex:none;fill:#fff}
  .lz-store-tx{display:flex;flex-direction:column;line-height:1.12;text-align:left}
  .lz-store-tx small{font-size:9.5px;font-weight:500;letter-spacing:.2px;opacity:.9}
  .lz-store-tx b{font-size:16px;font-weight:700;letter-spacing:.2px}
  .lz-store:not(.is-soon):hover{transform:translateY(-2px);border-color:rgba(255,255,255,.55);
    box-shadow:0 14px 30px -16px rgba(0,0,0,.9)}
  .lz-store.is-soon{opacity:.6;cursor:default}
  .lz-store.is-soon:hover{border-color:rgba(255,255,255,.4)}
  .lz-app-note{margin-top:16px;font-size:12.5px;color:#8b98a8}
  .lz-app-note button{background:none;border:0;color:#7fc8ff;font-size:12.5px;font-weight:700;
    cursor:pointer;padding:0}
  .lz-app-note button:hover{text-decoration:underline}
  /* inline "Season Pass" → opens the Season Pass modal wherever it's mentioned (Growth: every
     mention is a tap target). Reuses the landing accent-link color; never a new shape/color. */
  .sp-link{background:none;border:0;padding:0;margin:0;font:inherit;font-weight:800;color:#7fc8ff;
    cursor:pointer;text-decoration:underline;text-underline-offset:2px;
    text-decoration-thickness:1px;text-decoration-color:rgba(127,200,255,.45)}
  .sp-link:hover{text-decoration-color:#7fc8ff}
  .lz-app-tier .sp-chip{cursor:pointer;transition:filter .14s,transform .14s}
  .lz-app-tier .sp-chip:hover{text-decoration:none;filter:brightness(1.07);transform:translateY(-1px)}

  /* indie footer — homepage only (lives inside #landing, which hides in the app) */
  .lz-footer{max-width:640px;margin:30px auto 0;padding:18px 22px calc(34px + env(safe-area-inset-bottom));
    text-align:center}
  .lz-foot-love{font-size:14px;font-weight:700;color:#cdd8e4;letter-spacing:.1px}
  .lz-foot-sub{font-size:12px;color:var(--faint);margin-top:7px;line-height:1.5}
  .lz-foot-sub a{color:#7fc8ff;text-decoration:none}.lz-foot-sub a:hover{text-decoration:underline}

  .lz-faq{margin:48px auto 0;max-width:640px;width:100%}
  .lz-faq-title{text-align:center;font-size:13px;font-weight:800;text-transform:uppercase;
    letter-spacing:.8px;color:var(--muted);margin:0 0 20px}
  .lz-faq-item{border-top:1px solid var(--line);padding:0}
  .lz-faq-q{width:100%;background:none;border:0;text-align:left;padding:17px 4px;
    display:flex;justify-content:space-between;align-items:center;gap:12px;cursor:pointer}
  .lz-faq-q span{font-size:15px;font-weight:700;color:var(--txt);line-height:1.3}
  .lz-faq-icon{flex:none;width:20px;height:20px;color:var(--muted);transition:transform .22s}
  .lz-faq-item.open .lz-faq-icon{transform:rotate(45deg)}
  .lz-faq-a{max-height:0;overflow:hidden;transition:max-height .28s cubic-bezier(.4,0,.2,1)}
  .lz-faq-item.open .lz-faq-a{max-height:800px}
  .lz-faq-a p{margin:0 0 16px;font-size:13.5px;color:#9fb0c0;line-height:1.65;padding:0 4px}
  .lz-faq-a p:first-child{margin-top:0}
  .lz-faq-a b{color:#bcd0e0;font-weight:700}

  @media(max-width:640px){
    /* hero is a full-height focused screen; the story + FAQ live just below it (scroll). */
    .lz-inner{min-height:100svh;padding:30px 22px calc(40px + env(safe-area-inset-bottom))}
    .lz-story{padding:36px 18px 0}
    .lz-mark{width:40px;height:40px}
    .lz-word{font-size:24px}
    .lz-brand{margin-bottom:24px}
    .lz-window{margin-top:24px}
    .lz-app{padding:38px 18px 34px}
    .lz-app-feat{flex:1 1 100%;max-width:300px}
    .lz-store{flex:1 1 220px;justify-content:center;min-width:0}
  }
