/* =========================================================
   RULON GARDNER — Keynote Speaker
   Design: cinematic dark + Olympic gold. Forged-steel mood.
   ========================================================= */

:root{
  --bg:        #0a0e1a;   /* midnight */
  --bg-2:      #0f1424;
  --bg-3:      #131a2e;
  --ink:       #eef2fb;
  --ink-soft:  #aab3c8;
  --ink-dim:   #6f7a92;
  --gold:      #f5c451;
  --gold-deep: #d39a2a;
  --gold-glow: rgba(245,196,81,.35);
  --line:      rgba(255,255,255,.10);
  --line-2:    rgba(255,255,255,.06);
  --card:      rgba(255,255,255,.035);
  --card-2:    rgba(255,255,255,.06);
  --red:       #c8472f;
  --maxw:      1200px;
  --ease:      cubic-bezier(.16,1,.3,1);
  --font-disp: 'Anton', 'Oswald', Impact, sans-serif;
  --font-head: 'Oswald', sans-serif;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.txt-gold{color:var(--gold)}
em{font-style:italic;color:var(--ink)}

/* ---------- shared layout ---------- */
section{position:relative}
/* keep anchored sections clear of the fixed nav */
section[id], [id="contact"]{scroll-margin-top:84px}
.kicker{
  font-family:var(--font-head);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  font-weight:600;
  color:var(--gold);
  margin-bottom:1.1rem;
}
.section-head{max-width:760px;margin:0 auto 3.5rem;text-align:center;padding:0 1.5rem}
.section-head h2{
  font-family:var(--font-disp);
  font-size:clamp(2.4rem,6vw,4.4rem);
  line-height:.98;
  letter-spacing:.01em;
  text-transform:uppercase;
}
.section-head__sub{color:var(--ink-soft);font-size:1.08rem;margin-top:1.4rem}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6rem;justify-content:center;
  font-family:var(--font-head);font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;font-size:.95rem;
  padding:1rem 1.9rem;border-radius:2px;cursor:pointer;border:1px solid transparent;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s, color .25s;
  position:relative;
}
.btn--gold{
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));
  color:#1a1206;box-shadow:0 8px 30px -8px var(--gold-glow);
}
.btn--gold:hover{transform:translateY(-3px);box-shadow:0 16px 44px -10px var(--gold-glow)}
.btn--ghost{border-color:var(--line);color:var(--ink);background:rgba(255,255,255,.02)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}
.btn--lg{font-size:1.05rem;padding:1.15rem 2.4rem}
.btn--block{width:100%}
.btn__play{font-size:.7rem;color:var(--gold)}
.btn--ghost:hover .btn__play{color:var(--gold)}

