/* =====================================================================
   FITCOM FITNESS — INNER-PAGE STYLES  ·  Dev / LOOP · 2026-06-01
   Extends the LOCKED homepage design system (fc-* under .page-home).
   Every block here is a NEW INSTANCE of an existing paradigm — no new
   colours, no new fonts. Vars inherited from home.css :root.
   Inner pages set body_class="page-home page-<slug>" so all fc-* apply.
   ===================================================================== */

/* ---- Page-head: a centered eyebrow+H1+lead band (reuses hero tone) ---- */
.page-home .fc-pagehead{
  background:linear-gradient(180deg,#fff 0%, var(--fc-paper) 100%);
  text-align:center;
}
.page-home .fc-pagehead__inner{ max-width:64ch; margin-inline:auto; }
.page-home .fc-pagehead h1{
  font-size:var(--fs-h1); line-height:1.05; color:var(--fc-ink); margin:.2em 0 .4em;
  letter-spacing:-.02em; font-weight:800;
}
.page-home .fc-pagehead h1 .accent{ color:var(--fc-orange); }
.page-home .fc-pagehead__lead{
  font-size:var(--fs-body); color:var(--fc-body); line-height:1.65;
  max-width:60ch; margin:0 auto;
}
.page-home .fc-pagehead--ink{ background:var(--fc-ink); }
.page-home .fc-pagehead--ink h1{ color:#fff; }
.page-home .fc-pagehead--ink .fc-pagehead__lead{ color:#cfcfcf; }
.page-home .fc-pagehead--ink .fc-eyebrow{ color:var(--fc-orange); }

/* ---- Split section: text + media / text + text (reuses approach grid) ---- */
.page-home .fc-split{ background:#fff; }
.page-home .fc-split--paper{ background:var(--fc-paper); }
.page-home .fc-split__grid{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,1rem + 4vw,4rem);
  align-items:center;
}
.page-home .fc-split__body p{ font-size:var(--fs-body); color:var(--fc-body); line-height:1.7; margin:0 0 1rem; }
.page-home .fc-split__body p strong{ color:var(--fc-ink); }
.page-home .fc-split__media img{
  width:100%; height:clamp(280px,38vw,460px); object-fit:cover; object-position:50% 10%; align-self:flex-start; display:block;
  border-radius:24px; overflow:hidden;}

/* ---- Quote card (founder voice) — in-system cream + orange rule ---- */
.page-home .fc-quotecard{
  background:var(--fc-cream); border-left:3px solid var(--fc-orange);
  padding:clamp(1.5rem,1rem + 2vw,2.4rem);
}
.page-home .fc-quotecard__q{ font-size:clamp(1.05rem,.95rem + .6vw,1.35rem); color:var(--fc-ink); line-height:1.5; font-weight:600; margin:0 0 1.2rem; }
.page-home .fc-quotecard__who{ display:flex; align-items:center; gap:.9rem; }
.page-home .fc-quotecard__avatar{
  width:48px; height:48px; flex:none; display:flex; align-items:center; justify-content:center;
  background:var(--fc-orange); color:#fff; font-weight:800; font-size:1.05rem;
  border-radius:12px; overflow:hidden;}
.page-home .fc-quotecard__avatar img{ width:100%; height:100%; object-fit:cover; object-position:50% 15%; }
.page-home .fc-quotecard__name{ font-weight:700; color:var(--fc-ink); display:block; }
.page-home .fc-quotecard__role{ font-size:.85rem; color:var(--fc-body); }

/* ---- Timeline (Our Gyms 2019→2024) — numbered orange milestone rail ---- */
.page-home .fc-timeline{ background:var(--fc-paper); }
.page-home .fc-timeline__grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gutter);
}
.page-home .fc-tl{
  position:relative; background:#fff; border:1px solid var(--fc-line); padding:1.6rem 1.4rem;
  display:flex; flex-direction:column; gap:.5rem;
}
.page-home .fc-tl::before{ content:""; position:absolute; top:0; left:0; width:100%; height:3px; background:var(--fc-orange); }
.page-home .fc-tl__year{ font-size:clamp(1.6rem,1.2rem + 1.2vw,2.2rem); font-weight:800; color:var(--fc-orange); line-height:1; letter-spacing:-.02em; }
.page-home .fc-tl__studio{ font-size:var(--fs-h3); color:var(--fc-ink); margin:0; line-height:1.25; }
.page-home .fc-tl__loc{ font-size:.85rem; color:var(--fc-body); }

/* ---- Numbered pillar list (Approach 5 pillars / Our Story principles) ---- */
.page-home .fc-pillars{ background:#fff; }
.page-home .fc-pillars--paper{ background:var(--fc-paper); }
.page-home .fc-pillar{
  display:grid; grid-template-columns:auto 1fr; gap:clamp(1rem,.6rem + 1.5vw,2.2rem);
  align-items:start; padding:1.8rem 0; border-top:1px solid var(--fc-line);
}
.page-home .fc-pillar:last-child{ border-bottom:1px solid var(--fc-line); }
.page-home .fc-pillar__num{
  font-size:clamp(1.8rem,1.3rem + 1.6vw,2.8rem); font-weight:800; color:var(--fc-orange);
  line-height:1; letter-spacing:-.02em;
}
.page-home .fc-pillar__title{ font-size:var(--fs-h3); color:var(--fc-ink); margin:0 0 .5em; line-height:1.25; }
.page-home .fc-pillar__body{ font-size:var(--fs-body); color:var(--fc-body); line-height:1.65; margin:0 0 .8rem; max-width:70ch; }
.page-home .fc-pillar__list{ list-style:none; padding:0; margin:0; display:grid; gap:.5rem; }
.page-home .fc-pillar__list li{ position:relative; padding-left:1.5rem; font-size:var(--fs-body); color:var(--fc-body); line-height:1.55; }
.page-home .fc-pillar__list li::before{ content:""; position:absolute; left:0; top:.55em; width:9px; height:9px; background:var(--fc-orange); }

/* ---- Comparison band (No Comparison) — dark, single image ---- */
.page-home .fc-compare{ background:var(--fc-ink); color:#fff; text-align:center; }
.page-home .fc-compare__inner{ max-width:62ch; margin-inline:auto; }
.page-home .fc-compare .fc-eyebrow{ color:var(--fc-orange); }
.page-home .fc-compare .fc-h2{ color:#fff; }
.page-home .fc-compare__lead{ font-size:var(--fs-body); color:#cfcfcf; line-height:1.65; margin:0 auto 1.6rem; max-width:54ch; }
.page-home .fc-compare__fig{ margin:1.4rem auto 0; max-width:920px; }
.page-home .fc-compare__fig img{ width:100%; height:auto; display:block; }

/* ---- Booking guide (5 numbered steps) — reuses pillar/step grid ---- */
.page-home .fc-steps{ background:var(--fc-paper); }
.page-home .fc-steps__grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:var(--gutter); }
.page-home .fc-step{ background:#fff; border:1px solid var(--fc-line); padding:1.5rem 1.3rem; display:flex; flex-direction:column; gap:.5rem; }
.page-home .fc-step__num{
  width:42px; height:42px; display:flex; align-items:center; justify-content:center;
  background:var(--fc-cream); color:var(--fc-orange); font-weight:800; font-size:1.15rem;
  border-radius:12px; overflow:hidden;}
.page-home .fc-step__title{ font-size:1.05rem; color:var(--fc-ink); margin:0; line-height:1.25; }
.page-home .fc-step__body{ font-size:.92rem; color:var(--fc-body); line-height:1.55; margin:0; }

/* ---- FAQ accordion (grouped, 2-col, +/- sign reused from fc-acc) ---- */
.page-home .fc-faqs{ background:#fff; }
.page-home .fc-faqgroup{ margin-bottom:clamp(2rem,1.4rem + 2vw,3.2rem); }
.page-home .fc-faqgroup__label{
  font-size:var(--fs-h3); color:var(--fc-ink); font-weight:700; margin:0 0 1.2rem;
  padding-bottom:.6rem; border-bottom:2px solid var(--fc-orange); display:inline-block;
}
.page-home .fc-faqgrid{ display:grid; grid-template-columns:1fr 1fr; gap:0 clamp(1.5rem,1rem + 2vw,3rem); }
.page-home .fc-faq{ border-bottom:1px solid var(--fc-line); }
.page-home .fc-faq summary{
  list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between;
  gap:1rem; padding:1.1rem .25rem; font-size:1.02rem; font-weight:600; color:var(--fc-ink); line-height:1.35;
}
.page-home .fc-faq summary::-webkit-details-marker{ display:none; }
.page-home .fc-faq summary .fc-acc__sign{ position:relative; width:18px; height:18px; flex:none; }
.page-home .fc-faq summary .fc-acc__sign::before,
.page-home .fc-faq summary .fc-acc__sign::after{ content:""; position:absolute; background:var(--fc-orange); transition:transform .25s ease, opacity .25s ease; }
.page-home .fc-faq summary .fc-acc__sign::before{ top:8px; left:0; width:18px; height:2px; }
.page-home .fc-faq summary .fc-acc__sign::after{ top:0; left:8px; width:2px; height:18px; }
.page-home .fc-faq[open] summary .fc-acc__sign::after{ transform:scaleY(0); opacity:0; }
.page-home .fc-faq summary:hover{ color:var(--fc-orange-dark); }
.page-home .fc-faq__a{ font-size:var(--fs-body); color:var(--fc-body); line-height:1.65; padding:0 1.5rem 1.2rem .25rem; margin:0; }
.page-home .fc-faq__a a{ color:var(--fc-orange-dark); font-weight:600; }
.page-home .fc-faq__a ul{ margin:.5rem 0 0; padding-left:1.2rem; }

/* ---- Locations cards (full-width branch rows w/ details) ---- */
.page-home .fc-locs{ background:var(--fc-paper); }
.page-home .fc-locs__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gutter); align-items:start; }
.page-home .fc-loc{
  background:#fff; border:1px solid var(--fc-line); padding:clamp(1.2rem,.9rem + 1.4vw,1.8rem);
  display:grid; grid-template-columns:1fr; gap:.7rem;
}
.page-home .fc-loc__ctas .fc-btn{ width:100%; text-align:center; }
/* Locations pagehead runs tight on live (heading sits just above the map);
   trim the standalone-locations pagehead padding to match. Page-scoped. */
.page-locations .fc-pagehead[data-rv]{ padding-block:clamp(2.4rem,1.6rem + 2.4vw,3.6rem); }
.page-locations .fc-locs[data-rv]{ padding-block:clamp(2rem,1.4rem + 2vw,3.2rem); }
.page-home .fc-loc__region{ font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--fc-orange-dark); }
.page-home .fc-loc__name{ font-size:var(--fs-h3); color:var(--fc-ink); margin:.2rem 0 .4rem; line-height:1.25; }
.page-home .fc-loc__addr{ font-style:normal; font-size:var(--fs-body); color:var(--fc-body); line-height:1.6; }
.page-home .fc-loc__meta{ display:flex; flex-wrap:wrap; gap:.4rem 1.4rem; font-size:.92rem; color:var(--fc-body); margin-top:.3rem; }
.page-home .fc-loc__meta strong{ color:var(--fc-ink); }
.page-home .fc-loc__ctas{ display:flex; flex-wrap:wrap; gap:.7rem; margin-top:.4rem; }
.page-home .fc-loc__ctas .fc-btn{ padding:.7rem 1.2rem; font-size:.92rem; }

/* ---- Branch detail map embed ---- */
.page-home .fc-map{ width:100%; aspect-ratio:16/9; border:0; display:block; }
.page-home .fc-map-wrap{ overflow:hidden; border-radius:24px; }

/* ---- Story detail: results + customer panel ---- */
.page-home .fc-storyhero{ background:var(--fc-paper); }
.page-home .fc-storyhero__grid{ display:grid; grid-template-columns:1.4fr 1fr; gap:clamp(1.5rem,1rem + 3vw,3rem); align-items:start; }
.page-home .fc-storyhero__media{ position:relative; }
.page-home .fc-storyhero__media img{ width:100%; height:clamp(300px,40vw,460px); object-fit:cover; align-self:flex-start; display:block;
  border-radius:24px; overflow:hidden;}
/* Results panel: anchored to the BOTTOM-LEFT corner so it sits over the
   floor / negative space at the subject's feet — never over the head/torso.
   Compact so the before/after subject stays fully visible (was top:1rem;
   right:1rem covering the standing figure). Fixed 2026-06-01 across all
   4 story pages. */
.page-home .fc-results{
  position:absolute; left:.9rem; bottom:.9rem; right:auto; top:auto;
  background:rgba(14,14,14,.82); color:#fff;
  padding:.7rem .9rem; min-width:0; width:max-content; max-width:62%;
  backdrop-filter:blur(4px);
  border-radius:24px; overflow:hidden;}
.page-home .fc-results__head{ margin-bottom:.45rem; }
.page-home .fc-results__row{ padding:.3rem 0; gap:.9rem; }
.page-home .fc-results__head{ font-size:.8rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--fc-orange); margin:0 0 .7rem; }
.page-home .fc-results__row{ display:flex; justify-content:space-between; align-items:baseline; gap:.6rem; padding:.4rem 0; border-top:1px solid rgba(255,255,255,.14); }
.page-home .fc-results__row:first-of-type{ border-top:0; }
.page-home .fc-results__label{ font-size:.78rem; color:#cfcfcf; }
.page-home .fc-results__vals{ font-weight:700; font-size:.92rem; }
.page-home .fc-results__vals .to{ color:var(--fc-orange); }
.page-home .fc-results__vals .ar{ color:#9a9a9a; margin:0 .3rem; }

.page-home .fc-customer{ background:var(--fc-cream); padding:clamp(1.4rem,1rem + 2vw,2rem); }
.page-home .fc-customer__top{ display:flex; align-items:center; gap:1rem; margin-bottom:1.2rem; }
.page-home .fc-customer__avatar{ width:64px; height:64px; flex:none; overflow:hidden;
  border-radius:12px; background:var(--fc-orange); }
.page-home .fc-customer__avatar img{ width:100%; height:100%; object-fit:cover; object-position:50% 15%; }
.page-home .fc-customer__head{ font-size:.8rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--fc-orange-dark); }
.page-home .fc-customer__name{ font-size:var(--fs-h3); color:var(--fc-ink); margin:0; line-height:1.1; }
.page-home .fc-customer__list{ list-style:none; padding:0; margin:0 0 1.4rem; display:grid; gap:0; }
.page-home .fc-customer__list li{ display:flex; justify-content:space-between; gap:1rem; padding:.55rem 0; border-bottom:1px solid rgba(14,14,14,.08); font-size:.95rem; }
.page-home .fc-customer__list li:last-child{ border-bottom:0; }
.page-home .fc-customer__list .k{ color:var(--fc-body); }
.page-home .fc-customer__list .v{ color:var(--fc-ink); font-weight:700; text-align:right; }

.page-home .fc-storybody{ background:#fff; }
.page-home .fc-storybody__inner{ max-width:72ch; margin-inline:auto; }
.page-home .fc-storybody__date{ font-size:.85rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--fc-orange-dark); }
.page-home .fc-storybody h1{ font-size:clamp(1.6rem,1.3rem + 1.6vw,2.4rem); color:var(--fc-ink); margin:.3em 0 .8em; line-height:1.2; font-weight:800; }
.page-home .fc-storybody p{ font-size:var(--fs-body); color:var(--fc-body); line-height:1.8; margin:0 0 1.2rem; }
.page-home .fc-storybody p strong{ color:var(--fc-ink); }
.page-home .fc-share{ margin-top:1.6rem; display:flex; align-items:center; gap:1rem; }
.page-home .fc-share__label{ font-size:.85rem; font-weight:700; color:var(--fc-body); }
.page-home .fc-share a{ display:inline-flex; width:36px; height:36px; align-items:center; justify-content:center; background:var(--fc-orange); color:#fff;
  border-radius:12px; overflow:hidden;}
.page-home .fc-share a:hover{ background:var(--fc-orange-dark); }

/* ---- Careers benefits grid (variable count, reuses pcard) ---- */
.page-home .fc-benefits__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gutter); }
.page-home .fc-testicards{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gutter); margin-top:1.5rem; }
.page-home .fc-testicard{ background:var(--fc-paper); border:1px solid var(--fc-line); padding:1.6rem 1.5rem; display:flex; flex-direction:column; gap:1rem; }
.page-home .fc-testicard__q{ font-size:var(--fs-body); color:var(--fc-body); line-height:1.6; font-style:italic; margin:0; }
.page-home .fc-testicard__who{ font-weight:700; color:var(--fc-ink); font-size:.95rem; }
.page-home .fc-testicard__who span{ display:block; font-weight:500; color:var(--fc-orange-dark); font-size:.85rem; }

