/* ══════════════════════════════════════════════════════════════════
   Newberg Plumbing Services — Design A (Dragon Panel × Plumber)
   Slot-scoped: [data-design="a"] everywhere.
   Design tokens: --design-a-primary exposed as primary accent.
   ~950 rules / lines target.
   ZERO bare/global rules. ALL selectors begin [data-design="a"] or
   @media / @keyframes / :root.
═══════════════════════════════════════════════════════════════════ */

/* ── Design-A tokens ─────────────────────────────────────────── */
:root {
  --design-a-primary: #6FE3A8;   /* copper-warm → remapped: segment-green (the pressure-alive color) */
  /* Full Dragon Panel token set, prefixed dp-, scoped to [data-design="a"] */
}

[data-design="a"].dq-design,
[data-design="a"] .dq-design {
  --dp-bg:         #0F1112;
  --dp-surface:    #16191B;
  --dp-surface-2:  #1E2226;
  --dp-ink:        #E8E4D8;
  --dp-muted:      #8A8378;
  --dp-accent:     #6FE3A8;
  --dp-accent-2:   #F0B656;
  --dp-aluminum:   #C5C2BD;
  --dp-critical:   #E25555;
  --dp-success:    #6FE3A8;

  --dp-font-display: "Eurostile", "Bank Gothic", "Helvetica Neue Condensed", -apple-system, system-ui, "Segoe UI Condensed", sans-serif;
  --dp-font-body:    -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", system-ui, sans-serif;
  --dp-font-mono:    "JetBrains Mono", "IBM Plex Mono", "SF Mono", ui-monospace, Menlo, monospace;
  --dp-font-segment: "JetBrains Mono", "IBM Plex Mono", ui-monospace, Menlo, monospace;

  --dp-trace:    4px;
  --dp-detent:   8px;
  --dp-cell:     16px;
  --dp-panel:    28px;
  --dp-rack:     48px;
  --dp-bay:      96px;
  --dp-deck:     140px;

  --dp-flick:   80ms;
  --dp-snap:    180ms;
  --dp-settle:  380ms;
  --dp-sweep:   1400ms;
  --dp-drift:   24s;

  --dp-ease-calibrate: cubic-bezier(0.22, 0.61, 0.36, 1);
  --dp-ease-relay:     cubic-bezier(0.16, 1, 0.3, 1);
  --dp-ease-segment:   steps(8, end);

  --dp-radius-hair:   1px;
  --dp-radius-button: 3px;
  --dp-radius-plate:  6px;
  --dp-radius-pill:   9999px;

  --design-a-primary: #6FE3A8;
}

