/* ═══════════════════════════════════════════════════════════════════════
   CardToDeal v2 — components.css
   Reusable UI components. Tokens only (no raw hex, no font names).
   Load order: tokens.css → global.css → components.css
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Buttons ────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  border-radius: var(--r-sm);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  transition: filter var(--dur-fast) var(--ease-out-quart),
              transform var(--dur-fast) var(--ease-out-quart),
              background var(--dur-fast) var(--ease-out-quart),
              border-color var(--dur-fast) var(--ease-out-quart);
}
.btn:hover { text-decoration: none; }
.btn:active { transform: translateY(1px); }

.btn--primary {
  background: var(--acc);
  color: var(--on-acc);
  border: var(--bw2) solid var(--a2);
  box-shadow: var(--sh);
}
.btn--primary:hover { filter: brightness(1.08); color: var(--on-acc); transform: translateY(-1px); }
.btn--primary:disabled { background: var(--s3); border-color: var(--bdr); color: var(--t3); box-shadow: none; transform: none; filter: none; }

.btn--ghost {
  background: transparent;
  color: var(--t2);
  border: var(--bw) solid var(--bdr);
}
.btn--ghost:hover { background: var(--s2); color: var(--tx); }

/* button placed on top of a green/accent panel */
.btn--on-accent {
  background: var(--on-acc);
  color: var(--acc);
  border: none;
}
.btn--on-accent:hover { filter: brightness(0.96); color: var(--acc); }

.btn--block { width: 100%; }
.btn--lg { padding: var(--sp-4) var(--sp-6); font-size: var(--fs-md); }
.btn--sm { padding: var(--sp-2) var(--sp-3); font-size: var(--fs-xs); }

/* ── Badges ─────────────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 2px var(--sp-2);
  border-radius: var(--r-xs);
  font-size: var(--fs-2xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}
.badge--free { background: var(--acc); color: var(--on-acc); }
.badge--optional { background: var(--fade); color: var(--acc); letter-spacing: 0.04em; }

/* ── Card ───────────────────────────────────────────────────────────── */
.card {
  background: var(--sur);
  border: var(--bw) solid var(--bdr);
  border-radius: var(--r-lg);
  box-shadow: var(--sh);
  transition: transform var(--dur-base) var(--ease-out-quart),
              box-shadow var(--dur-base) var(--ease-out-quart),
              border-color var(--dur-base) var(--ease-out-quart);
}
.card--interactive:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh2);
  border-color: var(--acc);
}

/* ═══ NAV ════════════════════════════════════════════════════════════ */
.nav {
  position: sticky;
  top: 0;
  z-index: var(--z-nav);
  background: var(--sur);
  border-bottom: var(--bw3) solid var(--bdr);
}
.nav__inner {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
  height: 54px;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--sp-4);
}
.nav__logo {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-display);
  font-size: 1.0625rem;
  font-weight: var(--fw-display);
  letter-spacing: var(--ls-snug);
  color: var(--tx);
  flex-shrink: 0;
}
.nav__logo:hover { color: var(--tx); }
.nav__links { display: flex; align-items: center; gap: 2px; flex: 1; }
.nav__item { position: relative; }
.nav__link {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-sm);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--t2);
  white-space: nowrap;
}
.nav__link:hover { background: var(--s2); color: var(--tx); }
.nav__caret { font-size: 0.6rem; transition: transform var(--dur-base) var(--ease-out-quart); }
.nav__item:hover .nav__caret { transform: rotate(180deg); }

.mega {
  position: absolute;
  top: calc(100% + var(--sp-2));
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  min-width: 500px;
  padding: var(--sp-4);
  background: var(--sur);
  border: var(--bw2) solid var(--bdr);
  border-radius: var(--r-lg);
  box-shadow: var(--sh2);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--dur-base) var(--ease-out-quart),
              transform var(--dur-base) var(--ease-out-quart),
              visibility var(--dur-base);
  z-index: var(--z-mega);
}
.nav__item:hover .mega,
.nav__item:focus-within .mega { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.mega__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
.mega__col-title {
  font-size: var(--fs-2xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--t3);
  margin-bottom: var(--sp-2);
  padding-bottom: var(--sp-1);
  border-bottom: var(--bw) solid var(--b2);
}
.mega__link {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-1) var(--sp-2);
  border-radius: var(--r-xs);
  font-size: var(--fs-xs);
  color: var(--t2);
}
.mega__link:hover { background: var(--s2); color: var(--tx); }
.mega__icon { flex-shrink: 0; width: 16px; height: 16px; color: var(--acc); }

.nav__right { display: flex; align-items: center; gap: var(--sp-2); margin-left: auto; }
.nav__ext {
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--r-sm);
  font-size: var(--fs-xs);
  font-weight: var(--fw-medium);
  color: var(--t3);
  border: var(--bw) solid var(--b2);
  white-space: nowrap;
}
.nav__ext:hover { color: var(--tx); border-color: var(--bdr); background: var(--s2); }
.nav__cta {
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--r-sm);
  background: var(--acc);
  color: var(--on-acc);
  border: var(--bw2) solid var(--a2);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  white-space: nowrap;
  flex-shrink: 0;
  transition: filter var(--dur-fast) var(--ease-out-quart);
}
.nav__cta:hover { filter: brightness(1.08); color: var(--on-acc); }

/* Theme switcher dots */
.themes { display: flex; gap: var(--sp-1); align-items: center; padding-inline: var(--sp-1); }
.tdot {
  width: 14px; height: 14px;
  border-radius: var(--r-pill);
  border: var(--bw2) solid transparent;
  cursor: pointer;
  transition: transform var(--dur-fast) var(--ease-out-quart), border-color var(--dur-fast);
}
.tdot:hover { transform: scale(1.25); }
.tdot--on { border-color: var(--tx); }
.tdot[data-theme-dot="sage"]  { background: oklch(0.523 0.099 152); }
.tdot[data-theme-dot="dark"]  { background: oklch(0.235 0.038 258); }
.tdot[data-theme-dot="light"] { background: oklch(0.92 0.004 230); }

