/* =============================================================
   Dr.B Medspa — Design A · Keystroke Counsel remapped to [data-design="a"].dq-design
   All selectors scoped to [data-design="a"] — ZERO keystroke-counsel scopes.
   ~12 color tokens exposed on [data-design="a"] block.
   ============================================================= */

/* ── Token block ────────────────────────────────────────────── */
[data-design="a"] {
  /* Color tokens (12) */
  --design-a-primary:   #6D43F7;   /* signal violet — THE accent */
  --kc-bg:              #F6F7FB;   /* cool fog canvas */
  --kc-surface:         #FFFFFF;   /* card / sheet */
  --kc-ink:             #0E1116;   /* primary text */
  --kc-ink-2:           #3B4252;   /* secondary text */
  --kc-muted:           #6B7280;   /* captions, meta */
  --kc-line:            #E5E7EE;   /* hairlines */
  --kc-line-soft:       #EFF1F6;   /* row dividers */
  --kc-accent:          #6D43F7;   /* = --design-a-primary */
  --kc-accent-soft:     #EEE9FE;   /* accent surface tint */
  --kc-accent-ink:      #FFFFFF;   /* fg on accent */
  --kc-status-ok:       #16A34A;   /* success */

  /* Typography */
  --kc-font-display: 'Söhne', 'Inter Display', -apple-system, system-ui, sans-serif;
  --kc-font-body:    'Inter', -apple-system, 'Segoe UI', system-ui, sans-serif;
  --kc-font-mono:    'JetBrains Mono', 'IBM Plex Mono', ui-monospace, Menlo, monospace;

  /* Motion tokens */
  --kc-dur-tap:    80ms;
  --kc-dur-hover:  150ms;
  --kc-dur-glide:  240ms;
  --kc-dur-breath: 4500ms;
  --kc-dur-sweep:  18000ms;
  --kc-ease-out:   cubic-bezier(0.16, 1, 0.3, 1);
  --kc-ease-tap:   cubic-bezier(0.4, 0, 0.2, 1);
  --kc-ease-linear: linear;

  /* Radius */
  --kc-r-chip: 6px;
  --kc-r:      10px;
  --kc-r-card: 14px;

  /* Elevation */
  --kc-elev-hair: 0 0 0 1px var(--kc-line);
  --kc-elev-drop: 0 10px 32px -16px rgba(14,17,22,.18), 0 2px 6px -2px rgba(14,17,22,.08);

  /* Spacing */
  --kc-pad:          16px;
  --kc-pad-card:     20px;
  --kc-pad-section-y: 72px;

  box-sizing: border-box;
  font-family: var(--kc-font-body);
  font-size: 17px;
  line-height: 1.6;
  color: var(--kc-ink);
  background: var(--kc-bg);
}

[data-design="a"].dq-design *, [data-design="a"].dq-design *::before, [data-design="a"].dq-design *::after {
  box-sizing: inherit;
}

/* ── Utility ────────────────────────────────────────────────── */
[data-design="a"] .visually-hidden {
  position: absolute; width: 1px; height: 1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap;
}

/* ── E1: HEADER ─────────────────────────────────────────────── */
[data-design="a"] .kc-header {
  position: sticky; top: 0; z-index: 40;
  background: color-mix(in oklab, var(--kc-bg), white 30%);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
}
[data-design="a"] .kc-header__bar {
  max-width: 1200px; margin: 0 auto; padding: 14px 24px;
  display: flex; align-items: center; justify-content: space-between;
}

/* Logo — shimmer on a long cycle (~9-14s) */
[data-design="a"] .kc-logo {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--kc-font-display);
  font-size: 16px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--kc-ink); text-decoration: none;
  position: relative; overflow: hidden;
}
[data-design="a"] .kc-logo::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(105deg,
    transparent 30%,
    color-mix(in oklab, var(--kc-accent), transparent 55%) 50%,
    transparent 70%);
  transform: translateX(-120%);
  animation: kc-logo-shimmer 12000ms var(--kc-ease-linear) infinite;
  pointer-events: none;
}
@keyframes kc-logo-shimmer {
  0%   { transform: translateX(-120%); opacity: 0; }
  8%   { opacity: 1; }
  38%  { transform: translateX(120%); opacity: 0; }
  100% { transform: translateX(-120%); opacity: 0; }
}
[data-design="a"] .kc-logo__mark { position: relative; z-index: 1; }
[data-design="a"] .kc-logo__dot {
  width: 6px; height: 6px; background: var(--kc-accent); border-radius: 1px;
  flex-shrink: 0;
}

