/* ============================================================
   ZAIN RETHERFORD — 2026 redesign
   Build by Basch Solutions · Engineered with Graystorm
   ============================================================ */

:root{
  --ink:#080a0e;
  --ink-2:#0c1017;
  --panel:#11161f;
  --panel-2:#0e131c;
  --line:rgba(255,255,255,.10);
  --line-soft:rgba(255,255,255,.06);
  --blue:#3b8cff;
  --blue-hot:#1f6fe6;
  --blue-deep:#0a4bb0;
  --gold:#e6c067;
  --gold-soft:#caa64f;
  --text:#eef1f5;
  --muted:#98a2b0;
  --muted-2:#69727f;
  --paper:#f5f3ee;
  --maxw:1240px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --display:"Anton",system-ui,sans-serif;
  --body:"Inter",system-ui,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--ink);
  color:var(--text);
  font-family:var(--body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--blue);color:#fff}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{position:relative;padding:120px 0}
@media(max-width:760px){.section{padding:76px 0}}

/* ---------- Type ---------- */
.eyebrow{
  font-family:var(--body);
  font-weight:700;
  font-size:12.5px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--blue);
  display:inline-flex;align-items:center;gap:12px;
  margin:0 0 22px;
}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--blue)}
.eyebrow.center{justify-content:center}
.eyebrow.gold{color:var(--gold)}
.eyebrow.gold::before{background:var(--gold)}