/* Hamburger */
.hamburger { display: none; flex-direction: column; gap: 4px; padding: var(--sp-2); color: var(--tx); }
.hamburger__bar { display: block; width: 20px; height: 2px; background: currentColor; border-radius: var(--r-pill); transition: transform var(--dur-base) var(--ease-out-quart), opacity var(--dur-base); }
.hamburger--open .hamburger__bar:nth-child(1) { transform: rotate(45deg) translate(4px, 4px); }
.hamburger--open .hamburger__bar:nth-child(2) { opacity: 0; }
.hamburger--open .hamburger__bar:nth-child(3) { transform: rotate(-45deg) translate(4px, -4px); }

/* Mega menus need room: collapse to hamburger below 1025px.
   Hide the nav CTA too (it's in the mobile menu) so the bar never overflows. */
@media (max-width: 1024px) {
  .nav__links, .nav__ext, .themes, .nav__cta { display: none; }
  .hamburger { display: flex; }
}

/* ═══ MOBILE MENU ════════════════════════════════════════════════════ */
.mobnav {
  position: fixed;
  inset: 0;
  z-index: var(--z-menu);
  display: none;
  flex-direction: column;
  background: var(--sur);
  overflow-y: auto;
}
.mobnav--open { display: flex; }
.mobnav__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: var(--bw2) solid var(--bdr);
}
.mobnav__logo { font-family: var(--font-display); font-size: 1.0625rem; font-weight: var(--fw-display); color: var(--tx); }
.mobnav__close { font-size: 1.4rem; color: var(--t3); padding: 0 var(--sp-1); line-height: 1; }
.mobnav__body { flex: 1; padding: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-1); }
.mobnav__section {
  font-size: var(--fs-2xs); font-weight: var(--fw-bold); letter-spacing: var(--ls-wide);
  text-transform: uppercase; color: var(--t3); padding: var(--sp-2) var(--sp-3) var(--sp-1);
}
.mobnav__link {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3); border-radius: var(--r-md);
  font-size: var(--fs-lg); font-weight: var(--fw-semibold); color: var(--tx);
}
.mobnav__link:hover { background: var(--s2); color: var(--tx); }
.mobnav__icon { width: 22px; height: 22px; color: var(--acc); flex-shrink: 0; }
.mobnav__divider { height: var(--bw); background: var(--b2); margin-block: var(--sp-2); }
.mobnav__themes { display: flex; gap: var(--sp-3); align-items: center; padding: var(--sp-2) var(--sp-3); }
.mobnav__themes .tdot { width: 24px; height: 24px; }
.mobnav__foot { padding: var(--sp-4); border-top: var(--bw2) solid var(--bdr); }

/* ═══ ANNOUNCEMENT STRIP ═════════════════════════════════════════════ */
.hstrip {
  background: var(--acc);
  border-bottom: var(--bw3) solid var(--a2);
  padding: var(--sp-2) var(--sp-4);
  text-align: center;
}
.hstrip__text { font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--on-acc); }
.hstrip__sub { opacity: 0.78; font-weight: var(--fw-regular); margin-left: var(--sp-2); }
@media (max-width: 480px) { .hstrip__sub { display: none; } }

/* ═══ AD SLOTS ═══════════════════════════════════════════════════════ */
.adwrap { text-align: center; }
.ad__label {
  font-size: var(--fs-2xs); letter-spacing: var(--ls-wide); text-transform: uppercase;
  color: var(--t3); margin-bottom: var(--sp-1);
}
.ad {
  display: inline-block;
  background: var(--s2);
  border: var(--bw) dashed var(--bdr);
  border-radius: var(--r-xs);
  overflow: hidden;
}
.ad--leaderboard { width: 728px; height: 90px; }
.ad--rect { width: 300px; height: 250px; }
.ad--halfpage { width: 300px; height: 600px; }
.ad--responsive { display: block; width: 100%; }
.ad--banner { width: 320px; height: 50px; }
.adtop { padding: var(--sp-2) var(--sp-4); background: var(--sur); border-bottom: var(--bw) solid var(--b2); }
@media (max-width: 860px) { .adtop { display: none; } }

.ad-sticky {
  position: fixed; bottom: 0; left: 0; right: 0;
  z-index: var(--z-sticky-ad);
  display: none; justify-content: center;
  padding: var(--sp-1);
  background: var(--sur);
  border-top: var(--bw3) solid var(--bdr);
}
.ad-sticky__close { position: absolute; top: 2px; right: var(--sp-2); color: var(--t3); font-size: 0.85rem; }
@media (max-width: 600px) { .ad-sticky { display: flex; } }

/* ═══ HERO ═══════════════════════════════════════════════════════════ */
.hero { padding-block: var(--sp-6) var(--sp-8); }
.hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-7);
  align-items: start;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--sp-5);
}
.hero__scanner { position: sticky; top: 70px; display: flex; flex-direction: column; gap: var(--sp-4); }

.hero__title { font-size: var(--fs-3xl); margin-bottom: var(--sp-3); }
.hero__title-em { color: var(--acc); }  /* emphasis via accent; Bricolage has no italic */
.hero__sub { font-size: var(--fs-md); color: var(--t2); margin-bottom: var(--sp-5); max-width: 42ch; }

.scancount {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--r-pill);
  background: var(--fade);
  border: var(--bw) solid var(--bdr);
  font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--acc);
  margin-bottom: var(--sp-5);
}
.scancount__dot { width: 7px; height: 7px; border-radius: var(--r-pill); background: var(--grn); animation: ctd-pulse 2s infinite; }

