/* Momentum Coaching marketing site. Brand: teal + amber on light, Bricolage Grotesque + Inter. */
:root {
  --ink:#141D1B; --muted:#5D6675; --faint:#8A93A2;
  --teal:#0D9488; --teal-deep:#0B5A46; --teal-soft:#E8F4F1; --teal-glow:#2BD4A8;
  --amber:#EF9F27; --amber-ink:#3D2A05; --amber-soft:#FBF3E4;
  --bg:#FAFBFC; --card:#FFFFFF; --line:#E5EAF0; --night:#0E1614; --night-2:#13201C;
}
* { box-sizing:border-box; margin:0; }
html { scroll-behavior:smooth; overflow-x:hidden; overscroll-behavior-x:none; }
body { overflow-x:hidden; overscroll-behavior-x:none; position:relative; width:100%; }
body { font-family:Inter,system-ui,sans-serif; color:var(--ink); background:var(--bg); -webkit-font-smoothing:antialiased; }
h1,h2,h3,.disp { font-family:'Bricolage Grotesque',Inter,sans-serif; font-weight:800; letter-spacing:-.02em; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; }
.wrap { max-width:1180px; margin:0 auto; padding:0 28px; }
.pill { display:inline-flex; align-items:center; gap:8px; border-radius:999px; padding:13px 26px; font-size:14px; font-weight:700; letter-spacing:.02em; transition:.15s; }
.pill-amber { background:var(--amber); color:var(--amber-ink); }
.pill-amber:hover { filter:brightness(1.06); transform:translateY(-1px); }
.pill-teal { background:var(--teal); color:#fff; }
.pill-teal:hover { filter:brightness(1.08); }
.pill-ghost { border:1.5px solid rgba(255,255,255,.7); color:#fff; }
.pill-ghost:hover { background:rgba(255,255,255,.12); }
.kicker { font-size:12px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--teal); margin-bottom:14px; }
@keyframes bob { 0%,100% { transform:translateY(0) } 50% { transform:translateY(-9px) } }

/* header */
header.site { position:sticky; top:0; z-index:50; background:rgba(250,251,252,.88); backdrop-filter:blur(14px); border-bottom:1px solid var(--line); }
header.site .wrap { display:flex; align-items:center; justify-content:space-between; height:66px; }
.wordmark { font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:23px; letter-spacing:-.02em; color:var(--ink); }
.wordmark .dot { display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--teal); margin-left:2px; transform:translateY(-10px); }
nav.main { display:flex; align-items:center; gap:26px; font-size:14px; color:var(--muted); font-weight:600; }
nav.main a:hover { color:var(--ink); }
nav.main a.on { color:var(--teal); }
nav.main .pill { padding:10px 22px; color:#fff; }

section.band { padding:92px 0; }
.band h2, .lab h2, .sports h2 { font-size:clamp(30px,3.6vw,44px); }
.lead { margin-top:16px; color:var(--muted); font-size:16.5px; line-height:1.7; max-width:62ch; }
.ch-n { font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:15px; color:var(--amber); letter-spacing:.2em; }

/* footer */
footer.site { border-top:1px solid var(--line); background:var(--card); padding:58px 0 36px; }
footer.site .cols { display:grid; grid-template-columns:1.2fr 1fr 1fr 1.4fr; gap:36px; }
footer.site .lbl { font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); margin-bottom:14px; }
footer.site a.f { display:block; font-size:14px; color:var(--muted); margin-bottom:10px; }
footer.site a.f:hover { color:var(--ink); }
footer.site .blurb { margin-top:14px; font-size:13.5px; color:var(--muted); line-height:1.6; max-width:30ch; }
footer.site form { display:flex; gap:8px; margin-top:10px; }
footer.site input { flex:1; min-width:0; border:1px solid var(--line); border-radius:999px; padding:11px 18px; font-size:14px; font-family:inherit; }
footer.site button { border:0; border-radius:999px; background:var(--teal); color:#fff; font-weight:700; font-size:14px; padding:11px 22px; cursor:pointer; }
footer.site .nl-note { font-size:13px; color:var(--muted); }
.legal { display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; color:var(--faint); font-size:12.5px; border-top:1px solid var(--line); margin-top:42px; padding-top:22px; }
.legal a { color:var(--faint); text-decoration:underline; }
.legal a:hover { color:var(--ink); }
.legal button.linklike { border:0; background:none; padding:0; font:inherit; color:var(--faint); text-decoration:underline; cursor:pointer; }
.legal button.linklike:hover { color:var(--ink); }

/* HOME: rotating hero */
.hero { position:relative; min-height:92vh; display:flex; align-items:flex-end; overflow:hidden; background:var(--night); }
.hero .slide { position:absolute; inset:0; z-index:0; background-size:cover; background-position:center 35%; opacity:0; transform:scale(1.06); transition:opacity 1.6s ease; }
.hero .slide.on { opacity:1; animation:heroDrift 9s ease-in-out forwards; }
@keyframes heroDrift { from { transform:scale(1.06) } to { transform:scale(1.12) } }
.hero .tint { position:absolute; inset:0; z-index:3; background:linear-gradient(165deg, rgba(8,14,12,.32) 0%, rgba(8,14,12,.54) 55%, rgba(8,14,12,.84) 100%); }
.hero .inner { position:relative; width:100%; padding:0 28px 84px; color:#fff; z-index:4; }
.hero .eyebrow { font-size:12.5px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:#8BE0CE; margin-bottom:18px; }
.hero h1 { font-size:clamp(46px,7.2vw,96px); line-height:.98; text-transform:uppercase; }
.hero h1 .hl { color:var(--amber); }
.hero p.sub { margin-top:22px; font-size:18px; line-height:1.6; color:rgba(255,255,255,.88); max-width:54ch; font-weight:500; }
.hero .cta { margin-top:30px; display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.hero .dots { position:absolute; right:44px; top:84px; z-index:5; display:flex; flex-direction:column; gap:8px; }
.hero .dots i { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.35); transition:.3s; }
.hero .dots i.on { background:var(--amber); transform:scale(1.3); }

/* HOME: sports marquee */
.sports { padding:74px 0 64px; overflow:hidden; }
.sports .head { display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:34px; }
.sports .head p { color:var(--muted); font-size:15px; max-width:36ch; line-height:1.6; }
.marquee { display:flex; gap:18px; width:max-content; animation:slideX 46s linear infinite; }
.marquee:hover { animation-play-state:paused; }
@keyframes slideX { from { transform:translateX(0) } to { transform:translateX(-50%) } }
.tile { position:relative; width:248px; height:330px; border-radius:22px; overflow:hidden; flex:none; }
.tile img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.tile:hover img { transform:scale(1.06); }
.tile::after { content:''; position:absolute; inset:0; background:linear-gradient(180deg, rgba(8,14,12,0) 50%, rgba(8,14,12,.72) 100%); }
.tile span { position:absolute; left:18px; bottom:14px; z-index:2; color:#fff; font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:19px; }

/* HOME: readiness band */
.ready { background:var(--night); color:#fff; padding:96px 0; }
.ready .cols { display:grid; grid-template-columns:1fr 1.1fr; gap:64px; align-items:center; }
.ready .kicker { color:#8BE0CE; }
.ready h2 { font-size:clamp(32px,4vw,52px); line-height:1.04; }
.ready p.lead { color:rgba(255,255,255,.72); }
.ready .stats { display:flex; flex-wrap:wrap; gap:28px 40px; margin-top:36px; }
.ready .stat .n { font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:34px; color:var(--amber); }
.ready .stat .l { font-size:12.5px; color:rgba(255,255,255,.6); margin-top:4px; max-width:16ch; line-height:1.45; }
.showcase { position:relative; border-radius:28px; overflow:hidden; min-height:480px; }
.showcase img.ph { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.showcase::after { content:''; position:absolute; inset:0; background:linear-gradient(200deg, rgba(8,14,12,.05), rgba(8,14,12,.45)); }
.ui { position:absolute; z-index:3; background:rgba(14,22,20,.82); border:1px solid rgba(255,255,255,.14); backdrop-filter:blur(10px); border-radius:18px; padding:18px 20px; box-shadow:0 22px 50px -18px rgba(0,0,0,.6); }
.ui.ring { left:26px; top:26px; display:flex; gap:16px; align-items:center; color:#fff; }
.ring-svg { width:74px; height:74px; transform:rotate(-90deg); }
.ring-svg .track { stroke:rgba(255,255,255,.14); }
.ring-svg .arc { stroke:var(--teal-glow); stroke-linecap:round; }
.ui.ring .num { font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:26px; }
.ui.ring .lbl { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.65); }
.ui.bars { right:26px; bottom:26px; width:250px; color:#fff; }
.ui.bars .row { display:flex; align-items:center; gap:10px; margin-top:10px; font-size:11.5px; }
.ui.bars .row:first-child { margin-top:0; }
.ui.bars .name { width:62px; color:rgba(255,255,255,.7); }
.ui.bars .bar { flex:1; height:7px; border-radius:99px; background:rgba(255,255,255,.12); overflow:hidden; }
.ui.bars .bar i { display:block; height:100%; border-radius:99px; }
.ui.bars .v { width:32px; text-align:right; font-weight:700; }

/* HOME: story teaser + rotator */
.story { background:linear-gradient(180deg, #EDF5F2 0%, #F3F8F6 100%); border-top:1px solid #DCE8E3; border-bottom:1px solid #DCE8E3; }
.story .cols { display:grid; grid-template-columns:1.1fr .9fr; gap:60px; align-items:center; }
.story blockquote { font-family:'Bricolage Grotesque',sans-serif; font-weight:500; font-size:23px; line-height:1.45; border-left:3px solid var(--amber); padding-left:22px; margin-top:28px; }
.story-rot .rs { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity 1.4s ease; }
.story-rot .rs.on { opacity:1; }

/* HOME: how it works (dark) */
.how { background:linear-gradient(180deg, var(--night) 0%, var(--night-2) 100%); color:#fff; padding:96px 0; }
.how .kicker { color:#8BE0CE; }
.how h2 { color:#fff; }
.how .steps { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:46px; }
.how .step { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:22px; padding:30px; transition:.2s; }
.how .step:hover { background:rgba(255,255,255,.08); transform:translateY(-3px); }
.how .step .n { width:38px; height:38px; border-radius:50%; background:rgba(43,212,168,.16); color:var(--teal-glow); font-weight:800; font-size:15px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; font-family:'Bricolage Grotesque',sans-serif; }
.how .step h3 { font-size:20px; margin-bottom:8px; font-weight:700; color:#fff; }
.how .step p { font-size:14px; line-height:1.65; color:rgba(255,255,255,.66); }

/* Mo band */
.mo-band { background:linear-gradient(135deg, var(--teal-soft) 0%, #F4FAF8 60%, var(--amber-soft) 100%); border-radius:34px; padding:60px 64px; display:grid; grid-template-columns:auto 1fr; gap:56px; align-items:center; }
.mo-band img { width:200px; animation:bob 3.4s ease-in-out infinite; }
.mo-band h2 { font-size:clamp(28px,3.2vw,38px); }
.compete { font-weight:800; }
.compete .c1 { color:var(--teal); }
.compete .c2 { color:var(--amber); }
.ways { display:flex; gap:8px; flex-wrap:wrap; margin-top:20px; }
.way { background:rgba(255,255,255,.9); border:1px solid var(--line); border-radius:999px; padding:8px 15px; font-size:12.5px; font-weight:600; color:var(--muted); }

/* gift band */
.gift { position:relative; border-radius:34px; overflow:hidden; }
.gift .bg { position:absolute; inset:0; background:url('/assets/velo-squad.jpg') center/cover; }
.gift .tint { position:absolute; inset:0; background:linear-gradient(150deg, rgba(8,12,16,.8), rgba(8,12,16,.42)); }
.gift .inner { position:relative; padding:68px; max-width:580px; color:#fff; }
.gift h2 { font-size:clamp(28px,3.4vw,40px); color:#fff; }
.gift p { margin-top:14px; color:rgba(255,255,255,.85); line-height:1.65; font-size:15.5px; }

/* closer */
.closer { background:var(--night); color:#fff; text-align:center; padding:110px 28px; }
.closer h2 { font-size:clamp(44px,6.4vw,84px); text-transform:uppercase; line-height:1; }
.closer h2 em { font-style:normal; color:var(--amber); }
.closer p { margin-top:18px; color:rgba(255,255,255,.7); font-size:17px; }
.closer .cta { margin-top:34px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.closer img.mo { width:120px; margin:0 auto 18px; animation:bob 3.4s ease-in-out infinite; }

/* STORY page */
.shero { position:relative; overflow:hidden; background:linear-gradient(150deg, var(--teal-soft) 0%, #F7FBF9 45%, var(--amber-soft) 100%); padding:110px 0 90px; text-align:center; }
.shero .badge, .jhero .badge { display:inline-flex; align-items:center; gap:8px; border:1.5px solid var(--teal); color:var(--teal); border-radius:999px; padding:8px 18px; font-size:12px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; background:rgba(255,255,255,.7); }
.shero h1, .jhero h1 { margin-top:26px; font-size:clamp(44px,6.4vw,86px); line-height:1; text-transform:uppercase; }
.shero h1 em { font-style:normal; color:var(--teal); }
.shero p, .jhero p { margin:22px auto 0; max-width:58ch; color:var(--muted); font-size:17.5px; line-height:1.7; }
.shero img.mo, .jhero img.mo { width:130px; margin-top:34px; animation:bob 3.4s ease-in-out infinite; }
.chapter { padding:84px 0; }
.chapter.alt { background:linear-gradient(180deg, #EDF5F2 0%, #F3F8F6 100%); border-top:1px solid #DCE8E3; border-bottom:1px solid #DCE8E3; }
.chapter h2 { margin-top:10px; font-size:clamp(28px,3.6vw,44px); }
.chapter .lead { font-size:17px; }
.twocol { display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center; }
.twocol img.ph { width:100%; border-radius:26px; box-shadow:0 30px 60px -24px rgba(0,0,0,.3); }
.oly { position:relative; margin-top:54px; display:grid; grid-template-columns:repeat(6,1fr); gap:18px; }
.oly::before { content:''; position:absolute; left:26px; right:26px; top:26px; height:3px; border-radius:99px; background:linear-gradient(90deg, var(--teal), var(--amber)); }
.oitem { position:relative; padding-top:76px; }
.oitem .yr { position:absolute; left:0; top:0; width:53px; height:53px; border-radius:50%; background:var(--card); border:3px solid var(--teal); display:flex; align-items:center; justify-content:center; font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:13.5px; color:var(--teal-deep); box-shadow:0 0 0 6px var(--bg); }
.oitem.gold .yr { border-color:var(--amber); color:#8a5b10; background:var(--amber-soft); }
.oitem h3 { font-size:17px; font-weight:700; line-height:1.2; }
.oitem h3 small { display:block; font-family:Inter; font-size:10.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--teal); margin-top:5px; }
.oitem.gold h3 small { color:#B0731B; }
.oitem p { margin-top:9px; font-size:13px; line-height:1.6; color:var(--muted); }
.chapter.alt .oitem .yr { background:var(--bg); box-shadow:0 0 0 6px var(--card); }
.beliefs { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-top:46px; }
.belief { background:var(--card); border:1px solid var(--line); border-radius:24px; padding:30px; transition:.2s; }
.belief:hover { transform:translateY(-3px); box-shadow:0 18px 40px -18px rgba(13,148,136,.25); }
.belief .e { font-size:26px; }
.belief h3 { margin-top:12px; font-size:19px; font-weight:700; }
.belief p { margin-top:8px; font-size:14px; line-height:1.65; color:var(--muted); }
.team { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:46px; }
.tcard { background:var(--card); border:1px solid var(--line); border-radius:24px; padding:30px; display:flex; gap:20px; align-items:flex-start; }
.tcard .av { flex:none; width:62px; height:62px; border-radius:50%; color:#fff; display:flex; align-items:center; justify-content:center; font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:20px; }
.tcard .av-photo { flex:none; width:74px; height:74px; border-radius:50%; object-fit:cover; object-position:center top;
  border:2px solid #fff; box-shadow:0 6px 18px -6px rgba(14,22,20,.35); }
.tcard .av.pm { background:linear-gradient(140deg,#0D9488,#0B5A46); }
.tcard .av.js { background:linear-gradient(140deg,#EF9F27,#C97E12); color:#3D2A05; }
.tcard .role { background:none; border:0; border-radius:0; padding:0; margin-top:4px; text-align:left; display:block;
  font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--teal); }
.tcard .role.amber { color:#B0731B; }
.tcard h3 { font-size:19px; font-weight:700; }
.tcard p { margin-top:8px; font-size:14px; line-height:1.65; color:var(--muted); }
.value { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:46px; }
.vcard { border-radius:24px; padding:32px; color:#fff; min-height:280px; display:flex; flex-direction:column; justify-content:flex-end; position:relative; overflow:hidden; background-size:cover; background-position:center; }
.vcard .who { font-size:11px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:#8BE0CE; }
.vcard.c .who { color:#F5C97C; }
.vcard h3 { margin-top:8px; font-size:20px; font-weight:700; }
.vcard p { margin-top:8px; font-size:13.5px; line-height:1.6; opacity:.92; }
.impact { background:linear-gradient(135deg, var(--teal-soft) 0%, #F4FAF8 60%, var(--amber-soft) 100%); border-radius:34px; padding:60px 64px; display:grid; grid-template-columns:auto 1fr; gap:52px; align-items:center; }
.impact img { width:170px; animation:bob 3.4s ease-in-out infinite; }
.impact h2 { font-size:clamp(26px,3vw,36px); }
.scloser { background:var(--night); color:#fff; text-align:center; padding:100px 28px; }
.scloser h2 { font-size:clamp(40px,5.8vw,76px); text-transform:uppercase; line-height:1; }
.scloser h2 em { font-style:normal; color:var(--amber); }
.scloser p { margin-top:16px; color:rgba(255,255,255,.7); font-size:16.5px; }

/* LABS page (dark theme) */
body.labs { background:var(--night); color:#fff; }
body.labs header.site { background:rgba(14,22,20,.85); border-bottom:1px solid rgba(255,255,255,.1); }
body.labs header.site nav.main { color:rgba(255,255,255,.7); }
body.labs header.site nav.main a:hover { color:#fff; }
body.labs header.site nav.main a.on { color:var(--teal-glow); }
body.labs .wordmark { color:#fff; }
.lhero { position:relative; padding:120px 0 90px; overflow:hidden; text-align:center; }
.lhero .grid { position:absolute; inset:0; background-image:linear-gradient(rgba(43,212,168,.07) 1px, transparent 1px), linear-gradient(90deg, rgba(43,212,168,.07) 1px, transparent 1px); background-size:54px 54px; -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 75%); mask-image:radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 75%); }
.lhero .glow { position:absolute; left:50%; top:-220px; width:900px; height:560px; transform:translateX(-50%); background:radial-gradient(ellipse, rgba(43,212,168,.18), transparent 65%); }
.lhero .inner { position:relative; }
.lhero .badge { display:inline-flex; align-items:center; gap:8px; border:1px solid rgba(43,212,168,.4); color:var(--teal-glow); border-radius:999px; padding:8px 18px; font-size:12px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; }
.lhero h1 { margin-top:26px; font-size:clamp(44px,6.4vw,86px); line-height:1; text-transform:uppercase; }
.lhero h1 em { font-style:normal; color:var(--teal-glow); }
.lhero p { margin:22px auto 0; max-width:62ch; color:rgba(255,255,255,.72); font-size:17.5px; line-height:1.7; }
.pulse { margin:46px auto 0; max-width:760px; }
.pulse svg { width:100%; }
.pulse .line { fill:none; stroke:var(--teal-glow); stroke-width:2.5; stroke-linecap:round; stroke-dasharray:1200; stroke-dashoffset:1200; animation:draw 4s ease forwards infinite alternate; filter:drop-shadow(0 0 8px rgba(43,212,168,.7)); }
@keyframes draw { to { stroke-dashoffset:0 } }
.lab { padding:84px 0; }
.lab .kicker { color:var(--teal-glow); }
.lab h2 { color:#fff; font-size:clamp(28px,3.4vw,42px); }
.lab .lead { color:rgba(255,255,255,.7); }
.lcards { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:46px; }
.lcard { background:rgba(255,255,255,.045); border:1px solid rgba(255,255,255,.12); border-radius:24px; padding:32px; transition:.2s; }
.lcard:hover { background:rgba(255,255,255,.08); transform:translateY(-3px); border-color:rgba(43,212,168,.35); }
.lcard .ic { width:46px; height:46px; border-radius:14px; background:rgba(43,212,168,.14); color:var(--teal-glow); display:flex; align-items:center; justify-content:center; font-size:21px; margin-bottom:18px; }
.lcard h3 { font-size:19px; color:#fff; margin-bottom:9px; font-weight:700; }
.lcard p { font-size:14px; line-height:1.65; color:rgba(255,255,255,.66); }
.pillars { background:var(--night-2); }
.pline { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:46px; }
.pl { border-left:3px solid var(--teal-glow); padding:6px 0 6px 22px; }
.pl.amber { border-color:var(--amber); }
.pl .t { font-family:'Bricolage Grotesque',sans-serif; font-weight:700; font-size:18px; }
.pl .d { margin-top:8px; font-size:13.5px; line-height:1.6; color:rgba(255,255,255,.62); }
.roadmap { position:relative; margin-top:52px; }
.roadmap::before { content:''; position:absolute; left:11px; top:6px; bottom:6px; width:2px; background:linear-gradient(180deg, var(--teal-glow), rgba(43,212,168,.1)); }
.ritem { position:relative; padding:0 0 34px 46px; }
.ritem::before { content:''; position:absolute; left:4px; top:4px; width:16px; height:16px; border-radius:50%; background:var(--night); border:3px solid var(--teal-glow); }
.ritem.future::before { border-color:rgba(255,255,255,.3); }
.ritem .tag { display:inline-block; font-size:10.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--teal-glow); margin-bottom:6px; }
.ritem.future .tag { color:rgba(255,255,255,.5); }
.ritem h3 { font-size:18px; color:#fff; font-weight:700; }
.ritem p { margin-top:6px; font-size:14px; color:rgba(255,255,255,.62); line-height:1.6; max-width:62ch; }
.lcta { text-align:center; padding:96px 28px; }
.lcta img { width:110px; animation:bob 3.4s ease-in-out infinite; }
.lcta h2 { margin-top:16px; font-size:clamp(32px,4.4vw,56px); color:#fff; text-transform:uppercase; }
.lcta h2 em { font-style:normal; color:var(--amber); }
.lcta p { margin-top:14px; color:rgba(255,255,255,.68); }
body.labs footer.site { background:var(--night-2); border-top:1px solid rgba(255,255,255,.1); }
body.labs footer.site a.f, body.labs footer.site .lbl, body.labs footer.site .blurb, body.labs footer.site .nl-note { color:rgba(255,255,255,.6); }
body.labs footer.site a.f:hover { color:#fff; }
body.labs footer.site .wordmark { color:#fff; }
body.labs footer.site input { background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.18); color:#fff; }
body.labs .legal { border-color:rgba(255,255,255,.12); color:rgba(255,255,255,.45); }
body.labs .legal a, body.labs .legal button.linklike { color:rgba(255,255,255,.45); }

/* CONTACT page */
.cwrap { max-width:1080px; margin:64px auto 96px; padding:0 28px; }
.ccard { display:grid; grid-template-columns:1fr 1.1fr; border-radius:32px; overflow:hidden; box-shadow:0 44px 90px -30px rgba(13,148,136,.28); border:1px solid var(--line); background:var(--card); }
.cleft { position:relative; min-height:560px; }
.cleft .ph { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.cleft .tint { position:absolute; inset:0; background:linear-gradient(170deg, rgba(8,14,12,.25) 0%, rgba(8,14,12,.78) 100%); }
.cleft .inner { position:relative; height:100%; display:flex; flex-direction:column; justify-content:flex-end; padding:40px; color:#fff; }
.cleft h1 { font-size:clamp(30px,3.4vw,42px); line-height:1.05; }
.cleft p { margin-top:12px; color:rgba(255,255,255,.85); font-size:15px; line-height:1.65; max-width:38ch; }
.cleft .mo { position:absolute; top:26px; right:26px; width:96px; filter:drop-shadow(0 12px 22px rgba(0,0,0,.4)); animation:bob 3.4s ease-in-out infinite; }
.cright { padding:46px 48px; }
.cright h2 { font-size:24px; }
.cright .sub { margin-top:8px; color:var(--muted); font-size:14px; line-height:1.6; }
.frm { margin-top:28px; display:grid; gap:16px; }
.frm .two { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.frm label { display:block; font-size:11.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--faint); margin-bottom:7px; }
.frm input, .frm select, .frm textarea { width:100%; border:1px solid var(--line); border-radius:14px; padding:13px 16px; font-size:14.5px; font-family:inherit; color:var(--ink); background:var(--bg); outline:none; transition:.15s; }
.frm input:focus, .frm select:focus, .frm textarea:focus { border-color:var(--teal); background:#fff; box-shadow:0 0 0 4px rgba(13,148,136,.1); }
.frm textarea { resize:none; }
.frm .send { border:0; cursor:pointer; font-family:inherit; justify-self:start; }
.alts { margin-top:26px; padding-top:24px; border-top:1px solid var(--line); display:flex; gap:28px; flex-wrap:wrap; }
.alt { font-size:13.5px; color:var(--muted); }
.alt b { display:block; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--faint); margin-bottom:4px; }
.alt a { color:var(--teal); font-weight:600; }

/* AMBASSADOR page */
.ahero { position:relative; min-height:62vh; display:flex; align-items:flex-end; overflow:hidden; }
.ahero .bg { position:absolute; inset:0; background:url('/assets/velo-action.jpg') center 30%/cover; }
.ahero .tint { position:absolute; inset:0; background:linear-gradient(165deg, rgba(8,14,12,.35) 0%, rgba(8,14,12,.6) 60%, rgba(8,14,12,.85) 100%); }
.ahero .inner { position:relative; width:100%; padding:90px 28px 64px; color:#fff; }
.ahero .eyebrow { font-size:12.5px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:#8BE0CE; margin-bottom:16px; }
.ahero h1 { font-size:clamp(42px,6vw,80px); line-height:1; text-transform:uppercase; }
.ahero h1 .hl { color:var(--amber); }
.ahero p { margin-top:18px; font-size:17px; line-height:1.65; color:rgba(255,255,255,.88); max-width:56ch; }
.roles { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:44px; }
.role { background:var(--card); border:1px solid var(--line); border-radius:24px; padding:30px; transition:.2s; }
.role:hover { transform:translateY(-3px); box-shadow:0 18px 40px -18px rgba(13,148,136,.25); }
.role .ic { width:46px; height:46px; border-radius:14px; background:var(--teal-soft); display:flex; align-items:center; justify-content:center; font-size:21px; margin-bottom:16px; }
.role h3 { font-size:19px; font-weight:700; margin-bottom:8px; }
.role p { font-size:14px; line-height:1.65; color:var(--muted); }
.perks { background:linear-gradient(135deg, var(--teal-soft) 0%, #F4FAF8 60%, var(--amber-soft) 100%); border-radius:34px; padding:54px 58px; }
.perkgrid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px 28px; margin-top:28px; }
.perk { display:flex; gap:12px; align-items:flex-start; font-size:14.5px; line-height:1.6; color:var(--muted); }
.perk b { color:var(--ink); }
.perk .tick { flex:none; width:24px; height:24px; border-radius:50%; background:var(--teal); color:#fff; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:800; margin-top:2px; }
.aform { background:var(--card); border:1px solid var(--line); border-radius:28px; padding:44px 48px; max-width:720px; margin:46px auto 0; box-shadow:0 30px 70px -30px rgba(13,148,136,.25); }
.aform h3 { font-size:22px; }
.aform .sub { margin-top:6px; color:var(--muted); font-size:14px; }

/* JOURNEY page */
.jhero { position:relative; overflow:hidden; background:linear-gradient(150deg, var(--teal-soft) 0%, #F7FBF9 45%, var(--amber-soft) 100%); padding:100px 0 80px; text-align:center; }
.jhero h1 em { color:var(--amber); }
.journey { position:relative; margin-top:50px; }
.journey::before { content:''; position:absolute; left:25px; top:8px; bottom:8px; width:3px; border-radius:99px; background:linear-gradient(180deg, var(--teal), var(--amber)); }
.jstep { position:relative; padding:0 0 36px 80px; }
.jstep:last-child { padding-bottom:0; }
.jstep .when { position:absolute; left:0; top:0; width:53px; height:53px; border-radius:50%; background:var(--card); border:3px solid var(--teal); display:flex; align-items:center; justify-content:center; font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:10.5px; color:var(--teal-deep); text-align:center; line-height:1.1; box-shadow:0 0 0 6px var(--bg); }
.jstep h3 { font-size:20px; font-weight:700; }
.jstep p { margin-top:7px; font-size:14.5px; line-height:1.65; color:var(--muted); max-width:64ch; }
.plans { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:46px; align-items:stretch; }
.plan { position:relative; background:var(--card); border:1px solid var(--line); border-radius:26px; padding:34px 30px; display:flex; flex-direction:column; transition:.2s; }
.plan:hover { transform:translateY(-4px); box-shadow:0 24px 50px -22px rgba(13,148,136,.3); }
.plan.hot { border:2px solid var(--teal); box-shadow:0 24px 56px -22px rgba(13,148,136,.35); }
.plan .tag { position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--teal); color:#fff; font-size:10.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; border-radius:999px; padding:5px 14px; }
.plan h3 { font-size:21px; font-weight:800; }
.plan .for { margin-top:4px; font-size:12.5px; color:var(--faint); }
.plan .price { margin-top:18px; font-family:'Bricolage Grotesque',sans-serif; font-weight:800; font-size:38px; }
.plan .price small { font-family:Inter; font-size:13px; font-weight:600; color:var(--muted); }
.plan .ann { font-size:12px; color:var(--faint); margin-top:3px; }
.plan ul { list-style:none; padding:0; margin:22px 0 26px; display:grid; gap:10px; }
.plan li { display:flex; gap:10px; font-size:13.5px; line-height:1.5; color:var(--muted); }
.plan li::before { content:'✓'; flex:none; width:20px; height:20px; border-radius:50%; background:var(--teal-soft); color:var(--teal); font-size:11px; font-weight:800; display:flex; align-items:center; justify-content:center; margin-top:1px; }
.plan .go { margin-top:auto; justify-content:center; }
.fineprint { text-align:center; margin-top:26px; font-size:13px; color:var(--faint); }
.fineprint a { color:var(--teal); font-weight:600; }

/* Cookie consent: slim full-width bar */
.cookie-banner { position:fixed; left:0; right:0; bottom:0; z-index:100; background:var(--card); border-top:1px solid var(--line); padding:14px 24px; box-shadow:0 -16px 44px -22px rgba(0,0,0,.3); display:none; color:var(--ink); }
.cookie-banner.show { display:block; }
.cookie-banner .cb-inner { max-width:1180px; margin:0 auto; display:flex; align-items:center; gap:24px; flex-wrap:wrap; }
.cookie-banner .cb-text { flex:1 1 420px; min-width:240px; }
.cookie-banner h3 { font-size:13.5px; font-weight:800; display:flex; align-items:center; gap:7px; color:var(--ink); }
.cookie-banner p { margin-top:3px; font-size:12px; line-height:1.55; color:var(--muted); }
.cookie-banner p a { color:var(--teal); font-weight:600; }
.cookie-banner .row { display:flex; gap:8px; flex-wrap:wrap; margin:0; }
.cookie-banner .pill { padding:9px 16px; font-size:12.5px; cursor:pointer; border:0; font-family:inherit; }
.cookie-modal .pill { padding:10px 18px; font-size:13px; cursor:pointer; border:0; font-family:inherit; }
.cookie-banner .pill.quiet, .cookie-modal .pill.quiet { background:var(--bg); border:1px solid var(--line); color:var(--muted); }
.cookie-banner .pill.quiet:hover, .cookie-modal .pill.quiet:hover { color:var(--ink); }
.cookie-modal { position:fixed; inset:0; z-index:101; display:none; align-items:center; justify-content:center; background:rgba(8,14,12,.5); padding:20px; }
.cookie-modal.show { display:flex; }
.cookie-modal .box { background:var(--card); color:var(--ink); border-radius:22px; max-width:480px; width:100%; padding:30px 32px; box-shadow:0 40px 90px -28px rgba(0,0,0,.5); }
.cookie-modal h3 { font-size:19px; font-weight:800; }
.cookie-modal .sub { margin-top:6px; font-size:13px; color:var(--muted); line-height:1.6; }
.cookie-modal .opt { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; padding:16px 0; border-bottom:1px solid var(--line); }
.cookie-modal .opt:last-of-type { border-bottom:0; }
.cookie-modal .opt .t { font-size:14px; font-weight:700; }
.cookie-modal .opt .d { margin-top:3px; font-size:12.5px; color:var(--muted); line-height:1.5; }
.cookie-modal .opt .always { font-size:11px; font-weight:700; color:var(--teal); letter-spacing:.08em; text-transform:uppercase; white-space:nowrap; margin-top:3px; }
.switch { position:relative; width:44px; height:24px; flex:none; margin-top:2px; }
.switch input { opacity:0; width:0; height:0; }
.switch i { position:absolute; inset:0; border-radius:99px; background:var(--line); transition:.2s; cursor:pointer; }
.switch i::after { content:''; position:absolute; left:3px; top:3px; width:18px; height:18px; border-radius:50%; background:#fff; transition:.2s; box-shadow:0 1px 3px rgba(0,0,0,.25); }
.switch input:checked + i { background:var(--teal); }
.switch input:checked + i::after { transform:translateX(20px); }
.cookie-modal .row { display:flex; gap:10px; flex-wrap:wrap; margin-top:22px; }

@media (max-width:920px) {
  nav.main a:not(.pill) { display:none; }
  .ready .cols, .story .cols, .mo-band, .twocol, .beliefs, .team, .value, .impact, .ccard { grid-template-columns:1fr; }
  .how .steps, .lcards, .pline, .roles, .perkgrid, .plans { grid-template-columns:1fr; }
  footer.site .cols { grid-template-columns:repeat(2, minmax(0,1fr)); }
  .oly { display:flex; overflow-x:auto; padding-bottom:14px; }
  .oly::before { right:0; }
  .oitem { flex:none; width:230px; }
  .cleft { min-height:340px; }
  .aform, .cright { padding:30px 24px; }
}

/* Phones: single-column footer (must come after the 920px rules) */
@media (max-width:640px) {
  footer.site .cols { grid-template-columns:1fr; gap:28px; }
  footer.site form { flex-wrap:wrap; }
  .mo-band, .impact, .perks { padding:36px 26px; }
  .gift .inner { padding:44px 26px; }
  .mo-band img, .impact img { width:140px; }
}

/* Olympic photo strip (story chapter 02) */
.oly-photos { display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:34px; }
.oly-photos figure { margin:0; }
.oly-photos .frame { position:relative; display:block; border-radius:18px; overflow:hidden;
  box-shadow:0 26px 50px -26px rgba(14,22,20,.45); }
.oly-photos img { width:100%; height:300px; object-fit:cover; display:block; }
.oly-photos img.lift { filter:brightness(1.34) contrast(1.05) saturate(1.08); }
.oly-photos .tint-night img { filter:saturate(.92) brightness(.94); }
.oly-photos .tint-night::after { content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(165deg, rgba(14,22,20,.52) 0%, rgba(14,22,20,.22) 45%, rgba(11,90,70,.16) 100%); }
.oly-photos figcaption { margin-top:10px; font-size:12.5px; color:#5D6675; }
@media (max-width:760px) { .oly-photos { grid-template-columns:1fr; } .oly-photos img { height:230px; } }

/* Mobile hamburger nav (injected by site.js) */
.nav-burger { display:none; }
@media (max-width:920px) {
  .nav-burger { display:flex; align-items:center; justify-content:center; width:42px; height:42px; margin-left:10px;
    background:none; border:1px solid var(--line); border-radius:12px; cursor:pointer; color:var(--ink); flex:none; }
  body.labs .nav-burger { color:#fff; border-color:rgba(255,255,255,.25); }
}
.mobile-nav { position:fixed; inset:0; z-index:60; display:none; }
.mobile-nav.open { display:block; }
.mobile-nav .veil { position:absolute; inset:0; background:rgba(14,22,20,.45); }
.mobile-nav .panel { position:absolute; top:0; right:0; width:min(320px, 84vw); height:100%; background:#fff;
  padding:18px 26px 28px; display:flex; flex-direction:column; box-shadow:-20px 0 60px rgba(14,22,20,.25);
  animation:mnav-in .22s ease; overflow-y:auto; }
@keyframes mnav-in { from { transform:translateX(40px); opacity:0; } to { transform:none; opacity:1; } }
.mobile-nav .close { align-self:flex-end; background:none; border:0; font-size:30px; line-height:1; color:#5D6675; cursor:pointer; padding:6px 4px; }
.mobile-nav .panel a { padding:14px 8px; font-size:16px; font-weight:600; color:var(--ink); text-decoration:none; border-bottom:1px solid var(--line); }
.mobile-nav .panel a.on { color:var(--teal); }
.mobile-nav .panel a.pill { margin-top:20px; text-align:center; color:#fff; border-bottom:none; border-radius:999px; }
