/* ============================================================
   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:64ch;
  --r-sm:6px; --r:12px; --r-lg:20px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(0,0,0,.08),0 3px 8px rgba(0,0,0,.07);
  --shadow:0 14px 36px -16px rgba(0,0,0,.4);
  --shadow-lg:0 36px 80px -24px rgba(0,0,0,.5);
  --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.2rem,1.5vw,1.55rem)}
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}
@media (max-width:760px){
  .nav__links{position:absolute;inset:100% 0 auto 0;flex-direction:column;background:var(--page-bg);
    border-bottom:1px solid var(--hair);padding:1rem 1.4rem;gap:1rem;display:none}
  .nav__links.open{display:flex}
  .nav__toggle{display:block}
}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items: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.7rem;
  font-size:1.02rem;text-decoration:none;transition:transform .18s var(--ease),box-shadow .18s var(--ease),filter .18s}
.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 2.2rem;font-size:1.1rem}
.btn[aria-disabled="true"]{opacity:.5;pointer-events:none;filter:grayscale(.4)}

/* ============ 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;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}
.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}

/* ============ 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{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:1.1rem;border-top:1px solid var(--hair-soft)}
.price{font-family:var(--font-display);font-weight:800;font-size:1.7rem;color:var(--panel-ink)}
.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__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}
.bundle__price{font-family:var(--font-display);font-weight:800;font-size:clamp(2.6rem,5vw,3.6rem);color:var(--accent);line-height:1}
.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}
.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{width:68px;height:68px;border-radius:50%;display:grid;place-items:center;background:var(--accent-2);
  color:#fff;font-family:var(--font-accent);font-weight:800;font-size:.72rem;text-align:center;letter-spacing:.08em;line-height:1.1}
.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}

/* ============ 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:center 18%}
.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;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:center top}
.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 1rem;aspect-ratio:3/4;border-radius:var(--r);overflow:hidden;background:color-mix(in srgb,var(--panel-ink) 8%,var(--panel));box-shadow:var(--shadow-sm)}
.vol-card__cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.vol-card:hover .vol-card__cover img{transform:scale(1.04)}
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:60;transform:translateY(115%);transition:transform .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}
.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}.vol-card:hover .vol-card__cover img{transform:none}}


/* ---- skin:enoch ---- */
/* ============================================================
   ENOCH ROBINSON — "The Dossier" (v2 · face-of-channel)
   A confidential escape dossier: navy security-paper, fine GOLD
   editorial hairlines, stamped marks, boarding-pass + ledger +
   passport motifs, a notary seal, a measured author portrait.
   Sober, expensive, Cronkite-register. Never flashy / TikTok.
   Layers on base.css — decorates only, never restructures.
   ============================================================ */

