/* ============================================================
   MARTS Fitness v2 taste-skill build
   Read: premium athletic-editorial landing, redesign-overhaul
   Dials: VARIANCE 9 / MOTION 7 / DENSITY 3
   Theme lock: dark. Accent lock: brand gold #D7B46C. Shape: sharp + pill.
   Zero em-dashes anywhere on the page.
   ============================================================ */

:root{
  --bg:#0E0D0B;
  --bg2:#141210;
  --surface:#1A1712;
  --surface2:#221E16;
  --line:rgba(244,240,232,.10);
  --line2:rgba(244,240,232,.20);
  --fg:#F4F1EA;
  --muted:#9A938A;
  --muted2:#6A645B;
  --volt:#D7B46C;            /* brand gold (MARTS logo) */
  --volt-dim:#C2A05A;
  --ink:#14110A;             /* dark text on gold */

  --display:'Montserrat',system-ui,sans-serif;
  --body:'Open Sans',system-ui,sans-serif;
  --wrap:1280px;
  --ease:cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--fg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;color:inherit;border:none;background:none;cursor:pointer}
ul{list-style:none;padding:0}

.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:28px}

/* grain overlay (fixed, never on scrolling container) */
.grain{position:fixed;inset:0;z-index:90;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='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ---------- type helpers ---------- */
.h-display{
  font-family:var(--display);
  font-weight:800;
  font-size:clamp(2rem,5.4vw,4.4rem);
  line-height:1;
  letter-spacing:-.5px;
  text-transform:uppercase;
}
.brand__name,.stat__n,.cell__k,.club__name,.club__idx,.trainer__name,.trainer__exp,
.contact__phone,.foot__col h4,.s-time,.marquee__track{font-weight:800}
.volt{color:var(--volt)}
.dim{color:var(--muted)}
.eyebrow{
  font-family:var(--body);font-weight:600;text-transform:uppercase;
  letter-spacing:.32em;font-size:.74rem;color:var(--volt);margin-bottom:18px;
}
.lead{font-size:clamp(1.05rem,1.8vw,1.32rem);color:#D2D5DA;max-width:54ch;line-height:1.55}

.ico{display:inline-flex;width:1.1em;height:1.1em;flex:none}
.ico svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.ico--fill svg{fill:currentColor;stroke:none}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:1rem;
  padding:15px 28px;border-radius:999px;transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s;will-change:transform}
.btn .ico{width:1.05em;height:1.05em}
.btn--volt{background:var(--volt);color:var(--ink);font-weight:700}
.btn--volt:hover{background:#fff}
.btn--line{border:1px solid var(--line2);color:var(--fg)}
.btn--line:hover{border-color:var(--volt);color:var(--volt)}
.btn--full{width:100%;justify-content:center}
.btn:active{transform:scale(.97)}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:72px;display:flex;align-items:center;
  transition:background .3s,border-color .3s;border-bottom:1px solid transparent}
.nav.stuck{background:rgba(10,11,13,.78);backdrop-filter:blur(14px);border-bottom-color:var(--line)}
.nav__row{display:flex;align-items:center;justify-content:space-between;width:100%}
.brand{display:inline-flex;align-items:center;gap:11px}
.brand__mark{width:14px;height:14px;background:var(--volt);transform:rotate(45deg)}
.brand__name{font-family:var(--display);font-size:1.5rem;letter-spacing:1.5px}
.brand__name--big{font-size:2.2rem}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{font-weight:500;font-size:.96rem;color:#C7CAD0;transition:color .2s;position:relative}
.nav__links a:not(.nav__cta):hover{color:var(--fg)}
.nav__links a:not(.nav__cta)::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--volt);transition:width .25s var(--ease)}
.nav__links a:not(.nav__cta):hover::after{width:100%}
.nav__links a.nav__cta{background:var(--volt);color:var(--ink);font-weight:700;letter-spacing:.2px;padding:10px 24px;border-radius:999px}
.nav__links a.nav__cta:hover{background:#fff;color:var(--ink)}
.burger{display:none;flex-direction:column;gap:6px;width:44px;height:44px;align-items:center;justify-content:center}
.burger span{width:26px;height:2px;background:var(--fg);transition:transform .3s,opacity .2s}
.burger.open span:nth-child(1){transform:translateY(4px) rotate(45deg)}
.burger.open span:nth-child(2){transform:translateY(-4px) rotate(-45deg)}

@media(max-width:900px){
  .burger{display:flex}
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(80vw,340px);flex-direction:column;
    align-items:flex-start;justify-content:center;gap:28px;background:rgba(8,9,11,.98);
    padding:48px;transform:translateX(100%);transition:transform .4s var(--ease)}
  .nav__links.open{transform:translateX(0)}
  .nav__links a{font-size:1.5rem}
}

