/* =================  Base  ================= */
:root{
  --bg:#0b0b0b;
  --bg-2:#111111;
  --bg-3:#171512;
  --ink:#ffffff;
  --ink-soft:rgba(255,255,255,.78);
  --muted:rgba(255,255,255,.55);
  --line:rgba(255,255,255,.1);
  --accent:#c9a96a;
  --accent-2:#e0c389;
  --white:#ffffff;
  --radius:18px;
  --radius-lg:40px;
  --maxw:1240px;
  --serif:"Playfair Display", Georgia, serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --shadow:0 30px 60px -30px rgba(0,0,0,.6);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  background:#050505;
  background-image:
    radial-gradient(1200px 700px at 82% -10%,rgba(201,169,106,.18),transparent 60%),
    radial-gradient(900px 600px at -10% 40%,rgba(180,138,74,.12),transparent 55%),
    linear-gradient(180deg,#0a0a0a 0%,#15110a 100%);
  background-attachment:fixed;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 32px;width:100%}
.italic{font-style:italic;font-family:var(--serif);font-weight:600}

/* =================  Nav  ================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  backdrop-filter:saturate(160%) blur(16px);
  -webkit-backdrop-filter:saturate(160%) blur(16px);
  background:rgba(10,10,10,.55);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.nav__logo{
  font-family:var(--serif);font-weight:700;letter-spacing:.18em;
  font-size:17px;color:var(--white);display:flex;align-items:baseline;gap:10px;
}
.nav__logo span{
  font-family:var(--sans);font-size:10px;letter-spacing:.3em;
  color:var(--accent);font-weight:600;
}
.nav__menu{display:flex;gap:30px;align-items:center}
.nav__menu a{
  font-size:13px;font-weight:500;letter-spacing:.04em;
  color:rgba(255,255,255,.75);transition:color .2s;
}
.nav__menu a:hover{color:var(--white)}
.nav__cta{
  padding:9px 16px;border:1px solid rgba(255,255,255,.35);border-radius:999px;
  color:var(--white) !important;transition:background .2s,color .2s,border-color .2s;
}
.nav__cta:hover{background:var(--accent);color:#000 !important;border-color:var(--accent)}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;width:34px;height:34px;flex-direction:column;justify-content:center;gap:5px;padding:0}
.nav__toggle span{display:block;height:2px;background:var(--white);border-radius:2px}

/* =================  Buttons  ================= */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 22px;border-radius:999px;
  font-family:var(--sans);font-weight:600;font-size:13.5px;letter-spacing:.02em;
  border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease,background .25s,color .25s,border-color .25s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--white);color:#000}
