/* ═══════════════════════════════════════════════════════════════
   FLUM VAPE — core.css (Direction "Bright" / DNA-A)
   flum-vape.com — Authorized US Distributor · Greenwood IN
   Replaces the 5669-line Phase-1 Soft & Casual placeholder.
   2026-05-23 rebuild.

   Sections:
   1. Base reset (.fl)
   2. Typography (.fl-dna-a h1-h4, eyebrow, label, num, mono)
   3. Buttons / Chips / Dual chip / Inputs
   4. Cards / Price / TLDR / FAQ / Stamp / Lot / Tag
   5. Distributor mark (.gd-mark)
   6. Layout helpers (row/stack/grid)
   7. Device silhouettes (CSS-only bottle + slab)
   8. Chrome — announce bar, header, footer, cart panel, mobile drawer
   9. Page sections — home / collection / pdp / pillar / info / utility
   10. Mobile responsive (375 / 768 / 1280)
   ═══════════════════════════════════════════════════════════════ */

/* ═══════════ 1. Base reset ═══════════ */
.fl, .fl * { box-sizing: border-box; }
.fl { line-height: 1.5; -webkit-font-smoothing: antialiased; }
.fl h1, .fl h2, .fl h3, .fl h4, .fl p, .fl ul, .fl ol, .fl figure, .fl dl, .fl dd { margin: 0; padding: 0; }
.fl ul, .fl ol { list-style: none; }
.fl a { color: inherit; text-decoration: none; }
.fl button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; padding: 0; }
.fl img { max-width: 100%; display: block; }
.fl svg { display: block; }

.fl-sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ═══════════ 2. Typography (.fl-dna-a) ═══════════ */
.fl-dna-a {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--f-body);
  font-size: 15px;
  line-height: 1.5;
  font-feature-settings: "ss01" 1;
}
.fl-dna-a h1, .fl-dna-a h2, .fl-dna-a h3, .fl-dna-a h4 {
  font-family: var(--f-display);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.02;
  color: var(--ink);
  font-variation-settings: "wdth" 100, "opsz" 24;
}
.fl-dna-a h1       { font-size: 68px; font-variation-settings: "wdth" 100, "opsz" 48; }
.fl-dna-a h1.huge  { font-size: 96px; line-height: 0.96; font-variation-settings: "wdth" 100, "opsz" 96; }
.fl-dna-a h2       { font-size: 40px; letter-spacing: -0.025em; font-variation-settings: "wdth" 100, "opsz" 32; }
.fl-dna-a h3       { font-size: 24px; letter-spacing: -0.015em; line-height: 1.15; font-variation-settings: "wdth" 100, "opsz" 24; }
.fl-dna-a h4       { font-size: 17px; letter-spacing: -0.005em; line-height: 1.25; font-variation-settings: "wdth" 100, "opsz" 18; }
.fl-dna-a p        { color: var(--ink); }
.fl-dna-a .lede    { font-size: 19px; line-height: 1.45; color: var(--ink-2); font-weight: 400; }
.fl-dna-a .body    { font-size: 15px; line-height: 1.6; color: var(--ink-2); }
.fl-dna-a .small   { font-size: 13px; line-height: 1.5; color: var(--ink-2); }
.fl-dna-a .mono    { font-family: var(--f-mono); font-feature-settings: "zero" 1, "ss01" 1; font-variant-numeric: tabular-nums; }
.fl-dna-a .num     { font-family: var(--f-mono); font-variant-numeric: tabular-nums; font-feature-settings: "zero" 1; }
.fl-dna-a .eyebrow {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--signal-dk); font-weight: 500;
}
.fl-dna-a .eyebrow.ink  { color: var(--ink-2); }
.fl-dna-a .eyebrow.warm { color: var(--warm-dk); }
.fl-dna-a .label {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--ink-3);
}

/* Rules */
.fl-dna-a hr.rule { border: 0; border-top: 1px solid var(--rule); margin: 0; }
.fl-dna-a hr.rule.thick  { border-top: 2px solid var(--ink); }
.fl-dna-a hr.rule.aqua   { border-top: 2px solid var(--signal); }
.fl-dna-a hr.rule.dashed { border-top: 1px dashed var(--rule-2); }

/* ═══════════ 3. Buttons / Chips / Inputs ═══════════ */
.fl-dna-a .btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--f-body); font-size: 14px; font-weight: 600;
  letter-spacing: -0.005em;
  padding: 13px 22px;
  border: 1.5px solid var(--ink);
  background: var(--ink); color: #fff;
  cursor: pointer;
  border-radius: 999px;
  transition: transform 140ms ease, box-shadow 140ms ease, background 140ms ease;
  min-height: 46px;
  text-decoration: none;
}
.fl-dna-a .btn:hover { transform: translateY(-1px); box-shadow: 0 8px 20px -8px rgba(10,32,36,0.35); }
.fl-dna-a .btn.primary { background: var(--signal); border-color: var(--signal); color: var(--ink); font-weight: 700; }
.fl-dna-a .btn.primary:hover { background: var(--signal-dk); border-color: var(--signal-dk); color: #fff; box-shadow: var(--fl-sh-tiffany); }
.fl-dna-a .btn.warm    { background: var(--warm); border-color: var(--warm); color: #fff; }
.fl-dna-a .btn.warm:hover { background: var(--warm-dk); border-color: var(--warm-dk); }
.fl-dna-a .btn.ghost   { background: transparent; color: var(--ink); border-color: var(--rule-2); }
.fl-dna-a .btn.ghost:hover { background: var(--bg-soft); border-color: var(--ink); }
.fl-dna-a .btn.link    { background: transparent; border-color: transparent; padding: 0; min-height: 0; color: var(--signal-dk); }
.fl-dna-a .btn.link:hover { color: var(--ink); text-decoration: underline; box-shadow: none; transform: none; }
.fl-dna-a .btn.small   { font-size: 12px; padding: 9px 14px; min-height: 36px; }
.fl-dna-a .btn.large   { font-size: 16px; padding: 16px 26px; min-height: 54px; }
.fl-dna-a .btn .arrow  { font-family: var(--f-mono); font-weight: 400; }
.fl-dna-a .btn:disabled,
.fl-dna-a .btn[disabled] { opacity: 0.45; cursor: not-allowed; transform: none; box-shadow: none; }
.fl-dna-a .btn:focus-visible { outline: 2px solid var(--signal-dk); outline-offset: 2px; }

/* Single-flavor chips */
.fl-dna-a .chip {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--f-body); font-size: 13px; font-weight: 500;
  padding: 9px 13px;
  border: 1px solid var(--rule-2);
  background: var(--bg); color: var(--ink);
  min-height: 36px;
  cursor: pointer;
  border-radius: 999px;
  transition: all 120ms ease;
  text-align: left;
}
.fl-dna-a .chip:hover { border-color: var(--signal-dk); }
.fl-dna-a .chip[aria-selected="true"] {
  border: 2px solid var(--signal-dk); padding: 8px 12px;
  background: var(--signal-bg); color: var(--ink); font-weight: 600;
}
.fl-dna-a .chip[data-oos="true"] {
  opacity: 0.45; text-decoration: line-through; cursor: not-allowed;
}
.fl-dna-a .chip .glyph { font-family: var(--f-mono); font-size: 12px; color: var(--ink-2); }
.fl-dna-a .chip .fam-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--fam-fruit); display: inline-block; flex-shrink: 0;
}
.fl-dna-a .chip:focus-visible { outline: 2px solid var(--signal-dk); outline-offset: 2px; }

/* Dual-flavor chip (UT Bar Pro 50K signature) */
.fl-dna-a .chip-dual {
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: stretch;
  border: 1.5px solid var(--rule-2);
  background: var(--bg);
  cursor: pointer;
  font-size: 12px;
  min-height: 50px;
  border-radius: 12px;
  transition: all 140ms ease;
  position: relative;
  overflow: hidden;
}
.fl-dna-a .chip-dual:hover { border-color: var(--signal-dk); box-shadow: var(--fl-sh-micro); }
.fl-dna-a .chip-dual[aria-selected="true"] {
  border: 2px solid var(--ink); background: var(--bg);
  box-shadow: 0 4px 0 0 var(--ink);
  transform: translateY(-2px);
}
.fl-dna-a .chip-dual .tank {
  padding: 9px 12px; display: flex; flex-direction: column; gap: 2px;
  background: var(--signal-bg);
}
.fl-dna-a .chip-dual .tank-a { color: var(--signal-dk); }
.fl-dna-a .chip-dual .tank-b { background: var(--warm-bg); color: var(--warm-dk); align-items: flex-end; }
.fl-dna-a .chip-dual .divider {
  width: 1px; background: var(--rule-2); position: relative;
}
.fl-dna-a .chip-dual .divider::after {
  content: "/"; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  background: #fff; padding: 1px 4px; border-radius: 4px;
  font-family: var(--f-mono); font-size: 13px; color: var(--ink-3); font-weight: 500;
}
.fl-dna-a .chip-dual .tank-label {
  font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.12em;
  text-transform: uppercase; opacity: 0.7;
}
.fl-dna-a .chip-dual .tank-name { font-weight: 600; color: inherit; font-size: 12.5px; line-height: 1.15; }
.fl-dna-a .chip-dual:focus-visible { outline: 2px solid var(--signal-dk); outline-offset: 2px; }

/* Inputs */
.fl-dna-a .input {
  display: block; width: 100%;
  font-family: var(--f-body); font-size: 14px;
  padding: 13px 14px;
  background: var(--bg);
  border: 1.5px solid var(--rule-2);
  color: var(--ink);
  outline: none;
  border-radius: 10px;
  transition: border-color 120ms ease;
}
.fl-dna-a .input:focus { border-color: var(--signal-dk); box-shadow: 0 0 0 3px var(--signal-bg); }
.fl-dna-a .input::placeholder { color: var(--ink-3); }
.fl-dna-a textarea.input { min-height: 120px; resize: vertical; line-height: 1.5; }

/* Checkbox + radio */
.fl-dna-a .field-check {
  display: flex; gap: 12px; align-items: flex-start; cursor: pointer;
  font-size: 14px; line-height: 1.45; color: var(--ink-2);
}
.fl-dna-a .field-check input {
  width: 18px; height: 18px; margin-top: 2px; accent-color: var(--signal-dk);
}

/* ═══════════ 4. Cards / Price / TLDR / FAQ / Stamp / Lot / Tag ═══════════ */
.fl-dna-a .card {
  background: var(--bg);
  border: 1px solid var(--rule);
  position: relative;
  border-radius: 16px;
}
.fl-dna-a .card.tint        { background: var(--bg-soft); border-color: var(--rule); }
.fl-dna-a .card.thick       { border: 2px solid var(--ink); }
.fl-dna-a .card.signal      { background: var(--signal); color: var(--ink); border-color: var(--signal); }
.fl-dna-a .card.signal-tint { background: var(--signal-bg); border-color: var(--rule-2); }
.fl-dna-a .card.ink         { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.fl-dna-a .card.warm        { background: var(--warm-bg); border-color: #ffd5c5; }
.fl-dna-a .card-pad-sm { padding: 16px; }
.fl-dna-a .card-pad    { padding: 24px; }
.fl-dna-a .card-pad-lg { padding: 32px; }
.fl-dna-a .card-pad-xl { padding: 40px; }

.fl-dna-a .lift { transition: transform 180ms ease, box-shadow 180ms ease; }
.fl-dna-a .lift:hover { transform: translateY(-3px); box-shadow: var(--fl-sh-card-lg); }

/* Price */
.fl-dna-a .price { display: inline-flex; align-items: baseline; gap: 10px; }
.fl-dna-a .price .sale {
  font-family: var(--f-display); font-size: 36px; font-weight: 700;
  color: var(--signal-dk); letter-spacing: -0.025em;
  font-variation-settings: "wdth" 100, "opsz" 32;
}
.fl-dna-a .price.lg .sale { font-size: 48px; }
.fl-dna-a .price .list {
  font-family: var(--f-mono); font-size: 13px; color: var(--ink-3);
  text-decoration: line-through;
}

/* TLDR (Speakable) */
.fl-dna-a .tldr {
  padding: 26px 30px 28px;
  background: var(--signal-bg);
  border-left: 4px solid var(--signal);
  border-radius: 0 16px 16px 0;
  position: relative;
}
.fl-dna-a .tldr .tldr-label {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--signal-dk); margin-bottom: 10px;
  display: inline-flex; align-items: center; gap: 6px;
}
.fl-dna-a .tldr .tldr-label::before {
  content: ""; width: 14px; height: 1.5px; background: var(--signal-dk);
}
.fl-dna-a .tldr p { font-size: 17px; font-weight: 400; line-height: 1.55; color: var(--ink); }

/* FAQ accordion (CSS-only via <details>) */
.fl-dna-a .faq-list { border-top: 1px solid var(--rule); }
.fl-dna-a .faq-row {
  border-bottom: 1px solid var(--rule);
  padding: 0;
}
.fl-dna-a .faq-row summary {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 22px 0;
  cursor: pointer; list-style: none;
  font-family: var(--f-display);
  font-size: 19px;
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.fl-dna-a .faq-row summary::-webkit-details-marker { display: none; }
.fl-dna-a .faq-row summary .num {
  font-family: var(--f-mono); font-size: 11px; color: var(--signal-dk);
  padding-top: 6px; flex-shrink: 0; width: 26px; letter-spacing: 0.08em;
}
.fl-dna-a .faq-row summary .faq-q-text { flex: 1; }
.fl-dna-a .faq-row summary .faq-plus {
  margin-left: auto; flex-shrink: 0;
  width: 26px; height: 26px; border-radius: 50%;
  border: 1.5px solid var(--ink);
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 14px; line-height: 1;
  color: var(--ink); transition: transform 200ms ease;
}
.fl-dna-a .faq-row[open] summary .faq-plus { transform: rotate(45deg); }
.fl-dna-a .faq-row .faq-a {
  padding: 0 0 22px 40px;
  font-size: 14.5px; color: var(--ink-2); line-height: 1.6;
  max-width: 760px;
}
.fl-dna-a .faq-row .faq-a p + p { margin-top: 10px; }

/* Stamp (AUTHORIZED / DISPATCH) */
.fl-dna-a .stamp {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--signal-dk);
  padding: 5px 10px 4px;
  border: 1.5px dashed var(--signal-dk);
  background: transparent;
  border-radius: 999px;
}
.fl-dna-a .stamp.signal { color: var(--signal-dk); border-color: var(--signal-dk); }
.fl-dna-a .stamp.warm   { color: var(--warm-dk); border-color: var(--warm-dk); }
.fl-dna-a .stamp.ink    { color: var(--ink); border-color: var(--ink); }
.fl-dna-a .stamp.solid  { background: var(--signal); color: var(--ink); border-style: solid; border-color: var(--signal); }
.fl-dna-a .stamp .dot   { width: 5px; height: 5px; background: currentColor; border-radius: 50%; }

/* Lot pill */
.fl-dna-a .lot {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-2);
  padding: 3px 8px; border: 1px solid var(--rule-2); background: var(--bg-tint);
  border-radius: 999px;
  display: inline-block;
}