/* Animated extracted-data preview */
.cardpreview {
  position: relative;
  background: var(--sur);
  border: var(--bw2) solid var(--bdr);
  border-radius: var(--r-lg);
  box-shadow: var(--sh);
  padding: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-5);
}
.cardpreview__tag {
  position: absolute; top: var(--sp-2); right: var(--sp-3);
  font-size: var(--fs-2xs); font-weight: var(--fw-bold); letter-spacing: var(--ls-wide);
  color: var(--t3); opacity: 0.45;
}
.cardpreview__row { display: flex; align-items: flex-start; gap: var(--sp-2); padding-block: var(--sp-2); border-bottom: var(--bw) solid var(--b2); }
.cardpreview__row:last-child { border-bottom: none; }
.cardpreview__icon { width: 18px; height: 18px; color: var(--acc); flex-shrink: 0; margin-top: 2px; }
.cardpreview__key { font-size: var(--fs-2xs); font-weight: var(--fw-bold); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--t3); }
.cardpreview__val { font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--tx); transition: opacity var(--dur-base) var(--ease-out-quart); }
.cardpreview__val2 { font-size: var(--fs-xs); color: var(--t3); transition: opacity var(--dur-base) var(--ease-out-quart); }
.cardpreview--fading .cardpreview__val,
.cardpreview--fading .cardpreview__val2 { opacity: 0; }

/* VynDeal pitch panel (Committed brand color = voice) */
.pitch {
  background: linear-gradient(135deg, var(--acc), var(--a2));
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-5);
  color: var(--on-acc);
}
.pitch__title { font-family: var(--font-body); font-size: var(--fs-lg); font-weight: var(--fw-bold); color: var(--on-acc); margin-bottom: var(--sp-1); }
.pitch__sub { font-size: var(--fs-sm); opacity: 0.85; margin-bottom: var(--sp-4); }
.pitch__feats { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-top: var(--sp-3); }
.pitch__feat { background: oklch(1 0 0 / 0.18); border-radius: var(--r-xs); padding: 2px var(--sp-2); font-size: var(--fs-2xs); font-weight: var(--fw-semibold); }

/* ═══ SCANNER ════════════════════════════════════════════════════════ */
.scanner {
  background: var(--sur);
  border: var(--bw3) solid var(--acc);
  border-radius: var(--r-xl);
  box-shadow: var(--sh2);
  overflow: hidden;
}
.scanner__uz { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: var(--sp-6) var(--sp-5); text-align: center; cursor: pointer; border-bottom: var(--bw3) solid var(--b2); transition: background var(--dur-fast) var(--ease-out-quart); }
.scanner__uz:hover, .scanner__uz.is-drag { background: var(--s2); }
.uz__input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.uz__icon { width: 48px; height: 48px; margin: 0 auto var(--sp-3); display: flex; align-items: center; justify-content: center; border-radius: var(--r-lg); background: var(--fade); border: var(--bw2) solid var(--bdr); color: var(--acc); transition: transform var(--dur-base) var(--ease-out-quart); }
.scanner__uz:hover .uz__icon { transform: scale(1.08) rotate(-4deg); }
.uz__title { font-size: var(--fs-md); font-weight: var(--fw-bold); color: var(--tx); margin-bottom: var(--sp-1); }
.uz__sub { font-size: var(--fs-xs); color: var(--t3); }
.uz__sub b { color: var(--acc); }

.scanner__preview { position: relative; border-bottom: var(--bw3) solid var(--b2); }
.preview__img { width: 100%; max-height: 200px; object-fit: contain; background: var(--s2); }
.preview__clear { position: absolute; top: var(--sp-2); right: var(--sp-2); width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; border-radius: var(--r-pill); background: oklch(0.15 0.02 258 / 0.65); color: var(--on-acc); }

.scanner__camera { padding: var(--sp-2) var(--sp-4); border-bottom: var(--bw3) solid var(--b2); }
.camera__btn { width: 100%; min-height: 48px; display: flex; align-items: center; justify-content: center; padding: var(--sp-3) var(--sp-4); border-radius: var(--r-sm); border: var(--bw2) dashed var(--bdr); background: var(--s2); color: var(--t2); font-size: var(--fs-sm); font-weight: var(--fw-semibold); }
.camera__btn:hover { background: var(--s3); }
.scanner__camera-input { display: none; }

.scanner__scanrow { padding: var(--sp-4); border-bottom: var(--bw3) solid var(--b2); }

.scanner__loader { padding: var(--sp-7) var(--sp-5); text-align: center; }
.loader__spin { width: 34px; height: 34px; margin: 0 auto var(--sp-3); border-radius: var(--r-pill); border: 3px solid var(--b2); border-top-color: var(--acc); animation: ctd-spin 0.7s linear infinite; }
.loader__title { font-size: var(--fs-md); font-weight: var(--fw-bold); color: var(--tx); }
.loader__step { font-size: var(--fs-xs); color: var(--t3); margin-top: var(--sp-1); }

.results { padding: var(--sp-4); }
.results__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-3); }
.results__title { font-family: var(--font-body); font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--tx); }
.chip { font-size: var(--fs-2xs); font-weight: var(--fw-bold); padding: 3px var(--sp-2); border-radius: var(--r-pill); background: var(--fade); color: var(--acc); border: var(--bw) solid var(--bdr); }

.fields { display: flex; flex-direction: column; gap: var(--sp-1); margin-bottom: var(--sp-4); }
.field { display: flex; align-items: flex-start; gap: var(--sp-2); padding: var(--sp-2) var(--sp-3); border-radius: var(--r-sm); background: var(--s2); border: var(--bw) solid var(--b2); }
.field__icon { width: 18px; height: 18px; color: var(--acc); flex-shrink: 0; margin-top: 2px; }
.field__body { flex: 1; min-width: 0; }
.field__key { font-size: var(--fs-2xs); font-weight: var(--fw-bold); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--t3); }
.field__val { font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--tx); word-break: break-word; }
.field__extra { font-size: var(--fs-xs); color: var(--t3); margin-top: 2px; }
.field__copy { color: var(--t3); padding: 0 var(--sp-1); flex-shrink: 0; transition: color var(--dur-fast); }
.field__copy:hover { color: var(--acc); }

.results__actions { display: flex; gap: var(--sp-2); align-items: center; justify-content: space-between; flex-wrap: wrap; }
.results__actions-group { display: flex; gap: var(--sp-1); }