.btn--primary:hover{background:var(--accent)}
.btn--ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.4)}
.btn--ghost:hover{background:var(--white);color:#000;border-color:var(--white)}
.btn--dark{background:#000;color:var(--white)}
.btn--dark:hover{background:var(--accent);color:#000}
.btn--block{width:100%;justify-content:center}

/* =================  Stacking scroll (sticky, fixed 100vh)  ================= */
main{position:relative}

/* Hero pinned as backdrop */
.hero{
  position:sticky;top:0;z-index:1;
  height:100vh;min-height:540px;
  display:flex;align-items:center;
  padding:90px 0 50px;
  color:var(--white);
  overflow:hidden;
}

/* Each section sticks at top:0 and takes exactly one viewport.
   Content is anchored to the TOP (not center) so num + label + title
   stay visible; overflow:hidden clips anything below the fold. */
.section{
  position:sticky;top:0;
  height:100vh;min-height:560px;
  padding:90px 0 30px;
  display:flex;flex-direction:column;justify-content:flex-start;
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  box-shadow:0 -40px 80px -30px rgba(0,0,0,.55);
  overflow:hidden;
  will-change:transform,opacity;
}
.section > .container{
  margin-top:auto;margin-bottom:auto;  /* vertically center container once content fits */
}
.section--dark{background:var(--bg)}
.section--muted{background:var(--bg-2)}
.section--warm{background:var(--bg-3)}
.section--accent{
  background:
    radial-gradient(900px 500px at 20% 0%,rgba(201,169,106,.28),transparent 60%),
    linear-gradient(135deg,#1a1410 0%,#2a2015 60%,#3a2a18 100%);
}
#about{z-index:2}
#book{z-index:3}
#speaking{z-index:4}
#interviews{z-index:5}
#testimonials{z-index:6}
#newsletter{z-index:7}
#contact{z-index:8}

/* Scroll-linked zoom-out effect (driven by JS in script.js).
   transform-origin centered so each section recedes cleanly behind
   the next one as it scrolls past. */
.hero,.section{
  transform-origin:center center;
  will-change:transform,opacity;
}

/* Section number ribbon (subtle watermark top-right) */
.section__ribbon{
  position:absolute;top:92px;right:34px;z-index:3;
  font-family:var(--sans);font-size:10px;letter-spacing:.36em;
  color:rgba(255,255,255,.28);font-weight:600;
  text-transform:uppercase;
}
.section__num{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:.3em;font-weight:700;
  color:var(--accent);margin:0 0 12px;
  font-family:var(--sans);
}
.section__num::after{
  content:"";width:28px;height:1px;background:var(--accent);opacity:.6;
}
.section__label{
  font-size:10.5px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin:0 0 16px;
}
.section__title{
  font-family:var(--serif);
  font-size:clamp(28px,3.6vw,50px);line-height:1.08;
  font-weight:700;letter-spacing:-.015em;
  margin:0 0 22px;max-width:900px;color:var(--white);
}
.section__title .italic{color:var(--accent)}
.section__head{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:28px;margin-bottom:34px;flex-wrap:wrap;
}
.section__head .section__title{margin-bottom:0}
.section__cta{flex-shrink:0}

/* =================  Hero  ================= */
.hero__grid{
  display:grid;grid-template-columns:1.15fr .9fr;
  gap:70px;align-items:center;width:100%;
}
.eyebrow{
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin:0 0 18px;
}
.hero__title{
  font-family:var(--serif);font-weight:700;
  font-size:clamp(46px,6.2vw,96px);
  line-height:.94;letter-spacing:-.025em;margin:0 0 22px;
  color:var(--white);
}
.hero__title .italic{color:var(--accent)}
.hero__lede{
  font-size:clamp(14.5px,1.1vw,17px);color:var(--ink-soft);
  max-width:520px;margin:0 0 26px;line-height:1.55;
}
.hero__ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero__meta{
  display:flex;gap:36px;margin-top:30px;padding-top:22px;
  border-top:1px solid var(--line);flex-wrap:wrap;
}
.hero__meta span{
  font-size:10.5px;letter-spacing:.08em;color:var(--muted);
  display:flex;flex-direction:column;gap:4px;text-transform:uppercase;
}
.hero__meta strong{
  font-family:var(--serif);font-size:26px;color:var(--white);font-weight:700;
  letter-spacing:-.02em;
}
.hero__image{position:relative;max-width:440px;margin-left:auto}
.hero__photo{
  width:100%;aspect-ratio:4/5;object-fit:cover;max-height:62vh;
  border-radius:20px;
  box-shadow:0 40px 80px -30px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.06);
}
.hero__badge{
  position:absolute;left:-18px;bottom:30px;
  background:rgba(10,10,10,.92);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.1);border-radius:14px;
  padding:12px 16px;display:flex;flex-direction:column;gap:3px;
  box-shadow:var(--shadow);
}
.hero__badge-label{
  font-size:11px;letter-spacing:.18em;color:var(--accent);font-weight:700;
}
.hero__badge-sub{font-size:10px;color:var(--muted);letter-spacing:.1em}
.hero__scroll{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  font-size:10px;letter-spacing:.32em;color:var(--muted);font-weight:700;
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.hero__scroll::after{
  content:"";width:1px;height:30px;background:linear-gradient(180deg,var(--accent),transparent);
}

/* =================  About  ================= */
.about__head{margin-bottom:24px;max-width:1000px}
.about__grid{
  display:grid;grid-template-columns:1.15fr 1fr;gap:44px;
  align-items:start;
}
.about__text p{
  font-size:14.5px;color:var(--ink-soft);margin:0 0 12px;line-height:1.55;
}
.about__text .lead{
  font-size:17px;line-height:1.5;color:var(--white);font-weight:400;
  margin-bottom:14px;
}
.about__text em{font-style:italic;color:var(--white)}
.about__text strong{color:var(--white)}
.pull{
  margin:16px 0 0;padding:14px 20px;
  font-family:var(--serif);font-size:16px;font-style:italic;line-height:1.45;
  color:var(--white);background:rgba(201,169,106,.08);
  border-left:3px solid var(--accent);border-radius:0 10px 10px 0;
}
.about__side{display:grid;grid-template-columns:1fr;gap:14px}
.about__portrait{
  margin:0 auto;overflow:hidden;border-radius:var(--radius);
  aspect-ratio:3/4;max-width:340px;
  box-shadow:var(--shadow);
}
.about__portrait img{width:100%;height:100%;object-fit:cover;object-position:center top}
.awards{
  list-style:none;padding:14px 16px;margin:0;
  background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:12px;
}
.awards li{
  display:flex;gap:14px;align-items:baseline;
  padding:6px 0;border-bottom:1px solid var(--line);
  font-size:12.5px;color:var(--ink-soft);
}
.awards li:last-child{border-bottom:0;padding-bottom:0}
.awards li:first-child{padding-top:0}
.awards span{
  flex-shrink:0;width:42px;font-weight:700;color:var(--accent);
  font-size:10.5px;letter-spacing:.08em;
}
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  margin-top:24px;padding-top:18px;
  border-top:1px solid var(--line);
}
.stats>div{display:flex;flex-direction:column;gap:4px}
.stats strong{
  font-family:var(--serif);font-size:28px;font-weight:700;
  color:var(--white);letter-spacing:-.02em;line-height:1;
}
.stats span{font-size:10.5px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}

.featured{
  display:flex;align-items:center;gap:26px;
  margin-top:18px;padding-top:14px;border-top:1px solid var(--line);
  flex-wrap:wrap;
}
.featured__label{
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin:0;flex-shrink:0;
}
.featured__row{
  display:flex;flex-wrap:wrap;gap:4px 22px;align-items:center;
}
.featured__row span{
  font-family:var(--serif);font-size:15px;font-weight:600;letter-spacing:.02em;
  color:rgba(255,255,255,.5);transition:color .25s;
}
.featured__row span:hover{color:var(--white)}

/* =================  Book Form  ================= */
.book__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:start}
.book__copy{color:var(--ink-soft);font-size:15px;max-width:460px;margin:0 0 18px}
.book__list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:8px;
}
.book__list li{
  position:relative;padding-left:22px;font-size:14px;color:var(--ink-soft);
}
.book__list li::before{
  content:"→";position:absolute;left:0;color:var(--accent);font-weight:700;
}
.form{display:flex;flex-direction:column;gap:12px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form label{
  display:flex;flex-direction:column;gap:6px;
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:700;
}
.form input,.form select,.form textarea{
  font:inherit;font-size:14.5px;letter-spacing:0;text-transform:none;font-weight:400;
  padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);color:var(--white);
  transition:border-color .2s,background .2s;
  color-scheme:dark;
}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none;border-color:var(--accent);background:rgba(255,255,255,.08);
}
.form input::placeholder,.form textarea::placeholder{color:rgba(255,255,255,.35)}
.form textarea{min-height:74px;resize:vertical}
.form__note{
  font-size:13px;color:var(--accent);text-transform:none;letter-spacing:0;font-weight:500;
}