/* ---------- hero (asymmetric, video mask) ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;padding-bottom:9vh}
.hero__media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.hero__scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(10,11,13,.92) 0%,rgba(10,11,13,.55) 45%,rgba(10,11,13,.25) 100%),
             linear-gradient(0deg,rgba(10,11,13,.9) 0%,transparent 45%)}
.hero__inner{position:relative;z-index:2;max-width:880px}
.hero__title{font-family:var(--display);text-transform:uppercase;font-weight:800;
  font-size:clamp(2.8rem,8.5vw,6.6rem);line-height:.92;letter-spacing:-1px;margin-bottom:10px}
.hero__sub{font-size:clamp(1.08rem,2vw,1.4rem);color:#E3E6EA;max-width:46ch;margin:22px 0 34px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}

/* ---------- marquee (the one) ---------- */
.marquee{background:var(--bg2);color:var(--volt);padding:16px 0;overflow:hidden;border-block:1px solid var(--line)}
.marquee__track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:marq 30s linear infinite;font-family:var(--display);
  text-transform:uppercase;font-size:clamp(1.3rem,3vw,2.4rem);letter-spacing:.5px}
.marquee__track span{padding:0 26px}
.marquee__track .sep{color:rgba(215,180,108,.4)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- stats (editorial big numbers) ---------- */
.stats{border-bottom:1px solid var(--line)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);padding:64px 28px}
.stat{padding:8px 30px;border-left:1px solid var(--line)}
.stat:first-child{border-left:none;padding-left:0}
.stat__n{font-family:var(--display);font-size:clamp(3rem,6vw,5rem);line-height:1;color:var(--volt);
  font-variant-numeric:tabular-nums;display:block}
.stat__l{display:block;margin-top:12px;font-weight:500;color:var(--muted);font-size:.96rem;line-height:1.3}
@media(max-width:760px){.stats__grid{grid-template-columns:1fr 1fr;gap:40px 0}
  .stat{padding:8px 24px}.stat:nth-child(odd){border-left:none;padding-left:0}}

/* ---------- manifesto ---------- */
.manifesto{padding:clamp(80px,11vw,150px) 0}
.manifesto__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(40px,6vw,90px);align-items:center}
.manifesto__text .h-display{margin-bottom:28px}
.ticks{margin-top:30px;display:grid;gap:14px}
.ticks li{position:relative;padding-left:30px;color:#D2D5DA;font-size:1.05rem}
.ticks li::before{content:"";position:absolute;left:0;top:.6em;width:14px;height:2px;background:var(--volt)}
.manifesto__media{position:relative;aspect-ratio:4/5;overflow:hidden}
.manifesto__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) contrast(1.05)}
.manifesto__media::after{content:"";position:absolute;inset:0;border:1px solid var(--line)}
@media(max-width:820px){.manifesto__grid{grid-template-columns:1fr}.manifesto__media{max-width:460px}}

/* ---------- clubs (horizontal scroll gallery) ---------- */
.clubs{padding:clamp(70px,9vw,120px) 0;border-top:1px solid var(--line)}
.clubs__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:44px;flex-wrap:wrap}
.clubs__hint{display:inline-flex;align-items:center;gap:12px;color:var(--muted);font-size:.95rem}
.clubs__hint .swipe{display:inline-flex;align-items:center;gap:9px;color:var(--volt);font-weight:600}
.clubs__hint .swipe__a{position:relative;width:30px;height:1px;background:rgba(215,180,108,.45)}
.clubs__hint .swipe__a::after{content:"";position:absolute;right:0;top:-3px;width:7px;height:7px;
  border-top:1.5px solid var(--volt);border-right:1.5px solid var(--volt);transform:rotate(45deg);
  animation:swipe 1.6s var(--ease) infinite}
@keyframes swipe{0%,100%{transform:translateX(0) rotate(45deg);opacity:.5}50%{transform:translateX(6px) rotate(45deg);opacity:1}}
.clubs__railwrap{position:relative;max-width:var(--wrap);margin-inline:auto}
.clubs__railwrap::after{content:"";position:absolute;top:0;right:0;bottom:28px;width:96px;pointer-events:none;z-index:2;
  background:linear-gradient(90deg,transparent,var(--bg));transition:opacity .35s}
