/* ═══════════════════════════════════════════════════════════════════
   DESIGN-A · Cipher token system · Discover Chiropractic Bend
   All selectors scoped [data-design="a"]
   ~12-16 color tokens exposed on [data-design="a"].dq-design block
═══════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Inter+Tight:wght@700;800&family=JetBrains+Mono:wght@400;500;700&display=swap');

/* ── Token block ─────────────────────────────────────────────── */
[data-design="a"] {
  --cp-bg:              #060606;
  --cp-bg-soft:         #0E0E0E;
  --cp-bg-line:         #1A1A1A;
  --cp-ink:             #FAFAFA;
  --cp-ink-soft:        #C4C4C4;
  --cp-mute:            #6B6B6B;
  --cp-dim:             #3A3A3A;
  --cp-signal:          #58F500;
  --cp-signal-deep:     #2EAA00;
  --cp-amber:           #FFB020;
  --cp-red:             #FF3B30;
  --cp-rule:            rgba(250,250,250,.14);
  --cp-rule-strong:     rgba(250,250,250,.28);
  /* design-a primary exposure */
  --design-a-primary:   #58F500;

  /* Motion tokens */
  --cp-ease-cmd:        cubic-bezier(.6,0,.4,1);
  --cp-ease-linear:     linear;
  --cp-ease-settle:     cubic-bezier(.2,.7,.3,1);
  --cp-d-snap:          100ms;
  --cp-d-press:         120ms;
  --cp-d-register:      200ms;
  --cp-d-settle:        400ms;

  /* Spacing */
  --cp-hair:   1px;
  --cp-tight:  4px;
  --cp-snug:   8px;
  --cp-margin: 16px;
  --cp-gutter: 24px;
  --cp-bay:    32px;
  --cp-stanza: 64px;
  --cp-chapter:96px;
  --cp-folio:  128px;

  /* Radius */
  --cp-r-0:    0;
  --cp-r-1:    2px;
  --cp-r-card: 4px;

  background: var(--cp-bg);
  color: var(--cp-ink);
  font-family: "Inter", sans-serif;
  font-size: clamp(15px,1.3vw,17px);
  line-height: 1.55;
}

/* ── Reset within scope ──────────────────────────────────────── */
[data-design="a"].dq-design *, [data-design="a"].dq-design *::before, [data-design="a"].dq-design *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
[data-design="a"].dq-design fieldset { border: none; }
[data-design="a"].dq-design button, [data-design="a"].dq-design input, [data-design="a"].dq-design textarea { font-family: inherit; }


/* ═══════════════════════════════════════════════════════════════
   KEYFRAMES — all prefixed cp-
═══════════════════════════════════════════════════════════════════ */
@keyframes cp-blink { 0%,49% { opacity: 1; } 50%,100% { opacity: 0; } }
@keyframes cp-status-pulse { 0%,100% { opacity:1; box-shadow: 0 0 6px rgba(88,245,0,.6); } 50% { opacity:.65; box-shadow: 0 0 0 rgba(88,245,0,0); } }
@keyframes cp-cta-rotate { to { transform: rotate(360deg); } }
@keyframes cp-pointer-draw { to { transform: scaleY(1); } }
@keyframes cp-tick-fall {
  0%   { transform: translateY(0); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translateY(calc(108px - 10px)); opacity: 0; }
}
@keyframes cp-hero-title-in { to { opacity: 1; transform: translateY(0); } }
@keyframes cp-fade-in { to { opacity: 1; } }
@keyframes cp-rule-draw { to { transform: scaleX(1); } }
/* Logo shimmer — slow light-glint across wordmark */
@keyframes cp-logo-shimmer {
  0%, 88% { background-position: -200% center; }
  100%    { background-position: 200% center; }
}
/* Ambient rule drift — perceptible ongoing motion (HERO-1 ambient sustain) */
@keyframes cp-rule-drift {
  0%   { opacity: 0.18; transform: scaleX(1) translateX(0); }
  50%  { opacity: 0.32; transform: scaleX(1.04) translateX(1%); }
  100% { opacity: 0.18; transform: scaleX(1) translateX(0); }
}
/* Option row stagger entrance */
@keyframes cp-opt-in {
  from { opacity: 0; transform: translateX(-6px); }
  to   { opacity: 1; transform: translateX(0); }
}


/* ═══════════════════════════════════════════════════════════════
   E1 — HEADER  (three things: logo + ticker + menu)
═══════════════════════════════════════════════════════════════════ */
[data-design="a"] .cp-header {
  position: sticky; top: 0; z-index: 40;
  background: var(--cp-bg);
  border-bottom: 1px solid var(--cp-bg-line);
}
[data-design="a"] .cp-header__bar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 14px clamp(20px,4vw,40px);
  max-width: 1480px;
  margin: 0 auto;
}

