/* ================================================================
   Albers Counsel × Rich Phillips Construction — design-a
   ALL selectors scoped to [data-design="a"].dq-design or .dq-design
   Motion gate: ONLY transform / opacity / clip-path animated.
   ================================================================ */

/* ── Token system ────────────────────────────────────────────── */
[data-design="a"] {
  --ac-paper:       #F4EFE6;
  --ac-paper-2:     #EBE4D6;
  --ac-ink:         #1B1A17;
  --ac-ink-2:       #4A463E;
  --ac-rule:        #C8C0AE;
  --ac-plate-a:     #5E7F76;
  --ac-plate-b:     #C28A4B;
  --ac-plate-c:     #3A5670;
  --ac-plate-d:     #A14B3F;
  --ac-vermilion:   #B23A2A;
  --ac-vermilion-on:#F4EFE6;
  --ac-success:     #5C7A4A;
  --ac-critical:    #8E2A1F;

  /* Design-a primary (required by contract) */
  --design-a-primary: var(--ac-vermilion);

  /* Motion durations */
  --ac-dur-touch:   120ms;
  --ac-dur-press:   180ms;
  --ac-dur-settle:  420ms;
  --ac-dur-study:   1200ms;
  --ac-cycle-breath:4200ms;
  --ac-cycle-hue-a: 23s;
  --ac-cycle-hue-b: 31s;
  --ac-cycle-loom:  16s;
  --ac-cycle-plate: 20s;

  /* Easing */
  --ac-ease-study:  cubic-bezier(0.22, 0.61, 0.36, 1);
  --ac-ease-stamp:  cubic-bezier(0.83, 0, 0.17, 1);

  /* Radius */
  --ac-r-0: 0;
  --ac-r-1: 2px;
  --ac-r-2: 4px;

  /* Focus ring */
  --ac-focus-ring: 0 0 0 2px var(--ac-paper), 0 0 0 4px var(--ac-vermilion);

  /* Typography stacks */
  --font-display: 'Sectra', 'GT Sectra', 'Tiempos Headline', 'Georgia Pro', Georgia, serif;
  --font-body:    'Sectra', 'Tiempos Text', 'Charter', Georgia, serif;
  --font-caption: 'Söhne Breit', 'Inter', -apple-system, system-ui, sans-serif;
  --font-mono:    'GT America Mono', ui-monospace, 'JetBrains Mono', monospace;

  /* Spacing */
  --ac-tick:   4px;
  --ac-margin: 8px;
  --ac-bind:   12px;
  --ac-leaf:   20px;
  --ac-plate:  32px;
  --ac-folio:  56px;
  --ac-gutter: 88px;
  --ac-spread: 144px;
}

