/* ═══════════════════════════════════════════════════════════════
   Burris Plumbing — Design A (keystroke-counsel remapped to [data-design="a"])
   Slot: a · Trade: premium-funnel · Design: keystroke-counsel
   MOTION GATE: only transform/opacity/clip-path animated — ZERO layout props
   Every :hover/:focus-visible transform inside @media (hover:hover) and (pointer:fine)
   No scale(0) starts — minimum scale(0.96) or opacity:0 + translateY
   ═══════════════════════════════════════════════════════════════ */

/* ── Design tokens ────────────────────────────────────────────── */
[data-design="a"] {
  --design-a-primary:      #6D43F7;
  --kc-bg:                 #F6F7FB;
  --kc-surface:            #FFFFFF;
  --kc-ink:                #0E1116;
  --kc-ink-2:              #3B4252;
  --kc-muted:              #6B7280;
  --kc-line:               #E5E7EE;
  --kc-line-soft:          #EFF1F6;
  --kc-accent:             #6D43F7;
  --kc-accent-soft:        #EEE9FE;
  --kc-accent-ink:         #FFFFFF;
  --kc-status-ok:          #16A34A;
  --kc-status-warn:        #D97706;
  --kc-status-hot:         #DC2626;
  --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;
  --kc-r-chip:             6px;
  --kc-r:                  10px;
  --kc-r-card:             14px;
  --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);
  --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;
  box-sizing: border-box;
  font-family: var(--kc-font-body);
  background: var(--kc-bg);
  color: var(--kc-ink);
}

/* ── Mobile overflow guard — scoped to .dq-design ─────────────── */
[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;
}

/* ── Visually hidden util ─────────────────────────────────────── */
[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 — slow shimmer sweep across wordmark (9-14s cycle) */
[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; top: 0; left: -60%;
  width: 40%; height: 100%;
  background: linear-gradient(90deg,
    transparent 0%,
    color-mix(in oklab, var(--kc-accent), transparent 82%) 50%,
    transparent 100%);
  transform: translateX(0);
  animation: kc-a-logo-shimmer 11s var(--kc-ease-linear) infinite;
  pointer-events: none;
}
@keyframes kc-a-logo-shimmer {
  0%   { transform: translateX(0);    opacity: 0; }
  8%   { opacity: 1; }
  50%  { transform: translateX(350%); opacity: 0.7; }
  70%  { transform: translateX(350%); opacity: 0; }
  100% { transform: translateX(350%); opacity: 0; }
}

[data-design="a"] .kc-logo__dot {
  width: 6px; height: 6px;
  background: var(--kc-accent); border-radius: 1px; flex-shrink: 0;
}

[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);
}
[data-design="a"] .kc-burger:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--kc-accent-soft);
  border-color: var(--kc-accent);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-burger:hover { 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 rule + cursor sweep */
[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-a-header-sweep var(--kc-dur-sweep) var(--kc-ease-linear) infinite;
}
@keyframes kc-a-header-sweep {
  0%   { transform: translateX(0);    opacity: 0; }
  8%   { opacity: 1; }
  92%  { opacity: 1; }
  100% { transform: translateX(900%); opacity: 0; }
}

/* Drawer — slim: phone CTA only */
[data-design="a"] .kc-drawer[hidden] { display: none; }
[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-a-drawer-in var(--kc-dur-glide) var(--kc-ease-out);
}
@keyframes kc-a-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: 14px 18px;
  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__title {
  flex: 1; font-size: 14px; font-weight: 500; color: var(--kc-ink);
}
[data-design="a"] .kc-drawer__esc {
  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;
  transition: border-color var(--kc-dur-hover) var(--kc-ease-tap);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-drawer__esc:hover { border-color: var(--kc-accent); }
}
[data-design="a"] .kc-drawer__body {
  padding: 20px 18px;
}
[data-design="a"] .kc-drawer__phone {
  display: flex; align-items: center; gap: 10px;
  font-size: 20px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--kc-accent); text-decoration: none;
  padding: 12px 16px; border: 1px solid var(--kc-accent-soft);
  border-radius: var(--kc-r); background: var(--kc-accent-soft);
  transition: background var(--kc-dur-hover) var(--kc-ease-tap);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-drawer__phone:hover { background: color-mix(in oklab, var(--kc-accent-soft), var(--kc-accent) 10%); }
}
[data-design="a"] .kc-drawer__license {
  margin: 12px 0 0; font-size: 12px; color: var(--kc-muted);
  font-family: var(--kc-font-mono);
}

