/* ═══════════════════════════════════════════════════════════
   DESIGN-A · Polychrome remapped
   Slot-scope: [data-design="a"]  ·  Expose --design-a-primary
   ALL selectors under .dq-design[data-design="a"] or
   [data-design="a"] .class — ZERO bare element rules.
   ZERO [data-design="a"] references.
   Keyframes prefixed: a-*
═══════════════════════════════════════════════════════════ */

/* ── Token system ─────────────────────────────────────────── */
[data-design="a"] {
  /* Expose primary for harness */
  --design-a-primary: #C18367;

  /* Chrome (page chassis) */
  --pc-paper:        #F4EFE6;
  --pc-ink:          #1B1A17;
  --pc-ink-2:        #4A463E;
  --pc-rule:         #D7CFBE;
  --pc-shadow:       #C9C0AB;
  --pc-critical:     #8C2A1F;
  --pc-success:      #3A5C3F;

  /* Specimens */
  --pc-spec-chalk:   #E8E0CE;
  --pc-spec-clay:    #C18367;
  --pc-spec-sage:    #8FA08A;
  --pc-spec-paris:   #3F5C7A;
  --pc-spec-slate:   #3D3A36;
  --pc-spec-ochre:   #C7A24A;

  /* Typography */
  --pc-font-display: "GT Sectra","Tiempos Headline","Iowan Old Style",Georgia,serif;
  --pc-font-body:    "GT Sectra Fine","Tiempos Text","Charter","Iowan Old Style",Georgia,serif;
  --pc-font-meta:    "JetBrains Mono","IBM Plex Mono",ui-monospace,Menlo,monospace;

  /* Spacing */
  --pc-coat:    4px;
  --pc-bristle: 8px;
  --pc-band:    16px;
  --pc-stripe:  24px;
  --pc-pour:    40px;
  --pc-roll:    64px;
  --pc-wall:    112px;
  --pc-mural:   160px;

  /* Motion */
  --pc-dur-flick:    140ms;
  --pc-dur-settle:   320ms;
  --pc-dur-roll:     900ms;
  --pc-dur-cure:     18s;
  --pc-dur-curelong: 24s;
  --pc-ease-settle:  cubic-bezier(0.22, 0.61, 0.36, 1);
  --pc-ease-press:   cubic-bezier(0.4,  0,    0.6,  1);
  --pc-ease-brush:   cubic-bezier(0.65, 0.05, 0.36, 1);
  --pc-ease-cure:    cubic-bezier(0.42, 0,    0.58, 1);

  /* Radius */
  --pc-rad-card:  2px;
  --pc-rad-chip:  1px;
  --pc-rad-pill:  999px;
  --pc-rad-frame: 0;

  /* Elevation */
  --pc-elev-flat:   none;
  --pc-elev-card:   0 1px 0 var(--pc-rule), 0 12px 28px -20px var(--pc-shadow);
  --pc-elev-drawer: 0 24px 60px -24px rgba(0,0,0,0.18);
}

/* ── Base ─────────────────────────────────────────────────── */
[data-design="a"].dq-design {
  background: var(--pc-paper);
  color: var(--pc-ink);
  font-family: var(--pc-font-body);
  font-size: clamp(16px, 1.05vw, 19px);
  line-height: 1.6;
  box-sizing: border-box;
}