/* Result nudge strip (funnel CTA) */
.nudge { padding: var(--sp-3) var(--sp-4); background: var(--acc); border-top: var(--bw3) solid var(--a2); }
.nudge__inner { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.nudge__text { flex: 1; min-width: 0; color: var(--on-acc); }
.nudge__title { font-size: var(--fs-sm); font-weight: var(--fw-bold); margin-bottom: 2px; }
.nudge__sub { font-size: var(--fs-xs); opacity: 0.82; }

/* Save / email form */
.saveform { padding: var(--sp-4); border-top: var(--bw3) solid var(--b2); }
.saveform__title { font-family: var(--font-body); font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--tx); margin-bottom: var(--sp-1); }
.saveform__sub { font-size: var(--fs-xs); color: var(--t3); margin-bottom: var(--sp-3); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2); margin-bottom: var(--sp-3); }
.field-group { display: flex; flex-direction: column; gap: var(--sp-1); }
.field-label { font-size: var(--fs-2xs); font-weight: var(--fw-bold); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--t3); }
.input {
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-sm);
  border: var(--bw2) solid var(--bdr);
  background: var(--s2);
  color: var(--tx);
  font-size: var(--fs-sm);
  outline: none;
  transition: border-color var(--dur-fast) var(--ease-out-quart);
  -webkit-appearance: none;
  appearance: none;
}
.input:focus { border-color: var(--acc); }
.input::placeholder { color: var(--t3); }

.consent { display: flex; flex-direction: column; gap: var(--sp-2); padding: var(--sp-3); margin-bottom: var(--sp-3); background: var(--s2); border: var(--bw2) solid var(--b2); border-radius: var(--r-sm); }
.consent__row { display: flex; align-items: flex-start; gap: var(--sp-2); font-size: var(--fs-2xs); color: var(--t2); line-height: 1.5; cursor: pointer; }
.consent__check { width: 14px; height: 14px; margin-top: 2px; flex-shrink: 0; accent-color: var(--acc); cursor: pointer; }
.consent__row a { color: var(--acc); }

.msg { padding: var(--sp-2) var(--sp-3); border-radius: var(--r-sm); font-size: var(--fs-xs); line-height: 1.5; margin-top: var(--sp-2); }
.msg--ok { background: var(--fade); border: var(--bw) solid var(--bdr); color: var(--grn); }
.msg--err { background: oklch(0.6 0.16 25 / 0.1); border: var(--bw) solid oklch(0.6 0.16 25 / 0.28); color: var(--red); }

.ratebar { display: flex; align-items: center; gap: var(--sp-2); padding: var(--sp-2) var(--sp-4); border-top: var(--bw3) solid var(--b2); font-size: var(--fs-2xs); color: var(--t3); }
.ratebar__track { flex: 1; height: 3px; background: var(--s3); border-radius: var(--r-pill); overflow: hidden; }
.ratebar__fill { height: 100%; background: var(--acc); border-radius: var(--r-pill); transition: width var(--dur-slow) var(--ease-out-quart); }
.ratebar__link { color: var(--acc); font-weight: var(--fw-bold); }

.disclaimer { padding: var(--sp-2) var(--sp-4); border-top: var(--bw) solid var(--b2); font-size: var(--fs-2xs); color: var(--t3); line-height: 1.5; text-align: center; }

/* ═══ CROP OVERLAY ═══════════════════════════════════════════════════ */
.crop {
  position: fixed; inset: 0;
  z-index: var(--z-crop);
  display: none;
  flex-direction: column;
  background: oklch(0.13 0.02 258 / 0.84);
}
.crop--open { display: flex; }
.crop__nav { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-3) var(--sp-4); border-bottom: var(--bw) solid oklch(1 0 0 / 0.1); }
.crop__title { color: var(--on-acc); font-size: var(--fs-sm); font-weight: var(--fw-semibold); }
.crop__close { background: oklch(1 0 0 / 0.12); color: var(--on-acc); padding: var(--sp-1) var(--sp-2); border-radius: var(--r-xs); line-height: 1; }
.crop__orient { display: flex; gap: var(--sp-2); padding: var(--sp-2) var(--sp-3); }
.orient-btn { flex: 1; min-height: 36px; padding: var(--sp-2); border-radius: var(--r-sm); border: var(--bw2) solid oklch(1 0 0 / 0.25); background: oklch(1 0 0 / 0.08); color: oklch(1 0 0 / 0.7); font-size: var(--fs-sm); font-weight: var(--fw-semibold); }
.orient-btn--on { border-color: var(--acc); background: var(--acc); color: var(--on-acc); }
.crop__wrap { flex: 1; position: relative; display: flex; align-items: center; justify-content: center; overflow: hidden; min-height: 0; max-height: 52vh; }
.crop__img { max-width: 100%; max-height: 100%; object-fit: contain; user-select: none; -webkit-user-drag: none; }
.crop__rect { position: absolute; border: 3px solid var(--acc); box-shadow: 0 0 0 9999px oklch(0.13 0.02 258 / 0.55); box-sizing: border-box; cursor: move; touch-action: none; }
.crop__handle { position: absolute; width: 22px; height: 22px; background: var(--acc); border: 2px solid var(--sur); border-radius: var(--r-pill); touch-action: none; }
.crop__handle--tl { top: -11px; left: -11px; cursor: nwse-resize; }
.crop__handle--tr { top: -11px; right: -11px; cursor: nesw-resize; }
.crop__handle--bl { bottom: -11px; left: -11px; cursor: nesw-resize; }
.crop__handle--br { bottom: -11px; right: -11px; cursor: nwse-resize; }
.crop__actions { display: flex; gap: var(--sp-2); padding: var(--sp-2) var(--sp-3); padding-bottom: calc(var(--sp-2) + env(safe-area-inset-bottom)); border-top: var(--bw) solid oklch(1 0 0 / 0.1); }
.crop__skip { flex: 1; min-height: 44px; padding: var(--sp-3); border-radius: var(--r-sm); border: var(--bw2) solid oklch(1 0 0 / 0.25); background: oklch(1 0 0 / 0.08); color: oklch(1 0 0 / 0.85); font-size: var(--fs-sm); font-weight: var(--fw-semibold); }
.crop__use { flex: 2; min-height: 44px; padding: var(--sp-3); border-radius: var(--r-sm); background: var(--acc); color: var(--on-acc); font-size: var(--fs-md); font-weight: var(--fw-bold); }
.crop__use:hover { filter: brightness(1.08); }

