/* ==========================================================================
   VALLEY MMA — "From the Sand to the Cage"
   Fighters community · Calicut & Malappuram
   Real photos · premium motion · brand-true
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Inter+Tight:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&family=Fraunces:ital,opsz,wght@1,9..144,300;1,9..144,400;0,9..144,500&display=swap');

:root{
  --black:#0C0D0B;
  --ink:#15170F;
  --char:#1C1F18;
  --bone:#F2EDE3;
  --bone-2:#E6DECC;
  --sand:#C8A878;
  --sand-deep:#A8854E;
  --moss:#2C3A28;
  --moss-deep:#182116;
  --ember:#C5402F;
  --ember-bright:#E4583F;
  --line:rgba(12,13,11,.14);
  --line-d:rgba(242,237,227,.16);
  --maxw:1480px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter Tight',system-ui,sans-serif;
  font-size:17px;line-height:1.6;color:var(--ink);
  background:var(--bone);overflow-x:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:0;color:inherit}
::selection{background:var(--ember);color:var(--bone)}

/* ---------- TYPE ---------- */
.display{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.005em;line-height:.9;text-transform:uppercase}
h1,h2,h3{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.01em;line-height:.92;text-transform:uppercase}
h1{font-size:clamp(3rem,9.5vw,8.5rem)}
h2{font-size:clamp(2.3rem,6vw,5rem)}
h3{font-size:clamp(1.5rem,2.6vw,2.4rem)}
.serif{font-family:'Fraunces',serif;font-style:italic;font-weight:300;text-transform:none;letter-spacing:-.01em;font-variation-settings:'opsz' 144}
.mono{font-family:'JetBrains Mono',monospace;letter-spacing:.18em;text-transform:uppercase}

.eyebrow{display:inline-flex;align-items:center;gap:.65rem;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--sand-deep)}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor}
.eyebrow.on-dark{color:var(--sand)}

.tag{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--ember);color:var(--bone);
  padding:7px 16px 7px 24px;
  font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
  clip-path:polygon(10px 0,100% 0,100% 100%,10px 100%,0 50%);
}
.tag.sand{background:var(--sand);color:var(--ink)}
.tag.bone{background:var(--bone);color:var(--ink)}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 32px;color:var(--bone);
  transition:background .4s var(--ease),padding .4s var(--ease),backdrop-filter .4s;
}
.nav.scrolled{background:rgba(12,13,11,.9);backdrop-filter:blur(14px);padding:10px 32px;border-bottom:1px solid rgba(200,168,120,.16)}
.nav-logo{display:flex;align-items:center;gap:11px;color:var(--bone)}
.nav-logo svg{width:34px;height:34px;flex:none}
.nav-logo .name{font-family:'Anton',sans-serif;font-size:1.35rem;letter-spacing:.04em;text-transform:uppercase;line-height:1}
.nav-logo .name em{color:var(--ember);font-style:normal}
.nav-logo .sub{font-family:'JetBrains Mono',monospace;font-size:.52rem;letter-spacing:.22em;color:var(--sand);text-transform:uppercase;display:block;margin-top:3px}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bone);opacity:.82;position:relative;padding:4px 0;transition:opacity .2s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--ember);transition:width .3s var(--ease)}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{width:100%}
.nav-cta{
  background:var(--ember);color:var(--bone);padding:11px 20px;
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;
  display:inline-flex;align-items:center;gap:8px;transition:background .25s,transform .25s;
}
.nav-cta::after{display:none}
.nav-cta:hover{background:var(--ember-bright);transform:translateY(-2px)}
.nav-cta svg{width:14px;height:14px}
.menu-toggle{display:none;color:var(--bone)}
.menu-toggle svg{width:26px;height:26px}