/* Logo with shimmer — H-3 slow cycle (≥18s) */
[data-design="a"] .cp-logo {
  text-decoration: none;
  color: var(--cp-ink);
  font-family: "JetBrains Mono", monospace;
  font-size: clamp(12px,1.1vw,15px);
  font-weight: 500;
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  white-space: nowrap;
}
[data-design="a"] .cp-logo__bracket { color: var(--cp-signal); }
[data-design="a"] .cp-logo__mark {
  letter-spacing: -.005em;
  background: linear-gradient(90deg, var(--cp-ink) 40%, var(--cp-signal) 50%, var(--cp-ink) 60%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: cp-logo-shimmer 11s var(--cp-ease-linear) infinite;
}
[data-design="a"] .cp-logo__cursor {
  color: var(--cp-signal);
  animation: cp-blink 1.1s var(--cp-ease-linear) infinite;
  margin-left: 2px;
  -webkit-text-fill-color: var(--cp-signal);
}

/* Status ticker */
[data-design="a"] .cp-header__status {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  color: var(--cp-ink-soft);
  border: 1px solid var(--cp-bg-line);
  padding: 8px 14px;
  border-radius: var(--cp-r-1);
  background: var(--cp-bg-soft);
  overflow: hidden;
}
@media (max-width: 760px) { [data-design="a"] .cp-header__status { display: none; } }
[data-design="a"] .cp-header__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--cp-signal); flex: none;
  box-shadow: 0 0 6px rgba(88,245,0,.6);
  animation: cp-status-pulse 1.6s var(--cp-ease-settle) infinite;
}
[data-design="a"] .cp-header__ticker {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  color: var(--cp-signal);
}

/* Menu button */
[data-design="a"] .cp-menu-btn {
  appearance: none; background: transparent;
  color: var(--cp-ink);
  border: 1px solid var(--cp-rule-strong);
  padding: 8px 14px; cursor: pointer;
  border-radius: var(--cp-r-1);
  font-family: "JetBrains Mono", monospace; font-size: 13px;
  transition: border-color var(--cp-d-snap) var(--cp-ease-cmd), color var(--cp-d-snap) var(--cp-ease-cmd);
  min-width: 44px; min-height: 44px;
}
[data-design="a"] .cp-menu-btn:focus-visible { outline: 2px solid var(--cp-signal); outline-offset: 3px; }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .cp-menu-btn:hover { border-color: var(--cp-signal); color: var(--cp-signal); }
}

/* Drawer — phone-only, no nav (premium-funnel override) */
[data-design="a"] .cp-drawer {
  position: fixed; inset: 0; z-index: 50;
  background: var(--cp-bg);
  display: none;
}
[data-design="a"] .cp-drawer[data-open="true"] { display: block; }
[data-design="a"] .cp-drawer__close {
  appearance: none; background: transparent; border: 1px solid var(--cp-rule-strong);
  color: var(--cp-ink); font-family: "JetBrains Mono", monospace; font-size: 13px;
  padding: 12px 20px; cursor: pointer; border-radius: var(--cp-r-1);
  position: absolute; top: 20px; right: clamp(20px,4vw,40px);
  min-width: 44px; min-height: 44px;
}
[data-design="a"] .cp-drawer__close:focus-visible { outline: 2px solid var(--cp-signal); outline-offset: 3px; }
[data-design="a"] .cp-drawer__inner {
  max-width: 640px; margin: 0 auto;
  padding: clamp(80px,12vw,120px) clamp(20px,4vw,40px) 48px;
  display: grid; gap: 28px;
}
[data-design="a"] .cp-drawer__phone {
  display: grid; grid-template-columns: 40px 1fr auto; gap: 16px; align-items: baseline;
  padding: 24px 0; color: var(--cp-ink); text-decoration: none;
  border-bottom: 1px solid var(--cp-bg-line);
  font-family: "Inter Tight", sans-serif; font-weight: 700;
  font-size: clamp(28px,5vw,48px); letter-spacing: -.02em; line-height: 1.05;
}
[data-design="a"] .cp-drawer__sigil { font-family: "JetBrains Mono", monospace; font-size: 16px; color: var(--cp-mute); }
[data-design="a"] .cp-drawer__key { font-family: "JetBrains Mono", monospace; font-size: 13px; color: var(--cp-signal); }
[data-design="a"] .cp-drawer__note {
  font-family: "JetBrains Mono", monospace; font-size: 13px; color: var(--cp-mute); line-height: 1.6;
}