/* Tags */
.fl-dna-a .tag {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; padding: 4px 9px;
  border: 1px solid currentColor;
  display: inline-block; border-radius: 999px; font-weight: 500;
}
.fl-dna-a .tag.signal      { color: var(--signal-dk); }
.fl-dna-a .tag.warm        { color: var(--warm-dk); }
.fl-dna-a .tag.solid-signal{ background: var(--signal); color: var(--ink); border-color: var(--signal); }
.fl-dna-a .tag.solid-warm  { background: var(--warm); color: #fff; border-color: var(--warm); }
.fl-dna-a .tag.solid-ink   { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.fl-dna-a .tag.solid-sun   { background: var(--sun); color: var(--ink); border-color: var(--sun); }

/* 21+ pictogram */
.fl-dna-a .age21 {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 50%;
  border: 1.5px solid currentColor;
  font-family: var(--f-mono); font-size: 11px; font-weight: 600;
  letter-spacing: -0.02em;
}

/* Family swatch */
.fl-dna-a .fam-sw { display: inline-flex; align-items: center; gap: 6px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--ink-2); }
.fl-dna-a .fam-sw .sw { width: 10px; height: 10px; border-radius: 50%; }

/* Spec table */
.fl-dna-a .spec {
  width: 100%; border-collapse: collapse;
  font-family: var(--f-mono); font-size: 12.5px;
}
.fl-dna-a .spec tr { border-top: 1px solid var(--rule); }
.fl-dna-a .spec tr:last-child { border-bottom: 1px solid var(--rule); }
.fl-dna-a .spec td { padding: 11px 0; vertical-align: top; }
.fl-dna-a .spec td.k { color: var(--ink-3); letter-spacing: 0.08em; text-transform: uppercase; width: 38%; font-size: 11px; }
.fl-dna-a .spec td.v { color: var(--ink); font-feature-settings: "zero" 1; }

/* Schema annotation marker (designer-only — hidden in production) */
.fl-dna-a [data-schema] { position: relative; }

/* ═══════════ 5. Distributor mark (GD lockup) ═══════════ */
.fl-dna-a .gd-mark {
  display: inline-flex; align-items: center; gap: 12px;
  text-decoration: none;
}
.fl-dna-a .gd-mark .monogram {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--signal); color: var(--ink);
  display: grid; place-items: center;
  position: relative;
  flex-shrink: 0;
}
.fl-dna-a .gd-mark .monogram svg { display: block; }
.fl-dna-a .gd-mark .text { display: flex; flex-direction: column; line-height: 1; gap: 4px; }
.fl-dna-a .gd-mark .brand {
  font-family: var(--f-display); font-size: 19px; font-weight: 800; letter-spacing: -0.03em; color: var(--ink);
  font-variation-settings: "wdth" 100, "opsz" 18;
}
.fl-dna-a .gd-mark .brand .vape { color: var(--signal-dk); font-weight: 600; margin-left: 1px; }
.fl-dna-a .gd-mark .sub {
  font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-3);
}
.fl-dna-a .gd-mark[data-variant="knockout"] .monogram { background: #fff; color: var(--signal-dk); }
.fl-dna-a .gd-mark[data-variant="knockout"] .brand    { color: #fff; }
.fl-dna-a .gd-mark[data-variant="knockout"] .brand .vape { color: var(--signal); }
.fl-dna-a .gd-mark[data-variant="knockout"] .sub      { color: rgba(255,255,255,0.7); }
.fl-dna-a .gd-mark[data-variant="small"] .monogram   { width: 28px; height: 28px; }
.fl-dna-a .gd-mark[data-variant="small"] .monogram svg { width: 13px; height: 13px; }
.fl-dna-a .gd-mark[data-variant="small"] .brand      { font-size: 14px; }

/* ═══════════ 6. Layout helpers ═══════════ */
.fl-dna-a .row { display: flex; align-items: center; }
.fl-dna-a .row.start   { align-items: flex-start; }
.fl-dna-a .row.end     { align-items: flex-end; }
.fl-dna-a .row.between { justify-content: space-between; }
.fl-dna-a .row.center  { justify-content: center; }
.fl-dna-a .row.wrap    { flex-wrap: wrap; }
.fl-dna-a .row-gap-4   { gap: 4px; }
.fl-dna-a .row-gap-8   { gap: 8px; }
.fl-dna-a .row-gap-12  { gap: 12px; }
.fl-dna-a .row-gap-16  { gap: 16px; }
.fl-dna-a .row-gap-24  { gap: 24px; }
.fl-dna-a .row-gap-32  { gap: 32px; }
.fl-dna-a .stack { display: flex; flex-direction: column; }
.fl-dna-a .stack-gap-4  { gap: 4px; }
.fl-dna-a .stack-gap-6  { gap: 6px; }
.fl-dna-a .stack-gap-8  { gap: 8px; }
.fl-dna-a .stack-gap-12 { gap: 12px; }
.fl-dna-a .stack-gap-16 { gap: 16px; }
.fl-dna-a .stack-gap-20 { gap: 20px; }
.fl-dna-a .stack-gap-24 { gap: 24px; }
.fl-dna-a .stack-gap-32 { gap: 32px; }
.fl-dna-a .stack-gap-48 { gap: 48px; }
.fl-dna-a .grid { display: grid; }

.fl-dna-a .container {
  max-width: 1240px; margin: 0 auto; padding: 0 28px;
}
.fl-dna-a .container-content { max-width: 1120px; margin: 0 auto; padding: 0 28px; }
.fl-dna-a .container-read    { max-width: 720px;  margin: 0 auto; padding: 0 28px; }

.fl-dna-a .section { padding: 80px 0; }
.fl-dna-a .section-sm { padding: 56px 0; }
.fl-dna-a .section-lg { padding: 120px 0; }
.fl-dna-a .section-band-soft { background: var(--bg-soft); }
.fl-dna-a .section-band-tint { background: var(--bg-tint); }
.fl-dna-a .section-band-ink  { background: var(--ink); color: var(--bg); }

/* Section heading row */
.fl-dna-a .sec-head {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 32px;
  margin-bottom: 32px;
}
.fl-dna-a .sec-head .sec-head-text { max-width: 720px; }
.fl-dna-a .sec-head .sec-head-text .eyebrow { margin-bottom: 12px; display: block; }
.fl-dna-a .sec-head .sec-head-text h2 { margin-bottom: 12px; }
.fl-dna-a .sec-head .sec-head-text .lede { max-width: 640px; }

/* ═══════════ 7. Device silhouettes (CSS-only) ═══════════ */
.fl-dna-a .device-fig {
  display: inline-flex; flex-direction: column; align-items: center; gap: 8px;
}
.fl-dna-a .device-fig .silhouette {
  position: relative;
  border: 1.5px solid var(--ink);
}
.fl-dna-a .device-fig .silhouette.bottle {
  width: 76px; height: 200px;
  background: linear-gradient(180deg, var(--signal) 0 22%, var(--bg-soft) 22% 100%);
  border-radius: 18px 18px 28px 28px;
}
.fl-dna-a .device-fig .silhouette.slab {
  width: 64px; height: 170px;
  background: var(--ink);
  border-radius: 14px;
}
.fl-dna-a .device-fig .silhouette::before { /* mouthpiece */
  content: ""; position: absolute; top: -8px; left: 50%; transform: translateX(-50%);
  width: 28px; height: 10px; background: var(--ink); border-radius: 4px 4px 0 0;
}
.fl-dna-a .device-fig .silhouette.slab::before { width: 20px; height: 8px; }
.fl-dna-a .device-fig .silhouette .screen {
  position: absolute; left: 50%; transform: translateX(-50%);
  width: 60%; height: 20%;
  background: var(--ink); border-radius: 4px;
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 8px;
  color: var(--signal); letter-spacing: 0.05em;
}
.fl-dna-a .device-fig .silhouette.bottle .screen { top: 44%; }
.fl-dna-a .device-fig .silhouette.slab   .screen { top: 10%; height: 18%; }
.fl-dna-a .device-fig .silhouette.bottle .plate {
  position: absolute; top: 10%; left: 50%; transform: translateX(-50%);
  font-family: var(--f-display); font-weight: 800; font-size: 11px;
  color: var(--ink); letter-spacing: -0.04em;
}
.fl-dna-a .device-fig .silhouette.slab .plate {
  position: absolute; bottom: 8%; left: 50%; transform: translateX(-50%);
  font-family: var(--f-mono); font-size: 8px;
  color: var(--signal); letter-spacing: 0.04em;
}
.fl-dna-a .device-fig.lg .silhouette.bottle { width: 152px; height: 400px; }
.fl-dna-a .device-fig.lg .silhouette.slab   { width: 128px; height: 340px; }
.fl-dna-a .device-fig.lg .silhouette .screen { font-size: 14px; }
.fl-dna-a .device-fig.lg .silhouette.bottle .plate { font-size: 20px; }
.fl-dna-a .device-fig.lg .silhouette.slab   .plate { font-size: 13px; }

/* ═══════════ 8. CHROME — announce bar / header / footer / cart panel ═══════════ */

/* Announce bar (top of body) — replaces old fl-promo-tape */
.fl-dna-a .fla-announce {
  background: var(--ink); color: var(--bg);
  padding: 9px 28px;
  display: flex; align-items: center; gap: 14px;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
}
.fl-dna-a .fla-announce .ann-dot {
  width: 6px; height: 6px; background: var(--signal); border-radius: 50%;
}
.fl-dna-a .fla-announce .ann-msg { flex: 1; }
.fl-dna-a .fla-announce .ann-dots { display: flex; gap: 4px; }
.fl-dna-a .fla-announce .ann-dots span {
  width: 18px; height: 2px;
  background: rgba(255,255,255,0.2);
}
.fl-dna-a .fla-announce .ann-dots span.is-active { background: var(--signal); }
.fl-dna-a .fla-announce .ann-21 {
  display: inline-flex; align-items: center; gap: 6px; color: var(--signal);
}
.fl-dna-a .fla-announce .ann-21 .pict {
  display: inline-grid; place-items: center;
  width: 18px; height: 18px; border: 1.5px solid currentColor;
  border-radius: 50%; font-size: 8px; font-weight: 700;
}

/* Header */
.fl-dna-a .fla-header {
  background: var(--bg);
  border-bottom: 1px solid var(--rule);
  padding: 16px 28px;
  display: flex; align-items: center; gap: 32px;
  position: sticky; top: 0; z-index: 30;
}
.fl-dna-a .fla-header.transparent {
  background: transparent;
  border-bottom: 1px solid rgba(214,236,234,0.6);
}
.fl-dna-a .fla-nav {
  display: flex; gap: 4px; margin-left: 16px; flex: 1; flex-wrap: wrap;
}
.fl-dna-a .fla-nav a {
  font-size: 13.5px; font-weight: 500; padding: 8px 12px; border-radius: 999px;
  color: var(--ink-2); cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.fl-dna-a .fla-nav a:hover { color: var(--ink); background: var(--bg-tint); }
.fl-dna-a .fla-nav a.is-active,
.fl-dna-a .fla-nav a[aria-current="page"] {
  color: var(--ink); background: var(--signal-bg);
}
.fl-dna-a .fla-actions { display: flex; align-items: center; gap: 10px; }
.fl-dna-a .fla-actions .btn { white-space: nowrap; }
.fl-dna-a .fla-actions .btn .cart-count {
  background: var(--ink); color: var(--signal); font-family: var(--f-mono);
  font-size: 10px; padding: 1px 6px; border-radius: 999px; font-weight: 600;
  min-width: 18px; text-align: center;
}
.fl-dna-a .fla-actions .search-kbd {
  font-family: var(--f-mono); font-size: 9px;
  padding: 1px 5px; border: 1px solid var(--rule-2);
  background: var(--bg-tint); border-radius: 4px; color: var(--ink-3);
}
.fl-dna-a .fla-hamburger {
  display: none;
  width: 40px; height: 40px; align-items: center; justify-content: center;
  border: 1px solid var(--rule-2); border-radius: 999px; background: var(--bg);
}
.fl-dna-a .fla-hamburger span {
  display: block; width: 16px; height: 1.5px; background: var(--ink); margin: 2.5px 0;
}

/* Mobile drawer */
.fl-dna-a .fla-mobile-dialog {
  border: 0; padding: 0; margin: 0; width: 320px; max-width: 90vw; height: 100vh;
  max-height: 100vh;
  background: var(--bg); color: var(--ink);
  position: fixed; right: 0; top: 0; left: auto;
  box-shadow: -24px 0 60px -20px rgba(10,32,36,0.25);
}
.fl-dna-a .fla-mobile-dialog::backdrop {
  background: rgba(10,32,36,0.35);
}
.fl-dna-a .fla-mobile-head {
  padding: 20px 24px; display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--rule);
}
.fl-dna-a .fla-mobile-close {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid var(--rule-2); background: var(--bg-tint);
  display: grid; place-items: center; font-size: 16px; color: var(--ink);
}
.fl-dna-a .fla-mobile-list {
  list-style: none; margin: 0; padding: 16px 24px; display: flex; flex-direction: column; gap: 4px;
}
.fl-dna-a .fla-mobile-list li > a,
.fl-dna-a .fla-mobile-list details > summary {
  display: block; padding: 12px 0; font-size: 16px; font-weight: 600;
  color: var(--ink); cursor: pointer; list-style: none;
}
.fl-dna-a .fla-mobile-list details > summary::-webkit-details-marker { display: none; }
.fl-dna-a .fla-mobile-list details > summary::after {
  content: "▾"; float: right; color: var(--ink-3); font-size: 12px; transition: transform 200ms ease;
}
.fl-dna-a .fla-mobile-list details[open] > summary::after { transform: rotate(180deg); }
.fl-dna-a .fla-mobile-list details ul {
  padding: 6px 0 12px 14px;
  border-left: 1px solid var(--rule);
  margin-left: 2px;
}
.fl-dna-a .fla-mobile-list details ul li a {
  display: block; padding: 8px 0; font-size: 14px; font-weight: 500; color: var(--ink-2);
}
.fl-dna-a .fla-mobile-divider {
  height: 1px; background: var(--rule); margin: 12px 0;
}

/* Footer */
.fl-dna-a .fla-footer {
  background: var(--ink); color: var(--bg);
  padding: 56px 28px 28px;
}
.fl-dna-a .fla-footer-inner { max-width: 1280px; margin: 0 auto; }
.fl-dna-a .fla-warning {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
  padding: 12px 18px;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  color: rgba(255,255,255,0.85); margin-bottom: 48px; text-align: center;
  border-radius: 8px;
}
.fl-dna-a .fla-footer-grid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
  gap: 32px; margin-bottom: 48px;
}
.fl-dna-a .fla-footer-grid .brand-block p {
  margin-top: 18px; font-size: 13.5px; color: rgba(255,255,255,0.7);
  line-height: 1.55; max-width: 280px;
}
.fl-dna-a .fla-footer-grid .col-title {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--signal); font-weight: 500;
  margin-bottom: 14px;
}
.fl-dna-a .fla-footer-grid ul { display: flex; flex-direction: column; gap: 10px; padding: 0; }
.fl-dna-a .fla-footer-grid ul li a {
  font-size: 13.5px; color: rgba(255,255,255,0.78);
  transition: color 120ms ease;
}
.fl-dna-a .fla-footer-grid ul li a:hover { color: var(--signal); }