.clubs__railwrap.ends::after{opacity:0}
.clubs__rail{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:4px 28px 28px;scrollbar-width:thin;scrollbar-color:var(--volt) transparent;cursor:grab}
.clubs__rail.dragging{cursor:grabbing;scroll-snap-type:none;scroll-behavior:auto}
.clubs__rail::-webkit-scrollbar{height:6px}
.clubs__rail::-webkit-scrollbar-thumb{background:var(--volt)}
.club{scroll-snap-align:start;flex:0 0 clamp(280px,30vw,360px)}
.club__ph{position:relative;aspect-ratio:3/4;overflow:hidden}
.club__ph img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.club:hover .club__ph img{transform:scale(1.06)}
.club__idx{position:absolute;top:14px;left:14px;font-family:var(--display);font-size:1.1rem;color:var(--volt);
  background:rgba(10,11,13,.7);padding:2px 10px}
.club__name{font-family:var(--display);text-transform:uppercase;font-size:2rem;line-height:1;margin-top:18px}
.club__addr{display:flex;align-items:flex-start;gap:8px;color:#CBC4B8;margin-top:10px;font-size:.95rem}
.club__addr .ico{width:15px;height:15px;color:var(--volt);margin-top:3px}
.club__hours{color:var(--muted);font-size:.9rem;margin-top:8px}
.club__phone{display:inline-block;margin-top:14px;font-weight:600;color:var(--fg);border-bottom:1px solid var(--volt);padding-bottom:2px}
@media(max-width:560px){.clubs__rail{padding-inline:20px}.clubs__railwrap::after{width:48px}}

/* ---------- programs (photo bento) ---------- */
.programs{padding:clamp(70px,9vw,120px) 0}
.programs .h-display{margin-bottom:44px;max-width:18ch}
.bento{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:215px;gap:16px}
.cell{position:relative;overflow:hidden;display:flex;align-items:flex-end;isolation:isolate;border:1px solid var(--line)}
.cell__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .6s var(--ease)}
.cell:hover .cell__bg{transform:scale(1.05)}
.cell__scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(to top,rgba(8,7,5,.95) 0%,rgba(8,7,5,.55) 46%,rgba(8,7,5,.12) 100%)}
.cell__body{padding:26px;width:100%}
.cell__k{font-family:var(--display);text-transform:uppercase;font-size:1.55rem;line-height:1.05;color:var(--fg)}
.cell__k::after{content:"";display:block;width:34px;height:3px;background:var(--volt);margin-top:12px}
.cell__d{color:rgba(244,241,234,.74);font-size:.92rem;margin-top:12px}
.cell__tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.tag{font-size:.74rem;font-weight:600;color:#fff;border:1px solid rgba(255,255,255,.28);padding:4px 10px;background:rgba(0,0,0,.28)}
.cell.s-hero{grid-column:span 3;grid-row:span 2}
.cell.s-tall{grid-column:span 3;grid-row:span 2}
.cell.s-third{grid-column:span 2}
@media(max-width:820px){.bento{grid-template-columns:1fr;grid-auto-rows:225px}
  .cell.s-hero,.cell.s-tall,.cell.s-third{grid-column:span 1;grid-row:span 1}}

/* ---------- schedule (editorial tabbed list) ---------- */
.sched{padding:clamp(70px,9vw,120px) 0;border-top:1px solid var(--line);background:var(--bg2)}
.sched .h-display{margin-bottom:14px}
.sched__note{color:var(--muted);margin-bottom:34px;max-width:50ch}
.sched__tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.s-tab{font-weight:600;font-size:.96rem;padding:10px 18px;border:1px solid var(--line2);border-radius:999px;
  color:#C7CAD0;transition:all .2s}
.s-tab:hover{color:var(--fg);border-color:var(--volt)}
.s-tab.on{background:var(--volt);color:var(--ink);border-color:var(--volt)}
.sched__list{border-top:1px solid var(--line)}
.s-row{display:grid;grid-template-columns:120px 1fr auto;align-items:center;gap:24px;
  padding:20px 6px;border-bottom:1px solid var(--line);transition:background .2s,padding-left .25s var(--ease);
  animation:rin .4s var(--ease) both}
.s-row:hover{background:var(--surface);padding-left:18px}
@keyframes rin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.s-time{font-family:var(--display);font-size:1.7rem;color:var(--volt);font-variant-numeric:tabular-nums}
.s-name{font-weight:600;font-size:1.18rem}
.s-cat{color:var(--muted);font-size:.86rem;margin-top:2px}
.s-badge{font-size:.72rem;font-weight:600;padding:5px 12px;border:1px solid var(--line2);color:#C7CAD0;white-space:nowrap}
.s-badge.kids{border-color:var(--volt);color:var(--volt)}
.s-badge.mind{border-color:#2eaae0;color:#2eaae0}
@media(max-width:680px){.s-row{grid-template-columns:80px 1fr;gap:6px 16px}
  .s-time{font-size:1.35rem}.s-badge{grid-row:1;grid-column:2;justify-self:end}}

/* ---------- trainers (staggered portraits) ---------- */
.trainers{padding:clamp(70px,9vw,120px) 0}
.trainers__head{margin-bottom:50px}
.trainers__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;align-items:start}
.trainer:nth-child(2){transform:translateY(48px)}
.trainer__ph{position:relative;aspect-ratio:3/4;overflow:hidden;border:1px solid var(--line)}
.trainer__ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(.35);transition:transform .6s var(--ease),filter .4s}
.trainer:hover .trainer__ph img{transform:scale(1.05);filter:grayscale(0)}
.trainer__exp{position:absolute;left:14px;bottom:14px;background:var(--volt);color:var(--ink);
  font-family:var(--display);font-size:.9rem;padding:5px 12px;letter-spacing:.5px}
.trainer__name{font-family:var(--display);text-transform:uppercase;font-size:1.8rem;line-height:1;margin-top:18px}
.trainer__role{color:var(--volt);font-weight:500;font-size:.9rem;margin-top:4px}
.trainer__spec{color:var(--muted);font-size:.95rem;margin-top:12px}
@media(max-width:820px){.trainers__grid{grid-template-columns:1fr 1fr}.trainer:nth-child(2){transform:none}}
@media(max-width:560px){.trainers__grid{grid-template-columns:1fr;max-width:400px}}

/* ---------- barbershop (full-bleed band) ---------- */
.barber{position:relative;min-height:62vh;display:flex;align-items:center;overflow:hidden;border-block:1px solid var(--line)}
.barber__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;filter:grayscale(.3)}
.barber__scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(8,9,11,.94) 0%,rgba(8,9,11,.6) 50%,rgba(8,9,11,.2) 100%)}
.barber__inner{max-width:520px}
.barber__inner .lead{margin:18px 0 30px}