/* ---------- scroll progress ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--gold),var(--gold-deep));
  box-shadow:0 0 12px var(--gold-glow);
}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem clamp(1.2rem,4vw,3rem);
  transition:background .4s var(--ease), padding .4s var(--ease), backdrop-filter .4s;
}
.nav.scrolled{
  background:rgba(8,11,20,.82);backdrop-filter:blur(14px);
  padding:.7rem clamp(1.2rem,4vw,3rem);
  border-bottom:1px solid var(--line-2);
}
.nav__brand{display:flex;align-items:center;gap:.7rem}
.nav__mark{
  font-family:var(--font-disp);font-size:1.15rem;
  width:38px;height:38px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));
  color:#1a1206;border-radius:3px;letter-spacing:.02em;
}
.nav__name{font-family:var(--font-head);font-weight:600;letter-spacing:.18em;font-size:.95rem}
.nav__links{display:flex;align-items:center;gap:2rem}
.nav__links a{
  font-family:var(--font-head);font-weight:500;font-size:.92rem;
  letter-spacing:.05em;color:var(--ink-soft);transition:color .2s;position:relative;
}
.nav__links a:not(.nav__cta):hover{color:var(--ink)}
.nav__links a:not(.nav__cta)::after{
  content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--gold);transition:width .3s var(--ease);
}
.nav__links a:not(.nav__cta):hover::after{width:100%}
.nav__cta{
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#1a1206 !important;
  padding:.55rem 1.2rem;border-radius:2px;letter-spacing:.06em;
  transition:transform .2s var(--ease),box-shadow .2s;
}
.nav__cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px -8px var(--gold-glow)}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav__toggle span{width:26px;height:2px;background:var(--ink);transition:.3s var(--ease);display:block}
.nav.open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav__toggle span:nth-child(2){opacity:0}
.nav.open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{
  min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding:7rem 1.5rem 4rem;position:relative;overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__mountains{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 50% 120%, rgba(20,28,52,.0) 40%, rgba(8,11,20,.9) 100%),
    linear-gradient(180deg, #070a13 0%, #0c1426 45%, #0a0f1d 100%);
}
.hero__mountains::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:46%;
  background:
    linear-gradient(180deg, transparent, rgba(6,9,16,.6)),
    url("/assets/img/ridgeline.svg") repeat-x bottom center / auto 100%;
  opacity:.9;
}
.hero__glow{
  position:absolute;left:50%;top:38%;transform:translate(-50%,-50%);
  width:min(900px,90vw);height:min(900px,90vw);
  background:radial-gradient(circle, var(--gold-glow) 0%, transparent 62%);
  opacity:.5;filter:blur(8px);
  animation:pulseGlow 7s ease-in-out infinite;
}
@keyframes pulseGlow{0%,100%{opacity:.38;transform:translate(-50%,-50%) scale(1)}50%{opacity:.6;transform:translate(-50%,-50%) scale(1.07)}}
.hero__grain{
  position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero__inner{position:relative;z-index:2;max-width:920px}
.hero__eyebrow{
  font-family:var(--font-head);text-transform:uppercase;letter-spacing:.42em;
  font-size:.78rem;font-weight:600;color:var(--gold);margin-bottom:1.6rem;
}
.hero__title{
  font-family:var(--font-disp);
  font-size:clamp(4.2rem,17vw,12rem);
  line-height:.84;letter-spacing:.005em;text-transform:uppercase;
  text-shadow:0 0 60px rgba(0,0,0,.6);
}
.hero__title .reveal{display:inline-block}
.hero__title--gold{
  color:var(--gold);
  background:linear-gradient(180deg,#ffe39a,var(--gold) 50%,var(--gold-deep));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.hero__sub{
  font-size:clamp(1.05rem,2.3vw,1.4rem);color:var(--ink-soft);
  max-width:680px;margin:1.8rem auto 0;line-height:1.6;
}
.hero__sub strong{color:var(--ink);font-weight:600}
.hero__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.4rem}
.hero__credibility{
  list-style:none;display:flex;gap:clamp(1.2rem,4vw,3rem);justify-content:center;flex-wrap:wrap;
  margin-top:3.4rem;
}
.hero__credibility li{display:flex;flex-direction:column;align-items:center}
.hero__credibility strong{font-family:var(--font-disp);font-size:1.7rem;color:var(--gold);line-height:1}
.hero__credibility span{font-size:.72rem;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.14em;margin-top:.45rem}
.hero__scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;width:26px;height:42px;border:2px solid var(--line);border-radius:14px;display:grid;place-items:start center}
.hero__scroll span{width:4px;height:8px;background:var(--gold);border-radius:2px;margin-top:7px;animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(0)}40%{opacity:1}80%{opacity:0;transform:translateY(12px)}}

/* ---------- stakes / counters ---------- */
.stakes{padding:clamp(5rem,11vw,9rem) 1.5rem;background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.stakes__inner{max-width:920px;margin:0 auto;text-align:center}
.stakes__head{font-family:var(--font-disp);font-size:clamp(2.2rem,6vw,4rem);line-height:.98;text-transform:uppercase;margin:.4rem 0 1.6rem}
.stakes__lead{color:var(--ink-soft);font-size:1.12rem;max-width:760px;margin:0 auto}
.counters{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line-2);border:1px solid var(--line-2);border-radius:6px;overflow:hidden;
  margin:3.4rem 0;
}
.counter{background:var(--bg-3);padding:2.2rem 1rem;display:flex;flex-direction:column;align-items:center}
.counter__num{font-family:var(--font-disp);font-size:clamp(2.6rem,7vw,4.4rem);color:var(--gold);line-height:1;
  background:linear-gradient(180deg,#ffe39a,var(--gold-deep));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.counter__label{font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-dim);margin-top:.7rem;max-width:130px}
.stakes__turn{max-width:720px;margin:0 auto}
.stakes__turn p{color:var(--ink-soft);font-size:1.1rem;margin-bottom:1rem}
.stakes__score{font-family:var(--font-disp);font-size:clamp(1.8rem,4.5vw,2.8rem);text-transform:uppercase;color:var(--ink)}
.stakes__after{font-style:italic;color:var(--ink-soft)}

/* ---------- pull quote ---------- */
.pull{padding:clamp(4rem,9vw,7rem) 1.5rem;text-align:center;background:var(--bg-2);border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.pull__quote{font-family:var(--font-disp);font-size:clamp(2rem,6.5vw,4.6rem);line-height:1.02;text-transform:uppercase;max-width:1000px;margin:0 auto;position:relative}
.pull__mark{color:var(--gold);font-size:1.4em;line-height:0;vertical-align:-.35em;margin-right:.1em;opacity:.5}
.pull cite{display:block;margin-top:1.6rem;font-family:var(--font-head);font-style:normal;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-size:.95rem}

/* ---------- story / timeline ---------- */
.story{padding:clamp(5rem,11vw,9rem) 1.5rem;background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.timeline{list-style:none;max-width:880px;margin:0 auto;position:relative}
.timeline::before{content:"";position:absolute;left:64px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--gold),transparent)}
.timeline__item{display:grid;grid-template-columns:130px 1fr;gap:1.6rem;margin-bottom:2.2rem;position:relative}
.timeline__year{font-family:var(--font-disp);font-size:1.9rem;color:var(--ink-dim);text-align:right;padding-top:.2rem;position:relative}
.timeline__item::before{content:"";position:absolute;left:58px;top:14px;width:14px;height:14px;border-radius:50%;background:var(--bg);border:3px solid var(--gold);box-shadow:0 0 0 4px var(--bg),0 0 16px var(--gold-glow);z-index:2}
.timeline__card{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:1.6rem 1.8rem;transition:transform .35s var(--ease),border-color .35s,background .35s}
.timeline__card:hover{transform:translateX(6px);border-color:rgba(245,196,81,.4);background:var(--card-2)}
.timeline__card h3{font-family:var(--font-head);font-weight:600;font-size:1.4rem;margin-bottom:.5rem}
.timeline__card p{color:var(--ink-soft);font-size:1rem}
.timeline__card--gold{border-color:rgba(245,196,81,.5);background:linear-gradient(135deg,rgba(245,196,81,.10),rgba(245,196,81,.02))}
.timeline__card--gold h3{color:var(--gold)}
.story__tag{text-align:center;font-family:var(--font-head);font-size:clamp(1.2rem,3vw,1.8rem);max-width:780px;margin:3rem auto 0;line-height:1.3}

/* ---------- message ---------- */
.message{padding:clamp(5rem,11vw,9rem) 1.5rem;background:var(--bg)}
.message__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,5rem);align-items:center}
.message__col h2{font-family:var(--font-disp);font-size:clamp(2.2rem,5vw,3.6rem);line-height:.98;text-transform:uppercase;margin-bottom:1.4rem}
.message__col p{color:var(--ink-soft);font-size:1.08rem;margin-bottom:1.2rem}
.message__col .btn{margin-top:.6rem}
.message__principles{list-style:none;display:flex;flex-direction:column;gap:1rem}
.message__principles li{display:flex;gap:1.2rem;background:var(--card);border:1px solid var(--line);border-radius:8px;padding:1.4rem 1.5rem;transition:transform .3s var(--ease),border-color .3s}
.message__principles li:hover{transform:translateY(-3px);border-color:rgba(245,196,81,.4)}
.message__principles .num{font-family:var(--font-disp);font-size:1.6rem;color:var(--gold);opacity:.6;line-height:1}
.message__principles h4{font-family:var(--font-head);font-weight:600;font-size:1.15rem;margin-bottom:.3rem}
.message__principles p{color:var(--ink-soft);font-size:.96rem;margin:0}