.fl-dna-a .fla-dispatch {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0;
  border: 1px solid rgba(255,255,255,0.12); border-radius: 12px;
  overflow: hidden; margin-bottom: 32px;
}
.fl-dna-a .fla-dispatch > div {
  padding: 20px 24px;
}
.fl-dna-a .fla-dispatch > div + div { border-left: 1px solid rgba(255,255,255,0.12); }
.fl-dna-a .fla-dispatch .eyebrow {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--signal); margin-bottom: 8px; display: block;
}
.fl-dna-a .fla-dispatch .strong { font-size: 15px; font-weight: 600; color: var(--bg); }
.fl-dna-a .fla-dispatch .sub    { font-size: 14px; color: rgba(255,255,255,0.7); }
.fl-dna-a .fla-dispatch a       { color: var(--signal); font-size: 13px; text-decoration: underline; }

/* Footer subscribe (Stock Watch) */
.fl-dna-a .fla-subscribe {
  background: rgba(58,205,200,0.07);
  border: 1px dashed rgba(58,205,200,0.35);
  border-radius: 12px;
  padding: 18px 20px;
  margin-top: 18px;
}
.fl-dna-a .fla-subscribe .sub-eyebrow {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--signal);
  display: flex; align-items: center; gap: 6px;
}
.fl-dna-a .fla-subscribe .sub-eyebrow::before {
  content: ""; width: 5px; height: 5px; background: var(--signal); border-radius: 50%;
}
.fl-dna-a .fla-subscribe p {
  font-size: 13px; color: rgba(255,255,255,0.75); line-height: 1.5;
  margin: 8px 0 12px;
}
.fl-dna-a .fla-subscribe form {
  display: flex; gap: 6px; align-items: center;
}
.fl-dna-a .fla-subscribe input {
  flex: 1; padding: 10px 12px; border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.2);
  background: rgba(0,0,0,0.25); color: var(--bg);
  font-family: var(--f-body); font-size: 13px;
}
.fl-dna-a .fla-subscribe input::placeholder { color: rgba(255,255,255,0.45); }
.fl-dna-a .fla-subscribe button {
  width: 38px; height: 38px; border-radius: 8px;
  background: var(--signal); color: var(--ink);
  font-family: var(--f-mono); font-size: 16px; font-weight: 700;
  display: grid; place-items: center;
}
.fl-dna-a .fla-subscribe .done, .fl-dna-a .fla-subscribe .bad { font-size: 12px; margin-top: 8px; }
.fl-dna-a .fla-subscribe .done { color: var(--signal); }
.fl-dna-a .fla-subscribe .bad  { color: var(--warm); }

/* Footer legal row */
.fl-dna-a .fla-legal {
  border-top: 1px solid rgba(255,255,255,0.12);
  padding-top: 20px;
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  color: rgba(255,255,255,0.55);
}
.fl-dna-a .fla-legal a { color: rgba(255,255,255,0.65); }
.fl-dna-a .fla-legal a:hover { color: var(--signal); }
.fl-dna-a .fla-legal .legal-dot {
  width: 4px; height: 4px; background: rgba(255,255,255,0.3); border-radius: 50%;
}
.fl-dna-a .fla-legal .legal-tail {
  margin-left: auto; font-family: var(--f-body); font-size: 12px; color: rgba(255,255,255,0.5);
  max-width: 360px; text-align: right;
}

/* Cart side panel (DNA-A restyle of the existing Alpine cart drawer) */
.fl-dna-a .fl-cart-panel {
  position: fixed; top: 0; right: 0; width: 420px; max-width: 100vw; height: 100vh;
  background: var(--bg); color: var(--ink);
  box-shadow: -24px 0 60px -20px rgba(10,32,36,0.25);
  z-index: 100; transform: translateX(100%);
  transition: transform 320ms cubic-bezier(0.22, 0.61, 0.36, 1);
  display: flex; flex-direction: column;
}
.fl-dna-a .fl-cart-panel.is-open { transform: translateX(0); }
.fl-dna-a .fl-cart-panel-head {
  padding: 20px 24px; display: flex; align-items: center; justify-content: space-between;
  border-bottom: 1px solid var(--rule);
}
.fl-dna-a .fl-cart-panel-title {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--signal-dk);
}
.fl-dna-a .fl-cart-panel-head button {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid var(--rule-2); background: var(--bg-tint); color: var(--ink);
  display: grid; place-items: center;
}
.fl-dna-a .fl-cart-panel-body { flex: 1; overflow-y: auto; padding: 24px; }
.fl-dna-a .fl-cart-panel-foot {
  padding: 20px 24px; border-top: 1px solid var(--rule); display: flex; flex-direction: column; gap: 12px;
}
.fl-dna-a .fl-cart-subtotal {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--f-mono); font-size: 13px; color: var(--ink-2);
}
.fl-dna-a .fl-cart-subtotal strong { font-size: 22px; color: var(--signal-dk); font-family: var(--f-display); }
.fl-dna-a .fl-cart-items { display: flex; flex-direction: column; gap: 16px; }
.fl-dna-a .fl-cart-item {
  display: grid; grid-template-columns: 64px 1fr auto; gap: 12px;
  align-items: flex-start;
  padding-bottom: 16px; border-bottom: 1px solid var(--rule);
}
.fl-dna-a .fl-cart-item img { width: 64px; height: 64px; border-radius: 8px; object-fit: cover; background: var(--bg-tint); }
.fl-dna-a .fl-cart-item-name { font-size: 14px; font-weight: 600; color: var(--ink); margin-bottom: 4px; line-height: 1.3; }
.fl-dna-a .fl-cart-item-var  { font-size: 12px; color: var(--ink-3); font-family: var(--f-mono); margin-bottom: 8px; }
.fl-dna-a .fl-cart-qty {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--f-mono); font-size: 12px;
}
.fl-dna-a .fl-cart-qty button {
  width: 24px; height: 24px; border-radius: 6px;
  border: 1px solid var(--rule-2); background: var(--bg-tint); color: var(--ink);
}
.fl-dna-a .fl-cart-qty .fl-cart-rm {
  margin-left: 8px; padding: 0 6px; height: 24px;
  font-size: 11px; color: var(--ink-3); border: 0; background: transparent;
}
.fl-dna-a .fl-cart-price {
  font-family: var(--f-mono); font-size: 13px; font-weight: 600; color: var(--ink);
}
.fl-dna-a .fl-muted { color: var(--ink-3); }

/* ═══════════ 9. PAGE SECTIONS ═══════════ */

/* Page outer band — soft cream behind sticky chrome (Direction A signature) */
.fl-dna-a .page-band-outer {
  background: var(--bg-cream);
  min-height: 100vh;
}
.fl-dna-a .page-shell {
  background: var(--bg);
  border-radius: 24px;
  overflow: hidden;
  margin: 16px auto;
  max-width: 1480px;
  box-shadow: var(--fl-sh-card-lg);
}

/* —— HOME —— */
.fl-dna-a .home-hero {
  padding: 80px 0 96px;
  position: relative;
}
.fl-dna-a .home-hero-grid {
  display: grid; grid-template-columns: 1.2fr 1fr;
  gap: 64px; align-items: center;
}
.fl-dna-a .home-hero h1 {
  font-size: 80px; line-height: 0.96; margin-bottom: 24px;
  letter-spacing: -0.03em;
}
.fl-dna-a .home-hero h1 .signal-mark { color: var(--signal-dk); }
.fl-dna-a .home-hero .lede {
  font-size: 19px; color: var(--ink-2); max-width: 560px; margin-bottom: 32px;
}
.fl-dna-a .home-hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 32px; }
.fl-dna-a .home-hero-meta {
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
  font-family: var(--f-mono); font-size: 11px; color: var(--ink-3);
  letter-spacing: 0.08em; text-transform: uppercase;
}
.fl-dna-a .home-hero-meta .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--rule-2); }

.fl-dna-a .home-hero-theatre {
  background: linear-gradient(160deg, var(--signal-bg) 0%, var(--bg-tint) 60%);
  border-radius: 24px;
  padding: 48px 32px;
  position: relative;
  display: flex; align-items: center; justify-content: center;
  min-height: 480px;
  border: 1px solid var(--rule);
}
.fl-dna-a .home-hero-theatre .theatre-corner-stamp {
  position: absolute; top: 24px; right: 24px;
}
.fl-dna-a .home-hero-theatre .theatre-corner-lot {
  position: absolute; bottom: 24px; left: 24px;
}

/* 4-SKU grid */
.fl-dna-a .sku-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}

/* Product card */
.fl-dna-a .product-card {
  background: var(--bg); border: 1px solid var(--rule);
  border-radius: 16px; overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform 180ms ease, box-shadow 180ms ease;
}
.fl-dna-a .product-card:hover {
  transform: translateY(-3px); box-shadow: var(--fl-sh-card-lg);
}
.fl-dna-a .product-card .pc-art {
  position: relative; padding: 32px 24px 28px;
  min-height: 260px;
  display: flex; align-items: flex-end; justify-content: center;
}
.fl-dna-a .product-card.mello-fam .pc-art {
  background: linear-gradient(180deg, var(--signal-bg), var(--bg-soft));
}
.fl-dna-a .product-card.ut-fam .pc-art {
  background: linear-gradient(180deg, var(--warm-bg), var(--bg-tint));
}
.fl-dna-a .product-card .pc-art .pc-tag {
  position: absolute; top: 16px; left: 16px;
}
.fl-dna-a .product-card .pc-art .pc-lot {
  position: absolute; top: 18px; right: 16px;
}
.fl-dna-a .product-card .pc-body { padding: 24px; flex: 1; display: flex; flex-direction: column; }
.fl-dna-a .product-card .pc-meta-row {
  display: flex; justify-content: space-between; margin-bottom: 8px;
}
.fl-dna-a .product-card .pc-puffs {
  font-family: var(--f-mono); font-size: 12px; color: var(--ink-3); font-variant-numeric: tabular-nums;
}
.fl-dna-a .product-card h3 { margin-bottom: 10px; }
.fl-dna-a .product-card .pc-blurb {
  font-size: 13.5px; line-height: 1.5; color: var(--ink-2); margin-bottom: 18px; flex: 1;
}
.fl-dna-a .product-card .pc-foot {
  display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 18px;
}
.fl-dna-a .product-card .pc-actions { display: flex; gap: 8px; }
.fl-dna-a .product-card .pc-actions .btn { flex: 1; }
.fl-dna-a .product-card .pc-specs {
  margin-top: 10px;
  font-family: var(--f-mono); font-size: 11px; color: var(--ink-3);
  display: flex; gap: 8px; flex-wrap: wrap;
}