/* =================  Speaking cards  ================= */
.cards--feature{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
}
.feature{
  background:rgba(255,255,255,.03);border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);
  transition:transform .35s ease,border-color .35s,background .35s;
  display:flex;flex-direction:column;
}
.feature:hover{transform:translateY(-5px);border-color:rgba(201,169,106,.4);background:rgba(255,255,255,.05)}
.feature__media{
  position:relative;display:block;aspect-ratio:5/4;overflow:hidden;
}
.feature__media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;filter:saturate(.9) contrast(1.05);
}
.feature:hover .feature__media img{transform:scale(1.06)}
.feature__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.55) 100%);
}
.feature__play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:50px;height:50px;border-radius:50%;
  background:rgba(255,255,255,.92);color:#000;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;padding-left:3px;z-index:2;
  transition:transform .3s,background .3s;
}
.feature:hover .feature__play{background:var(--accent);transform:translate(-50%,-50%) scale(1.1)}
.feature__tag{
  position:absolute;top:12px;left:12px;z-index:2;
  padding:4px 10px;border-radius:999px;
  background:rgba(0,0,0,.6);backdrop-filter:blur(8px);
  color:var(--accent);border:1px solid rgba(201,169,106,.3);
  font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;
}
.feature__body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:4px}
.feature__meta{
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin:0;
}
.feature__body h3{
  margin:3px 0 4px;font-family:var(--serif);
  font-size:18px;font-weight:600;line-height:1.2;color:var(--white);
}
.feature__body p{margin:0;color:var(--muted);font-size:13px;line-height:1.4}
.card__link{
  margin-top:8px;font-weight:600;font-size:12.5px;
  color:var(--accent);letter-spacing:.06em;
  border-bottom:1px solid transparent;transition:border-color .2s,color .2s;
  align-self:flex-start;
}
.card__link:hover{color:var(--white);border-color:var(--white)}