@media (max-width:940px){
  .nav{padding:14px 20px}.nav.scrolled{padding:12px 20px}
  .nav-links{position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--black);padding:28px 20px;gap:20px;border-bottom:1px solid rgba(200,168,120,.18);display:none;align-items:flex-start}
  .nav-links.open{display:flex}
  .nav-links a{font-size:.95rem}
  .menu-toggle{display:block}
}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;background:var(--black);color:var(--bone);overflow:hidden;display:flex;flex-direction:column}
.hero-media{position:absolute;inset:0;overflow:hidden}
.hero-media img{
  width:100%;height:100%;object-fit:cover;object-position:center 30%;
  filter:grayscale(.25) contrast(1.08) brightness(.62);
  transform:scale(1.08);will-change:transform;
  animation:kenburns 22s ease-in-out infinite alternate;
}
@keyframes kenburns{from{transform:scale(1.08) translate(0,0)}to{transform:scale(1.16) translate(-1.5%,-2%)}}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:
   linear-gradient(180deg,rgba(12,13,11,.62) 0%,rgba(12,13,11,.42) 35%,rgba(12,13,11,.78) 72%,rgba(12,13,11,.97) 100%),
   radial-gradient(120% 90% at 80% 20%,rgba(197,64,47,.22),transparent 55%);
}
.grain{position:absolute;inset:0;pointer-events:none;z-index:2;opacity:.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='240' height='240' filter='url(%23n)' opacity='.5'/></svg>")}

.hero-top{position:relative;z-index:5;display:flex;justify-content:space-between;gap:14px;padding:104px 32px 0;font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sand);flex-wrap:wrap}
.hero-top .live{display:inline-flex;align-items:center;gap:8px}
.hero-top .dot{width:8px;height:8px;border-radius:50%;background:var(--ember);box-shadow:0 0 0 0 rgba(197,64,47,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(197,64,47,.6)}70%{box-shadow:0 0 0 12px rgba(197,64,47,0)}100%{box-shadow:0 0 0 0 rgba(197,64,47,0)}}

.hero-body{position:relative;z-index:5;flex:1;display:flex;flex-direction:column;justify-content:flex-end;max-width:var(--maxw);margin:0 auto;width:100%;padding:40px 32px 48px}
.hero-eyebrow{margin-bottom:24px}
.hero h1{font-size:clamp(3.4rem,12vw,10rem);margin-bottom:26px}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln > span{display:block;transform:translateY(100%);transition:transform 1s var(--ease)}
.hero.in h1 .ln > span{transform:translateY(0)}
.hero h1 em{color:var(--sand);font-style:normal}
.hero h1 .ember{color:var(--ember)}
.hero-sub{max-width:560px;font-size:1.18rem;line-height:1.6;color:rgba(242,237,227,.9);margin-bottom:34px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:52px}
.btn{
  display:inline-flex;align-items:center;gap:12px;padding:18px 30px;
  font-family:'JetBrains Mono',monospace;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  transition:transform .25s var(--ease),background .25s,border-color .25s,color .25s;will-change:transform;
}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--ember);color:var(--bone)}
.btn-primary:hover{background:var(--ember-bright);transform:translateY(-2px)}
.btn-sand{background:var(--sand);color:var(--ink)}
.btn-sand:hover{background:var(--bone);transform:translateY(-2px)}
.btn-ghost{border:1px solid rgba(242,237,227,.45);color:var(--bone)}
.btn-ghost:hover{border-color:var(--sand);background:rgba(200,168,120,.1)}
.btn-ghost-d{border:1px solid var(--line);color:var(--ink)}
.btn-ghost-d:hover{border-color:var(--ember);color:var(--ember)}

