/** Shopify CDN: Minification failed

Line 60:50 Expected identifier but found "!"
Line 62:49 Expected identifier but found "!"
Line 1600:2 Unexpected "}"
Line 2808:0 All "@import" rules must come first

**/
/** Shopify CDN: Minification failed

Line 54:50 Expected identifier but found "!"
Line 56:49 Expected identifier but found "!"
Line 2798:0 All "@import" rules must come first

**/
/** Shopify CDN: Minification failed

Line 47:50 Expected identifier but found "!"
Line 49:49 Expected identifier but found "!"
Line 2763:0 All "@import" rules must come first


html, body { max-width: 100%; overflow-x: hidden; }

/* henvii-custom.css */
/* Consolidated section styles — do not edit individual section <style> blocks */


/* ── section-bundle-cards_1__1_ (.bc-wrap) ── */


/* ── section-clinical-proof__1_ (.cp-section) ── */
.cp-section * { box-sizing: border-box; }

  .cp-section {
    background: var(--rose-deep);
    padding: 80px 60px;
    border-bottom: 1px solid rgba(255,255,255,.08);
  }

  /* ── HEADER ── */
  .cp-section .cp-top {
    text-align: center; max-width: 580px; margin: 0 auto 56px;
  }
  .cp-section .cp-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mauve); margin-bottom: 14px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
  }
  .cp-section .cp-eyebrow::before,
  .cp-section .cp-eyebrow::after {
    content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve);
  }
  .cp-section .cp-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(28px, 3vw, 38px); font-weight: 400; font-style: italic;
    line-height: 1.2; color: #fff; margin-bottom: 14px;
  }
  .cp-section p.cp-subhead {
    font-size: 14px; color: rgba(255,255,255,.7); !important; line-height: 1.75; font-weight: 300;
  }
  .cp-section p.cp-subhead strong { color: #fff; !important; font-weight: 500; }

  /* ── STAT CARDS ── */
  .cp-section .cp-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 12px;
  }
  .cp-section .cp-stat-card {
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 16px;
    padding: 24px 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .cp-section .cp-stat-num {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 48px; font-weight: 400; color: #fff; line-height: 1;
  }
  .cp-section .cp-stat-num span { font-size: 24px; }
  .cp-section .cp-stat-label {
    font-size: 12px; color: rgba(255,255,255,.85); line-height: 1.55; font-weight: 400; flex: 1;
  }
  .cp-section .cp-stat-source {
    font-size: 10px; color: var(--mauve); letter-spacing: .05em;
    margin-top: auto; padding-top: 10px;
    border-top: 1px solid rgba(255,255,255,.1);
  }

  /* ── STUDY CARDS ── */
  .cp-section .cp-studies-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 12px;
  }
  .cp-section .cp-study-card {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 16px;
    padding: 24px 26px;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  .cp-section .cp-study-label {
    font-size: 10px; font-weight: 500; letter-spacing: .12em; text-transform: uppercase;
    color: var(--mauve); display: flex; align-items: center; gap: 8px;
  }
  .cp-section .cp-study-label::before {
    content: ''; display: inline-block; width: 16px; height: 1px; background: var(--mauve); flex-shrink: 0;
  }
  .cp-section .cp-study-title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 20px; font-weight: 400; font-style: italic;
    color: #fff; line-height: 1.3;
  }
  .cp-section .cp-study-body {
    font-size: 13px; color: rgba(255,255,255,.7); line-height: 1.7; font-weight: 300; flex: 1;
  }
  .cp-section .cp-study-body strong { color: #fff; font-weight: 500; }
  .cp-section .cp-study-citation {
    font-size: 11px; color: var(--mauve); letter-spacing: .03em;
    padding-top: 12px; border-top: 1px solid rgba(255,255,255,.1);
  }

  /* ── OT ENDORSEMENT ── */
  .cp-section .cp-ot-box {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 16px;
    padding: 28px 32px;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 20px;
    align-items: start;
  }
  .cp-section .cp-ot-icon {
    width: 48px; height: 48px; border-radius: 50%;
    background: rgba(255,255,255,.1);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  }
  .cp-section .cp-ot-icon svg {
    width: 22px; height: 22px; stroke: var(--mauve);
  }
  .cp-section .cp-ot-label {
    font-size: 10px; font-weight: 500; letter-spacing: .12em; text-transform: uppercase;
    color: var(--mauve); margin-bottom: 8px;
  }
  .cp-section .cp-ot-text {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 20px; font-weight: 300; font-style: italic;
    color: rgba(255,255,255,.9); line-height: 1.55;
  }
  .cp-section .cp-ot-text strong {
    font-style: normal; font-weight: 500; color: #fff;
  }

  /* ── MOBILE ── */
  @media (max-width: 768px) {
    .cp-section { padding: 48px 20px; }
    .cp-section .cp-stat-grid { grid-template-columns: 1fr 1fr; }
    .cp-section .cp-studies-grid { grid-template-columns: 1fr; }
    .cp-section .cp-ot-box { grid-template-columns: 1fr; }
  }

/* ── section-cost-comparison__1_ (.cc-section) ── */
.cc-section * { box-sizing: border-box; }

  .cc-section {
    background: var(--ivory);
    padding: 80px 60px;
    border-bottom: 1px solid var(--border-soft);
  }

  /* ── HEADER ── */
  .cc-section .cc-top {
    text-align: center; max-width: 560px; margin: 0 auto 56px;
  }
  .cc-section .cc-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 14px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
  }
  .cc-section .cc-eyebrow::before,
  .cc-section .cc-eyebrow::after {
    content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve);
  }
  .cc-section .cc-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(28px, 3vw, 38px); font-weight: 400; font-style: italic;
    line-height: 1.2; color: var(--rose-deep); margin-bottom: 14px;
  }
  .cc-section .cc-subhead {
    font-size: 14px; color: var(--text-mid); line-height: 1.75; font-weight: 300;
  }
  .cc-section .cc-subhead strong { color: var(--rose-deep); font-weight: 500; }

  /* ── CALLOUT NUMBERS ── */
  .cc-section .cc-callouts {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 48px;
  }
  .cc-section .cc-callout {
    background: #fff; border: 1px solid var(--border); border-radius: 16px;
    padding: 24px 20px; text-align: center;
    display: flex; flex-direction: column; gap: 6px; align-items: center;
  }
  .cc-section .cc-callout-num {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 52px; font-weight: 400; color: var(--rose-deep); line-height: 1;
  }
  .cc-section .cc-callout-num span { font-size: 26px; }
  .cc-section .cc-callout-label {
    font-size: 12px; color: var(--text-mid); line-height: 1.5; font-weight: 300;
  }
  .cc-section .cc-callout-label strong {
    color: var(--rose-deep); font-weight: 500;
  }

  /* ── MAIN GRID ── */
  .cc-section .cc-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  }

  /* ── COST TABLE ── */
  .cc-section .cc-table {
    background: #fff; border: 1px solid var(--border); border-radius: 16px; overflow: hidden;
  }
  .cc-section .cc-table-header {
    padding: 14px 20px; background: var(--blush-light);
    border-bottom: 1px solid var(--border);
    font-size: 11px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
    color: var(--mauve-mid);
    display: flex; align-items: center; justify-content: space-between;
  }
  .cc-section .cc-usd-note {
    font-size: 10px; font-weight: 400; letter-spacing: .04em; text-transform: none;
    color: var(--text-light); font-style: italic;
  }
  .cc-section .cc-row {
    padding: 16px 20px; border-bottom: 1px solid var(--border-soft);
    display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
  }
  .cc-section .cc-row:last-child { border-bottom: none; }
  .cc-section .cc-row-name {
    font-size: 13px; font-weight: 500; color: var(--text-main); margin-bottom: 2px;
  }
  .cc-section .cc-row-sub {
    font-size: 11px; color: var(--text-light); line-height: 1.4;
  }
  .cc-section .cc-row-right { text-align: right; flex-shrink: 0; }
  .cc-section .cc-row-amount {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 18px; font-weight: 400; color: var(--text-main); line-height: 1;
  }
  .cc-section .cc-row-period {
    font-size: 10px; color: var(--text-light); letter-spacing: .06em;
    text-transform: uppercase; margin-top: 2px;
  }

  /* ── OUR DEVICE ROW ── */
  .cc-section .cc-row-ours {
    background: var(--blush-light);
    padding: 18px 20px; border-top: 1px solid var(--border);
    display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
  }
  .cc-section .cc-row-ours .cc-row-name { color: var(--rose-deep); }
  .cc-section .cc-ours-label {
    font-size: 10px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 4px;
  }
  .cc-section .cc-ours-price {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 28px; font-weight: 400; color: var(--rose-deep); line-height: 1;
  }
  .cc-section .cc-ours-period {
    font-size: 10px; color: var(--mauve-mid); letter-spacing: .06em;
    text-transform: uppercase; margin-top: 3px; font-weight: 500;
  }

  /* ── RIGHT PANEL ── */
  .cc-section .cc-right { display: flex; flex-direction: column; gap: 12px; }

  .cc-section .cc-math-card {
    background: var(--rose-deep); border-radius: 16px; padding: 28px 28px;
    display: flex; flex-direction: column; gap: 14px;
  }
  .cc-section .cc-math-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase;
    color: var(--mauve); display: flex; align-items: center; gap: 8px;
  }
  .cc-section .cc-math-eyebrow::before {
    content: ''; display: inline-block; width: 16px; height: 1px; background: var(--mauve); flex-shrink: 0;
  }
  .cc-section .cc-math-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 26px; font-weight: 400; font-style: italic; color: #fff; line-height: 1.25;
  }
  .cc-section .cc-math-body {
    font-size: 13px; color: rgba(255,255,255,.75); line-height: 1.8; font-weight: 300;
  }
  .cc-section .cc-math-body strong { color: #fff; font-weight: 500; }
  .cc-section .cc-math-cta {
    display: block; width: 100%; background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.3); border-radius: 50px;
    padding: 13px 20px; font-size: 12px; font-weight: 500; letter-spacing: .1em;
    text-transform: uppercase; color: #fff; text-align: center; text-decoration: none;
    margin-top: 4px; cursor: pointer; font-family: inherit;
    transition: background .2s;
  }
  .cc-section .cc-math-cta:hover { background: rgba(255,255,255,.25); }
  .cc-section .cc-math-cta[data-busy] { opacity: .6; cursor: not-allowed; }

  .cc-section .cc-fsa-card {
    background: var(--blush-light); border: 1px solid var(--border); border-radius: 16px;
    padding: 22px 24px; display: flex; align-items: flex-start; gap: 14px;
  }
  .cc-section .cc-fsa-icon {
    width: 36px; height: 36px; border-radius: 50%; background: var(--blush);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  }
  .cc-section .cc-fsa-icon svg { width: 16px; height: 16px; stroke: var(--rose-deep); }
  .cc-section .cc-fsa-label {
    font-size: 10px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 5px;
  }
  .cc-section .cc-fsa-text {
    font-size: 13px; color: var(--text-mid); line-height: 1.65; font-weight: 300;
  }
  .cc-section .cc-fsa-text strong { color: var(--rose-deep); font-weight: 500; }

  .cc-section .cc-guarantee-card {
    background: #fff; border: 1px solid var(--border); border-radius: 16px;
    padding: 18px 22px; display: flex; align-items: center; gap: 14px;
  }
  .cc-section .cc-guarantee-icon {
    width: 36px; height: 36px; border-radius: 50%; background: var(--blush-light);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  }
  .cc-section .cc-guarantee-icon svg { width: 16px; height: 16px; stroke: var(--rose); }
  .cc-section .cc-guarantee-text {
    font-size: 12px; color: var(--text-mid); line-height: 1.5;
  }
  .cc-section .cc-guarantee-text strong { color: var(--rose-deep); font-weight: 600; }

  /* ── MOBILE ── */
  @media (max-width: 768px) {
    .cc-section { padding: 48px 20px; }
    .cc-section .cc-callouts { grid-template-columns: 1fr 1fr; }
    .cc-section .cc-callouts .cc-callout:last-child { grid-column: span 2; }
    .cc-section .cc-grid { grid-template-columns: 1fr; }
  }

/* ── section-discount-bar (.ab-wrap) ── */


