/* ============================================================
   RXGRAB OVERHAUL v3 — "Editorial Receipt" baseline
   Loaded AFTER styles.css on every page via _worker.js head injection.
   Defines RxGrab's full design system + adapter overrides for the
   legacy engine-rendered nav/footer/disclosure markup, so untouched
   article and drug pages inherit the new visual on next load.
   ============================================================ */

:root{
  --paper:#faf6ef;
  --paper-deep:#f3ede1;
  --paper-card:#fffdf8;
  --paper-alt:#f7f2e8;
  --ink-900:#0f1310;
  --ink-800:#1f2520;
  --ink-700:#3a4640;
  --ink-600:#5b6760;
  --ink-500:#8a9690;
  --ink-400:#b4bdb7;
  --ink-300:#dad9d0;
  --ink-200:#ebe7dd;
  --ink-100:#f3efe5;

  --teal:#0f766e;
  --teal-deep:#0d6560;
  --teal-tint:#e7f5f2;
  --sky:#0ea5e9;
  --sky-deep:#0284c7;

  --win:#0a8a3c;
  --win-deep:#076e30;
  --win-tint:#e6f5ec;
  --warn:#c2410c;
  --warn-tint:#fde7dc;
  --warn-deep:#9a3408;

  --indigo:#3730a3;
  --indigo-tint:#eef0fb;

  --display:'Fraunces',Georgia,'Times New Roman',serif;
  --ui:'Inter',system-ui,-apple-system,sans-serif;
  --body:'DM Sans',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',monospace;

  --max:1180px;
  --max-narrow:760px;
  --max-mid:980px;

  /* Adapter: remap legacy styles.css tokens used by inherited components so
     they stay coherent without per-file edits. */
  --accent:var(--teal);
  --accent-light:var(--teal-tint);
  --accent-hover:var(--teal-deep);
  --secondary:var(--win);
  --secondary-light:var(--win-tint);
  --secondary-hover:var(--win-deep);
  --dark:var(--ink-900);
  --dark-mid:var(--ink-800);
  --muted:var(--ink-500);
  --text:var(--ink-800);
  --text-light:var(--ink-600);
  --border:var(--ink-200);
  --cream:var(--paper-deep);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{
  font-family:var(--body);
  color:var(--ink-800);
  background:var(--paper);
  font-size:16px;
  line-height:1.65;
  background-image:
    radial-gradient(rgba(15,19,16,.012) 1px, transparent 1px),
    radial-gradient(rgba(15,19,16,.012) 1px, transparent 1px);
  background-size:24px 24px, 24px 24px;
  background-position:0 0, 12px 12px;
  background-attachment:initial;
}
a{color:var(--teal);text-decoration:none}
img{max-width:100%;height:auto}

/* ============= TOP RIBBON ============= */
.ribbon{
  background:var(--ink-900);color:var(--paper);
  font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;
  padding:8px 24px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
}
.ribbon .pulse{display:inline-block;width:7px;height:7px;border-radius:100px;background:#22c55e;animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.55}50%{opacity:1}}
.ribbon strong{color:#fff;font-weight:600}
.ribbon .sep{color:#4b5550}
.ribbon .right{margin-left:auto;color:#9aa39d}
.ribbon .right a{color:#c7cdc9;text-decoration:none}
.ribbon .right a:hover{color:#fff}

/* ============= NEW NAV (homepage uses nav.top) ============= */
nav.top{
  border-bottom:1px solid var(--ink-200);padding:14px 24px;
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(8px);
  background:rgba(250,246,239,.94);
  display:block;grid-template-columns:none;max-width:none;margin:0;
}
.top-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:32px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand-mark{
  width:34px;height:34px;border-radius:8px;background:var(--ink-900);color:var(--paper);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-.02em;position:relative;
}
.brand-mark::after{content:'';position:absolute;right:-2px;bottom:-2px;width:10px;height:10px;background:var(--win);border-radius:50%;border:2px solid var(--paper)}
.brand-name{font-family:var(--display);font-weight:600;font-size:20px;color:var(--ink-900);letter-spacing:-.018em;line-height:1}
.brand-tag{font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-500);margin-top:3px}
nav.top .nav-links{display:flex;gap:22px;list-style:none;margin-left:auto;align-items:center;padding:0}
nav.top .nav-links a{font-family:var(--ui);font-size:14px;font-weight:500;color:var(--ink-700)}
nav.top .nav-links a:hover{color:var(--teal)}
nav.top .nav-cta{background:var(--ink-900);color:var(--paper);padding:9px 18px;border-radius:6px;font-family:var(--ui);font-size:13.5px;font-weight:600;display:inline-flex;align-items:center;gap:6px}
nav.top .nav-cta:hover{background:var(--teal);color:var(--paper);transform:none}

/* ============= LEGACY ENGINE NAV ADAPTER ============================
   The site_engine.js still renders the original markup:
   <nav class="nav"><div class="nav-left">...</div><a class="nav-brand">...</a><div class="nav-right"><a class="nav-cta">...</a></div></nav>
   These rules restyle THAT markup with the new tokens so every
   engine-rendered page (all 19 articles, 50 drug pages, tools, about,
   methodology) gets the new look without per-file or engine edits.
   ==================================================================== */
nav.nav,nav:not(.top){
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  max-width:var(--max);margin:0 auto;padding:14px 24px;
  border-bottom:1px solid var(--ink-200);background:rgba(250,246,239,.94);
  backdrop-filter:saturate(140%) blur(8px);position:sticky;top:0;z-index:50;
}
nav.nav .nav-left,nav:not(.top) .nav-left{display:flex;align-items:center;gap:1.5rem}
nav.nav .nav-left a,nav:not(.top) .nav-left a{font-family:var(--ui);font-size:14px;font-weight:500;color:var(--ink-700);text-decoration:none}
nav.nav .nav-left a:hover,nav:not(.top) .nav-left a:hover{color:var(--teal)}
nav.nav .nav-brand,nav:not(.top) .nav-brand{
  font-family:var(--display);font-weight:600;font-size:20px;color:var(--ink-900);
  background:transparent;padding:0;letter-spacing:-.018em;text-decoration:none;justify-self:center;
}
nav.nav .nav-brand span,nav:not(.top) .nav-brand span{color:var(--teal)}
nav.nav .nav-right,nav:not(.top) .nav-right{display:flex;align-items:center;justify-content:flex-end;gap:1rem}
nav.nav .nav-cta,nav:not(.top) .nav-cta{
  background:var(--ink-900);color:var(--paper);padding:9px 18px;border-radius:6px;
  font-family:var(--ui);font-size:13.5px;font-weight:600;text-decoration:none;white-space:nowrap;
}
nav.nav .nav-cta:hover,nav:not(.top) .nav-cta:hover{background:var(--teal);color:var(--paper);transform:none}

/* Legacy breadcrumbs adapter */
.breadcrumbs{
  max-width:var(--max);margin:0 auto;padding:10px 24px;
  font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;
  color:var(--ink-600);background:var(--paper-deep);border-bottom:1px solid var(--ink-200);
}
.breadcrumbs a{color:var(--ink-700);text-decoration:none}
.breadcrumbs a:hover{color:var(--teal)}

/* ============= HERO ============= */
.hero{padding:40px 24px 24px;border-bottom:1px solid var(--ink-200);max-width:none;margin:0;text-align:left;background:transparent}
/* minmax(0,...) on both tracks prevents content min-width from blowing out
   the fr ratios — without this, the long h1 + cred-strip squeeze the
   anchor-tool down to ~38px wide. */
.hero-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:minmax(0,1.3fr) minmax(360px,1fr);gap:48px;align-items:start}
@media(max-width:920px){.hero-inner{grid-template-columns:1fr;gap:32px}}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--teal);
  margin-bottom:16px;
}
.hero-eyebrow .pill{background:var(--teal);color:#fff;padding:3px 9px;border-radius:3px;font-size:9.5px;letter-spacing:.08em}
.hero-eyebrow .line{width:22px;height:1px;background:var(--ink-300)}
h1.hero-title,.hero h1{
  font-family:var(--display);font-size:clamp(36px,5.6vw,60px);font-weight:500;
  line-height:1.02;letter-spacing:-.024em;color:var(--ink-900);margin-bottom:18px;
  font-variation-settings:"opsz" 144;
}
h1.hero-title em,.hero h1 em{font-style:italic;color:var(--teal);font-weight:400}
.hero-dek,.hero p{font-size:19px;line-height:1.55;color:var(--ink-700);max-width:580px;font-weight:400;margin-bottom:20px}
.hero-byline{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-family:var(--ui);font-size:13px;color:var(--ink-600);padding:14px 0;border-top:1px solid var(--ink-200);border-bottom:1px solid var(--ink-200);margin-bottom:24px}
.hero-byline .avatar{width:36px;height:36px;border-radius:50%;background:var(--teal-tint);color:var(--teal-deep);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:700;font-size:13px;flex-shrink:0}
.hero-byline strong{color:var(--ink-900);font-weight:600}
.hero-byline .sep{color:var(--ink-300)}
.hero-byline .meta{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--ink-500)}
.hero-tag{font-family:var(--mono);font-size:11px;color:var(--teal);text-transform:uppercase;letter-spacing:.12em;margin-bottom:1rem;display:block}
.hero-cta{display:inline-block;padding:.875rem 2rem;background:var(--ink-900);color:var(--paper);font-family:var(--ui);font-weight:600;font-size:15px;text-decoration:none;border-radius:8px;transition:background .14s}
.hero-cta:hover{background:var(--teal);color:var(--paper);transform:none}

/* HERO CREDIBILITY STRIP — LaunchKits-grade card character
   Each cell is now its own multi-layer card: parchment foundation + radial
   teal glow + inset highlight + corner pip + display-font number with
   monospace subtext. Eye lands on the big number, reads the subtext, moves
   to the next card. No more "wall of grid cells." */
.cred-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
  background:transparent;border:0;border-radius:0;overflow:visible;
  margin-top:14px;max-width:none;padding:0;
}
@media(max-width:680px){.cred-strip{grid-template-columns:repeat(2,1fr);gap:8px}}
.cred-cell{
  position:relative;padding:18px 18px 16px;border:1px solid var(--ink-200);border-right:1px solid var(--ink-200);
  background:
    radial-gradient(120% 80% at 100% 0%,rgba(15,118,110,.06) 0%,transparent 55%),
    linear-gradient(180deg,var(--paper-card) 0%,#fbf7ef 100%);
  border-radius:12px;
  box-shadow:0 1px 0 rgba(255,253,247,.9) inset,0 1px 0 var(--ink-100),0 8px 22px -16px rgba(15,19,16,.18);
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;
}
.cred-cell::before{
  content:'';position:absolute;top:10px;right:10px;width:6px;height:6px;border-radius:50%;
  background:var(--teal);opacity:.35;box-shadow:0 0 0 3px rgba(15,118,110,.08);
}
.cred-cell:hover{transform:translateY(-2px);border-color:var(--teal);box-shadow:0 1px 0 rgba(255,253,247,.9) inset,0 1px 0 var(--ink-100),0 14px 28px -18px rgba(15,19,16,.24)}
.cred-cell:last-child{border-right:1px solid var(--ink-200)}
.cred-label{
  font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.14em;
  color:var(--ink-500);font-weight:700;margin-bottom:8px;
  display:inline-flex;align-items:center;gap:8px;
}
.cred-label::before{content:'';width:14px;height:1px;background:var(--ink-300)}
.cred-value{
  font-family:var(--display);font-weight:600;font-size:22px;color:var(--ink-900);
  letter-spacing:-.018em;line-height:1.1;margin-top:0;font-variation-settings:"opsz" 144;
}
.cred-meta{
  font-family:var(--mono);font-size:10.5px;color:var(--ink-500);margin-top:6px;line-height:1.45;
  padding-top:8px;border-top:1px dashed var(--ink-200);
}

/* HERO RIGHT — anchor tool live mock (LaunchKits depth: inset highlight,
   subtle radial accent behind, lifted shadow, glow ring on hover) */
.anchor-tool{
  position:relative;background:
    radial-gradient(120% 70% at 100% 0%,rgba(15,118,110,.06) 0%,transparent 50%),
    linear-gradient(180deg,var(--paper-card) 0%,#fbf7ef 100%);
  border:1px solid var(--ink-200);border-radius:16px;overflow:hidden;
  box-shadow:
    0 1px 0 rgba(255,253,247,.9) inset,
    0 1px 0 var(--ink-100),
    0 18px 44px -22px rgba(15,19,16,.22),
    0 4px 12px -8px rgba(15,118,110,.08);
  transition:transform .2s ease,box-shadow .2s ease;
}
.anchor-tool:hover{transform:translateY(-2px);box-shadow:0 1px 0 rgba(255,253,247,.9) inset,0 1px 0 var(--ink-100),0 22px 50px -22px rgba(15,19,16,.28),0 6px 16px -8px rgba(15,118,110,.14)}
.at-head{
  padding:14px 18px;background:var(--ink-900);color:#fff;
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;font-weight:600;
}
.at-head .live{display:flex;align-items:center;gap:6px;color:#22c55e}
.at-head .live .d{width:6px;height:6px;background:#22c55e;border-radius:50%;animation:pulse 2s infinite}
.at-body{padding:18px 20px}
.at-input{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--ink-300);border-radius:8px;background:var(--paper);margin-bottom:12px;font-family:var(--mono);font-size:13px;color:var(--ink-700)}
.at-input .ic{color:var(--ink-400)}
.at-input .typed{color:var(--ink-900);font-weight:600}
.at-input .cursor{display:inline-block;width:1.5px;height:14px;background:var(--teal);margin-left:2px;animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}
.at-result{font-family:var(--mono);font-size:12.5px}
.at-result-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dotted var(--ink-200)}
.at-result-row:last-of-type{border-bottom:0}
.at-result-row .name{color:var(--ink-700)}
.at-result-row .price{font-weight:600;color:var(--ink-900);font-variant-numeric:tabular-nums}
.at-result-row.win{background:var(--win-tint);margin:0 -20px;padding:8px 20px;border-bottom-color:transparent}
.at-result-row.win .name{color:var(--win-deep);font-weight:700}
.at-result-row.win .name::before{content:'✓ ';color:var(--win)}
.at-result-row.win .price{color:var(--win-deep);font-weight:700}
.at-foot{padding:12px 20px;border-top:1px solid var(--ink-200);background:var(--paper);font-family:var(--mono);font-size:11px;color:var(--ink-500);display:flex;justify-content:space-between}
.at-foot strong{color:var(--win-deep);font-weight:700;font-size:13px}

/* ============= SECTION BANNER ============= */
.section-banner{padding:8px 24px;background:var(--paper-deep);border-bottom:1px solid var(--ink-200)}
.section-banner-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-600);font-weight:700;padding:6px 0}
.section-banner-inner .crumb{display:flex;gap:14px;align-items:center}
.section-banner-inner .crumb span.sep{color:var(--ink-400)}
.section-banner-inner .right{color:var(--ink-500);font-weight:500;letter-spacing:.06em;text-transform:none;font-size:11px}

/* ============= WHY DIFFERENT ============= */
.why{padding:60px 24px;background:var(--paper-deep);border-bottom:1px solid var(--ink-200)}
.why-inner{max-width:var(--max);margin:0 auto}
.why-head{margin-bottom:36px;max-width:680px}
.why-eyebrow{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--teal);margin-bottom:12px}
.why-title{font-family:var(--display);font-size:clamp(28px,3.6vw,40px);font-weight:500;letter-spacing:-.02em;color:var(--ink-900);line-height:1.1;margin-bottom:14px;font-variation-settings:"opsz" 144}
.why-title em{font-style:italic;color:var(--teal);font-weight:400}
.why-sub{font-size:16px;color:var(--ink-700);line-height:1.55}
/* WHY cards — multi-layer LaunchKits treatment: radial corner glow + inset
   highlight + numbered chip moment + over-sized stat that anchors the eye */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;background:transparent;border:0;border-radius:0;overflow:visible}