.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(242,237,227,.18)}
.hero-stats .s{padding:22px 24px 0;border-left:1px solid rgba(242,237,227,.1)}
.hero-stats .s:first-child{border-left:0;padding-left:0}
.hero-stats .n{font-family:'Anton',sans-serif;font-size:clamp(1.8rem,3.4vw,2.8rem);line-height:1;margin-bottom:6px}
.hero-stats .n em{font-style:normal;color:var(--ember)}
.hero-stats .l{font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,237,227,.7)}
.scroll-cue{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:5;font-family:'JetBrains Mono',monospace;font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--sand);display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue .bar{width:1px;height:34px;background:linear-gradient(var(--sand),transparent);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

@media (max-width:940px){
  .hero-top{padding:92px 20px 0;font-size:.6rem}
  .hero-body{padding:30px 20px 40px}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:18px 0}
  .hero-stats .s:nth-child(3){border-left:0;padding-left:0}
  .hero-ctas{flex-direction:column;align-items:stretch}.btn{justify-content:center}
  .scroll-cue{display:none}
}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--ember);color:var(--bone);padding:16px 0;overflow:hidden;border-top:1px solid rgba(12,13,11,.2);border-bottom:1px solid rgba(12,13,11,.2)}
.marquee-track{display:flex;gap:0;width:max-content;animation:scrollx 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee .item{display:inline-flex;align-items:center;font-family:'Anton',sans-serif;font-size:1.15rem;letter-spacing:.04em;text-transform:uppercase;padding:0 26px;white-space:nowrap}
.marquee .item::after{content:"✦";color:rgba(242,237,227,.55);margin-left:52px;font-size:.8rem}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- SECTION SHELL ---------- */
section{position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;padding:120px 32px}
.wrap.tight{padding:96px 32px}
.sec-head{display:grid;grid-template-columns:230px 1fr;gap:54px;align-items:end;margin-bottom:64px}
.sec-head .meta{font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sand-deep);border-top:1px solid var(--line);padding-top:14px}
.sec-head h2 .serif{color:var(--sand-deep);font-size:.66em}
@media (max-width:820px){
  .wrap{padding:76px 20px}.wrap.tight{padding:64px 20px}
  .sec-head{grid-template-columns:1fr;gap:16px;margin-bottom:40px}
  .sec-head .meta{border-top:0;border-left:2px solid var(--ember);padding:0 0 0 12px}
}

/* dark / moss section variants */
.s-dark{background:var(--black);color:var(--bone)}
.s-ink{background:var(--ink);color:var(--bone)}
.s-moss{background:var(--moss);color:var(--bone)}
.s-dark .sec-head .meta,.s-ink .sec-head .meta,.s-moss .sec-head .meta{color:var(--sand);border-color:var(--line-d)}
.s-dark h2,.s-ink h2,.s-moss h2{color:var(--bone)}
.s-moss h2 .serif,.s-dark h2 .serif,.s-ink h2 .serif{color:var(--sand)}

/* ---------- INTRO / ETHOS ---------- */
.intro-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:72px;align-items:center}
.intro-copy h2{margin-bottom:28px}
.intro-copy h2 em{font-family:'Fraunces',serif;font-style:italic;font-weight:300;text-transform:none;letter-spacing:-.01em;color:var(--ember);font-variation-settings:'opsz' 144}
.intro-copy p{font-size:1.16rem;line-height:1.72;color:rgba(21,23,15,.82);margin-bottom:20px;max-width:560px}
.s-dark .intro-copy p,.s-moss .intro-copy p{color:rgba(242,237,227,.84)}
.intro-copy .mal{font-family:'Fraunces',serif;font-style:italic;font-weight:400;font-size:1.5rem;color:var(--sand-deep);margin:8px 0 4px}
.intro-figure{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--moss-deep)}
.intro-figure img{width:100%;height:100%;object-fit:cover}
.intro-figure .cap{position:absolute;left:0;bottom:0;right:0;padding:20px;background:linear-gradient(transparent,rgba(12,13,11,.9));font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bone)}
.intro-figure .cap b{color:var(--sand);display:block;margin-bottom:3px;letter-spacing:.2em}
@media (max-width:880px){.intro-grid{grid-template-columns:1fr;gap:40px}}