/* ═══ SECTIONS: STEPS + FAQ ══════════════════════════════════════════ */
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--sp-3); }
.step { padding: var(--sp-4); }
.step__num { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; border-radius: var(--r-sm); background: var(--fade); border: var(--bw2) solid var(--bdr); font-family: var(--font-display); font-weight: var(--fw-bold); color: var(--acc); margin-bottom: var(--sp-3); }
.step__title { font-family: var(--font-body); font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--tx); margin-bottom: var(--sp-1); }
.step__desc { font-size: var(--fs-xs); color: var(--t2); }

.section__kicker { margin-bottom: var(--sp-2); }
.section__title { margin-bottom: var(--sp-6); }

.faq { max-width: 760px; }
.faq__item { border-bottom: var(--bw2) solid var(--b2); }
.faq__q { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); padding-block: var(--sp-3); font-family: var(--font-body); font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--tx); cursor: pointer; list-style: none; }
.faq__q::-webkit-details-marker { display: none; }
.faq__q::after { content: '+'; color: var(--acc); font-size: 1.1rem; flex-shrink: 0; }
.faq__item[open] .faq__q::after { content: '\2212'; }
.faq__a { font-size: var(--fs-sm); color: var(--t2); padding-bottom: var(--sp-3); line-height: var(--lh-relaxed); }

/* ═══ FOOTER ═════════════════════════════════════════════════════════ */
.footer { background: var(--sur); border-top: var(--bw3) solid var(--bdr); padding-block: var(--sp-6); }
.footer__grid { display: flex; flex-wrap: wrap; gap: var(--sp-6); align-items: flex-start; justify-content: space-between; max-width: var(--container); margin-inline: auto; padding-inline: var(--sp-4); }
.footer__logo { font-family: var(--font-display); font-size: var(--fs-lg); font-weight: var(--fw-display); color: var(--tx); display: block; margin-bottom: var(--sp-1); }
.footer__tagline { font-size: var(--fs-xs); color: var(--t3); max-width: 24ch; }
.footer__disclaimer { font-size: var(--fs-2xs); color: var(--t3); max-width: 32ch; margin-top: var(--sp-2); padding: var(--sp-2); background: var(--s2); border: var(--bw) solid var(--b2); border-radius: var(--r-sm); line-height: 1.5; }
.footer__cols { display: flex; gap: var(--sp-6); flex-wrap: wrap; }
.footer__col-title { font-size: var(--fs-2xs); font-weight: var(--fw-bold); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--t3); margin-bottom: var(--sp-2); }
.footer__link { display: block; font-size: var(--fs-xs); color: var(--t2); margin-bottom: var(--sp-1); }
.footer__link:hover { color: var(--acc); }
.footer__bottom { max-width: var(--container); margin: var(--sp-4) auto 0; padding: var(--sp-3) var(--sp-4) 0; border-top: var(--bw) solid var(--b2); display: flex; flex-wrap: wrap; gap: var(--sp-2); align-items: center; justify-content: space-between; font-size: var(--fs-2xs); color: var(--t3); }
.footer__bottom a { color: var(--t3); }
.footer__bottom a:hover { color: var(--acc); }

/* ═══ HERO FEATURE PILLS + CTA BAND ══════════════════════════════════ */
.feature-pills { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-bottom: var(--sp-5); }
.feature-pill { display: inline-flex; align-items: center; gap: var(--sp-1); padding: var(--sp-1) var(--sp-3); border-radius: var(--r-pill); background: var(--s2); border: var(--bw) solid var(--b2); font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--t2); }

.cta-band { background: linear-gradient(135deg, var(--acc), var(--a2)); color: var(--on-acc); text-align: center; }
.cta-band__inner { max-width: 720px; margin-inline: auto; padding-inline: var(--sp-4); }
.cta-band__title { font-size: var(--fs-2xl); color: var(--on-acc); margin-bottom: var(--sp-3); }
.cta-band__sub { font-size: var(--fs-md); opacity: 0.9; margin-bottom: var(--sp-5); }

/* ═══ FUNNEL: source chips · floating card stack · email modal ═══════ */
/* Source / exhibition chips — revealed after first scan */
.source-chips { display: none; flex-wrap: wrap; gap: var(--sp-2); padding: var(--sp-3) var(--sp-4); border-top: var(--bw3) solid var(--b2); }
.source-chips.is-visible { display: flex; animation: ctd-rise var(--dur-base) var(--ease-out-expo) both; }
.source-chips__label { width: 100%; font-size: var(--fs-2xs); font-weight: var(--fw-bold); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--t3); }
.chip-btn { padding: var(--sp-1) var(--sp-3); min-height: 32px; border-radius: var(--r-pill); border: var(--bw) solid var(--bdr); background: var(--s2); color: var(--t2); font-size: var(--fs-xs); font-weight: var(--fw-semibold); transition: background var(--dur-fast) var(--ease-out-quart), border-color var(--dur-fast), color var(--dur-fast); }
.chip-btn:hover { border-color: var(--acc); color: var(--tx); }
.chip-btn--on { background: var(--acc); color: var(--on-acc); border-color: var(--a2); }
.chip-input { padding: var(--sp-1) var(--sp-3); min-height: 32px; border-radius: var(--r-pill); border: var(--bw2) solid var(--acc); background: var(--sur); color: var(--tx); font-size: var(--fs-xs); outline: none; }

