/* =====================================================================
   FITCOM FITNESS — homepage stylesheet (live-mirror + GSAP motion)
   Dev / LOOP · 2026-06-01.  Scoped to .page-home sections (fc-* classes).
   Mei spec: cut-corner buttons (no pills), chevron diet, tonal-contrast type.
   ===================================================================== */

:root{
  --fc-orange:#F6921E; --fc-orange-dark:#D97B0A;
  --fc-ink:#0E0E0E; --fc-body:#5A5A5A; --fc-paper:#F7F4EF; --fc-line:#E7E3DC;
  --fc-cream:#FFE9D4; /* live "Life Changing Stories" section peach */
  --fs-eyebrow: clamp(0.75rem, 0.7rem + 0.2vw, 0.875rem);
  --fs-body:    clamp(0.95rem, 0.9rem + 0.3vw, 1.0625rem);
  --fs-h3:      clamp(1.15rem, 1.0rem + 0.8vw, 1.6rem);
  --fs-h2:      clamp(1.625rem, 1.25rem + 1.6vw, 2.25rem); /* live section H2 = 36px @ 1440 */
  --fs-h1:      clamp(2.25rem, 1.6rem + 4.2vw, 4.25rem);
  --pad-section: clamp(3rem, 2rem + 6vw, 7rem);
  --gutter:      clamp(1rem, 0.6rem + 2vw, 2.5rem);
  --fc-container: min(1200px, 92vw);
}

.page-home .fc-wrap{ width:var(--fc-container); margin-inline:auto; }
.page-home section[data-rv]{ padding-block: var(--pad-section); }