/* ═══════════════════════════════════════════════════════════════
   E3 / HERO — Step 1 funnel (hero_role: funnel_step_1)
   ONE animated layer: horizontal rule draw-in + ambient drift
═══════════════════════════════════════════════════════════════════ */
[data-design="a"] .cp-hero {
  position: relative;
  background: var(--cp-bg);
  color: var(--cp-ink);
  padding: clamp(40px,6vw,80px) clamp(20px,4vw,40px) clamp(56px,8vw,96px);
  border-bottom: 1px solid var(--cp-bg-line);
  overflow: hidden;
}

/* The ONE animated layer — ambient horizontal rule (HERO-1, HERO-2, HERO-3) */
[data-design="a"] .cp-hero__ambient {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
}
[data-design="a"] .cp-hero__rule-draw {
  position: absolute;
  left: 0; right: 0;
  top: clamp(160px, 22vw, 240px);
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--cp-signal) 30%, var(--cp-signal-deep) 70%, transparent 100%);
  transform-origin: left center;
  transform: scaleX(0);
  animation:
    cp-rule-draw 900ms 300ms var(--cp-ease-cmd) forwards,
    cp-rule-drift 8s 1400ms var(--cp-ease-settle) infinite;
}

[data-design="a"] .cp-hero__inner {
  position: relative; z-index: 1;
  max-width: 760px;
  margin: 0 auto;
}

/* CLI preamble */
[data-design="a"] .cp-hero__preamble {
  font-family: "JetBrains Mono", monospace;
  font-size: clamp(12px,1.1vw,15px);
  margin: 0 0 var(--cp-stanza);
  color: var(--cp-signal);
  min-height: 1.4em;
}
[data-design="a"] .cp-hero__prompt { color: var(--cp-mute); margin-right: 6px; }
[data-design="a"] .cp-hero__type { color: var(--cp-signal); }
[data-design="a"] .cp-hero__cursor {
  color: var(--cp-signal);
  animation: cp-blink 1.1s var(--cp-ease-linear) infinite;
  margin-left: 1px;
}

/* Value prop — opacity:1 at FIRST PAINT (never reveal-gated) */
[data-design="a"] .cp-hero__title {
  font-family: "Inter Tight", sans-serif; font-weight: 700;
  font-size: clamp(32px,5.5vw,72px);
  line-height: 1.04; letter-spacing: -.025em;
  margin: 0 0 var(--cp-gutter);
  max-width: 22ch;
  text-wrap: balance;
  opacity: 1;
  color: var(--cp-ink);
}
[data-design="a"] .cp-hero__title em { color: var(--cp-signal); font-style: normal; }

/* Reassurance line — opacity:1 at first paint */
[data-design="a"] .cp-hero__reassurance {
  font-family: "JetBrains Mono", monospace;
  font-size: clamp(12px,1vw,14px);
  color: var(--cp-mute);
  margin: 0 0 var(--cp-gutter);
  opacity: 1;
}

/* Progress wrap */
[data-design="a"] .cp-hero__progress-wrap {
  display: flex; align-items: center; gap: 14px;
  margin: 0 0 var(--cp-stanza);
  font-family: "JetBrains Mono", monospace; font-size: 11px;
  color: var(--cp-mute); letter-spacing: .12em; text-transform: uppercase;
}
[data-design="a"] .cp-hero__progress-bar {
  flex: 1; max-width: 200px; height: 1px; background: var(--cp-bg-line); position: relative;
}
[data-design="a"] .cp-hero__progress-bar span {
  position: absolute; inset: 0 auto 0 0; height: 100%;
  transform: scaleX(var(--cp-fn-pct, 0.2));
  transform-origin: left;
  background: var(--cp-signal);
  box-shadow: 0 0 4px rgba(88,245,0,.4);
  transition: transform var(--cp-d-settle) var(--cp-ease-cmd);
}

/* Step 1 question label */
[data-design="a"] .cp-hero__q1-label {
  font-family: "Inter Tight", sans-serif; font-weight: 700;
  font-size: clamp(20px,2.4vw,28px);
  line-height: 1.2; letter-spacing: -.015em;
  margin: 0 0 var(--cp-gutter);
  color: var(--cp-ink);
  opacity: 1;
}

/* Hero option grid — visual-presence floor buttons */
[data-design="a"] .cp-hero__options {
  display: grid; gap: 1px;
  background: var(--cp-bg-line);
  border: 1px solid var(--cp-bg-line);
  border-radius: var(--cp-r-card);
  overflow: hidden;
  box-shadow: 0 0 0 1px rgba(88,245,0,.18), 0 24px 60px -40px rgba(88,245,0,.08);
}