/* ── section-faq__1_ (.faq-section) ── */
.faq-section * { box-sizing: border-box; }

  .faq-section {
    background: var(--ivory);
    padding: 80px 60px;
    border-bottom: 1px solid var(--border-soft);
  }

  /* ── HEADER ── */
  .faq-section .faq-top {
    text-align: center; max-width: 520px; margin: 0 auto 48px;
  }
  .faq-section .faq-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 14px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
  }
  .faq-section .faq-eyebrow::before,
  .faq-section .faq-eyebrow::after {
    content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve);
  }
  .faq-section .faq-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(26px, 3vw, 36px); font-weight: 400; font-style: italic;
    line-height: 1.2; color: var(--rose-deep);
  }

  /* ── FILTER TABS ── */
  .faq-section .faq-tabs {
    display: flex; gap: 6px; flex-wrap: wrap; justify-content: center; margin-bottom: 40px;
  }
  .faq-section .faq-tab {
    font-size: 11px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase;
    padding: 7px 16px; border-radius: 50px; cursor: pointer;
    border: 1px solid var(--border); background: #fff; color: var(--text-mid);
    transition: background .15s, color .15s, border-color .15s;
    font-family: inherit;
  }
  .faq-section .faq-tab:hover {
    border-color: var(--mauve);
  }
  .faq-section .faq-tab.is-active {
    background: var(--rose-deep); color: #fff; border-color: var(--rose-deep);
  }

  /* ── FAQ GRID ── */
  .faq-section .faq-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .faq-section .faq-item {
    background: #fff; border: 1px solid var(--border); border-radius: 14px;
    overflow: hidden; cursor: pointer; transition: border-color .15s;
  }
  .faq-section .faq-item:hover { border-color: var(--mauve); }
  .faq-section .faq-item.is-open { border-color: var(--rose-deep); }
  .faq-section .faq-item[hidden] { display: none; }

  .faq-section .faq-q {
    padding: 18px 20px;
    display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
    user-select: none;
  }
  .faq-section .faq-q-text {
    font-size: 13px; font-weight: 500; color: var(--text-main); line-height: 1.4;
  }
  .faq-section .faq-icon {
    width: 20px; height: 20px; border-radius: 50%; background: var(--blush-light);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px;
    transition: transform .2s, background .2s;
  }
  .faq-section .faq-item.is-open .faq-icon {
    background: var(--rose-deep); transform: rotate(45deg);
  }
  .faq-section .faq-icon svg {
    width: 10px; height: 10px; stroke: var(--mauve-mid); stroke-width: 2;
    fill: none; stroke-linecap: round;
  }
  .faq-section .faq-item.is-open .faq-icon svg { stroke: #fff; }

  .faq-section .faq-a {
    padding: 0 20px; max-height: 0; overflow: hidden;
    transition: max-height .3s ease, padding .3s;
  }
  .faq-section .faq-item.is-open .faq-a {
    max-height: 400px; padding: 0 20px 18px;
  }
  .faq-section .faq-a-inner {
    font-size: 13px; color: var(--text-mid); line-height: 1.75; font-weight: 300;
    border-top: 1px solid var(--border-soft); padding-top: 14px;
  }
  .faq-section .faq-a-inner strong {
    color: var(--rose-deep); font-weight: 500;
  }

  /* ── MOBILE ── */
  @media (max-width: 768px) {
    .faq-section { padding: 48px 20px; }
    .faq-section .faq-grid { grid-template-columns: 1fr; }
  }

/* ── section-founder-story__1_ (.fs-section) ── */
.fs-section * { box-sizing: border-box; }

  .fs-section {
    background: var(--blush-light);
    padding: 80px 60px;
    border-top: 1px solid var(--border-soft);
    border-bottom: 1px solid var(--border-soft);
  }

  .fs-section .fs-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 72px;
    align-items: center;
    max-width: 1100px;
    margin: 0 auto;
  }

  /* ── LEFT — photo ── */
  .fs-section .fs-photo-col {
    display: flex;
    flex-direction: column;
    gap: 20px;
  }

  .fs-section .fs-photo-frame {
    width: 100%;
    aspect-ratio: 3 / 4;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid var(--border);
    background: var(--blush);
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .fs-section .fs-photo-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .fs-section .fs-photo-placeholder svg {
    width: 40px;
    height: 40px;
    stroke: var(--mauve);
  }

  .fs-section .fs-sig {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 20px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 14px;
  }
  .fs-section .fs-sig-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--blush);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 18px;
    font-style: italic;
    color: var(--rose-deep);
    font-weight: 500;
    flex-shrink: 0;
  }
  .fs-section .fs-sig-name {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 22px;
    font-style: italic;
    font-weight: 400;
    color: var(--rose-deep);
    line-height: 1;
  }
  .fs-section .fs-sig-title {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--mauve-mid);
    margin-top: 3px;
  }
  .fs-section .fs-sig-company {
    font-size: 10px;
    font-weight: 400;
    letter-spacing: .06em;
    color: var(--mauve-mid);
    margin-top: 2px;
    opacity: .75;
  }

  /* ── RIGHT — story ── */
  .fs-section .fs-eyebrow {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--mauve-mid);
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .fs-section .fs-eyebrow::before {
    content: '';
    display: inline-block;
    width: 24px;
    height: 1px;
    background: var(--mauve);
    flex-shrink: 0;
  }

  .fs-section .fs-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(28px, 3vw, 38px);
    font-weight: 400;
    font-style: italic;
    line-height: 1.15;
    color: var(--rose-deep);
    margin-bottom: 28px;
  }

  .fs-section .fs-body {
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  .fs-section .fs-para {
    font-size: 14px;
    color: var(--text-mid);
    line-height: 1.85;
    font-weight: 300;
  }
  .fs-section .fs-para strong {
    color: var(--rose-deep);
    font-weight: 500;
  }

  .fs-section .fs-pull-quote {
    border-left: 2px solid var(--mauve);
    padding: 12px 20px;
    border-radius: 0;
  }
  .fs-section .fs-pull-quote p {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 20px;
    font-style: italic;
    font-weight: 300;
    color: var(--rose-deep);
    line-height: 1.5;
  }

  .fs-section .fs-still-uses {
    display: flex;
    align-items: center;
    gap: 12px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 50px;
    padding: 10px 18px;
    margin-top: 8px;
    width: fit-content;
  }
  .fs-section .fs-live-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #639922;
    flex-shrink: 0;
  }
  .fs-section .fs-still-uses-text {
    font-size: 12px;
    color: var(--text-mid);
  }
  .fs-section .fs-still-uses-text strong {
    color: var(--rose-deep);
    font-weight: 600;
  }

  /* ── MOBILE ── */
  @media (max-width: 768px) {
    .fs-section { padding: 48px 20px; }
    .fs-section .fs-inner {
      grid-template-columns: 1fr;
      gap: 36px;
    }
    .fs-section .fs-photo-frame { aspect-ratio: 4 / 3; }
  }