/* Collections row */
.fl-dna-a .col-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px;
}
.fl-dna-a .col-card {
  background: var(--bg); border: 1px solid var(--rule);
  border-radius: 16px; overflow: hidden; display: flex; flex-direction: column;
  transition: transform 180ms ease, box-shadow 180ms ease;
  text-decoration: none; color: inherit;
}
.fl-dna-a .col-card:hover { transform: translateY(-3px); box-shadow: var(--fl-sh-card-lg); }
.fl-dna-a .col-card .col-head {
  padding: 24px 24px 20px; position: relative; min-height: 140px;
  display: flex; align-items: flex-end;
}
.fl-dna-a .col-card.accent-signal .col-head {
  background: linear-gradient(135deg, var(--signal-bg), #fff);
}
.fl-dna-a .col-card.accent-warm .col-head {
  background: linear-gradient(135deg, var(--warm-bg), #fff);
}
.fl-dna-a .col-card .col-head .col-glyph {
  position: absolute; top: 18px; right: 22px;
  font-family: var(--f-display); font-size: 64px; font-weight: 800;
  color: var(--signal-dk); opacity: 0.35; line-height: 1;
}
.fl-dna-a .col-card.accent-warm .col-head .col-glyph { color: var(--warm-dk); }
.fl-dna-a .col-card h3 { font-size: 22px; line-height: 1.15; margin-top: 8px; }
.fl-dna-a .col-card .col-body { padding: 24px; flex: 1; display: flex; flex-direction: column; justify-content: space-between; }
.fl-dna-a .col-card .col-body p { font-size: 13px; line-height: 1.5; color: var(--ink-2); margin-bottom: 14px; }

/* Warehouse / Greenwood stat block */
.fl-dna-a .warehouse-block {
  background: var(--bg-soft); border: 1px solid var(--rule);
  border-radius: 24px; padding: 40px;
  display: grid; grid-template-columns: 1.1fr 1fr 1fr 1fr;
  position: relative; overflow: hidden;
}
.fl-dna-a .warehouse-block .wh-lead {
  padding-right: 32px;
}
.fl-dna-a .warehouse-block .wh-lead h3 {
  font-size: 28px; margin-top: 10px; margin-bottom: 12px; line-height: 1.18;
}
.fl-dna-a .warehouse-block .wh-stat {
  padding: 0 28px; border-left: 1px solid var(--rule);
  display: flex; flex-direction: column; justify-content: space-between;
}
.fl-dna-a .warehouse-block .wh-stat .num {
  font-size: 52px; color: var(--signal-dk); font-weight: 700;
  letter-spacing: -0.04em; font-family: var(--f-display); line-height: 1;
}
.fl-dna-a .warehouse-block .wh-stat .lbl { font-size: 15px; font-weight: 600; margin-top: 6px; }
.fl-dna-a .warehouse-block .wh-stat .sub { font-size: 13px; color: var(--ink-2); margin-top: 10px; }

/* Authenticity callout (the trust beat) */
.fl-dna-a .authenticity {
  background: var(--ink); color: var(--bg);
  border-radius: 24px; padding: 48px;
  position: relative; overflow: hidden;
}
.fl-dna-a .authenticity .auth-stamp {
  position: absolute; top: 28px; right: 32px;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--signal);
  border: 1.5px dashed var(--signal); padding: 4px 10px; border-radius: 999px;
}
.fl-dna-a .authenticity .auth-stamp .dot {
  display: inline-block; width: 5px; height: 5px; background: var(--signal);
  border-radius: 50%; margin-right: 6px; vertical-align: middle;
}
.fl-dna-a .authenticity-grid {
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: center;
}
.fl-dna-a .authenticity h2 {
  color: var(--bg); margin-top: 14px; margin-bottom: 16px; font-size: 44px;
}
.fl-dna-a .authenticity p {
  color: rgba(255,255,255,0.78); font-size: 16px; line-height: 1.55;
  max-width: 560px; margin-bottom: 28px;
}
.fl-dna-a .authenticity .auth-ghost {
  background: rgba(255,255,255,0.05); color: var(--bg); border-color: rgba(255,255,255,0.2);
}
.fl-dna-a .authenticity .auth-card {
  border: 1.5px dashed rgba(58,205,200,0.35);
  border-radius: 16px; padding: 28px;
  background: rgba(58,205,200,0.05);
}
.fl-dna-a .authenticity .auth-card .code {
  font-family: var(--f-mono); font-size: 18px; letter-spacing: 0.06em;
  color: var(--signal); padding: 14px 18px; border: 1px solid rgba(58,205,200,0.4);
  background: rgba(0,0,0,0.25); border-radius: 8px; text-align: center; margin-bottom: 14px;
}
.fl-dna-a .authenticity .auth-card ol {
  display: flex; flex-direction: column; gap: 12px;
  font-size: 13.5px; color: rgba(255,255,255,0.85);
}
.fl-dna-a .authenticity .auth-card ol li .step-no {
  color: var(--signal); font-family: var(--f-mono);
}

/* "What we don't claim" callout */
.fl-dna-a .dont-claim {
  background: var(--warm-bg); border: 1px solid #ffd5c5;
  border-radius: 16px; padding: 32px;
}
.fl-dna-a .dont-claim .dc-head {
  display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 18px;
}
.fl-dna-a .dont-claim ul { display: flex; flex-direction: column; gap: 12px; padding: 0; }
.fl-dna-a .dont-claim li { display: flex; gap: 12px; align-items: flex-start; font-size: 14.5px; color: var(--ink); line-height: 1.45; }
.fl-dna-a .dont-claim li .x-pict {
  flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%;
  background: var(--warm); color: #fff; font-family: var(--f-mono);
  font-size: 11px; font-weight: 700; display: grid; place-items: center; margin-top: 1px;
}

/* Trust strip — 4 icons row */
.fl-dna-a .trust-strip {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  background: var(--bg); border: 1px solid var(--rule-2); border-radius: 16px;
  overflow: hidden;
}
.fl-dna-a .trust-strip > div {
  padding: 20px 22px; display: flex; align-items: flex-start; gap: 14px;
}
.fl-dna-a .trust-strip > div + div { border-left: 1px solid var(--rule); }
.fl-dna-a .trust-strip .icon {
  flex-shrink: 0; width: 36px; height: 36px; border-radius: 50%;
  background: var(--signal-bg); color: var(--signal-dk);
  display: grid; place-items: center;
  font-family: var(--f-mono); font-size: 13px; font-weight: 700;
}
.fl-dna-a .trust-strip .lbl { font-size: 13.5px; font-weight: 600; color: var(--ink); line-height: 1.25; }
.fl-dna-a .trust-strip .sub { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); margin-top: 4px; display: block; }

/* Review card */
.fl-dna-a .review-card {
  background: var(--bg); border: 1px solid var(--rule);
  border-radius: 16px; padding: 24px;
  min-height: 240px; display: flex; flex-direction: column;
}
.fl-dna-a .review-card .stars { display: flex; gap: 4px; }
.fl-dna-a .review-card .stars span { font-size: 14px; }
.fl-dna-a .review-card .stars .filled { color: var(--sun); }
.fl-dna-a .review-card .stars .empty  { color: var(--rule); }
.fl-dna-a .review-card h4 { font-size: 17px; margin-bottom: 10px; }
.fl-dna-a .review-card .review-body { font-size: 14px; line-height: 1.55; color: var(--ink-2); margin-bottom: 18px; flex: 1; }
.fl-dna-a .review-card .review-meta { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; }
.fl-dna-a .review-card .review-meta .who-name { font-size: 13.5px; font-weight: 600; }
.fl-dna-a .review-card .review-meta .who-city { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.fl-dna-a .reviews-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}

/* Blog teaser row */
.fl-dna-a .blog-teaser-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.fl-dna-a .blog-card {
  background: var(--bg); border: 1px solid var(--rule);
  border-radius: 16px; overflow: hidden; display: flex; flex-direction: column;
  transition: transform 180ms ease, box-shadow 180ms ease;
  color: inherit; text-decoration: none;
}
.fl-dna-a .blog-card:hover { transform: translateY(-3px); box-shadow: var(--fl-sh-card-lg); }
.fl-dna-a .blog-card .blog-head {
  background: linear-gradient(180deg, var(--bg-tint), var(--bg-soft));
  padding: 24px; min-height: 130px;
  display: flex; flex-direction: column; justify-content: space-between;
  border-bottom: 1px solid var(--rule);
}
.fl-dna-a .blog-card .blog-body { padding: 20px 24px 24px; flex: 1; }
.fl-dna-a .blog-card h3 { font-size: 19px; line-height: 1.2; margin-bottom: 10px; }
.fl-dna-a .blog-card .blog-meta { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--ink-3); text-transform: uppercase; }

/* —— PDP —— */
.fl-dna-a .pdp-hero { padding: 32px 0 64px; }
.fl-dna-a .pdp-hero-grid {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px;
}
.fl-dna-a .pdp-gallery {
  background: linear-gradient(180deg, var(--signal-bg) 0 60%, var(--bg-soft) 60% 100%);
  border-radius: 24px;
  padding: 48px; position: relative;
  min-height: 540px; display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--rule);
}
.fl-dna-a .pdp-gallery.ut-fam {
  background: linear-gradient(180deg, var(--warm-bg) 0 60%, var(--bg-tint) 60% 100%);
}
.fl-dna-a .pdp-gallery .gallery-tag    { position: absolute; top: 24px; left: 24px; }
.fl-dna-a .pdp-gallery .gallery-stamp  { position: absolute; top: 24px; right: 24px; }
.fl-dna-a .pdp-gallery .gallery-thumbs { position: absolute; bottom: 24px; left: 24px; right: 24px; display: flex; gap: 8px; }
.fl-dna-a .pdp-gallery .gallery-thumbs .thumb {
  width: 60px; height: 60px; border-radius: 10px;
  background: rgba(255,255,255,0.6); border: 1.5px solid var(--rule-2);
}
.fl-dna-a .pdp-gallery .gallery-thumbs .thumb.is-active { border-color: var(--ink); }

.fl-dna-a .pdp-info { display: flex; flex-direction: column; gap: 24px; padding-top: 12px; }
.fl-dna-a .pdp-info h1 {
  font-size: 56px; line-height: 1; margin-bottom: 12px; letter-spacing: -0.025em;
}
.fl-dna-a .pdp-info .pdp-blurb { font-size: 16px; line-height: 1.55; color: var(--ink-2); max-width: 480px; }

.fl-dna-a .pdp-rating { display: flex; align-items: center; gap: 12px; }
.fl-dna-a .pdp-rating .stars { display: flex; gap: 2px; color: var(--sun); }
.fl-dna-a .pdp-rating .rating-num { font-family: var(--f-mono); font-size: 13px; color: var(--ink); font-weight: 600; }
.fl-dna-a .pdp-rating .rating-count { font-family: var(--f-mono); font-size: 12px; color: var(--ink-3); }

.fl-dna-a .pdp-price-block {
  background: var(--bg-soft); border: 1px solid var(--rule); border-radius: 16px; padding: 20px 24px;
}
.fl-dna-a .pdp-price-block .promo-line {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--signal-dk);
  text-transform: uppercase; margin-top: 8px; display: block;
}

/* Variation selector — single-flavor chip grid */
.fl-dna-a .var-select-head {
  display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px;
}
.fl-dna-a .var-select-head .label { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
.fl-dna-a .var-select-head .var-current { font-size: 14px; font-weight: 600; color: var(--ink); }
.fl-dna-a .var-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
}
.fl-dna-a .var-grid.dense { grid-template-columns: repeat(3, 1fr); }

/* Variation selector — dual-flavor pairing UX (UT 50K only) */
.fl-dna-a .var-dual-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}

/* PDP qty + cta row */
.fl-dna-a .pdp-cta-row { display: flex; gap: 12px; align-items: stretch; }
.fl-dna-a .qty-stepper {
  display: inline-flex; align-items: center; border: 1.5px solid var(--rule-2);
  border-radius: 999px; overflow: hidden;
}
.fl-dna-a .qty-stepper button {
  width: 42px; height: 46px; background: var(--bg-tint); color: var(--ink);
  font-family: var(--f-mono); font-size: 18px;
}
.fl-dna-a .qty-stepper .qty-val {
  width: 50px; text-align: center; font-family: var(--f-mono); font-size: 15px; font-variant-numeric: tabular-nums;
}

/* PDP trust strip (small) */
.fl-dna-a .pdp-trust-mini {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px 16px;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--ink-2); text-transform: uppercase;
  padding-top: 8px;
}
.fl-dna-a .pdp-trust-mini .trust-pill {
  display: inline-flex; align-items: center; gap: 8px;
}
.fl-dna-a .pdp-trust-mini .trust-pill::before {
  content: "✓"; width: 16px; height: 16px; border-radius: 50%;
  background: var(--signal-bg); color: var(--signal-dk);
  display: grid; place-items: center; font-size: 10px; font-weight: 700;
}

/* PDP — storySlot blocks */
.fl-dna-a .story-block {
  border-radius: 24px; padding: 48px;
  background: var(--bg-soft); border: 1px solid var(--rule);
}
.fl-dna-a .story-block.ink { background: var(--ink); color: var(--bg); border-color: var(--ink); }
.fl-dna-a .story-block.ink h2 { color: var(--bg); }
.fl-dna-a .story-block.ink .lede { color: rgba(255,255,255,0.78); }
.fl-dna-a .story-block-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px;
}

/* Mello editions tab strip */
.fl-dna-a .ed-tabs {
  display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 32px;
  padding: 6px; border: 1px solid var(--rule-2); border-radius: 999px; background: var(--bg-tint);
}
.fl-dna-a .ed-tabs button {
  padding: 8px 14px; border-radius: 999px;
  font-family: var(--f-body); font-size: 13px; font-weight: 600;
  color: var(--ink-2); background: transparent;
}
.fl-dna-a .ed-tabs button.is-active {
  background: var(--ink); color: var(--bg);
}

