/* ============================================================================
   TRAIN WITH MAIS — BRAND DESIGN SYSTEM   ·   brand.css
   ----------------------------------------------------------------------------
   Single source of truth for every Train with Mais page. Link it in any page's
   <head>, then build with the components below so everything stays on-brand.

       <link rel="stylesheet" href="brand.css">

   Voice: fun, warm, community-first. Visual-first, very little text (think
   apple.com / spacex.com, but joyful). Yellow leads; ink anchors; coral pops.
   Handle is @trainwithmais everywhere. Tagline: "On Mondays we chill."

   SECTIONS
     1. Tokens          6. Section heads
     2. Base / reset    7. Cards (ethos · session · strava · path)
     3. Layout          8. Marquee · badge · final CTA
     4. Typography      9. Footer
     5. Buttons/chips  10. Utilities · motion · responsive
   ============================================================================ */

/* ─── 1. TOKENS ───────────────────────────────────────────────────────────
   Use these variables instead of hard-coded values on new pages.            */
:root{
  /* color — palette */
  --paper:#FBF4E6;     /* warm off-white — default page background            */
  --paper-2:#F4E9D2;   /* deeper paper — alternating sections                 */
  --ink:#1C1710;       /* warm near-black — text, borders, dark sections      */
  --ink-soft:#5B5346;  /* muted ink — secondary text                          */
  --sun:#FFC42E;       /* PRIMARY gold (Mais's colour) — heroes, CTAs, fills  */
  --sun-deep:#F2A900;  /* deeper gold — gradients, depth                      */
  --ember:#FF5A36;     /* coral pop — use sparingly: smile, accents, kudos    */
  --sea:#1F7A6D;       /* swim / sea accent                                   */
  --line:rgba(28,23,16,.14);   /* hairlines on paper                         */

  /* color — on dark (ink) sections */
  --on-ink:        #FBF4E6;
  --on-ink-soft:   rgba(251,244,230,.74);
  --on-ink-line:   rgba(251,244,230,.20);

  /* type — families */
  --display:"Fraunces", Georgia, serif;         /* expressive soft serif      */
  --sans:"Hanken Grotesk", system-ui, sans-serif; /* clean body / UI          */

  /* type — scale (fluid). Headings should use these.                         */
  --fs-display: clamp(3.1rem, 8.2vw, 6.6rem);   /* hero statement             */
  --fs-h1:      clamp(2.6rem, 7vw,   5.4rem);   /* page / CTA headline        */
  --fs-h2:      clamp(2.1rem, 5vw,   3.5rem);   /* section headline           */
  --fs-h3:      clamp(1.8rem, 3.4vw, 2.6rem);   /* card / sub headline        */
  --fs-lead:    clamp(1.05rem,1.5vw, 1.28rem);  /* intro paragraph            */
  --fs-body:    1.05rem;
  --fs-small:   .86rem;
  --fs-eyebrow: .78rem;

  /* shape / depth */
  --r:22px;                                     /* card radius                */
  --r-pill:100px;                               /* pills, buttons, chips      */
  --shadow:    0 18px 50px -22px rgba(28,23,16,.45);
  --shadow-sm: 0 8px 24px -14px rgba(28,23,16,.40);
  --shadow-pop:3px 3px 0 var(--ink);            /* sticker / playful offset   */

  /* layout */
  --maxw:1220px;
  --space-section:96px;                          /* vertical rhythm per block  */
  --gap:24px;

  /* motion */
  --ease-bounce: cubic-bezier(.34,1.56,.64,1);
  --ease-out:    cubic-bezier(.2,.7,.2,1);
  --dur:.25s;
}

/* ─── 2. BASE / RESET ─────────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--ink);color:var(--sun)}
:focus-visible{outline:3px solid var(--ember);outline-offset:3px;border-radius:4px}

/* grain overlay — tactile, premium texture over the whole page. */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.045'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

/* ─── 3. LAYOUT ───────────────────────────────────────────────────────────
   .wrap         centred max-width container
   section.block standard vertical section spacing
   .alt          one shade deeper background (alternate sections)
   .on-dark      ink background section with light text                       */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