/* Stagger entrance on mount */
[data-design="a"] .cp-hero__options .cp-opt:nth-child(1) { animation: cp-opt-in 300ms 400ms var(--cp-ease-settle) both; }
[data-design="a"] .cp-hero__options .cp-opt:nth-child(2) { animation: cp-opt-in 300ms 520ms var(--cp-ease-settle) both; }
[data-design="a"] .cp-hero__options .cp-opt:nth-child(3) { animation: cp-opt-in 300ms 640ms var(--cp-ease-settle) both; }
[data-design="a"] .cp-hero__options .cp-opt:nth-child(4) { animation: cp-opt-in 300ms 760ms var(--cp-ease-settle) both; }
[data-design="a"] .cp-hero__options .cp-opt:nth-child(5) { animation: cp-opt-in 300ms 880ms var(--cp-ease-settle) both; }
[data-design="a"] .cp-hero__options .cp-opt:nth-child(6) { animation: cp-opt-in 300ms 1000ms var(--cp-ease-settle) both; }


/* ═══════════════════════════════════════════════════════════════
   SHARED cp-opt — terminal option rows
═══════════════════════════════════════════════════════════════════ */
[data-design="a"] .cp-opt {
  appearance: none;
  background: var(--cp-bg-soft);
  color: var(--cp-ink);
  border: 0;
  padding: 16px 18px;
  text-align: left;
  font-family: "JetBrains Mono", monospace;
  font-size: clamp(13px,1.1vw,14px);
  display: grid;
  grid-template-columns: 38px 1fr 18px;
  gap: 14px;
  align-items: baseline;
  cursor: pointer;
  min-height: 56px;
  transition: background var(--cp-d-snap) var(--cp-ease-cmd), color var(--cp-d-snap) var(--cp-ease-cmd);
  width: 100%;
}
[data-design="a"] .cp-opt:active { background: var(--cp-bg); color: var(--cp-signal); }
[data-design="a"] .cp-opt:focus-visible { outline: 2px solid var(--cp-signal); outline-offset: -2px; }
[data-design="a"] .cp-opt__key { color: var(--cp-mute); }
[data-design="a"] .cp-opt__arrow { color: var(--cp-signal); opacity: 0; transition: opacity var(--cp-d-snap) var(--cp-ease-cmd); }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .cp-opt:hover { background: var(--cp-bg); color: var(--cp-signal); }
  [data-design="a"] .cp-opt:hover .cp-opt__key { color: var(--cp-signal); }
  [data-design="a"] .cp-opt:hover .cp-opt__arrow { opacity: 1; }
}


/* ═══════════════════════════════════════════════════════════════
   E6 — POINTER  (signature element — bold, not a button)
   Rests directly above funnel — draws eye down into form
   HERO-2 override: hero_role=funnel_step_1 → pointer allowed
═══════════════════════════════════════════════════════════════════ */
[data-design="a"] .cp-pointer {
  position: relative; z-index: 5;
  max-width: 1480px;
  margin: -24px auto -12px;
  padding: 0 clamp(20px,4vw,40px);
  display: flex;
  justify-content: flex-start;
  pointer-events: none;
  /* Visibility guarantee — bounding-box ≥ 8px, opacity:1 */
  opacity: 1;
  min-height: 140px;
}
[data-design="a"] .cp-pointer__inner {
  display: flex; flex-direction: column; align-items: flex-start; gap: 10px;
  pointer-events: auto;
  padding-left: clamp(20px,4vw,40px);
}
[data-design="a"] .cp-pointer__header {
  display: inline-flex; align-items: baseline; gap: 8px;
  font-family: "JetBrains Mono", monospace; font-size: 13px; color: var(--cp-mute);
  /* Visible at first paint — no opacity:0 reveal gate */
  opacity: 1;
  animation: cp-fade-in 400ms 200ms var(--cp-ease-settle) both;
}
[data-design="a"] .cp-pointer__cursor {
  color: var(--cp-signal);
  animation: cp-blink 1.1s var(--cp-ease-linear) infinite;
}
[data-design="a"] .cp-pointer__rule {
  position: relative; width: 1px; height: 108px;
  background: var(--cp-signal-deep);
  transform-origin: top center;
  transform: scaleY(0);
  animation: cp-pointer-draw 700ms 600ms var(--cp-ease-cmd) forwards;
}
[data-design="a"] .cp-pointer__tick {
  position: absolute; left: -2px; right: -2px; top: 0; height: 10px;
  background: var(--cp-signal);
  box-shadow: 0 0 4px rgba(88,245,0,.6);
  animation: cp-tick-fall 4.4s 1400ms var(--cp-ease-linear) infinite;
}


