/* =========================================================
   Travis Isaacs — recruiting one-pager
   Frederick Douglass HS gold + black. Mobile-first.
   ========================================================= */

:root{
  --ink:#0c0c0e;
  --ink-2:#141418;
  --panel:#16161b;
  --gold:#d2a64a;
  --gold-2:#e7c977;
  --white:#f4f4f1;
  --muted:#bcc0c9;       /* AA on dark for body text */
  --muted-2:#9a9fab;     /* AA for large text only */
  --line:rgba(255,255,255,.12);
  --wrap:1120px;
  --r:14px;
  --shadow:0 18px 50px rgba(0,0,0,.45);
  --ff-disp:"Oswald",system-ui,"Arial Narrow",sans-serif;
  --ff-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--ink);
  color:var(--white);
  font-family:var(--ff-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

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

h1,h2{font-family:var(--ff-disp);font-weight:700;text-transform:uppercase;line-height:.96;letter-spacing:.01em;margin:0}
h2{font-size:clamp(2rem,5vw,3.2rem)}

/* ---------- skip link / focus ---------- */
.skip{position:absolute;left:-9999px;top:0;background:var(--gold);color:#1a1407;padding:10px 16px;z-index:200;border-radius:0 0 8px 0;font-weight:600}
.skip:focus{left:0}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{
  outline:3px solid var(--gold-2);outline-offset:2px;border-radius:4px
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;justify-content:center;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));
  color:#1a1407;font-weight:700;font-family:var(--ff-body);
  padding:14px 22px;border-radius:999px;border:0;cursor:pointer;
  letter-spacing:.01em;transition:transform .15s ease,box-shadow .15s ease;
  box-shadow:0 8px 22px rgba(210,166,74,.28);
}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(210,166,74,.4)}
.btn--lg{padding:16px 30px;font-size:1.05rem}
.btn--sm{padding:9px 16px;font-size:.92rem}
.btn--ghost{
  background:transparent;color:var(--gold-2);
  border:1.5px solid rgba(231,201,119,.55);box-shadow:none
}
.btn--ghost:hover{background:rgba(231,201,119,.1);box-shadow:none}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s ease,backdrop-filter .3s ease}
.nav--scrolled{background:rgba(10,10,12,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav__row{display:flex;align-items:center;justify-content:space-between;height:64px}
.nav__brand{font-family:var(--ff-disp);font-weight:700;font-size:1.15rem;letter-spacing:.06em}
.nav__brand span{color:var(--gold)}
.nav__menu{display:flex;align-items:center;gap:26px}
.nav__menu>a:not(.btn){color:var(--white);font-weight:500;font-size:.98rem;opacity:.9}
.nav__menu>a:not(.btn):hover{opacity:1;color:var(--gold-2)}
.nav__menu>a.nav__login{font-size:.82rem;color:var(--muted);border:1px solid var(--line);border-radius:99px;padding:7px 14px;opacity:1}
.nav__menu>a.nav__login:hover{color:var(--gold-2);border-color:rgba(231,201,119,.5)}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:0;border:0;padding:8px;cursor:pointer}
.nav__toggle span{width:24px;height:2px;background:var(--white);border-radius:2px;transition:.25s}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:820px){
  .nav__toggle{display:flex}
  .nav__menu{
    position:fixed;top:64px;right:0;left:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:rgba(10,10,12,.97);backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);
    padding:10px 22px 22px;
    transform:translateY(-130%);transition:transform .32s cubic-bezier(.4,0,.2,1);
  }
  .nav__menu.open{transform:translateY(0)}
  .nav__menu>a{padding:14px 4px;border-bottom:1px solid var(--line)}
  .nav__menu>.btn{margin-top:14px;border-bottom:0}
}