/* ══════════════════════════════════════════════════════════
   E1 — ANIMATED MINIMALIST HEADER
══════════════════════════════════════════════════════════ */
[data-design="a"] .pc-header {
  position: sticky;
  top: 0;
  z-index: 60;
  background: var(--pc-paper);
  border-bottom: 1px solid var(--pc-rule);
  isolation: isolate;
}
[data-design="a"] .pc-header__bar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--pc-pour);
  padding: var(--pc-band) clamp(16px, 4vw, 40px);
  max-width: 1280px;
  margin: 0 auto;
}
[data-design="a"] .pc-logo {
  font-family: var(--pc-font-display);
  font-size: clamp(16px, 1.4vw, 22px);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--pc-ink);
  text-decoration: none;
  white-space: nowrap;
}
[data-design="a"] .pc-header__caravan {
  overflow: hidden;
  min-width: 0;
  height: 14px;
  display: flex;
  align-items: center;
  mask-image: linear-gradient(to right, transparent, #000 12%, #000 88%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, #000 12%, #000 88%, transparent);
}
[data-design="a"] .pc-caravan__track {
  display: flex;
  gap: 18px;
  width: max-content;
  animation: a-caravan var(--pc-dur-curelong) linear infinite;
}
[data-design="a"] .pc-chip {
  width: 12px;
  height: 12px;
  display: inline-block;
  border: 1px solid var(--pc-rule);
  flex-shrink: 0;
}
[data-design="a"] .pc-burger {
  background: transparent;
  border: 1px solid var(--pc-ink);
  width: 44px;
  height: 44px;
  min-height: 44px;
  padding: 0 8px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  cursor: pointer;
  transition: background var(--pc-dur-settle) var(--pc-ease-settle);
}
[data-design="a"] .pc-burger:hover { background: var(--pc-rule); }
[data-design="a"] .pc-burger:focus-visible {
  outline: 2px dashed var(--pc-spec-ochre);
  outline-offset: 2px;
}
[data-design="a"] .pc-burger__line {
  height: 1px;
  background: var(--pc-ink);
  width: 100%;
  transition:
    transform var(--pc-dur-settle) var(--pc-ease-settle),
    opacity   var(--pc-dur-flick);
}
[data-design="a"] .pc-burger[aria-expanded="true"] .pc-burger__line:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}
[data-design="a"] .pc-burger[aria-expanded="true"] .pc-burger__line:nth-child(2) {
  opacity: 0;
}
[data-design="a"] .pc-burger[aria-expanded="true"] .pc-burger__line:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}

/* Drawer */
[data-design="a"] .pc-drawer {
  position: fixed;
  inset: 0;
  background: color-mix(in oklab, var(--pc-ink), transparent 82%);
  z-index: 90;
  display: grid;
  grid-template-columns: 1fr min(420px, 86vw);
  animation: a-drawer-fade var(--pc-dur-settle) var(--pc-ease-settle);
}
[data-design="a"] .pc-drawer[hidden] { display: none; }
[data-design="a"] .pc-drawer__panel {
  grid-column: 2;
  background: var(--pc-paper);
  padding: var(--pc-roll) var(--pc-pour);
  box-shadow: var(--pc-elev-drawer);
  display: flex;
  flex-direction: column;
  gap: var(--pc-pour);
  animation: a-drawer-slide var(--pc-dur-settle) var(--pc-ease-settle);
  overflow-y: auto;
}
[data-design="a"] .pc-drawer__close {
  align-self: flex-end;
  background: transparent;
  border: 0;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  color: var(--pc-ink);
  min-width: 44px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
[data-design="a"] .pc-drawer__nav {
  display: flex;
  flex-direction: column;
  gap: var(--pc-stripe);
}
[data-design="a"] .pc-drawer__link {
  font-family: var(--pc-font-meta);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--pc-ink);
  text-decoration: none;
  display: flex;
  gap: var(--pc-band);
  padding-bottom: 8px;
  border-bottom: 1px solid var(--pc-rule);
  position: relative;
  min-height: 44px;
  align-items: center;
}
[data-design="a"] .pc-drawer__link::after {
  content: "";
  position: absolute;
  left: 0; bottom: -1px;
  height: 1px;
  width: 0;
  background: var(--pc-spec-ochre);
  transition: width var(--pc-dur-roll) var(--pc-ease-brush);
}
[data-design="a"] .pc-drawer__link:hover::after,
[data-design="a"] .pc-drawer__link:focus-visible::after { width: 100%; }
[data-design="a"] .pc-drawer__num {
  color: var(--pc-ink-2);
  min-width: 2.5ch;
}
[data-design="a"] .pc-drawer__ctas {
  display: flex;
  flex-direction: column;
  gap: var(--pc-band);
}
[data-design="a"] .pc-drawer__phone {
  font-family: var(--pc-font-meta);
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pc-ink);
  text-decoration: none;
  padding: 12px 0;
  display: block;
  min-height: 44px;
}
[data-design="a"] .pc-drawer__signature {
  font-family: var(--pc-font-meta);
  color: var(--pc-ink-2);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* ══════════════════════════════════════════════════════════
   E2 — ANIMATED CTA (funnel-anchor stamp)
══════════════════════════════════════════════════════════ */
[data-design="a"] .pc-cta {
  --pc-cta-from: var(--pc-spec-clay);
  --pc-cta-to:   var(--pc-spec-ochre);
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--pc-band);
  padding: 14px 28px;
  border: 1px solid var(--pc-ink);
  background: var(--pc-paper);
  color: var(--pc-ink);
  font-family: var(--pc-font-meta);
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--pc-dur-flick) var(--pc-ease-press),
              padding-bottom var(--pc-dur-settle) var(--pc-ease-settle);
  min-height: 44px;
}
[data-design="a"] .pc-cta__field {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--pc-cta-from);
  animation: a-cta-cure 5s var(--pc-ease-cure) infinite alternate;
}
[data-design="a"] .pc-cta__label,
[data-design="a"] .pc-cta__arrow { color: var(--pc-ink); position: relative; z-index: 1; }
[data-design="a"] .pc-cta__name {
  position: absolute;
  left: 0; right: 0;
  bottom: -22px;
  font-size: 10px;
  color: var(--pc-ink-2);
  letter-spacing: 0.18em;
  text-align: center;
  transition: bottom var(--pc-dur-settle) var(--pc-ease-settle);
  pointer-events: none;
}
[data-design="a"] .pc-cta:hover .pc-cta__name,
[data-design="a"] .pc-cta:focus-visible .pc-cta__name { bottom: 4px; }
[data-design="a"] .pc-cta:hover { padding-bottom: 28px; }
[data-design="a"] .pc-cta:focus-visible {
  outline: 2px dashed var(--pc-spec-ochre);
  outline-offset: 3px;
}
[data-design="a"] .pc-cta:active { transform: translateY(1px); }