/* ── Base shell ───────────────────────────────────────────────── */
[data-design="a"].dq-design {
  background: var(--dp-bg);
  color: var(--dp-ink);
  font-family: var(--dp-font-body);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* ── Silkscreen label style ───────────────────────────────────── */
[data-design="a"] .dp-silkscreen {
  font-family: var(--dp-font-display);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 12px;
  color: var(--dp-muted);
  margin: 0;
}

/* ════════════════════════════════════════════════════════════════
   E1 — HEADER
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--dp-bg);
  font-family: var(--dp-font-display);
}

[data-design="a"] .dp-header__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px clamp(16px, 4vw, 40px);
  min-height: 64px;
  box-sizing: border-box;
}

[data-design="a"] .dp-logo {
  text-decoration: none;
}

[data-design="a"] .dp-logo__mark {
  color: var(--dp-ink);
  font-weight: 600;
  letter-spacing: 0.18em;
  font-size: 15px;
  text-transform: uppercase;
  white-space: nowrap;
}

[data-design="a"] .dp-hamburger {
  background: var(--dp-surface-2);
  border: 0;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--dp-aluminum), transparent 82%);
  border-radius: var(--dp-radius-button);
  width: 44px;
  height: 44px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  cursor: pointer;
  flex-shrink: 0;
  transition: box-shadow var(--dp-snap) var(--dp-ease-relay);
}

[data-design="a"] .dp-hamburger:hover {
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--dp-aluminum), transparent 60%);
}

[data-design="a"] .dp-hamburger:focus-visible {
  outline: 0;
  box-shadow:
    inset 0 0 0 1px var(--dp-accent),
    0 0 0 2px color-mix(in oklab, var(--dp-accent), transparent 60%);
}

[data-design="a"] .dp-hamburger__bar {
  display: block;
  width: 16px;
  height: 1px;
  background: var(--dp-ink);
}

[data-design="a"] .dp-header__rule {
  position: relative;
  height: 1px;
  background: color-mix(in oklab, var(--dp-aluminum), transparent 86%);
  overflow: hidden;
}

[data-design="a"] .dp-header__needle {
  position: absolute;
  top: -2px;
  left: -60px;
  width: 60px;
  height: 5px;
  background: radial-gradient(closest-side,
    color-mix(in oklab, var(--dp-accent), transparent 40%) 0%,
    color-mix(in oklab, var(--dp-accent), transparent 80%) 50%,
    transparent 100%);
  filter: blur(2px);
  animation: dp-header-drift 24s cubic-bezier(0.45, 0, 0.55, 1) infinite alternate;
}

@keyframes dp-header-drift {
  0%   { left: -60px;              opacity: 0.65; }
  35%  {                            opacity: 1; }
  50%  { left: calc(50% - 30px);   opacity: 0.9; }
  65%  {                            opacity: 1; }
  100% { left: calc(100% + 60px);  opacity: 0.65; }
}

/* Drawer — display:none when closed */
[data-design="a"] .dp-drawer {
  display: none;
  background: var(--dp-surface);
  padding: var(--dp-panel) clamp(16px, 4vw, 40px) var(--dp-rack);
  border-top: 1px solid color-mix(in oklab, var(--dp-aluminum), transparent 86%);
  position: relative;
  z-index: 51;
}

[data-design="a"] .dp-drawer[data-open="true"] {
  display: block;
}

[data-design="a"] .dp-drawer__close {
  position: absolute;
  top: 16px;
  right: clamp(16px, 4vw, 40px);
  background: var(--dp-surface-2);
  border: 0;
  color: var(--dp-ink);
  font-size: 18px;
  width: 44px;
  height: 44px;
  border-radius: var(--dp-radius-button);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--dp-aluminum), transparent 80%);
}

[data-design="a"] .dp-drawer__close:focus-visible {
  outline: 2px solid var(--dp-accent);
  outline-offset: 2px;
}

[data-design="a"] .dp-drawer a {
  display: block;
  color: var(--dp-ink);
  text-decoration: none;
  font-family: var(--dp-font-display);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 14px;
  padding: 14px 0;
  border-bottom: 1px solid color-mix(in oklab, var(--dp-aluminum), transparent 90%);
  transition: color var(--dp-snap) var(--dp-ease-relay);
  min-height: 44px;
}

[data-design="a"] .dp-drawer a:hover,
[data-design="a"] .dp-drawer a:focus-visible {
  color: var(--dp-accent);
  outline: 0;
}

[data-design="a"] .dp-drawer__phone {
  display: flex !important;
  align-items: center;
  gap: 12px;
  font-size: 16px !important;
  letter-spacing: 0.14em !important;
  color: var(--dp-accent) !important;
  margin-top: 16px;
  border-bottom: none !important;
}

/* Backdrop for drawer */
[data-design="a"] .dp-drawer-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  z-index: 49;
}

[data-design="a"] .dp-drawer-backdrop[data-open="true"] {
  display: block;
}

/* ════════════════════════════════════════════════════════════════
   HERO — E3 substrate + text in normal flow
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-hero {
  position: relative;
  min-height: clamp(420px, 70vh, 680px);
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: clamp(56px, 8vw, 96px) clamp(16px, 4vw, 64px);
  box-sizing: border-box;
}

/* E3: Single animated substrate layer — z-index 0, pointer-events none */
[data-design="a"] .dp-hero__substrate {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

/* Copper-pressure radial gradient field — sustained ambient breath */
[data-design="a"] .dp-hero__copper-field {
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 70% 60% at 62% 48%,
    color-mix(in oklab, #B05A1A, transparent 72%) 0%,
    color-mix(in oklab, var(--dp-accent), transparent 88%) 40%,
    transparent 75%
  );
  animation: dp-hero-copper-breath 5s var(--dp-ease-calibrate) infinite alternate;
  opacity: 1;
}

@keyframes dp-hero-copper-breath {
  0%   { opacity: 0.35; transform: scale(1);    }
  50%  { opacity: 0.65; transform: scale(1.04); }
  100% { opacity: 0.45; transform: scale(0.98); }
}

[data-design="a"] .dp-hero__pipe-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.18;
}