@media(max-width:880px){.why-grid{grid-template-columns:1fr}}
.why-card{
  position:relative;background:
    radial-gradient(140% 100% at 0% 0%,rgba(15,118,110,.05) 0%,transparent 50%),
    linear-gradient(180deg,var(--paper-card) 0%,#fbf7ef 100%);
  padding:32px 30px 30px;border:1px solid var(--ink-200);border-radius:14px;
  box-shadow:0 1px 0 rgba(255,253,247,.9) inset,0 1px 0 var(--ink-100),0 16px 36px -22px rgba(15,19,16,.22);
  transition:transform .18s ease,border-color .18s ease;
}
.why-card:hover{transform:translateY(-3px);border-color:var(--teal)}
.why-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--teal) 0%,var(--teal-deep) 100%);
  border-radius:14px 14px 0 0;opacity:.85;
}
.why-card .tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--teal);font-weight:700;margin-bottom:14px;
  background:var(--teal-tint);padding:5px 10px 5px 8px;border-radius:4px;
}
.why-card .tag::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--teal)}
.why-card h3{font-family:var(--display);font-size:24px;font-weight:600;color:var(--ink-900);letter-spacing:-.018em;line-height:1.18;margin-bottom:12px;font-variation-settings:"opsz" 144}
.why-card p{font-size:14.5px;color:var(--ink-700);line-height:1.6;margin-bottom:0}
.why-card .stat{
  font-family:var(--display);font-size:44px;font-weight:600;color:var(--teal);
  letter-spacing:-.028em;line-height:1;margin-top:24px;padding-top:18px;border-top:1px dashed var(--ink-200);
  font-variation-settings:"opsz" 144;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
}
.why-card .stat span{font-size:10.5px;color:var(--ink-500);font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin-left:0}