/* ---------- moment ---------- */
.moment{padding:clamp(5rem,11vw,9rem) 1.5rem;text-align:center;position:relative;overflow:hidden;background:var(--bg-2)}
.moment__bg{position:absolute;inset:0;background:radial-gradient(circle at 50% 40%, rgba(245,196,81,.10), transparent 60%)}
.moment__inner{position:relative;z-index:2;max-width:840px;margin:0 auto}
.scoreboard{display:flex;align-items:center;justify-content:center;gap:clamp(1.5rem,5vw,4rem);margin:2.2rem 0 2.6rem}
.scoreboard__side{display:flex;flex-direction:column;align-items:center;gap:.4rem}
.scoreboard__name{font-family:var(--font-head);font-weight:600;letter-spacing:.14em;color:var(--ink-soft);font-size:.95rem}
.scoreboard__pts{font-family:var(--font-disp);font-size:clamp(4rem,14vw,8rem);line-height:.8;color:var(--ink-dim)}
.scoreboard__pts--win{color:var(--gold);background:linear-gradient(180deg,#ffe39a,var(--gold-deep));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 50px var(--gold-glow)}
.scoreboard__flag{font-size:.72rem;letter-spacing:.2em;color:var(--ink-dim)}
.scoreboard__vs{font-family:var(--font-head);letter-spacing:.25em;color:var(--ink-dim);font-size:.8rem;border:1px solid var(--line);padding:.5rem .8rem;border-radius:3px}
.moment__quote{font-family:var(--font-disp);font-size:clamp(1.5rem,4vw,2.6rem);line-height:1.12;text-transform:uppercase;margin-bottom:1.4rem}
.moment__caption{color:var(--ink-soft);max-width:640px;margin:0 auto;font-size:1.05rem}

/* ---------- topics ---------- */
.topics{padding:clamp(5rem,11vw,9rem) 1.5rem;background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.topics__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.topic{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:2rem 1.8rem;transition:transform .35s var(--ease),border-color .35s,background .35s;position:relative;overflow:hidden}
.topic::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--gold),var(--gold-deep));transition:width .4s var(--ease)}
.topic:hover{transform:translateY(-6px);border-color:rgba(245,196,81,.4);background:var(--card-2)}
.topic:hover::before{width:100%}
.topic__icon{font-family:var(--font-disp);font-size:1.8rem;color:var(--gold);margin-bottom:1rem;opacity:.85}
.topic h3{font-family:var(--font-head);font-weight:600;font-size:1.35rem;margin-bottom:.7rem;line-height:1.1}
.topic p{color:var(--ink-soft);font-size:.98rem;margin-bottom:1.2rem}
.topic__tag{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);font-family:var(--font-head)}
.formats{max-width:var(--maxw);margin:3rem auto 0;text-align:center;border-top:1px solid var(--line-2);padding-top:2.4rem}
.formats__label{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.2em;color:var(--ink-dim);font-size:.8rem;margin-bottom:1.2rem}
.formats ul{list-style:none;display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}
.formats li{border:1px solid var(--line);border-radius:40px;padding:.55rem 1.3rem;font-size:.9rem;color:var(--ink-soft);font-family:var(--font-head)}

