/* ============================================================
   HUNTERS COUNTRY PRESS — "The Flight"
   One continuous scroll-scrubbed cinematic flythrough · V1
   ============================================================ */

:root{
  --navy:       #1a3050;
  --navy-dk:    #0b1e3a;
  --ink:        #0c0a08;
  --ivory:      #f0ebe0;
  --ivory-dim:  #cabfa9;
  --gold:       #b8923a;
  --gold-bright:#e6c87f;
  --line:       rgba(240,235,224,.18);

  --display: "Playfair Display", Georgia, serif;
  --serif:   "Cormorant Garamond", Georgia, serif;
  --ui:      "Inter", system-ui, sans-serif;

  --pad: clamp(1.3rem, 4.5vw, 5rem);
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ overflow-x:hidden; -webkit-text-size-adjust:100%; }
body{
  font-family: var(--serif);
  background:#000; color: var(--ivory);
  overflow-x:hidden; line-height:1.5;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
body.is-locked{ overflow:hidden; height:100vh; }
img,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }
::selection{ background: var(--gold); color: var(--navy-dk); }
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }

/* =============================================================
   PRELOADER
   ============================================================= */
.preloader{ position:fixed; inset:0; z-index:1000; background:var(--navy-dk);
  display:flex; align-items:center; justify-content:center; }
.preloader__inner{ text-align:center; position:relative; z-index:2; }
.preloader__brand{ display:block; font-family:var(--display); font-weight:600;
  font-size:clamp(2.2rem,5vw,3.6rem); letter-spacing:.04em; color:var(--gold-bright);
  opacity:0; transform:translateY(14px); animation:preFade 1s var(--ease-out) .15s forwards; }
.preloader__sub{ display:block; font-family:var(--ui); text-transform:uppercase;
  letter-spacing:.55em; font-size:clamp(.6rem,1vw,.78rem); color:var(--ivory); margin-top:.6rem;
  opacity:0; animation:preFade 1s var(--ease-out) .3s forwards; }
.preloader__rule{ width:min(46vw,320px); height:1px; margin:1.8rem auto 1.2rem;
  background:var(--line); position:relative; overflow:hidden; }
.preloader__rule i{ position:absolute; inset:0; transform-origin:left; transform:scaleX(0);
  background:linear-gradient(90deg,var(--gold),var(--gold-bright)); }
.preloader__count{ font-family:var(--display); font-size:clamp(1rem,1.5vw,1.3rem); color:var(--gold);
  opacity:0; animation:preFade 1s var(--ease-out) .45s forwards; }
.preloader__curtain{ position:absolute; inset:0; background:var(--navy-dk); }
@keyframes preFade{ to{ opacity:1; transform:none; } }

/* =============================================================
   NAV + RAIL
   ============================================================= */
.nav{ position:fixed; top:0; left:0; right:0; z-index:80;
  display:flex; align-items:center; justify-content:space-between;
  padding:clamp(1rem,2.2vw,1.7rem) var(--pad);
  opacity:0; transition:opacity 1s var(--ease); }
.nav.is-shown{ opacity:1; }
.nav__brand{ display:flex; flex-direction:column; line-height:1; }
.nav__brand-main{ font-family:var(--display); font-weight:600; font-size:clamp(1.05rem,1.6vw,1.4rem);
  letter-spacing:.06em; color:var(--gold-bright); text-shadow:0 1px 18px rgba(0,0,0,.5); }
.nav__brand-sub{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.36em;
  font-size:clamp(.48rem,.68vw,.58rem); color:var(--ivory); margin-top:.4rem; text-shadow:0 1px 12px rgba(0,0,0,.6); }
.nav__cta{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.2em; font-size:.66rem;
  color:var(--navy-dk); background:var(--ivory); padding:.85em 1.5em; border-radius:100px;
  transition:background .4s var(--ease), transform .4s var(--ease); }
.nav__cta:hover{ background:var(--gold-bright); transform:translateY(-1px); }

.rail{ position:fixed; top:0; right:0; width:2px; height:100vh; z-index:70;
  background:rgba(240,235,224,.10); pointer-events:none; }
.rail i{ display:block; width:100%; height:0%;
  background:linear-gradient(var(--gold),var(--gold-bright)); }

/* =============================================================
   THE FLIGHT — pinned stage
   ============================================================= */
.flight{ position:relative; height:100svh; overflow:hidden; }
.flight__stage{ position:absolute; inset:0; z-index:0; }