/* ============= ARTICLE LAYOUT (sticky TOC variant for flagships) ============= */
.article-wrap{max-width:var(--max);margin:0 auto;padding:48px 24px}
.article-wrap.with-toc{display:grid;grid-template-columns:200px 1fr;gap:48px}
@media(max-width:980px){.article-wrap.with-toc{grid-template-columns:1fr;gap:0;padding:32px 24px}}
.toc{position:sticky;top:90px;align-self:start;font-family:var(--ui);font-size:13px}
@media(max-width:980px){.toc{display:none}}
.toc-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-500);font-weight:700;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--ink-200)}
.toc ol{list-style:none;counter-reset:toc;padding:0;margin:0}
.toc li{counter-increment:toc;margin-bottom:10px;padding-left:28px;position:relative;line-height:1.4}
.toc li::before{content:counter(toc,decimal-leading-zero);position:absolute;left:0;top:1px;font-family:var(--mono);font-size:10.5px;color:var(--ink-400);font-weight:600;letter-spacing:.04em}
.toc li a{color:var(--ink-700);font-weight:500;font-size:13px}
.toc li a:hover{color:var(--teal)}
.toc li.active a{color:var(--teal-deep);font-weight:600}
.toc li.active::before{color:var(--teal)}
.toc-meta{margin-top:24px;padding-top:18px;border-top:1px solid var(--ink-200);font-family:var(--mono);font-size:10.5px;color:var(--ink-500);line-height:1.6}
.toc-meta strong{color:var(--ink-700);font-weight:600;display:block;margin-bottom:2px;text-transform:uppercase;letter-spacing:.08em;font-size:9.5px}

article{max-width:none;min-width:0}

/* drop cap */
.intro::first-letter{
  font-family:var(--display);font-weight:500;float:left;
  font-size:74px;line-height:.86;padding:8px 12px 0 0;color:var(--teal);
  font-variation-settings:"opsz" 144;
}

/* ============= IN-ARTICLE TYPOGRAPHY ============= */
article h2,.article-wrap h2{
  font-family:var(--display);font-size:clamp(28px,3.4vw,36px);font-weight:500;
  letter-spacing:-.022em;color:var(--ink-900);line-height:1.12;
  margin:56px 0 18px;padding-top:28px;border-top:1px solid var(--ink-200);
  font-variation-settings:"opsz" 100;
  display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;
}
article h2 .num,.article-wrap h2 .num{
  font-family:var(--mono);font-size:13px;color:var(--ink-500);font-weight:600;letter-spacing:.04em;
  border:1px solid var(--ink-300);padding:3px 9px;border-radius:4px;
  flex-shrink:0;align-self:center;transform:translateY(-2px);
}
article h3,.article-wrap h3{font-family:var(--display);font-size:22px;font-weight:600;color:var(--ink-900);margin:32px 0 12px;letter-spacing:-.014em}
article p,.article-wrap p{margin-bottom:18px;font-size:17px;line-height:1.72;color:var(--ink-800)}
article p a,.article-wrap p a{color:var(--teal);text-decoration:underline;text-decoration-color:rgba(15,118,110,.35);text-underline-offset:3px;text-decoration-thickness:1.5px}
article p a:hover,.article-wrap p a:hover{color:var(--teal-deep);text-decoration-color:var(--teal-deep)}
article strong,.article-wrap strong{color:var(--ink-900);font-weight:600}
article ul,article ol,.article-wrap ul,.article-wrap ol{margin:0 0 20px 22px;font-size:16.5px;line-height:1.7;color:var(--ink-800);padding-left:0}
article li,.article-wrap li{margin-bottom:8px}
article li::marker,.article-wrap li::marker{color:var(--teal)}

/* SUPERSCRIPT CITATIONS — Wirecutter pattern */
sup.cite{font-family:var(--mono);font-size:9.5px;color:var(--indigo);font-weight:700;background:var(--indigo-tint);padding:1px 5px;border-radius:3px;margin-left:2px;cursor:help;vertical-align:super;text-decoration:none}
sup.cite::before{content:''}