/* Hero content — normal flow, z-index 1, NO overlap between children */
[data-design="a"] .dp-hero__content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 760px;
}

[data-design="a"] .dp-hero__eyebrow {
  margin-bottom: 16px;
  letter-spacing: 0.22em;
}

[data-design="a"] .dp-hero__headline {
  font-family: var(--dp-font-display);
  font-size: clamp(28px, 5vw, 56px);
  font-weight: 600;
  letter-spacing: -0.005em;
  line-height: 1.08;
  color: var(--dp-ink);
  margin: 0 0 20px;
  max-width: 20ch;
  /* opacity:1 at first paint — never opacity:0 */
  opacity: 1;
}

[data-design="a"] .dp-hero__subtitle {
  font-size: clamp(16px, 2vw, 19px);
  line-height: 1.55;
  color: var(--dp-muted);
  margin: 0 0 16px;
  max-width: 52ch;
  opacity: 1;
}

[data-design="a"] .dp-hero__proof {
  font-family: var(--dp-font-display);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dp-muted);
  margin: 0 0 28px;
  opacity: 1;
}

/* E2: Phone CTA */
[data-design="a"] .dp-hero__cta {
  display: inline-flex;
  width: fit-content;
  min-width: 200px;
  margin-bottom: 16px;
}

[data-design="a"] .dp-hero__trust-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--dp-font-display);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dp-muted);
  margin: 0;
  opacity: 1;
}