/* ── Mobile overflow prevention (scoped to .dq-design) ──────── */
[data-design="a"].dq-design,
[data-design="a"] .dq-design {
  max-width: 100%;
  overflow-x: clip;
  background: var(--ac-paper);
  color: var(--ac-ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.55;
}
[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;
}

/* ================================================================
   E1 — HEADER
   ================================================================ */
[data-design="a"] .rf-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--ac-paper);
  border-bottom: 1px solid var(--ac-rule);
  isolation: isolate;
}
[data-design="a"] .rf-header__bar {
  position: relative;
  display: flex; align-items: center; justify-content: space-between;
  height: 76px;
  padding-inline: clamp(20px, 4vw, 56px);
}
[data-design="a"] .rf-logo { text-decoration: none; color: var(--ac-ink); }
[data-design="a"] .rf-logo__mark {
  font-family: var(--font-display);
  font-style: italic; font-weight: 500;
  font-size: clamp(16px, 2vw, 22px);
  letter-spacing: -0.01em;
}
[data-design="a"] .rf-header__swatches {
  position: absolute; inset: 0; pointer-events: none;
  overflow: hidden;
  opacity: 0.22;
}
[data-design="a"] .rf-header__swatch {
  position: absolute; top: 0; bottom: 0; width: 50%;
  filter: saturate(0.65);
}
[data-design="a"] .rf-header__swatch--a {
  left: 0; background: var(--ac-plate-a);
  animation: ac-hue-a var(--ac-cycle-hue-a) linear infinite;
}
[data-design="a"] .rf-header__swatch--b {
  right: 0; background: var(--ac-plate-b);
  animation: ac-hue-b var(--ac-cycle-hue-b) linear infinite;
}
[data-design="a"] .rf-header__seam {
  position: absolute; top: 0; bottom: 0; left: 50%;
  width: 1px; background: var(--ac-rule);
  transform: translateX(-50%);
}
@keyframes ac-hue-a {
  0%, 100% { background: var(--ac-plate-a); }
  50%      { background: var(--ac-plate-c); }
}
@keyframes ac-hue-b {
  0%, 100% { background: var(--ac-plate-b); }
  50%      { background: var(--ac-plate-d); }
}
[data-design="a"] .rf-burger {
  width: 44px; height: 44px;
  display: inline-flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 6px;
  background: transparent; border: 1px solid var(--ac-rule);
  border-radius: var(--ac-r-1);
  cursor: pointer;
  flex-shrink: 0;
}
[data-design="a"] .rf-burger__line {
  display: block; width: 18px; height: 1px; background: var(--ac-ink);
  transition: transform 220ms var(--ac-ease-study), opacity 220ms;
}
[data-design="a"] .rf-burger[aria-expanded="true"] .rf-burger__line:nth-child(1) {
  transform: translateY(3.5px) rotate(45deg);
}
[data-design="a"] .rf-burger[aria-expanded="true"] .rf-burger__line:nth-child(2) {
  transform: translateY(-3.5px) rotate(-45deg);
}
[data-design="a"] .rf-burger:focus-visible {
  outline: none; box-shadow: var(--ac-focus-ring);
}
[data-design="a"] .rf-drawer {
  position: fixed; inset: 76px 0 0 0;
  background: var(--ac-paper);
  border-top: 1px solid var(--ac-rule);
  transform: translateY(-12px); opacity: 0;
  transition: transform 280ms var(--ac-ease-study), opacity 220ms;
  overflow-y: auto;
  z-index: 49;
}
[data-design="a"] .rf-drawer:not([hidden]) {
  transform: translateY(0); opacity: 1;
}
[data-design="a"] .rf-drawer[hidden] { display: none; }
[data-design="a"] .rf-drawer__inner {
  display: flex; flex-direction: column; gap: 16px;
  padding: 40px clamp(20px, 4vw, 56px) 56px;
  max-width: 720px;
}
[data-design="a"] .rf-drawer__link {
  font-family: var(--font-display);
  font-size: clamp(24px, 4.5vw, 48px);
  color: var(--ac-ink); text-decoration: none;
  border-bottom: 1px solid var(--ac-rule);
  padding-block: 12px;
  display: block;
}
[data-design="a"] .rf-drawer__link--cta {
  color: var(--ac-vermilion);
  border-bottom-color: var(--ac-vermilion);
}
[data-design="a"] .rf-drawer__link--phone {
  font-family: var(--font-mono);
  font-size: clamp(16px, 2.5vw, 22px);
  color: var(--ac-ink-2);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .rf-drawer__link:hover {
    border-bottom-color: var(--ac-vermilion);
  }
}

/* ================================================================
   HERO — E3 blueprint backdrop + content
   ================================================================ */
[data-design="a"] .rf-hero {
  position: relative;
  min-height: clamp(420px, 75vh, 760px);
  display: flex; align-items: flex-end;
  overflow: hidden;
  background: var(--ac-paper-2);
}
[data-design="a"] .rf-hero__backdrop {
  position: absolute; inset: 0;
  overflow: hidden;
  pointer-events: none;
}
/* Blueprint field — the drifting ambient color plane */
[data-design="a"] .rf-hero__field {
  position: absolute; inset: 0;
  background: linear-gradient(
    160deg,
    color-mix(in oklab, var(--ac-plate-c), transparent 72%) 0%,
    color-mix(in oklab, var(--ac-plate-a), transparent 80%) 55%,
    color-mix(in oklab, var(--ac-plate-b), transparent 85%) 100%
  );
  animation: ac-hero-field-drift 12s ease-in-out infinite;
}
@keyframes ac-hero-field-drift {
  0%, 100% { opacity: 0.55; transform: scale(1.0); }
  50%      { opacity: 0.72; transform: scale(1.02); }
}
/* Blueprint SVG */
[data-design="a"] .rf-hero__blueprint {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  color: var(--ac-plate-c);
  opacity: 0;
  animation: ac-hero-blueprint-reveal 2.4s var(--ac-ease-study) 0.3s forwards;
}
@keyframes ac-hero-blueprint-reveal {
  from { opacity: 0; transform: scale(0.98); }
  to   { opacity: 1; transform: scale(1); }
}
/* Blueprint lines draw-in via clip-path (NOT width/height) */
[data-design="a"] .bp-line,
[data-design="a"] .bp-rect,
[data-design="a"] .bp-dim {
  stroke-dasharray: 2000;
  stroke-dashoffset: 2000;
  animation: ac-bp-draw 2.8s var(--ac-ease-study) 0.6s forwards;
}
[data-design="a"] .bp-line--1 { animation-delay: 0.7s; }
[data-design="a"] .bp-line--2 { animation-delay: 0.9s; }
[data-design="a"] .bp-line--3 { animation-delay: 0.9s; }
[data-design="a"] .bp-line--4 { animation-delay: 1.1s; }
[data-design="a"] .bp-line--5 { animation-delay: 1.1s; }
[data-design="a"] .bp-line--6 { animation-delay: 1.3s; }
[data-design="a"] .bp-line--7 { animation-delay: 1.4s; }
[data-design="a"] .bp-line--8 { animation-delay: 1.5s; }
[data-design="a"] .bp-rect--1 { animation-delay: 1.6s; }
[data-design="a"] .bp-rect--2 { animation-delay: 1.7s; }
[data-design="a"] .bp-rect--3 { animation-delay: 1.8s; }
[data-design="a"] .bp-dim--h  { animation-delay: 2.0s; }
[data-design="a"] .bp-dim--v  { animation-delay: 2.2s; }
@keyframes ac-bp-draw {
  to { stroke-dashoffset: 0; }
}
/* Continuous ambient pulse on blueprint after draw-in */
[data-design="a"] .rf-hero__blueprint {
  animation: ac-hero-blueprint-reveal 2.4s var(--ac-ease-study) 0.3s forwards,
             ac-hero-blueprint-breathe 9s ease-in-out 3s infinite;
}
@keyframes ac-hero-blueprint-breathe {
  0%, 100% { opacity: 0.9; }
  50%      { opacity: 0.55; }
}

