:root {
  --font-body: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-display: 'Inter', system-ui, sans-serif;
  --ink: #191919;
  --muted: #545454;
  --paper: #eeebe3;
  --paper-soft: #f7f4ed;
  --cream-warm: #f1e2d5;
  --orange: #ec520d;
  --orange-soft: #e78c3c;
  --green: #144236;
  --red: #73000e;
  --white: #ffffff;
  --border: rgba(25, 25, 25, 0.18);
  --radius-sm: 14px;
  --radius-md: 22px;
  --radius-lg: 32px;
  --shadow-hard: 6px 6px 0 var(--ink);
  --shadow-soft: 0 18px 40px rgba(25, 25, 25, 0.10);
  --container: 1200px;
  --gutter: clamp(18px, 4vw, 60px);
  --section-y: clamp(42px, 6.2vw, 78px);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--ink);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input { font: inherit; }
:focus-visible { outline: 3px solid var(--orange); outline-offset: 3px; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 72px;
  padding: 12px var(--gutter);
  background: rgba(238, 235, 227, 0.95);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(14px);
}
.brand {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(1.05rem, 1.55vw, 1.42rem);
  letter-spacing: 0.26em;
  line-height: 1;
  color: var(--orange);
  text-transform: uppercase;
  max-width: 16ch;
  overflow-wrap: anywhere;
}
.main-nav {
  display: flex;
  align-items: center;
  gap: clamp(14px, 2.2vw, 28px);
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: 0.045em;
  font-size: 0.8rem;
}
.main-nav a:not(.button) { padding: 10px 0; }
.main-nav a:not(.button):hover { border-bottom: 2px solid var(--orange); color: var(--orange); }
.nav-toggle { display: none; }

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  max-width: 100%;
  border: 2px solid var(--ink);
  border-radius: 999px;
  background: var(--orange);
  color: var(--white);
  padding: 0 22px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.035em;
  font-size: 0.84rem;
  line-height: 1.1;
  text-align: center;
  box-shadow: 5px 5px 0 var(--ink);
  transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease, color 160ms ease;
  white-space: normal;
  cursor: pointer;
}
.button:hover { transform: translate(2px, 2px); box-shadow: 3px 3px 0 var(--ink); }
.button-small { min-height: 38px; padding: 0 15px; font-size: 0.72rem; box-shadow: 4px 4px 0 var(--ink); }
.button-secondary, .button-light { background: var(--paper); color: var(--ink); }
.button-dark { background: var(--green); color: var(--white); }
.button.full { width: 100%; }
.button-row { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.section-cta { margin-top: 24px; display: flex; flex-wrap: wrap; gap: 14px; }
.cta-constrained { max-width: var(--container); margin-inline: auto; }
.cta-centered { justify-content: center; }

h1, h2, h3, p { margin-top: 0; }
h1, h2, .display-heading {
  font-family: var(--font-display);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: -0.035em;
  line-height: 0.94;
  text-wrap: balance;
  overflow-wrap: anywhere;
}
h1 { font-size: clamp(3.05rem, 7.6vw, 7.25rem); margin-bottom: 20px; max-width: 11ch; }
h2 { font-size: clamp(2.02rem, 5vw, 4.75rem); margin-bottom: 18px; max-width: 13ch; }
h3 { font-size: clamp(1.08rem, 1.55vw, 1.34rem); line-height: 1.15; margin-bottom: 10px; overflow-wrap: anywhere; }
p { margin-bottom: 16px; }
.eyebrow {
  margin-bottom: 13px;
  color: inherit;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.74rem;
  line-height: 1.3;
}
.lead, .hero-text, .page-hero p, .story-callout p {
  font-size: clamp(1.03rem, 1.72vw, 1.24rem);
  line-height: 1.52;
  color: rgba(25, 25, 25, 0.82);
  max-width: 720px;
}
.section-dark .lead,
.section-dark .hero-text,
.section-dark.page-hero p,
.section-dark.story-callout p { color: rgba(255, 255, 255, 0.88); }
.section-dark h1,
.section-dark h2,
.section-dark .eyebrow { color: var(--white); }
.text-link { display: inline-flex; margin-top: 4px; font-weight: 900; border-bottom: 2px solid var(--orange); color: var(--orange); }
.price { font-size: 1.08rem; font-weight: 900; margin-bottom: 12px; }
.disclaimer, .form-note { color: var(--muted); font-size: 0.86rem; line-height: 1.45; margin-top: 16px; margin-bottom: 0; }
.section-dark .form-note, .section-dark .disclaimer { color: rgba(255,255,255,0.72); }

.section, .hero, .page-hero, .product-page { padding: var(--section-y) var(--gutter); }
.section-tight { padding-top: clamp(34px, 4.6vw, 58px); padding-bottom: clamp(34px, 4.6vw, 58px); }
.section > *, .hero > *, .page-hero > *, .product-page > * { min-width: 0; }
.section-dark { background: var(--green); color: var(--white); }
.section-cream { background: var(--paper-soft); }
.section-heading { max-width: var(--container); margin: 0 auto 30px; }
.section-heading h2 { max-width: 14ch; }
.two-col {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
  gap: clamp(24px, 5vw, 74px);
  align-items: start;
  max-width: var(--container);
  margin-inline: auto;
}
.two-col p { font-size: 1.04rem; max-width: 760px; }

.hero {
  min-height: calc(86svh - 72px);
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(280px, 0.98fr);
  align-items: center;
  gap: clamp(30px, 5vw, 78px);
  border-bottom: 2px solid var(--ink);
  background: var(--orange);
  color: var(--white);
  overflow: hidden;
}
.hero-copy { max-width: 820px; }
.hero-copy h1 { max-width: 10.5ch; color: var(--white); }
.hero .eyebrow, .hero .hero-text { color: rgba(255, 255, 255, 0.92); }
.hero-product { display: grid; place-items: center; min-width: 0; }
.product-mockup { width: min(68vw, 380px); max-height: 560px; display: grid; place-items: center; transform: rotate(1.5deg); }
.product-mockup-tall { width: min(39vw, 292px); }
.product-photo { width: 100%; max-height: 560px; object-fit: contain; object-position: center; filter: none; }
.product-photo-contain { aspect-ratio: 0.42 / 1; object-fit: contain; padding: 0; background: transparent; }

.ticker {
  overflow: hidden;
  border-bottom: 2px solid var(--ink);
  background: var(--green);
  color: var(--white);
  white-space: nowrap;
}
.ticker-track {
  display: inline-flex;
  gap: clamp(34px, 5vw, 70px);
  padding: 13px 0;
  min-width: max-content;
  animation: tickerLoop 28s linear infinite;
}
.ticker-track span {
  flex: 0 0 auto;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: clamp(0.8rem, 1.8vw, 1.52rem);
}
@keyframes tickerLoop { from { transform: translateX(-50%); } to { transform: translateX(0); } }
@media (prefers-reduced-motion: reduce) { .ticker-track { animation: none; } }

.media-split {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: clamp(26px, 5vw, 70px);
  align-items: center;
  border-block: 2px solid var(--ink);
}
.media-split.reverse { grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr); }
.media-copy { max-width: 620px; }
.image-duo { display: grid; grid-template-columns: 0.82fr 1fr; gap: 14px; align-items: end; }
.image-duo .tall { transform: translateY(-16px); }
.image-tile {
  margin: 0;
  border: 2px solid var(--ink);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-hard);
  background: var(--paper);
  aspect-ratio: 4 / 5;
}
.image-tile:not(.tall) { aspect-ratio: 1 / 1; }
.image-tile img { width: 100%; height: 100%; object-fit: cover; }