/* Hamburger */
[data-design="a"] .kc-burger {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 12px; border: 1px solid var(--kc-line); background: var(--kc-surface);
  border-radius: var(--kc-r); cursor: pointer; color: var(--kc-ink);
  transition: border-color var(--kc-dur-hover) var(--kc-ease-tap);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-burger:hover { border-color: var(--kc-accent); }
}
[data-design="a"] .kc-burger:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--kc-accent-soft);
  border-color: var(--kc-accent);
}
[data-design="a"] .kc-burger__bars {
  width: 14px; height: 10px;
  background:
    linear-gradient(var(--kc-ink), var(--kc-ink)) top/100% 1.5px no-repeat,
    linear-gradient(var(--kc-ink), var(--kc-ink)) center/100% 1.5px no-repeat,
    linear-gradient(var(--kc-ink), var(--kc-ink)) bottom/100% 1.5px no-repeat;
}
[data-design="a"] .kc-burger__hint {
  font-family: var(--kc-font-mono); font-size: 11px; color: var(--kc-muted);
  padding: 2px 6px; border: 1px solid var(--kc-line); border-radius: 4px;
  background: var(--kc-bg);
}

/* Header hairline + cursor sweep (E1 atmospheric animation) */
[data-design="a"] .kc-header__rule {
  position: relative; height: 1px; background: var(--kc-line); overflow: hidden;
}
[data-design="a"] .kc-header__cursor {
  position: absolute; top: -1px; left: -8%; width: 12%; height: 3px;
  background: linear-gradient(90deg,
    transparent,
    color-mix(in oklab, var(--kc-accent), transparent 70%) 35%,
    var(--kc-accent) 50%,
    color-mix(in oklab, var(--kc-accent), transparent 70%) 65%,
    transparent);
  filter: blur(0.5px);
  animation: kc-header-sweep var(--kc-dur-sweep) var(--kc-ease-linear) infinite;
}
@keyframes kc-header-sweep {
  0%   { transform: translateX(0);    opacity: 0; }
  8%   { opacity: 1; }
  92%  { opacity: 1; }
  100% { transform: translateX(900%); opacity: 0; }
}

/* Drawer — display:none when closed */
[data-design="a"] .kc-drawer {
  position: fixed; inset: 0;
  background: rgba(14,17,22,.36);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 50;
  display: grid; place-items: start center; padding-top: 96px;
}
[data-design="a"] .kc-drawer__sheet {
  width: min(480px, calc(100% - 32px));
  background: var(--kc-surface); border-radius: var(--kc-r-card);
  border: 1px solid var(--kc-line); box-shadow: var(--kc-elev-drop);
  overflow: hidden;
  animation: kc-drawer-in var(--kc-dur-glide) var(--kc-ease-out);
}
@keyframes kc-drawer-in {
  from { opacity: 0; transform: translateY(-8px) scale(0.98); }
  to   { opacity: 1; transform: none; }
}
[data-design="a"] .kc-drawer__search {
  display: flex; align-items: center; gap: 12px; padding: 16px 20px;
  border-bottom: 1px solid var(--kc-line);
}
[data-design="a"] .kc-drawer__prompt {
  font-family: var(--kc-font-mono); color: var(--kc-accent); font-size: 16px;
}
[data-design="a"] .kc-drawer__firm-name {
  flex: 1; font-size: 14px; font-weight: 500; color: var(--kc-ink);
}
[data-design="a"] .kc-drawer__esc-btn {
  font-family: var(--kc-font-mono); font-size: 11px; color: var(--kc-muted);
  padding: 2px 8px; border: 1px solid var(--kc-line); border-radius: 4px;
  background: var(--kc-bg); cursor: pointer;
}
[data-design="a"] .kc-drawer__contact-block {
  padding: 20px;
  display: flex; flex-direction: column; gap: 10px;
}
[data-design="a"] .kc-drawer__phone {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 18px; font-weight: 600; color: var(--kc-accent);
  text-decoration: none; padding: 12px 0;
  min-height: 44px;
}
[data-design="a"] .kc-drawer__license,
[data-design="a"] .kc-drawer__address {
  font-size: 13px; color: var(--kc-muted); margin: 0;
  font-family: var(--kc-font-mono);
}