.flight__video{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center;
  z-index:1; transform:scale(1.05); will-change:transform,opacity;
}

/* cinematic grade — darken + navy tint for mood & legibility */
.flight__grade{ position:absolute; inset:0; z-index:3; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(8,16,30,.6) 0%, rgba(8,16,30,.18) 30%, rgba(8,16,30,.34) 62%, rgba(6,12,24,.86) 100%),
    radial-gradient(120% 80% at 50% 46%, rgba(20,30,55,0) 38%, rgba(8,14,28,.5) 100%);
  mix-blend-mode:multiply; }
.flight__vignette{ position:absolute; inset:0; z-index:4; pointer-events:none;
  background:radial-gradient(130% 100% at 50% 42%, transparent 46%, rgba(5,10,20,.55) 100%); }
.flight__grain{ position:absolute; inset:0; z-index:5; pointer-events:none; opacity:.06; mix-blend-mode:overlay;
  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='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* =============================================================
   BEATS
   ============================================================= */
.beats{ position:absolute; inset:0; z-index:10; }
.beat{ position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center;
  padding:0 var(--pad); opacity:0; will-change:transform,opacity; }

.beat__eyebrow,.beat__index{ font-family:var(--ui); text-transform:uppercase;
  letter-spacing:.42em; font-size:clamp(.6rem,.78vw,.74rem); color:var(--gold-bright);
  text-shadow:0 1px 16px rgba(0,0,0,.6); }
.beat__eyebrow{ margin-bottom:clamp(1.2rem,2.4vw,2rem); }
.beat__index{ margin-bottom:clamp(1rem,2vw,1.6rem); }

.beat__title{ font-family:var(--display); font-weight:500;
  font-size:clamp(2.8rem,8.2vw,8.5rem); line-height:.98; letter-spacing:-.01em;
  color:var(--ivory); text-shadow:0 4px 40px rgba(0,0,0,.5); }
.beat__title em{ font-style:italic; color:var(--gold-bright); }
.beat__title--close{ font-size:clamp(2.4rem,6.4vw,6.6rem); line-height:1.04; }

.beat__sub{ margin-top:clamp(1.4rem,2.6vw,2.2rem); font-family:var(--serif);
  font-size:clamp(1.1rem,1.9vw,1.6rem); color:var(--ivory-dim); letter-spacing:.01em;
  text-shadow:0 2px 20px rgba(0,0,0,.6); }

.beat__line{ font-family:var(--display); font-weight:400;
  font-size:clamp(2rem,6vw,5.6rem); line-height:1.08; letter-spacing:-.01em;
  max-width:20ch; color:var(--ivory); text-shadow:0 4px 40px rgba(0,0,0,.5); }
.beat__line em{ font-style:italic; color:var(--gold-bright); }

.beat__caption{ margin-top:clamp(2rem,4vw,3.2rem); font-family:var(--serif); font-style:italic;
  font-size:clamp(1rem,1.5vw,1.35rem); color:var(--ivory-dim); max-width:42ch;
  text-shadow:0 2px 18px rgba(0,0,0,.6); }

.beat__cta{ display:inline-flex; align-items:center; gap:1.1rem; margin-top:clamp(2.2rem,4.5vw,3.4rem);
  font-family:var(--ui); text-transform:uppercase; letter-spacing:.2em; font-size:.78rem;
  color:var(--navy-dk); background:var(--ivory); padding:1.05em 1.9em; border-radius:100px;
  transition:background .4s var(--ease), transform .4s var(--ease), gap .4s var(--ease); }
.beat__cta svg{ width:34px; height:8px; }
.beat__cta:hover{ background:var(--gold-bright); transform:translateY(-2px); gap:1.5rem; }

/* scroll cue */
.cue{ position:absolute; left:50%; bottom:clamp(1.4rem,3vw,2.4rem); z-index:12;
  transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:.8rem;
  font-family:var(--ui); text-transform:uppercase; letter-spacing:.4em; font-size:.58rem;
  color:var(--ivory-dim); text-shadow:0 1px 12px rgba(0,0,0,.6); }
.cue i{ width:1px; height:50px; background:linear-gradient(var(--gold),transparent); position:relative; overflow:hidden; }
.cue i::after{ content:""; position:absolute; top:0; left:0; width:100%; height:40%;
  background:var(--gold-bright); animation:cueDrop 2.2s var(--ease-out) infinite; }
@keyframes cueDrop{ 0%{transform:translateY(-100%)} 60%,100%{transform:translateY(260%)} }

/* =============================================================
   FOOTER (after the pinned flight)
   ============================================================= */
.foot{ background:var(--navy-dk); padding:clamp(2.4rem,5vw,3.4rem) var(--pad);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  font-family:var(--ui); text-transform:uppercase; letter-spacing:.24em;
  font-size:.6rem; color:var(--ivory-dim); border-top:1px solid var(--line); }
.foot__sign{ color:var(--gold); }

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width:680px){
  .nav__cta{ padding:.7em 1.1em; font-size:.58rem; }
  .foot{ flex-direction:column; gap:.5rem; }
}