/* Dual tank diagram (UT 50K) */
.fl-dna-a .dual-tank-vis {
  display: grid; grid-template-columns: 1fr auto 1fr; gap: 0;
  border: 2px solid var(--ink); border-radius: 16px;
  background: var(--bg); overflow: hidden;
}
.fl-dna-a .dual-tank-vis .dtv-side {
  padding: 24px;
}
.fl-dna-a .dual-tank-vis .dtv-a { background: var(--signal-bg); color: var(--signal-dk); }
.fl-dna-a .dual-tank-vis .dtv-b { background: var(--warm-bg); color: var(--warm-dk); text-align: right; }
.fl-dna-a .dual-tank-vis .dtv-divider {
  width: 2px; background: var(--ink); position: relative;
}
.fl-dna-a .dual-tank-vis .dtv-divider::after {
  content: "/"; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  background: var(--bg); padding: 4px 8px; border-radius: 6px;
  font-family: var(--f-mono); font-size: 16px; color: var(--ink); font-weight: 600;
}
.fl-dna-a .dual-tank-vis .dtv-label { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 8px; opacity: 0.8; }
.fl-dna-a .dual-tank-vis .dtv-name  { font-family: var(--f-display); font-size: 28px; font-weight: 700; letter-spacing: -0.02em; }
.fl-dna-a .dual-tank-vis .dtv-prof  { font-family: var(--f-mono); font-size: 11px; color: inherit; opacity: 0.7; margin-top: 6px; }

/* —— COLLECTION pages —— */
.fl-dna-a .col-hero {
  padding: 64px 0 48px;
  background: linear-gradient(180deg, var(--signal-bg), var(--bg-tint) 80%);
}
.fl-dna-a .col-hero h1 {
  font-size: 56px; line-height: 1; letter-spacing: -0.025em; margin-bottom: 16px;
}
.fl-dna-a .col-hero .lede { max-width: 720px; }
.fl-dna-a .col-hero .col-counter {
  font-family: var(--f-mono); font-size: 13px; color: var(--signal-dk);
  display: inline-block; margin-top: 18px;
  padding: 4px 12px; border: 1px solid var(--signal-dk); border-radius: 999px;
}