/* ════════════════════════════════════════════════════════════════
   HERO — Step 1 (premium-funnel: hero IS funnel Step 1)
   ════════════════════════════════════════════════════════════════ */
[data-design="a"] .kc-hero {
  position: relative;
  min-height: 88vh;
  display: flex; align-items: center;
  background: var(--kc-bg);
  overflow: hidden;
}

/* Hero substrate — slow ambient grid that breathes (satisfies HERO-3 visual presence floor) */
[data-design="a"] .kc-hero__substrate {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
}
[data-design="a"] .kc-hero__grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(var(--kc-line-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--kc-line-soft) 1px, transparent 1px);
  background-size: 48px 48px;
  animation: kc-a-grid-breathe 6s ease-in-out infinite;
  transform-origin: center;
}
@keyframes kc-a-grid-breathe {
  0%, 100% { opacity: 0.35; transform: scale(1); }
  50%       { opacity: 0.65; transform: scale(1.008); }
}

[data-design="a"] .kc-hero__inner {
  position: relative; z-index: 2;
  width: 100%; max-width: 760px;
  margin: 0 auto;
  padding: 72px 24px 56px;
  display: flex; flex-direction: column; gap: 20px;
}

/* Progress indicator — always visible */
[data-design="a"] .kc-hero__progress {
  display: flex; align-items: center; gap: 12px;
}
[data-design="a"] .kc-hero__progress-bar {
  flex: 1; height: 3px; background: var(--kc-line);
  border-radius: 2px; overflow: hidden;
}
[data-design="a"] .kc-hero__progress-fill {
  display: block; height: 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-hero__step-label {
  font-family: var(--kc-font-mono); font-size: 11px;
  color: var(--kc-muted); letter-spacing: 0.12em; white-space: nowrap;
}

/* Value prop — opacity:1 at FIRST PAINT — never hidden */
[data-design="a"] .kc-hero__value-prop {
  margin: 0;
  font-family: var(--kc-font-display);
  font-size: clamp(24px, 4.5vw, 42px);
  font-weight: 600; letter-spacing: -0.025em; line-height: 1.2;
  color: var(--kc-ink);
}
[data-design="a"] .kc-hero__reassurance {
  margin: 0;
  font-size: 14px; color: var(--kc-muted);
  font-family: var(--kc-font-mono);
}

/* ════════════════════════════════════════════════════════════════
   E6 — SIGNATURE POINTER (above-form, premium-funnel style)
   Must be: opacity > 0.5, height ≥ 8px, ≤ 2 siblings from #funnel
   ════════════════════════════════════════════════════════════════ */
[data-design="a"] .kc-pointer {
  display: flex; align-items: center; gap: 16px;
  padding: 14px 0;
  font-variant-numeric: tabular-nums;
  color: var(--kc-ink-2);
  opacity: 1;   /* HARD: never opacity:0 */
  min-height: 12px;  /* HARD: always visible */
}
[data-design="a"] .kc-pointer__counter {
  font-family: var(--kc-font-mono);
  font-size: 13px; letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0.75; color: var(--kc-muted);
}
[data-design="a"] .kc-pointer__counter-now {
  display: inline-block; min-width: 1ch; color: var(--kc-accent); font-weight: 600;
  animation: kc-a-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: 22px; font-weight: 300;
  color: var(--kc-accent);
  animation: kc-a-pointer-chev 4s ease-in-out infinite;
}
@keyframes kc-a-pointer-tick {
  0%   { transform: translateY(-6px); opacity: 0; }
  100% { transform: translateY(0);    opacity: 1; }
}
@keyframes kc-a-pointer-chev {
  0%, 100% { transform: translateX(0);   opacity: 0.45; }
  50%      { transform: translateX(5px); opacity: 1; }
}

/* ════════════════════════════════════════════════════════════════
   E5 — FUNNEL (the page IS the funnel)
   ════════════════════════════════════════════════════════════════ */
[data-design="a"] .kc-funnel-wrap {
  /* No extra margin — sits directly below the pointer (≤ 2 siblings rule) */
}

[data-design="a"] .kc-funnel {
  background: var(--kc-surface);
  border: 1px solid var(--kc-line);
  border-radius: var(--kc-r-card);
  overflow: hidden;
}

[data-design="a"] .kc-funnel__step { border: 0; padding: 24px 24px 0; margin: 0; }
[data-design="a"] .kc-funnel__step[hidden] { display: none; }
[data-design="a"] .kc-funnel__step.is-active {
  animation: kc-a-step-in var(--kc-dur-glide) var(--kc-ease-out);
}
@keyframes kc-a-step-in {
  from { opacity: 0; transform: translateY(8px) scale(0.985); }
  to   { opacity: 1; transform: none; }
}

[data-design="a"] .kc-funnel__legend {
  font-family: var(--kc-font-display);
  font-size: clamp(18px, 3vw, 24px); font-weight: 600;
  letter-spacing: -0.015em; line-height: 1.3;
  margin: 0 0 6px; color: var(--kc-ink);
}
[data-design="a"] .kc-funnel__sub {
  color: var(--kc-muted); margin: 0 0 16px; font-size: 14px;
}

/* Option cards — E2 step-advance buttons */
[data-design="a"] .kc-funnel__options {
  display: grid; gap: 8px; padding-bottom: 4px;
}
[data-design="a"] .kc-funnel__opt {
  display: grid; grid-template-columns: 28px 1fr; column-gap: 14px;
  align-items: center; padding: 14px 16px;
  border: 1px solid var(--kc-line); border-radius: var(--kc-r);
  background: var(--kc-surface); cursor: pointer;
  transition:
    border-color var(--kc-dur-tap) var(--kc-ease-tap),
    background var(--kc-dur-tap) var(--kc-ease-tap),
    transform var(--kc-dur-tap) var(--kc-ease-tap);
  min-height: 56px;
}
@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 40%);
  }
}
[data-design="a"] .kc-funnel__opt:active {
  transform: scale(0.995);
}
[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 {
  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);
}
[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;
}