@media (prefers-reduced-motion: reduce){
  /* the flythrough is scroll-driven and still works without smoothing;
     only the decorative looping cue is calmed here */
  .cue i::after{ animation:none; }
}

/* =============================================================
   ============== INNER PAGES (About, etc.) ====================
   shares tokens, nav, rail, footer, reveal primitives
   ============================================================= */
body.inner{ background:var(--navy-dk); }

/* shared kicker label */
.kicker{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.42em;
  font-size:clamp(.6rem,.78vw,.74rem); color:var(--gold-bright); }

/* inner-page nav gains a backdrop once past the hero */
body.inner .nav{ transition:background .5s var(--ease), padding .5s var(--ease), border-color .5s var(--ease); border-bottom:1px solid transparent; }
body.inner .nav.is-solid{ background:rgba(11,30,58,.82);
  backdrop-filter:blur(14px) saturate(120%); -webkit-backdrop-filter:blur(14px) saturate(120%);
  border-bottom-color:var(--line);
  padding-top:clamp(.7rem,1.4vw,1rem); padding-bottom:clamp(.7rem,1.4vw,1rem); }

/* nav menu (inner pages) */
.nav__menu{ display:flex; gap:clamp(1.4rem,2.6vw,2.6rem); }
.nav__menu a{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.22em;
  font-size:.7rem; color:var(--ivory-dim); position:relative; padding:.3rem 0;
  transition:color .4s var(--ease); }
.nav__menu a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:var(--gold); transform:scaleX(0); transform-origin:right; transition:transform .5s var(--ease); }
.nav__menu a:hover{ color:var(--ivory); }
.nav__menu a.is-active{ color:var(--ivory); }
.nav__menu a:hover::after,.nav__menu a.is-active::after{ transform:scaleX(1); transform-origin:left; }
@media (max-width:860px){ .nav__menu{ display:none; } }

/* ---- page hero ---- */
.page-hero{ position:relative; height:86svh; min-height:520px; overflow:hidden;
  display:flex; flex-direction:column; justify-content:center; padding:0 var(--pad); }
.page-hero[data-scrub]{ height:100svh; }
.page-hero__media{ position:absolute; inset:-6% 0; z-index:0; will-change:transform; }
.page-hero__video,.page-hero__media img{ position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:center; }
.page-hero__grade{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(8,16,30,.62), rgba(8,16,30,.28) 40%, rgba(7,14,26,.9)); }
.page-hero__vignette{ position:absolute; inset:0; z-index:1;
  background:radial-gradient(120% 90% at 50% 45%, transparent 45%, rgba(5,10,20,.6)); }
.page-hero__content{ position:relative; z-index:3; max-width:min(100%, 900px); }
.page-hero .kicker{ margin-bottom:clamp(1rem,2.2vw,1.8rem); }
.page-hero h1{ font-family:var(--display); font-weight:500; color:var(--ivory);
  font-size:clamp(2.6rem,6.8vw,6.6rem); line-height:1; letter-spacing:-.01em; }
.page-hero h1 .reveal-mask{ white-space:nowrap; }
.page-hero h1 em{ font-style:italic; color:var(--gold-bright); }
.page-hero__sub{ margin-top:clamp(1.2rem,2.2vw,1.8rem); font-family:var(--serif);
  font-size:clamp(1.1rem,1.8vw,1.5rem); color:var(--ivory-dim); font-style:italic; }

/* ---- story ---- */
.story{ max-width:1100px; margin:0 auto; padding:clamp(6rem,14vh,11rem) var(--pad) clamp(3rem,7vh,5rem);
  display:grid; grid-template-columns:1fr; gap:clamp(2rem,4vw,3rem); }