/* ══════════════════════════════════════════════════════════
   E3 — HERO + AMBIENT COLOR-CYCLE BACKDROP
   Hero text opacity:1 at first paint — NO opacity:0 on text.
══════════════════════════════════════════════════════════ */
[data-design="a"] .pc-hero {
  position: relative;
  isolation: isolate;
  min-height: clamp(520px, 72vh, 760px);
  padding: var(--pc-mural) clamp(20px, 5vw, 80px) var(--pc-wall);
  overflow: hidden;
}
[data-design="a"] .pc-ambient-a__field {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: var(--pc-spec-chalk);
  animation: a-hero-cure 22s var(--pc-ease-cure) infinite;
}
[data-design="a"] .pc-hero__inner {
  max-width: 760px;
  display: flex;
  flex-direction: column;
  gap: var(--pc-pour);
  position: relative;
  z-index: 1;
}
[data-design="a"] .pc-hero__eyebrow {
  font-family: var(--pc-font-meta);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 12px;
  color: var(--pc-ink-2);
  /* opacity:1 at first paint — hard rule */
  opacity: 1;
}
[data-design="a"] .pc-hero__title {
  font-family: var(--pc-font-display);
  font-size: clamp(40px, 6.5vw, 88px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0;
  text-wrap: balance;
  color: var(--pc-ink);
  /* opacity:1 at first paint — hard rule */
  opacity: 1;
}
[data-design="a"] .pc-hero__lede {
  font-family: var(--pc-font-body);
  font-size: clamp(17px, 1.25vw, 21px);
  line-height: 1.55;
  max-width: 56ch;
  color: var(--pc-ink);
  margin: 0;
  opacity: 1;
}
[data-design="a"] .pc-hero__cta-slot {
  display: flex;
  gap: var(--pc-band);
  flex-wrap: wrap;
}
[data-design="a"] .pc-ambient-a__index {
  position: absolute;
  right: clamp(20px, 5vw, 80px);
  bottom: var(--pc-roll);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  font-family: var(--pc-font-meta);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--pc-ink-2);
}

/* ══════════════════════════════════════════════════════════
   E6 — POINTER (wet-edge dimension-line, painting register)
   MUST render opacity>0, bbox height>8px.
   Sits IMMEDIATELY before #funnel — no siblings between.
══════════════════════════════════════════════════════════ */
[data-design="a"] .polychrome-pointer {
  display: flex;
  justify-content: center;
  padding: clamp(40px, 8vw, 80px) 16px clamp(56px, 10vw, 96px);
  background: var(--pc-paper);
}
[data-design="a"] .polychrome-pointer__hit {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: var(--pc-ink-2);
}
[data-design="a"] .polychrome-pointer__tick {
  display: block;
  width: 16px;
  height: 1px;
  background: currentColor;
  opacity: 0.7;
}
[data-design="a"] .polychrome-pointer__rule {
  display: block;
  width: 1px;
  height: 56px;
  background: currentColor;
  transform-origin: top center;
  animation: a-pointer-extend 5s ease-in-out infinite;
}
[data-design="a"] .polychrome-pointer__label {
  font-family: var(--pc-font-meta);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  opacity: 0;
  animation: a-pointer-stamp 5s ease-in-out infinite;
}

