/* ─────────────────────────────────────────────────────────
   MANA — Foundation Program sales page
   Cream-on-black brand · Helvetica Neue UPPERCASE · MANA red accent
   ─────────────────────────────────────────────────────────── */

:root{
  --bg:        #000000;
  --bg-2:      #0c0c0c;
  --fg:        #f1ede4;
  --muted:     rgba(241,237,228,.62);
  --faint:     rgba(241,237,228,.38);
  --line:      rgba(241,237,228,.14);
  --line-2:    rgba(241,237,228,.07);
  --acc:       #e62532;
  --acc-ink:   #f1ede4;

  --maxw: 1360px;
  --gutter: clamp(20px, 4vw, 64px);

  --display: 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
  --body:    'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;

  --h1: clamp(40px, 6vw, 96px);
  --h2: clamp(32px, 4.2vw, 72px);
  --h3: clamp(22px, 2.2vw, 36px);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:#000;color:var(--fg);font-family:var(--body);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden;-webkit-tap-highlight-color:transparent}
img,video,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
a{color:inherit;text-decoration:none}

/* ── Type — all caps Helvetica Neue ────────────────────── */
.display{font-family:var(--display);font-weight:700;line-height:.96;letter-spacing:-.02em;text-transform:uppercase}
.h1{font-family:var(--display);font-weight:700;font-size:var(--h1);line-height:.92;letter-spacing:-.03em;text-transform:uppercase}
.h2{font-family:var(--display);font-weight:700;font-size:var(--h2);line-height:.94;letter-spacing:-.025em;text-transform:uppercase}
.h3{font-family:var(--display);font-weight:700;font-size:var(--h3);line-height:1;letter-spacing:-.02em;text-transform:uppercase}
/* Accent emphasis — same font, red color */
.serif-it{font-family:var(--display);font-style:normal;font-weight:700;text-transform:uppercase;letter-spacing:-.02em;color:var(--acc)}

.eyebrow{font-family:var(--body);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--muted)}
.lede{font-size:clamp(17px,1.4vw,21px);line-height:1.5;color:var(--fg);max-width:62ch}
.body{font-size:16px;line-height:1.55;color:var(--muted);max-width:60ch}
.num-mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}

/* ── Layout ──────────────────────────────────────────── */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
section{position:relative}
.section-pad{padding-block:clamp(80px,9vw,160px)}
.divider{height:1px;background:var(--line)}
.hairline-top{border-top:1px solid var(--line)}
.hairline-bottom{border-bottom:1px solid var(--line)}

/* ── Nav ─────────────────────────────────────────────── */
.nav{position:fixed;inset:0 0 auto 0;z-index:50;padding:18px var(--gutter);display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(to bottom,rgba(0,0,0,.92),rgba(0,0,0,.6) 60%,rgba(0,0,0,0));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.nav.scrolled{background:rgba(0,0,0,.92);border-bottom:1px solid var(--line)}
.nav-links{display:flex;gap:34px}
.nav-link{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700;transition:color .2s}
.nav-link:hover{color:var(--fg)}
@media (max-width:760px){.nav-links{display:none}}

/* ── Buttons ─────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:14px;padding:18px 28px;border-radius:999px;font-family:var(--body);font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;transition:transform .2s, background .2s, color .2s, box-shadow .2s;cursor:pointer;will-change:transform}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--acc);color:var(--acc-ink)}
.btn-primary:hover{background:#ff3744;box-shadow:0 14px 40px -10px rgba(230,37,50,.45)}
.btn-ghost{background:transparent;color:var(--fg);border:1px solid var(--fg)}
.btn-ghost:hover{background:var(--fg);color:var(--bg)}
.btn-arrow{width:14px;height:14px;flex:none}
.btn-pill{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border-radius:999px;border:1px solid var(--line);background:var(--bg);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700;transition:all .2s}
.btn-pill:hover{color:var(--fg);border-color:var(--fg)}
/* Dot inside the red nav pill should pulse white, not red */
.btn-pill .spots-dot{background:#fff;animation:pulseWhite 2s infinite}
@keyframes pulseWhite{0%{box-shadow:0 0 0 0 rgba(255,255,255,.7)}70%{box-shadow:0 0 0 10px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}

.spots-pill{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border-radius:999px;border:1px solid var(--line);background:var(--bg);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700}
.spots-dot{width:6px;height:6px;border-radius:50%;background:var(--acc);box-shadow:0 0 0 0 var(--acc);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(230,37,50,.55)}70%{box-shadow:0 0 0 10px rgba(230,37,50,0)}100%{box-shadow:0 0 0 0 rgba(230,37,50,0)}}

/* ── Hero — cream BG with photo behind, subtle ───────── */
.hero{position:relative;min-height:100vh;padding:128px var(--gutter) 56px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--bg)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.1) contrast(1.05) brightness(.85)}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.3) 30%,rgba(0,0,0,.78) 65%,rgba(0,0,0,1) 100%)}
.hero-grain{position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='.9' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/></svg>");opacity:.06;mix-blend-mode:overlay;pointer-events:none;z-index:1}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%}
.hero-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;gap:32px;flex-wrap:wrap}
.hero-h1{font-family:var(--display);font-weight:700;font-size:var(--h1);line-height:.92;letter-spacing:-.035em;text-transform:uppercase;max-width:16ch}
.hero-h1 em{font-family:var(--display);font-style:normal;font-weight:700;text-transform:uppercase;color:var(--acc);letter-spacing:-.025em}
.hero-meta{display:grid;grid-template-columns:auto auto auto;gap:24px;align-items:center;border-top:1px solid var(--line);padding-top:24px;margin-top:56px}
.hero-meta-col{display:flex;flex-direction:column;gap:6px}
.hero-meta-col .label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);font-weight:700}
.hero-meta-col .val{font-size:14px;color:var(--fg);font-weight:600}
.hero-cta-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:36px}
.stars{display:flex;gap:2px;color:var(--acc)}
.stars svg{width:14px;height:14px;fill:currentColor}
@media (max-width:760px){.hero-meta{grid-template-columns:1fr;gap:14px}}