/* ── HERO ───────────────────────────────────────────────────── */
[data-design="a"] .kc-hero {
  position: relative; overflow: hidden;
  min-height: 90svh;
  display: flex; align-items: center;
  background: var(--kc-bg);
  padding: clamp(40px, 8svh, 96px) 0;
}

/* Hero substrate — single ambient animated layer (HERO-1/2/3)
   Three hairlines that draw in on arrival, then sweep continuously.
   No directional primitive. Purely ambient atmosphere.
   Animates only transform — compliant with motion gate. */
[data-design="a"] .kc-hero__substrate {
  position: absolute; inset: 0; pointer-events: none;
  overflow: hidden;
}
[data-design="a"] .kc-hero__substrate-line {
  position: absolute; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    color-mix(in oklab, var(--kc-accent), transparent 82%) 25%,
    color-mix(in oklab, var(--kc-accent), transparent 68%) 50%,
    color-mix(in oklab, var(--kc-accent), transparent 82%) 75%,
    transparent 100%);
  transform: scaleX(0);
  transform-origin: left;
  animation: kc-hero-line-in 900ms var(--kc-ease-out) both,
             kc-hero-line-sweep 14000ms var(--kc-ease-linear) infinite;
}
[data-design="a"] .kc-hero__substrate-line--1 { top: 28%; animation-delay: 0ms, 800ms; }
[data-design="a"] .kc-hero__substrate-line--2 { top: 54%; animation-delay: 160ms, 960ms; }
[data-design="a"] .kc-hero__substrate-line--3 { top: 76%; animation-delay: 300ms, 1100ms; }

@keyframes kc-hero-line-in {
  from { transform: scaleX(0); opacity: 0; }
  to   { transform: scaleX(1); opacity: 1; }
}
/* Sustained ambient: a slow brightness pulse using opacity — transform only */
@keyframes kc-hero-line-sweep {
  0%, 100% { opacity: 0.18; }
  30%      { opacity: 0.55; }
  60%      { opacity: 0.28; }
}

[data-design="a"] .kc-hero__inner {
  position: relative; z-index: 1;
  width: 100%; max-width: 680px;
  margin: 0 auto;
  padding: 0 clamp(16px, 5vw, 40px);
  display: flex; flex-direction: column; gap: 0;
}

[data-design="a"] .kc-hero__value-prop {
  font-family: var(--kc-font-display);
  font-size: clamp(24px, 4.5vw, 44px);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.18;
  color: var(--kc-ink);
  margin: 0 0 16px;
  max-width: 22ch;
}

[data-design="a"] .kc-hero__reassurance {
  font-size: 14px;
  color: var(--kc-muted);
  font-family: var(--kc-font-mono);
  letter-spacing: 0.02em;
  margin: 0 0 32px;
}

/* ── E6: POINTER (between hero text and funnel form) ────────── */
/* data-mf-role="pointer" — NOT a button.
   Always visible: opacity:1, height > 8px, no reveal-gate. */