/* ---- Shared type ---- */
.page-home .fc-eyebrow{
  display:inline-block; text-transform:uppercase; letter-spacing:.16em;
  font-size:var(--fs-eyebrow); font-weight:700; color:var(--fc-orange-dark);
  margin-bottom:.6rem;
}
.page-home .fc-h2{
  font-size:var(--fs-h2); line-height:1.3; letter-spacing:normal; font-weight:700;
  color:var(--fc-ink); margin:0 0 .4em;
}
.section--ink .fc-h2{ color:#fff; }
.page-home .accent{ color:var(--fc-orange); }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ---- Kick button — Fitcom owned angular shape (notch top-left + bottom-right)
   Shape lives in clip-path so it survives stray radius overrides. The
   authoritative override of the old "Muay-Thai-kick" block lives in site.css
   (loaded after home.css); these are the base values. ---- */
.page-home .fc-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.9rem 1.7rem; font-weight:700; font-size:var(--fs-body);
  border:0; border-radius:24px; position:relative;
  clip-path:none;
  transition:transform .22s cubic-bezier(.22,1,.36,1),box-shadow .22s cubic-bezier(.22,1,.36,1),filter .22s ease;
  text-decoration:none; line-height:1; cursor:pointer;
}
.page-home .fc-btn--orange{
  background:#F6921E;
  color:#fff;
  box-shadow:0 8px 22px rgba(246,146,30,.28),0 2px 6px rgba(217,123,10,.20);
}
.page-home .fc-btn--orange:hover{
  transform:translateY(-3px) translateX(2px);
  box-shadow:0 16px 38px rgba(246,146,30,.40),0 4px 10px rgba(217,123,10,.32);
  filter:saturate(1.06); text-decoration:none;
}
.page-home .fc-btn--ghost{
  background:transparent; color:var(--fc-ink);
  box-shadow:inset 0 0 0 1.5px rgba(14,14,14,.28);
}
.page-home .fc-btn--ghost:hover{
  color:var(--fc-orange-dark); transform:translateY(-3px) translateX(2px);
  box-shadow:inset 0 0 0 1.5px var(--fc-orange);
}
.section--ink .fc-btn--ghost{ color:#fff; box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.3); }
.section--ink .fc-btn--ghost:hover{ color:var(--fc-orange); box-shadow:inset 0 0 0 1.5px var(--fc-orange); }
@media (prefers-reduced-motion:reduce){
  .page-home .fc-btn{ transition:none; }
  .page-home .fc-btn--orange:hover,.page-home .fc-btn--ghost:hover{ transform:none; }
}

/* =====================================================================
   §0.3  GSAP REVEAL CONTRACT  (visible rule MUST out-specify hidden rule)
   Hidden state ONLY under html.js-motion -> no-JS/reduced-motion = visible.
   ===================================================================== */
html.js-motion .page-home [data-rv] .rv{ opacity:0; transform:translateY(24px); }
html.js-motion .page-home [data-rv].is-in .rv{ opacity:1 !important; transform:none !important; }
/* =====================================================================
   §1  HERO  — full-bleed dark gym photo + centered logo, then a white
   rounded card overlapping upward holding a cream EARN panel (live mirror)
   ===================================================================== */
.page-home .fc-hero{
  position:relative; overflow:visible;
  background:#fff;
  padding:0 0 var(--pad-section);
}
/* dark gym photo stage with centered FITCOM logo */
.page-home .fc-hero__stage{
  position:relative; width:100%;
  min-height:100vh;
  background-color:var(--fc-ink);
  background-size:cover; background-position:center;
  display:flex; align-items:center; justify-content:center;
}
.page-home .fc-hero__stage{ overflow:hidden; }
.page-home .fc-hero__bgvideo{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border:0; pointer-events:none; z-index:0; }
.page-home .fc-hero__stage::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(14,14,14,.45) 0%, rgba(14,14,14,.62) 100%);
}
.page-home .fc-hero__stagelogo{ position:relative; z-index:2; padding-bottom:0; will-change:transform,opacity; }
.page-home .fc-hero__stagelogo img{
  width:clamp(220px,30vw,420px); height:auto; display:block;
}
/* subtle scroll cue, bottom-centre of the hero stage (replaces the slab) */
.page-home .fc-hero__scroll{
  position:absolute; left:50%; bottom:clamp(1.6rem,3vh,2.6rem); transform:translateX(-50%);
  z-index:2; display:flex; flex-direction:column; align-items:center; gap:.7rem;
  pointer-events:none;
}
.page-home .fc-hero__scrolltxt{
  font-size:.7rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase;
  color:rgba(255,255,255,.78);
}
.page-home .fc-hero__scrollline{
  position:relative; width:1px; height:46px; overflow:hidden;
  background:rgba(255,255,255,.22);
}
.page-home .fc-hero__scrollline::after{
  content:""; position:absolute; left:0; top:0; width:1px; height:40%;
  background:var(--fc-orange);
  animation:fc-scrollcue 2.1s cubic-bezier(.65,0,.35,1) infinite;
}
@keyframes fc-scrollcue{
  0%   { transform:translateY(-100%); }
  55%  { transform:translateY(250%); }
  100% { transform:translateY(250%); }
}
@media (prefers-reduced-motion:reduce){
  .page-home .fc-hero__scrollline::after{ animation:none; }
}
/* white rounded card — sits BELOW the full-viewport video, revealed on scroll
   (deliberately NOT overlapping upward, so nothing peeks on load) */
.page-home .fc-hero__card{
  position:relative; z-index:3;
  margin-top:clamp(2rem,3vw,3.5rem);
  background:#fff; border-radius:28px;
  padding:0; /* flush — split panel fills edge-to-edge inside the card */
  box-shadow:0 18px 60px rgba(14,14,14,.10);
  overflow:hidden; /* clip children to 28px card corners */
}
/* cream inner panel (base — overridden by --split variant below) */
.page-home .fc-hero__panel{
  background:var(--fc-cream); border-radius:24px;
  padding:clamp(2rem,1.4rem + 3vw,3.5rem) clamp(1.25rem,1rem + 2vw,3rem) clamp(0px,0vw,0px);
  text-align:center; overflow:hidden;
}
.page-home .fc-hero__h1{
  font-size:var(--fs-h1); line-height:1.1; font-weight:800; letter-spacing:-.01em;
  color:var(--fc-orange); margin:0 auto .6rem; max-width:18ch;
}
.page-home .fc-hero__earnline{
  font-size:clamp(1rem,.9rem + .7vw,1.3rem); font-weight:700; color:var(--fc-ink);
  margin:0 0 1rem;
}
.page-home .fc-hero__ctas{ display:flex; justify-content:center; margin-bottom:clamp(1.5rem,1rem + 2vw,2.5rem); }