/* Contact step fields */
[data-design="a"] .kc-funnel__fields { display: grid; gap: 12px; padding-bottom: 4px; }
[data-design="a"] .kc-funnel__field { display: grid; gap: 6px; }
[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 14px; font: inherit; font-size: 15px;
  border: 1px solid var(--kc-line); border-radius: var(--kc-r);
  background: var(--kc-surface); color: var(--kc-ink);
  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);
}

/* Best time to call row */
[data-design="a"] .kc-funnel__reach-time {
  display: grid; gap: 8px;
}
[data-design="a"] .kc-funnel__reach-label {
  font-size: 13px; color: var(--kc-ink-2); font-weight: 500;
}
[data-design="a"] .kc-funnel__reach-opts {
  display: flex; gap: 8px; flex-wrap: wrap;
}
[data-design="a"] .kc-funnel__reach-opt {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  border: 1px solid var(--kc-line); border-radius: var(--kc-r);
  background: var(--kc-surface); cursor: pointer; font-size: 14px;
  min-height: 44px;
  transition: border-color var(--kc-dur-tap) var(--kc-ease-tap);
}
[data-design="a"] .kc-funnel__reach-opt:has(input:checked) {
  border-color: var(--kc-accent); background: var(--kc-accent-soft);
}
[data-design="a"] .kc-funnel__reach-opt input {
  accent-color: var(--kc-accent);
}

/* Funnel done state — display:none when hidden, NEVER opacity:0 */
[data-design="a"] .kc-funnel__done {
  padding: 24px 24px;
  animation: kc-a-funnel-stamp var(--kc-dur-glide) var(--kc-ease-out);
}
@keyframes kc-a-funnel-stamp {
  from { opacity: 0; transform: scale(0.98); }
  to   { opacity: 1; transform: none; }
}
[data-design="a"] .kc-funnel__done-id {
  font-family: var(--kc-font-mono); font-size: 12px;
  color: var(--kc-accent); margin: 0 0 10px; letter-spacing: 0.08em;
}
[data-design="a"] .kc-funnel__done-title {
  margin: 0 0 8px; font-size: 22px; font-weight: 600;
  letter-spacing: -0.015em; color: var(--kc-ink);
}
[data-design="a"] .kc-funnel__done-body {
  margin: 0; color: var(--kc-muted); font-size: 15px; line-height: 1.6;
}
[data-design="a"] .kc-funnel__done-body a {
  color: var(--kc-accent); text-decoration: none; font-weight: 500;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-funnel__done-body a:hover { text-decoration: underline; }
}