section.block{padding:var(--space-section) 0}
.alt{background:var(--paper-2)}
.on-dark{background:var(--ink);color:var(--on-ink)}
.on-dark .eyebrow{color:var(--sun)}

/* ─── 4. TYPOGRAPHY ───────────────────────────────────────────────────────
   .serif/.ital  switch family / style
   .eyebrow      small uppercase label above a heading
   .hl           yellow marker highlight behind inline text
   .smile        the signature hand-drawn underline (smile / sun / route).
                 Wrap a word in .smile and drop an <svg> arc inside; it draws
                 itself when an ancestor gets .in-view.                        */
.serif{font-family:var(--display)}
.ital{font-style:italic}
.eyebrow{font-size:var(--fs-eyebrow);letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--ink-soft)}
.hl{background:linear-gradient(transparent 62%, var(--sun) 62%);padding:0 .06em}
.handle{font-weight:800;font-size:1rem}            /* @trainwithmais          */
.dotsep{width:5px;height:5px;border-radius:50%;background:var(--ink);opacity:.4} /* inline separator */

.smile{position:relative;display:inline-block}
.smile svg{position:absolute;left:-2%;bottom:-.42em;width:104%;height:.5em;overflow:visible}
.smile svg path{fill:none;stroke:var(--ember);stroke-width:9;stroke-linecap:round;stroke-dasharray:1000;stroke-dashoffset:1000}
.in-view .smile svg path{animation:draw 1s .35s var(--ease-bounce) forwards}
@keyframes draw{to{stroke-dashoffset:0}}

/* ─── 5. BUTTONS & CHIPS ──────────────────────────────────────────────────
   .btn           base pill button (defaults to ink)
   .btn--sun      yellow (primary CTA)   .btn--ghost  outline
   .statchip      data pill (km, pace…)  .tag  category pill on media
   .chip-float    playful sticker (.c1/.c2 = preset float positions)
   .ph-label      label on a media poster                                     */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--sans);font-weight:700;font-size:1rem;line-height:1;
  padding:1.05em 1.6em;border-radius:var(--r-pill);border:2px solid var(--ink);
  background:var(--ink);color:var(--paper);cursor:pointer;
  transition:transform var(--dur) var(--ease-bounce), box-shadow var(--dur), background .2s;
  will-change:transform;
}
.btn:hover{transform:translateY(-3px) rotate(-1deg);box-shadow:var(--shadow)}
.btn--sun{background:var(--sun);color:var(--ink);border-color:var(--ink)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn svg{width:18px;height:18px;flex:none}
.t-short{display:none}      /* responsive: show a shorter button label on mobile */

.statchip{background:rgba(251,244,230,.85);border:1.5px solid var(--ink);border-radius:var(--r-pill);padding:5px 11px;font-weight:700;font-size:.78rem;backdrop-filter:blur(3px)}
.tag{background:var(--paper);border:2px solid var(--ink);border-radius:var(--r-pill);padding:6px 12px;font-weight:700;font-size:.78rem}
.chip-float{position:absolute;z-index:6;background:var(--paper);border:2px solid var(--ink);border-radius:var(--r-pill);padding:9px 14px;font-weight:700;font-size:.85rem;box-shadow:var(--shadow-pop);display:inline-flex;align-items:center;gap:7px}
.chip-float.c1{left:-22px;top:34%;transform:rotate(-6deg);animation:bob 5s ease-in-out infinite}
.chip-float.c2{right:6%;bottom:-18px;transform:rotate(4deg);background:var(--sun);animation:bob 6s ease-in-out infinite .6s}
@keyframes bob{0%,100%{translate:0 0}50%{translate:0 -9px}}
.ph-label{position:absolute;left:16px;top:16px;z-index:3;display:inline-flex;align-items:center;gap:8px;background:rgba(28,23,16,.78);color:var(--paper);padding:8px 13px;border-radius:var(--r-pill);font-size:.8rem;font-weight:700;backdrop-filter:blur(4px)}

/* Strava follow — the casual, recurring CTA. Put it in nav, hero and footer. */
.strava-mini{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:.86rem;color:var(--ink-soft);transition:color .2s}
.strava-mini:hover{color:var(--ember)}
.strava-mini svg{width:16px;height:16px}

/* ─── NAV ─────────────────────────────────────────────────────────────────
   <header class="nav" id="nav"> … gets .scrolled added past 20px scroll.     */
header.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:18px 0;transition:background .3s, box-shadow .3s, padding .3s}
header.nav.scrolled{background:rgba(251,244,230,.82);backdrop-filter:blur(14px) saturate(140%);box-shadow:0 1px 0 var(--line);padding:12px 0}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:-.01em}
.brand .dot{width:30px;height:30px;border-radius:50%;background:var(--sun);display:grid;place-items:center;flex:none;border:2px solid var(--ink);box-shadow:2px 2px 0 var(--ink)}
.brand .dot svg{width:18px;height:18px}
.brand b{font-size:1.12rem}
.brand span{font-family:var(--display);font-style:italic;font-weight:600}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a.lnk{font-weight:600;font-size:.96rem;position:relative}
.nav-links a.lnk::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;height:2px;background:var(--ember);transition:right .3s}
.nav-links a.lnk:hover::after{right:0}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none}