/* =================  Interviews  ================= */
.media-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
}
.media{
  display:grid;grid-template-columns:150px 1fr;gap:18px;align-items:stretch;
  padding:14px;border-radius:var(--radius);
  background:rgba(255,255,255,.03);border:1px solid var(--line);
  transition:transform .3s ease,background .3s,border-color .3s;
}
.media:hover{transform:translateY(-3px);border-color:rgba(201,169,106,.4);background:rgba(255,255,255,.05)}
.media__img{
  aspect-ratio:4/3;border-radius:10px;overflow:hidden;background:#1a1a1a;
}
.media__img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.media:hover .media__img img{transform:scale(1.06)}
.media__body{display:flex;flex-direction:column;justify-content:center;padding:2px 0}
.media__outlet{
  font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:6px;
}
.media__body h3{
  margin:0 0 8px;font-family:var(--serif);font-size:17px;font-weight:600;
  line-height:1.28;color:var(--white);
}
.media__meta{font-size:12px;color:var(--muted);letter-spacing:.04em}

/* =================  Testimonials  ================= */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.quote{
  margin:0;padding:26px 24px 22px;border-radius:var(--radius);
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  position:relative;
  display:flex;flex-direction:column;gap:14px;
}
.quote::before{
  content:"“";
  position:absolute;top:-10px;left:20px;
  font-family:var(--serif);font-size:70px;color:var(--accent);
  line-height:1;font-weight:700;
}
.quote blockquote{
  margin:10px 0 0;padding:0;font-size:15px;
  color:var(--ink-soft);font-family:var(--serif);font-style:italic;line-height:1.5;
}
.quote figcaption{
  display:flex;gap:12px;align-items:center;margin-top:auto;
  padding-top:14px;border-top:1px solid var(--line);
}
.quote figcaption img{
  width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0;
  border:1px solid var(--line);
}
.quote figcaption span{
  display:flex;flex-direction:column;gap:2px;
  font-size:12px;color:var(--muted);letter-spacing:.02em;
}
.quote figcaption strong{
  color:var(--white);font-size:12.5px;font-weight:600;letter-spacing:0;
}

/* =================  Newsletter  ================= */
.newsletter{text-align:center;max-width:740px;margin:0 auto}
.newsletter__title{
  font-family:var(--serif);font-size:clamp(38px,5vw,72px);
  font-weight:700;margin:0 0 14px;letter-spacing:-.02em;line-height:.98;
}
.newsletter__copy{color:var(--ink-soft);margin:0 0 28px;font-size:16px}
.newsletter__form{
  display:flex;gap:8px;max-width:540px;margin:0 auto 14px;
  padding:6px;background:rgba(255,255,255,.08);border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
}
.newsletter__form input{
  flex:1;padding:12px 20px;border-radius:999px;
  border:0;background:transparent;color:var(--white);font:inherit;font-size:14.5px;
}
.newsletter__form input:focus{outline:none}
.newsletter__form input::placeholder{color:rgba(255,255,255,.4)}
.newsletter__trust{
  font-size:12px;color:var(--muted);margin:0;letter-spacing:.06em;
}
.newsletter__trust strong{color:var(--accent);font-weight:700}

/* =================  Contact  ================= */
.contact{text-align:center;max-width:780px;margin:0 auto}
.contact__email{
  font-family:var(--serif);font-size:clamp(26px,3.2vw,40px);
  margin:0 0 12px;font-weight:600;
}
.contact__email a{
  color:var(--accent);border-bottom:1px solid rgba(201,169,106,.35);
  padding-bottom:4px;transition:color .2s,border-color .2s;
}
.contact__email a:hover{color:var(--white);border-color:var(--white)}
.contact__note{color:var(--muted);font-size:14.5px;margin:0 0 30px}
.socials{
  display:flex;flex-wrap:wrap;gap:12px 18px;justify-content:center;align-items:center;
}
.socials a{
  font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.7);font-weight:600;transition:color .2s;
}
.socials a:hover{color:var(--accent)}
.socials .dot{
  width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.22);
}