.fl-dna-a .col-filter-bar {
  background: var(--bg); border: 1px solid var(--rule-2);
  border-radius: 16px; padding: 18px 24px;
  display: flex; align-items: center; gap: 24px; flex-wrap: wrap; margin-bottom: 32px;
}
.fl-dna-a .col-filter-bar .filter-label {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--ink-3); margin-right: 8px;
}
.fl-dna-a .flavor-matrix {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
}
.fl-dna-a .flavor-card {
  background: var(--bg); border: 1px solid var(--rule); border-radius: 14px;
  padding: 18px; display: flex; flex-direction: column; gap: 10px;
  transition: transform 160ms ease, box-shadow 160ms ease;
  text-decoration: none; color: inherit;
}
.fl-dna-a .flavor-card:hover { transform: translateY(-2px); box-shadow: var(--fl-sh-card); }
.fl-dna-a .flavor-card .fc-art {
  height: 80px; border-radius: 10px;
  background: linear-gradient(135deg, var(--fam-fruit), color-mix(in srgb, var(--fam-fruit) 50%, white));
  position: relative;
}
.fl-dna-a .flavor-card[data-fam="berry"]     .fc-art { background: linear-gradient(135deg, var(--fam-berry), #ffd8e6); }
.fl-dna-a .flavor-card[data-fam="berry-ice"] .fc-art { background: linear-gradient(135deg, var(--fam-berry-ice), #e6f1fb); }
.fl-dna-a .flavor-card[data-fam="mint"]      .fc-art { background: linear-gradient(135deg, var(--fam-mint), #d7f1e5); }
.fl-dna-a .flavor-card[data-fam="tropical"]  .fc-art { background: linear-gradient(135deg, var(--fam-tropical), #fff0d6); }
.fl-dna-a .flavor-card[data-fam="candy"]     .fc-art { background: linear-gradient(135deg, var(--fam-candy), #ffdfee); }
.fl-dna-a .flavor-card[data-fam="floral"]    .fc-art { background: linear-gradient(135deg, var(--fam-floral), #f3dff5); }
.fl-dna-a .flavor-card[data-fam="fruit"]     .fc-art { background: linear-gradient(135deg, var(--fam-fruit), #ffe1c6); }
.fl-dna-a .flavor-card[data-fam="fruit-ice"] .fc-art { background: linear-gradient(135deg, var(--fam-fruit-ice), #d6eff2); }
.fl-dna-a .flavor-card[data-fam="tobacco"]   .fc-art { background: linear-gradient(135deg, var(--fam-tobacco), #e4d9c5); }

.fl-dna-a .flavor-card h4   { font-size: 15px; letter-spacing: -0.01em; }
.fl-dna-a .flavor-card .fc-profile { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.05em; color: var(--ink-3); }
.fl-dna-a .flavor-card .fc-foot {
  display: flex; justify-content: space-between; align-items: center; margin-top: auto;
  font-size: 11px; color: var(--ink-3);
}

.fl-dna-a .price-table {
  width: 100%; border-collapse: collapse; font-family: var(--f-body);
}
.fl-dna-a .price-table th, .fl-dna-a .price-table td {
  padding: 16px 14px; text-align: left; border-bottom: 1px solid var(--rule);
}
.fl-dna-a .price-table th {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-3); font-weight: 500;
  background: var(--bg-soft);
}
.fl-dna-a .price-table td.price-cell { font-family: var(--f-display); font-size: 22px; color: var(--signal-dk); font-weight: 700; }
.fl-dna-a .price-table td.ppm-cell   { font-family: var(--f-mono); font-size: 13px; color: var(--ink-2); }

/* States grid — Near Me */
.fl-dna-a .states-grid {
  display: grid; grid-template-columns: repeat(10, 1fr); gap: 6px;
}
.fl-dna-a .states-grid .state-pill {
  text-align: center;
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.06em;
  padding: 8px 4px; border: 1px solid var(--rule-2);
  border-radius: 8px; color: var(--ink-2); background: var(--bg);
}
.fl-dna-a .states-grid .state-pill.fav { background: var(--signal-bg); color: var(--signal-dk); border-color: var(--signal-dk); }

/* —— PILLAR / BLOG —— */
.fl-dna-a .pillar-hero {
  padding: 64px 0 32px;
}
.fl-dna-a .pillar-hero h1 {
  font-size: 64px; line-height: 1; letter-spacing: -0.03em; margin-bottom: 18px;
  max-width: 920px;
}
.fl-dna-a .pillar-hero .byline {
  font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-3); margin-top: 24px;
  display: flex; gap: 14px; flex-wrap: wrap; align-items: center;
}
.fl-dna-a .pillar-hero .byline .dot { width: 3px; height: 3px; background: var(--rule-2); border-radius: 50%; }

.fl-dna-a .pillar-layout {
  display: grid; grid-template-columns: 220px 1fr; gap: 64px;
  padding: 48px 0;
}
.fl-dna-a .pillar-toc {
  position: sticky; top: 80px; align-self: start;
}
.fl-dna-a .pillar-toc .toc-label {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--ink-3); margin-bottom: 14px; display: block;
}
.fl-dna-a .pillar-toc ul { display: flex; flex-direction: column; gap: 8px; padding: 0; }
.fl-dna-a .pillar-toc ul li a {
  font-size: 13px; line-height: 1.4; color: var(--ink-2);
  padding: 6px 0; display: block;
  border-left: 1.5px solid var(--rule); padding-left: 14px;
}
.fl-dna-a .pillar-toc ul li a:hover { color: var(--ink); border-color: var(--signal); }
.fl-dna-a .pillar-toc ul li a.is-active { color: var(--ink); border-color: var(--signal-dk); font-weight: 600; }
.fl-dna-a .pillar-body { max-width: 720px; }
.fl-dna-a .pillar-body h2 { font-size: 32px; margin-top: 56px; margin-bottom: 18px; }
.fl-dna-a .pillar-body h3 { margin-top: 32px; margin-bottom: 12px; }
.fl-dna-a .pillar-body p, .fl-dna-a .pillar-body li {
  font-size: 16px; line-height: 1.65; color: var(--ink-2); margin-bottom: 18px;
}
.fl-dna-a .pillar-body p + p { margin-top: 0; }
.fl-dna-a .pillar-body strong, .fl-dna-a .pillar-body b { color: var(--ink); font-weight: 600; }
.fl-dna-a .pillar-body ul { list-style: none; padding-left: 0; margin-bottom: 18px; }
.fl-dna-a .pillar-body ul li { padding-left: 26px; position: relative; margin-bottom: 8px; }
.fl-dna-a .pillar-body ul li::before {
  content: ""; position: absolute; left: 0; top: 12px;
  width: 14px; height: 1.5px; background: var(--signal-dk);
}
.fl-dna-a .pillar-body ol { padding-left: 0; margin-bottom: 18px; counter-reset: lol; }
.fl-dna-a .pillar-body ol li { padding-left: 36px; position: relative; margin-bottom: 8px; counter-increment: lol; }
.fl-dna-a .pillar-body ol li::before {
  content: counter(lol, decimal-leading-zero) ".";
  position: absolute; left: 0; top: 0;
  font-family: var(--f-mono); font-size: 13px; color: var(--signal-dk); font-weight: 600;
}
.fl-dna-a .pillar-body a { color: var(--signal-dk); text-decoration: underline; text-underline-offset: 3px; }
.fl-dna-a .pillar-body a:hover { color: var(--ink); }

.fl-dna-a .pro-tip {
  background: var(--signal-bg); border-left: 4px solid var(--signal);
  border-radius: 0 16px 16px 0; padding: 24px 28px; margin: 32px 0;
}
.fl-dna-a .pro-tip .tip-label {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--signal-dk); margin-bottom: 8px; display: block;
}
.fl-dna-a .service-bulletin {
  background: var(--warm-bg); border-left: 4px solid var(--warm);
  border-radius: 0 16px 16px 0; padding: 24px 28px; margin: 32px 0;
}
.fl-dna-a .service-bulletin .tip-label {
  color: var(--warm-dk);
}

.fl-dna-a .pull-quote {
  font-family: var(--f-display); font-size: 28px; font-weight: 500;
  line-height: 1.25; letter-spacing: -0.02em; color: var(--ink);
  border-left: 4px solid var(--ink); padding-left: 32px; margin: 48px 0;
}
.fl-dna-a .pull-quote cite {
  display: block; margin-top: 16px; font-family: var(--f-mono);
  font-size: 12px; font-weight: 400; color: var(--ink-3); font-style: normal;
  letter-spacing: 0.08em; text-transform: uppercase;
}

/* —— INFO / E-E-A-T pages —— */
.fl-dna-a .info-hero {
  padding: 56px 0 32px;
  background: var(--bg-tint);
}
.fl-dna-a .info-hero h1 {
  font-size: 56px; line-height: 1; letter-spacing: -0.025em;
}
.fl-dna-a .info-body { max-width: 720px; }
.fl-dna-a .info-body h2 { font-size: 28px; margin-top: 48px; margin-bottom: 14px; }
.fl-dna-a .info-body h3 { font-size: 19px; margin-top: 24px; margin-bottom: 10px; }
.fl-dna-a .info-body p, .fl-dna-a .info-body li {
  font-size: 15px; line-height: 1.65; color: var(--ink-2); margin-bottom: 14px;
}

/* Contact form */
.fl-dna-a .contact-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px;
}
.fl-dna-a .contact-fields { display: flex; flex-direction: column; gap: 18px; }
.fl-dna-a .contact-fields label {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-3); display: block; margin-bottom: 6px;
}

/* —— UTILITY — cart full page, checkout, my-account, search, tracking —— */
.fl-dna-a .util-hero { padding: 56px 0 24px; }
.fl-dna-a .util-hero h1 { font-size: 40px; }

.fl-dna-a .cart-table { width: 100%; border-collapse: collapse; }
.fl-dna-a .cart-table th, .fl-dna-a .cart-table td {
  padding: 16px 12px; text-align: left; border-bottom: 1px solid var(--rule);
  font-size: 14px; vertical-align: top;
}
.fl-dna-a .cart-table th { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); }
.fl-dna-a .cart-table .cart-line-name { font-weight: 600; color: var(--ink); }
.fl-dna-a .cart-table .cart-line-var  { font-family: var(--f-mono); font-size: 12px; color: var(--ink-3); margin-top: 4px; }
.fl-dna-a .cart-line-var-dual {
  display: inline-grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  margin-top: 6px; gap: 0;
  border: 1px solid var(--rule-2); border-radius: 6px; overflow: hidden;
  font-family: var(--f-mono); font-size: 11px;
}
.fl-dna-a .cart-line-var-dual .vd-tank { padding: 4px 10px; }
.fl-dna-a .cart-line-var-dual .vd-a { background: var(--signal-bg); color: var(--signal-dk); }
.fl-dna-a .cart-line-var-dual .vd-b { background: var(--warm-bg); color: var(--warm-dk); }
.fl-dna-a .cart-line-var-dual .vd-slash { padding: 0 6px; color: var(--ink-3); }

.fl-dna-a .checkout-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 48px; }
.fl-dna-a .checkout-step {
  padding: 24px 28px; border: 1px solid var(--rule); border-radius: 16px; margin-bottom: 18px;
  background: var(--bg);
}
.fl-dna-a .checkout-step-head {
  display: flex; align-items: center; gap: 12px; margin-bottom: 18px;
}
.fl-dna-a .checkout-step-head .step-no {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--signal); color: var(--ink); font-family: var(--f-mono);
  font-size: 13px; font-weight: 700; display: grid; place-items: center;
}
.fl-dna-a .checkout-step-head h3 { font-size: 18px; }
.fl-dna-a .checkout-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.fl-dna-a .checkout-fields label { font-size: 11px; font-family: var(--f-mono); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); display: block; margin-bottom: 4px; }
.fl-dna-a .checkout-fields .full { grid-column: 1 / -1; }
.fl-dna-a .pay-tabs {
  display: inline-flex; gap: 8px; padding: 6px;
  border: 1px solid var(--rule-2); border-radius: 999px; background: var(--bg-tint);
}
.fl-dna-a .pay-tabs button {
  font-family: var(--f-mono); font-size: 12px; padding: 8px 14px; border-radius: 999px;
  color: var(--ink-2); display: inline-flex; gap: 8px; align-items: center;
}
.fl-dna-a .pay-tabs button.is-active { background: var(--ink); color: var(--bg); }
.fl-dna-a .pay-tabs button .card-brand {
  font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.1em; padding: 2px 4px;
  background: rgba(0,0,0,0.05); border-radius: 4px;
}

.fl-dna-a .checkout-summary {
  background: var(--bg-soft); border: 1px solid var(--rule); border-radius: 16px; padding: 28px;
  position: sticky; top: 96px; align-self: start;
}
.fl-dna-a .checkout-summary .sum-line { display: flex; justify-content: space-between; padding: 8px 0; font-size: 14px; }
.fl-dna-a .checkout-summary .sum-line.total { font-family: var(--f-display); font-size: 24px; color: var(--signal-dk); font-weight: 700; padding-top: 14px; border-top: 1px solid var(--rule); margin-top: 8px; }

.fl-dna-a .account-grid { display: grid; grid-template-columns: 240px 1fr; gap: 48px; }
.fl-dna-a .account-nav { display: flex; flex-direction: column; gap: 4px; position: sticky; top: 96px; align-self: start; }
.fl-dna-a .account-nav a {
  padding: 10px 14px; border-radius: 10px; font-size: 14px; font-weight: 500; color: var(--ink-2);
}
.fl-dna-a .account-nav a:hover { background: var(--bg-tint); color: var(--ink); }
.fl-dna-a .account-nav a.is-active { background: var(--signal-bg); color: var(--ink); }
.fl-dna-a .order-row {
  display: grid; grid-template-columns: 1fr auto auto auto; gap: 18px; align-items: center;
  padding: 18px 22px; border: 1px solid var(--rule); border-radius: 14px; margin-bottom: 12px;
  font-size: 14px;
}
.fl-dna-a .order-row .order-no { font-family: var(--f-mono); font-size: 12px; color: var(--ink-3); }
.fl-dna-a .order-row .order-status { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; padding: 4px 10px; border-radius: 999px; }
.fl-dna-a .order-row .order-status.shipped { background: var(--signal-bg); color: var(--signal-dk); }
.fl-dna-a .order-row .order-status.processing { background: var(--warm-bg); color: var(--warm-dk); }
.fl-dna-a .order-row .order-status.delivered { background: #dcf5ea; color: var(--good); }

/* Search modal */
.fl-dna-a .search-shell {
  max-width: 720px; margin: 56px auto; background: var(--bg);
  border: 1px solid var(--rule); border-radius: 24px; padding: 32px;
  box-shadow: var(--fl-sh-card-lg);
}
.fl-dna-a .search-input-row {
  display: flex; align-items: center; gap: 12px;
  border: 1.5px solid var(--rule-2); border-radius: 12px; padding: 14px 16px;
}
.fl-dna-a .search-input-row input {
  flex: 1; border: 0; background: transparent; outline: none;
  font-family: var(--f-body); font-size: 17px; color: var(--ink);
}
.fl-dna-a .search-results { margin-top: 28px; }
.fl-dna-a .search-group-head {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-3); margin: 18px 0 8px;
}
.fl-dna-a .search-result {
  display: grid; grid-template-columns: 40px 1fr auto; gap: 14px;
  padding: 12px; border-radius: 10px; align-items: center;
}
.fl-dna-a .search-result:hover { background: var(--bg-tint); }

/* Order tracking */
.fl-dna-a .track-shell {
  max-width: 560px; margin: 56px auto; padding: 40px;
  background: var(--bg); border: 1px solid var(--rule);
  border-radius: 24px; box-shadow: var(--fl-sh-card);
  text-align: center;
}
.fl-dna-a .track-shell .track-input {
  margin: 24px 0 14px;
}
.fl-dna-a .track-shell .track-helper { font-size: 13px; color: var(--ink-3); line-height: 1.5; }

/* ═══════════ 10. MOBILE RESPONSIVE (768 / 375) ═══════════ */

@media (max-width: 1023px) {
  .fl-dna-a .fla-header { gap: 16px; padding: 14px 20px; }
  .fl-dna-a .fla-nav { display: none; }
  .fl-dna-a .fla-actions .btn .search-kbd { display: none; }
  .fl-dna-a .fla-hamburger { display: inline-flex; }

  .fl-dna-a .home-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .fl-dna-a .home-hero h1 { font-size: 56px; }
  .fl-dna-a .home-hero-theatre { min-height: 360px; padding: 32px 20px; }

  .fl-dna-a .sku-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .fl-dna-a .col-grid { grid-template-columns: repeat(2, 1fr); }
  .fl-dna-a .reviews-grid { grid-template-columns: repeat(2, 1fr); }
  .fl-dna-a .blog-teaser-grid { grid-template-columns: 1fr 1fr; }
  .fl-dna-a .flavor-matrix  { grid-template-columns: repeat(3, 1fr); }
  .fl-dna-a .states-grid    { grid-template-columns: repeat(6, 1fr); }

  .fl-dna-a .trust-strip { grid-template-columns: repeat(2, 1fr); }
  .fl-dna-a .trust-strip > div:nth-child(2) { border-left: 1px solid var(--rule); }
  .fl-dna-a .trust-strip > div:nth-child(3) { border-left: 0; border-top: 1px solid var(--rule); }
  .fl-dna-a .trust-strip > div:nth-child(4) { border-top: 1px solid var(--rule); }

  .fl-dna-a .warehouse-block { grid-template-columns: 1fr 1fr; gap: 32px 0; padding: 32px; }
  .fl-dna-a .warehouse-block .wh-lead { grid-column: 1 / -1; padding-right: 0; padding-bottom: 24px; border-bottom: 1px solid var(--rule); margin-bottom: 24px; }
  .fl-dna-a .warehouse-block .wh-stat { padding: 0 20px; }
  .fl-dna-a .warehouse-block .wh-stat:nth-of-type(odd) { border-left: 0; padding-left: 0; }

  .fl-dna-a .authenticity { padding: 32px; }
  .fl-dna-a .authenticity-grid { grid-template-columns: 1fr; gap: 32px; }
  .fl-dna-a .authenticity h2 { font-size: 32px; }

  .fl-dna-a .pdp-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .fl-dna-a .pdp-info h1 { font-size: 40px; }
  .fl-dna-a .pdp-gallery { min-height: 360px; padding: 32px; }
  .fl-dna-a .story-block-grid { grid-template-columns: 1fr; gap: 32px; }
  .fl-dna-a .story-block { padding: 32px 24px; }

  .fl-dna-a .pillar-layout { grid-template-columns: 1fr; gap: 32px; }
  .fl-dna-a .pillar-toc { position: relative; top: auto; padding: 18px 20px; border: 1px solid var(--rule); border-radius: 12px; background: var(--bg-tint); }
  .fl-dna-a .pillar-toc ul { display: grid; grid-template-columns: repeat(2, 1fr); gap: 4px; }
  .fl-dna-a .pillar-body { max-width: none; }

  .fl-dna-a .contact-grid { grid-template-columns: 1fr; gap: 32px; }
  .fl-dna-a .checkout-grid { grid-template-columns: 1fr; gap: 32px; }
  .fl-dna-a .checkout-summary { position: static; }
  .fl-dna-a .account-grid { grid-template-columns: 1fr; gap: 24px; }
  .fl-dna-a .account-nav { position: static; flex-direction: row; flex-wrap: wrap; gap: 6px; }
  .fl-dna-a .account-nav a { padding: 8px 12px; }

  .fl-dna-a .fla-footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 32px 24px;
  }
  .fl-dna-a .fla-footer-grid .brand-block { grid-column: 1 / -1; }
  .fl-dna-a .fla-dispatch { grid-template-columns: 1fr; }
  .fl-dna-a .fla-dispatch > div + div { border-left: 0; border-top: 1px solid rgba(255,255,255,0.12); }
  .fl-dna-a .fla-legal .legal-tail { width: 100%; text-align: left; margin-left: 0; }
}

@media (max-width: 640px) {
  .fl-dna-a .container,
  .fl-dna-a .container-content,
  .fl-dna-a .container-read { padding: 0 20px; }

  .fl-dna-a .section { padding: 56px 0; }
  .fl-dna-a .section-lg { padding: 72px 0; }
  .fl-dna-a .section-sm { padding: 40px 0; }

  .fl-dna-a h1 { font-size: 44px; }
  .fl-dna-a h1.huge { font-size: 64px; }
  .fl-dna-a h2 { font-size: 28px; }
  .fl-dna-a .lede { font-size: 16px; }

  .fl-dna-a .home-hero { padding: 40px 0 56px; }
  .fl-dna-a .home-hero h1 { font-size: 42px; line-height: 1.02; }
  .fl-dna-a .home-hero .lede { font-size: 16px; }
  .fl-dna-a .home-hero-ctas .btn { flex: 1; }

  .fl-dna-a .sku-grid { grid-template-columns: 1fr; }
  .fl-dna-a .col-grid { grid-template-columns: 1fr; }
  .fl-dna-a .reviews-grid { grid-template-columns: 1fr; }
  .fl-dna-a .blog-teaser-grid { grid-template-columns: 1fr; }
  .fl-dna-a .flavor-matrix { grid-template-columns: repeat(2, 1fr); }
  .fl-dna-a .states-grid { grid-template-columns: repeat(4, 1fr); }

  .fl-dna-a .trust-strip { grid-template-columns: 1fr; }
  .fl-dna-a .trust-strip > div { border-left: 0; }
  .fl-dna-a .trust-strip > div + div { border-top: 1px solid var(--rule); }

  .fl-dna-a .warehouse-block { grid-template-columns: 1fr; padding: 24px; }
  .fl-dna-a .warehouse-block .wh-stat { padding: 18px 0; border-left: 0; border-top: 1px solid var(--rule); }
  .fl-dna-a .warehouse-block .wh-stat:first-of-type { border-top: 0; }

  .fl-dna-a .authenticity { padding: 24px; border-radius: 16px; }
  .fl-dna-a .authenticity h2 { font-size: 26px; }
  .fl-dna-a .authenticity .auth-stamp { position: relative; top: auto; right: auto; margin-bottom: 14px; }

  .fl-dna-a .pdp-info h1 { font-size: 32px; }
  .fl-dna-a .var-grid { grid-template-columns: 1fr 1fr; }
  .fl-dna-a .var-grid.dense { grid-template-columns: 1fr 1fr; }
  .fl-dna-a .var-dual-grid { grid-template-columns: 1fr; }
  .fl-dna-a .pdp-cta-row { flex-direction: column; }
  .fl-dna-a .pdp-cta-row .btn { width: 100%; }
  .fl-dna-a .qty-stepper { align-self: flex-start; }
  .fl-dna-a .story-block { padding: 24px 20px; }
  .fl-dna-a .dual-tank-vis .dtv-name { font-size: 19px; }
  .fl-dna-a .dual-tank-vis .dtv-side { padding: 18px 14px; }
  .fl-dna-a .pdp-trust-mini { grid-template-columns: 1fr; }

  .fl-dna-a .col-hero h1 { font-size: 36px; }
  .fl-dna-a .pillar-hero h1 { font-size: 40px; }
  .fl-dna-a .info-hero h1 { font-size: 36px; }

  .fl-dna-a .ed-tabs { overflow-x: auto; flex-wrap: nowrap; }
  .fl-dna-a .ed-tabs button { white-space: nowrap; }

  .fl-dna-a .price-table th, .fl-dna-a .price-table td { padding: 12px 8px; font-size: 13px; }
  .fl-dna-a .price-table td.price-cell { font-size: 18px; }

  .fl-dna-a .cart-table thead { display: none; }
  .fl-dna-a .cart-table, .fl-dna-a .cart-table tbody,
  .fl-dna-a .cart-table tr, .fl-dna-a .cart-table td { display: block; width: 100%; }
  .fl-dna-a .cart-table tr {
    border: 1px solid var(--rule); border-radius: 14px; padding: 18px; margin-bottom: 14px;
  }
  .fl-dna-a .cart-table td { border-bottom: 0; padding: 4px 0; }

  .fl-dna-a .fla-footer-grid { grid-template-columns: 1fr; }
  .fl-dna-a .fla-footer { padding: 40px 20px 24px; }
  .fl-dna-a .fla-announce { padding: 9px 20px; gap: 12px; }
  .fl-dna-a .fla-announce .ann-dots { display: none; }
}

/* Hide mobile drawer on desktop */
@media (min-width: 1024px) {
  .fl-dna-a .fla-mobile-dialog { display: none; }
}

/* Tablet refinement */
@media (min-width: 768px) and (max-width: 1023px) {
  .fl-dna-a .fla-footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr; gap: 24px; }
  .fl-dna-a .fla-footer-grid .brand-block { grid-column: 1 / 3; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .fl-dna-a *,
  .fl-dna-a *::before,
  .fl-dna-a *::after {
    animation-duration: 0s !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0s !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   11. LEGACY .fl-pdp-* / .fl-article restyle to DNA-A
   The pdp.njk layout uses Alpine pdpAdd + WC variations and renders
   these legacy class names. Restyle them under .fl-dna-a so existing
   production code keeps working with the new visual language.
   ═══════════════════════════════════════════════════════════════ */

.fl-dna-a .fl-article {
  max-width: 1280px; margin: 0 auto; padding: 0 28px;
}
.fl-dna-a .fl-pdp { padding: 32px 0 80px; }

/* PDP hero — 2-col image left + buy widgets right */
.fl-dna-a .fl-pdp-hero {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px;
  margin-bottom: 64px;
  padding: 0;
}
.fl-dna-a .fl-pdp-hero-media {
  background: linear-gradient(180deg, var(--signal-bg) 0 60%, var(--bg-soft) 60% 100%);
  border-radius: 24px; padding: 32px;
  border: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: center;
  min-height: 520px;
}
.fl-dna-a .fl-pdp-hero-media img {
  max-width: 100%; height: auto; mix-blend-mode: multiply;
}
.fl-dna-a .fl-pdp-hero-body { display: flex; flex-direction: column; gap: 22px; padding-top: 8px; }
.fl-dna-a .fl-pdp-title {
  font-family: var(--f-display); font-size: 52px; font-weight: 700;
  line-height: 1; letter-spacing: -0.025em; color: var(--ink);
  font-variation-settings: "wdth" 100, "opsz" 48;
  margin: 0;
}
.fl-dna-a .fl-pdp-pricerow {
  display: inline-flex; align-items: baseline; gap: 14px;
  background: var(--bg-soft); border: 1px solid var(--rule);
  border-radius: 16px; padding: 14px 20px;
  font-family: var(--f-body);
}
.fl-dna-a .fl-pdp-price {
  font-family: var(--f-display); font-size: 40px; font-weight: 700;
  color: var(--signal-dk); letter-spacing: -0.025em;
}
.fl-dna-a .fl-pdp-price-was {
  font-family: var(--f-mono); font-size: 14px; color: var(--ink-3); text-decoration: line-through;
}
.fl-dna-a .fl-pdp-stock {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; padding: 4px 9px;
  border-radius: 999px;
}
.fl-dna-a .fl-pdp-stock--instock { background: var(--signal-bg); color: var(--signal-dk); border: 1px solid var(--signal-dk); }
.fl-dna-a .fl-pdp-stock--outofstock { background: var(--warm-bg); color: var(--warm-dk); border: 1px solid var(--warm-dk); }
.fl-dna-a .fl-pdp-short {
  font-size: 15px; line-height: 1.55; color: var(--ink-2); max-width: 480px;
}
.fl-dna-a .fl-pdp-short p { margin-bottom: 10px; }
.fl-dna-a .fl-pdp-short strong { color: var(--ink); font-weight: 600; }

/* Picker */
.fl-dna-a .fl-pdp-picker {
  background: var(--bg); border: 1px solid var(--rule);
  border-radius: 16px; padding: 22px 22px 20px;
}
.fl-dna-a .fl-pdp-picker-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 16px; gap: 12px; flex-wrap: wrap;
}
.fl-dna-a .fl-pdp-picker-h {
  font-family: var(--f-display); font-size: 19px; font-weight: 700;
  letter-spacing: -0.015em; color: var(--ink); margin: 0;
}
.fl-dna-a .fl-pdp-picker-h-count {
  font-family: var(--f-mono); font-size: 12px; font-weight: 500;
  color: var(--signal-dk); margin-left: 4px;
}
.fl-dna-a .fl-pdp-picker-meta {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-3);
}
.fl-dna-a .fl-pdp-picker-group { margin-bottom: 16px; }
.fl-dna-a .fl-pdp-picker-group:not(:has(.fl-pdp-flavor-chip)) { display: none; }
.fl-dna-a .fl-pdp-picker-group-h {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink-3); margin-bottom: 8px;
}
.fl-dna-a .fl-pdp-picker-group-h--oos { color: var(--warm-dk); }
.fl-dna-a .fl-pdp-flavor-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
  margin: 0; padding: 0;
}

/* Flavor chip — adapted from .chip */
.fl-dna-a .fl-pdp-flavor-chip {
  display: flex; flex-direction: column; align-items: flex-start; gap: 2px;
  font-family: var(--f-body); font-size: 13px; font-weight: 500;
  padding: 10px 14px;
  border: 1.5px solid var(--rule-2);
  background: var(--bg); color: var(--ink);
  border-radius: 10px;
  cursor: pointer;
  transition: all 120ms ease;
  text-align: left; min-height: 56px;
}
.fl-dna-a .fl-pdp-flavor-chip:hover { border-color: var(--signal-dk); transform: translateY(-1px); box-shadow: var(--fl-sh-micro); }
.fl-dna-a .fl-pdp-flavor-chip.is-selected,
.fl-dna-a .fl-pdp-flavor-chip[aria-checked="true"] {
  border: 2px solid var(--signal-dk); padding: 9px 13px;
  background: var(--signal-bg); color: var(--ink); font-weight: 600;
  box-shadow: 0 4px 0 0 var(--signal-dk);
}
.fl-dna-a .fl-pdp-flavor-chip.is-oos {
  opacity: 0.45; cursor: not-allowed; text-decoration: line-through;
  border-style: dashed; background: var(--bg-tint);
}
.fl-dna-a .fl-pdp-flavor-chip-name { font-size: 13px; line-height: 1.2; }
.fl-dna-a .fl-pdp-flavor-chip-stock {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.06em;
  color: var(--signal-dk); opacity: 0.7;
}
.fl-dna-a .fl-pdp-flavor-chip.is-oos .fl-pdp-flavor-chip-stock { color: var(--warm-dk); opacity: 0.7; }
.fl-dna-a .fl-pdp-flavor-chip:focus-visible { outline: 2px solid var(--signal-dk); outline-offset: 2px; }

.fl-dna-a .fl-pdp-picker-oos { margin-top: 8px; padding-top: 12px; border-top: 1px dashed var(--rule-2); }
.fl-dna-a .fl-pdp-picker-oos-toggle {
  font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.06em;
  color: var(--ink-3); padding: 8px 0;
  text-transform: uppercase;
}
.fl-dna-a .fl-pdp-picker-oos-toggle:hover { color: var(--ink); }

/* Buy row */
.fl-dna-a .fl-pdp-buy-row {
  display: flex; gap: 12px; margin-top: 18px;
}
.fl-dna-a .fl-pdp-qty {
  display: inline-flex; align-items: center;
  border: 1.5px solid var(--rule-2); border-radius: 999px; overflow: hidden;
}
.fl-dna-a .fl-pdp-qty-btn {
  width: 44px; height: 50px; background: var(--bg-tint); color: var(--ink);
  font-family: var(--f-mono); font-size: 18px; border: 0;
}
.fl-dna-a .fl-pdp-qty-btn:hover { background: var(--signal-bg); }
.fl-dna-a .fl-pdp-qty-input {
  width: 52px; height: 50px; text-align: center;
  font-family: var(--f-mono); font-size: 15px; font-variant-numeric: tabular-nums;
  border: 0; background: transparent; color: var(--ink); outline: none;
}
.fl-dna-a .fl-pdp-add {
  flex: 1; min-height: 50px; padding: 0 22px;
  background: var(--signal); border: 1.5px solid var(--signal); color: var(--ink);
  font-family: var(--f-body); font-size: 15px; font-weight: 700;
  border-radius: 999px;
  cursor: pointer;
  transition: transform 140ms ease, box-shadow 140ms ease, background 140ms ease;
}
.fl-dna-a .fl-pdp-add:hover:not(:disabled) {
  background: var(--signal-dk); border-color: var(--signal-dk); color: #fff;
  box-shadow: var(--fl-sh-tiffany); transform: translateY(-1px);
}
.fl-dna-a .fl-pdp-add:disabled { opacity: 0.5; cursor: not-allowed; }

.fl-dna-a .fl-pdp-buy-err {
  font-family: var(--f-mono); font-size: 12px; color: var(--warm-dk);
  padding: 8px 12px; background: var(--warm-bg); border-radius: 8px;
  border: 1px solid #ffd5c5; margin-top: 12px;
}
.fl-dna-a .fl-pdp-flavors-foot {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--ink-3); margin-top: 14px;
}

/* Imported body section */
.fl-dna-a .fl-pdp-body {
  max-width: 1120px; margin: 0 auto; padding: 48px 0;
}
.fl-dna-a .fl-pdp-body h2 {
  font-size: 32px; margin-top: 48px; margin-bottom: 16px;
  letter-spacing: -0.02em;
}
.fl-dna-a .fl-pdp-body h3 { font-size: 22px; margin-top: 28px; margin-bottom: 12px; }
.fl-dna-a .fl-pdp-body p, .fl-dna-a .fl-pdp-body li {
  font-size: 15.5px; line-height: 1.65; color: var(--ink-2); margin-bottom: 14px;
}
.fl-dna-a .fl-pdp-body ul, .fl-dna-a .fl-pdp-body ol {
  margin-bottom: 18px; padding-left: 0;
}
.fl-dna-a .fl-pdp-body ul li { padding-left: 26px; position: relative; }
.fl-dna-a .fl-pdp-body ul li::before {
  content: ""; position: absolute; left: 0; top: 12px;
  width: 14px; height: 1.5px; background: var(--signal-dk);
}
.fl-dna-a .fl-pdp-body table {
  width: 100%; border-collapse: collapse; margin: 18px 0;
  font-family: var(--f-mono); font-size: 13px;
}
.fl-dna-a .fl-pdp-body table th, .fl-dna-a .fl-pdp-body table td {
  padding: 10px 12px; border-bottom: 1px solid var(--rule); text-align: left;
}
.fl-dna-a .fl-pdp-body table th {
  background: var(--bg-soft); font-weight: 600; color: var(--ink-3);
  letter-spacing: 0.04em; text-transform: uppercase; font-size: 11px;
}
.fl-dna-a .fl-pdp-body img { border-radius: 12px; }
.fl-dna-a .fl-pdp-body strong { color: var(--ink); font-weight: 600; }
.fl-dna-a .fl-pdp-body a { color: var(--signal-dk); text-decoration: underline; text-underline-offset: 3px; }

.fl-dna-a .fl-pdp-related {
  max-width: 1280px; margin: 64px auto 0; padding: 40px 28px;
  background: var(--bg-soft); border: 1px solid var(--rule);
  border-radius: 24px;
}
.fl-dna-a .fl-pdp-related h2 { font-size: 22px; margin-bottom: 18px; }
.fl-dna-a .fl-link-strip {
  display: flex; flex-wrap: wrap; gap: 10px;
  list-style: none; padding: 0; margin: 0;
}
.fl-dna-a .fl-link-strip li a {
  font-family: var(--f-body); font-size: 13px; font-weight: 500;
  padding: 8px 14px; border: 1px solid var(--rule-2);
  background: var(--bg); color: var(--ink);
  border-radius: 999px; transition: all 120ms ease;
}
.fl-dna-a .fl-link-strip li a:hover {
  border-color: var(--signal-dk); background: var(--signal-bg); color: var(--ink);
}

/* PDP responsive */
@media (max-width: 1023px) {
  .fl-dna-a .fl-pdp-hero { grid-template-columns: 1fr; gap: 40px; }
  .fl-dna-a .fl-pdp-title { font-size: 40px; }
  .fl-dna-a .fl-pdp-hero-media { min-height: 360px; padding: 28px; }
}
@media (max-width: 640px) {
  .fl-dna-a .fl-pdp-title { font-size: 32px; }
  .fl-dna-a .fl-pdp-price { font-size: 32px; }
  .fl-dna-a .fl-pdp-flavor-grid { grid-template-columns: 1fr 1fr; }
  .fl-dna-a .fl-pdp-buy-row { flex-direction: column; }
  .fl-dna-a .fl-pdp-qty { align-self: flex-start; }
  .fl-dna-a .fl-pdp-add { width: 100%; }
  .fl-dna-a .fl-pdp-hero-media { min-height: 280px; padding: 20px; }
  .fl-dna-a .fl-pdp-body h2 { font-size: 26px; }
}

/* ═══════════════════════════════════════════════════════════════
   12. LEGACY .fl-article restyle (used by /about/, /faqs/, /shipping-policy/
   and other info / policy pages — wraps imported body in raw[slug]).
   ═══════════════════════════════════════════════════════════════ */
.fl-dna-a .fl-article {
  font-family: var(--f-body);
  font-size: 15.5px; line-height: 1.65;
  color: var(--ink);
}
.fl-dna-a .fl-article h1 {
  font-size: 52px; line-height: 1; letter-spacing: -0.025em;
  margin: 40px 0 18px;
}
.fl-dna-a .fl-article h2 {
  font-size: 32px; margin: 48px 0 14px; letter-spacing: -0.02em;
}
.fl-dna-a .fl-article h3 { font-size: 22px; margin: 28px 0 10px; }
.fl-dna-a .fl-article h4 { font-size: 18px; margin: 22px 0 8px; }
.fl-dna-a .fl-article p, .fl-dna-a .fl-article li {
  font-size: 15.5px; line-height: 1.65; color: var(--ink-2); margin-bottom: 14px;
}
.fl-dna-a .fl-article a { color: var(--signal-dk); text-decoration: underline; text-underline-offset: 3px; }
.fl-dna-a .fl-article a:hover { color: var(--ink); }
.fl-dna-a .fl-article strong { color: var(--ink); font-weight: 600; }
.fl-dna-a .fl-article ul, .fl-dna-a .fl-article ol { padding-left: 0; margin-bottom: 18px; }
.fl-dna-a .fl-article ul li { padding-left: 26px; position: relative; }
.fl-dna-a .fl-article ul li::before {
  content: ""; position: absolute; left: 0; top: 12px;
  width: 14px; height: 1.5px; background: var(--signal-dk);
}
.fl-dna-a .fl-article ol { counter-reset: ol; padding-left: 0; }
.fl-dna-a .fl-article ol li { padding-left: 36px; position: relative; counter-increment: ol; }
.fl-dna-a .fl-article ol li::before {
  content: counter(ol, decimal-leading-zero) ".";
  position: absolute; left: 0; top: 0;
  font-family: var(--f-mono); font-size: 13px; color: var(--signal-dk); font-weight: 600;
}
.fl-dna-a .fl-article table {
  width: 100%; border-collapse: collapse; margin: 18px 0;
  font-family: var(--f-mono); font-size: 13px;
}
.fl-dna-a .fl-article th, .fl-dna-a .fl-article td {
  padding: 10px 12px; border-bottom: 1px solid var(--rule); text-align: left;
}
.fl-dna-a .fl-article th {
  background: var(--bg-soft); font-weight: 600; color: var(--ink-3);
  letter-spacing: 0.04em; text-transform: uppercase; font-size: 11px;
}
.fl-dna-a .fl-article blockquote {
  border-left: 4px solid var(--signal); padding: 8px 24px; margin: 24px 0;
  background: var(--signal-bg); border-radius: 0 12px 12px 0;
  font-style: normal; color: var(--ink);
}
.fl-dna-a .fl-article img { border-radius: 12px; max-width: 100%; margin: 18px 0; }
.fl-dna-a .fl-article details {
  border-bottom: 1px solid var(--rule); padding: 0;
}
.fl-dna-a .fl-article details summary {
  cursor: pointer; padding: 18px 0; font-family: var(--f-display);
  font-size: 17px; font-weight: 600; color: var(--ink);
  list-style: none;
}
.fl-dna-a .fl-article details summary::-webkit-details-marker { display: none; }
.fl-dna-a .fl-article details[open] { padding-bottom: 14px; }
.fl-dna-a .fl-article details summary::after {
  content: "+"; float: right; font-family: var(--f-mono); font-size: 18px;
  color: var(--signal-dk); transition: transform 200ms ease;
}
.fl-dna-a .fl-article details[open] summary::after { content: "−"; }

/* DNA-A PDP add-on sections (TLDR, spec, story, FAQ, authenticity-mini) — class scoped */
.fl-dna-a .pdp-section {
  max-width: 1120px; margin: 0 auto; padding: 32px 28px;
}
.fl-dna-a .pdp-section h2 { font-size: 32px; margin-bottom: 18px; letter-spacing: -0.02em; }
.fl-dna-a .pdp-section.bordered {
  border-top: 1px solid var(--rule);
}
.fl-dna-a .pdp-spec-card {
  background: var(--bg-soft); border: 1px solid var(--rule);
  border-radius: 16px; padding: 32px;
}
.fl-dna-a .pdp-spec-card table { width: 100%; }

/* ═══════════════════════════════════════════════════════════════
   13. LEGACY CHECKOUT / MY-ACCOUNT / UTILITY restyle to DNA-A
   Existing utility pages use .fl-checkout-*, .fl-btn-*, .fl-pdp-bcr,
   .fl-stamp, .fl-cart-* classes. Restyle them under .fl-dna-a so
   the checkout 禁区 markup stays untouched but renders Direction A.
   ═══════════════════════════════════════════════════════════════ */

/* Breadcrumb (legacy) */
.fl-dna-a .fl-pdp-bcr {
  padding: 16px 0; max-width: 1280px; margin: 0 auto;
}
.fl-dna-a .fl-pdp-bcr-inner {
  padding: 0 28px;
  display: flex; align-items: center; gap: 10px;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--ink-3);
}
.fl-dna-a .fl-pdp-bcr a { color: var(--ink-3); }
.fl-dna-a .fl-pdp-bcr .sep { color: var(--rule-2); }
.fl-dna-a .fl-pdp-bcr .current { color: var(--ink); }

/* Buttons (legacy) */
.fl-dna-a .fl-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--f-body); font-size: 14px; font-weight: 600;
  letter-spacing: -0.005em;
  padding: 13px 22px;
  border: 1.5px solid var(--ink);
  background: var(--ink); color: #fff;
  cursor: pointer; border-radius: 999px;
  text-decoration: none;
  min-height: 46px;
  transition: transform 140ms ease, box-shadow 140ms ease, background 140ms ease;
}
.fl-dna-a .fl-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 20px -8px rgba(10,32,36,0.35); }
.fl-dna-a .fl-btn-accent,
.fl-dna-a .fl-btn-red {
  background: var(--signal); border-color: var(--signal); color: var(--ink); font-weight: 700;
}
.fl-dna-a .fl-btn-accent:hover,
.fl-dna-a .fl-btn-red:hover { background: var(--signal-dk); border-color: var(--signal-dk); color: #fff; box-shadow: var(--fl-sh-tiffany); }
.fl-dna-a .fl-btn-ghost { background: transparent; color: var(--ink); border-color: var(--rule-2); }
.fl-dna-a .fl-btn-ghost:hover { background: var(--bg-soft); border-color: var(--ink); }
.fl-dna-a .fl-btn-full { width: 100%; }
.fl-dna-a .fl-btn-between { justify-content: space-between; }

/* Cart page (legacy) */
.fl-dna-a .fl-cartpage-shell,
.fl-dna-a .fl-checkout-shell {
  max-width: 1280px; margin: 0 auto; padding: 32px 28px 80px;
}
.fl-dna-a .fl-cartpage-promo {
  margin-bottom: 24px;
}
.fl-dna-a .fl-checkout-title {
  margin: 24px 0;
}
.fl-dna-a .fl-checkout-title-inner h1 {
  font-family: var(--f-display); font-size: 56px; font-weight: 700;
  letter-spacing: -0.025em; line-height: 1; color: var(--ink); margin: 14px 0 0;
}
.fl-dna-a .fl-pdp-stamps {
  display: inline-flex; gap: 10px; flex-wrap: wrap;
}
.fl-dna-a .fl-stamp {
  font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--signal-dk);
  padding: 5px 10px 4px;
  border: 1.5px dashed var(--signal-dk);
  border-radius: 999px;
}
.fl-dna-a .fl-stamp-y {
  color: var(--warm-dk); border-color: var(--warm-dk);
}
.fl-dna-a .fl-checkout-progress {
  margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--rule);
}
.fl-dna-a .fl-checkout-progress-inner {
  display: flex; gap: 10px; flex-wrap: wrap;
}
.fl-dna-a .fl-checkout-step {
  padding: 8px 14px; border-radius: 999px;
  background: var(--bg-tint); border: 1px solid var(--rule-2);
  font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-3);
}
.fl-dna-a .fl-checkout-step.is-active {
  background: var(--ink); color: var(--bg); border-color: var(--ink);
}
.fl-dna-a .fl-checkout-body {
  display: grid; grid-template-columns: 1.5fr 1fr; gap: 40px;
  margin-top: 24px;
}
.fl-dna-a .fl-checkout-block {
  background: var(--bg); border: 1px solid var(--rule); border-radius: 16px;
  overflow: hidden; margin-bottom: 18px;
}
.fl-dna-a .fl-checkout-block-head {
  padding: 18px 24px; border-bottom: 1px solid var(--rule);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-2);
}
.fl-dna-a .fl-checkout-block-head .yellow,
.fl-dna-a .fl-checkout-title .yellow { color: var(--signal-dk); }
.fl-dna-a .fl-cart-line {
  display: grid; grid-template-columns: 80px 1fr auto auto; gap: 18px;
  padding: 20px 24px; border-bottom: 1px solid var(--rule); align-items: flex-start;
}
.fl-dna-a .fl-cart-swatch {
  width: 80px; height: 80px; border-radius: 12px;
  border: 1px solid var(--rule); background: var(--bg-tint);
}
.fl-dna-a .fl-cart-line-name {
  font-size: 15px; font-weight: 600; color: var(--ink); line-height: 1.3;
}
.fl-dna-a .fl-cart-line-flavor {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--ink-3); margin-top: 4px; text-transform: uppercase;
}
.fl-dna-a .fl-cart-line-qty {
  display: inline-flex; align-items: center; gap: 8px;
  border: 1.5px solid var(--rule-2); border-radius: 999px; overflow: hidden;
}
.fl-dna-a .fl-cart-line-qty button {
  width: 32px; height: 36px; background: var(--bg-tint); color: var(--ink);
  font-family: var(--f-mono); font-size: 16px;
}
.fl-dna-a .fl-cart-line-qty .val {
  min-width: 28px; text-align: center; font-family: var(--f-mono);
  font-size: 14px; font-variant-numeric: tabular-nums;
}
.fl-dna-a .fl-cart-line-total {
  font-family: var(--f-mono); font-size: 15px; font-weight: 600;
  color: var(--ink); white-space: nowrap;
}
.fl-dna-a .fl-checkout-summary {
  position: sticky; top: 96px; align-self: start;
}
.fl-dna-a .fl-checkout-summary-card {
  background: var(--bg-soft); border: 1px solid var(--rule); border-radius: 16px;
  overflow: hidden;
}
.fl-dna-a .fl-checkout-summary-row {
  display: flex; justify-content: space-between; padding: 8px 0;
}
.fl-dna-a .fl-checkout-summary-row .fl-label,
.fl-dna-a .fl-checkout-label {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink-3);
}
.fl-dna-a .fl-checkout-summary-row .mono {
  font-family: var(--f-mono); font-size: 14px; color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.fl-dna-a .fl-checkout-trust {
  background: var(--signal-bg); border: 1px solid var(--rule-2); border-radius: 12px;
  padding: 18px 20px; margin-top: 18px;
}
.fl-dna-a .fl-cart-points,
.fl-dna-a .fl-cart-earn-line,
.fl-dna-a .fl-cart-points-cta {
  padding: 12px 14px; background: var(--signal-bg); border: 1px solid var(--rule-2);
  border-radius: 10px; margin-top: 12px;
  font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em;
  color: var(--ink-2); line-height: 1.5;
}
.fl-dna-a .fl-cart-points-head {
  display: flex; justify-content: space-between; margin-bottom: 8px;
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--signal-dk);
}
.fl-dna-a .fl-cart-points-toggle {
  display: flex; gap: 10px; align-items: center; cursor: pointer;
}
.fl-dna-a .fl-cart-earn-line strong { color: var(--signal-dk); font-weight: 700; }