[data-design="a"] .kc-pointer {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px 0 14px;
  font-variant-numeric: tabular-nums;
  opacity: 1;               /* ALWAYS visible */
  min-height: 40px;         /* bbox height well above 8px gate */
}
[data-design="a"] .kc-pointer__counter {
  font-family: var(--kc-font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--kc-muted);
}
[data-design="a"] .kc-pointer__counter-now {
  display: inline-block;
  min-width: 1ch;
  animation: kc-pointer-tick 320ms var(--kc-ease-out);
}
[data-design="a"] .kc-pointer__bar {
  position: relative;
  flex: 1;
  height: 2px;
  background: var(--kc-line);
  border-radius: 1px;
  overflow: hidden;
}
[data-design="a"] .kc-pointer__bar-fill {
  position: absolute; inset: 0;
  transform: scaleX(var(--kc-pointer-progress, 0.2));
  transform-origin: left;
  background: var(--kc-accent);
  transition: transform 480ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
[data-design="a"] .kc-pointer__chev {
  font-size: 20px;
  color: var(--kc-accent);
  animation: kc-pointer-chev 4s ease-in-out infinite;
  display: inline-block;
}
@keyframes kc-pointer-tick {
  0%   { transform: translateY(-5px); opacity: 0; }
  100% { transform: translateY(0);    opacity: 1; }
}
@keyframes kc-pointer-chev {
  0%, 100% { transform: translateX(0);   opacity: 0.5; }
  50%      { transform: translateX(4px); opacity: 1.0; }
}

/* ── E5: FUNNEL WRAP ────────────────────────────────────────── */
[data-design="a"] .kc-funnel-wrap {
  width: 100%;
}

[data-design="a"] .kc-funnel {
  background: var(--kc-surface);
  border: 1px solid var(--kc-line);
  border-radius: var(--kc-r-card);
  overflow: hidden;
}

/* Progress bar + meta */
[data-design="a"] .kc-funnel__progress {
  position: relative; height: 4px; background: var(--kc-line-soft);
}
[data-design="a"] .kc-funnel__progress-bar {
  height: 100%; width: 100%;
  transform: scaleX(var(--p, 0.2));
  transform-origin: left;
  background: var(--kc-accent);
  transition: transform var(--kc-dur-glide) var(--kc-ease-out);
}
[data-design="a"] .kc-funnel__progress-meta {
  display: flex; justify-content: space-between;
  padding: 10px 20px;
  border-bottom: 1px solid var(--kc-line);
  font-family: var(--kc-font-mono); font-size: 11px; color: var(--kc-muted);
}

/* Steps */
[data-design="a"] .kc-funnel__steps {
  position: relative; padding: 24px 20px; min-height: 260px;
}
[data-design="a"] .kc-funnel__step {
  border: 0; padding: 0; margin: 0;
}
[data-design="a"] .kc-funnel__step[hidden] { display: none; }
[data-design="a"] .kc-funnel__step.is-active {
  animation: kc-step-in var(--kc-dur-glide) var(--kc-ease-out);
}
@keyframes kc-step-in {
  from { opacity: 0; transform: translateY(8px) scale(0.985); }
  to   { opacity: 1; transform: none; }
}
[data-design="a"] .kc-funnel__legend {
  font-size: clamp(18px, 2.5vw, 22px);
  font-weight: 500; letter-spacing: -0.01em;
  margin: 0 0 6px; color: var(--kc-ink);
  display: block;
}
[data-design="a"] .kc-funnel__sub {
  color: var(--kc-muted); margin: 0 0 16px; font-size: 14px;
}

/* Option cards — tap targets ≥56px (funnel floor) */
[data-design="a"] .kc-funnel__options { display: grid; gap: 8px; }
[data-design="a"] .kc-funnel__opt {
  display: grid; grid-template-columns: 28px 1fr; column-gap: 12px;
  align-items: start; padding: 14px;
  border: 1px solid var(--kc-line); border-radius: var(--kc-r);
  background: var(--kc-surface); cursor: pointer;
  min-height: 56px;
  transition: border-color var(--kc-dur-tap) var(--kc-ease-tap),
              background var(--kc-dur-tap) var(--kc-ease-tap);
  /* Entrance stagger applied via JS class */
}
[data-design="a"] .kc-funnel__opt.kc-opt-enter {
  animation: kc-opt-enter 280ms var(--kc-ease-out) both;
}
@keyframes kc-opt-enter {
  from { opacity: 0; transform: translateY(6px) scale(0.97); }
  to   { opacity: 1; transform: none; }
}

@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-funnel__opt:hover {
    border-color: var(--kc-accent);
    background: color-mix(in oklab, var(--kc-accent-soft), transparent 50%);
  }
}
[data-design="a"] .kc-funnel__opt input {
  position: absolute; opacity: 0; pointer-events: none;
}
[data-design="a"] .kc-funnel__opt:has(input:checked) {
  border-color: var(--kc-accent); background: var(--kc-accent-soft);
}
[data-design="a"] .kc-funnel__opt:has(input:focus-visible) {
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--kc-accent), transparent 70%);
}
[data-design="a"] .kc-funnel__kbd {
  grid-row: 1 / span 2;
  font-family: var(--kc-font-mono); font-size: 11px;
  display: inline-flex; align-items: center; justify-content: center;
  height: 22px; padding: 0 6px;
  border: 1px solid var(--kc-line); border-radius: 4px;
  color: var(--kc-muted); background: var(--kc-bg);
  align-self: center;
}
[data-design="a"] .kc-funnel__opt:has(input:checked) .kc-funnel__kbd {
  color: var(--kc-accent); border-color: var(--kc-accent);
}
[data-design="a"] .kc-funnel__opt-label {
  font-size: 15px; color: var(--kc-ink); font-weight: 500;
}
[data-design="a"] .kc-funnel__opt-sub {
  display: block; font-size: 13px; color: var(--kc-muted); margin-top: 2px;
}