/* --- security-paper atmosphere: guilloché + gold corner washes --- */
body{
  background-color:var(--page-bg);
  background-image:
    radial-gradient(120% 80% at 50% -8%, color-mix(in srgb,var(--accent) 9%,transparent), transparent 60%),
    radial-gradient(90% 60% at 100% 100%, color-mix(in srgb,var(--accent-2) 14%,transparent), transparent 55%),
    repeating-linear-gradient(58deg, color-mix(in srgb,var(--ink) 3.5%,transparent) 0 1px, transparent 1px 9px),
    repeating-linear-gradient(-58deg, color-mix(in srgb,var(--ink) 2.5%,transparent) 0 1px, transparent 1px 11px),
    linear-gradient(180deg, color-mix(in srgb,#000 8%,var(--page-bg)), var(--page-bg) 40%);
  background-attachment:fixed;
}
/* a faint engraved "secure document" microguilloché, desktop only */
@media (min-width:760px){
  body::before{
    content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;
    background-image:
      repeating-radial-gradient(circle at 18% 30%, transparent 0 18px, color-mix(in srgb,var(--accent) 4%,transparent) 18px 19px, transparent 19px 38px),
      repeating-radial-gradient(circle at 86% 74%, transparent 0 22px, color-mix(in srgb,var(--accent-2) 4%,transparent) 22px 23px, transparent 23px 46px);
    mask-image:linear-gradient(180deg,transparent,#000 12%,#000 88%,transparent);
  }
}
.nav,.ribbon,main,.footer,.sticky-cta{position:relative;z-index:1}

/* --- ribbon: a printed entry-stamp banner with engraved gold rule --- */
.ribbon{
  background:
    repeating-linear-gradient(90deg, transparent 0 22px, color-mix(in srgb,#1b1407 14%,transparent) 22px 23px),
    var(--accent);
  border-bottom:1px solid color-mix(in srgb,#1b1407 30%,transparent);
  box-shadow:inset 0 -1px 0 color-mix(in srgb,#fff 18%,transparent);
  text-transform:uppercase;letter-spacing:.16em;font-size:.8rem;
}

/* --- nav: thin double gold rule, like a classified document header --- */
.nav{
  border-bottom:1px solid color-mix(in srgb,var(--accent) 30%,transparent);
  box-shadow:0 1px 0 color-mix(in srgb,var(--accent) 14%,transparent);
}
.brandmark{text-shadow:0 1px 0 color-mix(in srgb,#000 30%,transparent)}
.brandmark .dot{
  border-radius:0;width:.7rem;height:.7rem;transform:rotate(45deg);
  background:linear-gradient(135deg,color-mix(in srgb,#fff 22%,var(--accent)),var(--accent));
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 26%,transparent);
}

/* --- the SIGNATURE mark: stamped eyebrow (passport entry stamp) --- */
.eyebrow{
  display:inline-block;position:relative;
  border:1.5px solid color-mix(in srgb,var(--accent) 70%,transparent);
  padding:.42em .9em;border-radius:3px;
  color:var(--accent);letter-spacing:.26em;
  transform:rotate(-1.4deg);
  background:color-mix(in srgb,var(--accent) 7%,transparent);
}
.eyebrow::after{
  content:"";position:absolute;inset:3px;border-radius:2px;
  border:1px dashed color-mix(in srgb,var(--accent) 38%,transparent);
  pointer-events:none;
}
.center .eyebrow{transform:rotate(-1deg)}

/* --- section bands: faint gold editorial hairline framing --- */
.section{position:relative}
.band{
  background-image:
    radial-gradient(140% 90% at 50% 0%, color-mix(in srgb,var(--accent) 11%,transparent), transparent 62%),
    linear-gradient(180deg, color-mix(in srgb,#000 14%,var(--deep)), var(--deep));
  border-top:1px solid color-mix(in srgb,var(--accent) 26%,transparent);
  border-bottom:1px solid color-mix(in srgb,var(--accent) 12%,transparent);
}

/* ============================================================
   HERO — document spotlight + premium author portrait
   ============================================================ */
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(70% 55% at 22% 30%, color-mix(in srgb,var(--accent) 12%,transparent), transparent 60%),
    radial-gradient(60% 50% at 92% 80%, color-mix(in srgb,var(--accent-2) 16%,transparent), transparent 60%);
}
.hero__grid{position:relative;z-index:1}
.hero__title{letter-spacing:-.018em;text-shadow:0 2px 0 color-mix(in srgb,#000 24%,transparent)}
.hero__title::after{
  content:"";display:block;width:88px;height:2px;margin-top:.5rem;
  background:linear-gradient(90deg,var(--accent),transparent);
}
.hero__trust{font-style:italic}

/* PORTRAIT — frame Enoch as a premium editorial author portrait:
   navy/gold vignette, fine gold inner rule, registration ticks. */
.hero__art--face{
  border:1px solid color-mix(in srgb,var(--accent) 38%,transparent);
  box-shadow:
    var(--shadow-lg),
    inset 0 0 0 1px color-mix(in srgb,var(--accent) 14%,transparent),
    inset 0 0 90px color-mix(in srgb,#000 42%,transparent);
}
.hero__art--face img{
  filter:saturate(.94) contrast(1.03);
  transition:transform .8s var(--ease),filter .8s var(--ease);
}
.hero__art--face:hover img{transform:scale(1.025);filter:saturate(1) contrast(1.05)}
/* navy vignette + a single edge-light gradient that reads as window light */
.hero__art--face::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  background:
    linear-gradient(105deg, color-mix(in srgb,var(--accent) 12%,transparent), transparent 38%),
    radial-gradient(120% 100% at 50% 6%, transparent 52%, color-mix(in srgb,var(--page-bg) 78%,transparent) 100%);
}
/* corner registration tick (top-left) — the "filed & verified" cue */
.hero__art--face::after{
  content:"";position:absolute;top:14px;left:14px;width:20px;height:20px;z-index:2;
  border-top:1.5px solid color-mix(in srgb,var(--accent) 66%,transparent);
  border-left:1.5px solid color-mix(in srgb,var(--accent) 66%,transparent);
}
/* refined stamped caption — name in display, role as a filed sub-line */
.hero__cap{
  background:linear-gradient(0deg,
    color-mix(in srgb,#000 86%,transparent),
    color-mix(in srgb,#000 42%,transparent) 52%, transparent);
  border-top:1px solid color-mix(in srgb,var(--accent) 30%,transparent);
}
.hero__cap b{
  font-family:var(--font-display);letter-spacing:.012em;
  text-shadow:0 1px 2px rgba(0,0,0,.6);
}
.hero__cap b::before{
  content:"";display:inline-block;width:.55rem;height:.55rem;margin-right:.5rem;
  transform:translateY(-1px) rotate(45deg);
  background:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 30%,transparent);
}
.hero__cap span{text-transform:none;letter-spacing:.01em;
  color:color-mix(in srgb,#fff 74%,var(--accent))}

/* scene hero (faceless fallback) keeps the boarding-pass treatment */
.hero__art--scene{
  border:1px solid color-mix(in srgb,var(--accent) 34%,transparent);
  box-shadow:var(--shadow-lg), inset 0 0 0 1px color-mix(in srgb,var(--accent) 10%,transparent);
}
.hero__art--scene::after{
  content:"";position:absolute;top:14px;left:14px;width:18px;height:18px;
  border-top:1.5px solid color-mix(in srgb,var(--accent) 60%,transparent);
  border-left:1.5px solid color-mix(in srgb,var(--accent) 60%,transparent);
}
.hero__art--scene .ph{letter-spacing:.2em;color:color-mix(in srgb,var(--on-deep) 62%,transparent)}

/* --- buttons: engraved, restrained lift (no flashy bounce) --- */
.btn--primary{
  background:linear-gradient(180deg, color-mix(in srgb,#fff 16%,var(--accent)), var(--accent));
  box-shadow:var(--shadow), inset 0 1px 0 color-mix(in srgb,#fff 32%,transparent);
}
.btn--ghost{border-color:color-mix(in srgb,var(--accent) 46%,transparent)}

/* ============================================================
   AUTHOR — the "Meet Enoch" trust band
   ============================================================ */
.author{position:relative}
.author::before{ /* top gold filing rule across the band */
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--accent) 50%,transparent),transparent);
}
/* author portrait — same dossier frame as the hero, quieter */
.author__photo{
  border:1px solid color-mix(in srgb,var(--accent) 34%,transparent);
  box-shadow:var(--shadow-lg), inset 0 0 0 1px color-mix(in srgb,var(--accent) 12%,transparent);
}
.author__photo img{filter:saturate(.94) contrast(1.02)}
.author__photo::after{ /* registration tick echoes the hero */
  content:"";position:absolute;right:14px;bottom:14px;width:18px;height:18px;
  border-right:1.5px solid color-mix(in srgb,var(--accent) 58%,transparent);
  border-bottom:1.5px solid color-mix(in srgb,var(--accent) 58%,transparent);
  pointer-events:none;
}
.author__photo{position:relative}
.author__role{position:relative;padding-bottom:.4rem}
.author__role::after{
  content:"";position:absolute;left:0;bottom:0;width:60px;height:2px;
  background:color-mix(in srgb,var(--accent) 70%,transparent);
}
/* the disclosure paragraph (I am not your attorney…) reads as a stamped note */
.author__bio p strong{color:var(--accent)}
/* SIGNATURE — the author sign reads like a real fountain-pen signature */
.author__sign{
  font-family:var(--font-accent);
  border-top:1px solid color-mix(in srgb,var(--accent) 34%,transparent);
}
.author__sign::before{
  content:"Signed,";display:block;font-style:normal;font-size:.66rem;
  letter-spacing:.24em;text-transform:uppercase;
  color:color-mix(in srgb,var(--ink) 55%,var(--page-bg));margin-bottom:.25rem;
}
.author__sign{
  font-size:1.5rem;font-style:italic;
  color:color-mix(in srgb,var(--accent) 78%,var(--ink));
  text-shadow:0 1px 0 color-mix(in srgb,#000 22%,transparent);
}

/* ============================================================
   PRICING — ledger paper with gold filing-tab spines + covers
   ============================================================ */
.vol-card{
  position:relative;overflow:hidden;
  background:
    linear-gradient(90deg, color-mix(in srgb,var(--accent) 7%,var(--panel)) 0 4px, transparent 4px),
    repeating-linear-gradient(0deg, transparent 0 31px, color-mix(in srgb,var(--panel-ink) 4%,transparent) 31px 32px),
    var(--panel);
  border-color:var(--hair);
}
.vol-card::before{ /* filing-tab notch top-left */
  content:"";position:absolute;top:0;left:1.5rem;width:46px;height:5px;
  background:var(--accent);border-radius:0 0 2px 2px;z-index:2;
}
.vol-card--feature{
  outline-color:var(--accent);
  box-shadow:var(--shadow), 0 0 0 4px color-mix(in srgb,var(--accent) 12%,transparent);
}
.vol-card__num{letter-spacing:.22em}
.vol-card__title{font-family:var(--font-display);letter-spacing:-.01em}
.vol-list li::before{
  border-radius:0;transform:rotate(45deg);width:.5rem;height:.5rem;
  box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 24%,transparent);
}
/* book-cover thumbnail — framed like a filed plate with a gold edge */
.vol-card__cover{
  border:1px solid color-mix(in srgb,var(--panel-ink) 16%,var(--panel));
  box-shadow:
    var(--shadow-sm),
    inset 0 0 0 1px color-mix(in srgb,var(--accent) 22%,transparent);
}
.vol-card__cover::after{ /* soft top sheen, never gaudy */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(160deg, color-mix(in srgb,#fff 14%,transparent), transparent 42%);
}
.vol-card__cover{position:relative}
.price{text-shadow:0 1px 0 color-mix(in srgb,var(--panel) 70%,transparent)}

/* ============================================================
   BUNDLE — navy dossier folder, gold seam (the buy path stays loud)
   ============================================================ */
.bundle{
  background:
    radial-gradient(110% 80% at 0% 0%, color-mix(in srgb,var(--accent) 14%,var(--deep)), transparent 55%),
    linear-gradient(150deg, var(--deep), color-mix(in srgb,var(--accent-2) 20%,var(--deep)));
  border-color:color-mix(in srgb,var(--accent) 50%,transparent);
}
.bundle::before{ /* dossier-folder tab on the left body edge */
  content:"";position:absolute;top:0;left:clamp(1.8rem,3vw,2.8rem);width:120px;height:6px;
  background:linear-gradient(90deg,var(--accent),color-mix(in srgb,var(--accent) 40%,transparent));
  border-radius:0 0 3px 3px;z-index:2;
}
.bundle::after{ /* top gold seam */
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
}
.bundle__title{font-family:var(--font-display)}
.bundle__price{text-shadow:0 1px 0 color-mix(in srgb,#000 30%,transparent)}
.bundle__save{
  background:var(--danger);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--danger) 22%,transparent);
}
.bundle__includes li::before{text-shadow:0 0 8px color-mix(in srgb,var(--accent) 50%,transparent)}

/* ============================================================
   NARRATIVE — printed editorial columns
   ============================================================ */
.narrative h2{position:relative;padding-bottom:.35rem}
.narrative h2::after{
  content:"";position:absolute;left:0;bottom:0;width:56px;height:2px;
  background:color-mix(in srgb,var(--accent) 70%,transparent);
}
.narrative .block em{color:color-mix(in srgb,var(--accent) 86%,var(--ink));font-style:italic}

/* ============================================================
   GUARANTEE — embossed notary medallion + filed proof
   ============================================================ */
.guarantee{border-top:3px solid color-mix(in srgb,var(--accent) 55%,transparent)}
.guarantee .seal{
  background:
    repeating-conic-gradient(from 0deg, color-mix(in srgb,#fff 14%,var(--accent-2)) 0 12deg, var(--accent-2) 12deg 24deg);
  box-shadow:
    inset 0 0 0 3px color-mix(in srgb,#fff 24%,transparent),
    0 0 0 4px color-mix(in srgb,var(--accent) 24%,transparent),
    var(--shadow-sm);
}
/* reviews-empty: a candid classified manila placeholder */
.reviews-empty{
  border-style:solid;border-color:color-mix(in srgb,var(--accent) 30%,transparent);
  background:
    repeating-linear-gradient(45deg, transparent 0 13px, color-mix(in srgb,var(--accent) 5%,transparent) 13px 14px);
}

/* ============================================================
   FAQ — ledger rows
   ============================================================ */
.faq__item{border-bottom-color:color-mix(in srgb,var(--accent) 22%,transparent)}
.faq__q{transition:color .2s var(--ease)}
.faq__q:hover{color:var(--accent)}
.faq__q .chev{font-weight:400}

/* ============================================================
   STICKY CTA — on-brand persistent buy bar (instantly readable)
   ============================================================ */
.sticky-cta{
  background:color-mix(in srgb,var(--deep) 95%,transparent);
  border-top:1px solid color-mix(in srgb,var(--accent) 42%,transparent);
  box-shadow:0 -14px 36px -14px rgba(0,0,0,.6);
}
.sticky-cta::before{ /* a fine gold seam, like the dossier folder edge */
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--accent) 60%,transparent),transparent);
}
.sticky-cta__txt b{color:var(--on-deep)}
.sticky-cta__price{font-style:italic}

/* ============================================================
   FOOTER — signed-document baseline
   ============================================================ */
.footer{
  border-top:2px solid color-mix(in srgb,var(--accent) 28%,transparent);
  background:
    radial-gradient(100% 70% at 50% 0%, color-mix(in srgb,var(--accent) 8%,transparent), transparent 60%),
    var(--deep);
}
.disclaimer-box{border-left:2px solid color-mix(in srgb,var(--accent) 34%,transparent)}
.doc h2{position:relative}

/* ============================================================
   RESPONSIVE — heavy flourishes desktop-only; nothing overflows
   ============================================================ */
@media (max-width:760px){
  .eyebrow,.center .eyebrow{transform:none}
  .author__sign{font-size:1.3rem}
}

/* ============================================================
   MOTION — GPU transform/opacity only; full reduced-motion honor
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  .btn--primary:hover,.btn--ghost:hover,
  .vol-card:hover,.vol-card:hover .vol-card__cover img,
  .hero__art--face:hover img{transform:none}
  .hero__art--face img,.hero__art--face:hover img{transition:none}
}