/* =====================================================================
   EARN section — split-layout redesign (Mei 2026-06-02)
   Left: cream text column (heading + 4-pillar strip + CTA)
   Right: coach photo — flush to card edge, clips to card border-radius
   Border-radius fix: card is overflow:hidden so both columns clip to
   28px. No inner border-radius needed on the split panel.
   Photo = hero-kkma.webp (KK Ma, not hero-kelvin used in §3 Programmes)
   ===================================================================== */

/* Split panel layout — fills card flush, no inner radius needed */
.page-home .fc-hero__panel--split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  align-items:stretch;
  padding:0;
  overflow:hidden;
  border-radius:24px;
}

/* LEFT — cream text column */
.page-home .fc-hero__panel-text{
  background:var(--fc-cream);
  padding:clamp(1.5rem,1rem + 2vw,2.5rem) clamp(1.25rem,1rem + 2vw,2.25rem);
  text-align:left;
  display:flex; flex-direction:column; justify-content:center;
}

/* RIGHT — photo column, flush to card right edge */
.page-home .fc-hero__panel-photo{
  position:relative; overflow:hidden;
  min-height:360px;
}
.page-home .fc-hero__coach-img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover; object-position:50% 40%; /* action shot — centre on kick */
  display:block;
}

/* Heading — left-aligned in split mode, capped so full card fits viewport */
.page-home .fc-hero__panel--split .fc-hero__h1{
  text-align:left; margin-left:0; margin-right:0; max-width:none;
  font-size:clamp(1.8rem,1.3rem + 2.8vw,3rem);
  margin-bottom:.5rem;
}

/* Subtitle — left-aligned */
.page-home .fc-hero__panel--split .fc-hero__earnline{
  text-align:left;
}

/* CTA row */
.page-home .fc-hero__panel--split .fc-hero__ctas{
  justify-content:flex-start;
  margin-bottom:0;
}

/* ── 4-pillar strip ─────────────────────────────────────── */
.page-home .fc-earn-pillars{
  list-style:none; margin:0 0 1rem; padding:0;
  display:flex; flex-direction:column; gap:.35rem;
}
.page-home .fc-earn-pillars li{
  display:flex; align-items:center; gap:.55rem;
}
.page-home .fc-earn-pillars__letter{
  flex-shrink:0;
  width:2rem; height:2rem;
  background:var(--fc-orange);
  color:#fff;
  font-family:var(--font-head); font-weight:800; font-size:.85rem;
  display:flex; align-items:center; justify-content:center;
  border-radius:12px;
  line-height:1;
}
.page-home .fc-earn-pillars__word{
  font-family:var(--font-head); font-weight:600;
  font-size:clamp(.85rem,.7rem + .6vw,1rem);
  color:var(--fc-ink); letter-spacing:.01em;
}

/* ── Mobile: stack vertically ───────────────────────────── */
@media(max-width:680px){
  .page-home .fc-hero__panel--split{
    grid-template-columns:1fr;
  }
  .page-home .fc-hero__panel-photo{
    min-height:260px;
    order:-1; /* photo top on mobile */
  }
  .page-home .fc-hero__panel-text{
    text-align:center;
  }
  .page-home .fc-hero__panel--split .fc-hero__h1,
  .page-home .fc-hero__panel--split .fc-hero__earnline{
    text-align:center;
  }
  .page-home .fc-hero__panel--split .fc-hero__ctas{
    justify-content:center;
  }
  .page-home .fc-earn-pillars{
    flex-direction:row; flex-wrap:wrap; justify-content:flex-start; gap:.5rem;
  }
  .page-home .fc-earn-pillars li{
    flex:0 0 calc(50% - .25rem);
  }
}

/* =====================================================================
   §2  CUSTOMER FIRST, OUR PROMISE
   ===================================================================== */
.page-home .fc-promise{ background:#fff; }
.page-home .fc-promise__head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:var(--gutter); margin-bottom:clamp(1.5rem,1rem + 2vw,3rem); flex-wrap:wrap;
}
/* 7 promises = 4 top + 3 bottom. Use a 12-col grid (each card spans 3) and
   offset the first card of the 2nd row by 1.5 cols so the trailing 3 centre. */