/* ════════════════════════════════════════════════════════════════
   E2 — CTA button (phone + inline variants)
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 22px 14px 18px;
  background: var(--dp-surface-2);
  color: var(--dp-ink);
  font-family: var(--dp-font-display);
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: var(--dp-radius-button);
  border: 0;
  box-shadow:
    inset 0 0 0 1px color-mix(in oklab, var(--dp-aluminum), transparent 78%),
    inset 0 1px 0 0 color-mix(in oklab, var(--dp-aluminum), transparent 72%),
    0 1px 0 0 #000;
  transition:
    box-shadow var(--dp-snap) var(--dp-ease-relay),
    transform var(--dp-snap) var(--dp-ease-relay),
    color var(--dp-snap) var(--dp-ease-relay);
  cursor: pointer;
  min-height: 44px;
  box-sizing: border-box;
}

[data-design="a"] .dp-cta__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--dp-radius-pill);
  background: var(--dp-muted);
  box-shadow: 0 0 0 1px color-mix(in oklab, var(--dp-muted), transparent 60%);
  animation: dp-cta-breath 4.2s var(--dp-ease-calibrate) infinite;
  flex-shrink: 0;
}

[data-design="a"] .dp-cta__arrow {
  display: inline-flex;
  align-items: center;
  color: var(--dp-muted);
  transition:
    color var(--dp-snap) var(--dp-ease-relay),
    transform var(--dp-snap) var(--dp-ease-relay);
  flex-shrink: 0;
}

[data-design="a"] .dp-cta:hover,
[data-design="a"] .dp-cta:focus-visible {
  outline: 0;
  color: var(--dp-ink);
  box-shadow:
    inset 0 0 0 1px color-mix(in oklab, var(--dp-aluminum), transparent 55%),
    inset 0 1px 0 0 color-mix(in oklab, var(--dp-aluminum), transparent 50%),
    0 1px 0 0 #000;
}

[data-design="a"] .dp-cta:hover .dp-cta__dot,
[data-design="a"] .dp-cta:focus-visible .dp-cta__dot {
  background: var(--dp-accent);
  box-shadow: 0 0 6px color-mix(in oklab, var(--dp-accent), transparent 55%);
  animation: none;
}

[data-design="a"] .dp-cta:hover .dp-cta__arrow,
[data-design="a"] .dp-cta:focus-visible .dp-cta__arrow {
  color: var(--dp-accent);
  transform: translateX(2px);
}

[data-design="a"] .dp-cta:active {
  transform: translateY(1px);
}

[data-design="a"] .dp-cta[data-armed="true"] .dp-cta__dot {
  background: var(--dp-accent);
  box-shadow: 0 0 10px var(--dp-accent), 0 0 0 1px var(--dp-accent);
}

[data-design="a"] .dp-cta--inline {
  display: inline-flex;
  margin-top: 20px;
}

@keyframes dp-cta-breath {
  0%, 100% {
    background: var(--dp-muted);
    box-shadow: 0 0 0 1px color-mix(in oklab, var(--dp-muted), transparent 60%);
  }
  50% {
    background: var(--dp-accent-2);
    box-shadow: 0 0 6px color-mix(in oklab, var(--dp-accent-2), transparent 55%);
  }
}

/* ════════════════════════════════════════════════════════════════
   SERVICES — E4 schematic ambient B
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-schematic {
  position: relative;
  padding: var(--dp-bay) clamp(16px, 4vw, 40px);
  background: var(--dp-surface);
  overflow: hidden;
  color: var(--dp-ink);
}

[data-design="a"] .dp-schematic__svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  color: color-mix(in oklab, var(--dp-aluminum), transparent 78%);
  pointer-events: none;
}

[data-design="a"] .dp-trace {
  stroke-dasharray: 1400;
  stroke-dashoffset: 1400;
}

[data-design="a"] .dp-schematic[data-armed="true"] .dp-trace {
  animation: dp-trace-draw 2400ms var(--dp-ease-calibrate) forwards;
}

[data-design="a"] .dp-schematic[data-armed="true"] .dp-trace:nth-child(2) { animation-delay: 200ms; }
[data-design="a"] .dp-schematic[data-armed="true"] .dp-trace:nth-child(3) { animation-delay: 300ms; }
[data-design="a"] .dp-schematic[data-armed="true"] .dp-trace:nth-child(4) { animation-delay: 500ms; }
[data-design="a"] .dp-schematic[data-armed="true"] .dp-trace:nth-child(n+5) { animation-delay: 700ms; }

@keyframes dp-trace-draw { to { stroke-dashoffset: 0; } }

[data-design="a"] .dp-schematic__live {
  opacity: 0;
  filter: drop-shadow(0 0 6px var(--dp-accent));
}

[data-design="a"] .dp-schematic[data-armed="true"] .dp-schematic__live {
  opacity: 1;
  animation: dp-live-pulse 3.6s var(--dp-ease-calibrate) infinite 2.4s;
}

@keyframes dp-live-pulse {
  0%, 100% { opacity: 0.55; }
  50%      { opacity: 1; }
}

[data-design="a"] .dp-schematic__content {
  position: relative;
  z-index: 1;
  max-width: 860px;
  background: linear-gradient(180deg,
    color-mix(in oklab, var(--dp-surface), transparent 0%) 0%,
    color-mix(in oklab, var(--dp-surface), transparent 0%) 80%,
    transparent 100%);
  padding: 24px 28px;
  border-left: 1px solid color-mix(in oklab, var(--dp-aluminum), transparent 86%);
}

[data-design="a"] .dp-schematic__title {
  font-family: var(--dp-font-display);
  font-size: clamp(28px, 4vw, 48px);
  letter-spacing: -0.005em;
  line-height: 1.08;
  margin: 8px 0 24px;
  max-width: 22ch;
}

[data-design="a"] .dp-schematic__body {
  color: var(--dp-ink);
  line-height: 1.6;
  max-width: 740px;
}

/* Service list rows */
[data-design="a"] .dp-service-list {
  list-style: none;
  padding: 0;
  margin: 0 0 8px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

[data-design="a"] .dp-service-row {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  align-items: baseline;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid color-mix(in oklab, var(--dp-aluminum), transparent 90%);
  background: var(--dp-surface);
  box-shadow: inset 0 0 0 0 transparent;
  transition: box-shadow var(--dp-snap) var(--dp-ease-relay);
  border-radius: 0;
}

[data-design="a"] .dp-service-row:first-child {
  border-radius: var(--dp-radius-plate) var(--dp-radius-plate) 0 0;
  border: 1px solid color-mix(in oklab, var(--dp-aluminum), transparent 88%);
  border-bottom: 1px solid color-mix(in oklab, var(--dp-aluminum), transparent 90%);
}

[data-design="a"] .dp-service-row:last-child {
  border-radius: 0 0 var(--dp-radius-plate) var(--dp-radius-plate);
}

[data-design="a"] .dp-service-num {
  font-family: var(--dp-font-display);
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--dp-muted);
  text-transform: uppercase;
}