/* ---------- proof ---------- */
.proof{padding:clamp(5rem,11vw,9rem) 1.5rem;background:var(--bg)}
.proof__quotes{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:1.4rem;align-items:stretch}
.quotecard{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:2rem;display:flex;flex-direction:column;justify-content:space-between}
.quotecard blockquote{font-size:1.08rem;color:var(--ink);line-height:1.5;margin-bottom:1.4rem}
.quotecard--feature{background:linear-gradient(135deg,rgba(245,196,81,.12),rgba(245,196,81,.02));border-color:rgba(245,196,81,.4)}
.quotecard--feature blockquote{font-family:var(--font-head);font-size:1.45rem;font-weight:500;line-height:1.3}
.quotecard figcaption strong{display:block;font-family:var(--font-head);letter-spacing:.04em;font-size:1.05rem}
.quotecard figcaption span{color:var(--ink-dim);font-size:.85rem}
.logos{max-width:var(--maxw);margin:3rem auto 0;text-align:center;border-top:1px solid var(--line-2);padding-top:2.6rem}
.logos__label{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.22em;color:var(--ink-dim);font-size:.78rem;margin-bottom:1.4rem}
.logos__row{list-style:none;display:flex;flex-wrap:wrap;gap:clamp(1.4rem,4vw,3rem);justify-content:center;align-items:center}
.logos__row li{font-family:var(--font-head);font-weight:600;letter-spacing:.12em;color:var(--ink-dim);font-size:1rem;opacity:.7;transition:opacity .3s,color .3s}
.logos__row li:hover{opacity:1;color:var(--ink-soft)}