.story__index{ }
.story__lead{ font-family:var(--display); font-weight:500; letter-spacing:-.01em;
  font-size:clamp(2.2rem,5.4vw,4.6rem); line-height:1.05; color:var(--ivory); max-width:18ch; }
.story__lead em{ font-style:italic; color:var(--gold-bright); }
.story__body{ max-width:60ch; display:flex; flex-direction:column; gap:1.6rem; }
.story__body p{ font-family:var(--serif); font-size:clamp(1.15rem,1.6vw,1.5rem);
  line-height:1.65; color:var(--ivory-dim); }
@media (min-width:900px){
  .story{ grid-template-columns:0.85fr 1.15fr; align-items:start; }
  .story__index{ grid-column:1/2; }
  .story__lead{ grid-column:1/2; grid-row:2; position:sticky; top:18vh; }
  .story__body{ grid-column:2/3; grid-row:1/3; padding-top:.4rem; }
}

/* ---- pull quote ---- */
.pull{ padding:clamp(4rem,10vh,8rem) var(--pad); text-align:center; }
.pull blockquote{ font-family:var(--display); font-weight:400; font-style:italic;
  font-size:clamp(1.8rem,4.8vw,4rem); line-height:1.18; letter-spacing:-.01em;
  color:var(--ivory); max-width:24ch; margin:0 auto; }
.pull blockquote em{ color:var(--gold-bright); }

/* ---- stats ---- */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.5rem,4vw,4rem);
  max-width:1200px; margin:0 auto; padding:clamp(3rem,7vh,5rem) var(--pad);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.stat{ text-align:center; display:flex; flex-direction:column; gap:.8rem; }
.stat__num{ font-family:var(--display); font-weight:500; color:var(--gold-bright);
  font-size:clamp(2.2rem,5vw,4.4rem); line-height:1; letter-spacing:-.01em; }
.stat__label{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.24em;
  font-size:.64rem; color:var(--ivory-dim); }
@media (max-width:680px){ .stats{ grid-template-columns:1fr; gap:2.4rem; } }

/* ---- stand out ---- */
.standout{ max-width:1100px; margin:0 auto; padding:clamp(6rem,13vh,10rem) var(--pad); }
.standout__head{ margin-bottom:clamp(3rem,7vh,5rem); }
.standout__title{ font-family:var(--display); font-weight:500; letter-spacing:-.01em;
  font-size:clamp(2.2rem,5.4vw,4.6rem); line-height:1.04; color:var(--ivory); margin-top:1rem; }
.standout__title em{ font-style:italic; color:var(--gold-bright); }
.standout__list{ list-style:none; }
.standout__list li{ display:flex; align-items:baseline; gap:clamp(1.2rem,3vw,2.6rem);
  padding:clamp(1.4rem,3vw,2.2rem) 0; border-top:1px solid var(--line); }
.standout__list li:last-child{ border-bottom:1px solid var(--line); }
.standout__n{ font-family:var(--ui); font-size:.72rem; letter-spacing:.2em; color:var(--gold);
  flex:0 0 auto; padding-top:.5em; }
.standout__t{ font-family:var(--display); font-weight:400; color:var(--ivory);
  font-size:clamp(1.3rem,2.6vw,2.3rem); line-height:1.2; letter-spacing:-.005em; }

/* ---- close ---- */
.page-close{ position:relative; min-height:80svh; overflow:hidden;
  display:flex; flex-direction:column; justify-content:center; padding:clamp(5rem,10vh,8rem) var(--pad); }
.page-close__media{ position:absolute; inset:-6% 0; z-index:0; will-change:transform; }
.page-close__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.page-close__grade{ position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(8,16,30,.84), rgba(8,16,30,.6) 45%, rgba(7,14,26,.92)); }
.page-close__content{ position:relative; z-index:3; max-width:22ch; }
.page-close__title{ font-family:var(--display); font-weight:500; color:var(--ivory);
  font-size:clamp(2.6rem,7vw,6.8rem); line-height:1; letter-spacing:-.01em; }
.page-close__title em{ font-style:italic; color:var(--gold-bright); }
.page-close .beat__cta{ margin-top:clamp(2.2rem,4.5vw,3.4rem); }

/* ---- testimonials: featured value-prop quote ---- */
.feature-quote{ max-width:1100px; margin:0 auto; text-align:center;
  padding:clamp(6rem,14vh,11rem) var(--pad) clamp(3rem,7vh,5rem); }