/* Funnel nav bar */
[data-design="a"] .kc-funnel__nav {
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  padding: 16px 24px; border-top: 1px solid var(--kc-line);
  background: var(--kc-bg);
}

/* Buttons — E2 step-advance primary */
[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;
  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);
  min-height: 44px;
}
[data-design="a"] .kc-key[hidden],
[data-design="a"] .kc-key[style*="display:none"] { display: none; }
[data-design="a"] .kc-key--primary {
  background: var(--kc-accent); color: var(--kc-accent-ink);
}
[data-design="a"] .kc-key--primary:focus-visible {
  outline: none; box-shadow: 0 0 0 3px var(--kc-accent-soft);
}
[data-design="a"] .kc-key--primary:active { transform: scale(0.97); }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-key--primary:hover {
    background: color-mix(in oklab, var(--kc-accent), black 8%);
  }
}
[data-design="a"] .kc-key--ghost {
  background: transparent; color: var(--kc-ink);
  border-color: var(--kc-line);
}
[data-design="a"] .kc-key--ghost:focus-visible {
  outline: none; box-shadow: 0 0 0 3px var(--kc-accent-soft);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-key--ghost:hover { border-color: var(--kc-accent); }
}

/* kbd badge inside buttons */
[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);
}

/* ════════════════════════════════════════════════════════════════
   E3 — TRIAD-2 Scroll-linked / ambient transition motion
   The funnel step transition IS Element 3.
   Plus: scroll-linked reveal on the reassurance section.
   ════════════════════════════════════════════════════════════════ */
[data-design="a"] .kc-reassurance {
  background: var(--kc-surface);
  border-top: 1px solid var(--kc-line);
  padding: 40px 24px;
  /* Scroll-linked reveal — JS adds .is-visible */
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity 500ms var(--kc-ease-out),
    transform 500ms var(--kc-ease-out);
}
[data-design="a"] .kc-reassurance.is-visible {
  opacity: 1;
  transform: translateY(0);
}

[data-design="a"] .kc-reassurance__inner {
  max-width: 960px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 20px;
}
[data-design="a"] .kc-reassurance__bar {
  display: flex; flex-wrap: wrap; gap: 8px 24px; align-items: center;
  font-size: 14px; color: var(--kc-ink-2);
}
[data-design="a"] .kc-reassurance__item {
  display: flex; align-items: center; gap: 6px;
}
[data-design="a"] .kc-reassurance__item a {
  color: var(--kc-accent); text-decoration: none; font-weight: 600;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-reassurance__item a:hover { text-decoration: underline; }
}
[data-design="a"] .kc-reassurance__sep {
  color: var(--kc-line); font-size: 18px;
}
[data-design="a"] .kc-reassurance__icon { opacity: 0.6; }

/* E4 barometer mini sparkline */
[data-design="a"] .kc-barometer-mini {
  display: flex; flex-direction: column; gap: 6px;
}
[data-design="a"] .kc-barometer-mini__svg {
  width: 100%; height: 48px;
  display: block;
}
[data-design="a"] .kc-barometer-mini__line {
  stroke-dasharray: 800; stroke-dashoffset: 800;
  animation: kc-a-bar-draw 16000ms linear infinite;
}
@keyframes kc-a-bar-draw {
  0%   { stroke-dashoffset: 800; }
  35%  { stroke-dashoffset: 0; }
  85%  { stroke-dashoffset: 0; opacity: 1; }
  100% { stroke-dashoffset: 0; opacity: 0; }
}
[data-design="a"] .kc-barometer-mini__label {
  font-family: var(--kc-font-mono); font-size: 10px; color: var(--kc-muted);
  letter-spacing: 0.06em; text-transform: uppercase;
}