.scroll-cue{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);font-weight:700;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:3}
.scroll-cue::after{content:"";width:1px;height:34px;background:linear-gradient(to bottom,var(--faint),transparent);animation:drop 1.8s ease-in-out infinite}
@keyframes drop{0%,100%{transform:scaleY(.4);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

/* ── Marquee ─────────────────────────────────────────── */
.marquee{display:flex;gap:64px;overflow:hidden;padding:22px 0;border-block:1px solid var(--line);background:var(--bg-2)}
.marquee-track{display:flex;gap:64px;animation:scroll 30s linear infinite;flex:none}
.marquee-item{display:flex;align-items:center;gap:18px;font-family:var(--display);font-weight:700;font-size:22px;text-transform:uppercase;letter-spacing:-.01em;white-space:nowrap;color:var(--fg)}
.marquee-item .dot{width:6px;height:6px;border-radius:50%;background:var(--acc);flex:none}
@keyframes scroll{to{transform:translateX(calc(-50% - 32px))}}

/* ── Countdown banner ────────────────────────────────── */
.countdown{padding:clamp(56px,7vw,120px) var(--gutter);text-align:center;background:var(--bg-2);border-block:1px solid var(--line)}
.countdown-eyebrow{margin-bottom:24px}
.countdown-grid{display:flex;justify-content:center;align-items:flex-start;gap:clamp(20px,3vw,56px);margin:32px 0 40px}
.cd-unit{display:flex;flex-direction:column;align-items:center;gap:10px;min-width:96px}
.cd-num{font-family:var(--display);font-weight:700;font-size:clamp(72px,10vw,140px);line-height:.9;letter-spacing:-.04em;color:var(--fg);font-variant-numeric:tabular-nums}
.cd-lbl{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700}
.cd-sep{font-family:var(--display);font-weight:300;font-size:clamp(48px,7vw,96px);color:var(--faint);align-self:center;margin-top:-8px;letter-spacing:-.02em}

/* ── Pillars ─────────────────────────────────────────── */
.pillars-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:64px}
@media (max-width:880px){.pillars-head{grid-template-columns:1fr}}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:880px){.pillars-grid{grid-template-columns:1fr}}
.pillar{position:relative;overflow:hidden;border:1px solid var(--line);background:var(--bg-2);display:flex;flex-direction:column}
.pillar-img{aspect-ratio:4/5;position:relative;overflow:hidden}
.pillar-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.pillar:hover .pillar-img img{transform:scale(1.04)}
.pillar-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.85))}
.pillar-num{position:absolute;top:18px;left:20px;font-family:var(--body);font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--fg);z-index:2;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:6px 10px;border-radius:999px;border:1px solid var(--line)}
.pillar-body{padding:28px 28px 32px;display:flex;flex-direction:column;gap:12px}
.pillar-title{font-family:var(--display);font-weight:700;font-size:30px;line-height:1.04;letter-spacing:-.025em;text-transform:uppercase}

