/* ============================================================
   BASE.CSS — shared structural engine for all 5 ebook sites.
   build.py injects a per-site :root with SEMANTIC tokens so the
   same engine renders correctly on light-bg (Earl) and dark-bg
   (Enoch/Ada/Buried Ways/Modern Relic) brands.
   Soft tones are DERIVED with color-mix so they auto-adapt.
   Per-brand skin-<slug>.css layers flourishes on top.
   ============================================================ */

:root{
  /* injected per-site (fallbacks = Enoch dark) */
  --page-bg:#14233A; --ink:#F5EEDC; --panel:#F5EEDC; --panel-ink:#14233A;
  --deep:#0F1B2E; --on-deep:#F5EEDC;
  --accent:#E0A52E; --accent-2:#2E5E45; --danger:#B83A26; --ok:#2E5E45; --border:#D9C29A;
  --font-display:Georgia,serif; --font-body:system-ui,sans-serif; --font-accent:var(--font-display);

  /* derived (auto-adapt to light/dark) */
  --ink-soft:color-mix(in srgb,var(--ink) 62%,var(--page-bg));
  --panel-ink-soft:color-mix(in srgb,var(--panel-ink) 66%,var(--panel));
  --hair:color-mix(in srgb,var(--border) 55%,transparent);
  --hair-soft:color-mix(in srgb,var(--border) 28%,transparent);

  --maxw:1180px; --measure:60ch;
  --focal-hero:50% 50%; --focal-author:50% 30%;
  --r-sm:6px; --r:12px; --r-lg:20px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(0,0,0,.1),0 4px 12px -2px rgba(0,0,0,.1);
  --shadow:0 10px 24px -10px rgba(0,0,0,.34),0 26px 50px -24px rgba(0,0,0,.46);
  --shadow-lg:0 20px 44px -16px rgba(0,0,0,.42),0 48px 96px -28px rgba(0,0,0,.55);
  --ring:0 0 0 3px color-mix(in srgb,var(--accent) 50%,transparent);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--page-bg);color:var(--ink);font-family:var(--font-body);
  font-size:clamp(1.02rem,.5vw + .92rem,1.16rem);line-height:1.7;letter-spacing:.002em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:inherit}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.06;margin:0 0 .4em;font-weight:700;letter-spacing:-.01em;text-wrap:balance}
h1{font-size:clamp(2.3rem,5vw,4.3rem)}
h2{font-size:clamp(1.85rem,3.4vw,2.9rem)}
h3{font-size:clamp(1.25rem,1.6vw,1.6rem)}
p{margin:0 0 1rem;max-width:var(--measure)}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--r-sm)}
::selection{background:var(--accent);color:#16110a}

.wrap{width:min(100% - 2.4rem,var(--maxw));margin-inline:auto}
.section{padding-block:clamp(3rem,7vw,6.5rem)}
.band{background:var(--deep);color:var(--on-deep)}
.band p{color:color-mix(in srgb,var(--on-deep) 84%,transparent)}
.eyebrow{font-family:var(--font-accent);text-transform:uppercase;letter-spacing:.22em;font-size:.78rem;
  font-weight:700;color:var(--accent);margin:0 0 1rem}
.lede{font-size:clamp(1.08rem,1.3vw,1.32rem);color:var(--ink-soft);max-width:56ch}
.center{text-align:center}.center .lede,.center p{margin-inline:auto}

/* ============ RIBBON ============ */
.ribbon{background:var(--accent);color:#1b1407;text-align:center;font-weight:600;font-size:.92rem;
  padding:.62rem 1.2rem;letter-spacing:.005em}
.ribbon strong{font-weight:800}

/* ============ NAV ============ */
.nav{position:sticky;top:0;z-index:40;backdrop-filter:saturate(150%) blur(10px);
  background:color-mix(in srgb,var(--page-bg) 80%,transparent);border-bottom:1px solid var(--hair-soft)}
.nav__in{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.8rem}
.brandmark{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:800;
  font-size:1.18rem;letter-spacing:.01em;text-decoration:none;color:var(--ink)}
.brandmark .dot{width:.62rem;height:.62rem;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent)}
.nav__links{display:flex;gap:1.5rem;align-items:center;font-size:.95rem}
.nav__links a{text-decoration:none;opacity:.82;color:var(--ink)}
.nav__links a:hover{opacity:1;color:var(--accent)}
.nav__toggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer;padding:.4rem}
/* the nav (and its dropdown) MUST out-stack the hero. Some skins set
   .nav{position:relative;z-index:1}, which dropped the open mobile menu BEHIND the hero.
   header.nav beats .nav by specificity, restoring a sticky, top-of-stack nav on every skin. */
header.nav{position:sticky;top:0;z-index:60}
@media (max-width:760px){
  .nav__links{position:absolute;inset:100% 0 auto 0;flex-direction:column;align-items:stretch;
    background:var(--page-bg);z-index:60;
    border-top:1px solid var(--hair-soft);border-bottom:1px solid var(--hair);
    padding:.4rem 1.4rem 1rem;gap:0;display:none;
    box-shadow:0 18px 34px -12px rgba(0,0,0,.55)}
  .nav__links.open{display:flex}
  .nav__links a{opacity:1;min-height:48px;display:flex;align-items:center;
    border-top:1px solid var(--hair-soft)}
  .nav__links a:first-child{border-top:0}
  .nav__links .btn{margin-top:.7rem;min-height:50px;justify-content:center}
  .nav__toggle{display:inline-flex;align-items:center;justify-content:center;min-width:46px;min-height:46px;padding:.4rem}
  .brandmark{min-height:46px;align-items:center}
}

/* ============ BUTTONS ============ */
/* Overflow-proof: gumroad.js injects extra price spans into .gumroad-button anchors,
   so the flex button + its children must never push past their container. */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;cursor:pointer;font-family:var(--font-accent);
  font-weight:700;letter-spacing:.01em;border:0;border-radius:var(--r-pill);padding:.95rem 1.6rem;
  font-size:1.02rem;line-height:1.18;text-align:center;text-decoration:none;position:relative;overflow:hidden;
  max-width:100%;min-width:0;white-space:normal;overflow-wrap:anywhere;
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),filter .18s}
.btn>*{min-width:0;max-width:100%}
.gumroad-button{max-width:100%;white-space:normal}
.btn--primary{background:var(--accent);color:#1b1407;box-shadow:var(--shadow)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);filter:brightness(1.05)}
.btn--ghost{background:transparent;color:inherit;border:1.5px solid color-mix(in srgb,currentColor 34%,transparent)}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn--block{width:100%;justify-content:center}
.btn--lg{padding:1.1rem 2rem;font-size:1.1rem}
.btn[aria-disabled="true"]{opacity:.55;pointer-events:none;filter:grayscale(.3)}
.btn--prelaunch{background:color-mix(in srgb,var(--ok) 18%,var(--panel));color:var(--panel-ink);
  border:1px solid color-mix(in srgb,var(--ok) 45%,var(--border))}
.btn--primary:active{transform:translateY(0) scale(.985);box-shadow:var(--shadow-sm)}
/* tasteful shimmer sweep on the big money CTAs only (hero / bundle / offer) — GPU-only */
.btn--lg::after{content:"";position:absolute;top:0;left:-65%;width:42%;height:100%;pointer-events:none;
  background:linear-gradient(105deg,transparent,color-mix(in srgb,#fff 42%,transparent),transparent);
  transform:skewX(-18deg);animation:btn-shimmer 6s var(--ease) infinite}
@keyframes btn-shimmer{0%,68%{left:-65%}84%,100%{left:145%}}
@media (prefers-reduced-motion:reduce){.btn--lg::after{display:none}}

/* ============ HERO ============ */
.hero{position:relative;overflow:hidden;padding-block:clamp(3.2rem,8vw,6.5rem)}
.hero__grid{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(2rem,4vw,4rem);align-items:center}
@media (max-width:900px){.hero__grid{grid-template-columns:1fr;gap:2.4rem}}
.hero__title{margin:.15em 0 .45em}
.hero__sub{font-size:clamp(1.05rem,1.25vw,1.26rem);color:var(--ink-soft);max-width:48ch}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;margin-top:2rem}
.hero__trust{margin-top:1.1rem;font-size:.9rem;color:var(--ink-soft);display:flex;gap:.5rem;align-items:center}
.hero__art{position:relative;aspect-ratio:4/5;min-height:240px;border-radius:var(--r-lg);overflow:hidden;background:var(--deep);
  border:1px solid var(--hair);box-shadow:var(--shadow-lg);display:grid;place-items:center}
.hero__art img{width:100%;height:100%;object-fit:cover;object-position:var(--focal-hero)}
.hero__art .ph{color:color-mix(in srgb,var(--on-deep) 55%,transparent);font-family:var(--font-accent);
  text-align:center;padding:2rem;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;line-height:2}

/* ============ TRUST STRIP (under hero CTA) ============ */
.trust-strip{display:flex;flex-wrap:wrap;gap:.7rem 1.3rem;margin-top:1.1rem}
.trust-strip__item{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--ink-soft)}
.trust-strip__item svg{width:1rem;height:1rem;color:var(--accent);flex:none}

/* ============ PRICING (volumes + bundle) ============ */
.pricing{display:grid;grid-template-columns:repeat(12,1fr);gap:1.2rem}
.vol-card{grid-column:span 4;background:var(--panel);color:var(--panel-ink);border-radius:var(--r-lg);
  padding:1.7rem 1.55rem;display:flex;flex-direction:column;border:1px solid var(--hair);
  box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.vol-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.vol-card--feature{outline:2px solid var(--accent);outline-offset:-2px}
@media (max-width:880px){.vol-card{grid-column:span 6}}
@media (max-width:560px){.vol-card{grid-column:span 12}}
.vol-card__num{font-family:var(--font-accent);font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--danger);font-weight:700}
.vol-card__title{font-size:1.3rem;margin:.3rem 0 .1rem;color:var(--panel-ink)}
.vol-card__sub{color:var(--panel-ink-soft);font-size:.95rem;margin-bottom:.8rem;font-style:italic}
.vol-card__blurb{font-size:.96rem;color:color-mix(in srgb,var(--panel-ink) 82%,var(--panel))}
.vol-list{list-style:none;margin:1rem 0 1.3rem;padding:0;display:grid;gap:.5rem}
.vol-list li{position:relative;padding-left:1.55rem;font-size:.92rem;line-height:1.5;color:color-mix(in srgb,var(--panel-ink) 84%,var(--panel))}
.vol-list li::before{content:"";position:absolute;left:0;top:.42em;width:.62rem;height:.62rem;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent)}
.vol-card__foot{display:flex;flex-direction:column;align-items:stretch;gap:.85rem;margin-top:auto;
  padding-top:1.1rem;border-top:1px solid var(--hair-soft)}