/* ═══════════════════════════════════════════════════════════════
   E5 — FUNNEL SECTION  (steps 2-5)
═══════════════════════════════════════════════════════════════════ */
[data-design="a"] .cp-funnel-section {
  background: var(--cp-bg);
  color: var(--cp-ink);
  padding: clamp(40px,6vw,80px) clamp(20px,4vw,40px) clamp(64px,9vw,112px);
  border-bottom: 1px solid var(--cp-bg-line);
}
[data-design="a"] .cp-funnel-section__head {
  max-width: 680px; margin: 0 auto var(--cp-gutter);
}

/* Eyebrow */
[data-design="a"] .cp-eyebrow {
  font-family: "JetBrains Mono", monospace; font-size: 11px;
  letter-spacing: .14em; color: var(--cp-mute); text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 10px;
  margin-bottom: 4px;
}
[data-design="a"] .cp-eyebrow__dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--cp-signal);
}

/* Funnel form container */
[data-design="a"] .cp-funnel {
  max-width: 680px; margin: 0 auto;
  background: var(--cp-bg-soft);
  border: 1px solid var(--cp-rule-strong);
  border-radius: var(--cp-r-card);
  box-shadow: 0 0 0 1px rgba(88,245,0,.18), 0 24px 60px -40px rgba(88,245,0,.08);
  overflow: hidden;
}

/* Progress bar */
[data-design="a"] .cp-funnel__progress {
  display: grid; grid-template-columns: auto 1fr auto; gap: 16px; align-items: center;
  padding: 14px 22px; border-bottom: 1px solid var(--cp-bg-line);
  background: var(--cp-bg);
  font-family: "JetBrains Mono", monospace; font-size: 12px;
}
[data-design="a"] .cp-funnel__progress-num { color: var(--cp-mute); white-space: nowrap; }
[data-design="a"] .cp-funnel__progress-bar {
  flex: 1; height: 1px; background: var(--cp-bg-line); position: relative;
}
[data-design="a"] .cp-funnel__progress-bar span {
  position: absolute; inset: 0 auto 0 0; height: 100%;
  transform: scaleX(var(--cp-fn-pct, 0.25));
  transform-origin: left;
  background: var(--cp-signal); box-shadow: 0 0 4px rgba(88,245,0,.4);
  transition: transform var(--cp-d-settle) var(--cp-ease-cmd);
}
[data-design="a"] .cp-funnel__hint { color: var(--cp-mute); font-size: 11px; font-family: "JetBrains Mono", monospace; }
@media (max-width: 560px) { [data-design="a"] .cp-funnel__hint { display: none; } }

/* Steps container */
[data-design="a"] .cp-funnel__steps {
  position: relative;
  padding: clamp(24px,4vw,40px);
  min-height: 360px;
  overflow: hidden;
}

/* Individual step — E3 transition motion (200ms fade + 60ms translate) */
[data-design="a"] .cp-funnel__step {
  position: absolute;
  inset: clamp(24px,4vw,40px);
  opacity: 0;
  pointer-events: none;
  transform: translateX(8px);
  transition: opacity 200ms var(--cp-ease-cmd), transform 200ms var(--cp-ease-cmd);
}
[data-design="a"] .cp-funnel__step[data-active="true"] {
  opacity: 1; pointer-events: auto; transform: translateX(0);
}
/* Done step uses same transition */
[data-design="a"] .cp-funnel__done {
  position: absolute;
  inset: clamp(24px,4vw,40px);
  opacity: 0;
  pointer-events: none;
  transform: translateX(8px);
  transition: opacity 200ms var(--cp-ease-cmd), transform 200ms var(--cp-ease-cmd);
}
[data-design="a"] .cp-funnel__done[data-active="true"] {
  opacity: 1; pointer-events: auto; transform: translateX(0);
}

[data-design="a"] .cp-funnel__step h3 {
  font-family: "Inter Tight", sans-serif; font-weight: 700;
  font-size: clamp(20px,2.4vw,26px); line-height: 1.2; letter-spacing: -.015em;
  margin: 0 0 8px;
}
[data-design="a"] .cp-prompt {
  font-family: "JetBrains Mono", monospace;
  color: var(--cp-signal); margin-right: 6px;
}
[data-design="a"] .cp-funnel__step p {
  font-family: "Inter", sans-serif; font-size: 15px; color: var(--cp-ink-soft);
  margin: 0 0 20px; max-width: 52ch;
}