/* ── In 6 weeks ──────────────────────────────────────── */
.six-weeks{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:start}
@media (max-width:880px){.six-weeks{grid-template-columns:1fr;gap:40px}}
.six-media{aspect-ratio:4/5;position:relative;overflow:hidden;border:1px solid var(--line)}
.six-media img{width:100%;height:100%;object-fit:cover}
.six-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 65%,rgba(0,0,0,.6))}
.six-tag{position:absolute;top:20px;left:20px;display:inline-flex;align-items:center;gap:8px;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--line);padding:8px 14px;border-radius:999px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg);font-weight:700;z-index:2}
.six-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--acc)}
.six-list{list-style:none;display:flex;flex-direction:column}
.six-list li{display:grid;grid-template-columns:48px 1fr auto;gap:20px;align-items:center;padding:22px 0;border-bottom:1px solid var(--line);font-family:var(--display);font-weight:700;font-size:clamp(20px,2vw,28px);text-transform:uppercase;letter-spacing:-.02em;line-height:1.15}
.six-list li:first-child{border-top:1px solid var(--line)}
.six-idx{font-family:var(--body);font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.six-check{width:22px;height:22px;border-radius:50%;background:var(--acc);display:grid;place-items:center;color:var(--acc-ink);flex:none}
.six-check svg{width:11px;height:11px;stroke:currentColor;stroke-width:3;fill:none}

/* ── Testimonials — horizontal scroll w/ photos ─────────── */
.tst-toolbar{display:flex;justify-content:space-between;align-items:center;gap:24px;margin-bottom:clamp(28px,3.5vw,48px);flex-wrap:wrap}
.tst-meta{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:13px;letter-spacing:.04em}
.tst-stars{display:inline-flex;gap:2px;color:var(--acc)}
.tst-stars svg{width:14px;height:14px;fill:currentColor;display:block}
.tst-rating-text{font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-size:11px}
.tst-arrows{display:flex;gap:8px}
.tst-arrow{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--fg);display:grid;place-items:center;transition:all .2s;cursor:pointer}
.tst-arrow:hover{background:var(--acc);border-color:var(--acc);color:var(--acc-ink)}
.tst-arrow svg{width:16px;height:16px}

.tst-scroller{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;padding-block:8px;
  scroll-padding-left:var(--gutter)}
.tst-scroller::-webkit-scrollbar{display:none}
.tst-gutter-left,.tst-gutter-right{flex:0 0 var(--gutter);min-width:var(--gutter)}

.tst{flex:0 0 clamp(300px, 28vw, 420px);scroll-snap-align:start;
  display:grid;grid-template-rows:auto 1fr;padding:0;border:1px solid var(--line);
  background:var(--bg-2);transition:border-color .25s, transform .25s}
.tst:hover{border-color:rgba(241,237,228,.32);transform:translateY(-2px)}
.tst-photo{aspect-ratio:5/4;overflow:hidden;position:relative;background:#0a0a0a}
.tst-photo img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.tst-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.5))}
.tst-content{padding:24px 26px 26px;display:flex;flex-direction:column;gap:16px}
.tst-body{font-size:15.5px;line-height:1.55;color:var(--fg);flex:1;letter-spacing:-.005em;text-wrap:pretty}
.tst-foot{padding-top:16px;border-top:1px solid var(--line)}
.tst-name{font-weight:700;color:var(--fg);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.tst-result{font-size:11px;color:var(--acc);letter-spacing:.12em;text-transform:uppercase;font-weight:700;margin-top:6px}
@media (max-width:720px){
  .tst{flex-basis:82vw}
}

/* ── Team block (under MeetExpert) ─────────────────────── */
.team-block{margin-top:clamp(64px,8vw,120px);padding-top:clamp(48px,6vw,80px);border-top:1px solid var(--line)}
.team-head{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:end;margin-bottom:clamp(32px,4vw,56px)}
@media (max-width:760px){.team-head{grid-template-columns:1fr;gap:18px}}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:760px){.team-grid{grid-template-columns:1fr 1fr}}
.team-card{background:var(--bg-2);border:1px solid var(--line);display:flex;flex-direction:column;overflow:hidden;transition:border-color .25s, transform .25s}
.team-card:hover{border-color:rgba(241,237,228,.32);transform:translateY(-2px)}
.team-img{aspect-ratio:4/5;overflow:hidden;position:relative}
.team-img img{width:100%;height:100%;object-fit:cover;object-position:center 22%;transition:transform .8s ease}
.team-card:hover .team-img img{transform:scale(1.04)}
.team-info{padding:18px 20px 22px}
.team-name{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.01em;text-transform:uppercase}
.team-role{font-size:11px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-weight:700;margin-top:6px}