.page-home .fc-promise__grid{
  display:grid; grid-template-columns:repeat(12,1fr); gap:var(--gutter);
  align-items:stretch;
}
.page-home .fc-promise__grid .fc-pcard{ grid-column:span 3; }
.page-home .fc-promise__grid .fc-pcard:nth-child(5){ grid-column:2 / span 3; }
.page-home .fc-promise__grid .fc-pcard:nth-child(6){ grid-column:span 3; }
.page-home .fc-promise__grid .fc-pcard:nth-child(7){ grid-column:span 3; }
.page-home .fc-pcard{
  position:relative; background:var(--fc-paper); padding:1.8rem 1.5rem;
  border:1px solid var(--fc-line); border-radius:24px;
  display:flex; flex-direction:column; gap:.7rem; overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease;
}
.page-home .fc-pcard::before{
  content:""; position:absolute; top:0; left:0; right:0; height:2px;
  background:var(--fc-orange); transform:scaleX(0); transform-origin:left;
  transition:transform .25s ease;
}
.page-home .fc-pcard:hover{ transform:translateY(-4px); box-shadow:0 14px 32px rgba(14,14,14,.08); }
.page-home .fc-pcard:hover::before{ transform:scaleX(1); }
.page-home .fc-pcard__icon img{ width:56px; height:56px; object-fit:contain; }
.page-home .fc-pcard__title{ font-size:var(--fs-h3); color:var(--fc-ink); margin:0; line-height:1.2; }
.page-home .fc-pcard__body{ font-size:var(--fs-body); color:var(--fc-body); margin:0; line-height:1.55; }

/* =====================================================================
   §3  OUR PROGRAMMES — image + accordion
   ===================================================================== */
.page-home .fc-approach{ background:var(--fc-paper); }
.page-home .fc-approach__grid{
  display:grid; grid-template-columns:0.9fr 1.1fr; gap:clamp(1.5rem,1rem + 4vw,4rem);
  align-items:start;
}
.page-home .fc-approach__media{ position:sticky; top:110px; overflow:hidden;
  border-radius:24px; }
.page-home .fc-approach__media img{
  width:100%; height:clamp(320px,42vw,560px); object-fit:cover; object-position:50% 20%; display:block;
}
/* parallaxed media gets a touch of overscan so the yPercent shift never gaps */
.page-home [data-depth]{ will-change:transform; }
.page-home .fc-approach__media img[data-depth]{ height:calc(clamp(320px,42vw,560px) * 1.14); margin-top:-7%; object-position:50% 20%; }
.page-home .fc-acc{ margin-top:1.2rem; border-top:1px solid var(--fc-line); }
.page-home .fc-acc__item{ border-bottom:1px solid var(--fc-line); }
.page-home .fc-acc__head{
  width:100%; display:flex; align-items:center; justify-content:space-between;
  gap:1rem; padding:1.15rem .25rem; background:none; border:0; text-align:left;
  font-size:var(--fs-h3); font-weight:700; color:var(--fc-ink); line-height:1.25;
}
.page-home .fc-acc__head:hover{ color:var(--fc-orange-dark); }
.page-home .fc-acc__title{ flex:1; }
/* +/- affordance (NOT », per chevron diet) */
.page-home .fc-acc__sign{ position:relative; width:18px; height:18px; flex:none; }
.page-home .fc-acc__sign::before,
.page-home .fc-acc__sign::after{
  content:""; position:absolute; background:var(--fc-orange);
  transition:transform .25s ease, opacity .25s ease;
}
.page-home .fc-acc__sign::before{ top:8px; left:0; width:18px; height:2px; }
.page-home .fc-acc__sign::after{ top:0; left:8px; width:2px; height:18px; }
.page-home .fc-acc__item.is-open .fc-acc__sign::after{ transform:scaleY(0); opacity:0; }
.page-home .fc-acc__panel{ overflow:hidden; }
.page-home .fc-acc__panel p{
  font-size:var(--fs-body); color:var(--fc-body); line-height:1.65;
  margin:0 0 1.15rem; padding-right:1.5rem;
}

/* =====================================================================
   §2b  E.A.R.N. PHILOSOPHY  (reuses .fc-promise / .fc-pcard grid)
   ===================================================================== */