/* =================  Footer  ================= */
.footer{
  background:#000;color:rgba(255,255,255,.55);
  padding:22px 0;font-size:12px;letter-spacing:.04em;
  position:relative;z-index:20;
}
.footer__inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* =================  Responsive  ================= */

/* ---- Large laptops / small desktops (≤1180px) ---- */
@media (max-width:1180px){
  .container{padding:0 28px}
  .cards--feature{grid-template-columns:repeat(2,1fr);gap:20px}
  .hero__grid{gap:52px}
}

/* ---- Small laptops / large tablets (≤1080px) ---- */
@media (max-width:1080px){
  .hero__grid{gap:44px}
  .about__grid{grid-template-columns:1fr 1fr;gap:36px}
  .media-grid{grid-template-columns:1fr}
  .quotes{grid-template-columns:1fr 1fr}
  .quotes .quote:nth-child(3){grid-column:span 2;max-width:520px;margin:0 auto;width:100%}
  .section__title{font-size:clamp(26px,3.4vw,44px)}
}

/* ---- Sticky stacking OFF below this point (tablets + mobile only) ---- */
@media (max-width:960px){
  html,body{overflow-x:hidden}
  .hero,.section{
    position:relative;height:auto;min-height:auto;
    transform:none !important;opacity:1 !important;
    overflow:visible;
    border-radius:0;
    box-shadow:none;
  }
  .section{padding:72px 0 60px}
  .hero{padding:100px 0 56px}
  .section__ribbon{display:none}
}

/* ---- Tablets portrait (≤960px) ---- */
@media (max-width:960px){
  .container{padding:0 24px}
  .nav__inner{height:64px}
  .hero__grid{grid-template-columns:1fr;gap:40px;text-align:left}
  .hero__image{order:-1;max-width:380px;margin:0 auto 0 0}
  .hero__badge{left:-10px;bottom:20px}
  .hero__scroll{display:none}
  .hero__title{font-size:clamp(48px,8vw,88px)}
  .about__grid{grid-template-columns:1fr;gap:32px}
  .about__side{max-width:100%;display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}
  .about__portrait{aspect-ratio:3/4;max-width:320px;margin:0}
  .cards--feature{grid-template-columns:repeat(2,1fr);max-width:720px;margin:0 auto;gap:20px}
  .quotes{grid-template-columns:1fr;max-width:540px;margin:0 auto}
  .quotes .quote:nth-child(3){grid-column:auto;max-width:none;margin:0}
  .book__grid{grid-template-columns:1fr;gap:34px}
  .stats{grid-template-columns:repeat(4,1fr);gap:16px}
  .stats strong{font-size:26px}
  .section__head{flex-direction:column;align-items:flex-start;gap:18px}
  .featured{flex-direction:column;align-items:flex-start;gap:12px}
}

/* ---- Nav collapse (≤768px) ---- */
@media (max-width:768px){
  .nav__menu{
    position:fixed;inset:64px 0 auto 0;flex-direction:column;align-items:stretch;
    padding:20px;gap:4px;background:rgba(8,8,8,.98);
    backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:transform .3s ease;
  }
  .nav__menu a{padding:12px 4px;font-size:14px;border-bottom:1px solid rgba(255,255,255,.05)}
  .nav__menu a:last-child{border-bottom:0}
  .nav__cta{border:0;padding:12px 4px;text-align:left;border-radius:0}
  .nav__menu.is-open{transform:translateY(0)}
  .nav__toggle{display:flex}
}

/* ---- Phones landscape / small tablets (≤720px) ---- */
@media (max-width:720px){
  .container{padding:0 20px}
  .about__side{grid-template-columns:1fr}
  .about__portrait{aspect-ratio:3/4;max-width:300px;margin:0 auto}
  .awards{max-width:520px;margin:0 auto}
  .cards--feature{grid-template-columns:1fr;max-width:440px}
  .media{grid-template-columns:1fr;padding:14px}
  .media__img{aspect-ratio:16/10}
  .stats{grid-template-columns:repeat(2,1fr);gap:18px 24px}
  .book__copy,.book__list{max-width:none}
}