/* Options grid */
[data-design="a"] .cp-funnel__options {
  display: grid; gap: 1px;
  background: var(--cp-bg-line);
  border: 1px solid var(--cp-bg-line);
}

/* Actions row */
[data-design="a"] .cp-funnel__actions {
  display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 20px;
}
[data-design="a"] .cp-funnel__actions--submit { flex-wrap: wrap; gap: 16px; }
[data-design="a"] .cp-funnel__back {
  appearance: none; background: transparent; border: 0;
  color: var(--cp-mute); font-family: "JetBrains Mono", monospace; font-size: 13px;
  cursor: pointer; padding: 8px 0; min-height: 44px;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .cp-funnel__back:hover { color: var(--cp-ink); }
}

/* Contact fields */
[data-design="a"] .cp-funnel__field { display: grid; gap: 6px; margin-bottom: 14px; }
[data-design="a"] .cp-funnel__field label {
  font-family: "JetBrains Mono", monospace; font-size: 11px;
  color: var(--cp-mute); letter-spacing: .14em; text-transform: uppercase;
}
[data-design="a"] .cp-funnel__field input,
[data-design="a"] .cp-funnel__field textarea {
  background: var(--cp-bg); color: var(--cp-ink);
  border: 1px solid var(--cp-rule-strong);
  padding: 12px 14px;
  font-family: "JetBrains Mono", monospace; font-size: 14px;
  outline: none; width: 100%;
  border-radius: var(--cp-r-1);
  min-height: 44px;
  transition: border-color var(--cp-d-register) var(--cp-ease-cmd), box-shadow var(--cp-d-register) var(--cp-ease-cmd);
}
[data-design="a"] .cp-funnel__field input:focus,
[data-design="a"] .cp-funnel__field textarea:focus {
  border-color: var(--cp-signal);
  box-shadow: 0 0 0 1px rgba(88,245,0,.4);
}


/* ═══════════════════════════════════════════════════════════════
   E2 — CTA BUTTON  (terminal bracket + traveling glow)
   Used as submit button in funnel and inline
═══════════════════════════════════════════════════════════════════ */
[data-design="a"] .cp-cta {
  position: relative;
  display: inline-flex; align-items: center;
  padding: 16px 24px;
  background: var(--cp-bg);
  color: var(--cp-ink);
  border: 1px solid var(--cp-signal-deep);
  text-decoration: none; cursor: pointer; isolation: isolate;
  font-family: "JetBrains Mono", monospace; font-size: 14px; font-weight: 500;
  border-radius: var(--cp-r-1);
  min-height: 56px;
  transition: transform var(--cp-d-press) var(--cp-ease-cmd), border-color var(--cp-d-register) var(--cp-ease-cmd);
}
[data-design="a"] .cp-cta__glow {
  position: absolute; inset: -1px; border-radius: inherit; pointer-events: none; z-index: -1;
  background: conic-gradient(from 0deg, transparent 0deg, var(--cp-signal) 60deg, transparent 120deg);
  animation: cp-cta-rotate 4.4s var(--cp-ease-linear) infinite;
  opacity: .7;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding: 1px;
}
[data-design="a"] .cp-cta__arrow {
  color: var(--cp-signal);
  opacity: 0;
  transition: opacity var(--cp-d-register) var(--cp-ease-cmd);
}
[data-design="a"] .cp-cta:active { transform: translateY(1px); }
[data-design="a"] .cp-cta:focus-visible { outline: 2px solid var(--cp-signal); outline-offset: 3px; }
[data-design="a"] .cp-cta--submit { border-color: var(--cp-signal); }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .cp-cta:hover { border-color: var(--cp-signal); }
  [data-design="a"] .cp-cta:hover .cp-cta__glow { animation-duration: 2.2s; opacity: 1; }
  [data-design="a"] .cp-cta:hover .cp-cta__arrow { opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .cp-cta__glow { animation: none !important; opacity: .35 !important; }
}

/* Confirmation state */
[data-design="a"] .cp-funnel__log {
  font-family: "JetBrains Mono", monospace; font-size: 13px;
  background: var(--cp-bg); border: 1px solid var(--cp-bg-line);
  border-radius: var(--cp-r-1);
  padding: 12px 16px; margin-bottom: 20px; color: var(--cp-ink-soft);
  display: grid; grid-template-columns: 120px 60px 1fr; gap: 16px; align-items: baseline;
}
[data-design="a"] .cp-log__level {
  display: inline-block; font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
  padding: 2px 6px; border-radius: var(--cp-r-1); border: 1px solid currentColor; line-height: 1.2;
  font-family: "JetBrains Mono", monospace;
}
[data-design="a"] .cp-log__level--ok   { color: var(--cp-signal); }
[data-design="a"] .cp-log__level--info { color: var(--cp-ink-soft); }
[data-design="a"] .cp-log__level--warn { color: var(--cp-amber); }
[data-design="a"] .cp-log__level--err  { color: var(--cp-red); }