/* ══════════════════════════════════════════════════════════
   E5 — FUNNEL (4-step qualifying intake)
══════════════════════════════════════════════════════════ */
[data-design="a"] .pc-funnel {
  background: var(--pc-spec-slate);
  color: var(--pc-paper);
  padding: var(--pc-wall) clamp(20px, 5vw, 80px);
}
[data-design="a"] .pc-funnel__inner {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--pc-roll);
}
[data-design="a"] .pc-funnel__eyebrow {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--pc-paper), transparent 30%);
}
[data-design="a"] .pc-funnel__title {
  font-family: var(--pc-font-display);
  font-size: clamp(36px, 5vw, 56px);
  line-height: 1.08;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--pc-paper);
}
[data-design="a"] .pc-funnel__lede {
  font-family: var(--pc-font-body);
  font-size: clamp(16px, 1.1vw, 19px);
  line-height: 1.5;
  max-width: 56ch;
  color: color-mix(in oklab, var(--pc-paper), transparent 20%);
  margin: 0;
}
[data-design="a"] .pc-funnel__steps {
  display: flex;
  flex-direction: column;
  gap: var(--pc-roll);
}
[data-design="a"] .pc-funnel__step {
  border: 0;
  padding: 0;
  margin: 0;
}
[data-design="a"] .pc-funnel__step[hidden] { display: none; }
[data-design="a"] .pc-funnel__step-legend {
  font-family: var(--pc-font-display);
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--pc-paper);
  display: flex;
  align-items: baseline;
  gap: var(--pc-band);
  margin-bottom: var(--pc-pour);
  width: 100%;
}
[data-design="a"] .pc-funnel__step-num {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pc-spec-ochre);
  flex-shrink: 0;
}
[data-design="a"] .pc-funnel__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--pc-band);
}
[data-design="a"] .pc-funnel__chip {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pc-paper);
  background: transparent;
  border: 1px solid color-mix(in oklab, var(--pc-paper), transparent 60%);
  padding: 10px 20px;
  min-height: 44px;
  cursor: pointer;
  transition:
    background var(--pc-dur-settle) var(--pc-ease-settle),
    border-color var(--pc-dur-settle) var(--pc-ease-settle);
}
[data-design="a"] .pc-funnel__chip:hover,
[data-design="a"] .pc-funnel__chip:focus-visible {
  background: color-mix(in oklab, var(--pc-paper), transparent 85%);
  border-color: var(--pc-paper);
}
[data-design="a"] .pc-funnel__chip.is-selected {
  background: var(--pc-spec-ochre);
  border-color: var(--pc-spec-ochre);
  color: var(--pc-ink);
}
[data-design="a"] .pc-funnel__chip:focus-visible {
  outline: 2px dashed var(--pc-spec-ochre);
  outline-offset: 2px;
}