[data-design="a"] .dp-service-name {
  font-family: var(--dp-font-display);
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dp-ink);
}

[data-design="a"] .dp-service-note {
  font-size: 13px;
  color: var(--dp-muted);
  text-align: right;
}

/* ════════════════════════════════════════════════════════════════
   SERVICE AREA
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-area {
  padding: var(--dp-bay) clamp(16px, 4vw, 40px);
  background: var(--dp-bg);
  color: var(--dp-ink);
}

[data-design="a"] .dp-area__content {
  max-width: 640px;
}

[data-design="a"] .dp-area__title {
  font-family: var(--dp-font-display);
  font-size: clamp(26px, 4vw, 42px);
  letter-spacing: -0.005em;
  line-height: 1.1;
  margin: 8px 0 16px;
}

[data-design="a"] .dp-area__body {
  color: var(--dp-muted);
  line-height: 1.6;
  margin: 0 0 16px;
  max-width: 56ch;
}

[data-design="a"] .dp-area__list {
  list-style: none;
  padding: 0;
  margin: 0 0 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

[data-design="a"] .dp-area__list li {
  font-family: var(--dp-font-display);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--dp-muted);
  background: var(--dp-surface);
  padding: 6px 12px;
  border-radius: var(--dp-radius-button);
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--dp-aluminum), transparent 84%);
}

/* ════════════════════════════════════════════════════════════════
   ABOUT
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-about {
  padding: var(--dp-bay) clamp(16px, 4vw, 40px);
  background: var(--dp-surface);
  color: var(--dp-ink);
}

[data-design="a"] .dp-about__content {
  max-width: 720px;
}

[data-design="a"] .dp-about__title {
  font-family: var(--dp-font-display);
  font-size: clamp(26px, 4vw, 42px);
  letter-spacing: -0.005em;
  line-height: 1.1;
  margin: 8px 0 20px;
}

[data-design="a"] .dp-about__body {
  color: var(--dp-muted);
  line-height: 1.65;
  margin: 0 0 24px;
  max-width: 66ch;
  font-size: 17px;
}

[data-design="a"] .dp-trust-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

[data-design="a"] .dp-trust-list li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--dp-font-display);
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dp-muted);
}

/* ════════════════════════════════════════════════════════════════
   INDICATOR DOT (shared)
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-indicator-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: var(--dp-radius-pill);
  background: var(--dp-accent);
  box-shadow: 0 0 6px color-mix(in oklab, var(--dp-accent), transparent 55%);
  animation: dp-live-indicator 3.6s var(--dp-ease-calibrate) infinite;
  flex-shrink: 0;
}

@keyframes dp-live-indicator {
  0%, 100% { opacity: 0.55; }
  50%      { opacity: 1; }
}

/* ════════════════════════════════════════════════════════════════
   E6 — POINTER
   Immediate preceding sibling of #funnel.
   Height >= 12px. Opacity 1.
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-pointer {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px clamp(16px, 4vw, 40px);
  background: var(--dp-bg);
  color: var(--dp-ink);
  font-variant-numeric: tabular-nums;
  /* pointer wrapper bbox height > 8px — guaranteed by padding: 20px top + 20px bottom + content */
  min-height: 64px;
  opacity: 1;
  box-sizing: border-box;
  border-top: 1px solid color-mix(in oklab, var(--dp-aluminum), transparent 88%);
}

[data-design="a"] .dp-pointer__counter {
  font-family: var(--dp-font-display);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  opacity: 0.75;
  white-space: nowrap;
  flex-shrink: 0;
}

[data-design="a"] .dp-pointer__counter-now {
  display: inline-block;
  min-width: 1ch;
  animation: dp-pointer-tick 320ms ease-out;
  color: var(--dp-accent);
}

[data-design="a"] .dp-pointer__bar {
  position: relative;
  flex: 1;
  height: 2px;
  background: currentColor;
  opacity: 0.15;
  border-radius: 1px;
  overflow: hidden;
  /* ensures pointer height contribution beyond 8px */
  min-height: 2px;
}