h1,h2,h3{font-family:var(--display);font-weight:400;text-transform:uppercase;line-height:.92;margin:0;letter-spacing:.01em}
.h-xl{font-size:clamp(3.4rem,11vw,9.5rem)}
.h-lg{font-size:clamp(2.6rem,6.4vw,5.3rem)}
.h-md{font-size:clamp(2rem,4vw,3.2rem)}
.lead{font-size:clamp(1.05rem,1.6vw,1.32rem);line-height:1.6;color:#cfd6df;font-weight:400}
.muted{color:var(--muted)}
.accent{color:var(--blue)}
.accent-gold{color:var(--gold)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--body);font-weight:700;font-size:13px;
  letter-spacing:.16em;text-transform:uppercase;
  padding:17px 30px;border-radius:2px;border:1px solid transparent;
  cursor:pointer;transition:.35s var(--ease);position:relative;
}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translateX(6px)}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:#fff;color:var(--ink)}
.btn-ghost{border-color:var(--line);color:var(--text)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.04)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:90;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 28px;
  transition:.4s var(--ease);
}
.nav::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,rgba(8,10,14,.78) 0%,rgba(8,10,14,.35) 55%,transparent 100%);
  transition:opacity .4s var(--ease);
}
.nav.scrolled::before{opacity:0}
.nav.scrolled{
  padding:13px 28px;
  background:rgba(8,10,14,.85);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.brand{display:flex;align-items:center;gap:14px}
.brand img{height:42px;width:auto;transition:.4s var(--ease)}
.nav.scrolled .brand img{height:34px}
.brand .bname{font-family:var(--display);font-size:21px;letter-spacing:.04em;line-height:1}
.brand .bname small{display:block;font-family:var(--body);font-weight:600;font-size:9px;letter-spacing:.3em;color:var(--blue);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#d4dae2;transition:.25s;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-7px;width:0;height:2px;background:var(--blue);transition:width .3s var(--ease)}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}
.nav-social{display:flex;gap:16px;align-items:center;margin-left:8px;padding-left:26px;border-left:1px solid var(--line)}
.nav-social a{font-size:15px;color:var(--muted);transition:.25s}
.nav-social a:hover{color:var(--blue);transform:translateY(-2px)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:0}
.burger span{width:26px;height:2px;background:#fff;transition:.3s}

@media(max-width:1000px){
  .nav-links,.nav-social{display:none}
  .burger{display:flex}
}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:95;background:rgba(8,10,14,.98);
  backdrop-filter:blur(8px);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:8px;
  opacity:0;pointer-events:none;transition:.4s var(--ease);
}
.mobile-menu.open{opacity:1;pointer-events:auto}
.mobile-menu a{font-family:var(--display);font-size:2.4rem;color:#fff;text-transform:uppercase;padding:6px 0;transition:.25s}
.mobile-menu a:hover{color:var(--blue)}
.mobile-menu .mm-social{display:flex;gap:26px;margin-top:30px;font-size:22px}
.mobile-close{position:absolute;top:26px;right:30px;font-size:34px;color:#fff;background:none;border:0;cursor:pointer;line-height:1}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:50% 16%;transform:scale(1.06);animation:heroZoom 14s var(--ease) forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(8,10,14,.55) 0%,rgba(8,10,14,0) 22%,rgba(8,10,14,0) 45%,rgba(8,10,14,.82) 86%,var(--ink) 100%),
    linear-gradient(90deg,rgba(8,10,14,.8) 0%,rgba(8,10,14,.25) 45%,rgba(8,10,14,0) 75%);
}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px 92px}
.hero-flag{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.hero-flag .bar{width:46px;height:3px;background:var(--blue)}
.hero-flag span{font-weight:700;font-size:12.5px;letter-spacing:.3em;text-transform:uppercase;color:#dfe5ec}
.hero h1{font-size:clamp(3.6rem,12.5vw,11rem);text-shadow:0 6px 40px rgba(0,0,0,.5)}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln i{display:block;font-style:normal;transform:translateY(105%);animation:rise 1s var(--ease) forwards}
.hero h1 .ln:nth-child(2) i{animation-delay:.12s}
@keyframes rise{to{transform:translateY(0)}}
.hero-sub{
  margin-top:26px;display:flex;flex-wrap:wrap;align-items:center;gap:10px 20px;
  opacity:0;animation:fadeUp .9s var(--ease) .55s forwards;
}
.hero-sub .tag{font-weight:700;font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:#eef1f5}
.hero-sub .dot{width:5px;height:5px;border-radius:50%;background:var(--blue)}
.hero-cta{margin-top:40px;display:flex;flex-wrap:wrap;gap:16px;opacity:0;animation:fadeUp .9s var(--ease) .72s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.hero-credit{position:absolute;right:28px;bottom:24px;z-index:2;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.42)}
.scrollcue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--muted);font-size:10px;letter-spacing:.25em;text-transform:uppercase}
.scrollcue .line{width:1px;height:46px;background:linear-gradient(var(--blue),transparent);animation:cue 2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media(max-width:760px){.hero-credit,.scrollcue{display:none}.hero-inner{padding-bottom:64px}}
@media(max-width:600px){
  .hero-flag{align-items:flex-start}
  .hero-flag .bar{margin-top:7px}
  .hf-sep{display:none}
  .hf-team{display:block;margin-top:5px}
}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{background:var(--blue);overflow:hidden;border-top:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(0,0,0,.2)}
.marquee-track{display:flex;gap:0;white-space:nowrap;animation:scrollX 32s linear infinite;will-change:transform}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--display);font-size:1.5rem;text-transform:uppercase;color:#fff;padding:16px 0;letter-spacing:.03em;display:inline-flex;align-items:center}
.marquee-track span::after{content:"\2605";color:rgba(255,255,255,.55);margin:0 30px;font-size:1rem}
@keyframes scrollX{to{transform:translateX(-50%)}}

/* ============================================================
   RETURN
   ============================================================ */
.return{background:var(--ink-2);position:relative;overflow:hidden}
.return::before{content:"06";position:absolute;top:-4%;right:2%;font-family:var(--display);font-size:34vw;color:rgba(255,255,255,.018);line-height:1;pointer-events:none}
.return .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:70px;align-items:center}
.return .big{font-family:var(--display);font-size:clamp(2.4rem,5vw,4.4rem);text-transform:uppercase;line-height:1;margin:0 0 26px}
.return .big em{font-style:normal;color:var(--gold)}
.return p{color:#c3cbd5;margin:0 0 20px}
.return p:last-of-type{margin-bottom:34px}
.return-media{position:relative}
.return-media img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:50% 22%;border:1px solid var(--line)}
.return-media .badge{
  position:absolute;left:-22px;bottom:34px;background:var(--blue);color:#fff;
  padding:22px 26px;max-width:230px;box-shadow:0 24px 60px rgba(0,0,0,.5);
}
.return-media .badge b{font-family:var(--display);font-size:2.6rem;display:block;line-height:1}
.return-media .badge span{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600}
@media(max-width:900px){.return .grid{grid-template-columns:1fr;gap:46px}.return-media .badge{left:14px}}

/* ============================================================
   STATS
   ============================================================ */
.stats{background:var(--ink)}
.stats-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:54px}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
.stat{background:var(--ink);padding:46px 38px;transition:.4s var(--ease)}
.stat:hover{background:var(--panel)}
.stat .num{font-family:var(--display);font-size:clamp(3rem,5vw,4.6rem);line-height:.9;color:#fff}
.stat .num .u{color:var(--blue);font-size:.55em;margin-left:2px}
.stat:hover .num .u{color:var(--gold)}
.stat .lbl{margin-top:14px;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}
.stat .sub{margin-top:6px;font-size:13px;color:var(--muted-2)}
@media(max-width:820px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.stat-grid{grid-template-columns:1fr}.stat{padding:34px 28px}}

/* ============================================================
   STORY
   ============================================================ */
.story{background:var(--panel-2);position:relative}
.story .grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:74px;align-items:center}
.story-media{position:relative}
.story-credit{position:absolute;right:0;bottom:-22px;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.story-media img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:50% 18%;border:1px solid var(--line)}
.story-media::before{content:"";position:absolute;inset:18px -18px -18px 18px;border:1px solid var(--blue);z-index:-1;opacity:.5}
.story h2{margin-bottom:26px}
.story p{color:#c3cbd5;margin:0 0 20px}
.story .pull{font-family:var(--display);font-size:clamp(1.4rem,2.4vw,2.1rem);color:#fff;text-transform:uppercase;line-height:1.05;margin:34px 0;padding-left:24px;border-left:3px solid var(--blue)}
.story .sig{margin-top:30px;display:flex;align-items:center;gap:16px;color:var(--muted);font-size:14px}
.story .sig b{color:#fff;font-weight:700}
@media(max-width:900px){.story .grid{grid-template-columns:1fr;gap:46px}.story-media{order:-1}}

/* ============================================================
   RESUME / HARDWARE
   ============================================================ */
.resume{background:var(--ink);position:relative}
.resume::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 0%,rgba(59,140,255,.07),transparent 55%);pointer-events:none}
.res-list{position:relative;margin-top:54px;border-top:1px solid var(--line)}
.res-row{
  display:grid;grid-template-columns:130px 1fr auto;gap:30px;align-items:center;
  padding:26px 6px;border-bottom:1px solid var(--line);transition:.35s var(--ease);
}
.res-row:hover{background:var(--panel);padding-left:20px;padding-right:20px}
.res-row .yr{font-family:var(--display);font-size:1.7rem;color:var(--blue);transition:.35s}
.res-row:hover .yr{color:var(--gold)}
.res-row .ev{font-size:1.05rem;font-weight:600;color:#fff}
.res-row .ev small{display:block;font-weight:400;font-size:.86rem;color:var(--muted);margin-top:3px;letter-spacing:.02em}
.res-row .medal{font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:7px 14px;border:1px solid var(--line);border-radius:2px;color:var(--muted);white-space:nowrap}
.res-row .medal.gold{color:var(--gold);border-color:rgba(230,192,103,.45)}
.res-row .medal.silver{color:#cfd6df;border-color:var(--line)}
@media(max-width:720px){
  .res-row{grid-template-columns:64px 1fr;gap:16px}
  .res-row .yr{font-size:1.2rem}
  .res-row .medal{grid-column:2;justify-self:start;margin-top:4px}
}

/* ============================================================
   BEYOND THE MAT
   ============================================================ */
.beyond{background:var(--ink-2)}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:54px}
.card{
  position:relative;display:flex;flex-direction:column;padding:40px 36px 34px;
  background:linear-gradient(165deg,#151d2b 0%,#0c1019 100%);
  border:1px solid var(--line);border-radius:4px;overflow:hidden;
  transition:transform .4s var(--ease),border-color .4s var(--ease),box-shadow .4s var(--ease);
}
.card>*{position:relative;z-index:1}
.card::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;z-index:2;background:linear-gradient(90deg,var(--blue),rgba(59,140,255,0));opacity:.35;transition:.45s var(--ease)}
.card::after{content:"";position:absolute;top:-30%;right:-15%;width:60%;height:75%;z-index:0;background:radial-gradient(circle,rgba(59,140,255,.2),transparent 70%);opacity:0;transition:.45s var(--ease);pointer-events:none}
.card:hover{transform:translateY(-6px);border-color:rgba(59,140,255,.5);box-shadow:0 26px 54px rgba(0,0,0,.5)}
.card:hover::before{opacity:1}
.card:hover::after{opacity:1}
.card .ico{font-size:24px;color:var(--blue);margin-bottom:22px}
.card h3{font-size:1.45rem;margin-bottom:12px}
.card p{color:var(--muted);font-size:.98rem;margin:0 0 26px}
.card .link{
  margin-top:auto;align-self:flex-start;
  display:inline-flex;align-items:center;gap:10px;
  font-size:11.5px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#fff;
  padding:12px 20px;border:1px solid var(--line);border-radius:3px;
  transition:background .3s var(--ease),border-color .3s var(--ease),color .3s var(--ease);
}
.card .link .arr{color:var(--blue);transition:transform .3s var(--ease),color .3s var(--ease)}
.card:hover .link,.card .link:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.card:hover .link .arr,.card .link:hover .arr{color:#fff;transform:translateX(4px)}
@media(max-width:720px){.cards{grid-template-columns:1fr}}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{background:var(--ink)}
.g-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:230px;gap:14px;margin-top:54px}
.g-item{position:relative;overflow:hidden;cursor:pointer;border:1px solid var(--line-soft)}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .5s}
.g-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(8,10,14,.7));opacity:.5;transition:.4s}
.g-item:hover img{transform:scale(1.07)}
.g-item:hover::after{opacity:.85}
.g-item .cap{position:absolute;left:18px;bottom:14px;z-index:2;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:0;transform:translateY(8px);transition:.4s}
.g-item:hover .cap{opacity:1;transform:translateY(0)}
.g-tall{grid-row:span 2}
.g-wide{grid-column:span 2}
.g-credit{margin-top:22px;text-align:right;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2)}
@media(max-width:820px){.g-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}.g-wide{grid-column:span 2}.g-tall{grid-row:span 1}}