.vol-card__foot .btn{width:100%;justify-content:center}
.price{font-family:var(--font-display);font-weight:800;
  font-size:clamp(1.7rem,1.2vw + 1.35rem,2.1rem);line-height:1;color:var(--panel-ink);font-variant-numeric:tabular-nums}
.price small{font-size:.78rem;font-weight:600;color:var(--panel-ink-soft)}
.in-vault{font-family:var(--font-accent);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent-2);font-weight:700}
.tag{display:inline-block;font-family:var(--font-accent);font-size:.64rem;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;background:var(--accent);color:#1b1407;padding:.28rem .6rem;border-radius:var(--r-pill)}

/* BUNDLE */
.bundle{grid-column:span 12;position:relative;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(150deg,var(--deep),color-mix(in srgb,var(--accent) 16%,var(--deep)));
  color:var(--on-deep);border:1.5px solid color-mix(in srgb,var(--accent) 45%,transparent);
  box-shadow:var(--shadow-lg);display:grid;grid-template-columns:1.3fr .7fr}
@media (max-width:820px){.bundle{grid-template-columns:1fr}}
.bundle__body{padding:clamp(1.8rem,3vw,2.8rem)}
.bundle__title{font-size:clamp(1.6rem,2.4vw,2.2rem);margin-bottom:.4rem;color:var(--on-deep)}
.bundle__body p{color:color-mix(in srgb,var(--on-deep) 84%,transparent)}
.bundle__includes{list-style:none;padding:0;margin:1.2rem 0;display:grid;grid-template-columns:1fr 1fr;gap:.5rem .9rem}
@media (max-width:560px){.bundle__includes{grid-template-columns:1fr}}
.bundle__includes li{padding-left:1.5rem;position:relative;font-size:.94rem;color:color-mix(in srgb,var(--on-deep) 90%,transparent)}
.bundle__includes li::before{content:"\2713";position:absolute;left:0;color:var(--accent);font-weight:800}
.bundle__bonuses{margin-top:.6rem;font-size:.9rem;color:color-mix(in srgb,var(--on-deep) 74%,transparent)}
.bundle__stack{display:flex;flex-direction:column;gap:.35rem;margin:1rem 0}
.bundle__stack-row{display:flex;justify-content:space-between;gap:1rem;font-size:.92rem;color:var(--panel-ink-soft)}
.bundle__stack-row b{color:var(--panel-ink)}
.bundle__stack-total{display:flex;justify-content:space-between;gap:1rem;border-top:1px solid var(--hair);
  margin-top:.45rem;padding-top:.55rem;font-weight:700;color:var(--panel-ink);font-variant-numeric:tabular-nums}
.bundle__buy{background:color-mix(in srgb,#000 20%,var(--deep));display:flex;flex-direction:column;
  justify-content:center;gap:.6rem;padding:clamp(1.8rem,3vw,2.6rem);text-align:center;border-left:1px solid color-mix(in srgb,var(--accent) 28%,transparent)}
@media (max-width:820px){.bundle__buy{border-left:0;border-top:1px solid color-mix(in srgb,var(--accent) 28%,transparent)}}
.bundle__compare{color:color-mix(in srgb,var(--on-deep) 56%,transparent);text-decoration:line-through;font-size:1.1rem;font-variant-numeric:tabular-nums}
.bundle__price{font-family:var(--font-display);font-weight:800;font-size:clamp(2.6rem,5vw,3.6rem);color:var(--accent);line-height:1;font-variant-numeric:tabular-nums}
.bundle__save{display:inline-block;background:var(--danger);color:#fff;font-weight:700;font-size:.82rem;padding:.3rem .8rem;border-radius:var(--r-pill);letter-spacing:.04em}

/* ============ NARRATIVE ============ */
.narrative .block{max-width:768px;margin-inline:auto;margin-bottom:clamp(2rem,4vw,3.2rem)}
.narrative .block:last-child{margin-bottom:0}
.narrative h2{margin-bottom:.5rem}
.narrative .block p{max-width:none}
.narrative .block:nth-child(even) h2{color:var(--accent)}

/* ============ OFFER ============ */
.offer .countdown{display:none;gap:.8rem;justify-content:center;margin:1.5rem 0}
.offer .countdown.is-live{display:flex}
.cd-unit{background:color-mix(in srgb,var(--on-deep) 8%,transparent);border:1px solid color-mix(in srgb,var(--on-deep) 18%,transparent);
  border-radius:var(--r);padding:.7rem 1rem;min-width:76px;text-align:center}
.cd-unit b{font-family:var(--font-display);font-size:1.9rem;display:block;line-height:1;font-variant-numeric:tabular-nums}
.cd-unit span{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;opacity:.7}

/* ============ PROOF + GUARANTEE ============ */
.proof__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:1.6rem;align-items:stretch}
@media (max-width:820px){.proof__grid{grid-template-columns:1fr}}
.guarantee{background:var(--panel);color:var(--panel-ink);border-radius:var(--r-lg);padding:2rem;
  border:1px solid var(--hair);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.7rem}
.guarantee h3{color:var(--panel-ink)}
.guarantee p{color:var(--panel-ink-soft)}
.guarantee .seal{position:relative;width:clamp(96px,9vw,112px);aspect-ratio:1;flex:0 0 auto;border-radius:50%;
  display:grid;place-content:center;gap:.02rem;padding:0;text-align:center;background:var(--accent-2);color:#fff;
  font-family:var(--font-accent);text-transform:uppercase;letter-spacing:.04em;
  box-shadow:inset 0 2px 3px color-mix(in srgb,#fff 30%,transparent),inset 0 -3px 7px color-mix(in srgb,#000 28%,transparent),
    0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent),0 12px 24px -10px rgba(0,0,0,.5);
  text-shadow:0 1px 1px color-mix(in srgb,#000 40%,transparent)}
.guarantee .seal::before{content:"";position:absolute;inset:7px;border-radius:inherit;
  border:1px solid color-mix(in srgb,#fff 38%,transparent);pointer-events:none}
.seal__n{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,3vw,2.5rem);line-height:.82}
.seal__d{font-size:.6rem;letter-spacing:.22em;opacity:.92;margin-top:.1rem}
.seal__g{font-size:.58rem;letter-spacing:.14em;font-weight:800;opacity:.95}
.reviews-empty{border:1.5px dashed var(--hair);border-radius:var(--r-lg);padding:2rem;display:flex;
  align-items:center;justify-content:center;text-align:center;color:var(--ink-soft);font-style:italic;min-height:160px}

/* ============ COMPARE BAND ============ */
.compare{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:1.6rem;align-items:stretch}
.compare__col{border:1px solid var(--hair);border-radius:var(--r-lg);padding:1.5rem 1.4rem;
  background:var(--panel);color:var(--panel-ink);box-shadow:var(--shadow-sm)}
.compare__col--ours{border:2px solid var(--accent);
  background:color-mix(in srgb,var(--accent) 10%,var(--panel));
  box-shadow:var(--shadow),0 0 0 5px color-mix(in srgb,var(--accent) 16%,transparent)}
.compare__name{font-family:var(--font-display);font-size:1.12rem;line-height:1.18;color:var(--panel-ink);margin-bottom:1rem}
.compare__col--ours .compare__name{color:color-mix(in srgb,var(--accent) 64%,var(--panel-ink))}
.compare__row{display:flex;flex-direction:column;gap:.12rem;padding:.7rem 0;border-top:1px solid var(--hair-soft)}
.compare__row:first-of-type{border-top:0;padding-top:0}
.compare__k{font-family:var(--font-accent);font-size:.68rem;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:var(--danger)}
.compare__v{font-size:.95rem;line-height:1.5;color:color-mix(in srgb,var(--panel-ink) 85%,var(--panel))}
.compare__col--ours .compare__v{color:var(--panel-ink)}
@media (max-width:760px){.compare{grid-template-columns:1fr}}

/* ============ OBJECTION HANDLER ============ */
.not-for{border-left:3px solid var(--accent);background:color-mix(in srgb,var(--accent) 6%,transparent);
  padding:1.1rem 1.3rem;border-radius:0 var(--r) var(--r) 0;margin-top:1.2rem}

/* ============ FAQ ============ */
.faq{max-width:820px;margin-inline:auto}
.faq__item{border-bottom:1px solid var(--hair)}
.faq__q{list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center;width:100%;
  cursor:pointer;padding:1.15rem 0;font-family:var(--font-display);font-weight:700;font-size:1.08rem;color:var(--ink)}
.faq__q::-webkit-details-marker{display:none}
.faq__q .chev{transition:transform .25s var(--ease);flex:0 0 auto;color:var(--accent);font-size:1.4rem;line-height:1}
.faq__item[open] .chev{transform:rotate(45deg)}
.faq__a{padding:0 0 1.2rem;color:var(--ink-soft)}
.faq__a p{max-width:none}

/* ============ EXIT POPUP ============ */
.exit{position:fixed;inset:0;z-index:90;display:none;place-items:center;padding:1.4rem;background:rgba(8,10,16,.62);backdrop-filter:blur(4px)}
.exit.is-open{display:grid;animation:fade .25s var(--ease)}
.exit__card{background:var(--panel);color:var(--panel-ink);max-width:480px;border-radius:var(--r-lg);padding:2.4rem;box-shadow:var(--shadow-lg);position:relative;text-align:center}
.exit__card h3{color:var(--panel-ink)}.exit__card p{color:var(--panel-ink-soft);margin-inline:auto}
.exit__close{position:absolute;top:.7rem;right:1rem;background:none;border:0;font-size:1.7rem;cursor:pointer;color:var(--panel-ink-soft);line-height:1}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ============ FOOTER ============ */
.footer{background:var(--deep);color:var(--on-deep);border-top:1px solid color-mix(in srgb,var(--accent) 20%,transparent);padding-block:clamp(2.6rem,5vw,4rem);font-size:.92rem}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2rem}
@media (max-width:720px){.footer__grid{grid-template-columns:1fr}}
.footer h4{color:var(--on-deep);font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;font-family:var(--font-accent)}
.footer a{color:color-mix(in srgb,var(--on-deep) 80%,transparent);text-decoration:none;display:block;margin:.4rem 0}
.footer a:hover{color:var(--accent)}
.footer .legal{font-size:.8rem;color:color-mix(in srgb,var(--on-deep) 56%,transparent);margin-top:2rem;border-top:1px solid color-mix(in srgb,var(--on-deep) 14%,transparent);padding-top:1.4rem;max-width:none}
.disclaimer-box{background:color-mix(in srgb,#000 16%,var(--deep));border-radius:var(--r);padding:1.2rem 1.4rem;font-size:.82rem;line-height:1.65;color:color-mix(in srgb,var(--on-deep) 72%,transparent);margin-top:1.2rem}
.disclaimer-box strong{color:color-mix(in srgb,var(--on-deep) 90%,transparent)}

/* ============ reveal ============ */
.reveal-on [data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal-on [data-reveal].in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal-on [data-reveal]{opacity:1;transform:none;transition:none}}

/* ============ legal docs ============ */
.doc{max-width:760px;margin-inline:auto;padding-block:clamp(2.4rem,5vw,4rem)}
.doc h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:.6rem}
.doc h2{font-size:1.35rem;margin-top:2rem;color:var(--accent)}
.doc p,.doc li{color:var(--ink-soft)}
.doc a{color:var(--accent)}
.doc .back{font-family:var(--font-accent);text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;text-decoration:none;opacity:.85;display:inline-block;margin-bottom:1.4rem}
.doc .updated{font-size:.85rem;color:var(--ink-soft);font-style:italic}

/* ============================================================
   v2 — face/faceless hero, "meet the host" band, sticky CTA,
   volume covers. Conversion-safe: no layout shift, lazy media,
   sticky buy bar never blocks content, reduced-motion honored.
   ============================================================ */
.hero__art--face{aspect-ratio:4/5}
.hero__art--face img{width:100%;height:100%;object-fit:cover;object-position:var(--focal-hero)}
.hero__cap{position:absolute;left:0;right:0;bottom:0;padding:1.5rem 1.3rem .95rem;
  background:linear-gradient(0deg,color-mix(in srgb,#000 80%,transparent),color-mix(in srgb,#000 30%,transparent) 55%,transparent);
  display:flex;flex-direction:column;gap:.15rem;color:#fff}
.hero__cap b{font-family:var(--font-display);font-size:1.18rem;letter-spacing:.01em}
.hero__cap span{font-size:.78rem;line-height:1.35;color:color-mix(in srgb,#fff 78%,transparent);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.hero__art--scene{aspect-ratio:4/5}
.hero__art--scene img{width:100%;height:100%;object-fit:cover}
.author__grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(1.8rem,4vw,3.5rem);align-items:center}
@media (max-width:820px){.author__grid{grid-template-columns:1fr;gap:2rem}}
.author__photo{margin:0;aspect-ratio:4/5;min-height:240px;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--hair);box-shadow:var(--shadow-lg);background:var(--deep)}
.author__photo img{width:100%;height:100%;object-fit:cover;object-position:var(--focal-author)}
.author__photo .ph{display:grid;place-items:center;height:100%;color:var(--ink-soft);font-family:var(--font-accent);letter-spacing:.14em;text-transform:uppercase;font-size:.8rem;text-align:center;padding:1rem}
.author__role{font-size:clamp(1.5rem,2.4vw,2.2rem);margin-bottom:.8rem}
.author__bio p{color:var(--ink-soft)}
.author__sign{margin-top:1.2rem;font-style:italic;color:var(--ink-soft);border-top:1px solid var(--hair-soft);padding-top:1rem}
.vol-card__cover{margin:-.2rem 0 1.3rem;aspect-ratio:3/4;min-height:8rem;border-radius:var(--r);overflow:hidden;position:relative;
  background:color-mix(in srgb,var(--panel-ink) 8%,var(--panel));
  border:3px solid color-mix(in srgb,var(--accent) 42%,var(--border));
  /* animated brand glow ring — skin-agnostic (no skin uses outline) so it lands on all 5 + thickens the frame */
  outline:2.5px solid color-mix(in srgb,var(--accent) 30%,transparent);outline-offset:2px;
  box-shadow:0 20px 38px -18px rgba(0,0,0,.62),inset 0 0 0 1px color-mix(in srgb,#fff 26%,transparent);
  animation:coverFrameGlow 3.4s var(--ease) infinite}
@keyframes coverFrameGlow{
  0%,100%{outline-color:color-mix(in srgb,var(--accent) 22%,transparent);outline-offset:2px}
  50%{outline-color:color-mix(in srgb,var(--accent) 66%,transparent);outline-offset:4px}}
@media (prefers-reduced-motion:reduce){.vol-card__cover{animation:none;outline-color:color-mix(in srgb,var(--accent) 45%,transparent)}}
.vol-card:hover .vol-card__cover{outline-color:color-mix(in srgb,var(--accent) 70%,transparent)}
.vol-card__cover img{width:100%;height:100%;object-fit:var(--cover-fit,cover);object-position:var(--focal-cover,50% 18%);transition:transform .5s var(--ease)}
/* book-spine shadow down the left edge so covers read as physical books */
.vol-card__cover::before{content:"";position:absolute;left:0;top:0;bottom:0;width:9px;z-index:2;pointer-events:none;
  background:linear-gradient(90deg,color-mix(in srgb,#000 30%,transparent),transparent)}
.vol-card:hover .vol-card__cover img{transform:scale(1.05) rotate(.3deg)}
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:60;transform:translateY(115%);opacity:0;transition:transform .35s var(--ease),opacity .35s var(--ease);background:color-mix(in srgb,var(--deep) 94%,transparent);backdrop-filter:blur(10px);border-top:1px solid color-mix(in srgb,var(--accent) 35%,transparent);box-shadow:0 -12px 32px -14px rgba(0,0,0,.55)}
.sticky-cta.is-visible{transform:none;opacity:1}
.sticky-cta__in{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.7rem}
.sticky-cta__txt{display:flex;flex-direction:column;line-height:1.25;color:var(--on-deep);min-width:0}
.sticky-cta__txt b{font-family:var(--font-display);font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:48vw}
.sticky-cta__price{font-size:.86rem;color:color-mix(in srgb,var(--on-deep) 78%,transparent)}
.sticky-cta__price s{opacity:.55;margin-left:.45rem}
@media (max-width:560px){.sticky-cta__txt b{display:none}.sticky-cta .btn{flex:1;justify-content:center}}
@media (prefers-reduced-motion:reduce){.sticky-cta{transition:none;opacity:1}.vol-card:hover .vol-card__cover img{transform:none}}

/* launch-price display (legal: slash = regular, labeled "Launch price · regular $X") */
.vol-price{display:flex;flex-direction:column;gap:.45rem;min-width:0}
.vol-price__row{display:flex;align-items:baseline;flex-wrap:wrap;gap:.2rem .55rem}
.price-was{text-decoration:line-through;text-decoration-color:color-mix(in srgb,var(--danger) 72%,transparent);
  text-decoration-thickness:2px;opacity:.7;font-size:1.12rem;color:var(--panel-ink-soft);
  font-family:var(--font-display);font-weight:700;font-variant-numeric:tabular-nums}
.vol-save{display:inline-flex;align-items:center;align-self:center;
  background:linear-gradient(180deg,color-mix(in srgb,#fff 16%,var(--danger)),var(--danger));color:#fff;
  font-family:var(--font-accent);font-weight:800;font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;
  padding:.3rem .6rem;border-radius:var(--r-pill);white-space:nowrap;
  box-shadow:0 4px 10px -4px color-mix(in srgb,var(--danger) 70%,transparent)}
.you-save{font-size:.82rem;color:var(--ok);font-weight:800;letter-spacing:.01em}
.vol-save-bar{height:5px;border-radius:999px;overflow:hidden;background:color-mix(in srgb,var(--panel-ink) 12%,var(--panel))}
.vol-save-bar i{display:block;height:100%;border-radius:999px;
  background:linear-gradient(90deg,var(--danger),color-mix(in srgb,var(--accent) 65%,var(--danger)))}
.launch-note{font-size:.72rem;color:var(--danger);font-weight:700;letter-spacing:.03em;text-transform:uppercase}
.buy-micro{font-size:.74rem;color:var(--panel-ink-soft);text-align:center}
.order-bump{display:block;font-size:.82rem;text-align:center;padding:.6rem .7rem;border-radius:var(--r);text-decoration:none;
  background:color-mix(in srgb,var(--ok) 10%,var(--panel));border:1px dashed color-mix(in srgb,var(--ok) 42%,var(--border))}
.order-bump:hover{background:color-mix(in srgb,var(--ok) 16%,var(--panel))}
.order-bump,.order-bump strong{color:color-mix(in srgb,var(--ok) 86%,var(--panel-ink));font-weight:700}

/* ============ typography polish ============ */
.vol-card__title{line-height:1.18}
@media (max-width:560px){.eyebrow{letter-spacing:.16em;font-size:.72rem}}

/* ============ animations (GPU-only, reduced-motion safe) ============ */
@media (prefers-reduced-motion:no-preference){
  .pricing [data-reveal]:nth-child(2){transition-delay:.06s}
  .pricing [data-reveal]:nth-child(3){transition-delay:.12s}
  .reveal-on [data-reveal] .vol-save{opacity:0;transform:scale(.8);
    transition:opacity .25s var(--ease) .25s,transform .25s var(--ease) .25s}
  .reveal-on [data-reveal].in .vol-save{opacity:1;transform:none}
}

/* ============ MOBILE MEDIA QUERIES ============ */
@media (max-width:560px){
  .offer .countdown{gap:.5rem}
  .cd-unit{min-width:0;flex:1 1 0;padding:.6rem .4rem}
  .cd-unit b{font-size:1.5rem}
  .cd-unit span{font-size:.6rem}
  .trust-strip__item{flex:1 1 45%}
  .hero__art--face,.hero__art--scene{aspect-ratio:3/4;max-height:62vh}
  .author__photo{max-height:70vh}
  .price{font-size:1.6rem}
  .guarantee{padding:1.5rem}
  .nav__links a{padding:.55rem 0}
  .nav__toggle{padding:.6rem}
  .footer a{padding:.35rem 0}
}
@media (max-width:390px){
  .offer .countdown{gap:.4rem}
  .cd-unit{padding:.55rem .25rem}
  .cd-unit b{font-size:1.3rem}
}

/* ============================================================
   v3 — premium conversion layer (additive, honest-only).
   New components + richer motion + fuller responsive coverage.
   ============================================================ */

/* flex parents: never let injected/long children overflow the frame */
.vol-card__foot,.bundle__buy,.hero__cta,.sticky-cta__in,.exit__card{min-width:0}

/* nav micro-shadow once scrolled (app.js toggles .is-scrolled) */
.nav.is-scrolled{box-shadow:0 8px 24px -16px rgba(0,0,0,.55)}
/* the nav CTA lives inside .nav__links, whose `a{color:var(--ink)}` would override the button's
   text color (low contrast: light text on the gold/cream button). Restore correct button contrast. */
.nav__links a.btn--primary{color:#1b1407}
.nav__links a.btn--prelaunch{color:var(--panel-ink)}
.nav__links a.btn:hover{color:#1b1407}
.nav__links a.btn--prelaunch:hover{color:var(--panel-ink)}


/* section sub-heading ("Prefer just one? Pick a single guide") */
.section-sub{display:flex;align-items:center;gap:1rem;margin:2.8rem 0 1.4rem;color:var(--ink-soft);
  font-family:var(--font-accent);text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;font-weight:700}
.section-sub::before,.section-sub::after{content:"";flex:1;height:1px;background:var(--hair-soft)}

/* bundle: "buy all three separately" anchor label + stronger struck regular price */
.bundle__separately{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
  color:color-mix(in srgb,var(--on-deep) 64%,transparent)}
.bundle__compare{font-size:1.35rem}
.bundle__stack-total{font-size:.98rem}

/* reassurance row (proof/guarantee): real, icon-backed trust signals */
.reassure{display:flex;flex-wrap:wrap;gap:.6rem 1.3rem;margin-top:1.1rem}
.reassure__item{display:inline-flex;align-items:center;gap:.45rem;font-size:.86rem;color:var(--panel-ink-soft);font-weight:600}
.reassure__item .ico{color:var(--accent-2);width:1.05em;height:1.05em;flex:none}

/* "What's inside" — honest contents/sample preview */
.inside__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.8rem}
.inside__card{background:var(--panel);color:var(--panel-ink);border:1px solid var(--hair);border-radius:var(--r-lg);
  padding:1.5rem 1.4rem;box-shadow:var(--shadow-sm)}
.inside__card h3{color:var(--panel-ink);font-size:1.1rem;margin-bottom:.2rem}
.inside__tag{font-family:var(--font-accent);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--danger);font-weight:800}
.inside__list{list-style:none;margin:.9rem 0 0;padding:0;display:grid;gap:.5rem}
.inside__list li{position:relative;padding-left:1.5rem;font-size:.92rem;line-height:1.5;color:color-mix(in srgb,var(--panel-ink) 84%,var(--panel))}
.inside__list li::before{content:"";position:absolute;left:0;top:.5em;width:.55rem;height:.55rem;border-radius:2px;background:var(--accent);transform:rotate(45deg)}
.inside__note{margin-top:1rem;font-size:.82rem;color:var(--panel-ink-soft);font-style:italic}

/* ---- richer motion (GPU-only, reduced-motion safe) ---- */
@media (prefers-reduced-motion:no-preference){
  .pricing [data-reveal]:nth-child(4){transition-delay:.18s}
  .pricing [data-reveal]:nth-child(5){transition-delay:.24s}
  /* hero trust-strip cascade */
  .reveal-on .trust-strip__item{opacity:0;transform:translateY(8px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
  .reveal-on [data-reveal].in .trust-strip__item{opacity:1;transform:none}
  .reveal-on [data-reveal].in .trust-strip__item:nth-child(2){transition-delay:.08s}
  .reveal-on [data-reveal].in .trust-strip__item:nth-child(3){transition-delay:.16s}
  .reveal-on [data-reveal].in .trust-strip__item:nth-child(4){transition-delay:.24s}
  /* savings bar grows in on reveal */
  .reveal-on [data-reveal] .vol-save-bar i{transform:scaleX(0);transform-origin:left;transition:transform .7s var(--ease) .3s}
  .reveal-on [data-reveal].in .vol-save-bar i{transform:none}
  /* bundle save badge pop */
  .reveal-on [data-reveal] .bundle__save{opacity:0;transform:scale(.82);transition:opacity .3s var(--ease) .2s,transform .3s var(--ease) .2s}
  .reveal-on [data-reveal].in .bundle__save{opacity:1;transform:none}
  /* hero headline clip-reveal (no layout shift) */
  .reveal-on .hero [data-reveal] .hero__title{clip-path:inset(0 0 102% 0);transition:clip-path .85s var(--ease) .05s}
  .reveal-on .hero [data-reveal].in .hero__title{clip-path:inset(0 0 -2% 0)}
  /* slow ken-burns on faceless hero scenes only (face portraits stay still = trust) */
  .hero__art--scene img{animation:kenburns 20s var(--ease) infinite alternate}
}
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.09) translate(1.4%,-1.4%)}}

/* ---- responsive: fuller coverage (768 / 480) ---- */
@media (max-width:768px){
  .bundle{grid-template-columns:1fr}
  .inside__grid{grid-template-columns:1fr}
  .section-sub{margin-top:2rem}
}
@media (max-width:480px){
  .section{padding-block:clamp(2.4rem,9vw,3.4rem)}
  .vol-card{padding:1.45rem 1.25rem}
  .btn{padding:.95rem 1.2rem;font-size:.98rem;min-height:48px}
  .btn--lg{padding:1.05rem 1.3rem;font-size:1.04rem}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{width:100%}
  .price{font-size:1.85rem}
  .nav__links a,.faq__q{min-height:44px}
  .footer a{display:flex;align-items:center;min-height:42px;margin:0}
  .reassure__item{font-size:.82rem}
}
@media (max-width:390px){
  .price{font-size:1.72rem}
  .seal__n{font-size:1.85rem}
}


/* ---- skin:buriedways ---- */
/* ============================================================
   SKIN — BURIED WAYS  ·  "The Excavation"
   ------------------------------------------------------------
   The page is a manuscript pulled out of the ground in strata.
   It opens in warm soil-brown lamplight (the food lane) and
   descends into ember-charcoal (the off-grid lane), bridged by
   one continuous warm-to-cool light gradient. Chiseled Cardo
   engraving rules, aged field-guide cards with torn top edges
   and a stratum index tab, the ember "Vault" as a treasure
   chamber, and exactly ONE signal-red wax seal on the guarantee.
   FACELESS: hero is a museum-specimen scene plate; no host band.
   No neon, no chrome, no bounce. Decorate, never restructure.
   ============================================================ */

/* ---- ember-amber + lamp-glow are brand secondaries (not tokens);
        used only inside gradients/mixes, never as flat brand fills ---- */

/* ============================================================
   1 · THE GROUND — page as excavated soil strata
   Faint horizontal stratum lines + a vertical core-grain + a
   warm lamp bloom top-left that cools to charcoal at depth.
   ============================================================ */
body{
  background:
    /* vertical core-sample grain (very faint) */
    repeating-linear-gradient(91deg,
      transparent 0 3px,
      color-mix(in srgb,#000 4%,transparent) 3px 4px),
    /* horizontal soil strata */
    repeating-linear-gradient(180deg,
      transparent 0 27px,
      color-mix(in srgb,#000 5%,transparent) 27px 28px),
    /* lamp bloom cooling into the deep */
    radial-gradient(135% 78% at 16% -10%,
      color-mix(in srgb,var(--accent) 17%,var(--page-bg)) 0%,
      var(--page-bg) 42%,
      color-mix(in srgb,var(--deep) 70%,var(--page-bg)) 100%);
  background-attachment:fixed;
  position:relative;
}
/* settled-dust grain over everything, behind content */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(circle at 22% 12%, color-mix(in srgb,var(--accent) 7%,transparent) 0, transparent 38%),
    radial-gradient(circle at 84% 88%, color-mix(in srgb,#F39A2B 7%,transparent) 0, transparent 42%);
  mix-blend-mode:screen;opacity:.7;
}
.wrap{position:relative;z-index:1}

/* ============================================================
   2 · ENGRAVING — eyebrows ride a double cut-rule
   ============================================================ */
.eyebrow{
  display:inline-block;position:relative;padding-bottom:.6rem;
  font-family:var(--font-accent);font-weight:700;
  text-shadow:0 1px 0 color-mix(in srgb,#000 18%,transparent);
}
.eyebrow::after{
  content:"";position:absolute;left:0;bottom:0;width:2.8rem;height:0;
  border-top:1px solid var(--accent);
  box-shadow:0 3px 0 -1px color-mix(in srgb,var(--accent) 48%,transparent);
}

/* chiseled display with a faint cut-shadow */
.hero__title,.bundle__title,.narrative h2,.guarantee h3,.author__role,.doc h1{
  letter-spacing:-.006em;
}
.hero__title{
  text-shadow:0 1px 0 color-mix(in srgb,#000 30%,transparent),
              0 0 36px color-mix(in srgb,var(--accent) 10%,transparent);
}

/* ============================================================
   3 · RIBBON — stamped manuscript banner with a debossed edge
   ============================================================ */
.ribbon{
  background:
    linear-gradient(180deg,
      color-mix(in srgb,#fff 16%,var(--accent)),
      color-mix(in srgb,#000 4%,var(--accent)));
  color:#2a1d07;letter-spacing:.05em;text-transform:uppercase;
  font-family:var(--font-accent);font-weight:700;font-size:.8rem;
  border-bottom:1px solid color-mix(in srgb,#000 30%,var(--accent));
  box-shadow:inset 0 -2px 0 color-mix(in srgb,#000 18%,transparent),
             inset 0 1px 0 color-mix(in srgb,#fff 30%,transparent);
}
.ribbon strong{color:#1c1304}

/* ============================================================
   4 · NAV — lamp-lit cream rule over soil
   ============================================================ */
.nav{
  background:color-mix(in srgb,var(--page-bg) 88%,transparent);
  border-bottom:1px solid var(--hair);
}
.brandmark{text-shadow:0 1px 0 color-mix(in srgb,#000 22%,transparent)}
.brandmark .dot{
  border-radius:1.5px;transform:rotate(45deg);
  background:linear-gradient(135deg,
    color-mix(in srgb,#fff 30%,var(--accent)),var(--accent));
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent),
             0 0 14px color-mix(in srgb,var(--accent) 48%,transparent);
}
.nav__links a:hover{color:var(--accent)}

/* ============================================================
   5 · BUTTONS — a struck brass field-stamp (the buy path: louder)
   ============================================================ */
.btn--primary{
  background:linear-gradient(180deg,
    color-mix(in srgb,#fff 18%,var(--accent)),
    color-mix(in srgb,#000 10%,var(--accent)));
  color:#241803;
  box-shadow:var(--shadow),
             inset 0 1px 0 color-mix(in srgb,#fff 46%,transparent),
             inset 0 -2px 0 color-mix(in srgb,#000 16%,transparent);
  text-shadow:0 1px 0 color-mix(in srgb,#fff 30%,transparent);
}
.btn--primary:hover{filter:brightness(1.05) saturate(1.06)}
.btn--ghost{
  border-color:color-mix(in srgb,var(--accent) 42%,transparent);
  background:color-mix(in srgb,var(--accent) 5%,transparent);
}
.btn--ghost:hover{
  border-color:var(--accent);
  background:color-mix(in srgb,var(--accent) 10%,transparent);
}

/* ============================================================
   6 · HERO — the museum-specimen plate (FACELESS world scene)
   The scene image is framed like a glass-cased excavation find:
   inset bezel, deep vignette, brass edge, a corner SPECIMEN slug.
   ============================================================ */
.hero{isolation:isolate}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(80% 60% at 78% 40%,
      color-mix(in srgb,#F39A2B 9%,transparent) 0, transparent 60%);
}
.hero__art,
.hero__art--scene{
  border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);
  box-shadow:
    var(--shadow-lg),
    inset 0 0 0 1px color-mix(in srgb,#000 30%,transparent),
    inset 0 0 0 7px color-mix(in srgb,#000 26%,transparent),
    inset 0 0 110px color-mix(in srgb,#000 46%,transparent);
  background:
    radial-gradient(95% 95% at 32% 22%,
      color-mix(in srgb,var(--accent) 13%,var(--deep)),
      var(--deep) 78%);
}
/* the scene image itself: slow warm grade + corner-darkened depth */
.hero__art--scene img{
  filter:saturate(1.04) contrast(1.04);
}
.hero__art--scene::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(120% 100% at 50% 22%,transparent 52%,
      color-mix(in srgb,#000 50%,transparent) 100%),
    linear-gradient(180deg,transparent 58%,
      color-mix(in srgb,var(--deep) 64%,transparent) 100%);
}
.hero__art .ph{
  letter-spacing:.24em;
  color:color-mix(in srgb,var(--accent) 60%,transparent);
}

/* ============================================================
   7 · VOLUME CARDS — aged field-guide pages on a CHISELED STONE
   TABLET. Torn top edge, a stratum index tab (the volume number),
   an archival hairline rule, a soft page-curl shadow on hover.
   v2 frame upgrade: the card now reads as a solid, deliberately
   FRAMED object — a thick stone-tablet edge built from a chiseled
   double-bevel (raised outer lip + carved inner channel via
   box-shadow rings) + an engraved double-hairline frame inset
   (.vol-card::before, free — base only puts ::before on --feature)
   + carved corner ticks. The outer border thickens to 2px so the
   silhouette is unmistakable against both light (Earl) and dark
   (others) pages. overflow stays hidden so the frame is crisp.
   ============================================================ */
.vol-card{
  position:relative;overflow:hidden;
  background:
    /* faint top-corner lamplight catching the page edge */
    radial-gradient(120% 60% at 0% 0%,
      color-mix(in srgb,var(--accent) 7%,transparent),transparent 52%),
    linear-gradient(180deg,
      color-mix(in srgb,#fff 5%,var(--panel)),
      color-mix(in srgb,var(--border) 9%,var(--panel)));
  /* thicker, brass-warmed stone edge — a real outline, not a hairline */
  border:2px solid color-mix(in srgb,var(--border) 64%,transparent);
  box-shadow:
    /* carved channel just inside the outer lip (the chisel cut) */
    inset 0 0 0 1px color-mix(in srgb,#000 16%,transparent),
    /* raised inner lip catching lamplight = embossed tablet face */
    inset 0 0 0 3px color-mix(in srgb,#fff 30%,transparent),
    /* top sheen + ambient depth */
    inset 0 1px 0 color-mix(in srgb,#fff 58%,transparent),
    var(--shadow-sm),
    /* grounded drop so the tablet sits ON the page, not in it */
    0 22px 38px -22px rgba(0,0,0,.5);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);
}
.vol-card:hover{
  transform:translateY(-5px);
  border-color:color-mix(in srgb,var(--accent) 46%,var(--border));
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb,#000 16%,transparent),
    inset 0 0 0 3px color-mix(in srgb,#fff 34%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 64%,transparent),
    var(--shadow),
    0 30px 52px -26px rgba(0,0,0,.55);
}
/* warm soil tint creeps up from the page bottom */
.vol-card::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:34%;
  pointer-events:none;
  background:linear-gradient(180deg,transparent,
    color-mix(in srgb,var(--border) 10%,transparent));
}
/* ENGRAVED FRAME: a double-hairline rule inset from the tablet edge,
   with carved corner ticks burned into each corner — the unmistakable
   "this is a framed field-guide card" outline. Sits above the bg but
   below content; pointer-events:none so it never blocks the CTA. */
.vol-card::before{
  content:"";position:absolute;inset:.7rem;z-index:1;pointer-events:none;
  border-radius:calc(var(--r-lg) - .55rem);
  /* the engraving: a thin cut-line + a paler raised companion line */
  border:1px solid color-mix(in srgb,var(--border) 46%,transparent);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb,#fff 26%,transparent),
    0 1px 0 color-mix(in srgb,#fff 20%,transparent);
  /* carved corner registration ticks — small brass squares burned into
     each corner of the engraved frame (accent, NOT signal-red: red stays
     reserved for the single wax seal). Reads as a chiseled plate marker. */
  background:
    linear-gradient(color-mix(in srgb,var(--accent) 60%,transparent),color-mix(in srgb,var(--accent) 60%,transparent)) top left/9px 9px no-repeat,
    linear-gradient(color-mix(in srgb,var(--accent) 60%,transparent),color-mix(in srgb,var(--accent) 60%,transparent)) top right/9px 9px no-repeat,
    linear-gradient(color-mix(in srgb,var(--accent) 60%,transparent),color-mix(in srgb,var(--accent) 60%,transparent)) bottom left/9px 9px no-repeat,
    linear-gradient(color-mix(in srgb,var(--accent) 60%,transparent),color-mix(in srgb,var(--accent) 60%,transparent)) bottom right/9px 9px no-repeat;
}
/* archival hairline beneath the title block */
.vol-card__num{
  letter-spacing:.24em;position:relative;
}
.vol-card__num::after{
  content:"";display:block;margin-top:.55rem;height:0;width:2.2rem;
  border-top:1px solid color-mix(in srgb,var(--danger) 55%,transparent);
}
.vol-card__title{letter-spacing:-.01em}

/* feature card — the "Most Popular" guide gets a brass display case:
   accent ring + lamp halo + a brass top-edge bar. We DON'T use a persistent
   transform:scale for the pop — base.css drives the reveal/hover transform on
   .vol-card and would override a static scale. The ring + 6px accent halo +
   44px outer glow + gilt rail make it pop in-brand without touching transform. */
.vol-card--feature{
  outline:2px solid var(--accent);outline-offset:-2px;
  /* premium gilt edge: thicker brass border than the standard tablet */
  border-color:color-mix(in srgb,var(--accent) 58%,var(--border));
  background:
    radial-gradient(130% 70% at 50% 0%,
      color-mix(in srgb,var(--accent) 13%,transparent),transparent 58%),
    linear-gradient(180deg,
      color-mix(in srgb,#fff 6%,var(--panel)),
      color-mix(in srgb,var(--border) 10%,var(--panel)));
  /* the most-popular plate gets a deeper carved double-channel + a wider
     gilt halo + outer glow — a museum display-case frame, not just a card */
  box-shadow:var(--shadow-lg),
             0 0 0 6px color-mix(in srgb,var(--accent) 16%,transparent),
             0 0 44px -6px color-mix(in srgb,var(--accent) 34%,transparent),
             inset 0 0 0 1px color-mix(in srgb,#000 18%,transparent),
             inset 0 0 0 3px color-mix(in srgb,var(--accent) 24%,transparent),
             inset 0 0 0 4px color-mix(in srgb,#fff 40%,transparent),
             inset 0 1px 0 color-mix(in srgb,#fff 58%,transparent);
}
/* brass top-edge bar: the case's gilt rail */
.vol-card--feature::before{
  content:"";position:absolute;left:0;right:0;top:0;height:4px;z-index:2;pointer-events:none;
  background:linear-gradient(90deg,
    color-mix(in srgb,#000 14%,var(--accent)),
    color-mix(in srgb,#fff 30%,var(--accent)),
    color-mix(in srgb,#000 14%,var(--accent)));
  box-shadow:0 0 14px color-mix(in srgb,var(--accent) 50%,transparent);
}
.vol-card--feature:hover{
  box-shadow:var(--shadow-lg),
             0 0 0 6px color-mix(in srgb,var(--accent) 20%,transparent),
             0 0 56px -4px color-mix(in srgb,var(--accent) 40%,transparent),
             inset 0 0 0 1px color-mix(in srgb,#fff 62%,transparent);
}

/* the .tag badge as a stitched leather flag */
.tag{
  box-shadow:0 2px 6px -2px color-mix(in srgb,#000 50%,transparent),
             inset 0 1px 0 color-mix(in srgb,#fff 35%,transparent);
}

/* cover thumbnail: glass-cased specimen.
   base.css owns the left book-spine via .vol-card__cover::before + a min-height +
   object-position:var(--focal-cover). We only enrich the FRAME so it harmonizes
   with that spine: a warm brass bevel, a page-block highlight on the RIGHT edge
   (the opposite side from base's spine, so the cover reads as a real bound book),
   and a deeper corner vignette. No ::before here (base owns it); cover keeps
   overflow:hidden so all depth lives in inset shadows + the outer drop. */
.vol-card__cover{
  /* chiseled specimen-PLATE edge: a thicker brass border than base's 2px
     accent line, so the cover reads as a mounted plate, not a bare photo.
     base owns the left spine (::before) + the 2px accent border; we widen
     the brass plate frame + carve a beveled channel inside it. */
  border:3px solid color-mix(in srgb,var(--accent) 38%,var(--border));
  box-shadow:
    var(--shadow),
    /* page-block: stacked-pages highlight down the right edge */
    inset -7px 0 9px -7px color-mix(in srgb,#fff 30%,transparent),
    inset -1px 0 0 0 color-mix(in srgb,var(--border) 40%,transparent),
    /* carved channel just inside the brass plate (the chisel cut) */
    inset 0 0 0 1px color-mix(in srgb,#000 30%,transparent),
    inset 0 0 0 3px color-mix(in srgb,#fff 22%,transparent),
    /* brass top bevel + glass-case inner edge + deep corner vignette */
    inset 0 1px 0 color-mix(in srgb,#fff 26%,transparent),
    inset 0 0 56px color-mix(in srgb,#000 30%,transparent);
}
/* ENGRAVED MAT: an inset hairline rule floats just inside the plate edge,
   like the matting of a framed specimen. ::after is free (base owns the
   ::before spine). Coexists with the spine: starts past the spine width so
   it never collides with it. pointer-events:none, sits above the image. */
.vol-card__cover::after{
  content:"";position:absolute;top:6px;right:6px;bottom:6px;left:13px;z-index:3;pointer-events:none;
  border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);
  box-shadow:inset 0 0 0 1px color-mix(in srgb,#000 22%,transparent);
}
.vol-card:hover .vol-card__cover{
  border-color:color-mix(in srgb,var(--accent) 52%,var(--border));
  box-shadow:
    var(--shadow-lg),
    inset -7px 0 9px -7px color-mix(in srgb,#fff 34%,transparent),
    inset -1px 0 0 0 color-mix(in srgb,var(--border) 46%,transparent),
    inset 0 0 0 1px color-mix(in srgb,#000 30%,transparent),
    inset 0 0 0 3px color-mix(in srgb,#fff 26%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 30%,transparent),
    inset 0 0 56px color-mix(in srgb,#000 28%,transparent);
}
.vol-card:hover .vol-card__cover::after{
  border-color:color-mix(in srgb,var(--accent) 44%,transparent);
}

/* harvest-grain bullet seeds */
.vol-list li::before{
  background:radial-gradient(circle at 34% 28%,
    color-mix(in srgb,#fff 32%,var(--accent)),
    color-mix(in srgb,#000 20%,var(--accent)));
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 16%,transparent);
}

/* the launch-price discount block, dressed as a field-stamp markdown.
   base.css owns layout/tokens; we only add brand depth + a warmer "you save". */
.price-was{text-shadow:0 1px 0 color-mix(in srgb,#fff 28%,transparent)}
.vol-save{
  box-shadow:0 4px 10px -4px color-mix(in srgb,var(--danger) 70%,transparent),
             inset 0 1px 0 color-mix(in srgb,#fff 26%,transparent);
  text-shadow:0 1px 1px color-mix(in srgb,#000 30%,transparent);
}
.you-save{text-shadow:0 1px 0 color-mix(in srgb,#fff 26%,transparent)}
.vol-save-bar{box-shadow:inset 0 1px 2px color-mix(in srgb,#000 22%,transparent)}
.vol-save-bar i{box-shadow:0 0 8px color-mix(in srgb,var(--accent) 40%,transparent)}
.launch-note{text-shadow:0 1px 0 color-mix(in srgb,#fff 22%,transparent)}

/* ============================================================
   7b · WHAT'S INSIDE + REASSURE — excavation log cards + field marks
   base.css ships these as plain token cards; we age them into the
   manuscript: warm paper gradient, archival hairline tab, brass marks.
   ============================================================ */
.inside__card{
  position:relative;overflow:hidden;
  background:
    radial-gradient(120% 60% at 0% 0%,
      color-mix(in srgb,var(--accent) 6%,transparent),transparent 52%),
    linear-gradient(180deg,
      color-mix(in srgb,#fff 5%,var(--panel)),
      color-mix(in srgb,var(--border) 9%,var(--panel)));
  border:1px solid color-mix(in srgb,var(--border) 50%,transparent);
  box-shadow:var(--shadow-sm),
             inset 0 1px 0 color-mix(in srgb,#fff 54%,transparent),
             inset 0 0 0 1px color-mix(in srgb,#fff 40%,transparent);
  transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease);
}
.inside__card:hover{
  transform:translateY(-3px);
  border-color:color-mix(in srgb,var(--accent) 34%,var(--border));
  box-shadow:var(--shadow),
             inset 0 1px 0 color-mix(in srgb,#fff 60%,transparent),
             inset 0 0 0 1px color-mix(in srgb,#fff 44%,transparent);
}
/* the section/index tag rides a short red cut-rule, matching the vol-card num */
.inside__tag{position:relative;display:inline-block;padding-bottom:.4rem}
.inside__tag::after{
  content:"";position:absolute;left:0;bottom:0;width:1.8rem;height:0;
  border-top:1px solid color-mix(in srgb,var(--danger) 55%,transparent);
}
/* the rotated-square "inside" bullets get a brass cast + faint glow */
.inside__list li::before{
  background:linear-gradient(135deg,
    color-mix(in srgb,#fff 28%,var(--accent)),
    color-mix(in srgb,#000 18%,var(--accent)));
  box-shadow:0 0 6px color-mix(in srgb,var(--accent) 30%,transparent);
}

/* reassurance row: each mark is a stamped field assurance */
.reassure__item{letter-spacing:.005em}
.reassure__item .ico{filter:drop-shadow(0 1px 1px color-mix(in srgb,#000 28%,transparent))}

/* ============================================================
   8 · BUNDLE — "The Vault": the ember treasure chamber
   This is the deepest stratum. Charcoal walls, a gold seam of
   ore through the rock, the price glowing like a lamp in a pit.
   ============================================================ */
.bundle{
  background:
    radial-gradient(150% 110% at 0% 0%,
      color-mix(in srgb,var(--accent) 24%,var(--deep)) 0%,
      var(--deep) 52%),
    radial-gradient(120% 90% at 100% 100%,
      color-mix(in srgb,#F39A2B 20%,var(--deep)) 0%,
      transparent 60%),
    linear-gradient(160deg,var(--deep),
      color-mix(in srgb,#F39A2B 12%,var(--deep)));
  border:1.5px solid color-mix(in srgb,var(--accent) 54%,transparent);
  /* hero of the pricing area: outer lamp halo announces it before you read it */
  box-shadow:var(--shadow-lg),
             0 0 0 1px color-mix(in srgb,var(--accent) 22%,transparent),
             0 28px 70px -30px color-mix(in srgb,var(--accent) 40%,transparent),
             inset 0 1px 0 color-mix(in srgb,var(--accent) 30%,transparent),
             inset 0 0 130px color-mix(in srgb,#000 40%,transparent);
}
/* a gilt inner rule frames the chamber like a vault door (sits BEHIND body text) */
.bundle__body{position:relative;z-index:1}
.bundle__body::after{
  content:"";position:absolute;inset:.7rem;z-index:-1;pointer-events:none;border-radius:var(--r);
  border:1px solid color-mix(in srgb,var(--accent) 16%,transparent);
}
/* a gold ore-seam threading diagonally across the chamber */
.bundle::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(118deg,transparent 0 46%,
    color-mix(in srgb,var(--accent) 40%,transparent) 49.4% 50%,
    transparent 53%);
  opacity:.5;
}
.bundle__body,.bundle__buy{position:relative;z-index:1}
.bundle__title{
  text-shadow:0 0 30px color-mix(in srgb,var(--accent) 22%,transparent);
}
.bundle__price{
  text-shadow:0 0 26px color-mix(in srgb,var(--accent) 50%,transparent),
              0 0 6px color-mix(in srgb,var(--accent) 40%,transparent);
}
.bundle__compare{font-style:italic}
.bundle__save{
  box-shadow:0 6px 16px -6px color-mix(in srgb,var(--danger) 70%,transparent),
             inset 0 1px 0 color-mix(in srgb,#fff 28%,transparent);
}
/* ration the buy panel a touch darker so the gold price pops */
.bundle__includes li::before{
  color:var(--accent);
  text-shadow:0 0 8px color-mix(in srgb,var(--accent) 45%,transparent);
}

/* ============================================================
   9 · NARRATIVE band — the dug-out dark with ember-edge rules
   Two gold horizon hairlines top + bottom; even headings flip
   to harvest-gold (the "they buried it" turns).
   ============================================================ */
.band{
  background:
    radial-gradient(110% 76% at 50% 0%,
      color-mix(in srgb,#F39A2B 10%,var(--deep)),var(--deep) 70%);
  position:relative;
}
.band::before,.band::after{
  content:"";position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,
    color-mix(in srgb,var(--accent) 62%,transparent),transparent);
}
.band::before{top:0}.band::after{bottom:0}
.narrative h2{position:relative;padding-bottom:.4rem}
.narrative .block:nth-child(even) h2{
  color:var(--accent);
  text-shadow:0 0 24px color-mix(in srgb,var(--accent) 14%,transparent);
}
/* drop cap on the first narrative paragraph: an illuminated initial */
.narrative .block:first-child > div > p:first-of-type::first-letter,
.narrative .block:first-child p:first-of-type::first-letter{
  font-family:var(--font-display);font-weight:700;
  font-size:3.1em;line-height:.78;float:left;
  margin:.06em .14em 0 0;
  color:var(--accent);
  text-shadow:0 1px 0 color-mix(in srgb,#000 40%,transparent);
}

/* ============================================================
   10 · GUARANTEE — the single signal-red WAX SEAL
   Irregular wax-blob radius, embossed center, dripping shadow.
   The only place signal-red appears at size on the page.
   ============================================================ */
.guarantee{
  background:linear-gradient(180deg,
    color-mix(in srgb,#fff 5%,var(--panel)),
    color-mix(in srgb,var(--border) 8%,var(--panel)));
  border:1px solid color-mix(in srgb,var(--border) 50%,transparent);
  box-shadow:var(--shadow-sm),
             inset 0 0 0 1px color-mix(in srgb,#fff 50%,transparent);
}
/* base.css owns the seal SIZING (width/height/font-size) + a ::before ring with
   border-radius:inherit — so the ring follows our wax-blob radius. We set only
   the wax BACKGROUND / blob radius / color / shadow here (no sizing). */
.guarantee .seal{
  background:
    radial-gradient(circle at 38% 30%,
      color-mix(in srgb,#fff 26%,var(--danger)),
      color-mix(in srgb,var(--danger) 92%,#000) 62%,
      color-mix(in srgb,#000 30%,var(--danger)) 100%);
  color:#fff5ec;
  border-radius:46% 54% 52% 48% / 52% 48% 56% 44%;
  letter-spacing:.04em;
  text-shadow:0 1px 1px color-mix(in srgb,#000 40%,transparent);
  box-shadow:
    0 8px 20px -6px color-mix(in srgb,var(--danger) 70%,transparent),
    0 0 28px -8px color-mix(in srgb,var(--danger) 55%,transparent),
    inset 0 0 0 2px color-mix(in srgb,#000 22%,transparent),
    inset 0 3px 6px color-mix(in srgb,#fff 24%,transparent),
    inset 0 -5px 9px color-mix(in srgb,#000 26%,transparent);
}

/* reviews-empty: an unstamped archival card awaiting entries */
.reviews-empty{
  border:1px dashed color-mix(in srgb,var(--accent) 40%,transparent);
  background:
    repeating-linear-gradient(135deg,transparent 0 12px,
      color-mix(in srgb,var(--accent) 5%,transparent) 12px 13px);
  color:var(--ink-soft);
}

/* ============================================================
   11 · OFFER + countdown — lamp-lit dials in the dark
   ============================================================ */
.cd-unit{
  background:color-mix(in srgb,#000 26%,var(--deep));
  border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);
  box-shadow:inset 0 0 24px color-mix(in srgb,#000 40%,transparent);
}
.cd-unit b{color:var(--accent);
  text-shadow:0 0 18px color-mix(in srgb,var(--accent) 40%,transparent)}

/* ============================================================
   12 · FAQ — each question is a stratum boundary
   ============================================================ */
.faq__item{
  border-bottom:1px solid color-mix(in srgb,var(--accent) 24%,transparent);
}
.faq__q{transition:color .2s var(--ease)}
.faq__q:hover{color:var(--accent)}
.faq__item[open] .faq__q{color:var(--accent)}

/* ============================================================
   13 · STICKY CTA — the brass field-stamp bar (irresistible-to-tap)
   Warm chamber backdrop, gold rule above, glowing price.
   Reads instantly; never fights the page.
   ============================================================ */
.sticky-cta{
  background:
    linear-gradient(180deg,
      color-mix(in srgb,var(--accent) 12%,var(--deep)),
      color-mix(in srgb,var(--deep) 96%,transparent));
  border-top:1px solid color-mix(in srgb,var(--accent) 46%,transparent);
  box-shadow:0 -14px 36px -14px rgba(0,0,0,.6),
             inset 0 1px 0 color-mix(in srgb,var(--accent) 26%,transparent);
}
.sticky-cta__txt b{
  color:var(--on-deep);
  text-shadow:0 1px 0 color-mix(in srgb,#000 40%,transparent);
}
.sticky-cta__price{color:color-mix(in srgb,var(--accent) 80%,var(--on-deep))}
.sticky-cta__price s{color:color-mix(in srgb,var(--on-deep) 50%,transparent)}

/* ============================================================
   14 · FOOTER — buried bedrock with a gold horizon line
   ============================================================ */
.footer{
  background:linear-gradient(180deg,
    var(--deep),color-mix(in srgb,#000 34%,var(--deep)));
  border-top:1px solid color-mix(in srgb,var(--accent) 32%,transparent);
}
.footer h4{color:color-mix(in srgb,var(--accent) 84%,var(--on-deep))}
.disclaimer-box{
  border-left:3px solid color-mix(in srgb,var(--danger) 60%,transparent);
}

/* legal-doc headings keep the engraving accent */
.doc h2{position:relative}

/* ============================================================
   15 · DESKTOP-ONLY heavy decoration (kept off phones)
   ============================================================ */
@media (min-width:760px){
  /* engraved underline under narrative headings */
  .narrative h2::after{
    content:"";position:absolute;left:0;bottom:0;width:3.6rem;
    border-top:1px solid color-mix(in srgb,var(--accent) 60%,transparent);
    box-shadow:0 3px 0 -1px color-mix(in srgb,var(--accent) 30%,transparent);
  }
  /* SPECIMEN slug on the hero plate */
  .hero__art::after,
  .hero__art--scene .hero__art-slug{}
  .hero__art--scene::before{
    content:"FIELD SPECIMEN · NO. 01";
    position:absolute;bottom:.85rem;right:1rem;z-index:2;
    font-family:var(--font-accent);font-size:.6rem;letter-spacing:.32em;
    text-transform:uppercase;
    color:color-mix(in srgb,var(--accent) 72%,transparent);
    text-shadow:0 1px 2px #000;
  }
  /* a faint excavation grid corner-mark on the bundle chamber */
  .bundle__body::before{
    content:"FROM THE VAULT";
    display:block;font-family:var(--font-accent);font-size:.62rem;
    letter-spacing:.34em;text-transform:uppercase;
    color:color-mix(in srgb,var(--accent) 70%,transparent);
    margin-bottom:.6rem;
  }
}

/* ============================================================
   16 · MOTION — slow, deliberate, period-evocative (no bounce)
   A single GPU-only lamp-glow breathe on the bundle price and
   the hero plate edge. Disabled under reduced-motion.
   ============================================================ */
@media (min-width:760px) and (prefers-reduced-motion:no-preference){
  @keyframes bw-lamp{
    0%,100%{opacity:.85}
    50%{opacity:1}
  }
  .bundle__price{
    will-change:opacity;
    animation:bw-lamp 5.5s var(--ease) infinite;
  }
  /* slow cover settle on card hover (transform only) */
  .vol-card{transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
}

@media (prefers-reduced-motion:reduce){
  .bundle__price{animation:none}
  .btn--primary,.btn--primary:hover{transition:none}
  body::before{display:none}
}