/* ─── HERO ────────────────────────────────────────────────────────────────
   .hero > .hero-grid (copy + .hero-media). .poster = media placeholder card,
   .badge = rotating circular stamp, .sun-blob = soft ambient glow.           */
.hero{position:relative;padding:150px 0 70px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:26px}
.flag{font-size:1rem;letter-spacing:.1em}
.hero h1{font-family:var(--display);font-weight:900;font-size:var(--fs-display);line-height:.94;letter-spacing:-.025em;margin-bottom:48px}
.hero h1 .l2{display:block;font-style:italic;font-weight:900}
.hero p.lede{font-size:var(--fs-lead);color:var(--ink-soft);max-width:30ch;margin-bottom:34px;font-weight:500}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-foot{display:flex;align-items:center;gap:22px;margin-top:38px;flex-wrap:wrap}

.hero-media{position:relative}
.poster{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/5;border:2px solid var(--ink);box-shadow:var(--shadow);
  background:radial-gradient(120% 90% at 20% 0%, rgba(255,255,255,.35), transparent 55%), linear-gradient(150deg, var(--sun) 0%, var(--sun-deep) 48%, #E07B2E 100%)}
.poster .grainy{position:absolute;inset:0;opacity:.25;background:repeating-linear-gradient(115deg, rgba(28,23,16,.08) 0 2px, transparent 2px 7px)}
.poster .cap{position:absolute;left:16px;right:16px;bottom:16px;z-index:3;color:var(--ink);display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.poster .cap .ctxt{font-family:var(--display);font-weight:600;font-size:1.15rem;line-height:1.1}
.poster .cap small{display:block;font-family:var(--sans);font-weight:600;font-size:.78rem;opacity:.7;margin-top:3px}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--ember);box-shadow:0 0 0 0 rgba(255,90,54,.7);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,90,54,.6)}70%{box-shadow:0 0 0 10px rgba(255,90,54,0)}100%{box-shadow:0 0 0 0 rgba(255,90,54,0)}}
.play{width:64px;height:64px;border-radius:50%;background:var(--paper);border:2px solid var(--ink);display:grid;place-items:center;flex:none;box-shadow:var(--shadow-sm);transition:transform var(--dur)}
.poster:hover .play{transform:scale(1.08)}
.play svg{width:22px;height:22px;margin-left:3px}

.badge{position:absolute;right:-26px;top:-26px;width:118px;height:118px;z-index:5;animation:spin 16s linear infinite}
.badge svg{width:100%;height:100%}
.badge .bcenter{position:absolute;inset:0;display:grid;place-items:center}
.badge .bcenter span{width:52px;height:52px;border-radius:50%;background:var(--ember);border:2px solid var(--ink);display:grid;place-items:center;color:var(--paper);font-size:22px}
.badge text{font-family:var(--sans);font-weight:800;font-size:13.5px;letter-spacing:.04em;fill:var(--ink)}
@keyframes spin{to{transform:rotate(360deg)}}