/* ---------- hero ---------- */
.hero{position:relative;min-height:94vh;display:flex;align-items:flex-end;overflow:hidden}
.hero__media{
  position:absolute;inset:0;
  background:#222 url("img/t9-hero.jpg") 48% 24% / cover no-repeat;
  transform:scale(1.04);
}
.hero__veil{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(8,8,10,.8) 0%,rgba(8,8,10,.32) 20%,rgba(8,8,10,.14) 42%,rgba(8,8,10,.6) 70%,rgba(8,8,10,.96) 100%),
    linear-gradient(90deg,rgba(8,8,10,.85) 0%,rgba(8,8,10,.5) 32%,transparent 62%);
}
.hero__inner{position:relative;z-index:2;padding-bottom:70px;padding-top:120px}
.eyebrow{font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.22em;font-size:.8rem;color:var(--gold-2);margin:0 0 14px}
.hero__name{font-size:clamp(3.4rem,13vw,8.2rem);text-shadow:0 4px 30px rgba(0,0,0,.5)}
.hero__name br{line-height:.86}
.hero__tag{font-size:clamp(1.05rem,2.6vw,1.5rem);margin:16px 0 26px;max-width:30ch;color:#f1efe9;text-shadow:0 1px 3px rgba(0,0,0,.72),0 2px 16px rgba(0,0,0,.5)}
.hero__tag strong{color:#f6dd8e;text-shadow:0 1px 2px rgba(0,0,0,.92),0 1px 9px rgba(0,0,0,.7)}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero__facts{
  list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin:34px 0 0;padding:0;
}
.hero__facts li{
  background:rgba(20,20,24,.6);backdrop-filter:blur(6px);
  border:1px solid var(--line);border-radius:12px;padding:11px 18px;min-width:96px
}
.hero__facts span{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted-2)}
.hero__facts b{font-family:var(--ff-disp);font-size:1.5rem;color:var(--white)}
.hero__scroll{
  position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:2;
  color:var(--gold-2);font-size:1.4rem;opacity:.85;animation:bob 1.8s ease-in-out infinite
}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- sections ---------- */
.section{padding:88px 0;position:relative}
.section--dark{background:var(--ink-2)}
.kicker{font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.2em;color:var(--gold);font-size:.82rem;margin:0 0 10px}
.lead{font-size:1.18rem;color:var(--muted);max-width:60ch;margin:14px 0 0}
.small{font-size:.95rem;color:var(--muted-2)}

/* ---------- film ---------- */
.film{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;margin-top:36px;align-items:stretch}
.film__card{
  position:relative;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:16px;
  background:linear-gradient(150deg,#1d1d22,#101014);
  border:1px solid var(--line);border-radius:var(--r);padding:48px 24px;text-align:center;min-height:220px;
  transition:border-color .2s ease,transform .2s ease
}
.film__card:hover{border-color:rgba(231,201,119,.5);transform:translateY(-3px)}
.film__play{
  width:74px;height:74px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#1a1407;font-size:1.6rem;padding-left:4px;
  box-shadow:0 10px 30px rgba(210,166,74,.4)
}
.film__label{font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.08em;font-size:1.1rem}
.film__impact{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);position:relative}
.film__impact img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.film__cap{position:absolute;left:0;right:0;bottom:0;margin:0;padding:26px 16px 12px;font-size:.85rem;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.8));color:#e9e7e1}