/* ── section-gift-buyer_1__1_ (.gb-section) ── */
.gb-section * { box-sizing: border-box; }

  .gb-section {
    background: var(--blush-light);
    padding: 80px 60px;
    border-bottom: 1px solid var(--border-soft);
  }

  /* ── HEADER ── */
  .gb-section .gb-top { text-align: center; max-width: 560px; margin: 0 auto 56px; }
  .gb-section .gb-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 14px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
  }
  .gb-section .gb-eyebrow::before,
  .gb-section .gb-eyebrow::after { content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve); }
  .gb-section .gb-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(28px, 3vw, 38px); font-weight: 400; font-style: italic;
    line-height: 1.2; color: var(--rose-deep); margin-bottom: 14px;
  }
  .gb-section .gb-subhead { font-size: 14px; color: var(--text-mid); line-height: 1.75; font-weight: 300; }
  .gb-section .gb-subhead strong { color: var(--rose-deep); font-weight: 500; }

  /* ── PERSONA CARDS ── */
  .gb-section .gb-personas { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 48px; }
  .gb-section .gb-persona-card { background: #fff; border: 1px solid var(--border); border-radius: 16px; padding: 24px 22px; display: flex; flex-direction: column; gap: 12px; }
  .gb-section .gb-persona-icon { width: 40px; height: 40px; border-radius: 50%; background: var(--blush); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .gb-section .gb-persona-icon svg { width: 18px; height: 18px; stroke: var(--rose); }
  .gb-section .gb-occasions { display: flex; flex-wrap: wrap; gap: 4px; }
  .gb-section .gb-occasion-tag { background: var(--blush-light); border-radius: 50px; padding: 2px 8px; font-size: 10px; color: var(--mauve-mid); font-weight: 500; letter-spacing: .04em; }
  .gb-section .gb-persona-title { font-family: 'Cormorant Garamond', Georgia, serif; font-size: 20px; font-weight: 400; color: var(--rose-deep); line-height: 1.2; }
  .gb-section .gb-persona-moment { font-size: 13px; color: var(--text-mid); line-height: 1.7; font-weight: 300; flex: 1; border-left: 2px solid var(--border-soft); padding-left: 12px; font-style: italic; }
  .gb-section .gb-persona-review { font-size: 12px; color: var(--text-mid); line-height: 1.6; background: var(--blush-light); border-radius: 10px; padding: 10px 12px; }
  .gb-section .gb-persona-review strong { color: var(--rose-deep); font-weight: 500; }
  .gb-section .gb-persona-reviewer { font-size: 10px; color: var(--text-light); margin-top: 4px; letter-spacing: .03em; }

  /* ── FEARS GRID ── */
  .gb-section .gb-fears { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 48px; }
  .gb-section .gb-fear-card { background: #fff; border: 1px solid var(--border); border-radius: 16px; padding: 22px; display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: start; }
  .gb-section .gb-fear-icon { width: 32px; height: 32px; border-radius: 50%; background: var(--blush-light); display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
  .gb-section .gb-fear-icon svg { width: 14px; height: 14px; stroke: var(--mauve-mid); }
  .gb-section .gb-fear-label { font-size: 11px; font-weight: 600; color: var(--text-main); margin-bottom: 4px; }
  .gb-section .gb-fear-answer { font-size: 12px; color: var(--text-mid); line-height: 1.65; font-weight: 300; }
  .gb-section .gb-fear-answer strong { color: var(--rose-deep); font-weight: 500; }

  /* ── GIFT CTA ── */
  .gb-section .gb-cta { background: var(--rose-deep); border-radius: 20px; overflow: hidden; display: grid; grid-template-columns: 1fr 1.1fr 1fr; }

  /* Image / video slot */
  .gb-section .gb-cta-media { position: relative; min-height: 380px; background: rgba(255,255,255,.07); display: flex; align-items: center; justify-content: center; overflow: hidden; }
  .gb-section .gb-cta-media img.gb-media-img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
  .gb-section .gb-cta-media video { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
  .gb-section .gb-media-placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 32px; text-align: center; }
  .gb-section .gb-media-placeholder svg { width: 40px; height: 40px; stroke: rgba(255,255,255,.25); }
  .gb-section .gb-media-placeholder span { font-size: 10px; color: rgba(255,255,255,.25); letter-spacing: .08em; text-transform: uppercase; }
  .gb-section .gb-play-btn {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
    width: 52px; height: 52px; border-radius: 50%;
    background: rgba(255,255,255,.2); border: 2px solid rgba(255,255,255,.5);
    display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 2;
    transition: background .2s;
  }
  .gb-section .gb-play-btn:hover { background: rgba(255,255,255,.35); }
  .gb-section .gb-play-btn svg { width: 20px; height: 20px; fill: #fff; stroke: #fff; margin-left: 3px; }

  /* Copy */
  .gb-section .gb-cta-copy { padding: 40px 36px; display: flex; flex-direction: column; gap: 14px; justify-content: center; }
  .gb-section .gb-cta-copy-eyebrow { font-size: 10px; font-weight: 500; letter-spacing: .16em; text-transform: uppercase; color: var(--mauve); display: flex; align-items: center; gap: 8px; }
  .gb-section .gb-cta-copy-eyebrow::before { content: ''; display: inline-block; width: 16px; height: 1px; background: var(--mauve); flex-shrink: 0; }
  .gb-section .gb-cta-headline { font-family: 'Cormorant Garamond', Georgia, serif; font-size: clamp(20px, 2.2vw, 26px); font-weight: 400; font-style: italic; color: #fff; line-height: 1.25; }
  .gb-section .gb-cta-body { font-size: 13px; color: rgba(255,255,255,.75); line-height: 1.8; font-weight: 300; }
  .gb-section .gb-cta-body strong { color: #fff; font-weight: 500; }
  .gb-section .gb-cta-btn { display: inline-block; align-self: flex-start; background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.3); border-radius: 50px; padding: 12px 24px; font-size: 12px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: #fff; text-decoration: none; white-space: nowrap; }

  /* Reviews */
  .gb-section .gb-cta-reviews { padding: 32px 28px; display: flex; flex-direction: column; gap: 10px; justify-content: center; border-left: 1px solid rgba(255,255,255,.1); }
  .gb-section .gb-gift-review { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1); border-radius: 14px; padding: 16px 18px; }
  .gb-section .gb-gift-stars { color: var(--gold); font-size: 12px; letter-spacing: 1px; margin-bottom: 6px; }
  .gb-section .gb-gift-text { font-size: 12px; color: rgba(255,255,255,.85); line-height: 1.65; font-style: italic; font-weight: 300; }
  .gb-section .gb-gift-text strong { font-style: normal; font-weight: 500; color: #fff; }
  .gb-section .gb-gift-reviewer { font-size: 11px; color: var(--mauve); margin-top: 6px; letter-spacing: .03em; }

  /* ── MOBILE ── */
  @media (max-width: 768px) {
    .gb-section { padding: 48px 20px; }
    .gb-section .gb-personas { grid-template-columns: 1fr; }
    .gb-section .gb-fears { grid-template-columns: 1fr; }
    .gb-section .gb-cta { grid-template-columns: 1fr; }
    .gb-section .gb-cta-media { min-height: 240px; }
    .gb-section .gb-cta-reviews { border-left: none; border-top: 1px solid rgba(255,255,255,.1); }
  }

/* ── section-guarantee-cta__1_ (.gc-guarantee) ── */
.gc-guarantee * { box-sizing: border-box; }

  /* ── GUARANTEE ── */
  .gc-guarantee {
    background: var(--ivory);
    padding: 80px 60px;
    border-bottom: 1px solid var(--border-soft);
  }
  .gc-guarantee-inner {
    display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
    align-items: center; max-width: 1000px; margin: 0 auto;
  }

  .gc-guarantee .gc-left { display: flex; flex-direction: column; gap: 20px; align-items: flex-start; }

  .gc-guarantee .gc-badge {
    width: 96px; height: 96px; border-radius: 50%;
    background: var(--blush-light); border: 2px solid var(--border);
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1px; flex-shrink: 0;
  }
  .gc-guarantee .gc-badge-num {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 32px; font-weight: 400; color: var(--rose-deep); line-height: 1;
  }
  .gc-guarantee .gc-badge-label {
    font-size: 9px; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--mauve-mid);
  }

  .gc-guarantee .gc-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(26px, 3vw, 36px); font-weight: 400; font-style: italic;
    line-height: 1.2; color: var(--rose-deep);
  }
  .gc-guarantee .gc-body {
    font-size: 14px; color: var(--text-mid); line-height: 1.8; font-weight: 300;
  }
  .gc-guarantee .gc-body strong { color: var(--rose-deep); font-weight: 500; }
  .gc-guarantee .gc-terms {
    font-size: 11px; color: var(--text-light); line-height: 1.6;
    padding: 12px 16px; background: var(--blush-light); border-radius: 10px;
    border-left: 2px solid var(--mauve);
  }

  .gc-guarantee .gc-right { display: flex; flex-direction: column; gap: 10px; }
  .gc-guarantee .gc-check-row {
    display: flex; align-items: flex-start; gap: 12px;
    background: #fff; border: 1px solid var(--border); border-radius: 14px; padding: 16px 18px;
  }
  .gc-guarantee .gc-check-icon {
    width: 24px; height: 24px; border-radius: 50%; background: #EAF3DE;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px;
  }
  .gc-guarantee .gc-check-icon svg {
    width: 12px; height: 12px; stroke: #3B6D11; stroke-width: 2.5; fill: none; stroke-linecap: round; stroke-linejoin: round;
  }
  .gc-guarantee .gc-check-title { font-size: 13px; font-weight: 500; color: var(--text-main); margin-bottom: 2px; }
  .gc-guarantee .gc-check-desc { font-size: 12px; color: var(--text-mid); line-height: 1.55; font-weight: 300; }

  /* ── FINAL CTA ── */
  .gc-final {
    background: #6B2E43;
    padding: 80px 60px;
  }
  .gc-final-inner {
    max-width: 680px; margin: 0 auto; text-align: center;
    display: flex; flex-direction: column; align-items: center; gap: 22px;
  }
  .gc-fc-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mauve); display: flex; align-items: center; gap: 10px;
  }
  .gc-fc-eyebrow::before,
  .gc-fc-eyebrow::after { content: ''; display: inline-block; width: 24px; height: 1px; background: #C4A0B0; }
  .gc-fc-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(32px, 4vw, 44px); font-weight: 400; font-style: italic;
    line-height: 1.15; color: #fff;
  }
  .gc-fc-headline em { font-style: normal; color: rgba(255,255,255,.65); }
  .gc-fc-body {
    font-size: 14px; color: rgba(255,255,255,.7); line-height: 1.8; font-weight: 300; max-width: 520px;
  }
  .gc-fc-body strong { color: #fff; font-weight: 500; }

  .gc-price-row {
    display: flex; align-items: baseline; gap: 10px; justify-content: center; flex-wrap: wrap;
  }
  .gc-price {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 44px; font-weight: 400; color: #fff; line-height: 1;
  }
  .gc-compare { font-size: 20px; color: rgba(255,255,255,.4); text-decoration: line-through; }
  .gc-save {
    font-size: 12px; background: rgba(255,255,255,.15); color: #fff;
    border-radius: 50px; padding: 4px 12px; font-weight: 500; letter-spacing: .04em;
  }
  .gc-fsa { font-size: 13px; color: #C4A0B0; }
  .gc-fsa strong { color: #fff; font-weight: 500; }

  .gc-btn {
    display: inline-block; background: #fff; color: var(--rose-deep);
    padding: 16px 52px; border-radius: 50px; font-size: 13px; font-weight: 600;
    letter-spacing: .1em; text-transform: uppercase; border: none; cursor: pointer;
    font-family: inherit; text-decoration: none; transition: opacity .2s;
  }
  .gc-btn:hover { opacity: .9; }
  .gc-btn[data-busy] { opacity: .6; cursor: not-allowed; }
  .gc-micro { font-size: 12px; color: rgba(255,255,255,.45); letter-spacing: .03em; }

  /* ── URGENCY STRIP (dark variant) ── */
  .gc-urgency {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 9px 20px;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 6px;
    font-size: 12px;
    color: rgba(255,255,255,.8);
    letter-spacing: .01em;
    line-height: 1.4;
    text-align: center;
  }
  .gc-urgency__timer {
    font-weight: 600;
    color: #f5c8a0;
    letter-spacing: .03em;
  }

  .gc-trust-row { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
  .gc-trust-pill {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
    border-radius: 50px; padding: 6px 14px; font-size: 11px; color: rgba(255,255,255,.8);
  }
  .gc-trust-pill svg { width: 12px; height: 12px; stroke: #C4A0B0; flex-shrink: 0; }
  .gc-trust-pill strong { color: #fff; font-weight: 600; }

  /* ── FDA DISCLAIMER ── */
  .gc-fda {
    background: #6B2E43;
    padding: 14px 60px;
    border-top: 1px solid rgba(255,255,255,.08);
    text-align: center;
    font-size: 11px; color: rgba(255,255,255,.3); line-height: 1.5;
  }

  /* ── MOBILE ── */
  @media (max-width: 768px) {
    .gc-guarantee { padding: 48px 20px; }
    .gc-guarantee-inner { grid-template-columns: 1fr; gap: 36px; }
    .gc-final { padding: 56px 20px; }
    .gc-fda { padding: 14px 20px; }
  }

/* ── section-lori-testimonial__1_ (.lt-section) ── */
.lt-section * { box-sizing: border-box; }

  .lt-section {
    background: var(--rose-deep);
    padding: 72px 60px;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 48px;
    align-items: center;
  }

  /* ── LEFT — quote ── */
  .lt-section .lt-label {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--mauve);
    margin-bottom: 20px;
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .lt-section .lt-label::before {
    content: '';
    display: inline-block;
    width: 24px;
    height: 1px;
    background: var(--mauve);
    flex-shrink: 0;
  }

  .lt-section .lt-quote-mark {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 96px;
    line-height: .7;
    color: var(--mauve);
    margin-bottom: 8px;
    font-weight: 300;
  }

  .lt-section .lt-quote-text {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 24px;
    font-weight: 300;
    font-style: italic;
    line-height: 1.55;
    color: rgba(255,255,255,.92);
    margin-bottom: 28px;
    letter-spacing: .01em;
  }
  .lt-section .lt-quote-text strong {
    font-style: normal;
    font-weight: 500;
    color: #fff;
  }

  .lt-section .lt-attribution {
    display: flex;
    align-items: center;
    gap: 14px;
  }
  .lt-section .lt-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--mauve);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 18px;
    font-style: italic;
    color: var(--rose-deep);
    font-weight: 500;
    flex-shrink: 0;
  }
  .lt-section .lt-attr-name {
    font-size: 13px;
    font-weight: 500;
    color: #fff;
    letter-spacing: .04em;
  }
  .lt-section .lt-attr-meta {
    font-size: 11px;
    color: rgba(255,255,255,.5);
    margin-top: 2px;
    letter-spacing: .03em;
  }
  .lt-section .lt-attr-stars {
    color: var(--gold);
    font-size: 12px;
    letter-spacing: 2px;
    margin-top: 3px;
  }

  /* ── MIDDLE — image ── */
  .lt-section .lt-image-col {
    display: flex;
    flex-direction: column;
  }
  .lt-section .lt-image-frame {
    width: 100%;
    aspect-ratio: 3 / 4;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.06);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
  .lt-section .lt-image-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  .lt-section .lt-image-placeholder svg {
    width: 36px;
    height: 36px;
    stroke: var(--mauve);
  }
  .lt-section .lt-image-placeholder span {
    font-size: 11px;
    color: rgba(255,255,255,.35);
    letter-spacing: .08em;
    text-transform: uppercase;
  }
  .lt-section .lt-image-caption {
    margin-top: 12px;
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 13px;
    font-style: italic;
    color: rgba(255,255,255,.35);
    text-align: center;
    letter-spacing: .03em;
  }

  /* ── RIGHT — context ── */
  .lt-section .lt-right {
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  .lt-section .lt-context-card {
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 16px;
    padding: 22px 24px;
  }
  .lt-section .lt-context-label {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--mauve);
    margin-bottom: 10px;
  }
  .lt-section .lt-context-text {
    font-size: 13px;
    color: rgba(255,255,255,.7);
    line-height: 1.7;
    font-weight: 300;
  }
  .lt-section .lt-context-text strong {
    color: rgba(255,255,255,.92);
    font-weight: 500;
  }

  .lt-section .lt-journey {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background: rgba(255,255,255,.1);
    border-radius: 16px;
    overflow: hidden;
  }
  .lt-section .lt-journey-step {
    background: rgba(255,255,255,.05);
    padding: 16px 18px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
  }
  .lt-section .lt-journey-icon {
    flex-shrink: 0;
    margin-top: 1px;
  }
  .lt-section .lt-journey-icon svg {
    width: 16px;
    height: 16px;
    stroke: var(--mauve);
  }
  .lt-section .lt-journey-title {
    font-size: 12px;
    font-weight: 500;
    color: rgba(255,255,255,.9);
    margin-bottom: 2px;
  }
  .lt-section .lt-journey-desc {
    font-size: 11px;
    color: rgba(255,255,255,.45);
    line-height: 1.5;
  }

  /* ── BOTTOM STRIP ── */
  .lt-bottom-strip {
    background: #FAF3F5;
    border-top: 1px solid #E8D8DE;
    border-bottom: 1px solid #E8D8DE;
    padding: 16px 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 13px;
    color: #5C3D4A;
    flex-wrap: wrap;
    text-align: center;
  }
  .lt-bottom-strip strong {
    color: #6B2E43;
    font-weight: 600;
  }
  .lt-section .lt-dot {
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: var(--mauve);
    flex-shrink: 0;
  }

  /* ── MOBILE ── */
  @media (max-width: 768px) {
    .lt-section {
      grid-template-columns: 1fr;
      padding: 48px 24px;
      gap: 36px;
    }
    .lt-section .lt-image-col { order: -1; }
    .lt-section .lt-image-frame { aspect-ratio: 4 / 3; }
    .lt-bottom-strip { padding: 16px 24px; }
  }

/* ── section-mechanism__1_ (.mech-section) ── */
.mech-section * { box-sizing: border-box; }

  .mech-section {
    background: var(--blush-light);
    border-bottom: 1px solid var(--border-soft);
  }

  /* ── HEADER ── */
  .mech-section .mech-inner { padding: 80px 60px 0; }
  .mech-section .mech-top { text-align: center; max-width: 600px; margin: 0 auto 56px; }
  .mech-section .mech-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 14px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
  }
  .mech-section .mech-eyebrow::before,
  .mech-section .mech-eyebrow::after {
    content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve);
  }
  .mech-section .mech-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(28px, 3vw, 38px); font-weight: 400; font-style: italic;
    line-height: 1.2; color: var(--rose-deep); margin-bottom: 14px;
  }
  .mech-section .mech-subhead {
    font-size: 14px; color: var(--text-mid); line-height: 1.75; font-weight: 300;
  }
  .mech-section .mech-subhead strong { color: var(--rose-deep); font-weight: 500; }

  /* ── FULL-WIDTH TICKER ── */
  .mech-section .mech-ticker-wrap {
    width: 100%; overflow: hidden; background: var(--rose-deep); padding: 11px 0;
  }
  .mech-section .mech-ticker-inner {
    display: flex; gap: 48px; white-space: nowrap;
    animation: mech-ticker 20s linear infinite;
    width: max-content;
  }
  @keyframes mech-ticker {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
  }
  .mech-section .mech-ticker-item {
    font-size: 11px; font-weight: 500; letter-spacing: .12em; text-transform: uppercase;
    color: rgba(255,255,255,.75); display: flex; align-items: center; gap: 14px; flex-shrink: 0;
  }
  .mech-section .mech-ticker-dot {
    width: 4px; height: 4px; border-radius: 50%; background: var(--mauve); flex-shrink: 0;
  }

  /* ── TIMELINE ── */
  .mech-section .mech-timeline-wrap { padding: 56px 60px; }
  .mech-section .mech-timeline {
    display: grid; grid-template-columns: 88px 1fr; gap: 0 28px;
    max-width: 760px; margin: 0 auto 48px;
  }

  /* ── CLOCK PILL ── */
  .mech-section .mech-time-col {
    display: flex; flex-direction: column; align-items: center; padding-top: 6px;
  }
  .mech-section .mech-clock-pill {
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    background: #fff; border: 1px solid var(--border); border-radius: 14px;
    padding: 8px 10px; flex-shrink: 0; min-width: 72px;
  }
  .mech-section .mech-clock-face {
    width: 36px; height: 36px; position: relative; flex-shrink: 0;
  }
  .mech-section .mech-clock-face svg { width: 100%; height: 100%; }
  .mech-section .mech-clock-time {
    font-size: 10px; font-weight: 600; letter-spacing: .06em;
    color: var(--rose-deep); text-align: center; line-height: 1;
  }
  .mech-section .mech-time-line {
    width: 1px; background: var(--border); flex: 1; margin: 8px 0;
  }

  /* ── PHASE CARDS ── */
  .mech-section .mech-phase-col { padding-bottom: 40px; }
  .mech-section .mech-phase-card {
    background: #fff; border: 1px solid var(--border); border-radius: 16px; overflow: hidden;
  }
  .mech-section .mech-phase-image {
    width: 100%; aspect-ratio: 16 / 9;
    background: var(--blush);
    display: flex; align-items: center; justify-content: center; overflow: hidden;
  }
  .mech-section .mech-phase-image img {
    width: 100%; height: 100%; object-fit: cover; display: block;
  }
  .mech-section .mech-phase-placeholder {
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
  }
  .mech-section .mech-phase-placeholder svg { width: 32px; height: 32px; stroke: var(--mauve); }
  .mech-section .mech-phase-placeholder span {
    font-size: 10px; color: var(--text-light); letter-spacing: .08em; text-transform: uppercase;
  }
  .mech-section .mech-phase-body { padding: 20px 22px; }
  .mech-section .mech-phase-label {
    font-size: 10px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 6px;
  }
  .mech-section .mech-phase-title {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 22px; font-weight: 400; color: var(--rose-deep);
    margin-bottom: 8px; line-height: 1.2;
  }
  .mech-section .mech-phase-desc {
    font-size: 13px; color: var(--text-mid); line-height: 1.7; font-weight: 300; margin-bottom: 12px;
  }
  .mech-section .mech-phase-divider {
    width: 100%; height: 1px; background: var(--border-soft); margin-bottom: 12px;
  }
  .mech-section .mech-phase-feel {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 15px; font-style: italic; color: var(--rose-deep);
    display: flex; align-items: flex-start; gap: 8px;
  }
  .mech-section .mech-phase-feel::before {
    content: '→'; font-style: normal; flex-shrink: 0; margin-top: 1px;
  }

  /* ── SESSION COMPLETE ── */
  .mech-section .mech-complete .mech-phase-card { background: var(--rose-deep); border-color: var(--rose-deep); }
  .mech-section .mech-complete .mech-phase-image { background: rgba(255,255,255,.07); }
  .mech-section .mech-complete .mech-phase-placeholder svg { stroke: rgba(255,255,255,.3); }
  .mech-section .mech-complete .mech-phase-placeholder span { color: rgba(255,255,255,.3); }
  .mech-section .mech-complete .mech-phase-label { color: var(--mauve); }
  .mech-section .mech-complete .mech-phase-title { color: #fff; }
  .mech-section .mech-complete .mech-phase-desc { color: rgba(255,255,255,.75); }
  .mech-section .mech-complete .mech-phase-divider { background: rgba(255,255,255,.12); }
  .mech-section .mech-complete .mech-phase-feel { color: #fff; }
  .mech-section .mech-complete .mech-clock-pill { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.2); }
  .mech-section .mech-complete-time { color: var(--mauve) !important; }

  /* ── PRE-SLEEP RITUAL ── */
  .mech-section .mech-ritual-box {
    max-width: 760px; margin: 0 auto;
    background: var(--rose-deep); border-radius: 20px;
    padding: 36px 44px; display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center;
  }
  .mech-section .mech-ritual-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .16em; text-transform: uppercase;
    color: var(--mauve); margin-bottom: 12px; display: flex; align-items: center; gap: 8px;
  }
  .mech-section .mech-ritual-eyebrow::before {
    content: ''; display: inline-block; width: 20px; height: 1px; background: var(--mauve); flex-shrink: 0;
  }
  .mech-section .mech-ritual-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(20px, 2.2vw, 26px); font-weight: 400; font-style: italic;
    line-height: 1.25; color: #fff; margin-bottom: 14px;
  }
  .mech-section .mech-ritual-body {
    font-size: 13px; color: rgba(255,255,255,.75); line-height: 1.8; font-weight: 300;
  }
  .mech-section .mech-ritual-body strong { color: #fff; font-weight: 500; }
  .mech-section .mech-ritual-steps {
    display: flex; flex-direction: column; gap: 1px;
    background: rgba(255,255,255,.1); border-radius: 14px; overflow: hidden;
  }
  .mech-section .mech-ritual-step {
    background: rgba(255,255,255,.06); padding: 14px 18px;
    display: flex; align-items: flex-start; gap: 12px;
  }
  .mech-section .mech-ritual-step-time {
    font-size: 11px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase;
    color: var(--mauve); min-width: 52px; padding-top: 1px; flex-shrink: 0;
  }
  .mech-section .mech-ritual-step-text {
    font-size: 12px; color: rgba(255,255,255,.8); line-height: 1.5;
  }
  .mech-section .mech-ritual-step-text strong { color: #fff; font-weight: 500; }

  /* ── MOBILE ── */
  @media (max-width: 768px) {
    .mech-section .mech-inner { padding: 48px 20px 0; }
    .mech-section .mech-timeline-wrap { padding: 40px 20px; }
    .mech-section .mech-timeline { grid-template-columns: 72px 1fr; gap: 0 16px; }
    .mech-section .mech-clock-pill { min-width: 58px; padding: 6px 8px; }
    .mech-section .mech-clock-face { width: 28px; height: 28px; }
    .mech-section .mech-ritual-box { grid-template-columns: 1fr; padding: 28px 24px; gap: 28px; }
  }

/* ── section-mid-cta__1_ (.mcta-section) ── */
.mcta-section * { box-sizing: border-box; }

  .mcta-section {
    background: var(--blush-light);
    padding: 64px 60px;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
  }

  .mcta-section .mcta-inner {
    max-width: 560px;
    margin: 0 auto;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }

  .mcta-section .mcta-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mauve-mid); display: flex; align-items: center; gap: 10px;
  }
  .mcta-section .mcta-eyebrow::before,
  .mcta-section .mcta-eyebrow::after {
    content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve);
  }

  .mcta-section .mcta-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(26px, 2.8vw, 34px); font-weight: 400; font-style: italic;
    line-height: 1.2; color: var(--rose-deep);
  }

  .mcta-section .mcta-price-row {
    display: flex; align-items: baseline; gap: 10px; justify-content: center; flex-wrap: wrap;
  }
  .mcta-section .mcta-price {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 38px; font-weight: 400; color: var(--rose-deep); line-height: 1;
  }
  .mcta-section .mcta-compare {
    font-size: 18px; color: #9A7A87; text-decoration: line-through;
  }
  .mcta-section .mcta-save {
    font-size: 12px; background: var(--blush); color: var(--rose-deep);
    border-radius: 50px; padding: 3px 12px; font-weight: 600;
  }

  .mcta-section .mcta-btn {
    display: inline-block;
    background: var(--rose);
    color: #fff;
    padding: 16px 48px;
    font-size: 13px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
    border-radius: 50px; text-decoration: none; cursor: pointer;
    border: none; font-family: inherit;
    transition: background .2s;
  }
  .mcta-section .mcta-btn:hover { background: var(--rose-deep); }
  .mcta-section .mcta-btn[data-busy] { opacity: .6; cursor: not-allowed; }

  .mcta-section .mcta-micro {
    font-size: 12px; color: var(--mauve-mid); letter-spacing: .03em;
    display: flex; align-items: center; gap: 16px; flex-wrap: wrap; justify-content: center;
  }
  .mcta-section .mcta-micro-dot {
    width: 3px; height: 3px; border-radius: 50%; background: var(--mauve); flex-shrink: 0;
  }

  .mcta-section .mcta-trust-pills {
    display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
  }
  .mcta-section .mcta-pill {
    display: inline-flex; align-items: center; gap: 6px;
    background: #fff; border: 1px solid var(--border); border-radius: 50px;
    padding: 7px 14px; font-size: 12px; color: #5C3D4A;
  }
  .mcta-section .mcta-pill svg {
    width: 13px; height: 13px; stroke: var(--rose); flex-shrink: 0;
  }
  .mcta-section .mcta-pill strong { color: var(--rose-deep); font-weight: 600; }

  .mcta-section .mcta-fsa {
    font-size: 12px; color: var(--mauve-mid);
  }
  .mcta-section .mcta-fsa strong { color: var(--rose-deep); font-weight: 600; }

  @media (max-width: 768px) {
    .mcta-section { padding: 48px 20px; }
  }

/* ── section-modality-trap_1__1_ (.mt-part1) ── */
.mt-part1 * { box-sizing: border-box; }

  /* ═══ PART 1 ═══ */
  .mt-part1 {
    background: var(--ivory); padding: 80px 60px 48px; border-bottom: 1px solid var(--border-soft);
  }
  .mt-part1 .mt-top { text-align: center; max-width: 640px; margin: 0 auto 56px; }
  .mt-part1 .mt-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 16px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
  }
  .mt-part1 .mt-eyebrow::before,
  .mt-part1 .mt-eyebrow::after { content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve); }
  .mt-part1 .mt-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(30px, 3.5vw, 42px); font-weight: 400; font-style: italic;
    line-height: 1.2; color: var(--rose-deep); margin-bottom: 18px;
  }
  .mt-part1 .mt-headline em { font-style: normal; color: var(--text-main); }
  .mt-part1 .mt-subhead { font-size: 15px; color: var(--text-mid); line-height: 1.8; font-weight: 300; }
  .mt-part1 .mt-subhead strong { color: var(--rose-deep); font-weight: 500; }

  .mt-part1 .mt-sol-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 48px;
  }
  .mt-part1 .mt-sol-card {
    background: #fff; border: 1px solid var(--border); border-radius: 16px;
    padding: 24px 20px; display: flex; flex-direction: column; gap: 12px;
    position: relative; overflow: hidden;
  }
  .mt-part1 .mt-sol-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: var(--blush); border-radius: 16px 16px 0 0;
  }
  .mt-part1 .mt-sol-icon {
    width: 36px; height: 36px; background: var(--blush-light); border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
  }
  .mt-part1 .mt-sol-icon svg { width: 18px; height: 18px; stroke: var(--mauve-mid); }
  .mt-part1 .mt-sol-name { font-size: 13px; font-weight: 500; color: var(--text-main); }
  .mt-part1 .mt-sol-what { font-size: 12px; color: var(--text-mid); line-height: 1.6; font-weight: 300; flex: 1; }
  .mt-part1 .mt-sol-limit {
    font-size: 11px; color: var(--mauve-mid); background: var(--blush-light);
    border-radius: 50px; padding: 4px 10px; font-weight: 500; width: fit-content; display: inline-block;
  }
  .mt-part1 .mt-sol-verdict {
    font-size: 11px; color: var(--text-light); line-height: 1.6; font-style: italic;
    border-top: 1px solid var(--border-soft); padding-top: 10px;
  }

  .mt-part1 .mt-pivot {
    background: var(--blush-light); border: 1px solid var(--border); border-radius: 20px;
    padding: 40px 48px; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
  }
  .mt-part1 .mt-pivot-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .16em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
  }
  .mt-part1 .mt-pivot-eyebrow::before { content: ''; display: inline-block; width: 20px; height: 1px; background: var(--mauve); flex-shrink: 0; }
  .mt-part1 .mt-pivot-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(22px, 2.5vw, 30px); font-weight: 400; font-style: italic;
    line-height: 1.25; color: var(--rose-deep); margin-bottom: 16px;
  }
  .mt-part1 .mt-pivot-body { font-size: 13px; color: var(--text-mid); line-height: 1.8; font-weight: 300; }
  .mt-part1 .mt-pivot-body strong { color: var(--rose-deep); font-weight: 500; }
  .mt-three-part {
    display: flex; flex-direction: column; gap: 1px; background: var(--border); border-radius: 14px; overflow: hidden;
  }
  .mt-part1 .mt-tp-row { background: #fff; padding: 16px 18px; display: flex; align-items: flex-start; gap: 14px; }
  .mt-part1 .mt-tp-num {
    width: 28px; height: 28px; border-radius: 50%; background: var(--blush);
    display: flex; align-items: center; justify-content: center;
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 16px; font-style: italic; color: var(--rose-deep); font-weight: 400; flex-shrink: 0;
  }
  .mt-part1 .mt-tp-title { font-size: 12px; font-weight: 500; color: var(--text-main); margin-bottom: 2px; }
  .mt-part1 .mt-tp-desc { font-size: 11px; color: var(--text-light); line-height: 1.55; }
  .mt-part1 .mt-pivot-cta {
    margin-top: 12px; font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 14px; font-style: italic; color: var(--rose-deep); text-align: center;
    padding: 12px 16px; background: var(--blush); border-radius: 50px;
  }

  /* ═══ BRIDGE ═══ */
  .mt-bridge {
    background: var(--ivory); padding: 18px 60px; border-bottom: 1px solid var(--border-soft);
    display: flex; align-items: center; justify-content: center;
  }
  .mt-bridge-line {
    font-size: 11px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
    color: var(--mauve-mid); display: flex; align-items: center; gap: 12px;
  }
  .mt-bridge-line::before,
  .mt-bridge-line::after { content: ''; display: inline-block; width: 48px; height: 1px; background: var(--border); }

  /* ═══ PART 2 ═══ */
  .mt-part2 {
    background: var(--blush-light); padding: 48px 60px 64px; border-bottom: 1px solid var(--border-soft);
  }
  .mt-p2-top { text-align: center; max-width: 520px; margin: 0 auto 32px; }
  .mt-p2-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 12px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
  }
  .mt-p2-eyebrow::before,
  .mt-p2-eyebrow::after { content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve); }
  .mt-p2-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(24px, 2.8vw, 32px); font-weight: 400; font-style: italic;
    line-height: 1.2; color: var(--rose-deep);
  }

  /* ── DESKTOP TABLE ── */
  .mt-table-wrap { border-radius: 20px; overflow: hidden; border: 1px solid var(--border); background: #fff; }
  .mt-thead {
    display: grid; grid-template-columns: 2fr 1.2fr 1fr 1fr 1fr; background: var(--rose-deep);
  }
  .mt-th {
    padding: 14px; font-size: 11px; font-weight: 500; letter-spacing: .08em; text-transform: uppercase;
    color: rgba(255,255,255,.6); text-align: center; border-right: 1px solid rgba(255,255,255,.08);
  }
  .mt-th:first-child { text-align: left; color: rgba(255,255,255,.4); }
  .mt-th:last-child { border-right: none; }
  .mt-th-ours {
    color: #fff; background: rgba(255,255,255,.1); display: flex; flex-direction: column; align-items: center; gap: 3px;
  }
  .mt-th-ours span { font-size: 9px; letter-spacing: .06em; color: var(--mauve); font-weight: 400; text-transform: none; }
  .mt-trow {
    display: grid; grid-template-columns: 2fr 1.2fr 1fr 1fr 1fr; border-top: 1px solid var(--border-soft);
  }
  .mt-trow:hover { background: var(--blush-light); }
  .mt-td {
    padding: 13px 14px; font-size: 12px; color: var(--text-mid);
    display: flex; align-items: center; justify-content: center;
    border-right: 1px solid var(--border-soft);
  }
  .mt-td:first-child { justify-content: flex-start; font-weight: 400; color: var(--text-main); }
  .mt-td:last-child { border-right: none; }
  .mt-td-ours { background: rgba(139,65,87,.04); }

  /* ── MOBILE TABLE — card stack layout ── */
  .mt-mobile-table { display: none; }
 .mt-mob-header {
    display: grid; 
    grid-template-columns: 55% 25% 20%;
    background: var(--rose-deep); border-radius: 16px 16px 0 0; overflow: hidden;
  }
.mt-mob-th {
  padding: 10px 8px; font-size: 10px; font-weight: 500; letter-spacing: .06em;
  text-transform: uppercase; color: rgba(255,255,255,.6); text-align: center;
  border-right: 1px solid rgba(255,255,255,.08);
  box-sizing: border-box;
}
  }
  .mt-mob-th:last-child { border-right: none; }
  .mt-mob-th-ours {
    color: #fff; background: rgba(255,255,255,.1);
    display: flex; flex-direction: column; align-items: center; gap: 2px;
  }
  .mt-mob-th-ours span {
    font-size: 8px; color: rgba(255,255,255,.5); font-weight: 400; text-transform: none; letter-spacing: .03em;
  }
  .mt-mob-body {
    border: 1px solid var(--border); border-top: none;
    border-radius: 0 0 16px 16px; overflow: hidden; background: #fff;
  }
