/* ============================================================
   STEPHEN ADEMOLU — styles.css
   Luxury sports-editorial. Void navy + warm gold.
   Plain CSS, no build step.
   ============================================================ */

:root{
  --ink:#0D1B2A;
  --ink-900:#08121c;
  --ink-800:#0b1826;
  --ink-700:#10202f;
  --gold:#C8A96E;
  --gold-bright:#E4C98C;
  --gold-soft:rgba(200,169,110,.5);
  --white:#FFFFFF;
  --text:#F1F1F1;
  --subtle:#9aa7b6;
  --muted:#6B7280;
  --line:rgba(200,169,110,.22);
  --line-soft:rgba(255,255,255,.08);
  --surface:rgba(255,255,255,.03);
  --surface-2:rgba(255,255,255,.055);
  --maxw:1180px;
  --pad:clamp(20px,5vw,40px);
  --font-display:"Playfair Display",Georgia,"Times New Roman",serif;
  --font-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--ink);
  color:var(--text);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.72;
  font-weight:400;
  -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(--gold);color:var(--ink)}

/* ---------- layout helpers ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:clamp(64px,9vw,120px)}
.section--alt{background:var(--ink-900)}
.section--tight{padding-block:clamp(48px,6vw,80px)}
.center{text-align:center}
.lead{font-size:clamp(17px,2vw,19px);color:var(--subtle);max-width:62ch}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.08;margin:0;letter-spacing:.2px}
.h-xl{font-size:clamp(2.6rem,7vw,5rem)}
.h-lg{font-size:clamp(2rem,4.6vw,3.4rem)}
.h-md{font-size:clamp(1.5rem,3vw,2.1rem)}
p{margin:0 0 1.1em}
p:last-child{margin-bottom:0}

.eyebrow{
  font-family:var(--font-body);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.72rem;
  font-weight:600;
  color:var(--gold);
  margin:0 0 1.1rem;
}
.slogan{
  font-family:var(--font-display);
  font-style:italic;
  font-weight:500;
  color:var(--gold);
  line-height:1.25;
}
.rule{width:64px;height:2px;background:var(--gold);margin:1.5rem 0;border:0}
.center .rule{margin-inline:auto}

/* gold "in motion" inline mark */
.tick{display:inline-flex;align-items:center;gap:.5rem;color:var(--gold)}
.tick::before{content:"";width:26px;height:1px;background:var(--gold)}

/* ---------- buttons ---------- */
.btn{
  --bh:54px;
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  height:var(--bh);padding:0 1.7rem;
  font-family:var(--font-body);font-weight:600;font-size:.95rem;
  letter-spacing:.04em;
  border-radius:2px;border:1px solid transparent;cursor:pointer;
  transition:transform .35s var(--ease),background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.btn--sm{--bh:44px;padding:0 1.2rem;font-size:.85rem}
.btn--gold{background:var(--gold);color:var(--ink);box-shadow:0 10px 30px -12px rgba(200,169,110,.6)}
.btn--gold:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 16px 40px -12px rgba(200,169,110,.7)}
.btn--ghost{background:transparent;color:var(--text);border-color:rgba(255,255,255,.45)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.btn--block{width:100%}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--gold);outline-offset:3px;border-radius:2px;
}