.testimonials{max-width:var(--maxw);margin:4rem auto 0}
.testimonials__head{text-align:center;font-family:var(--font-head);font-weight:600;font-size:1.6rem;margin-bottom:2rem}
.placeholder-note{display:block;font-size:.8rem;color:var(--ink-dim);font-family:var(--font-body);font-weight:400;letter-spacing:0;text-transform:none;margin-top:.4rem}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.testimonial{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:1.8rem}
.testimonial[data-placeholder]{border-style:dashed;opacity:.78}
.testimonial__stars{color:var(--gold);letter-spacing:.2em;margin-bottom:.9rem}
.testimonial blockquote{color:var(--ink-soft);font-size:1rem;line-height:1.55;margin-bottom:1.2rem}
.testimonial figcaption strong{display:block;font-family:var(--font-head)}
.testimonial figcaption span{color:var(--ink-dim);font-size:.85rem}

/* ---------- cta strip ---------- */
.ctastrip{padding:clamp(4rem,9vw,7rem) 1.5rem;background:linear-gradient(135deg,var(--bg-3),var(--bg-2));border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.ctastrip__inner{max-width:900px;margin:0 auto;text-align:center}
.ctastrip h2{font-family:var(--font-disp);font-size:clamp(2rem,5.5vw,3.6rem);line-height:1;text-transform:uppercase;margin-bottom:2rem}

/* ---------- booking ---------- */
.book{padding:clamp(5rem,11vw,9rem) 1.5rem;background:var(--bg)}
.book__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,6vw,5rem);align-items:start}
.book__pitch h2{font-family:var(--font-disp);font-size:clamp(2.2rem,5vw,3.4rem);line-height:.98;text-transform:uppercase;margin-bottom:1.2rem}
.book__pitch>p{color:var(--ink-soft);font-size:1.08rem}
.book__steps{list-style:none;margin:2rem 0;display:flex;flex-direction:column;gap:.9rem}
.book__steps li{display:flex;align-items:center;gap:1rem;color:var(--ink-soft);font-size:1.02rem}
.book__steps span{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-disp);font-size:.95rem;color:#1a1206;background:linear-gradient(135deg,var(--gold),var(--gold-deep))}
.book__contact{border-top:1px solid var(--line-2);padding-top:1.6rem;margin-top:.5rem}
.book__contact p{margin-bottom:.3rem;color:var(--ink-soft)}
.book__agent{color:var(--ink-dim) !important;font-size:.9rem}
.book__contact a{color:var(--gold)}
.book__contact a:hover{text-decoration:underline}