/* Checkout form labels + inputs */
.fl-dna-a .fl-checkout-block input[type="text"],
.fl-dna-a .fl-checkout-block input[type="email"],
.fl-dna-a .fl-checkout-block input[type="tel"],
.fl-dna-a .fl-checkout-block input[type="number"],
.fl-dna-a .fl-checkout-block input[type="password"],
.fl-dna-a .fl-checkout-block select,
.fl-dna-a .fl-checkout-block textarea {
  width: 100%; padding: 12px 14px;
  border: 1.5px solid var(--rule-2); border-radius: 10px;
  background: var(--bg); font-family: var(--f-body); font-size: 14px;
  color: var(--ink); outline: none;
  transition: border-color 120ms ease;
}
.fl-dna-a .fl-checkout-block input:focus,
.fl-dna-a .fl-checkout-block select:focus,
.fl-dna-a .fl-checkout-block textarea:focus {
  border-color: var(--signal-dk);
  box-shadow: 0 0 0 3px var(--signal-bg);
}

/* my-account (legacy) */
.fl-dna-a .fl-account-shell { max-width: 1280px; margin: 0 auto; padding: 32px 28px 80px; }
.fl-dna-a .fl-account-grid { display: grid; grid-template-columns: 260px 1fr; gap: 48px; align-items: start; }
.fl-dna-a .fl-account-nav {
  position: sticky; top: 96px; align-self: start;
  display: flex; flex-direction: column; gap: 4px;
}
.fl-dna-a .fl-account-nav a {
  padding: 10px 14px; border-radius: 10px; font-size: 14px; font-weight: 500;
  color: var(--ink-2); text-decoration: none;
}
.fl-dna-a .fl-account-nav a:hover { background: var(--bg-tint); color: var(--ink); }
.fl-dna-a .fl-account-nav a.is-active { background: var(--signal-bg); color: var(--ink); }
.fl-dna-a .fl-account-card {
  background: var(--bg); border: 1px solid var(--rule); border-radius: 16px; padding: 24px;
  margin-bottom: 18px;
}
.fl-dna-a .fl-account-card h2,
.fl-dna-a .fl-account-card h3 {
  font-family: var(--f-display); letter-spacing: -0.02em; margin-bottom: 14px;
}
.fl-dna-a .fl-account-card h2 { font-size: 28px; }
.fl-dna-a .fl-account-card h3 { font-size: 19px; }
.fl-dna-a .fl-account-empty {
  text-align: center; padding: 60px 32px;
}