.feature-quote .kicker{ margin-bottom:clamp(2rem,4vw,3rem); }
.feature-quote blockquote{ font-family:var(--display); font-weight:400; font-style:italic;
  font-size:clamp(1.8rem,4.4vw,3.6rem); line-height:1.2; letter-spacing:-.01em;
  color:var(--ivory); max-width:24ch; margin:0 auto; }
.feature-quote blockquote em{ color:var(--gold-bright); }
.feature-quote__attr{ margin-top:clamp(1.6rem,3vw,2.4rem); font-family:var(--ui);
  text-transform:uppercase; letter-spacing:.24em; font-size:.66rem; color:var(--ivory-dim); }
.feature-quote__attr span{ color:var(--gold); }

/* ---- testimonials: cover-paired features ---- */
.pair{ max-width:1200px; margin:0 auto; display:grid; align-items:center;
  grid-template-columns:0.8fr 1.2fr; gap:clamp(2rem,6vw,6rem);
  padding:clamp(3rem,7vh,5.5rem) var(--pad); }
.pair__cover{ margin:0; }
.pair__cover img{ width:210px; max-width:100%; height:auto; display:block;
  border-radius:2px; box-shadow:0 2px 1px rgba(0,0,0,.4), 0 36px 70px -34px rgba(0,0,0,.9); }
.pair__quote blockquote{ font-family:var(--display); font-weight:400; font-style:italic;
  font-size:clamp(1.6rem,3.4vw,2.9rem); line-height:1.25; letter-spacing:-.01em; color:var(--ivory); }
.pair__quote blockquote em{ color:var(--gold-bright); }
.pair__attr{ margin-top:clamp(1.4rem,2.6vw,2rem); font-family:var(--ui);
  text-transform:uppercase; letter-spacing:.22em; font-size:.66rem; color:var(--ivory-dim); line-height:1.8; }
.pair__attr span{ color:var(--gold); }
.pair--rev .pair__cover{ order:2; justify-self:end; }
@media (max-width:760px){
  .pair,.pair--rev{ grid-template-columns:1fr; gap:2rem; justify-items:start; }
  .pair--rev .pair__cover{ order:0; justify-self:start; }
  .pair__cover img{ max-width:220px; }
}

/* ---- testimonials: voices wall ---- */
.voices-wall-wrap{ max-width:1300px; margin:0 auto; padding:clamp(5rem,11vh,9rem) var(--pad); }
.voices-wall__head{ margin-bottom:clamp(3rem,7vh,5rem); }
.voices-wall__title{ font-family:var(--display); font-weight:500; letter-spacing:-.01em;
  font-size:clamp(2.2rem,5.4vw,4.6rem); line-height:1.04; color:var(--ivory); margin-top:1rem; }
.voices-wall__title em{ font-style:italic; color:var(--gold-bright); }
.voices-wall{ columns:3; column-gap:clamp(2rem,4vw,4rem); }
.voice{ break-inside:avoid; margin:0 0 clamp(2.4rem,4vw,3.4rem);
  padding-top:1.6rem; border-top:1px solid var(--line); }
.voice blockquote{ font-family:var(--serif); font-style:italic; font-weight:400;
  font-size:clamp(1.2rem,1.5vw,1.5rem); line-height:1.45; color:var(--ivory); }