.card-grid { display: grid; gap: clamp(14px, 1.8vw, 18px); max-width: var(--container); margin-inline: auto; }
.card-grid.four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.card-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.card {
  min-width: 0;
  min-height: 164px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border: 2px solid var(--ink);
  border-radius: var(--radius-md);
  background: var(--paper-soft);
  padding: clamp(19px, 2.3vw, 26px);
  box-shadow: var(--shadow-hard);
  overflow: hidden;
}
.card p { color: var(--muted); margin-bottom: 0; }
.cards-section { background: var(--paper-soft); }
.editorial-section { background: var(--paper-soft); }
.editorial-heading { margin-bottom: 34px; }
.editorial-heading .lead, .formula-heading .lead { max-width: 780px; }
.editorial-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(16px, 2vw, 22px);
  max-width: var(--container);
  margin-inline: auto;
}
.editorial-card {
  min-width: 0;
  padding: clamp(20px, 2.4vw, 28px) 0 0;
  border-top: 2px solid var(--ink);
  background: transparent;
}
.editorial-card span, .stack-item span, .ingredient-table span {
  display: block;
  margin-bottom: 18px;
  color: var(--orange);
  font-weight: 950;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 0.72rem;
}
.editorial-card h3 { margin-bottom: 12px; }
.editorial-card p { color: var(--muted); margin-bottom: 18px; }
.editorial-card small {
  display: block;
  color: var(--ink);
  font-weight: 750;
  line-height: 1.4;
}
.problem-card { background: var(--white); min-height: 190px; }
.lab-strip {
  max-width: var(--container);
  margin: 22px auto 0;
  padding: 18px 22px;
  border: 2px solid var(--ink);
  border-radius: var(--radius-md);
  background: var(--paper);
  font-weight: 750;
}
.lab-strip span { color: var(--orange); font-weight: 950; }