/* ── Club tour video ───────────────────────────────────── */
.club-tour-section{padding-bottom:clamp(80px,9vw,140px)}
.club-tour{position:relative;overflow:hidden;max-width:480px;margin:clamp(40px,5vw,72px) auto 0;
  aspect-ratio:9/16;border:1px solid var(--line);background:#0a0a0a;border-radius:6px}
.club-tour-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.club-tour-overlay{position:absolute;inset:0;pointer-events:none;display:flex;flex-direction:column;justify-content:space-between;padding:20px;
  background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,transparent 18%,transparent 80%,rgba(0,0,0,.6) 100%)}
.club-tour-tag{display:inline-flex;align-items:center;gap:10px;align-self:flex-start;
  background:rgba(0,0,0,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--line);
  padding:8px 14px;border-radius:999px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg);font-weight:700}
.club-tour-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--acc)}
.club-tour-controls{align-self:flex-end;display:flex;gap:10px;pointer-events:auto}
.ct-btn{width:48px;height:48px;border-radius:50%;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:1px solid var(--line);color:var(--fg);display:grid;place-items:center;cursor:pointer;transition:background .2s,border-color .2s}
.ct-btn:hover{background:var(--acc);border-color:var(--acc);color:var(--acc-ink)}
.ct-btn svg{width:18px;height:18px}
.club-tour-fallback{position:absolute;inset:0;display:grid;place-items:center;background:rgba(0,0,0,.55);
  text-align:center;padding:24px;color:var(--muted);font-size:13px;pointer-events:auto}
.club-tour-fallback code{font-family:ui-monospace,Menlo,monospace;background:rgba(241,237,228,.08);padding:2px 8px;border-radius:4px;color:var(--fg);font-size:12px}

/* ── Drone-tour fallback: open-in-new-tab pill ─────────── */
.ct-fallback{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px 14px 18px;border-radius:999px;
  background:var(--acc);color:#fff;font-family:var(--display);font-weight:700;
  font-size:13px;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;
  box-shadow:0 14px 36px -10px rgba(0,0,0,.5);pointer-events:auto;z-index:3;
  transition:transform .15s, background .2s, box-shadow .2s}
.ct-fallback:hover{background:#ff3744;transform:translate(-50%,-50%) scale(1.04);
  box-shadow:0 16px 44px -10px rgba(230,37,50,.5)}
.ct-fallback svg{width:18px;height:18px;margin-left:2px}

/* ── Big tap-to-play overlay on the drone tour video ─────── */
.ct-bigplay{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:78px;height:78px;border-radius:50%;
  background:rgba(230,37,50,.95);color:#fff;border:none;
  display:grid;place-items:center;cursor:pointer;pointer-events:auto;
  box-shadow:0 14px 40px -8px rgba(0,0,0,.55), 0 0 0 0 rgba(230,37,50,.7);
  animation:ctPulse 2.4s ease-in-out infinite;z-index:2;transition:transform .15s, background .2s}
.ct-bigplay:hover{background:#ff3744;transform:translate(-50%,-50%) scale(1.05)}
.ct-bigplay svg{width:30px;height:30px;margin-left:4px}
@keyframes ctPulse{0%,100%{box-shadow:0 14px 40px -8px rgba(0,0,0,.55), 0 0 0 0 rgba(230,37,50,.5)}50%{box-shadow:0 14px 40px -8px rgba(0,0,0,.55), 0 0 0 16px rgba(230,37,50,0)}}
.club-tour{cursor:pointer}
.tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:880px){.tst-grid{grid-template-columns:1fr}}

/* ── Included cards ──────────────────────────────────── */
.incl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media (max-width:880px){.incl-grid{grid-template-columns:1fr}}
.incl{background:var(--bg);padding:48px 36px 40px;display:flex;flex-direction:column;gap:18px;min-height:340px;position:relative;transition:background .3s}
.incl:hover{background:var(--bg-2)}
.incl-num{font-family:var(--body);font-weight:700;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--acc)}
.incl-icon{width:40px;height:40px;display:grid;place-items:center;color:var(--acc);margin-bottom:18px}
.incl-title{font-family:var(--display);font-weight:700;font-size:28px;line-height:1.04;text-transform:uppercase;letter-spacing:-.025em}
.incl-body{font-size:15px;color:var(--muted);line-height:1.55;margin-top:8px}