/* ---------- navbar ---------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;background:transparent}
.nav.is-scrolled{background:rgba(8,18,28,.86);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom-color:var(--line)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.7rem}
.brand__mark{
  width:42px;height:42px;flex:none;display:grid;place-items:center;
  font-family:var(--font-display);font-weight:800;font-size:1.05rem;letter-spacing:-1px;
  color:var(--gold);border:1px solid var(--gold-soft);border-radius:50%;
}
.brand__name{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.3px;white-space:nowrap}
.nav__menu{display:flex;align-items:center;gap:2rem}
.nav__menu a{font-size:.92rem;font-weight:500;letter-spacing:.02em;color:var(--text);position:relative;transition:color .3s}
.nav__menu a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1.5px;background:var(--gold);transition:width .35s var(--ease)}
.nav__menu a:not(.btn):hover{color:var(--gold)}
.nav__menu a:not(.btn):hover::after,.nav__menu a.is-active:not(.btn)::after{width:100%}
.nav__menu a.is-active:not(.btn){color:var(--gold)}
.nav__toggle{display:none;width:44px;height:44px;background:none;border:0;cursor:pointer;flex-direction:column;justify-content:center;gap:5px;padding:0}
.nav__toggle span{display:block;height:2px;width:24px;background:var(--text);margin-inline:auto;transition:transform .35s var(--ease),opacity .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)}

/* ---------- scroll hero ("The Approach") ---------- */
.hero-scroll{position:relative;height:260vh}
.hero-sticky{position:sticky;top:0;height:100vh;overflow:hidden;display:grid;place-items:center;background:radial-gradient(120% 120% at 50% 18%,#13243a 0%,var(--ink) 55%,var(--ink-900) 100%)}
.hero-glow{position:absolute;width:min(120vw,1100px);height:min(120vw,1100px);border-radius:50%;
  background:radial-gradient(circle,rgba(200,169,110,.28) 0%,rgba(200,169,110,.07) 38%,transparent 66%);
  transform:translateY(4vh) scale(.7);will-change:transform,opacity;pointer-events:none}
.hero-streaks{position:absolute;inset:0;pointer-events:none;opacity:.0;transition:opacity .4s}
.hero-streaks svg{width:100%;height:100%}
.hero-figure-wrap{position:absolute;bottom:-4vh;height:92vh;display:grid;place-items:end center;will-change:transform,opacity}
.hero-figure{height:100%;width:auto;filter:drop-shadow(0 24px 60px rgba(0,0,0,.55)) drop-shadow(0 0 40px rgba(200,169,110,.22));transform-origin:bottom center}
.hero-figure.run{animation:run 1.05s var(--ease) infinite alternate}
@keyframes run{
  from{transform:translateY(0) rotate(-.4deg)}
  to{transform:translateY(-9px) rotate(.5deg)}
}
.hero-copy{position:relative;z-index:3;text-align:center;padding-inline:var(--pad);max-width:880px;will-change:transform,opacity}
.hero-name{font-size:clamp(2.8rem,9vw,6.4rem);font-weight:800;letter-spacing:1px;line-height:.98;text-shadow:0 4px 40px rgba(0,0,0,.5)}
.hero-copy .rule{margin-inline:auto;margin-block:1.4rem}
.hero-slogan{font-size:clamp(1.5rem,4.2vw,2.6rem)}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.2rem}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:4;display:flex;flex-direction:column;align-items:center;gap:8px;
  font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--subtle)}
.scroll-cue i{width:1px;height:34px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.scroll-cue i::after{content:"";position:absolute;top:-34px;left:0;width:1px;height:34px;background:var(--gold);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:translateY(0)}100%{transform:translateY(68px)}}

/* fallback for no-JS: compose hero statically */
.no-js .hero-figure-wrap{transform:scale(1.15)}
.no-js .hero-copy{transform:none;opacity:1}

/* ---------- stats bar ---------- */
.stats{border-block:1px solid var(--line);background:var(--ink-900)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:clamp(32px,5vw,52px) 1rem;text-align:center;border-left:1px solid var(--line-soft)}
.stat:first-child{border-left:0}
.stat__num{font-family:var(--font-display);font-weight:700;color:var(--gold);font-size:clamp(2.4rem,5vw,3.4rem);line-height:1}
.stat__label{margin-top:.6rem;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--subtle)}

/* ---------- feature rows ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:center}
.feature + .feature{margin-top:clamp(56px,8vw,110px)}
.feature--reverse .feature__media{order:-1}
.feature__body .eyebrow{margin-bottom:.9rem}

/* placeholder media tiles (swap for real photos) */
.ph{position:relative;border:1px solid var(--line);background:
    linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,0)),var(--ink-800);
  border-radius:3px;overflow:hidden;display:grid;place-items:center;text-align:center;padding:2rem}