/* Scroll-parallax layer (TRIAD-2 — scroll-driven via JS) */
[data-design="a"] .rf-hero__parallax-layer {
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 60%,
    color-mix(in oklab, var(--ac-paper-2), transparent 30%) 100%
  );
  transform: translateY(0);
  will-change: transform;
}

/* Hero content */
[data-design="a"] .rf-hero__content {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: flex-start;
  gap: var(--ac-plate);
  padding: clamp(64px, 10vh, 120px) clamp(20px, 6vw, 80px) clamp(64px, 8vh, 100px);
  max-width: 860px;
}
[data-design="a"] .rf-hero__text {
  display: flex; flex-direction: column; gap: var(--ac-bind);
}
[data-design="a"] .rf-hero__rail {
  color: var(--ac-ink-2);
}
[data-design="a"] .rf-hero__headline {
  font-family: var(--font-display);
  font-size: clamp(30px, 4.5vw, 60px);
  line-height: 1.08;
  letter-spacing: -0.018em;
  margin: 0;
  color: var(--ac-ink);
}
[data-design="a"] .rf-hero__subtitle {
  font-family: var(--font-body);
  font-size: clamp(17px, 2vw, 22px);
  line-height: 1.5;
  color: var(--ac-ink-2);
  margin: 0;
  max-width: 560px;
}
[data-design="a"] .rf-hero__proof {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--ac-ink-2);
  margin: 0;
  opacity: 0.85;
}

/* ================================================================
   E2 — CTA (funnel-anchor seal button)
   ================================================================ */
[data-design="a"] .rf-cta {
  --m-x: 0px; --m-y: 0px;
  position: relative;
  display: inline-flex; align-items: baseline; gap: 12px;
  padding: 16px 26px;
  background: var(--ac-vermilion); color: var(--ac-vermilion-on);
  text-decoration: none;
  border: 1px solid var(--ac-vermilion);
  border-radius: var(--ac-r-1);
  transform: translate(var(--m-x), var(--m-y));
  transition: transform 320ms var(--ac-ease-study),
              background-color var(--ac-dur-press);
  animation: ac-cta-breath var(--ac-cycle-breath) ease-in-out infinite;
  will-change: transform;
}
[data-design="a"] .rf-cta__caption {
  font-family: var(--font-caption);
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.18em;
  opacity: 0.78;
}
[data-design="a"] .rf-cta__label {
  font-family: var(--font-display);
  font-style: italic; font-size: 18px; letter-spacing: -0.005em;
}
[data-design="a"] .rf-cta__arrow {
  font-family: var(--font-display);
  font-size: 20px;
  transition: transform 240ms var(--ac-ease-study);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .rf-cta:hover {
    background: color-mix(in oklab, var(--ac-vermilion), black 6%);
  }
  [data-design="a"] .rf-cta:hover .rf-cta__arrow {
    transform: translateX(4px);
  }
}
[data-design="a"] .rf-cta:focus-visible { outline: none; box-shadow: var(--ac-focus-ring); }
[data-design="a"] .rf-cta:active {
  transform: translate(var(--m-x), calc(var(--m-y) + 1px));
  background: color-mix(in oklab, var(--ac-vermilion), black 12%);
}
[data-design="a"] .rf-cta.is-stamped::after {
  content: ""; position: absolute; inset: -1px;
  border: 1px solid var(--ac-vermilion); border-radius: inherit;
  pointer-events: none; opacity: 0.5;
  animation: ac-stamp-dry 600ms ease-out forwards;
}
@keyframes ac-cta-breath {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--ac-vermilion), transparent 70%); }
  50%      { box-shadow: 0 0 0 6px color-mix(in oklab, var(--ac-vermilion), transparent 92%); }
}
@keyframes ac-stamp-dry {
  0%   { opacity: 0.55; transform: scale(1); }
  100% { opacity: 0;    transform: scale(1.04); }
}
[data-design="a"] .rf-cta--portfolio,
[data-design="a"] .rf-cta--footer {
  font-size: 15px;
}

/* ================================================================
   E6 — POINTER (dimension-line wayfinding, drafted-measured)
   ================================================================ */