/* ============= PHARMACY SCORE CARD (overhauled — overrides legacy) ============= */
.score-card{
  background:var(--paper-card);border:1px solid var(--ink-200);border-radius:14px;
  padding:28px;margin:32px 0;display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:start;
  box-shadow:none;
}
@media(max-width:640px){.score-card{grid-template-columns:1fr;gap:20px}}
.score-badge{
  width:108px;height:108px;border-radius:50%;
  background:conic-gradient(var(--win) 0deg 327deg, var(--ink-200) 327deg 360deg);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;
}
.score-badge::before{content:'';position:absolute;inset:8px;border-radius:50%;background:var(--paper-card)}
.score-badge .n{position:relative;font-family:var(--display);font-size:34px;font-weight:600;color:var(--ink-900);letter-spacing:-.02em;line-height:1;font-variation-settings:"opsz" 144}
.score-badge .n span{font-size:18px;color:var(--ink-500);font-weight:500}
.score-badge.b{background:conic-gradient(var(--win) 0deg 285deg, var(--ink-200) 285deg 360deg)}
.score-badge.c{background:conic-gradient(var(--warn) 0deg 264deg, var(--ink-200) 264deg 360deg)}
.sc-body .sc-tag{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-500);font-weight:700;margin-bottom:6px}
.sc-body h4{font-family:var(--display);font-size:24px;font-weight:600;color:var(--ink-900);letter-spacing:-.014em;line-height:1.18;margin-bottom:8px}
.sc-body .verdict{font-size:14.5px;color:var(--ink-700);line-height:1.5;margin-bottom:14px}
.sc-attrs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding-top:14px;border-top:1px solid var(--ink-200)}
@media(max-width:520px){.sc-attrs{grid-template-columns:1fr 1fr}}
.sc-attrs .a{display:flex;flex-direction:column;gap:2px}
.sc-attrs .a .lbl{font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-500);font-weight:600}
.sc-attrs .a .val{font-family:var(--mono);font-size:13px;color:var(--ink-900);font-weight:600;font-variant-numeric:tabular-nums}
.sc-attrs .a .val.win{color:var(--win-deep)}

/* RECEIPT TAPE */
.receipt{
  background:#fdfaf3;border:1px solid var(--ink-200);border-radius:6px;
  padding:18px 22px;font-family:var(--mono);font-size:13px;color:var(--ink-800);
  margin:28px 0;position:relative;box-shadow:0 1px 0 var(--ink-100),0 8px 24px -12px rgba(15,19,16,.08);
}
.receipt::before,.receipt::after{content:'';position:absolute;left:0;right:0;height:12px;background-image:radial-gradient(circle at 6px 6px, var(--paper) 5px, transparent 5px);background-size:12px 12px;background-repeat:repeat-x}
.receipt::before{top:-6px}.receipt::after{bottom:-6px;transform:rotate(180deg)}
.receipt-head{display:flex;justify-content:space-between;padding-bottom:10px;margin-bottom:12px;border-bottom:1px dashed var(--ink-300);font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-500);font-weight:600}
.receipt-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dotted var(--ink-200)}
.receipt-row:last-of-type{border-bottom:0}
.receipt-row .name{color:var(--ink-800)}
.receipt-row .price{font-weight:600;color:var(--ink-900);font-variant-numeric:tabular-nums}
.receipt-row.win{background:var(--win-tint);margin:0 -22px;padding:6px 22px;border-bottom-color:transparent}
.receipt-row.win .name{color:var(--win-deep);font-weight:600}
.receipt-row.win .name::before{content:'✓ ';color:var(--win)}
.receipt-row.win .price{color:var(--win-deep)}
.receipt-foot{margin-top:12px;padding-top:10px;border-top:1px dashed var(--ink-300);display:flex;justify-content:space-between;font-size:11.5px;color:var(--ink-600)}
.receipt-foot strong{color:var(--win-deep);font-weight:700;font-size:14px}

/* BATTLE CARD */
.battle{display:grid;grid-template-columns:1fr auto 1fr;gap:0;background:var(--paper-card);border:1px solid var(--ink-200);border-radius:14px;overflow:hidden;margin:32px 0}
@media(max-width:640px){.battle{grid-template-columns:1fr}}
.b-side{padding:24px 26px;position:relative}
.b-side.winner{background:var(--win-tint)}
.b-side .b-name{font-family:var(--display);font-size:22px;font-weight:600;color:var(--ink-900);letter-spacing:-.012em;margin-bottom:4px}
.b-side .b-tag{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-500);margin-bottom:14px;font-weight:600}
.b-side .b-price{font-family:var(--mono);font-size:30px;font-weight:600;color:var(--ink-900);font-variant-numeric:tabular-nums;margin-bottom:10px}
.b-side.winner .b-price{color:var(--win-deep)}
.b-side .b-price .unit{font-size:13px;font-weight:500;color:var(--ink-500);margin-left:4px}
.b-side ul.b-attr{list-style:none;font-size:13.5px;color:var(--ink-700);line-height:1.6;margin:0;padding:0}
.b-side ul.b-attr li{padding:4px 0;display:flex;gap:8px;margin:0}
.b-side ul.b-attr li::marker{display:none;content:''}
.b-side ul.b-attr li::before{content:'›';color:var(--ink-400);flex-shrink:0}
.b-side .winner-badge{position:absolute;top:14px;right:14px;background:var(--win);color:#fff;font-family:var(--mono);font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:3px 9px;border-radius:3px}
.b-vs{background:var(--ink-900);color:var(--paper);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-style:italic;font-size:22px;font-weight:500;padding:0 18px;min-width:54px}
@media(max-width:640px){.b-vs{padding:8px 0;min-width:auto}}

/* PULL QUOTE */
.pullquote{margin:36px -8px;padding:24px 28px;font-family:var(--display);font-style:italic;font-weight:400;font-size:26px;line-height:1.32;color:var(--ink-900);letter-spacing:-.014em;border-left:3px solid var(--teal);font-variation-settings:"opsz" 144}
.pullquote cite{display:block;margin-top:10px;font-family:var(--mono);font-size:11px;font-style:normal;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-500);font-weight:600}

/* CALLOUT (overrides legacy) */
.callout{background:var(--paper-card);border:1px solid var(--ink-200);border-left:3px solid var(--teal);padding:18px 22px;border-radius:0 8px 8px 0;margin:26px 0;font-size:15.5px;line-height:1.6}
.callout.warn,.callout.warning{border-left-color:var(--warn);background:var(--warn-tint)}
.callout.win,.callout.success{border-left-color:var(--win);background:var(--win-tint)}
.callout.indigo{border-left-color:var(--indigo);background:var(--indigo-tint)}
.callout.tip{border-left-color:var(--warn);background:var(--warn-tint)}
.callout strong{display:block;margin-bottom:6px;font-family:var(--ui);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-900)}
.callout.warn strong,.callout.warning strong{color:var(--warn-deep)}
.callout.win strong,.callout.success strong{color:var(--win-deep)}
.callout.indigo strong{color:var(--indigo)}