[data-design="a"] .cp-funnel__done h3 {
  font-family: "Inter Tight", sans-serif; font-weight: 700;
  font-size: clamp(22px,3vw,30px); margin: 0 0 10px; letter-spacing: -.015em;
}
[data-design="a"] .cp-funnel__done p {
  font-family: "Inter", sans-serif; color: var(--cp-ink-soft); margin: 0 0 20px; max-width: 48ch;
}
[data-design="a"] .cp-funnel__writ {
  border-top: 1px solid var(--cp-bg-line); padding-top: 20px; margin-top: 20px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
[data-design="a"] .cp-funnel__writ a {
  font-family: "JetBrains Mono", monospace; font-size: 14px;
  color: var(--cp-ink); text-decoration: none; display: grid; gap: 4px; line-height: 1.4;
}
[data-design="a"] .cp-funnel__writ a small { font-size: 10.5px; color: var(--cp-mute); letter-spacing: .14em; text-transform: uppercase; }
[data-design="a"] .cp-funnel__writ a strong { color: var(--cp-signal); font-weight: 500; }
@media (max-width: 480px) { [data-design="a"] .cp-funnel__writ { grid-template-columns: 1fr; } }


/* ═══════════════════════════════════════════════════════════════
   E4 — REASSURANCE BAR (tailed log — ambient segment B)
═══════════════════════════════════════════════════════════════════ */
[data-design="a"] .cp-reassurance {
  background: var(--cp-bg);
  padding: clamp(56px,8vw,96px) clamp(20px,4vw,40px);
  border-bottom: 1px solid var(--cp-bg-line);
}
[data-design="a"] .cp-reassurance__inner { max-width: 1480px; margin: 0 auto; }
[data-design="a"] .cp-reassurance__head { margin-bottom: var(--cp-gutter); }
[data-design="a"] .cp-log-section__head { max-width: 1480px; margin: 0 auto var(--cp-stanza); }

[data-design="a"] .cp-log {
  background: var(--cp-bg-soft);
  border: 1px solid var(--cp-bg-line);
  border-radius: var(--cp-r-card);
  font-family: "JetBrains Mono", monospace; font-size: 13px;
  overflow-x: auto;
}
[data-design="a"] .cp-log__head {
  display: grid; grid-template-columns: 140px 72px 1fr; gap: 16px;
  padding: 12px 20px; border-bottom: 1px solid var(--cp-bg-line);
  color: var(--cp-mute); text-transform: uppercase; letter-spacing: .12em; font-size: 11px;
}
@media (max-width: 600px) {
  [data-design="a"] .cp-log__head { grid-template-columns: 1fr; }
  [data-design="a"] .cp-log__head span:not(:first-child) { display: none; }
}
[data-design="a"] .cp-log__row {
  display: grid; grid-template-columns: 140px 72px 1fr; gap: 16px; align-items: baseline;
  padding: 12px 20px; border-bottom: 1px solid var(--cp-bg-line);
  opacity: 0; transform: translateX(-4px);
  transition: opacity 400ms var(--cp-ease-cmd), transform 400ms var(--cp-ease-cmd);
}
[data-design="a"] .cp-log__row:last-child { border-bottom: 0; }
[data-design="a"] .cp-log__row[data-in="true"] { opacity: 1; transform: translateX(0); }
@media (max-width: 600px) {
  [data-design="a"] .cp-log__row { grid-template-columns: auto 1fr; }
  [data-design="a"] .cp-log__time { display: none; }
}
[data-design="a"] .cp-log__time { color: var(--cp-mute); }
[data-design="a"] .cp-log__msg { color: var(--cp-ink); }
[data-design="a"] .cp-log__link { color: var(--cp-signal); text-decoration: none; }
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .cp-log__link:hover { text-decoration: underline; }
}


