/* Nerve Harmony - Harmonic Violet theme
   nh- component classes + [data-*] variants + native nesting (pseudo only)
   cascade: reset / tokens / base / layout / components / sections / utilities / responsive */

/* ---- reset ---- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body,h1,h2,h3,h4,p,figure,blockquote,ul,ol,dl,dd{margin:0}
ul[class],ol[class]{list-style:none;padding:0}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none}
table{border-collapse:collapse;width:100%}

/* ---- tokens ---- */
:root{
  --ink:#1d172e;
  --muted:#5f5878;
  --soft:#7a7396;
  --violet-900:#3b0f73;
  --violet-800:#4c1d95;
  --violet-700:#5b21b6;
  --violet-600:#6d28d9;
  --amethyst:#7c3aed;
  --lav-50:#faf8ff;
  --lav-100:#f3effc;
  --lav-200:#e8dffa;
  --line:#e7e1f3;
  --amber:#f6a821;
  --amber-600:#cf8508;
  --amber-ink:#3a2606;
  --good:#2f8a5b;
  --bg:#ffffff;
  --paper:#faf8ff;
  --grad:linear-gradient(135deg,#3b0f73 0%,#5b21b6 52%,#7c3aed 100%);
  --shadow-sm:0 1px 2px rgba(40,15,90,.06),0 2px 6px rgba(40,15,90,.05);
  --shadow:0 10px 30px rgba(50,20,100,.10);
  --shadow-lg:0 22px 50px rgba(50,20,100,.18);
  --r-sm:8px;--r:14px;--r-lg:22px;--r-pill:999px;
  --wrap:1140px;--narrow:760px;
  --serif:"Source Serif 4",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,-apple-system,"Segoe UI",sans-serif;
}

/* ---- base ---- */
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--serif);line-height:1.16;font-weight:600;color:var(--ink);letter-spacing:-.01em}
h1{font-size:clamp(2rem,4.6vw,3.25rem)}
h2{font-size:clamp(1.6rem,3.2vw,2.4rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{margin-bottom:1rem}
strong{font-weight:700;color:#2a2140}
:focus-visible{outline:3px solid var(--amethyst);outline-offset:2px;border-radius:4px}

/* ---- layout primitives ---- */
.nh-wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:20px}
.nh-narrow{max-width:var(--narrow);margin-inline:auto;padding-inline:20px}
.nh-cols{display:grid;gap:24px}
@media(min-width:760px){
  .nh-cols[data-cols="2"]{grid-template-columns:repeat(2,1fr)}
  .nh-cols[data-cols="3"]{grid-template-columns:repeat(3,1fr)}
  .nh-cols[data-cols="4"]{grid-template-columns:repeat(4,1fr)}
}
.nh-section{padding:64px 0}
.nh-section[data-tint]{background:var(--paper)}
.nh-section[data-tint="lav"]{background:var(--lav-100)}

/* ---- skip + a11y ---- */
.nh-skip{position:absolute;left:-9999px;top:0;background:var(--violet-800);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 var(--r-sm) 0}
.nh-skip:focus{left:0}

/* ---- ribbon ---- */
.nh-ribbon{background:var(--violet-900);color:#efe9ff;font-size:.82rem;text-align:center;padding:7px 16px;letter-spacing:.02em}
.nh-ribbon b{color:#fff}

/* ---- header ---- */
.nh-head{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nh-head-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0}
.nh-brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:700;font-size:1.18rem;color:var(--violet-800)}
.nh-brand small{display:block;font-family:var(--sans);font-weight:600;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--soft)}
.nh-mark{width:34px;height:34px;border-radius:9px;background:var(--grad);display:grid;place-items:center;color:#fff;font-family:var(--sans);font-weight:800;font-size:1.05rem;box-shadow:var(--shadow-sm)}
.nh-nav{display:flex;align-items:center;gap:22px}
.nh-nav a{font-size:.94rem;font-weight:600;color:var(--muted)}
.nh-nav a:hover,.nh-nav a[aria-current="page"]{color:var(--violet-700)}
.nh-burger{display:none;width:44px;height:44px;border-radius:10px;border:1px solid var(--line);font-size:1.3rem;color:var(--violet-800)}

/* ---- buttons ---- */
.nh-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:800;border-radius:var(--r-pill);padding:13px 26px;line-height:1.1;transition:transform .12s ease,box-shadow .12s ease;text-align:center}
.nh-btn[data-kind="cta"]{background:var(--amber);color:var(--amber-ink);box-shadow:0 8px 20px rgba(207,133,8,.32)}
.nh-btn[data-kind="cta"]:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(207,133,8,.4)}
.nh-btn[data-kind="violet"]{background:var(--violet-700);color:#fff;box-shadow:0 8px 20px rgba(91,33,182,.28)}
.nh-btn[data-kind="violet"]:hover{transform:translateY(-2px)}
.nh-btn[data-kind="ghost"]{border:1.5px solid var(--lav-200);color:var(--violet-700);background:#fff}
.nh-btn[data-kind="ghost"]:hover{border-color:var(--amethyst)}
.nh-btn[data-size="lg"]{padding:16px 34px;font-size:1.05rem}

/* ---- badges / chips ---- */
.nh-badges{display:flex;flex-wrap:wrap;gap:8px}
.nh-chip{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--violet-800);background:var(--lav-100);border:1px solid var(--lav-200);padding:6px 11px;border-radius:var(--r-pill)}
.nh-chip[data-tone="amber"]{color:var(--amber-ink);background:#fdf2dc;border-color:#f6dca0}

/* ---- hero ---- */
.nh-hero{background:var(--grad);color:#fff;padding:54px 0 64px;position:relative;overflow:hidden}
.nh-hero::after{content:"";position:absolute;inset:0;background:radial-gradient(700px 320px at 80% 0,rgba(255,255,255,.16),transparent 60%);pointer-events:none}
.nh-hero h1{color:#fff}
.nh-hero-grid{display:grid;gap:36px;align-items:center;position:relative;z-index:2}
@media(min-width:860px){.nh-hero-grid{grid-template-columns:1.1fr .9fr}}
.nh-hero .nh-eyebrow{display:inline-block;font-size:.8rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#e3d4ff;margin-bottom:14px}
.nh-hero p.lede{font-size:1.12rem;color:#ede6ff;max-width:46ch}
.nh-hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin:24px 0 18px}
.nh-hero-trust{display:flex;flex-wrap:wrap;gap:16px;font-size:.84rem;color:#ddd0fb}
.nh-hero-trust span{display:inline-flex;align-items:center;gap:6px}
.nh-hero-img{position:relative}
.nh-hero-img img{margin-inline:auto;filter:drop-shadow(0 24px 40px rgba(0,0,0,.35))}
.nh-tagline{font-family:var(--serif);font-style:italic;color:#f4d99a;font-size:1.05rem;margin-top:6px}

/* ---- portal sentence ---- */
.nh-portal{background:var(--lav-50);border:1px solid var(--lav-200);border-left:4px solid var(--amethyst);border-radius:var(--r);padding:18px 22px;font-size:1rem;color:#37305a}
.nh-portal b{color:var(--violet-800)}

/* ---- TL;DR ---- */
.nh-tldr{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 26px;box-shadow:var(--shadow-sm)}
.nh-tldr h2{font-size:1.15rem;display:flex;align-items:center;gap:10px;margin-bottom:8px}
.nh-tldr .tag{font-family:var(--sans);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;background:var(--violet-700);color:#fff;padding:4px 9px;border-radius:var(--r-pill)}
.nh-tldr p{margin-bottom:0;color:#3a3358}

/* ---- key facts ---- */
.nh-facts{width:100%;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);background:#fff}
.nh-facts caption{caption-side:top;text-align:left;font-family:var(--serif);font-size:1.3rem;font-weight:600;padding:18px 20px 6px}
.nh-facts th,.nh-facts td{text-align:left;padding:12px 20px;border-top:1px solid var(--line);vertical-align:top;font-size:.96rem}
.nh-facts th{width:38%;color:var(--muted);font-weight:700}
.nh-facts td{color:var(--ink);font-weight:600}
.nh-facts tr:nth-child(even){background:var(--lav-50)}

/* ---- cards ---- */
.nh-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-sm)}
.nh-card h3{margin-bottom:8px}
.nh-num{font-family:var(--serif);font-size:1.4rem;color:var(--amethyst);font-weight:700}

/* ---- pillar / ingredient ---- */
.nh-pillar{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-sm)}
.nh-pillar .dose{display:inline-block;background:var(--lav-100);color:var(--violet-800);font-weight:800;border-radius:var(--r-pill);padding:3px 12px;font-size:.85rem;margin-bottom:8px}

/* ---- verify table ---- */
.nh-vtable{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.nh-vtable caption{caption-side:top;text-align:left;font-family:var(--serif);font-size:1.25rem;padding:18px 20px 4px}
.nh-vtable th,.nh-vtable td{padding:13px 20px;border-top:1px solid var(--line);text-align:left;font-size:.95rem}
.nh-vtable th{color:var(--muted);font-weight:700;width:46%}
.nh-vtable td{font-weight:600}
.nh-verifybadge{display:inline-flex;align-items:center;gap:6px;color:var(--good);font-weight:700;font-size:.85rem}

/* ---- pricing ---- */
.nh-price-grid{display:grid;gap:24px;align-items:stretch}
@media(min-width:820px){.nh-price-grid{grid-template-columns:repeat(3,1fr)}}
.nh-plan{position:relative;background:#fff;border:1.5px solid var(--line);border-radius:var(--r-lg);padding:28px 24px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}
.nh-plan[data-pop]{border-color:var(--amethyst);box-shadow:var(--shadow-lg);transform:translateY(-6px)}
.nh-plan[data-pop]::before{content:attr(data-pop);position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--amber);color:var(--amber-ink);font-weight:800;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;padding:6px 16px;border-radius:var(--r-pill);white-space:nowrap}
.nh-plan h3{text-align:center}
.nh-plan .sub{text-align:center;color:var(--muted);font-size:.92rem;margin-bottom:14px}
.nh-plan .bottles{margin:6px auto 14px;max-width:200px}
.nh-plan .ppb{text-align:center;font-family:var(--serif)}
.nh-plan .ppb b{font-size:2.6rem;color:var(--violet-800);font-weight:700}
.nh-plan .ppb span{color:var(--muted);font-size:.9rem}
.nh-plan .was{text-align:center;color:var(--soft);text-decoration:line-through;font-size:.95rem}
.nh-plan .tot{text-align:center;font-weight:700;margin:4px 0 2px}
.nh-plan .ship{text-align:center;font-size:.86rem;color:var(--good);font-weight:700;margin-bottom:16px}
.nh-plan .nh-btn{width:100%;margin-top:auto}
.nh-plan ul{margin:0 0 18px;display:grid;gap:7px}
.nh-plan li{font-size:.9rem;color:var(--muted);padding-left:22px;position:relative}
.nh-plan li::before{content:"✓";position:absolute;left:0;color:var(--amethyst);font-weight:800}

/* ---- review / testimonial ---- */
.nh-stars{color:var(--amber);letter-spacing:1px}
.nh-quote{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-sm)}
.nh-quote .who{display:flex;align-items:center;gap:12px;margin-top:14px}
.nh-avatar{width:42px;height:42px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.9rem}
.nh-quote .who b{display:block;font-size:.92rem}
.nh-quote .who small{color:var(--soft)}
.nh-vb{font-size:.72rem;color:var(--good);font-weight:800;text-transform:uppercase;letter-spacing:.04em}

/* ---- ratings bars ---- */
.nh-bar{display:grid;grid-template-columns:140px 1fr 48px;align-items:center;gap:12px;margin-bottom:10px;font-size:.9rem}
.nh-bar .track{height:9px;background:var(--lav-100);border-radius:var(--r-pill);overflow:hidden}
.nh-bar .fill{height:100%;background:var(--grad);border-radius:var(--r-pill)}
.nh-bar b{text-align:right;color:var(--violet-800)}

/* ---- stat snapshot ---- */
.nh-stat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px;text-align:center;box-shadow:var(--shadow-sm)}
.nh-stat b{display:block;font-family:var(--serif);font-size:1.9rem;color:var(--violet-800);line-height:1}
.nh-stat span{font-size:.82rem;color:var(--muted);font-weight:600}

/* ---- takeaways ---- */
.nh-take{background:var(--lav-50);border:1px solid var(--lav-200);border-radius:var(--r-lg);padding:26px}
.nh-take h2{margin-bottom:12px}
.nh-take ul{display:grid;gap:10px}
.nh-take li{position:relative;padding-left:30px;color:#37305a}
.nh-take li::before{content:"◆";position:absolute;left:6px;color:var(--amethyst)}

/* ---- Q&A ---- */
.nh-qa{border-top:1px solid var(--line);padding-top:22px;margin-top:22px}
.nh-qa h3{margin-bottom:6px}
.nh-qa .ans{font-weight:600;color:#2a2140;margin-bottom:6px}

/* ---- big rating ---- */
.nh-bigrate{display:flex;flex-wrap:wrap;align-items:center;gap:26px;background:var(--grad);color:#fff;border-radius:var(--r-lg);padding:30px 32px}
.nh-bigrate .score{font-family:var(--serif);font-size:3.6rem;font-weight:700;line-height:1}
.nh-bigrate small{color:#e3d4ff}

/* ---- breadcrumb ---- */
.nh-crumb{font-size:.84rem;color:var(--soft);padding:14px 0}
.nh-crumb a{color:var(--violet-700);font-weight:600}
.nh-crumb a:hover{text-decoration:underline}

/* ---- byline ---- */
.nh-byline{font-size:.86rem;color:var(--soft);border-left:3px solid var(--lav-200);padding-left:14px;margin:6px 0 22px}
.nh-byline b{color:var(--muted)}

/* ---- prose ---- */
.nh-prose h2{margin:34px 0 12px}
.nh-prose h3{margin:24px 0 8px}
.nh-prose p,.nh-prose li{color:#3a3358}
.nh-prose ul{margin:0 0 16px;display:grid;gap:8px}
.nh-prose ul li{padding-left:24px;position:relative}
.nh-prose ul li::before{content:"–";position:absolute;left:6px;color:var(--amethyst);font-weight:800}

/* ---- forms ---- */
.nh-field{display:block;margin-bottom:16px}
.nh-field label{display:block;font-weight:700;font-size:.9rem;margin-bottom:6px;color:var(--muted)}
.nh-field input,.nh-field select,.nh-field textarea{width:100%;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:12px 14px;font:inherit;background:#fff}
.nh-field input:focus,.nh-field textarea:focus,.nh-field select:focus{border-color:var(--amethyst);outline:none}

/* ---- dl glossary ---- */
.nh-gloss dt{font-weight:800;color:var(--violet-800);margin-top:14px}
.nh-gloss dd{margin:2px 0 0;color:#3a3358}

/* ---- comparison table ---- */
.nh-compare{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.nh-compare th,.nh-compare td{padding:12px 16px;border-top:1px solid var(--line);text-align:left;font-size:.92rem}
.nh-compare thead th{background:var(--violet-800);color:#fff;border:0}
.nh-compare td[data-yes]{color:var(--good);font-weight:700}

/* ---- final cta ---- */
.nh-final{background:var(--grad);color:#fff;border-radius:var(--r-lg);padding:48px 34px;text-align:center}
.nh-final h2{color:#fff}
.nh-final p{color:#ede6ff;max-width:54ch;margin-inline:auto}

/* ---- footer ---- */
.nh-foot{background:#1a1330;color:#cabfe6;font-size:.9rem;padding:52px 0 26px;margin-top:10px}
.nh-foot h4{color:#fff;font-family:var(--sans);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.nh-foot a{color:#cabfe6}
.nh-foot a:hover{color:#fff}
.nh-foot-grid{display:grid;gap:30px}
@media(min-width:760px){.nh-foot-grid{grid-template-columns:1.6fr 1fr 1fr 1fr}}
.nh-foot ul{display:grid;gap:8px}
.nh-foot-brand b{color:#fff;font-family:var(--serif);font-size:1.15rem}
.nh-foot-legal{border-top:1px solid #322a4d;margin-top:30px;padding-top:20px;font-size:.8rem;color:#9d92bd}
.nh-foot-legal p{margin-bottom:10px}
.nh-updated{font-size:.82rem;color:#9d92bd}

/* ---- utilities ---- */
.u-center{text-align:center}
.u-mt0{margin-top:0}.u-mb0{margin-bottom:0}
.u-lede{font-size:1.1rem;color:var(--muted)}
.u-eyebrow{font-size:.8rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--amethyst);margin-bottom:8px}
.u-mw{max-width:62ch}
.u-stack>*+*{margin-top:14px}

/* ---- responsive nav ---- */
@media(max-width:880px){
  .nh-burger{display:grid;place-items:center}
  .nh-nav{position:fixed;inset:62px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-bottom:1px solid var(--line);padding:8px 20px 18px;box-shadow:var(--shadow);display:none}
  .nh-nav[data-open="true"]{display:flex}
  .nh-nav a{padding:12px 4px;border-bottom:1px solid var(--lav-100)}
  .nh-nav .nh-btn{margin-top:12px}
}
@media(max-width:560px){
  .nh-section{padding:46px 0}
  .nh-bigrate .score{font-size:2.8rem}
}
