/* ============================================================
   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:ada ---- */
/* ============================================================
   ADA MAE WHITFIELD — "The Pantry Method"
   A warm old kitchen at golden hour, written down on recipe cards.
   World: walnut wood + linen paper + a jug of vinegar and a box of
   baking soda lit like they matter. The site IS Ada's recipe box:
   ruled index-card paper, stitched-dashed edges, a pantry-gold
   filing tab, a sage check on every honest line, and a confiding
   hand-note in the margin. Calm, lived-in, trustworthy — NEVER
   flashy (this 45-75 cohort reads flash as a scam, not a grandmother).
   Layers on base.css. No external fonts/images. transform/opacity only.
   Fonts injected by build.py for this site: EB Garamond (display),
   Mulish (body/accent), Caveat (loaded — used for the hand-notes).
   ============================================================ */

/* ---- ATMOSPHERE: a warm hearth-walnut room, soft pantry-paper grain,
        a low golden-hour glow from the upper corners ---- */
body{
  background:
    radial-gradient(135% 70% at 6% -8%, color-mix(in srgb,var(--accent) 13%,transparent), transparent 56%),
    radial-gradient(110% 60% at 102% -4%, color-mix(in srgb,var(--accent-2) 9%,transparent), transparent 52%),
    radial-gradient(140% 90% at 50% 118%, color-mix(in srgb,var(--accent) 6%,transparent), transparent 60%),
    repeating-linear-gradient(0deg, transparent 0 3px, color-mix(in srgb,#000 4%,transparent) 3px 4px),
    linear-gradient(178deg, var(--page-bg), color-mix(in srgb,#000 9%,var(--page-bg)));
  background-attachment:fixed,fixed,fixed,scroll,fixed;
}

/* a faint hanging "shelf line" of pantry-gold that separates sections,
   like a kitchen-shelf edge catching the light */
.section{position:relative}
.band{position:relative;isolation:isolate}

/* channel name + headings — warm, intimate, a touch of editorial */
.eyebrow{color:var(--accent);font-weight:800}
.hero__title{letter-spacing:-.018em;text-shadow:0 1px 0 color-mix(in srgb,#000 22%,transparent)}
.brandmark{letter-spacing:.005em}
.brandmark .dot{
  background:radial-gradient(circle at 34% 30%, color-mix(in srgb,#fff 30%,var(--accent)), var(--accent));
  box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent), 0 0 10px -1px color-mix(in srgb,var(--accent) 60%,transparent);
}

/* ---- RIBBON: a strip of torn pantry-paper pinned across the top ---- */
.ribbon{
  background:
    repeating-linear-gradient(90deg, transparent 0 22px, color-mix(in srgb,#3a2a0c 6%,transparent) 22px 23px),
    linear-gradient(180deg, color-mix(in srgb,#fff 18%,var(--accent)), var(--accent));
  color:#3a2a0c;
  border-bottom:1px dashed color-mix(in srgb,#3a2a0c 42%,transparent);
  text-shadow:0 1px 0 color-mix(in srgb,#fff 30%,transparent);
}
.ribbon strong{font-weight:800}

/* ============================================================
   HERO — a framed editorial portrait of Ada in her kitchen,
   leaning on the counter like a recipe card propped against the wall.
   ============================================================ */
.hero__art{
  background:
    linear-gradient(180deg, color-mix(in srgb,var(--accent) 6%,var(--deep)), var(--deep));
  border:1px solid color-mix(in srgb,var(--border) 55%,transparent);
  box-shadow:
    var(--shadow-lg),
    inset 0 0 0 7px var(--panel),
    inset 0 0 0 8px color-mix(in srgb,var(--border) 55%,transparent),
    inset 0 0 90px -10px color-mix(in srgb,#000 50%,transparent);
}
/* warm vignette + brand edge-light so the portrait reads as a treasured photo */
.hero__art--face{position:relative}
.hero__art--face::after{
  content:"";position:absolute;inset:7px;z-index:1;pointer-events:none;border-radius:inherit;
  background:
    radial-gradient(120% 80% at 80% 8%, color-mix(in srgb,var(--accent) 24%,transparent), transparent 46%),
    radial-gradient(130% 120% at 50% 116%, color-mix(in srgb,#000 62%,transparent), transparent 58%),
    linear-gradient(98deg, transparent 60%, color-mix(in srgb,#000 30%,transparent));
  mix-blend-mode:multiply;opacity:.9;
}
.hero__art--face img{object-position:center 14%;filter:saturate(1.04) contrast(1.02)}

/* the name caption — a linen filing label clipped to the bottom of the frame */
.hero__cap{
  z-index:2;
  background:linear-gradient(0deg,
    color-mix(in srgb,#000 86%,transparent),
    color-mix(in srgb,#000 42%,transparent) 52%,
    transparent);
}
.hero__cap b{
  font-family:var(--font-body);font-weight:800;letter-spacing:.01em;
  font-size:1.22rem;color:#fff;
}
.hero__cap b::before{
  content:"";display:inline-block;width:.5rem;height:.5rem;margin-right:.5rem;border-radius:50%;
  background:var(--accent);box-shadow:0 0 8px color-mix(in srgb,var(--accent) 80%,transparent);
  vertical-align:middle;
}
.hero__cap span{color:color-mix(in srgb,#fff 82%,transparent)}

/* placeholder text (before the photo lands) */
.hero__art .ph{color:color-mix(in srgb,var(--on-deep) 60%,transparent);letter-spacing:.2em}

/* the confiding hand-note in the margin — "the way my mother did it."
   Caveat IS loaded for this site (build.py FONTS["ada"]), so this is a
   genuine handwritten pencil aside, per design.md's Caveat spec. */
.hero{position:relative}
@media (min-width:760px){
  .hero::after{
    content:"the way my mother did it.";
    position:absolute;right:clamp(1rem,5vw,4rem);bottom:.7rem;z-index:3;
    font-family:"Caveat",var(--font-body),cursive;font-weight:700;
    font-size:clamp(1.7rem,2.7vw,2.5rem);letter-spacing:.005em;
    color:color-mix(in srgb,var(--accent) 88%,#fff);
    transform:rotate(-5deg);opacity:.94;pointer-events:none;line-height:1;
    text-shadow:0 1px 7px color-mix(in srgb,#000 62%,transparent);
  }
}
.hero__trust{color:var(--ink-soft)}
.hero__trust::before{
  content:"";flex:0 0 auto;width:.55rem;height:.55rem;border-radius:50%;
  background:var(--accent-2);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-2) 22%,transparent);
}

/* ============================================================
   "MEET THE HOST" AUTHOR BAND — like sitting at Ada's kitchen table.
   Portrait framed warm; bio on a faint linen field; a real-feeling
   signature line at the bottom.
   ============================================================ */
.author{position:relative}
.author::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(80% 60% at 12% 0%, color-mix(in srgb,var(--accent) 10%,transparent), transparent 60%),
    radial-gradient(70% 60% at 100% 100%, color-mix(in srgb,var(--accent-2) 8%,transparent), transparent 60%);
}
.author__grid{position:relative;z-index:1}
.author__photo{
  position:relative;
  border:1px solid color-mix(in srgb,var(--border) 55%,transparent);
  box-shadow:var(--shadow-lg), inset 0 0 0 6px var(--panel), inset 0 0 0 7px color-mix(in srgb,var(--border) 45%,transparent);
}
.author__photo::after{
  content:"";position:absolute;inset:6px;border-radius:inherit;pointer-events:none;
  background:
    radial-gradient(110% 70% at 30% 4%, color-mix(in srgb,var(--accent) 16%,transparent), transparent 48%),
    radial-gradient(120% 100% at 50% 120%, color-mix(in srgb,#000 40%,transparent), transparent 60%);
  mix-blend-mode:multiply;opacity:.85;
}
.author__photo img{filter:saturate(1.03)}
.author__role{color:var(--ink);position:relative;display:inline-block}
.author__role::after{
  content:"";display:block;width:3.2rem;height:3px;margin-top:.55rem;border-radius:2px;
  background:linear-gradient(90deg,var(--accent),color-mix(in srgb,var(--accent) 0%,transparent));
}
.author__bio p strong{color:color-mix(in srgb,var(--accent) 92%,var(--ink));font-weight:700}

/* the signature — Ada's own hand at the bottom of the note, in Caveat */
.author__sign{
  border-top:1px dashed color-mix(in srgb,var(--accent) 40%,var(--hair));
  font-style:normal;color:var(--ink-soft);
}
.author__sign b,.author__sign strong{
  font-family:"Caveat",var(--font-body),cursive;font-style:normal;font-weight:700;
  font-size:clamp(2rem,3.4vw,2.8rem);letter-spacing:.01em;
  color:color-mix(in srgb,var(--accent) 82%,var(--ink));
  transform:rotate(-3deg);display:inline-block;line-height:1.05;
}

/* ============================================================
   NARRATIVE — the confiding letter. Stitched recipe-rule dividers
   between blocks; the punch-line strongs glow pantry-gold.
   ============================================================ */
.narrative .block{position:relative}
.narrative .block + .block{padding-top:clamp(2rem,4vw,3.2rem)}
.narrative .block + .block::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(240px,62%);height:0;
  border-top:2px dashed color-mix(in srgb,var(--on-deep) 34%,transparent);
}
/* a tiny pantry-gold lozenge centered on the stitch, like a button on a card */
.narrative .block + .block::after{
  content:"";position:absolute;top:-4px;left:50%;transform:translateX(-50%);
  width:9px;height:9px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 20%,transparent);
}
.narrative h2{letter-spacing:-.01em}
.narrative .block strong{
  color:var(--accent);font-weight:800;
  text-shadow:0 1px 0 color-mix(in srgb,#000 30%,transparent);
}

/* ============================================================
   VOLUME CARDS = recipe / index cards: linen paper, faint blue rules,
   a red margin line, a stitched edge, a pantry-gold filing tab.
   ============================================================ */
.vol-card{
  position:relative;overflow:visible;
  background:
    /* the red margin line down the left, like a real index card */
    linear-gradient(90deg, color-mix(in srgb,var(--danger) 34%,transparent) 0 2px, transparent 2px) 1.5rem 0/100% 100% no-repeat,
    /* faint blue ruled lines */
    repeating-linear-gradient(180deg, transparent 0 30px, color-mix(in srgb,var(--accent-2) 17%,transparent) 30px 31px),
    var(--panel);
  border:1.5px dashed color-mix(in srgb,var(--accent) 52%,var(--border));
  box-shadow:
    var(--shadow-sm),
    inset 0 0 0 4px var(--panel),
    inset 0 0 0 5px color-mix(in srgb,var(--border) 42%,transparent);
  border-radius:9px;
}
.vol-card:hover{
  box-shadow:
    var(--shadow),
    inset 0 0 0 4px var(--panel),
    inset 0 0 0 5px color-mix(in srgb,var(--accent) 34%,transparent);
}
/* the gold filing tab clipped to the top corner */
.vol-card::before{
  content:"";position:absolute;top:-1px;right:1.5rem;width:2.5rem;height:.58rem;z-index:2;
  background:linear-gradient(180deg,color-mix(in srgb,#fff 20%,var(--accent)),var(--accent));
  border-radius:0 0 5px 5px;
  box-shadow:0 2px 6px -1px color-mix(in srgb,var(--accent) 60%,transparent);
}
.vol-card--feature{
  outline:none;
  border-color:color-mix(in srgb,var(--accent) 70%,transparent);
  box-shadow:
    var(--shadow),
    inset 0 0 0 4px var(--panel),
    inset 0 0 0 5px color-mix(in srgb,var(--accent) 46%,transparent),
    0 0 0 5px color-mix(in srgb,var(--accent) 16%,transparent);
}
.vol-card--feature::before{
  width:3.6rem;
  background:linear-gradient(180deg,color-mix(in srgb,#fff 24%,var(--accent)),var(--accent));
}

/* the volume's book-cover thumbnail — framed premium, brand edge, inner shadow */
.vol-card__cover{
  position:relative;
  border:1px solid color-mix(in srgb,var(--border) 60%,transparent);
  box-shadow:var(--shadow-sm), inset 0 0 0 3px var(--panel);
  background:color-mix(in srgb,var(--panel-ink) 8%,var(--panel));
}
.vol-card__cover::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:
    linear-gradient(105deg, color-mix(in srgb,#fff 16%,transparent) 0 14%, transparent 36%),
    radial-gradient(120% 90% at 50% 116%, color-mix(in srgb,#000 30%,transparent), transparent 56%);
  box-shadow:inset 0 0 22px -6px color-mix(in srgb,#000 40%,transparent);
}

.vol-card__num{color:var(--danger);font-weight:800}
.vol-card__title{font-weight:800;color:var(--panel-ink);letter-spacing:-.005em}
.vol-card__sub{color:color-mix(in srgb,var(--panel-ink) 72%,var(--panel))}

/* the honest sage check on each line — the channel's "it worked / it's true" mark */
.vol-list li::before{
  content:"\2713";background:none;box-shadow:none;border-radius:0;
  width:auto;height:auto;left:.05rem;top:.04em;
  color:var(--accent-2);font-weight:900;font-size:1rem;
}

/* badges — the "Start Here / Most Popular / Vault Only" filing tabs */
.tag{
  background:var(--accent-2);color:var(--panel);font-weight:800;
  box-shadow:0 2px 7px -2px color-mix(in srgb,var(--accent-2) 70%,transparent);
}
.vol-card--feature .tag{
  background:linear-gradient(180deg,color-mix(in srgb,#fff 14%,var(--accent)),var(--accent));
  color:#3a2a0c;
}
.in-vault{color:var(--danger)}
.price{color:var(--panel-ink)}
.price small{color:color-mix(in srgb,var(--panel-ink) 66%,var(--panel))}

/* ============================================================
   BUNDLE = the recipe box itself: a warm walnut lid with a gold seam,
   the whole lifetime handed down at the kitchen table.
   ============================================================ */
.bundle{
  background:
    repeating-linear-gradient(180deg, transparent 0 36px, color-mix(in srgb,var(--accent) 6%,transparent) 36px 37px),
    linear-gradient(150deg, color-mix(in srgb,#000 10%,var(--deep)), color-mix(in srgb,var(--accent) 22%,var(--deep)));
  border:1.5px dashed color-mix(in srgb,var(--accent) 60%,transparent);
  box-shadow:var(--shadow-lg), inset 0 0 0 1px color-mix(in srgb,#000 18%,transparent);
}
/* a soft golden glow pooling around the buy column, drawing the eye to the price */
.bundle__buy{position:relative}
.bundle__buy::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(90% 70% at 50% 30%, color-mix(in srgb,var(--accent) 14%,transparent), transparent 62%);
}
.bundle__title{color:var(--on-deep);letter-spacing:-.01em}
.bundle__includes li::before{color:var(--accent-2);font-weight:900}
.bundle__price{
  text-shadow:0 2px 0 color-mix(in srgb,#000 35%,transparent), 0 0 24px color-mix(in srgb,var(--accent) 35%,transparent);
}
.bundle__save{
  background:var(--danger);border-radius:var(--r-sm);
  transform:rotate(-1.6deg);box-shadow:0 3px 8px -2px color-mix(in srgb,var(--danger) 60%,transparent);
}

/* ============================================================
   OFFER / COUNTDOWN — little kitchen-timer tickets
   ============================================================ */
.cd-unit{
  border:1px dashed color-mix(in srgb,var(--on-deep) 28%,transparent);
  border-radius:var(--r-sm);
  background:color-mix(in srgb,var(--on-deep) 7%,transparent);
}
.cd-unit b{color:var(--accent)}

/* ============================================================
   PROOF + GUARANTEE — a stitched recipe card with a stamped sage seal,
   and the reviews placeholder as a blank card waiting to be filled.
   ============================================================ */
.proof__grid p strong{color:var(--accent)}
.guarantee{
  background:
    repeating-linear-gradient(180deg, transparent 0 30px, color-mix(in srgb,var(--accent-2) 13%,transparent) 30px 31px),
    var(--panel);
  border:1.5px dashed color-mix(in srgb,var(--accent) 48%,var(--border));
  box-shadow:
    var(--shadow-sm),
    inset 0 0 0 4px var(--panel),
    inset 0 0 0 5px color-mix(in srgb,var(--border) 42%,transparent);
  border-radius:9px;
}
.guarantee h3{color:var(--panel-ink)}
.guarantee .seal{
  background:
    radial-gradient(circle at 34% 28%, color-mix(in srgb,#fff 18%,var(--accent-2)), var(--accent-2));
  box-shadow:
    0 0 0 3px var(--panel),
    0 0 0 4px color-mix(in srgb,var(--accent-2) 62%,transparent),
    0 0 0 8px color-mix(in srgb,var(--accent-2) 22%,transparent);
}
.reviews-empty{
  border:2px dashed color-mix(in srgb,var(--accent) 38%,var(--hair));
  background:repeating-linear-gradient(180deg, transparent 0 28px, color-mix(in srgb,var(--ink) 9%,transparent) 28px 29px);
  border-radius:9px;color:var(--ink-soft);
}

/* ============================================================
   FAQ — ruled-line entries, a pantry-gold plus that rotates to an X
   ============================================================ */
.faq__item{border-bottom:1px dashed color-mix(in srgb,var(--on-deep) 28%,transparent)}
.faq__q{color:var(--ink)}
.faq__q .chev{color:var(--accent)}

/* ============================================================
   BUTTONS — warm, settled, inviting. Never bouncy.
   The primary buy button is the warmest, brightest thing on the page.
   ============================================================ */
.btn{transition:transform .22s var(--ease),box-shadow .22s var(--ease),filter .22s}
.btn--primary{
  background:linear-gradient(180deg, color-mix(in srgb,#fff 16%,var(--accent)), var(--accent));
  color:#3a2a0c;
  box-shadow:var(--shadow), 0 0 0 1px color-mix(in srgb,#3a2a0c 12%,transparent) inset, 0 8px 22px -10px color-mix(in srgb,var(--accent) 75%,transparent);
}
.btn--primary:hover{
  filter:brightness(1.06);
  box-shadow:var(--shadow-lg), 0 12px 30px -10px color-mix(in srgb,var(--accent) 80%,transparent);
}
.btn--ghost{border-color:color-mix(in srgb,var(--accent) 40%,transparent)}
.btn--ghost:hover{background:color-mix(in srgb,var(--accent) 12%,transparent);border-color:var(--accent)}

/* ============================================================
   STICKY BUY BAR — a warm linen ledge that slides up from the counter.
   On-brand, instantly readable, irresistible-to-tap; never fights the page.
   ============================================================ */
.sticky-cta{
  background:
    linear-gradient(180deg, color-mix(in srgb,var(--accent) 10%,var(--deep)), color-mix(in srgb,var(--deep) 96%,transparent));
  border-top:1px solid color-mix(in srgb,var(--accent) 42%,transparent);
  box-shadow:0 -14px 36px -16px rgba(0,0,0,.6), 0 -1px 0 color-mix(in srgb,var(--accent) 30%,transparent) inset;
}
.sticky-cta__txt b{color:var(--on-deep);letter-spacing:.005em}
.sticky-cta__txt b::before{
  content:"";display:inline-block;width:.45rem;height:.45rem;margin-right:.5rem;border-radius:50%;
  background:var(--accent);box-shadow:0 0 7px color-mix(in srgb,var(--accent) 75%,transparent);
  vertical-align:middle;
}
.sticky-cta__price{color:color-mix(in srgb,var(--on-deep) 82%,transparent)}
.sticky-cta__price s{opacity:.5}

/* ============================================================
   FOOTER — a kitchen-shelf edge; the disclaimer kept clearly legible.
   ============================================================ */
.footer{
  border-top:2px dashed color-mix(in srgb,var(--accent) 32%,transparent);
  background:
    radial-gradient(80% 100% at 50% 0%, color-mix(in srgb,var(--accent) 7%,transparent), transparent 60%),
    var(--deep);
}
.footer h4{color:color-mix(in srgb,var(--accent) 60%,var(--on-deep))}
.disclaimer-box{
  border-left:3px solid var(--danger);
  background:color-mix(in srgb,#000 20%,var(--deep));
  border-radius:var(--r-sm);
}

/* legal docs */
.doc h2{color:var(--accent)}

/* ============================================================
   MOTION DISCIPLINE — a gentle settle, never a bounce.
   GPU-only (opacity/transform). Honors reduced-motion.
   ============================================================ */
@media (min-width:760px){
  .vol-card{transition:transform .22s var(--ease),box-shadow .22s var(--ease)}
}

@media (prefers-reduced-motion:reduce){
  .btn,.vol-card,.sticky-cta{transition:none}
  .hero::after{transform:rotate(-5deg)}
  .author__sign b,.author__sign strong{transform:none}
}