[data-design="a"] .dp-pointer__bar-fill {
  position: absolute;
  inset: 0;
  width: var(--dp-pointer-progress, 16%);
  background: var(--dp-accent);
  opacity: 1;
  transition: width 480ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

[data-design="a"] .dp-pointer__label {
  font-family: var(--dp-font-display);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--dp-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

[data-design="a"] .dp-pointer__chev {
  font-size: 18px;
  opacity: 0.6;
  color: var(--dp-accent);
  animation: dp-pointer-chev 4s ease-in-out infinite;
  flex-shrink: 0;
}

@keyframes dp-pointer-tick {
  0%   { transform: translateY(-6px); opacity: 0; }
  100% { transform: translateY(0);    opacity: 1; }
}

@keyframes dp-pointer-chev {
  0%, 100% { transform: translateX(0);    opacity: 0.45; }
  50%      { transform: translateX(4px);  opacity: 0.9; }
}

/* ════════════════════════════════════════════════════════════════
   E5 — FUNNEL (5-step scheduling intake)
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-diagnostic {
  padding: var(--dp-bay) clamp(16px, 4vw, 40px);
  background: var(--dp-bg);
  color: var(--dp-ink);
}

[data-design="a"] .dp-diagnostic__head {
  max-width: 720px;
  margin-bottom: var(--dp-rack);
}

[data-design="a"] .dp-diagnostic h2 {
  font-family: var(--dp-font-display);
  font-size: clamp(28px, 4vw, 48px);
  letter-spacing: -0.005em;
  margin: 8px 0 12px;
  line-height: 1.1;
}

[data-design="a"] .dp-diagnostic__sub {
  color: var(--dp-muted);
  max-width: 56ch;
  line-height: 1.6;
  margin: 0;
}

[data-design="a"] .dp-diagnostic__panel {
  background: var(--dp-surface);
  border-radius: var(--dp-radius-plate);
  box-shadow:
    inset 0 0 0 1px color-mix(in oklab, var(--dp-aluminum), transparent 82%),
    inset 0 1px 0 0 color-mix(in oklab, var(--dp-aluminum), transparent 70%);
  padding: clamp(20px, 3vw, 36px);
}

[data-design="a"] .dp-diagnostic__steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--dp-rack);
}

[data-design="a"] .dp-step {
  opacity: 0.35;
  pointer-events: none;
  transition: opacity var(--dp-settle) var(--dp-ease-calibrate);
}

[data-design="a"] .dp-step[data-active="true"],
[data-design="a"] .dp-step[data-done="true"] {
  opacity: 1;
  pointer-events: auto;
}

[data-design="a"] .dp-step__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--dp-detent);
  margin-top: 12px;
}

[data-design="a"] .dp-step__grid--single {
  grid-template-columns: 1fr;
  max-width: 440px;
}

[data-design="a"] .dp-pick {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--dp-surface-2);
  color: var(--dp-ink);
  font-family: var(--dp-font-display);
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border: 0;
  border-radius: var(--dp-radius-button);
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--dp-aluminum), transparent 82%);
  cursor: pointer;
  text-align: left;
  min-height: 44px;
  transition: box-shadow var(--dp-snap) var(--dp-ease-relay);
}

[data-design="a"] .dp-pick:hover,
[data-design="a"] .dp-pick:focus-visible {
  outline: 0;
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--dp-aluminum), transparent 60%);
}

[data-design="a"] .dp-pick__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--dp-radius-pill);
  background: var(--dp-muted);
  flex-shrink: 0;
  transition:
    background var(--dp-snap) var(--dp-ease-relay),
    box-shadow var(--dp-snap) var(--dp-ease-relay);
}

[data-design="a"] .dp-pick[aria-checked="true"] {
  box-shadow: inset 0 0 0 1px var(--dp-accent);
}

[data-design="a"] .dp-pick[aria-checked="true"] .dp-pick__dot {
  background: var(--dp-accent);
  box-shadow: 0 0 6px color-mix(in oklab, var(--dp-accent), transparent 50%);
}

/* Contact fieldset */
[data-design="a"] .dp-contact {
  border: 0;
  padding: 0;
  margin: var(--dp-rack) 0 var(--dp-cell);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--dp-cell);
}

[data-design="a"] .dp-field--full {
  grid-column: 1 / -1;
}

[data-design="a"] .dp-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

[data-design="a"] .dp-field input,
[data-design="a"] .dp-field textarea {
  background: transparent;
  border: 0;
  border-bottom: 1px solid color-mix(in oklab, var(--dp-aluminum), transparent 78%);
  color: var(--dp-ink);
  font-family: var(--dp-font-mono);
  font-size: 15px;
  padding: 8px 0;
  outline: 0;
  transition: border-color var(--dp-snap) var(--dp-ease-relay);
  resize: vertical;
  min-height: 44px;
}

[data-design="a"] .dp-field textarea {
  min-height: 80px;
}

[data-design="a"] .dp-field input:focus-visible,
[data-design="a"] .dp-field textarea:focus-visible {
  border-bottom-color: var(--dp-accent);
}

[data-design="a"] .dp-req {
  color: var(--dp-accent-2);
  font-size: 10px;
}

[data-design="a"] .dp-diagnostic__book {
  margin-top: 8px;
}

[data-design="a"] .dp-diagnostic[data-complete="true"] .dp-diagnostic__book .dp-cta__dot {
  background: var(--dp-accent);
  box-shadow: 0 0 8px var(--dp-accent);
  animation: none;
}

/* Success message — display:none until shown (never opacity:0) */
[data-design="a"] .dp-success-msg {
  margin-top: 24px;
  padding: 20px 24px;
  background: var(--dp-surface-2);
  border-radius: var(--dp-radius-plate);
  border-left: 2px solid var(--dp-accent);
}

[data-design="a"] .dp-success-msg p {
  margin: 4px 0;
  color: var(--dp-muted);
  font-size: 15px;
  line-height: 1.55;
}

[data-design="a"] .dp-success-msg a {
  color: var(--dp-accent);
}

/* Emergency shortcut inside funnel (display:none until selected) */
[data-design="a"] .dp-emergency-shortcut {
  padding-top: 8px;
}

/* ════════════════════════════════════════════════════════════════
   LOAD METER (E3 / segment A — repurposed as trust section ambient)
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-loadmeter {
  padding: var(--dp-bay) clamp(16px, 4vw, 40px);
  background: var(--dp-bg);
  color: var(--dp-ink);
}

[data-design="a"] .dp-loadmeter__head {
  max-width: 640px;
  margin-bottom: var(--dp-rack);
}

[data-design="a"] .dp-loadmeter__title {
  font-family: var(--dp-font-display);
  font-size: clamp(28px, 4vw, 48px);
  letter-spacing: -0.005em;
  line-height: 1.08;
  margin: 8px 0 16px;
  max-width: 22ch;
}

[data-design="a"] .dp-loadmeter__body {
  max-width: 56ch;
  color: var(--dp-muted);
  line-height: 1.55;
  margin: 0;
}

[data-design="a"] .dp-loadmeter__meter {
  display: grid;
  grid-template-columns: repeat(16, 1fr);
  gap: var(--dp-trace);
  padding: 16px;
  background: var(--dp-surface);
  border-radius: var(--dp-radius-plate);
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--dp-aluminum), transparent 86%);
}

[data-design="a"] .dp-seg {
  display: block;
  height: 56px;
  border-radius: 1px;
  background: color-mix(in oklab, var(--dp-accent), transparent 88%);
  transform-origin: bottom;
  animation: dp-seg-rise 3.6s var(--dp-ease-calibrate) infinite alternate;
  animation-delay: calc(var(--i) * -180ms);
}

[data-design="a"] .dp-seg--peak {
  background: color-mix(in oklab, var(--dp-accent-2), transparent 86%);
  animation-name: dp-seg-rise-peak;
  animation-duration: 4.8s;
}

@keyframes dp-seg-rise {
  0%   { transform: scaleY(0.18); background: color-mix(in oklab, var(--dp-accent), transparent 92%); }
  60%  { transform: scaleY(0.85); background: var(--dp-accent); }
  100% { transform: scaleY(0.32); background: color-mix(in oklab, var(--dp-accent), transparent 78%); }
}

@keyframes dp-seg-rise-peak {
  0%   { transform: scaleY(0.22); background: color-mix(in oklab, var(--dp-accent-2), transparent 92%); }
  72%  { transform: scaleY(0.96); background: var(--dp-accent-2); }
  100% { transform: scaleY(0.40); background: color-mix(in oklab, var(--dp-accent-2), transparent 78%); }
}

[data-design="a"] .dp-loadmeter__legend {
  display: flex;
  justify-content: space-between;
  padding: 12px 4px 0;
  max-width: 100%;
}

[data-design="a"] .dp-loadmeter[data-paused="true"] .dp-seg {
  animation-play-state: paused;
}

/* ════════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-footer {
  padding: var(--dp-deck) clamp(16px, 4vw, 40px) clamp(40px, 6vw, 80px);
  background: var(--dp-bg);
  color: var(--dp-ink);
}

[data-design="a"] .dp-footer__rule {
  height: 1px;
  background: color-mix(in oklab, var(--dp-aluminum), transparent 84%);
  margin-bottom: var(--dp-rack);
}

[data-design="a"] .dp-footer__cols {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--dp-rack) var(--dp-panel);
  margin-bottom: var(--dp-rack);
}

[data-design="a"] .dp-footer__col p,
[data-design="a"] .dp-footer__col address {
  font-style: normal;
  font-size: 15px;
  line-height: 1.6;
  color: var(--dp-muted);
  margin: 8px 0 0;
}

[data-design="a"] .dp-footer__phone,
[data-design="a"] .dp-footer__email {
  display: block;
  font-family: var(--dp-font-mono);
  font-size: 15px;
  color: var(--dp-accent);
  text-decoration: none;
  margin-top: 8px;
  transition: color var(--dp-snap) var(--dp-ease-relay);
}

[data-design="a"] .dp-footer__phone:hover,
[data-design="a"] .dp-footer__email:hover {
  color: var(--dp-ink);
}

[data-design="a"] .dp-footer__copy {
  font-size: 11px;
  color: color-mix(in oklab, var(--dp-muted), transparent 40%);
  margin: 0;
  padding-top: var(--dp-rack);
  border-top: 1px solid color-mix(in oklab, var(--dp-aluminum), transparent 90%);
}

/* ════════════════════════════════════════════════════════════════
   STEP-ADVANCE button (zip step)
════════════════════════════════════════════════════════════════ */
[data-design="a"] .dp-step-advance {
  margin-top: 8px;
}

/* ════════════════════════════════════════════════════════════════
   MOBILE — no horizontal scroll.
   ALL rules scoped to [data-design="a"].dq-design or [data-design="a"].
   Appended at bottom per spec.
════════════════════════════════════════════════════════════════ */
[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;
}

@media (max-width: 560px) {
  [data-design="a"] .dp-logo__mark { font-size: 12px; letter-spacing: 0.12em; }
  [data-design="a"] .dp-header__bar { padding: 14px 16px; min-height: 56px; }
  [data-design="a"] .dp-hero { padding: clamp(40px, 6vw, 64px) 16px; min-height: clamp(360px, 80vh, 520px); }
  [data-design="a"] .dp-seg { height: 38px; }
  [data-design="a"] .dp-loadmeter__meter { padding: 12px; }
  [data-design="a"] .dp-contact { grid-template-columns: 1fr; }
  [data-design="a"] .dp-schematic__svg { opacity: 0.45; }
  [data-design="a"] .dp-service-row { grid-template-columns: 28px 1fr; }
  [data-design="a"] .dp-service-note { display: none; }
  [data-design="a"] .dp-footer__cols { grid-template-columns: 1fr 1fr; }
  [data-design="a"] .dp-pointer { flex-wrap: wrap; gap: 10px; }
  [data-design="a"] .dp-pointer__label { width: 100%; }
}

@media (max-width: 768px) {
  [data-design="a"] .dp-step__grid { grid-template-columns: 1fr 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .dp-header__needle { animation: none; left: calc(50% - 30px); opacity: 0.7; }
  [data-design="a"] .dp-hero__copper-field { animation: none; opacity: 0.45; }
  [data-design="a"] .dp-cta__dot { animation: none; background: var(--dp-accent-2); }
  [data-design="a"] .dp-seg { animation-play-state: paused; transform: scaleY(0.55); }
  [data-design="a"] .dp-seg--peak { transform: scaleY(0.75); }
  [data-design="a"] .dp-trace { stroke-dashoffset: 0; animation: none; }
  [data-design="a"] .dp-schematic__live { opacity: 1; animation: none; }
  [data-design="a"] .dp-pointer__counter-now { animation: none; }
  [data-design="a"] .dp-pointer__chev { animation: none; }
  [data-design="a"] .dp-pointer__bar-fill { transition: none; }
  [data-design="a"] .dp-indicator-dot { animation: none; opacity: 0.85; }
}

/* 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; }
