/* =============================================================
   home-modules.css
   CD design handoff — Module 1 (Ingredients Deck) + Module 2
   (Comparison Table). Imported by home.html.
   Source: _notes/from-cd/HomepageAssets.html + ComparisonTable.html
   ============================================================= */

/* =============================================================
   MODULE 1 — INGREDIENTS DECK (3 swipable cards)
   ============================================================= */

/* Section wrap */
.ingredients-section{background:#f1efeb;color:var(--fg-l-1);padding:clamp(28px,5vw,48px) 0}

/* Horizontal swipable deck — first card aligned left so more peek shows on RHS */
.deck{
  display:flex;flex-direction:row;flex-wrap:nowrap;gap:14px;
  overflow-x:auto;overscroll-behavior-x:contain;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:0 16px;scroll-padding-left:16px;width:100%;
}
.deck::-webkit-scrollbar{display:none}
.deck > .ingredients-card{flex:0 0 auto;width:min(82vw,500px);scroll-snap-align:start}

/* Parent card chrome — shared by all 3 deck cards AND the comparison card.
   White surface: stages vary in color, foreground cards stay white/black. */
.ingredients-card{
  background:#FFFFFF;border-radius:0;padding:12px;width:100%;max-width:520px;
  position:relative;overflow:hidden;font-family:var(--sans);
  display:flex;flex-direction:column;
}
@media(min-width:540px){.ingredients-card{padding:14px}}

.ic-eyebrow{
  font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;letter-spacing:1.6px;
  text-transform:uppercase;color:#111;margin-bottom:10px;
}

.ic-title{
  font-family:var(--sans);font-weight:800;
  font-size:clamp(20px,4.5vw,28px);letter-spacing:-.6px;line-height:1.05;
  color:#111;max-width:300px;margin:0;
}
.ic-title span{display:block}
.ic-title em{font-style:normal;color:#111}

.ic-stage{margin-top:9px;display:flex;flex-direction:column;gap:6px;flex:1}
@media(min-width:540px){.ic-stage{margin-top:11px;gap:7px}}
.ic-stage .mol-card{flex:1}

/* ----- Molecule cards (Card 1 inner) ----- */
.mol-card{
  border-radius:14px;padding:3px 10px;
  box-shadow:0 1px 0 rgba(17,17,17,.04), 0 8px 18px rgba(17,17,17,.06), 0 2px 5px rgba(17,17,17,.04);
  display:flex;align-items:center;gap:16px;
  transition:transform .35s ease, box-shadow .35s ease;
}
@media(min-width:540px){.mol-card{padding:4px 12px;border-radius:16px;gap:18px}}
.mol-card:hover{
  transform:translateY(-4px) !important;
  box-shadow:0 1px 0 rgba(17,17,17,.04), 0 24px 48px rgba(17,17,17,.14), 0 4px 12px rgba(17,17,17,.06);
  z-index:10;position:relative;
}
.mol-card .swatch{
  flex-shrink:0;width:62px;height:62px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;overflow:visible;color:#111;
}
@media(min-width:540px){.mol-card .swatch{width:70px;height:70px;border-radius:10px}}
.mol-card .swatch img{width:100%;height:100%;object-fit:contain;transform:scale(1);transition:transform .35s ease}
.mol-card:hover .swatch img{transform:scale(1.18)}

.mol-card .meta{min-width:0}
.mol-card .meta .num{
  font-family:var(--mono);font-size:18px;font-weight:400;letter-spacing:-.4px;line-height:1;
  color:rgba(17,17,17,.72);margin-bottom:1px;
}
@media(min-width:540px){.mol-card .meta .num{font-size:21px;margin-bottom:1px}}
.mol-card .meta h3{
  font-family:var(--sans);font-weight:700;font-size:17px;letter-spacing:-.3px;
  color:#111;margin:0 0 1px;line-height:1.1;
}
@media(min-width:540px){.mol-card .meta h3{font-size:19px;letter-spacing:-.4px}}
.mol-card .meta .sub{font-family:var(--mono);font-size:var(--fs-md);letter-spacing:.2px;color:#111;line-height:1.2}
.mol-card .meta .blurb{
  font-family:var(--sans);font-weight:500;font-size:var(--fs-md);letter-spacing:-.1px;
  color:#111;line-height:1.35;margin-top:3px;
}

/* Per-ingredient palette */
.mol-sildenafil{background:#E6EEF8}
.mol-sildenafil .swatch{background:#CCDDF0}
.mol-tadalafil{background:#FAE9D0}
.mol-tadalafil .swatch{background:#F2D5A4}
.mol-apomorphine{background:#E7F1D5}
.mol-apomorphine .swatch{background:#D5E6B1}

/* ----- Pathway cards (Card 2 inner + Card 3) ----- */
.path-card{
  position:relative;border-radius:18px;overflow:hidden;
  box-shadow:0 1px 0 rgba(17,17,17,.04), 0 12px 28px rgba(17,17,17,.08), 0 2px 6px rgba(17,17,17,.04);
  transition:transform .35s ease, box-shadow .35s ease;
}
.path-card:hover{
  transform:translateY(-4px) !important;
  box-shadow:0 1px 0 rgba(17,17,17,.04), 0 24px 48px rgba(17,17,17,.14), 0 4px 12px rgba(17,17,17,.06);
  z-index:10;
}
.path-card .anim{width:100%;aspect-ratio:20/5.5;position:relative;overflow:hidden}
.path-card .body{padding:6px 12px 8px}
@media(min-width:540px){.path-card .body{padding:8px 14px 10px}}
.path-card .num{
  font-family:var(--mono);font-size:18px;font-weight:400;letter-spacing:-.4px;line-height:1;
  color:rgba(17,17,17,.72);margin-bottom:2px;
}
@media(min-width:540px){.path-card .num{font-size:21px;margin-bottom:3px}}
.path-card h3{
  font-family:var(--sans);font-weight:700;font-size:17px;letter-spacing:-.3px;
  color:#111;margin:0 0 1px;line-height:1.1;
}
@media(min-width:540px){.path-card h3{font-size:19px;letter-spacing:-.4px}}
.path-card .sub{font-family:var(--mono);font-size:var(--fs-md);letter-spacing:.2px;color:#111;line-height:1.2;margin-bottom:6px}
.path-card .desc{font-family:var(--sans);font-size:var(--fs-md);line-height:1.4;color:#111;max-width:42ch;margin:0}

/* Card 3 — sublingual tablet card */
.tablet-card .delivery-title{
  font-family:var(--sans);font-weight:800;
  font-size:clamp(20px,4.5vw,28px);letter-spacing:-.6px;line-height:1.05;
  color:#111;margin:0;display:flex;flex-direction:column;
}
.tablet-card .delivery-title span{display:block}
.tablet-card .delivery-mech{
  font-family:var(--mono);font-size:var(--fs-sm);font-weight:400;
  letter-spacing:.2px;color:#111;line-height:1.35;
  margin:8px 0 0;
}

.path-physical{background:#F8E0CD}
.path-physical .anim{background:#F2C9A4}
.path-mental{background:#F4DAD2}
.path-mental .anim{background:#ECC2B6}

/* Lavender variant for Mental synapse card */
.path-mental.is-lavender{background:#E8D8EC}
.path-card.path-mental.is-lavender .anim{background:#D2BAD8}

.path-card.is-white .body{background:#FFFFFF}
.path-card.is-white .num{color:rgba(17,17,17,.72)}

/* Card 3 — tablet card (lifestyle photo + clinical fact) */
.tablet-card{background:#F0EAE0;display:flex;flex-direction:column}
.ic-stage > .tablet-card{flex:1}
.tablet-card .anim{aspect-ratio:16/9;background:#1a1400;display:block;overflow:hidden}
.tablet-card .anim img{width:100%;height:100%;object-fit:cover;object-position:50% 16%;transform:scale(1.05);display:block}
.tablet-card .body{padding:22px 16px 16px;flex:1}
@media(min-width:540px){.tablet-card .body{padding:28px 20px 20px}}
.tablet-card .body h3{font-size:18px;letter-spacing:-.3px;max-width:24ch;line-height:1.15;margin-bottom:6px}
@media(min-width:540px){.tablet-card .body h3{font-size:20px;letter-spacing:-.4px;margin-bottom:8px}}
/* Card 3 delivery list — smaller bullets under the lead claim */
.delivery-list{list-style:none;padding:0;margin:10px 0 0;font-family:var(--sans);font-weight:500;font-size:14px;letter-spacing:-.1px;line-height:1.5;color:#111}
.delivery-list li{padding:0}

/* Synapse animation bg */
.path-card.synapse .anim{background:#F2C9A4}

/* ----- Synapse keyframes (Card 2 Mental) ----- */
.syn-nt{
  animation:syn-fire 2.8s cubic-bezier(.4,.05,.6,.95) infinite;
  opacity:0;transform-box:fill-box;transform-origin:50% 50%;
}
@keyframes syn-fire{
  0%   {transform:translate(0,0) scale(.4);opacity:0}
  8%   {transform:translate(1px,0) scale(.7);opacity:1}
  35%  {transform:translate(12px,0) scale(1.15);opacity:1}
  55%  {transform:translate(22px,0) scale(1);opacity:.6}
  65%  {transform:translate(28px,0) scale(.7);opacity:0}
  100% {transform:translate(28px,0) scale(.7);opacity:0}
}
.syn-nt:nth-of-type(1){animation-delay:0s}
.syn-nt:nth-of-type(2){animation-delay:.18s}
.syn-nt:nth-of-type(3){animation-delay:.36s}
.syn-nt:nth-of-type(4){animation-delay:.54s}
.syn-nt:nth-of-type(5){animation-delay:.72s}

.syn-pre{transform-box:fill-box;transform-origin:95% 50%;animation:syn-prePulse 2.8s ease-in-out infinite}
@keyframes syn-prePulse{
  0%,90%,100%{transform:scale(1)}
  8%        {transform:scale(1.03,.97)}
  20%       {transform:scale(1)}
}
.syn-post{transform-box:fill-box;transform-origin:5% 50%;animation:syn-postReceive 2.8s ease-in-out infinite}
@keyframes syn-postReceive{
  0%,50%,100%{transform:scale(1)}
  65%       {transform:scale(1.03)}
  80%       {transform:scale(1)}
}

/* ----- Blood-flow tube keyframes (Card 2 Physical) ----- */
.bf-seg{
  transform-box:fill-box;transform-origin:50% 50%;
  animation:bf-breathe 3.2s cubic-bezier(.45,.05,.55,.95) infinite;
  will-change:transform;
}
@keyframes bf-breathe{
  0%,100%{transform:scale(1.75)}
  50%    {transform:scale(2.65)}
}

/* =============================================================
   MODULE 2 — COMPARISON TABLE
   ============================================================= */

.cmp-section{background:#f1efeb;color:var(--fg-l-1);padding:clamp(28px,5vw,48px) 0}
/* cmp-wrap uses unified container on all viewports */
.cmp-wrap{
  width:min(1280px, 88vw);
  margin:28px auto 0;
  padding:0;
  display:block;
}

.cmp-card{
  background:#FFFFFF !important;
  border-radius:0;padding:14px 0 14px;
  width:100%;max-width:none;
  font-family:var(--sans);overflow:hidden;
}
.cmp-card .ic-eyebrow,
.cmp-card .ic-title{padding:0 18px}

.cmp-scroll{
  margin-top:14px;overflow-x:auto;overscroll-behavior-x:contain;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;scrollbar-color:rgba(17,17,17,.28) transparent;
  padding-bottom:8px;
}
.cmp-scroll::-webkit-scrollbar{height:8px;-webkit-appearance:none}
.cmp-scroll::-webkit-scrollbar-track{background:rgba(17,17,17,.04);border-radius:3px}
.cmp-scroll::-webkit-scrollbar-thumb{background:rgba(17,17,17,.28);border-radius:3px}
.cmp-scroll::-webkit-scrollbar-thumb:hover{background:rgba(17,17,17,.45)}

/* Table: fluid columns w/ minimum widths.
   - At mobile (card < min), table is min-wide and the cmp-scroll surfaces a scrollbar.
   - At tablet/desktop (card >= min), fr columns expand to fill 100% so the table sits
     edge-to-edge inside the card with no scroll. */
.cmp-table{display:grid;grid-template-columns:110px repeat(5,minmax(96px,1fr));min-width:580px;width:100%;align-items:stretch;padding-left:14px}
.cmp-table > *{box-sizing:border-box}

.cmp-h{
  padding:12px 6px;text-align:center;color:#111;
  border-bottom:1px solid rgba(17,17,17,.2);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
  gap:6px;min-height:64px;
}
.cmp-h .brand{font-family:var(--sans);font-weight:700;font-size:15px;letter-spacing:-.3px;line-height:1;color:#111;white-space:nowrap}
.cmp-h .wordmark{display:block;height:13px;width:auto;fill:#111}
.cmp-h .variant{
  font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;letter-spacing:1.2px;
  text-transform:uppercase;color:#111;line-height:1.1;white-space:nowrap;
}

.cmp-cell{
  padding:14px 6px;text-align:center;
  border-bottom:1px solid rgba(17,17,17,.1);
  font-family:var(--mono);font-size:15px;font-weight:500;color:#111;
  display:flex;align-items:center;justify-content:center;line-height:1.2;
  position:relative;
}
.cmp-cell .dash{color:rgba(17,17,17,.35);font-size:18px}
.cmp-cell .fn{
  position:absolute;top:6px;right:8px;
  font-family:var(--mono);font-size:15px;font-weight:600;color:#111;line-height:1;
}
/* Inline footnote — sits to the right of the checkmark, no offset corner */
.cmp-cell .cmp-yes-fn{position:relative}
.cmp-cell .fn-inline{
  position:absolute;top:-4px;right:-12px;
  font-family:var(--mono);font-size:13px;font-weight:600;color:#111;line-height:1;
}
.cmp-cell .u{
  font-family:var(--mono);font-size:11px;font-weight:400;color:rgba(17,17,17,.72);
  margin-left:1px;letter-spacing:.2px;text-transform:lowercase;
}

.cmp-attr{
  padding:14px 6px 14px 2px;
  border-bottom:1px solid rgba(17,17,17,.1);
  font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:-.2px;
  color:#111;line-height:1.25;display:flex;align-items:center;
}
.cmp-attr .u{font-family:var(--mono);font-weight:400;font-size:var(--fs-sm);color:rgba(17,17,17,.72);margin-left:3px;letter-spacing:.3px;text-transform:lowercase}

/* Helmd column tints (derived from --accent #FBBC04) */
.cmp-h.is-helmd, .cmp-cell.is-helmd{background:rgba(251,188,4,.12)}
.cmp-h.is-helmd-max, .cmp-cell.is-helmd-max{background:rgba(251,188,4,.28)}

/* Mental Arousal row — gold tint ONLY on HELMD Drive + Drive Max cells (others transparent) */
.cmp-cell.is-arousal-row.arousal-d1{background:rgba(251,188,4,.55)}
.cmp-cell.is-arousal-row.arousal-d2{background:rgba(251,188,4,.55)}
.cmp-attr.is-arousal-row{background:transparent}

/* Subtle vertical column lines — flank columns 2, 3, 4, 5 (HELMD Drive, Drive Max, BlueChew, Hims). Ro (col 6) is detached. */
.cmp-table > *:nth-child(6n+2),
.cmp-table > *:nth-child(6n+3),
.cmp-table > *:nth-child(6n+4),
.cmp-table > *:nth-child(6n+5){border-left:1px solid rgba(17,17,17,.08)}
.cmp-table > *:nth-child(6n+5){border-right:1px solid rgba(17,17,17,.08)}

.cmp-table > .cmp-attr.is-last,
.cmp-table > .cmp-cell.is-last{border-bottom:none}

/* Yes / No glyphs */
.cmp-yes, .cmp-no{
  display:inline-flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:50%;
}
.cmp-yes{background:#111;color:#FBBC04}
.cmp-no{background:transparent;border:1.5px solid rgba(17,17,17,.3);color:rgba(17,17,17,.72)}
/* Non-Helmd checks keep the black circle but the check stroke is white (not gold) */
.cmp-cell:not(.is-helmd):not(.is-helmd-max) .cmp-yes{color:#FFFFFF}
.cmp-yes svg, .cmp-no svg{width:14px;height:14px;display:block}
.cmp-yes svg path{stroke-width:2.4}

/* Notes: small fine print under the table. Size set on the <p> itself so
   the base `p{}` rule in colors_and_type.css can't override it. No per-note
   padding — just two tight lines, 12.5px to match the row labels. */
.cmp-foot{padding:12px 18px 2px;font-family:var(--sans);color:#111}
.cmp-foot p{margin:0;padding:0;font-size:12px;font-weight:400;line-height:1.5;color:#111}
.cmp-foot p:last-child{margin-bottom:0}
.cmp-foot .marker{font-family:var(--mono);color:#111;margin-right:2px}

/* Helmd wordmark inline in the 'Helmd vs. the rest' comparison title */
.cmp-title{display:flex;align-items:center}
.cmp-title > span{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cmp-title-mark{height:.7em;width:auto;fill:#111;display:inline-block;vertical-align:middle}
.cmp-title-text{display:inline}

/* =============================================================
   WHY DRIVE — white card on the cream stage
   50/50 split: small product label + chemistry headline | value props
   ============================================================= */
.why-drive-section{background:#f1efeb;padding:clamp(28px,5vw,48px) 0}
.prod-mark{height:.82em;width:auto;fill:currentColor;display:inline-block;vertical-align:-.05em;margin-right:.06em}
/* Small product label sits above the chemistry headline. HELMD wordmark + Drive. */
.prod-mark-sm{height:.95em;width:auto;fill:currentColor;display:inline-block;vertical-align:-.1em;margin-right:.18em}
.prod-label{
  font-family:var(--sans);font-weight:700;font-size:16px;letter-spacing:-.2px;
  color:#111;display:flex;align-items:baseline;
  margin-bottom:18px;
}
.prod-label sup{font-size:.5em;vertical-align:super;font-weight:400;letter-spacing:0}
.why-wrap{padding:0 16px;margin-top:22px}
.why-card{padding:24px}
.why-grid{display:flex;flex-direction:column;gap:28px}
.why-lhs{display:flex;flex-direction:column}
.why-rhs{display:flex;flex-direction:column;justify-content:center}
.why-headline{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(22px,2.9vw,34px);letter-spacing:-.6px;line-height:1.12;
  color:#111;margin:0;
  display:flex;flex-direction:column;gap:2px;
}
.why-headline .brand-strong{
  font-weight:800;letter-spacing:-2px;
  font-size:clamp(36px,8vw,64px);line-height:1.0;
  display:block;margin-bottom:14px;
}
.why-headline .chem-line{display:block;font-weight:600;font-size:clamp(12px,3.3vw,20px)}
/* Keep "Sildenafil + Tadalafil + Apomorphine" on one line at every viewport */
@media(max-width:560px){
  .why-card{padding:18px}
}
.why-card .value-list{margin-bottom:0;display:flex;flex-direction:column;gap:10px;max-width:none}
.why-card .value-list li{display:flex;align-items:flex-start;gap:14px;line-height:1.5}
.ls .value-list .v-text{color:#111}
.ls .value-list .v-text strong{color:#111}
.ls .value-list svg{stroke:var(--accent)}

@media(min-width:768px){
  .why-card{padding:32px}
  .why-card .value-list{gap:18px}
}
@media(min-width:1024px){
  .why-card{padding:48px}
  .why-grid{flex-direction:row;gap:0;align-items:stretch}
  .why-lhs{flex:1;padding-right:48px;border-right:1px solid rgba(17,17,17,.1);justify-content:center}
  .why-rhs{flex:1;padding-left:48px}
}

/* =============================================================
   DRIVE / DRIVE MAX — peek card deck on light bg
   ============================================================= */
.strengths-section{background:#f1efeb;color:#111;padding:clamp(28px,5vw,48px) 0}

/* Strengths deck — no background frame, cards flush to container */
.strengths-deck-wrap{margin-top:8px}

.strengths-deck{
  display:flex;flex-direction:row;flex-wrap:nowrap;gap:12px;
  overflow-x:auto;overscroll-behavior-x:contain;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:0 16px;scroll-padding-left:16px;width:100%;
}
.strengths-deck::-webkit-scrollbar{display:none}

.strength-card{
  flex:0 0 auto;width:min(70vw,380px);scroll-snap-align:start;
  background:#fff;border:1px solid rgba(17,17,17,.06);
  display:flex;flex-direction:column;overflow:hidden;
  border-radius:0;
}

/* Header (eyebrow + title) on TOP of card.
   Padding mirrors .doc-eyebrow-strip / .ingredients-card (16px/20px rhythm). */
.strength-head{
  padding:16px 20px 18px;
  border-bottom:1px solid rgba(17,17,17,.06);
}
.strength-eyebrow{
  font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;letter-spacing:1.6px;
  text-transform:uppercase;color:#111;margin-bottom:10px;
}
.strength-title{
  font-family:var(--sans);font-weight:600;font-size:22px;letter-spacing:-.5px;
  color:#111;margin:0;line-height:1;
}
.strength-title .brand-strong{font-weight:800;letter-spacing:-.6px}

.strength-photo{width:100%;aspect-ratio:4/3;overflow:hidden;background:#1a1400;max-height:300px}
.strength-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 57%;display:block;transition:transform .4s ease}
.strength-card:hover .strength-photo img{transform:scale(1.04)}
/* Drive Max tablet appears bigger — reinforces 'more potency' alongside the saturated color */
.strength-card.is-max .strength-photo img{transform:scale(1.14)}
.strength-card.is-max:hover .strength-photo img{transform:scale(1.18)}

.strength-body{padding:11px 16px 13px;display:flex;flex-direction:column;gap:9px}

.strength-doses{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.strength-doses li{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:3px 0;border-bottom:1px solid rgba(17,17,17,.08);
  font-family:var(--mono);
}
.strength-doses li:last-child{border-bottom:none}
.strength-doses li span{font-size:14.5px;color:#111;letter-spacing:.2px;font-weight:400}
.strength-doses li strong{font-size:18px;font-weight:600;color:#111;letter-spacing:-.2px;display:inline-flex;align-items:baseline;gap:5px}
.strength-doses .u{font-family:var(--mono);font-size:14px;font-weight:400;color:#111;margin-left:1px;letter-spacing:.2px;text-transform:lowercase}
.strength-doses .bump{
  font-family:var(--mono);font-size:12px;font-weight:600;
  color:var(--bg);background:var(--accent);
  padding:4px 7px;border-radius:3px;letter-spacing:.3px;
  line-height:1;margin-right:4px;
}

/* 3 identical fact bullets shared by both cards */
.strength-facts{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.strength-facts li{
  font-family:var(--sans);font-size:var(--fs-body);line-height:var(--lh-body);color:#111;
  padding-left:16px;position:relative;letter-spacing:-.1px;
}
.strength-facts li::before{
  content:"";position:absolute;left:0;top:.55em;
  width:6px;height:6px;border-radius:50%;background:var(--accent);
}

.btn-strength{
  display:block;width:100%;text-align:center;
  background:var(--accent);color:#111;
  font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.2px;
  padding:13px 20px;border-radius:4px;
  transition:filter .15s;margin-top:4px;
}
.btn-strength:hover{filter:brightness(1.08)}

/* === CTA card — all content bottom-justified; title at top of bottom stack, bullets, arrow last === */
.strength-cta-card{
  background:var(--accent);
  border:1px solid var(--accent);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:18px 18px 16px;
  text-decoration:none;color:#111;
  transition:background .2s ease, border-color .2s ease;
}
.strength-cta-card:hover{background:rgba(251,188,4,.45);border-color:rgba(251,188,4,.55)}
.strength-cta-card .cta-text{
  font-family:var(--sans);font-weight:800;
  font-size:clamp(22px,2.8vw,30px);letter-spacing:-.7px;line-height:1.05;
  color:#111;margin:0 0 18px;
}
.strength-cta-card .cta-meta{
  list-style:none;padding:0;margin:0 0 22px;
  display:flex;flex-direction:column;gap:6px;
}
.strength-cta-card .cta-meta li{
  font-family:var(--sans);font-size:var(--fs-body);line-height:var(--lh-body);color:#111;letter-spacing:-.1px;
  padding-left:16px;position:relative;
}
.strength-cta-card .cta-meta li::before{
  content:"";position:absolute;left:0;top:.55em;
  width:6px;height:6px;border-radius:50%;background:#111;
}
.strength-cta-card .cta-arrow{
  font-family:var(--sans);font-size:28px;font-weight:400;color:#111;
  align-self:flex-end;line-height:1;
}
@media(max-width:1023px){
  /* Match the strength cards: proper width + snap target so it's reachable in the scroller.
     Keep the column / bottom-justified layout with the bullets visible. */
  .strength-cta-card{
    flex:0 0 auto;width:min(70vw,380px);scroll-snap-align:start;
    padding:20px 18px 18px;
  }
  .strength-cta-card .cta-text{font-size:24px;margin:0 0 16px}
  .strength-cta-card .cta-meta{margin:0 0 18px}
}

/* =============================================================
   SECTION HEADINGS — for deck-bearing .ls sections
   (.ls has 0 horizontal padding; heading + content set their own 16px)
   ============================================================= */
.sec-head{padding:0 16px 10px;border-bottom:1px solid rgba(17,17,17,.12);margin-bottom:28px}
.sec-head .ds-h{margin-bottom:0}
.sec-head .ds-sub{margin:8px 0 0;max-width:520px;color:#111}
.ds .sec-head{border-bottom-color:rgba(250,250,248,.15)}
/* Mobile: inset the heading underline so it starts where the text starts
   (pseudo-element is a content-box child → respects the 16px padding) */
@media(max-width:767px){
  .sec-head{border-bottom:none;padding-bottom:0}
  .sec-head::after{content:"";display:block;height:1px;background:rgba(17,17,17,.12);margin-top:10px}
  .ds .sec-head::after{background:rgba(250,250,248,.15)}
}

/* =============================================================
   DOCTORS — Medical Advisory Board deck
   ============================================================= */
.docs-deck{
  display:flex;flex-direction:row;flex-wrap:nowrap;gap:12px;
  overflow-x:auto;overscroll-behavior-x:contain;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;padding:0 16px;scroll-padding-left:16px;width:100%;margin-top:22px;
}
.docs-deck::-webkit-scrollbar{display:none}
.doc-card{
  flex:0 0 auto;width:min(70vw,330px);scroll-snap-align:start;
  background:#fff;border:1px solid rgba(17,17,17,.06);
  display:flex;flex-direction:column;overflow:hidden;
}
.doc-photo{width:100%;aspect-ratio:4/3;overflow:hidden;background:#ECE9E2}
.doc-photo img{width:100%;height:100%;object-fit:cover;object-position:center 18%;display:block}
.doc-body{padding:13px 16px 15px;display:flex;flex-direction:column}
.doc-eyebrow{
  font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;letter-spacing:1.6px;
  text-transform:uppercase;color:#111;margin-bottom:8px;
}
.doc-name{font-family:var(--sans);font-weight:800;font-size:19px;letter-spacing:-.4px;color:#111;margin:0;line-height:1.1}
.doc-title{
  font-family:var(--mono);font-size:var(--fs-sm);letter-spacing:.6px;text-transform:uppercase;
  color:#111;margin-top:5px;
}
.doc-bio{font-family:var(--sans);font-size:var(--fs-body);line-height:var(--lh-body);color:#111;margin:11px 0 0}
.doc-cta{
  font-family:var(--sans);font-size:var(--fs-body);font-weight:700;color:#111;
  margin-top:14px;align-self:flex-start;
  display:inline-flex;align-items:center;gap:6px;
  border-bottom:2px solid var(--accent);padding-bottom:2px;
  transition:gap .15s ease;
}
.doc-cta:hover{gap:10px}

/* Credibility points — white card */
.cred-wrap{padding:0 16px;display:flex;justify-content:flex-start;margin-top:20px}
.cred-card .cred-item:first-child{border-top:none}
.cred-card .cred-item:last-child{border-bottom:none}
.cred-card .cred-item p{color:#111}

/* === CREDIBILITY 3-card deck — value props + 2 doctors === */
.cred-deck{margin-top:22px}
.cred-points-card{padding:0;background:#fff;display:flex;flex-direction:column}
.cred-points-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
@media(min-width:540px){.cred-points-body{padding:18px 22px 22px}}
.cred-points-card .cred-intro{font-family:var(--sans);font-size:var(--fs-md);line-height:1.45;color:#111;margin:0;padding:2px 0 14px}
.cred-points-card .cred-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.cred-points-card .cred-item{padding:12px 0;border-top:1px solid rgba(17,17,17,.08)}
.cred-points-card .cred-item h4{font-family:var(--sans);font-weight:600;font-size:var(--fs-md);letter-spacing:-.1px;color:#111;margin:0 0 2px;line-height:var(--lh-tight)}
.cred-points-card .cred-item p{font-family:var(--sans);font-size:var(--fs-md);line-height:1.45;color:#111;margin:0}
.cred-points-card .cred-cta{
  font-family:var(--sans);font-size:var(--fs-body);font-weight:700;color:#111;
  margin-top:auto;padding-top:22px;
  align-self:flex-start;display:inline-flex;align-items:center;gap:6px;
  border-bottom:2px solid var(--accent);padding-bottom:2px;transition:gap .15s ease;
}
.cred-points-card .cred-cta:hover{gap:10px}

/* Eyebrow strip shared by cred Card 1 + doctor cards — same height, same border */
.doc-eyebrow-strip{padding:16px 20px;background:#fff;border-bottom:1px solid rgba(17,17,17,.08)}
.doc-eyebrow-strip .ic-eyebrow{margin-bottom:0}
/* Doctor cards in the new deck */
.doc-card-v2{padding:0;background:#fff;display:flex;flex-direction:column;overflow:hidden}
.doc-card-v2 .doc-photo{width:100%;aspect-ratio:16/9;overflow:hidden;background:#ECE9E2}
.doc-card-v2 .doc-photo img{width:100%;height:100%;object-fit:cover;object-position:center 28%;display:block}
.doc-card-v2 .doc-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.doc-card-v2 .doc-name{font-family:var(--sans);font-weight:800;font-size:1.125rem;letter-spacing:-.4px;color:#111;margin:0;line-height:1.15}
.doc-card-v2 .doc-title{font-family:var(--mono);font-size:var(--fs-sm);letter-spacing:.6px;text-transform:uppercase;color:#111;margin-top:6px;line-height:1.5}
.doc-card-v2 .doc-bio{font-family:var(--sans);font-size:var(--fs-md);line-height:1.45;color:#111;margin:12px 0 0}
.doc-card-v2 .doc-cta{
  font-family:var(--sans);font-size:var(--fs-body);font-weight:700;color:#111;
  margin-top:auto;padding-top:18px;
  align-self:flex-start;display:inline-flex;align-items:center;gap:6px;
  border-bottom:2px solid var(--accent);padding-bottom:2px;transition:gap .15s ease;
}
.doc-card-v2 .doc-cta:hover{gap:10px}

/* =============================================================
   HOW IT WORKS — streamlined vertical timeline
   ============================================================= */
.hiw-wrap{padding:0 16px;display:flex;justify-content:flex-start;margin-top:22px}
.hiw-card{padding:clamp(24px,6vw,32px) 16px}
.timeline{list-style:none;margin:0;padding:0}
.tl-step{
  position:relative;padding:0 0 20px 24px;
  border-left:2px solid rgba(17,17,17,.13);
}
.tl-step:last-child{padding-bottom:2px}
/* Dot box: width 12 + 3px border each side = 18px render box. Line (border-left) at x=0 width:2 → center x=1.
   To center dot on line, place dot at left:-8 → render -8 to 10, center x=1. */
.tl-step::before{
  content:"";position:absolute;left:-8px;top:0;
  width:12px;height:12px;border-radius:50%;
  background:var(--accent);border:3px solid #fff;
  box-shadow:0 0 0 1px rgba(17,17,17,.13);
  transition:transform .18s ease;
}
.tl-step:hover::before{transform:scale(1.3)}
/* "Today" dot — larger + pulsing (where the user is in the process) */
.tl-step:first-child::before{width:16px;height:16px;left:-10px;animation:tl-pulse 2.2s ease-out infinite}
@keyframes tl-pulse{
  0%{box-shadow:0 0 0 1px rgba(17,17,17,.13),0 0 0 0 rgba(251,188,4,.45)}
  70%{box-shadow:0 0 0 1px rgba(17,17,17,.13),0 0 0 13px rgba(251,188,4,0)}
  100%{box-shadow:0 0 0 1px rgba(17,17,17,.13),0 0 0 0 rgba(251,188,4,0)}
}
.tl-eyebrow{
  font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;letter-spacing:1.6px;
  text-transform:uppercase;color:#111;margin-bottom:4px;
}
.tl-text{
  font-family:var(--sans);font-size:var(--fs-body);font-weight:600;line-height:var(--lh-body);
  color:#111;letter-spacing:-.2px;
}
.tl-meta{font-family:var(--mono);font-weight:400;font-size:var(--fs-sm);color:#111}

/* =============================================================
   HOW TO TAKE DRIVE — 3-step usage card deck
   ============================================================= */
.usage-deck{
  display:flex;flex-direction:row;flex-wrap:nowrap;gap:12px;
  overflow-x:auto;overscroll-behavior-x:contain;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;padding:0 16px;scroll-padding-left:16px;width:100%;margin-top:22px;
}
.usage-deck::-webkit-scrollbar{display:none}
.usage-card{
  flex:0 0 auto;width:min(72vw,340px);scroll-snap-align:start;
  background:#fff;border:1px solid rgba(17,17,17,.06);
  display:flex;flex-direction:column;overflow:hidden;
}
.usage-photo{width:100%;aspect-ratio:4/3;overflow:hidden;background:#ECE9E2;border-bottom:1px solid rgba(17,17,17,.08)}
.usage-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 32%;display:block}
.usage-photo.is-placeholder{display:flex;align-items:center;justify-content:center}
.usage-photo.is-placeholder span{
  font-family:var(--mono);font-size:var(--fs-sm);font-weight:500;letter-spacing:1.4px;
  text-transform:uppercase;color:rgba(17,17,17,.72);
}
/* Card 03: real tablet-dissolving image on black, with a subtle bounce.
   Effervescent bubbles are baked into the image; black bg keeps the bounce seamless. */
.usage-photo-dissolve{background:#000}
.usage-photo-dissolve img{
  object-fit:contain;
  object-position:center;
  animation:dz-bounce 3.6s ease-in-out infinite;
}
@keyframes dz-bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@media (prefers-reduced-motion:reduce){
  .usage-photo-dissolve img{animation:none}
}
.usage-body{padding:15px 18px 18px;display:flex;flex-direction:column;gap:9px}
.usage-num{font-family:var(--mono);font-size:1.125rem;font-weight:400;letter-spacing:-.4px;color:rgba(17,17,17,.72);line-height:1}
.usage-text{font-family:var(--sans);font-size:var(--fs-body);font-weight:700;line-height:var(--lh-tight);color:#111;letter-spacing:-.2px}
.usage-sub{font-family:var(--sans);font-size:var(--fs-body);line-height:var(--lh-body);color:#111;margin:6px 0 0}
/* Card 01: mini-timeline sized to match photo cards 02-04 (same aspect-ratio + overflow guard) */
.usage-card-timeline{display:flex;flex-direction:column;container-type:inline-size}
/* Card 01 timeline. The area is a query container; all timeline metrics scale in
   cqw (% of card width). Because the 4/3 box height also scales with width, the
   content keeps a constant ratio to the box and fits at every viewport — no clipping,
   while the photo cards stay 4/3. */
.usage-timeline-area{
  background:#fff;
  aspect-ratio:4/3;
  display:flex;align-items:center;justify-content:flex-start;
  border-bottom:1px solid rgba(17,17,17,.08);
  box-sizing:border-box;
  overflow:hidden;
  padding:5cqw 6cqw;
}
.timeline-mini{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;width:100%;gap:4cqw;
  position:relative;
}
.tl-mini-step{
  position:relative;padding:0 0 0 11cqw;
}
/* Dot box = 4.6cqw + 2×1.1cqw border = 6.8cqw; eyebrow line-height matches → centers align. */
.tl-mini-step::before{
  content:"";position:absolute;left:0;top:0;
  width:4.6cqw;height:4.6cqw;border-radius:50%;
  background:var(--accent);border:1.1cqw solid #fff;
  box-shadow:0 0 0 .4cqw rgba(17,17,17,.18);
  z-index:1;
}
/* Connector: from this dot's center (top 3.4cqw) to the next dot's center. */
.tl-mini-step:not(:last-child)::after{
  content:"";position:absolute;left:3cqw;top:3.4cqw;
  width:.8cqw;height:calc(100% + 4cqw);
  background:rgba(17,17,17,.18);
}
.tl-mini-step.tl-mini-first::before{animation:tl-pulse 2.2s ease-out infinite}
.tl-mini-eyebrow{font-family:var(--mono);font-size:4.2cqw;font-weight:500;letter-spacing:.35cqw;text-transform:uppercase;color:#111;line-height:6.8cqw;margin-bottom:.4cqw}
.tl-mini-text{font-family:var(--sans);font-size:4.7cqw;font-weight:400;line-height:1.2;color:#111;letter-spacing:-.2px}
.tl-mini-meta{font-family:var(--mono);font-weight:400;font-size:4.2cqw;color:#111}