/* ============================================================
   CTA STRIP
   ============================================================ */
.cta{position:relative;padding:130px 0;text-align:center;overflow:hidden}
.cta-bg{position:absolute;inset:0;z-index:0}
.cta-bg img{width:100%;height:100%;object-fit:cover;object-position:50% 30%}
.cta-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,10,14,.86),rgba(10,75,176,.55))}
.cta .wrap{position:relative;z-index:2}
.cta h2{margin:0 0 22px}
.cta p{max-width:560px;margin:0 auto 36px;color:#dde3ea}

/* ============================================================
   FOOTER
   ============================================================ */
.sponsors{background:var(--ink);padding:64px 0;border-top:1px solid var(--line-soft)}
.sponsors .lbl{text-align:center;font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted-2);margin-bottom:34px}
.sponsor-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:18px 46px}
.sponsor-row a{font-family:var(--display);font-size:1.4rem;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;transition:.3s;opacity:.65}
.sponsor-row a:hover{color:#fff;opacity:1}

footer.foot{background:var(--ink-2);border-top:1px solid var(--line-soft);padding:80px 0 36px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:50px;padding-bottom:56px;border-bottom:1px solid var(--line-soft)}
.foot-brand img{height:54px;margin-bottom:20px}
.foot-brand p{color:var(--muted);font-size:.95rem;max-width:430px}
.foot-col h4{font-family:var(--body);font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-2);margin:0 0 20px}
.foot-col a{display:block;color:#cfd6df;font-size:.97rem;padding:7px 0;transition:.25s}
.foot-col a:hover{color:var(--blue);transform:translateX(4px)}
.foot-social{display:flex;gap:16px;margin-top:8px}
.foot-social a{width:42px;height:42px;border:1px solid var(--line);border-radius:50%;display:grid;place-items:center;color:#cfd6df;font-size:16px;transition:.3s}
.foot-social a:hover{background:var(--blue);border-color:var(--blue);color:#fff;transform:translateY(-3px)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px;padding-top:30px}
.foot-bottom .copy{font-size:13px;color:var(--muted-2)}
.credits{display:flex;align-items:center;gap:30px;flex-wrap:wrap}
.credit{display:flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2)}
.credit img{height:18px;width:auto;opacity:.92;transition:.3s}
.credit:hover img{opacity:1}
.credit.gs img{height:14px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr;gap:40px}.foot-bottom{flex-direction:column;align-items:flex-start}}

/* ---------- Lightbox ---------- */
.lb{position:fixed;inset:0;z-index:120;background:rgba(5,6,9,.96);display:none;align-items:center;justify-content:center;padding:40px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:86vh;object-fit:contain;border:1px solid var(--line)}
.lb .x{position:absolute;top:24px;right:30px;font-size:34px;color:#fff;cursor:pointer;background:none;border:0;line-height:1}
.lb .nav-arrow{position:absolute;top:50%;transform:translateY(-50%);font-size:34px;color:#fff;cursor:pointer;background:none;border:0;padding:18px;opacity:.7;transition:.25s}
.lb .nav-arrow:hover{opacity:1}
.lb .prev{left:14px}.lb .next{right:14px}
.lb .lb-credit{position:absolute;bottom:22px;left:0;right:0;text-align:center;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(38px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .hero h1 .ln i{transform:none}
}

/* ============================================================
   ADDED — v2 (2026 run, schedule, media, forms, partners)
   ============================================================ */

/* ---------- 2026 RUN ---------- */
.run{background:var(--panel-2);position:relative;overflow:hidden}
.run::before{content:"5\2013 0";position:absolute;top:-6%;right:-1%;font-family:var(--display);font-size:26vw;color:rgba(59,140,255,.04);line-height:1;pointer-events:none}
.run-head{max-width:760px;margin-bottom:50px}
.run-head h2{margin-bottom:22px}
.run-banner{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);margin-bottom:46px}
.run-banner .b{background:var(--ink);padding:34px 30px;text-align:center}
.run-banner .b .n{font-family:var(--display);font-size:clamp(2.4rem,4.4vw,3.6rem);color:var(--blue);line-height:.9}
.run-banner .b .l{margin-top:10px;font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600}
.bouts{border-top:1px solid var(--line)}
.bout{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;padding:22px 6px;border-bottom:1px solid var(--line);transition:.3s var(--ease)}
.bout:hover{background:var(--panel);padding-left:18px;padding-right:18px}
.bout .opp{font-size:1.15rem;font-weight:700;color:#fff}
.bout .opp small{display:block;font-weight:400;font-size:.85rem;color:var(--muted);margin-top:3px;letter-spacing:.02em}
.bout .score{font-family:var(--display);font-size:1.5rem;color:var(--blue);white-space:nowrap;display:flex;align-items:center;gap:12px}
.bout .score .w{font-size:11px;font-weight:700;letter-spacing:.12em;color:#0b1018;background:var(--blue);padding:5px 10px;border-radius:2px;font-family:var(--body)}
@media(max-width:600px){.run-banner{grid-template-columns:1fr}.bout .opp{font-size:1rem}}

/* ---------- SCHEDULE / NEXT ---------- */
.next{background:var(--ink)}
.next-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:start;margin-top:50px}
.next-feature{position:relative;border:1px solid var(--line);background:linear-gradient(160deg,#0e1626,#0b0f17);padding:40px 36px}
.next-feature .tagline{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:18px}
.next-feature h3{font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:8px}
.next-feature .loc{color:var(--muted);font-size:.98rem;margin-bottom:24px}
.next-feature .flo{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff;border:1px solid var(--line);padding:12px 18px;border-radius:2px;transition:.3s}
.next-feature .flo:hover{border-color:var(--blue);background:rgba(59,140,255,.08)}
.next-feature .flo i{color:var(--blue)}
.next-feature .wt{margin-top:26px;padding-top:22px;border-top:1px solid var(--line);font-size:.92rem;color:var(--muted)}
.sched{position:relative}
.sched .day{font-family:var(--display);font-size:1.3rem;color:#fff;margin:0 0 4px;padding-top:18px}
.sched .day:first-child{padding-top:0}
.sched .slot{display:grid;grid-template-columns:170px 1fr;gap:20px;padding:16px 0;border-bottom:1px solid var(--line-soft)}
.sched .slot .time{font-weight:700;color:var(--blue);font-size:.95rem}
.sched .slot .ev{color:#cfd6df;font-size:.97rem}
.sched .note{margin-top:18px;font-size:.85rem;color:var(--muted-2)}
@media(max-width:860px){.next-wrap{grid-template-columns:1fr;gap:36px}.sched .slot{grid-template-columns:130px 1fr;gap:14px}}

/* ---------- AFFILIATION CARDS w/ logos ---------- */
.card .card-logo{height:58px;display:flex;align-items:center;margin-bottom:24px}
.card .card-logo img{max-height:58px;max-width:180px;width:auto;object-fit:contain}
.card .card-logo.mono img{filter:brightness(0) invert(1);opacity:.92}

/* ---------- MEDIA (featured + list) ---------- */
.media{background:var(--panel-2);position:relative;overflow:hidden}
.media::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:
  radial-gradient(circle at 82% 6%,rgba(59,140,255,.13),transparent 46%),
  radial-gradient(circle at 4% 96%,rgba(59,140,255,.08),transparent 42%)}
.media::after{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.6;
  background-image:radial-gradient(rgba(255,255,255,.045) 1px,transparent 1px);background-size:24px 24px;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 18%,#000 82%,transparent);
  mask-image:linear-gradient(180deg,transparent,#000 18%,#000 82%,transparent)}
.media .wrap{position:relative;z-index:1}
.media-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;margin-bottom:46px}
.media-all{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;border:1px solid var(--line);padding:14px 22px;border-radius:2px;display:inline-flex;align-items:center;gap:10px;transition:.3s var(--ease)}
.media-all:hover{border-color:var(--blue);background:rgba(59,140,255,.08)}
.media-all .arr{color:var(--blue);transition:transform .3s var(--ease)}
.media-all:hover .arr{transform:translateX(5px)}
.media-feature{display:grid;grid-template-columns:1.5fr 1fr;gap:26px;align-items:stretch}
.vid{position:relative;cursor:pointer;border:1px solid var(--line-soft);overflow:hidden;background:#000;transition:.4s var(--ease)}
.vid:hover{border-color:rgba(59,140,255,.5);transform:translateY(-3px)}
.vid .poster{position:relative;aspect-ratio:16/9;overflow:hidden}
.vid .poster img{width:100%;height:100%;object-fit:cover;transition:.7s var(--ease)}
.vid:hover .poster img{transform:scale(1.06)}
.vid .poster::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,10,14,.1) 0%,transparent 35%,transparent 60%,rgba(8,10,14,.55) 100%);transition:.4s}
.vid .play{position:absolute;inset:0;display:grid;place-items:center;z-index:2}
.vid .play span{width:62px;height:62px;border-radius:50%;background:rgba(59,140,255,.94);display:grid;place-items:center;color:#fff;font-size:19px;padding-left:4px;transition:.3s var(--ease);box-shadow:0 12px 44px rgba(0,0,0,.55)}
.vid:hover .play span{transform:scale(1.12);background:#fff;color:var(--blue)}
.vbadge{position:absolute;top:16px;left:16px;z-index:3;background:rgba(8,10,14,.78);backdrop-filter:blur(4px);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:7px 12px;border-radius:2px}
.vid .meta{padding:22px 24px}
.vid .src{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
.vid-lg .meta h3{font-size:clamp(1.3rem,2vw,1.7rem);line-height:1.05}
.vid-lg .meta p{margin:12px 0 0;color:var(--muted);font-size:.96rem}
.media-side{display:flex;flex-direction:column;gap:24px}
.vid-sm{flex:1;display:grid;grid-template-columns:44% 1fr;align-items:stretch}
.vid-sm .poster{aspect-ratio:auto;height:100%;min-height:130px}
.vid-sm .play span{width:46px;height:46px;font-size:14px}
.vid-sm .meta{display:flex;flex-direction:column;justify-content:center;padding:18px 22px}
.vid-sm .meta h3{font-size:1.08rem;line-height:1.12}
@media(max-width:860px){
  .media-feature{grid-template-columns:1fr}
  .vid-sm{grid-template-columns:40% 1fr}
  .vid-sm .poster{min-height:110px}
}
@media(max-width:520px){.vid-sm{grid-template-columns:1fr}.vid-sm .poster{aspect-ratio:16/9;height:auto}}

/* ---------- FORMS ---------- */
.connect2{background:var(--ink);position:relative}
.connect2::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 15% 10%,rgba(59,140,255,.07),transparent 50%);pointer-events:none}
.connect-head{max-width:720px;margin-bottom:48px;position:relative}
.connect-head .lead{margin-top:18px}
.connect-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:start;position:relative}
.connect-left{display:flex;flex-direction:column;gap:24px}
.contact-info a{display:flex;align-items:center;gap:14px;color:#cfd6df;padding:12px 0;font-size:1rem;transition:.25s;border-bottom:1px solid var(--line-soft)}
.contact-info a:hover{color:var(--blue)}
.contact-info a i{color:var(--blue);width:20px;text-align:center}
form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
form .field{margin-bottom:16px}
form label{display:block;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.inp{width:100%;background:var(--panel);border:1px solid var(--line);color:#fff;font-family:var(--body);font-size:15px;padding:14px 16px;border-radius:2px;transition:.25s;-webkit-appearance:none;appearance:none}
.inp:focus{outline:none;border-color:var(--blue);background:#141b27;box-shadow:0 0 0 3px rgba(59,140,255,.12)}
.inp::placeholder{color:var(--muted-2)}
select.inp{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%233b8cff' stroke-width='1.6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;background-size:12px;padding-right:42px}
textarea.inp{resize:vertical;min-height:130px}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}
form .submit{width:100%;justify-content:center;margin-top:6px}
form .submit:disabled{opacity:.55;cursor:wait}
.form-msg{display:none;margin-top:16px;padding:14px 18px;border-radius:2px;font-size:.92rem}
.form-msg.show{display:block}
.form-msg.ok{background:rgba(59,140,255,.12);border:1px solid rgba(59,140,255,.4);color:#cfe1ff}
.form-msg.err{background:rgba(255,80,80,.1);border:1px solid rgba(255,80,80,.35);color:#ffd2d2}
.form-fine{margin-top:14px;font-size:12px;color:var(--muted-2)}
@media(max-width:860px){.connect-grid{grid-template-columns:1fr;gap:40px}form .row{grid-template-columns:1fr}}

/* ---------- NEWSLETTER (dark card) ---------- */
.news{background:var(--ink-2);padding:84px 0}
.news-card{position:relative;overflow:hidden;background:linear-gradient(135deg,#0f1932,#0b0f17);border:1px solid var(--line);border-radius:6px;padding:52px 56px;display:grid;grid-template-columns:1fr minmax(360px,440px);gap:48px;align-items:center}
.news-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 92% 6%,rgba(59,140,255,.2),transparent 52%);pointer-events:none}
.news-copy{position:relative;z-index:1}
.news-copy h3{color:#fff;font-size:clamp(1.9rem,3.2vw,2.7rem);margin:4px 0 10px}
.news-copy p{color:var(--muted);font-size:1rem;margin:0;max-width:430px}
.news-form{position:relative;z-index:1}
.news-input{display:flex;gap:10px}
.news-input input{flex:1;min-width:0;background:var(--ink);border:1px solid var(--line);color:#fff;padding:16px 18px;border-radius:2px;font-family:var(--body);font-size:15px;transition:.25s}
.news-input input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,140,255,.12)}
.news-input input::placeholder{color:var(--muted-2)}
.news-input .btn{white-space:nowrap}
.news .news-msg{margin-top:14px;font-size:13.5px;display:none}
.news .news-msg.show{display:block}
.news .news-msg.ok{color:var(--blue)}
.news .news-msg.err{color:#ff9b9b}
@media(max-width:820px){.news-card{grid-template-columns:1fr;padding:40px 32px;gap:24px}}

/* ---------- PARTNERS LOGOS ---------- */
.sponsor-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:34px 64px}
.sponsor-logos a{display:flex;align-items:center;transition:.35s var(--ease);opacity:.62;filter:grayscale(1) brightness(1.6)}
.sponsor-logos a:hover{opacity:1;filter:none;transform:translateY(-3px)}
.sponsor-logos img{height:46px;width:auto;object-fit:contain}
.sponsor-logos a.mono{filter:brightness(0) invert(1);opacity:.6}
.sponsor-logos a.mono:hover{filter:brightness(0) invert(1);opacity:1}
@media(max-width:600px){.sponsor-logos{gap:26px 36px}.sponsor-logos img{height:34px}}

/* ---------- FOOTER LOGO BIGGER ---------- */
.foot-brand img{height:84px}

/* ---------- VIDEO LIGHTBOX ---------- */
.vlb{position:fixed;inset:0;z-index:130;background:rgba(5,6,9,.96);display:none;align-items:center;justify-content:center;padding:40px}
.vlb.open{display:flex}
.vlb .frame{position:relative;width:min(1000px,92vw);aspect-ratio:16/9}
.vlb iframe{width:100%;height:100%;border:0}
.vlb .x{position:absolute;top:-46px;right:0;font-size:32px;color:#fff;cursor:pointer;background:none;border:0;line-height:1}

/* ============================================================
   ADDED — v3 (run photo, worlds bg, resume collapse, connect photo, usaw)
   ============================================================ */

/* ---------- 2026 RUN: compact highlight band ---------- */
.run{padding:84px 0}
.run::before{font-size:18vw;top:8%}
.run-compact{display:grid;grid-template-columns:.66fr 1.34fr;gap:46px;align-items:center}
.run-media{position:relative}
.run-media img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:50% 10%;border:1px solid var(--line)}
.run-credit{position:absolute;right:0;bottom:-20px;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.run-info h2{margin-bottom:16px}
.run-info p{margin:0 0 22px;max-width:520px}
.run-stats-inline{display:flex;gap:40px;flex-wrap:wrap;padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.run-stats-inline .n{font-family:var(--display);font-size:clamp(2rem,3.4vw,2.9rem);color:var(--blue);line-height:.9;display:block}
.run-stats-inline .l{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:8px;display:block}
.bouts-toggle{margin-top:24px;border:1px solid var(--line);border-radius:2px;background:var(--ink)}
.bouts-toggle summary{cursor:pointer;list-style:none;padding:18px 22px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:12px}
.bouts-toggle summary::-webkit-details-marker{display:none}
.bouts-toggle summary i{color:var(--blue);transition:transform .3s var(--ease)}
.bouts-toggle[open] summary i{transform:rotate(180deg)}
.bouts-toggle summary:hover{color:var(--blue)}
.bouts-toggle .bouts{border-top:1px solid var(--line);padding:0 22px}
.bouts-toggle .bout{padding:16px 0}
.bouts-toggle .bout:hover{background:none;padding-left:0;padding-right:0}
.bouts-toggle .bout .opp{font-size:1rem}
.bouts-toggle .bout .score{font-size:1.25rem}
@media(max-width:820px){.run-compact{grid-template-columns:1fr;gap:38px}.run-media img{aspect-ratio:5/4;object-position:50% 18%}.run-credit{bottom:-18px}.run-stats-inline{gap:28px}}

/* ---------- WHAT'S NEXT bg ---------- */
.next{overflow:hidden}
.next-bg{position:absolute;inset:0;z-index:0}
.next-bg img{width:100%;height:100%;object-fit:cover;object-position:50% 58%;filter:brightness(.9) saturate(1.04)}
.next-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(8,10,14,.74) 0%,rgba(8,10,14,.55) 50%,rgba(8,10,14,.92) 100%),
  linear-gradient(90deg,rgba(8,10,14,.6) 0%,rgba(8,10,14,.52) 55%,rgba(8,10,14,.66) 100%)}
.next .wrap{position:relative;z-index:2}
.next-feature{background:linear-gradient(160deg,rgba(14,22,38,.92),rgba(11,15,23,.92));backdrop-filter:blur(4px)}

/* ---------- RÉSUMÉ collapse ---------- */
.res-extra{display:none}
body.resume-open .res-extra{display:grid;animation:fadeUp .5s var(--ease) both}
.res-more-btn{margin-top:30px;display:inline-flex;align-items:center;gap:12px;background:none;border:1px solid var(--line);color:#fff;font-family:var(--body);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;padding:15px 26px;border-radius:2px;cursor:pointer;transition:.3s var(--ease)}
.res-more-btn:hover{border-color:var(--blue);background:rgba(59,140,255,.08);color:var(--blue)}
.res-more-btn i{color:var(--blue)}

/* ---------- CONNECT photo ---------- */
.connect-photo{border:1px solid var(--line);overflow:hidden}
.connect-photo img{width:100%;aspect-ratio:16/10;object-fit:cover;object-position:50% 30%;transition:transform .8s var(--ease)}
.connect-photo:hover img{transform:scale(1.04)}
@media(max-width:860px){.connect-photo{display:none}}