.why-clean { background: var(--paper-soft); }
.why-clean .section-heading { margin-bottom: 22px; }
.why-statement {
  max-width: var(--container);
  margin: 0 auto clamp(20px, 3vw, 34px);
  padding: clamp(20px, 3vw, 34px);
  border: 2px solid var(--ink);
  border-radius: var(--radius-lg);
  background: var(--orange);
  color: var(--white);
}
.why-statement p {
  max-width: 920px;
  margin: 0;
  color: var(--white);
  font-size: clamp(1.55rem, 4vw, 3.65rem);
  line-height: 0.96;
  letter-spacing: -0.065em;
  font-weight: 950;
  text-transform: uppercase;
}
.why-rhythm {
  max-width: var(--container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(12px, 1.8vw, 18px);
}
.why-rhythm article {
  min-width: 0;
  padding: clamp(18px, 2.2vw, 26px);
  border: 2px solid var(--ink);
  border-radius: var(--radius-md);
  background: var(--paper);
}
.why-rhythm span, .formula-lines span {
  display: block;
  margin-bottom: 14px;
  color: var(--orange);
  font-size: 0.74rem;
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.why-rhythm h3 { margin-bottom: 10px; }
.why-rhythm p { margin: 0; color: var(--muted); }
.lab-strip.subtle {
  border: 0;
  border-top: 2px solid var(--ink);
  border-radius: 0;
  padding: 16px 0 0;
  background: transparent;
  box-shadow: none;
}

.product-band { background: var(--green); border-block: 2px solid var(--ink); color: var(--white); }
.product-card-large {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(22px, 4vw, 42px);
  align-items: stretch;
  max-width: var(--container);
  margin: 0 auto;
}
.product-image-card, .gallery-main {
  border: 2px solid var(--ink);
  border-radius: var(--radius-lg);
  display: grid;
  place-items: center;
  background: var(--paper-soft);
  overflow: hidden;
}
.product-image-card img,
.gallery-main img { width: 100%; height: 100%; object-fit: contain; }
.product-image-contain img,
.gallery-contain img { object-fit: contain; padding: 0; background: transparent; width: auto; height: auto; max-width: 88%; max-height: 88%; }
.product-image-contain img { max-width: 84%; max-height: 88%; }
.gallery-main.gallery-contain img { max-width: 90%; max-height: 90%; }
.product-image-card { aspect-ratio: 4 / 4.5; min-height: auto; padding: 0; }
.product-info {
  min-width: 0;
  border: 2px solid var(--ink);
  border-radius: var(--radius-lg);
  padding: clamp(24px, 4vw, 44px);
  background: var(--paper);
  color: var(--ink);
  box-shadow: none;
}
.product-info h2 { max-width: 12ch; }
.mini-meta { margin: 22px 0; }
.mini-meta div {
  display: grid;
  grid-template-columns: 0.32fr 0.68fr;
  gap: 14px;
  padding: 10px 0;
  border-top: 1px solid var(--border);
}
.mini-meta div:last-child { border-bottom: 1px solid var(--border); }
.mini-meta dt { font-weight: 900; }
.mini-meta dd { margin: 0; color: var(--muted); }

.formula-section { background: var(--paper); }
.formula-stack {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(18px, 2.4vw, 30px);
  max-width: var(--container);
  margin-inline: auto;
}
.stack-item {
  min-width: 0;
  border-top: 2px solid var(--ink);
  padding-top: 22px;
}
.stack-item h3 { font-size: clamp(1.22rem, 2vw, 1.7rem); margin-bottom: 14px; }
.stack-item p { color: var(--muted); font-size: 1.02rem; line-height: 1.5; margin-bottom: 0; }
.ingredient-table {
  max-width: var(--container);
  margin-inline: auto;
  border-top: 2px solid var(--ink);
}
.ingredient-table article {
  display: grid;
  grid-template-columns: minmax(110px, 0.26fr) minmax(0, 0.74fr);
  gap: clamp(18px, 4vw, 52px);
  padding: clamp(18px, 2.5vw, 28px) 0;
  border-bottom: 1px solid var(--border);
  align-items: start;
}
.ingredient-table h3 { font-size: clamp(1.18rem, 2vw, 1.6rem); margin-bottom: 8px; }
.ingredient-table p { color: var(--muted); margin-bottom: 0; max-width: 780px; }
.research-drawer { max-width: var(--container); margin: 28px auto 0; border-block: 2px solid var(--ink); border-inline: 0; border-radius: 0; background: transparent; padding: 0; }
.research-drawer summary { padding: 18px 0; list-style-position: inside; }
.research-links { padding: 0 0 22px; display: flex; flex-wrap: wrap; gap: 10px 16px; }
.research-links a { font-weight: 900; color: var(--orange); border-bottom: 1px solid var(--orange); }
.lab-note { max-width: var(--container); margin: 0 auto 24px; padding: 0; background: transparent; color: var(--muted); font-size: 1.02rem; }
.lab-note strong { color: var(--ink); }

.formula-editorial { background: var(--paper); }
.formula-lines {
  max-width: var(--container);
  margin: 0 auto;
  border-top: 2px solid var(--ink);
}
.formula-lines article {
  display: grid;
  grid-template-columns: minmax(160px, 0.24fr) minmax(0, 0.76fr);
  gap: clamp(18px, 4vw, 46px);
  align-items: start;
  padding: clamp(18px, 2.5vw, 26px) 0;
  border-bottom: 1px solid var(--border);
}
.formula-lines p {
  max-width: 860px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(1.08rem, 2vw, 1.42rem);
  line-height: 1.38;
}
.product-formula-section .formula-heading { margin-bottom: 28px; }
.ingredient-table-compact {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 clamp(24px, 4vw, 54px);
  border-top: 2px solid var(--ink);
}
.ingredient-table-compact article {
  grid-template-columns: minmax(86px, 0.24fr) minmax(0, 0.76fr);
  gap: 16px;
  padding: 18px 0;
}
.ingredient-table-compact h3 { font-size: clamp(1.05rem, 1.6vw, 1.28rem); margin-bottom: 5px; }
.ingredient-table-compact p { font-size: 0.96rem; line-height: 1.42; }
.brand-code-grid .card { min-height: 148px; justify-content: flex-start; }
.brand-code-grid .card p { font-size: 1rem; }

.story-callout { text-align: center; }
.story-callout h2 { max-width: 14ch; margin-left: auto; margin-right: auto; }
.story-callout p { margin-left: auto; margin-right: auto; }
.with-gallery .button { margin-top: 8px; }
.culture-strip { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; max-width: var(--container); margin: 30px auto 26px; }
.culture-strip img { width: 100%; height: clamp(180px, 24vw, 310px); object-fit: cover; border: 2px solid var(--ink); border-radius: var(--radius-md); box-shadow: 5px 5px 0 var(--ink); background: var(--paper); }
.waitlist {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(24px, 5vw, 52px);
  align-items: center;
  max-width: calc(var(--container) + (var(--gutter) * 2));
  margin-inline: auto;
}
.waitlist-form { min-width: 0; border: 2px solid var(--ink); border-radius: var(--radius-lg); padding: clamp(22px, 3vw, 30px); background: var(--white); box-shadow: var(--shadow-hard); }
.waitlist-form label { display: block; font-weight: 900; margin-bottom: 10px; }
.input-row { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; align-items: center; }
input { width: 100%; min-width: 0; min-height: 52px; border: 2px solid var(--ink); border-radius: 999px; padding: 0 18px; background: var(--white); color: var(--ink); }

.page-hero { min-height: 38vh; display: flex; flex-direction: column; justify-content: center; border-bottom: 2px solid var(--ink); }
.page-hero h1 { max-width: 12ch; }
.about-hero, .contact-hero { display: grid; grid-template-columns: minmax(0, 0.92fr) minmax(260px, 0.58fr); gap: clamp(24px, 5vw, 60px); align-items: center; }
.hero-side-image { margin: 0; border: 2px solid var(--ink); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-hard); aspect-ratio: 4 / 3.8; background: var(--paper); }
.hero-side-image img { width: 100%; height: 100%; object-fit: cover; }

.product-page { display: grid; grid-template-columns: minmax(0, 1.03fr) minmax(340px, 0.97fr); gap: clamp(22px, 4vw, 50px); align-items: start; max-width: calc(var(--container) + (var(--gutter) * 2)); margin-inline: auto; padding-top: clamp(4px, 0.8vw, 10px); padding-bottom: clamp(42px, 5vw, 64px); }
.gallery { min-width: 0; }
.gallery-main { aspect-ratio: 1.12 / 0.94; min-height: auto; padding: 0; background: var(--paper-soft); }
.gallery-main img { object-position: center; transition: opacity 160ms ease; }
.gallery-thumbs { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; margin-top: 12px; }
.gallery-thumb { aspect-ratio: 1 / 0.78; border: 2px solid var(--ink); border-radius: var(--radius-sm); background: var(--white); overflow: hidden; cursor: pointer; padding: 0; }
.gallery-thumb img { width: 100%; height: 100%; object-fit: cover; }
.gallery-thumb[data-contain="true"] img { object-fit: contain; padding: 8px; background: var(--white); }
.gallery-thumb.is-active { box-shadow: 4px 4px 0 var(--orange); }
.purchase-panel { position: sticky; top: 80px; min-width: 0; border: 2px solid var(--ink); border-radius: var(--radius-lg); background: var(--white); padding: clamp(18px, 2.5vw, 30px); box-shadow: var(--shadow-soft); }
.purchase-panel h1 { font-size: clamp(2.2rem, 4.35vw, 4.05rem); max-width: 10ch; color: var(--orange); margin-bottom: 10px; }
.product-summary { font-size: 1rem; color: var(--muted); line-height: 1.45; }
.product-meta { margin: 14px 0; }
.product-meta div { display: grid; grid-template-columns: minmax(0, 0.38fr) minmax(0, 0.62fr); gap: 16px; padding: 8px 0; border-top: 1px solid var(--border); }
.product-meta div:last-child { border-bottom: 1px solid var(--border); }
.product-meta dt { font-weight: 900; }
.product-meta dd { margin: 0; text-align: right; color: var(--muted); overflow-wrap: anywhere; }
.product-detail-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr); gap: clamp(24px, 5vw, 60px); align-items: center; border-block: 2px solid var(--ink); }
.label-image { border: 2px solid var(--ink); border-radius: var(--radius-lg); overflow: hidden; box-shadow: none; background: var(--paper-soft); aspect-ratio: 1.35 / 1; display:grid; place-items:center; }
.label-image img { width: 100%; height: 100%; object-fit: contain; }
.detail-copy { max-width: 620px; }
.check-list { list-style: none; padding: 0; margin: 24px 0 0; display: grid; gap: 10px; }
.check-list li { border-top: 2px solid var(--ink); padding-top: 10px; font-weight: 900; }
.image-band { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.image-band img { width: 100%; height: clamp(220px, 28vw, 360px); object-fit: cover; border: 2px solid var(--ink); border-radius: var(--radius-lg); box-shadow: var(--shadow-hard); }

.faq-list { max-width: 980px; margin: 0 auto; }
details { border-top: 2px solid var(--ink); padding: 20px 0; }
details:last-child { border-bottom: 2px solid var(--ink); }
summary { cursor: pointer; font-size: clamp(1.05rem, 2vw, 1.28rem); line-height: 1.25; font-weight: 900; padding-right: 24px; }
details p { max-width: 760px; color: var(--muted); margin: 14px 0 0; }
.contact-single { max-width: 780px; margin: 0 auto; }
.contact-card { min-width: 0; border: 2px solid var(--ink); border-radius: var(--radius-lg); padding: clamp(24px, 4vw, 42px); background: var(--white); box-shadow: var(--shadow-hard); }
.contact-card h2 { font-family: var(--font-body); font-size: clamp(1.55rem, 3vw, 2.4rem); line-height: 1.05; letter-spacing: -0.025em; text-transform: none; max-width: none; margin-bottom: 12px; }
.contact-card p { color: var(--muted); overflow-wrap: anywhere; }
.contact-card .email-link { display:inline-flex; margin-top:12px; color: var(--orange); font-weight:900; border-bottom:2px solid var(--orange); }

.modal-overlay { position: fixed; inset: 0; z-index: 200; display: none; align-items: center; justify-content: center; padding: 22px; background: rgba(25,25,25,0.62); }
.modal-overlay.is-open { display: flex; }
.modal-card { width: min(680px, 100%); background: var(--paper); border: 2px solid var(--ink); border-radius: var(--radius-lg); box-shadow: 12px 12px 0 var(--ink); padding: clamp(22px, 4vw, 38px); position: relative; }
.modal-close { position:absolute; top:14px; right:14px; width:42px; height:42px; border:2px solid var(--ink); border-radius:999px; background:var(--white); font-weight:900; cursor:pointer; }
.modal-card h2 { font-size: clamp(2rem, 6vw, 4.2rem); }
.success-message { display:none; margin-top:14px; padding:12px 14px; border:2px solid var(--ink); background:var(--green); color:var(--white); font-weight:900; border-radius:var(--radius-sm); }
.success-message.is-visible { display:block; }

.site-footer { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 32px; align-items: start; padding: 40px var(--gutter); border-top: 2px solid var(--ink); background: var(--ink); color: var(--white); }
.site-footer p { margin: 12px 0 0; color: rgba(255, 255, 255, 0.72); }
.site-footer nav { display: flex; gap: 18px; flex-wrap: wrap; font-weight: 900; text-transform: uppercase; font-size: 0.82rem; letter-spacing: 0.04em; }

@media (max-width: 1100px) {
  .card-grid.four, .card-grid.three { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .editorial-grid, .formula-stack { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .culture-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

.nav-toggle, .nav-toggle:hover, .nav-toggle:focus, .nav-toggle:active, .nav-toggle[aria-expanded="true"] { background: var(--orange) !important; color: var(--white) !important; border-color: var(--ink) !important; -webkit-tap-highlight-color: rgba(236,82,13,.2); }
.nav-toggle:focus-visible { outline: 3px solid rgba(236,82,13,.35); outline-offset: 3px; }

@media (max-width: 920px) {
  .site-header { min-height: 70px; }
  .nav-toggle { display: inline-flex; align-items: center; justify-content: center; border: 2px solid var(--ink); border-radius: 999px; background: var(--orange); color: var(--white); min-height: 40px; padding: 0 15px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.04em; box-shadow: 4px 4px 0 var(--ink); appearance: none; -webkit-appearance: none; }
  .main-nav { display: none; position: absolute; inset: calc(100% + 10px) var(--gutter) auto var(--gutter); flex-direction: column; align-items: stretch; background: var(--paper); color: var(--ink); border: 2px solid var(--ink); border-radius: var(--radius-md); padding: 18px; box-shadow: var(--shadow-hard); }
  .main-nav.is-open { display: flex; }
  .main-nav a { width: 100%; }
  .hero, .two-col, .product-card-large, .waitlist, .product-page, .media-split, .media-split.reverse, .product-detail-grid, .about-hero, .contact-hero { grid-template-columns: 1fr; }
  .hero { min-height: auto; }
  .hero-copy h1, h1, h2, .purchase-panel h1 { max-width: 14ch; }
  .product-mockup { width: min(46vw, 220px); }
  .product-mockup-tall { width: min(54vw, 248px); }
  .purchase-panel { position: static; }
  .input-row { grid-template-columns: 1fr; }
  .image-duo .tall { transform: none; }
}
@media (max-width: 640px) {
  :root { --gutter: 18px; --section-y: 42px; }
  h1 { font-size: clamp(2.5rem, 15vw, 3.45rem); }
  h2 { font-size: clamp(1.9rem, 10.4vw, 2.65rem); }
  .brand { font-size: 1rem; letter-spacing: 0.18em; }
  .button { width: 100%; min-height: 50px; }
  .button-small { width: 100%; }
  .button-row, .section-cta { width: 100%; }
  .card-grid.four, .card-grid.three, .editorial-grid, .formula-stack, .culture-strip, .image-band, .why-rhythm, .ingredient-table-compact { grid-template-columns: 1fr; }
  .card { min-height: 140px; }
  .gallery-main { aspect-ratio: 4 / 4.1; }
  .product-image-card { aspect-ratio: 4 / 4.6; }
  .gallery-thumbs { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
  .product-meta div, .mini-meta div { grid-template-columns: 1fr; gap: 4px; }
  .product-meta dd { text-align: left; }
  .ingredient-table article, .formula-lines article { grid-template-columns: 1fr; gap: 6px; }
  .ingredients-grid { grid-template-columns: 1fr; }
  .ingredients-panel { max-height: 290px; }
  .site-footer { grid-template-columns: 1fr; }
  .site-footer nav { flex-direction: column; gap: 10px; }
  .culture-strip img, .image-band img { height: 280px; }
  .modal-overlay { align-items: flex-end; padding: 12px; }
  .modal-card { box-shadow: 6px 6px 0 var(--ink); }
}


/* Deployment-ready account, contact and dashboard additions */
[hidden] { display: none !important; }
.auth-terminal-section {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(360px, .72fr);
  gap: clamp(2rem, 6vw, 5rem);
  align-items: center;
  min-height: calc(100vh - 170px);
}
.auth-terminal-copy h1 { max-width: 9.5ch; }

.auth-terminal-copy .eyebrow { color: var(--muted); }
.auth-terminal-note span { transition: transform .18s ease, border-color .18s ease; }
.auth-terminal-note span:hover { transform: translateY(-1px); border-color: var(--orange); }
.auth-terminal .button { box-shadow: 5px 5px 0 rgba(255,255,255,.18); }
.auth-terminal .button:hover { transform: translate(-1px, -1px); box-shadow: 6px 6px 0 rgba(255,255,255,.2); }

.auth-terminal-copy p { max-width: 560px; font-size: clamp(1.05rem, 1.8vw, 1.24rem); color: var(--muted); }
.auth-terminal-note {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: 1.35rem;
}
.auth-terminal-note span {
  border: 2px solid var(--ink);
  border-radius: 999px;
  padding: .48rem .8rem;
  font-weight: 900;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  background: var(--white);
}
.auth-terminal {
  background: var(--ink);
  color: var(--white);
  border: 2px solid var(--ink);
  border-radius: 32px;
  padding: clamp(1.25rem, 3vw, 2rem);
  box-shadow: 12px 12px 0 var(--orange);
  min-height: 540px;
  display: flex;
  flex-direction: column;
}
.auth-terminal-kicker {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
  color: rgba(255,255,255,.72);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.auth-terminal-kicker span:last-child { color: var(--orange); }
.auth-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border: 2px solid rgba(255,255,255,.2);
  border-radius: 18px;
  padding: 5px;
  margin-bottom: 1.15rem;
}
.auth-tab {
  appearance: none;
  border: 0;
  border-radius: 13px;
  padding: .9rem 1rem;
  background: transparent;
  color: var(--white);
  font: inherit;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  cursor: pointer;
}
.auth-tab.is-active { background: var(--orange); color: var(--white); }
.auth-form, .contact-form { display: grid; gap: 1rem; margin-top: 1.4rem; }
.terminal-form { margin-top: 0; min-height: 380px; align-content: start; }
.terminal-field, .contact-form label { display: grid; gap: .45rem; font-weight: 800; }
.terminal-field label { color: rgba(255,255,255,.78); text-transform: uppercase; font-size: .78rem; letter-spacing: .1em; }
.terminal-field input, .contact-form input, .contact-form select, .contact-form textarea {
  width: 100%;
  border: 2px solid transparent;
  border-radius: 16px;
  padding: .98rem 1rem;
  font: inherit;
  background: var(--white);
  color: var(--ink);
  outline: none;
}
.terminal-field input:focus, .contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus {
  border-color: var(--orange);
  box-shadow: 0 0 0 3px rgba(236,82,13,.22);
}
.terminal-submit { width: 100%; margin-top: .35rem; }
.terminal-footnote {
  margin: -.15rem 0 0;
  color: rgba(255,255,255,.58);
  font-size: .85rem;
  line-height: 1.45;
}
.terminal-footnote a { color: var(--white); text-decoration: underline; text-underline-offset: 3px; }
.terminal-status { min-height: 1.4em; margin: 0; color: rgba(255,255,255,.72); font-weight: 800; }
.terminal-status[data-state="success"] { color: #fff; }
.terminal-status[data-state="error"] { color: #ffd8ca; }
.contact-form-card, .metric-card, .dashboard-panel { background: var(--white); border: 2px solid var(--ink); border-radius: 28px; padding: clamp(1.4rem, 3vw, 2.4rem); box-shadow: 8px 8px 0 var(--ink); }
.field-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.dashboard-toolbar { display: flex; align-items: end; justify-content: space-between; gap: 1rem; margin-bottom: 1.5rem; }
.metric-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.metric-card span { display: block; font-size: clamp(2rem, 5vw, 4rem); line-height: .9; font-weight: 900; letter-spacing: -.07em; color: var(--orange); }
.metric-card p { margin: .6rem 0 0; font-weight: 800; }
.dashboard-panel { margin-top: 1.2rem; box-shadow: none; }
.dashboard-table { display: grid; gap: .5rem; overflow-x: auto; }
.table-row { display: grid; grid-template-columns: 1.1fr .7fr .9fr; gap: 1rem; min-width: 620px; border-bottom: 1px solid rgba(28,28,28,.14); padding: .75rem 0; }
.table-row:first-child { font-weight: 900; text-transform: uppercase; letter-spacing: .08em; font-size: .82rem; }
@media (max-width: 900px) {
  .auth-terminal-section { grid-template-columns: 1fr; min-height: auto; }
  .auth-terminal-copy h1 { max-width: 10.5ch; }
}
@media (max-width: 820px) { .field-grid, .metric-grid { grid-template-columns: 1fr; } .dashboard-toolbar { align-items: start; flex-direction: column; } }


.footer-legal {
  grid-column: 1 / -1;
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  padding-top: 1.2rem;
  border-top: 1px solid rgba(255,255,255,.16);
  font-size: .82rem;
  opacity: .72;
}
.footer-legal a { color: inherit; }
.legal-document {
  max-width: 980px;
  margin-inline: auto;
  background: var(--white);
  border: 1px solid rgba(28,28,28,.16);
  border-radius: 24px;
  padding: clamp(1.35rem, 4vw, 3rem);
  box-shadow: none;
}
.legal-document h2 {
  font-size: clamp(1.6rem, 3vw, 2.35rem);
  letter-spacing: -.04em;
  max-width: none;
  margin-top: 2.2rem;
}
.legal-document h2:first-child { margin-top: 0; }
.legal-document h3 { margin: 1.35rem 0 .45rem; }
.legal-document p, .legal-document li { color: var(--muted); font-size: 1rem; line-height: 1.72; }
.legal-document ul { padding-left: 1.2rem; }
.legal-document a { color: var(--ink); font-weight: 800; text-decoration: underline; text-decoration-color: var(--orange); text-underline-offset: 3px; }
.legal-section { padding-top: 0; }
.legal-hero h1 { max-width: none; }
.legal-table { width: 100%; border-collapse: collapse; margin: 1rem 0 1.5rem; font-size: .96rem; }
.legal-table th, .legal-table td { border: 1px solid rgba(28,28,28,.16); padding: .85rem; vertical-align: top; text-align: left; }
.legal-table th { background: var(--cream); color: var(--ink); font-weight: 900; }
.legal-table td { color: var(--muted); line-height: 1.55; }
.legal-meta { color: var(--muted); font-weight: 800; margin-top: .5rem; }
@media (max-width: 640px) {
  .auth-terminal-section { gap: 1.5rem; }
  .auth-terminal { border-radius: 24px; box-shadow: 7px 7px 0 var(--orange); min-height: 520px; }
  .terminal-form { min-height: 360px; }
  .auth-terminal-copy h1 { max-width: 10ch; }
  .auth-terminal-note span { width: 100%; text-align: center; }
  .auth-tabs { border-radius: 15px; }
  .auth-tab { padding: .82rem .6rem; font-size: .88rem; }
  .legal-table { display: block; overflow-x: auto; white-space: normal; }
  .legal-document { border-radius: 18px; }
}


/* V11 professional polish */
.auth-terminal-copy p { max-width: 620px; }
.auth-terminal-copy h1 { max-width: 10.8ch; }
.auth-terminal { min-height: 520px; }
.terminal-form { min-height: 390px; grid-template-rows: auto auto auto auto auto 1fr; }
.terminal-field.is-hidden-field { visibility: hidden; pointer-events: none; }
.terminal-field.is-hidden-field input { pointer-events: none; }
.auth-name-field { min-height: 84px; }

.contact-single { max-width: 860px; }
.contact-card { background: var(--white); }
.contact-card h2 { font-size: clamp(1.8rem, 3.6vw, 3rem); letter-spacing: -0.045em; }
.contact-card > p { max-width: 680px; }
.contact-form { gap: 1.15rem; }
.contact-form label { color: var(--ink); font-weight: 900; }
.contact-form input, .contact-form select, .contact-form textarea {
  border: 2px solid rgba(28,28,28,.18);
  background: #fbfaf6;
  color: var(--ink);
  border-radius: 18px;
  min-height: 56px;
}
.contact-form textarea { min-height: 190px; resize: vertical; line-height: 1.5; padding-top: 1rem; }
.contact-form input::placeholder, .contact-form textarea::placeholder { color: rgba(28,28,28,.42); }
.contact-human-note {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(28,28,28,.14);
  color: var(--ink) !important;
  font-weight: 850;
}

.gallery-main.gallery-contain img {
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
}
.gallery-main.gallery-contain img[src*="sachet"] { max-width: 34% !important; max-height: 88% !important; }
.gallery-main.gallery-contain img[src*="pouch"] { max-width: 78% !important; max-height: 82% !important; }
@media (max-width: 640px) {
  .gallery-main.gallery-contain img[src*="sachet"] { max-width: 40% !important; max-height: 86% !important; }
  .gallery-main.gallery-contain img[src*="pouch"] { max-width: 82% !important; max-height: 82% !important; }
}

.ingredients-accordion {
  margin: 18px 0 22px;
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  padding: 0;
}
.ingredients-accordion summary {
  padding: 16px 0;
  font-size: .92rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.ingredients-panel { padding: 0 0 18px; }
.ingredients-panel h3 {
  margin: 16px 0 8px;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.ingredients-panel table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.ingredients-panel th, .ingredients-panel td { padding: 8px 0; border-top: 1px solid rgba(28,28,28,.12); text-align: left; vertical-align: top; }
.ingredients-panel th { font-weight: 850; color: var(--ink); }
.ingredients-panel td { text-align: right; color: var(--muted); }
.ingredients-panel p { font-size: .94rem; line-height: 1.55; color: var(--muted); margin: 0; }

.legal-hero { min-height: auto; padding-top: clamp(46px, 7vw, 82px); padding-bottom: clamp(26px, 4vw, 44px); }
.legal-hero h1 { font-size: clamp(1.85rem, 4vw, 3.15rem); letter-spacing: -0.045em; }
.legal-document { border-radius: 12px; }
.legal-document h2 {
  font-size: .98rem;
  line-height: 1.35;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-top: 2rem;
  border-top: 1px solid rgba(28,28,28,.16);
  padding-top: 1.05rem;
}
.legal-document h2:first-child { border-top: 0; padding-top: 0; }
.legal-document h3 { font-size: .98rem; }
.legal-document p, .legal-document li { font-size: .94rem; line-height: 1.68; }
.legal-table { font-size: .88rem; }

.nav-toggle[aria-expanded="true"] { background: var(--orange) !important; color: var(--white) !important; }


/* V16 product ingredient modal */
.ingredients-trigger {
  width: 100%;
  margin: 18px 0 20px;
  padding: 16px 0;
  border: 0;
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  background: transparent;
  color: var(--ink);
  text-align: left;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
  cursor: pointer;
}
.ingredients-trigger::before { content: '+ '; color: var(--orange); }
.ingredients-trigger:hover { color: var(--orange); }
.ingredients-modal-card {
  width: min(860px, 100%);
  max-height: min(760px, calc(100vh - 34px));
  overflow: auto;
  background: #fbfaf6;
  box-shadow: 10px 10px 0 var(--orange);
}
.ingredients-modal-card h2 { font-size: clamp(2.05rem, 5vw, 4.3rem); line-height: .95; max-width: 9.5ch; margin-bottom: 10px; }
.modal-intro { color: var(--muted); max-width: 560px; margin-bottom: 24px; }
.ingredients-modal-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 22px; border-top: 2px solid var(--ink); padding-top: 20px; }
.ingredients-modal-panel { min-width: 0; }
.ingredients-modal-panel h3 { margin: 0 0 10px; font-size: .78rem; text-transform: uppercase; letter-spacing: .12em; color: var(--orange); }
.ingredients-modal-panel table { width: 100%; border-collapse: collapse; font-size: .92rem; }
.ingredients-modal-panel th, .ingredients-modal-panel td { padding: 9px 0; border-top: 1px solid rgba(28,28,28,.13); vertical-align: top; }
.ingredients-modal-panel th { text-align: left; font-weight: 850; }
.ingredients-modal-panel td { text-align: right; color: var(--muted); white-space: nowrap; }
.ingredients-modal-panel .ingredients-copy { color: var(--muted); font-size: .96rem; line-height: 1.62; margin: 0 0 22px; }
@media (max-width: 720px) {
  .ingredients-modal-card { border-radius: 24px; padding: 24px 18px; max-height: calc(100vh - 20px); }
  .ingredients-modal-grid { grid-template-columns: 1fr; gap: 20px; }
  .ingredients-modal-card h2 { max-width: 10ch; }
}


/* V17 social and ingredient modal refinements */
.footer-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.footer-socials a,
.social-pill-row a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 13px;
  border: 1px solid currentColor;
  border-radius: 999px;
  color: inherit;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
}
.footer-socials a:hover,
.social-pill-row a:hover { color: var(--orange); }
.contact-social-block { margin-top: 28px; padding-top: 20px; border-top: 1px solid rgba(28,28,28,.12); }
.social-pill-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 10px; }
.social-pill-row a { color: var(--ink); border: 2px solid var(--ink); box-shadow: 3px 3px 0 var(--ink); }
.ingredient-modal-trigger { width: 100%; margin: 18px 0 20px; justify-content: center; }
.ingredient-modal-overlay {
  position: fixed !important;
  inset: 0 !important;
  z-index: 300 !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
  padding: clamp(14px, 3vw, 28px) !important;
  background: rgba(18,18,18,.58) !important;
  backdrop-filter: blur(5px);
}
.ingredient-modal-overlay.is-open { display: flex !important; }
.ingredients-modal-card {
  width: min(920px, 100%) !important;
  max-height: min(780px, calc(100vh - 28px)) !important;
  overflow: auto !important;
  background: #fbfaf6 !important;
  border: 2px solid var(--ink) !important;
  border-radius: 32px !important;
  box-shadow: 10px 10px 0 var(--orange) !important;
}
.ingredients-modal-card h2 { max-width: 12ch !important; }
@media (max-width: 720px) {
  .ingredient-modal-overlay { align-items: center !important; padding: 10px !important; }
  .ingredients-modal-card { border-radius: 24px !important; box-shadow: 5px 5px 0 var(--orange) !important; }
  .footer-socials, .social-pill-row { gap: 8px; }
}

/* V18 mobile product actions + compact ingredient modal */
.product-action-stack {
  display: grid;
  gap: 14px;
  margin: 18px 0 18px;
}
.product-action-stack .button,
.product-action-stack button {
  width: 100%;
  margin: 0 !important;
  touch-action: manipulation;
}
.ingredient-modal-trigger {
  cursor: pointer;
  position: relative;
  z-index: 2;
}
.ingredients-modal-compact {
  width: min(980px, calc(100vw - 32px)) !important;
  max-height: none !important;
  overflow: visible !important;
  padding: clamp(18px, 3vw, 30px) !important;
}
.ingredients-modal-compact h2 {
  font-size: clamp(2.1rem, 5vw, 4rem) !important;
  line-height: .9 !important;
  margin-bottom: 18px !important;
  max-width: none !important;
}
.ingredient-modal-columns {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: clamp(18px, 3vw, 30px);
  align-items: start;
}
.ingredient-modal-block h3 {
  font-size: .86rem;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin: 0 0 10px;
}
.active-mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-top: 2px solid var(--ink);
  border-left: 2px solid var(--ink);
}
.active-mini-grid div {
  min-width: 0;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 9px 10px;
  border-right: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  font-size: .76rem;
  line-height: 1.15;
}
.active-mini-grid strong {
  overflow-wrap: anywhere;
}
.active-mini-grid span {
  flex: 0 0 auto;
  color: var(--orange);
  font-weight: 900;
}
.compact-copy {
  font-size: .86rem !important;
  line-height: 1.42 !important;
  margin: 0 !important;
  color: var(--muted) !important;
}
.use-strip {
  display: grid;
  gap: 6px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 2px solid var(--ink);
  font-size: .85rem;
  line-height: 1.35;
}
.use-strip strong {
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .74rem;
}
@media (max-width: 720px) {
  .product-action-stack { gap: 18px; margin: 18px 0 22px; }
  .product-action-stack .button { min-height: 58px; }
  .ingredients-modal-compact {
    width: calc(100vw - 18px) !important;
    padding: 13px 12px 12px !important;
    border-radius: 20px !important;
    box-shadow: 4px 4px 0 var(--orange) !important;
  }
  .ingredients-modal-compact .eyebrow { font-size: .62rem; margin-bottom: 7px; }
  .ingredients-modal-compact h2 { font-size: clamp(1.55rem, 9vw, 2.15rem) !important; margin-bottom: 10px !important; }
  .ingredients-modal-compact .modal-close { width: 34px; height: 34px; top: 8px; right: 8px; }
  .ingredient-modal-columns { grid-template-columns: 1fr; gap: 10px; }
  .ingredient-modal-block h3 { font-size: .67rem; margin-bottom: 6px; }
  .active-mini-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .active-mini-grid div { padding: 5px 6px; gap: 4px; font-size: .53rem; line-height: 1.05; }
  .compact-copy { font-size: .58rem !important; line-height: 1.22 !important; }
  .use-strip { margin-top: 7px; padding-top: 7px; gap: 3px; font-size: .58rem; line-height: 1.22; }
  .use-strip strong { font-size: .54rem; }
}
@media (max-width: 380px) {
  .active-mini-grid div { font-size: .5rem; padding: 4px 5px; }
  .compact-copy, .use-strip { font-size: .54rem !important; }
}
