/* =========================================================
   PRODIGY JIU-JITSU — Shared Design System
   Palette: Midnight Navy #17202C · Prodigy Red #EF152E · White
   Type: Anton (display) · Oswald (headings/labels) · Sora (body)
   ========================================================= */

:root{
  --navy:#17202C;
  --navy-900:#0f1622;
  --navy-800:#1b2536;
  --navy-700:#222e42;
  --red:#EF152E;
  --red-dark:#c70f23;
  --white:#ffffff;
  --ink:#0c1118;
  --muted:#9aa4b4;
  --muted-2:#c3cad6;
  --line:rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.18);

  --font-display:'Anton',sans-serif;
  --font-head:'Oswald',sans-serif;
  --font-body:'Sora',system-ui,sans-serif;

  --maxw:1240px;
  --pad:clamp(20px,5vw,64px);
  --radius:12px;
  --radius-btn:6px;
  --shadow:0 30px 60px -28px rgba(0,0,0,.62);
  --shadow-soft:0 48px 92px -46px rgba(0,0,0,.82);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip;scroll-padding-top:88px}
iframe,svg,video{max-width:100%}
body{
  font-family:var(--font-body);
  background:var(--navy);
  color:var(--white);
  line-height:1.65;
  letter-spacing:-.006em;
  overflow-x:hidden;
  overflow-wrap:break-word;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01" 1,"liga" 1,"calt" 1;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
::selection{background:var(--red);color:#fff}

/* ---------- Type ---------- */
h1,h2,h3,h4{line-height:1.02;text-transform:uppercase;font-weight:400;text-wrap:balance}
.eyebrow{
  font-family:var(--font-head);
  text-transform:uppercase;
  letter-spacing:.26em;
  font-size:.74rem;
  font-weight:600;
  color:var(--red);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);display:inline-block}
.eyebrow.center{justify-content:center}
.display{font-family:var(--font-display);letter-spacing:.005em}
.section-title{
  font-family:var(--font-display);
  font-size:clamp(2.1rem,5.2vw,4rem);
  letter-spacing:.012em;
  line-height:.95;
}
.lead{font-size:clamp(1.02rem,1.6vw,1.18rem);color:var(--muted-2);max-width:62ch;text-wrap:pretty}
p{text-wrap:pretty}
.text-red{color:var(--red)}
.text-muted{color:var(--muted)}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:clamp(64px,9vw,128px)}
.section--tight{padding-block:clamp(48px,6vw,80px)}
.bg-navy{background:var(--navy)}
.bg-navy-900{background:var(--navy-900)}
.bg-band{background:linear-gradient(180deg,var(--navy) 0%,var(--navy-900) 100%)}
.divider{height:1px;background:var(--line);border:0}
.center{text-align:center}
.mx-auto{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--font-head);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:600;
  font-size:.86rem;
  display:inline-flex;align-items:center;gap:.6em;
  padding:1.05em 1.7em;
  border-radius:var(--radius-btn);
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
  will-change:transform;
}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(5px)}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 18px 34px -16px rgba(239,20,44,.72)}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-3px);box-shadow:0 22px 40px -16px rgba(239,20,44,.6)}
.btn-ghost{background:transparent;color:#fff;border-color:var(--line-strong)}
.btn-ghost:hover{background:#fff;color:var(--navy);border-color:#fff;transform:translateY(-3px)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--navy-800);transform:translateY(-3px)}
.btn-sm{padding:.8em 1.2em;font-size:.78rem}

/* ---------- Header / Nav ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  transition:background .4s var(--ease),border-color .4s var(--ease),backdrop-filter .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;z-index:2;pointer-events:none;
  background:linear-gradient(90deg,transparent,var(--red) 30%,#a30d1c 50%,var(--red) 70%,transparent);
  opacity:0;transition:opacity .4s var(--ease);
}
.site-header.scrolled::before{opacity:.9}
.site-header.scrolled{
  background:rgba(15,22,34,.86);
  backdrop-filter:blur(14px);
  border-bottom-color:var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:78px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-head);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:1.05rem}
.brand img{height:46px;width:auto}
.brand small{display:block;font-size:.55rem;letter-spacing:.42em;color:var(--muted);font-weight:500}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{
  font-family:var(--font-head);text-transform:uppercase;letter-spacing:.13em;
  font-size:.82rem;font-weight:500;color:var(--muted-2);position:relative;padding-block:6px;
  transition:color .25s var(--ease);
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--red);transition:width .3s var(--ease)}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:#fff}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none;width:46px;height:46px;border:1px solid var(--line-strong);border-radius:10px;background:rgba(255,255,255,.04);cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.nav-toggle span{width:20px;height:2px;background:#fff;transition:transform .3s var(--ease),opacity .3s var(--ease)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:99;overflow:hidden;
  background:
    radial-gradient(55% 42% at 90% 4%,rgba(239,20,44,.2),transparent 60%),
    radial-gradient(52% 46% at 0% 102%,rgba(45,66,120,.28),transparent 60%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 1px,transparent 1px 66px),
    repeating-linear-gradient(180deg,rgba(255,255,255,.025) 0 1px,transparent 1px 66px),
    linear-gradient(160deg,#0b1119,#0e1622 58%,var(--navy));
  display:flex;flex-direction:column;justify-content:center;gap:2px;
  padding:100px var(--pad) 40px;
  transform:translateY(-100%);transition:transform .5s var(--ease);
  visibility:hidden;
}
.mobile-menu.open{transform:translateY(0);visibility:visible}
.mobile-menu::after{content:"PRODIGY";position:absolute;left:-4px;bottom:8px;z-index:0;font-family:var(--font-display);font-size:clamp(3.2rem,17vw,5.5rem);line-height:.8;color:rgba(255,255,255,.035);letter-spacing:.03em;pointer-events:none}
.mobile-menu::before{content:"";position:absolute;right:-70px;top:104px;z-index:0;width:230px;height:230px;border-radius:50%;border:1px dashed rgba(239,20,44,.22);box-shadow:0 0 70px -10px rgba(239,20,44,.3),inset 0 0 50px -20px rgba(239,20,44,.4);pointer-events:none;animation:spin 55s linear infinite}
.mobile-menu > a:not(.btn)::after{content:"→";margin-left:auto;font-family:var(--font-head);color:var(--red);opacity:0;transform:translateX(-8px);transition:opacity .3s var(--ease),transform .3s var(--ease)}
.mobile-menu > a:not(.btn):hover::after,.mobile-menu > a:not(.btn):active::after{opacity:1;transform:none}
.mobile-menu > a:not(.btn){
  position:relative;z-index:1;font-family:var(--font-display);font-size:1.95rem;text-transform:uppercase;
  padding:.5em 0 .5em 16px;border-bottom:1px solid var(--line);color:#fff;
  display:flex;align-items:center;justify-content:flex-start;gap:18px;
  opacity:0;transform:translateX(-14px);border-radius:12px;
  transition:color .3s var(--ease),padding-left .3s var(--ease),background .3s var(--ease),opacity .45s var(--ease),transform .45s var(--ease);
}
.mobile-menu > a:not(.btn)::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--red);border-radius:2px;transition:height .3s var(--ease)}
.mobile-menu > a:not(.btn) span{order:-1;flex:none;width:38px;height:38px;border-radius:50%;display:grid;place-items:center;border:1px solid rgba(239,20,44,.4);background:rgba(239,20,44,.08);font-family:var(--font-head);font-size:.72rem;font-weight:600;color:var(--red);letter-spacing:.04em;transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease)}
.mobile-menu > a:not(.btn):hover,.mobile-menu > a:not(.btn):active{color:#fff;padding-left:22px;background:linear-gradient(90deg,rgba(239,20,44,.15),transparent 72%)}
.mobile-menu > a:not(.btn):hover::before,.mobile-menu > a:not(.btn):active::before{height:64%}
.mobile-menu > a:not(.btn):hover span,.mobile-menu > a:not(.btn):active span{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 0 16px -2px rgba(239,20,44,.7)}
.mobile-menu.open > a:not(.btn){opacity:1;transform:none}
.mobile-menu.open > a:not(.btn):nth-child(1){transition-delay:.06s}
.mobile-menu.open > a:not(.btn):nth-child(2){transition-delay:.12s}
.mobile-menu.open > a:not(.btn):nth-child(3){transition-delay:.18s}
.mobile-menu.open > a:not(.btn):nth-child(4){transition-delay:.24s}
.mobile-menu.open > a:not(.btn):nth-child(5){transition-delay:.30s}
.mobile-menu .btn{position:relative;z-index:1;margin-top:30px;width:100%;justify-content:center}
@media(prefers-reduced-motion:reduce){.mobile-menu > a:not(.btn){opacity:1;transform:none;transition:color .3s var(--ease),padding-left .3s var(--ease)}.mobile-menu::before{animation:none}}

/* ---------- Hero (generic) ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden}
.hero-page{min-height:64vh}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 28%}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(15,22,34,.55) 0%,rgba(15,22,34,.2) 35%,rgba(15,22,34,.78) 80%,var(--navy) 100%),
    linear-gradient(90deg,rgba(15,22,34,.85) 0%,rgba(15,22,34,.35) 55%,rgba(15,22,34,.1) 100%);
}
.hero-inner{position:relative;z-index:2;width:100%;padding-block:clamp(48px,10vh,120px)}
.hero h1{
  font-family:var(--font-display);
  font-size:clamp(2.9rem,8.5vw,6.6rem);
  letter-spacing:.005em;max-width:16ch;
  text-shadow:0 4px 30px rgba(0,0,0,.4);
}
.hero h1 em{font-style:normal;color:var(--red)}
.hero .lead{margin-top:22px;color:#e7ebf2}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.trust{display:flex;flex-wrap:wrap;gap:26px;margin-top:40px;padding-top:26px;border-top:1px solid var(--line)}
.trust .item{display:flex;flex-direction:column;gap:2px}
.trust .num{font-family:var(--font-display);font-size:1.9rem;color:#fff;line-height:1}
.trust .lbl{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;color:var(--muted)}

/* ---------- Marquee strip ---------- */
.strip{background:var(--red);overflow:hidden;border-block:1px solid rgba(0,0,0,.15)}
.strip-track{display:flex;gap:0;white-space:nowrap;animation:marquee 30s linear infinite}
.strip-track span{
  font-family:var(--font-head);text-transform:uppercase;letter-spacing:.28em;font-weight:600;
  font-size:.82rem;color:#fff;padding:14px 0;
}
.strip-track .dot{padding-inline:26px;opacity:.6}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- Split / intro ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,76px);align-items:center}
.split.rev{grid-template-columns:.95fr 1.05fr}
.split-media{position:relative}
.split-media img{width:100%;height:100%;max-height:560px;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow)}
.split-media .badge{
  position:absolute;left:-18px;bottom:26px;background:var(--red);color:#fff;
  font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-weight:600;
  padding:14px 20px;border-radius:12px;font-size:.84rem;box-shadow:var(--shadow);max-width:220px;line-height:1.3;
}
.frame{position:relative;border-radius:var(--radius);overflow:hidden}
.frame::after{content:"";position:absolute;inset:0;border:1px solid var(--line-strong);border-radius:var(--radius);pointer-events:none}
.prose p+p{margin-top:1.05em;color:var(--muted-2)}
.prose .section-title+p{margin-top:1.2em}

/* ---------- Program cards ---------- */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.programs{display:grid;grid-template-columns:repeat(6,1fr);gap:22px}
.prog{
  position:relative;border-radius:var(--radius);overflow:hidden;min-height:420px;
  display:flex;flex-direction:column;justify-content:flex-end;
  background:var(--navy-800);isolation:isolate;
  border:1px solid var(--line);
}
.prog.span-3{grid-column:span 3}
.prog.span-2{grid-column:span 2}
.prog-img{position:absolute;inset:0;z-index:-2}
.prog-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.prog::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(15,22,34,.05) 0%,rgba(15,22,34,.55) 52%,rgba(12,17,24,.96) 100%)}
.prog:hover .prog-img img{transform:scale(1.07)}
.prog-body{padding:28px;position:relative}
.prog .tag{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.18em;font-size:.66rem;color:var(--red);font-weight:600}
.prog h3{font-family:var(--font-display);font-size:1.7rem;margin-top:8px}
.prog p{color:var(--muted-2);font-size:.92rem;margin-top:10px;max-width:42ch}
.prog .who{display:inline-block;margin-top:14px;font-size:.78rem;color:var(--muted);font-family:var(--font-head);letter-spacing:.06em;text-transform:uppercase}
.prog .go{
  margin-top:18px;display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-head);text-transform:uppercase;letter-spacing:.13em;font-size:.78rem;font-weight:600;color:#fff;
}
.prog .go .arr{transition:transform .35s var(--ease);color:var(--red)}
.prog:hover .go .arr{transform:translateX(6px)}

/* ---------- Feature / why ---------- */
.feats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.feat{background:var(--navy-900);padding:34px 30px;transition:background .35s var(--ease)}
.feat:hover{background:var(--navy-800)}
.feat .ic{width:52px;height:52px;border-radius:12px;background:rgba(239,20,44,.12);color:var(--red);display:grid;place-items:center;margin-bottom:18px}
.feat .ic svg{width:26px;height:26px}
.feat h3{font-family:var(--font-head);font-weight:600;font-size:1.18rem;letter-spacing:.02em;text-transform:none}
.feat p{color:var(--muted);font-size:.93rem;margin-top:10px}

/* ---------- Stats band ---------- */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;text-align:center}
.statband .num{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,3.6rem);color:#fff;line-height:1}
.statband .num span{color:var(--red)}
.statband .lbl{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--muted);margin-top:6px}

/* ---------- Coach cards ---------- */
.coach-lead{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,5vw,64px);align-items:center}
.coach-lead .frame img{width:100%;max-height:620px;object-fit:cover;object-position:center 25%}
.coach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.coach{background:var(--navy-900);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .4s var(--ease),border-color .4s var(--ease)}
.coach:hover{transform:translateY(-6px);border-color:var(--line-strong)}
.coach-photo{aspect-ratio:4/5;overflow:hidden}
.coach-photo img{width:100%;height:100%;object-fit:cover;object-position:center 22%;transition:transform .8s var(--ease)}
.coach:hover .coach-photo img{transform:scale(1.05)}
.coach-info{padding:22px}
.coach-info h3{font-family:var(--font-head);font-weight:600;font-size:1.2rem;text-transform:none}
.coach-info .role{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.68rem;color:var(--red);font-weight:600;margin-top:4px}
.coach-info p{color:var(--muted);font-size:.9rem;margin-top:12px}