/* ---------- hudl video embed ---------- */
.tape{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:#0e0e12}
.tape iframe{width:100%;aspect-ratio:16/9;display:block;border:0}
.tape__poster{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  min-height:260px;height:100%;text-align:center;padding:30px 20px;
  background-image:linear-gradient(rgba(8,8,10,.5),rgba(8,8,10,.66)),url("img/nine-helmet.jpg");
  background-size:cover;background-position:center 20%}
.tape__play{width:78px;height:78px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#1a1407;font-size:1.8rem;padding-left:5px;
  box-shadow:0 12px 30px rgba(0,0,0,.55);transition:transform .15s ease}
.tape__poster:hover .tape__play{transform:scale(1.08)}
.tape__txt{font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.08em;font-size:1.2rem;color:#fff}
.tape__src{font-size:.78rem;color:var(--gold-2);text-transform:uppercase;letter-spacing:.2em}
.tape--main{margin-top:34px}
.tape-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:16px}
.film__more{margin-top:24px}
@media (max-width:680px){.tape-grid{grid-template-columns:1fr}}

/* ---------- stat grids ---------- */
.grid{display:grid;gap:14px;margin-top:34px}
.grid--stats{grid-template-columns:repeat(4,1fr)}
.grid--acad{grid-template-columns:repeat(4,1fr)}
.stat{
  background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px 18px 16px;
}
.stat span{display:block;font-size:.74rem;text-transform:uppercase;letter-spacing:.13em;color:var(--muted-2);margin-bottom:6px}
.stat b{font-family:var(--ff-disp);font-size:1.7rem;color:var(--gold-2);line-height:1.05;display:block}
.stat b small{font-family:var(--ff-body);font-size:.7rem;color:var(--muted-2);letter-spacing:0}
.todo{color:var(--muted-2)!important;font-family:var(--ff-body)!important;font-size:1rem!important;font-style:italic}

.callout{margin-top:26px;border-left:3px solid var(--gold);background:rgba(210,166,74,.07);
  padding:16px 20px;border-radius:0 10px 10px 0}
.callout p{margin:0;color:#e9e7e1}

/* ---------- scouting split ---------- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.split__text .lead{margin-bottom:8px}
.checks{list-style:none;margin:22px 0 18px;padding:0;display:grid;gap:11px}
.checks li{position:relative;padding-left:30px;color:#e7e6e1}
.checks li::before{content:"";position:absolute;left:0;top:.45em;width:15px;height:9px;
  border-left:2.5px solid var(--gold);border-bottom:2.5px solid var(--gold);transform:rotate(-45deg)}
.split__media{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.split__media img{width:100%;height:540px;object-fit:cover;object-position:center 20%}

/* ---------- gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:34px}
.gallery img{
  width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center 18%;
  border-radius:10px;border:1px solid var(--line);
  transition:transform .3s ease,filter .3s ease;filter:saturate(1.02)
}
.gallery img:hover{transform:scale(1.03)}

/* ---------- schedule ---------- */
.sched{width:100%;border-collapse:collapse;margin-top:30px;font-size:.98rem}
.sched th,.sched td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line)}
.sched thead th{font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;color:var(--gold)}
.sched tbody tr:hover{background:rgba(255,255,255,.03)}