[data-design="a"] .ac-pointer {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(36px, 5vh, 64px) clamp(20px, 4vw, 56px);
  background: var(--ac-paper);
  border-bottom: 1px solid var(--ac-rule);
}
[data-design="a"] .ac-pointer__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  width: 100%;
  max-width: 600px;
}
[data-design="a"] .ac-pointer__dimline {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
}
[data-design="a"] .ac-pointer__tick--l,
[data-design="a"] .ac-pointer__tick--r {
  display: block;
  width: 1px;
  height: 18px;
  background: var(--ac-ink-2);
  opacity: 0.5;
  flex-shrink: 0;
}
[data-design="a"] .ac-pointer__rule {
  flex: 1;
  height: 1px;
  background: var(--ac-ink-2);
  opacity: 0.3;
  /* draw-in animation using scaleX (NOT width) */
  transform: scaleX(0);
  transform-origin: left center;
  animation: ac-dim-rule-draw 1.2s var(--ac-ease-study) 0.4s forwards;
}
@keyframes ac-dim-rule-draw {
  to { transform: scaleX(1); }
}
[data-design="a"] .ac-pointer__label {
  font-family: var(--font-caption);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ac-ink-2);
  opacity: 0.75;
  white-space: nowrap;
  flex-shrink: 0;
}
[data-design="a"] .ac-pointer__bar {
  position: relative;
  width: clamp(120px, 30vw, 240px);
  height: 2px;
  background: var(--ac-rule);
  border-radius: 1px;
  overflow: hidden;
}
[data-design="a"] .ac-pointer__bar-fill {
  position: absolute;
  inset: 0;
  transform: scaleX(0.16);
  transform-origin: left;
  background: var(--ac-plate-a);
  opacity: 1;
  transition: transform 480ms var(--ac-ease-study);
}
[data-design="a"] .ac-pointer__chev {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--ac-ink-2);
  opacity: 0.5;
  animation: ac-pointer-chev-drift 4.2s ease-in-out infinite;
}
@keyframes ac-pointer-chev-drift {
  0%, 100% { transform: translateY(0);   opacity: 0.4; }
  50%      { transform: translateY(5px); opacity: 0.75; }
}

/* ================================================================
   E5 — FUNNEL (5-step qualifying intake)
   ================================================================ */