.ph::after{content:"";position:absolute;inset:10px;border:1px dashed rgba(200,169,110,.28);border-radius:2px;pointer-events:none}
.ph--portrait{aspect-ratio:4/5}
.ph--wide{aspect-ratio:16/10}
.ph--square{aspect-ratio:1/1}
.ph--tall{aspect-ratio:3/4}
.ph__tag{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}
.ph__txt{font-size:.92rem;color:var(--subtle);max-width:28ch;margin:0 auto}
.ph__ico{font-size:1.4rem;margin-bottom:.6rem;opacity:.8}

/* ---------- quote band ---------- */
.quote{background:var(--ink-900);border-block:1px solid var(--line)}
.quote__inner{max-width:980px;border-left:3px solid var(--gold);padding-left:clamp(20px,4vw,40px)}
.quote__text{font-family:var(--font-display);font-style:italic;font-weight:500;font-size:clamp(1.4rem,3.4vw,2.2rem);line-height:1.4;color:var(--text)}
.quote__cite{margin-top:1.2rem;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}

/* ---------- timeline ---------- */
.tl{position:relative;max-width:980px;margin-inline:auto;padding-left:34px}
.tl::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:1px;background:linear-gradient(var(--gold),var(--gold-soft),transparent)}
.tl__item{position:relative;padding:0 0 clamp(34px,5vw,52px)}
.tl__item:last-child{padding-bottom:0}
.tl__item::before{content:"";position:absolute;left:-34px;top:6px;width:15px;height:15px;border-radius:50%;background:var(--ink);border:2px solid var(--gold);box-shadow:0 0 0 4px rgba(200,169,110,.12)}
.tl__year{font-family:var(--font-body);font-weight:600;letter-spacing:.12em;font-size:.78rem;color:var(--gold);text-transform:uppercase}
.tl__club{font-family:var(--font-display);font-weight:700;font-size:clamp(1.25rem,2.5vw,1.6rem);margin:.25rem 0 .5rem}
.tl__club span{color:var(--subtle);font-weight:400;font-size:.8em;font-style:italic}
.tl__detail{color:var(--subtle);font-size:.98rem}
.tl__detail strong{color:var(--text);font-weight:600}

/* ---------- card grids ---------- */
.cards{display:grid;gap:clamp(16px,2.4vw,24px)}
.cards--4{grid-template-columns:repeat(4,1fr)}
.cards--3{grid-template-columns:repeat(3,1fr)}
.cards--2{grid-template-columns:repeat(2,1fr)}
.card{
  position:relative;background:var(--surface);border:1px solid var(--line-soft);border-radius:4px;
  padding:clamp(22px,3vw,32px);transition:transform .4s var(--ease),border-color .4s var(--ease),background .4s var(--ease),box-shadow .4s var(--ease);
}
.card:hover{transform:translateY(-5px);border-color:var(--gold-soft);background:var(--surface-2);box-shadow:0 24px 50px -28px rgba(0,0,0,.8)}
.card__ico{font-size:1.5rem;display:block;margin-bottom:1rem}
.card__kicker{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.card__title{font-family:var(--font-display);font-weight:700;font-size:1.25rem;margin:0 0 .5rem;line-height:1.2}
.card__role{font-size:.8rem;letter-spacing:.06em;color:var(--subtle);text-transform:uppercase;margin-bottom:.8rem}
.card__text{font-size:.95rem;color:var(--subtle);margin:0}
.card__media{margin:-clamp(22px,3vw,32px) -clamp(22px,3vw,32px) clamp(16px,2vw,22px)}
.card__media .ph{border:0;border-bottom:1px solid var(--line);border-radius:0}
.card__media .ph::after{inset:8px}
.badge{position:absolute;top:14px;right:14px;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:var(--gold);padding:.28rem .55rem;border-radius:2px;font-weight:700}
.badge--ghost{background:transparent;color:var(--subtle);border:1px solid var(--line)}
.card .btn{margin-top:1.3rem}

/* ---------- book ---------- */
.book{display:grid;grid-template-columns:.7fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.book__cover{aspect-ratio:2/3;max-width:300px}
.book__cover .ph{height:100%}
.book__meta{font-size:.82rem;letter-spacing:.06em;color:var(--subtle);margin:1rem 0 1.4rem}
.book__meta b{color:var(--gold);font-weight:600}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.45fr .85fr;gap:clamp(28px,5vw,56px);align-items:start}
.formcard{background:var(--surface);border:1px solid var(--line-soft);border-radius:6px;padding:clamp(24px,4vw,40px)}
.field{margin-bottom:1.2rem}
.field label{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--subtle);margin-bottom:.5rem}
.field label .req{color:var(--gold)}
.field input,.field select,.field textarea{
  width:100%;background:var(--ink-900);border:1px solid var(--line-soft);border-radius:3px;color:var(--text);
  font-family:var(--font-body);font-size:1rem;padding:.85rem 1rem;transition:border-color .3s,background .3s;
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);background:#0a1520;outline:none}
.field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--gold) 50%),linear-gradient(135deg,var(--gold) 50%,transparent 50%);background-position:calc(100% - 20px) 55%,calc(100% - 14px) 55%;background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.hp{position:absolute;left:-9999px}