/* ---------- contact ---------- */
.section--contact{background:linear-gradient(180deg,var(--ink-2),#0a0a0c)}
.contact{display:grid;grid-template-columns:1fr 1fr;gap:34px;margin-top:34px;align-items:start}
.contact__cards{display:grid;gap:14px}
.vcard{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px 20px}
.vcard__role{font-size:.74rem;text-transform:uppercase;letter-spacing:.13em;color:var(--gold)}
.vcard b{display:block;font-size:1.15rem;margin:4px 0 8px}
.vcard a{display:inline-block;color:var(--muted);margin-right:16px;border-bottom:1px solid transparent}
.vcard a:hover{color:var(--gold-2);border-bottom-color:var(--gold-2)}
.contact__form{display:grid;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:24px}
.contact__form label{display:grid;gap:6px;font-size:.85rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.contact__form input,.contact__form textarea{
  background:#0e0e12;border:1px solid var(--line);border-radius:9px;color:var(--white);
  font:inherit;padding:12px 14px;text-transform:none;letter-spacing:0
}
.contact__form input:focus,.contact__form textarea:focus{border-color:var(--gold)}
.hidden{position:absolute;left:-9999px}

/* ---------- footer + mobile bar ---------- */
.foot{border-top:1px solid var(--line);padding:30px 0;background:#0a0a0c}
.foot__row{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.foot p{margin:0;color:var(--muted-2);font-size:.9rem}
.foot b{color:var(--white)}
.foot__links a{margin-left:18px;color:var(--muted)}
.foot__links a:hover{color:var(--gold-2)}

.mobilebar{display:none}
@media (max-width:680px){
  .mobilebar{
    display:grid;grid-template-columns:1fr 1fr;gap:1px;
    position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--line)
  }
  .mobilebar a{background:var(--ink-2);text-align:center;padding:15px;font-weight:600;color:var(--white)}
  .mobilebar a:first-child{color:#1a1407;background:linear-gradient(180deg,var(--gold-2),var(--gold))}
  body{padding-bottom:54px}
}

/* ---------- responsive ---------- */
@media (max-width:820px){
  .film{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:26px}
  .split__media img{height:420px}
  .contact{grid-template-columns:1fr}
  .grid--stats,.grid--acad{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .section{padding:64px 0}
}
@media (max-width:420px){
  .hero__facts li{min-width:calc(50% - 6px);flex:1}
}

/* ---------- reveal on scroll (safe: visible unless JS opts in) ---------- */
body.reveal-ready .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
body.reveal-ready .reveal.is-in{opacity:1;transform:none}
body.reveal-ready .hero .reveal{opacity:1;transform:none}
/* film: videos stack into place on scroll */
body.reveal-ready .tape-grid .tape{transform:translateY(50px) scale(.93);transition:opacity .55s ease,transform .7s cubic-bezier(.16,.84,.34,1)}
body.reveal-ready .tape-grid .tape.is-in{transform:none}
body.reveal-ready .tape-grid .tape:nth-child(2){transition-delay:.1s}
body.reveal-ready .tape-grid .tape:nth-child(3){transition-delay:.2s}
body.reveal-ready .tape-grid .tape:nth-child(4){transition-delay:.3s}

/* ================= BENTO HUB + BBE design DNA ================= */
[hidden]{display:none!important}

/* hub nav: few items, always visible (no hamburger) */
.nav__menu--hub{display:flex!important;flex-direction:row!important;align-items:center;gap:16px;position:static!important;transform:none!important;background:none!important;border:0!important;padding:0!important}
@media (max-width:560px){.nav__menu--hub{gap:9px}}

/* compact hub hero */
.hero--hub{min-height:60svh}
@media (max-width:560px){.hero--hub{min-height:64svh}}
.hub__hint{font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.22em;font-size:.74rem;color:var(--gold);text-align:center;margin:34px 0 16px}

/* shimmer gold text (BBE stat-shimmer DNA) */
.shimmer{background:linear-gradient(135deg,#d2a64a 0%,#f6dd8e 50%,#d2a64a 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:shimmer-text 4.5s linear infinite}
@keyframes shimmer-text{0%{background-position:100% 50%}100%{background-position:-100% 50%}}

/* shimmer-sweep on buttons (BBE btn-gold DNA) */
.btn--shimmer{position:relative;overflow:hidden}
.btn--shimmer::before{content:"";position:absolute;top:0;left:0;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transform:translateX(-130%) skewX(-15deg);animation:btn-sweep 3.4s infinite;pointer-events:none}
@keyframes btn-sweep{0%{transform:translateX(-130%) skewX(-15deg)}55%,100%{transform:translateX(330%) skewX(-15deg)}}

/* bento grid */
.bento{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;padding-bottom:64px}
.bento__card{position:relative;display:flex;flex-direction:column;gap:6px;justify-content:flex-end;min-height:162px;
  padding:22px;border-radius:18px;background:var(--panel);border:1px solid var(--line);overflow:hidden;text-decoration:none;
  transition:transform .35s cubic-bezier(.16,.84,.34,1),border-color .35s ease,box-shadow .35s ease}
.bento__card:hover{transform:translateY(-4px);border-color:rgba(231,201,119,.5);box-shadow:0 18px 44px rgba(0,0,0,.4)}
.bento__k{font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;color:var(--gold)}
.bento__big{font-family:var(--ff-disp);font-weight:700;text-transform:uppercase;line-height:.98;font-size:clamp(1.6rem,5vw,2.3rem);color:var(--white)}
.bento__sub{color:var(--muted);font-size:.9rem}
.bento__arrow{position:absolute;top:20px;right:22px;color:var(--gold-2);font-size:1.2rem;transition:transform .25s ease;z-index:3}
.bento__card:hover .bento__arrow{transform:translateX(4px)}
.bento--wide{grid-column:1 / -1;min-height:268px}
.bento--story{background:linear-gradient(135deg,#15151a,#1d2026)}
.bento__play{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#1a1407;font-size:1.15rem;padding-left:3px;box-shadow:0 8px 24px rgba(0,0,0,.45);margin-bottom:4px}

/* every card carries a photo backdrop + zoom on hover (BBE exp-tile DNA) */
.bento__card{color:#fff}
.bento__card::before{content:"";position:absolute;inset:0;z-index:0;background:#17171c var(--img,none) var(--pos,50% 30%) / cover no-repeat;filter:saturate(1.05) brightness(.93);transition:transform .55s cubic-bezier(.4,0,.2,1)}
.bento__card::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,8,10,0) 0%,rgba(8,8,10,.22) 24%,rgba(8,8,10,.56) 44%,rgba(8,8,10,.75) 64%,rgba(8,8,10,.97) 100%)}
.bento__card:hover::before{transform:scale(1.06)}
.bento__card>*{position:relative;z-index:2;text-shadow:0 1px 2px rgba(0,0,0,.92),0 2px 14px rgba(0,0,0,.6)}
.bento__card .bento__sub{color:#eef0f2}
.bento__card .bento__big,.bento__card .bento__big.shimmer{text-shadow:0 0 2px rgba(0,0,0,.9),0 1px 1px rgba(0,0,0,.96),0 1px 7px rgba(0,0,0,.85),0 2px 16px rgba(0,0,0,.55)}
.bento--film,.bento--photo{min-height:210px}
.bento--film{grid-column:1 / -1}

/* statbar (BBE stat-bar DNA: shimmer numbers, no clutter boxes) */
.statbar{display:flex;flex-wrap:wrap;gap:0;margin:30px 0 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.statbar__item{flex:1 1 0;min-width:84px;display:flex;flex-direction:column;align-items:center;gap:5px;padding:22px 12px;border-right:1px solid var(--line)}
.statbar__item:last-child{border-right:0}
.statbar__item b{font-family:var(--ff-disp);font-weight:700;font-size:clamp(1.7rem,4.5vw,2.6rem);line-height:1;color:var(--gold-2)}
.statbar__item span{font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.13em;font-size:.64rem;color:var(--muted-2);text-align:center}
@media (max-width:560px){.statbar__item{flex-basis:33.33%;border-bottom:1px solid var(--line)}}

/* back link + view entrance */
.backhub{display:inline-block;margin-bottom:18px;font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;color:var(--muted)}
.backhub:hover{color:var(--gold-2)}
.view[data-view]:not(#hub){animation:view-in .5s cubic-bezier(.16,.84,.34,1)}
@keyframes view-in{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.split--player{margin-top:40px}
.split--player h3{font-family:var(--ff-disp);text-transform:uppercase;font-size:1.6rem;margin:0 0 10px}

@media (prefers-reduced-motion:reduce){
  .shimmer{animation:none}
  .btn--shimmer::before{display:none}
  .view[data-view]{animation:none}
}
@media (prefers-reduced-motion:reduce){
  body.reveal-ready .reveal{opacity:1!important;transform:none!important;transition:none}
  .hero__media{transform:none}
  .hero__scroll{animation:none}
}

/* anchor offset so the fixed nav doesn't hide section headings on jump */
section[id]{scroll-margin-top:74px}

/* ================= opening transition (name slam) ================= */
#intro{position:fixed;inset:0;z-index:300;background:#0c0c0e;overflow:hidden;display:grid;place-items:center;
  animation:slam-hide 2s cubic-bezier(.7,0,.3,1) forwards}
.intro__9{position:absolute;font-family:var(--ff-disp);font-weight:700;line-height:1;pointer-events:none;
  font-size:min(82vh,96vw);color:transparent;-webkit-text-stroke:2px rgba(210,166,74,.55);
  opacity:0;animation:slam-9 2s ease forwards}
.intro__name{position:relative;font-family:var(--ff-disp);font-weight:700;text-transform:uppercase;
  letter-spacing:.03em;line-height:.9;text-align:center;padding:0 16px;color:#fff;
  font-size:clamp(2.4rem,12vw,6.5rem);text-shadow:0 6px 30px rgba(0,0,0,.6);
  opacity:0;animation:slam-name 2s cubic-bezier(.2,.85,.25,1) forwards}
@keyframes slam-name{0%{opacity:0;transform:scale(2.5);filter:blur(10px)}13%{opacity:1;transform:scale(.9);filter:blur(0)}21%{transform:scale(1)}100%{opacity:1;transform:scale(1)}}
@keyframes slam-9{0%{opacity:0;transform:scale(1.5)}17%{opacity:.42;transform:scale(1)}100%{opacity:.42;transform:scale(1)}}
@keyframes slam-hide{0%,60%{transform:translateY(0)}90%{transform:translateY(-105%)}100%{transform:translateY(-105%);visibility:hidden;pointer-events:none}}

/* ================= mobile polish ================= */
.hero{min-height:86svh}
@media (max-width:560px){
  .section{padding:54px 0}
  .nav__brand{font-size:1rem}
  .hero__inner{padding-bottom:56px}
  .hero__tag{font-size:1.06rem}
  .hero__cta{flex-direction:column;align-items:stretch;gap:10px}
  .hero__cta .btn{width:100%}
  .lead{font-size:1.06rem}
  .sched th,.sched td{padding:10px 8px;font-size:.85rem}
  .stat b{font-size:1.5rem}
  .hero__facts{display:grid;grid-template-columns:1fr 1fr}
  .hero__facts li{min-width:0}
}
@media (prefers-reduced-motion:reduce){ #intro{display:none} }

/* ================= internal "for Travis" modal ================= */
.tmodal{position:fixed;inset:0;z-index:250;display:grid;place-items:center;padding:20px;
  background:rgba(6,6,8,.72);backdrop-filter:blur(4px);animation:tm-in .3s ease}
.tmodal[hidden]{display:none}
.tmodal__card{position:relative;max-width:440px;width:100%;background:var(--ink-2);border:1px solid var(--line);
  border-radius:16px;padding:30px 26px;text-align:center;box-shadow:var(--shadow)}
.tmodal__x{position:absolute;top:10px;right:14px;background:0;border:0;color:var(--muted);font-size:1.8rem;line-height:1;cursor:pointer}
.tmodal__x:hover{color:#fff}
.tmodal__eyebrow{font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.2em;color:var(--gold);font-size:.78rem;margin:0 0 8px}
.tmodal__card h2{font-size:1.7rem;margin:0 0 10px}
.tmodal__lead{color:var(--muted);margin:0 0 22px}
.tmodal__card .btn{width:100%}
.tmodal__later{display:block;width:100%;margin-top:12px;background:0;border:0;color:var(--muted-2);cursor:pointer;font:inherit;padding:8px}
.tmodal__later:hover{color:var(--gold-2)}
@keyframes tm-in{from{opacity:0}to{opacity:1}}

/* ================= story section (His Why) ================= */
.section--story{background:linear-gradient(180deg,#0a0a0c,#101418 58%,#0a0a0c);text-align:center;position:relative}
.section--story::before{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);width:1px;height:46px;background:linear-gradient(var(--gold),transparent)}
.story{max-width:780px}
.story__lead{font-size:clamp(1.18rem,2.6vw,1.6rem);line-height:1.62;color:#ece9e2;margin:20px auto 0;font-weight:400}
.story__mem{margin-top:30px;font-family:var(--ff-disp);text-transform:uppercase;letter-spacing:.18em;font-size:.85rem;color:var(--gold-2)}

/* ================= scroll progress bar ================= */
#scrollbar{position:fixed;top:0;left:0;height:3px;width:0;z-index:150;
  background:linear-gradient(90deg,var(--gold),var(--gold-2));box-shadow:0 0 12px rgba(231,201,119,.5);transition:width .08s linear}

/* ================= hero ken-burns drift ================= */
.hero__media{animation:kenburns 26s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.14) translateY(-1.5%)}}

/* ================= card depth polish ================= */
.stat{transition:transform .2s ease,border-color .2s ease,background .2s ease}
.stat:hover{transform:translateY(-3px);border-color:rgba(231,201,119,.4);background:#1a1a20}
.vcard{transition:transform .2s ease,border-color .2s ease}
.vcard:hover{transform:translateY(-3px);border-color:rgba(231,201,119,.35)}
.callout{box-shadow:0 14px 40px rgba(0,0,0,.22)}

@media (prefers-reduced-motion:reduce){
  .hero__media{animation:none}
  #scrollbar{transition:none}
}