/* ── Journey — vertical timeline with scroll-fill ─────── */
.journey-track{position:relative;margin-top:clamp(48px,6vw,88px);padding-block:8px}
.journey-rail{position:absolute;left:50%;top:clamp(60px,7vw,96px);bottom:clamp(60px,7vw,96px);width:1px;background:var(--line);transform:translateX(-.5px);pointer-events:none;z-index:1}
.journey-rail-fill{position:absolute;left:0;top:0;width:1px;background:var(--acc);height:0;will-change:height;box-shadow:0 0 12px 0 rgba(230,37,50,.5)}
.journey-rail-fill::after{content:"";position:absolute;left:-3px;bottom:-3px;width:7px;height:7px;border-radius:50%;background:var(--acc);box-shadow:0 0 16px rgba(230,37,50,.9), 0 0 0 4px rgba(230,37,50,.18)}
.journey-list{display:flex;flex-direction:column;position:relative;z-index:2}
.journey-row{display:grid;grid-template-columns:1fr 80px 1fr;gap:clamp(16px,2vw,48px);align-items:center;padding:clamp(36px,5vw,72px) 0}
.journey-content{display:flex;flex-direction:column;gap:14px;transition:opacity .4s ease}
.journey-row.alt-left .journey-content{grid-column:1;text-align:right;align-items:flex-end}
.journey-row.alt-right .journey-content{grid-column:3;text-align:left;align-items:flex-start}
.journey-dot{grid-column:2;width:16px;height:16px;border-radius:50%;background-color:var(--bg);border:1.5px solid rgba(241,237,228,.4);box-shadow:0 0 0 3px var(--bg);justify-self:center;z-index:3;transition:transform .35s ease, box-shadow .35s ease;position:relative}
.journey-dot::after{content:"";position:absolute;inset:-10px;border-radius:50%;border:1px solid var(--acc);opacity:0;transform:scale(.6);transition:opacity .35s ease, transform .35s ease;pointer-events:none}
.journey-row.passed .journey-dot{background-color:var(--acc);border-color:var(--acc);transform:scale(1.15);box-shadow:0 0 0 3px var(--bg), 0 0 16px rgba(230,37,50,.6)}
.journey-row.passed .journey-dot::after{opacity:.7;transform:scale(1)}
.journey-num{font-family:var(--display);font-weight:700;font-size:clamp(48px,7vw,104px);line-height:.9;letter-spacing:-.05em;color:var(--fg);font-variant-numeric:tabular-nums;transition:color .35s ease}
.journey-num em{font-family:var(--body);font-style:normal;font-size:.16em;letter-spacing:.18em;text-transform:uppercase;display:block;margin-bottom:8px;color:var(--muted);font-weight:700}
.journey-row.passed .journey-num{color:var(--acc)}
.journey-title{font-family:var(--display);font-weight:700;font-size:clamp(22px,2.2vw,32px);line-height:1.05;text-transform:uppercase;letter-spacing:-.025em}
.journey-body{font-size:15px;line-height:1.55;color:var(--muted);max-width:46ch}
@media (max-width:880px){
  .journey-track{padding-left:36px}
  .journey-rail{left:0;top:32px;bottom:32px}
  .journey-row{grid-template-columns:1fr;gap:14px;padding:32px 0;position:relative}
  .journey-row.alt-left .journey-content,
  .journey-row.alt-right .journey-content{grid-column:1;text-align:left;align-items:flex-start}
  .journey-dot{position:absolute;left:-36px;top:44px;grid-column:auto;justify-self:start}
  .journey-body{max-width:none}
}

/* ── Meet expert ─────────────────────────────────────── */
.expert{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}
@media (max-width:880px){.expert{grid-template-columns:1fr;gap:40px}}
.expert-img{aspect-ratio:4/5;position:relative;overflow:hidden;border:1px solid var(--line)}
.expert-img img{width:100%;height:100%;object-fit:cover}
.expert-tag{position:absolute;top:22px;left:22px;background:var(--acc);color:var(--acc-ink);padding:8px 14px;border-radius:999px;font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-weight:700}
.expert-quotes{list-style:none;display:flex;flex-direction:column;gap:14px;margin:24px 0 0;padding:24px 0 0;border-top:1px solid var(--line)}
.expert-quotes li{display:flex;gap:14px;font-size:16px;color:var(--fg);line-height:1.5}
.expert-quotes .q-mark{font-family:var(--display);font-style:normal;color:var(--acc);font-size:18px;font-weight:700;flex:none;width:24px;text-align:center}
.expert-sig{margin-top:36px;font-family:var(--display);font-weight:700;font-size:42px;color:var(--fg);letter-spacing:-.03em;line-height:1;text-transform:uppercase}
.expert-sig + .role{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-top:10px}