/* Contact step fields */
[data-design="a"] .kc-funnel__fields { display: grid; gap: 12px; }
[data-design="a"] .kc-funnel__field { display: grid; gap: 5px; }
[data-design="a"] .kc-funnel__field span {
  font-size: 13px; color: var(--kc-ink-2); font-weight: 500;
}
[data-design="a"] .kc-funnel__field input {
  padding: 11px 13px; font: inherit; font-size: 15px;
  border: 1px solid var(--kc-line); border-radius: var(--kc-r);
  background: var(--kc-surface); color: var(--kc-ink);
  min-height: 48px;
  transition: border-color var(--kc-dur-tap) var(--kc-ease-tap),
              box-shadow var(--kc-dur-tap) var(--kc-ease-tap);
}
[data-design="a"] .kc-funnel__field input:focus-visible {
  outline: none; border-color: var(--kc-accent);
  box-shadow: 0 0 0 3px var(--kc-accent-soft);
}
[data-design="a"] .kc-funnel__field-group { display: grid; gap: 8px; }
[data-design="a"] .kc-funnel__field-group-label {
  font-size: 13px; color: var(--kc-ink-2); font-weight: 500;
}
[data-design="a"] .kc-funnel__time-opts {
  display: flex; flex-wrap: wrap; gap: 8px;
}
[data-design="a"] .kc-funnel__time-opt {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; border: 1px solid var(--kc-line); border-radius: var(--kc-r);
  cursor: pointer; font-size: 14px; min-height: 44px;
  transition: border-color var(--kc-dur-tap) var(--kc-ease-tap),
              background var(--kc-dur-tap) var(--kc-ease-tap);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-funnel__time-opt:hover { border-color: var(--kc-accent); }
}
[data-design="a"] .kc-funnel__time-opt:has(input:checked) {
  border-color: var(--kc-accent); background: var(--kc-accent-soft); color: var(--kc-accent);
}
[data-design="a"] .kc-funnel__time-opt input { position: absolute; opacity: 0; pointer-events: none; }

/* Funnel nav bar */
[data-design="a"] .kc-funnel__nav {
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  padding: 14px 20px; border-top: 1px solid var(--kc-line); background: var(--kc-bg);
}

/* Keys / buttons */
[data-design="a"] .kc-key {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 11px 18px; border-radius: var(--kc-r);
  font: inherit; font-size: 14px; font-weight: 500; cursor: pointer;
  border: 1px solid transparent; min-height: 44px;
  transition: transform var(--kc-dur-tap) var(--kc-ease-tap),
              background var(--kc-dur-hover) var(--kc-ease-tap),
              border-color var(--kc-dur-hover) var(--kc-ease-tap);
}
[data-design="a"] .kc-key[style*="display:none"],
[data-design="a"] .kc-key[hidden] { display: none !important; }
[data-design="a"] .kc-key--primary {
  background: var(--kc-accent); color: var(--kc-accent-ink);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-key--primary:hover {
    background: color-mix(in oklab, var(--kc-accent), black 6%);
  }
}
[data-design="a"] .kc-key--primary:active {
  transform: scale(0.97); transition-duration: 60ms;
}
[data-design="a"] .kc-key--ghost {
  background: transparent; color: var(--kc-ink); border-color: var(--kc-line);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-key--ghost:hover { border-color: var(--kc-accent); }
}
[data-design="a"] .kc-key:focus-visible {
  outline: none; box-shadow: 0 0 0 3px var(--kc-accent-soft);
}
[data-design="a"] .kc-cta__kbd {
  font-family: var(--kc-font-mono); font-size: 11px;
  padding: 2px 6px; border-radius: 4px;
  background: color-mix(in oklab, var(--kc-accent-ink), transparent 78%);
  color: var(--kc-accent-ink);
}
[data-design="a"] .kc-key--primary .kc-cta__kbd {
  background: color-mix(in oklab, var(--kc-accent-ink), transparent 78%);
  color: var(--kc-accent-ink);
}