/* Responsive */
@media (max-width: 1023px) {
  .fl-dna-a .fl-checkout-body { grid-template-columns: 1fr; }
  .fl-dna-a .fl-checkout-summary { position: static; }
  .fl-dna-a .fl-account-grid { grid-template-columns: 1fr; }
  .fl-dna-a .fl-account-nav { position: static; flex-direction: row; flex-wrap: wrap; }
  .fl-dna-a .fl-cart-line { grid-template-columns: 60px 1fr; gap: 12px; }
  .fl-dna-a .fl-cart-swatch { width: 60px; height: 60px; }
  .fl-dna-a .fl-cart-line-qty,
  .fl-dna-a .fl-cart-line-total { grid-column: 2; }
}
@media (max-width: 640px) {
  .fl-dna-a .fl-checkout-title-inner h1 { font-size: 36px; }
  .fl-dna-a .fl-checkout-progress-inner { overflow-x: auto; flex-wrap: nowrap; }
  .fl-dna-a .fl-checkout-step { white-space: nowrap; }
}

/* ═══════════════════════════════════════════════════════════════
   14. Product card image rendering — real WC product images
   Replaces the CSS-only .device-fig silhouettes on home + cross-sell
   + collection-device-anchor cards. Pulls /img/products/<slug>.webp
   from wcProducts.mainImage.
   ═══════════════════════════════════════════════════════════════ */
.fl-dna-a .product-card .pc-art {
  align-items: center;
  min-height: 280px;
}
.fl-dna-a .product-card .pc-art .pc-img {
  max-width: 70%;
  max-height: 240px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 12px 28px rgba(10, 32, 36, 0.18));
  transition: transform 240ms ease;
}
.fl-dna-a .product-card:hover .pc-art .pc-img { transform: translateY(-4px) scale(1.02); }

/* PDP hero — align image to top, sticky on desktop so it follows long flavor lists */
.fl-dna-a .fl-pdp-hero { align-items: start; }
.fl-dna-a .fl-pdp-hero-media {
  align-self: start;
  position: sticky;
  top: 100px;
  max-height: calc(100vh - 120px);
}
.fl-dna-a .fl-pdp-hero-media img {
  max-width: 100%;
  max-height: 480px;
  width: auto;
  height: auto;
  object-fit: contain;
  margin: 0 auto;
}
@media (max-width: 1023px) {
  .fl-dna-a .fl-pdp-hero-media {
    position: static;
    top: auto;
    max-height: none;
  }
}