/* Step 4 form */
[data-design="a"] .pc-funnel__form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--pc-pour) var(--pc-roll);
}
[data-design="a"] .pc-funnel__field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
[data-design="a"] .pc-funnel__field--full {
  grid-column: 1 / -1;
}
[data-design="a"] .pc-funnel__field-label {
  font-family: var(--pc-font-meta);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--pc-paper), transparent 30%);
}
[data-design="a"] .pc-funnel__field-note {
  color: color-mix(in oklab, var(--pc-paper), transparent 50%);
  font-size: 10px;
}
[data-design="a"] .pc-funnel__form input,
[data-design="a"] .pc-funnel__form textarea {
  background: transparent;
  border: 0;
  border-bottom: 1px solid color-mix(in oklab, var(--pc-paper), transparent 60%);
  padding: 8px 0;
  font-family: var(--pc-font-body);
  font-size: clamp(16px, 1.05vw, 18px);
  color: var(--pc-paper);
  outline: none;
  resize: vertical;
  transition: border-color var(--pc-dur-settle) var(--pc-ease-settle);
  min-width: 0;
}
[data-design="a"] .pc-funnel__form input:focus,
[data-design="a"] .pc-funnel__form textarea:focus {
  border-color: var(--pc-spec-ochre);
}
[data-design="a"] .pc-funnel__form input::placeholder,
[data-design="a"] .pc-funnel__form textarea::placeholder {
  color: color-mix(in oklab, var(--pc-paper), transparent 55%);
}
[data-design="a"] .pc-funnel__submit {
  grid-column: 1 / -1;
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 16px 32px;
  min-height: 44px;
  background: var(--pc-spec-ochre);
  color: var(--pc-ink);
  border: 1px solid var(--pc-spec-ochre);
  cursor: pointer;
  transition: transform var(--pc-dur-flick) var(--pc-ease-press),
              background var(--pc-dur-settle) var(--pc-ease-settle);
  align-self: start;
  justify-self: start;
}
[data-design="a"] .pc-funnel__submit:hover { background: var(--pc-spec-clay); }
[data-design="a"] .pc-funnel__submit:active { transform: translateY(1px); }
[data-design="a"] .pc-funnel__submit:focus-visible {
  outline: 2px dashed var(--pc-paper);
  outline-offset: 2px;
}

/* Confirm */
[data-design="a"] .pc-funnel__confirm { display: flex; flex-direction: column; gap: var(--pc-band); }
[data-design="a"] .pc-funnel__confirm[hidden] { display: none; }
[data-design="a"] .pc-funnel__confirm-mark {
  font-size: 32px;
  color: var(--pc-success);
}
[data-design="a"] .pc-funnel__confirm-text {
  font-family: var(--pc-font-body);
  font-size: clamp(17px, 1.2vw, 20px);
  line-height: 1.55;
  color: var(--pc-paper);
  margin: 0;
  max-width: 56ch;
}
[data-design="a"] .pc-funnel__confirm-phone {
  font-family: var(--pc-font-meta);
  font-size: 13px;
  letter-spacing: 0.12em;
  color: color-mix(in oklab, var(--pc-paper), transparent 30%);
  margin: 0;
}
[data-design="a"] .pc-funnel__confirm-phone a {
  color: var(--pc-spec-ochre);
  text-decoration: none;
}

[data-design="a"] .pc-funnel__meta {
  border-top: 1px solid color-mix(in oklab, var(--pc-paper), transparent 75%);
  padding-top: var(--pc-stripe);
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--pc-paper), transparent 40%);
  display: flex;
  flex-direction: column;
  gap: var(--pc-band);
}
[data-design="a"] .pc-funnel__meta p { margin: 0; }

/* ══════════════════════════════════════════════════════════
   SERVICES
══════════════════════════════════════════════════════════ */
[data-design="a"] .pc-services {
  padding: var(--pc-wall) clamp(20px, 5vw, 80px);
  background: var(--pc-paper);
}
[data-design="a"] .pc-services__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--pc-roll);
}
[data-design="a"] .pc-services__eyebrow {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pc-ink-2);
}
[data-design="a"] .pc-services__title {
  font-family: var(--pc-font-display);
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.08;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--pc-ink);
}
[data-design="a"] .pc-services__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px;
}
[data-design="a"] .pc-plate {
  border: 1px solid var(--pc-rule);
  padding: var(--pc-pour);
  background: var(--pc-paper);
}
[data-design="a"] .pc-plate__head {
  font-family: var(--pc-font-display);
  font-size: clamp(20px, 1.8vw, 26px);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--pc-ink);
  margin: 0 0 var(--pc-band);
}
[data-design="a"] .pc-plate__body {
  font-family: var(--pc-font-body);
  font-size: clamp(15px, 1vw, 17px);
  line-height: 1.6;
  color: var(--pc-ink-2);
  margin: 0;
}