.book__form{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:clamp(1.6rem,4vw,2.6rem)}
.field{margin-bottom:1.1rem;display:flex;flex-direction:column}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field label{font-family:var(--font-head);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.5rem}
.field input,.field select,.field textarea{
  background:rgba(0,0,0,.25);border:1px solid var(--line);border-radius:6px;
  padding:.85rem .95rem;color:var(--ink);font-family:var(--font-body);font-size:1rem;width:100%;
  transition:border-color .25s,box-shadow .25s,background .25s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow);background:rgba(0,0,0,.35);
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-dim)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23f5c451' stroke-width='2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.field textarea{resize:vertical;min-height:90px}
.field.invalid input,.field.invalid select{border-color:var(--red);box-shadow:0 0 0 3px rgba(200,71,47,.25)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.book__form .btn{margin-top:.6rem}
.book__formnote{margin-top:1rem;font-size:.95rem;min-height:1.4em;text-align:center}
.book__formnote.success{color:var(--gold)}
.book__formnote.error{color:var(--red)}

/* ---------- faq ---------- */
.faq{padding:clamp(5rem,11vw,9rem) 1.5rem;background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.faq__list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:.8rem}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:8px;overflow:hidden;transition:border-color .3s}
.faq details[open]{border-color:rgba(245,196,81,.4)}
.faq summary{cursor:pointer;list-style:none;padding:1.3rem 1.6rem;font-family:var(--font-head);font-weight:500;font-size:1.12rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold);font-size:1.5rem;transition:transform .3s var(--ease);line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 1.6rem 1.4rem;color:var(--ink-soft)}
.faq details a{color:var(--gold);text-decoration:underline}

/* ---------- footer ---------- */
.footer{background:#070a13;border-top:1px solid var(--line-2);padding:4rem 1.5rem 2rem}
.footer__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem}
.footer__brand .nav__mark{margin-bottom:1rem}
.footer__name{font-family:var(--font-head);font-weight:600;letter-spacing:.2em;font-size:1.2rem}
.footer__tag{color:var(--ink-dim);font-size:.9rem;margin-top:.5rem;max-width:320px}
.footer__col h4{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:.85rem;color:var(--gold);margin-bottom:1rem}
.footer__col p{margin-bottom:.5rem;color:var(--ink-soft);font-size:.95rem}
.footer__col a:hover{color:var(--gold)}
.footer__bottom{max-width:var(--maxw);margin:3rem auto 0;padding-top:1.6rem;border-top:1px solid var(--line-2);display:flex;justify-content:space-between;align-items:center;color:var(--ink-dim);font-size:.85rem}
.footer__top:hover{color:var(--gold)}

/* ---------- sticky mobile book bar ---------- */
.stickybar{
  position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:90;
  display:none;align-items:center;justify-content:center;gap:.5rem;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#1a1206;
  font-family:var(--font-head);font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  padding:1rem;border-radius:6px;box-shadow:0 10px 30px -8px rgba(0,0,0,.6);
  opacity:0;transform:translateY(120%);transition:opacity .4s var(--ease),transform .4s var(--ease);
}
.stickybar.show{opacity:1;transform:translateY(0)}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s 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}.reveal.d5{transition-delay:.5s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__glow,.hero__scroll span{animation:none}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:980px){
  .message__inner{grid-template-columns:1fr}
  .proof__quotes{grid-template-columns:1fr 1fr}
  .quotecard--feature{grid-column:1/-1}
  .book__grid{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav__links{
    position:fixed;inset:0 0 0 auto;width:min(80vw,320px);flex-direction:column;align-items:flex-start;
    gap:1.6rem;background:rgba(10,14,26,.97);backdrop-filter:blur(16px);padding:6rem 2rem 2rem;
    transform:translateX(100%);transition:transform .4s var(--ease);border-left:1px solid var(--line)}
  .nav.open .nav__links{transform:translateX(0)}
  .nav__toggle{display:flex;z-index:101}
  .nav__name{font-size:.85rem}
  .counters{grid-template-columns:1fr 1fr}
  .topics__grid{grid-template-columns:1fr}
  .proof__quotes{grid-template-columns:1fr}
  .testimonials__grid{grid-template-columns:1fr}
  .timeline::before{left:8px}
  .timeline__item{grid-template-columns:1fr;gap:.6rem;padding-left:2.4rem}
  .timeline__year{text-align:left;font-size:1.5rem}
  .timeline__item::before{left:2px;top:6px}
  .footer__inner{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;gap:1rem;text-align:center}
  .field-row{grid-template-columns:1fr}
  .stickybar{display:flex}
  .scoreboard__vs{align-self:center}
}
@media (max-width:420px){
  .counters{grid-template-columns:1fr}
  .hero__credibility{gap:1.4rem}
}