/* ---------- JOURNEY (sand to cage) ---------- */
.journey{background:var(--ink);color:var(--bone)}
.journey-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line-d);border-left:1px solid var(--line-d)}
.jstep{position:relative;border-right:1px solid var(--line-d);border-bottom:1px solid var(--line-d);overflow:hidden;min-height:440px;display:flex;flex-direction:column;justify-content:flex-end}
.jstep img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.35) brightness(.6) contrast(1.05);transition:transform .9s var(--ease),filter .5s}
.jstep:hover img{transform:scale(1.07);filter:grayscale(0) brightness(.7) contrast(1.08)}
.jstep::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 30%,rgba(12,13,11,.92))}
.jstep .c{position:relative;z-index:2;padding:28px 24px}
.jstep .num{font-family:'Anton',sans-serif;font-size:3.4rem;color:var(--ember);line-height:.8;margin-bottom:auto;position:absolute;top:22px;left:24px}
.jstep h3{color:var(--bone);margin-bottom:10px;font-size:1.5rem}
.jstep p{font-size:.93rem;line-height:1.55;color:rgba(242,237,227,.8)}
@media (max-width:1000px){.journey-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.journey-grid{grid-template-columns:1fr}.jstep{min-height:360px}}

/* ---------- DISCIPLINES ---------- */
.disc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.s-dark .disc-grid,.s-moss .disc-grid{border-color:var(--line-d)}
.disc-card{position:relative;padding:44px 38px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:background .3s;overflow:hidden}
.s-dark .disc-card,.s-moss .disc-card{border-color:var(--line-d)}
.disc-card:hover{background:rgba(197,64,47,.06)}
.disc-card .num{font-family:'JetBrains Mono',monospace;font-size:.64rem;letter-spacing:.2em;color:var(--ember);margin-bottom:22px;display:block}
.disc-card .ic{width:46px;height:46px;color:var(--sand);margin-bottom:22px}
.disc-card h3{margin-bottom:12px}
.s-dark .disc-card h3{color:var(--bone)}
.disc-card p{font-size:.98rem;line-height:1.62;color:rgba(21,23,15,.78);max-width:380px}
.s-dark .disc-card p,.s-moss .disc-card p{color:rgba(242,237,227,.78)}
.disc-card .lvl{margin-top:18px;font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sand-deep)}
.s-dark .disc-card .lvl{color:var(--sand)}
@media (max-width:760px){.disc-grid{grid-template-columns:1fr}.disc-card{padding:36px 26px}}

/* ---------- CHAMPIONS / RECORD ---------- */
.champ{background:var(--black);color:var(--bone);position:relative;overflow:hidden}
.champ::before{content:"";position:absolute;inset:0;background:radial-gradient(90% 70% at 70% 10%,rgba(197,64,47,.16),transparent 60%);pointer-events:none}
.champ-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center;position:relative}
.champ-figure{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--moss-deep)}
.champ-figure img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.champ-figure .belt{position:absolute;top:20px;left:20px;background:var(--ember);color:var(--bone);padding:10px 16px;font-family:'JetBrains Mono',monospace;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase}
.champ-copy h2{margin-bottom:24px}
.champ-copy h2 em{font-family:'Fraunces',serif;font-style:italic;font-weight:300;text-transform:none;color:var(--sand);font-variation-settings:'opsz' 144}
.champ-copy > p{font-size:1.12rem;line-height:1.7;color:rgba(242,237,227,.85);margin-bottom:28px;max-width:520px}
.record{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line-d)}
.record .r{padding:24px 0;border-bottom:1px solid var(--line-d);border-right:1px solid var(--line-d);padding-right:20px}
.record .r:last-child{border-right:0}
.record .n{font-family:'Anton',sans-serif;font-size:2.8rem;line-height:1;color:var(--bone);margin-bottom:6px}
.record .n em{font-style:normal;color:var(--ember)}
.record .l{font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(242,237,227,.7);line-height:1.4}
@media (max-width:880px){.champ-grid{grid-template-columns:1fr;gap:40px}}