/* ══════════════════════════════════════════════════════════
   E4 — AMBIENT B: PROCESS / DRY-DOWN LEDGER
══════════════════════════════════════════════════════════ */
[data-design="a"] .pc-ambient-b {
  background: var(--pc-spec-sage);
  padding: var(--pc-wall) clamp(20px, 5vw, 80px);
}
[data-design="a"] .pc-ambient-b__head {
  display: flex;
  flex-direction: column;
  gap: var(--pc-band);
  margin-bottom: var(--pc-roll);
  max-width: 760px;
}
[data-design="a"] .pc-ambient-b__eyebrow {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pc-ink-2);
}
[data-design="a"] .pc-ambient-b__title {
  font-family: var(--pc-font-display);
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.08;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--pc-ink);
}
[data-design="a"] .pc-process__lede {
  font-family: var(--pc-font-body);
  font-size: clamp(16px, 1.1vw, 19px);
  line-height: 1.55;
  max-width: 56ch;
  color: var(--pc-ink);
  margin: 0;
}
[data-design="a"] .pc-ledger {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--pc-rule);
}
[data-design="a"] .pc-ledger__row {
  display: grid;
  grid-template-columns: 48px 1fr auto auto 80px;
  align-items: center;
  gap: var(--pc-pour);
  padding: var(--pc-stripe) 0;
  border-bottom: 1px solid var(--pc-rule);
  font-family: var(--pc-font-meta);
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--pc-ink);
}
[data-design="a"] .pc-ledger__num   { color: var(--pc-ink-2); }
[data-design="a"] .pc-ledger__name  { font-family: var(--pc-font-body); font-size: 18px; letter-spacing: 0; }
[data-design="a"] .pc-ledger__finish,
[data-design="a"] .pc-ledger__date  { text-transform: uppercase; color: var(--pc-ink-2); }
[data-design="a"] .pc-ledger__chip {
  position: relative;
  height: 28px;
  border: 1px solid var(--pc-rule);
  overflow: hidden;
  background: var(--pc-paper);
}
[data-design="a"] .pc-ledger__chip::after {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--chip);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--pc-dur-roll) var(--pc-ease-brush);
}
[data-design="a"] .pc-ledger__row.is-brushed .pc-ledger__chip::after {
  transform: scaleX(1);
}

/* ══════════════════════════════════════════════════════════
   E5 — COLOR VISUALIZER (mid-page interactive element)
══════════════════════════════════════════════════════════ */
[data-design="a"] .pc-interactive {
  background: var(--pc-paper);
  padding: var(--pc-wall) clamp(20px, 5vw, 80px);
}
[data-design="a"] .pc-vis {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  gap: var(--pc-roll);
}
[data-design="a"] .pc-vis__head {
  display: flex;
  flex-direction: column;
  gap: var(--pc-band);
  max-width: 640px;
}
[data-design="a"] .pc-vis__eyebrow {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pc-ink-2);
}
[data-design="a"] .pc-vis__title {
  font-family: var(--pc-font-display);
  font-size: clamp(32px, 4.5vw, 56px);
  line-height: 1.08;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--pc-ink);
}
[data-design="a"] .pc-vis__lede {
  font-family: var(--pc-font-body);
  font-size: clamp(16px, 1.1vw, 19px);
  line-height: 1.5;
  margin: 0;
  color: var(--pc-ink);
  max-width: 56ch;
}
[data-design="a"] .pc-vis__stage {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: var(--pc-pour);
  align-items: end;
}
[data-design="a"] .pc-vis__room {
  width: 100%;
  height: auto;
  border: 1px solid var(--pc-ink);
  background: var(--pc-paper);
  display: block;
}
[data-design="a"] .pc-vis__wall-prev,
[data-design="a"] .pc-vis__wall-next {
  transition: fill var(--pc-dur-flick) var(--pc-ease-press);
}
[data-design="a"] .pc-vis__wall-next {
  transform-origin: left center;
  transform: scaleX(0);
}
[data-design="a"] .pc-vis__wall-next.is-stroking {
  transition: transform var(--pc-dur-roll) var(--pc-ease-brush);
  transform: scaleX(1);
}
[data-design="a"] .pc-vis__readout {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-bottom: 4px;
}
[data-design="a"] .pc-vis__readout-label {
  font-family: var(--pc-font-meta);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--pc-ink-2);
}
[data-design="a"] .pc-vis__readout-name {
  font-family: var(--pc-font-display);
  font-size: 24px;
  letter-spacing: -0.01em;
  color: var(--pc-ink);
}
[data-design="a"] .pc-vis__readout-hex {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.1em;
  color: var(--pc-ink-2);
}
[data-design="a"] .pc-vis__picker {
  display: flex;
  flex-wrap: wrap;
  gap: var(--pc-band);
}
[data-design="a"] .pc-vis__chip {
  width: 56px;
  height: 56px;
  min-width: 44px;
  min-height: 44px;
  background: var(--chip);
  border: 1px solid var(--pc-rule);
  cursor: pointer;
  position: relative;
  padding: 0;
  transition: transform var(--pc-dur-flick) var(--pc-ease-press),
              outline-color var(--pc-dur-flick);
  outline: 2px solid transparent;
  outline-offset: 3px;
}
[data-design="a"] .pc-vis__chip:hover { transform: translateY(-1px); }
[data-design="a"] .pc-vis__chip:focus-visible {
  outline: 2px dashed var(--pc-spec-ochre);
}
[data-design="a"] .pc-vis__chip.is-active {
  outline: 2px solid var(--pc-ink);
}