[data-design="a"] .rf-interactive {
  --surround: var(--ac-paper-2);
  background: var(--surround);
  border-block: 1px solid var(--ac-rule);
  padding: var(--ac-spread) clamp(20px, 4vw, 56px);
  transition: background-color var(--ac-dur-study) var(--ac-ease-study);
}
[data-design="a"] .rf-funnel__head {
  max-width: 720px; margin: 0 auto var(--ac-folio);
}
[data-design="a"] .rf-rail--accent { color: var(--ac-vermilion); }
[data-design="a"] .rf-funnel__counter {
  font-family: var(--font-caption);
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
}
[data-design="a"] .rf-funnel {
  max-width: 720px; margin: 0 auto;
  border: 1px solid var(--ac-rule); background: var(--ac-paper);
  padding: clamp(24px, 5vw, 48px);
}
[data-design="a"] .rf-funnel__steps {
  list-style: none; padding: 0; margin: 0; display: grid;
}
[data-design="a"] .rf-funnel__step {
  grid-area: 1 / 1; visibility: hidden; opacity: 0;
  transform: translateX(28px);
  transition: opacity var(--ac-dur-settle) var(--ac-ease-study),
              transform var(--ac-dur-settle) var(--ac-ease-study);
}
[data-design="a"] .rf-funnel__step.is-active {
  visibility: visible; opacity: 1; transform: none;
}
[data-design="a"] .rf-funnel__step.is-leaving {
  visibility: visible; opacity: 0; transform: translateX(-28px);
}
[data-design="a"] .rf-funnel fieldset { border: 0; padding: 0; margin: 0; }
[data-design="a"] .rf-funnel legend {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.8vw, 27px); line-height: 1.25;
  margin: 10px 0 20px; color: var(--ac-ink);
}
[data-design="a"] .rf-chips { display: flex; flex-wrap: wrap; gap: 10px; }
[data-design="a"] .rf-chip {
  position: relative; display: inline-flex; align-items: center;
  padding: 12px 18px;
  border: 1px solid var(--ac-rule); border-radius: var(--ac-r-2);
  cursor: pointer;
  transition: border-color 80ms, background-color 80ms;
  min-height: 44px;
}
[data-design="a"] .rf-chip input {
  position: absolute; inset: 0; opacity: 0; cursor: pointer;
}
[data-design="a"] .rf-chip span {
  font-family: var(--font-body); font-size: 16px; color: var(--ac-ink);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .rf-chip:hover { border-color: var(--ac-ink-2); }
}
[data-design="a"] .rf-chip:has(input:focus-visible) { box-shadow: var(--ac-focus-ring); }
[data-design="a"] .rf-chip:has(input:checked) {
  border-color: var(--ac-vermilion); border-width: 1.5px;
  background: color-mix(in oklab, var(--ac-vermilion), var(--ac-paper) 88%);
}
[data-design="a"] .rf-fields {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
[data-design="a"] .rf-field { display: flex; flex-direction: column; gap: 6px; }
[data-design="a"] .rf-field--full { grid-column: 1 / -1; }
[data-design="a"] .rf-field input,
[data-design="a"] .rf-field textarea {
  border: 0; border-bottom: 1px solid var(--ac-ink-2);
  background: transparent;
  font-family: var(--font-body); font-size: 16px; color: var(--ac-ink);
  padding: 8px 0; resize: vertical;
  transition: border-color 200ms;
}
[data-design="a"] .rf-field input:focus,
[data-design="a"] .rf-field textarea:focus {
  outline: none;
  border-bottom-color: var(--ac-vermilion);
  border-bottom-width: 2px;
}
[data-design="a"] .rf-funnel__nav {
  display: flex; gap: 12px; flex-wrap: wrap; align-items: center;
  margin-block-start: var(--ac-plate);
  padding-block-start: var(--ac-plate);
  border-top: 1px solid var(--ac-rule);
}
[data-design="a"] .rf-btn {
  font-family: var(--font-display);
  font-size: 16px; padding: 12px 18px;
  background: transparent; color: var(--ac-ink);
  border: 1px solid var(--ac-rule); border-radius: var(--ac-r-1);
  cursor: pointer; min-height: 44px;
  transition: border-color 160ms, background-color 160ms;
}
[data-design="a"] .rf-btn--primary {
  background: var(--ac-ink); color: var(--ac-paper);
  border-color: var(--ac-ink);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .rf-btn--secondary:hover {
    border-color: var(--ac-ink-2); background: var(--ac-paper-2);
  }
  [data-design="a"] .rf-btn--primary:hover {
    background: color-mix(in oklab, var(--ac-ink), transparent 12%);
  }
}
[data-design="a"] .rf-btn:focus-visible { outline: none; box-shadow: var(--ac-focus-ring); }
[data-design="a"] .rf-btn[hidden] { display: none; }

/* Funnel surround tints by project type */
[data-design="a"] .rf-interactive[data-tint="custom-home"]  { --surround: color-mix(in oklab, var(--ac-paper-2), var(--ac-plate-a) 16%); }
[data-design="a"] .rf-interactive[data-tint="major-remodel"]{ --surround: color-mix(in oklab, var(--ac-paper-2), var(--ac-plate-c) 14%); }
[data-design="a"] .rf-interactive[data-tint="addition"]     { --surround: color-mix(in oklab, var(--ac-paper-2), var(--ac-plate-b) 14%); }
[data-design="a"] .rf-interactive[data-tint="kitchen"]      { --surround: color-mix(in oklab, var(--ac-paper-2), var(--ac-plate-d) 13%); }
[data-design="a"] .rf-interactive[data-tint="bathroom"]     { --surround: color-mix(in oklab, var(--ac-paper-2), var(--ac-plate-a) 12%); }
[data-design="a"] .rf-interactive[data-tint="whole-home"]   { --surround: color-mix(in oklab, var(--ac-paper-2), var(--ac-plate-c) 14%); }
[data-design="a"] .rf-interactive[data-tint="basement"]     { --surround: color-mix(in oklab, var(--ac-paper-2), var(--ac-plate-d) 13%); }
[data-design="a"] .rf-interactive[data-tint="other"]        { --surround: color-mix(in oklab, var(--ac-paper-2), var(--ac-ink-2) 10%); }

/* Done / confirmation plate */
[data-design="a"] .rf-funnel__step--done { padding-block: var(--ac-bind); }
[data-design="a"] .rf-funnel__alt-contact {
  font-size: 15px; color: var(--ac-ink-2); margin-block-start: var(--ac-leaf);
}

/* Below-funnel trust block */
[data-design="a"] .rf-funnel__trust {
  max-width: 720px; margin: var(--ac-folio) auto 0;
  display: grid; gap: 8px;
  border-top: 1px solid var(--ac-rule);
  padding-block-start: var(--ac-plate);
}
[data-design="a"] .rf-funnel__trust-line {
  font-family: var(--font-mono);
  font-size: 13px; color: var(--ac-ink-2);
  line-height: 1.5; margin: 0;
}

/* ================================================================
   PORTFOLIO — E3 ambient (Albers plates typography-first)
   ================================================================ */
[data-design="a"] .rf-portfolio {
  background: var(--ac-paper);
  padding: var(--ac-spread) clamp(20px, 4vw, 56px);
}
[data-design="a"] .rf-portfolio__head {
  max-width: 720px; margin: 0 auto var(--ac-folio);
}
[data-design="a"] .rf-plates {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: var(--ac-folio);
  max-width: 1100px; margin-inline: auto;
}
[data-design="a"] .rf-plate {
  --sq-l: var(--ac-plate-a); --sq-r: var(--ac-plate-b);
  border: 1px solid var(--ac-rule);
  background: var(--ac-paper);
  padding: 24px 24px 0;
  opacity: 0; transform: translateY(14px);
  transition: opacity 600ms var(--ac-ease-study), transform 600ms var(--ac-ease-study);
}
[data-design="a"] .rf-plate[data-pair="cd"] { --sq-l: var(--ac-plate-c); --sq-r: var(--ac-plate-d); }
[data-design="a"] .rf-plate.is-in { opacity: 1; transform: none; }
[data-design="a"] .rf-plate__pair {
  position: relative; display: grid; grid-template-columns: 1fr 1fr;
  min-height: 140px; margin-block-start: 20px;
}
[data-design="a"] .rf-plate__pair::after {
  content: ""; position: absolute; inset-block: 0; left: 50%;
  width: 1px; background: var(--ac-rule);
  transform: translateX(-50%) scaleY(0); transform-origin: center;
  transition: transform 1200ms var(--ac-ease-study) 200ms;
}
[data-design="a"] .rf-plate.is-in .rf-plate__pair::after {
  transform: translateX(-50%) scaleY(1);
}
[data-design="a"] .rf-plate__square {
  padding: 20px 20px 28px;
  color: var(--ac-paper);
}
[data-design="a"] .rf-plate__square--l {
  background: var(--sq-l);
  animation: ac-plate-drift-l var(--ac-cycle-plate) ease-in-out infinite;
}
[data-design="a"] .rf-plate__square--r {
  background: var(--sq-r);
  animation: ac-plate-drift-r var(--ac-cycle-plate) ease-in-out infinite;
  animation-delay: -10s;
}
[data-design="a"] .rf-plate__square p { margin: 0; }
[data-design="a"] .rf-plate__square p:last-child {
  font-family: var(--font-body);
  font-size: 16px; line-height: 1.5; margin-block-start: 10px;
}
[data-design="a"] .rf-plate.is-paused .rf-plate__square--l,
[data-design="a"] .rf-plate.is-paused .rf-plate__square--r {
  animation-play-state: paused;
}
@keyframes ac-plate-drift-l {
  0%, 100% { background: var(--sq-l); }
  50%      { background: color-mix(in oklab, var(--sq-l), var(--sq-r) 14%); }
}
@keyframes ac-plate-drift-r {
  0%, 100% { background: var(--sq-r); }
  50%      { background: color-mix(in oklab, var(--sq-r), var(--sq-l) 14%); }
}
[data-design="a"] .rf-portfolio__cta-repeat {
  max-width: 720px; margin: var(--ac-gutter) auto 0;
  display: flex; flex-direction: column; align-items: flex-start; gap: var(--ac-plate);
  padding-block-start: var(--ac-folio);
  border-top: 1px solid var(--ac-rule);
}
[data-design="a"] .rf-portfolio__cta-note {
  font-family: var(--font-body);
  font-style: italic; font-size: 20px; color: var(--ac-ink-2);
  margin: 0;
}

/* ================================================================
   PROCESS — E4 loom (Ambient B, mid-page)
   ================================================================ */
[data-design="a"] .rf-process {
  background: var(--ac-paper-2);
  border-block: 1px solid var(--ac-rule);
  padding: var(--ac-spread) clamp(20px, 4vw, 56px);
}
[data-design="a"] .rf-process__inner {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--ac-folio);
  max-width: 1100px; margin: 0 auto; align-items: start;
}
[data-design="a"] .rf-process__head { grid-column: 1; }
[data-design="a"] .rf-loom {
  position: relative; grid-column: 1; grid-row: 2;
  height: 180px; margin-block-start: var(--ac-leaf);
  border: 1px solid var(--ac-rule); background: var(--ac-paper);
  overflow: hidden;
}
[data-design="a"] .rf-loom__warp {
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(
    to right,
    transparent 0,
    transparent 11px,
    var(--ac-rule) 11px,
    var(--ac-rule) 11.5px
  );
}
/* MOTION GATE FIX: original design uses `top:` in @keyframes.
   Replaced with translateY() — transform only (no layout prop). */