/* ---------- YUDHA FEATURE ---------- */
.yudha{position:relative;background:var(--moss-deep);color:var(--bone);overflow:hidden}
.yudha-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:0;align-items:stretch}
.yudha-media{position:relative;min-height:520px;overflow:hidden}
.yudha-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.yudha-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 40%,var(--moss-deep))}
.yudha-copy{padding:88px 64px;display:flex;flex-direction:column;justify-content:center}
.yudha-copy .tag{margin-bottom:24px;align-self:flex-start}
.yudha-copy h2{margin-bottom:18px;color:var(--bone)}
.yudha-copy h2 .ember{color:var(--ember);font-style:normal}
.yudha-copy .lead{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:1.6rem;color:var(--sand);margin-bottom:24px;font-variation-settings:'opsz' 144}
.yudha-copy p{font-size:1.04rem;line-height:1.68;color:rgba(242,237,227,.82);margin-bottom:20px;max-width:520px}
.yudha-stages{display:grid;grid-template-columns:1fr 1fr;gap:0;margin:14px 0 30px;border-top:1px solid var(--line-d)}
.yudha-stages .st{padding:20px 0;border-bottom:1px solid var(--line-d);border-right:1px solid var(--line-d);padding-right:22px}
.yudha-stages .st:last-child{border-right:0;padding-right:0;padding-left:22px}
.yudha-stages .st .k{font-family:'Anton',sans-serif;font-size:2rem;color:var(--ember);line-height:1;margin-bottom:8px}
.yudha-stages .st .v{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(242,237,227,.8);line-height:1.5}
@media (max-width:920px){.yudha-grid{grid-template-columns:1fr}.yudha-media{min-height:320px}.yudha-media::after{background:linear-gradient(transparent 40%,var(--moss-deep))}.yudha-copy{padding:56px 24px}}

/* ---------- GALLERY ---------- */
.gallery{background:var(--ink);color:var(--bone)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:240px;gap:12px}
.gal-item{position:relative;overflow:hidden;background:var(--moss-deep);cursor:pointer}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter .4s;filter:grayscale(.2) contrast(1.05)}
.gal-item:hover img{transform:scale(1.06);filter:grayscale(0)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(12,13,11,.85));opacity:0;transition:opacity .35s}
.gal-item:hover::after{opacity:1}
.gal-item .cap{position:absolute;left:16px;bottom:14px;right:16px;z-index:2;font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bone);opacity:0;transform:translateY(8px);transition:opacity .35s,transform .35s}
.gal-item:hover .cap{opacity:1;transform:translateY(0)}
.gal-item .cap b{color:var(--sand)}
.gal-item.tall{grid-row:span 2}.gal-item.wide{grid-column:span 2}
.gal-foot{margin-top:30px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.gal-foot .note{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sand)}
@media (max-width:1000px){.gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}}
@media (max-width:520px){.gal-grid{grid-template-columns:1fr;grid-auto-rows:260px}.gal-item.wide{grid-column:span 1}.gal-item.tall{grid-row:span 1}}

/* ---------- COACH ---------- */
.coach{background:var(--bone)}
.coach-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center}
.coach-figure{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--moss-deep)}
.coach-figure img{width:100%;height:100%;object-fit:cover;filter:grayscale(.1)}
.coach-figure .badge{position:absolute;bottom:20px;left:20px;background:var(--ink);color:var(--sand);padding:12px 16px;font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase}
.coach-copy .tag{margin-bottom:22px}
.coach-copy h2{margin-bottom:14px}
.coach-copy .role{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ember);margin-bottom:26px;display:block}
.coach-copy p{font-size:1.08rem;line-height:1.72;color:rgba(21,23,15,.82);margin-bottom:18px;max-width:540px}
.coach-copy .quote{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:1.5rem;line-height:1.45;color:var(--moss);border-left:3px solid var(--ember);padding-left:22px;margin:26px 0;font-variation-settings:'opsz' 144}
@media (max-width:880px){.coach-grid{grid-template-columns:1fr;gap:36px}}

