:root {
  --page-bg: #FFFFFF;
  --ink: #2C221E;
  --muted: rgba(44, 34, 30, .66);
  --paper: #F4EFEA;
  --surface: rgba(244, 239, 234, .74);
  --surface-soft: rgba(255, 252, 247, .38);
  --espresso: #2C221E;
  --cacao: #2C221E;
  --accent: #1C352D;
  --footer-bg: #4B4038;
  --line: rgba(44, 34, 30, .14);
  --line-strong: rgba(44, 34, 30, .28);
  --shadow: 0 28px 90px rgba(44, 34, 30, .06);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Helvetica, "Helvetica Neue", Arial, sans-serif;
  font-size: 15px;
  font-weight: 300;
  color: var(--ink);
  background: var(--page-bg);
  line-height: 1.72;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}
.scroll-reveal {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity .7s ease, transform .8s cubic-bezier(.22, 1, .36, 1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}
.scroll-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
a { color: inherit; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 20px clamp(20px, 4vw, 64px);
  background: rgba(244, 239, 234, .86);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
}
.brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; font-size: 16px; font-weight: 300; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); }
.brand-logo { display: block; width: 34px; height: 34px; object-fit: contain; padding: 7px; border-radius: 50%; background: var(--accent); mix-blend-mode: normal; }
nav { display: flex; align-items: center; gap: clamp(14px, 2.4vw, 34px); font-size: 11px; font-weight: 300; letter-spacing: .08em; text-transform: uppercase; }
nav a { text-decoration: none; color: var(--muted); }
nav a.active, nav a:hover { color: var(--ink); }
.nav-icon-link { position: relative; display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; color: var(--muted); }
.nav-icon-link svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.nav-icon-link.active, .nav-icon-link:hover { color: var(--ink); }
.nav-icon-badge { position: absolute; top: -5px; right: -7px; min-width: 15px; height: 15px; padding: 0 4px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; background: var(--accent); color: var(--paper); font-size: 8px; font-weight: 300; letter-spacing: 0; line-height: 1; }
.nav-dropdown { position: relative; }
.nav-dropdown > button { border: 0; background: transparent; padding: 0; font: inherit; letter-spacing: inherit; text-transform: inherit; color: var(--muted); cursor: pointer; }
.nav-dropdown > button.active, .nav-dropdown:hover > button { color: var(--ink); }
.nav-menu { position: absolute; right: 0; top: calc(100% + 16px); min-width: 260px; display: grid; gap: 0; padding: 12px; background: rgba(244, 239, 234, .96); border: 1px solid var(--line); box-shadow: var(--shadow); opacity: 0; visibility: hidden; transform: translateY(8px); transition: .2s ease; }
.nav-dropdown:hover .nav-menu, .nav-dropdown:focus-within .nav-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-menu a { padding: 12px 10px; border-bottom: 1px solid var(--line); }
.nav-menu a:last-child { border-bottom: 0; }
.hero { --hero-fade: 0; position: relative; min-height: clamp(720px, 92vh, 980px); display: grid; align-items: center; overflow: hidden; padding: clamp(72px, 9vw, 118px) clamp(24px, 7vw, 108px); background: var(--page-bg); }
.hero:before { content: ""; position: absolute; inset: 0; background-image: url("/assets/hero-herbal-fullbleed.png?v=20260620a"); background-size: cover; background-position: center; background-repeat: no-repeat; opacity: calc(1 - (var(--hero-fade) * .12)); transform: scale(calc(1 + (var(--hero-fade) * .04))); transform-origin: center top; transition: opacity .12s linear, transform .18s ease-out; }
.hero:after { content: none; }
.hero-content { position: relative; z-index: 2; width: 100%; max-width: 1180px; padding: 0; opacity: calc(1 - (var(--hero-fade) * .78)); transform: translateY(calc(var(--hero-fade) * -36px)); transition: opacity .12s linear, transform .18s ease-out; will-change: opacity, transform; text-shadow: 0 10px 28px rgba(44, 34, 30, .28); }
.eyebrow { margin: 0 0 16px; color: var(--muted); font-size: 10px; text-transform: uppercase; font-weight: 300; letter-spacing: .18em; }
h1, h2, h3 { line-height: 1.04; letter-spacing: -.035em; margin: 0; font-weight: 300; }
.hero .eyebrow { color: rgba(255,255,255,.88); font-weight: 500; }
.hero h1 { max-width: 820px; font-size: clamp(38px, 6vw, 84px); font-weight: 600; color: #fff; letter-spacing: -.06em; line-height: .98; }
.hero-brand-title { font-size: clamp(34px, 5.3vw, 74px); letter-spacing: -.025em; margin-bottom: 14px; }
.hero-subtitle { max-width: 690px; margin: 0; color: rgba(255,255,255,.98); font-size: clamp(17px, 2.8vw, 37px); font-weight: 600; letter-spacing: -.02em; line-height: 1.04; }
.hero-lede { max-width: 560px; font-size: clamp(20px, 2.4vw, 28px); color: rgba(255,255,255,.92); font-weight: 500; letter-spacing: -.025em; line-height: 1.18; }
.hero-actions { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-top: 32px; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; padding: 10px 18px; border-radius: 0; text-decoration: none; font-weight: 300; font-family: Helvetica, "Helvetica Neue", Arial, sans-serif; letter-spacing: .08em; text-transform: uppercase; font-size: 10px; border: 1px solid var(--accent); }
.primary { color: var(--paper); background: var(--accent); }
.secondary { color: var(--accent); background: transparent; }
.hero .button { border-color: rgba(255,255,255,.9); box-shadow: 0 10px 24px rgba(44, 34, 30, .18); }
.hero .primary { color: #fff; background: transparent; }
.hero .secondary { color: #fff; background: transparent; }
.hero-art { position: absolute; inset: 0; pointer-events: none; }
.wash, .tea-bowl, .steam, .botanical, .flower-sketch { display: none; }
.hero-banner { display: none; }
.intro-band { display: grid; grid-template-columns: minmax(0, .95fr) minmax(280px, .8fr); gap: clamp(24px, 5vw, 76px); align-items: center; padding: clamp(64px, 8vw, 118px) clamp(20px, 6vw, 88px); background: transparent; border-block: 1px solid var(--line); }
.founder-section { padding: clamp(96px, 14vw, 180px) clamp(32px, 12vw, 180px); border-bottom: 1px solid var(--line); }
.founder-story { max-width: 780px; margin: 0 auto; text-align: center; }
.founder-story h1, .founder-story h2 { font-size: clamp(24px, 3.2vw, 42px); margin-bottom: clamp(24px, 4vw, 42px); color: var(--espresso); }
.founder-story p { margin: 0 auto 18px; color: var(--muted); font-size: clamp(13px, 1.1vw, 16px); line-height: 1.8; }
.founder-story p:last-child { margin-bottom: 0; color: var(--accent); }
.standalone-founder { padding-top: clamp(42px, 7vw, 88px); border-bottom: 0; }
.intro-band h2, .section-heading h2, .page-hero h1 { font-size: clamp(27px, 3.6vw, 48px); }
.intro-band p:last-child { color: var(--muted); font-size: 16px; }
.preview-section, .products-section, .blog-preview, .page-shell, .article-shell { padding: clamp(46px, 7vw, 92px) clamp(18px, 6vw, 82px); }
.product-page-shell { padding: clamp(20px, 3.5vw, 40px) clamp(18px, 6vw, 82px) clamp(46px, 7vw, 92px); }
.section-heading { display: flex; justify-content: space-between; gap: 20px; align-items: end; margin-bottom: 28px; }
.preview-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.journal-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.product-grid { display: grid; gap: 22px; }
.product-card { display: grid; grid-template-columns: 1fr; gap: 0; background: var(--surface-soft); border: 1px solid var(--line); overflow: hidden; box-shadow: var(--shadow); }
.card-photo { display: block; aspect-ratio: 4 / 3; overflow: hidden; background: rgba(255,252,247,.4); }
.card-photo img, .product-hero-image { display: block; width: 100%; height: 100%; object-fit: cover; }
.article-hero-photo { display: block; width: 100%; height: auto; object-fit: contain; }
.product-photo { aspect-ratio: 1 / .86; }
.product-media { min-height: 280px; position: relative; background: linear-gradient(135deg, rgba(42,27,22,.12), rgba(230,221,210,.45)); overflow: hidden; }
.product-media:after { content: ""; position: absolute; inset: 22%; border: 1px solid rgba(42,27,22,.18); border-radius: 50%; }
.product-media span { display: none; }
.herb-2, .herb-3, .herb-4, .herb-5, .herb-6 { background: linear-gradient(135deg, rgba(42,27,22,.09), rgba(230,221,210,.5)); }
.product-copy { padding: clamp(24px, 4vw, 44px); }
.product-copy h3, .article-card h3 { font-size: clamp(17px, 1.55vw, 24px); line-height: 1.12; }
.product-copy p { color: var(--muted); }
.formula-list { display: grid; gap: 8px; margin: 22px 0; }
details { border-top: 1px solid var(--line); padding: 12px 0; }
summary { cursor: pointer; font-weight: 300; color: var(--espresso); }
.text-link { color: var(--espresso); font-weight: 300; text-decoration-thickness: 1px; text-underline-offset: 5px; }
.article-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.article-grid.wide { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.tcm-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-bottom: clamp(42px, 7vw, 84px); }
.tcm-grid article { min-height: 250px; padding: 28px; border: 1px solid var(--line); background: var(--surface-soft); box-shadow: var(--shadow); }
.tcm-grid h2 { font-size: clamp(22px, 2.5vw, 30px); margin-bottom: 12px; }
.tcm-grid p { color: var(--muted); }
.journal-intro { margin: clamp(22px, 4vw, 48px) 0 clamp(46px, 7vw, 92px); }
.journal-heading { padding-top: clamp(18px, 3vw, 38px); border-top: 1px solid var(--line); }
.article-card { min-height: 250px; border: 1px solid var(--line); background: var(--surface-soft); text-decoration: none; display: flex; flex-direction: column; gap: 0; box-shadow: var(--shadow); overflow: hidden; }
.article-card > div { padding: 22px; display: grid; gap: 10px; }
.article-card span, .article-meta, small { color: var(--muted); font-size: 12px; font-weight: 300; letter-spacing: .12em; text-transform: uppercase; }
.article-card p, .page-hero p, .article-page p, .related a { color: var(--muted); }
.page-hero { max-width: 900px; margin-bottom: 34px; }
.article-shell { display: grid; grid-template-columns: minmax(0, 780px) minmax(220px, 320px); gap: clamp(28px, 5vw, 72px); align-items: start; }
.article-page { background: var(--surface-soft); border: 1px solid var(--line); padding: clamp(28px, 5vw, 64px); box-shadow: var(--shadow); }
.article-page h1 { font-size: clamp(30px, 4.2vw, 52px); margin-bottom: 12px; }
.article-hero-photo { margin: 28px 0 22px; border: 1px solid var(--line); }
.article-page h2 { margin-top: 38px; font-size: clamp(22px, 2.4vw, 30px); }
.article-page p { font-size: 16px; }
.article-sources { margin-top: 42px; padding-top: 22px; border-top: 1px solid var(--line); }
.article-sources ul { margin: 14px 0 0; padding-left: 20px; color: var(--muted); }
.article-sources li + li { margin-top: 10px; }
.article-sources a { color: var(--accent); text-underline-offset: 4px; }
.product-showcase { display: grid; grid-template-columns: minmax(0, .88fr) minmax(340px, 460px); gap: clamp(26px, 4vw, 64px); align-items: start; margin-bottom: clamp(42px, 7vw, 84px); }
.product-gallery { display: grid; gap: 16px; align-content: start; justify-items: stretch; }
.product-gallery-rail { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; justify-content: flex-start; }
.gallery-rail-nav { display: flex; gap: 10px; align-items: center; }
.product-gallery-stage { position: relative; min-height: 0; width: 100%; display: block; align-self: start; }
.gallery-arrow { width: 32px; height: 32px; border: 1px solid var(--line); background: #fff; color: var(--ink); font: inherit; cursor: pointer; box-shadow: var(--shadow); }
.gallery-thumb { width: 56px; height: 70px; padding: 0; border: 1px solid var(--line); background: #fff; overflow: hidden; cursor: pointer; opacity: .72; transition: opacity .2s ease, border-color .2s ease; }
.gallery-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gallery-thumb.is-active { opacity: 1; border-color: var(--line-strong); }
.product-gallery-slide { width: 100%; margin: 0; border: 1px solid var(--line); background: var(--surface-soft); box-shadow: var(--shadow); display: block; overflow: hidden; align-self: start; justify-self: stretch; }
.product-gallery-slide[hidden] { display: none; }
.product-gallery-slide-photo { border: 0; background: transparent; box-shadow: none; line-height: 0; }
.product-gallery-image { display: block; width: 100%; max-width: 100%; height: auto; object-fit: cover; vertical-align: top; }
.product-gallery-formula { padding: 0; display: grid; gap: 18px; }
.product-info-panel, .how-to-use, .safety-note { background: var(--surface-soft); border: 1px solid var(--line); padding: clamp(22px, 4vw, 38px); box-shadow: var(--shadow); }
.product-info-panel h1 { font-size: clamp(22px, 2.8vw, 36px); margin-bottom: 14px; }
.product-summary { color: var(--muted); font-size: 15px; line-height: 1.7; margin-bottom: 24px; }
.product-copy-block + .product-copy-block { margin-top: 24px; padding-top: 22px; border-top: 1px solid var(--line); }
.product-copy-block p { color: var(--muted); font-size: 15px; line-height: 1.7; }
.product-copy-block .eyebrow { font-weight: 500; color: var(--ink); }
.best-for ul { margin: 8px 0 0; padding-left: 20px; color: var(--muted); }
.best-for li { line-height: 1.7; }
.best-for li + li { margin-top: 0; }
.product-buy-row { margin-top: 28px; padding-top: 22px; border-top: 1px solid var(--line); display: grid; gap: 12px; align-content: start; }
.product-buy-button { width: 100%; justify-content: center; }
.formula-visual { display: grid; gap: 22px; align-items: start; }
.formula-figure { position: relative; width: min(100%, 920px); aspect-ratio: 16 / 10; margin: 0 auto; background: #fff; border: 1px solid rgba(44, 34, 30, .08); overflow: hidden; }
.formula-visual-image { background: transparent; aspect-ratio: auto; object-fit: contain; width: 100%; height: 100%; display: block; }
.product-gallery-formula .formula-figure { width: 100%; aspect-ratio: auto; margin: 0; background: transparent; border: 0; }
.product-gallery-formula .formula-visual-image { width: 100%; height: auto; object-fit: cover; display: block; }
.formula-step-buttons, .formula-phase-list { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.formula-step-button, .formula-phase-list span { padding: 8px 10px; border: 1px solid var(--line); font: inherit; font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); background: rgba(255,255,255,.54); cursor: pointer; }
.formula-step-button.is-active { background: #2C221E; color: #fff; border-color: #2C221E; }
.how-to-use { display: grid; gap: 22px; margin-bottom: clamp(42px, 7vw, 84px); }
.how-to-use-header { display: grid; gap: 6px; }
.how-to-use-body { display: block; margin-top: 8px; }
.how-to-use ol { margin: 0; padding-left: 22px; }
.how-to-use-steps { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 22px; }
.how-to-use-step { display: grid; gap: 12px; justify-items: center; text-align: center; align-content: start; }
.how-to-use-icon { width: 52px; height: 52px; display: grid; place-items: center; color: var(--accent); }
.how-to-use-icon svg { width: 32px; height: 32px; stroke: currentColor; fill: none; stroke-width: 1.45; stroke-linecap: round; stroke-linejoin: round; }
.how-to-use-step h3 { margin: 0; font-size: 14px; letter-spacing: .14em; text-transform: uppercase; font-weight: 400; color: var(--ink); }
.how-to-use-step p { margin: 0; font-size: 15px; line-height: 1.72; color: var(--muted); max-width: 260px; }
.safety-note p { color: rgba(44, 34, 30, .56); }
.price { color: var(--accent); font-size: 18px; margin: 0; }
.commerce-shell { max-width: 1180px; margin: 0 auto; }
.commerce-card { background: var(--surface-soft); border: 1px solid var(--line); padding: clamp(22px, 4vw, 38px); box-shadow: var(--shadow); }
.checkout-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, 420px); gap: 20px; align-items: start; }
.cart-line { display: grid; grid-template-columns: 96px minmax(0, 1fr); gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--line); }
.cart-line img { width: 96px; height: 78px; object-fit: cover; border: 1px solid var(--line); }
.cart-line h3, .order-card h3 { font-size: 18px; margin: 0 0 4px; }
.cart-line p, .empty-state, .fine-note, .order-card p, .order-card li { color: var(--muted); }
.cart-line button { border: 0; background: transparent; padding: 0; text-align: left; color: var(--accent); font: inherit; cursor: pointer; }
.cart-summary { display: flex; justify-content: space-between; align-items: center; margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--line-strong); }
.cart-summary p { margin: 0; color: var(--muted); }
.cart-summary strong { font-size: 22px; font-weight: 300; color: var(--accent); }
.success-panel { max-width: 760px; margin: 0 auto; text-align: center; }
.success-panel h1 { font-size: clamp(30px, 4vw, 52px); }
.inline-form { grid-template-columns: minmax(0, 1fr) auto; align-items: end; margin-bottom: 26px; }
.order-card { border-top: 1px solid var(--line); padding: 18px 0; }
.order-card select { width: 100%; margin-top: 8px; border: 1px solid var(--line-strong); padding: 10px; background: rgba(230,221,210,.62); font: inherit; }
.cms-manager { margin-top: 42px; padding-top: 32px; border-top: 1px solid var(--line-strong); }
.cms-header { display: flex; justify-content: space-between; gap: 20px; align-items: start; margin-bottom: 24px; }
.cms-header h2, .cms-block h3 { font-size: clamp(22px, 2.4vw, 32px); }
.cms-header p { color: var(--muted); margin: 8px 0 0; }
.cms-block { display: grid; gap: 14px; padding: 22px 0; border-top: 1px solid var(--line); }
.cms-block details { background: rgba(255, 252, 247, .25); border: 1px solid var(--line); padding: 14px; }
.cms-editor-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; padding-top: 16px; }
.cms-editor-grid textarea { min-height: 170px; }
.cms-editor-grid label:nth-child(3), .cms-editor-grid label:nth-child(4), .cms-editor-grid label:nth-child(5) { grid-column: 1 / -1; }
.cms-image-preview { grid-column: 1 / -1; }
.cms-image-preview img { width: min(360px, 100%); aspect-ratio: 4 / 3; object-fit: cover; border: 1px solid var(--line); background: var(--paper); }
form { display: grid; gap: 14px; }
label { display: grid; gap: 6px; font-weight: 300; color: var(--ink); }
input, textarea { width: 100%; border: 1px solid var(--line-strong); padding: 12px 13px; font: inherit; color: var(--ink); background: rgba(230,221,210,.62); }
textarea { min-height: 120px; resize: vertical; }
button.button { border: 0; cursor: pointer; font: inherit; }
.article-cta { margin-top: 38px; padding: 28px; background: rgba(42, 27, 22, .06); border: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.related { position: sticky; top: 96px; display: grid; gap: 12px; }
.related a { display: block; padding: 14px 0; border-top: 1px solid var(--line); text-decoration: none; font-weight: 300; }
.site-footer { display: grid; grid-template-columns: .9fr 1.2fr 1.2fr; gap: 28px; padding: 34px clamp(18px, 6vw, 82px); background: var(--footer-bg); color: var(--paper); }
.site-footer p { color: rgba(207, 193, 178, .78); margin: 8px 0 0; }
.footer-column { display: grid; align-content: start; gap: 10px; }
.footer-column-brand { justify-items: end; text-align: right; }
.footer-title { margin: 0; color: var(--paper); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; }
.footer-link { color: rgba(244, 239, 234, .88); text-decoration: none; }
.footer-address { color: rgba(207, 193, 178, .78); }
.footer-subscribe { display: grid; gap: 8px; }
.footer-subscribe label { color: rgba(244, 239, 234, .88); }
.footer-subscribe-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 10px; }
.footer-subscribe input { background: rgba(255,255,255,.08); color: var(--paper); border-color: rgba(244,239,234,.18); }
.footer-form-note { min-height: 18px; font-size: 13px; }
.footer-button { align-self: start; }
.footer-button-accent { color: var(--espresso); background: #D8C2A8; border-color: #D8C2A8; }
.fine-print { grid-column: 1 / -1; margin-top: 6px; padding-top: 18px; border-top: 1px solid rgba(244, 239, 234, .12); font-size: 13px; text-align: left; }
.faq-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.faq-grid details { border-top: 1px solid var(--line); padding: 14px 0; }
.legal-copy { max-width: 920px; }
.legal-copy p + p { margin-top: 18px; }
.admin-section { margin-top: 42px; }
.admin-email-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-top: 22px; }
.email-compose { margin-top: 12px; }
.list-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 0; border-top: 1px solid var(--line); }
.list-row p { margin: 6px 0 0; color: var(--muted); }
.email-card { border-top: 1px solid var(--line); padding: 16px 0; }
.email-card h3 { font-size: 18px; margin: 0 0 8px; }
.track-status { margin-top: 14px; display: flex; justify-content: space-between; gap: 12px; padding: 12px 14px; border: 1px solid var(--line); background: rgba(28, 53, 45, .05); }
.track-status span { color: var(--muted); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; }
.track-status strong { color: var(--accent); font-weight: 300; }
@media (prefers-reduced-motion: reduce) {
  .scroll-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
@media (max-width: 820px) {
  .site-header { align-items: flex-start; flex-direction: column; }
  nav { width: 100%; overflow-x: auto; padding-bottom: 4px; }
  .hero { grid-template-columns: 1fr; min-height: 720px; padding-top: 64px; }
  .hero:before, .hero:after { inset: 0; }
  .hero:before { background-image: url("/assets/hero-herbal-fullbleed.png?v=20260620a"); background-size: cover; background-position: center; }
  .hero-content { padding: 0; }
  .intro-band, .product-card, .article-shell, .site-footer, .product-showcase, .how-to-use, .checkout-grid, .inline-form, .cms-editor-grid, .faq-grid, .admin-email-grid, .footer-subscribe-row { grid-template-columns: 1fr; }
  .product-gallery { grid-template-columns: 1fr; }
  .product-gallery-rail { justify-content: flex-start; align-items: center; }
  .gallery-rail-nav { margin-top: 0; }
  .how-to-use-steps { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cms-header { display: block; }
  .article-grid, .article-grid.wide, .tcm-grid, .preview-grid, .journal-grid { grid-template-columns: 1fr; }
  .section-heading { display: block; }
  .article-cta { align-items: flex-start; flex-direction: column; }
  .formula-figure { aspect-ratio: 5 / 6; width: min(100%, 560px); }
}
@media (max-width: 520px) {
  .hero h1 { font-size: 48px; }
  .hero-subtitle { font-size: 32px; }
  .hero-actions .button { width: 100%; }
  .product-media { min-height: 210px; }
  .how-to-use-steps { grid-template-columns: 1fr; }
}