/* ── FAQ ─────────────────────────────────────────────── */
.faq{max-width:1000px;margin-inline:auto;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:24px;padding:28px 0;text-align:left;font-family:var(--display);font-weight:700;font-size:clamp(20px,2vw,28px);text-transform:uppercase;letter-spacing:-.02em;line-height:1.2;transition:color .2s}
.faq-q:hover{color:var(--acc)}
.faq-q .plus{flex:none;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:all .3s;color:var(--muted)}
.faq-q.open .plus{background:var(--acc);border-color:var(--acc);color:var(--acc-ink);transform:rotate(45deg)}
.faq-q .plus svg{width:14px;height:14px}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;color:var(--muted);font-size:16px;line-height:1.6;max-width:64ch}
.faq-q.open + .faq-a{max-height:280px;padding-bottom:28px}

/* ── Final CTA ───────────────────────────────────────── */
.final-cta{padding:clamp(80px,10vw,180px) var(--gutter);text-align:center;background:radial-gradient(ellipse at center 130%,rgba(230,37,50,.14),transparent 60%),var(--bg);border-top:1px solid var(--line);position:relative;overflow:hidden}
.final-cta .watermark{position:absolute;left:50%;top:54%;transform:translate(-50%,-50%);width:min(60vw,560px);opacity:.10;pointer-events:none;z-index:0}
.final-cta > *{position:relative;z-index:1}
.final-cta .h1{margin-bottom:28px;max-width:18ch;margin-inline:auto}
.final-cta .h1 em{font-family:var(--display);font-style:normal;font-weight:700;text-transform:uppercase;color:var(--acc);letter-spacing:-.025em}

/* ── Footer ──────────────────────────────────────────── */
footer{padding:48px var(--gutter) 32px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;background:var(--bg-2)}
footer .legal{font-size:10px;color:var(--faint);letter-spacing:.14em;text-transform:uppercase;font-weight:700}
footer .legal a{margin-left:18px;transition:color .2s}
footer .legal a:hover{color:var(--fg)}

/* ── Section title block ─────────────────────────────── */
.sec-head{display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:end;margin-bottom:clamp(48px,6vw,88px)}
@media (max-width:880px){.sec-head{grid-template-columns:1fr;gap:24px}}
.sec-tag{display:inline-flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700}
.sec-tag::before{content:"";width:24px;height:1px;background:var(--acc)}