.form-success{display:none;text-align:center;padding:clamp(28px,5vw,48px) 1rem}
.form-success.is-on{display:block;animation:fade .6s var(--ease)}
.success-ring{width:84px;height:84px;border-radius:50%;border:2px solid var(--gold);display:grid;place-items:center;margin:0 auto 1.6rem;color:var(--gold);font-size:2rem;box-shadow:0 0 0 6px rgba(200,169,110,.12)}
.form-success .slogan{font-size:1.35rem;margin:1rem auto 1.8rem;max-width:24ch}
@keyframes fade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.info{list-style:none;margin:0;padding:0;display:grid;gap:1.2rem}
.info li{display:flex;gap:.95rem;align-items:flex-start}
.info .ico{flex:none;width:22px;color:var(--gold);margin-top:2px}
.info a{color:var(--text);border-bottom:1px solid transparent;transition:border-color .3s,color .3s}
.info a:hover{color:var(--gold);border-bottom-color:var(--gold-soft)}
.info small{display:block;color:var(--muted);font-size:.78rem}

/* ---------- page hero (interior) ---------- */
.phero{position:relative;min-height:62vh;display:grid;align-items:end;padding-top:74px;overflow:hidden;
  background:radial-gradient(120% 90% at 70% 10%,#15273d,var(--ink) 60%,var(--ink-900))}
.phero__inner{padding-block:clamp(40px,7vw,84px)}
.phero .h-xl{max-width:16ch}
.phero__sub{color:var(--subtle);font-size:clamp(1rem,2vw,1.2rem);margin-top:1rem;max-width:54ch}

/* ---------- CTA strip ---------- */
.cta{background:var(--ink-900);border-top:1px solid var(--line);text-align:center}
.cta .slogan{font-size:clamp(1.5rem,4vw,2.4rem);margin:1.2rem auto 2rem;max-width:20ch}

/* ---------- footer ---------- */
.footer{background:var(--ink-900);border-top:1px solid var(--line);padding-block:clamp(48px,7vw,72px)}
.footer__top{display:grid;grid-template-columns:1.3fr 1fr;gap:2.5rem;align-items:start}
.footer__slogan{font-size:clamp(1.25rem,2.6vw,1.7rem);max-width:18ch}
.footer__mark{display:flex;align-items:center;gap:.7rem;margin-bottom:1.2rem}
.footer__links{display:flex;gap:1.6rem;flex-wrap:wrap;align-items:center}
.footer__links a{font-size:.92rem;color:var(--subtle);transition:color .3s}
.footer__links a:hover{color:var(--gold)}
.social{display:flex;gap:.8rem;margin-top:1.4rem}
.social a{width:40px;height:40px;display:grid;place-items:center;border:1px solid var(--line-soft);border-radius:50%;color:var(--subtle);transition:color .3s,border-color .3s,transform .3s}
.social a:hover{color:var(--gold);border-color:var(--gold-soft);transform:translateY(-2px)}
.social svg{width:18px;height:18px}
.footer__base{margin-top:clamp(32px,5vw,48px);padding-top:1.5rem;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.8rem;color:var(--muted)}

/* ---------- youtube ---------- */
.yt{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px);align-items:center}
.video-frame{position:relative;aspect-ratio:16/9;border:1px solid var(--line);border-radius:4px;overflow:hidden}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:920px){
  .nav__menu{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;
    background:rgba(8,18,28,.97);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);padding:1rem var(--pad) 1.6rem;
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity .3s,transform .3s}
  .nav__menu.is-open{transform:none;opacity:1;pointer-events:auto}
  .nav__menu a{padding:.9rem 0;border-bottom:1px solid var(--line-soft);font-size:1.05rem}
  .nav__menu a:not(.btn)::after{display:none}
  .nav__menu .btn{margin-top:1rem}
  .nav__toggle{display:flex}

  .feature,.book,.contact-grid,.yt,.footer__top{grid-template-columns:1fr}
  .feature--reverse .feature__media{order:0}
  .book__cover{max-width:240px;margin-inline:auto}
  .cards--4{grid-template-columns:repeat(2,1fr)}
  .cards--3{grid-template-columns:repeat(2,1fr)}
  .footer__top{gap:1.8rem}
}
@media (max-width:600px){
  body{font-size:16px}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(odd){border-left:0}
  .stat:nth-child(n+3){border-top:1px solid var(--line-soft)}
  .cards--4,.cards--3,.cards--2,.grid-2{grid-template-columns:1fr}
  .hero-scroll{height:215vh}
  .footer__base{flex-direction:column}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .hero-figure.run{animation:none}
  .reveal{opacity:1;transform:none}
  .hero-figure-wrap{transform:scale(1.12)!important}
  .hero-copy{opacity:1!important;transform:none!important}
  .hero-glow{opacity:.5!important;transform:scale(1)!important}
  .scroll-cue,.scroll-cue i::after{animation:none}
}