/* ════════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════════ */
[data-design="a"] .kc-footer {
  background: var(--kc-bg);
  border-top: 1px solid var(--kc-line);
  padding: 32px 24px;
}
[data-design="a"] .kc-footer__inner {
  max-width: 960px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 12px;
}
[data-design="a"] .kc-footer__row {
  display: flex; flex-wrap: wrap; gap: 8px 24px; align-items: center;
}
[data-design="a"] .kc-footer__row--top {
  font-size: 15px; font-weight: 600; color: var(--kc-ink);
}
[data-design="a"] .kc-footer__row--mid {
  font-size: 13px; color: var(--kc-muted);
  font-family: var(--kc-font-mono);
}
[data-design="a"] .kc-footer__row--bot {
  font-size: 12px; color: var(--kc-muted);
  border-top: 1px solid var(--kc-line-soft); padding-top: 12px;
  flex-direction: column; align-items: flex-start; gap: 4px;
}
[data-design="a"] .kc-footer__phone,
[data-design="a"] .kc-footer__email {
  color: var(--kc-accent); text-decoration: none; font-weight: 500;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .kc-footer__phone:hover,
  [data-design="a"] .kc-footer__email:hover { text-decoration: underline; }
}
[data-design="a"] .kc-footer__disclaimer {
  font-style: italic; opacity: 0.7;
}

/* ════════════════════════════════════════════════════════════════
   REDUCED MOTION FALLBACKS
   ════════════════════════════════════════════════════════════════ */
@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-hero__grid { animation: none; opacity: 0.4; }
  [data-design="a"] .kc-drawer__sheet { animation: none; }
  [data-design="a"] .kc-funnel__step.is-active { animation: none; }
  [data-design="a"] .kc-funnel__done { animation: none; }
  [data-design="a"] .kc-hero__progress-fill { transition: none; }
  [data-design="a"] .kc-pointer__counter-now { animation: none; }
  [data-design="a"] .kc-pointer__chev { animation: none; }
  [data-design="a"] .kc-pointer__bar-fill { transition: none; }
  [data-design="a"] .kc-barometer-mini__line { animation: none; stroke-dashoffset: 0; }
  [data-design="a"] .kc-reassurance {
    opacity: 1; transform: none; transition: none;
  }
}

/* ════════════════════════════════════════════════════════════════
   RESPONSIVE — 320 / 560 / 768 / 1440
   ALL rules scoped to .dq-design — never bare [data-design]
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 560px) {
  [data-design="a"].dq-design .kc-header__bar { padding: 12px 16px; }
  [data-design="a"].dq-design .kc-burger__hint { display: none; }
  [data-design="a"].dq-design .kc-hero__inner { padding: 56px 16px 40px; }
  [data-design="a"].dq-design .kc-funnel__step { padding: 18px 16px 0; }
  [data-design="a"].dq-design .kc-funnel__nav { padding: 14px 16px; }
  [data-design="a"].dq-design .kc-funnel__opt { padding: 12px 12px; }
  [data-design="a"].dq-design .kc-funnel__opt-label { font-size: 14px; }
  [data-design="a"].dq-design .kc-reassurance { padding: 28px 16px; }
  [data-design="a"].dq-design .kc-footer { padding: 24px 16px; }
  [data-design="a"].dq-design .kc-reassurance__sep { display: none; }
  [data-design="a"].dq-design .kc-reassurance__bar { gap: 10px 0; flex-direction: column; align-items: flex-start; }
  [data-design="a"].dq-design .kc-pointer { padding: 10px 0; }
}

@media (max-width: 380px) {
  [data-design="a"].dq-design .kc-logo__mark { font-size: 14px; }
  [data-design="a"].dq-design .kc-funnel__legend { font-size: 17px; }
}

@media (min-width: 769px) {
  [data-design="a"].dq-design .kc-hero {
    min-height: 82vh;
  }
  [data-design="a"].dq-design .kc-hero__inner {
    padding: 88px 32px 64px;
  }
  [data-design="a"].dq-design .kc-funnel__step {
    padding: 28px 32px 0;
  }
  [data-design="a"].dq-design .kc-funnel__nav {
    padding: 18px 32px;
  }
  [data-design="a"].dq-design .kc-funnel__options {
    grid-template-columns: 1fr 1fr;
  }
  /* 5-option step stays single column on wide for readability */
  [data-design="a"].dq-design .kc-funnel__step[data-step="1"] .kc-funnel__options {
    grid-template-columns: 1fr;
  }
}

/* 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; }