/* ---------- Schedule ---------- */
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:42px}
.filter{
  font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;font-weight:600;
  padding:.7em 1.2em;border-radius:999px;border:1px solid var(--line-strong);background:transparent;color:var(--muted-2);cursor:pointer;
  transition:all .3s var(--ease);
}
.filter:hover{color:#fff;border-color:#fff}
.filter.active{background:var(--red);border-color:var(--red);color:#fff}
/* ---------- Reviews ---------- */
.rev-head{display:flex;flex-wrap:wrap;align-items:center;gap:18px;justify-content:center;margin-bottom:14px}
.rev-score{font-family:var(--font-display);font-size:3rem;line-height:1;color:#fff}
.stars{color:#ffc043;letter-spacing:2px;font-size:1.1rem}
.review-stats{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;
  max-width:400px;margin:0 auto;padding:clamp(30px,4vw,44px) clamp(24px,4vw,40px);border-radius:20px;
  background:rgba(255,255,255,.045);border:1px solid var(--line-strong);box-shadow:0 30px 60px -30px rgba(0,0,0,.7)}
.rv-score{font-family:var(--font-display);font-size:clamp(3.6rem,9vw,5rem);line-height:1;color:#fff;letter-spacing:.01em}
.rv-stars{font-size:1.8rem;letter-spacing:5px;line-height:1;color:#ffc043}
.rv-count{font-size:1.02rem;color:var(--muted-2)}
.rv-count strong{color:#fff;font-weight:600}

/* ===== TESTIMONIAL CARDS (shared: home + program pages) ===== */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(288px,1fr));gap:20px}
.tcard{display:flex;flex-direction:column;gap:15px;padding:28px 26px 24px;border-radius:16px;
  background:rgba(255,255,255,.045);border:1px solid var(--line-strong);box-shadow:0 24px 50px -30px rgba(0,0,0,.6)}
.tcard-stars{color:#ffc043;font-size:1rem;letter-spacing:3px;line-height:1}
.tcard-quote{margin:0;font-size:.98rem;line-height:1.62;color:#e2e7ef}
.tcard-by{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:6px}
.tcard-avatar{flex:0 0 auto;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  background:var(--red);color:#fff;font-family:var(--font-head);font-weight:700;font-size:1.05rem;line-height:1}
.tcard-meta{display:flex;flex-direction:column;gap:2px;min-width:0}
.tcard-name{font-family:var(--font-head);font-weight:600;font-size:.95rem;color:#fff;line-height:1.1}
.tcard-tag{font-size:.72rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.09em}

/* ---------- Location / map ---------- */
.loc{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.loc .info{background:var(--navy-900);padding:clamp(30px,4vw,52px)}
.loc .map{min-height:440px}
.loc .map iframe{width:100%;height:100%;min-height:440px;border:0;filter:grayscale(.25) contrast(1.05)}
.contact-rows{display:flex;flex-direction:column;gap:24px;margin-top:30px}
.crow{display:flex;gap:16px;align-items:flex-start}
.crow .ic{flex:0 0 44px;height:44px;border-radius:11px;background:rgba(239,20,44,.12);color:var(--red);display:grid;place-items:center}
.crow .ic svg{width:22px;height:22px}
.crow .k{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;color:var(--muted)}
.crow .v{font-size:1.05rem;color:#fff;margin-top:2px}
.crow a.v:hover{color:var(--red)}

/* ---------- Contact form ---------- */
.form{display:grid;gap:16px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.68rem;color:var(--muted)}
.field input,.field select,.field textarea{
  font-family:var(--font-body);font-size:.96rem;color:#fff;
  background:var(--navy-800);border:1px solid var(--line-strong);border-radius:10px;padding:.85em 1em;
  transition:border-color .25s var(--ease),box-shadow .25s var(--ease);
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--red);box-shadow:0 0 0 3px rgba(239,20,44,.18)}
.field textarea{min-height:130px;resize:vertical}
.form-note{font-size:.82rem;color:var(--muted)}
.form-success{display:none;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.4);color:#86efac;padding:14px 16px;border-radius:10px;font-size:.92rem}
.form-success.show{display:block}

/* ---------- CTA band ---------- */
.cta-band{position:relative;border-radius:var(--radius);overflow:hidden;isolation:isolate}
.cta-band .bgimg{position:absolute;inset:0;z-index:-2}
.cta-band .bgimg img{width:100%;height:100%;object-fit:cover}
.cta-band::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,rgba(15,22,34,.96),rgba(15,22,34,.7) 60%,rgba(199,15,35,.5))}
.cta-band .inner{padding:clamp(44px,7vw,96px);text-align:center;max-width:840px;margin-inline:auto}
.cta-band h2{font-family:var(--font-display);font-size:clamp(2.2rem,5.5vw,4.2rem)}
.cta-band p{color:#e7ebf2;margin-top:16px}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:32px}

/* ---------- Footer ---------- */
.footer{position:relative;overflow:hidden;border-top:1px solid var(--line);padding-top:64px;
  background:radial-gradient(42vw 32vw at 0% 0%,rgba(239,20,44,.12),transparent 60%),radial-gradient(46vw 34vw at 100% 100%,rgba(45,66,120,.18),transparent 62%),linear-gradient(180deg,#0c1320 0%,#070b12 100%)}
.footer::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,transparent,var(--red) 30%,#a30d1c 50%,var(--red) 70%,transparent);opacity:.85;z-index:2}
.footer::after{content:"PRODIGY";position:absolute;left:50%;bottom:-3rem;transform:translateX(-50%);font-family:var(--font-display);font-size:clamp(6rem,18vw,16rem);line-height:.8;letter-spacing:.02em;color:rgba(255,255,255,.025);white-space:nowrap;pointer-events:none;z-index:0;user-select:none}
.footer .container{position:relative;z-index:1}
.footer .socials a{transition:transform .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease)}
.footer .socials a:hover{box-shadow:0 12px 24px -10px rgba(239,20,44,.7)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
.footer .brand img{height:54px}
.footer-about{color:var(--muted);font-size:.92rem;margin-top:18px;max-width:34ch}
.footer h4{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:#fff;margin-bottom:18px;font-weight:600}
.footer-links{display:flex;flex-direction:column;gap:11px}
.footer-links a{color:var(--muted-2);font-size:.92rem;transition:color .25s var(--ease)}
.footer-links a:hover{color:var(--red)}
.footer-contact{display:flex;flex-direction:column;gap:14px;color:var(--muted-2);font-size:.92rem}
.footer-contact a:hover{color:var(--red)}
.socials{display:flex;gap:12px;margin-top:20px}
.socials a{width:44px;height:44px;border-radius:11px;border:1px solid var(--line-strong);display:grid;place-items:center;color:#fff;transition:all .3s var(--ease)}
.socials a:hover{background:var(--red);border-color:var(--red);transform:translateY(-3px)}
.socials svg{width:20px;height:20px}
.footer-bottom{margin-top:54px;border-top:1px solid var(--line);padding:24px 0;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;color:var(--muted);font-size:.8rem}
.footer-bottom a{color:var(--muted-2);text-decoration:none;transition:color .25s var(--ease)}
.footer-bottom a:hover{color:var(--red)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
.reveal.d5{transition-delay:.40s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .strip-track{animation:none}
  *{scroll-behavior:auto}
}

@keyframes driftR{0%{transform:translate3d(0,0,0) scale(1) rotate(0)}50%{transform:translate3d(-6vw,4vh,0) scale(1.14) rotate(-7deg)}100%{transform:translate3d(2vw,-3vh,0) scale(1.02) rotate(5deg)}}
@keyframes driftBL{0%{transform:translate3d(0,0,0) scale(1) rotate(0)}50%{transform:translate3d(6vw,-5vh,0) scale(1.13) rotate(-6deg)}100%{transform:translate3d(-3vw,3vh,0) scale(1.03) rotate(4deg)}}
@keyframes pulseA{0%,100%{opacity:.42}50%{opacity:.78}}
@keyframes pulseB{0%,100%{opacity:.34}50%{opacity:.66}}
@keyframes grainShift{0%{transform:translate(0,0)}100%{transform:translate(-12%,8%)}}
@media (prefers-reduced-motion:reduce){
  .hero-smoke .blob{animation:none;opacity:.55}
  .hero-smoke .grain{animation:none}
}

/* ---------- New image-led hero (xhero) ---------- */
.xhero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(120% 95% at 88% -10%, #20304d 0%, transparent 52%),
    linear-gradient(180deg,#131c2b 0%, var(--navy) 58%);
  padding:calc(78px + clamp(38px,7vh,86px)) 0 clamp(54px,8vh,96px);
}
.xhero-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.xhero-fx .glow{position:absolute;border-radius:50%;filter:blur(90px)}
.xhero-fx .glow-a{width:48vw;height:48vw;right:-12vw;top:-16vw;background:radial-gradient(circle,rgba(239,20,44,.32),transparent 66%);animation:floatGlow 16s ease-in-out infinite}
.xhero-fx .glow-b{width:42vw;height:42vw;left:-16vw;bottom:-20vw;background:radial-gradient(circle,rgba(120,18,30,.30),transparent 70%);animation:floatGlow 22s ease-in-out infinite reverse}
.xhero-grain{position:absolute;inset:-50%;width:200%;height:200%;opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='nx'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23nx)'/%3E%3C/svg%3E");
  animation:grainShift 6s steps(6) infinite}
@keyframes floatGlow{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(3vw,2vh) scale(1.08)}}

/* refined mesh: structural strokes, flowing light, constellation */
.x-mesh{position:absolute;inset:0;width:100%;height:100%}
.x-mesh .struct{stroke:rgba(255,255,255,.055);stroke-width:1;fill:none}
.x-mesh .flow{fill:none;stroke-linecap:round}
.x-mesh .f1{stroke:url(#gRed);stroke-width:2.4;stroke-dasharray:170 1700;stroke-dashoffset:0;animation:streakA 9s linear infinite}
.x-mesh .f2{stroke:url(#gRed);stroke-width:1.8;stroke-dasharray:130 1700;stroke-dashoffset:0;animation:streakB 13s linear infinite}
.x-mesh .net{fill:none;stroke:rgba(255,255,255,.085);stroke-width:1}
.x-mesh .nd{fill:#EF152E;opacity:.18;filter:url(#soft);animation:nodePulse 4.5s ease-in-out infinite}
.x-mesh .nd.w{fill:#fff}
.x-mesh .nodes circle:nth-child(2){animation-delay:.6s}
.x-mesh .nodes circle:nth-child(3){animation-delay:1.2s}
.x-mesh .nodes circle:nth-child(4){animation-delay:1.8s}
.x-mesh .nodes circle:nth-child(5){animation-delay:2.4s}
.x-mesh .nodes circle:nth-child(6){animation-delay:3s}
.x-mesh .nodes circle:nth-child(7){animation-delay:3.6s}
.x-mesh .nodes circle:nth-child(8){animation-delay:4.2s}
@keyframes streakA{from{stroke-dashoffset:0}to{stroke-dashoffset:-1870}}
@keyframes streakB{from{stroke-dashoffset:1830}to{stroke-dashoffset:0}}
@keyframes nodePulse{0%,100%{opacity:.14}50%{opacity:.85}}

/* floating rings */
.x-ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.07)}
.x-ring1{width:540px;height:540px;right:-170px;top:-190px;animation:floatA 18s ease-in-out infinite}
.x-ring2{width:300px;height:300px;right:-50px;top:-30px;border-color:rgba(239,20,44,.18);animation:floatB 22s ease-in-out infinite}
.x-ring3{width:190px;height:190px;left:-80px;bottom:-60px;border-style:dashed;border-color:rgba(255,255,255,.06);animation:spin 60s linear infinite}
@keyframes floatA{0%,100%{transform:translate(0,0)}50%{transform:translate(-22px,18px)}}
@keyframes floatB{0%,100%{transform:translate(0,0)}50%{transform:translate(16px,22px)}}

/* drifting particles */
.x-particles{position:absolute;inset:0;overflow:hidden}
.x-particles i{position:absolute;bottom:-12px;width:4px;height:4px;border-radius:50%;
  background:rgba(239,20,44,.55);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;
  animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.x-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.6);box-shadow:0 0 7px rgba(255,255,255,.35)}
@keyframes rise{
  0%{transform:translateY(0) translateX(0);opacity:0}
  12%{opacity:.8}
  85%{opacity:.5}
  100%{transform:translateY(-78vh) translateX(22px);opacity:0}
}
@media (prefers-reduced-motion:reduce){
  .x-mesh .flow,.x-mesh .nd,.x-ring,.x-particles i,.xhero-fx .glow{animation:none}
  .x-particles i{opacity:.4}
}

.xhero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.06fr;gap:clamp(34px,5vw,72px);align-items:center}

.chip-eyebrow{display:inline-flex;align-items:center;gap:.7em;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.17em;font-size:.72rem;font-weight:600;color:var(--muted-2);background:rgba(255,255,255,.05);border:1px solid var(--line);padding:.6em 1.05em;border-radius:999px}
.pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--red);animation:pdot 2.4s infinite}
@keyframes pdot{0%{box-shadow:0 0 0 0 rgba(239,20,44,.55)}70%{box-shadow:0 0 0 12px rgba(239,20,44,0)}100%{box-shadow:0 0 0 0 rgba(239,20,44,0)}}

.xhero-title{font-family:var(--font-display);font-size:clamp(3.1rem,8.4vw,6.2rem);line-height:.9;letter-spacing:.01em;margin-top:22px}
.xhero-title .hl{position:relative;color:var(--red);display:inline-block}
.xhero-title .hl::after{content:"";position:absolute;left:0;right:0;bottom:.04em;height:.085em;background:var(--red);transform:scaleX(0);transform-origin:left;animation:ulgrow 1s var(--ease) .55s forwards}
@keyframes ulgrow{to{transform:scaleX(1)}}
.xhero .lead{margin-top:22px;max-width:46ch}
.xhero .hero-actions{margin-top:32px}
.xhero-proof{display:flex;align-items:center;gap:12px;margin-top:30px;font-size:.9rem;color:var(--muted-2)}
.xhero-proof strong{color:#fff}
.stars-sm{color:#ffc043;letter-spacing:1px;white-space:nowrap}

.xhero-media{position:relative;perspective:1200px;min-height:clamp(380px,54vh,580px)}
.xhero-card{position:relative;z-index:2;border-radius:22px;overflow:hidden;box-shadow:0 44px 90px -34px rgba(0,0,0,.8);transform-style:preserve-3d;transition:transform .35s var(--ease)}
.xhero-card img{width:100%;height:clamp(380px,54vh,580px);object-fit:cover;object-position:center 38%;display:block}
.card-ring{position:absolute;inset:0;border-radius:22px;border:1px solid rgba(255,255,255,.18);pointer-events:none}
.accent-block{position:absolute;z-index:1;width:60%;height:68%;right:-20px;bottom:-20px;border-radius:22px;background:linear-gradient(135deg,var(--red),#760f1c);opacity:.92}
.xhero-media::before{content:"";position:absolute;left:-14px;top:-14px;width:62px;height:62px;border-left:3px solid var(--red);border-top:3px solid var(--red);border-radius:5px 0 0 0;z-index:3}

.chip{position:absolute;z-index:4;display:flex;flex-direction:column;gap:1px;background:rgba(11,16,23,.66);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line-strong);border-radius:14px;padding:12px 16px;box-shadow:0 20px 40px -20px rgba(0,0,0,.7)}
.chip strong{font-family:var(--font-head);font-size:1.12rem;line-height:1}
.chip span{font-size:.68rem;color:var(--muted-2);font-family:var(--font-head);text-transform:uppercase;letter-spacing:.13em}
.chip-rating{left:-24px;top:38px;flex-direction:row;align-items:center;gap:9px;animation:bob 6s ease-in-out infinite}
.chip-rating .lbl2{color:#fff;letter-spacing:.05em;font-size:.74rem}
.chip-free{right:-18px;top:-20px;text-align:center;animation:bob 5s ease-in-out infinite .5s}
.chip-free strong{color:var(--red)}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

.spin-badge{position:absolute;z-index:5;left:-28px;bottom:-28px;width:116px;height:116px;border-radius:50%;background:rgba(11,16,23,.86);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--line-strong);display:grid;place-items:center;box-shadow:var(--shadow)}
.spin-badge svg{position:absolute;inset:0;width:100%;height:100%;animation:spin 20s linear infinite;fill:var(--muted-2);font-family:var(--font-head);font-size:9px;letter-spacing:1.3px;text-transform:uppercase}
.spin-core{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;background:var(--red);box-shadow:0 8px 20px -6px rgba(239,20,44,.85)}
.spin-core img{width:40px;height:auto}
@keyframes spin{to{transform:rotate(360deg)}}

@media(max-width:860px){
  .xhero-grid{grid-template-columns:1fr;gap:46px}
  .xhero-media{max-width:560px;margin-inline:auto;width:100%}
  .xhero-card{transform:none!important}
}
@media(max-width:560px){
  .xhero{padding-top:calc(78px + 26px)}
  .chip-rating{left:6px;top:14px}
  .chip-free{right:6px;top:-14px}
  .spin-badge{width:92px;height:92px;left:4px;bottom:-18px}
  .spin-core{width:44px;height:44px}.spin-core img{width:30px}
  .accent-block{right:-8px;bottom:-12px}
}

/* ---------- Reimagined intro section ---------- */
.intro2{position:relative;overflow:hidden;background:
  radial-gradient(90% 70% at 12% 0%, #1a2436 0%, transparent 55%), var(--navy)}
.intro2-watermark{position:absolute;right:-2%;top:-24px;font-family:var(--font-display);
  font-size:clamp(7rem,20vw,18rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;pointer-events:none;user-select:none;z-index:0}
.intro2-grid{position:relative;z-index:2;display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(48px,7vw,104px);align-items:center}

.intro2-media{position:relative;padding:24px 40px 44px 14px}
.im-main{position:relative;z-index:2;border-radius:20px;overflow:hidden;box-shadow:0 40px 80px -34px rgba(0,0,0,.8)}
.im-main::after{content:"";position:absolute;inset:0;border-radius:20px;border:1px solid rgba(255,255,255,.14)}
.im-main img{width:100%;height:clamp(430px,58vh,580px);object-fit:cover;object-position:center 28%;transition:transform 1s var(--ease)}
.intro2-media:hover .im-main img{transform:scale(1.05)}
.im-sub{position:absolute;z-index:3;right:8px;bottom:8px;width:48%;border-radius:16px;overflow:hidden;border:5px solid var(--navy);box-shadow:0 26px 50px -24px rgba(0,0,0,.85)}
.im-sub img{width:100%;height:190px;object-fit:cover;object-position:center 30%;transition:transform 1s var(--ease)}
.im-sub:hover img{transform:scale(1.07)}
.im-badge{position:absolute;z-index:4;left:-6px;top:42px;background:var(--red);color:#fff;border-radius:16px;padding:16px 20px;display:flex;flex-direction:column;gap:4px;box-shadow:0 22px 44px -18px rgba(239,20,44,.8);animation:bob 6s ease-in-out infinite}
.bg-num{font-family:var(--font-display);font-size:2.5rem;line-height:.9}
.bg-num i{font-style:normal;font-size:1.4rem;vertical-align:top}
.bg-lbl{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.66rem;line-height:1.3;opacity:.95}
.im-ring{position:absolute;z-index:1;left:-30px;top:-26px;width:150px;height:150px;border-radius:50%;border:1px solid rgba(239,20,44,.3);animation:spin 40s linear infinite}
.im-dots{position:absolute;z-index:0;left:-22px;bottom:96px;width:104px;height:104px;
  background-image:radial-gradient(rgba(255,255,255,.18) 1.4px,transparent 1.4px);background-size:18px 18px;opacity:.55;
  -webkit-mask-image:radial-gradient(circle at 30% 70%,#000,transparent 75%);mask-image:radial-gradient(circle at 30% 70%,#000,transparent 75%)}

/* extra decorative layer around the intro image cluster */
.im-lines{position:absolute;inset:-42px;width:auto;height:auto;z-index:0;pointer-events:none}
.im-lines .il{stroke:rgba(255,255,255,.075);stroke-width:1}
.im-lines .il-faint{stroke:rgba(255,255,255,.04)}
.im-lines .il-red{stroke:url(#imRed);stroke-width:2;stroke-dasharray:150 640;animation:streakA 11s linear infinite}
.im-glow{position:absolute;z-index:0;left:-66px;top:-60px;width:250px;height:250px;border-radius:50%;
  background:radial-gradient(circle,rgba(239,20,44,.30),transparent 70%);filter:blur(54px)}
.im-ring2{position:absolute;z-index:0;right:-30px;bottom:26px;width:132px;height:132px;border-radius:50%;
  border:1px dashed rgba(255,255,255,.13);animation:spin 50s linear infinite}
.im-ticks{position:absolute;z-index:0;right:-20px;top:34%;width:16px;height:120px;
  background-image:repeating-linear-gradient(180deg,rgba(255,255,255,.2) 0 2px,transparent 2px 15px)}
.im-bracket{position:absolute;z-index:5;right:24px;top:2px;width:58px;height:58px;
  border-top:3px solid var(--red);border-right:3px solid var(--red);border-radius:0 6px 0 0}
.im-plus{position:absolute;z-index:5;font-family:var(--font-head);line-height:1;user-select:none}
.im-plus-a{font-size:24px;color:rgba(239,20,44,.6);right:74px;top:-12px;animation:floatB 13s ease-in-out infinite}
.im-plus-b{font-size:18px;color:rgba(255,255,255,.28);left:-14px;bottom:22px;animation:floatA 16s ease-in-out infinite}

.intro2-copy .eyebrow{margin-bottom:18px}
.intro2-copy p{color:var(--muted-2)}
.intro2-copy p+p{margin-top:1.05em}
.intro2-stats{display:flex;flex-wrap:wrap;gap:14px 34px;align-items:flex-start;margin:30px 0 6px;padding-top:26px;border-top:1px solid var(--line)}
.intro2-stats .st{display:flex;flex-wrap:wrap;align-items:baseline;column-gap:.08em;line-height:1}
.intro2-stats .s-num{font-family:var(--font-display);font-size:2.6rem;color:#fff;line-height:1}
.intro2-stats .s-suf{font-family:var(--font-display);font-size:1.4rem;color:var(--red);line-height:1}
.intro2-stats .s-lbl{flex-basis:100%;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;color:var(--muted);margin-top:8px}
.intro2-copy .hero-actions{margin-top:30px}

@media(max-width:860px){
  .intro2-grid{grid-template-columns:1fr;gap:54px}
  .intro2-media{max-width:560px;margin-inline:auto;width:100%;padding:18px 26px 36px 10px}
  .im-main img{height:clamp(360px,50vh,460px)}
}
@media(max-width:560px){
  .im-sub{width:54%}
  .im-sub img{height:150px}
  .im-badge{left:-2px;top:24px;padding:13px 16px}
  .bg-num{font-size:2rem}
  .intro2-stats{gap:12px 24px}
  .intro2-stats .s-num{font-size:2.1rem}
}

/* ---------- Programs — expanding accordion ---------- */
.programs2{position:relative;overflow:hidden;background:linear-gradient(180deg,#0e1521 0%,#0b111c 100%)}
.p2-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.p2-glow{position:absolute;width:48vw;height:48vw;left:-16vw;top:-18vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.22),transparent 66%);filter:blur(80px);animation:floatGlow 20s ease-in-out infinite}
.p2-dots{position:absolute;right:2.5%;bottom:7%;width:160px;height:130px;background-image:radial-gradient(rgba(255,255,255,.14) 1.4px,transparent 1.4px);background-size:20px 20px;opacity:.5;
  -webkit-mask-image:radial-gradient(circle at 70% 70%,#000,transparent 75%);mask-image:radial-gradient(circle at 70% 70%,#000,transparent 75%)}
.p2-watermark{position:absolute;left:-1%;bottom:-4%;font-family:var(--font-display);font-size:clamp(6rem,16vw,15rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.p2-glow2{left:auto;top:auto;right:-12vw;bottom:-18vw;width:44vw;height:44vw;background:radial-gradient(circle,rgba(70,100,165,.16),transparent 68%);animation-duration:26s}
.p2-lines{position:absolute;inset:0;width:100%;height:100%}
.p2-lines .p2-struct{stroke:rgba(255,255,255,.06);stroke-width:1;fill:none}
.p2-lines .p2-faint{stroke:rgba(255,255,255,.035)}
.p2-lines .p2-flow{fill:none;stroke:url(#p2Red);stroke-width:2;stroke-dasharray:160 1500;animation:streakA 11s linear infinite}
.p2-grid{position:absolute;right:0;top:40px;width:50%;height:320px;opacity:.5;
  background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.045) 0 1px,transparent 1px 78px),repeating-linear-gradient(180deg,rgba(255,255,255,.04) 0 1px,transparent 1px 78px);
  -webkit-mask-image:radial-gradient(120% 120% at 100% 0%,#000,transparent 70%);mask-image:radial-gradient(120% 120% at 100% 0%,#000,transparent 70%)}
.p2-ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.06)}
.p2-ring1{width:280px;height:280px;right:7%;top:-94px;border-color:rgba(239,20,44,.14);animation:floatB 22s ease-in-out infinite}
.p2-ring2{width:160px;height:160px;left:30%;bottom:-54px;border-style:dashed;animation:spin 55s linear infinite}
.p2-particles{position:absolute;inset:0;overflow:hidden}
.p2-particles i{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:rgba(239,20,44,.5);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.p2-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.55);box-shadow:0 0 7px rgba(255,255,255,.35)}
@media(prefers-reduced-motion:reduce){.p2-lines .p2-flow,.p2-ring,.p2-particles i,.p2-glow{animation:none}}

.p2-head{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap;margin-bottom:clamp(34px,4vw,52px)}
.p2-head-copy{max-width:640px}
.p2-head-copy .lead{max-width:46ch}
.p2-emblem{position:relative;width:152px;height:152px;flex:none;display:grid;place-items:center}
.p2-emblem svg{position:absolute;inset:0;width:100%;height:100%;fill:var(--muted-2);font-family:var(--font-head);font-size:9px;letter-spacing:1.5px;text-transform:uppercase;animation:spin 24s linear infinite}
.p2-emblem-core{width:94px;height:94px;border-radius:50%;display:grid;place-items:center;align-content:center;text-align:center;background:rgba(239,20,44,.1);border:1px solid rgba(239,20,44,.35);box-shadow:inset 0 0 40px -12px rgba(239,20,44,.5)}
.pe-num{font-family:var(--font-display);font-size:2.1rem;color:#fff;line-height:.85}
.pe-lbl{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.6rem;color:var(--red);margin-top:3px}
@media(max-width:640px){.p2-emblem{display:none}}
.p2-hint{display:block;margin-top:12px;color:var(--red);font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;font-weight:600}

.pshow{position:relative;z-index:2;display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,4vw,58px);align-items:stretch}
.pa-tag{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.18em;font-size:.68rem;color:var(--red);font-weight:600}

/* program name menu */
.pshow-list{display:flex;flex-direction:column;justify-content:center;padding:4px 0}
.ps-item{position:relative;display:flex;align-items:center;gap:16px;padding:21px 6px 21px 16px;border-bottom:1px solid var(--line);cursor:pointer;outline:none}
.ps-item:first-child{border-top:1px solid var(--line)}
.ps-item::before{content:"";position:absolute;left:-2px;top:50%;width:3px;height:60%;background:var(--red);border-radius:2px;transform:translateY(-50%) scaleY(0);transform-origin:center;transition:transform .4s var(--ease)}
.ps-item.active::before{transform:translateY(-50%) scaleY(1)}
.ps-num{font-family:var(--font-head);font-size:.78rem;letter-spacing:.12em;color:var(--muted);width:30px;flex:none;transition:color .3s var(--ease)}
.ps-name{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(1.55rem,3.3vw,2.55rem);line-height:1.04;color:#fff;transition:color .35s var(--ease),transform .4s var(--ease)}
.ps-chev{margin-left:auto;color:var(--red);font-family:var(--font-head);font-size:1.1rem;opacity:0;transform:translateX(-10px);transition:opacity .35s var(--ease),transform .35s var(--ease)}
.ps-item:hover .ps-name,.ps-item.active .ps-name,.ps-item:focus-visible .ps-name{color:var(--red);transform:translateX(12px)}
.ps-item:hover .ps-num,.ps-item.active .ps-num,.ps-item:focus-visible .ps-num{color:var(--red)}
.ps-item:hover .ps-chev,.ps-item.active .ps-chev,.ps-item:focus-visible .ps-chev{opacity:1;transform:none}

/* showcase stage */
.pshow-stage{position:relative;border-radius:20px;overflow:hidden;min-height:clamp(440px,56vh,560px);border:1px solid var(--line);box-shadow:0 40px 80px -34px rgba(0,0,0,.8)}
.ps-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .55s var(--ease)}
.ps-slide.active{opacity:1;visibility:visible}
.ps-slide>img{width:100%;height:100%;object-fit:cover;object-position:center 32%;transform:scale(1.05);transition:transform 1.4s var(--ease)}
.ps-slide.active>img{transform:scale(1)}
.ps-slide::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,17,24,.08) 0%,rgba(12,17,24,.5) 50%,rgba(8,11,16,.95) 100%)}
.ps-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:clamp(26px,3vw,40px);opacity:0;transform:translateY(18px);transition:opacity .5s var(--ease) .12s,transform .5s var(--ease) .12s}
.ps-slide.active .ps-cap{opacity:1;transform:none}
.ps-cap .pa-tag{display:inline-block;margin-bottom:14px;background:var(--red);color:#fff;padding:5px 12px;border-radius:999px;letter-spacing:.14em;font-size:.64rem}
.ps-cap h3{font-family:var(--font-display);font-size:clamp(2rem,3.4vw,2.8rem);line-height:1.02;margin-bottom:14px;text-shadow:0 2px 22px rgba(0,0,0,.55)}
.ps-cap p{color:#e7ebf2;font-size:1rem;line-height:1.6;max-width:46ch;margin-bottom:24px;text-shadow:0 1px 14px rgba(0,0,0,.55)}

/* active menu tint + auto-play progress bar */
.ps-item.active{background:linear-gradient(90deg,rgba(239,20,44,.07),transparent 72%)}
.ps-prog{position:absolute;left:0;bottom:-1px;height:2px;width:100%;background:var(--red);border-radius:2px;transform:scaleX(0);transform-origin:left}
.ps-item.active .ps-prog{animation:fillbar 5.4s linear forwards}
.pshow.paused .ps-item.active .ps-prog{animation-play-state:paused}
@keyframes fillbar{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@media(prefers-reduced-motion:reduce){.ps-item.active .ps-prog{animation:none;transform:scaleX(1)}}

@media(max-width:860px){
  .pshow{grid-template-columns:1fr;gap:22px}
  .pshow-stage{order:-1;min-height:340px}
  .pshow-list{padding:0}
  .ps-name{font-size:clamp(1.5rem,7vw,2rem)}
  .ps-item{padding:18px 6px 18px 14px}
}

/* ---------- Coaching Culture ---------- */
.culture{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--navy),#0e1622)}
.culture-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.cu-glow{position:absolute;left:-12vw;top:-10vw;width:42vw;height:42vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.16),transparent 66%);filter:blur(82px);animation:floatGlow 24s ease-in-out infinite}
.cu-lines{position:absolute;inset:0;width:100%;height:100%}
.cu-lines .cul{stroke:rgba(255,255,255,.05);stroke-width:1}
.cu-lines .cul-red{stroke:url(#cuRed);stroke-width:2;fill:none;stroke-dasharray:150 1500;animation:streakA 13s linear infinite}
.cu-ring{position:absolute;right:6%;top:-90px;width:240px;height:240px;border-radius:50%;border:1px dashed rgba(255,255,255,.07);animation:spin 60s linear infinite}
.cu-dots{position:absolute;right:4%;bottom:18%;width:120px;height:100px;background-image:radial-gradient(rgba(255,255,255,.14) 1.4px,transparent 1.4px);background-size:19px 19px;opacity:.5;-webkit-mask-image:radial-gradient(circle at 70% 70%,#000,transparent 75%);mask-image:radial-gradient(circle at 70% 70%,#000,transparent 75%)}
.cu-watermark{position:absolute;right:-1%;bottom:-6%;font-family:var(--font-display);font-size:clamp(6rem,15vw,13rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.cu-particles{position:absolute;inset:0;overflow:hidden}
.cu-particles i{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:rgba(239,20,44,.5);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.cu-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.55);box-shadow:0 0 7px rgba(255,255,255,.35)}
.culture-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,72px);align-items:center}
.cu-media{position:relative;padding:18px 18px 22px 0}
.cu-accent{position:absolute;left:-16px;bottom:-16px;width:56%;height:58%;border-radius:18px;background:linear-gradient(135deg,var(--red),#760f1c);opacity:.9;z-index:0}
.cu-frame{position:relative;z-index:2;border-radius:18px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 40px 80px -34px rgba(0,0,0,.8)}
.cu-frame img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center 32%;display:block;transition:transform 1s var(--ease)}
.cu-media:hover .cu-frame img{transform:scale(1.04)}
.cu-bracket{position:absolute;z-index:3;right:-10px;top:-10px;width:58px;height:58px;border-right:3px solid var(--red);border-top:3px solid var(--red);border-radius:0 6px 0 0}
.cu-badge{position:absolute;z-index:4;right:-12px;bottom:34px;background:rgba(11,16,23,.74);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line-strong);border-radius:13px;padding:13px 17px;box-shadow:0 22px 44px -18px rgba(0,0,0,.7);animation:bob 6s ease-in-out infinite}
.cu-badge b{display:block;font-family:var(--font-display);font-size:1.2rem;color:#fff;line-height:1}
.cu-badge span{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.6rem;color:var(--red);margin-top:4px}
.culture-copy p{color:var(--muted-2)}
.culture-copy p+p{margin-top:1em;color:var(--muted)}
.culture-copy .btn{margin-top:24px}
@media(max-width:860px){
  .culture-grid{grid-template-columns:1fr;gap:40px}
  .cu-media{max-width:540px;width:100%;order:-1;padding:18px 14px 22px 14px}
}
@media(prefers-reduced-motion:reduce){.cu-glow,.cu-lines .cul-red,.cu-ring,.cu-particles i,.cu-badge{animation:none}}

/* ---------- Meet The Team (editorial) ---------- */
.meet{position:relative;overflow:hidden;background:linear-gradient(180deg,#0b111c 0%,#0e1622 55%,var(--navy) 100%)}
.meet::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='nmt'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23nmt)'/%3E%3C/svg%3E")}
.meet-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.mt-ghost{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.06;filter:grayscale(1) contrast(1.1);-webkit-mask-image:radial-gradient(80% 80% at 75% 25%,#000,transparent 72%);mask-image:radial-gradient(80% 80% at 75% 25%,#000,transparent 72%)}
.mt-smoke{position:absolute;border-radius:50%;filter:blur(72px);mix-blend-mode:screen;opacity:.6}
.mt-smoke-a{width:46vw;height:46vw;right:-12vw;top:-14vw;background:radial-gradient(circle,rgba(168,28,40,.55),rgba(96,14,24,.25) 45%,transparent 70%);animation:driftR 40s ease-in-out infinite alternate,pulseB 16s ease-in-out infinite}
.mt-smoke-b{width:42vw;height:42vw;left:-14vw;bottom:-18vw;background:radial-gradient(circle,rgba(150,22,34,.5),rgba(80,12,18,.22) 45%,transparent 72%);animation:driftBL 46s ease-in-out infinite alternate,pulseA 19s ease-in-out infinite}
.mt-watermark{position:absolute;left:-2%;top:6%;font-family:var(--font-display);font-size:clamp(7rem,20vw,19rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.mt-dots{position:absolute;right:4%;bottom:24%;width:140px;height:120px;background-image:radial-gradient(rgba(255,255,255,.14) 1.4px,transparent 1.4px);background-size:20px 20px;opacity:.5;-webkit-mask-image:radial-gradient(circle at 70% 70%,#000,transparent 75%);mask-image:radial-gradient(circle at 70% 70%,#000,transparent 75%)}
.mt-lines{position:absolute;inset:0;width:100%;height:100%}
.mt-lines .ml{stroke:rgba(255,255,255,.05);stroke-width:1}
.mt-lines .ml-red{stroke:url(#mtRed);stroke-width:2;fill:none;stroke-dasharray:160 1600;animation:streakA 13s linear infinite}
.mt-vlabel{position:absolute;z-index:1;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.4em;font-size:.66rem;font-weight:600;color:rgba(255,255,255,.12);white-space:nowrap}
.mt-vlabel.left{left:14px;top:50%;transform:rotate(180deg) translateX(50%);writing-mode:vertical-rl}
.mt-vlabel.right{right:14px;top:50%;transform:translateY(-50%);writing-mode:vertical-rl}
.mt-stamp{position:absolute;right:3%;top:6%;width:128px;height:128px;opacity:.18}
.mt-stamp svg{width:100%;height:100%;animation:spin 26s linear infinite;fill:rgba(255,255,255,.8);font-family:var(--font-head);font-size:8.2px;letter-spacing:1.3px;text-transform:uppercase}

/* featured head coach */
.meet-top{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.04fr;gap:clamp(34px,5vw,74px);align-items:center}
.meet-intro .display-xl{font-family:var(--font-display);font-size:clamp(2.6rem,6vw,4.6rem);line-height:.95;text-transform:uppercase;margin-top:18px}
.meet-intro .display-xl em{font-style:normal;color:var(--red)}
.meet-intro .lead{margin-top:20px;max-width:42ch}
.meet-hl{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.meet-hl span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:600;color:var(--muted-2);background:rgba(255,255,255,.05);border:1px solid var(--line);padding:.55em .95em;border-radius:999px}
.meet-feature{position:relative;padding:22px 0 24px 22px}
.mf-accent{position:absolute;z-index:0;right:-16px;top:-16px;width:60%;height:58%;border-radius:20px;background:linear-gradient(135deg,var(--red),#760f1c);opacity:.9}
.mf-frame{position:relative;z-index:2;border-radius:20px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 50px 90px -36px rgba(0,0,0,.85)}
.mf-frame img{width:100%;height:clamp(440px,64vh,620px);object-fit:cover;object-position:center 26%;display:block;transition:transform 1.1s var(--ease)}
.meet-feature:hover .mf-frame img{transform:scale(1.04)}
.mf-plate{position:absolute;z-index:3;left:0;right:0;bottom:0;padding:clamp(26px,2.8vw,38px) clamp(22px,2.4vw,32px) clamp(22px,2.4vw,30px);background:linear-gradient(0deg,rgba(8,11,16,.96) 0%,rgba(8,11,16,.62) 52%,transparent 100%)}
.mf-plate .role{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.18em;font-size:.62rem;font-weight:600;color:var(--red)}
.mf-plate h3{font-family:var(--font-display);font-size:clamp(1.8rem,2.6vw,2.3rem);line-height:1;margin-top:7px}
.mf-plate .pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.mf-plate .pills span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.58rem;font-weight:600;color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:.42em .75em;border-radius:999px;backdrop-filter:blur(6px)}
.meet-bio{position:relative;z-index:2;max-width:760px;margin-top:clamp(30px,4vw,42px);color:var(--muted-2)}
.meet-bio strong{color:#fff}

/* trust metrics */
.meet-stats{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-top:clamp(36px,4vw,52px)}
.ms-cell{background:#0f1622;padding:26px 22px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;transition:background .35s var(--ease)}
.ms-cell:hover{background:#141d2c}
.ms-ic{width:42px;height:42px;border-radius:11px;background:rgba(239,20,44,.12);color:var(--red);display:grid;place-items:center;margin-bottom:4px}
.ms-ic svg{width:20px;height:20px}
.ms-num{font-family:var(--font-display);font-size:clamp(1.9rem,3.4vw,2.6rem);color:#fff;line-height:1}
.ms-num span{color:var(--red)}
.ms-lbl{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;color:var(--muted)}

.meet-head{position:relative;z-index:2;text-align:center;max-width:760px;margin:0 auto clamp(34px,4vw,50px)}
.meet-head .section-title{margin-top:14px}
.meet-head .section-title em{font-style:normal;color:var(--red)}
.meet-head .lead{margin:16px auto 0}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

@media(max-width:860px){.mt-vlabel,.mt-stamp{display:none}}
@media(prefers-reduced-motion:reduce){.mt-smoke,.mt-lines .ml-red,.mt-stamp svg{animation:none}}

/* =====================================================
   COACH SHOWCASE — editorial instructor redesign
   ===================================================== */
.cs-kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.2em;font-size:.64rem;font-weight:600;color:var(--red)}
.cs-kicker::before{content:"";width:26px;height:2px;background:var(--red)}

/* featured coach — editorial split with layered imagery */
.cs-featured{position:relative;z-index:2;display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(24px,4vw,64px);align-items:center;margin-bottom:clamp(56px,7vw,96px)}
.cs-feat-media{position:relative;padding:34px 34px 0 0}
.cs-feat-no{position:absolute;top:-26px;right:0;z-index:0;font-family:var(--font-display);font-size:clamp(7rem,13vw,12rem);line-height:.7;color:transparent;-webkit-text-stroke:2px rgba(239,20,44,.32);text-stroke:2px rgba(239,20,44,.32);pointer-events:none}
.cs-feat-frame{position:relative;z-index:1;aspect-ratio:4/5;border-radius:22px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 50px 92px -40px rgba(0,0,0,.85)}
.cs-feat-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(8,11,16,.5));pointer-events:none}
.cs-feat-frame img{width:100%;height:100%;object-fit:cover;object-position:center 20%;transition:transform 1.1s var(--ease)}
.cs-featured:hover .cs-feat-frame img{transform:scale(1.04)}
.cs-feat-tag{position:absolute;left:-10px;bottom:30px;z-index:2;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.66rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--red),#a30d1c);padding:.7em 1.1em;border-radius:10px;box-shadow:0 16px 30px -14px rgba(239,20,44,.8)}
.cs-feat-badge{position:absolute;right:-6px;top:8px;z-index:2;display:flex;flex-direction:column;background:rgba(11,16,23,.92);border:1px solid var(--line-strong);border-radius:13px;padding:11px 16px;box-shadow:0 22px 44px -18px rgba(0,0,0,.7)}
.cs-feat-badge b{font-family:var(--font-display);font-size:1.05rem;color:#fff;line-height:1}
.cs-feat-badge span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.54rem;color:var(--red);margin-top:3px}
.cs-feat-name{font-family:var(--font-display);font-size:clamp(2.1rem,4vw,3.3rem);line-height:.98;margin-top:12px;text-transform:uppercase}
.cs-feat-name em{font-style:normal;color:var(--red)}
.cs-feat-bio{color:var(--muted-2);margin-top:16px;line-height:1.7;max-width:54ch}
.cs-feat-bio strong{color:#fff}
.cs-philo{margin-top:24px;display:flex;flex-direction:column;gap:14px}
.cs-philo-item{display:flex;gap:13px;align-items:flex-start}
.cs-philo-ic{flex:none;min-width:34px;color:var(--red);font-family:var(--font-display);font-size:1.6rem;line-height:1}
.cs-philo-item>div{padding-top:2px}
.cs-philo-item b{display:block;font-family:var(--font-head);font-size:1rem;color:#fff;font-weight:600;line-height:1.2}
.cs-philo-item span{display:block;color:var(--muted);font-size:.88rem;line-height:1.55;margin-top:2px}
.cs-feat-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.cs-feat-pills span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.6rem;font-weight:600;color:var(--muted-2);background:rgba(255,255,255,.06);border:1px solid var(--line-strong);padding:.5em .85em;border-radius:999px}

/* roster head */
.cs-roster-head{position:relative;z-index:2;display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;margin-bottom:26px}
.cs-roster-head .eyebrow{margin:0}
.cs-roster-head h3{font-family:var(--font-display);font-size:clamp(1.6rem,2.8vw,2.3rem);text-transform:uppercase;line-height:1}

/* coach roster — editorial numbered rows */
.cstaff{position:relative;z-index:2;border-top:1px solid var(--line)}
.cst-row{position:relative;display:grid;grid-template-columns:auto 172px 1fr auto;align-items:center;gap:clamp(18px,2.4vw,38px);padding:26px 20px 26px 8px;border-bottom:1px solid var(--line);text-decoration:none;color:#fff;overflow:hidden;transition:background .4s var(--ease),padding-left .4s var(--ease)}
.cst-row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);transform:scaleY(0);transform-origin:top;transition:transform .45s var(--ease)}
.cst-row::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(239,20,44,.1),transparent 55%);opacity:0;transition:opacity .4s var(--ease);pointer-events:none}
.cst-row:hover,.cst-row:focus-visible{background:rgba(255,255,255,.02);padding-left:22px;outline:none}
.cst-row:hover::before,.cst-row:focus-visible::before{transform:scaleY(1)}
.cst-row:hover::after,.cst-row:focus-visible::after{opacity:1}

.cst-no{font-family:var(--font-display);font-size:clamp(2.2rem,3.4vw,3.1rem);line-height:1;color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.28);text-stroke:1.5px rgba(255,255,255,.28);transition:-webkit-text-stroke-color .4s var(--ease),transform .4s var(--ease)}
.cst-row:hover .cst-no{-webkit-text-stroke-color:rgba(239,20,44,.85);text-stroke-color:rgba(239,20,44,.85)}

.cst-thumb{position:relative;z-index:1;width:172px;height:214px;border-radius:14px;overflow:hidden;border:1px solid var(--line-strong);background:#0f1622;box-shadow:0 22px 40px -20px rgba(0,0,0,.8);transform-origin:center;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease)}
.cst-row:hover .cst-thumb,.cst-row:focus-visible .cst-thumb{transform:scale(1.12);z-index:3;border-color:rgba(239,20,44,.6);box-shadow:0 32px 56px -22px rgba(0,0,0,.9),0 0 26px -6px rgba(239,20,44,.45)}
.cst-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.cst-row:hover .cst-thumb img{transform:scale(1.08)}
.cst-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,11,16,.4));pointer-events:none}

.cst-body{min-width:0}
.cst-role{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.18em;font-size:.64rem;font-weight:600;color:var(--red)}
.cst-name{display:block;font-family:var(--font-display);font-size:clamp(1.5rem,2.6vw,2.1rem);line-height:1;margin-top:7px;text-transform:uppercase}
.cst-bio{display:block;color:var(--muted-2);font-size:.92rem;line-height:1.6;margin-top:11px;max-width:62ch}

.cst-go{flex:none;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;color:#fff;border:1px solid var(--line-strong);background:rgba(255,255,255,.04);transition:background .35s var(--ease),border-color .35s var(--ease),transform .35s var(--ease)}
.cst-go svg{width:20px;height:20px;transition:transform .35s var(--ease)}
.cst-row:hover .cst-go{background:var(--red);border-color:var(--red);transform:translateX(4px)}
.cst-row:hover .cst-go svg{transform:translateX(2px)}

@media(max-width:760px){
  .cst-row{grid-template-columns:auto 124px 1fr;gap:16px;padding:20px 6px}
  .cst-thumb{width:124px;height:156px}
  .cst-go{display:none}
  .cst-name{font-size:1.5rem}
  .cst-bio{font-size:.86rem;margin-top:8px}
}
@media(max-width:430px){
  .cst-row{grid-template-columns:108px 1fr;gap:14px;padding:16px 4px}
  .cst-no{display:none}
  .cst-thumb{width:108px;height:138px}
}

/* academy credentials */
.cs-creds{position:relative;z-index:2;margin-top:clamp(56px,7vw,90px);text-align:center}
.cs-creds-label{display:inline-block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.22em;font-size:.66rem;font-weight:600;color:var(--muted);margin-bottom:22px}
.cs-creds-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cs-cred{position:relative;padding:26px 18px;border-radius:16px;background:linear-gradient(160deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid var(--line-strong);overflow:hidden}
.cs-cred::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--red),transparent)}
.cs-cred-n{font-family:var(--font-display);font-size:clamp(2.4rem,4vw,3.2rem);line-height:1;color:#fff;display:block}
.cs-cred-n em{font-style:normal;color:var(--red)}
.cs-cred-l{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.13em;font-size:.62rem;color:var(--muted);margin-top:8px;display:block}

/* join the team */
.cs-join{position:relative;z-index:2;margin-top:clamp(40px,5vw,64px);display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;padding:clamp(28px,3.4vw,44px);border-radius:20px;background:linear-gradient(135deg,#1f2c49 0%,#141d33 55%,#2a1320 100%);border:1px solid var(--line-strong);box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 40px 80px -40px rgba(0,0,0,.8);overflow:hidden}
.cs-join::after{content:"";position:absolute;right:-60px;top:-60px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.3),transparent 68%);pointer-events:none}
.cs-join-text{position:relative;min-width:0}
.cs-join-text h3{font-family:var(--font-display);font-size:clamp(1.7rem,3vw,2.5rem);text-transform:uppercase;line-height:1;margin-top:10px}
.cs-join-text p{color:var(--muted-2);margin-top:10px;max-width:50ch;font-size:.95rem}
.cs-join .btn{position:relative;flex:none}

@media(max-width:1024px){
  .cs-creds-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:860px){
  .cs-featured{grid-template-columns:1fr;gap:30px}
  .cs-feat-media{max-width:460px;margin-inline:auto;padding-right:24px}
}
@media(max-width:640px){
  .cs-join{flex-direction:column;align-items:flex-start}
  .cs-join .btn{width:100%;justify-content:center}
}
@media(max-width:420px){.cs-creds-grid{grid-template-columns:1fr 1fr;gap:12px}}

/* ---------- Inner page hero (phero) ---------- */
.phero{position:relative;overflow:hidden;background:linear-gradient(180deg,#101a29 0%,#0e1622 58%,var(--navy) 100%);padding:calc(78px + clamp(30px,5vh,54px)) 0 clamp(38px,5vh,62px)}
.phero-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.phero-grid{position:absolute;inset:0;opacity:.7;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 1px,transparent 1px 72px),repeating-linear-gradient(180deg,rgba(255,255,255,.03) 0 1px,transparent 1px 72px);-webkit-mask-image:radial-gradient(120% 110% at 28% 18%,#000,transparent 80%);mask-image:radial-gradient(120% 110% at 28% 18%,#000,transparent 80%)}
.phero-glow{position:absolute;right:-10vw;top:-12vw;width:44vw;height:44vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.2),transparent 66%);filter:blur(80px);animation:floatGlow 22s ease-in-out infinite}
.phero-lines{position:absolute;inset:0;width:100%;height:100%}
.phero-lines .pl{stroke:rgba(255,255,255,.05);stroke-width:1}
.phero-lines .pl-red{stroke:url(#pheroRed);stroke-width:2;fill:none;stroke-dasharray:150 1500;animation:streakA 12s linear infinite}
.phero-word{position:absolute;right:-1%;bottom:-6%;font-family:var(--font-display);font-size:clamp(6.5rem,19vw,17rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.phero-particles{position:absolute;inset:0;overflow:hidden}
.phero-particles i{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:rgba(239,20,44,.5);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.phero-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.55);box-shadow:0 0 7px rgba(255,255,255,.35)}

.phero{display:flex;align-items:center;min-height:56vh}
.phero-word{right:auto;left:2%;top:auto;bottom:-5%;transform:none;text-align:left}
.phero .container{position:relative;z-index:2;width:100%}
.phero-inner{max-width:min(540px,43vw);text-align:left}
.phero-inner .chip-eyebrow{margin-bottom:6px}
.phero-title{font-family:var(--font-display);font-size:clamp(2.7rem,6.2vw,5.2rem);line-height:.95;text-transform:uppercase;margin-top:18px}
.phero-title .hl{position:relative;color:var(--red);display:inline-block}
.phero-title .hl::after{content:"";position:absolute;left:0;right:0;bottom:.03em;height:.07em;background:var(--red);transform:scaleX(0);transform-origin:left;animation:ulgrow 1s var(--ease) .5s forwards}
.phero .lead{margin-top:20px;max-width:34ch;color:#e1e6ee}
.phero-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.phero-chip{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:600;color:var(--muted-2);background:rgba(255,255,255,.05);border:1px solid var(--line);padding:.55em .95em;border-radius:999px}
.phero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}

/* diagonal image panel */
.phero-media{position:absolute;top:0;right:0;width:55%;height:100%;z-index:1}
.ph-red{position:absolute;inset:0;background:linear-gradient(135deg,var(--red),#8c1020);clip-path:polygon(15% 0,100% 0,100% 100%,0% 100%)}
.ph-img{position:absolute;inset:0;overflow:hidden;clip-path:polygon(18% 0,100% 0,100% 100%,3% 100%)}
.ph-img img{width:100%;height:100%;object-fit:cover;object-position:center 30%;transition:transform 1.4s var(--ease)}
.phero-media:hover .ph-img img{transform:scale(1.05)}
.ph-img::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(14,21,33,.92) 0%,rgba(14,21,33,.25) 30%,transparent 55%)}
.phero-media .pm-badge{position:absolute;z-index:3;top:26px;right:26px;text-align:left;background:rgba(11,16,23,.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line-strong);border-radius:13px;padding:12px 16px;box-shadow:0 22px 44px -18px rgba(0,0,0,.7);animation:bob 6s ease-in-out infinite}
.pm-badge b{display:block;font-family:var(--font-display);font-size:1.15rem;color:#fff;line-height:1;font-weight:400}
.pm-badge span{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.6rem;color:var(--red);margin-top:4px}

@media(max-width:820px){
  .phero{display:block;min-height:0;padding-top:calc(78px + 26px);padding-bottom:48px}
  .phero-media{position:relative;width:100%;height:280px;margin-bottom:30px}
  .ph-red{clip-path:polygon(0 0,100% 0,100% 90%,0 100%)}
  .ph-img{clip-path:polygon(0 0,100% 0,100% 84%,0 96%)}
  .ph-img::after{background:linear-gradient(0deg,rgba(14,21,33,.55),transparent 50%)}
  .phero-inner{max-width:none}
  .phero-title{font-size:clamp(2.3rem,9vw,3.2rem)}
  .phero-word{bottom:auto;top:6%}
}
@media(prefers-reduced-motion:reduce){.phero-glow,.phero-lines .pl-red,.phero-particles i,.pm-badge,.ph-img img{animation:none}}

/* ---------- Head Coach feature (coachx) ---------- */
.coachx{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--navy) 0%,#0e1622 100%)}
.coachx-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.cx-glow{position:absolute;right:-12vw;top:-14vw;width:46vw;height:46vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.2),transparent 66%);filter:blur(80px);animation:floatGlow 22s ease-in-out infinite}
.cx-lines{position:absolute;inset:0;width:100%;height:100%}
.cx-lines .cl{stroke:rgba(255,255,255,.05);stroke-width:1}
.cx-lines .cl-red{stroke:url(#cxRed);stroke-width:2;fill:none;stroke-dasharray:150 1500;animation:streakA 12s linear infinite}
.cx-ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.06)}
.cx-ring1{width:300px;height:300px;left:40%;top:-120px;border-color:rgba(239,20,44,.13);animation:floatB 24s ease-in-out infinite}
.cx-ring2{width:180px;height:180px;right:8%;bottom:-64px;border-style:dashed;animation:spin 55s linear infinite}
.cx-dots{position:absolute;right:4%;top:13%;width:130px;height:110px;background-image:radial-gradient(rgba(255,255,255,.16) 1.4px,transparent 1.4px);background-size:19px 19px;opacity:.5;
  -webkit-mask-image:radial-gradient(circle at 70% 30%,#000,transparent 75%);mask-image:radial-gradient(circle at 70% 30%,#000,transparent 75%)}
.cx-watermark{position:absolute;right:-1%;bottom:-3%;font-family:var(--font-display);font-size:clamp(7rem,18vw,17rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.cx-particles{position:absolute;inset:0;overflow:hidden}
.cx-particles i{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:rgba(239,20,44,.5);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.cx-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.55);box-shadow:0 0 7px rgba(255,255,255,.35)}

.coachx-grid{position:relative;z-index:2;display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(38px,5vw,82px);align-items:center}
.coachx-media{position:relative;padding:22px 26px 26px 16px}
.cx-photo{position:relative;z-index:2;border-radius:20px;overflow:hidden;box-shadow:0 44px 90px -34px rgba(0,0,0,.85)}
.cx-photo::after{content:"";position:absolute;inset:0;border-radius:20px;border:1px solid rgba(255,255,255,.14)}
.cx-photo img{width:100%;height:clamp(440px,60vh,600px);object-fit:cover;object-position:center 22%;transition:transform 1.1s var(--ease)}
.coachx-media:hover .cx-photo img{transform:scale(1.04)}
.cx-accent{position:absolute;z-index:1;left:-20px;bottom:-20px;width:66%;height:72%;border-radius:20px;background:linear-gradient(135deg,var(--red),#760f1c);opacity:.92}
.cx-bracket{position:absolute;z-index:3;right:-10px;top:-10px;width:60px;height:60px;border-top:3px solid var(--red);border-right:3px solid var(--red);border-radius:0 6px 0 0}
.cx-badge{position:absolute;z-index:4;right:-16px;bottom:38px;background:rgba(11,16,23,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line-strong);border-radius:14px;padding:14px 18px;box-shadow:0 22px 44px -18px rgba(0,0,0,.7);animation:bob 6s ease-in-out infinite}
.cx-badge-k{display:block;font-family:var(--font-display);font-size:1.25rem;color:#fff;line-height:1}
.cx-badge-v{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.62rem;color:var(--red);margin-top:5px}

.coachx-copy .eyebrow{margin-bottom:16px}
.coachx-name{font-family:var(--font-display);font-size:clamp(2.5rem,5.4vw,4.3rem);line-height:.96;text-transform:uppercase}
.coachx-name .hl{color:var(--red)}
.cx-lineage{display:flex;flex-wrap:wrap;gap:10px;margin:22px 0 4px}
.cx-pill{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:600;color:var(--muted-2);background:rgba(255,255,255,.05);border:1px solid var(--line);padding:.55em .95em;border-radius:999px}
.cx-pill:first-child{color:#fff;border-color:rgba(239,20,44,.5);background:rgba(239,20,44,.12)}
.coachx-copy .lead{margin-top:20px}
.coachx-copy p+p{margin-top:1em;color:var(--muted-2)}
.cx-belt{height:13px;max-width:330px;border-radius:7px;margin:24px 0 4px;position:relative;background:linear-gradient(90deg,#0c0c0c 0 76%,#c70f23 76% 100%);box-shadow:0 6px 16px -8px rgba(0,0,0,.7)}
.cx-belt::after{content:"";position:absolute;right:7%;top:0;bottom:0;width:3px;background:rgba(255,255,255,.55)}
.coachx-copy .hero-actions{margin-top:26px}

@media(max-width:860px){
  .coachx-grid{grid-template-columns:1fr;gap:50px}
  .coachx-media{max-width:520px;margin-inline:auto;width:100%}
}

/* ---------- Choose Your Training Path (light CTA) ---------- */
.path{position:relative;overflow:hidden;color:#17202C;background:radial-gradient(48vw 42vw at 100% -6%,rgba(239,20,44,.13),transparent 58%),radial-gradient(46vw 42vw at -6% 106%,rgba(45,66,120,.15),transparent 60%),#f4f1ec}
.path::after{content:"";position:absolute;right:-46px;top:24%;width:120px;height:120px;background:rgba(239,20,44,.06);border:1px solid rgba(239,20,44,.22);border-radius:22px;transform:rotate(18deg);z-index:0;pointer-events:none;animation:floatB 18s ease-in-out infinite}
.path::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.06;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='np'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23np)'/%3E%3C/svg%3E")}
.path-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.path-fx::before{content:"";position:absolute;right:-10vw;top:-12vw;width:46vw;height:46vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.2),transparent 66%);filter:blur(70px);animation:floatGlow 22s ease-in-out infinite}
.path-fx::after{content:"";position:absolute;left:3%;bottom:12%;width:130px;height:110px;background-image:radial-gradient(rgba(23,32,47,.16) 1.4px,transparent 1.4px);background-size:20px 20px;opacity:.5;-webkit-mask-image:radial-gradient(circle at 30% 70%,#000,transparent 75%);mask-image:radial-gradient(circle at 30% 70%,#000,transparent 75%)}
.path-grid::after{content:"";position:absolute;right:7%;top:13%;width:150px;height:150px;border-radius:50%;border:1px dashed rgba(239,20,44,.24);animation:spin 60s linear infinite}
@media(prefers-reduced-motion:reduce){.path-fx::before,.path-grid::after,.path::after{animation:none}}
.path-grid{position:absolute;inset:0;opacity:.8;
  background-image:repeating-linear-gradient(90deg,rgba(23,32,47,.04) 0 1px,transparent 1px 74px),repeating-linear-gradient(180deg,rgba(23,32,47,.04) 0 1px,transparent 1px 74px);
  -webkit-mask-image:radial-gradient(125% 110% at 50% 25%,#000,transparent 82%);mask-image:radial-gradient(125% 110% at 50% 25%,#000,transparent 82%)}
.path-word{position:absolute;font-family:var(--font-display);text-transform:uppercase;line-height:.8;letter-spacing:.01em;user-select:none;white-space:nowrap}
.path-word1{font-size:20vw;left:-3%;top:1%;color:rgba(23,32,47,.05)}
.path-word2{font-size:16vw;right:-2%;bottom:-3%;color:rgba(239,20,44,.08)}
.path-stamp{position:absolute;right:3%;top:7%;width:152px;height:152px;border-radius:50%;border:1px solid rgba(239,20,44,.4);display:grid;place-items:center;opacity:.6}
.path-stamp svg{position:absolute;inset:0;width:100%;height:100%;animation:spin 26s linear infinite;fill:rgba(23,32,47,.55);font-family:var(--font-head);font-size:8.4px;letter-spacing:1.3px;text-transform:uppercase}
.path-stamp-core{font-family:var(--font-display);font-size:1.5rem;color:var(--red);letter-spacing:.04em}

/* single clean CTA panel */
.path-panel{position:relative;z-index:2;max-width:880px;margin:0 auto;text-align:center;background:#fff;border:1px solid rgba(23,32,47,.08);border-radius:24px;padding:clamp(40px,5vw,70px) clamp(26px,5vw,68px);box-shadow:0 44px 90px -38px rgba(23,32,47,.5);overflow:hidden}
.path-panel-tab{position:absolute;left:50%;top:0;transform:translateX(-50%);width:120px;height:5px;background:var(--red);border-radius:0 0 6px 6px}
.path-panel .section-title{color:#17202C;margin-top:14px}
.path-panel .lead{color:#55535b;margin:18px auto 0}
.path-panel .cta-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:32px}
.path-panel .path-badges{justify-content:center;margin-top:30px;padding-top:24px;border-top:1px solid rgba(23,32,47,.1)}
@media(max-width:560px){.path-panel .cta-actions .btn{flex:1;justify-content:center}}

.path-head{position:relative;z-index:2;text-align:center;max-width:760px;margin:0 auto clamp(30px,3.5vw,48px)}
.path .section-title{color:#17202C;margin-top:14px}
.path .lead{color:#55535b;margin:18px auto 0}
.path-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 24px;margin-top:26px}
.path-badges li{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;font-weight:600;color:#3a3a40;display:inline-flex;align-items:center;gap:.5em}
.path-badges li i{color:var(--red);font-style:normal;font-weight:700}

.path-trust{position:relative;z-index:2;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px 18px;margin-bottom:clamp(30px,4vw,46px);padding:16px 0;border-top:1px solid rgba(23,32,47,.1);border-bottom:1px solid rgba(23,32,47,.1)}
.path-trust span:not(.sep){font-family:var(--font-head);text-transform:uppercase;letter-spacing:.13em;font-size:.74rem;font-weight:600;color:#2a2a30}
.path-trust .sep{width:6px;height:6px;border-radius:50%;background:var(--red);opacity:.75}

.path-cards{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.pcard:nth-child(1),.pcard:nth-child(3){margin-top:34px}
.pcard{background:#fff;border:1px solid rgba(23,32,47,.08);border-radius:18px;overflow:hidden;text-decoration:none;color:#17202C;display:flex;flex-direction:column;box-shadow:0 22px 44px -28px rgba(23,32,47,.4);transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.pcard:hover{transform:translateY(-10px);box-shadow:0 44px 74px -30px rgba(23,32,47,.45)}
.pcard-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.pcard-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.pcard:hover .pcard-img img{transform:scale(1.07)}
.pcard-img::after{content:"";position:absolute;left:0;bottom:0;height:4px;width:0;background:var(--red);transition:width .5s var(--ease);z-index:2}
.pcard:hover .pcard-img::after{width:100%}
.pcard-body{padding:26px;display:flex;flex-direction:column;flex:1}
.pcard-cat{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.64rem;font-weight:600;color:var(--red)}
.pcard-body h3{font-family:var(--font-display);font-size:1.7rem;margin-top:8px;color:#17202C}
.pcard-body p{color:#5d5a5e;font-size:.93rem;line-height:1.6;margin-top:10px;flex:1}
.pcard-go{margin-top:18px;display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.13em;font-size:.78rem;font-weight:600;color:#17202C}
.pcard-go .arr{color:var(--red);transition:transform .35s var(--ease)}
.pcard:hover .pcard-go .arr{transform:translateX(6px)}

.path-bar{position:relative;z-index:2;margin-top:clamp(34px,4vw,54px);border-radius:20px;overflow:hidden;background:#fff;border:1px solid rgba(23,32,47,.1);color:#17202C;padding:clamp(34px,4vw,54px) clamp(28px,4vw,54px);display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px;box-shadow:0 30px 64px -34px rgba(23,32,47,.4)}
.path-bar::before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,var(--red),#a30d1c)}
.path-bar::after{content:"";position:absolute;right:-50px;top:-50px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.12),transparent 70%);pointer-events:none}
.path-bar-text{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}
.path-bar-label{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;font-weight:600;color:var(--red);margin-bottom:12px}
.path-bar-label::before{content:"";width:24px;height:2px;background:var(--red)}
.path-bar h3{font-family:var(--font-display);font-size:clamp(1.8rem,3.3vw,2.7rem);line-height:1.02;color:#17202C}
.path-bar p{color:#55535b;margin:10px auto 0;max-width:52ch}
.path-bar-actions{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.btn-lg{padding:1.2em 2.1em;font-size:.92rem;box-shadow:0 18px 36px -14px rgba(239,20,44,.85)}
.btn-light{background:#fff;color:#17202C}
.btn-light:hover{background:#f0eee9;transform:translateY(-3px)}

@media(max-width:900px){
  .path-cards{grid-template-columns:1fr;gap:20px}
  .pcard:nth-child(1),.pcard:nth-child(3){margin-top:0}
}
@media(max-width:560px){
  .path-stamp{width:108px;height:108px;right:4%;top:3%}
  .path-bar{flex-direction:column;align-items:flex-start}
  .path-bar-actions{width:100%}
  .path-bar-actions .btn{flex:1;justify-content:center}
}
@media(prefers-reduced-motion:reduce){.path-stamp svg{animation:none}}

/* ---------- About light hero (lhero) ---------- */
.lhero{position:relative;overflow:hidden;background:#f4f2ee;color:#17202C;padding:calc(78px + clamp(34px,6vh,62px)) 0 clamp(46px,6vh,78px)}
.lhero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.05;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='nl'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23nl)'/%3E%3C/svg%3E")}
.lhero-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.lh-grid{position:absolute;inset:0;opacity:.8;background-image:repeating-linear-gradient(90deg,rgba(23,32,47,.04) 0 1px,transparent 1px 74px),repeating-linear-gradient(180deg,rgba(23,32,47,.04) 0 1px,transparent 1px 74px);-webkit-mask-image:radial-gradient(120% 110% at 25% 18%,#000,transparent 80%);mask-image:radial-gradient(120% 110% at 25% 18%,#000,transparent 80%)}
.lh-glow{position:absolute;right:-12vw;top:-14vw;width:44vw;height:44vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.16),transparent 66%);filter:blur(80px);animation:floatGlow 22s ease-in-out infinite}
.lh-watermark{position:absolute;left:-1%;bottom:-5%;font-family:var(--font-display);font-size:clamp(7rem,18vw,17rem);line-height:.8;color:rgba(23,32,47,.04);letter-spacing:.02em;user-select:none}

.lhero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,72px);align-items:center}
.lhero .chip-eyebrow{color:#17202C;background:rgba(23,32,47,.05);border-color:rgba(23,32,47,.12)}
.lhero-title{font-family:var(--font-display);font-size:clamp(2.8rem,7vw,5.2rem);line-height:.94;text-transform:uppercase;color:#17202C;margin-top:18px}
.lhero-title .hl{position:relative;color:var(--red);display:inline-block}
.lhero-title .hl::after{content:"";position:absolute;left:0;right:0;bottom:.03em;height:.07em;background:var(--red);transform:scaleX(0);transform-origin:left;animation:ulgrow 1s var(--ease) .5s forwards}
.lhero .lead{margin-top:20px;max-width:44ch;color:#55535b}
.lhero-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.lhero-chip{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:600;color:#3a3a40;background:#fff;border:1px solid rgba(23,32,47,.1);padding:.5em .9em;border-radius:999px;box-shadow:0 6px 14px -10px rgba(23,32,47,.4)}
.lhero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}

.lhero-media{position:relative;padding:20px 22px 28px 4px}
.lh-accent{position:absolute;z-index:0;right:-14px;top:-14px;width:56%;height:58%;border-radius:20px;background:linear-gradient(135deg,var(--red),#8c1020)}
.lh-ring{position:absolute;z-index:0;left:-26px;bottom:34px;width:120px;height:120px;border-radius:50%;border:1px dashed rgba(23,32,47,.18);animation:spin 50s linear infinite}
.lh-main{position:relative;z-index:2;border-radius:20px;overflow:hidden;border:5px solid #fff;box-shadow:0 38px 76px -32px rgba(23,32,47,.5)}
.lh-main img{width:100%;height:clamp(360px,52vh,520px);object-fit:cover;object-position:center 26%;display:block;transition:transform 1s var(--ease)}
.lhero-media:hover .lh-main img{transform:scale(1.04)}
.lh-sub{position:absolute;z-index:3;left:-14px;bottom:-6px;width:44%;border-radius:14px;overflow:hidden;border:5px solid #f4f2ee;box-shadow:0 22px 44px -20px rgba(23,32,47,.55)}
.lh-sub img{width:100%;height:160px;object-fit:cover;object-position:center 30%;display:block}
.lh-badge{position:absolute;z-index:4;right:-10px;bottom:44px;background:#fff;border:1px solid rgba(23,32,47,.1);border-radius:14px;padding:12px 16px;box-shadow:0 22px 44px -18px rgba(23,32,47,.4);animation:bob 6s ease-in-out infinite;display:flex;align-items:center;gap:10px}
.lh-badge-t{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;font-weight:600;color:#17202C}
.lh-badge-t b{color:var(--red)}

@media(max-width:860px){
  .lhero-inner{grid-template-columns:1fr;gap:40px}
  .lhero-media{max-width:520px;width:100%}
}

/* ---------- About: Community (photo marquee) ---------- */
.commx{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--navy),#0e1622)}
.commx-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.cx-glow{position:absolute;right:-10vw;top:-12vw;width:42vw;height:42vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.16),transparent 66%);filter:blur(82px);animation:floatGlow 24s ease-in-out infinite}
.cx-watermark{position:absolute;left:-1%;top:-2%;font-family:var(--font-display);font-size:clamp(6rem,15vw,13rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.commx-head{position:relative;z-index:2;display:grid;grid-template-columns:1fr auto;gap:30px 50px;align-items:end;margin-bottom:clamp(32px,4vw,50px)}
.commx-head .lead{max-width:42ch}
.commx-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:20px}
.commx-strip{position:relative;z-index:2;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.commx-track{display:flex;gap:18px;width:max-content;animation:marqueePhotos 48s linear infinite}
.commx-strip:hover .commx-track{animation-play-state:paused}
.commx-item{position:relative;flex:none;width:clamp(248px,26vw,350px);height:clamp(230px,30vh,310px);border-radius:16px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 26px 52px -30px rgba(0,0,0,.7)}
.commx-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s var(--ease)}
.commx-item:hover img{transform:scale(1.06)}
.commx-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,11,16,.55));pointer-events:none}
.commx-badge{position:relative;z-index:3;display:inline-flex;align-items:center;gap:.6em;margin-top:26px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;font-weight:600;color:var(--muted-2)}
.commx-badge::before{content:"";width:26px;height:2px;background:var(--red)}
@keyframes marqueePhotos{to{transform:translateX(calc(-50% - 9px))}}
@media(max-width:760px){
  .commx-head{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  .cx-glow{animation:none}
  .commx-track{animation:none}
  .commx-strip{overflow-x:auto}
}

/* ---------- About: Community (montage) ---------- */
.comm2{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--navy),#0e1622)}
.comm2-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.c2-glow{position:absolute;right:-12vw;top:-12vw;width:42vw;height:42vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.16),transparent 66%);filter:blur(82px);animation:floatGlow 24s ease-in-out infinite}
.c2-watermark{position:absolute;left:-1%;bottom:-6%;font-family:var(--font-display);font-size:clamp(6rem,15vw,13rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.comm2-grid{position:relative;z-index:2;display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(34px,5vw,68px);align-items:center}
.comm2-copy .lead{margin-top:18px}
.comm2-copy p+p{margin-top:14px;color:var(--muted)}
.comm2-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.comm2-gallery{position:relative;display:grid;grid-template-columns:1.25fr .75fr;grid-template-rows:1fr 1fr;gap:14px;height:clamp(380px,54vh,520px)}
.cg{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 30px 60px -34px rgba(0,0,0,.7)}
.cg img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s var(--ease)}
.cg:hover img{transform:scale(1.06)}
.cg-a{grid-row:1 / span 2}
.cg-badge{position:absolute;z-index:3;left:-10px;bottom:26px;background:var(--red);color:#fff;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;font-weight:600;font-size:.74rem;line-height:1.3;padding:12px 16px;border-radius:12px;max-width:230px;box-shadow:0 18px 36px -14px rgba(239,20,44,.8);animation:bob 6s ease-in-out infinite}
@media(max-width:860px){
  .comm2-grid{grid-template-columns:1fr;gap:42px}
  .comm2-gallery{height:auto;grid-template-rows:200px 200px}
}
@media(max-width:520px){
  .comm2-gallery{grid-template-columns:1fr;grid-template-rows:repeat(3,210px)}
  .cg-a{grid-row:auto}
}
@media(prefers-reduced-motion:reduce){.c2-glow,.cg-badge{animation:none}}

/* ---------- About: Who We Serve (reveal cards) ---------- */
.serve{position:relative;overflow:hidden;background:linear-gradient(180deg,#0e1622 0%,var(--navy) 100%)}
.serve-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.sv-glow{position:absolute;left:50%;top:38%;transform:translate(-50%,-50%);width:60vw;height:40vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.14),transparent 64%);filter:blur(90px);animation:floatGlow 24s ease-in-out infinite}
.sv-lines{position:absolute;inset:0;width:100%;height:100%}
.sv-lines .sl{stroke:rgba(255,255,255,.05);stroke-width:1}
.sv-lines .sl-red{stroke:url(#svRed);stroke-width:2;fill:none;stroke-dasharray:150 1500;animation:streakA 13s linear infinite}
.sv-ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.06)}
.sv-ring1{width:300px;height:300px;right:4%;top:-120px;border-color:rgba(239,20,44,.13);animation:floatB 24s ease-in-out infinite}
.sv-ring2{width:170px;height:170px;left:3%;bottom:6%;border-style:dashed;animation:spin 55s linear infinite}
.sv-dots{position:absolute;left:4%;top:34%;width:120px;height:100px;background-image:radial-gradient(rgba(255,255,255,.14) 1.4px,transparent 1.4px);background-size:19px 19px;opacity:.5;-webkit-mask-image:radial-gradient(circle at 30% 40%,#000,transparent 75%);mask-image:radial-gradient(circle at 30% 40%,#000,transparent 75%)}
.sv-watermark{position:absolute;right:-1%;bottom:-5%;font-family:var(--font-display);font-size:clamp(6rem,15vw,13rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.sv-particles{position:absolute;inset:0;overflow:hidden}
.sv-particles i{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:rgba(239,20,44,.5);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.sv-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.55);box-shadow:0 0 7px rgba(255,255,255,.35)}

.serve-head{position:relative;z-index:2;text-align:center;max-width:720px;margin:0 auto clamp(38px,5vw,58px)}
.serve-head .lead{margin:16px auto 0}
.serve-cards{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start}
.scard{position:relative;border-radius:20px;overflow:hidden;min-height:clamp(440px,58vh,580px);display:flex;flex-direction:column;justify-content:flex-end;text-decoration:none;color:#fff;border:1px solid var(--line);isolation:isolate;transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.scard:hover{transform:translateY(-8px);box-shadow:0 44px 74px -30px rgba(0,0,0,.7)}
.scard:nth-child(2){margin-top:-34px}
.sc-img{position:absolute;inset:0;z-index:-2}
.sc-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.scard:hover .sc-img img{transform:scale(1.06)}
.scard::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(12,17,24,.12) 0%,rgba(12,17,24,.5) 46%,rgba(8,11,16,.96) 100%)}
.scard::before{content:"";position:absolute;left:0;bottom:0;height:4px;width:0;background:var(--red);z-index:2;transition:width .5s var(--ease)}
.scard:hover::before,.scard:focus-within::before{width:100%}
.sc-top{position:absolute;top:20px;left:20px;right:20px;z-index:2;display:flex;align-items:center;justify-content:space-between}
.sc-cat{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;font-weight:600;color:#fff;background:rgba(239,20,44,.88);padding:.45em .8em;border-radius:999px}
.sc-no{font-family:var(--font-display);font-size:1.7rem;color:rgba(255,255,255,.72)}
.sc-body{position:relative;z-index:2;padding:26px}
.sc-body h3{font-family:var(--font-display);font-size:2rem;line-height:1}
.sc-reveal{overflow:hidden;max-height:0;opacity:0;transform:translateY(10px);transition:max-height .55s var(--ease),opacity .45s var(--ease),transform .45s var(--ease)}
.scard:hover .sc-reveal,.scard:focus-within .sc-reveal{max-height:280px;opacity:1;transform:none}
.sc-reveal p{color:var(--muted-2);font-size:.93rem;line-height:1.6;margin-top:12px}
.sc-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.sc-chip{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.6rem;font-weight:600;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:.4em .75em;border-radius:999px}
.sc-go{display:inline-flex;align-items:center;gap:.5em;margin-top:16px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.13em;font-size:.76rem;font-weight:600;color:#fff}
.sc-go .arr{color:var(--red);transition:transform .35s var(--ease)}
.scard:hover .sc-go .arr{transform:translateX(6px)}
@media(max-width:820px){
  .serve-cards{grid-template-columns:1fr;gap:18px}
  .scard{min-height:430px}
  .scard:nth-child(2){margin-top:0}
  .sc-reveal{max-height:280px;opacity:1;transform:none}
}
@media(prefers-reduced-motion:reduce){.sv-glow,.sv-lines .sl-red,.sv-ring,.sv-particles i{animation:none}}

/* ---------- About: Who We Serve (tab switcher) ---------- */
.levels{position:relative;overflow:hidden;background:radial-gradient(62% 52% at 50% -6%,#1b2540 0%,transparent 58%),linear-gradient(180deg,var(--navy) 0%,#0e1622 100%)}
.levels-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.lv-glow{position:absolute;left:50%;top:6%;transform:translateX(-50%);width:60vw;height:34vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.14),transparent 64%);filter:blur(90px);animation:floatGlow 24s ease-in-out infinite}
.lv-watermark{position:absolute;right:-1%;bottom:-4%;font-family:var(--font-display);font-size:clamp(6rem,16vw,14rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.lv-lines{position:absolute;inset:0;width:100%;height:100%}
.lv-lines .lvl{stroke:rgba(255,255,255,.05);stroke-width:1}
.lv-lines .lvl-red{stroke:url(#lvRed);stroke-width:2;fill:none;stroke-dasharray:160 1500;animation:streakA 13s linear infinite}
.lv-glow2{position:absolute;left:-12vw;bottom:-14vw;width:40vw;height:40vw;border-radius:50%;background:radial-gradient(circle,rgba(45,66,120,.24),transparent 66%);filter:blur(88px);animation:floatGlow 28s ease-in-out infinite reverse}
.lv-ring{position:absolute;right:5%;top:14%;width:160px;height:160px;border-radius:50%;border:1px dashed rgba(239,20,44,.2);animation:spin 60s linear infinite}
.lv-ring2{position:absolute;left:7%;bottom:10%;width:110px;height:110px;border-radius:50%;border:1px solid rgba(255,255,255,.06);animation:floatB 22s ease-in-out infinite}
.lv-shape{position:absolute;left:5%;top:24%;width:92px;height:92px;border:1px solid rgba(255,255,255,.08);border-radius:18px;transform:rotate(16deg);animation:floatB 18s ease-in-out infinite}
.lv-dots{position:absolute;right:6%;bottom:18%;width:120px;height:100px;background-image:radial-gradient(rgba(255,255,255,.14) 1.4px,transparent 1.4px);background-size:20px 20px;opacity:.5;-webkit-mask-image:radial-gradient(circle at 70% 70%,#000,transparent 75%);mask-image:radial-gradient(circle at 70% 70%,#000,transparent 75%)}
.lv-particles{position:absolute;inset:0;overflow:hidden}
.lv-particles i{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:rgba(239,20,44,.5);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.lv-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.55);box-shadow:0 0 7px rgba(255,255,255,.35)}
.levels-head{position:relative;z-index:2;text-align:center;max-width:720px;margin:0 auto}
.levels-head .lead{margin:16px auto 0}
.lv-tabs{position:relative;z-index:2;display:flex;justify-content:center;flex-wrap:wrap;gap:10px;margin:clamp(28px,3.5vw,42px) 0 clamp(28px,3vw,40px)}
.lv-tab{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;font-weight:600;color:var(--muted-2);background:rgba(255,255,255,.05);border:1px solid var(--line-strong);padding:.8em 1.3em;border-radius:999px;cursor:pointer;transition:color .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease),transform .3s var(--ease)}
.lv-tab .n{font-family:var(--font-display);font-size:.92rem;color:var(--red)}
.lv-tab:hover{color:#fff;border-color:#fff;transform:translateY(-2px)}
.lv-tab.active{background:var(--red);border-color:var(--red);color:#fff}
.lv-tab.active .n{color:#fff}
.lv-panels{position:relative;z-index:2}
.lv-panel{display:none;grid-template-columns:1.04fr .96fr;gap:clamp(30px,4vw,64px);align-items:center}
.lv-panel.active{display:grid;animation:fadeUp .55s var(--ease)}
.lv-media{position:relative;padding:16px 16px 20px 0}
.lv-accent{position:absolute;left:-16px;bottom:-16px;width:56%;height:58%;border-radius:18px;background:linear-gradient(135deg,var(--red),#760f1c);opacity:.9;z-index:0}
.lv-frame{position:relative;z-index:2;border-radius:18px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 40px 80px -34px rgba(0,0,0,.8)}
.lv-frame img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform 1s var(--ease)}
.lv-media:hover .lv-frame img{transform:scale(1.04)}
.lv-bracket{position:absolute;z-index:3;right:-10px;top:-10px;width:56px;height:56px;border-right:3px solid var(--red);border-top:3px solid var(--red);border-radius:0 6px 0 0}
.lv-content .sc-cat{display:inline-block}
.lv-content h3{font-family:var(--font-display);font-size:clamp(2rem,3.6vw,3rem);line-height:1;margin-top:10px}
.lv-content p{color:var(--muted-2);line-height:1.7;margin-top:14px;max-width:48ch}
.lv-content .sc-chips{margin-top:16px}
.lv-content .btn{margin-top:24px}
@media(max-width:860px){.lv-panel.active{grid-template-columns:1fr;gap:32px}.lv-media{max-width:540px}}
@media(prefers-reduced-motion:reduce){.lv-glow,.lv-glow2,.lv-lines .lvl-red,.lv-ring,.lv-ring2,.lv-shape,.lv-particles i{animation:none}}

/* ---------- About: Who We Serve (alternating rows) ---------- */
.who3{position:relative;overflow:hidden;background:linear-gradient(180deg,#0e1622,var(--navy))}
.who3-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.w3-glow{position:absolute;left:-12vw;top:30%;width:42vw;height:42vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.15),transparent 66%);filter:blur(82px);animation:floatGlow 24s ease-in-out infinite}
.w3-watermark{position:absolute;right:-1%;top:-3%;font-family:var(--font-display);font-size:clamp(6rem,15vw,13rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.w3-lines{position:absolute;inset:0;width:100%;height:100%}
.w3-lines .ll{stroke:rgba(255,255,255,.05);stroke-width:1}
.w3-lines .ll-faint{stroke:rgba(255,255,255,.03)}
.w3-lines .ll-red{stroke:url(#w3Red);stroke-width:2;fill:none;stroke-dasharray:150 1500;animation:streakA 13s linear infinite}
.w3-ring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.06)}
.w3-ring1{width:300px;height:300px;right:5%;top:-110px;border-color:rgba(239,20,44,.13);animation:floatB 24s ease-in-out infinite}
.w3-ring2{width:170px;height:170px;left:3%;bottom:8%;border-style:dashed;animation:spin 55s linear infinite}
.w3-dots{position:absolute;right:4%;top:40%;width:120px;height:100px;background-image:radial-gradient(rgba(255,255,255,.14) 1.4px,transparent 1.4px);background-size:19px 19px;opacity:.5;-webkit-mask-image:radial-gradient(circle at 70% 40%,#000,transparent 75%);mask-image:radial-gradient(circle at 70% 40%,#000,transparent 75%)}
.w3-particles{position:absolute;inset:0;overflow:hidden}
.w3-particles i{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:rgba(239,20,44,.5);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.w3-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.55);box-shadow:0 0 7px rgba(255,255,255,.35)}
.who3-head{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:clamp(28px,4vw,46px)}
.who3-head .lead{max-width:42ch}
.who3-rows{position:relative;z-index:2}
.who3-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,68px);align-items:center;padding-block:clamp(30px,4vw,48px)}
.who3-row:not(:first-child){border-top:1px solid var(--line)}
.who3-media{position:relative;transition:transform .45s var(--ease)}
.who3-media:hover{transform:translateY(-6px)}
.wr-accent{position:absolute;z-index:0;width:86%;height:86%;right:-14px;bottom:-14px;border-radius:18px;background:linear-gradient(135deg,var(--red),#760f1c);opacity:.9}
.who3-row.rev .wr-accent{right:auto;left:-14px}
.wr-frame{position:relative;z-index:2;border-radius:18px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 38px 76px -34px rgba(0,0,0,.8)}
.wr-frame img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center 25%;display:block;transition:transform 1s var(--ease)}
.who3-media:hover .wr-frame img{transform:scale(1.05)}
.wr-bracket{position:absolute;z-index:3;left:-9px;top:-9px;width:54px;height:54px;border-left:3px solid var(--red);border-top:3px solid var(--red);border-radius:6px 0 0 0}
.who3-row.rev .who3-media{order:2}
.who3-content{position:relative}
.wr-bg-no{position:absolute;right:0;top:-48px;z-index:0;font-family:var(--font-display);font-size:clamp(5rem,9vw,8.5rem);line-height:1;color:rgba(255,255,255,.035);pointer-events:none;user-select:none}
.who3-content>*{position:relative;z-index:1}
.wr-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.wr-chip{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.64rem;font-weight:600;color:var(--muted-2);background:rgba(255,255,255,.05);border:1px solid var(--line);padding:.45em .85em;border-radius:999px}
.wr-top{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.wr-num{flex:none;width:52px;height:52px;border-radius:50%;border:1px solid rgba(239,20,44,.4);color:var(--red);display:grid;place-items:center;font-family:var(--font-display);font-size:1.3rem;box-shadow:inset 0 0 26px -8px rgba(239,20,44,.5)}
.wr-cat{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;font-weight:600;color:var(--muted-2)}
.who3-content h3{font-family:var(--font-display);font-size:clamp(1.9rem,3.4vw,2.8rem);line-height:1;text-transform:uppercase}
.who3-content p{color:var(--muted-2);margin-top:14px;max-width:46ch}
.wr-go{display:inline-flex;align-items:center;gap:.5em;margin-top:18px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.13em;font-size:.78rem;font-weight:600;color:#fff}
.wr-go .arr{color:var(--red);transition:transform .35s var(--ease)}
.wr-go:hover .arr{transform:translateX(6px)}
@media(max-width:820px){
  .who3-row,.who3-row.rev{grid-template-columns:1fr;gap:26px}
  .who3-row.rev .who3-media{order:-1}
  .who3-media{max-width:560px}
}
@media(prefers-reduced-motion:reduce){.w3-glow,.w3-lines .ll-red,.w3-ring,.w3-particles i{animation:none}}

/* ---------- About: The Environment ---------- */
.env2{position:relative;overflow:hidden;background:#f4f2ee;color:#17202C}
.env2::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.05;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='ne2'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23ne2)'/%3E%3C/svg%3E")}
.env2-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.e2-glow{position:absolute;right:-12vw;bottom:-14vw;width:42vw;height:42vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.14),transparent 66%);filter:blur(82px);animation:floatGlow 24s ease-in-out infinite}
.e2-watermark{position:absolute;right:-1%;top:0;font-family:var(--font-display);font-size:clamp(6rem,15vw,13rem);line-height:.8;color:rgba(23,32,47,.04);letter-spacing:.02em;user-select:none}
.e2-dots{position:absolute;right:5%;bottom:14%;width:120px;height:100px;background-image:radial-gradient(rgba(23,32,47,.16) 1.4px,transparent 1.4px);background-size:19px 19px;opacity:.55;-webkit-mask-image:radial-gradient(circle at 70% 70%,#000,transparent 75%);mask-image:radial-gradient(circle at 70% 70%,#000,transparent 75%)}
.env2-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(34px,5vw,72px);align-items:center}
.env2 .section-title{color:#17202C}
.env2-media{position:relative;padding:18px 0 22px 18px}
.em-accent{position:absolute;left:-16px;bottom:-16px;width:56%;height:60%;border-radius:18px;background:linear-gradient(135deg,var(--red),#760f1c);opacity:.9;z-index:0}
.em-frame{position:relative;z-index:2;border-radius:18px;overflow:hidden;border:5px solid #fff;box-shadow:0 36px 72px -32px rgba(23,32,47,.5)}
.em-frame img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center 40%;display:block;transition:transform 1s var(--ease)}
.env2-media:hover .em-frame img{transform:scale(1.04)}
.em-bracket{position:absolute;z-index:3;right:-10px;top:-10px;width:58px;height:58px;border-right:3px solid var(--red);border-top:3px solid var(--red);border-radius:0 6px 0 0}
.em-badge{position:absolute;z-index:4;right:-12px;bottom:34px;background:#fff;border:1px solid rgba(23,32,47,.1);border-radius:13px;padding:13px 17px;box-shadow:0 22px 44px -18px rgba(23,32,47,.4);animation:bob 6s ease-in-out infinite}
.em-badge b{display:block;font-family:var(--font-display);font-size:1.2rem;color:#17202C;line-height:1}
.em-badge span{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.6rem;color:var(--red);margin-top:4px}
.env2-copy .lead{margin-top:18px;max-width:46ch;color:#55535b}
.env2-feats{display:grid;grid-template-columns:1fr 1fr;gap:20px 26px;margin-top:30px}
.ef-item{display:flex;gap:13px;align-items:flex-start}
.ef-ic{flex:none;width:40px;height:40px;border-radius:11px;background:rgba(239,20,44,.1);color:var(--red);display:grid;place-items:center}
.ef-ic svg{width:20px;height:20px}
.ef-item h4{font-family:var(--font-head);font-weight:600;font-size:1.02rem;color:#17202C;text-transform:none}
.ef-item p{color:#5d5a5e;font-size:.86rem;line-height:1.5;margin-top:4px}
@media(max-width:860px){
  .env2-grid{grid-template-columns:1fr;gap:40px}
  .env2-media{max-width:540px;width:100%;order:-1;padding:18px 14px 22px 14px}
}
@media(max-width:480px){.env2-feats{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){.e2-glow,.em-badge{animation:none}}

/* ---------- About: Our Values ---------- */
.values2{position:relative;overflow:hidden;background:linear-gradient(180deg,#0e1622 0%,var(--navy) 100%)}
.values2-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.v2-glow{position:absolute;left:-12vw;top:-12vw;width:44vw;height:44vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.18),transparent 66%);filter:blur(82px);animation:floatGlow 24s ease-in-out infinite}
.v2-lines{position:absolute;inset:0;width:100%;height:100%}
.v2-lines .vl{stroke:rgba(255,255,255,.05);stroke-width:1}
.v2-lines .vl-red{stroke:url(#v2Red);stroke-width:2;fill:none;stroke-dasharray:150 1500;animation:streakA 12s linear infinite}
.v2-watermark{position:absolute;right:-1%;bottom:-6%;font-family:var(--font-display);font-size:clamp(6rem,15vw,14rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.v2-particles{position:absolute;inset:0;overflow:hidden}
.v2-particles i{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:rgba(239,20,44,.5);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.v2-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.55);box-shadow:0 0 7px rgba(255,255,255,.35)}

.values2-grid{position:relative;z-index:2;display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(34px,5vw,68px);align-items:center}
.values2-intro .lead{margin-top:18px;max-width:38ch}
.v2-tagline{display:flex;flex-wrap:wrap;gap:10px 14px;margin-top:26px}
.v2-tagline span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;font-weight:600;color:var(--muted-2)}
.v2-tagline span::before{content:"//";color:var(--red);margin-right:10px}
.v2-tagline span:first-child::before{display:none}

.v2-media{position:relative;margin-top:32px;max-width:480px;padding:16px 18px 20px 0}
.v2-figure{position:relative;z-index:2;border-radius:18px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 32px 64px -34px rgba(0,0,0,.8)}
.v2-figure img{width:100%;aspect-ratio:16/10;object-fit:cover;object-position:center 22%;display:block;transition:transform 1s var(--ease)}
.v2-media:hover .v2-figure img{transform:scale(1.05)}
.v2-figure::after{content:"";position:absolute;inset:0;border-radius:18px;border:1px solid rgba(255,255,255,.12);pointer-events:none}
.v2-fig-bracket{position:absolute;left:-9px;top:-9px;width:54px;height:54px;border-left:3px solid var(--red);border-top:3px solid var(--red);border-radius:6px 0 0 0;z-index:3}
.v2-accent{position:absolute;z-index:0;right:-14px;top:-14px;width:54%;height:56%;border-radius:18px;background:linear-gradient(135deg,var(--red),#760f1c);opacity:.9}
.v2-ring{position:absolute;z-index:0;right:-22px;bottom:-18px;width:96px;height:96px;border-radius:50%;border:1px dashed rgba(255,255,255,.16);animation:spin 50s linear infinite}
.v2-fdots{position:absolute;z-index:0;left:-22px;bottom:24px;width:92px;height:80px;background-image:radial-gradient(rgba(255,255,255,.16) 1.4px,transparent 1.4px);background-size:18px 18px;opacity:.5;-webkit-mask-image:radial-gradient(circle at 30% 70%,#000,transparent 75%);mask-image:radial-gradient(circle at 30% 70%,#000,transparent 75%)}
.v2-badge{position:absolute;z-index:3;right:-12px;bottom:26px;background:rgba(11,16,23,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--line-strong);border-radius:12px;padding:11px 15px;box-shadow:0 18px 36px -16px rgba(0,0,0,.7);animation:bob 6s ease-in-out infinite}
.v2-badge b{display:block;font-family:var(--font-display);font-size:1.05rem;color:#fff;line-height:1;font-weight:400}
.v2-badge span{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.56rem;color:var(--red);margin-top:3px}
@media(prefers-reduced-motion:reduce){.v2-ring,.v2-badge{animation:none}}
.values2-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.vcard{position:relative;background:var(--navy-900);border:1px solid var(--line);border-radius:16px;padding:30px 28px;overflow:hidden;transition:transform .4s var(--ease),border-color .4s var(--ease),background .4s var(--ease)}
.vcard::before{content:"";position:absolute;left:0;top:0;height:4px;width:0;background:var(--red);transition:width .45s var(--ease)}
.vcard:hover{transform:translateY(-7px);border-color:var(--line-strong);background:var(--navy-800)}
.vcard:hover::before{width:100%}
.vcard .v-no{position:absolute;right:18px;top:4px;font-family:var(--font-display);font-size:3rem;color:rgba(255,255,255,.05);line-height:1}
.vcard .v-ic{width:48px;height:48px;border-radius:12px;background:rgba(239,20,44,.12);color:var(--red);display:grid;place-items:center;margin-bottom:16px}
.vcard .v-ic svg{width:24px;height:24px}
.vcard h3{font-family:var(--font-head);font-weight:600;font-size:1.2rem;text-transform:none;color:#fff;letter-spacing:.01em}
.vcard p{color:var(--muted);font-size:.92rem;line-height:1.6;margin-top:10px}
@media(max-width:860px){
  .values2-grid{grid-template-columns:1fr;gap:38px}
}
@media(max-width:520px){
  .values2-cards{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){.v2-glow,.v2-lines .vl-red,.v2-particles i{animation:none}}

/* ---------- About: Our Story (light, collage + journey) ---------- */
.story4{position:relative;overflow:hidden;background:#f4f2ee;color:#17202C}
.story4::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.05;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='ns4'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23ns4)'/%3E%3C/svg%3E")}
.story4-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.s4-glow{position:absolute;right:-12vw;top:-12vw;width:42vw;height:42vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.15),transparent 66%);filter:blur(82px);animation:floatGlow 24s ease-in-out infinite}
.s4-dots{position:absolute;left:3%;bottom:18%;width:120px;height:110px;background-image:radial-gradient(rgba(23,32,47,.16) 1.4px,transparent 1.4px);background-size:19px 19px;opacity:.5;-webkit-mask-image:radial-gradient(circle at 30% 70%,#000,transparent 75%);mask-image:radial-gradient(circle at 30% 70%,#000,transparent 75%)}
.s4-watermark{position:absolute;right:-1%;bottom:-6%;font-family:var(--font-display);font-size:clamp(6rem,15vw,14rem);line-height:.8;color:rgba(23,32,47,.04);letter-spacing:.02em;user-select:none}

.story4-top{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.08fr;gap:clamp(34px,5vw,72px);align-items:center}
.story4 .section-title{color:#17202C;margin-top:14px}
.story4-copy .lead{color:#55535b;margin-top:18px;max-width:46ch}
.founder-card{display:flex;align-items:center;gap:15px;margin-top:28px;background:#fff;border:1px solid rgba(23,32,47,.1);border-radius:16px;padding:14px 18px;box-shadow:0 18px 38px -22px rgba(23,32,47,.5);max-width:380px}
.founder-card img{width:62px;height:62px;border-radius:12px;object-fit:cover;object-position:center 14%;flex:none}
.fc-name{font-family:var(--font-head);font-weight:600;font-size:1.06rem;color:#17202C;line-height:1.1}
.fc-role{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.62rem;color:var(--red);margin-top:4px}

.story4-collage{position:relative;padding:26px 26px 28px 6px}
.sc-accent{position:absolute;right:-14px;top:-14px;width:52%;height:56%;border-radius:18px;background:linear-gradient(135deg,var(--red),#8c1020);z-index:0}
.sc-ring{position:absolute;left:-22px;bottom:26px;width:118px;height:118px;border-radius:50%;border:1px dashed rgba(23,32,47,.18);animation:spin 50s linear infinite;z-index:0}
.sc-main{position:relative;z-index:2;border-radius:18px;overflow:hidden;border:5px solid #fff;box-shadow:0 36px 72px -32px rgba(23,32,47,.5)}
.sc-main img{width:100%;aspect-ratio:4/3;object-fit:cover;object-position:center 28%;display:block;transition:transform 1s var(--ease)}
.story4-collage:hover .sc-main img{transform:scale(1.04)}
.sc-sub{position:absolute;z-index:3;left:-16px;bottom:-12px;width:42%;border-radius:14px;overflow:hidden;border:5px solid #f4f2ee;box-shadow:0 22px 44px -20px rgba(23,32,47,.55)}
.sc-sub img{width:100%;height:150px;object-fit:cover;object-position:center 30%;display:block}
.sc-stat{position:absolute;z-index:4;background:#fff;border:1px solid rgba(23,32,47,.1);border-radius:12px;padding:10px 15px;box-shadow:0 20px 40px -20px rgba(23,32,47,.45);text-align:center}
.sc-stat b{display:block;font-family:var(--font-display);font-size:1.4rem;color:#17202C;line-height:1}
.sc-stat span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.58rem;color:var(--red)}
.sc-stat-1{right:-12px;bottom:48px;animation:bob 6s ease-in-out infinite}
.sc-stat-2{left:14px;top:-14px;animation:bob 5s ease-in-out infinite .5s}
.sc-stat-2 b{color:#17202C}.sc-stat-2 .stars-sm{font-size:.8rem}

.story4-journey{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:clamp(44px,5vw,66px);padding-top:clamp(30px,4vw,44px);border-top:1px solid rgba(23,32,47,.1)}
.j-card{position:relative;background:#fff;border:1px solid rgba(23,32,47,.08);border-radius:16px;padding:28px 26px;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.j-card::before{content:"";position:absolute;left:0;top:0;height:4px;width:0;background:var(--red);transition:width .45s var(--ease)}
.j-card:hover{transform:translateY(-7px);box-shadow:0 32px 56px -28px rgba(23,32,47,.4)}
.j-card:hover::before{width:100%}
.j-no{position:absolute;right:18px;top:6px;font-family:var(--font-display);font-size:3.2rem;color:rgba(23,32,47,.06);line-height:1}
.j-ic{width:48px;height:48px;border-radius:12px;background:rgba(239,20,44,.1);color:var(--red);display:grid;place-items:center;margin-bottom:16px}
.j-ic svg{width:24px;height:24px}
.j-card h3{font-family:var(--font-head);font-weight:600;font-size:1.18rem;color:#17202C;text-transform:none}
.j-card p{color:#5d5a5e;font-size:.93rem;line-height:1.65;margin-top:10px}
@media(max-width:860px){
  .story4-top{grid-template-columns:1fr;gap:44px}
  .story4-collage{max-width:520px;width:100%;order:-1}
  .story4-journey{grid-template-columns:1fr;gap:18px}
}

/* ---------- About: Our Story (light, timeline) ---------- */
.story3{position:relative;overflow:hidden;background:#f4f2ee;color:#17202C}
.story3::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.05;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='ns3'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23ns3)'/%3E%3C/svg%3E")}
.story3-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.s3-glow{position:absolute;right:-12vw;top:-10vw;width:42vw;height:42vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.14),transparent 66%);filter:blur(80px);animation:floatGlow 24s ease-in-out infinite}
.s3-watermark{position:absolute;left:-1%;bottom:-6%;font-family:var(--font-display);font-size:clamp(6rem,15vw,14rem);line-height:.8;color:rgba(23,32,47,.04);letter-spacing:.02em;user-select:none}
.story3-head{position:relative;z-index:2;text-align:center;max-width:780px;margin:0 auto clamp(38px,5vw,58px)}
.story3 .section-title{color:#17202C;margin-top:14px}
.story3-head .lead{color:#55535b;margin:18px auto 0}
.story3-head .btn{margin-top:28px}
.story3-grid{position:relative;z-index:2;display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(34px,5vw,70px);align-items:center}
.story3-media{position:relative;padding:16px 0 0 16px}
.s3-accent{position:absolute;left:-16px;top:-16px;width:54%;height:54%;border-radius:18px;background:linear-gradient(135deg,var(--red),#8c1020);z-index:0}
.s3-frame{position:relative;z-index:2;border-radius:18px;overflow:hidden;border:5px solid #fff;box-shadow:0 34px 70px -30px rgba(23,32,47,.45)}
.s3-frame img{width:100%;aspect-ratio:3/2;object-fit:cover;object-position:center;display:block;transition:transform 1s var(--ease)}
.story3-media:hover .s3-frame img{transform:scale(1.04)}
.s3-quote{position:relative;z-index:3;margin-top:16px;display:flex;gap:14px;align-items:flex-start;background:#17202C;color:#fff;border-radius:14px;padding:18px 22px;box-shadow:0 24px 48px -22px rgba(23,32,47,.5)}
.s3-quote .mark{font-family:var(--font-display);color:var(--red);font-size:2.4rem;line-height:.7;flex:none}
.s3-quote p{font-size:1rem;line-height:1.45;font-style:italic}
.s3-quote .who{display:block;margin-top:8px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;color:#ff8a96;font-style:normal}
.story3-timeline{position:relative;padding-left:54px}
.story3-timeline::before{content:"";position:absolute;left:18px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--red),rgba(239,20,44,.25))}
.s3-step{position:relative;padding-bottom:30px}
.s3-step:last-child{padding-bottom:0}
.s3-step .no{position:absolute;left:-53px;top:-3px;width:34px;height:34px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-size:1rem;box-shadow:0 0 0 5px #f4f2ee}
.s3-step h3{font-family:var(--font-head);font-weight:600;font-size:1.22rem;color:#17202C;text-transform:none;letter-spacing:.01em}
.s3-step p{color:#5d5a5e;margin-top:9px;font-size:.95rem;line-height:1.65}
@media(max-width:860px){
  .story3-grid{grid-template-columns:1fr;gap:46px}
  .story3-media{max-width:520px;width:100%}
}

/* ---------- About: Our Story ---------- */
.story2{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--navy),#0e1622)}
.story2-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.s2-glow{position:absolute;left:-12vw;top:-10vw;width:42vw;height:42vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.16),transparent 66%);filter:blur(80px);animation:floatGlow 24s ease-in-out infinite}
.s2-watermark{position:absolute;right:-1%;top:2%;font-family:var(--font-display);font-size:clamp(6rem,15vw,14rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.story2-top{position:relative;z-index:2;display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(32px,5vw,72px);align-items:center}
.story2-media{position:relative;padding:18px 18px 22px 0}
.s2-accent{position:absolute;left:-18px;top:-18px;width:58%;height:62%;border-radius:18px;background:linear-gradient(135deg,var(--red),#760f1c);opacity:.9;z-index:0}
.s2-frame{position:relative;z-index:2;border-radius:18px;overflow:hidden;box-shadow:0 40px 80px -34px rgba(0,0,0,.8)}
.s2-frame::after{content:"";position:absolute;inset:0;border-radius:18px;border:1px solid rgba(255,255,255,.14)}
.s2-frame img{width:100%;height:clamp(360px,48vh,500px);object-fit:cover;object-position:center 30%;display:block;transition:transform 1s var(--ease)}
.story2-media:hover .s2-frame img{transform:scale(1.04)}
.s2-quote{position:absolute;z-index:3;right:-8px;bottom:26px;max-width:300px;background:rgba(11,16,23,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--line-strong);border-radius:14px;padding:18px 20px;box-shadow:0 22px 44px -18px rgba(0,0,0,.7)}
.s2-quote .mark{font-family:var(--font-display);color:var(--red);font-size:2rem;line-height:.5;display:block;margin-bottom:6px}
.s2-quote p{font-size:.98rem;color:#fff;line-height:1.45;font-style:italic}
.s2-quote .who{display:block;margin-top:10px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;color:var(--red)}
.story2-intro .lead{margin-top:18px}
.story2-intro .btn{margin-top:26px}
.story2-steps{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:clamp(44px,5vw,68px);padding-top:clamp(30px,4vw,44px);border-top:1px solid var(--line)}
.s2-step .no{width:48px;height:48px;border-radius:50%;background:var(--navy-900);border:1px solid rgba(239,20,44,.4);color:var(--red);display:grid;place-items:center;font-family:var(--font-display);font-size:1.2rem;margin-bottom:16px;box-shadow:0 0 30px -10px rgba(239,20,44,.5)}
.s2-step h3{font-family:var(--font-head);font-weight:600;font-size:1.18rem;text-transform:none;letter-spacing:.01em;color:#fff}
.s2-step p{color:var(--muted);font-size:.93rem;margin-top:10px;line-height:1.65}
@media(max-width:860px){
  .story2-top{grid-template-columns:1fr;gap:40px}
  .story2-media{max-width:520px;order:-1}
  .story2-steps{grid-template-columns:1fr;gap:24px}
}

/* ---------- Get In Touch (dark) ---------- */
.touch{position:relative;overflow:hidden;background:linear-gradient(180deg,#0b111c 0%,#0e1622 55%,var(--navy) 100%)}
.touch-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.tc-glow{position:absolute;right:-10vw;top:-12vw;width:44vw;height:44vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.16),transparent 64%);filter:blur(82px);animation:floatGlow 24s ease-in-out infinite}
.tc-lines{position:absolute;inset:0;width:100%;height:100%}
.tc-lines .tcl{stroke:rgba(255,255,255,.05);stroke-width:1}
.tc-lines .tcl-red{stroke:url(#touchRed);stroke-width:2;fill:none;stroke-dasharray:160 1500;animation:streakA 14s linear infinite}
.tc-watermark{position:absolute;left:-1%;bottom:-6%;font-family:var(--font-display);font-size:clamp(6rem,15vw,13rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.tc-ring{position:absolute;right:6%;top:16%;width:150px;height:150px;border-radius:50%;border:1px dashed rgba(239,20,44,.2);animation:spin 60s linear infinite}
.tc-shape{position:absolute;left:5%;top:24%;width:90px;height:90px;border:1px solid rgba(255,255,255,.08);border-radius:18px;transform:rotate(16deg);animation:floatB 18s ease-in-out infinite}
.tc-dots{position:absolute;left:8%;bottom:16%;width:120px;height:100px;background-image:radial-gradient(rgba(255,255,255,.14) 1.4px,transparent 1.4px);background-size:20px 20px;opacity:.5;-webkit-mask-image:radial-gradient(circle at 30% 70%,#000,transparent 75%);mask-image:radial-gradient(circle at 30% 70%,#000,transparent 75%)}

.touch .container{position:relative;z-index:2}
.touch-head{text-align:center;max-width:680px;margin:0 auto clamp(32px,4vw,46px)}
.touch-head .lead{margin:16px auto 0}
.touch-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(24px,3vw,40px);align-items:start}
.touch-info{display:flex;flex-direction:column;gap:14px}
.ti-card{position:relative;display:flex;gap:15px;align-items:center;background:linear-gradient(135deg,#16213400,#0f1622),linear-gradient(135deg,#172234,#0d1420);border:1px solid var(--line);border-radius:14px;padding:18px 20px;text-decoration:none;color:#fff;overflow:hidden;box-shadow:0 20px 44px -28px rgba(0,0,0,.7);transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease)}
.ti-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease)}
.ti-card:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:0 30px 54px -28px rgba(0,0,0,.75)}
.ti-card:hover::before{transform:scaleY(1)}
.ti-ic{flex:none;width:46px;height:46px;border-radius:12px;background:rgba(239,20,44,.14);color:var(--red);display:grid;place-items:center;transition:background .35s var(--ease)}
.ti-card:hover .ti-ic{background:rgba(239,20,44,.22)}
.ti-ic svg{width:22px;height:22px}
.ti-k{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.62rem;font-weight:600;color:var(--red);margin-bottom:3px}
.ti-v{display:block;font-size:1rem;color:#fff;line-height:1.4}
.ti-promo{position:relative;overflow:hidden;display:flex;gap:14px;align-items:center;background:linear-gradient(135deg,var(--red),#8c1020);color:#fff;border-radius:14px;padding:18px 20px;box-shadow:0 22px 46px -22px rgba(239,20,44,.7)}
.ti-promo::after{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 70%)}
.ti-promo .pic{flex:none;width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.18);display:grid;place-items:center;color:#fff}
.ti-promo .pic svg{width:22px;height:22px}
.ti-promo b{display:block;font-family:var(--font-head);font-size:1.02rem;font-weight:600}
.ti-promo span{display:block;font-size:.8rem;color:rgba(255,255,255,.85);margin-top:2px}
.ti-social{background:#0f1622;border:1px solid var(--line);border-radius:14px;padding:16px 20px;box-shadow:0 20px 44px -28px rgba(0,0,0,.7)}
.ti-social .lbl{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.62rem;font-weight:600;color:var(--muted);margin-bottom:12px}
.ti-social .socials{margin:0}
.tc-particles{position:absolute;inset:0;overflow:hidden}
.tc-particles i{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:rgba(239,20,44,.5);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.tc-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.55);box-shadow:0 0 7px rgba(255,255,255,.35)}

.touch-form-wrap{position:relative;background:#ffffff;border:1px solid rgba(23,32,47,.1);border-radius:20px;padding:clamp(24px,3vw,42px);box-shadow:0 40px 80px -38px rgba(0,0,0,.6);overflow:hidden}
.touch-form-wrap::before{content:"";position:absolute;left:0;top:0;right:0;height:5px;background:linear-gradient(90deg,var(--red),#a30d1c)}
.touch .field label{color:#55535b}
.touch .field input,.touch .field select,.touch .field textarea{background:#f4f1ec;border:1px solid rgba(23,32,47,.16);color:#17202C}
.touch .field input::placeholder,.touch .field textarea::placeholder{color:#9a958d}
.touch .field input:focus,.touch .field select:focus,.touch .field textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(239,20,44,.16)}
.touch .form-note{color:#6b6870}
.touch .form-note a{color:var(--red)}
.touch .form-success{background:rgba(34,150,80,.1);border-color:rgba(34,150,80,.4);color:#1f7a44}
.touch .field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23ef142c' stroke-width='2.5'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;-webkit-appearance:none;appearance:none;padding-right:2.6em}
.touch .field select option{background:#fff;color:#17202C}

/* custom designed dropdown (contact form) */
.cselect{position:relative}
.cselect-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 15px;border-radius:11px;border:1px solid rgba(23,32,47,.16);background:#f4f1ec;color:#17202C;font-family:var(--font-body);font-size:.95rem;text-align:left;cursor:pointer;transition:border-color .25s var(--ease),box-shadow .25s var(--ease)}
.cselect-btn:hover{border-color:rgba(23,32,47,.3)}
.cselect-btn:focus-visible{outline:0;border-color:var(--red);box-shadow:0 0 0 3px rgba(239,20,44,.16)}
.cselect.open .cselect-btn{border-color:var(--red);box-shadow:0 0 0 3px rgba(239,20,44,.16)}
.cselect-arrow{flex:none;width:18px;height:18px;color:var(--red);transition:transform .3s var(--ease)}
.cselect.open .cselect-arrow{transform:rotate(180deg)}
.cselect-list{list-style:none;position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:20;margin:0;padding:6px;background:#fff;border:1px solid rgba(23,32,47,.12);border-radius:13px;box-shadow:0 26px 50px -22px rgba(0,0,0,.45);opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s;max-height:280px;overflow-y:auto}
.cselect.open .cselect-list{opacity:1;visibility:visible;transform:none}
.cselect-opt{padding:11px 13px;border-radius:9px;font-size:.92rem;color:#2a2f37;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .18s var(--ease),color .18s var(--ease)}
.cselect-opt:hover,.cselect-opt.is-active{background:rgba(239,20,44,.08);color:var(--red)}
.cselect-opt.is-selected{color:var(--red);font-weight:600}
.cselect-opt.is-selected::after{content:"✓";color:var(--red);font-size:.85rem}
@media(max-width:860px){.touch-grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){.tc-glow,.tc-lines .tcl-red,.tc-ring,.tc-shape,.tc-particles i{animation:none}}

/* ---------- Visit The Academy (bento) ---------- */
.visit{position:relative;overflow:hidden;background:linear-gradient(180deg,#0e1622 0%,var(--navy) 100%)}
.visit-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.visit-glow{position:absolute;left:18%;top:30%;width:48vw;height:48vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.16),transparent 66%);filter:blur(90px);animation:floatGlow 24s ease-in-out infinite}
.visit-lines{position:absolute;inset:0;opacity:.7;
  background-image:repeating-linear-gradient(90deg,rgba(239,20,44,.045) 0 1px,transparent 1px 70px),repeating-linear-gradient(180deg,rgba(255,255,255,.025) 0 1px,transparent 1px 70px);
  -webkit-mask-image:radial-gradient(120% 100% at 50% 30%,#000,transparent 80%);mask-image:radial-gradient(120% 100% at 50% 30%,#000,transparent 80%)}
.visit-watermark{position:absolute;left:-1%;bottom:-3%;font-family:var(--font-display);font-size:clamp(6rem,15vw,14rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}

.visit-head{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:clamp(30px,3.5vw,46px)}
.visit-head .lead{max-width:46ch}

.visit-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);
  grid-template-areas:"map map addr phone" "map map email badge" "cta cta cta cta";gap:16px}

/* map block */
.v-map{grid-area:map;position:relative;border-radius:18px;overflow:hidden;min-height:452px;border:1px solid var(--line-strong);box-shadow:0 34px 70px -32px rgba(0,0,0,.75)}
.v-map iframe{width:100%;height:100%;min-height:452px;border:0;display:block;filter:grayscale(.25) contrast(1.05) brightness(.96)}
.v-corner{position:absolute;width:26px;height:26px;z-index:3;pointer-events:none}
.v-corner.tl{left:12px;top:12px;border-left:2px solid var(--red);border-top:2px solid var(--red)}
.v-corner.tr{right:12px;top:12px;border-right:2px solid var(--red);border-top:2px solid var(--red)}
.v-corner.bl{left:12px;bottom:12px;border-left:2px solid var(--red);border-bottom:2px solid var(--red)}
.v-corner.br{right:12px;bottom:12px;border-right:2px solid var(--red);border-bottom:2px solid var(--red)}
.v-maplabel{position:absolute;left:14px;top:14px;z-index:3;display:flex;align-items:center;gap:9px;background:rgba(11,16,23,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--line-strong);border-radius:10px;padding:9px 13px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;font-size:.66rem;color:#fff;max-width:calc(100% - 28px)}
.v-pin{width:9px;height:9px;border-radius:50%;background:var(--red);flex:none;animation:pdot 2.2s infinite}
.v-mapcta{position:absolute;right:14px;bottom:14px;z-index:3}

/* contact cards */
.v-card{position:relative;background:#0f1622;border:1px solid var(--line);border-radius:16px;padding:24px;display:flex;flex-direction:column;justify-content:center;gap:6px;text-decoration:none;color:#fff;overflow:hidden;
  transition:transform .4s var(--ease),border-color .4s var(--ease),background .4s var(--ease)}
.v-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--red);transition:width .45s var(--ease)}
.v-card:hover{transform:translateY(-6px);border-color:var(--line-strong);background:#131d2c}
.v-card:hover::before{width:100%}
.v-addr{grid-area:addr}.v-phone{grid-area:phone}.v-email{grid-area:email}.v-badge{grid-area:badge}
.v-ic{width:42px;height:42px;border-radius:11px;background:rgba(239,20,44,.12);color:var(--red);display:grid;place-items:center;margin-bottom:8px}
.v-ic svg{width:21px;height:21px}
.v-k{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.64rem;color:var(--muted)}
.v-v{font-size:.98rem;color:#fff;line-height:1.45}
.v-email .v-v{font-size:.82rem;word-break:break-word}
.v-badge{background:linear-gradient(150deg,rgba(239,20,44,.16),rgba(239,20,44,.03));border-color:rgba(239,20,44,.3)}
.v-badge .v-ic{background:rgba(239,20,44,.2)}

/* CTA card */
.v-cta{grid-area:cta;position:relative;border-radius:18px;overflow:hidden;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:22px;padding:clamp(26px,3vw,42px);background:linear-gradient(120deg,#141d2c,#1b2536);border:1px solid var(--line-strong)}
.v-cta::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 130% at 100% 50%,rgba(239,20,44,.2),transparent 60%);pointer-events:none}
.v-cta-text{position:relative;z-index:2}
.v-cta-text h3{font-family:var(--font-display);font-size:clamp(1.7rem,3vw,2.4rem);line-height:1.02}
.v-cta-text p{color:var(--muted-2);margin-top:10px;max-width:48ch}
.v-cta-actions{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:12px}

@media(max-width:900px){
  .visit-grid{grid-template-columns:repeat(2,1fr);grid-template-areas:"map map" "addr phone" "email badge" "cta cta"}
  .v-map,.v-map iframe{min-height:360px}
}
@media(max-width:560px){
  .visit-grid{grid-template-columns:1fr;grid-template-areas:"cta" "addr" "phone" "email" "badge" "map"}
  .v-cta{flex-direction:column;align-items:flex-start}
  .v-cta-actions{width:100%}
  .v-cta-actions .btn{flex:1;justify-content:center}
  .v-map,.v-map iframe{min-height:300px}
  .v-mapcta{right:12px;bottom:12px}
}

/* ---------- Stats strip (panel) ---------- */
.statstrip{position:relative;overflow:hidden;background:linear-gradient(180deg,#0d1421 0%,#0b111c 100%)}
.statstrip-glow{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:62vw;height:42vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.13),transparent 65%);filter:blur(80px);pointer-events:none;z-index:0}
.statpanel{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:0 34px 64px -34px rgba(0,0,0,.7)}
.stat-cell{background:#0f1622;padding:clamp(28px,3.4vw,46px) 22px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;transition:background .35s var(--ease)}
.stat-cell:hover{background:#141d2c}
.stat-ic{width:48px;height:48px;border-radius:13px;background:rgba(239,20,44,.12);color:var(--red);display:grid;place-items:center;margin-bottom:8px}
.stat-ic svg{width:23px;height:23px}
.stat-num{font-family:var(--font-display);font-size:clamp(2.6rem,5vw,3.8rem);color:#fff;line-height:1;display:inline-flex;align-items:flex-start}
.stat-num i{color:var(--red);font-style:normal;font-size:.55em;margin-left:.05em;line-height:1.2}
.stat-lbl{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:var(--muted);margin-top:6px}
@media(max-width:760px){.statpanel{grid-template-columns:repeat(2,1fr)}}

/* ---------- Schedule (dark, timeline cards) ---------- */
.sched{position:relative;overflow:hidden;background:linear-gradient(180deg,#0b111c 0%,#0e1622 55%,var(--navy) 100%)}
.sched-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.sd-glow{position:absolute;left:50%;top:32%;transform:translate(-50%,-50%);width:60vw;height:40vw;border-radius:50%;background:radial-gradient(circle,rgba(239,20,44,.14),transparent 64%);filter:blur(86px);animation:floatGlow 24s ease-in-out infinite}
.sd-lines{position:absolute;inset:0;width:100%;height:100%}
.sd-lines .sdl{stroke:rgba(255,255,255,.05);stroke-width:1}
.sd-lines .sdl-red{stroke:url(#schedRed);stroke-width:2;fill:none;stroke-dasharray:160 1500;animation:streakA 14s linear infinite}
.sd-watermark{position:absolute;right:-1%;bottom:-5%;font-family:var(--font-display);font-size:clamp(6rem,16vw,14rem);line-height:.8;color:rgba(255,255,255,.022);letter-spacing:.02em;user-select:none}
.sd-dots{position:absolute;left:3%;top:30%;width:130px;height:110px;background-image:radial-gradient(rgba(255,255,255,.14) 1.4px,transparent 1.4px);background-size:20px 20px;opacity:.5;-webkit-mask-image:radial-gradient(circle at 30% 40%,#000,transparent 75%);mask-image:radial-gradient(circle at 30% 40%,#000,transparent 75%)}
.sd-ring{position:absolute;right:5%;top:16%;width:170px;height:170px;border-radius:50%;border:1px dashed rgba(239,20,44,.2);animation:spin 60s linear infinite}
.sd-shape{position:absolute;left:6%;bottom:14%;width:92px;height:92px;border:1px solid rgba(255,255,255,.08);border-radius:18px;transform:rotate(16deg);animation:floatB 18s ease-in-out infinite}
.sd-particles{position:absolute;inset:0;overflow:hidden}
.sd-particles i{position:absolute;bottom:-10px;width:4px;height:4px;border-radius:50%;background:rgba(239,20,44,.5);box-shadow:0 0 8px rgba(239,20,44,.5);opacity:0;animation-name:rise;animation-timing-function:linear;animation-iteration-count:infinite}
.sd-particles i.w{width:3px;height:3px;background:rgba(255,255,255,.55);box-shadow:0 0 7px rgba(255,255,255,.35)}

.sched .container{position:relative;z-index:2}
.sched-head{text-align:center;max-width:680px;margin:0 auto clamp(26px,3vw,38px)}

/* dropdown filter */
.sched-filter{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;margin-bottom:clamp(36px,4vw,52px)}
.sched-filter label{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;font-weight:600;color:var(--muted)}
.sched-select{appearance:none;-webkit-appearance:none;background:var(--navy-800) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%23ef142c' stroke-width='2.5'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 16px center;border:1px solid var(--line-strong);color:#fff;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;font-weight:600;font-size:.82rem;padding:.95em 3em .95em 1.2em;border-radius:12px;cursor:pointer;min-width:260px;transition:border-color .25s var(--ease),box-shadow .25s var(--ease)}
.sched-select:hover{border-color:#fff}
.sched-select:focus{outline:0;border-color:var(--red);box-shadow:0 0 0 3px rgba(239,20,44,.18)}
.sched-select option{background:var(--navy-900);color:#fff}

.sched .center .lead{color:var(--muted-2)}
@media(prefers-reduced-motion:reduce){.sd-glow,.sd-lines .sdl-red,.sd-ring,.sd-shape,.sd-particles i{animation:none}}

/* ---------- Why Prodigy — LIGHT MODE ---------- */

/* ---------- Why Prodigy — LIGHT MODE ---------- */
.why-light{background:#f4f2ef;color:#17202C;position:relative}
.why-light .section-title{color:#17202C}
.why-light .lead{color:#55535b}
.why-head{display:grid;grid-template-columns:1.22fr .78fr;gap:clamp(30px,5vw,64px);align-items:center;margin-bottom:clamp(34px,5vw,58px)}
.why-figure{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 34px 64px -32px rgba(13,17,23,.45)}
.why-figure img{width:100%;height:clamp(260px,30vw,320px);object-fit:cover;object-position:center 26%;display:block;transition:transform .9s var(--ease)}
.why-figure:hover img{transform:scale(1.05)}
.why-tag{position:absolute;left:16px;bottom:16px;background:var(--red);color:#fff;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;font-weight:600;padding:10px 14px;border-radius:10px;box-shadow:0 12px 24px -10px rgba(239,20,44,.7)}

.why-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.wc{position:relative;background:#fff;border:1px solid rgba(13,17,23,.08);border-radius:16px;padding:30px 26px 28px;overflow:hidden;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease)}
.wc::before{content:"";position:absolute;left:0;top:0;height:4px;width:0;background:var(--red);transition:width .45s var(--ease)}
.wc:hover{transform:translateY(-8px);box-shadow:0 32px 54px -26px rgba(13,17,23,.4);border-color:transparent}
.wc:hover::before{width:100%}
.wc-no{position:absolute;right:16px;top:2px;font-family:var(--font-display);font-size:3.6rem;line-height:1;color:rgba(13,17,23,.06)}
.wc-ic{width:50px;height:50px;border-radius:12px;background:rgba(239,20,44,.10);color:var(--red);display:grid;place-items:center;margin-bottom:18px}
.wc-ic svg{width:25px;height:25px}
.wc h3{font-family:var(--font-head);font-weight:600;font-size:1.16rem;text-transform:none;color:#17202C;letter-spacing:.01em;line-height:1.15}
.wc p{color:#5d5a5e;font-size:.92rem;margin-top:10px}
.wc-cta{background:#17202C;color:#fff;text-decoration:none;display:flex;flex-direction:column}
.wc-cta::before{background:var(--red)}
.wc-cta .wc-ic{background:rgba(239,20,44,.2)}
.wc-cta h3{color:#fff}
.wc-cta p{color:#c3cad6}
.wc-cta .cta-go{display:block;margin-top:12px;color:#ff8a96;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;font-weight:600;transition:transform .35s var(--ease)}
.wc-cta:hover{transform:translateY(-8px);box-shadow:0 32px 54px -22px rgba(0,0,0,.6)}
.wc-cta:hover .cta-go{transform:translateX(5px)}

@media(max-width:980px){
  .why-head{grid-template-columns:1fr;gap:30px}
  .why-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .why-cards{grid-template-columns:1fr}
}

/* ---------- Location (programmatic SEO) pages ---------- */
.loc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.loc-card{position:relative;display:flex;flex-direction:column;background:var(--navy-900);border:1px solid var(--line);border-radius:16px;overflow:hidden;text-decoration:none;color:#fff;transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease)}
.loc-card::before{content:"";position:absolute;left:0;top:0;height:4px;width:0;background:var(--red);transition:width .45s var(--ease);z-index:2}
.loc-card:hover{transform:translateY(-7px);border-color:var(--line-strong);box-shadow:0 32px 56px -28px rgba(0,0,0,.7)}
.loc-card:hover::before{width:100%}
.loc-card .lc-ic{width:44px;height:44px;border-radius:11px;background:rgba(239,20,44,.12);color:var(--red);display:grid;place-items:center;margin-bottom:14px}
.loc-card .lc-ic svg{width:22px;height:22px}
.loc-card-body{padding:26px}
.loc-card h3{font-family:var(--font-head);font-weight:600;font-size:1.2rem;text-transform:none;color:#fff}
.loc-card p{color:var(--muted);font-size:.92rem;margin-top:8px;line-height:1.6}
.loc-card .lc-go{display:inline-flex;align-items:center;gap:.5em;margin-top:14px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.13em;font-size:.74rem;font-weight:600;color:#fff}
.loc-card .lc-go .arr{color:var(--red);transition:transform .35s var(--ease)}
.loc-card:hover .lc-go .arr{transform:translateX(6px)}

.areas-serve{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.areas-serve a{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;font-weight:600;color:var(--muted-2);background:rgba(255,255,255,.05);border:1px solid var(--line);padding:.55em .95em;border-radius:999px;text-decoration:none;transition:all .3s var(--ease)}
.areas-serve a:hover{color:#fff;border-color:var(--red);background:rgba(239,20,44,.12)}
.areas-serve a[aria-current="page"]{color:#fff;background:var(--red);border-color:var(--red)}

.faq-list{display:grid;gap:14px}
.faq-item{background:var(--navy-900);border:1px solid var(--line);border-radius:14px;padding:22px 24px}
.faq-item h3{font-family:var(--font-head);font-weight:600;font-size:1.08rem;text-transform:none;color:#fff}
.faq-item p{color:var(--muted-2);margin-top:8px;line-height:1.65}

@media(max-width:900px){.loc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.loc-grid{grid-template-columns:1fr}}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .programs{grid-template-columns:repeat(2,1fr)}
  .prog.span-3,.prog.span-2{grid-column:span 1}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:820px){
  .nav-links{display:none}
  .nav-cta .btn{display:none}
  .nav-toggle{display:flex}
  .split,.split.rev,.coach-lead,.loc{grid-template-columns:1fr}
  .split.rev .split-media{order:-1}
  .feats,.grid-3,.coach-grid,.statband{grid-template-columns:1fr 1fr}
  .form .row{grid-template-columns:1fr}
  .split-media .badge{left:14px}
}
@media(max-width:560px){
  .programs,.feats,.grid-3,.grid-2,.coach-grid{grid-template-columns:1fr}
  .statband{grid-template-columns:1fr 1fr;gap:34px 20px}
  .hero h1{font-size:clamp(2.5rem,11vw,3.4rem)}
  .loc .map iframe,.loc .map{min-height:320px}
  .footer-grid{grid-template-columns:1fr}
}

/* =========================================================
   TYPOGRAPHY & SPACING REFINEMENTS (site-wide)
   ========================================================= */
/* readable measure for body copy */
.prose p,.intro2-copy p,.coach-lead .prose p{max-width:60ch}
.lead{line-height:1.62}
.prose p,.intro2-copy p{line-height:1.7}

/* consistent rhythm: eyebrow → heading → body */
.eyebrow{margin-bottom:15px;line-height:1.4}
.section-title{margin:0}
.prose .section-title+p,.intro2-copy .section-title+p{margin-top:20px}

/* card & component text breathing room */
.wc p,.feat p,.coach-info p,.pa-content p,.prog p{line-height:1.6}
.wc h3,.feat h3,.coach-info h3{line-height:1.25}
.coach-info p{margin-top:12px}
.crow .v{line-height:1.45}
.footer-links a,.footer-contact{line-height:1.55}
.footer-about{line-height:1.7}

/* refined nav + button spacing */
.nav-links{gap:36px}
.nav-links a{letter-spacing:.14em}
.btn{letter-spacing:.13em;line-height:1.1;text-align:center}
.mobile-menu a{padding-block:.5em}

/* tablet rhythm */
@media(max-width:860px){
  .section{padding-block:clamp(58px,8vw,92px)}
  .lead{max-width:60ch}
}

/* mobile readability */
@media(max-width:560px){
  body{line-height:1.62}
  .section{padding-block:52px}
  .container{--pad:22px}
  .eyebrow{letter-spacing:.24em;font-size:.68rem}
  .xhero-title{font-size:clamp(2.4rem,9.5vw,3.3rem);line-height:.98}
  .section-title{font-size:clamp(1.95rem,7.6vw,2.5rem);line-height:1.04}
  .cta-band h2{font-size:clamp(2rem,8vw,2.6rem);line-height:1.02}
  .pa-content h3{font-size:1.5rem}
  .lead,.prose p,.intro2-copy p{font-size:1rem;line-height:1.62}
  .hero-actions,.cta-actions{gap:12px}
  .hero-actions .btn,.cta-actions .btn{width:100%;justify-content:center}
  .xhero-proof{align-items:flex-start;gap:10px}
  .intro2-stats{gap:18px 26px}
}

/* ================= NAVIGATION REDESIGN ================= */
/* Smooth, GPU-cheap scroll state: a slim SOLID bar — no backdrop blur, no width/padding morph */
/* Solid by default so the nav is always legible; only the homepage hero shows it transparent. */
.site-header{background:#10161f;border-bottom:1px solid var(--line);transition:background .28s var(--ease),box-shadow .28s var(--ease),border-color .28s var(--ease)}
body.home .site-header:not(.scrolled){background:transparent;border-bottom-color:transparent}
.nav{position:relative;height:86px;transition:height .28s var(--ease)}
.brand img{transition:height .28s var(--ease)}
.site-header.scrolled{background:#10161f;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom-color:var(--line);box-shadow:0 12px 30px -18px rgba(0,0,0,.7)}
.site-header.scrolled .nav{height:64px}
.site-header.scrolled .nav::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,transparent,rgba(239,20,44,.7),transparent)}
.site-header.scrolled .brand img{height:34px}

/* glass pill nav rail */
.nav-links{gap:6px;background:transparent;border:0;border-radius:0;padding:0;box-shadow:none}
.nav-links a{position:relative;padding:.62em 1.05em;border-radius:999px;color:var(--muted-2);font-size:.78rem;letter-spacing:.13em;transition:color .25s var(--ease),background .25s var(--ease)}
.nav-links a::after{content:"";position:absolute;left:50%;bottom:6px;transform:translateX(-50%);width:0;height:5px;border-radius:50%;background:var(--red);box-shadow:0 0 9px rgba(239,20,44,.85);transition:width .25s var(--ease)}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav-links a:hover::after{width:5px}
.nav-links a[aria-current="page"]{color:#fff;background:rgba(239,20,44,.18);box-shadow:inset 0 0 0 1px rgba(239,20,44,.4)}
.nav-links a[aria-current="page"]::after{width:5px}
.nav-cta .btn-primary{box-shadow:0 14px 28px -14px rgba(239,20,44,.85)}

/* scroll progress bar */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;background:rgba(255,255,255,.04);pointer-events:none}
.scroll-progress span{display:block;height:100%;width:100%;transform:scaleX(0);transform-origin:left center;will-change:transform;background:linear-gradient(90deg,#EF152E,#ff5a68);box-shadow:0 0 12px rgba(239,20,44,.8)}

/* mobile menu contact + social footer (injected by JS) */
.mm-foot{position:relative;z-index:1;margin-top:26px;padding-top:22px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:14px}
.mm-foot .mm-contact{display:flex;flex-direction:column;gap:6px}
.mm-foot .mm-line{color:var(--muted-2);font-family:var(--font-head);letter-spacing:.04em;font-size:.95rem;text-decoration:none;transition:color .25s var(--ease)}
.mm-foot .mm-line:hover{color:var(--red)}
.mm-foot .mm-social{display:flex;gap:12px}
.mm-foot .mm-social a{width:44px;height:44px;border-radius:11px;border:1px solid var(--line-strong);display:grid;place-items:center;color:#fff;transition:transform .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease)}
.mm-foot .mm-social a:hover{background:var(--red);border-color:var(--red);transform:translateY(-3px)}
.mm-foot .mm-social svg{width:20px;height:20px}
@media(prefers-reduced-motion:reduce){.scroll-progress span{transition:none}}

/* =====================================================
   LEAD-CAPTURE MODAL — 2-step light form
   ===================================================== */
.pmodal{position:fixed;inset:0;z-index:500;display:flex;align-items:flex-start;justify-content:center;
  padding:clamp(10px,2.4vh,22px) clamp(14px,4vw,44px);visibility:hidden;pointer-events:none;overflow-y:auto}
.pmodal.open,.pmodal.closing{visibility:visible;pointer-events:auto}
.pmodal-overlay{position:fixed;inset:0;background:rgba(9,12,18,.74);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;transition:opacity .3s var(--ease)}
.pmodal.open .pmodal-overlay{opacity:1}

.pmodal-card{position:relative;width:100%;max-width:620px;margin:auto;overflow:hidden;
  background:linear-gradient(158deg,#fdfcfb 0%,#f7f3f2 60%,#f2eeed 100%);
  border:1px solid rgba(23,32,44,.10);border-radius:22px;color:var(--navy);
  box-shadow:0 50px 100px -34px rgba(0,0,0,.72);
  opacity:0;transform:translateY(18px) scale(.985);transition:opacity .34s var(--ease),transform .34s var(--ease)}
.pmodal.open .pmodal-card{opacity:1;transform:none}
.pmodal-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;z-index:3;
  background:linear-gradient(90deg,#b30d1f,var(--red) 42%,#ff5566)}

.pm-glow{position:absolute;border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(circle,rgba(239,20,44,.16),rgba(239,20,44,0) 70%)}
.pm-glow-1{top:-120px;right:-120px;width:360px;height:360px}
.pm-glow-2{bottom:-150px;left:-140px;width:340px;height:340px;
  background:radial-gradient(circle,rgba(239,20,44,.10),rgba(239,20,44,0) 70%)}
.pm-watermark{position:absolute;right:-6px;bottom:-16px;z-index:0;pointer-events:none;
  font-family:var(--font-display);font-size:6rem;line-height:1;letter-spacing:.02em;
  color:rgba(23,32,44,.045);white-space:nowrap}

.pmodal-x{position:absolute;top:16px;right:16px;z-index:4;width:42px;height:42px;display:grid;place-items:center;
  border:0;border-radius:50%;background:var(--navy);color:#fff;cursor:pointer;
  transition:background .25s var(--ease),transform .3s var(--ease)}
.pmodal-x:hover{background:var(--red);transform:rotate(90deg)}
.pmodal-x svg{width:18px;height:18px}

.pm-body{position:relative;z-index:2;padding:clamp(20px,2.6vw,30px)}

/* header */
.pm-logo{display:block;height:42px;width:auto;margin-bottom:13px}
.pm-eyebrow{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.2em;
  font-size:.68rem;font-weight:600;color:var(--red);margin-bottom:8px}
.pm-head h2{font-family:var(--font-display);font-size:clamp(1.6rem,3.4vw,2.15rem);line-height:1;
  letter-spacing:.005em;text-transform:uppercase;color:var(--navy)}
.pm-sub{margin-top:8px;max-width:52ch;font-size:.9rem;line-height:1.45;color:#4c5563}
.pm-note{display:flex;margin-top:12px;border-radius:12px;overflow:hidden;
  background:var(--navy);box-shadow:0 14px 30px -18px rgba(23,32,44,.6)}
.pm-note::before{content:"";flex:0 0 5px;background:var(--red)}
.pm-note p{padding:10px 15px;font-family:var(--font-head);font-weight:500;font-size:.85rem;line-height:1.38;color:#fff}

/* progress */
.pm-progress{margin:15px 0 15px}
.pm-progress-top{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px}
.pm-step-label{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.68rem;font-weight:600;color:#5b6472}
.pm-pct{font-family:var(--font-head);font-weight:700;font-size:.8rem;color:var(--red)}
.pm-bar{height:6px;border-radius:99px;background:rgba(23,32,44,.10);overflow:hidden}
.pm-bar span{display:block;height:100%;width:0;border-radius:99px;
  background:linear-gradient(90deg,var(--red),#ff5566);transition:width .4s var(--ease)}

/* form + steps */
.pm-form{position:relative}
.pm-hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden;opacity:0}
.pm-step{display:flex;flex-direction:column;gap:13px}
.pm-step[hidden]{display:none}

.pm-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.pm-field{display:flex;flex-direction:column;gap:5px}
.pm-field label{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.11em;font-size:.66rem;font-weight:600;color:#5b6472}
.pm-field input{height:48px;padding:0 16px;border-radius:12px;border:1.5px solid rgba(23,32,44,.14);
  background:#fff;color:var(--navy);font-family:var(--font-body);font-size:1rem;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.pm-field input::placeholder{color:#aab0b8}
.pm-field input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(239,20,44,.13)}
.pm-field input.ok{border-color:rgba(30,160,90,.55)}

/* program / choice cards */
.pm-progs{display:flex;flex-direction:column;gap:8px}
.pm-progs-label{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.11em;font-size:.66rem;font-weight:600;color:#5b6472}
.pm-progs-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pm-prog-card{display:flex;align-items:center;gap:12px;text-align:left;cursor:pointer;
  padding:10px 13px;border-radius:14px;border:1.5px solid rgba(23,32,44,.12);background:#fff;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),transform .2s var(--ease)}
.pm-prog-card:hover{border-color:rgba(23,32,44,.3);transform:translateY(-1px)}
.pm-prog-ic{flex:0 0 auto;width:40px;height:40px;display:grid;place-items:center;border-radius:11px;background:var(--navy);color:#fff;
  transition:background .2s var(--ease)}
.pm-prog-ic svg{width:21px;height:21px}
.pm-prog-txt{display:flex;flex-direction:column;gap:2px;min-width:0}
.pm-prog-txt strong{font-family:var(--font-head);font-weight:600;font-size:.94rem;line-height:1.15;color:var(--navy)}
.pm-prog-txt em{font-style:normal;font-size:.79rem;color:#5b6472}
.pm-prog-card[aria-checked="true"]{border-color:var(--red);background:rgba(239,20,44,.05);box-shadow:0 0 0 3px rgba(239,20,44,.14)}
.pm-prog-card[aria-checked="true"] .pm-prog-ic{background:var(--red)}
.pm-prog-card:focus-visible{outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(239,20,44,.2)}

/* consents */
.pm-consents{display:flex;flex-direction:column;gap:9px;padding-top:0}
.pm-check{display:flex;gap:10px;cursor:pointer;align-items:flex-start}
.pm-check input{position:absolute;opacity:0;width:0;height:0}
.pm-box{flex:0 0 auto;width:19px;height:19px;margin-top:1px;border-radius:6px;border:1.5px solid rgba(23,32,44,.3);
  background:#fff;display:grid;place-items:center;transition:border-color .18s var(--ease),background .18s var(--ease)}
.pm-box::after{content:"";width:10px;height:6px;margin-top:-2px;border-left:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(-45deg) scale(0);transition:transform .18s var(--ease)}
.pm-check input:checked+.pm-box{background:var(--red);border-color:var(--red)}
.pm-check input:checked+.pm-box::after{transform:rotate(-45deg) scale(1)}
.pm-check input:focus-visible+.pm-box{box-shadow:0 0 0 4px rgba(239,20,44,.2)}
.pm-ctext{font-size:.72rem;line-height:1.4;color:#5b6472}

/* step 2 — time preference + recap */
.pm-recap{display:flex;align-items:center;gap:10px;padding:11px 15px;border-radius:12px;
  background:rgba(23,32,44,.05);font-size:.88rem;line-height:1.4;color:#4c5563}
.pm-recap strong{color:var(--navy)}
.pm-times{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pm-time{padding:12px 15px;border-radius:14px;border:1.5px solid rgba(23,32,44,.12);background:#fff;cursor:pointer;text-align:left;
  font-family:var(--font-head);font-weight:600;font-size:.92rem;color:var(--navy);
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),transform .2s var(--ease)}
.pm-time:hover{border-color:rgba(23,32,44,.3);transform:translateY(-1px)}
.pm-time small{display:block;margin-top:3px;font-family:var(--font-body);font-weight:400;font-size:.78rem;color:#5b6472}
.pm-time[aria-checked="true"]{border-color:var(--red);background:rgba(239,20,44,.05);box-shadow:0 0 0 3px rgba(239,20,44,.14)}
.pm-time:focus-visible{outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(239,20,44,.2)}

/* actions */
.pm-actions{display:flex;gap:12px;align-items:center;margin-top:2px}
.pm-submit{flex:1;height:52px;border:0;border-radius:13px;cursor:pointer;background:var(--red);color:#fff;
  font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-weight:700;font-size:.92rem;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;box-shadow:0 18px 34px -14px rgba(239,20,44,.7);
  transition:background .25s var(--ease),transform .25s var(--ease),opacity .25s var(--ease)}
.pm-submit .arr{transition:transform .3s var(--ease)}
.pm-submit:not(:disabled):hover{background:var(--red-dark);transform:translateY(-2px)}
.pm-submit:not(:disabled):hover .arr{transform:translateX(4px)}
.pm-submit:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}
.pm-back{flex:0 0 auto;height:52px;padding:0 22px;border-radius:13px;cursor:pointer;background:transparent;
  border:1.5px solid rgba(23,32,44,.18);color:var(--navy);font-family:var(--font-head);text-transform:uppercase;
  letter-spacing:.08em;font-weight:600;font-size:.82rem;transition:border-color .2s var(--ease),background .2s var(--ease)}
.pm-back:hover{border-color:var(--navy);background:rgba(23,32,44,.04)}
.pm-msg{margin:9px 0 0;font-size:.84rem;color:#c30f22;text-align:center;display:none}
.pm-msg.show{display:block}

@media(max-width:560px){
  .pm-grid,.pm-progs-grid,.pm-times{grid-template-columns:1fr}
  .pm-head h2{font-size:2rem}
  .pm-watermark{font-size:4rem}
}
@media(prefers-reduced-motion:reduce){
  .pmodal-overlay,.pmodal-card,.pm-bar span{transition:none!important}
  .pmodal-card{opacity:1!important;transform:none!important}
  .pmodal-x:hover{transform:none}
}

/* =====================================================
   BOOKING PAGE (funnel — final step)
   ===================================================== */
.book-wrap{position:relative;overflow:hidden;padding:clamp(96px,12vh,140px) 0 clamp(60px,8vh,90px);background:linear-gradient(170deg,#0f1622 0%,#141d2c 46%,#17202C 100%);isolation:isolate}
.phero + .book-wrap{padding-top:clamp(40px,6vh,68px)}
.book-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.book-fx .bk-glow{position:absolute;border-radius:50%;filter:blur(70px)}
.book-fx .bk-glow-1{width:520px;height:520px;top:-180px;right:-120px;background:radial-gradient(circle,rgba(239,20,44,.5),transparent 66%);opacity:.6;animation:pmFloat 12s ease-in-out infinite}
.book-fx .bk-glow-2{width:420px;height:420px;bottom:-160px;left:-120px;background:radial-gradient(circle,rgba(239,20,44,.28),transparent 70%);opacity:.5;animation:pmFloat 15s ease-in-out infinite reverse}
.book-fx .bk-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:42px 42px;mask:radial-gradient(120% 80% at 50% 0%,#000,transparent 76%);-webkit-mask:radial-gradient(120% 80% at 50% 0%,#000,transparent 76%)}
.book-fx .bk-word{position:absolute;bottom:-30px;left:50%;transform:translateX(-50%);font-family:var(--font-display);font-size:clamp(8rem,22vw,18rem);line-height:.8;color:rgba(255,255,255,.025);letter-spacing:.02em;white-space:nowrap}
.book-wrap .container{position:relative;z-index:1}

/* "not done yet" alert — unmistakable */
.book-alert{position:relative;display:flex;align-items:center;gap:16px;max-width:760px;margin:0 auto 30px;padding:18px 22px;border-radius:16px;background:linear-gradient(120deg,rgba(239,20,44,.16),rgba(239,20,44,.06));border:1px solid rgba(239,20,44,.4);box-shadow:0 24px 50px -26px rgba(239,20,44,.7),inset 0 1px 0 rgba(255,255,255,.06);overflow:hidden}
.book-alert::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,#ff4256,#c70f23)}
.book-alert .bk-pulse{flex:none;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;color:#fff;background:linear-gradient(150deg,#EF152E,#ff4256);box-shadow:0 0 0 0 rgba(239,20,44,.55);animation:bkPulse 2s var(--ease) infinite}
.book-alert .bk-pulse svg{width:24px;height:24px}
@keyframes bkPulse{0%{box-shadow:0 0 0 0 rgba(239,20,44,.55)}70%{box-shadow:0 0 0 16px rgba(239,20,44,0)}100%{box-shadow:0 0 0 0 rgba(239,20,44,0)}}
.book-alert-tx{min-width:0}
.book-alert-tx b{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.04em;font-size:1.02rem;color:#fff;line-height:1.15}
.book-alert-tx span{display:block;margin-top:3px;color:var(--muted-2);font-size:.88rem;line-height:1.45}
.book-alert .bk-step{flex:none;margin-left:auto;align-self:flex-start;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.6rem;font-weight:600;color:var(--red);background:rgba(239,20,44,.12);border:1px solid rgba(239,20,44,.35);border-radius:999px;padding:5px 11px;white-space:nowrap}

.book-head{text-align:center;max-width:680px;margin:0 auto 26px}
.book-head .eyebrow{justify-content:center}
.book-head h1{font-family:var(--font-display);font-size:clamp(2.1rem,4.6vw,3.2rem);text-transform:uppercase;line-height:1;margin-top:12px}
.book-head h1 em{font-style:normal;color:var(--red)}
.book-prog-pill{display:inline-flex;align-items:center;gap:9px;margin-top:16px;padding:9px 16px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid var(--line-strong);font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;color:#fff}
.book-prog-pill::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 10px rgba(239,20,44,.9)}
.book-greet{margin-top:12px;color:var(--muted-2);font-size:.95rem}
.book-greet b{color:#fff}

/* back-to-chooser link */
.book-back{max-width:820px;margin:0 auto clamp(16px,2.4vw,24px)}
.book-back a{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;font-weight:600;color:var(--muted-2);text-decoration:none;padding:9px 15px;border:1px solid var(--line-strong);border-radius:999px;background:rgba(255,255,255,.04);transition:color .25s var(--ease),border-color .25s var(--ease),transform .25s var(--ease)}
.book-back a svg{width:16px;height:16px}
.book-back a:hover{color:#fff;border-color:var(--red);transform:translateX(-3px)}

/* class chooser cards */
.cc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);max-width:1040px;margin:clamp(10px,2vw,20px) auto 0}
.cc-card{position:relative;display:flex;flex-direction:column;border-radius:20px;overflow:hidden;background:linear-gradient(160deg,#141d2c,#0f1622);border:1px solid var(--line-strong);text-decoration:none;color:#fff;box-shadow:0 36px 70px -36px rgba(0,0,0,.8);transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease)}
.cc-card:hover{transform:translateY(-7px);border-color:rgba(239,20,44,.55);box-shadow:0 48px 84px -36px rgba(0,0,0,.85),0 0 34px -8px rgba(239,20,44,.4)}
.cc-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.cc-img img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.cc-card:hover .cc-img img{transform:scale(1.06)}
.cc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(15,22,34,.85));pointer-events:none}
.cc-body{position:relative;padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.cc-tag{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.6rem;font-weight:600;color:var(--red)}
.cc-name{font-family:var(--font-display);font-size:1.7rem;text-transform:uppercase;line-height:1;margin-top:8px}
.cc-desc{color:var(--muted-2);font-size:.9rem;line-height:1.6;margin-top:10px;flex:1}
.cc-go{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;font-weight:600;color:#fff}
.cc-go i{font-style:normal;color:var(--red);transition:transform .3s var(--ease)}
.cc-card:hover .cc-go i{transform:translateX(5px)}
@media(max-width:860px){.cc-grid{grid-template-columns:1fr;max-width:460px}}

/* calendar card */
.book-cal{position:relative;max-width:820px;margin:0 auto;border-radius:22px;background:#fff;padding:10px;box-shadow:0 50px 100px -34px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.06);overflow:hidden}
.book-cal::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#c70f23,#EF152E,#ff6472);z-index:2}
.book-cal-inner{position:relative;border-radius:16px;overflow:hidden;min-height:640px;background:#fff}
.book-cal-inner iframe{width:100%;min-height:640px;border:0;display:block}
.book-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:#5a6473;font-family:var(--font-head);letter-spacing:.05em;text-transform:uppercase;font-size:.8rem}
.book-loading .bk-spin{width:36px;height:36px;border-radius:50%;border:3px solid #e8eaee;border-top-color:var(--red);animation:spin .9s linear infinite}

.book-help{text-align:center;margin-top:24px;color:var(--muted-2);font-size:.92rem}
.book-help a{color:#fff;font-family:var(--font-head);letter-spacing:.04em;text-decoration:none;border-bottom:2px solid rgba(239,20,44,.6)}
.book-help a:hover{color:var(--red)}

.book-reassure{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 26px;margin:22px auto 0;max-width:760px}
.book-reassure li{list-style:none;display:flex;align-items:center;gap:8px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.05em;font-size:.74rem;color:var(--muted-2)}
.book-reassure .bk-tick{flex:none;width:18px;height:18px;border-radius:50%;display:grid;place-items:center;background:rgba(239,20,44,.16);border:1px solid rgba(239,20,44,.4);color:var(--red)}
.book-reassure svg{width:10px;height:10px}

@media(max-width:600px){
  .book-alert{flex-wrap:wrap;gap:12px}
  .book-alert .bk-step{margin-left:0;order:3;width:100%}
  .book-cal{padding:7px}
  .book-cal-inner,.book-cal-inner iframe{min-height:560px}
}
@media(prefers-reduced-motion:reduce){
  .book-fx .bk-glow,.book-alert .bk-pulse{animation:none!important}
}

/* =====================================================
   PERFORMANCE PASS — smoother scrolling, lighter paint
   The decorative glows already use soft, low-alpha radial
   gradients, so the heavy filter:blur() layered on top was
   redundant and the single biggest paint cost. We drop the
   blur, stop continuously re-compositing those large layers,
   and remove scroll-time backdrop-filter from small overlays.
   ===================================================== */

/* 1 — kill the redundant 70–90px blur on all gradient glows + stop them animating */
[class*="glow"]{filter:none!important;-webkit-filter:none!important;animation:none!important}

/* 2 — Muay-Thai smoke: drop the expensive blur (gradient stays soft) */
.mt-smoke{filter:none!important;-webkit-filter:none!important}

/* 3 — glass badges/labels sit over images and re-blur every scroll frame;
       a solid dark tint reads almost identically for far less cost */
.chip,.spin-badge,.cu-badge,.cx-badge,.v2-badge,.s2-quote,.v-maplabel,
.phero-media .pm-badge{
  backdrop-filter:none!important;-webkit-backdrop-filter:none!important;
  background:rgba(11,16,23,.92)!important
}
.mf-plate .pills span{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}

/* 4 — hint the compositor for the few elements that DO animate transforms */
.strip-track,.commx-track{will-change:transform}

/* 5 — phones: the ambient gradient layers add cost for little payoff; hide them
       and disable the looping badge/ring motion so scrolling stays buttery */
@media(max-width:760px){
  [class*="glow"],[class*="-fx"] [class*="ring"],[class*="-fx"] [class*="dots"]{display:none!important}
  .spin-badge,.cu-badge,.cx-badge,.v2-badge,.phero-media .pm-badge{animation:none!important}
}

/* 6 — fully honour reduced-motion: neutralise every animation/transition site-wide */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important
  }
  .reveal{opacity:1!important;transform:none!important}
}

/* =====================================================
   TRAINING BOARD — schedule redesign (dark headers + warm light bodies)
   ===================================================== */
.tb-stack{display:flex;flex-direction:column;gap:22px}
.tboard{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
  --c-gi:#3b6fe0;--c-nogi:#13b6a6;--c-kids:#f59e0b;--c-mt:#ef4444;--c-comp:#a855f7}

.tb-day{position:relative;border-radius:20px;overflow:hidden;background:#f5f2ec;border:1px solid var(--line);box-shadow:0 30px 60px -30px rgba(0,0,0,.6);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.tb-day:hover{transform:translateY(-5px);box-shadow:0 44px 74px -30px rgba(0,0,0,.7)}
.tb-day.hide{display:none}
.tb-day.is-today{box-shadow:0 30px 60px -30px rgba(0,0,0,.6),0 0 0 2px var(--red),0 0 28px -6px rgba(239,20,44,.5)}

/* dark day header */
.tb-head{width:100%;display:flex;align-items:center;gap:14px;padding:18px 20px;border:0;text-align:left;color:#fff;cursor:default;position:relative;overflow:hidden;
  background:linear-gradient(135deg,#1f2c49 0%,#141d33 55%,#2a1320 100%);box-shadow:inset 0 -2px 0 rgba(239,20,44,.55)}
.tb-head::after{content:"";position:absolute;inset:0;pointer-events:none;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.035) 0 1px,transparent 1px 22px);opacity:.6}
.tb-headl{position:relative;display:flex;flex-direction:column;gap:3px}
.tb-dow{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.22em;font-size:.58rem;font-weight:600;color:var(--red)}
.tb-day.is-today .tb-dow::after{content:" • Today";color:#fff}
.tb-dayname{font-family:var(--font-display);font-size:1.5rem;line-height:.86;letter-spacing:.01em}
.tb-meta{position:relative;margin-left:auto;display:flex;align-items:center;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:.58rem;color:var(--muted-2)}
.tb-meta b{display:inline-grid;place-items:center;min-width:24px;height:24px;padding:0 7px;margin-right:7px;border-radius:999px;background:linear-gradient(135deg,var(--red),#a30d1c);color:#fff;font-family:var(--font-display);font-size:.82rem;box-shadow:0 6px 14px -6px rgba(239,20,44,.7)}
.tb-chev{position:relative;flex:none;width:20px;height:20px;color:#fff;opacity:.85;display:none;transition:transform .35s var(--ease)}

/* accordion body (open on desktop, collapsible on mobile) */
.tb-body{display:grid;grid-template-rows:1fr}
.tb-sessions{overflow:hidden;min-height:0;background-color:#f3efe8;background-image:radial-gradient(rgba(23,32,47,.05) 1px,transparent 1px);background-size:16px 16px;box-shadow:inset 0 1px 0 rgba(255,255,255,.6)}

.tb-session{padding:15px 18px 7px}
.tb-session+.tb-session{border-top:1px solid rgba(23,32,47,.09)}
.tb-session.hide{display:none}
.tb-slabel{display:flex;align-items:center;gap:9px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;font-weight:600;color:#39434f;margin-bottom:4px}
.tb-sic{flex:none;width:12px;height:12px;border-radius:50%;background:#aab2c0}
.tb-sun{background:#c9a45c}
.tb-aft{background:#c08f5b}
.tb-moon{background:#8a93a8}

.tb-list{list-style:none;display:flex;flex-direction:column;gap:2px}
.tb-class{position:relative;display:flex;align-items:center;gap:13px;padding:12px 8px 12px 16px;border-radius:12px;transition:background .25s var(--ease),transform .25s var(--ease),box-shadow .25s var(--ease)}
.tb-class::before{content:"";position:absolute;left:0;top:11px;bottom:11px;width:3px;border-radius:3px;background:rgba(23,32,47,.16)}
.tb-class:hover::before,.tb-day.is-today .tb-class::before{background:rgba(239,20,44,.55)}
.tb-class:hover{background:#fff;transform:translateX(3px);box-shadow:0 12px 26px -16px rgba(23,32,47,.55)}
.tb-class.hide{display:none}

.tb-time{flex:none;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:76px;padding:8px 9px;border-radius:11px;color:#fff;background:linear-gradient(135deg,var(--red),#c70f23);font-family:var(--font-head);font-weight:600;font-size:.8rem;line-height:1.05;font-variant-numeric:tabular-nums;box-shadow:0 10px 20px -10px rgba(239,20,44,.7)}
.tb-time em{font-style:normal;font-size:.54rem;letter-spacing:.14em;opacity:.9;margin-top:2px}
.tb-info{min-width:0;display:flex;flex-direction:column;gap:6px}
.tb-name{font-family:var(--font-head);font-weight:500;font-size:1rem;line-height:1.25;color:#17202C}
.tb-name small{color:#8a93a1;font-weight:400;font-size:.82rem}
.tb-chip{align-self:flex-start;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;font-size:.56rem;font-weight:600;padding:.36em .72em;border-radius:999px;color:#5a6473;background:rgba(23,32,47,.05);border:1px solid rgba(23,32,47,.16)}

@media(max-width:860px){
  .tboard{grid-template-columns:1fr;gap:13px}
  .tb-stack{gap:13px}
  .tb-head{cursor:pointer}
  .tb-chev{display:block}
  .tb-body{grid-template-rows:0fr;transition:grid-template-rows .42s var(--ease)}
  .tb-day.open .tb-body{grid-template-rows:1fr}
  .tb-day.open .tb-chev{transform:rotate(180deg)}
  .tb-dayname{font-size:1.35rem}
}
@media(max-width:380px){
  .tb-class{gap:10px;padding-left:14px}
  .tb-time{min-width:66px;font-size:.74rem}
}

/* =====================================================
   HOME HERO — static editorial split (Peerless-inspired)
   Intentionally NO animation: no moving lines, no floating
   images, no underline reveal, no tilt/parallax, no particles.
   ===================================================== */
.hhero{
  position:relative;overflow:hidden;color:#fff;
  background:var(--navy);
  border-bottom:1px solid var(--line);
}
/* full-bleed background photo, faded into the navy */
.hhero-bg{position:absolute;inset:0;z-index:0}
.hhero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%;display:block}
.hhero-bg::after{content:"";position:absolute;inset:0;pointer-events:none;background:
  linear-gradient(95deg, rgba(15,22,34,.96) 0%, rgba(15,22,34,.86) 30%, rgba(15,22,34,.5) 58%, rgba(15,22,34,.66) 100%),
  linear-gradient(180deg, rgba(15,22,34,.5) 0%, transparent 24%, rgba(15,22,34,.34) 66%, var(--navy) 100%)}
.hhero-side{position:absolute;right:calc(var(--pad) - 6px);top:50%;transform:translateY(-50%) rotate(180deg);
  writing-mode:vertical-rl;font-family:var(--font-head);font-size:.66rem;letter-spacing:.34em;text-transform:uppercase;
  color:rgba(255,255,255,.5);z-index:2}
.hhero .container{position:relative;z-index:2;display:flex;align-items:center;
  min-height:min(90vh,880px);
  padding-top:calc(78px + clamp(24px,4vw,56px));padding-bottom:clamp(56px,7vw,110px)}
.hhero-copy{max-width:600px}

/* ---- copy ---- */
.hhero-eyebrow{display:inline-flex;align-items:center;gap:.7rem;margin:0 0 22px;
  font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#fff}
.hhero-eyebrow .rule{width:34px;height:2px;background:var(--red);display:inline-block}
.hhero-eyebrow .eb-loc{color:var(--red)}
.hhero-title{font-family:var(--font-display);font-size:clamp(2.9rem,6.6vw,5.6rem);line-height:.94;letter-spacing:.012em;
  text-transform:uppercase;max-width:15ch}
.hhero-title em{font-style:normal;color:var(--red)}
.hhero-lead{margin-top:24px;max-width:48ch;font-size:clamp(1.06rem,1.5vw,1.28rem);line-height:1.6;color:#e2e7ef;text-shadow:0 1px 14px rgba(0,0,0,.45)}
.hhero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hhero-trust{list-style:none;margin:40px 0 0;padding:28px 0 0;border-top:1px solid var(--line-strong);
  display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;max-width:520px}
.hhero-trust li{display:flex;align-items:center;gap:10px;font-size:.92rem;color:#e2e7ef}
.hhero-trust svg{width:16px;height:16px;color:var(--red);flex:none}

/* ---- floating "1st class free" card ---- */
.hhero-card{position:absolute;z-index:3;right:clamp(20px,5vw,64px);bottom:clamp(26px,5vw,52px);
  display:flex;align-items:center;gap:14px;width:min(300px,80%);
  background:rgba(11,16,23,.82);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--line-strong);border-radius:14px;padding:16px 18px;box-shadow:0 30px 60px -28px rgba(0,0,0,.85)}
.hhero-card-dot{flex:none;width:10px;height:10px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px rgba(239,20,44,.18)}
.hhero-card-tx strong{display:block;font-family:var(--font-display);font-size:1.25rem;line-height:1;color:#fff;letter-spacing:.01em}
.hhero-card-tx span{display:block;margin-top:5px;font-size:.76rem;color:var(--muted-2);line-height:1.35}

/* ---- rotating brand seal (circular PRODIGY stamp) ---- */
.hhero-seal{position:absolute;z-index:3;top:clamp(102px,16vh,168px);right:clamp(28px,6vw,92px);
  width:clamp(132px,13vw,180px);aspect-ratio:1;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 36%,#1b2532 0%,#0d131c 78%);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 34px 66px -26px rgba(0,0,0,.9),inset 0 1px 0 rgba(255,255,255,.07),inset 0 0 48px -20px #000}
.hhero-seal::before{content:"";position:absolute;inset:16.5%;border-radius:50%;border:1.5px solid rgba(239,20,44,.62)}
.hhero-seal-text{position:absolute;inset:0;width:100%;height:100%;animation:spin 34s linear infinite}
.hhero-seal-text text{fill:rgba(255,255,255,.88);font-family:var(--font-head);font-weight:600;
  font-size:7.1px;letter-spacing:1.05px;text-transform:uppercase}
.hhero-seal-core{position:relative;z-index:2;width:47%;aspect-ratio:1;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 34%,#f4223a,#cf0a1e);
  box-shadow:0 10px 24px -8px rgba(239,20,44,.85),inset 0 1px 0 rgba(255,255,255,.28)}
.hhero-seal-core img{width:72%;height:auto;display:block;filter:drop-shadow(0 2px 5px rgba(0,0,0,.5))}
@media(max-width:700px){.hhero-seal{display:none}}
@media(prefers-reduced-motion:reduce){.hhero-seal-text{animation:none}}

/* ---- responsive ---- */
@media(max-width:980px){
  .hhero-side{display:none}
  .hhero .container{min-height:0;padding-top:calc(78px + 26px);padding-bottom:clamp(44px,8vw,66px)}
  .hhero-title{max-width:18ch}
  .hhero-bg img{object-position:center 42%}
}
@media(max-width:860px){
  .hhero-card{display:none}
}
@media(max-width:560px){
  .hhero-trust{grid-template-columns:1fr;gap:12px}
  .hhero-cta .btn{width:100%;justify-content:center}
  .hhero-bg::after{background:linear-gradient(180deg, rgba(15,22,34,.72) 0%, rgba(15,22,34,.52) 42%, rgba(15,22,34,.9) 100%)}
}

/* =====================================================
   CALM MODE (2026-07-02)
   Remove constellation-style meshes, flowing/floating lines,
   particles, dot fields, spinning/floating rings, drifting
   glows, bobbing badges, spinning stamps, and heading-underline
   reveals across EVERY section. Keeps static gradients, ghost
   watermark words, accent shapes, and functional spinners/marquees.
   ===================================================== */

/* 1 — hide line / mesh / particle / dot "constellation" overlays site-wide */
[class*="-lines"],
[class*="-particles"],
[class*="dots"],
.x-mesh,
.phero-grid,.p2-grid,.path-grid,.bk-grid{display:none !important}

/* 2 — hide floating / spinning decorative rings */
[class*="-ring"]{display:none !important}

/* 3 — remove the animated underline under highlighted heading words */
.hl::after{display:none !important}

/* 4 — stop spinning circular-text stamps/emblems + mobile-menu ring (keep static) */
[class*="-stamp"] svg,[class*="-emblem"] svg,.spin-badge svg,
.mobile-menu::before{animation:none !important}

/* 5 — neutralise decorative motion keyframes globally (drifting glows,
   smoke, flow lines, node pulse, bobbing, particles, pulse dot, underline).
   NOTE: 'spin' is intentionally NOT touched — the booking loader uses it. */
@keyframes floatGlow{}
@keyframes floatA{}
@keyframes floatB{}
@keyframes driftR{}
@keyframes driftBL{}
@keyframes grainShift{}
@keyframes streakA{}
@keyframes streakB{}
@keyframes nodePulse{}
@keyframes bob{}
@keyframes rise{}
@keyframes pulseA{}
@keyframes pulseB{}
@keyframes pdot{}
@keyframes ulgrow{}

/* =====================================================
   NAV — Programs dropdown (desktop) + mobile programs group
   ===================================================== */
.nav-links .nav-item{position:relative;display:inline-flex;align-items:center}
.nav-drop-trigger{display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.nav-caret{width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg);margin-top:-4px;transition:transform .3s var(--ease)}
.nav-item:hover .nav-caret,.nav-item:focus-within .nav-caret{transform:rotate(-135deg);margin-top:2px}
/* invisible bridge so the menu stays reachable across the gap */
.nav-item:hover::after,.nav-item:focus-within::after{content:"";position:absolute;left:-10px;right:-10px;top:100%;height:18px}
.nav-drop-menu{position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%) translateY(8px);min-width:214px;
  background:rgba(15,22,34,.98);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--line-strong);border-radius:12px;padding:8px;
  box-shadow:0 30px 60px -26px rgba(0,0,0,.75);
  opacity:0;visibility:hidden;transition:opacity .26s var(--ease),transform .26s var(--ease),visibility .26s;z-index:120}
.nav-item:hover .nav-drop-menu,.nav-item:focus-within .nav-drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-drop-menu a{display:block;padding:10px 14px;border-radius:8px;font-family:var(--font-head);text-transform:uppercase;
  letter-spacing:.1em;font-size:.76rem;font-weight:500;color:var(--muted-2);white-space:nowrap;
  transition:background .2s var(--ease),color .2s var(--ease),padding-left .2s var(--ease)}
.nav-drop-menu a::after{display:none}
.nav-drop-menu a:hover{background:rgba(239,20,44,.12);color:#fff;padding-left:18px}

/* mobile menu — compact Programs group */
.m-programs{position:relative;z-index:1;border-bottom:1px solid var(--line);padding:14px 0 16px}
.m-programs-label{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.2em;
  font-size:.66rem;color:var(--muted);margin-bottom:6px}
.m-programs a{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.06em;
  font-size:1.05rem;color:var(--muted-2);padding:8px 0 8px 16px;position:relative;
  transition:color .25s var(--ease),padding-left .25s var(--ease)}
.m-programs a::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:2px;background:var(--red)}
.m-programs a:hover{color:#fff;padding-left:22px}

/* =====================================================
   SCHEDULE HERO (.shero) — static, image-free, calendar-grid motif
   ===================================================== */
.shero{position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(160deg,#1b2434 0%, var(--navy) 52%, #0f1622 100%);border-bottom:1px solid var(--line)}
.shero-grid{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:clamp(64px,7vw,104px) 100%, 100% clamp(64px,7vw,104px);
  -webkit-mask-image:radial-gradient(120% 120% at 16% 18%, #000 6%, transparent 74%);
          mask-image:radial-gradient(120% 120% at 16% 18%, #000 6%, transparent 74%)}
.shero-side{position:absolute;right:calc(var(--pad) - 6px);top:50%;transform:translateY(-50%) rotate(180deg);
  writing-mode:vertical-rl;font-family:var(--font-head);font-size:.64rem;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(255,255,255,.36);z-index:1}
.shero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(34px,5vw,78px);align-items:center;
  padding-top:calc(78px + clamp(30px,5vw,64px));padding-bottom:clamp(48px,6vw,88px);min-height:min(72vh,720px)}
.shero-eyebrow{display:inline-flex;align-items:center;gap:.7rem;margin:0 0 20px;font-family:var(--font-head);
  font-size:.78rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#fff}
.shero-eyebrow .rule{width:34px;height:2px;background:var(--red);display:inline-block}
.shero-eyebrow .eb-loc{color:var(--red)}
.shero-title{font-family:var(--font-display);font-size:clamp(2.8rem,6.4vw,5.4rem);line-height:.94;letter-spacing:.012em;
  text-transform:uppercase;max-width:14ch}
.shero-title em{font-style:normal;color:var(--red)}
.shero-lead{margin-top:22px;max-width:46ch;font-size:clamp(1.04rem,1.4vw,1.24rem);line-height:1.6;color:#d8dee8}
.shero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}
.shero-copy,.shero-week{min-width:0}
.shero-eyebrow{flex-wrap:wrap}

/* week rail — the creative, image-free graphic */
.shero-week{position:relative;background:rgba(11,16,23,.55);border:1px solid var(--line-strong);border-radius:16px;
  padding:20px 24px;box-shadow:0 40px 80px -46px rgba(0,0,0,.8)}
.shero-week-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:4px}
.shero-week .sw-label{font-family:var(--font-display);text-transform:uppercase;font-size:1.15rem;letter-spacing:.02em;color:#fff}
.shero-week .sw-sub{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.18em;font-size:.6rem;color:var(--muted)}
.shero-days{list-style:none;margin:0;padding:0}
.shero-days li{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.shero-days li:last-child{border-bottom:0}
.shero-days .sw-day{margin-right:auto;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;font-size:.9rem;font-weight:500;color:var(--muted-2)}
.shero-days .sw-meter{flex:none;width:clamp(56px,9vw,96px);height:6px;border-radius:3px;background:rgba(255,255,255,.1);overflow:hidden}
.shero-days .sw-meter i{display:block;height:100%;border-radius:3px;background:var(--red);box-shadow:0 0 12px -3px rgba(239,20,44,.55)}
.shero-days .sw-n{flex:none;min-width:16px;text-align:right;font-family:var(--font-display);font-size:1.15rem;line-height:1;color:#fff}
.shero-days li.is-today .sw-day{color:#fff}
.shero-days li.is-today .sw-day::after{content:" · Today";color:var(--red);font-size:.72em;letter-spacing:.1em}
.shero-days li.is-today .sw-n{color:var(--red)}
.shero-week-foot{display:flex;align-items:baseline;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.shero-week-foot span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.18em;font-size:.6rem;color:var(--muted)}
.shero-week-foot b{font-family:var(--font-display);font-size:1.05rem;color:#fff;letter-spacing:.02em}

@media(max-width:860px){
  .shero-side{display:none}
  .shero-inner{grid-template-columns:1fr;gap:30px;min-height:0;padding-top:calc(78px + 26px);padding-bottom:clamp(40px,8vw,60px)}
  .shero-title{max-width:100%;font-size:clamp(2.6rem,10vw,4rem)}
  .shero-week{max-width:100%}
}
@media(max-width:560px){.shero-cta .btn{width:100%;justify-content:center}}

/* =====================================================
   CONTACT HERO (.chero) — sleek, minimal, image-free, centered
   ===================================================== */
.chero{position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(165deg,#1b2434 0%, var(--navy) 55%, #0f1622 100%);border-bottom:1px solid var(--line)}
.chero-inner{position:relative;z-index:2;max-width:780px;margin:0 auto;text-align:center;
  padding-top:calc(78px + clamp(44px,7vw,96px));padding-bottom:clamp(48px,7vw,92px)}
.chero-eyebrow{display:inline-flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.7rem;margin:0 0 20px;
  font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#fff}
.chero-eyebrow .rule{width:30px;height:2px;background:var(--red);display:inline-block}
.chero-eyebrow .eb-loc{color:var(--red)}
.chero-title{font-family:var(--font-display);font-size:clamp(2.8rem,7vw,5.4rem);line-height:.94;letter-spacing:.012em;text-transform:uppercase}
.chero-title em{font-style:normal;color:var(--red)}
.chero-lead{margin:22px auto 0;max-width:52ch;font-size:clamp(1.04rem,1.4vw,1.24rem);line-height:1.6;color:#d8dee8}
.chero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:32px}
.chero-meta{display:flex;flex-wrap:wrap;justify-content:center;gap:16px 44px;margin-top:clamp(34px,4vw,50px);padding-top:26px;border-top:1px solid var(--line)}
.chero-meta a{display:flex;flex-direction:column;gap:5px;color:#e7ebf2;font-size:.98rem;transition:color .25s var(--ease)}
.chero-meta a span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:.6rem;color:var(--muted)}
.chero-meta a:hover{color:var(--red)}
@media(max-width:560px){
  .chero-cta .btn{width:100%;justify-content:center}
  .chero-meta{gap:18px}
}

/* =====================================================
   HOME PAGE — white navigation bar (scoped to body.home)
   ===================================================== */
body.home .site-header,
body.home .site-header:not(.scrolled){background:#fff;border-bottom:1px solid rgba(23,32,47,.10)}
body.home .site-header.scrolled{background:#fff;border-bottom-color:rgba(23,32,47,.12);
  box-shadow:0 12px 30px -20px rgba(0,0,0,.35)}
body.home .site-header.scrolled .nav::after{background:linear-gradient(90deg,transparent,rgba(239,20,44,.55),transparent)}
/* brand + nav go dark on white */
body.home .brand,body.home .brand span{color:var(--navy)}
body.home .brand small{color:#6b7280}
body.home .nav-links a{color:#3a4557}
body.home .nav-links a:hover{color:var(--navy);background:rgba(23,32,47,.06)}
body.home .nav-links a[aria-current="page"]{color:var(--navy);background:rgba(239,20,44,.10);box-shadow:inset 0 0 0 1px rgba(239,20,44,.28)}
/* Programs dropdown — light to match the white bar */
body.home .nav-drop-menu{background:#fff;border-color:rgba(23,32,47,.12);box-shadow:0 30px 60px -26px rgba(0,0,0,.28)}
body.home .nav-drop-menu a{color:#3a4557}
body.home .nav-drop-menu a:hover{background:rgba(239,20,44,.08);color:var(--navy)}
/* hamburger (mobile) dark on white — but keep the white "X" when the dark menu is open */
body.home .nav-toggle:not(.open){border-color:rgba(23,32,47,.16);background:rgba(23,32,47,.04)}
body.home .nav-toggle:not(.open) span{background:var(--navy)}

/* =====================================================
   NAV — sleek modern refresh (2026-07-03)
   No red dot, no filled current-page bubble. State is a
   thin red underline that eases in on hover / stays for the
   current page, plus a brighter text colour. Red stays a
   slim accent; the rest is quiet and typographic.
   ===================================================== */
.nav-links{gap:clamp(2px,1vw,12px)}
.nav-links a{
  padding:.5em .72em;border-radius:8px;
  font-size:.78rem;letter-spacing:.11em;
  color:var(--muted-2);background:transparent;
  transition:color .25s var(--ease);
}
/* thin underline indicator (replaces the old dot) */
.nav-links a::after{
  content:"";position:absolute;left:.72em;right:.72em;bottom:.28em;top:auto;
  height:2px;width:auto;border-radius:2px;background:var(--red);box-shadow:none;
  transform:scaleX(0);transform-origin:left center;
  transition:transform .32s cubic-bezier(.22,.61,.36,1);
}
.nav-links a:hover{color:#fff;background:transparent}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-links a[aria-current="page"]{color:#fff;background:transparent;box-shadow:none}
.nav-links a[aria-current="page"]::after{transform:scaleX(1);transform-origin:left center}
@media(prefers-reduced-motion:reduce){.nav-links a::after{transition:none}}

/* home page (white bar): dark ink text, same red underline */
body.home .nav-links a{color:#3a4557}
body.home .nav-links a:hover,
body.home .nav-links a[aria-current="page"]{color:var(--navy);background:transparent;box-shadow:none}

/* =====================================================
   WHITE NAV — applied to EVERY page (2026-07-03)
   The white bar was scoped to the home page; these
   unscoped rules extend it site-wide so the nav is
   white everywhere (interior + location pages included).
   ===================================================== */
.site-header,
.site-header:not(.scrolled){background:#fff;border-bottom:1px solid rgba(23,32,47,.10)}
.site-header.scrolled{background:#fff;border-bottom-color:rgba(23,32,47,.12);
  box-shadow:0 12px 30px -20px rgba(0,0,0,.35)}
.site-header.scrolled .nav::after{background:linear-gradient(90deg,transparent,rgba(239,20,44,.55),transparent)}
/* brand + links go dark on the white bar */
.brand,.brand span{color:var(--navy)}
.brand small{color:#6b7280}
.nav-links a{color:#3a4557}
.nav-links a:hover,
.nav-links a[aria-current="page"]{color:var(--navy);background:transparent;box-shadow:none}
/* Programs dropdown — light to match */
.nav-drop-menu{background:#fff;border-color:rgba(23,32,47,.12);box-shadow:0 30px 60px -26px rgba(0,0,0,.28)}
.nav-drop-menu a{color:#3a4557}
.nav-drop-menu a:hover{background:rgba(239,20,44,.08);color:var(--navy)}
/* hamburger (mobile) dark on white; keep white "X" when the dark menu is open */
.nav-toggle:not(.open){border-color:rgba(23,32,47,.16);background:rgba(23,32,47,.04)}
.nav-toggle:not(.open) span{background:var(--navy)}

/* =====================================================
   INSTRUCTORS HERO (.ihero) — static, image-free
   Typographic headline + a black-belt lineage chain.
   ===================================================== */
.ihero{position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(160deg,#1b2434 0%, var(--navy) 55%, #0f1622 100%);border-bottom:1px solid var(--line)}
.ihero-grid{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:clamp(64px,7vw,104px) 100%, 100% clamp(64px,7vw,104px);
  -webkit-mask-image:radial-gradient(120% 120% at 18% 16%, #000 6%, transparent 74%);
          mask-image:radial-gradient(120% 120% at 18% 16%, #000 6%, transparent 74%)}
.ihero-side{position:absolute;right:calc(var(--pad) - 6px);top:50%;transform:translateY(-50%) rotate(180deg);
  writing-mode:vertical-rl;font-family:var(--font-head);font-size:.64rem;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(255,255,255,.36);z-index:1}
.ihero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(34px,5vw,76px);align-items:center;
  padding-top:calc(78px + clamp(30px,5vw,64px));padding-bottom:clamp(48px,6vw,88px);min-height:min(72vh,700px)}
.ihero-copy{min-width:0}
.ihero-eyebrow{display:inline-flex;align-items:center;gap:.7rem;flex-wrap:wrap;margin:0 0 20px;
  font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:#fff}
.ihero-eyebrow .rule{width:34px;height:2px;background:var(--red);display:inline-block}
.ihero-eyebrow .eb-loc{color:var(--red)}
.ihero-title{font-family:var(--font-display);font-size:clamp(2.7rem,6vw,5rem);line-height:.95;letter-spacing:.012em;
  text-transform:uppercase;max-width:15ch}
.ihero-title em{font-style:normal;color:var(--red)}
.ihero-lead{margin-top:22px;max-width:46ch;font-size:clamp(1.04rem,1.4vw,1.24rem);line-height:1.6;color:#d8dee8}
.ihero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

/* black-belt lineage chain */
.ihero-lineage{position:relative;min-width:0;background:rgba(11,16,23,.55);border:1px solid var(--line-strong);
  border-radius:16px;padding:24px 26px;box-shadow:0 40px 80px -46px rgba(0,0,0,.8)}
.ihero-lineage .il-label{display:block;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.2em;
  font-size:.64rem;font-weight:600;color:var(--red);margin-bottom:18px}
.il-chain{list-style:none;margin:0;padding:0}
.il-chain li{position:relative;display:flex;gap:16px;padding-bottom:22px}
.il-chain li:last-child{padding-bottom:0}
.il-chain li:not(:last-child)::before{content:"";position:absolute;left:6px;top:16px;bottom:0;width:2px;
  background:linear-gradient(var(--line-strong),rgba(255,255,255,.06))}
.il-dot{position:relative;z-index:1;flex:none;width:14px;height:14px;border-radius:50%;margin-top:2px;
  background:var(--navy-800);border:2px solid var(--line-strong)}
.il-dot-red{background:var(--red);border-color:var(--red);box-shadow:0 0 0 4px rgba(239,20,44,.18)}
.il-node b{display:block;font-family:var(--font-head);font-weight:600;font-size:1rem;color:#fff;letter-spacing:.01em;line-height:1.2}
.il-node span{display:block;margin-top:3px;font-size:.8rem;color:var(--muted-2);line-height:1.35}
.il-foot{margin:18px 0 0;padding-top:16px;border-top:1px solid var(--line);font-size:.82rem;color:var(--muted);line-height:1.5}

@media(max-width:900px){
  .ihero-side{display:none}
  .ihero-inner{grid-template-columns:1fr;gap:30px;min-height:0;padding-top:calc(78px + 26px);padding-bottom:clamp(40px,8vw,60px)}
  .ihero-title{max-width:20ch}
  .ihero-lineage{max-width:460px}
}
@media(max-width:560px){.ihero-cta .btn{width:100%;justify-content:center}}