/* DATA TABLE (overrides legacy) */
.data-table{width:100%;border-collapse:collapse;margin:28px 0;font-family:var(--body);font-size:14px;background:var(--paper-card);border:1px solid var(--ink-200);border-radius:8px;overflow:hidden;box-shadow:none}
.data-table th{text-align:left;padding:12px 16px;background:var(--ink-900);color:var(--paper);font-family:var(--mono);font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.data-table td{padding:13px 16px;border-top:1px solid var(--ink-200);color:var(--ink-800);font-variant-numeric:tabular-nums}
.data-table tr:nth-child(even) td{background:var(--paper)}
.data-table td.win{color:var(--win-deep);font-weight:700;background:var(--win-tint) !important}
.data-table td.win::before{content:'✓ ';color:var(--win)}
.data-table td.x{color:var(--ink-400)}

/* ============= MATH BLOCK ============= */
.math-block{margin:40px 0;background:var(--paper-card);border:1px solid var(--ink-200);border-radius:14px;overflow:hidden}
.math-head{padding:22px 28px;background:var(--ink-900);color:#fff}
.math-head .tag{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:#9aa39d;font-weight:600;margin-bottom:8px}
.math-head h3{font-family:var(--display);font-size:26px;font-weight:500;color:#fff;letter-spacing:-.014em;line-height:1.2;margin:0;font-variation-settings:"opsz" 144}
.math-head h3 em{font-style:italic;color:var(--win);font-weight:400}
.math-table{width:100%;border-collapse:collapse;font-size:14px}
.math-table th{text-align:left;padding:11px 22px;background:var(--paper-alt);color:var(--ink-700);font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--ink-200)}
.math-table th:last-child{text-align:right}
.math-table td{padding:14px 22px;border-bottom:1px solid var(--ink-200);color:var(--ink-800);vertical-align:middle}
.math-table td:last-child{text-align:right;font-family:var(--mono);font-weight:700;font-variant-numeric:tabular-nums;color:var(--ink-900)}
.math-table tr.win td{background:var(--win-tint)}
.math-table tr.win td:first-child{font-weight:700;color:var(--win-deep)}
.math-table tr.win td:first-child::before{content:'✓ ';color:var(--win);font-weight:700}
.math-table tr.win td:last-child{color:var(--win-deep)}
.math-table tr:last-child td{border-bottom:0}
.math-table .row-label{font-weight:600;color:var(--ink-900)}
.math-table .sub{display:block;font-family:var(--mono);font-size:11px;color:var(--ink-500);margin-top:2px;font-weight:500}

/* ============= METHODOLOGY STRIPE ============= */
.method{background:var(--paper-deep);border-top:1px solid var(--ink-200);border-bottom:1px solid var(--ink-200);padding:60px 24px;margin:48px -24px}
@media(max-width:980px){.method{margin:48px -24px;padding:48px 24px}}
.method-inner{max-width:var(--max-mid);margin:0 auto}
.method-eyebrow{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--teal);margin-bottom:12px}
.method-title{font-family:var(--display);font-size:32px;font-weight:500;color:var(--ink-900);letter-spacing:-.02em;line-height:1.12;margin-bottom:14px;font-variation-settings:"opsz" 144;max-width:580px}
.method-title em{font-style:italic;color:var(--teal);font-weight:400}
.method-sub{font-size:15.5px;color:var(--ink-700);line-height:1.55;max-width:560px;margin-bottom:32px}
.method-sub a{color:var(--teal);text-decoration:underline}
/* Override legacy .method-grid (3-col) with the new 6-col rhythm */
.method .method-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0;background:var(--ink-200);border:1px solid var(--ink-200);border-radius:10px;overflow:hidden;max-width:none;padding:0;margin:0}
@media(max-width:920px){.method .method-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.method .method-grid{grid-template-columns:repeat(2,1fr)}}
.method .method-cell{background:var(--paper-card);padding:20px 18px;position:relative;border:0;border-radius:0;transform:none}
.method .method-cell .ix{font-family:var(--mono);font-size:11px;color:var(--ink-400);letter-spacing:.04em;font-weight:600;margin-bottom:10px}
.method .method-cell h5{font-family:var(--display);font-size:15px;font-weight:600;color:var(--ink-900);letter-spacing:-.008em;line-height:1.25;margin-bottom:6px;margin-top:0}
.method .method-cell p{font-size:12.5px;color:var(--ink-600);line-height:1.5;margin:0}

/* ============= SWITCHING FROM ============= */
.switch{padding:60px 24px;border-bottom:1px solid var(--ink-200)}
.switch-inner{max-width:var(--max);margin:0 auto}
.switch-eyebrow{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--teal);margin-bottom:12px}
.switch-title{font-family:var(--display);font-size:32px;font-weight:500;color:var(--ink-900);letter-spacing:-.02em;line-height:1.12;margin-bottom:12px;font-variation-settings:"opsz" 144;max-width:600px;border:0;padding:0;display:block}
.switch-title em{font-style:italic;color:var(--teal);font-weight:400}
.switch-sub{font-size:15.5px;color:var(--ink-700);line-height:1.55;max-width:540px;margin-bottom:28px}
.switch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:880px){.switch-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.switch-grid{grid-template-columns:1fr}}
.switch-card{
  position:relative;background:
    radial-gradient(120% 80% at 100% 0%,rgba(10,138,60,.06) 0%,transparent 55%),
    linear-gradient(180deg,var(--paper-card) 0%,#fbf7ef 100%);
  border:1px solid var(--ink-200);border-radius:14px;padding:22px 24px 20px;
  text-decoration:none;color:inherit;display:block;
  box-shadow:0 1px 0 rgba(255,253,247,.9) inset,0 1px 0 var(--ink-100),0 10px 26px -18px rgba(15,19,16,.18);
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;
}
.switch-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--win) 0%,var(--win-deep) 100%);
  border-radius:14px 14px 0 0;opacity:0;transition:opacity .18s ease;
}
.switch-card:hover{transform:translateY(-3px);border-color:var(--win);box-shadow:0 1px 0 rgba(255,253,247,.9) inset,0 1px 0 var(--ink-100),0 18px 36px -20px rgba(15,19,16,.28)}
.switch-card:hover::before{opacity:1}
.switch-card .from{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-500);font-weight:700;margin-bottom:10px;
  background:var(--ink-100);padding:4px 9px;border-radius:4px;
}
.switch-card .from::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--ink-400)}
.switch-card .name{font-family:var(--display);font-size:22px;font-weight:600;color:var(--ink-900);letter-spacing:-.014em;margin-bottom:6px;font-variation-settings:"opsz" 144}
.switch-card .sub{font-size:13px;color:var(--ink-600);line-height:1.5;margin-bottom:18px}
.switch-card .stat{display:flex;align-items:baseline;gap:10px;padding-top:16px;border-top:1px dashed var(--ink-200);flex-wrap:wrap}
.switch-card .stat .v{font-family:var(--display);font-size:34px;font-weight:600;color:var(--win-deep);letter-spacing:-.024em;line-height:1;font-variation-settings:"opsz" 144}
.switch-card .stat .u{font-family:var(--mono);font-size:10px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.12em;font-weight:700}
.switch-card .go{font-family:var(--mono);font-size:11px;color:var(--teal);font-weight:700;margin-top:14px;display:inline-flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.1em;transition:gap .18s ease}
.switch-card .go::after{content:'→';transition:transform .18s ease}
.switch-card:hover .go{gap:10px;color:var(--teal-deep)}
.switch-card:hover .go::after{transform:translateX(2px)}

/* ============= BIG STAT BANK — LaunchKits dark-mode card grid =============
   Each stat is its own floating card with radial green/teal glow corners,
   inset highlight, and a HUGE Fraunces number that the eye sees first.
   Subtext under does the explaining. */