/* ---------- app (split) ---------- */
.app{padding:clamp(70px,9vw,120px) 0}
.app__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center}
.app__badges{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.store{display:inline-flex;align-items:center;gap:12px;border:1px solid var(--line2);padding:11px 20px;transition:border-color .2s,transform .2s}
.store:hover{border-color:var(--volt);transform:translateY(-2px)}
.store .ico{width:24px;height:24px;color:var(--fg)}
.store span{display:flex;flex-direction:column;font-weight:700;font-size:1.02rem;line-height:1.1}
.store small{font-size:.62rem;font-weight:500;color:var(--muted);letter-spacing:.5px}
.app__media{aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line)}
.app__media img{width:100%;height:100%;object-fit:cover}
@media(max-width:760px){.app__grid{grid-template-columns:1fr}.app__media{max-width:380px}}

/* ---------- business (manifesto band) ---------- */
.biz{padding:clamp(70px,9vw,120px) 0;border-top:1px solid var(--line);text-align:center}
.biz__inner{max-width:760px;margin-inline:auto}
.biz__inner .lead{margin:20px auto 30px}

/* ---------- contact ---------- */
.contact{padding:clamp(70px,9vw,120px) 0;border-top:1px solid var(--line);background:var(--bg2)}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.contact__left .h-display{margin:6px 0 18px}
.contact__meta{margin-top:28px;display:flex;flex-direction:column;gap:8px}
.contact__phone{font-family:var(--display);font-size:2rem;color:var(--fg)}
.contact__sub{color:var(--muted)}
.form{position:relative;background:var(--surface);border:1px solid var(--line);padding:clamp(26px,4vw,40px)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:.82rem;color:#C7CAD0;margin-bottom:8px}
.field input,.field select{width:100%;background:var(--bg);border:1px solid var(--line2);color:var(--fg);
  padding:14px 16px;font-family:inherit;font-size:1rem;min-height:50px;transition:border-color .2s,box-shadow .2s}
.field input::placeholder{color:var(--muted2)}
.field input:focus,.field select:focus{outline:none;border-color:var(--volt);box-shadow:0 0 0 3px rgba(215,180,108,.32)}
.field select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238C9098' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:20px;padding-right:44px}
.err{display:none;color:#fca5a5;font-size:.82rem;margin-top:6px}
.field.bad input,.field.bad select{border-color:#ef4444}
.field.bad .err{display:block}
.form__note{font-size:.8rem;color:var(--muted2);margin-top:14px;text-align:center}
.spin{display:none;width:18px;height:18px;border:2px solid rgba(10,11,13,.3);border-top-color:var(--ink);border-radius:50%;animation:sp .7s linear infinite;margin-left:8px}
@keyframes sp{to{transform:rotate(360deg)}}
.btn.loading .btn__t{opacity:.5}
.btn.loading .spin{display:inline-block}
.form__ok{display:none;position:absolute;inset:0;background:var(--surface);flex-direction:column;align-items:center;
  justify-content:center;gap:14px;text-align:center;padding:30px;font-size:1.1rem}
.form__ok.show{display:flex;animation:fin .4s var(--ease)}
.form__ok .ico{width:54px;height:54px;color:var(--volt)}
@keyframes fin{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}
@media(max-width:820px){.contact__grid{grid-template-columns:1fr}}

/* ---------- footer ---------- */
.foot{border-top:1px solid var(--line);padding-top:64px;background:var(--bg)}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px}
.foot__tag{color:var(--muted);margin-top:16px;max-width:30ch}
.foot__soc{display:flex;gap:12px;margin-top:22px}
.foot__soc a{width:40px;height:40px;border:1px solid var(--line);display:grid;place-items:center;transition:all .2s}
.foot__soc a:hover{background:var(--volt);color:var(--ink);border-color:var(--volt)}
.foot__soc .ico{width:18px;height:18px}
.foot__col h4{font-family:var(--display);text-transform:uppercase;font-size:1.05rem;letter-spacing:1px;margin-bottom:18px}
.foot__col ul{display:grid;gap:11px}
.foot__col a,.foot__col li{color:var(--muted);font-size:.95rem;transition:color .2s}
.foot__col a:hover{color:var(--volt)}
.foot__bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  border-top:1px solid var(--line);padding:22px 28px;color:var(--muted2);font-size:.86rem}
.foot__demo{opacity:.7}
@media(max-width:820px){.foot__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot__grid{grid-template-columns:1fr}}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- premium motion ---------- */
/* scroll progress bar (gold). CSS scroll-timeline where supported, JS --p fallback */
.progress{position:fixed;top:0;left:0;height:2px;width:100%;z-index:120;transform-origin:0 50%;
  transform:scaleX(var(--p,0));background:linear-gradient(90deg,var(--volt-dim),var(--volt));
  box-shadow:0 0 12px rgba(215,180,108,.5);pointer-events:none}
@supports (animation-timeline: scroll()){
  .progress{animation:grow linear;animation-timeline:scroll(root)}
  @keyframes grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
}
/* hero: slow Ken-Burns drift for depth */
.hero__media{animation:kenburns 28s var(--ease) infinite alternate;will-change:transform}
@keyframes kenburns{from{transform:scale(1.03)}to{transform:scale(1.13) translate(-1.5%,-1%)}}
/* section-image parallax (modern browsers; static fallback) */
@supports (animation-timeline: view()){
  @media (prefers-reduced-motion: no-preference){
    .manifesto__media img,.app__media img{animation:par linear both;animation-timeline:view();animation-range:entry 0% exit 100%}
    .barber__bg{animation:parbg linear both;animation-timeline:view();animation-range:entry 0% exit 100%}
    @keyframes par{from{transform:scale(1.1) translateY(-5%)}to{transform:scale(1.1) translateY(5%)}}
    @keyframes parbg{from{transform:scale(1.14) translateY(-4%)}to{transform:scale(1.14) translateY(4%)}}
  }
}
/* gold sheen sweep on primary buttons */
.btn--volt{position:relative;overflow:hidden}
.btn--volt:hover{background:#E6CB86}
.btn--volt>*{position:relative;z-index:1}
.btn--volt::after{content:"";position:absolute;top:0;left:-130%;width:65%;height:100%;z-index:0;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent);transform:skewX(-18deg);transition:left .6s var(--ease)}
.btn--volt:hover::after{left:150%}
/* hover lift (clubs + bento cells; trainers keep their offset/zoom) */
.club{transition:transform .45s var(--ease)}
.club:hover{transform:translateY(-6px)}
.cell{transition:transform .45s var(--ease),border-color .3s}
.cell:hover{transform:translateY(-5px);border-color:var(--line2)}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .marquee__track,.hero__media{animation:none;transform:none}
  .trainer:nth-child(2){transform:none}
  .progress{display:none}
  .clubs__hint .swipe__a::after{animation:none}
}