/* careers stages: reuse fc-steps grid but 4-up */
.page-home .fc-stages__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gutter); }

/* orange CTA band */
.page-home .fc-ctaband{ background:var(--fc-orange); color:#fff; }
.page-home .fc-ctaband__inner{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; }
.page-home .fc-ctaband__txt{ font-size:clamp(1.15rem,1rem + .8vw,1.6rem); font-weight:800; color:#fff; margin:0; max-width:46ch; line-height:1.3; }
.page-home .fc-ctaband .fc-btn--ghost{ background:#fff; color:var(--fc-ink); border-color:#fff; }
.page-home .fc-ctaband .fc-btn--ghost:hover{ background:var(--fc-ink); color:#fff; border-color:var(--fc-ink); transform:translateY(-2px); }

/* dark CTA band (reuses promiseband tone) */
.page-home .fc-finalcta{ background:var(--fc-ink); color:#fff; text-align:center; }
.page-home .fc-finalcta__inner{ max-width:60ch; margin-inline:auto; }
.page-home .fc-finalcta .fc-h2{ color:#fff; }
.page-home .fc-finalcta__lead{ font-size:var(--fs-body); color:#cfcfcf; line-height:1.65; margin:0 auto 1.6rem; }

/* ---- Coach team grid ---- */
.page-home .fc-team__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gutter); }
.page-home .fc-coach{ background:#fff; border:1px solid var(--fc-line); overflow:hidden; }
.page-home .fc-coach__img{ width:100%; aspect-ratio:3/4; object-fit:cover; object-position:top center; display:block; align-self:flex-start; }
.page-home .fc-coach__cap{ padding:1rem 1.1rem 1.2rem; }
.page-home .fc-coach__name{ font-size:1.05rem; color:var(--fc-ink); margin:0; line-height:1.2; }
.page-home .fc-coach__role{ font-size:.85rem; color:var(--fc-orange-dark); font-weight:600; }

/* ---- Open positions list ---- */
.page-home .fc-jobs__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:var(--gutter); }
.page-home .fc-job{ background:#fff; border:1px solid var(--fc-line); border-left:3px solid var(--fc-orange); padding:1.5rem 1.6rem; display:flex; flex-direction:column; gap:.6rem; }
.page-home .fc-job__tags{ display:flex; flex-wrap:wrap; gap:.5rem; }
.page-home .fc-job__tag{ font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--fc-orange-dark); background:var(--fc-cream); padding:.25rem .6rem; }
.page-home .fc-job__title{ font-size:var(--fs-h3); color:var(--fc-ink); margin:0; line-height:1.25; }
.page-home .fc-job__body{ font-size:var(--fs-body); color:var(--fc-body); line-height:1.6; margin:0; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1199px){
  .page-home .fc-timeline__grid{ grid-template-columns:repeat(2,1fr); }
  .page-home .fc-steps__grid{ grid-template-columns:repeat(3,1fr); }
  .page-home .fc-stages__grid{ grid-template-columns:repeat(2,1fr); }
  .page-home .fc-benefits__grid{ grid-template-columns:repeat(2,1fr); }
  .page-home .fc-testicards{ grid-template-columns:1fr; }
  .page-home .fc-team__grid{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:991px){
  .page-home .fc-split__grid{ grid-template-columns:1fr; }
  .page-home .fc-storyhero__grid{ grid-template-columns:1fr; }
  .page-home .fc-faqgrid{ grid-template-columns:1fr; }
  .page-home .fc-jobs__grid{ grid-template-columns:1fr; }
}
@media (max-width:767px){
  .page-home .fc-locs__grid{ grid-template-columns:1fr; }
  .page-home .fc-timeline__grid{ grid-template-columns:1fr; }
  .page-home .fc-steps__grid{ grid-template-columns:1fr; }
  .page-home .fc-stages__grid{ grid-template-columns:1fr; }
  .page-home .fc-benefits__grid{ grid-template-columns:1fr; }
  .page-home .fc-team__grid{ grid-template-columns:repeat(2,1fr); }
  .page-home .fc-pillar{ grid-template-columns:1fr; gap:.5rem; }
  .page-home .fc-results{ position:static; margin-top:.8rem; min-width:0; }
  .page-home .fc-ctaband__inner{ flex-direction:column; align-items:flex-start; }
}

/* =====================================================================
   Heading-level normalization (2026-06-01).
   Several card labels were promoted from <span>/<h3> to <h2> to mirror
   live fitcomfitness.com's heading structure 1:1. These rules keep them
   visually identical to the locked design system (no default h2 size/margin).
   ===================================================================== */
.page-home .fc-story__loc, .page-home .fc-story__title, .page-home .fc-story__coach,
.page-home .fc-story__tag, .page-home .fc-loc__region, .page-home .fc-loc__name,
.page-home .fc-job__tag, .page-home .fc-job__title, .page-home .fc-step__num,
.page-home .fc-step__title, .page-home .fc-pillar__num, .page-home .fc-pillar__title,
.page-home .fc-tl__year, .page-home .fc-testicard__who, .page-home .fc-quotecard__q{
  margin:0; font-weight:inherit; letter-spacing:inherit; line-height:1.3;
}
.page-home h2.fc-loc__name{ font-size:1.15rem; font-weight:800; color:var(--fc-ink); line-height:1.3; margin:.1rem 0 .4rem; }
.page-home h2.fc-loc__region{ font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--fc-orange-dark); }
.page-home h2.fc-job__title{ font-size:1.2rem; font-weight:800; color:var(--fc-ink); margin:0 0 .3rem; }
.page-home h2.fc-step__title{ font-size:var(--fs-h3); font-weight:700; color:var(--fc-ink); }
.page-home h2.fc-step__num{ font-size:2rem; font-weight:800; color:var(--fc-orange); line-height:1; }
.page-home h2.fc-pillar__title{ font-size:var(--fs-h3); font-weight:800; color:var(--fc-ink); }
.page-home h2.fc-pillar__num{ font-weight:800; color:var(--fc-orange); }
.page-home h2.fc-tl__year{ font-size:1.5rem; font-weight:800; color:var(--fc-orange); }
.page-home h2.fc-testicard__who{ font-size:.95rem; font-weight:700; color:var(--fc-ink); margin-top:.8rem; }

/* Our Gyms studio cards reuse .fc-loc; keep image area tidy */
.page-home .fc-ourgyms .fc-map-wrap{ aspect-ratio:4/3; overflow:hidden; border-radius:24px; }
.page-home .fc-ourgyms .fc-map{ width:100%; height:100%; object-fit:cover; }

/* Legal pages (privacy / terms) — prose headings in the storybody container */
.page-home .fc-legal.fc-storybody{ padding-block:clamp(2rem,1.4rem + 2vw,3.5rem); }
.page-home .fc-storybody h2{ font-size:1.3rem; color:var(--fc-ink); font-weight:800; line-height:1.3; margin:1.6em 0 .5em; }
.page-home .fc-storybody h2:first-child{ margin-top:0; }
.page-home .fc-storybody h3{ font-size:1.1rem; color:var(--fc-ink); font-weight:700; margin:1.2em 0 .4em; }

/* Legal pages run dense + full-width (matches live's compact policy text,
   which uses the whole container, not a 72ch measure → far fewer line wraps).
   Scoped to .fc-legal so story-detail editorial prose is untouched. */
.page-home .fc-legal.fc-storybody{ padding-block:clamp(1.4rem,1rem + 1.4vw,2.4rem); }
.page-home .fc-legal .fc-storybody__inner{ max-width:none; }
.page-home .fc-legal h2{ font-size:1.25rem; margin:1.1em 0 .35em; }
.page-home .fc-legal h3{ margin:.8em 0 .3em; }
.page-home .fc-legal p{ font-size:1rem; line-height:1.55; margin:0 0 .8rem; }
.page-home .fc-legal ul,.page-home .fc-legal ol{ margin:.3rem 0 .9rem; line-height:1.5; }
.page-home .fc-legal li{ margin:0 0 .3rem; }

/* Eyebrows promoted to <h2 class="fc-eyebrow"> to mirror live's heading
   structure 1:1 — class fully controls styling; reset default h2 box. */
.page-home h2.fc-eyebrow{ font-size:var(--fs-eyebrow); font-weight:700; line-height:1.2; }

/* Our Gyms studio card labels promoted to h2 to mirror live heading structure */
.page-home h2.fc-loc__addr{ font-size:.9rem; font-weight:500; color:var(--fc-body); line-height:1.5; margin:.2rem 0 0; }

/* =====================================================================
   Careers page proportion (2026-06-01).
   Live's "More Than a Job" pillars are large image+text rows (~600-800px
   each); the staging mirror carries the text only (no images — per "do not
   add content"). To stop the page reading visibly compressed vs live,
   give the existing pillar rows + hero + sections more vertical room.
   Scoped to .page-careers so the locked/other fc-pillar uses are untouched.
   ===================================================================== */
/* --- Careers pillars: alternating image + text rows (mirror live) --- */
.page-careers .fc-pillar{
  display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  align-items:center; gap:clamp(1.8rem,1rem + 3vw,4rem);
  padding:clamp(3rem,2rem + 3vw,5rem) 0; border-top:1px solid var(--fc-line);
}
.page-careers .fc-pillar--alt .fc-pillar__media{ order:2; }
.page-careers .fc-pillar--alt .fc-pillar__text{ order:1; }
.page-careers .fc-pillar__media{ align-self:flex-start; }
.page-careers .fc-pillar__media picture{ display:block; }
.page-careers .fc-pillar__media img{
  display:block; width:100%; height:auto; aspect-ratio:3 / 2;
  object-fit:cover; object-position:50% 15%; border-radius:24px;
}
.page-careers .fc-pillar__text{ align-self:center; }
.page-careers .fc-pillar__num{ font-size:clamp(2.8rem,2rem + 2.6vw,4.4rem); display:block; margin-bottom:.2em; }
.page-careers .fc-pillar__title{ font-size:clamp(1.4rem,1.1rem + 1vw,1.9rem); margin-bottom:.8em; }
.page-careers .fc-pillar__body{ font-size:1.1rem; line-height:1.95; max-width:54ch; margin-bottom:0; }
.page-careers .fc-pillars[data-rv]{ padding-block:clamp(4rem,2.6rem + 5vw,7rem); }
.page-careers .fc-pagehead[data-rv]{ padding-block:clamp(6rem,4rem + 6vw,10rem); }
.page-careers .fc-pagehead__inner{ max-width:72ch; }
.page-careers .fc-pagehead h1{ margin-block:.35em .55em; }
.page-careers .fc-split[data-rv]{ padding-block:clamp(4rem,2.6rem + 6vw,8rem); }
.page-careers .fc-split__media img{ height:clamp(420px,46vw,620px); }
.page-careers .fc-stories[data-rv]{ padding-block:clamp(4rem,2.6rem + 6vw,8rem); }
.page-careers .fc-finalcta[data-rv]{ padding-block:clamp(4rem,2.6rem + 6vw,8rem); }

/* Careers pillars stack (image on top) on tablet/mobile */
@media (max-width:767px){
  .page-careers .fc-pillar{ grid-template-columns:1fr; gap:clamp(1.2rem,.8rem + 2vw,1.8rem); padding:clamp(2.2rem,1.6rem + 3vw,3rem) 0; }
  .page-careers .fc-pillar--alt .fc-pillar__media{ order:1; }
  .page-careers .fc-pillar--alt .fc-pillar__text{ order:2; }
}