.voice blockquote::before{ content:"\201C"; color:var(--gold-bright); margin-right:.05em; }
.voice blockquote::after{ content:"\201D"; color:var(--gold-bright); margin-left:.05em; }
.voice figcaption{ margin-top:1rem; font-family:var(--ui); font-size:.6rem;
  text-transform:uppercase; letter-spacing:.2em; color:var(--sage,#8b977f); line-height:1.7; }
.voice figcaption span{ display:block; color:var(--gold); letter-spacing:.16em; margin-bottom:.2em; }
@media (max-width:980px){ .voices-wall{ columns:2; } }
@media (max-width:620px){ .voices-wall{ columns:1; } }
.voices-wall--three{ max-width:1000px; }
.voices-wall__note{ margin-top:clamp(2rem,4vw,3rem); font-family:var(--ui); text-transform:uppercase;
  letter-spacing:.22em; font-size:.6rem; color:var(--sage,#8b977f); }

/* ---- testimonials: intro ---- */
.rv-intro{ max-width:1100px; margin:0 auto; text-align:center;
  padding:clamp(5rem,11vh,8rem) var(--pad) clamp(2rem,5vh,3.5rem); }
.rv-intro .kicker{ margin-bottom:1rem; }
.rv-intro__title{ font-family:var(--display); font-weight:500; letter-spacing:-.01em;
  font-size:clamp(2.2rem,5.4vw,4.4rem); line-height:1.04; color:var(--ivory); }
.rv-intro__title em{ font-style:italic; color:var(--gold-bright); }

/* ---- full review body (shared by featured + masonry) ---- */
.review__body p{ font-family:var(--serif); font-size:clamp(1.08rem,1.45vw,1.32rem);
  line-height:1.62; color:var(--ivory-dim); margin-bottom:1rem; }
.review__body p:last-child{ margin-bottom:0; }
.review__pull{ color:var(--ivory) !important; font-style:italic;
  font-size:clamp(1.18rem,1.7vw,1.5rem) !important; line-height:1.45 !important; }
.review__by{ margin-top:1.4rem; display:flex; flex-direction:column; gap:.55rem; }
.draw-rule{ display:block; width:48px; height:1px; background:var(--gold); transform-origin:left; }
.review__name{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.2em; font-size:.66rem; color:var(--gold); }
.review__biz{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.18em; font-size:.58rem; color:var(--sage,#8b977f); }

/* featured cover + full review */
.pair--full{ align-items:start; grid-template-columns:250px minmax(0,1fr); gap:clamp(2rem,5vw,5rem); }
.pair--full .pair__cover{ grid-column:1; order:0; justify-self:start; }
.pair--full .pair__quote{ grid-column:2; }
.pair--full.pair--rev{ grid-template-columns:minmax(0,1fr) 250px; }
.pair--full.pair--rev .pair__cover{ grid-column:2; justify-self:end; }
.pair--full.pair--rev .pair__quote{ grid-column:1; }
@media (min-width:761px){
  .pair--full .pair__cover{ position:sticky; top:15vh; align-self:start; }
}
@media (max-width:760px){
  .pair--full,.pair--full.pair--rev{ grid-template-columns:1fr; }
  .pair--full .pair__cover,.pair--full.pair--rev .pair__cover{ grid-column:1; justify-self:start; }
  .pair--full .pair__quote,.pair--full.pair--rev .pair__quote{ grid-column:1; }
}

/* ---- testimonials: recent editions cover showcase ---- */
.editions{ max-width:1100px; margin:0 auto; text-align:center;
  padding:clamp(1rem,3vh,2.5rem) var(--pad) clamp(3rem,6vh,5rem); }
.editions__grid{ display:flex; justify-content:center; flex-wrap:wrap;
  gap:clamp(2rem,5vw,4.5rem); margin-top:clamp(1.8rem,4vw,2.8rem); }
.edition{ margin:0; }
.edition img{ height:260px; width:auto; max-width:100%; display:block; border-radius:2px;
  box-shadow:0 2px 1px rgba(0,0,0,.4), 0 36px 70px -34px rgba(0,0,0,.9);
  transition:transform .6s var(--ease); }
@media (max-width:600px){ .edition img{ height:210px; } }
.edition:hover img{ transform:translateY(-6px); }
.edition figcaption{ margin-top:1rem; font-family:var(--ui); text-transform:uppercase;
  letter-spacing:.2em; font-size:.6rem; color:var(--sage,#8b977f); }
.edition figcaption span{ display:block; color:var(--gold); margin-bottom:.25em; }

/* ---- masonry of full reviews ---- */
.reviews-wrap{ max-width:1280px; margin:0 auto;
  padding:clamp(2rem,5vh,4rem) var(--pad) clamp(5rem,11vh,9rem); }
.reviews{ columns:2; column-gap:clamp(2.2rem,4.5vw,5rem); }
.review{ break-inside:avoid; margin:0 0 clamp(2.4rem,4vw,3.4rem);
  padding-bottom:clamp(2rem,3.5vw,2.8rem); border-bottom:1px solid var(--line); }
@media (max-width:820px){ .reviews{ columns:1; } }

/* ---- contact ---- */
.page-hero--short{ height:82svh; min-height:560px; }
.contact{ max-width:1240px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(2.5rem,6vw,6rem); padding:clamp(6rem,13vh,10rem) var(--pad); align-items:start; }
.contact__title{ font-family:var(--display); font-weight:500; letter-spacing:-.01em;
  font-size:clamp(2.4rem,5vw,4.4rem); line-height:1.02; color:var(--ivory); margin:1rem 0 1.6rem; }
.contact__title em{ font-style:italic; color:var(--gold-bright); }
.contact__lede{ font-family:var(--serif); font-size:clamp(1.1rem,1.5vw,1.4rem); line-height:1.6;
  color:var(--ivory-dim); max-width:46ch; }
.contact__details{ margin-top:clamp(2.4rem,5vw,3.5rem); display:flex; flex-direction:column; gap:1.8rem; }
.contact__email{ font-family:var(--display); font-style:italic; font-weight:400;
  font-size:clamp(1.3rem,2.4vw,2.1rem); color:var(--gold-bright); width:fit-content;
  border-bottom:1px solid transparent; transition:border-color .4s var(--ease); }
.contact__email:hover{ border-bottom-color:var(--gold); }
.contact__block{ display:flex; flex-direction:column; gap:.5rem; }
.contact__label{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.28em;
  font-size:.6rem; color:var(--gold); }
.contact__block address,.contact__block p{ font-family:var(--serif); font-style:normal;
  font-size:clamp(1.02rem,1.3vw,1.2rem); line-height:1.6; color:var(--ivory-dim); }
.contact__block a{ color:var(--ivory); border-bottom:1px solid var(--line); }
.contact__block a:hover{ border-bottom-color:var(--gold); }
.contact__reg{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.2em;
  font-size:.58rem; color:var(--sage,#8b977f); margin-top:.4rem; }

/* form */
.contact__form{ display:flex; flex-direction:column; gap:clamp(1.4rem,2.4vw,1.9rem); }
.field{ display:flex; flex-direction:column; gap:.6rem; }
.field label{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.22em;
  font-size:.6rem; color:var(--ivory-dim); }
.field input,.field textarea{ background:transparent; border:none; border-bottom:1px solid var(--line);
  color:var(--ivory); font-family:var(--serif); font-size:clamp(1.05rem,1.4vw,1.3rem);
  padding:.6rem 0; transition:border-color .4s var(--ease); resize:vertical; }
.field input:focus,.field textarea:focus{ outline:none; border-bottom-color:var(--gold-bright); }
.field input::placeholder,.field textarea::placeholder{ color:rgba(202,191,169,.4); }
.contact__submit{ align-self:flex-start; margin-top:.6rem; border:none; cursor:pointer; }
.contact__note{ font-family:var(--ui); letter-spacing:.04em; font-size:.74rem; color:var(--gold-bright);
  min-height:1.2em; }
@media (max-width:820px){
  .contact{ grid-template-columns:1fr; gap:3rem; }
}

/* =============================================================
   SITE-WIDE MENU — hamburger + overlay (mobile) & footer menu
   ============================================================= */
.nav__toggle{ display:none; position:relative; z-index:2; width:30px; height:18px;
  background:none; border:none; cursor:pointer; padding:0; }
.nav__toggle span{ position:absolute; left:0; width:100%; height:1.5px; background:var(--ivory);
  transition:transform .4s var(--ease), opacity .3s var(--ease); }
.nav__toggle span:nth-child(1){ top:2px; }
.nav__toggle span:nth-child(2){ bottom:2px; }
.nav__toggle.is-active span:nth-child(1){ top:8px; transform:rotate(45deg); }
.nav__toggle.is-active span:nth-child(2){ bottom:8px; transform:rotate(-45deg); }

.menu-overlay{ position:fixed; inset:0; z-index:75; background:var(--navy-dk);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:clamp(1.4rem,4vw,2rem);
  opacity:0; pointer-events:none; transition:opacity .5s var(--ease); }
.menu-overlay.is-open{ opacity:1; pointer-events:auto; }
.menu-overlay__links{ display:flex; flex-direction:column; align-items:center; gap:clamp(1rem,3vw,1.6rem); }
.menu-overlay__links a{ font-family:var(--display); font-weight:500; font-style:italic;
  font-size:clamp(2rem,9vw,3rem); color:var(--ivory); letter-spacing:-.01em;
  transition:color .3s var(--ease); }
.menu-overlay__links a:hover,.menu-overlay__links a.is-active{ color:var(--gold-bright); }
.menu-overlay__cta{ margin-top:clamp(1.4rem,4vw,2.4rem); font-family:var(--ui); text-transform:uppercase;
  letter-spacing:.2em; font-size:.72rem; color:var(--navy-dk); background:var(--ivory);
  padding:1em 1.8em; border-radius:100px; }
body.menu-open{ overflow:hidden; }

@media (max-width:860px){
  .nav__toggle{ display:block; }
  .nav .nav__cta{ display:none; }   /* CTA lives in the overlay on mobile */
}

/* footer menu */
.foot{ flex-direction:column; align-items:stretch; gap:clamp(1.8rem,4vw,2.6rem); }
.foot__menu{ display:flex; flex-wrap:wrap; gap:clamp(1.4rem,3vw,2.6rem); }
.foot__menu a{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.22em;
  font-size:.66rem; color:var(--ivory-dim); transition:color .35s var(--ease); }
.foot__menu a:hover{ color:var(--gold-bright); }
.foot__base{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem;
  padding-top:clamp(1.4rem,3vw,2rem); border-top:1px solid var(--line); }
@media (max-width:680px){ .foot__base{ flex-direction:column; gap:.5rem; } }

/* =============================================================
   LEGAL PAGES (Privacy, Terms)
   ============================================================= */
.legal-hero{ padding:clamp(8rem,18vh,12rem) var(--pad) clamp(2.5rem,5vh,4rem); max-width:1000px; margin:0 auto; }
.legal-hero .kicker{ margin-bottom:clamp(1rem,2vw,1.6rem); }
.legal-hero h1{ font-family:var(--display); font-weight:500; letter-spacing:-.01em;
  font-size:clamp(2.6rem,6vw,5rem); line-height:1; color:var(--ivory); }
.legal__updated{ margin-top:1.2rem; font-family:var(--ui); text-transform:uppercase;
  letter-spacing:.24em; font-size:.62rem; color:var(--gold); }
.legal{ max-width:1000px; margin:0 auto; padding:0 var(--pad) clamp(6rem,12vh,9rem); }
.legal__lead{ font-family:var(--serif); font-style:italic; font-size:clamp(1.2rem,1.8vw,1.6rem);
  line-height:1.5; color:var(--ivory); max-width:60ch; margin-bottom:clamp(2.5rem,5vw,4rem);
  padding-bottom:clamp(2rem,4vw,3rem); border-bottom:1px solid var(--line); }
.legal h2{ font-family:var(--display); font-weight:500; letter-spacing:-.005em;
  font-size:clamp(1.4rem,2.4vw,2rem); color:var(--gold-bright); margin:clamp(2.4rem,4vw,3.2rem) 0 1rem; }
.legal p,.legal li{ font-family:var(--serif); font-size:clamp(1.05rem,1.35vw,1.25rem);
  line-height:1.65; color:var(--ivory-dim); max-width:68ch; }
.legal p{ margin-bottom:1.1rem; }
.legal ul{ list-style:none; margin:0 0 1.1rem; padding:0; display:flex; flex-direction:column; gap:.7rem; }
.legal li{ position:relative; padding-left:1.5rem; }
.legal li::before{ content:"—"; position:absolute; left:0; color:var(--gold); }
.legal strong{ color:var(--ivory); font-weight:500; }
.legal a{ color:var(--gold-bright); border-bottom:1px solid var(--line); transition:border-color .35s var(--ease); }
.legal a:hover{ border-bottom-color:var(--gold-bright); }

/* =============================================================
   KEYBOARD FOCUS — visible ring for all interactive elements
   ============================================================= */
:focus-visible{ outline:2px solid var(--gold-bright); outline-offset:3px; }
.nav__menu a:focus-visible{ outline-offset:4px; }
.nav__cta:focus-visible,.beat__cta:focus-visible,.menu-overlay__cta:focus-visible{
  outline:2px solid var(--gold-bright); outline-offset:4px; }
.nav__toggle:focus-visible{ outline:2px solid var(--gold-bright); outline-offset:4px; }
.foot__menu a:focus-visible{ outline:2px solid var(--gold-bright); outline-offset:4px; }
.menu-overlay__links a:focus-visible{ outline:2px solid var(--gold-bright); outline-offset:6px; }
.field input:focus-visible,.field textarea:focus-visible{ outline:none; border-bottom-color:var(--gold-bright); }
.contact__submit:focus-visible{ outline:2px solid var(--gold-bright); outline-offset:4px; }
