/* ============================================================
   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;
  --accent-ink:#1b1407; /* injected per-site: AA+ text color ON the accent fill (dark or white) */
  --accent-strong:var(--accent); /* injected per-site: accent fill for text-bearing chips (==accent unless a mid-tone needed a minimal darken for AA) */
  --font-display:Georgia,serif; --font-body:system-ui,sans-serif; --font-accent:var(--font-display);

  /* derived (auto-adapt to light/dark). Soft tones tuned toward WCAG AAA (7:1) for
     the 50+ eye: secondary copy stays comfortably readable on every skin. */
  --ink-soft:color-mix(in srgb,var(--ink) 82%,var(--page-bg));
  --panel-ink-soft:color-mix(in srgb,var(--panel-ink) 84%,var(--panel));
  /* small accent LABELS (eyebrows, deal tags): anchored to the local text color so they
     auto-stay AA+ on light pages, dark bands, and every brand accent (fixes faint gold/red labels). */
  --accent-label:color-mix(in srgb,var(--accent) 55%,currentColor);
  --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.08rem,.4vw + .98rem,1.2rem);line-height:1.65;letter-spacing:0;
  -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:0;text-wrap:balance}
h1{font-size:clamp(2.15rem,4.5vw,4rem)}
h2{font-size:clamp(1.8rem,3vw,2.65rem)}
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(2.8rem,5.8vw,5.4rem)}
.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:.84rem;
  font-weight:700;color:var(--accent-label);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-strong);color:var(--accent-ink);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);min-height:44px}
.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);display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px}
.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:break-word;word-break:normal;hyphens:none;
  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-strong);color:var(--accent-ink);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(2.4rem,5.8vw,4.8rem)}