.sun-blob{position:absolute;z-index:-1;border-radius:50%;filter:blur(8px);opacity:.5}
.sun-blob.b1{width:520px;height:520px;background:radial-gradient(circle,var(--sun),transparent 62%);top:-160px;right:-120px}
.sun-blob.b2{width:360px;height:360px;background:radial-gradient(circle,#FFE08A,transparent 60%);bottom:-120px;left:-130px}

/* ─── 6. SECTION HEADS ───────────────────────────────────────────────────
   .sec-head > .eyebrow + h2 + p  — the standard way to open a section.       */
.sec-head{max-width:680px;margin-bottom:48px}
.sec-head .eyebrow{margin-bottom:16px;display:block}
.sec-head h2{font-family:var(--display);font-weight:900;font-size:var(--fs-h2);line-height:1.02;letter-spacing:-.02em}
.sec-head p{margin-top:16px;color:var(--ink-soft);font-size:1.1rem;max-width:46ch;font-weight:500}
.on-dark .sec-head p{color:var(--on-ink-soft)}

/* ─── 7. CARDS ────────────────────────────────────────────────────────────
   .ecard  ethos / value card  (designed for a .on-dark section)
   .scard  session media card  (+ .bg-ride/.bg-swim/.bg-track/.bg-sauna duotone,
                                  + .big/.sm/.t3 spans inside .show-grid)
   .route-card  Strava route + stats card
   .pcard  pricing / path card (+ .open yellow, + .priv ink)                  */
.ecard{border:2px solid var(--on-ink-line);border-radius:var(--r);padding:32px 28px;background:rgba(251,244,230,.03);transition:transform .3s, background .3s, border-color .3s}
.ecard:hover{transform:translateY(-6px);background:rgba(255,196,46,.08);border-color:var(--sun)}
.ecard .ic{font-size:1.8rem;margin-bottom:6px;display:block}
.ecard .num{font-family:var(--display);font-style:italic;font-weight:600;color:var(--sun);font-size:1.4rem}
.ecard h3{font-family:var(--display);font-weight:700;font-size:1.7rem;margin:14px 0 10px;letter-spacing:-.01em}
.ecard p{color:var(--on-ink-soft);font-size:1.02rem}
.ethos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}

.show-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.scard{position:relative;border-radius:var(--r);overflow:hidden;border:2px solid var(--ink);box-shadow:var(--shadow-sm);min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;transition:transform .35s var(--ease-bounce)}
.scard:hover{transform:translateY(-6px)}
.scard .grainy{position:absolute;inset:0;opacity:.22;background:repeating-linear-gradient(115deg, rgba(28,23,16,.1) 0 2px, transparent 2px 8px)}
.scard.big{grid-column:span 7;min-height:420px}
.scard.sm{grid-column:span 5}
.scard.t3{grid-column:span 4;min-height:300px}
.scard .meta{position:relative;z-index:2;padding:22px;color:var(--ink)}
.scard h3{font-family:var(--display);font-weight:700;font-size:1.5rem;line-height:1.05}
.scard .chips{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.scard .pbtn{position:absolute;top:16px;right:16px;z-index:3;width:46px;height:46px;border-radius:50%;background:var(--ink);display:grid;place-items:center;transition:transform var(--dur)}
.scard:hover .pbtn{transform:scale(1.12)}
.scard .pbtn svg{width:16px;height:16px;margin-left:2px}
/* duotone media backgrounds — keep within the brand temperature */
.bg-ride{background:linear-gradient(155deg,#FFD15C,#F2A900 55%,#E0702A)}
.bg-swim{background:linear-gradient(155deg,#6FD3C6,#1F7A6D 60%,#155E66)}
.bg-track{background:linear-gradient(155deg,#FF8A6B,#FF5A36 60%,#C7381E)}
.bg-sauna{background:linear-gradient(155deg,#FFC97A,#E08A3C 55%,#8C4A1E)}
.scard.bg-swim h3,.scard.bg-swim .meta,.scard.bg-track h3,.scard.bg-track .meta,.scard.bg-sauna h3,.scard.bg-sauna .meta{color:var(--paper)}

.route-card{border:2px solid var(--ink);border-radius:var(--r);background:var(--paper);overflow:hidden;box-shadow:var(--shadow)}
.route-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:2px solid var(--ink)}
.route-head .who{display:flex;align-items:center;gap:11px;font-weight:800}
.route-head .who .av{width:36px;height:36px;border-radius:50%;background:var(--sun);border:2px solid var(--ink);display:grid;place-items:center;font-family:var(--display);font-weight:900;font-style:italic}
.route-head .who small{display:block;font-weight:600;font-size:.78rem;color:var(--ink-soft)}
.kudos{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:.85rem;color:var(--ember)}
.route-map{position:relative;aspect-ratio:16/10;background:
  linear-gradient(0deg,var(--line),var(--line)) 0 0/100% 1px no-repeat,
  repeating-linear-gradient(0deg,transparent 0 31px,var(--line) 31px 32px),
  repeating-linear-gradient(90deg,transparent 0 31px,var(--line) 31px 32px),
  var(--paper)}
.route-map svg{position:absolute;inset:0;width:100%;height:100%}
.route-stats{display:grid;grid-template-columns:repeat(4,1fr)}
.route-stats div{padding:15px 8px;text-align:center}
.route-stats div:last-child{border-right:0}
.route-stats .v{font-family:var(--display);font-weight:900;font-size:clamp(1.2rem,3.2vw,1.6rem);line-height:1;font-variant-numeric:tabular-nums}
.route-stats .k{font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;margin-top:6px;white-space:nowrap}

.paths-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap)}
.pcard{border:2px solid var(--ink);border-radius:var(--r);padding:38px 34px;position:relative;overflow:hidden;transition:transform .3s}
.pcard:hover{transform:translateY(-6px)}
.pcard.open{background:var(--sun)}
.pcard.priv{background:var(--ink);color:var(--paper)}
.pcard .ptag{font-weight:800;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase}
.pcard h3{font-family:var(--display);font-weight:900;font-size:var(--fs-h3);line-height:1;margin:14px 0 14px;letter-spacing:-.02em}
.pcard p{font-size:1.05rem;margin-bottom:26px;max-width:34ch;font-weight:500}
.pcard.priv p{color:var(--on-ink-soft)}
.pcard ul{list-style:none;margin-bottom:28px;display:flex;flex-direction:column;gap:10px}
.pcard li{display:flex;align-items:center;gap:10px;font-weight:600}
.pcard li svg{width:18px;height:18px;flex:none}
.pcard.priv .btn{background:var(--sun);color:var(--ink);border-color:var(--sun)}
.both-note{text-align:center;margin-top:26px;font-family:var(--display);font-style:italic;font-size:1.15rem;color:var(--ink-soft)}

/* ─── 8. MARQUEE · FINAL CTA ──────────────────────────────────────────────
   .marquee > .track > span…  (duplicate the spans once for a seamless loop;
   wrap the separator glyph in .star to colour it coral).                     */
.marquee{background:var(--ink);color:var(--sun);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);overflow:hidden;padding:18px 0;margin-top:30px}
.marquee .track{display:flex;white-space:nowrap;width:max-content;animation:scroll 26s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee .track span{font-family:var(--display);font-style:italic;font-weight:600;font-size:1.7rem;padding:0 .55em;display:inline-flex;align-items:center;gap:.55em}
.marquee .star{color:var(--ember);font-style:normal}
@keyframes scroll{to{transform:translateX(-50%)}}

.final{background:var(--ink);color:var(--paper);text-align:center;position:relative;overflow:hidden}
.final .sun-blob.bf{width:600px;height:600px;background:radial-gradient(circle,rgba(255,196,46,.55),transparent 60%);top:-200px;left:50%;translate:-50% 0;opacity:.6;filter:blur(10px)}
.final h2{font-family:var(--display);font-weight:900;font-size:var(--fs-h1);line-height:.96;letter-spacing:-.025em;margin-bottom:22px}
.final h2 em{color:var(--sun);font-weight:900;font-style:italic}
.final p{color:var(--on-ink-soft);font-size:1.2rem;margin-bottom:38px;font-weight:500}
.final .hero-ctas{justify-content:center}
.final .btn--ghost{color:var(--paper);border-color:var(--paper)}
.final .btn--ghost:hover{background:var(--paper);color:var(--ink)}

/* ─── 9. FOOTER ─────────────────────────────────────────────────────────── */
footer{background:var(--ink);color:var(--paper);padding:60px 0 40px;border-top:2px solid var(--on-ink-line)}
.foot-grid{display:flex;align-items:flex-start;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot-brand{font-family:var(--display);font-weight:900;font-style:italic;font-size:2rem}
.foot-brand+p{color:rgba(251,244,230,.6);margin-top:8px;max-width:30ch}
.foot-soc{display:flex;gap:14px;margin-top:18px}
.foot-soc a{width:44px;height:44px;border-radius:50%;border:2px solid rgba(251,244,230,.3);display:grid;place-items:center;transition:.25s}
.foot-soc a:hover{background:var(--sun);color:var(--ink);border-color:var(--sun);transform:translateY(-3px)}
.foot-soc a svg{width:20px;height:20px}
.foot-cols{display:flex;gap:64px;flex-wrap:wrap}
.foot-cols h4{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sun);margin-bottom:16px}
.foot-cols a{display:block;color:rgba(251,244,230,.78);margin-bottom:11px;font-weight:500;transition:.2s}
.foot-cols a:hover{color:var(--paper);transform:translateX(5px)}
.foot-base{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:48px;padding-top:24px;border-top:1px solid var(--on-ink-line);flex-wrap:wrap;color:rgba(251,244,230,.55);font-size:.86rem}
.foot-base .chill{font-family:var(--display);font-style:italic;color:var(--sun);font-weight:600}

/* ─── 10. UTILITIES · MOTION · RESPONSIVE ─────────────────────────────────
   .reveal (+ .d1..d4 stagger delays) — add .in-view via IntersectionObserver
   to fade/slide content in on scroll.                                        */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease-out), transform .8s var(--ease-out)}
.reveal.in-view{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

@media(max-width:920px){
  .hero-grid,.strava-grid{grid-template-columns:1fr}
  .hero-media{width:100%;max-width:440px;margin:0 auto;order:-1}
  .ethos-grid{grid-template-columns:1fr}
  .show-grid{grid-template-columns:1fr}
  .scard.big,.scard.sm,.scard.t3{grid-column:span 1;min-height:300px}
  .paths-grid{grid-template-columns:1fr}
  .nav-links{display:none}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--paper);padding:24px;gap:18px;border-bottom:2px solid var(--ink);box-shadow:var(--shadow)}
  .nav-toggle{display:grid;place-items:center;width:44px;height:44px;border:2px solid var(--ink);border-radius:12px;background:var(--paper);cursor:pointer}
  .nav-toggle svg{width:22px;height:22px}
}
@media(max-width:620px){
  .nav-cta .strava-mini{display:none}
  .brand b{font-size:1rem;white-space:nowrap}
  .navjoin{padding:.72em 1.05em;font-size:.85rem}
  .t-long{display:none}
  .t-short{display:inline}
}
@media(max-width:540px){
  .hero{padding-top:120px}
  .badge{width:92px;height:92px;right:-10px;top:-16px}
  .route-stats{grid-template-columns:repeat(2,1fr)}
  .route-stats div:nth-child(2){border-right:0}
  .route-stats div:nth-child(1),.route-stats div:nth-child(2){border-bottom:2px solid var(--ink)}
  .marquee .track span{font-size:1.3rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
  .reveal{opacity:1;transform:none}
  .smile svg path{stroke-dashoffset:0}
}

/* The Strava section sets its own two-column grid; it lives with the page that
   uses it, but the helper is here so any page can reuse it. */
.strava-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}
.strava-copy h2{font-family:var(--display);font-weight:900;font-size:clamp(2rem,4.4vw,3.2rem);line-height:1.03;letter-spacing:-.02em;margin-bottom:18px}
.strava-copy p{color:var(--ink-soft);font-size:1.12rem;margin-bottom:24px;max-width:42ch;font-weight:500}