[data-design="a"] .rf-loom__weft {
  position: absolute;
  top: 50%;
  left: -8%;
  width: 116%; height: 1px;
  background: linear-gradient(
    to right,
    transparent 0%, var(--ac-ink-2) 8%, var(--ac-ink-2) 92%, transparent 100%
  );
  transform-origin: left center;
  animation: ac-loom-weave var(--ac-cycle-loom) linear infinite;
}
[data-design="a"] .rf-loom.is-paused .rf-loom__weft {
  animation-play-state: paused;
}
/* Weft sweeps via translateY — no `top` changes in keyframes */
@keyframes ac-loom-weave {
  0%   { transform: translateY(-56%) rotate(0deg); }
  25%  { transform: translateY(0%)   rotate(0.5deg); }
  50%  { transform: translateY(56%)  rotate(0deg); }
  75%  { transform: translateY(0%)   rotate(-0.5deg); }
  100% { transform: translateY(-56%) rotate(0deg); }
}
[data-design="a"] .rf-process__steps {
  grid-column: 2; grid-row: 1 / span 2;
}
[data-design="a"] .rf-process__list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: var(--ac-plate);
}
[data-design="a"] .rf-process__item {
  display: grid; grid-template-columns: 52px 1fr; gap: var(--ac-bind);
  align-items: baseline;
  font-family: var(--font-body); font-size: 17px; line-height: 1.6;
  color: var(--ac-ink);
  border-bottom: 1px solid var(--ac-rule);
  padding-block-end: var(--ac-plate);
  opacity: 0; transform: translateY(10px);
  transition: opacity 600ms var(--ac-ease-study), transform 600ms var(--ac-ease-study);
}
[data-design="a"] .rf-process__item.is-in { opacity: 1; transform: none; }
[data-design="a"] .rf-process__item:last-child { border-bottom: 0; }
[data-design="a"] .rf-process__num {
  font-family: var(--font-mono); font-size: 12px;
  color: var(--ac-plate-a); opacity: 0.9; padding-block-start: 4px;
}