/* ============================================================
   V2 — REAL PHOTOGRAPHY, PANELS, VIDEO FACADE, 404
   (appended refinement layer — overrides where noted)
   ============================================================ */

/* --- Hero <picture> wrapper: preserve the height chain --- */
.hero-figure-wrap{grid-template-rows:100%;grid-template-columns:100%}
.hero-figure-wrap picture{height:100%;min-height:0;display:flex;align-items:flex-end;justify-content:center}
.hero-figure-wrap picture source{display:none}
.hero-figure{max-height:100%}
.hero-figure{
  -webkit-mask-image:linear-gradient(to top,transparent 0,#000 7%);
          mask-image:linear-gradient(to top,transparent 0,#000 7%);
}

/* --- Photo figures (real photography) --- */
.photo{position:relative;margin:0;border:1px solid var(--line);border-radius:4px;overflow:hidden;background:#0a1622}
.photo img{display:block;width:100%;height:100%;object-fit:cover}
.photo--portrait{aspect-ratio:4/5}
.photo--wide{aspect-ratio:16/10}
.photo--frame::after{content:"";position:absolute;inset:10px;border:1px solid rgba(200,169,110,.32);border-radius:2px;pointer-events:none}
.photo__cap{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:2.4rem 1.15rem .85rem;
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);
  background:linear-gradient(to top,rgba(7,15,24,.92),rgba(7,15,24,.55) 55%,transparent);
}
.photo--frame .photo__cap{padding-inline:1.5rem;padding-bottom:1.15rem}

/* --- Record panels (typographic stand-ins where no photo exists yet) --- */
.panel{
  position:relative;display:flex;flex-direction:column;justify-content:center;
  border:1px solid var(--line);border-radius:4px;overflow:hidden;
  padding:2.2rem 1.9rem;
  background:
    radial-gradient(120% 90% at 85% 8%,rgba(200,169,110,.10),transparent 55%),
    linear-gradient(160deg,#0e1d2d,#0a1521 70%);
}
.panel::after{content:"";position:absolute;inset:10px;border:1px solid rgba(200,169,110,.22);border-radius:2px;pointer-events:none}
.panel--portrait{aspect-ratio:4/5}
.panel--wide{aspect-ratio:16/7;padding:2.4rem 2.4rem}
.panel__kicker{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.panel__num{font-family:var(--font-display);font-size:clamp(3.2rem,7vw,4.6rem);line-height:.95;color:var(--text)}
.panel__big{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3rem);line-height:1.05;color:var(--text)}
.panel__txt{color:var(--subtle);font-size:.92rem;line-height:1.65;margin-top:.85rem;max-width:34ch}
.panel__sep{width:44px;height:1px;background:var(--gold);opacity:.6;margin:1.4rem 0 1.2rem;border:0}
.panel__list{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.panel__list li{position:relative;padding-left:1.2rem;color:var(--subtle);font-size:.88rem;line-height:1.5}
.panel__list li::before{content:"";position:absolute;left:0;top:.62em;width:.65rem;height:1px;background:var(--gold)}

/* --- Timeline grid with sticky photo (about: pro years) --- */
.tl-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:3.2rem;align-items:start}
.tl-photo{position:sticky;top:104px}
@media (max-width:920px){
  .tl-grid{grid-template-columns:1fr;gap:2.4rem}
  .tl-photo{position:static;max-width:440px}
}

/* --- Video facade (click-to-play, no iframe until intent) --- */
.video-frame{background:#0a1622}
.vf-link{position:absolute;inset:0;display:block;cursor:pointer}
.vf-link img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease),opacity .4s}
.vf-link:hover img,.vf-link:focus-visible img{transform:scale(1.035)}
.vf-link::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(7,15,24,.75),rgba(7,15,24,.12) 45%,rgba(7,15,24,.18));z-index:1;transition:opacity .4s}
.vf-play{
  position:absolute;z-index:2;top:50%;left:50%;transform:translate(-50%,-50%);
  width:74px;height:74px;border-radius:50%;
  display:grid;place-items:center;
  color:var(--gold);border:1px solid rgba(200,169,110,.65);
  background:rgba(7,15,24,.55);backdrop-filter:blur(6px);
  transition:background .35s,color .35s,transform .35s var(--ease)
}
.vf-play svg{width:26px;height:26px;margin-left:3px}
.vf-link:hover .vf-play,.vf-link:focus-visible .vf-play{background:var(--gold);color:#0D1B2A;transform:translate(-50%,-50%) scale(1.06)}
.vf-meta{
  position:absolute;z-index:2;left:0;right:0;bottom:0;
  padding:2.2rem 1.25rem .9rem;
  font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--gold);
}
.vf-link:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* --- Icon refinements (SVG replaces emoji) --- */
.card__ico{font-size:0;display:block;margin-bottom:1.1rem;width:30px;height:30px;color:var(--gold)}
.card__ico svg{width:100%;height:100%}
.info .ico{display:inline-grid;place-items:center;width:22px;height:22px}
.info .ico svg{width:19px;height:19px}

/* --- Book cover (real image) --- */
.book__img{display:block;width:100%;height:auto;border:1px solid var(--line);border-radius:3px;box-shadow:0 18px 50px rgba(0,0,0,.5),0 0 40px rgba(200,169,110,.12)}
.book__cover{aspect-ratio:auto}

/* --- 404 --- */
.err{min-height:78vh;display:grid;place-items:center;text-align:center;padding:7rem 0 5rem}
.err__code{
  font-family:var(--font-display);font-size:clamp(6rem,22vw,13rem);line-height:.9;
  color:transparent;-webkit-text-stroke:1.5px rgba(200,169,110,.75);
  letter-spacing:.04em;display:block;margin-bottom:1.2rem
}
.err__title{font-family:var(--font-display);font-size:clamp(1.6rem,4vw,2.4rem);margin-bottom:.9rem}
.err__txt{color:var(--subtle);max-width:42ch;margin:0 auto 2.2rem}
.err__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