/* ═══════════════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════════════════ */
[data-design="a"] .cp-footer {
  background: var(--cp-bg);
  padding: clamp(40px,6vw,64px) clamp(20px,4vw,40px) clamp(24px,3vw,32px);
  border-top: 1px solid var(--cp-bg-line);
}
[data-design="a"] .cp-footer__inner {
  max-width: 1480px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(24px,4vw,48px);
}
@media (max-width: 760px) { [data-design="a"] .cp-footer__inner { grid-template-columns: 1fr; } }
[data-design="a"] .cp-footer__col { display: grid; gap: 8px; align-content: start; }
[data-design="a"] .cp-footer__brand {
  font-family: "JetBrains Mono", monospace; font-size: 13px; color: var(--cp-ink); font-weight: 500;
}
[data-design="a"] .cp-footer__tagline {
  font-family: "JetBrains Mono", monospace; font-size: 12px; color: var(--cp-mute);
}
[data-design="a"] .cp-footer__phone {
  font-family: "Inter Tight", sans-serif; font-weight: 700; font-size: 18px;
  color: var(--cp-signal); text-decoration: none; display: block;
}
[data-design="a"] .cp-footer__addr {
  font-family: "JetBrains Mono", monospace; font-size: 12px; color: var(--cp-mute); display: block; line-height: 1.6;
}
[data-design="a"] .cp-footer__col--legal { display: grid; gap: 10px; align-content: start; }
[data-design="a"] .cp-footer__copy {
  font-family: "JetBrains Mono", monospace; font-size: 11px; color: var(--cp-mute);
}
[data-design="a"] .cp-footer__disclaimer {
  font-family: "Inter", sans-serif; font-size: 11px; color: var(--cp-dim); line-height: 1.5; max-width: 48ch;
}
[data-design="a"] .cp-footer__status {
  max-width: 1480px; margin: 24px auto 0;
  padding-top: 16px; border-top: 1px solid var(--cp-bg-line);
  display: flex; align-items: center; gap: 12px;
  font-family: "JetBrains Mono", monospace; font-size: 11px; color: var(--cp-mute);
}
[data-design="a"] .cp-footer__dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--cp-signal); flex: none;
  box-shadow: 0 0 4px rgba(88,245,0,.5);
  animation: cp-status-pulse 1.6s var(--cp-ease-settle) infinite;
}
[data-design="a"] .cp-footer__right { margin-left: auto; }


/* ═══════════════════════════════════════════════════════════════
   TRIAD-2 — SCROLL-LINKED MOTION (hero→funnel handoff)
   Real scroll-driven parallax: reassurance rows transform on scroll
   Uses scroll-timeline on supporting browsers, JS fallback
═══════════════════════════════════════════════════════════════════ */
[data-design="a"] .cp-reassurance {
  --scroll-progress: 0;
}
[data-design="a"] .cp-log--trust {
  transform: translateY(calc(var(--scroll-progress) * -20px));
  transition: transform 0ms linear;
}

/* ═══════════════════════════════════════════════════════════════
   REDUCED MOTION FALLBACKS
═══════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .cp-logo__mark { animation: none !important; background: none !important; -webkit-text-fill-color: var(--cp-ink) !important; }
  [data-design="a"] .cp-logo__cursor { animation: none !important; opacity: 1 !important; }
  [data-design="a"] .cp-header__dot { animation: none !important; opacity: 1 !important; }
  [data-design="a"] .cp-hero__rule-draw { animation: none !important; transform: scaleX(1) !important; opacity: 0.25 !important; }
  [data-design="a"] .cp-hero__cursor { animation: none !important; opacity: 1 !important; }
  [data-design="a"] .cp-hero__options .cp-opt { animation: none !important; opacity: 1 !important; transform: none !important; }
  [data-design="a"] .cp-pointer__header { animation: none !important; opacity: 1 !important; }
  [data-design="a"] .cp-pointer__rule { animation: none !important; transform: scaleY(1) !important; }
  [data-design="a"] .cp-pointer__tick { animation: none !important; opacity: 1 !important; }
  [data-design="a"] .cp-pointer__cursor { animation: none !important; opacity: 1 !important; }
  [data-design="a"] .cp-funnel__step { transition-duration: 100ms !important; transform: none !important; }
  [data-design="a"] .cp-funnel__done { transition-duration: 100ms !important; transform: none !important; }
  [data-design="a"] .cp-log__row { transition-duration: 50ms !important; transform: none !important; }
  [data-design="a"] .cp-cta__glow { animation: none !important; opacity: .35 !important; }
  [data-design="a"] .cp-footer__dot { animation: none !important; opacity: 1 !important; }
  [data-design="a"] .cp-log--trust { transform: none !important; }
}


/* ═══════════════════════════════════════════════════════════════
   MOBILE ANTI-HSCROLL GUARD (scoped, mandatory)
═══════════════════════════════════════════════════════════════════ */
[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;
}

/* 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; }