/* ================================================================
   SERVICES
   ================================================================ */
[data-design="a"] .rf-services {
  background: var(--ac-paper);
  padding: var(--ac-spread) clamp(20px, 4vw, 56px);
}
[data-design="a"] .rf-services__inner { max-width: 960px; margin: 0 auto; }
[data-design="a"] .rf-services__head { margin-block-end: var(--ac-folio); }
[data-design="a"] .rf-services__list {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 0;
}
[data-design="a"] .rf-service-item {
  font-family: var(--font-body);
  font-size: 18px; line-height: 1.55; color: var(--ac-ink);
  border-bottom: 1px solid var(--ac-rule);
  padding-block: var(--ac-bind) var(--ac-plate);
  padding-inline-end: var(--ac-plate);
}
[data-design="a"] .rf-services__area {
  font-family: var(--font-mono); font-size: 13px;
  color: var(--ac-ink-2); margin-block-start: var(--ac-folio);
  letter-spacing: 0.04em;
}

/* ================================================================
   ABOUT
   ================================================================ */
[data-design="a"] .rf-about {
  background: var(--ac-paper-2);
  border-block: 1px solid var(--ac-rule);
  padding: var(--ac-spread) clamp(20px, 4vw, 56px);
}
[data-design="a"] .rf-about__inner { max-width: 1100px; margin: 0 auto; }
[data-design="a"] .rf-about__plate {
  border: 1px solid var(--ac-rule);
  padding: clamp(28px, 4vw, 48px);
  background: var(--ac-paper);
}
[data-design="a"] .rf-about__pair {
  display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--ac-gutter);
  margin-block-start: var(--ac-plate); align-items: start;
}
[data-design="a"] .rf-about__body {
  font-family: var(--font-body); font-size: 18px; line-height: 1.65;
  color: var(--ac-ink); margin: 0 0 var(--ac-plate);
}
[data-design="a"] .rf-about__cred {
  font-family: var(--font-mono); font-size: 13px;
  color: var(--ac-ink-2); line-height: 1.8; margin: 0;
}
[data-design="a"] .rf-about__glyph {
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--ac-rule);
  background: var(--ac-paper-2);
  color: var(--ac-plate-c);
  aspect-ratio: 5/6;
  min-height: 160px;
}
[data-design="a"] .rf-about__glyph svg { width: 60%; height: auto; }

/* ================================================================
   FOOTER
   ================================================================ */
[data-design="a"] .rf-footer {
  background: var(--ac-paper-2);
  border-top: 1px solid var(--ac-rule);
  padding: var(--ac-gutter) clamp(20px, 4vw, 56px) var(--ac-folio);
}
[data-design="a"] .rf-footer__inner {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1.2fr; gap: var(--ac-folio);
  align-items: start;
}
[data-design="a"] .rf-footer__name {
  font-style: italic; font-size: 18px;
  display: block; margin-block-end: var(--ac-bind);
  text-decoration: none; color: var(--ac-ink);
}
[data-design="a"] .rf-footer__license {
  font-family: var(--font-mono); font-size: 12px;
  color: var(--ac-ink-2); line-height: 1.7; margin: 0 0 8px;
}
[data-design="a"] .rf-footer__contact p,
[data-design="a"] .rf-footer__area p {
  font-family: var(--font-body); font-size: 15px;
  color: var(--ac-ink-2); line-height: 1.65; margin: 0 0 6px;
}
[data-design="a"] .rf-footer__rule {
  max-width: 1100px; margin: var(--ac-folio) auto var(--ac-plate);
  height: 1px; background: var(--ac-rule);
}
[data-design="a"] .rf-footer__copy {
  max-width: 1100px; margin: 0 auto;
  font-family: var(--font-mono); font-size: 12px;
  color: var(--ac-ink-2); letter-spacing: 0.04em;
}