/* Completion state */
[data-design="a"] .kc-funnel__done {
  animation: kc-funnel-stamp var(--kc-dur-glide) var(--kc-ease-out);
  padding: 8px 0;
}
@keyframes kc-funnel-stamp {
  from { opacity: 0; transform: scale(0.97); }
  to   { opacity: 1; transform: none; }
}
[data-design="a"] .kc-funnel__done-id {
  font-family: var(--kc-font-mono); font-size: 12px;
  color: var(--kc-status-ok); margin: 0 0 10px; letter-spacing: 0.06em;
}
[data-design="a"] .kc-funnel__done-title {
  margin: 0 0 10px; font-size: clamp(20px, 2.5vw, 26px);
  font-weight: 500; letter-spacing: -0.01em;
}
[data-design="a"] .kc-funnel__done-body {
  margin: 0; color: var(--kc-muted); font-size: 14px; max-width: 52ch;
}
[data-design="a"] .kc-funnel__done-body a {
  color: var(--kc-accent); text-decoration: none;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-funnel__done-body a:hover { text-decoration: underline; }
}

/* ── E4: REASSURANCE BAR ────────────────────────────────────── */
[data-design="a"] .kc-reassure {
  border-top: 1px solid var(--kc-line-soft);
  border-bottom: 1px solid var(--kc-line-soft);
  background: var(--kc-surface);
  overflow: hidden; padding: 0;
}
[data-design="a"] .kc-reassure__inner {
  overflow: hidden; padding: 14px 0;
}
[data-design="a"] .kc-reassure__track { overflow: hidden; }
[data-design="a"] .kc-reassure__items {
  display: inline-flex; align-items: center; gap: 18px;
  white-space: nowrap;
  animation: kc-reassure-drift 38000ms var(--kc-ease-linear) infinite;
}
@keyframes kc-reassure-drift {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
[data-design="a"] .kc-reassure__item {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--kc-font-mono); font-size: 12px;
  color: var(--kc-muted); letter-spacing: 0.03em;
}
[data-design="a"] .kc-reassure__dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--kc-accent); opacity: 0.7; flex-shrink: 0;
}
[data-design="a"] .kc-reassure__sep {
  color: var(--kc-line); font-size: 14px;
}

/* ── FOOTER ─────────────────────────────────────────────────── */
[data-design="a"] .kc-footer {
  background: var(--kc-bg);
  border-top: 1px solid var(--kc-line);
  padding: clamp(32px, 5vw, 56px) 24px clamp(24px, 4vw, 40px);
}
[data-design="a"] .kc-footer__inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; flex-wrap: wrap; gap: 32px;
}
[data-design="a"] .kc-footer__col { flex: 1 1 180px; min-width: 0; }
[data-design="a"] .kc-footer__name {
  display: block;
  font-family: var(--kc-font-display); font-size: 15px; font-weight: 600;
  color: var(--kc-ink); margin-bottom: 6px;
}
[data-design="a"] .kc-footer__tagline {
  display: block; font-size: 13px; color: var(--kc-muted);
}
[data-design="a"] .kc-footer__phone,
[data-design="a"] .kc-footer__email {
  display: block; font-size: 14px; color: var(--kc-accent);
  text-decoration: none; margin-bottom: 4px; min-height: 44px;
  line-height: 44px;
}
[data-design="a"] .kc-footer__address {
  font-size: 13px; color: var(--kc-muted); font-style: normal;
  line-height: 1.6; margin: 4px 0 0;
}
[data-design="a"] .kc-footer__credential {
  font-family: var(--kc-font-mono); font-size: 11px;
  color: var(--kc-ink-2); margin: 0 0 8px; line-height: 1.6;
}
[data-design="a"] .kc-footer__disclaimer {
  font-size: 12px; color: var(--kc-muted); margin: 0 0 8px;
  max-width: 56ch; line-height: 1.6;
}
[data-design="a"] .kc-footer__copy {
  font-family: var(--kc-font-mono); font-size: 11px;
  color: var(--kc-muted); margin: 0;
}