/* Floating card-stack badge + slide-up panel */
.cardstack-badge { position: fixed; right: var(--sp-4); bottom: var(--sp-4); z-index: var(--z-float); display: none; align-items: center; gap: var(--sp-2); padding: var(--sp-3) var(--sp-4); min-height: 44px; border-radius: var(--r-pill); background: var(--acc); color: var(--on-acc); box-shadow: var(--sh2); font-size: var(--fs-sm); font-weight: var(--fw-bold); }
.cardstack-badge.is-visible { display: inline-flex; animation: ctd-rise var(--dur-base) var(--ease-out-expo) both; }
.cardstack-panel { position: fixed; right: var(--sp-4); bottom: calc(var(--sp-4) + 60px); z-index: var(--z-float); width: min(340px, calc(100vw - var(--sp-6))); max-height: 60vh; display: none; flex-direction: column; background: var(--sur); border: var(--bw2) solid var(--bdr); border-radius: var(--r-lg); box-shadow: var(--sh2); overflow: hidden; }
.cardstack-panel.is-open { display: flex; animation: ctd-rise var(--dur-base) var(--ease-out-expo) both; }
.cardstack-panel__head { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-3) var(--sp-4); border-bottom: var(--bw) solid var(--b2); font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--tx); }
.cardstack-panel__close { color: var(--t3); min-width: 32px; min-height: 32px; }
.cardstack-list { overflow-y: auto; padding: var(--sp-2); display: flex; flex-direction: column; gap: var(--sp-1); }
.cardstack-empty { padding: var(--sp-5) var(--sp-4); text-align: center; font-size: var(--fs-xs); color: var(--t3); }
.cardstack-item { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-2); border-radius: var(--r-sm); }
.cardstack-item:hover { background: var(--s2); }
.cardstack-item__thumb { width: 46px; height: 30px; object-fit: cover; border-radius: var(--r-xs); border: var(--bw) solid var(--b2); background: var(--s2); flex-shrink: 0; }
.cardstack-item__body { flex: 1; min-width: 0; }
.cardstack-item__name { font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--tx); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cardstack-item__co { font-size: var(--fs-2xs); color: var(--t3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cardstack-item__del { color: var(--t3); min-width: 32px; min-height: 32px; flex-shrink: 0; }
.cardstack-item__del:hover { color: var(--red); }

/* Email-capture modal (fires when free limit hit) */
.emailmodal { position: fixed; inset: 0; z-index: var(--z-modal); display: none; align-items: center; justify-content: center; padding: var(--sp-4); background: oklch(0.13 0.02 258 / 0.6); }
.emailmodal.is-open { display: flex; animation: ctd-fade var(--dur-base) var(--ease-out-quart); }
.emailmodal__card { width: min(420px, 100%); max-height: 90vh; overflow-y: auto; position: relative; padding: var(--sp-6) var(--sp-5); background: var(--sur); border-radius: var(--r-xl); box-shadow: var(--sh2); }
.emailmodal__close { position: absolute; top: var(--sp-3); right: var(--sp-3); color: var(--t3); font-size: 1.2rem; min-width: 32px; min-height: 32px; }
.emailmodal__title { font-size: var(--fs-xl); margin-bottom: var(--sp-2); }
.emailmodal__sub { font-size: var(--fs-sm); color: var(--t2); margin-bottom: var(--sp-4); }
.emailmodal__thumbs { display: flex; gap: var(--sp-2); flex-wrap: wrap; margin-bottom: var(--sp-4); }
.emailmodal__thumb { width: 50px; height: 33px; object-fit: cover; border-radius: var(--r-xs); border: var(--bw) solid var(--b2); background: var(--s2); }
.emailmodal__fineprint { font-size: var(--fs-2xs); color: var(--t3); text-align: center; margin-top: var(--sp-3); }

/* ═══ MEGA MENU EXTRAS ═══════════════════════════════════════════════ */
.mega__cols--2 { grid-template-columns: 1fr 1fr; }
.mega--single { min-width: 280px; }
.mega--single .mega__cols { grid-template-columns: 1fr; }
.mega__link { align-items: flex-start; }
.mega__lt { display: block; font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--tx); }
.mega__ld { display: block; font-size: var(--fs-2xs); color: var(--t3); margin-top: 1px; }

/* ═══ SEO INTRO PARAGRAPH ════════════════════════════════════════════ */
.seo-intro { font-size: var(--fs-sm); color: var(--t2); max-width: var(--measure); margin-bottom: var(--sp-5); line-height: var(--lh-base); }

/* ═══ COOKIE CONSENT BANNER (GDPR) ═══════════════════════════════════ */
.cookie-banner { position: fixed; left: 0; right: 0; bottom: 0; z-index: var(--z-toast); display: none; gap: var(--sp-4); align-items: center; justify-content: center; flex-wrap: wrap; padding: var(--sp-3) var(--sp-4); padding-bottom: calc(var(--sp-3) + env(safe-area-inset-bottom)); background: var(--sur); border-top: var(--bw3) solid var(--bdr); box-shadow: var(--sh2); }
.cookie-banner.is-visible { display: flex; }
.cookie-banner__text { flex: 1; min-width: 240px; max-width: 62ch; font-size: var(--fs-xs); color: var(--t2); line-height: 1.5; }
.cookie-banner__text a { color: var(--acc); }
.cookie-banner__actions { display: flex; gap: var(--sp-2); flex-shrink: 0; }

/* ═══ READY TABLE (post-save VynDeal push) ═══════════════════════════ */
.ready { padding: var(--sp-4); border-top: var(--bw3) solid var(--b2); }
.ready__head { font-family: var(--font-body); font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--tx); margin-bottom: var(--sp-3); }
.ready__table { display: flex; flex-direction: column; gap: var(--sp-1); margin-bottom: var(--sp-4); }
.ready__row { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-2); border-radius: var(--r-sm); background: var(--s2); border: var(--bw) solid var(--b2); }
.ready__thumb { width: 46px; height: 30px; object-fit: cover; border-radius: var(--r-xs); border: var(--bw) solid var(--b2); background: var(--s3); flex-shrink: 0; }
.ready__info { flex: 1; min-width: 0; }
.ready__name { font-size: var(--fs-xs); font-weight: var(--fw-semibold); color: var(--tx); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ready__meta { font-size: var(--fs-2xs); color: var(--t3); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ready__followup { flex-shrink: 0; }

/* ═══ ARTICLE / EDITORIAL (content pages) ════════════════════════════ */
.breadcrumb { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-1); font-size: var(--fs-xs); color: var(--t3); margin-bottom: var(--sp-4); }
.breadcrumb a { color: var(--t3); }
.breadcrumb a:hover { color: var(--acc); }
.breadcrumb__sep { opacity: 0.5; }

.article-hero { padding-block: var(--sp-6) var(--sp-7); }
.article-hero__grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: var(--sp-7); align-items: start; max-width: var(--container); margin-inline: auto; padding-inline: var(--sp-5); }
.article-hero__scanner { position: sticky; top: 70px; display: flex; flex-direction: column; gap: var(--sp-3); }
.article-hero__scanner-label { font-size: var(--fs-2xs); font-weight: var(--fw-bold); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--t3); text-align: center; }
.hero-badge { display: inline-flex; align-items: center; gap: var(--sp-2); padding: var(--sp-1) var(--sp-3); border-radius: var(--r-pill); background: var(--fade); border: var(--bw) solid var(--bdr); font-size: var(--fs-2xs); font-weight: var(--fw-bold); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--acc); margin-bottom: var(--sp-4); }
.article-hero h1 { font-size: var(--fs-3xl); margin-bottom: var(--sp-4); }
.article-hero h1 em { font-style: normal; color: var(--acc); }
.hero-sub { font-size: var(--fs-lg); color: var(--t2); line-height: var(--lh-relaxed); max-width: 54ch; }