/* ================================================================
   SHARED TYPOGRAPHY
   ================================================================ */
[data-design="a"] .rf-display {
  font-family: var(--font-display);
  font-size: clamp(30px, 4.5vw, 52px); line-height: 1.08;
  letter-spacing: -0.014em; margin: 0 0 var(--ac-bind);
  color: var(--ac-ink);
}
[data-design="a"] .rf-display--md {
  font-size: clamp(22px, 3vw, 34px);
}
[data-design="a"] .rf-lead {
  font-family: var(--font-body);
  font-size: 20px; line-height: 1.55; color: var(--ac-ink-2); margin: 0;
}
[data-design="a"] .rf-rail {
  font-family: var(--font-caption);
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--ac-ink-2); margin: 0 0 10px;
  display: block;
}
[data-design="a"] .rf-rail--micro { font-size: 11px; opacity: 0.85; }
[data-design="a"] .rf-inline-link {
  color: var(--ac-vermilion); text-decoration: underline;
  text-underline-offset: 2px;
}

/* ================================================================
   RESPONSIVE — mobile (all scoped to .dq-design)
   ================================================================ */
@media (max-width: 768px) {
  [data-design="a"].dq-design .rf-process__inner {
    grid-template-columns: 1fr;
  }
  [data-design="a"].dq-design .rf-loom {
    grid-column: 1; grid-row: auto;
    height: 120px;
  }
  [data-design="a"].dq-design .rf-process__steps {
    grid-column: 1; grid-row: auto;
  }
  [data-design="a"].dq-design .rf-about__pair {
    grid-template-columns: 1fr;
  }
  [data-design="a"].dq-design .rf-about__col--r {
    display: none;
  }
  [data-design="a"].dq-design .rf-footer__inner {
    grid-template-columns: 1fr 1fr;
    gap: var(--ac-plate);
  }
  [data-design="a"].dq-design .rf-footer__brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 560px) {
  [data-design="a"].dq-design .rf-header__bar { height: 60px; padding-inline: 16px; }
  [data-design="a"].dq-design .rf-drawer { inset-block-start: 60px; }
  [data-design="a"].dq-design .rf-fields { grid-template-columns: 1fr; }
  [data-design="a"].dq-design .rf-funnel__nav .rf-cta { width: 100%; justify-content: center; }
  [data-design="a"].dq-design .rf-cta { padding: 14px 18px; }
  [data-design="a"].dq-design .rf-cta__label { font-size: 16px; }
  [data-design="a"].dq-design .rf-plate__pair { grid-template-columns: 1fr; }
  [data-design="a"].dq-design .rf-plate__pair::after {
    inset: auto 0; left: 0; inset-block-start: 50%;
    width: auto; height: 1px;
    transform: translateY(-50%) scaleX(0);
  }
  [data-design="a"].dq-design .rf-plate.is-in .rf-plate__pair::after {
    transform: translateY(-50%) scaleX(1);
  }
  [data-design="a"].dq-design .rf-hero__content {
    padding-inline: 16px;
  }
  [data-design="a"].dq-design .rf-footer__inner {
    grid-template-columns: 1fr;
  }
  [data-design="a"].dq-design .rf-footer__cta {
    display: none;
  }
  [data-design="a"].dq-design .rf-lead { font-size: 17px; }
}

/* ================================================================
   REDUCED MOTION
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .rf-header__swatch--a,
  [data-design="a"] .rf-header__swatch--b { animation: none; }
  [data-design="a"] .rf-drawer { transition: none; }
  [data-design="a"] .rf-hero__field { animation: none; opacity: 0.55; }
  [data-design="a"] .rf-hero__blueprint { animation: none; opacity: 1; }
  [data-design="a"] .bp-line, [data-design="a"] .bp-rect,
  [data-design="a"] .bp-dim { animation: none; stroke-dashoffset: 0; }
  [data-design="a"] .rf-hero__parallax-layer { transform: none !important; }
  [data-design="a"] .rf-cta { animation: none; transition: background-color 120ms; }
  [data-design="a"] .rf-cta.is-stamped::after { animation: none; }
  [data-design="a"] .ac-pointer__rule { animation: none; transform: scaleX(1); }
  [data-design="a"] .ac-pointer__chev { animation: none; }
  [data-design="a"] .rf-loom__weft { animation: none; }
  [data-design="a"] .rf-plate { opacity: 1; transform: none; transition: none; }
  [data-design="a"] .rf-plate__pair::after {
    transform: translateX(-50%) scaleY(1); transition: none;
  }
  [data-design="a"] .rf-plate__square--l,
  [data-design="a"] .rf-plate__square--r { animation: none; }
  [data-design="a"] .rf-funnel__step { transition: none; }
  [data-design="a"] .rf-funnel__step.is-active { opacity: 1; transform: none; }
  [data-design="a"] .rf-interactive { transition: none; }
  [data-design="a"] .rf-process__item { opacity: 1; transform: none; transition: none; }
}

/* 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; }