/* ── Form Modal — LIGHT THEME (Enter details) ──────────── */
.modal-back{position:fixed;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:10000;display:grid;place-items:center;padding:24px;opacity:0;pointer-events:none;visibility:hidden;transition:opacity .25s,visibility .25s}
.modal-back.open{opacity:1;pointer-events:auto;visibility:visible}
.modal-light{width:100%;max-width:520px;background:#fff;color:#0a0a0a;border-radius:14px;padding:36px 36px 32px;position:relative;transform:translateY(20px);transition:transform .35s cubic-bezier(.2,.8,.2,1);box-shadow:0 30px 80px -20px rgba(0,0,0,.6)}
.modal-back.open .modal-light{transform:translateY(0)}
.modal-light .modal-close{position:absolute;top:18px;right:18px;width:32px;height:32px;display:grid;place-items:center;border:none;border-radius:50%;color:#aaa;background:transparent;transition:color .2s}
.modal-light .modal-close:hover{color:#0a0a0a}

.modal-progress-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-right:32px}
.mp-label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:#9a9a9a}
.mp-count{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:800;color:var(--acc)}
.modal-progress-bar{height:8px;background:#f1efe8;border-radius:999px;overflow:hidden;margin-bottom:28px}
.modal-progress-fill{height:100%;width:68%;background:linear-gradient(90deg,#e62532 0%,#ff6a3d 100%);border-radius:999px}

.modal-light-title{font-family:var(--display);font-weight:800;font-size:30px;line-height:1.1;letter-spacing:-.02em;color:#0a0a0a;margin:0 0 24px;text-transform:none}

.modal-light-form{display:flex;flex-direction:column;gap:14px}
.modal-light-form input{width:100%;padding:16px 18px;background:#fff;border:1px solid #d8d5cc;color:#0a0a0a;font:inherit;font-size:14.5px;border-radius:10px;transition:border-color .2s, box-shadow .2s;font-weight:400}
.modal-light-form input::placeholder{color:#9a958a}
.modal-light-form input:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px rgba(230,37,50,.12)}
.modal-input-wrap{position:relative;display:flex;align-items:center}
.modal-input-wrap input{padding-left:48px}
.modal-input-icon{position:absolute;left:18px;width:18px;height:18px;color:#9a958a;pointer-events:none;z-index:2}
.modal-input-flag{position:absolute;left:14px;width:22px;height:16px;display:flex;flex-direction:column;border-radius:2px;overflow:hidden;border:1px solid #ccc;pointer-events:none;z-index:2}
.modal-input-flag span{flex:1;display:block}
.modal-cta-light{margin-top:6px;width:100%;padding:18px 28px;border-radius:10px;background:var(--acc);color:#fff;font-family:var(--display);font-weight:800;font-size:14px;letter-spacing:.08em;text-transform:uppercase;border:none;cursor:pointer;transition:transform .15s, background .15s, box-shadow .2s}
.modal-cta-light:hover{background:#ff3744;box-shadow:0 14px 40px -10px rgba(230,37,50,.45)}
.modal-cta-light:active{transform:translateY(1px)}

/* ── Sticky bottom bar (mobile) ──────────────────────── */
.sticky-cta{display:none;position:fixed;left:0;right:0;bottom:0;z-index:9999;padding:14px 16px;background:rgba(0,0,0,.96);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;pointer-events:auto}
@media (max-width:760px){.sticky-cta{display:flex}}
.sticky-cta *{pointer-events:auto !important}
.sticky-cta .meta{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700}
.sticky-cta .btn{padding:14px 20px;font-size:11px}

/* ── Brand marks ─────────────────────────────────────── */
/* Wordmark + SPC are black PNGs — already correct on cream BG. No filter. */
.brand-s{display:block;height:28px;width:auto}
.brand-wordmark{display:block;height:13px;width:auto;filter:invert(96%) sepia(2%) saturate(180%) hue-rotate(2deg) brightness(96%)}
.brand-stack{display:flex;align-items:center;gap:12px}
.spc-oval{display:inline-block;height:24px;width:auto;filter:invert(96%) sepia(2%) saturate(180%) hue-rotate(2deg) brightness(96%);opacity:.85}

/* Hero SPC eyebrow: long label visible on desktop, hidden block on mobile */
.hero-spc-group{display:flex;align-items:center;gap:12px}
.hero-spc-desktop{display:inline}
.hero-loc-val{display:inline-flex;align-items:center;gap:8px}
@media (max-width:760px){
  .hero-spc-group{display:none}
}

/* ── Reveal-on-scroll (progressive enhancement) ──────── */
.js-reveal-ready .reveal:not(.in){opacity:0;transform:translateY(24px);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:translateY(0);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1)}
.js-reveal-ready .reveal-stagger:not(.in) > *{opacity:0;transform:translateY(16px);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:0ms}
.reveal-stagger.in > *:nth-child(2){transition-delay:80ms}
.reveal-stagger.in > *:nth-child(3){transition-delay:160ms}
.reveal-stagger.in > *:nth-child(4){transition-delay:240ms}
.reveal-stagger.in > *:nth-child(5){transition-delay:320ms}
.reveal-stagger.in > *:nth-child(6){transition-delay:400ms}


/* ─────────────────────────────────────────────────────────────────────
   MOBILE FIXES — keep everything inside the viewport
   ───────────────────────────────────────────────────────────────────── */
html{overflow-x:hidden}
body{overflow-x:hidden}

@media (max-width:760px){
  :root{
    --gutter: 20px;
    --h1: clamp(30px, 7.2vw, 44px);
    --h2: clamp(26px, 6.5vw, 40px);
    --h3: 20px;
  }

  /* HERO */
  .hero{padding:96px 20px 40px;min-height:100svh}
  .hero-top{flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:32px}
  .hero-h1{font-size:clamp(35px,9.4vw,52px);line-height:1;letter-spacing:-.025em;max-width:none}
  .hero-meta{grid-template-columns:1fr;gap:16px;margin-top:32px}
  .hero-cta-row{margin-top:24px;gap:14px;align-items:flex-start;flex-direction:column}
  .hero-cta-row .btn{width:auto}
  .scroll-cue{display:none}

  /* NAV — tighter pill on mobile */
  .nav{padding:14px 20px}
  .nav .btn-pill{padding:9px 14px;font-size:9.5px;letter-spacing:.1em}

  /* MARQUEE — smaller */
  .marquee-item{font-size:16px}

  /* COUNTDOWN — radically smaller so 4 units + separators fit */
  .countdown{padding:48px 20px}
  .countdown-grid{gap:6px;margin:24px 0 28px;flex-wrap:nowrap}
  .cd-unit{min-width:0;flex:1 1 0;gap:6px}
  .cd-num{font-size:clamp(36px,11vw,52px);line-height:1;letter-spacing:-.03em}
  .cd-lbl{font-size:8.5px;letter-spacing:.1em}
  .cd-sep{font-size:clamp(28px,8vw,40px);margin-top:0}

  /* SECTION SPACING */
  .section-pad{padding-block:64px}
  .sec-head{margin-bottom:40px;gap:12px}
  .h2{font-size:clamp(28px,7.5vw,44px);line-height:.96;letter-spacing:-.02em}

  /* PILLARS / SIX-WEEKS / EXPERT — all stack already, just shrink pad */
  .pillar-body{padding:22px 22px 26px}
  .pillar-title{font-size:22px}
  .six-media{height:auto !important;aspect-ratio:4/5}
  .six-list li{grid-template-columns:32px 1fr 28px;gap:14px;padding:16px 0;font-size:16px}
  .six-idx{font-size:10px}

  /* TESTIMONIALS scroller */
  .tst-toolbar{gap:14px;margin-bottom:24px}
  .tst-meta{font-size:11px;gap:10px}
  .tst-rating-text{font-size:10px}
  .tst-arrow{width:38px;height:38px}
  .tst{flex-basis:82vw}
  .tst-content{padding:18px 20px 20px;gap:12px}
  .tst-body{font-size:14.5px}

  /* CLUB TOUR — keep vertical but tighter */
  .club-tour-section{padding-bottom:64px}
  .club-tour{max-width:calc(100vw - 40px);margin-top:32px;border-radius:4px}
  .club-tour-overlay{padding:14px}
  .club-tour-tag{font-size:9px;padding:6px 12px}
  .ct-btn{width:42px;height:42px}

  /* INCLUDED — single column */
  .incl{padding:36px 24px 32px;min-height:auto}
  .incl-title{font-size:22px}

  /* JOURNEY — keep the rail in the middle but tighter content */
  .journey-row{gap:8px;padding:36px 0}
  .journey-num{font-size:48px;line-height:.95}
  .journey-num em{font-size:11px}
  .journey-title{font-size:20px;line-height:1.1}
  .journey-body{font-size:14px}

  /* EXPERT + TEAM */
  .expert-quotes li{font-size:14px;gap:10px}
  .expert-sig{font-size:32px}
  .team-block{margin-top:48px;padding-top:40px}
  .team-info{padding:14px 14px 16px}
  .team-name{font-size:15px}
  .team-role{font-size:9.5px;letter-spacing:.1em}

  /* FAQ */
  .faq-q{font-size:18px;padding:22px 0;gap:14px}
  .faq-q .plus{width:28px;height:28px}
  .faq-q .plus svg{width:11px;height:11px}
  .faq-q.open + .faq-a{max-height:400px;padding-bottom:22px}
  .faq-a{font-size:14.5px}

  /* FINAL CTA */
  .final-cta{padding:80px 20px}
  .final-cta .h1{font-size:clamp(36px,9vw,56px);max-width:none}

  /* FOOTER */
  footer{padding:32px 20px 24px;flex-direction:column;align-items:flex-start;gap:16px;text-align:left}
  footer .legal{font-size:9px;letter-spacing:.12em}
  footer .legal a{margin-left:0;margin-right:14px;display:inline-block;margin-top:6px}
  footer .legal span{display:block;margin-top:8px;margin-left:0 !important}

  /* MODAL */
  .modal-light{padding:28px 22px 26px;border-radius:10px}
  .modal-light-title{font-size:24px}
  .modal-light-form input{padding:14px 16px;font-size:14px}
  .modal-light-form .modal-input-wrap input{padding-left:44px}
  .modal-cta-light{padding:16px 24px;font-size:12px}

  /* Stop tweaks panel from sticking out */
  .twk-panel{right:8px;bottom:8px;width:calc(100vw - 16px);max-width:280px}
}