/* ══════════════════════════════════════════════════════════
   ABOUT
══════════════════════════════════════════════════════════ */
[data-design="a"] .pc-about {
  background: var(--pc-spec-chalk);
  padding: var(--pc-wall) clamp(20px, 5vw, 80px);
}
[data-design="a"] .pc-about__inner {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--pc-band);
}
[data-design="a"] .pc-about__eyebrow {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pc-ink-2);
}
[data-design="a"] .pc-about__title {
  font-family: var(--pc-font-display);
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--pc-ink);
}
[data-design="a"] .pc-about__body {
  font-family: var(--pc-font-body);
  font-size: clamp(16px, 1.1vw, 19px);
  line-height: 1.65;
  color: var(--pc-ink);
  max-width: 65ch;
  margin: 0;
}

/* ══════════════════════════════════════════════════════════
   SERVICE AREA
══════════════════════════════════════════════════════════ */
[data-design="a"] .pc-area {
  background: var(--pc-paper);
  padding: var(--pc-wall) clamp(20px, 5vw, 80px);
}
[data-design="a"] .pc-area__inner {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--pc-band);
}
[data-design="a"] .pc-area__eyebrow {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--pc-ink-2);
}
[data-design="a"] .pc-area__title {
  font-family: var(--pc-font-display);
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--pc-ink);
}
[data-design="a"] .pc-area__list {
  list-style: none;
  padding: 0;
  margin: var(--pc-band) 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--pc-band);
  border-top: 1px solid var(--pc-rule);
  padding-top: var(--pc-stripe);
}
[data-design="a"] .pc-area__list li {
  font-family: var(--pc-font-meta);
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--pc-ink-2);
  padding: 8px 16px;
  border: 1px solid var(--pc-rule);
}

/* Repeat CTA */
[data-design="a"] .pc-repeat-cta {
  display: flex;
  justify-content: center;
  padding: var(--pc-wall) clamp(20px, 5vw, 80px);
  background: var(--pc-paper);
}

/* ══════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════ */
[data-design="a"] .pc-footer {
  background: var(--pc-spec-slate);
  color: var(--pc-paper);
  padding: var(--pc-wall) clamp(20px, 5vw, 80px) var(--pc-roll);
}
[data-design="a"] .pc-footer__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--pc-roll);
  padding-bottom: var(--pc-roll);
  border-bottom: 1px solid color-mix(in oklab, var(--pc-paper), transparent 75%);
}
[data-design="a"] .pc-footer__firm {
  font-family: var(--pc-font-display);
  font-size: clamp(18px, 1.5vw, 22px);
  font-weight: 500;
  color: var(--pc-paper);
  margin: 0 0 var(--pc-bristle);
}
[data-design="a"] .pc-footer__dba,
[data-design="a"] .pc-footer__addr,
[data-design="a"] .pc-footer__cred {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--pc-paper), transparent 40%);
  margin: 0 0 var(--pc-bristle);
}
[data-design="a"] .pc-footer__col-head {
  font-family: var(--pc-font-meta);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--pc-paper), transparent 50%);
  margin: 0 0 var(--pc-band);
}
[data-design="a"] .pc-footer__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--pc-bristle);
}
[data-design="a"] .pc-footer__list li {
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--pc-paper), transparent 30%);
}
[data-design="a"] .pc-footer__phone {
  font-family: var(--pc-font-meta);
  font-size: 13px;
  letter-spacing: 0.12em;
  color: var(--pc-paper);
  text-decoration: none;
  display: block;
  margin-bottom: var(--pc-band);
  min-height: 44px;
  line-height: 44px;
}
[data-design="a"] .pc-footer__cta { display: inline-flex; }
[data-design="a"] .pc-footer__copy {
  max-width: 1280px;
  margin: var(--pc-pour) auto 0;
  font-family: var(--pc-font-meta);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--pc-paper), transparent 55%);
  text-align: center;
}