/* ---------- CTA BAND ---------- */
.cta{background:var(--ember);color:var(--bone);position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;opacity:.5;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='240' height='240' filter='url(%23n)' opacity='.4'/></svg>");mix-blend-mode:overlay}
.cta-grid{position:relative;display:grid;grid-template-columns:1.3fr 1fr;gap:56px;align-items:center}
.cta-grid h2{margin-bottom:20px;color:var(--bone)}
.cta-grid h2 em{font-family:'Fraunces',serif;font-style:italic;font-weight:300;text-transform:none;color:var(--ink);font-variation-settings:'opsz' 144}
.cta-grid p{font-size:1.12rem;line-height:1.65;color:rgba(12,13,11,.82);max-width:480px;margin-bottom:28px}
.cta-actions{display:flex;flex-direction:column;gap:14px}
.cta-actions .btn{justify-content:space-between;background:var(--ink);color:var(--bone)}
.cta-actions .btn:hover{background:var(--black);transform:translateX(6px)}
.cta-actions .btn.wa{background:var(--bone);color:var(--ink)}
.cta-actions .btn.wa:hover{background:#fff}
.cta-actions .small{font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(12,13,11,.7);margin-top:6px}
@media (max-width:880px){.cta-grid{grid-template-columns:1fr;gap:32px}}

/* ---------- FORM (shared) ---------- */
.fbox{background:var(--ink);color:var(--bone);padding:42px 38px}
.fbox h3{color:var(--bone);margin-bottom:22px;font-size:1.5rem}
.fbox .field{margin-bottom:18px}
.fbox label{font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sand);display:block;margin-bottom:8px}
.fbox input,.fbox select,.fbox textarea{width:100%;background:rgba(242,237,227,.06);border:0;border-bottom:1px solid rgba(242,237,227,.3);color:var(--bone);padding:11px 0;font-family:'Inter Tight',sans-serif;font-size:1rem;outline:none;transition:border-color .25s}
.fbox input::placeholder,.fbox textarea::placeholder{color:rgba(242,237,227,.4)}
.fbox input:focus,.fbox select:focus,.fbox textarea:focus{border-color:var(--ember)}
.fbox select option{background:var(--ink)}
.fbox .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.fbox button{width:100%;margin-top:8px;background:var(--ember);color:var(--bone);padding:17px;font-family:'JetBrains Mono',monospace;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;transition:background .25s}
.fbox button:hover{background:var(--ember-bright)}
.fbox .note{margin-top:12px;font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(242,237,227,.5);text-align:center}
@media (max-width:520px){.fbox .row{grid-template-columns:1fr}}

/* ---------- FOOTER ---------- */
.foot{background:var(--black);color:var(--bone);padding:88px 32px 34px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:42px;max-width:var(--maxw);margin:0 auto;padding-bottom:52px;border-bottom:1px solid var(--line-d)}
.foot-brand .nav-logo{margin-bottom:22px}
.foot-brand p{font-size:.96rem;line-height:1.65;color:rgba(242,237,227,.66);max-width:340px;margin-bottom:22px}
.foot-brand .wa{display:inline-flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:.78rem;letter-spacing:.1em;color:var(--sand);border:1px solid rgba(200,168,120,.4);padding:10px 16px;transition:background .25s,color .25s}
.foot-brand .wa:hover{background:var(--sand);color:var(--ink)}
.foot-col h5{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sand);margin-bottom:18px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.foot-col a,.foot-col li{color:rgba(242,237,227,.7);font-size:.94rem;transition:color .2s}
.foot-col a:hover{color:var(--ember)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:30px;max-width:var(--maxw);margin:0 auto;flex-wrap:wrap;gap:12px}
.foot-bottom .c{font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,237,227,.46)}
.foot-bottom .c a{color:var(--sand)}
@media (max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/-1}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ---------- REVEAL (fail-open) ---------- */
.reveal{opacity:1;transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal--off{opacity:0;transform:translateY(30px)}
.reveal--off.d1{transition-delay:.08s}.reveal--off.d2{transition-delay:.16s}.reveal--off.d3{transition-delay:.24s}.reveal--off.d4{transition-delay:.32s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal--off{opacity:1!important;transform:none!important}
  .hero h1 .ln>span{transform:none!important}
}
