/* native page rewrites — shop-cat (CollectionB) / brand hub / best+blog (PillarB shell). From wf_a4599da4. */


/* ===== shop-cat.njk ===== */
/* ─── shop-cat (CollectionB flavor-browse hub) — scoped .shopcat-* ─── */
.shopcat-hero .shopcat-sub {
  font-size: 18px; line-height: 1.6; font-weight: 500;
  color: var(--fl-ink); max-width: 680px; margin: 22px 0 0;
}

/* browse-by-family chip strip */
.shopcat-browse { padding: 4px 0 8px; }
.shopcat-browse-label {
  font-size: 11px; font-weight: 700; letter-spacing: 0.16em;
  color: var(--fl-ink2); margin: 0 0 14px;
}
.shopcat-chips { display: flex; flex-wrap: wrap; gap: 10px; }
.shopcat-chips .fl-chip { text-decoration: none; }
/* family tints not covered by base .fl-chip[data-fam] rules */
.fl-chip[data-fam="tobacco"]  { background: var(--fl-fam-dessert, #f5e2d0); }
.fl-chip[data-fam="beverage"] { background: var(--fl-fam-citrus,  #fff4c0); }
.fl-chip[data-fam="mixed"]    { background: var(--fl-fam-cosmos,  #ddd0ff); }

/* product grid — color-block cards tinted by family */
.shopcat-grid-sec { padding-top: 8px; }
.shopcat-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 24px; margin-top: 18px;
}
.shopcat-card {
  display: flex; flex-direction: column; padding: 0;
  text-decoration: none; color: inherit; overflow: hidden;
}
.shopcat-card[data-fam="berry"]    { background: var(--fl-fam-berry,    #f5e9ff); }
.shopcat-card[data-fam="fruit"]    { background: var(--fl-fam-fruit,    #ffe4dc); }
.shopcat-card[data-fam="tropical"] { background: var(--fl-fam-tropical, #fff0c8); }
.shopcat-card[data-fam="mint"]     { background: var(--fl-fam-mint,     #d9f4ec); }
.shopcat-card[data-fam="citrus"]   { background: var(--fl-fam-citrus,   #fff4c0); }
.shopcat-card[data-fam="candy"]    { background: var(--fl-fam-candy,    #ffd9e8); }
.shopcat-card[data-fam="lemonade"] { background: var(--fl-fam-lemonade, #fff7a8); }
.shopcat-card[data-fam="dessert"]  { background: var(--fl-fam-dessert,  #f5e2d0); }
.shopcat-card[data-fam="tart"]     { background: var(--fl-fam-tart,     #e0f5b8); }
.shopcat-card[data-fam="tobacco"]  { background: var(--fl-fam-dessert,  #f5e2d0); }
.shopcat-card[data-fam="beverage"] { background: var(--fl-fam-citrus,   #fff4c0); }
.shopcat-card[data-fam="mixed"]    { background: var(--fl-fam-cosmos,   #ddd0ff); }
.shopcat-card-img {
  aspect-ratio: 1/1; background: #fff;
  border-bottom: 2px solid var(--fl-ink);
  display: flex; align-items: center; justify-content: center;
}
.shopcat-card-img img { width: 100%; height: 100%; object-fit: contain; padding: 12px; }
.shopcat-card-body {
  padding: 16px 18px; display: flex; flex-direction: column;
  gap: 10px; flex: 1;
}
.shopcat-card-name {
  font-size: 20px; line-height: 1.0; letter-spacing: -0.01em;
  flex: 1;
}
.shopcat-card-foot {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-top: 8px; padding-top: 12px; border-top: 2px solid var(--fl-ink);
}
.shopcat-card-price { display: flex; align-items: baseline; gap: 8px; }
.shopcat-card-price .fl-display { font-size: 20px; color: var(--fl-purple); }
.shopcat-card-vars { font-size: 11px; font-weight: 700; letter-spacing: 0.06em; color: var(--fl-ink2); }
.shopcat-card-go { font-size: 22px; font-weight: 900; line-height: 1; }

/* empty / restocking state */
.shopcat-empty {
  padding: 28px 30px; display: flex; flex-direction: column;
  align-items: flex-start; gap: 16px; background: var(--fl-cream2);
}
.shopcat-empty p { font-size: 16px; line-height: 1.6; color: var(--fl-ink); margin: 0; max-width: 560px; }

/* editorial + faq columns */
.shopcat-editorial-wrap { max-width: 820px; }
.shopcat-editorial { padding-top: 8px; }
.shopcat-faq { padding-top: 8px; }
.shopcat-faq .gd-keep-h2 { margin-top: 10px; }
.shopcat-faq-list { display: flex; flex-direction: column; gap: 12px; margin-top: 18px; }
.shopcat-faq-item { padding: 0; }
.shopcat-faq-q {
  cursor: pointer; font-weight: 800; font-size: 16px;
  padding: 16px 20px; list-style: none; font-family: var(--fl-font-display);
}
.shopcat-faq-q::-webkit-details-marker { display: none; }
.shopcat-faq-q::after { content: "+"; float: right; font-size: 20px; line-height: 1; color: var(--fl-purple); }
.shopcat-faq-item[open] .shopcat-faq-q::after { content: "–"; }
.shopcat-faq-a {
  padding: 0 20px 18px; font-size: 15px; line-height: 1.7; color: var(--fl-ink2);
  border-top: 2px solid var(--fl-ink); padding-top: 14px;
}

/* keep-reading band reuses .gd-keep / .gd-keep-* (no overrides needed) */

@media (max-width: 600px) {
  .shopcat-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 14px; }
  .shopcat-card-name { font-size: 17px; }
}

/* ===== brand.njk ===== */
/* ═══ .brandhub — /brand/{slug}/ native CollectionB shell (reuses .gd-* hero/TOC/keep) ═══ */

/* color-tinted product grid (devices have no flavor-family → cycle accent via --bh-acc) */
.brandhub-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
  gap: 20px;
  margin: 0 0 8px;
}
.brandhub-card {
  display: flex; flex-direction: column;
  padding: 0; overflow: hidden;
  text-decoration: none; color: inherit;
}
.brandhub-card-img {
  aspect-ratio: 1 / 1;
  background: #fff;
  border-bottom: 2px solid var(--fl-ink);
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.brandhub-card-img::before {
  content: ""; position: absolute; inset: 0;
  background: var(--bh-acc, var(--fl-purple));
  opacity: 0.10; pointer-events: none;
}
.brandhub-card-img img { position: relative; width: 100%; height: 100%; object-fit: contain; padding: 12px; }
.brandhub-card-body { padding: 14px 15px 16px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.brandhub-card-name { font-weight: 800; font-size: 19px; line-height: 0.98; letter-spacing: -0.01em; flex: 1; }
.brandhub-card-foot {
  display: flex; align-items: baseline; gap: 8px;
  padding-top: 11px; border-top: 2px solid var(--fl-ink);
}
.brandhub-card-meta { font-size: 10px; font-weight: 700; letter-spacing: 0.1em; color: var(--fl-ink2); }
.brandhub-card-price { font-weight: 900; font-size: 18px; color: var(--bh-acc, var(--fl-purple)); margin-left: auto; }
.brandhub-card-go { font-size: 18px; font-weight: 900; color: var(--bh-acc, var(--fl-purple)); line-height: 1; }
.brandhub-card:not(:has(.brandhub-card-price)) .brandhub-card-go { margin-left: auto; }

/* lifted aboutHtml in .fl-rich; just constrain measure */
.brandhub-about { max-width: 720px; }

/* device lineup spec table (Hyper Drop framing) */
.brandhub-table-wrap { overflow-x: auto; border: 2px solid var(--fl-ink); border-radius: 12px; box-shadow: 4px 4px 0 var(--fl-ink); }
.brandhub-table { width: 100%; border-collapse: collapse; font-size: 14px; background: #fff; }
.brandhub-table th {
  text-align: left; padding: 11px 14px;
  background: var(--fl-cream2); font-family: var(--fl-font-display);
  font-weight: 800; font-size: 12px; letter-spacing: 0.04em;
  border-bottom: 2px solid var(--fl-ink);
}
.brandhub-table td { padding: 10px 14px; border-bottom: 1px solid rgba(14,10,20,.12); }
.brandhub-table tr:last-child td { border-bottom: none; }
.brandhub-tlink { color: var(--fl-purple); font-weight: 700; text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 2px; }
.brandhub-tlink:hover { color: var(--fl-hot); }

/* guide cross-link callout (color-block) */
.brandhub-callout {
  background: var(--fl-acid);
  border: 2px solid var(--fl-ink); border-radius: 16px;
  box-shadow: 5px 5px 0 var(--fl-ink);
  padding: 22px 24px;
  display: flex; flex-direction: column; align-items: flex-start; gap: 14px;
}
.brandhub-callout-p { font-size: 15.5px; line-height: 1.6; color: var(--fl-ink); margin: 0; max-width: 60ch; font-weight: 500; }

/* FAQ accordion */
.brandhub-faq { display: flex; flex-direction: column; gap: 10px; }
.brandhub-faq-item {
  background: #fff; border: 2px solid var(--fl-ink); border-radius: 12px;
  box-shadow: 3px 3px 0 var(--fl-ink); padding: 4px 18px;
}
.brandhub-faq-item summary {
  cursor: pointer; list-style: none;
  font-family: var(--fl-font-display); font-weight: 700; font-size: 15.5px;
  padding: 12px 0; color: var(--fl-ink);
}
.brandhub-faq-item summary::-webkit-details-marker { display: none; }
.brandhub-faq-item summary::after { content: "+"; float: right; font-weight: 800; color: var(--fl-purple); }
.brandhub-faq-item[open] summary::after { content: "–"; }
.brandhub-faq-a { font-size: 14px; line-height: 1.7; color: var(--fl-ink2); padding: 0 0 14px; }

@media (max-width: 640px) {
  .brandhub-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 14px; }
  .brandhub-card-name { font-size: 17px; }
}

/* ═══ /best/{slug}/ — FlavorSingleB (single-flavor pages only) ═══ */
.fsb { background: var(--fl-cream); color: var(--fl-ink); }
.fsb a { text-decoration: none; }
.fsb-crumb { padding: 18px 56px; background: #dfc8ff; border-bottom: 2px solid var(--fl-ink); }
.fsb-crumb-line { font-size: 11px; letter-spacing: .14em; font-weight: 700; color: var(--fl-ink); margin: 0; }
.fsb-crumb-a { color: var(--fl-ink); }
.fsb-crumb-a:hover { color: var(--fl-purple); }
.fsb-crumb-cur { background: var(--fl-purple); color: #fff; padding: 2px 8px; border-radius: 4px; }
.fsb-hero { padding: 64px 0 80px; background: linear-gradient(180deg, #dfc8ff 0%, var(--fl-cream) 100%); }
.fsb-hero-grid { max-width: 1180px; margin: 0 auto; padding: 0 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.fsb-eyebrows { display: flex; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
.fsb-flavor-name { font-size: clamp(38px, 5.4vw, 76px); line-height: 1.02; margin: 0; letter-spacing: -0.01em; }
.fsb-flavor-last { color: var(--fl-cyan); background: var(--fl-ink); padding: 0 14px; border-radius: 14px; border: 2px solid var(--fl-ink); display: inline-block; white-space: nowrap; }
.fsb-h1-sub { font-size: clamp(18px, 2.4vw, 27px); line-height: 1.25; font-weight: 700; color: var(--fl-ink2); max-width: 520px; margin: 18px 0 0; }
.fsb-seo-h1 { font-size: 19px; line-height: 1.4; font-weight: 700; max-width: 480px; margin: 26px 0 0; }
.fsb-byline { font-size: 11px; color: var(--fl-ink2); margin-top: 22px; letter-spacing: .14em; font-weight: 700; }
.fsb-hero-right { position: relative; }
.fsb-mono-card { position: relative; height: 460px; border: 2px solid var(--fl-ink); border-radius: 18px; background: linear-gradient(135deg, #4f3aa8 0%, #1a1140 100%); box-shadow: 10px 10px 0 var(--fl-ink); overflow: hidden; display: flex; align-items: center; justify-content: center; }
.fsb-mono-initials { font-size: clamp(140px, 22vw, 280px); color: rgba(255,255,255,.08); line-height: 1; }
.fsb-mono-img { position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%); max-height: 190px; max-width: 60%; width: auto; object-fit: contain; filter: drop-shadow(0 8px 18px rgba(0,0,0,.4)); }
.fsb-mono-tag-tl { position: absolute; top: 24px; left: 24px; }
.fsb-mono-tag-br { position: absolute; bottom: 24px; right: 24px; }
.fsb-taste { padding: 96px 0; }
.fsb-taste-grid { max-width: 1180px; margin: 0 auto; padding: 0 56px; display: grid; grid-template-columns: 1fr 1.4fr; gap: 64px; }
.fsb-taste-h2 { font-size: clamp(40px, 6vw, 60px); margin: 18px 0 0; line-height: .92; }
.fsb-taste-note { font-size: 14px; color: var(--fl-ink2); margin-top: 18px; max-width: 340px; line-height: 1.6; }
.fsb-axis { display: grid; grid-template-columns: 140px 1fr 60px; gap: 24px; align-items: center; padding: 16px 0; border-bottom: 2px solid var(--fl-ink); }
.fsb-axis-label { font-size: 12px; font-weight: 700; letter-spacing: .14em; margin: 0; }
.fsb-axis-bar { display: flex; gap: 6px; }
.fsb-seg { flex: 1; height: 18px; background: transparent; border: 2px solid var(--fl-ink); border-radius: 6px; }
.fsb-axis-val { font-size: 24px; text-align: right; margin: 0; }
.fsb-notes-card { margin-top: 32px; padding: 24px; background: var(--fl-cream); border: 2px solid var(--fl-ink); border-radius: 14px; box-shadow: 5px 5px 0 var(--fl-purple); }
.fsb-notes-fam { font-size: 17px; margin: 14px 0 0; line-height: 1.6; font-weight: 500; }
.fsb-notes-link { margin: 12px 0 0; }
.fsb-jump { color: var(--fl-purple); font-weight: 700; border-bottom: 2px solid var(--fl-purple); }
.fsb-notes-fact { font-size: 11px; letter-spacing: .14em; font-weight: 700; color: var(--fl-ink2); margin: 14px 0 0; }
.fsb-devices { padding: 0 0 96px; }
.fsb-devices-head, .fsb-devices-grid { max-width: 1180px; margin: 0 auto; padding: 0 56px; }
.fsb-devices-head { display: flex; align-items: baseline; gap: 18px; margin-bottom: 32px; flex-wrap: wrap; }
.fsb-devices-h2 { font-size: clamp(40px, 6vw, 60px); margin: 0; }
.fsb-devices-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.fsb-dev-card { padding: 24px; border: 2px solid var(--fl-ink); border-radius: 14px; box-shadow: 6px 6px 0 var(--fl-ink); display: flex; justify-content: space-between; align-items: center; gap: 14px; color: var(--fl-ink); transition: transform .12s ease, box-shadow .12s ease; }
.fsb-dev-card:hover { transform: translate(-3px, -3px); box-shadow: 9px 9px 0 var(--fl-ink); }
.fsb-dev-name { font-size: 22px; line-height: 1.1; margin: 0; }
.fsb-dev-brand { font-size: 11px; letter-spacing: .14em; font-weight: 700; margin: 8px 0 0; opacity: .82; }
.fsb-dev-meta { font-size: 11px; letter-spacing: .12em; font-weight: 700; margin: 6px 0 0; opacity: .82; }
.fsb-dev-arrow { font-size: 28px; font-weight: 900; flex: none; }
.fsb-acid { background: var(--fl-acid); } .fsb-cyan { background: var(--fl-cyan); } .fsb-amber { background: var(--fl-amber); }
.fsb-purple { background: var(--fl-purple); color: #fff; } .fsb-hot { background: var(--fl-hot); color: #fff; } .fsb-cream2 { background: var(--fl-cream2); }
/* ── Shop this flavor — section wrapper. The grid itself reuses the .fl-rich-scoped
   tvf-gp / gm-sf classes (shared CSS) so it's visually identical to the brand widget. ── */
[x-cloak] { display: none !important; }
.bsf-sec { padding: 8px 0 90px; }
.bsf-sec > .fl-rich { max-width: 1180px; margin: 0 auto; padding: 0 56px; }
@media (max-width: 860px) { .bsf-sec > .fl-rich { padding: 0 22px; } }
/* inside the topic gd-main content column, drop the full-width section chrome */
.gd-main .bsf-sec { padding: 0 0 36px; }
.gd-main .bsf-sec > .fl-rich { max-width: none; padding: 0; }

.fsb-rich-wrap { max-width: 920px; margin: 0 auto; padding: 0 56px 24px; }
.fsb-keep { padding: 80px 0 96px; border-top: 2px solid var(--fl-ink); }
.fsb-keep-wrap { max-width: 1180px; margin: 0 auto; padding: 0 56px; }
.fsb-keep-h2 { font-size: clamp(40px, 6vw, 60px); margin: 16px 0 32px; }
.fsb-keep-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.fsb-keep-card { display: flex; flex-direction: column; gap: 8px; padding: 24px; min-height: 150px; border: 2px solid var(--fl-ink); border-radius: 14px; box-shadow: 6px 6px 0 var(--fl-ink); color: var(--fl-ink); transition: transform .12s ease, box-shadow .12s ease; }
.fsb-keep-card:hover { transform: translate(-3px, -3px); box-shadow: 9px 9px 0 var(--fl-ink); }
.fsb-keep-tag { font-size: 11px; letter-spacing: .14em; font-weight: 700; }
.fsb-keep-title { font-size: 24px; line-height: 1.05; margin-top: auto; }
.fsb-keep-go { font-size: 12px; letter-spacing: .1em; font-weight: 700; }
.fsb-tilt-l { transform: rotate(-3deg); } .fsb-tilt-r { transform: rotate(5deg); }
@media (max-width: 860px) {
  .fsb-crumb { padding: 14px 22px; }
  .fsb-hero { padding: 40px 0 56px; }
  .fsb-hero-grid, .fsb-taste-grid { grid-template-columns: 1fr; gap: 36px; padding: 0 22px; }
  .fsb-devices-head, .fsb-devices-grid, .fsb-keep-wrap, .fsb-rich-wrap { padding-left: 22px; padding-right: 22px; }
  .fsb-mono-card { height: 340px; }
  .fsb-axis { grid-template-columns: 96px 1fr 48px; gap: 12px; }
  .fsb-devices-grid { grid-template-columns: 1fr 1fr; }
  .fsb-keep-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) { .fsb-devices-grid, .fsb-keep-grid { grid-template-columns: 1fr; } }

/* ═══ .bhome — Hyper Drop "HomeB" single-brand showcase (src/brand.njk) ═══ */
.fl .bhome { --bh-shadow: 8px 8px 0 var(--fl-ink); }
.bhome-wrap { max-width: var(--fl-maxw); margin: 0 auto; padding: 0 var(--fl-pad-x); }
.bhome .bhome-tilt-a { display: inline-flex; transform: rotate(-4deg); }
.bhome .bhome-tilt-b { display: inline-block; transform: rotate(-3deg); }
.bhome-hero { padding: 56px 0 64px; position: relative; overflow: hidden; }
.bhome-hero-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 48px; align-items: center; }
.bhome-hero-l { position: relative; }
.bhome-eyebrow { font-size: 11px; color: var(--fl-ink2); letter-spacing: 0.18em; text-transform: uppercase; margin: 18px 0 0; }
.bhome-tagline { font-size: clamp(56px, 9vw, 118px); line-height: 0.86; margin: 14px 0 0; color: var(--fl-ink); }
.bhome-tagline .bhome-c-purple { color: var(--fl-purple); }
.bhome-tagline .bhome-c-hot { color: var(--fl-hot); margin-left: 12px; }
.bhome-seo-h1 { font-size: clamp(20px, 2.4vw, 28px); line-height: 1.1; margin: 22px 0 0; color: var(--fl-ink); }
/* dramatic multi-color display H1 (restores the original tagline UI, applied to the real H1) */
.bhome-h1 { font-size: clamp(46px, 7vw, 92px); line-height: 0.88; letter-spacing: -0.025em; margin: 14px 0 0; color: var(--fl-ink); }
.bhome-h1-lead { display: block; }
.bhome-h1-pop { color: var(--fl-purple); display: inline-block; }
.bhome-h1-tail { display: block; color: var(--fl-hot); font-size: 0.4em; line-height: 1.02; letter-spacing: -0.01em; margin-top: 0.34em; font-weight: 800; max-width: 20ch; }
.bhome-statline { margin: 20px 0 0; }
.bhome-statline .bhome-hl { display: inline; background: var(--fl-acid); color: var(--fl-ink); padding: 3px 8px; border-radius: 6px; border: 2px solid var(--fl-ink); font-size: 15px; font-weight: 700; line-height: 1.9; box-decoration-break: clone; -webkit-box-decoration-break: clone; }
.bhome-lede { font-size: 17px; color: var(--fl-ink2); margin: 20px 0 0; max-width: 540px; line-height: 1.6; font-weight: 500; }
.bhome-cta-row { display: flex; gap: 14px; margin-top: 32px; flex-wrap: wrap; }
.bhome-cta-row .fl-btn { padding: 16px 28px; font-size: 15px; }
.bhome-hero-r { position: relative; min-height: 480px; }
/* brand-LOGO card (replaces the device showcase) — white panel, logo centered, no oversized art */
.bhome-logocard {
  position: absolute; inset: 0; background: var(--fl-white);
  border: 3px solid var(--fl-ink); border-radius: 32px; box-shadow: 10px 10px 0 var(--fl-ink);
  overflow: hidden; display: flex; align-items: center; justify-content: center; padding: 14%;
}
.bhome-logocard-img { max-width: 74%; max-height: 56%; width: auto; height: auto; object-fit: contain; }
.bhome-logocard-flag { position: absolute; top: 18px; left: 18px; transform: rotate(-4deg); z-index: 2; }
.bhome-logocard-pill { position: absolute; bottom: 18px; right: 18px; z-index: 2; max-width: 80%; }
/* lineup stock badge */
.bhome-card-stock {
  align-self: flex-start; margin-bottom: 14px; font-size: 10px; font-weight: 800;
  letter-spacing: 0.1em; padding: 3px 10px; border: 2px solid var(--fl-ink); border-radius: 999px;
  background: var(--fl-acid); color: var(--fl-ink); box-shadow: 2px 2px 0 var(--fl-ink); line-height: 1.4;
}
.bhome-card-stock.is-oos { background: var(--fl-cream2); color: var(--fl-ink2); }
.bhome-card.is-oos { opacity: 0.8; }
.bhome-devcard { position: absolute; inset: 0; background: var(--fl-purple); border: 3px solid var(--fl-ink); border-radius: 32px; box-shadow: 10px 10px 0 var(--fl-ink); overflow: hidden; display: block; transition: transform 0.15s ease, box-shadow 0.15s ease; }
.bhome-devcard:hover { transform: translate(-2px,-2px); box-shadow: 12px 12px 0 var(--fl-ink); }
.bhome-devcard-mono { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-size: clamp(140px, 22vw, 260px); color: rgba(255,255,255,0.13); line-height: 1; white-space: nowrap; pointer-events: none; user-select: none; }
.bhome-devcard-img { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); max-height: 78%; width: auto; object-fit: contain; z-index: 1; filter: drop-shadow(0 10px 24px rgba(0,0,0,0.35)); }
.bhome-devcard-flag { position: absolute; top: 18px; left: 18px; transform: rotate(-4deg); z-index: 2; }
.bhome-devcard-pill { position: absolute; bottom: 18px; right: 18px; z-index: 2; max-width: 80%; }
.bhome-devcard-corner { position: absolute; top: -16px; right: -14px; transform: rotate(8deg); padding: 11px 16px; font-size: 13px; z-index: 3; }
.bhome-devcard-low { position: absolute; bottom: -20px; left: 26px; transform: rotate(-5deg); z-index: 3; }
.bhome-stripe { margin: 0; }
.bhome-spot { padding: 76px 0; background: var(--fl-cream2); }
.bhome-spot-head { display: flex; align-items: baseline; gap: 18px; margin-bottom: 28px; flex-wrap: wrap; }
.bhome-spot-kicker { font-size: clamp(34px, 5vw, 48px); }
.bhome-spot-card { padding: 0; display: grid; grid-template-columns: 1.2fr 1fr; align-items: stretch; }
.bhome-spot-body { padding: 44px; position: relative; }
.bhome-spot-meta { font-size: 11px; color: var(--fl-ink2); letter-spacing: 0.14em; }
.bhome-spot-name { font-size: clamp(40px, 6vw, 66px); line-height: 0.94; margin: 14px 0 0; }
.bhome-spot-blurb { font-size: 16px; color: var(--fl-ink2); margin: 18px 0 0; max-width: 440px; line-height: 1.6; }
.bhome-spot-buy { display: flex; gap: 16px; margin-top: 30px; align-items: center; }
.bhome-spot-price { font-size: 38px; color: var(--fl-purple); }
.bhome-spot-art { background: linear-gradient(135deg, var(--fl-hot) 0%, var(--fl-amber) 100%); position: relative; min-height: 360px; border-left: 2px solid var(--fl-ink); overflow: hidden; }
.bhome-spot-art-mono { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-size: clamp(80px, 12vw, 130px); color: rgba(255,255,255,0.42); white-space: nowrap; pointer-events: none; user-select: none; }
/* product image fills the art frame edge-to-edge (marketing shots are square w/ their own
   bg → cover removes the gradient-gap mismatch the user flagged) */
.bhome-spot-art-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; z-index: 1; }
.bhome-spot-art-pill { position: absolute; bottom: 22px; left: 22px; z-index: 2; max-width: 84%; }
.bhome-lineup { padding: 84px 0; }
.bhome-lineup-head { display: flex; align-items: baseline; gap: 18px; margin-bottom: 44px; flex-wrap: wrap; }
.bhome-lineup-h2 { font-size: clamp(26px, 3.6vw, 40px); line-height: 1.02; }
.bhome-lineup-all { margin-left: auto; font-size: 12px; font-weight: 700; letter-spacing: 0.14em; color: var(--fl-ink); }
.bhome-lineup-all:hover { color: var(--fl-purple); }
.bhome-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
/* device cards now lead with the product main image (white panel) over a colored body */
.bhome-card { background: var(--bh-acc); color: var(--fl-ink); padding: 0; overflow: hidden; display: flex; flex-direction: column; border: 2px solid var(--fl-ink); border-radius: 18px; box-shadow: 6px 6px 0 var(--fl-ink); transition: transform .12s ease, box-shadow .12s ease; }
.bhome-card:hover { transform: translate(-3px,-3px); box-shadow: 9px 9px 0 var(--fl-ink); }
.bhome-card-imgwrap { position: relative; aspect-ratio: 4/3; background: #fff; border-bottom: 2px solid var(--fl-ink); display: flex; align-items: center; justify-content: center; }
.bhome-card-img { max-width: 100%; max-height: 100%; object-fit: contain; padding: 14px; }
.bhome-card-stock { position: absolute; top: 10px; left: 10px; z-index: 2; font-size: 9px; font-weight: 800; letter-spacing: 0.08em; padding: 3px 8px; border: 2px solid var(--fl-ink); border-radius: 999px; background: var(--fl-acid); color: var(--fl-ink); box-shadow: 2px 2px 0 var(--fl-ink); line-height: 1.3; }
.bhome-card-stock.is-oos { background: var(--fl-cream2); color: var(--fl-ink2); }
.bhome-card-body { padding: 16px 18px; display: flex; flex-direction: column; flex: 1; }
.bhome-card-name { font-size: 16px; line-height: 1.1; letter-spacing: -0.01em; }
.bhome-card-foot { display: flex; justify-content: space-between; align-items: flex-end; margin-top: auto; padding-top: 14px; border-top: 2px solid rgba(14,10,20,0.22); }
.bhome-card-puffs { font-size: 11px; opacity: 0.72; }
.bhome-card-price { font-size: 24px; margin-top: 4px; }
.bhome-card-go { font-size: 22px; font-weight: 900; line-height: 1; }
.bhome-flavors { margin-top: 36px; padding: 32px; border: 2px solid var(--fl-ink); border-radius: 24px; background: var(--fl-white); box-shadow: 5px 5px 0 var(--fl-ink); }
.bhome-flavors-p { font-size: 16px; color: var(--fl-ink2); margin: 14px 0 18px; max-width: 620px; line-height: 1.6; }
.bhome-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.bhome-about { padding: 64px 0 28px; }
.bhome-about-card { padding: 40px 44px 36px; }
.bhome-about-head { display: flex; align-items: baseline; justify-content: space-between; gap: 18px; flex-wrap: wrap; margin-bottom: 6px; }
.bhome-about-meta { font-size: 11px; letter-spacing: 0.14em; color: var(--fl-ink2); }
.bhome-about-card .bhome-rich { margin-top: 14px; max-width: 820px; }
.bhome-rich { margin-top: 18px; line-height: 1.7; font-size: 16px; max-width: 760px; }
.bhome-rich > h2:first-child, .bhome-rich > h3:first-child, .bhome-rich > p:first-child { margin-top: 0; }
.bhome-rich h2 { font-size: 28px; margin: 34px 0 12px; }
.bhome-rich h3 { font-size: 20px; margin: 26px 0 8px; color: var(--fl-purple); }
.bhome-rich p { margin: 0 0 14px; }
.bhome-rich a { color: var(--fl-purple); font-weight: 600; text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 2px; }
.bhome-rich a:hover { color: var(--fl-hot); }
.bhome-rich ul, .bhome-rich ol { margin: 0 0 16px; padding-left: 22px; }
.bhome-rich li { margin: 0 0 6px; }
.bhome-faq-sec { padding: 0 0 84px; }
.bhome-faq-head { display: flex; align-items: baseline; gap: 18px; margin-bottom: 28px; flex-wrap: wrap; }
.bhome-faq-h2 { font-size: clamp(36px, 5vw, 56px); }
.bhome-faq { display: flex; flex-direction: column; gap: 14px; }
.bhome-faq-item { border: 2px solid var(--fl-ink); border-radius: 18px; background: var(--fl-white); box-shadow: 4px 4px 0 var(--fl-ink); overflow: hidden; }
.bhome-faq-item[open] { background: var(--fl-cream); }
.bhome-faq-item summary { list-style: none; cursor: pointer; padding: 22px 24px; display: flex; align-items: center; gap: 18px; }
.bhome-faq-item summary::-webkit-details-marker { display: none; }
.bhome-faq-num { font-size: 30px; color: var(--fl-purple); flex-shrink: 0; line-height: 1; }
.bhome-faq-q { flex: 1; font-weight: 700; font-size: 17px; line-height: 1.3; }
.bhome-faq-plus { font-family: var(--fl-font-display); font-size: 30px; color: var(--fl-ink); line-height: 1; flex-shrink: 0; transition: transform 0.15s ease; }
.bhome-faq-item[open] .bhome-faq-plus { transform: rotate(45deg); }
.bhome-faq-a { padding: 0 24px 22px 64px; font-size: 15px; color: var(--fl-ink2); line-height: 1.65; }
.bhome-faq-a p { margin: 0 0 10px; }
.bhome-keep { padding: 0 0 96px; }
.bhome-keep-h2 { font-size: clamp(40px, 6vw, 64px); margin: 14px 0 28px; }
.bhome-keep-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.bhome-keep-card { border: 2px solid var(--fl-ink); border-radius: 22px; box-shadow: 5px 5px 0 var(--fl-ink); padding: 24px; display: flex; flex-direction: column; gap: 8px; min-height: 150px; color: var(--fl-ink); transition: transform 0.15s ease, box-shadow 0.15s ease; }
.bhome-keep-card:hover { transform: translate(-2px,-2px); box-shadow: 8px 8px 0 var(--fl-ink); }
.bhome-keep-tag { font-size: 11px; letter-spacing: 0.14em; opacity: 0.7; }
.bhome-keep-title { font-size: 26px; line-height: 1; margin-top: auto; }
.bhome-keep-go { font-size: 11px; letter-spacing: 0.1em; opacity: 0.8; }
@media (max-width: 980px) { .bhome-hero-grid { grid-template-columns: 1fr; gap: 40px; } .bhome-hero-r { min-height: 420px; margin-top: 14px; } .bhome-spot-card { grid-template-columns: 1fr; } .bhome-spot-art { border-left: 0; border-top: 2px solid var(--fl-ink); min-height: 280px; } .bhome-grid { grid-template-columns: repeat(2, 1fr); } .bhome-keep-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .bhome-tagline { font-size: 52px; } .bhome-spot-body { padding: 28px; } .bhome-grid { grid-template-columns: 1fr; } .bhome-keep-grid { grid-template-columns: 1fr; } .bhome-faq-a { padding-left: 24px; } }

/* ═══════════════════════════════════════════════════════════════════════
   .idx-* — NATIVE Hyper Drop index hubs (/brand/ /guide/ /best/ listing pages)
   Reuses .gd-hero / .gd-wrap / .fl-sticker / .fl-card / .gd-keep chrome.
   ═══════════════════════════════════════════════════════════════════════ */
.idx-hero .idx-sub {
  font-size: 18px; line-height: 1.6; font-weight: 500;
  color: var(--fl-ink); max-width: 680px; margin: 22px 0 0;
}
.idx-grid-sec { padding-top: 10px; padding-bottom: 14px; }
.idx-grid-sec .gd-h2 { margin: 0 0 18px; }
.idx-grid-sec-alt { padding-top: 28px; }

/* image cards (brand index) */
.idx-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 24px;
}
.idx-card { display: flex; flex-direction: column; padding: 0; overflow: hidden; transition: transform 0.15s ease, box-shadow 0.15s ease; }
.idx-card:hover { transform: translate(-2px,-2px); box-shadow: 8px 8px 0 var(--fl-ink); }
.idx-card-main { display: flex; flex-direction: column; flex: 1; text-decoration: none; color: inherit; }
.idx-card-img {
  aspect-ratio: 1/1; background: #fff;
  border-bottom: 2px solid var(--fl-ink);
  display: flex; align-items: center; justify-content: center;
}
.idx-card-img img { width: 100%; height: 100%; object-fit: contain; padding: 14px; }
.idx-card-mono { font-size: 12px; letter-spacing: 0.06em; color: var(--fl-ink2); padding: 14px; text-align: center; }
.idx-card-body { padding: 16px 18px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.idx-card-kicker { font-size: 10px; font-weight: 700; letter-spacing: 0.12em; }
.idx-card-name { font-size: 22px; line-height: 0.98; letter-spacing: -0.01em; }
.idx-card-stats { display: flex; gap: 14px; font-size: 12px; color: var(--fl-ink2); margin-top: 2px; }
.idx-card-stats b { color: var(--fl-ink); }
.idx-card-go { font-size: 13px; font-weight: 800; letter-spacing: 0.02em; margin-top: 10px; padding-top: 12px; border-top: 2px solid var(--fl-ink); }
/* when the "View flavors →" is its own link at the card foot (brand-index) */
.idx-card-go-link { display: block; margin: 0; padding: 13px 18px; border-top: 2px solid var(--fl-ink); text-decoration: none; transition: background 0.12s ease; }
.idx-card-go-link:hover { background: var(--fl-cream2); }

/* text cards (guide + best index) */
.idx-grid-text { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.idx-tcard {
  display: flex; flex-direction: column; gap: 12px;
  padding: 22px 22px 20px; position: relative; overflow: hidden;
  text-decoration: none; color: inherit;
}
.idx-tcard-bar { position: absolute; left: 0; top: 0; bottom: 0; width: 7px; }
.idx-tcard-kicker { font-size: 10px; font-weight: 700; letter-spacing: 0.12em; color: var(--fl-ink2); padding-left: 6px; }
.idx-tcard-name { font-size: 21px; line-height: 1.06; letter-spacing: -0.01em; flex: 1; padding-left: 6px; }
.idx-tcard-go { font-size: 12px; font-weight: 800; letter-spacing: 0.02em; padding-left: 6px; padding-top: 12px; border-top: 2px solid var(--fl-ink); }

.idx-editorial { padding-top: 18px; }
.idx-editorial-wrap { max-width: 820px; }
.idx-keep { padding-top: 24px; }

@media (max-width: 640px) {
  .idx-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 14px; }
  .idx-grid-text { grid-template-columns: 1fr; }
  .idx-card-name { font-size: 18px; }
}

/* ═══════════════════════════════════════════════════════════════════════
   .info-* — NATIVE Hyper Drop "InfoB" hero/body (policy pages + misc/about/team/quiz)
   Body prose stays in .fl-rich (verbatim lifted content, retuned by redress).
   ═══════════════════════════════════════════════════════════════════════ */
.info-hero { padding-bottom: 24px; }
.info-hero-wrap { max-width: 1080px; }
.info-hero-h1 { max-width: 18ch; }
.info-hero-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 36px; align-items: start; margin-top: 4px; }
.info-hero-grid > div:first-child { min-width: 0; }

.info-author { display: flex; align-items: center; gap: 14px; margin-top: 26px; }
.info-author-avatar {
  width: 46px; height: 46px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--fl-font-display); font-size: 19px; color: #fff;
  border: 2px solid var(--fl-ink);
}
.info-author-name { font-weight: 700; font-size: 14px; line-height: 1.3; }
.info-author-meta { font-size: 11px; letter-spacing: 0.06em; color: var(--fl-ink2); margin-top: 3px; }

.info-snap { padding: 22px 24px; align-self: start; }
.info-snap-label { font-size: 11px; letter-spacing: 0.14em; color: var(--fl-ink2); margin-bottom: 16px; }
.info-snap-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px 16px; }
.info-snap-val { font-size: 30px; line-height: 1; color: var(--fl-purple); }
.info-snap-key { font-size: 10px; letter-spacing: 0.08em; color: var(--fl-ink2); margin-top: 6px; }

.info-tldr { margin-top: 28px; padding: 0; overflow: hidden; }
.info-tldr summary { list-style: none; cursor: pointer; padding: 18px 24px; display: flex; align-items: center; justify-content: space-between; }
.info-tldr summary::-webkit-details-marker { display: none; }
.info-tldr-label { font-size: 12px; letter-spacing: 0.1em; font-weight: 700; }
.info-tldr-hint { color: var(--fl-ink2); font-weight: 500; }
.info-tldr-plus { font-size: 26px; line-height: 1; transition: transform 0.15s ease; }
.info-tldr[open] .info-tldr-plus { transform: rotate(45deg); }
.info-tldr-body { padding: 0 24px 22px; font-size: 15px; line-height: 1.7; color: var(--fl-ink); margin: 0; }

.info-body { padding-top: 8px; padding-bottom: 40px; }
.info-body-wrap { max-width: 820px; }

@media (max-width: 860px) {
  .info-hero-grid { grid-template-columns: 1fr; gap: 26px; }
  .info-snap { max-width: 420px; }
}

/* ════════════════════════════════════════════════════════════════════════
   .iab-* — NATIVE "InfoB" ABOUT page (ported 1:1 from design-source
   direction-b.jsx → function InfoB). Hand-written bespoke Hyper Drop layout:
   giant display H1, purple clarification feature block (10px offset shadow),
   solid color-block cards, numbered process strip. Reuses .fl-card / .fl-sticker
   / .fl-display / .fl-btn. Scoped to .iab-*; no other page affected.
   ════════════════════════════════════════════════════════════════════════ */
.iab-hero { padding: 72px 0 36px; }
.iab-stickers { display: flex; gap: 10px; margin-bottom: 20px; flex-wrap: wrap; }
.iab-h1 { font-size: clamp(44px, 8.5vw, 104px); line-height: 0.9; max-width: 1100px; margin: 0; color: var(--fl-ink); }
.iab-lede { font-size: clamp(17px, 2vw, 20px); color: var(--fl-ink); margin: 30px 0 0; max-width: 780px; line-height: 1.55; font-weight: 500; }

.iab-sec { padding: 0 0 64px; }
.iab-sec-last { padding-bottom: 88px; }

/* clarification feature block */
.iab-clar { background: var(--fl-purple); color: var(--fl-cream); box-shadow: 10px 10px 0 var(--fl-ink); border-radius: 24px; padding: clamp(28px, 4vw, 48px); }
.iab-clar-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: clamp(28px, 4vw, 48px); align-items: start; }
.iab-clar-h2 { font-size: clamp(34px, 5vw, 60px); line-height: 0.95; color: var(--fl-cream); margin: 18px 0 0; }
.iab-em-acid { color: var(--fl-acid); }
.iab-clar-body p { font-size: clamp(16px, 1.8vw, 18px); line-height: 1.7; font-weight: 500; margin: 0; color: var(--fl-cream); }
.iab-chip-acid, .iab-chip-cream { padding: 2px 8px; border-radius: 6px; border: 2px solid var(--fl-ink); color: var(--fl-ink); font-weight: 700; white-space: nowrap; }
.iab-chip-acid { background: var(--fl-acid); }
.iab-chip-cream { background: var(--fl-cream); }
.iab-clar-cta { margin-top: 26px; }

/* section heads */
.iab-head { display: flex; align-items: baseline; gap: 16px; margin-bottom: 28px; flex-wrap: wrap; }
.iab-h2 { font-size: clamp(30px, 4.5vw, 56px); line-height: 1; color: var(--fl-ink); margin: 0; }
.iab-h2-big { font-size: clamp(40px, 6vw, 76px); line-height: 0.94; margin: 16px 0 0; color: var(--fl-ink); max-width: 960px; }

/* solid color-block USP cards */
.iab-cards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.iab-card { padding: 28px; border-radius: 20px; box-shadow: 5px 5px 0 var(--fl-ink); }
.iab-card-t { font-size: clamp(24px, 2.6vw, 32px); line-height: 1.05; margin: 0; color: var(--fl-ink); }
.iab-card-p { font-size: 14.5px; margin: 14px 0 0; line-height: 1.6; font-weight: 500; opacity: 0.92; color: var(--fl-ink); }
.iab-on-dark, .iab-on-dark .iab-card-t, .iab-on-dark .iab-card-p, .iab-on-dark .iab-phase-n, .iab-on-dark .iab-phase-t { color: #fff !important; }

/* review process */
.iab-process-card { background: var(--fl-cream2); border-radius: 20px; box-shadow: 5px 5px 0 var(--fl-ink); padding: clamp(24px, 3vw, 36px); margin-top: 26px; }
.iab-process-card p { font-size: 15.5px; line-height: 1.7; margin: 0 0 14px; color: var(--fl-ink); }
.iab-process-card p:last-child { margin-bottom: 0; }
.iab-phases { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 20px; }
.iab-phase { padding: 24px; border-radius: 18px; box-shadow: 5px 5px 0 var(--fl-ink); display: flex; flex-direction: column; }
.iab-phase-n { font-size: clamp(44px, 5vw, 64px); line-height: 1; color: var(--fl-ink); }
.iab-phase-t { font-size: clamp(20px, 2.2vw, 26px); margin-top: 8px; color: var(--fl-ink); }

/* contact */
.iab-contact { background: var(--fl-cream2); border-radius: 20px; box-shadow: 5px 5px 0 var(--fl-ink); padding: clamp(24px, 3vw, 36px); }
.iab-contact-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin: 20px 0 0; }
.iab-contact-k { font-size: 11px; letter-spacing: 0.1em; opacity: 0.55; margin: 0 0 4px; }
.iab-contact-v { font-size: 16px; font-weight: 600; margin: 0; color: var(--fl-ink); word-break: break-word; }
.iab-contact-v a { color: var(--fl-purple); text-decoration: underline; }
.iab-contact-note { font-size: 14px; line-height: 1.6; margin: 18px 0 0; color: var(--fl-ink2); }

@media (max-width: 860px) {
  .iab-clar-grid { grid-template-columns: 1fr; }
  .iab-phases { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .iab-cards { grid-template-columns: 1fr; }
  .iab-contact-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════════════════
   .us-* — NATIVE "SearchB" (design-source direction-b-utility.jsx → SearchB).
   Sticker hero + big display query + chunky search bar + color-block jump
   cards + chunky result cards. Alpine searchPage() preserved.
   ════════════════════════════════════════════════════════════════════════ */
.us-hero { padding: 56px 0 8px; position: relative; }
.us-stickers { display: flex; gap: 10px; margin-bottom: 18px; flex-wrap: wrap; }
.us-h1 { font-size: clamp(40px, 7vw, 80px); line-height: 0.92; margin: 0; color: var(--fl-ink); }
.us-sub { font-size: clamp(15px, 1.7vw, 17px); color: var(--fl-ink2); max-width: 680px; margin: 18px 0 0; line-height: 1.55; font-weight: 500; }
.us-bar { display: flex; align-items: center; gap: 10px; background: #fff; border: 2px solid var(--fl-ink); border-radius: 999px; box-shadow: 5px 5px 0 var(--fl-ink); padding: 8px 8px 8px 22px; margin-top: 28px; max-width: 920px; }
.us-bar-icon { color: var(--fl-ink2); display: flex; flex: none; }
.us-bar-input { flex: 1; border: 0; outline: none; background: transparent; font-size: clamp(15px, 1.8vw, 18px); font-weight: 600; font-family: inherit; color: var(--fl-ink); min-width: 0; }
.us-bar-btn { flex: none; padding: 12px 22px; }

.us-body { padding: 36px 0 88px; }
.us-eyebrow { font-size: 11px; letter-spacing: 0.16em; font-weight: 700; color: var(--fl-ink2); margin: 0 0 14px; }
.us-eyebrow-gap { margin-top: 32px; }
.us-pills { display: flex; gap: 9px; flex-wrap: wrap; }

.us-jump { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 14px; }
.us-jump-card { display: flex; justify-content: space-between; align-items: center; padding: 22px 24px; border-radius: 18px; box-shadow: 5px 5px 0 var(--fl-ink); text-decoration: none; color: var(--fl-ink); }
.us-jump-card .fl-display { font-size: clamp(18px, 2.2vw, 24px); }
.us-jump-arr { font-size: 26px; font-weight: 900; }
.us-on-dark, .us-on-dark .fl-display { color: #fff !important; }
.us-jump-card:hover { transform: translate(-2px,-2px); box-shadow: 7px 7px 0 var(--fl-ink); }

.us-empty-card { background: #fff; padding: clamp(24px, 4vw, 40px); border-radius: 20px; box-shadow: 5px 5px 0 var(--fl-ink); }
.us-empty-h2 { font-size: clamp(26px, 3.5vw, 40px); margin: 14px 0 8px; color: var(--fl-ink); }
.us-empty-body { font-size: 15px; color: var(--fl-ink2); margin: 0 0 20px; font-weight: 500; }

.us-results { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.us-card { display: flex; flex-direction: column; background: #fff; border-radius: 18px; box-shadow: 5px 5px 0 var(--fl-ink); overflow: hidden; text-decoration: none; color: var(--fl-ink); }
.us-card:hover { transform: translate(-2px,-2px); box-shadow: 7px 7px 0 var(--fl-ink); }
.us-card-img { position: relative; aspect-ratio: 1; background: var(--fl-cream2); border-bottom: 2px solid var(--fl-ink); display: flex; align-items: center; justify-content: center; }
.us-card-img img { width: 100%; height: 100%; object-fit: contain; }
.us-card-stock { position: absolute; top: 8px; right: 8px; background: var(--fl-ink); color: var(--fl-acid); font-size: 9.5px; font-weight: 700; letter-spacing: 0.04em; padding: 3px 8px; border-radius: 999px; }
.us-card-body { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 6px; }
.us-card-title { font-size: 16px; line-height: 1.15; margin: 0; color: var(--fl-ink); }
.us-card-meta { font-size: 10.5px; color: var(--fl-ink2); margin: 0; letter-spacing: 0.04em; }
.us-card-meta strong { color: var(--fl-purple); }
.us-card-price { font-size: 17px; font-weight: 800; color: var(--fl-ink); margin: 2px 0 0; font-family: var(--fl-font-display); }
.us-card-was { font-size: 12px; color: var(--fl-ink2); text-decoration: line-through; font-weight: 600; margin-left: 6px; }

@media (max-width: 960px) { .us-results { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px) { .us-results { grid-template-columns: repeat(2, 1fr); } .us-jump, .us-success .us-results { } }
@media (max-width: 560px) { .us-jump { grid-template-columns: 1fr; } .us-results { grid-template-columns: 1fr 1fr; } }

/* ════════════════════════════════════════════════════════════════════════
   .uc-* — NATIVE "CartB" (design-source direction-b-utility.jsx → CartB).
   Sticker hero + color-swatch line cards + acid sticky summary + WE ACCEPT.
   Alpine $store.cart bindings preserved; this is visual shell only.
   ════════════════════════════════════════════════════════════════════════ */
.uc-hero { padding: 56px 0 8px; position: relative; }
.uc-stickers { display: flex; gap: 10px; margin-bottom: 18px; flex-wrap: wrap; }
.uc-h1 { font-size: clamp(44px, 7vw, 72px); line-height: 0.92; margin: 0; color: var(--fl-ink); }
.uc-body { padding: 32px 0 88px; }
.uc-loading { font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fl-ink2); }

.uc-empty { background: #fff; padding: clamp(28px, 5vw, 56px); border-radius: 20px; box-shadow: 5px 5px 0 var(--fl-ink); text-align: center; }
.uc-empty-h2 { font-size: clamp(30px, 4vw, 48px); margin: 16px 0 10px; color: var(--fl-ink); }
.uc-empty-body { font-size: 15px; color: var(--fl-ink2); margin: 0 auto 22px; max-width: 460px; font-weight: 500; }
.uc-empty-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

.uc-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 40px; align-items: start; }
.uc-top-promo { margin-bottom: 18px; }
.uc-error { color: var(--fl-hot); font-weight: 700; margin: 0 0 14px; }

.uc-line { display: grid; grid-template-columns: 92px 1fr auto; gap: 18px; align-items: center; padding: 16px 18px; border-radius: 16px; box-shadow: 4px 4px 0 var(--fl-ink); margin-bottom: 14px; }
.uc-line-img { width: 92px; height: 92px; border: 2px solid var(--fl-ink); border-radius: 12px; background: var(--fl-cream2); }
.uc-line-name { font-size: 17px; line-height: 1.1; color: var(--fl-ink); }
.uc-line-var { font-size: 10px; letter-spacing: 0.1em; color: var(--fl-purple); font-weight: 700; margin-top: 5px; }
.uc-line-controls { display: flex; align-items: center; gap: 14px; margin-top: 12px; flex-wrap: wrap; }
.uc-qty { display: inline-flex; align-items: center; border: 2px solid var(--fl-ink); border-radius: 999px; overflow: hidden; background: #fff; }
.uc-qty button { padding: 5px 12px; font-weight: 800; font-size: 14px; background: none; border: 0; cursor: pointer; color: var(--fl-ink); }
.uc-qty button:disabled { opacity: 0.4; cursor: default; }
.uc-qty span { padding: 5px 8px; font-weight: 700; font-size: 13px; }
.uc-remove { background: none; border: 0; padding: 0; color: var(--fl-ink2); font-size: 10px; letter-spacing: 0.12em; cursor: pointer; text-decoration: underline; }
.uc-remove:hover { color: var(--fl-hot); }
.uc-line-price { font-size: 22px; color: var(--fl-ink); text-align: right; white-space: nowrap; }
.uc-keep { display: inline-block; margin-top: 8px; font-size: 12px; font-weight: 700; letter-spacing: 0.12em; color: var(--fl-purple); text-decoration: none; }
.uc-keep:hover { color: var(--fl-hot); }

.uc-aside { position: sticky; top: 24px; display: flex; flex-direction: column; gap: 16px; }
.uc-summary { background: var(--fl-acid); padding: 24px; border-radius: 18px; box-shadow: 6px 6px 0 var(--fl-ink); }
.uc-sum-count { font-size: 30px; margin: 14px 0 16px; color: var(--fl-ink); }
.uc-sum-rows { display: flex; flex-direction: column; gap: 2px; }
.uc-sum-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; font-size: 12px; font-weight: 700; letter-spacing: 0.04em; color: var(--fl-ink); border-bottom: 1.5px solid rgba(14,10,20,0.15); }
.uc-sum-val { font-family: var(--fl-font-sans, inherit); font-weight: 700; }
.uc-sum-ok, .uc-sum-free { color: var(--fl-purple); }
.uc-checkout { width: 100%; margin-top: 18px; justify-content: center; }
.uc-sum-disclaim { font-size: 11px; margin: 12px 0 0; text-align: center; line-height: 1.5; font-weight: 600; color: var(--fl-ink); }
.uc-sum-hr { border: 0; border-top: 2px solid var(--fl-ink); margin: 18px 0; }
.uc-coupon-label { font-size: 10px; letter-spacing: 0.12em; font-weight: 700; color: var(--fl-ink); margin-bottom: 8px; }
.uc-coupon-row { display: grid; grid-template-columns: 1fr auto; gap: 8px; }
.uc-coupon-input { padding: 11px 14px; border: 2px solid var(--fl-ink); border-radius: 10px; font-size: 13px; background: #fff; text-transform: uppercase; }
.uc-coupon-btn { padding: 11px 18px; }
.uc-coupon-msg { font-size: 11px; margin: 8px 0 0; }
.uc-coupon-err { color: var(--fl-hot); }
.uc-coupon-ok { color: #1a7a3c; }

.uc-accept { background: #fff; padding: 18px 20px; border-radius: 16px; box-shadow: 4px 4px 0 var(--fl-ink); }
.uc-accept-label { font-size: 10px; letter-spacing: 0.14em; font-weight: 700; color: var(--fl-ink2); margin: 0 0 10px; }
.uc-accept-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.uc-accept-chips .fl-sticker { font-size: 10px; }
.uc-stamps { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.uc-stamps li { font-size: 10.5px; letter-spacing: 0.04em; color: var(--fl-ink2); line-height: 1.4; }

@media (max-width: 880px) { .uc-grid { grid-template-columns: 1fr; } .uc-aside { position: static; } }
@media (max-width: 520px) { .uc-line { grid-template-columns: 64px 1fr; } .uc-line-price { grid-column: 2; text-align: left; margin-top: 6px; } .uc-line-img { width: 64px; height: 64px; } }

/* ════════════════════════════════════════════════════════════════════════
   .ot-* — NATIVE "OrderTrackingB". Sticker hero + chunky lookup form +
   result/multi cards + color-dot vertical timeline (6 order states).
   Alpine orderLookup() preserved.
   ════════════════════════════════════════════════════════════════════════ */
.ot-hero { padding: 56px 0 8px; position: relative; }
.ot-center { max-width: 760px; }
.ot-stickers { display: flex; gap: 10px; margin-bottom: 18px; flex-wrap: wrap; }
.ot-h1 { font-size: clamp(40px, 7vw, 76px); line-height: 0.92; margin: 0; color: var(--fl-ink); }
.ot-sub { font-size: clamp(15px, 1.8vw, 17px); color: var(--fl-ink2); margin: 18px 0 0; line-height: 1.55; font-weight: 500; }
.ot-form { background: #fff; padding: 24px; border-radius: 18px; box-shadow: 5px 5px 0 var(--fl-ink); margin-top: 28px; }
.ot-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ot-form label { display: block; }
.ot-form-label { display: block; font-size: 10px; letter-spacing: 0.14em; font-weight: 700; color: var(--fl-ink2); margin-bottom: 6px; }
.ot-form-input { width: 100%; padding: 13px 15px; border: 2px solid var(--fl-ink); border-radius: 10px; font-size: 14px; background: #fff; }
.ot-form-btn { margin-top: 16px; }
.ot-err { color: var(--fl-hot); font-weight: 700; margin: 12px 0 0; }
.ot-form-help { font-size: 9.5px; letter-spacing: 0.06em; color: var(--fl-ink2); margin: 12px 0 0; line-height: 1.5; }
.ot-result { background: #fff; padding: 26px; border-radius: 18px; box-shadow: 6px 6px 0 var(--fl-ink); margin-top: 28px; }
.ot-result-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; flex-wrap: wrap; }
.ot-result-h3 { font-size: clamp(26px, 4vw, 38px); margin: 12px 0 8px; color: var(--fl-ink); }
.ot-result-meta { font-size: 12px; color: var(--fl-ink2); }
.ot-result-meta a { color: var(--fl-purple); font-weight: 700; }
.ot-hr { border: 0; border-top: 2px solid var(--fl-ink); margin: 18px 0; }
.ot-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.ot-micro { font-size: 10px; letter-spacing: 0.1em; color: var(--fl-ink2); margin-bottom: 6px; }
.ot-addr-name { font-size: 14px; font-weight: 700; line-height: 1.4; color: var(--fl-ink); }
.ot-addr-line { font-size: 13px; color: var(--fl-ink2); line-height: 1.5; margin-top: 2px; }
.ot-detail-label { margin-top: 4px; }
.ot-detail-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-bottom: 1.5px solid rgba(14,10,20,0.12); font-size: 14px; font-weight: 600; }
.ot-result-cta { margin-top: 18px; }
.ot-multi { margin-top: 28px; }
.ot-multi-label { font-size: 11px; letter-spacing: 0.1em; color: var(--fl-ink2); margin-bottom: 14px; }
.ot-multi-card { display: block; width: 100%; text-align: left; background: #fff; padding: 18px 20px; border-radius: 14px; box-shadow: 4px 4px 0 var(--fl-ink); margin-bottom: 12px; cursor: pointer; }
.ot-multi-card:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--fl-ink); }
.ot-multi-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.ot-multi-row + .ot-multi-row { margin-top: 8px; }
.ot-multi-num { font-size: 14px; font-weight: 700; }
.ot-multi-date { font-size: 12px; color: var(--fl-ink2); }
.ot-multi-total { font-size: 18px; color: var(--fl-ink); }
.ot-info-sec { padding: 24px 0 88px; }
.ot-info { background: #fff; padding: clamp(24px, 4vw, 34px); border-radius: 18px; box-shadow: 5px 5px 0 var(--fl-ink); margin-bottom: 24px; }
.ot-info-h2 { font-size: clamp(24px, 3.2vw, 34px); margin: 14px 0 22px; color: var(--fl-ink); }
.ot-timeline { list-style: none; padding: 0; margin: 0; }
.ot-tl-item { position: relative; padding-left: 56px; padding-bottom: 26px; }
.ot-tl-item:not(.ot-tl-last)::before { content: ""; position: absolute; left: 16px; top: 34px; bottom: 0; width: 3px; background: var(--fl-ink); }
.ot-tl-dot { position: absolute; left: 0; top: 0; width: 34px; height: 34px; border-radius: 50%; border: 3px solid var(--fl-ink); display: flex; align-items: center; justify-content: center; font-weight: 900; font-size: 14px; color: var(--fl-ink); font-family: var(--fl-font-display); }
.ot-tl-t { font-size: 20px; margin: 2px 0 4px; color: var(--fl-ink); }
.ot-tl-d { font-size: 13.5px; color: var(--fl-ink2); line-height: 1.55; margin: 0; font-weight: 500; }
.ot-steps { margin: 0; padding-left: 22px; }
.ot-steps li { font-size: 14.5px; line-height: 1.6; color: var(--fl-ink2); margin-bottom: 10px; }
.ot-steps a, .ot-faq-a a { color: var(--fl-purple); font-weight: 700; text-decoration: underline; }
.ot-faq details { border: 2px solid var(--fl-ink); border-radius: 12px; box-shadow: 3px 3px 0 var(--fl-ink); margin-bottom: 12px; overflow: hidden; }
.ot-faq summary { cursor: pointer; font-family: var(--fl-font-display); font-weight: 700; font-size: 15.5px; padding: 14px 18px; list-style: none; color: var(--fl-ink); }
.ot-faq summary::-webkit-details-marker { display: none; }
.ot-faq summary::after { content: "+"; float: right; color: var(--fl-purple); font-size: 20px; line-height: 1; }
.ot-faq details[open] summary::after { content: "–"; }
.ot-faq-a { padding: 0 18px 16px; font-size: 14px; line-height: 1.65; color: var(--fl-ink2); }
@media (max-width: 600px) { .ot-form-grid, .ot-grid-2 { grid-template-columns: 1fr; } }

/* ════════════════════════════════════════════════════════════════════════
   Hyper Drop polish for /checkout/ + /my-account/ active states (CLASS-based,
   .fl-scoped so it beats core.css). Markup, Alpine bindings, payment fields,
   and inline form styles are UNTOUCHED — this only color-blocks the chrome
   that already carries stable classes. (§10 oh- bridge handles the cards.)
   ════════════════════════════════════════════════════════════════════════ */
/* checkout progress strip */
.fl .oh-checkout-step.is-active { color: var(--fl-purple) !important; font-weight: 800; }
.fl .oh-checkout-step.is-done .check { color: var(--fl-ink) !important; background: var(--fl-acid); border: 2px solid var(--fl-ink); border-radius: 999px; padding: 0 5px; }
/* checkout big total → display purple */
.fl .oh-checkout-total-num { font-family: var(--fl-font-display) !important; color: var(--fl-purple) !important; }
.fl .oh-checkout-trust { background: var(--fl-cream2) !important; border: 2.5px solid var(--fl-ink) !important; border-radius: 16px !important; box-shadow: 6px 6px 0 var(--fl-ink) !important; }
.fl .oh-checkout-trust .oh-display { color: var(--fl-ink) !important; }
/* checkout inline place-order total */
.fl .oh-checkout-inline-cta-num { font-family: var(--fl-font-display) !important; color: var(--fl-purple) !important; }

/* my-account reward-points cards → solid color blocks (acid / cyan / amber) */
.fl .oh-acct-points-card { border: 2px solid var(--fl-ink) !important; border-radius: 16px !important; box-shadow: 5px 5px 0 var(--fl-ink) !important; }
.fl .oh-acct-points-card.is-balance { background: var(--fl-acid) !important; }
.fl .oh-acct-points-card.is-pending { background: var(--fl-cyan) !important; }
.fl .oh-acct-points-card.is-rate    { background: var(--fl-amber) !important; }
.fl .oh-acct-points-card-number { font-family: var(--fl-font-display) !important; color: var(--fl-ink) !important; }
.fl .oh-acct-points-card-label, .fl .oh-acct-points-card-sub { color: var(--fl-ink) !important; opacity: 0.8; }
/* order status chips → ink-bordered */
.fl .oh-acct-status { border: 2px solid var(--fl-ink) !important; border-radius: 999px !important; font-weight: 700 !important; }

/* ═══════════════════════════════════════════════════════════════════════
   InfoB structured body — native Hyper Drop (replaces oh-info-* bridge skin)
   Used by: /faq/ /product-authentication/ /age-verification/ (infoSections)
   Chunky cards · 2px ink border · 5px ink offset shadow · Bricolage heads.
   ═══════════════════════════════════════════════════════════════════════ */
.ipg-body { display: grid; grid-template-columns: 300px 1fr; gap: 40px; align-items: start; padding-top: 8px; padding-bottom: 72px; }
.ipg-aside { position: sticky; top: 96px; }
.ipg-toc { padding: 22px 22px 24px; border-radius: 18px; }
.ipg-toc-label { font-size: 10.5px; letter-spacing: 0.12em; color: var(--fl-ink2); opacity: 0.7; margin: 0 0 12px; }
.ipg-toc-label-2 { margin-top: 22px; padding-top: 18px; border-top: 2px solid var(--fl-ink); }
.ipg-toc-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 4px; }
.ipg-toc-list a { display: flex; align-items: center; gap: 10px; text-decoration: none; color: var(--fl-ink); padding: 7px 8px; border-radius: 10px; font-weight: 600; font-size: 13.5px; line-height: 1.25; transition: background .12s ease; }
.ipg-toc-list a:hover { background: var(--fl-cream2); }
.ipg-toc-n { flex: none; width: 22px; height: 22px; display: grid; place-items: center; background: var(--fl-acid); color: var(--fl-ink); border: 2px solid var(--fl-ink); border-radius: 7px; font-size: 11px; font-weight: 700; }
.ipg-ext-list { display: flex; flex-direction: column; gap: 10px; }
.ipg-ext { display: block; text-decoration: none; color: var(--fl-ink); background: var(--fl-cream2); border: 2px solid var(--fl-ink); border-radius: 12px; padding: 11px 13px; transition: transform .12s ease, box-shadow .12s ease; }
.ipg-ext:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--fl-ink); }
.ipg-ext-label { font-size: 10px; letter-spacing: 0.08em; color: var(--fl-purple); font-weight: 700; }
.ipg-ext-url { font-size: 12.5px; font-weight: 700; margin: 3px 0 0; }
.ipg-ext-blurb { font-size: 11.5px; line-height: 1.45; opacity: 0.8; margin-top: 4px; }

.ipg-main { display: flex; flex-direction: column; gap: 26px; min-width: 0; }
.ipg-sec { background: #fff; border: 2px solid var(--fl-ink); border-radius: 20px; box-shadow: 5px 5px 0 var(--fl-ink); padding: clamp(24px, 3vw, 38px); scroll-margin-top: 96px; }
.ipg-sec-tint { background: var(--fl-cream2); }
.ipg-sec-eb { display: inline-block; margin-bottom: 14px; }
.ipg-sec-h2 { font-size: clamp(23px, 2.7vw, 33px); line-height: 1.06; letter-spacing: -0.02em; margin: 0 0 16px; color: var(--fl-ink); display: inline-block; border-bottom: 3px solid var(--fl-ink); padding-bottom: 6px; }
.ipg-sec-prose { font-size: 15px; line-height: 1.7; color: var(--fl-ink); font-weight: 450; }
.ipg-sec-prose p { margin: 0 0 14px; }
.ipg-sec-prose p:last-child { margin-bottom: 0; }
.ipg-sec-prose a { color: var(--fl-purple); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
.ipg-sec-prose strong { font-weight: 700; }
.ipg-sec-prose ul, .ipg-sec-prose ol { margin: 0 0 14px; padding-left: 22px; }
.ipg-sec-prose li { margin: 0 0 7px; }
.ipg-sec-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.ipg-chip { background: var(--fl-cream2); border: 2px solid var(--fl-ink); border-radius: 999px; padding: 5px 13px; font-size: 12px; font-weight: 700; color: var(--fl-ink); }

.ipg-callout { background: var(--fl-purple); color: var(--fl-cream); border: 2px solid var(--fl-ink); border-radius: 22px; box-shadow: 8px 8px 0 var(--fl-ink); padding: clamp(26px, 3.4vw, 42px); }
.ipg-callout-eb { display: inline-block; margin-bottom: 14px; }
.ipg-callout-h2 { font-size: clamp(26px, 3.2vw, 40px); line-height: 1.0; letter-spacing: -0.02em; margin: 0 0 14px; color: var(--fl-cream); }
.ipg-callout-body { font-size: 15.5px; line-height: 1.65; margin: 0; color: var(--fl-cream); opacity: 0.95; }
.ipg-callout-chips { margin-top: 20px; }
.ipg-chip-on-purple { background: rgba(255,255,255,0.12); border-color: var(--fl-cream); color: var(--fl-cream); }

.ipg-faq { background: #fff; border: 2px solid var(--fl-ink); border-radius: 20px; box-shadow: 5px 5px 0 var(--fl-ink); padding: clamp(24px, 3vw, 36px); }
.ipg-faq-h2 { font-size: clamp(25px, 3vw, 34px); line-height: 1.05; letter-spacing: -0.02em; margin: 12px 0 20px; color: var(--fl-ink); }
.ipg-faq-list { display: flex; flex-direction: column; gap: 12px; }
.ipg-faq-item { border: 2px solid var(--fl-ink); border-radius: 14px; background: var(--fl-cream2); overflow: hidden; }
.ipg-faq-q { display: flex; justify-content: space-between; align-items: center; gap: 14px; cursor: pointer; list-style: none; padding: 16px 18px; font-family: var(--fl-font-display); font-weight: 700; font-size: 16px; line-height: 1.3; color: var(--fl-ink); }
.ipg-faq-q::-webkit-details-marker { display: none; }
.ipg-faq-mk { flex: none; width: 26px; height: 26px; display: grid; place-items: center; background: var(--fl-acid); border: 2px solid var(--fl-ink); border-radius: 8px; font-family: var(--fl-font-display); font-weight: 700; font-size: 18px; line-height: 1; transition: transform .15s ease; }
.ipg-faq-item[open] .ipg-faq-mk { transform: rotate(45deg); }
.ipg-faq-a { padding: 0 18px 18px; font-size: 14.5px; line-height: 1.65; color: var(--fl-ink); }
.ipg-faq-a a { color: var(--fl-purple); font-weight: 600; }

@media (max-width: 1023px) {
  .ipg-body { grid-template-columns: 1fr; gap: 24px; }
  .ipg-aside { position: static; }
  .ipg-toc { border-radius: 16px; }
}