.hero__grid{display:grid;grid-template-columns:1.12fr .78fr;gap:clamp(1.6rem,3.5vw,3.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.02rem,1vw,1.18rem);line-height:1.58;color:var(--ink-soft);max-width:50ch}
.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__deal{margin-top:1.1rem;max-width:42rem;display:grid;grid-template-columns:auto 1fr;gap:.75rem 1rem;
  align-items:center;padding:.9rem 1rem;border-radius:var(--r);background:color-mix(in srgb,var(--panel) 9%,transparent);
  border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);
  box-shadow:0 12px 28px -22px rgba(0,0,0,.55),inset 0 1px 0 color-mix(in srgb,#fff 10%,transparent)}
.hero__deal-main{display:flex;align-items:baseline;flex-wrap:wrap;gap:.35rem .55rem;min-width:0}
.hero__deal-main span{font-family:var(--font-accent);font-size:.77rem;font-weight:800;letter-spacing:.11em;text-transform:uppercase;color:var(--accent-label)}
.hero__deal-main strong{font-family:var(--font-display);font-size:clamp(1.45rem,2vw,2rem);line-height:1;color:var(--ink)}
.hero__deal-main s{font-family:var(--font-display);font-weight:700;color:color-mix(in srgb,var(--ink-soft) 70%,transparent)}
.hero__deal-save{justify-self:end;align-self:center;background:var(--danger);color:#fff;border-radius:var(--r-pill);
  padding:.32rem .66rem;font-family:var(--font-accent);font-size:.72rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  box-shadow:0 8px 18px -10px color-mix(in srgb,var(--danger) 80%,transparent)}
.hero__deal-list{grid-column:1/-1;display:flex;flex-wrap:wrap;gap:.45rem .8rem;margin:0;padding:0;list-style:none;
  font-size:.82rem;color:var(--ink-soft)}
.hero__deal-list li{display:flex;align-items:center;gap:.36rem}
.hero__deal-list li::before{content:"";width:.42rem;height:.42rem;border-radius:50%;background:var(--accent);flex:none}
.hero-buy{margin-top:1.25rem;max-width:46rem;display:grid;grid-template-columns:minmax(172px,220px) 1fr;gap:1rem;
  align-items:center;padding:1rem;border-radius:var(--r-lg);
  background:linear-gradient(135deg,color-mix(in srgb,var(--panel) 15%,transparent),color-mix(in srgb,var(--deep) 45%,transparent));
  border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);
  box-shadow:0 22px 54px -34px rgba(0,0,0,.72),inset 0 1px 0 color-mix(in srgb,#fff 12%,transparent)}
/* no-cover state (sites before cover images are added): body fills the full width
   instead of being crammed into the empty covers column. Sites WITH covers are unaffected. */
.hero-buy:not(:has(.hero-buy__covers)){grid-template-columns:1fr}
.hero-buy__covers{display:flex;align-items:center;justify-content:center;min-height:196px;padding:.35rem .2rem;
  border-radius:calc(var(--r-lg) - 4px);background:color-mix(in srgb,#000 22%,transparent);overflow:hidden}
.hero-buy__covers img{width:clamp(106px,10vw,138px);aspect-ratio:3/4;object-fit:cover;object-position:var(--focal-cover,50% 14%);
  border-radius:5px;border:1px solid color-mix(in srgb,var(--accent) 34%,transparent);
  box-shadow:0 18px 26px -18px rgba(0,0,0,.82),-7px 0 12px -10px rgba(0,0,0,.85);background:var(--deep)}
.hero-buy__covers img+img{margin-left:-52px}
.hero-buy__covers img:nth-child(1){transform:rotate(-7deg) translateY(5px)}
.hero-buy__covers img:nth-child(2){transform:translateY(-2px);z-index:2}
.hero-buy__covers img:nth-child(3){transform:rotate(7deg) translateY(5px)}
.hero-buy__body{min-width:0;display:flex;flex-direction:column;justify-content:center}
.hero-buy__eyebrow{font-family:var(--font-accent);font-size:.84rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-label)}
.hero-buy__title{margin:.18rem 0 .45rem;font-size:clamp(1.28rem,2.1vw,1.7rem);line-height:1.08;color:var(--ink)}
.hero-buy__price{display:flex;align-items:baseline;flex-wrap:wrap;gap:.35rem .55rem;margin-bottom:.75rem}
.hero-buy__price span{font-family:var(--font-display);font-weight:800;font-size:clamp(2.05rem,4.4vw,3rem);line-height:1;color:var(--accent);font-variant-numeric:tabular-nums}
.hero-buy__price s{font-family:var(--font-display);font-weight:700;color:color-mix(in srgb,var(--ink-soft) 72%,transparent);font-size:1.05rem}
.hero-buy__price b{font-family:var(--font-accent);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;background:var(--danger);color:#fff;
  border-radius:var(--r-pill);padding:.28rem .56rem;white-space:nowrap}
.hero-buy__actions{display:grid;grid-template-columns:1.2fr .8fr;gap:.7rem;margin-bottom:.78rem}
.hero-buy__actions .btn{min-height:50px;justify-content:center}
.hero-buy__bits{display:flex;flex-wrap:wrap;gap:.4rem .65rem;list-style:none;margin:0;padding:0;font-size:.82rem;color:var(--ink-soft)}
.hero-buy__bits li{display:flex;align-items:center;gap:.32rem}
.hero-buy__bits li::before{content:"";width:.38rem;height:.38rem;border-radius:50%;background:var(--accent);flex:none}
.hero-buy__micro{margin:.65rem 0 0;font-size:.83rem;line-height:1.35;color:var(--ink-soft)}
.hero__art{position:relative;aspect-ratio:4/5;min-height:240px;max-height:min(66vh,620px);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:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--danger);font-weight:800}
.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:.75rem;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;background:var(--accent-strong);color:var(--accent-ink);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__covers{display:flex;justify-content:center;align-items:flex-end;min-height:132px;margin:-.2rem 0 .65rem;
  filter:drop-shadow(0 18px 20px rgba(0,0,0,.36))}
.bundle__covers img{width:clamp(76px,7vw,108px);aspect-ratio:2/3;object-fit:cover;border-radius:5px;
  border:2px solid color-mix(in srgb,var(--accent) 42%,transparent);
  box-shadow:0 16px 28px -18px rgba(0,0,0,.8),inset 0 0 0 1px color-mix(in srgb,#fff 18%,transparent);
  transform:rotate(-6deg);background:var(--panel)}
.bundle__covers img+img{margin-left:-24px}
.bundle__covers img:nth-child(2){transform:translateY(-8px) rotate(0deg);z-index:2}
.bundle__covers img:nth-child(3){transform:rotate(6deg)}
.bundle__compare{color:color-mix(in srgb,var(--on-deep) 72%,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 ============ */
/* calm, dated founding-deadline line (replaces the ticking countdown — 50+ react
   against pressure timers; the real deadline stays, the pressure visual goes). */
.offer__hold{margin:1.15rem auto 0;max-width:54ch;font-size:1.04rem;line-height:1.55;color:var(--ink-soft)}
.offer__hold b{color:var(--ink);font-weight:700}
.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:.78rem;text-transform:uppercase;letter-spacing:.1em;opacity:.85}

/* ============ 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:.72rem;letter-spacing:.18em;opacity:.95;margin-top:.1rem}
.seal__g{font-size:.68rem;letter-spacing:.1em;font-weight:800;opacity: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:color-mix(in srgb,var(--ink) 78%,var(--page-bg));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:.78rem;font-weight:800;letter-spacing:.08em;
  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}
/* The FAQ renders inside a .band (dark --deep bg). On the one light-page skin (Earl)
   --ink / --ink-soft resolve DARK, so the question/answer text would be dark-on-dark
   (invisible). <summary> text is skipped by Lighthouse's contrast audit, so this is
   caught here: inside a band, use the band's light foreground. No-op on dark-page skins. */
.band .faq__q{color:var(--on-deep)}
.band .faq__a{color:color-mix(in srgb,var(--on-deep) 82%,transparent)}
.band .faq__item{border-bottom-color:color-mix(in srgb,var(--on-deep) 16%,transparent)}

/* ============ FINAL CTA ============ */
.final-cta{background:
  radial-gradient(90% 80% at 50% 0%, color-mix(in srgb,var(--accent) 13%,transparent), transparent 60%),
  linear-gradient(180deg, color-mix(in srgb,var(--deep) 86%,var(--page-bg)), var(--deep));
  color:var(--on-deep);border-top:1px solid color-mix(in srgb,var(--accent) 26%,transparent)}
.final-cta .lede{color:color-mix(in srgb,var(--on-deep) 82%,transparent);margin-inline:auto}
.final-cta__box{max-width:860px}
.final-cta__actions{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap;margin-top:1.5rem}
.final-cta .btn--ghost{color:var(--on-deep);border-color:color-mix(in srgb,var(--on-deep) 34%,transparent)}
.final-cta .btn--ghost:hover{color:var(--accent);border-color:var(--accent)}

/* ============ 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:flex;align-items:center;min-height:44px;margin:0}
.footer a:hover{color:var(--accent)}
.footer .legal{font-size:.86rem;color:color-mix(in srgb,var(--on-deep) 74%,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:.86rem;line-height:1.65;color:color-mix(in srgb,var(--on-deep) 78%,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:.74;margin-left:.45rem}
@media (max-width:560px){
  .sticky-cta__in{
    display:grid;
    grid-template-columns:1fr;
    gap:.55rem;
    padding-block:.65rem .75rem;
  }
  .sticky-cta__txt{
    align-items:center;
    text-align:center;
  }
  .sticky-cta__txt b{display:none}
  .sticky-cta__price{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    gap:.18rem .45rem;
    line-height:1.25;
  }
  .sticky-cta__price s{margin-left:0}
  .sticky-cta .btn{
    width:100%;
    justify-content:center;
    min-height:48px;
    white-space:normal;
  }
}
@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:.85;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:.82rem;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:.14em;font-size:.79rem}}

/* ============ 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:.7rem}
  .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:var(--accent-ink)}
.nav__links a.btn--prelaunch{color:var(--panel-ink)}
.nav__links a.btn:hover{color:var(--accent-ink)}
.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}
  .hero__deal{grid-template-columns:1fr}
  .hero__deal-save{justify-self:start}
  .hero-buy{grid-template-columns:1fr;gap:.85rem}
  .hero-buy__covers{min-height:158px}
  .hero-buy__actions{grid-template-columns:1fr}
  .bundle__covers{min-height:112px}
}
@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%}
  .hero__art--face,.hero__art--scene{max-height:420px}
  .hero{padding-block:1.15rem 2.1rem}
  .hero__grid{gap:1.1rem}
  .hero__title{font-size:clamp(2.05rem,9vw,2.55rem);line-height:.96;margin:.08em 0 .24em}
  .hero__sub{font-size:.98rem;line-height:1.45;margin-top:.85rem}
  .hero-buy{grid-template-columns:92px 1fr;gap:.62rem;margin-top:.65rem;padding:.72rem;border-radius:var(--r)}
  .hero-buy__covers{min-height:104px;padding:.18rem .06rem;align-self:center}
  .hero-buy__covers img{width:62px;border-radius:4px}
  .hero-buy__covers img+img{margin-left:-41px}
  .hero-buy__title{font-size:1.02rem;line-height:1.05;margin:.1rem 0 .28rem}
  .hero-buy__eyebrow{font-size:.72rem;letter-spacing:.1em}
  .hero-buy__price{gap:.2rem .38rem;margin-bottom:.42rem}
  .hero-buy__price span{font-size:1.62rem}
  .hero-buy__price s{font-size:.82rem}
  .hero-buy__price b{font-size:.7rem;padding:.22rem .46rem}
  .hero-buy__actions{grid-template-columns:1fr;gap:.42rem;margin-bottom:.38rem}
  .hero-buy__actions .btn{min-height:48px;padding:.8rem .84rem;font-size:.97rem}
  .hero-buy__actions .btn--ghost{display:none}
  .hero-buy__bits{font-size:.78rem;gap:.2rem .5rem;line-height:1.3}
  .hero-buy__bits li:nth-child(n+3){display:none}
  .hero-buy__micro{display:none}
  .hero__deal{padding:.85rem .9rem}
  .hero__deal-main strong{font-size:1.45rem}
  .hero__deal-list{font-size:.78rem;gap:.35rem .65rem}
  .final-cta__actions{flex-direction:column;align-items:stretch}
  .final-cta__actions .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}
}

/* ==== v4 — newsletter (5% welcome code) + volume quick-nav layer ==== */
/* All colors ride the semantic tokens, so every skin themes this for free. */

/* volume quick-nav chips (hero buybox -> single-guide cards) — REAL buttons,
   accent-built so they read as buttons on dark and light heroes alike */
.vol-chips{display:flex;align-items:center;gap:.55rem;row-gap:.55rem;flex-wrap:wrap;margin-top:1.05rem}
.vol-chips__lbl{font-family:var(--font-accent);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;opacity:.9;white-space:nowrap;flex-basis:100%}
.vol-chips__chip{display:inline-flex;align-items:center;gap:.55rem;padding:.6rem 1rem;border-radius:var(--r-pill);text-decoration:none;
  border:1.5px solid color-mix(in srgb,var(--accent) 62%,transparent);background:color-mix(in srgb,var(--accent) 15%,transparent);
  color:inherit;font-size:.87rem;line-height:1;font-weight:600;box-shadow:0 5px 16px -9px rgba(0,0,0,.5);
  transition:border-color .18s var(--ease),background .18s var(--ease),color .18s var(--ease),transform .18s var(--ease),box-shadow .18s var(--ease)}
.vol-chips__chip b{font-family:var(--font-accent);font-weight:800;letter-spacing:.02em}
.vol-chips__chip span{opacity:.85}
.vol-chips__chip::after{content:"\2193";font-size:.8em;opacity:.7;transition:transform .18s var(--ease)}
.vol-chips__chip:hover{background:var(--accent-strong);border-color:var(--accent-strong);color:var(--accent-ink);transform:translateY(-2px);box-shadow:var(--shadow)}
.vol-chips__chip:hover span{opacity:.9}
.vol-chips__chip:hover::after{transform:translateY(2px)}
.vol-chips__chip:active{transform:translateY(0)}
.vol-card{scroll-margin-top:92px}
@media (max-width:760px){
  /* phone: no horizontal scroll strip — a clean grid of equal, full-width buttons */
  .vol-chips{display:grid;grid-template-columns:repeat(auto-fit,minmax(88px,1fr));gap:.5rem}
  .vol-chips__lbl{grid-column:1/-1;text-align:center;margin-bottom:.1rem}
  .vol-chips__chip{flex-direction:column;justify-content:center;gap:.3rem;min-height:56px;
    padding:.55rem .4rem;border-radius:var(--r);text-align:center}
  .vol-chips__chip::after{display:none}
  .vol-chips__chip b{font-size:.9rem}
  .vol-chips__chip span{font-size:.82rem}
}

/* newsletter modal — stage 1 (our form), stage 2 (embedded $0 checkout), stage 3 (done) */
.nl{position:fixed;inset:0;z-index:96;display:none;place-items:center;padding:1.2rem}
.nl.is-open{display:grid}
.nl__backdrop{position:absolute;inset:0;background:rgba(8,10,16,.66);backdrop-filter:blur(5px);animation:fade .25s var(--ease)}
.nl__card{position:relative;z-index:1;background:var(--panel);color:var(--panel-ink);width:min(520px,100%);max-height:min(92dvh,860px);
  overflow:auto;border-radius:var(--r-lg);padding:2.2rem 2.1rem 1.7rem;box-shadow:var(--shadow-lg);text-align:center;
  border-top:4px solid var(--accent);animation:nl-up .32s var(--ease)}
.nl__card:focus{outline:none}
@keyframes nl-up{from{transform:translateY(18px);opacity:0}to{transform:none;opacity:1}}
.nl__close{position:absolute;top:.55rem;right:.85rem;background:none;border:0;font-size:1.8rem;line-height:1;cursor:pointer;
  color:color-mix(in srgb,var(--panel-ink) 55%,transparent);padding:.35rem;z-index:2}
.nl__close:hover{color:var(--panel-ink)}
.nl__badge{display:inline-block;font-family:var(--font-accent);font-weight:800;font-size:.78rem;letter-spacing:.16em;
  background:var(--accent-strong);color:var(--accent-ink);border-radius:var(--r-pill);padding:.4rem .85rem;margin-bottom:1rem}
.nl__head{font-family:var(--font-display);font-size:clamp(1.35rem,3.6vw,1.7rem);line-height:1.18;color:var(--panel-ink);margin-bottom:.55rem}
.nl__body{color:color-mix(in srgb,var(--panel-ink) 78%,transparent);font-size:.98rem;max-width:38ch;margin-inline:auto}
.nl__form{display:flex;gap:.6rem;margin-top:1.25rem}
.nl__email{flex:1;min-width:0;padding:.85rem 1rem;border-radius:var(--r);border:1.5px solid color-mix(in srgb,var(--panel-ink) 28%,transparent);
  background:color-mix(in srgb,var(--panel-ink) 4%,transparent);color:var(--panel-ink);font:inherit;font-size:.95rem}
.nl__email:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
.nl__email[aria-invalid="true"]{border-color:var(--danger);outline-color:var(--danger)}
.nl__cta{white-space:nowrap}
.nl__consent{font-size:.8rem;color:color-mix(in srgb,var(--panel-ink) 70%,transparent);margin-top:.9rem;max-width:46ch;margin-inline:auto}
.nl__consent a{color:inherit;text-decoration:underline}
.nl__dismiss{background:none;border:0;cursor:pointer;font:inherit;font-size:.8rem;margin-top:.7rem;
  color:color-mix(in srgb,var(--panel-ink) 50%,transparent);text-decoration:underline;text-underline-offset:3px}
.nl__dismiss:hover{color:var(--panel-ink)}
/* stage 2: embedded checkout */
.nl__loading{display:flex;align-items:center;justify-content:center;gap:.6rem;min-height:90px;font-size:.9rem;
  color:color-mix(in srgb,var(--panel-ink) 70%,transparent)}
.nl__spinner{width:1.05rem;height:1.05rem;border-radius:50%;border:2.5px solid color-mix(in srgb,var(--panel-ink) 25%,transparent);
  border-top-color:var(--accent);animation:nl-spin .8s linear infinite;display:inline-block}
@keyframes nl-spin{to{transform:rotate(360deg)}}
.nl--frame-loaded .nl__loading{display:none}
.nl__frame{width:100%;height:min(64dvh,560px);border:0;border-radius:var(--r);background:#fff;display:block}
.nl--frame-loaded .nl__frame{box-shadow:var(--shadow)}
/* floating pill (re-entry after dismissal) */
.nl-pill[hidden]{display:none}
.nl-pill{position:fixed;left:.9rem;bottom:calc(.9rem + env(safe-area-inset-bottom,0px));z-index:61;display:inline-flex;align-items:center;gap:.5rem;
  border:0;cursor:pointer;border-radius:var(--r-pill);padding:.62rem 1rem .62rem .62rem;background:var(--accent-strong);color:var(--accent-ink);
  font-family:var(--font-accent);font-weight:800;font-size:.84rem;letter-spacing:.04em;box-shadow:var(--shadow-lg);
  transition:transform .25s var(--ease),bottom .3s var(--ease)}
.nl-pill:hover{transform:translateY(-2px)}
.nl-pill__tag{display:grid;place-items:center;width:1.7rem;height:1.7rem;border-radius:50%;background:#1b1407;color:var(--accent);font-size:.9rem}
body.sticky-on .nl-pill{bottom:calc(4.6rem + env(safe-area-inset-bottom,0px))}
/* footer inline form */
.footer__grid--nl{grid-template-columns:1.5fr 1fr 1fr 1.35fr}
@media (max-width:900px){.footer__grid--nl{grid-template-columns:1fr 1fr}}
@media (max-width:720px){.footer__grid--nl{grid-template-columns:1fr}}
.footer-nl__form{display:flex;gap:.5rem;margin-top:.6rem}
.footer-nl__form input{flex:1;min-width:0;padding:.7rem .85rem;border-radius:var(--r);font:inherit;font-size:.9rem;
  border:1.5px solid color-mix(in srgb,var(--on-deep) 30%,transparent);background:color-mix(in srgb,var(--on-deep) 8%,transparent);color:var(--on-deep)}
.footer-nl__form input:focus{outline:2px solid var(--accent);outline-offset:1px}
.footer-nl__form input[aria-invalid="true"]{border-color:var(--danger)}
.footer-nl__form .btn{padding:.7rem 1.05rem;font-size:.88rem}
.footer-nl__hint{font-size:.8rem;color:color-mix(in srgb,var(--on-deep) 68%,transparent);margin-top:.5rem}
/* in-flow newsletter band (right after pricing — where the price objection forms) */
.nl-strip{background:color-mix(in srgb,var(--accent) 10%,var(--page-bg));border-block:1px solid color-mix(in srgb,var(--accent) 38%,transparent);padding-block:1.7rem}
.nl-strip__in{display:flex;align-items:center;justify-content:space-between;gap:1.4rem}
.nl-strip__txt{display:flex;flex-direction:column;gap:.3rem;min-width:0}
.nl-strip__txt b{font-family:var(--font-display);font-size:1.32rem;line-height:1.2}
.nl-strip__txt span{font-size:.96rem;opacity:.85;max-width:54ch}
.nl-strip__btn{white-space:nowrap;flex:0 0 auto}
@media (max-width:760px){
  .nl-strip__in{flex-direction:column;align-items:stretch;text-align:center}
  .nl-strip__btn{width:100%}
  .nl-strip__txt b{font-size:1.18rem}
}

/* exit modal: code reminder line, revealed only once the visitor has a code */
.exit__code{display:none;font-size:.86rem;margin-top:.7rem;padding:.55rem .8rem;border-radius:var(--r);
  background:color-mix(in srgb,var(--accent) 16%,transparent);color:var(--panel-ink)}
html.has-code .exit__code{display:block}
/* scroll lock while the modal is open */
html.nl-lock,html.nl-lock body{overflow:hidden}
/* mobile: bottom sheet, full-bleed checkout */
@media (max-width:760px){
  .nl{padding:0;place-items:end stretch}
  .nl__card{width:100%;max-width:none;max-height:94dvh;border-radius:var(--r-lg) var(--r-lg) 0 0;
    padding:1.7rem 1.15rem calc(1.1rem + env(safe-area-inset-bottom,0px));animation:nl-sheet .3s var(--ease)}
  .nl__form{flex-direction:column}
  .nl__cta{width:100%}
  .nl__frame{height:calc(94dvh - 6.5rem)}
  .nl-pill__txt{display:none}
  .nl-pill{padding:.62rem;border-radius:50%}
}
@keyframes nl-sheet{from{transform:translateY(40px);opacity:.4}to{transform:none;opacity:1}}
@media (prefers-reduced-motion:reduce){
  .nl__card,.nl__backdrop{animation:none}
  .nl-pill{transition:none}
  .nl__spinner{animation-duration:1.6s}
}

/* ============ COOKIE CONSENT — non-blocking bottom bar (region-aware defaults set in <head>) ============ */
.consent{position:fixed;left:0;right:0;bottom:0;z-index:80;color:var(--on-deep);
  background:color-mix(in srgb,var(--deep) 96%,transparent);backdrop-filter:saturate(140%) blur(8px);
  border-top:1px solid color-mix(in srgb,var(--accent) 36%,transparent);
  box-shadow:0 -14px 34px -16px rgba(0,0,0,.6);transform:translateY(112%);transition:transform .4s var(--ease)}
.consent:not([hidden]){display:block}
.consent.is-open{transform:none}
.consent__in{display:flex;align-items:center;justify-content:space-between;gap:.85rem 1.4rem;flex-wrap:wrap;padding-block:.9rem}
.consent__txt{margin:0;font-size:.92rem;line-height:1.5;max-width:70ch;color:color-mix(in srgb,var(--on-deep) 90%,transparent)}
.consent__txt a{color:var(--accent-label,var(--accent));text-decoration:underline;text-underline-offset:2px}
.consent__btns{display:flex;gap:.6rem;flex:0 0 auto}
.consent__btn{min-height:44px;padding:.7rem 1.3rem;font-size:.95rem}
.consent .btn--ghost{color:var(--on-deep);border-color:color-mix(in srgb,var(--on-deep) 34%,transparent)}
.consent .btn--ghost:hover{color:var(--accent);border-color:var(--accent)}
@media (max-width:560px){
  .consent__txt{font-size:.86rem}
  .consent__btns{width:100%}
  .consent__btn{flex:1 1 0;justify-content:center}
}
@media (prefers-reduced-motion:reduce){.consent{transition:none}}


/* ---- skin:marcus ---- */
/* ============================================================
   DR. MARCUS REARDON — "THE EXAM ROOM" skin
   The Forgotten Muscle Library — clinical slate + cream chart-paper,
   amber chart-rules, the glowing-teal diaphragm, coral rationed to
   stakes. A calm, credible exam room at dusk: a two-mood arc — cool
   clinical concern (teal = the breath / "rest") resolving into warm
   lamp-lit reassurance (amber = the win / reveal). Grounded and
   premium, the OPPOSITE of a bouncy supplement ad (the 50-75 cohort
   reads bounce as a scam). Signature emblem: a glowing-wire diaphragm
   DOME — a teal arc under a faint heart-and-lungs silhouette.
   Type: Anton (display caps) · Inter (body) · Roboto Mono (vitals /
   monitor small-labels) · Caveat (a sparing hand-written annotation).
   Layers on engine/base.css — DECORATES ONLY via the injected vars
   (--accent amber, --accent-2 teal, --danger coral, --border sand).
   transform/opacity motion only; gentle, no bounce; CLS-safe; full
   reduced-motion honor. No external assets — pure CSS texture.
   ============================================================ */

/* ============================================================
   1. ATMOSPHERE — the exam room at dusk. A cool clinical wash
      up top (teal concern), a low warm lamp pool at the foot
      (amber reassurance) = the two-mood arc made into the page
      itself. A faint dotted "chart grid" + paper grain so the
      slate never reads as a flat screen.
   ============================================================ */
body{
  background-color:var(--page-bg);
  background-image:
    /* cool clinical window-light, top — the concern mood */
    radial-gradient(125% 78% at 50% -12%, color-mix(in srgb,var(--accent-2) 12%,transparent), transparent 60%),
    /* warm lamp pool, lower-right — the reassurance mood resolving in */
    radial-gradient(110% 70% at 92% 112%, color-mix(in srgb,var(--accent) 14%,transparent), transparent 58%),
    /* a faint dotted CHART GRID — the exam-room chart paper rule */
    radial-gradient(circle at center, color-mix(in srgb,var(--ink) 5%,transparent) 1px, transparent 1.4px),
    /* fine vertical paper fibre, very faint */
    repeating-linear-gradient(90deg, color-mix(in srgb,var(--ink) 2.4%,transparent) 0 1px, transparent 1px 7px),
    /* a settled top-shade so the room has ceiling */
    linear-gradient(180deg, color-mix(in srgb,#16212A 26%,var(--page-bg)) 0%, var(--page-bg) 30%, var(--page-bg) 100%);
  background-size:auto, auto, 22px 22px, auto, auto;
  background-attachment:fixed, fixed, fixed, scroll, fixed;
  position:relative;
}
/* a soft settled vignette + a barely-there EKG breath-trace ghost
   running across the upper field, masked so it never fights text */
@media (min-width:760px){
  body::before{
    content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
    background-image:
      /* settled exam-room vignette */
      radial-gradient(150% 120% at 50% -16%, transparent 56%, color-mix(in srgb,#16212A 22%,transparent) 100%),
      /* a faint repeating chart column relief, like a long monitor strip */
      repeating-linear-gradient(90deg, transparent 0 132px,
        color-mix(in srgb,var(--accent-2) 5%,transparent) 132px 133px);
    -webkit-mask-image:linear-gradient(180deg, transparent, #000 14%, #000 86%, transparent);
            mask-image:linear-gradient(180deg, transparent, #000 14%, #000 86%, transparent);
  }
}
/* keep functional layers above the fixed atmosphere */
.nav,.ribbon,main,.footer,.sticky-cta,.consent{position:relative;z-index:1}

/* ============================================================
   2. RIBBON — a printed chart-header strip. Amber lamp-warm,
      slate ink, a fine sand rule beneath like a chart rule.
   ============================================================ */
.ribbon{
  font-family:var(--font-accent);
  letter-spacing:.06em;
  background:
    /* faint ruled ticks like a chart margin */
    repeating-linear-gradient(90deg, transparent 0 30px, color-mix(in srgb,#1E2A33 9%,transparent) 30px 31px),
    linear-gradient(180deg, color-mix(in srgb,#fff 14%,var(--accent)), var(--accent) 62%, color-mix(in srgb,#D8C7A6 26%,var(--accent)));
  border-bottom:1px solid color-mix(in srgb,#1E2A33 26%,transparent);
  box-shadow:inset 0 -1px 0 color-mix(in srgb,#fff 22%,transparent),
             inset 0 1px 0 color-mix(in srgb,#fff 14%,transparent);
}
.ribbon strong{font-weight:800}

/* ============================================================
   3. NAV + WORDMARK — a quiet clinic-counter header. A fine
      amber chart-rule beneath; the brand dot is the DIAPHRAGM
      DOME in miniature (a teal glowing arc).
   ============================================================ */
.nav{
  border-bottom:1px solid color-mix(in srgb,var(--accent) 26%,var(--hair));
  background:color-mix(in srgb,var(--page-bg) 84%,transparent);
  box-shadow:0 1px 0 color-mix(in srgb,var(--accent) 12%,transparent);
}
.brandmark{letter-spacing:.02em;text-shadow:0 1px 0 color-mix(in srgb,#000 26%,transparent)}
/* the wordmark dot = a tiny teal diaphragm dome: a half-disc with
   a glowing-wire teal rim, calm-mood emblem at counter scale */
.brandmark .dot{
  width:.72rem;height:.72rem;border-radius:50% 50% 50% 50% / 70% 70% 30% 30%;
  background:
    radial-gradient(120% 150% at 50% 120%, color-mix(in srgb,#fff 30%,var(--accent-2)), var(--accent-2) 58%, color-mix(in srgb,#16212A 30%,var(--accent-2)));
  box-shadow:
    0 0 0 3px color-mix(in srgb,var(--accent-2) 18%,transparent),
    0 0 12px 1px color-mix(in srgb,var(--accent-2) 62%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 40%,transparent);
}
@media (prefers-reduced-motion:no-preference){
  .brandmark .dot{animation:mx-breathe 4.6s var(--ease) infinite}
}
/* the brand's quiet "breath" — a slow calm inhale/exhale glow */
@keyframes mx-breathe{
  0%,100%{box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-2) 14%,transparent),
            0 0 10px 1px color-mix(in srgb,var(--accent-2) 50%,transparent),
            inset 0 1px 0 color-mix(in srgb,#fff 36%,transparent)}
  50%{box-shadow:0 0 0 4px color-mix(in srgb,var(--accent-2) 22%,transparent),
            0 0 18px 2px color-mix(in srgb,var(--accent-2) 78%,transparent),
            inset 0 1px 0 color-mix(in srgb,#fff 44%,transparent)}
}
.nav__links a{font-family:var(--font-body);font-weight:600}
.nav__links a:hover{color:var(--accent);opacity:1}

/* ============================================================
   4. EYEBROW — a monitor read-out label: Roboto Mono caps with
      a leading teal "vitals tick" + a short amber chart-rule.
   ============================================================ */
.eyebrow{
  font-family:"Roboto Mono", ui-monospace, monospace;
  color:var(--accent-label);
  letter-spacing:.2em;
  display:inline-flex;align-items:center;gap:.55rem;
}
.eyebrow::before{
  content:"";flex:0 0 auto;width:.5rem;height:.5rem;border-radius:50%;
  background:var(--accent-2);
  box-shadow:0 0 8px 1px color-mix(in srgb,var(--accent-2) 60%,transparent);
}
.eyebrow::after{
  content:"";flex:0 0 auto;width:1.4rem;height:2px;border-radius:2px;
  background:linear-gradient(90deg, var(--accent), transparent);
}
.center .eyebrow{justify-content:center}

/* ============================================================
   5. SECTION HEADINGS — set in Anton condensed caps. A clean
      amber chart-rule under section/narrative heads; the
      narrative alternates to the teal "breath" color so the
      page keeps its two-mood arc as it scrolls.
   ============================================================ */
.section h2,.narrative h2{position:relative;letter-spacing:.004em}
.narrative h2{padding-bottom:.4rem}
.narrative h2::after{
  content:"";position:absolute;left:0;bottom:0;width:clamp(54px,15%,132px);height:2px;border-radius:2px;
  background:linear-gradient(90deg, var(--accent), color-mix(in srgb,var(--accent) 24%,transparent));
}
.narrative .block:nth-child(even) h2::after{
  background:linear-gradient(90deg, var(--accent-2), color-mix(in srgb,var(--accent-2) 22%,transparent));
}
.center h2::after{margin-inline:auto}
.center .section h2::after,.center h2::after{left:50%}
.narrative .block strong{color:var(--accent);font-weight:700}
.narrative .block em{font-style:italic;color:color-mix(in srgb,var(--ink) 82%,var(--accent-2))}

/* ============================================================
   6. HERO — the exam room at dusk. Cool clinical light pooled
      top-left (concern), a warm lamp glow lower-right (the
      resolve). The title gets an EKG / breath-trace underline.
   ============================================================ */
.hero{
  background:
    radial-gradient(72% 110% at 8% 0%, color-mix(in srgb,var(--accent-2) 12%,transparent), transparent 56%),
    radial-gradient(64% 96% at 100% 100%, color-mix(in srgb,var(--accent) 11%,transparent), transparent 58%);
}
.hero__title{letter-spacing:.004em;text-shadow:0 1px 0 color-mix(in srgb,#000 30%,transparent)}
/* the signature breath-trace: a faint EKG line under the H1, drawn
   purely with layered gradients — a flat baseline, then one calm
   beat. Amber (the reveal), thin, never gaudy. */
.hero__title::after{
  content:"";display:block;height:14px;margin-top:.55rem;width:min(280px,72%);
  background:
    /* the QRS beat: a short up-stroke + down-stroke, amber */
    linear-gradient(45deg, transparent 47%, var(--accent) 47% 50%, transparent 50%) 116px 0 / 13px 14px no-repeat,
    linear-gradient(-45deg, transparent 47%, var(--accent) 47% 50%, transparent 50%) 129px 0 / 13px 14px no-repeat,
    /* the flat baseline trace */
    linear-gradient(90deg,
      var(--accent) 0 116px,
      transparent 116px 142px,
      color-mix(in srgb,var(--accent) 62%,transparent) 142px 100%) left 50% / 100% 1.5px no-repeat;
  opacity:.92;
  -webkit-mask-image:linear-gradient(90deg,#000 76%,transparent);
          mask-image:linear-gradient(90deg,#000 76%,transparent);
}
.hero__trust{
  font-style:italic;
  color:color-mix(in srgb,var(--ink) 70%,var(--page-bg));
}
.hero__trust::before{
  content:"";flex:0 0 auto;width:.5rem;height:.5rem;border-radius:50%;
  background:var(--accent-2);box-shadow:0 0 8px 1px color-mix(in srgb,var(--accent-2) 60%,transparent);
}
/* a pencilled clinician's margin note, far right, desktop only */
@media (min-width:1040px){
  .hero::after{
    content:"\201C The muscle nobody thinks to train. \201D";
    position:absolute;right:clamp(1rem,3vw,3rem);bottom:1.1rem;
    font-family:"Caveat", cursive;font-weight:700;
    font-size:clamp(1.15rem,1.7vw,1.6rem);line-height:1;
    color:color-mix(in srgb,var(--accent) 56%,var(--ink));
    transform:rotate(-2.4deg);opacity:.9;pointer-events:none;
  }
}

/* ============================================================
   7. FACE HERO — Dr. Reardon framed as a credible clinician
      portrait. A cream chart-paper mat (the inset ring), a cool
      window edge-light, a settled foot-shadow, a teal corner
      registration tick (the "examined & filed" cue), and a
      stamped caption with the diaphragm-dome glyph.
   ============================================================ */
.hero__art{
  border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));
  box-shadow:
    var(--shadow-lg),
    inset 0 0 0 5px color-mix(in srgb,var(--panel) 82%,transparent),
    inset 0 0 70px -24px color-mix(in srgb,#16212A 60%,transparent);
}
.hero__art .ph{
  font-family:"Roboto Mono", ui-monospace, monospace;letter-spacing:.2em;
  color:color-mix(in srgb,var(--on-deep) 60%,transparent);
}
.hero__art--face{
  background:linear-gradient(160deg, color-mix(in srgb,var(--accent-2) 13%,var(--deep)), var(--deep));
}
.hero__art--face img{
  object-position:var(--focal-hero);
  filter:saturate(.96) contrast(1.03);
  transition:transform .8s var(--ease),filter .8s var(--ease);
}
.hero__art--face:hover img{transform:scale(1.02);filter:saturate(1) contrast(1.05)}
/* cool window edge-light from the upper-left + a warm settle at the
   foot — the two-mood arc inside the portrait itself */
.hero__art--face::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(112deg, color-mix(in srgb,var(--accent-2) 14%,transparent) 0%, transparent 36%),
    radial-gradient(120% 76% at 50% -8%, color-mix(in srgb,#fff 8%,transparent), transparent 52%),
    linear-gradient(0deg, color-mix(in srgb,var(--accent) 12%,transparent) 0%, transparent 40%),
    radial-gradient(120% 100% at 50% 8%, transparent 54%, color-mix(in srgb,var(--page-bg) 72%,transparent) 100%);
}
/* teal corner registration tick — top-left "examined & filed" 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-2) 66%,transparent);
  border-left:1.5px solid color-mix(in srgb,var(--accent-2) 66%,transparent);
}
.hero__cap{
  background:linear-gradient(0deg,
    color-mix(in srgb,#16212A 88%,transparent),
    color-mix(in srgb,#16212A 40%,transparent) 54%, transparent);
  border-top:1px solid color-mix(in srgb,var(--accent) 32%,transparent);
}
.hero__cap b{
  font-family:var(--font-display);letter-spacing:.012em;
  text-shadow:0 1px 2px rgba(0,0,0,.6);
}
/* the diaphragm-dome glyph before the name — a teal half-disc */
.hero__cap b::before{
  content:"";display:inline-block;width:.6rem;height:.32rem;margin-right:.5rem;
  border-radius:.6rem .6rem 0 0;vertical-align:.04em;
  background:var(--accent-2);
  box-shadow:0 0 7px 0 color-mix(in srgb,var(--accent-2) 60%,transparent),
    0 0 0 1px color-mix(in srgb,var(--accent-2) 30%,transparent);
}
.hero__cap span{text-transform:none;letter-spacing:.01em;
  color:color-mix(in srgb,#fff 74%,var(--accent-2))}

/* faceless-scene fallback (Marcus is FACE, but keep safe + on-brand) */
.hero__art--scene{
  border:1px solid color-mix(in srgb,var(--accent) 28%,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;inset:0;pointer-events:none;
  background:
    radial-gradient(120% 90% at 50% 42%, transparent 54%, color-mix(in srgb,#16212A 52%,transparent) 100%),
    linear-gradient(0deg, color-mix(in srgb,var(--accent) 8%,transparent), transparent 50%);
}

/* ============================================================
   8. BUTTONS — a calm warm-lamp primary (amber = the win) with
      a clean pressed face. The buy path stays obviously tap-able,
      clear contrast, never flashy. Ghost = cool steel outline.
   ============================================================ */
.btn--primary{
  background:linear-gradient(180deg, color-mix(in srgb,#fff 15%,var(--accent)), var(--accent) 64%, color-mix(in srgb,#D8C7A6 22%,var(--accent)));
  box-shadow:
    var(--shadow),
    inset 0 1px 0 color-mix(in srgb,#fff 34%,transparent),
    0 0 0 1px color-mix(in srgb,#1E2A33 16%,transparent);
}
.btn--primary:hover{
  filter:brightness(1.05) saturate(1.03);
  box-shadow:var(--shadow-lg), 0 0 22px -4px color-mix(in srgb,var(--accent) 60%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 38%,transparent);
}
.btn--ghost{border-color:color-mix(in srgb,var(--accent-2) 44%,transparent)}
.btn--ghost:hover{border-color:var(--accent-2);color:var(--accent-2)}
.btn--lg{letter-spacing:.01em}

/* ============================================================
   9. THE DIAPHRAGM DOME — the brand's quiet emblem. A glowing-
      teal arc/dome under a faint heart-and-lungs silhouette,
      drawn as a stamped seal on the AUTHOR band so it reads as
      Dr. Reardon's mark. Pure CSS, no images.
   ============================================================ */
.author{position:relative;overflow:hidden}
.author::before{ /* a top amber chart-rule across the trust band */
  content:"";position:absolute;left:0;right:0;top:0;height:1px;z-index:2;
  background:linear-gradient(90deg, transparent, color-mix(in srgb,var(--accent) 50%,transparent), transparent);
}
/* the emblem: a faint teal dome glow seated in the band's far corner.
   A radial "lung field" wash + a hard teal arc (the diaphragm) under
   it. Desktop-only, masked, never over text. */
@media (min-width:900px){
  .author::after{
    content:"";position:absolute;right:-3%;top:50%;transform:translateY(-50%);
    width:300px;height:300px;z-index:0;pointer-events:none;opacity:.5;
    background:
      /* the diaphragm arc — a teal glowing curve across the lower third */
      radial-gradient(120% 120% at 50% -36%, transparent 64%,
        color-mix(in srgb,var(--accent-2) 60%,transparent) 65%, color-mix(in srgb,var(--accent-2) 60%,transparent) 67%, transparent 68%),
      /* the faint heart-and-lung field above it */
      radial-gradient(closest-side at 38% 36%, color-mix(in srgb,var(--accent-2) 18%,transparent), transparent 72%),
      radial-gradient(closest-side at 62% 36%, color-mix(in srgb,var(--accent-2) 16%,transparent), transparent 72%),
      radial-gradient(closest-side at 50% 30%, color-mix(in srgb,var(--accent) 12%,transparent), transparent 70%);
    -webkit-mask-image:radial-gradient(closest-side, #000 60%, transparent);
            mask-image:radial-gradient(closest-side, #000 60%, transparent);
    filter:drop-shadow(0 0 16px color-mix(in srgb,var(--accent-2) 30%,transparent));
  }
}
.author__photo{
  position:relative;overflow:hidden;
  border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));
  box-shadow:
    var(--shadow-lg),
    inset 0 0 0 5px color-mix(in srgb,var(--panel) 80%,transparent);
  background:linear-gradient(160deg, color-mix(in srgb,var(--accent-2) 12%,var(--deep)), var(--deep));
}
.author__photo img{object-position:var(--focal-author);filter:saturate(.96) contrast(1.02)}
/* cool edge-light + warm settle echoing the hero portrait */
.author__photo::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(112deg, color-mix(in srgb,var(--accent-2) 11%,transparent) 0, transparent 34%),
    linear-gradient(0deg, color-mix(in srgb,var(--accent) 12%,transparent) 0, transparent 38%);
}
.author__role{position:relative;padding-bottom:.4rem}
.author__role::after{
  content:"";position:absolute;left:0;bottom:0;width:60px;height:2px;border-radius:2px;
  background:color-mix(in srgb,var(--accent) 70%,transparent);
}
.author__bio{position:relative;z-index:1}
.author__bio p strong{color:var(--accent)}
/* the signature — a hand-written Caveat sign-off with a teal seal-rule */
.author__sign{
  font-family:"Caveat", cursive;font-style:normal;
  font-size:1.7rem;letter-spacing:.005em;line-height:1.1;
  color:color-mix(in srgb,var(--ink) 86%,var(--accent));
  border-top:0;margin-top:1.3rem;padding-top:1.1rem;position:relative;display:inline-block;
}
.author__sign::before{
  content:"Dr. Marcus Reardon";display:block;
  font-family:var(--font-body);font-style:normal;font-weight:700;
  font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
  color:color-mix(in srgb,var(--ink) 52%,var(--page-bg));margin-bottom:.3rem;
}
.author__sign::after{
  content:"";position:absolute;left:0;top:1.1rem;width:clamp(80px,30%,150px);height:2px;
  background:color-mix(in srgb,var(--accent-2) 56%,transparent);
}

/* ============================================================
   10. VOLUME CARDS — cream "chart-paper" plates seated on the
       slate with a soft warm shadow. A defined sand frame so
       each reads as a real filed chart, an amber chart-rule
       head band, a teal vitals tick per line, and a calm lift.
   ============================================================ */
.vol-card{
  position:relative;overflow:hidden;
  background:
    /* an amber chart-rule head band */
    linear-gradient(180deg, color-mix(in srgb,var(--accent) 11%,var(--panel)) 0 6px, var(--panel) 6px),
    /* faint horizontal chart ruling down the card */
    repeating-linear-gradient(0deg, transparent 0 30px, color-mix(in srgb,var(--panel-ink) 4%,transparent) 30px 31px),
    var(--panel);
  /* SOLID OBJECT FRAME — a defined warm-sand edge so the card reads
     as a real filed chart, not a faint panel, on the slate page. */
  border:1.5px solid color-mix(in srgb,var(--accent) 24%,var(--border));
  box-shadow:
    var(--shadow-sm),
    /* warm lamp drop so the chart sits proud of the slate */
    0 18px 34px -22px color-mix(in srgb,var(--accent) 30%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 56%,transparent),
    /* an inset double-hairline frame — a fine sand rule set in from
       the edge so the chart-paper has a stamped, boxed border */
    inset 0 0 0 1px color-mix(in srgb,var(--panel) 62%,transparent),
    inset 0 0 0 6px var(--panel),
    inset 0 0 0 7px color-mix(in srgb,var(--accent) 16%,transparent);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease);
}
/* a fine amber dashed chart-tick rule just under the head band */
.vol-card::before{
  content:"";position:absolute;left:0;right:0;top:6px;height:2px;z-index:1;pointer-events:none;
  background:repeating-linear-gradient(90deg, color-mix(in srgb,var(--accent) 64%,transparent) 0 5px, transparent 5px 10px);
}
.vol-card:hover{
  transform:translateY(-5px);
  border-color:color-mix(in srgb,var(--accent) 42%,var(--border));
  box-shadow:
    var(--shadow),
    0 26px 44px -24px color-mix(in srgb,var(--accent) 40%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 60%,transparent),
    inset 0 0 0 1px color-mix(in srgb,var(--panel) 62%,transparent),
    inset 0 0 0 6px var(--panel),
    inset 0 0 0 7px color-mix(in srgb,var(--accent) 30%,transparent);
}
.vol-card__num{font-family:"Roboto Mono", ui-monospace, monospace;letter-spacing:.16em;color:var(--danger)}
.vol-card__title{font-family:var(--font-display);letter-spacing:.006em}
.vol-card__sub{color:color-mix(in srgb,var(--panel-ink) 70%,var(--panel))}
/* teal "vitals" tick bullets — the breath/rest color, a small square */
.vol-list li::before{
  border-radius:1px;transform:rotate(45deg);width:.55rem;height:.55rem;
  background:var(--accent-2);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-2) 18%,transparent),
    0 0 6px 0 color-mix(in srgb,var(--accent-2) 42%,transparent);
}
.in-vault{color:var(--accent-2)}
.price{font-family:var(--font-display)}

/* "Most Popular" — clearly the chosen chart: a warmer cream, a glowing
   amber frame + soft lamp halo, a lifted resting state. */
.vol-card--feature{
  outline-color:var(--accent);
  border-color:color-mix(in srgb,var(--accent) 52%,var(--border));
  background:
    linear-gradient(180deg, color-mix(in srgb,var(--accent) 15%,var(--panel)) 0 6px, color-mix(in srgb,var(--accent) 5%,var(--panel)) 6px),
    repeating-linear-gradient(0deg, transparent 0 30px, color-mix(in srgb,var(--panel-ink) 4%,transparent) 30px 31px),
    var(--panel);
  transform:translateY(-3px);
  box-shadow:
    var(--shadow),
    0 0 0 5px color-mix(in srgb,var(--accent) 16%,transparent),
    0 28px 60px -34px color-mix(in srgb,var(--accent) 54%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 58%,transparent),
    inset 0 0 0 6px color-mix(in srgb,var(--accent) 5%,var(--panel)),
    inset 0 0 0 7px color-mix(in srgb,var(--accent) 38%,transparent);
}
.vol-card--feature:hover{
  transform:translateY(-8px);
  box-shadow:
    var(--shadow-lg),
    0 0 0 6px color-mix(in srgb,var(--accent) 22%,transparent),
    0 34px 72px -34px color-mix(in srgb,var(--accent) 60%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 62%,transparent),
    inset 0 0 0 6px color-mix(in srgb,var(--accent) 7%,var(--panel)),
    inset 0 0 0 7px color-mix(in srgb,var(--accent) 48%,transparent);
}
.vol-card--feature::before{background:repeating-linear-gradient(90deg, var(--accent) 0 6px, transparent 6px 11px)}

/* badge chips — a pressed amber chart-stamp */
.tag{box-shadow:0 1px 0 color-mix(in srgb,#1E2A33 26%,var(--accent)), inset 0 1px 0 color-mix(in srgb,#fff 24%,transparent)}

/* ---- VOLUME COVER — a filed chart-plate catching the lamp.
   base.css owns the left book-spine (.vol-card__cover::before) +
   min-height + focal object-position. We do NOT add a competing
   ::before. Our ::after adds a cool window edge-light + a fine
   sand seam ring, so the cover reads as a real premium plate. ---- */
.vol-card__cover{
  border-color:color-mix(in srgb,var(--accent) 44%,var(--border));
  box-shadow:
    var(--shadow),
    /* a cream chart-mat built from inset rings */
    inset 0 0 0 1px color-mix(in srgb,var(--accent) 38%,transparent),
    inset 0 0 0 5px color-mix(in srgb,var(--panel) 72%,transparent),
    inset 0 0 0 6px color-mix(in srgb,var(--accent) 24%,transparent),
    inset 0 -16px 24px -14px color-mix(in srgb,#16212A 44%,transparent);
}
.vol-card__cover::after{
  content:"";position:absolute;inset:7px;z-index:3;pointer-events:none;border-radius:3px;
  border:1px solid color-mix(in srgb,var(--accent) 26%,transparent);
  background:
    /* cool window edge-light sweeping from the top-right */
    linear-gradient(216deg, color-mix(in srgb,var(--accent-2) 14%,transparent) 0%, transparent 30%),
    /* warm settled pool at the foot */
    linear-gradient(0deg, color-mix(in srgb,var(--accent) 12%,transparent) 0%, transparent 24%);
}
.vol-card:hover .vol-card__cover{
  box-shadow:
    var(--shadow-lg),
    inset 0 0 0 1px color-mix(in srgb,var(--accent) 50%,transparent),
    inset 0 0 0 5px color-mix(in srgb,var(--panel) 74%,transparent),
    inset 0 0 0 6px color-mix(in srgb,var(--accent) 34%,transparent),
    inset 0 -16px 24px -14px color-mix(in srgb,#16212A 48%,transparent);
}
.vol-card:hover .vol-card__cover::after{border-color:color-mix(in srgb,var(--accent) 40%,transparent)}
.vol-card--feature .vol-card__cover{border-color:color-mix(in srgb,var(--accent) 56%,var(--border))}
.vol-card--feature .vol-card__cover::after{border-color:color-mix(in srgb,var(--accent) 40%,transparent)}

/* ============================================================
   11. BUNDLE — the consult drawer on the slate bench: a deep
       two-mood wash (cool teal corner + warm amber corner), a
       chart-rule top seam, and a hand-set lamp-warm price plate.
       The hero of the buy path.
   ============================================================ */
.bundle{
  background:
    radial-gradient(120% 96% at 0% 100%, color-mix(in srgb,var(--accent-2) 20%,var(--deep)), transparent 56%),
    radial-gradient(96% 84% at 100% 0%, color-mix(in srgb,var(--accent) 20%,var(--deep)), transparent 54%),
    linear-gradient(150deg, var(--deep), color-mix(in srgb,var(--accent) 14%,var(--deep)));
  border-color:color-mix(in srgb,var(--accent) 52%,transparent);
  box-shadow:
    var(--shadow-lg),
    0 0 64px -24px color-mix(in srgb,var(--accent) 40%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 13%,transparent);
}
/* a top amber chart-seam, like the drawer edge */
.bundle::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;z-index:2;
  background:linear-gradient(90deg, transparent, var(--accent), transparent);
}
/* a low teal "breath" corner glow that strengthens on hover */
.bundle::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;border-radius:inherit;
  background:radial-gradient(78% 60% at 6% 100%, color-mix(in srgb,var(--accent-2) 18%,transparent), transparent 60%);
  opacity:.7;transition:opacity .4s var(--ease);
}
.bundle:hover::after{opacity:1}
.bundle__body,.bundle__buy{position:relative;z-index:1}
.bundle__title{font-family:var(--font-display);letter-spacing:.01em}
.bundle__includes li::before{text-shadow:0 0 9px color-mix(in srgb,var(--accent) 60%,transparent)}
.bundle__separately{color:color-mix(in srgb,var(--on-deep) 66%,transparent)}
/* the buy column reads as a cut chart-card seated in the drawer */
.bundle__buy{
  background:
    radial-gradient(90% 70% at 50% 0%, color-mix(in srgb,var(--accent) 11%,transparent), transparent 62%),
    color-mix(in srgb,#16212A 22%,var(--deep));
  border-left-color:color-mix(in srgb,var(--accent) 38%,transparent);
}
@media (max-width:820px){
  .bundle__buy{border-top-color:color-mix(in srgb,var(--accent) 38%,transparent)}
}
.bundle__price{
  text-shadow:0 1px 0 color-mix(in srgb,#000 30%,transparent),
    0 0 26px color-mix(in srgb,var(--accent) 40%,transparent);
}
.bundle__compare{text-decoration-color:color-mix(in srgb,var(--danger) 70%,transparent)}
.bundle__save{
  box-shadow:0 0 0 3px color-mix(in srgb,var(--danger) 18%,transparent),
    0 6px 14px -6px color-mix(in srgb,var(--danger) 56%,transparent);
}
/* the bundle's CTA gets the warmest lamp-lift on the page */
.bundle__buy .btn--primary{
  box-shadow:var(--shadow-lg),
    inset 0 1px 0 color-mix(in srgb,#fff 36%,transparent),
    0 0 0 1px color-mix(in srgb,var(--accent) 30%,transparent),
    0 0 26px -6px color-mix(in srgb,var(--accent) 56%,transparent);
}

/* ============================================================
   11b. DISCOUNT / SAVINGS — base owns the structure via tokens.
        We add only small clinical glints: a coral struck rule
        (CORAL = stakes-rationed, and a price you'd lose is a
        legitimate stake) + a teal "you-save" mark.
   ============================================================ */
.price-was{text-decoration-color:color-mix(in srgb,var(--danger) 78%,transparent)}
.vol-save{
  box-shadow:0 4px 10px -4px color-mix(in srgb,var(--danger) 66%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 22%,transparent);
}
.vol-save-bar{background:color-mix(in srgb,var(--panel-ink) 10%,var(--panel))}
.vol-save-bar i{
  background:linear-gradient(90deg, var(--danger), color-mix(in srgb,var(--accent) 66%,var(--danger)));
  box-shadow:0 0 9px -1px color-mix(in srgb,var(--accent) 50%,transparent);
}
.you-save{font-family:"Roboto Mono", ui-monospace, monospace;color:var(--accent-2)}
.launch-note{color:var(--danger);letter-spacing:.05em}
.order-bump{border-style:dashed;border-color:color-mix(in srgb,var(--accent-2) 44%,var(--border))}

/* ============================================================
   11c. "WHAT'S INSIDE" CARDS — filed contents charts: a teal
        tick per line, an amber top chart-rule, the same physical
        edge language as the pricing charts.
   ============================================================ */
.inside__card{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg, color-mix(in srgb,var(--accent) 6%,var(--panel)), var(--panel));
  border-color:color-mix(in srgb,var(--accent) 20%,var(--border));
  box-shadow:
    var(--shadow-sm),
    inset 0 1px 0 color-mix(in srgb,#fff 50%,transparent),
    inset 0 0 0 1px color-mix(in srgb,var(--accent) 8%,transparent);
  transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s var(--ease);
}
.inside__card::before{
  content:"";position:absolute;left:0;right:0;top:0;height:2px;z-index:2;
  background:linear-gradient(90deg, var(--accent), color-mix(in srgb,var(--accent) 24%,transparent));
}
.inside__card:hover{
  transform:translateY(-4px);
  border-color:color-mix(in srgb,var(--accent) 34%,var(--border));
  box-shadow:var(--shadow), inset 0 1px 0 color-mix(in srgb,#fff 54%,transparent);
}
.inside__card h3{font-family:var(--font-display);letter-spacing:.006em}
.inside__tag{font-family:"Roboto Mono", ui-monospace, monospace;color:var(--danger);letter-spacing:.16em}
/* the square checklist mark becomes a teal vitals tick, matching the
   pricing bullets, so the two sections share one visual language */
.inside__list li::before{
  background:var(--accent-2);transform:rotate(45deg);border-radius:1px;
  box-shadow:0 0 0 2px color-mix(in srgb,var(--accent-2) 18%,transparent),
    0 0 6px 0 color-mix(in srgb,var(--accent-2) 40%,transparent);
}
.inside__note{font-style:italic}

/* ============================================================
   11d. REASSURANCE ROW — bench-note trust marks: a teal icon
        (the calm/rest color), soft slate text, set like a
        pencilled chart-margin line.
   ============================================================ */
.reassure__item{font-family:var(--font-body);color:color-mix(in srgb,var(--panel-ink) 74%,var(--panel))}
.reassure__item .ico{
  color:var(--accent-2);
  filter:drop-shadow(0 0 5px color-mix(in srgb,var(--accent-2) 36%,transparent));
}

/* ============================================================
   11e. SECTION SUB-RULE — "Prefer just one?" The connector rules
        become the amber chart-rule used across the chart.
   ============================================================ */
.section-sub{color:color-mix(in srgb,var(--ink) 60%,var(--page-bg));letter-spacing:.14em}
.section-sub::before,.section-sub::after{
  background:linear-gradient(90deg, transparent, color-mix(in srgb,var(--accent) 50%,transparent), transparent);
  height:2px;
}

/* ============================================================
   12. TRUST STRIP + VOL CHIPS — clinical accents that ride the
       semantic tokens (already themed for free); a touch of teal.
   ============================================================ */
.trust-strip__item svg{color:var(--accent-2)}
.vol-chips__lbl{font-family:"Roboto Mono", ui-monospace, monospace}

/* ============================================================
   13. THE SAFETY CHIP — the ONE place coral is loud on purpose.
       The "not-for" / objection block carries the see-a-doctor /
       911 register: a coral left-rule + a small coral SAFETY chip,
       so the page's single alarm color marks the single real stake.
   ============================================================ */
.not-for{
  border-left:3px solid var(--danger);
  background:color-mix(in srgb,var(--danger) 6%,transparent);
  position:relative;
}
.not-for::before{
  content:"SAFETY";position:absolute;top:-.72rem;left:1rem;
  font-family:"Roboto Mono", ui-monospace, monospace;font-size:.62rem;font-weight:700;letter-spacing:.18em;
  color:#fff;background:var(--danger);
  padding:.2rem .55rem;border-radius:var(--r-pill);
  box-shadow:0 4px 10px -5px color-mix(in srgb,var(--danger) 80%,transparent);
}

/* ============================================================
   14. GUARANTEE — a clinician's STAMP seal on a cream chart card.
       A teal struck-medallion (the calm/trust register) with a
       fine sand ring, reading as an embossed exam-room stamp.
   ============================================================ */
.guarantee{
  background:linear-gradient(180deg, color-mix(in srgb,var(--accent) 5%,var(--panel)), var(--panel));
  border-top:3px solid color-mix(in srgb,var(--accent) 52%,transparent);
  box-shadow:var(--shadow-sm), inset 0 1px 0 color-mix(in srgb,#fff 54%,transparent);
}
.guarantee .seal{
  background:
    repeating-conic-gradient(from 0deg, color-mix(in srgb,#fff 12%,var(--accent-2)) 0 12deg, var(--accent-2) 12deg 24deg);
  box-shadow:
    inset 0 0 0 3px color-mix(in srgb,#fff 22%,transparent),
    0 0 0 4px color-mix(in srgb,var(--accent) 22%,transparent),
    var(--shadow-sm);
  border:2px solid color-mix(in srgb,#fff 28%,transparent);
}
/* reviews-empty: a candid clinical chart-paper placeholder */
.reviews-empty{
  border-style:solid;font-style:italic;
  border-color:color-mix(in srgb,var(--accent) 28%,var(--hair));
  background:repeating-linear-gradient(45deg, transparent 0 13px, color-mix(in srgb,var(--accent) 5%,transparent) 13px 14px);
}

/* ============================================================
   15. COMPARE BAND — the recommended column reads as the chosen
       chart: an amber lamp ring (base owns the structure via
       --accent; we add a warm glow + keep coral on the row keys).
   ============================================================ */
.compare__col--ours{
  box-shadow:var(--shadow),
    0 0 0 5px color-mix(in srgb,var(--accent) 16%,transparent),
    0 26px 56px -34px color-mix(in srgb,var(--accent) 50%,transparent);
}
.compare__k{font-family:"Roboto Mono", ui-monospace, monospace}

/* ============================================================
   16. OFFER / COUNTDOWN — vault tally plates (if ever enabled).
   ============================================================ */
.cd-unit{
  background:color-mix(in srgb,#16212A 26%,var(--deep));
  border:1px solid color-mix(in srgb,var(--accent) 26%,transparent);
  box-shadow:inset 0 1px 0 color-mix(in srgb,#fff 9%,transparent);
}
.cd-unit b{font-family:var(--font-display);color:var(--accent);text-shadow:0 0 14px color-mix(in srgb,var(--accent) 46%,transparent)}
.offer__hold b{color:var(--accent)}

/* ============================================================
   17. FAQ — fine chart-rule rows, an amber "+" that swings open.
   ============================================================ */
.faq__item{border-bottom-color:color-mix(in srgb,var(--accent) 20%,var(--hair))}
.faq__q{font-family:var(--font-display);letter-spacing:.004em;transition:color .2s var(--ease)}
.faq__q:hover{color:var(--accent)}
.faq__q .chev{color:var(--accent)}
/* inside the dark .band, keep the accent legible against slate */
.band .faq__q:hover{color:var(--accent)}

/* ============================================================
   18. STICKY CTA — a calm clinic service-bar. A fine amber seam,
       a clear price, an unmissable tap target; reads instantly,
       never fights the page.
   ============================================================ */
.sticky-cta{
  background:
    radial-gradient(60% 220% at 0% 50%, color-mix(in srgb,var(--accent) 12%,transparent), transparent 60%),
    color-mix(in srgb,var(--deep) 95%,transparent);
  border-top:1px solid color-mix(in srgb,var(--accent) 40%,transparent);
  box-shadow:0 -14px 34px -16px rgba(0,0,0,.6), 0 -1px 0 color-mix(in srgb,var(--accent) 28%,transparent);
}
.sticky-cta::before{
  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{font-family:var(--font-display);color:var(--on-deep);letter-spacing:.006em}
.sticky-cta__price{color:color-mix(in srgb,var(--on-deep) 80%,transparent);font-style:italic}
.sticky-cta__price s{color:color-mix(in srgb,var(--on-deep) 48%,transparent)}

/* ============================================================
   19. NEWSLETTER — the 5% chart-note. Token-driven (themes for
       free); a teal top accent + a mono badge so it reads clinical.
   ============================================================ */
.nl__card{border-top-color:var(--accent-2)}
.nl__badge{font-family:"Roboto Mono", ui-monospace, monospace;letter-spacing:.14em}
.nl__head{font-family:var(--font-display);letter-spacing:.006em}
.nl-strip__txt b{font-family:var(--font-display)}
.nl-pill{font-family:"Roboto Mono", ui-monospace, monospace}

/* ============================================================
   20. FOOTER — the slate clinic floor, an amber top chart-rail
       + a faint dotted chart grain.
   ============================================================ */
.footer{
  border-top:1px solid color-mix(in srgb,var(--accent) 26%,transparent);
  background:
    radial-gradient(100% 70% at 50% 0%, color-mix(in srgb,var(--accent) 8%,transparent), transparent 58%),
    linear-gradient(180deg, var(--deep), color-mix(in srgb,#16212A 22%,var(--deep)));
}
.footer h4{color:var(--accent);font-family:"Roboto Mono", ui-monospace, monospace}
.footer a:hover{color:var(--accent)}
.disclaimer-box{border-left:3px solid color-mix(in srgb,var(--danger) 60%,transparent)}

/* ============================================================
   21. LEGAL DOCS — keep the amber chart-rule motif on headings.
   ============================================================ */
.doc h2{color:var(--accent);position:relative}
.doc .back{font-family:"Roboto Mono", ui-monospace, monospace}

/* ============================================================
   22. RESPONSIVE — ease heavy decoration so nothing crowds; drop
       the fixed wash on mobile so scroll stays smooth.
   ============================================================ */
@media (max-width:760px){
  body{background-attachment:scroll, scroll, scroll, scroll, scroll}
  body::before{display:none}
  .hero__art--face::after{top:10px;left:10px;width:16px;height:16px}
  .author::after{display:none}
}
/* the card frame is built from inset shadows; it scales with the box
   and never overflows. On narrow screens pull the seam ring in a touch
   so base.css's tighter card padding never clips it. */
@media (max-width:480px){
  .vol-card{box-shadow:
    var(--shadow-sm),
    0 14px 26px -20px color-mix(in srgb,var(--accent) 30%,transparent),
    inset 0 1px 0 color-mix(in srgb,#fff 54%,transparent),
    inset 0 0 0 1px color-mix(in srgb,var(--panel) 62%,transparent),
    inset 0 0 0 5px var(--panel),
    inset 0 0 0 6px color-mix(in srgb,var(--accent) 16%,transparent)}
  .hero__title::after{width:88%}
}

/* ============================================================
   23. MOTION DISCIPLINE — calm, clinical, NEVER bouncy. This
       cohort reads flashy motion as a hustle. Full reduced-motion
       honor: kill every decorative movement.
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  .brandmark .dot{animation:none}
  .btn--primary:hover{filter:none}
  .vol-card:hover,.vol-card--feature:hover,.inside__card:hover,
  .hero__art--face:hover img{transform:none}
  .hero__art--face img,.hero__art--face:hover img{transition:none}
  /* keep the "Most Popular" resting lift — it is layout emphasis, not motion */
  .vol-card--feature{transform:translateY(-3px)}
  .bundle::after{transition:none}
}

/* ============================================================================
   DARK MODE, SOFTENED WHITE  (2026-06-18)
   Per user: keep the original slate + the beautiful textured background; just
   take the bright white down a notch so it isn't so strong. We restore the
   ORIGINAL dark tokens (so the original two-mood textured body returns) and
   only soften the light text a little (still AAA, no glare) + keep the bundle
   value-ledger legible. `html:root` beats the inline tokens -> marcus only.
   ============================================================================ */
html:root{
  --page-bg:#1E2A33;   /* original slate + textured background (the look the user likes) */
  --deep:#16212A;
  --ink:#ECE5D4;       /* was bright #F4EFE6 -> a notch softer/warmer, ~11.6:1, not harsh */
  --on-deep:#ECE5D4;
}
/* comfortable reading rhythm for 50+ */
body{font-size:clamp(1.05rem,1rem + .28vw,1.16rem);line-height:1.66;letter-spacing:.004em}
p{line-height:1.72}

/* keep the bundle value-ledger clearly legible on the dark bundle (prices amber) */
.bundle__stack-row{color:#EAE2CD;font-size:1rem;line-height:1.5}
.bundle__stack-row > span:last-child{color:var(--accent);font-weight:700}
.bundle__stack-total{color:#F2EAD6;font-weight:700;
  border-top-color:color-mix(in srgb,var(--accent) 52%,transparent)}
.bundle__stack-total > span:last-child{color:var(--accent)}