.stats-bank{
  background:
    radial-gradient(60% 80% at 0% 0%,rgba(10,138,60,.10) 0%,transparent 55%),
    radial-gradient(60% 80% at 100% 100%,rgba(15,118,110,.10) 0%,transparent 55%),
    var(--ink-900);
  color:#fff;padding:64px 24px;border-bottom:1px solid var(--ink-200);
  position:relative;
}
.stats-bank::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:18px 18px;
}
.stats-bank-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:12px;border:0;border-radius:0;overflow:visible;position:relative}
@media(max-width:780px){.stats-bank-inner{grid-template-columns:repeat(2,1fr);gap:10px}}
.stat-c{
  position:relative;padding:24px 22px;border:1px solid #2a3530;border-radius:12px;
  background:
    radial-gradient(120% 80% at 100% 0%,rgba(10,138,60,.10) 0%,transparent 55%),
    linear-gradient(180deg,#13180f 0%,#0c100a 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset,0 12px 28px -20px rgba(0,0,0,.6);
  transition:transform .18s ease,border-color .18s ease;
}
.stat-c::before{
  content:'';position:absolute;top:12px;right:12px;width:6px;height:6px;border-radius:50%;
  background:var(--win);opacity:.55;box-shadow:0 0 0 3px rgba(10,138,60,.18);
}
.stat-c:hover{transform:translateY(-2px);border-color:var(--win)}
.stat-c .lbl{
  font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.14em;
  color:#7a847e;font-weight:700;margin-bottom:14px;
  display:inline-flex;align-items:center;gap:8px;
}
.stat-c .lbl::before{content:'';width:14px;height:1px;background:#3a4640}
.stat-c .v{
  font-family:var(--display);font-size:52px;font-weight:600;color:#fff;
  letter-spacing:-.028em;line-height:.95;font-variation-settings:"opsz" 144;
  display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;
}
.stat-c .v em{font-style:italic;color:var(--win);font-weight:400;font-size:.55em;letter-spacing:0}
.stat-c .sub{
  font-size:12px;color:#9aa39d;margin-top:14px;line-height:1.5;
  padding-top:12px;border-top:1px dashed #2a3530;font-family:var(--body);
}

/* ============= REVIEWERS ============= */
.reviewers{padding:60px 24px;border-bottom:1px solid var(--ink-200)}
.reviewers-inner{max-width:var(--max-mid);margin:0 auto}
.rv-eyebrow{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--indigo);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.rv-eyebrow .line{width:22px;height:1px;background:var(--ink-300)}
.rv-title{font-family:var(--display);font-size:30px;font-weight:500;color:var(--ink-900);letter-spacing:-.02em;line-height:1.12;margin-bottom:14px;max-width:600px;font-variation-settings:"opsz" 144;border:0;padding:0;display:block}
.rv-title em{font-style:italic;color:var(--indigo);font-weight:400}
.rv-sub{font-size:15.5px;color:var(--ink-700);line-height:1.55;max-width:580px;margin-bottom:28px}
.rv-sub a{color:var(--teal);text-decoration:underline}
.rv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:760px){.rv-grid{grid-template-columns:1fr}}
.rv-card{
  position:relative;display:flex;gap:18px;padding:24px;
  background:
    radial-gradient(120% 80% at 100% 0%,rgba(55,48,163,.05) 0%,transparent 55%),
    linear-gradient(180deg,var(--paper-card) 0%,#fbf7ef 100%);
  border:1px solid var(--ink-200);border-radius:14px;align-items:flex-start;
  box-shadow:0 1px 0 rgba(255,253,247,.9) inset,0 1px 0 var(--ink-100),0 10px 24px -18px rgba(15,19,16,.18);
  transition:transform .18s ease,border-color .18s ease;
}
.rv-card:hover{transform:translateY(-2px);border-color:var(--indigo)}
.rv-photo{
  flex-shrink:0;width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,var(--indigo) 0%,#4f46a6 100%);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:600;font-size:20px;letter-spacing:-.01em;
  box-shadow:0 2px 0 rgba(255,255,255,.4) inset,0 6px 16px -8px rgba(55,48,163,.5);
  font-variation-settings:"opsz" 144;
}
.rv-name{font-family:var(--display);font-weight:600;color:var(--ink-900);font-size:17px;letter-spacing:-.012em;line-height:1.2;font-variation-settings:"opsz" 144}
.rv-cred{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10px;color:var(--indigo);text-transform:uppercase;letter-spacing:.12em;margin-top:6px;line-height:1.4;font-weight:700;
  background:var(--indigo-tint);padding:4px 9px;border-radius:4px;
}
.rv-bio{font-size:13px;color:var(--ink-600);margin-top:10px;line-height:1.55;padding-top:10px;border-top:1px dashed var(--ink-200)}

/* ============= CTA BLOCK (overrides legacy) ============= */
.cta-block{background:var(--ink-900);color:var(--paper);padding:32px;border-radius:14px;margin:40px 0;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;border:0}
@media(max-width:640px){.cta-block{grid-template-columns:1fr;text-align:left}}
.cta-block h4,.cta-block .cta-block-title{font-family:var(--display);font-size:22px;font-weight:500;color:#fff;margin-bottom:6px;letter-spacing:-.012em;line-height:1.2}
.cta-block p,.cta-block .cta-block-desc{color:#c7cdc9;font-size:14.5px;line-height:1.5;margin:0}
.cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--win);color:#fff;padding:14px 24px;border-radius:8px;font-family:var(--ui);font-weight:600;font-size:15px;text-decoration:none;white-space:nowrap;transition:background .14s}
.cta-btn:hover{background:var(--win-deep);color:#fff}
.cta-btn .arrow{transition:transform .14s}
.cta-btn:hover .arrow{transform:translateX(3px)}

/* EMAIL MICRO (overrides legacy) */
.email-micro{background:var(--teal-tint);border:1px solid #c4e5df;border-radius:10px;padding:18px 22px;margin:32px 0;display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center}
@media(max-width:640px){.email-micro{grid-template-columns:1fr}}
.email-micro .em-ic,.email-micro .email-micro-icon{font-size:24px}
.email-micro .em-text,.email-micro .email-micro-text{font-size:14.5px;color:var(--ink-800);line-height:1.45}
.email-micro .em-text strong,.email-micro .email-micro-text strong{color:var(--teal-deep);font-weight:700}
.email-micro form{display:flex;gap:8px}
.email-micro input,.email-micro .email-micro-input{padding:9px 12px;border:1px solid var(--ink-300);border-radius:6px;font-family:var(--body);font-size:13.5px;background:#fff;min-width:200px;max-width:none}
.email-micro button,.email-micro .email-micro-btn{background:var(--teal);color:#fff;border:0;border-radius:6px;padding:9px 18px;font-family:var(--ui);font-weight:600;font-size:13.5px;cursor:pointer}
.email-micro button:hover,.email-micro .email-micro-btn:hover{background:var(--teal-deep)}

/* FAQ (overrides legacy) */
.faq{margin:48px 0}
.faq-h,.faq-title{font-family:var(--display);font-size:30px;font-weight:500;color:var(--ink-900);margin-bottom:18px;letter-spacing:-.02em;font-variation-settings:"opsz" 144}
.faq-item{background:var(--paper-card);border:1px solid var(--ink-200);border-radius:10px;margin-bottom:10px;overflow:hidden;padding:0}
.faq-item summary{padding:18px 22px;cursor:pointer;list-style:none;font-family:var(--ui);font-weight:600;font-size:16px;color:var(--ink-900);display:flex;align-items:center;gap:12px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{content:''}
.faq-item summary::after{content:'+';margin-left:auto;color:var(--teal);font-family:var(--mono);font-size:20px;font-weight:600;transition:transform .15s}
.faq-item[open] summary::after{content:'−'}
.faq-item[open] summary::before{content:''}
.faq-item .a,.faq-item .faq-answer{padding:0 22px 18px;color:var(--ink-700);font-size:15.5px;line-height:1.65;border-top:1px solid var(--ink-100)}
.faq-item[open] .a,.faq-item[open] .faq-answer{padding-top:14px}

/* SOURCES CITED */
.sources{margin:48px 0;padding:32px;background:var(--paper-alt);border-radius:14px;border:1px solid var(--ink-200)}
.sources-h{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--indigo);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.sources-h .ct{background:var(--indigo);color:#fff;font-size:9.5px;padding:2px 7px;border-radius:3px;letter-spacing:.08em}
.sources ol{list-style:none;counter-reset:src;padding:0;margin:0}
.sources li{counter-increment:src;padding:8px 0;padding-left:32px;position:relative;font-size:13px;line-height:1.55;color:var(--ink-700);border-bottom:1px solid var(--ink-200)}
.sources li:last-child{border-bottom:0}
.sources li::before{content:counter(src,decimal-leading-zero);position:absolute;left:0;top:8px;font-family:var(--mono);font-size:10.5px;color:var(--indigo);font-weight:700;background:var(--indigo-tint);padding:1px 6px;border-radius:3px}
.sources li strong{color:var(--ink-900);font-weight:600}
.sources li a{color:var(--teal);text-decoration:underline}

/* RELATED (overrides legacy) */
.related{margin-top:56px;padding-top:36px;border-top:1px solid var(--ink-200)}
.related-h,.related-title{font-family:var(--display);font-size:26px;font-weight:500;color:var(--ink-900);margin-bottom:20px;letter-spacing:-.018em;font-variation-settings:"opsz" 144}
.related-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(max-width:600px){.related-grid{grid-template-columns:1fr}}
.rel-card,.related-card{display:flex;gap:16px;align-items:flex-start;text-decoration:none;color:inherit;background:var(--paper-card);border:1px solid var(--ink-200);padding:20px;border-radius:10px;transition:border-color .15s,transform .15s}
.rel-card:hover,.related-card:hover{border-color:var(--teal);transform:translateY(-2px);background:var(--paper-card);box-shadow:none}
.rel-score{width:48px;height:48px;border-radius:50%;background:var(--win-tint);color:var(--win-deep);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:600;font-size:15px;flex-shrink:0;border:2px solid var(--win)}
.rel-card .rt,.related-card .related-card-tag{font-family:var(--mono);font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--teal);margin-bottom:6px}
.rel-card h5,.related-card .related-card-title{font-family:var(--display);font-size:17px;font-weight:600;color:var(--ink-900);line-height:1.25;letter-spacing:-.008em;margin-bottom:6px}
.rel-card p{font-size:13px;color:var(--ink-600);line-height:1.5;margin:0}

/* ============= NETWORK STRIP ============= */
.network{background:var(--ink-900);color:#9aa39d;padding:48px 24px;border-bottom:1px solid #2a3530}
.network-inner{max-width:var(--max);margin:0 auto}
.network-eye{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#c7cdc9;margin-bottom:14px}
.network-title{font-family:var(--display);font-size:26px;font-weight:500;color:#fff;letter-spacing:-.016em;margin-bottom:8px;font-variation-settings:"opsz" 144}
.network-title em{font-style:italic;color:var(--win);font-weight:400}
.network-sub{font-size:14px;color:#9aa39d;max-width:580px;margin-bottom:28px;line-height:1.55}
.network-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;background:transparent;border:0;border-radius:0;overflow:visible}
@media(max-width:780px){.network-grid{grid-template-columns:repeat(2,1fr);gap:8px}}
.net-card{border:1px solid #2a3530;border-radius:12px}
.net-card{
  position:relative;background:
    radial-gradient(120% 80% at 100% 0%,rgba(10,138,60,.08) 0%,transparent 55%),
    var(--ink-900);
  padding:22px 22px 20px;text-decoration:none;color:#fff;
  transition:background .18s ease,transform .18s ease;
  overflow:hidden;
}
.net-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--win) 0%,var(--teal) 100%);
  opacity:0;transition:opacity .18s ease;
}
.net-card:hover{background:#13180f;transform:translateY(-2px)}
.net-card:hover::before{opacity:1}
.net-card .nt{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.14em;color:#7a847e;margin-bottom:12px;font-weight:700;
}
.net-card .nt::before{content:'';width:12px;height:1px;background:#4b5550}
.net-card .nn{font-family:var(--display);font-size:22px;font-weight:600;color:#fff;letter-spacing:-.018em;margin-bottom:6px;font-variation-settings:"opsz" 144}
.net-card .nn span{color:var(--win)}
.net-card .nd{font-size:12.5px;color:#9aa39d;line-height:1.5;padding-top:10px;margin-top:6px;border-top:1px dashed #2a3530}

/* STICKY MOBILE CTA */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--ink-900);color:#fff;padding:12px 16px;display:none;align-items:center;gap:12px;box-shadow:0 -8px 24px -10px rgba(15,19,16,.4)}
@media(max-width:640px){.sticky-cta{display:flex}}
.sticky-cta .s-text{flex:1;font-family:var(--ui);font-size:13px;line-height:1.3}
.sticky-cta .s-text strong{color:var(--win);font-family:var(--mono);font-weight:700}
.sticky-cta a{background:var(--win);color:#fff;padding:9px 16px;border-radius:6px;font-family:var(--ui);font-weight:600;font-size:13px;white-space:nowrap}

/* ============= NEW FOOTER (homepage uses footer.overhaul) ============= */
footer.overhaul,body > footer:last-of-type{background:#0a0d0b;color:#c7cdc9;padding:56px 24px 28px;max-width:none;margin:0;display:block;border:0}
footer.overhaul .f-inner,body > footer:last-of-type .f-inner{max-width:var(--max);margin:0 auto}
footer.overhaul .f-grid,body > footer:last-of-type .f-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px;margin-bottom:36px}
@media(max-width:780px){footer.overhaul .f-grid,body > footer:last-of-type .f-grid{grid-template-columns:1fr 1fr}}
footer.overhaul h6,body > footer:last-of-type h6{font-family:var(--ui);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#fff;margin-bottom:14px}
footer.overhaul ul,body > footer:last-of-type ul{list-style:none;padding:0;margin:0}
footer.overhaul li,body > footer:last-of-type li{margin-bottom:8px}
footer.overhaul a,body > footer:last-of-type a{color:#c7cdc9;font-size:13.5px;text-decoration:none}
footer.overhaul a:hover,body > footer:last-of-type a:hover{color:var(--win)}
footer.overhaul .f-brand,body > footer:last-of-type .f-brand{font-family:var(--display);font-size:22px;color:#fff;font-weight:500;letter-spacing:-.015em;margin-bottom:8px;display:block}
footer.overhaul .f-mission,body > footer:last-of-type .f-mission{font-size:13.5px;color:#9aa39d;line-height:1.55;max-width:280px}
footer.overhaul .f-foot,body > footer:last-of-type .f-foot{border-top:1px solid #2a3530;padding-top:20px;display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;color:#7a847e;letter-spacing:.04em;flex-wrap:wrap;gap:10px}
footer.overhaul .f-disc,body > footer:last-of-type .f-disc{font-size:11px;color:#7a847e;flex-basis:100%;margin-top:8px;line-height:1.55;font-family:var(--body)}

/* ============= LEGACY ENGINE FOOTER ADAPTER ============================
   site_engine.js renders:
   <footer><a class="footer-logo">RxGrab</a><ul class="footer-links">...</ul>
     <div class="footer-disclosure">...</div><p class="footer-note">...</p>
     <div class="footer-network">...</div></footer>
   These rules restyle THAT markup with the new dark palette so every
   engine-rendered page gets the new look.
   ==================================================================== */
footer:has(.footer-logo){
  background:#0a0d0b;color:#c7cdc9;padding:56px 24px 28px;
  max-width:none;margin:0;border:0;display:block;
}
footer:has(.footer-logo) .footer-logo{font-family:var(--display);font-size:22px;color:#fff;font-weight:500;letter-spacing:-.015em;text-decoration:none}
footer:has(.footer-logo) .footer-logo span{color:var(--win)}
footer:has(.footer-logo) .footer-links{list-style:none;display:flex;flex-wrap:wrap;gap:20px;padding:0;margin:18px 0}
footer:has(.footer-logo) .footer-links a{color:#c7cdc9;font-family:var(--ui);font-size:13.5px;text-decoration:none}
footer:has(.footer-logo) .footer-links a:hover{color:var(--win)}
footer:has(.footer-logo) .footer-disclosure{
  background:rgba(199,205,201,.05);border:1px solid #2a3530;border-radius:6px;
  padding:14px 16px;font-family:var(--body);font-size:11.5px;color:#9aa39d;
  line-height:1.55;margin:14px 0;text-align:left;flex-basis:100%;
}
footer:has(.footer-logo) .footer-disclosure a{color:var(--win);font-weight:600}
footer:has(.footer-logo) .footer-note{font-family:var(--body);font-size:11px;color:#7a847e;max-width:760px;line-height:1.6;flex-basis:100%;margin-top:8px}
footer:has(.footer-logo) .footer-network{font-family:var(--mono);font-size:10.5px;color:#7a847e;display:flex;flex-wrap:wrap;gap:14px;align-items:center;flex-basis:100%;margin-top:18px;padding-top:18px;border-top:1px solid #2a3530;letter-spacing:.04em}
footer:has(.footer-logo) .footer-network span{font-weight:700;color:#c7cdc9;margin-right:6px;text-transform:uppercase}
footer:has(.footer-logo) .footer-network a{color:#9aa39d;font-family:var(--mono);text-decoration:none;text-transform:uppercase;letter-spacing:.06em}
footer:has(.footer-logo) .footer-network a:hover{color:var(--win)}

/* ============= ARTICLE DISCLOSURE NOTICE (engine-rendered above-fold) ============= */
.affiliate-disclosure-notice{
  max-width:var(--max);margin:14px auto 0;padding:10px 16px;
  background:var(--paper-card);border:1px solid var(--ink-200);border-left:3px solid var(--indigo);
  border-radius:0 6px 6px 0;font-family:var(--ui);font-size:12px;color:var(--ink-700);line-height:1.5;
}
.affiliate-disclosure-notice strong{color:var(--ink-900);font-weight:700}
.affiliate-disclosure-notice a{color:var(--teal);font-weight:600;text-decoration:underline}

/* ============= LEGACY HOMEPAGE SECTIONS (untouched homepage cards) ============= */
.section{max-width:var(--max);margin:0 auto;padding:48px 24px}
.section-title{font-family:var(--display);font-size:28px;font-weight:500;color:var(--ink-900);margin-bottom:.5rem;letter-spacing:-.02em}
.section-sub{font-size:15px;color:var(--ink-600);margin-bottom:24px}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.guide-card{display:block;text-decoration:none;color:inherit;background:var(--paper-card);border:1px solid var(--ink-200);border-radius:12px;padding:22px;transition:border-color .15s,transform .15s}
.guide-card:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:none}
.guide-card-cat{font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--teal);margin-bottom:8px}
.guide-card-title{font-family:var(--display);font-size:17px;font-weight:600;color:var(--ink-900);margin-bottom:6px;line-height:1.3;letter-spacing:-.008em}
.guide-card-desc{font-size:13.5px;color:var(--ink-600);line-height:1.5}
.guide-card-tag{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-500);margin-top:10px}

/* ============= QUICK VERDICT (legacy article component override) ============= */
.quick-verdict{background:var(--teal-tint);border-left:3px solid var(--teal);padding:18px 22px;border-radius:0 8px 8px 0;margin:24px 0;font-size:15.5px}
.quick-verdict strong{display:block;font-family:var(--display);font-weight:600;margin-bottom:6px;color:var(--ink-900);font-size:16px}

/* ============= PRODUCT CARD (legacy override) ============= */
.product-card{background:var(--paper-card);border:1px solid var(--ink-200);border-radius:12px;padding:22px;margin:24px 0;position:relative;box-shadow:none}
.product-card-badge{position:absolute;top:-10px;left:16px;background:var(--teal);color:#fff;font-family:var(--mono);font-size:9.5px;font-weight:700;padding:3px 9px;border-radius:3px;text-transform:uppercase;letter-spacing:.08em}
.product-card-name{font-family:var(--display);font-size:20px;color:var(--ink-900);margin:8px 0 4px;font-weight:600;letter-spacing:-.012em}
.product-card-price{font-family:var(--mono);font-size:14px;color:var(--teal);font-weight:700;margin-bottom:10px}
.product-card-body{font-size:14px;color:var(--ink-700);line-height:1.6;margin-bottom:12px}
.product-card-body a{color:var(--teal)}

/* ============= WHO-BLOCK (legacy override) ============= */
.who-block{border:1px solid var(--ink-200);border-radius:12px;overflow:hidden;margin:24px 0;background:var(--paper-card)}
.who-block-header{padding:14px 22px;font-family:var(--display);font-weight:600;font-size:16px}
.who-block-header.good{background:var(--win-tint);color:var(--win-deep);border-bottom:1px solid #c8e8d4}
.who-block-header.bad{background:var(--warn-tint);color:var(--warn-deep);border-bottom:1px solid #f5cdb5}
.who-block-body{padding:14px 22px;font-size:14.5px;line-height:1.7;color:var(--ink-700)}
.who-block-body li{margin-bottom:6px}

/* ============= TIER LIST (legacy override) ============= */
.tier{margin:24px 0}
.tier-header{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--ink-900);color:#fff;border-radius:10px 10px 0 0;font-family:var(--display);font-size:15px;font-weight:600}
.tier-header .tier-badge{font-family:var(--mono);font-size:10px;padding:3px 8px;border-radius:3px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.tier-header .tier-badge.t1{background:var(--win);color:#fff}
.tier-header .tier-badge.t2{background:var(--warn);color:#fff}
.tier-header .tier-badge.t3{background:var(--ink-500);color:#fff}
.tier-body{border:1px solid var(--ink-200);border-top:0;border-radius:0 0 10px 10px;padding:18px 22px;background:var(--paper-card)}
.tier-body ul{margin:0;padding-left:18px;font-size:14.5px;line-height:1.8;color:var(--ink-700)}

/* ============= BUTTONS (legacy override) ============= */
.btn-deal{display:inline-block;padding:11px 22px;background:var(--win);color:#fff;font-family:var(--ui);font-weight:600;font-size:14px;text-decoration:none;border-radius:8px;transition:background .14s;box-shadow:none}
.btn-deal:hover{background:var(--win-deep);transform:none;text-decoration:none;box-shadow:none}
.btn-secondary{display:inline-block;padding:10px 20px;background:transparent;color:var(--teal);font-family:var(--ui);font-weight:600;font-size:14px;text-decoration:none;border:1.5px solid var(--teal);border-radius:8px;transition:all .14s}
.btn-secondary:hover{background:var(--teal);color:#fff}

/* ============= VS-GRID (legacy override) ============= */
.vs-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;margin:24px 0;align-items:center}
.vs-grid-card{background:var(--paper-card);border:1px solid var(--ink-200);border-radius:12px;padding:20px;text-align:center;box-shadow:none}
.vs-grid-card-name{font-family:var(--display);font-size:18px;color:var(--ink-900);margin-bottom:6px;font-weight:600}
.vs-grid-card-price{font-family:var(--mono);font-size:13px;color:var(--teal);font-weight:700}
.vs-grid-divider{font-family:var(--display);font-style:italic;font-size:22px;color:var(--ink-500);font-weight:500}
@media(max-width:600px){.vs-grid{grid-template-columns:1fr;gap:12px}.vs-grid-divider{text-align:center}}

/* ============= AD ZONE alignment ============= */
.ad-zone{max-width:var(--max);margin:32px auto;min-height:0}
.ad-zone:empty{display:none}

/* ============= PRINT ============= */
@media print{nav.top,nav.nav,nav:not(.top),.ribbon,.email-micro,.email-strip,.ad-zone,.sticky-cta,.network,.cred-strip{display:none}body{background:#fff}}