.article-body { max-width: 720px; margin-inline: auto; padding-inline: var(--sp-5); padding-block: var(--sp-2) var(--sp-7); }
.content-section { margin-bottom: var(--sp-6); }
.content-section h2 { font-size: var(--fs-2xl); letter-spacing: var(--ls-tight); margin-bottom: var(--sp-3); }
.content-section h3 { font-size: var(--fs-xl); margin-bottom: var(--sp-2); }
.content-section p { font-size: var(--fs-lg); color: var(--t2); line-height: var(--lh-relaxed); max-width: var(--measure); margin-bottom: var(--sp-3); }
.article-body a, .content-section a { color: var(--acc); font-weight: var(--fw-semibold); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 2px; }
.article-body a:hover, .content-section a:hover { color: var(--a2); }

.feature-list { list-style: none; display: flex; flex-direction: column; gap: var(--sp-3); margin-bottom: var(--sp-2); }
.feature-list li { position: relative; padding: var(--sp-3) var(--sp-4) var(--sp-3) var(--sp-6); background: var(--s2); border: var(--bw) solid var(--b2); border-radius: var(--r-md); font-size: var(--fs-md); color: var(--t2); }
.feature-list li::before { content: ''; position: absolute; left: var(--sp-3); top: 50%; width: 8px; height: 8px; margin-top: -4px; border-radius: var(--r-pill); background: var(--acc); }
.feature-list li strong { color: var(--tx); }

.pullquote { margin: var(--sp-6) 0; padding: var(--sp-5) var(--sp-6); border-radius: var(--r-lg); background: var(--s2); font-family: var(--font-display); font-size: var(--fs-xl); line-height: var(--lh-snug); color: var(--tx); }
.pullquote cite { display: block; margin-top: var(--sp-3); font-family: var(--font-body); font-size: var(--fs-sm); font-style: normal; color: var(--t3); }

.cta-card { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); flex-wrap: wrap; margin: var(--sp-6) 0; padding: var(--sp-5) var(--sp-6); border-radius: var(--r-lg); background: linear-gradient(135deg, var(--acc), var(--a2)); color: var(--on-acc); }
.cta-card-text h3 { font-family: var(--font-body); color: var(--on-acc); font-size: var(--fs-lg); margin-bottom: var(--sp-1); }
.cta-card-text p { color: var(--on-acc); opacity: 0.9; font-size: var(--fs-sm); margin: 0; max-width: 48ch; }

.stats-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-3); margin: var(--sp-6) 0; }
.stat { padding: var(--sp-5) var(--sp-4); text-align: center; background: var(--sur); border: var(--bw) solid var(--bdr); border-radius: var(--r-lg); box-shadow: var(--sh); transition: transform var(--dur-base) var(--ease-out-quart), box-shadow var(--dur-base) var(--ease-out-quart); }
.stat:hover { transform: translateY(-4px); box-shadow: var(--sh2); }
.stat-n { display: block; font-family: var(--font-display); font-size: var(--fs-3xl); font-weight: var(--fw-display-bold); color: var(--acc); line-height: 1; }
.stat-l { display: block; margin-top: var(--sp-2); font-size: var(--fs-xs); color: var(--t3); }

.related { margin: var(--sp-7) 0 var(--sp-6); }
.related h2 { font-size: var(--fs-xl); margin-bottom: var(--sp-4); }
.related-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--sp-3); }
.related-card { display: flex; flex-direction: column; gap: var(--sp-1); padding: var(--sp-4); background: var(--sur); border: var(--bw) solid var(--bdr); border-radius: var(--r-md); transition: transform var(--dur-base) var(--ease-out-quart), border-color var(--dur-base), box-shadow var(--dur-base); }
.related-card:hover { transform: translateY(-3px); border-color: var(--acc); box-shadow: var(--sh2); text-decoration: none; }
.related-card-label { font-size: var(--fs-2xs); font-weight: var(--fw-bold); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--t3); }
.related-card-title { font-size: var(--fs-sm); font-weight: var(--fw-semibold); color: var(--tx); }

.final-cta { margin: var(--sp-7) 0; padding: var(--sp-7) var(--sp-6); text-align: center; border-radius: var(--r-xl); background: var(--s2); border: var(--bw) solid var(--b2); }
.final-cta h2 { font-size: var(--fs-2xl); margin-bottom: var(--sp-3); }
.final-cta p { color: var(--t2); font-size: var(--fs-md); margin-bottom: var(--sp-5); max-width: 56ch; margin-inline: auto; }