.page-home .fc-earnsec{ background:var(--fc-paper); }
.page-home .fc-earnsec__lead{
  font-size:var(--fs-body); color:var(--fc-body); line-height:1.6;
  max-width:60ch; margin:.6rem 0 0;
}
/* letter badge replaces the icon img — same card, in-system orange accent */
.page-home .fc-pcard__badge{
  display:inline-flex; align-items:center; justify-content:center;
  width:56px; height:56px; font-weight:800; font-size:1.9rem; line-height:1;
  color:var(--fc-orange); background:var(--fc-cream);
  border-radius:12px; overflow:hidden;}
.page-home .fc-pcard--earn{ background:#fff; }
.page-home .fc-safe{
  margin:clamp(1.5rem,1rem + 2vw,2.5rem) 0 0;
  padding:1.1rem 1.4rem; background:#fff; border-left:3px solid var(--fc-orange);
  font-size:var(--fs-body); color:var(--fc-body); line-height:1.6;
}
.page-home .fc-safe strong{ color:var(--fc-ink); }

/* =====================================================================
   §2c  WHY FITCOM IS DIFFERENT — 5-point feature list
   ===================================================================== */
.page-home .fc-diff{ background:#fff; }
.page-home .fc-diff__head{ margin-bottom:clamp(1.5rem,1rem + 2vw,3rem); }
.page-home .fc-diff__grid{ display:grid; gap:var(--gutter); }
.page-home .fc-diff__item{
  display:grid; grid-template-columns:auto 1fr; gap:clamp(1rem,.6rem + 1.5vw,2rem);
  align-items:start; padding:1.4rem 0; border-top:1px solid var(--fc-line);
}
.page-home .fc-diff__item:last-child{ border-bottom:1px solid var(--fc-line); }
.page-home .fc-diff__num{
  font-size:clamp(1.6rem,1.2rem + 1.4vw,2.4rem); font-weight:800;
  color:var(--fc-orange); line-height:1; letter-spacing:-.02em;
}
.page-home .fc-diff__title{ font-size:var(--fs-h3); color:var(--fc-ink); margin:0 0 .35em; line-height:1.25; }
.page-home .fc-diff__sub{ color:var(--fc-body); font-weight:600; }
.page-home .fc-diff__body{ font-size:var(--fs-body); color:var(--fc-body); line-height:1.6; margin:0; max-width:64ch; }

/* =====================================================================
   §4b  OUR PROMISE band + TRUST badges
   ===================================================================== */
.page-home .fc-promiseband{ background:var(--fc-ink); color:#fff; text-align:center; }
.page-home .fc-promiseband__inner{ max-width:62ch; }
.page-home .fc-promiseband .fc-eyebrow{ color:var(--fc-orange); }
.page-home .fc-promiseband__lead{ font-size:var(--fs-body); color:#cfcfcf; margin:0 0 1rem; line-height:1.6; }
.page-home .fc-promiseband__big{
  font-size:clamp(1.3rem,1.05rem + 1.1vw,1.9rem); font-weight:700; color:#fff;
  line-height:1.35; margin:0 0 1.2rem;
}
.page-home .fc-promiseband__sign{ font-size:var(--fs-body); color:#e5e5e5; line-height:1.6; margin:0; }
.page-home .fc-promiseband__cn{ display:block; margin-top:.4rem; color:var(--fc-orange); font-weight:600; }

.page-home .fc-trust{
  margin-top:clamp(2rem,1.4rem + 2vw,3.2rem); padding-top:clamp(1.5rem,1rem + 2vw,2.4rem);
  border-top:1px solid rgba(255,255,255,.12); text-align:center;
}
.page-home .fc-trust__label{
  display:block; text-transform:uppercase; letter-spacing:.18em; font-size:var(--fs-eyebrow);
  font-weight:700; color:#9a9a9a; margin-bottom:1.1rem;
}
.page-home .fc-trust__list{
  list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap;
  justify-content:center; gap:clamp(1rem,.6rem + 2vw,2.6rem); align-items:center;
}
/* monochrome / desaturated — NO competing colour (guardrail) */
.page-home .fc-trust__badge{
  font-weight:800; font-size:clamp(1.05rem,.9rem + .6vw,1.5rem); letter-spacing:.02em;
  color:#fff; opacity:.55; filter:grayscale(1);
  transition:opacity .2s ease;
}
.page-home .fc-trust__badge:hover{ opacity:.9; }

/* =====================================================================
   §4  EVERY JOURNEY STARTS SOMEWHERE — story cards
   ===================================================================== */
.page-home .fc-stories{ background:var(--fc-cream); }
.page-home .fc-stories__head{ text-align:center; margin-bottom:clamp(1.5rem,1rem + 2vw,3rem); }
.page-home .fc-stories__grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gutter);
}
.page-home .fc-story{
  display:flex; flex-direction:column; background:#fff; border:1px solid var(--fc-line);
  border-radius:24px; text-decoration:none; color:inherit; overflow:hidden;
  transition:transform .2s ease, box-shadow .2s ease;
}
.page-home .fc-story:hover{ transform:translateY(-4px); box-shadow:0 16px 36px rgba(14,14,14,.10); text-decoration:none; }
.page-home .fc-story__img{ position:relative; }
.page-home .fc-story__img img{
  width:100%; height:clamp(200px,22vw,260px); object-fit:cover; object-position:50% 15%; align-self:flex-start;
}
.page-home .fc-story__loc{
  position:absolute; top:.7rem; left:.7rem; background:var(--fc-ink); color:#fff;
  font-size:.72rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  padding:.3rem .6rem;
  border-radius:12px; overflow:hidden;}
.page-home .fc-story__cap{ padding:1.1rem 1.2rem 1.4rem; display:flex; flex-direction:column; gap:.5rem; }
.page-home .fc-story__tag{ font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--fc-orange-dark); }
.page-home .fc-story__title{ font-size:1.05rem; line-height:1.35; color:var(--fc-ink); margin:0; }
.page-home .fc-story__coach{ font-size:.85rem; color:var(--fc-body); margin-top:auto; }
.page-home .fc-stories__foot{ text-align:center; margin-top:clamp(1.5rem,1rem + 2vw,2.5rem); }

/* =====================================================================
   §5  TESTIMONIALS — structural-absence placeholder
   ===================================================================== */
.page-home .fc-testi{ background:#fff; }
.page-home .fc-testi__inner{ text-align:center; max-width:60ch; margin-inline:auto; }
.page-home .fc-testi__placeholder{ font-size:var(--fs-body); color:var(--fc-body); margin:0 0 1.5rem; line-height:1.6; }
/* ===== §5 REVIEWS CAROUSEL ===== */
.page-home .fc-testi__inner{ text-align:center; max-width:none; }
.page-home .fc-reviews{ margin-top:2.5rem; position:relative; overflow:hidden; }
.page-home .fc-reviews__track{
  display:flex; transition:transform .45s cubic-bezier(.4,0,.2,1);
}
.page-home .fc-review{
  flex:0 0 100%; padding:2.5rem clamp(1.5rem,6vw,4rem);
  background:var(--fc-cream); border-radius:24px;
  text-align:left; display:flex; flex-direction:column; gap:.9rem;
}
.page-home .fc-review__stars{ color:var(--fc-orange); font-size:1.1rem; letter-spacing:.1em; }
.page-home .fc-review__text{
  font-size:clamp(1rem,1rem + .3vw,1.15rem); line-height:1.7;
  color:var(--fc-ink); margin:0; font-style:italic;
}
.page-home .fc-review__author{ display:flex; align-items:center; gap:.6rem; margin-top:auto; }
.page-home .fc-review__name{ font-weight:700; font-size:.9rem; color:var(--fc-ink); }
.page-home .fc-review__platform{
  font-size:.75rem; color:var(--fc-body); border:1px solid var(--fc-line);
  border-radius:8px; padding:.1em .5em;
}
.page-home .fc-reviews__nav{
  display:flex; align-items:center; justify-content:center;
  gap:1rem; margin-top:1.5rem;
}
.page-home .fc-reviews__btn{
  background:var(--fc-orange); color:#fff; border:none;
  width:40px; height:40px; border-radius:50%; font-size:1.1rem;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  transition:opacity .2s;
}
.page-home .fc-reviews__btn:hover{ opacity:.85; }
.page-home .fc-reviews__dots{ display:flex; gap:.5rem; }
.page-home .fc-reviews__dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--fc-line); cursor:pointer; transition:background .2s;
}
.page-home .fc-reviews__dot.is-active{ background:var(--fc-orange); }


/* =====================================================================
   §6  JOIN THE TEAM — Where Passion Becomes a Profession (2-col, light grey)
   ===================================================================== */
.page-home .fc-jointeam{ background:#F2F2F2; }
.page-home .fc-jointeam__grid{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,1rem + 4vw,4rem);
  align-items:center;
}
.page-home .fc-jointeam__lead{
  font-size:var(--fs-body); color:var(--fc-body); line-height:1.6;
  max-width:46ch; margin:.4rem 0 1.6rem;
}
.page-home .fc-jointeam__media{ position:relative; overflow:hidden;
  border-radius:24px; }
.page-home .fc-jointeam__media img{
  width:100%; height:clamp(240px,26vw,360px); object-fit:cover; object-position:50% 20%; display:block;
}
.page-home .fc-jointeam__media img[data-depth]{ height:calc(clamp(240px,26vw,360px) * 1.16); margin-top:-8%; }
/* orange chevron motif overlaying the lower-left of the photo (1 of allowed) */
.page-home .fc-jointeam__chev{
  position:absolute; left:-6%; bottom:-8%; width:42%; height:auto; z-index:2;
  pointer-events:none;
}
.page-home .fc-jointeam__chev path{
  fill:none; stroke:var(--fc-orange); stroke-width:18;
  stroke-linecap:round; stroke-linejoin:round;
}

/* =====================================================================
   §7  ENQUIRE NOW (full-width dark, centered — existing handler)
   ===================================================================== */
.page-home .fc-enquire.section--ink{ background:var(--fc-ink); color:#fff; }
.page-home .fc-enquire__inner{ max-width:720px; margin-inline:auto; }
.page-home .fc-enquire__head{ text-align:center; margin-bottom:clamp(1.5rem,1rem + 2vw,2.5rem); }
.page-home .fc-enquire__head .fc-h2{ margin-bottom:.3em; }
.page-home .fc-enquire__lead{ color:#cfcfcf; font-size:var(--fs-body); line-height:1.6; margin:0; }
/* fields sit directly on the dark section (live has no white card) */
.page-home .fc-enquire__formwrap{ background:transparent; box-shadow:none; padding:0; border-radius:12px; color:#fff; }
.page-home .fc-enquire .fc-field span{ color:#e9e9e9; }

.page-home .fc-form{ display:grid; gap:1rem; }
.page-home .fc-form__row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.page-home .fc-field{ display:flex; flex-direction:column; gap:.4rem; }
.page-home .fc-field span{ font-size:.85rem; font-weight:600; color:#e5e5e5; }
.page-home .fc-field input,
.page-home .fc-field select,
.page-home .fc-field textarea{
  width:100%; padding:.8rem .9rem; border:1px solid #3a3a3a; border-radius:12px;
  background:#fff; color:var(--fc-ink); font-family:inherit; font-size:var(--fs-body);
  min-height:48px;
}
.page-home .fc-field textarea{ min-height:auto; resize:vertical; }
.page-home .fc-field input:focus,
.page-home .fc-field select:focus,
.page-home .fc-field textarea:focus{ outline:none; border-color:var(--fc-orange); box-shadow:0 0 0 3px rgba(246,146,30,.25); }
.page-home .fc-form__submit{ justify-self:start; margin-top:.3rem; }
.page-home .fc-form__fine{ font-size:.8rem; color:#9a9a9a; margin:.4rem 0 0; }
.page-home .fc-form__fine a{ color:var(--fc-orange); }
.page-home .fc-hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }

/* --- radio / checkbox groups (Region, Goals, Experience, Time, Consent) --- */
[x-cloak]{ display:none !important; }
.page-home .fc-choice{ gap:.55rem; border:0; padding:0; margin:0; min-width:0; }
.page-home .fc-choice legend{ font-size:.85rem; font-weight:600; color:#e5e5e5; padding:0; margin-bottom:.5rem; }
.page-home .fc-choice legend small{ font-weight:500; color:#b9b9b9; }
.page-home .fc-radio,
.page-home .fc-check{
  flex-direction:row; align-items:center; gap:.6rem;
  font-size:var(--fs-body); color:#e9e9e9; cursor:pointer; line-height:1.3;
}
.page-home .fc-radio input,
.page-home .fc-check input{
  width:20px; height:20px; min-height:0; flex:0 0 20px; margin:0; padding:0;
  accent-color:var(--fc-orange); cursor:pointer;
}
.page-home .fc-radio span,
.page-home .fc-check span{ font-size:var(--fs-body); font-weight:400; color:#e9e9e9; }
.page-home .fc-cond input{ margin:0; }
.page-home .fc-agree{ margin-top:.2rem; align-items:flex-start; }
.page-home .fc-agree span{ font-size:.9rem; color:#cfcfcf; }
.page-home .fc-agree a{ color:var(--fc-orange); }

.page-home .fc-formmsg{ padding:1rem 1.2rem; margin-bottom:1.2rem; border-left:3px solid; display:flex; flex-direction:column; gap:.2rem; }
.page-home .fc-formmsg--ok{ background:rgba(246,146,30,.12); border-color:var(--fc-orange); }
.page-home .fc-formmsg--ok strong{ color:var(--fc-orange); }
.page-home .fc-formmsg--err{ background:rgba(220,80,60,.14); border-color:#dc503c; }
.page-home .fc-formmsg span{ color:#e5e5e5; font-size:.9rem; }

/* =====================================================================
   RESPONSIVE  — tablet 768–1199 / mobile <=767
   ===================================================================== */
@media (max-width:1199px){
  .page-home .fc-promise__grid{ grid-template-columns:repeat(2,1fr); }
  .page-home .fc-promise__grid .fc-pcard,
  .page-home .fc-promise__grid .fc-pcard:nth-child(5),
  .page-home .fc-promise__grid .fc-pcard:nth-child(6),
  .page-home .fc-promise__grid .fc-pcard:nth-child(7){ grid-column:auto; }
  .page-home .fc-stories__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:991px){
  .page-home .fc-approach__grid{ grid-template-columns:1fr; }
  .page-home .fc-approach__media{ position:static; }
  .page-home .fc-approach__media img{ height:clamp(240px,52vw,380px); }
  .page-home .fc-jointeam__grid{ grid-template-columns:1fr; }
  .page-home .fc-hero__card{ margin-top:clamp(-60px,-6vw,-40px); }
}
@media (max-width:767px){
  .page-home section[data-rv]{ padding-block: clamp(2rem, 1.5rem + 3vw, 3rem); }
  .page-home .fc-promise__grid{ grid-template-columns:1fr; }
  .page-home .fc-promise__head{ flex-direction:column; align-items:flex-start; }
  .page-home .fc-stories__grid{ grid-template-columns:1fr; }
  .page-home .fc-form__row{ grid-template-columns:1fr; }
}

/* =====================================================================
   HOMEPAGE HEADER — transparent overlay on the hero video, animates IN
   on load (GSAP), becomes a solid fixed bar once scrolled past the hero.
   Hero video is full-bleed to the very top, sitting UNDER the header.
   ===================================================================== */
.page-home .fc-hero{ margin-top:0; padding-top:0; position:relative; z-index:1; }
.page-home .fc-hero__stage{ min-height:100vh; padding-top:0; }

/* take the header out of flow so the video runs full-bleed beneath it */
.is-home .site-header{
  position:absolute; top:0; left:0; right:0; z-index:50;
  padding-block:clamp(.6rem,1.4vw,1.1rem);
  will-change:transform,opacity;
}
.is-home .site-header:not(.is-scrolled){
  background:transparent; border-bottom-color:transparent; box-shadow:none;
  -webkit-backdrop-filter:none; backdrop-filter:none;
}
/* white pill keeps the links legible over the dark video */
.is-home .site-header:not(.is-scrolled) .nav-links{
  background:#fff; border-radius:999px; padding:.55rem 1.6rem;
}
/* once past the hero: solid bar pinned to top */
.is-home .site-header.is-scrolled{
  position:fixed; top:0; padding-block:0;
  background:rgba(255,255,255,.97);
  -webkit-backdrop-filter:saturate(180%) blur(8px); backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--fc-line);
}
.is-home .site-header.is-scrolled .nav-links{ background:none; padding:0; }

/* GSAP pre-hides the header (autoAlpha) under js-motion only; this is the
   no-JS / reduced-motion guarantee that the nav is always visible */
html:not(.js-motion) .is-home .site-header{ opacity:1; visibility:visible; }