.mt-mob-row {
    display: grid; 
    grid-template-columns: 55% 25% 20%;
    border-top: 1px solid var(--border-soft);
  }
  .mt-mob-row:first-child { border-top: none; }
  .mt-mob-cell {
    padding: 11px 8px; font-size: 11px; color: var(--text-mid);
    display: flex; align-items: center; justify-content: center;
    border-right: 1px solid var(--border-soft); text-align: center;
  }
  .mt-mob-cell:first-child {
    justify-content: flex-start; font-size: 11px; color: var(--text-main);
    font-weight: 400; padding-left: 12px;
  }
  .mt-mob-cell:last-child { border-right: none; }
  .mt-mob-cell-ours { background: rgba(139,65,87,.04); }

  .mt-mob-note {
    margin-top: 10px; font-size: 10px; color: var(--text-light);
    text-align: center; letter-spacing: .03em;
  }

  /* ── SHARED ICONS ── */
  .mt-ck { width: 22px; height: 22px; border-radius: 50%; background: #EAF3DE; display: flex; align-items: center; justify-content: center; }
  .mt-ck svg { width: 12px; height: 12px; stroke: #3B6D11; stroke-width: 2.5; fill: none; stroke-linecap: round; stroke-linejoin: round; }
  .mt-cx { width: 22px; height: 22px; border-radius: 50%; background: #FDF2F2; display: flex; align-items: center; justify-content: center; }
  .mt-cx svg { width: 12px; height: 12px; stroke: #C0392B; stroke-width: 2.5; fill: none; stroke-linecap: round; stroke-linejoin: round; }
  .mt-cp { width: 22px; height: 22px; border-radius: 50%; background: #FEF9EE; display: flex; align-items: center; justify-content: center; }
  .mt-cp svg { width: 12px; height: 12px; stroke: var(--gold); stroke-width: 2.5; fill: none; stroke-linecap: round; stroke-linejoin: round; }

  /* smaller icon variant for mobile */
  .mt-ck-sm { width: 18px; height: 18px; border-radius: 50%; background: #EAF3DE; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .mt-ck-sm svg { width: 10px; height: 10px; stroke: #3B6D11; stroke-width: 2.5; fill: none; stroke-linecap: round; stroke-linejoin: round; }
  .mt-cx-sm { width: 18px; height: 18px; border-radius: 50%; background: #FDF2F2; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .mt-cx-sm svg { width: 10px; height: 10px; stroke: #C0392B; stroke-width: 2.5; fill: none; stroke-linecap: round; stroke-linejoin: round; }
  .mt-cp-sm { width: 18px; height: 18px; border-radius: 50%; background: #FEF9EE; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .mt-cp-sm svg { width: 10px; height: 10px; stroke: var(--gold); stroke-width: 2.5; fill: none; stroke-linecap: round; stroke-linejoin: round; }

  .mt-tfoot {
    padding: 14px 20px; background: var(--rose-deep);
    display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  }
  .mt-tfoot-text {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 14px; font-style: italic; color: rgba(255,255,255,.8);
  }
  .mt-tfoot-text strong { color: #fff; font-style: normal; }
  .mt-tfoot-cta {
    font-size: 11px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
    color: #fff; background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.3);
    border-radius: 50px; padding: 8px 18px; white-space: nowrap; text-decoration: none; display: inline-block;
  }

  .mt-legend {
    display: flex; align-items: center; justify-content: center; gap: 20px;
    margin-top: 14px; flex-wrap: wrap;
  }
  .mt-legend-item { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-light); }

  /* ═══ RESPONSIVE ═══ */
  @media (max-width: 768px) {
    .mt-part1,
    .mt-part2 { padding: 48px 20px; }
    .mt-bridge { padding: 14px 20px; }
    .mt-part1 .mt-sol-grid { grid-template-columns: 1fr 1fr; }
    .mt-part1 .mt-pivot { grid-template-columns: 1fr; padding: 28px 24px; gap: 28px; }

    /* hide desktop table, show mobile version */
    .mt-table-wrap { display: none; }
    .mt-mobile-table { display: block; }

    .mt-tfoot {
      flex-direction: column; align-items: stretch; text-align: center;
      border-radius: 0 0 16px 16px;
    }
    .mt-tfoot-cta { text-align: center; }
    .mt-legend { gap: 12px; }
  }

/* ── section-product-atf__1_ (.hv-atf) ── */
.hv-atf * { box-sizing: border-box; }

  .hv-atf .atf-announce {
    background: var(--rose-deep);
    color: rgba(255,255,255,.88);
    padding: 8px 20px;
    font-size: 12px;
    letter-spacing: .07em;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
  }
  .hv-atf .atf-announce strong { color: #fff; font-weight: 600; }
  .hv-atf .atf-announce-text { text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  @media (max-width: 768px) {
    .hv-atf .atf-announce { padding: 8px 16px; gap: 10px; }
    .hv-atf .atf-announce .currency-selector { display: none; }
    .hv-atf .atf-announce-text { font-size: 11px; letter-spacing: .04em; }
  }

  .hv-atf .currency-selector { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
  .hv-atf .currency-selector select {
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.3);
    color: #fff;
    font-size: 11px;
    font-family: inherit;
    padding: 3px 22px 3px 8px;
    border-radius: 20px;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='white' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 7px center;
    letter-spacing: .04em;
  }
  .hv-atf .currency-selector select option { background: #6B2E43; color: #fff; }
  .hv-atf .currency-selector select:focus { outline: none; border-color: rgba(255,255,255,.6); }
  .hv-atf .currency-icon { width: 14px; height: 14px; stroke: rgba(255,255,255,.7); flex-shrink: 0; }

  .hv-atf .atf-grid {
    background: var(--blush-bg);
    padding: 48px 60px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 56px;
    align-items: start;
    border-bottom: 1px solid var(--border);
  }

  .hv-atf .carousel-wrap { width: 100%; }

  .hv-atf .carousel-stage {
    width: 100%;
    border-radius: 20px;
    border: 1px solid var(--border);
    background: var(--blush);
    overflow: hidden;
    position: relative;
    user-select: none;
  }
  .hv-atf .carousel-track {
    display: flex;
    width: 100%;
    transition: transform .35s ease;
  }
  .hv-atf .carousel-track.is-dragging {
    transition: none;
  }
  .hv-atf .carousel-slide {
    min-width: 100%;
    width: 100%;
    flex-shrink: 0;
    aspect-ratio: 1 / 1;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--blush);
    overflow: hidden;
  }
  .hv-atf .carousel-slide img {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    object-fit: contain;
    object-position: center;
    display: block;
    pointer-events: none;
  }
  .hv-atf .carousel-slide iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none; display: block; }
  .hv-atf .slide-placeholder {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 8px; width: 100%; height: 100%; color: var(--text-light);
    font-size: 12px; letter-spacing: .06em; text-transform: uppercase; font-family: inherit;
  }
  .hv-atf .slide-placeholder svg { width: 40px; height: 40px; stroke: var(--mauve); }
  .hv-atf .slide-video-bg { background: var(--rose-deep); }
  .hv-atf .video-play-btn {
    width: 52px; height: 52px; border-radius: 50%;
    background: rgba(255,255,255,.2); border: 2px solid rgba(255,255,255,.5);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%); transition: background .2s; z-index: 2;
  }
  .hv-atf .video-play-btn:hover { background: rgba(255,255,255,.35); }
  .hv-atf .video-play-btn svg { width: 20px; height: 20px; stroke: #fff; fill: #fff; margin-left: 3px; }
  .hv-atf .video-poster { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; display: block; }

  /* ── DOT INDICATORS ── */
  .hv-atf .carousel-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 12px;
    min-height: 10px;
  }
  .hv-atf .carousel-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--mauve);
    opacity: .35;
    border: none;
    padding: 0;
    cursor: pointer;
    transition: opacity .2s, transform .2s;
    flex-shrink: 0;
  }
  .hv-atf .carousel-dot.is-active {
    opacity: 1;
    transform: scale(1.4);
    background: var(--rose);
  }

  .hv-atf .proof-pill {
    display: inline-flex; align-items: center; gap: 10px;
    background: #fff; border: 1px solid var(--border); border-radius: 50px;
    padding: 8px 18px 8px 12px; font-size: 12px; color: var(--text-mid); margin-top: 12px;
  }
  .hv-atf .proof-stars { color: #C4956A; letter-spacing: 1px; }
  .hv-atf .proof-count { font-weight: 600; color: var(--rose-deep); }

  .hv-atf .product-col { padding-top: 4px; }
  .hv-atf .p-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .16em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 16px; display: flex; align-items: center; gap: 10px;
  }
  .hv-atf .p-eyebrow::before {
    content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve); flex-shrink: 0;
  }
  .hv-atf .p-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(30px, 3.2vw, 44px); font-weight: 400; font-style: italic;
    line-height: 1.12; color: var(--rose-deep); margin-bottom: 18px; letter-spacing: -.01em;
  }
  .hv-atf .p-headline em { font-style: normal; color: var(--text-main); }
  .hv-atf .p-divider { width: 40px; height: 1px; background: var(--mauve); margin-bottom: 20px; }
  .hv-atf .p-subhead { font-size: 14px; color: var(--text-mid); line-height: 1.8; margin-bottom: 26px; font-weight: 300; }
  .hv-atf .p-subhead strong { color: var(--rose-deep); font-weight: 500; }

  .hv-atf .p-price-row { display: flex; align-items: baseline; gap: 10px; margin-bottom: 5px; flex-wrap: wrap; }
  .hv-atf .p-price-main {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 34px; font-weight: 400; color: var(--rose-deep); line-height: 1;
  }
  .hv-atf .p-price-compare { font-size: 16px; color: var(--text-light); text-decoration: line-through; }
  .hv-atf .p-price-save {
    font-size: 11px; background: var(--blush); color: var(--rose-deep);
    border-radius: 50px; padding: 3px 11px; font-weight: 600; letter-spacing: .02em;
  }
  .hv-atf .p-fsa { font-size: 12px; color: var(--mauve-mid); margin-bottom: 22px; letter-spacing: .02em; }
  .hv-atf .p-fsa strong { color: var(--rose-deep); }

  .hv-atf .p-btn-add {
    display: block; width: 100%; background: var(--rose); color: #fff; border: none;
    padding: 16px; font-size: 13px; font-weight: 500; letter-spacing: .1em;
    text-transform: uppercase; border-radius: 50px; cursor: pointer; font-family: inherit;
    text-align: center; text-decoration: none; transition: background .2s; margin-bottom: 10px;
  }
  .hv-atf .p-btn-add:hover { background: var(--rose-deep); }
  .hv-atf .p-btn-add[data-busy] { opacity: .7; cursor: not-allowed; }
  .hv-atf .p-btn-micro { font-size: 11px; color: var(--text-light); text-align: center; letter-spacing: .03em; margin-bottom: 12px; }

  /* ── URGENCY STRIP ── */
  .hv-atf .atf-urgency {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 9px 16px;
    background: #fff8f0;
    border: 1px solid #e8c99a;
    border-radius: 6px;
    margin-bottom: 18px;
    font-size: 12px;
    color: #5a3a28;
    letter-spacing: .01em;
    line-height: 1.4;
    text-align: center;
  }
  .hv-atf .atf-urgency__timer {
    font-weight: 600;
    color: var(--rose-deep);
    letter-spacing: .03em;
  }

  .hv-atf .trust-pills { display: flex; flex-wrap: wrap; gap: 6px; }
  .hv-atf .trust-pill {
    display: inline-flex; align-items: center; gap: 6px; background: #fff;
    border: 1px solid var(--border); border-radius: 50px; padding: 6px 13px;
    font-size: 11px; color: var(--text-mid);
  }
  .hv-atf .trust-pill svg { width: 13px; height: 13px; stroke: var(--rose); flex-shrink: 0; }
  .hv-atf .trust-pill strong { color: var(--rose-deep); font-weight: 600; }

  /* ── FEATURED REVIEW ── */
  .hv-atf .p-featured-review {
    display: flex; align-items: flex-start; gap: 10px;
    background: var(--blush); border-radius: 12px; padding: 12px 14px;
    margin-bottom: 16px; border: 1px solid var(--border);
  }
  .hv-atf .p-review-avatar {
    width: 36px; height: 36px; border-radius: 50%; overflow: hidden;
    flex-shrink: 0; background: var(--blush);
    display: flex; align-items: center; justify-content: center;
  }
  .hv-atf .p-review-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .hv-atf .p-review-avatar svg { width: 16px; height: 16px; stroke: var(--mauve-mid); }
  .hv-atf .p-review-text { font-size: 12px; color: var(--text-mid); line-height: 1.55; font-weight: 300; flex: 1; }
  .hv-atf .p-review-stars { color: #C4956A; font-size: 11px; letter-spacing: 1px; margin-top: 4px; }
  .hv-atf .p-review-name { font-size: 11px; color: var(--text-light); margin-left: 4px; }

  /* ── STAR RATING LINE ── */
  .hv-atf .p-rating-line {
    display: flex; align-items: center; gap: 8px; margin-bottom: 14px; flex-wrap: wrap;
  }
  .hv-atf .p-rating-stars { color: #C4956A; font-size: 14px; letter-spacing: 1px; }
  .hv-atf .p-rating-score { font-size: 13px; font-weight: 500; color: var(--rose-deep); }
  .hv-atf .p-rating-count {
    font-size: 12px; color: var(--mauve-mid); text-decoration: underline;
    text-underline-offset: 2px; cursor: pointer;
  }

  /* ── BULLET POINTS ── */
  .hv-atf .p-bullets { display: flex; flex-direction: column; gap: 6px; margin-bottom: 22px; }
  .hv-atf .p-bullet {
    display: flex; align-items: flex-start; gap: 8px;
    font-size: 13px; color: var(--text-mid); line-height: 1.5; font-weight: 300;
  }
  .hv-atf .p-fit-note {
    font-size: 11px;
    color: var(--text-light);
    letter-spacing: .03em;
    margin-top: -10px;
    margin-bottom: 18px;
    padding-left: 24px;
  }
  .hv-atf .p-bullet-icon {
    width: 16px; height: 16px; flex-shrink: 0; margin-top: 1px; stroke: var(--rose); fill: none;
  }

  /* ── ACCORDIONS ── */
  .hv-atf .p-accordions { display: flex; flex-direction: column; gap: 0; margin-top: 16px; border-top: 1px solid var(--border); }
  .hv-atf .p-accordion { border-bottom: 1px solid var(--border); }
  .hv-atf .p-accordion-q {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    padding: 13px 0; cursor: pointer; user-select: none;
  }
  .hv-atf .p-accordion-q-left { display: flex; align-items: center; gap: 8px; }
  .hv-atf .p-accordion-q-icon svg { width: 14px; height: 14px; stroke: var(--mauve-mid); }
  .hv-atf .p-accordion-label { font-size: 12px; font-weight: 500; color: var(--text-main); }
  .hv-atf .p-accordion-chevron {
    width: 16px; height: 16px; flex-shrink: 0; transition: transform .2s; stroke: var(--text-light); fill: none;
  }
  .hv-atf .p-accordion.is-open .p-accordion-chevron { transform: rotate(180deg); }
  .hv-atf .p-accordion-body { max-height: 0; overflow: hidden; transition: max-height .25s ease; }
  .hv-atf .p-accordion.is-open .p-accordion-body { max-height: 200px; }
  .hv-atf .p-accordion-content {
    font-size: 12px; color: var(--text-mid); line-height: 1.7; font-weight: 300; padding-bottom: 13px;
  }

  /* ── AS SEEN ON ── */
  .hv-atf .p-seen-on { margin-top: 18px; }
  .hv-atf .p-seen-on-label {
    font-size: 9px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase;
    color: var(--text-light); margin-bottom: 10px; text-align: center;
  }
  .hv-atf .p-seen-on-logos { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
  .hv-atf .p-seen-on-logo {
    font-size: 13px; font-weight: 600; letter-spacing: .06em;
    color: var(--text-light); text-decoration: none; opacity: .6; font-family: Georgia, serif; transition: opacity .15s;
  }
  .hv-atf .p-seen-on-logo:hover { opacity: 1; }
  .hv-atf .p-seen-on-logo img { height: 18px; width: auto; opacity: .5; filter: grayscale(1); display: block; }

  .hv-atf .p-mechanism {
    font-size: 14px;
    color: var(--text-mid);
    line-height: 1.6;
    margin-bottom: 22px;
    border-left: 2px solid var(--mauve);
    padding-left: 12px;
    font-weight: 300;
  }
  .hv-atf .p-mechanism strong { color: var(--rose-deep); font-weight: 500; }

  @media (max-width: 768px) {
    .hv-atf .atf-grid { grid-template-columns: 1fr; padding: 20px 20px 28px; gap: 20px; }
    .hv-atf .carousel-wrap { order: -1; }
    .hv-atf .atf-announce { font-size: 11px; gap: 10px; }
    .hv-atf .p-btf-block { border-top: 1px solid var(--border); padding-top: 16px; margin-top: 4px; }
    .hv-atf .p-divider { display: none; }
    .hv-atf .p-subhead { font-size: 13px; line-height: 1.65; margin-bottom: 18px; }
    .hv-atf .p-subhead p { margin-bottom: 10px; }
    .hv-atf .p-bullets { gap: 5px; margin-bottom: 16px; }
    .hv-atf .p-bullet { font-size: 12px; line-height: 1.4; }
    .hv-atf .p-fit-note { margin-bottom: 12px; }

    /* ── Cap image height so headline + CTA are visible above fold ── */
    /* Keep aspect-ratio intact — shrink via max-height on the wrap, not the slide */
    .hv-atf .carousel-stage { max-height: 38vh; overflow: hidden; }
    .hv-atf .carousel-slide {
      aspect-ratio: 1 / 1;
      max-height: 38vh;
    }
    .hv-atf .carousel-slide img { object-fit: cover; object-position: center center; }

    /* ── Tighten product-col spacing so CTA fits in first screen ── */
    .hv-atf .product-col { padding-top: 0; }
    .hv-atf .p-eyebrow { margin-bottom: 8px; }
    .hv-atf .p-headline { font-size: clamp(24px, 6.5vw, 32px); margin-bottom: 8px; }
    .hv-atf .p-rating-line { margin-bottom: 8px; }
    .hv-atf .p-mechanism { display: none; }
    .hv-atf .p-price-row { margin-bottom: 4px; }
    .hv-atf .p-fsa { margin-bottom: 12px; }
    .hv-atf .p-featured-review { display: none; }
    .hv-atf .carousel-dots { margin-top: 6px; min-height: 6px; }
    .hv-atf .proof-pill { display: none; }
    .hv-atf .atf-grid { gap: 12px; padding: 16px 20px 28px; }
  }

/* ── section-proof-wall__1_ (.pw-section) ── */
.pw-section * { box-sizing: border-box; }

  .pw-section {
    background: var(--ivory);
    padding: 72px 60px;
    border-bottom: 1px solid var(--border-soft);
  }

  /* ── HEADER ── */
  .pw-section .pw-top { text-align: center; max-width: 560px; margin: 0 auto 40px; }
  .pw-section .pw-eyebrow {
    font-size: 10px; font-weight: 500; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mauve-mid); margin-bottom: 14px;
    display: flex; align-items: center; justify-content: center; gap: 10px;
  }
  .pw-section .pw-eyebrow::before,
  .pw-section .pw-eyebrow::after { content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve); }
  .pw-section .pw-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(28px, 3vw, 38px); font-weight: 400; font-style: italic;
    line-height: 1.2; color: var(--rose-deep); margin-bottom: 12px;
  }
  .pw-section .pw-subhead { font-size: 14px; color: var(--text-mid); line-height: 1.7; font-weight: 300; }

  /* ── RATING BAR ── */
  .pw-section .pw-rating-bar {
    display: flex; align-items: center; justify-content: center; gap: 20px;
    margin: 0 auto 48px; padding: 14px 28px;
    background: #fff; border: 1px solid var(--border); border-radius: 50px;
    width: fit-content; flex-wrap: wrap;
  }
  .pw-section .pw-rating-num {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 34px; font-weight: 400; color: var(--rose-deep); line-height: 1;
  }
  .pw-section .pw-rating-stars { color: var(--gold); font-size: 15px; letter-spacing: 2px; }
  .pw-section .pw-rating-count { font-size: 12px; color: var(--text-light); }
  .pw-section .pw-rating-divider { width: 1px; height: 28px; background: var(--border); }
  .pw-section .pw-five-star { font-size: 12px; color: var(--text-mid); }
  .pw-section .pw-five-star strong { color: var(--rose-deep); font-weight: 600; }

  /* ── REVIEW GRID ── */
  .pw-section .pw-review-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 48px;
  }
  .pw-section .pw-review-card {
    background: #fff; border: 1px solid var(--border); border-radius: 16px;
    padding: 22px 20px; display: flex; flex-direction: column; gap: 12px;
  }
  .pw-section .pw-review-card.is-featured { background: var(--blush-light); border-color: var(--mauve); }
  .pw-section .pw-review-header { display: flex; align-items: center; gap: 10px; }
  .pw-section .pw-avatar {
    width: 36px; height: 36px; border-radius: 50%; background: var(--blush);
    display: flex; align-items: center; justify-content: center;
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 15px; font-style: italic; color: var(--rose-deep); font-weight: 500; flex-shrink: 0;
  }
  .pw-section .pw-reviewer-name { font-size: 13px; font-weight: 500; color: var(--text-main); }
  .pw-section .pw-reviewer-meta { font-size: 11px; color: var(--text-light); margin-top: 1px; }
  .pw-section .pw-star-row { display: flex; gap: 6px; align-items: center; }
  .pw-section .pw-stars { color: var(--gold); font-size: 11px; letter-spacing: 1px; }
  .pw-section .pw-verified {
    font-size: 9px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase;
    color: var(--green-text); background: var(--green-bg); border-radius: 20px; padding: 2px 7px; display: inline-block;
  }
  .pw-section .pw-condition {
    font-size: 10px; font-weight: 500; letter-spacing: .08em; text-transform: uppercase;
    color: var(--mauve-mid); background: var(--blush-light);
    border-radius: 20px; padding: 3px 10px; display: inline-block; width: fit-content;
  }
  .pw-section .pw-review-card.is-featured .pw-condition { background: #fff; }
  .pw-section .pw-review-text { font-size: 13px; color: var(--text-mid); line-height: 1.7; font-weight: 300; flex: 1; }
  .pw-section .pw-review-text strong { color: var(--rose-deep); font-weight: 500; }
  .pw-section .pw-review-photo {
    width: 100%; aspect-ratio: 4 / 3; border-radius: 10px;
    overflow: hidden; background: var(--blush); display: flex; align-items: center; justify-content: center;
  }
  .pw-section .pw-review-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .pw-section .pw-review-photo svg { width: 28px; height: 28px; stroke: var(--mauve); }

  /* ── VIDEO SECTION ── */
  .pw-section .pw-video-label { text-align: center; margin-bottom: 20px; }
  .pw-section .pw-video-label p {
    font-size: 10px; font-weight: 500; letter-spacing: .16em; text-transform: uppercase;
    color: var(--mauve-mid); display: flex; align-items: center; justify-content: center; gap: 10px;
  }
  .pw-section .pw-video-label p::before,
  .pw-section .pw-video-label p::after { content: ''; display: inline-block; width: 24px; height: 1px; background: var(--mauve); }
  .pw-section .pw-video-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  }
  .pw-section .pw-video-card {
    border-radius: 16px; overflow: hidden; border: 1px solid var(--border);
    background: var(--rose-deep); aspect-ratio: 9 / 16;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 10px; position: relative; cursor: pointer;
  }

  /* ── POSTER IMAGE ── */
  .pw-section .pw-video-card img.pw-poster {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; display: block;
  }

  /* ── SHOPIFY NATIVE VIDEO ── */
  .pw-section .pw-video-card video {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover;
    display: block;
  }

  /* ── OVERLAY (shown over poster or when no poster) ── */
  .pw-section .pw-video-overlay {
    position: absolute; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(107,46,67,.4);
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px;
  }
  .pw-section .pw-video-play {
    width: 44px; height: 44px; border-radius: 50%;
    background: rgba(255,255,255,.2); border: 2px solid rgba(255,255,255,.5);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  }
  .pw-section .pw-video-play svg { width: 18px; height: 18px; fill: #fff; stroke: #fff; margin-left: 3px; }
  .pw-section .pw-video-name { font-size: 12px; font-weight: 500; color: #fff; }
  .pw-section .pw-video-location { font-size: 10px; color: rgba(255,255,255,.55); letter-spacing: .04em; }
  .pw-section .pw-video-condition {
    position: absolute; bottom: 12px; left: 12px; right: 12px;
    font-size: 10px; font-weight: 500; letter-spacing: .06em; text-transform: uppercase;
    color: rgba(255,255,255,.8); background: rgba(0,0,0,.25);
    border-radius: 20px; padding: 4px 10px; text-align: center;
  }
  .pw-section .pw-video-placeholder {
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px;
  }

  /* ── MOBILE ── */
  @media (max-width: 768px) {
    .pw-section { padding: 48px 20px; }
    .pw-section .pw-review-grid { grid-template-columns: 1fr; }
    .pw-section .pw-video-grid { grid-template-columns: repeat(2, 1fr); }
    .pw-section .pw-rating-bar { gap: 12px; padding: 12px 18px; }
    .pw-section .pw-rating-divider { display: none; }
  }

/* ── section-reviews-closer (.rc-section) ── */
.rc-section {
    background: #FAF3F5;
    padding: 80px 24px;
    font-family: 'Jost', sans-serif;
  }

  .rc-section .rc-container {
    max-width: 1080px;
    margin: 0 auto;
  }

  /* Header */
  .rc-section .rc-header {
    text-align: center;
    margin-bottom: 48px;
  }

  .rc-section .rc-eyebrow {
    font-size: 10px;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: #8B4157;
    margin-bottom: 10px;
  }

  .rc-section .rc-heading {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(28px, 4vw, 42px);
    font-weight: 400;
    color: #2C1A22;
    margin: 0 0 14px;
    line-height: 1.2;
  }

  .rc-section .rc-rating-summary {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
  }

  .rc-section .rc-stars {
    color: #C4813A;
    font-size: 16px;
    letter-spacing: 1px;
  }

  .rc-section .rc-rating-text {
    font-size: 13px;
    color: #6B4D58;
  }

  /* Grid */
  .rc-section .rc-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-bottom: 52px;
  }

  @media (max-width: 768px) {
    .rc-section .rc-grid {
      grid-template-columns: 1fr;
    }
  }

  @media (min-width: 769px) and (max-width: 1024px) {
    .rc-section .rc-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  /* Card */
  .rc-section .rc-card {
    background: #fff;
    border-radius: 12px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    border: 1px solid #F0E4E8;
  }

  .rc-section .rc-card__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
  }

  .rc-section .rc-star {
    color: #E0CDD3;
    font-size: 15px;
  }

  .rc-section .rc-star--filled {
    color: #C4813A;
  }

  .rc-section .rc-card__badge {
    font-size: 9px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    background: #F2E4E8;
    color: #8B4157;
    padding: 3px 8px;
    border-radius: 20px;
    font-weight: 500;
  }

  .rc-section .rc-card__quote {
    font-size: 14px;
    line-height: 1.6;
    color: #3D2530;
    flex: 1;
    margin: 0;
    font-style: normal;
  }

  .rc-section .rc-card__footer {
    display: flex;
    align-items: center;
    gap: 10px;
    padding-top: 12px;
    border-top: 1px solid #F2E4E8;
  }

  .rc-section .rc-card__avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #8B4157;
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    text-transform: uppercase;
  }

  .rc-section .rc-card__meta {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 1px;
  }

  .rc-section .rc-card__name {
    font-size: 13px;
    font-weight: 600;
    color: #2C1A22;
  }

  .rc-section .rc-card__source {
    font-size: 11px;
    color: #9E7A88;
  }

  .rc-section .rc-card__verified {
    font-size: 10px;
    color: #6B7F6E;
    font-weight: 500;
    letter-spacing: 0.05em;
    white-space: nowrap;
  }

  /* Footer CTA */
  .rc-section .rc-footer-cta {
    text-align: center;
  }

  .rc-section .rc-cta-btn {
    display: inline-block;
    background: #8B4157;
    color: #fff;
    font-family: 'Jost', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 14px 36px;
    border-radius: 50px;
    text-decoration: none;
    margin-bottom: 12px;
    transition: background 0.2s;
  }

  .rc-section .rc-cta-btn:hover {
    background: #6B2E43;
  }

  .rc-section .rc-cta-sub {
    font-size: 12px;
    color: #9E7A88;
    margin: 0;
  }

/* ── section-sticky-cta__1_ (.sc-sticky-bar) ── */
.sc-sticky-bar {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: #fff;
    border-top: 1px solid #E8D8DE;
    padding: 12px 40px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    z-index: 999;
    box-shadow: 0 -4px 24px rgba(44,26,34,.08);
    transform: translateY(105%);
    transition: transform .32s cubic-bezier(.4,0,.2,1);
    font-family: 'Jost', sans-serif;
  }
  .sc-sticky-bar.sc-visible { transform: translateY(0); }

  /* Left — product info */
  .sc-left { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
  .sc-thumb {
    width: 44px; height: 44px; border-radius: 10px;
    background: #F2E4E8; border: 1px solid #E8D8DE;
    overflow: hidden; display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  }
  .sc-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .sc-thumb svg { width: 20px; height: 20px; stroke: #9A6B7E; }
  .sc-name { font-size: 13px; font-weight: 500; color: #2C1A22; line-height: 1.3; }
  .sc-rating-row { display: flex; align-items: center; gap: 4px; margin-top: 2px; }
  .sc-stars { color: #C4956A; font-size: 11px; letter-spacing: 1px; }
  .sc-rating-text { font-size: 11px; color: #9A7A87; }

  /* Middle — price */
  .sc-mid { display: flex; align-items: baseline; gap: 8px; flex-shrink: 0; }
  .sc-price {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 26px; font-weight: 400; color: #6B2E43; line-height: 1;
  }
  .sc-compare { font-size: 14px; color: #9A7A87; text-decoration: line-through; }
  .sc-save {
    font-size: 10px; background: #F2E4E8; color: #6B2E43;
    border-radius: 50px; padding: 2px 8px; font-weight: 600; letter-spacing: .02em;
  }

  /* Right — CTA */
  .sc-right { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0; }
  .sc-btn {
    background: #8B4157; color: #fff; border: none;
    padding: 12px 28px; border-radius: 50px;
    font-size: 12px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase;
    cursor: pointer; font-family: inherit; white-space: nowrap;
    text-decoration: none; display: inline-block;
    transition: background .2s;
  }
  .sc-btn:hover { background: #6B2E43; }
  .sc-micro { font-size: 10px; color: #9A7A87; letter-spacing: .03em; }

  /* Mobile — simplified */
  @media (max-width: 768px) {
    .sc-sticky-bar {
      padding: 10px 16px;
      gap: 0;
      flex-direction: column;
      align-items: stretch;
    }
    .sc-left { display: none; }
    .sc-mid {
      justify-content: center;
      margin-bottom: 8px;
    }
    .sc-right { align-items: stretch; }
    .sc-btn { text-align: center; padding: 12px 20px; width: 100%; }
    .sc-micro { display: none; }
  }

/* ── section-transformation (.tf-section) ── */
.tf-section * { box-sizing: border-box; }

  .tf-section {
    background: var(--blush-bg);
    padding: 80px 60px;
    font-family: 'Jost', sans-serif;
  }

  .tf-section .tf-inner {
    max-width: 1000px;
    margin: 0 auto;
  }

  /* ── HEADER ── */
  .tf-section .tf-header {
    text-align: center;
    margin-bottom: 56px;
  }
  .tf-section .tf-eyebrow {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--mauve-mid);
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
  .tf-section .tf-eyebrow::before,
  .tf-section .tf-eyebrow::after {
    content: '';
    display: inline-block;
    width: 24px;
    height: 1px;
    background: var(--mauve);
  }
  .tf-section .tf-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(32px, 4vw, 50px);
    font-weight: 400;
    font-style: italic;
    line-height: 1.1;
    color: var(--rose-deep);
    margin-bottom: 20px;
    letter-spacing: -.01em;
  }
  .tf-section .tf-headline em {
    font-style: normal;
    color: var(--text-main);
  }
  .tf-section .tf-intro {
    font-size: 15px;
    color: var(--text-mid);
    line-height: 1.8;
    font-weight: 300;
    max-width: 560px;
    margin: 0 auto;
  }
  .tf-section .tf-intro strong {
    color: var(--rose-deep);
    font-weight: 500;
  }

  /* ── MOMENT CARDS ── */
  .tf-section .tf-moments {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-bottom: 56px;
  }

  .tf-section .tf-card {
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 32px 28px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity .5s ease, transform .5s ease;
  }
  .tf-section .tf-card.tf-visible {
    opacity: 1;
    transform: translateY(0);
  }
  .tf-section .tf-card:nth-child(2) { transition-delay: .12s; }
  .tf-section .tf-card:nth-child(3) { transition-delay: .24s; }

  .tf-section .tf-card__icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--blush);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  .tf-section .tf-card__icon svg {
    width: 18px;
    height: 18px;
    stroke: var(--rose);
    fill: none;
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .tf-section .tf-card__label {
    font-size: 9px;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--mauve-mid);
  }

  .tf-section .tf-card__moment {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 22px;
    font-weight: 400;
    font-style: italic;
    line-height: 1.25;
    color: var(--rose-deep);
  }

  .tf-section .tf-card__body {
    font-size: 13px;
    color: var(--text-mid);
    line-height: 1.7;
    font-weight: 300;
    flex: 1;
  }

  .tf-section .tf-card__divider {
    width: 32px;
    height: 1px;
    background: var(--blush);
  }

  .tf-section .tf-card__before {
    font-size: 11px;
    color: var(--text-light);
    line-height: 1.6;
    font-style: italic;
    padding-left: 10px;
    border-left: 2px solid var(--blush);
  }

  /* ── CLOSING STATEMENT ── */
  .tf-section .tf-close {
    text-align: center;
    max-width: 640px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
  .tf-section .tf-close__quote {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(22px, 3vw, 30px);
    font-weight: 400;
    font-style: italic;
    line-height: 1.4;
    color: var(--text-main);
  }
  .tf-section .tf-close__quote strong {
    color: var(--rose-deep);
    font-style: normal;
    font-weight: 500;
  }
  .tf-section .tf-close__sub {
    font-size: 13px;
    color: var(--text-light);
    line-height: 1.7;
    font-weight: 300;
    max-width: 480px;
  }


  @media (max-width: 768px) {
    .tf-section { padding: 56px 20px; }
    .tf-section .tf-moments { grid-template-columns: 1fr; }
    .tf-section .tf-card { opacity: 1; transform: none; }
  }

/* ── section-whats-included (.wi-section) ── */
.wi-section * { box-sizing: border-box; }

  .wi-section {
    background: var(--ivory);
    padding: 40px 40px;
    font-family: 'Jost', sans-serif;
    border-top: 1px solid var(--border);
  }

  .wi-section .wi-inner {
    max-width: 600px;
    margin: 0 auto;
  }

  .wi-section .wi-header {
    text-align: center;
    margin-bottom: 36px;
  }

  .wi-section .wi-eyebrow {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--mauve-mid);
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
  .wi-section .wi-eyebrow::before,
  .wi-section .wi-eyebrow::after {
    content: '';
    display: inline-block;
    width: 24px;
    height: 1px;
    background: var(--mauve);
  }

  .wi-section .wi-headline {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: clamp(26px, 3vw, 34px);
    font-weight: 400;
    font-style: italic;
    color: var(--rose-deep);
    line-height: 1.15;
    margin: 0;
  }

  .wi-section .wi-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 20px;
  }

  .wi-section .wi-row {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    background: #fff;
    border: 1px solid var(--border);
    border-radius: 14px;
  }

  .wi-section .wi-row--featured {
    border: 2px solid var(--rose);
  }

  .wi-section .wi-icon {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: var(--blush);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  .wi-section .wi-icon svg {
    width: 18px;
    height: 18px;
    stroke: var(--rose);
    fill: none;
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .wi-section .wi-text { flex: 1; }

  .wi-section .wi-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--text-main);
    margin: 0 0 2px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
  }

  .wi-section .wi-badge {
    font-size: 10px;
    font-weight: 500;
    background: var(--blush);
    color: var(--rose);
    padding: 2px 9px;
    border-radius: 20px;
    letter-spacing: .04em;
    white-space: nowrap;
  }

  .wi-section .wi-desc {
    font-size: 12px;
    color: var(--text-light);
    margin: 0;
    font-weight: 300;
    line-height: 1.5;
  }

  .wi-section .wi-fsa {
    padding: 11px 16px;
    background: var(--blush-bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .wi-section .wi-fsa svg {
    width: 14px;
    height: 14px;
    stroke: var(--mauve-mid);
    fill: none;
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
    flex-shrink: 0;
  }
  .wi-section .wi-fsa p {
    font-size: 12px;
    color: var(--text-mid);
    margin: 0;
    font-weight: 300;
  }
  .wi-section .wi-fsa strong {
    color: var(--rose-deep);
    font-weight: 500;
  }

  @media (max-width: 768px) {
    .wi-section { padding: 56px 20px; }
  }

/* ── section-bundle-cards_1__1_ (second block) ── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;1,400&family=Jost:wght@300;400;500;600&display=swap');

  .bc-wrap {
    background: var(--bc-bg);
    padding: var(--bc-py) 20px;
    font-family: 'Jost', sans-serif;
    color: var(--bc-text);
    box-sizing: border-box;
  }

  .bc-header { text-align: center; margin-bottom: 32px; }
  .bc-eyebrow {
    font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
    color: var(--bc-accent); font-weight: 500; margin-bottom: 8px;
  }
  .bc-headline {
    font-family: 'Cormorant Garamond', serif; font-size: 30px; font-weight: 500;
    color: var(--bc-text); line-height: 1.2; margin-bottom: 10px;
  }
  .bc-headline em { font-style: italic; color: var(--bc-accent); }
  .bc-sub {
    font-size: 14px; color: var(--bc-text-mid); line-height: 1.6;
    max-width: 480px; margin: 0 auto;
  }

  .bc-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: var(--bc-gap); max-width: 900px; margin: 0 auto;
  }
  @media (max-width: 700px) {
    .bc-grid { grid-template-columns: 1fr; max-width: 420px; }
  }

  .bc-card {
    border-radius: var(--bc-radius); overflow: hidden;
    border: 1.5px solid var(--bc-card-border); background: var(--bc-card-bg);
    display: flex; flex-direction: column;
    cursor: pointer;
    transition: box-shadow .2s, transform .15s;
    -webkit-tap-highlight-color: transparent;
    user-select: none;
    -webkit-user-select: none;
  }
  .bc-card:hover {
    box-shadow: 0 4px 20px rgba(44,26,34,.1);
    transform: translateY(-2px);
  }
  .bc-card.bc-featured {
    border: 2px solid var(--bc-feat-border);
    background: var(--bc-feat-card-bg);
  }
  .bc-card.bc-selected {
    border-color: var(--bc-feat-border) !important;
    box-shadow: 0 0 0 3px rgba(139,65,87,.18), 0 6px 24px rgba(44,26,34,.12);
    transform: translateY(-3px);
  }
  .bc-card.bc-selected .bc-btn {
    background: var(--bc-accent-deep);
  }
  .bc-card.bc-selected .bc-img-wrap::after {
    content: '✓';
    position: absolute; top: 12px; right: 12px;
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--bc-feat-border); color: #fff;
    font-size: 15px; font-weight: 700;
    display: block;
    line-height: 28px;
    text-align: center;
    z-index: 2;
  }

  .bc-img-wrap {
    position: relative; aspect-ratio: 4 / 3; overflow: hidden;
    background: var(--bc-img-bg); display: flex; align-items: center; justify-content: center;
  }
  .bc-card.bc-featured .bc-img-wrap { background: var(--bc-feat-img-bg); }
  .bc-img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .bc-img-placeholder {
    font-size: 12px; color: var(--bc-text-light);
    text-align: center; padding: 20px; line-height: 1.6;
  }
  .bc-card.bc-featured .bc-img-placeholder { color: var(--bc-text-mid); }

  .bc-badge {
    position: absolute; top: 12px; left: 12px;
    background: var(--bc-badge-bg); color: var(--bc-badge-text);
    font-size: 10px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
    padding: 4px 12px; border-radius: 20px; white-space: nowrap; z-index: 1;
  }
  .bc-card.bc-featured .bc-badge {
    background: var(--bc-feat-badge-bg); color: var(--bc-feat-badge-text);
  }

  .bc-body { padding: 18px 18px 22px; display: flex; flex-direction: column; flex: 1; }
  .bc-category {
    font-size: 10px; letter-spacing: .1em; text-transform: uppercase;
    color: var(--bc-text-light); font-weight: 500; margin-bottom: 5px;
  }
  .bc-title {
    font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 500;
    color: var(--bc-text); line-height: 1.2; margin-bottom: 6px;
  }
  .bc-desc { font-size: 12.5px; color: var(--bc-text-mid); line-height: 1.55; margin-bottom: 14px; }

  .bc-price-row { display: flex; align-items: baseline; flex-wrap: wrap; gap: 6px; margin-bottom: 4px; }
  .bc-price {
    font-family: 'Cormorant Garamond', serif; font-size: 28px;
    font-weight: 400; color: var(--bc-text); line-height: 1;
  }
  .bc-strike { font-size: 13px; color: var(--bc-strike); text-decoration: line-through; }
  .bc-save {
    font-size: 11px; font-weight: 600; background: var(--bc-save-bg); color: var(--bc-save-text);
    padding: 3px 9px; border-radius: 20px; white-space: nowrap;
  }
  .bc-per-unit { font-size: 11.5px; color: var(--bc-text-light); margin-bottom: 14px; }

  .bc-bullets { list-style: none; display: flex; flex-direction: column; gap: 7px; margin-bottom: 18px; flex: 1; }
  .bc-bullets li {
    display: flex; align-items: flex-start; gap: 8px; font-size: 12.5px;
    color: var(--bc-text); line-height: 1.45; background: var(--bc-bullet-bg);
    border-radius: 8px; padding: 7px 10px;
  }
  .bc-bullets li::before {
    content: '✓'; color: var(--bc-accent); font-weight: 600;
    flex-shrink: 0; font-size: 11px; margin-top: 1px;
  }
  .bc-card.bc-featured .bc-bullets li { background: var(--bc-feat-bullet-bg); }

  .bc-btn {
    display: block; width: 100%; background: var(--bc-btn-bg); color: var(--bc-btn-text);
    font-family: 'Jost', sans-serif; font-size: 13px; font-weight: 600;
    letter-spacing: .06em; text-transform: uppercase; border: none;
    border-radius: 50px; padding: 13px 20px; cursor: pointer;
    transition: background .18s, transform .1s; margin-top: auto;
    -webkit-tap-highlight-color: transparent;
  }
  .bc-btn:hover { background: var(--bc-btn-hover); }
  .bc-btn:active { transform: scale(.98); }
  .bc-btn:disabled { opacity: .6; cursor: not-allowed; }

  .bc-crosslink {
    text-align: center; font-size: 12px; color: var(--bc-link);
    text-decoration: underline; margin-top: 10px; cursor: pointer;
  }

  .bc-below {
    text-align: center; font-size: 12px; color: var(--bc-text-light);
    margin-top: 20px; max-width: 480px; margin-left: auto; margin-right: auto; line-height: 1.6;
  }

  /* ── URGENCY STRIP ── */
  .bc-wrap .bc-urgency {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 9px 16px;
    background: #fff8f0;
    border: 1px solid #e8c99a;
    border-radius: 6px;
    margin: 12px auto 0;
    max-width: 480px;
    font-family: 'Jost', sans-serif;
    font-size: 12px;
    color: #5a3a28;
    letter-spacing: .01em;
    line-height: 1.4;
    text-align: center;
  }
  .bc-wrap .bc-urgency__timer {
    font-weight: 600;
    color: #6B2E43;
    letter-spacing: .03em;
  }

  .bc-empty {
    text-align: center; padding: 40px; color: var(--bc-text-light); font-size: 13px;
    border: 2px dashed var(--bc-card-border); border-radius: var(--bc-radius);
    max-width: 600px; margin: 0 auto;
  }

/* ── section-discount-bar (second block) ── */
/* ── Wrapper ── */
  .ab-wrap {
    background: var(--ab-bg);
    color: var(--ab-text);
    font-family: 'Jost', sans-serif;
    font-size: var(--ab-font-size);
    line-height: 1.4;
    width: 100%;
    z-index: 1;
  }

  .ab-sticky {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 9999;
  }

  /* Push page content down so the fixed bar doesn't overlap it */
  body:has(.ab-sticky) {
    padding-top: var(--ab-bar-height, 60px);
  }

  /* ── Main bar ── */
  .ab-main {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px 12px;
    padding: var(--ab-py) 20px;
    position: relative;
  }

  /* ── Occasion label ── */
  .ab-occasion {
    font-weight: 500;
    letter-spacing: .03em;
  }

  /* ── Discount badge ── */
  .ab-badge {
    background: var(--ab-badge-bg);
    color: var(--ab-badge-text);
    font-size: calc(var(--ab-font-size) - 1px);
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: 2px 9px;
    border-radius: 3px;
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* ── Divider dot ── */
  .ab-divider {
    color: var(--ab-divider);
    flex-shrink: 0;
    font-size: calc(var(--ab-font-size) + 2px);
    line-height: 1;
    opacity: .6;
  }

  /* ── Message ── */
  .ab-message {
    letter-spacing: .01em;
  }
  .ab-link {
    color: var(--ab-link);
    text-decoration: none;
  }
  .ab-link:hover { text-decoration: underline; }
  .ab-link-label {
    font-weight: 600;
    white-space: nowrap;
  }

  /* ── Timer ── */
  .ab-timer {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    background: var(--ab-timer-bg);
    color: var(--ab-timer-text);
    padding: 3px 10px;
    border-radius: 4px;
    flex-shrink: 0;
  }
  .ab-timer-unit {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
  }
  .ab-timer-num {
    font-weight: 600;
    font-size: calc(var(--ab-font-size) + 1px);
    font-variant-numeric: tabular-nums;
    letter-spacing: .03em;
  }
  .ab-timer-label {
    font-size: calc(var(--ab-font-size) - 3px);
    opacity: .7;
    letter-spacing: .06em;
    text-transform: uppercase;
    margin-top: 1px;
  }
  .ab-timer-colon {
    font-weight: 600;
    margin-bottom: 4px;
    opacity: .7;
  }
  .ab-timer-expired {
    font-weight: 500;
    font-style: italic;
  }
  .ab-hidden { display: none !important; }

  /* ── Close button ── */
  .ab-close {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: var(--ab-text);
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    opacity: .5;
    padding: 4px 6px;
    transition: opacity .15s;
  }
  .ab-close:hover { opacity: 1; }

  /* ── Ticker ── */
  .ab-ticker-wrap {
    background: var(--ab-ticker-bg);
    overflow: hidden;
    padding: 5px 0;
  }
  .ab-ticker {
    display: flex;
    width: max-content;
    animation: ab-scroll 28s linear infinite;
  }
  .ab-ticker:hover { animation-play-state: paused; }
  .ab-ticker-inner {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    padding-right: 40px;
  }
  .ab-tick {
    color: var(--ab-ticker-text);
    font-size: calc(var(--ab-font-size) - 1px);
    letter-spacing: .05em;
    white-space: nowrap;
    padding: 0 6px;
    font-weight: 400;
  }
  .ab-tick-sep {
    color: var(--ab-ticker-text);
    opacity: .35;
    font-size: 8px;
    padding: 0 6px;
  }
  @keyframes ab-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
  }

  /* ── Mobile ── */
  @media (max-width: 640px) {
    .ab-main { gap: 6px 8px; }
    .ab-close { right: 8px; }
    .ab-ticker { animation-duration: 20s; }
  }