/* ── Scroll-linked premium motion (TRIAD-2) ─────────────────── */
/* Hero value-prop + reassurance get a scroll-linked translate.
   Uses @scroll-timeline where supported; JS fallback via IntersectionObserver. */
[data-design="a"] .kc-hero__value-prop,
[data-design="a"] .kc-hero__reassurance {
  will-change: transform;
}
/* Scroll-linked via CSS only where supported */
@supports (animation-timeline: scroll()) {
  [data-design="a"] .kc-hero__value-prop {
    animation: kc-hero-scroll-prop linear both;
    animation-timeline: scroll(root block);
    animation-range: 0% 30%;
  }
  [data-design="a"] .kc-hero__reassurance {
    animation: kc-hero-scroll-prop linear both;
    animation-timeline: scroll(root block);
    animation-range: 0% 25%;
  }
  @keyframes kc-hero-scroll-prop {
    from { transform: translateY(0); opacity: 1; }
    to   { transform: translateY(-18px); opacity: 0.4; }
  }
}

/* ── prefers-reduced-motion: all animations off ─────────────── */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .kc-header__cursor    { animation: none; opacity: 0.5; left: 30%; }
  [data-design="a"] .kc-logo::after       { animation: none; opacity: 0; }
  [data-design="a"] .kc-drawer__sheet     { animation: none; }
  [data-design="a"] .kc-hero__substrate-line { animation: none; opacity: 0.3; transform: scaleX(1); }
  [data-design="a"] .kc-pointer__counter-now,
  [data-design="a"] .kc-pointer__chev,
  [data-design="a"] .kc-pointer__bar-fill { animation: none; transition: none; }
  [data-design="a"] .kc-funnel__step.is-active,
  [data-design="a"] .kc-funnel__done       { animation: none; }
  [data-design="a"] .kc-funnel__progress-bar { transition: none; }
  [data-design="a"] .kc-reassure__items   { animation: none; }
  [data-design="a"] .kc-funnel__opt.kc-opt-enter { animation: none; }
  [data-design="a"] .kc-hero__value-prop,
  [data-design="a"] .kc-hero__reassurance { animation: none !important; }
}

/* ── MOBILE NO-HSCROLL GUARANTEE ────────────────────────────── */
/* Scoped to .dq-design as required by contract */
[data-design="a"].dq-design,
[data-design="a"] .dq-design { max-width: 100%; overflow-x: clip; }
[data-design="a"].dq-design * { min-width: 0; }
[data-design="a"].dq-design img,
[data-design="a"].dq-design svg:not([data-keep-size]) { max-width: 100%; height: auto; }

/* Responsive overrides */
@media (max-width: 768px) {
  [data-design="a"] .kc-header__bar { padding: 12px 16px; }
  [data-design="a"] .kc-burger__hint { display: none; }
  [data-design="a"] .kc-hero { min-height: 85svh; padding: 32px 0; }
  [data-design="a"] .kc-hero__inner { padding: 0 16px; }
  [data-design="a"] .kc-funnel__steps { padding: 20px 16px; min-height: 200px; }
  [data-design="a"] .kc-funnel__nav { padding: 12px 16px; }
  [data-design="a"] .kc-funnel__progress-meta { padding: 8px 16px; }
  [data-design="a"] .kc-footer__inner { flex-direction: column; gap: 24px; }
}

@media (max-width: 380px) {
  [data-design="a"] .kc-logo__mark { font-size: 14px; }
  [data-design="a"] .kc-funnel__opt { padding: 12px; }
  [data-design="a"] .kc-funnel__steps { padding: 16px 12px; }
  [data-design="a"] .kc-funnel__nav { padding: 10px 12px; }
  [data-design="a"] .kc-footer { padding: 28px 14px 20px; }
}

/* Phase-3.4 hero visibility floor (forge_assemble) */
[data-design="a"] [data-mf-role="hero"] :is(h1,h2,p,.headline,.subtitle,.proof,[class*="headline"],[class*="subtitle"],[class*="proof"]),
[data-design="a"] [data-mf-role="cta"] { opacity: 1 !important; }