/* ══════════════════════════════════════════════════════════
   KEYFRAMES — prefixed a-*
══════════════════════════════════════════════════════════ */
@keyframes a-caravan {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes a-drawer-fade {
  from { background-color: transparent; }
  to   { background-color: color-mix(in oklab, var(--pc-ink), transparent 82%); }
}
@keyframes a-drawer-slide {
  from { transform: translateX(100%); }
  to   { transform: translateX(0); }
}
@keyframes a-hero-cure {
  0%   { background: var(--pc-spec-chalk); }
  33%  { background: var(--pc-spec-sage); }
  66%  { background: var(--pc-spec-paris); }
  100% { background: var(--pc-spec-chalk); }
}
@keyframes a-cta-cure {
  from { background: var(--pc-cta-from); }
  to   { background: var(--pc-cta-to); }
}
@keyframes a-pointer-extend {
  0%, 100% { transform: scaleY(0.4); opacity: 0.4; }
  50%      { transform: scaleY(1);   opacity: 0.85; }
}
@keyframes a-pointer-stamp {
  0%, 30%, 100% { opacity: 0; }
  50%, 70%      { opacity: 0.85; }
}
@keyframes a-step-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ══════════════════════════════════════════════════════════
   REDUCED MOTION
══════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .pc-caravan__track { animation: none; }
  [data-design="a"] .pc-drawer,
  [data-design="a"] .pc-drawer__panel { animation: none; }
  [data-design="a"] .pc-burger__line { transition: none; }
  [data-design="a"] .pc-ambient-a__field {
    animation: none;
    background: var(--pc-spec-chalk);
  }
  [data-design="a"] .pc-cta__field { animation: none; }
  [data-design="a"] .pc-cta,
  [data-design="a"] .pc-cta__name { transition: none; }
  [data-design="a"] .pc-vis__wall-next,
  [data-design="a"] .pc-vis__wall-prev,
  [data-design="a"] .pc-vis__chip { transition: none; }
  [data-design="a"] .pc-vis__wall-next.is-stroking { transform: scaleX(1); }
  [data-design="a"] .pc-ledger__chip::after { transition: none; transform: scaleX(1); }
  [data-design="a"] .polychrome-pointer__rule,
  [data-design="a"] .polychrome-pointer__label { animation: none; opacity: 0.7; }
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════ */
@media (max-width: 1023px) {
  [data-design="a"] .pc-services__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 767px) {
  [data-design="a"] {
    --pc-wall: 72px;
    --pc-mural: 96px;
  }
  [data-design="a"] .pc-services__grid {
    grid-template-columns: 1fr;
  }
  [data-design="a"] .pc-ledger__row {
    grid-template-columns: 32px 1fr 60px;
    grid-template-areas:
      "num name chip"
      ".   meta meta";
    row-gap: 6px;
  }
  [data-design="a"] .pc-ledger__num    { grid-area: num; }
  [data-design="a"] .pc-ledger__name   { grid-area: name; }
  [data-design="a"] .pc-ledger__chip   { grid-area: chip; }
  [data-design="a"] .pc-ledger__finish { grid-area: meta; }
  [data-design="a"] .pc-ledger__date   { grid-area: meta; justify-self: end; }
  [data-design="a"] .pc-vis__stage {
    grid-template-columns: 1fr;
  }
  [data-design="a"] .pc-funnel__form {
    grid-template-columns: 1fr;
  }
  [data-design="a"] .pc-footer__inner {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 559px) {
  [data-design="a"] .pc-header__caravan { display: none; }
  [data-design="a"] .pc-header__bar { grid-template-columns: 1fr auto; }
  [data-design="a"] .pc-ambient-a__index { display: none; }
}

/* ══════════════════════════════════════════════════════════
   MOBILE H-SCROLL GUARD (REQUIRED by contract)
══════════════════════════════════════════════════════════ */
[data-design="a"].dq-design,
[data-design="a"] .dq-design { max-width: 100%; overflow-x: clip; }
[data-design="a"].dq-design * { min-width: 0; }
[data-design="a"].dq-design img,
[data-design="a"].dq-design svg:not([data-keep-size]) { max-width: 100%; height: auto; }

/* 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; }