/* ---- Phones portrait (≤560px) ---- */
@media (max-width:560px){
  .container{padding:0 18px}
  .nav__inner{height:60px}
  .nav__menu{inset-block-start:60px}
  .nav__logo{font-size:15px;letter-spacing:.14em}

  .hero{padding:86px 0 40px}
  .hero__title{font-size:clamp(44px,12vw,74px);line-height:.95}
  .hero__lede{font-size:15px}
  .hero__ctas{flex-direction:column;align-items:stretch;gap:10px}
  .hero__ctas .btn{justify-content:center;width:100%}
  .hero__meta{gap:14px 22px;margin-top:28px;padding-top:20px}
  .hero__meta strong{font-size:22px}
  .hero__meta span{font-size:10px}
  .hero__image{max-width:100%;margin:0 auto}
  .hero__photo{max-height:none;border-radius:18px}
  .hero__badge{position:static;margin-top:12px;width:fit-content}

  .section{padding:60px 0 50px}
  .section__title{font-size:clamp(24px,7vw,34px);line-height:1.1}
  .section__num{font-size:10px}
  .section__num::after{width:20px}
  .section__label{font-size:10px;letter-spacing:.28em}

  .about__text .lead{font-size:15.5px}
  .about__text p{font-size:14px}
  .pull{font-size:15px;padding:14px 18px;margin-top:14px}
  .awards li{font-size:12px}
  .stats strong{font-size:22px}
  .stats span{font-size:9.5px}
  .featured__row{gap:6px 16px}
  .featured__row span{font-size:14px}

  .form__row{grid-template-columns:1fr;gap:10px}
  .form input,.form select,.form textarea{font-size:15px;padding:12px 14px}
  .btn{padding:12px 20px;font-size:13px}

  .feature__body{padding:14px 16px 16px}
  .feature__body h3{font-size:17px}
  .feature__body p{font-size:12.5px}

  .media{padding:12px;gap:14px}
  .media__body h3{font-size:16px}

  .quote{padding:22px 20px 20px}
  .quote blockquote{font-size:14.5px}
  .quote::before{font-size:60px;top:-6px;left:16px}

  .newsletter__title{font-size:clamp(32px,9vw,52px)}
  .newsletter__copy{font-size:14.5px;margin-bottom:22px}
  .newsletter__form{
    flex-direction:column;padding:10px;border-radius:18px;background:rgba(255,255,255,.06);
  }
  .newsletter__form input{padding:12px 14px;text-align:center}
  .newsletter__form .btn{width:100%;justify-content:center}

  .contact__email{font-size:22px;word-break:break-word}
  .contact__note{font-size:13.5px}
  .socials{gap:10px 14px}
  .socials a{font-size:10.5px;letter-spacing:.18em}
  .socials .dot{display:none}

  .footer__inner{flex-direction:column;text-align:center;gap:8px}
  .footer{padding:20px 0;font-size:11.5px}
}

/* ---- Small phones / iPhone SE (≤400px) ---- */
@media (max-width:400px){
  .container{padding:0 16px}
  .hero{padding:80px 0 32px}
  .hero__title{font-size:clamp(38px,13vw,64px)}
  .hero__meta{gap:10px 16px}
  .hero__meta>span{min-width:0}
  .hero__meta strong{font-size:19px}
  .section{padding:50px 0 42px}
  .section__title{font-size:22px;margin-bottom:18px}
  .about__portrait{aspect-ratio:5/4}
  .stats{gap:14px 18px}
  .stats strong{font-size:20px}
  .feature__body h3{font-size:16px}
  .media__body h3{font-size:15px}
  .newsletter__title{font-size:28px}
  .contact__email{font-size:19px}
}

/* ---- Touch targets (min 44px tap area) ---- */
@media (pointer:coarse){
  .btn{min-height:44px}
  .nav__menu a{min-height:44px;display:flex;align-items:center}
  .nav__toggle{width:44px;height:44px}
  .card__link{padding:6px 0}
  .socials a{padding:6px 0}
}

/* ---- Reduce motion ---- */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important}
  html{scroll-behavior:auto}
}