/* SVG flow graphic frame */
.flowgraphic { margin: var(--sp-6) 0; padding: var(--sp-5); background: var(--sur); border: var(--bw) solid var(--bdr); border-radius: var(--r-lg); box-shadow: var(--sh); }
.flowgraphic svg { width: 100%; height: auto; display: block; }

/* Comparison table (compare/* pages) — premium, responsive, theme-aware */
.compare-wrap { margin: var(--sp-6) 0; overflow-x: auto; border: var(--bw) solid var(--bdr); border-radius: var(--r-lg); box-shadow: var(--sh); -webkit-overflow-scrolling: touch; }
.compare-table { width: 100%; border-collapse: collapse; font-size: var(--fs-sm); min-width: 520px; }
.compare-table caption { text-align: left; padding: var(--sp-4) var(--sp-5) 0; font-size: var(--fs-xs); color: var(--t3); }
.compare-table th, .compare-table td { padding: var(--sp-4) var(--sp-5); text-align: left; border-bottom: var(--bw) solid var(--bdr); vertical-align: top; }
.compare-table thead th { background: var(--s2); font-family: var(--font-display); font-weight: var(--fw-display); color: var(--tx); position: sticky; top: 0; }
.compare-table thead th.is-us { background: var(--acc); color: var(--on-acc); }
.compare-table tbody th { font-weight: var(--fw-semibold); color: var(--tx); white-space: normal; }
.compare-table tbody tr:nth-child(even) td, .compare-table tbody tr:nth-child(even) th { background: var(--s2); }
.compare-table td.is-us { color: var(--tx); font-weight: var(--fw-semibold); }
.compare-table .yes { color: var(--acc); font-weight: var(--fw-bold); }
.compare-table .no { color: var(--t3); }
.compare-table tbody tr:last-child td, .compare-table tbody tr:last-child th { border-bottom: none; }

/* Legacy button aliases used by ported content */
.btn-primary { display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2); padding: var(--sp-3) var(--sp-5); border-radius: var(--r-sm); background: var(--acc); color: var(--on-acc); border: var(--bw2) solid var(--a2); font-weight: var(--fw-semibold); font-size: var(--fs-sm); box-shadow: var(--sh); transition: filter var(--dur-fast) var(--ease-out-quart), transform var(--dur-fast) var(--ease-out-quart); }
.btn-primary:hover { filter: brightness(1.08); transform: translateY(-1px); color: var(--on-acc); text-decoration: none; }
.btn-outline { display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2); padding: var(--sp-3) var(--sp-5); border-radius: var(--r-sm); background: transparent; color: var(--acc); border: var(--bw2) solid var(--bdr); font-weight: var(--fw-semibold); font-size: var(--fs-sm); transition: background var(--dur-fast), border-color var(--dur-fast); }
.btn-outline:hover { background: var(--s2); border-color: var(--acc); text-decoration: none; }
.cta-card .btn-primary, .cta-card .btn-outline { background: var(--on-acc); color: var(--acc); border-color: transparent; box-shadow: none; }
/* keep on-panel buttons high-contrast on hover too (generic .btn-primary:hover would
   otherwise reset color back to --on-acc → light text on the light button = invisible) */
.cta-card .btn-primary:hover, .cta-card .btn-outline:hover { background: var(--on-acc); color: var(--acc); border-color: transparent; filter: brightness(0.95); }

/* Newsletter band (injected by footer.js) */
.newsletter { background: var(--s2); border-top: var(--bw) solid var(--b2); }
.newsletter__inner { max-width: 640px; margin-inline: auto; padding: var(--sp-6) var(--sp-5); text-align: center; }
.newsletter__title { font-family: var(--font-display); font-size: var(--fs-xl); color: var(--tx); margin-bottom: var(--sp-2); }
.newsletter__sub { font-size: var(--fs-sm); color: var(--t2); margin-bottom: var(--sp-4); }
.newsletter__form { display: flex; gap: var(--sp-2); max-width: 440px; margin-inline: auto; flex-wrap: wrap; }
.newsletter__input { flex: 1; min-width: 200px; padding: var(--sp-3) var(--sp-4); border-radius: var(--r-sm); border: var(--bw2) solid var(--bdr); background: var(--sur); color: var(--tx); font-size: var(--fs-sm); outline: none; }
.newsletter__input:focus { border-color: var(--acc); }
.newsletter__msg { font-size: var(--fs-xs); color: var(--grn); margin-top: var(--sp-2); min-height: 1em; }

@media (max-width: 860px) {
  .article-hero__grid { grid-template-columns: 1fr; gap: var(--sp-5); }
  .article-hero__scanner { position: static; order: -1; }   /* scanner-first on mobile */
  .stats-row { grid-template-columns: 1fr; }
  .cta-card { flex-direction: column; align-items: flex-start; }
}

/* ═══ KEYFRAMES ══════════════════════════════════════════════════════ */
@keyframes ctd-pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.5; transform: scale(0.8); } }
@keyframes ctd-spin { to { transform: rotate(360deg); } }
@keyframes ctd-fade { from { opacity: 0; } to { opacity: 1; } }

/* ═══ RESPONSIVE ═════════════════════════════════════════════════════ */
@media (max-width: 860px) {
  .hero__grid { grid-template-columns: 1fr; gap: var(--sp-5); }
  /* HARD RULE: scanner sits in the first viewport on mobile (within ~80px of top).
     Scanner is DOM-second (H1 stays early for SEO) but order:-1 puts it visually first. */
  .hero__scanner { position: static; order: -1; }
  .hero__copy { order: 1; }
  .hero { padding-block: var(--sp-3) var(--sp-6); }
  .hstrip { display: none; }       /* keep the scanner directly under the 54px nav */
  .mega { min-width: 0; }
}
@media (max-width: 480px) {
  .form-grid { grid-template-columns: 1fr; }
  .hero { padding-block: var(--sp-4) var(--sp-6); }
}
