/* ═══════════════════════════════════════════════════════════════
   A Good Lawn — Watershed design, slot A
   All selectors scoped [data-design="a"].dq-design or [data-design="a"].dq-design
   Keyframes: ws- prefixed
   ZERO layout-prop animations (width/height/top/left/margin/padding)
   ALL :hover/:focus-visible transforms inside @media (hover:hover) and (pointer:fine)
   ═══════════════════════════════════════════════════════════════ */

/* ── Token binding (slot a, remapped from watershed) ──────────── */
[data-design="a"] {
  --bond:#F1ECDA; --bond-deep:#E3DBC0;
  --ink:#15171C; --ink-soft:#3A3D45; --muted:#7B7866; --rule:#22252B;
  --watercourse:#1F5A8A; --contour-brown:#7B502D; --cattail:#3A6248;
  --pool-amber:#C28220; --critical:#A0231A;

  --font-display:"Founders Grotesk","Söhne","Helvetica Neue",sans-serif;
  --font-survey:"Cooper Hewitt","Avenir Next","Inter",sans-serif;
  --font-body:"Sentinel Book","Roboto Slab","PT Serif",Georgia,serif;
  --font-map:"Tradesman","Caveat",cursive;
  --font-data:"IBM Plex Mono","JetBrains Mono",monospace;

  --space-tick:2px; --space-em:8px; --space-stream:16px; --space-bank:24px;
  --space-bend:48px; --space-river:80px; --space-basin:144px;

  --dur-tick:140ms; --dur-flow:520ms; --dur-draw:900ms; --dur-fill:1200ms;
  --dur-survey:2200ms; --dur-ambient:20000ms;
  --ease-flow:cubic-bezier(.22,1,.36,1);
  --ease-draw:cubic-bezier(.65,.05,.36,1);
  --ease-fill:cubic-bezier(.34,.04,.26,1);
  --ease-pulse:cubic-bezier(.45,.05,.55,.95);

  --radius-zero:0; --radius-pin:50%;
  --shadow-map:2px 2px 0 var(--bond-deep), 4px 4px 0 var(--rule);
  --shadow-press:inset 0 2px 0 rgba(0,0,0,.1);

  /* Design-a primary token (required by contract) */
  --design-a-primary: var(--watercourse);

  color:var(--ink); background:var(--bond);
  font-family:var(--font-body);
}
@media (prefers-color-scheme: dark) {
  [data-design="a"] {
    --bond:#0C0E13; --bond-deep:#15191F;
    --ink:#E5E0CC; --ink-soft:#B5B098; --muted:#7E7B64; --rule:#9A9476;
    --watercourse:#4F8CC0; --contour-brown:#A8794A; --cattail:#6E9576;
    --pool-amber:#E0A547; --critical:#CD3F30;
  }
}
[data-design="a"].dq-design *,
[data-design="a"].dq-design *::before,
[data-design="a"].dq-design *::after { box-sizing:border-box; }

/* ── Mobile / overflow guards ─────────────────────────────────── */
[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; }

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 1 — Animated minimalist header (Watercourse Strip)
   ═══════════════════════════════════════════════════════════════ */
[data-design="a"] .ws-header {
  position:sticky; top:0; z-index:50; width:100%;
  background:var(--bond); border-bottom:1px solid var(--rule);
}
[data-design="a"] .ws-header__bar {
  display:flex; align-items:center; justify-content:space-between;
  gap:var(--space-stream); max-width:1280px; margin:0 auto;
  padding:14px clamp(16px,4vw,40px);
}
[data-design="a"] .ws-logo {
  display:inline-flex; align-items:center; gap:10px;
  text-decoration:none; color:var(--ink); min-width:0;
}
[data-design="a"] .ws-logo__pin {
  flex:0 0 auto; width:9px; height:9px; border-radius:var(--radius-pin);
  background:var(--cattail);
  box-shadow:0 0 0 3px color-mix(in oklab,var(--cattail),transparent 76%);
  animation:ws-pin-pulse 6s var(--ease-pulse) infinite;
}
[data-design="a"] .ws-logo__mark {
  font-family:var(--font-survey); font-weight:700;
  font-size:clamp(14px,2.4vw,20px); letter-spacing:.14em;
  text-transform:uppercase; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
[data-design="a"] .ws-header__course {
  position:absolute; left:0; right:0; bottom:-5px; width:100%; height:12px; display:block;
}
[data-design="a"] .ws-header__bed {
  fill:none; stroke:color-mix(in oklab,var(--cattail),transparent 80%); stroke-width:1.5;
}
[data-design="a"] .ws-header__flow {
  fill:none; stroke:var(--cattail); stroke-width:2; stroke-linecap:round;
  stroke-dasharray:16 280; stroke-dashoffset:0;
  animation:ws-course-flow 24s linear infinite;
}
@keyframes ws-course-flow { to { stroke-dashoffset:-296; } }
@keyframes ws-pin-pulse { 0%,100%{ transform:scale(1); opacity:.95; } 50%{ transform:scale(1.4); opacity:.5; } }

[data-design="a"] .ws-burger {
  flex:0 0 auto; display:inline-flex; flex-direction:column; justify-content:center;
  gap:5px; width:44px; height:44px; padding:0; cursor:pointer;
  border:1px solid var(--rule); background:var(--bond); border-radius:var(--radius-zero);
}
[data-design="a"] .ws-burger__line {
  display:block; width:20px; height:2px; margin:0 auto; background:var(--ink);
  transition:transform var(--dur-tick) var(--ease-flow), opacity var(--dur-tick);
}
[data-design="a"] .ws-burger[aria-expanded="true"] .ws-burger__line:first-child {
  transform:translateY(3.5px) rotate(45deg);
}
[data-design="a"] .ws-burger[aria-expanded="true"] .ws-burger__line:last-child {
  transform:translateY(-3.5px) rotate(-45deg);
}
[data-design="a"] .ws-burger:focus-visible { outline:2px solid var(--pool-amber); outline-offset:3px; }

[data-design="a"] .ws-drawer {
  position:fixed; inset:0; z-index:60;
  background:color-mix(in oklab,var(--bond),transparent 6%);
  display:flex; justify-content:flex-end;
  opacity:0; transition:opacity var(--dur-flow) var(--ease-flow);
}
[data-design="a"] .ws-drawer[hidden] { display:none; }
[data-design="a"] .ws-drawer.is-open { opacity:1; }
[data-design="a"] .ws-drawer__panel {
  width:min(420px,86vw); height:100%; padding:84px var(--space-bank) var(--space-bank);
  background:var(--bond-deep); border-left:1px solid var(--rule);
  transform:translateX(24px); transition:transform var(--dur-flow) var(--ease-flow);
  display:flex; flex-direction:column; gap:var(--space-bend);
}
[data-design="a"] .ws-drawer.is-open .ws-drawer__panel { transform:none; }
[data-design="a"] .ws-drawer__nav {
  display:flex; flex-direction:column; gap:var(--space-bank);
}
[data-design="a"] .ws-drawer__nav a {
  font-family:var(--font-display); font-weight:600; font-size:clamp(20px,5vw,28px);
  letter-spacing:.04em; text-transform:uppercase; text-decoration:none; color:var(--ink);
  padding:8px 0; border-bottom:1px solid color-mix(in oklab,var(--rule),transparent 60%);
  background-image:linear-gradient(var(--cattail),var(--cattail));
  background-size:0% 2px; background-repeat:no-repeat; background-position:0 100%;
  transition:background-size var(--dur-flow) var(--ease-flow);
}
[data-design="a"] .ws-drawer__ctas {
  display:flex; flex-direction:column; gap:var(--space-stream);
}
[data-design="a"] .ws-drawer__phone {
  font-family:var(--font-data); font-size:16px; letter-spacing:.06em; color:var(--ink);
  text-decoration:none; padding:12px 0; border-bottom:1px solid color-mix(in oklab,var(--rule),transparent 60%);
}

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 2 — Animated CTA (Survey button)
   ═══════════════════════════════════════════════════════════════ */
[data-design="a"] .ws-cta {
  --cta-shift:0px;
  position:relative; display:inline-flex; align-items:center; gap:12px;
  max-width:100%; padding:14px 28px; border:none; cursor:pointer;
  background:var(--cattail); color:var(--bond); text-decoration:none;
  font-family:var(--font-display); font-weight:600; font-size:16px;
  letter-spacing:.08em; text-transform:uppercase; border-radius:var(--radius-zero);
  box-shadow:var(--shadow-press);
  transform:translate(var(--cta-shift),0);
  transition:background var(--dur-flow) var(--ease-flow),
             transform var(--dur-tick) var(--ease-flow);
  animation:ws-cta-breath 5s var(--ease-pulse) infinite;
}
[data-design="a"] .ws-cta__arrow svg { width:30px; height:10px; display:block; }
[data-design="a"] .ws-cta__arrow path { fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
[data-design="a"] .ws-cta__arrow { transition:transform var(--dur-flow) var(--ease-flow); }
[data-design="a"] .ws-cta__course {
  position:absolute; left:0; bottom:0; height:2px; width:100%;
  background:color-mix(in oklab,var(--bond),var(--cattail) 12%);
  transform:scaleX(0); transform-origin:left center;
  transition:transform var(--dur-flow) var(--ease-flow);
}
@keyframes ws-cta-breath {
  0%,100%{ box-shadow:var(--shadow-press); }
  50%{ box-shadow:var(--shadow-press),0 0 0 4px color-mix(in oklab,var(--cattail),transparent 84%); }
}

/* Hover / focus gated behind pointer:fine */
@media (hover:hover) and (pointer:fine) {
  [data-design="a"] .ws-cta:hover,
  [data-design="a"] .ws-cta:focus-visible {
    background:color-mix(in oklab,var(--cattail),black 8%); outline:none;
  }
  [data-design="a"] .ws-cta:hover .ws-cta__course,
  [data-design="a"] .ws-cta:focus-visible .ws-cta__course { transform:scaleX(1); }
  [data-design="a"] .ws-cta:hover .ws-cta__arrow,
  [data-design="a"] .ws-cta:focus-visible .ws-cta__arrow { transform:translateX(5px); }
  [data-design="a"] .ws-drawer__nav a:hover,
  [data-design="a"] .ws-drawer__nav a:focus-visible { background-size:100% 2px; outline:none; }
}
[data-design="a"] .ws-cta:focus-visible { outline:2px solid var(--pool-amber); outline-offset:4px; }
[data-design="a"] .ws-cta:active { transform:translate(var(--cta-shift),2px); box-shadow:var(--shadow-press); }
[data-design="a"] .ws-cta.is-received .ws-cta__course { transform:scaleX(1); }

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 3 (Ambient A) — Hero: seasonal wash + drawn contour motif
   Maintenance-thin fallback: NO stock photos, animation-only substrate
   ═══════════════════════════════════════════════════════════════ */
[data-design="a"] .ws-hero {
  position:relative; overflow:hidden;
  min-height:clamp(460px,72vh,640px);
  display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(24px,5vw,64px);
  align-items:center; max-width:1280px; margin:0 auto;
  padding:clamp(48px,9vw,var(--space-river)) clamp(16px,4vw,40px);
}

/* Unique animated backdrop: seasonal grass/lawn wash + drawn lot survey lines */
[data-design="a"] .ws-hero__backdrop {
  position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden;
}

/* Seasonal color wash — low-chroma green field, perceptible at first paint (opacity≥0.25) */
[data-design="a"] .ws-hero__wash {
  position:absolute; inset:0;
  background:linear-gradient(
    160deg,
    color-mix(in oklab,var(--cattail),transparent 72%) 0%,
    color-mix(in oklab,var(--bond-deep),transparent 0%) 50%,
    color-mix(in oklab,var(--contour-brown),transparent 82%) 100%
  );
  animation:ws-hero-wash 12s var(--ease-pulse) infinite alternate;
}
@keyframes ws-hero-wash {
  0%   { opacity:.35; }
  50%  { opacity:.52; }
  100% { opacity:.38; }
}

/* Contour / lawn-survey SVG — ground lines + mown stripes + drainage path */
[data-design="a"] .ws-hero__contour-map {
  position:absolute; inset:0; width:100%; height:100%; display:block;
}

/* Ground survey lines — drawn in via clip-path on a full-width line */
[data-design="a"] .ws-gl {
  stroke:var(--contour-brown); stroke-width:1; stroke-linecap:round;
  opacity:.28;
  clip-path:inset(0 100% 0 0);
  animation:ws-line-draw var(--dur-draw) var(--ease-draw) forwards;
}
[data-design="a"] .ws-gl--1 { animation-delay:.2s; }
[data-design="a"] .ws-gl--2 { animation-delay:.4s; }
[data-design="a"] .ws-gl--3 { animation-delay:.6s; }
[data-design="a"] .ws-gl--4 { animation-delay:.8s; }
[data-design="a"] .ws-gl--5 { animation-delay:1.0s; }
@keyframes ws-line-draw {
  from { clip-path:inset(0 100% 0 0); }
  to   { clip-path:inset(0 0% 0 0); }
}

/* Mown stripe bands — translate reveal from left (not width grow) */
[data-design="a"] .ws-stripe {
  fill:color-mix(in oklab,var(--cattail),transparent 88%);
  transform:translateX(-100%);
  animation:ws-stripe-in 1.2s var(--ease-flow) forwards;
}
[data-design="a"] .ws-stripe--a { animation-delay:.3s; }
[data-design="a"] .ws-stripe--b { animation-delay:.55s; }
[data-design="a"] .ws-stripe--c { animation-delay:.8s; }
@keyframes ws-stripe-in {
  from { transform:translateX(-100%); }
  to   { transform:translateX(0); }
}

/* Property lot outline — stroke-dashoffset draw (NOT width/height animation) */
[data-design="a"] .ws-hero__lot {
  fill:none; stroke:var(--contour-brown); stroke-width:1.2; opacity:.22;
  stroke-dasharray:1960; stroke-dashoffset:1960;
  animation:ws-lot-draw 2.2s var(--ease-draw) 0.4s forwards;
}
@keyframes ws-lot-draw {
  from { stroke-dashoffset:1960; }
  to   { stroke-dashoffset:0; }
}

/* Survey pin — scale from 0.92 (never scale(0)) */
[data-design="a"] .ws-hero__pin {
  fill:var(--cattail); opacity:.6;
  transform:scale(0.92); transform-box:fill-box; transform-origin:center;
  animation:ws-pin-settle 0.7s var(--ease-flow) 1.6s both, ws-map-pin 6s var(--ease-pulse) 2.4s infinite;
}
@keyframes ws-pin-settle {
  from { transform:scale(0.92); opacity:.2; }
  to   { transform:scale(1); opacity:.6; }
}
@keyframes ws-map-pin { 0%,100%{ transform:scale(1); } 50%{ transform:scale(1.2); } }

/* Drainage path — the "watercourse" for landscaper: lot drainage line */
[data-design="a"] .ws-hero__drain-bed {
  fill:none; stroke:color-mix(in oklab,var(--watercourse),transparent 75%); stroke-width:1.8;
}
[data-design="a"] .ws-hero__drain {
  fill:none; stroke:var(--watercourse); stroke-width:2.4; stroke-linecap:round;
  stroke-dasharray:12 400; stroke-dashoffset:0;
  animation:ws-drain-pulse var(--dur-ambient) var(--ease-pulse) infinite;
  opacity:.55;
}
@keyframes ws-drain-pulse {
  0%,100%{ stroke-dashoffset:0; opacity:.38; }
  50%    { stroke-dashoffset:-412; opacity:.65; }
}

/* Hero text — all z-index:1 above backdrop, all opacity:1 at first paint */
[data-design="a"] .ws-hero__banner {
  position:relative; z-index:1;
}
[data-design="a"] .ws-hero__kicker {
  font-family:var(--font-data); font-size:13px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--cattail); margin:0 0 var(--space-stream);
  opacity:1;
}
[data-design="a"] .ws-hero__title {
  font-family:var(--font-survey); font-weight:700; line-height:1.05;
  font-size:clamp(38px,7vw,68px); letter-spacing:-.01em; margin:0 0 var(--space-stream);
  text-wrap:balance; color:var(--ink); opacity:1;
}
[data-design="a"] .ws-hero__subtitle {
  font-family:var(--font-body); font-size:clamp(16px,2vw,19px); line-height:1.6;
  color:var(--ink-soft); max-width:48ch; margin:0 0 var(--space-stream); opacity:1;
}
[data-design="a"] .ws-hero__proof {
  font-family:var(--font-data); font-size:13px; letter-spacing:.06em;
  color:var(--muted); margin:0 0 var(--space-bank); opacity:1;
}
[data-design="a"] .ws-hero__cta { margin-top:var(--space-em); }

/* Survey map figure — right column, z-index:1 so it sits above wash */
[data-design="a"] .ws-hero__survey-frame {
  position:relative; z-index:1;
}

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 6 — Pointer (surveyed-grown datum line + planted-row ticks)
   MUST be immediately before #funnel (≤1 sibling)
   opacity:1, height≥8px at all breakpoints — NEVER reveal-gated
   ═══════════════════════════════════════════════════════════════ */
[data-design="a"] .ws-pointer {
  display:flex; flex-direction:column; align-items:center; gap:var(--space-em);
  padding:clamp(20px,4vw,40px) clamp(16px,4vw,40px);
  max-width:1280px; margin:0 auto;
  opacity:1; /* HARD RULE: never 0 */
  min-height:56px; /* gate: ≥8px */
}
[data-design="a"] .ws-pointer__svg {
  width:min(600px,90%); height:48px; display:block;
}
[data-design="a"] .ws-pointer__line {
  stroke:var(--contour-brown); stroke-width:1.2; opacity:.45;
  stroke-dasharray:1200; stroke-dashoffset:1200;
  animation:ws-pointer-draw 1.4s var(--ease-draw) 0.5s forwards;
}
@keyframes ws-pointer-draw {
  from { stroke-dashoffset:1200; }
  to   { stroke-dashoffset:0; }
}
[data-design="a"] .ws-pointer__tick {
  stroke:var(--cattail); stroke-width:1.2; stroke-linecap:round; opacity:.5;
  transform:scaleY(0); transform-box:fill-box; transform-origin:bottom;
  animation:ws-tick-sprout 0.5s var(--ease-flow) forwards;
}
[data-design="a"] .ws-pointer__tick--1 { animation-delay:1.0s; }
[data-design="a"] .ws-pointer__tick--2 { animation-delay:1.2s; }
[data-design="a"] .ws-pointer__tick--3 { animation-delay:1.4s; }
[data-design="a"] .ws-pointer__tick--4 { animation-delay:1.6s; }
[data-design="a"] .ws-pointer__tick--5 { animation-delay:1.8s; }
@keyframes ws-tick-sprout {
  from { transform:scaleY(0); opacity:.1; }
  to   { transform:scaleY(1); opacity:.5; }
}
[data-design="a"] .ws-pointer__terminus {
  fill:none; stroke:var(--contour-brown); stroke-width:1.2; stroke-linecap:round; stroke-linejoin:round;
  opacity:.45;
}
[data-design="a"] .ws-pointer__label {
  font-family:var(--font-data); font-size:12px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--muted); opacity:1;
}

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 5 — Routing qualifying funnel
   ═══════════════════════════════════════════════════════════════ */
[data-design="a"] .ws-survey {
  background:var(--bond-deep); border-top:1px solid var(--rule);
  padding:clamp(40px,8vw,var(--space-river)) 0;
}
[data-design="a"] .ws-survey__inner {
  max-width:760px; margin:0 auto; padding:0 clamp(16px,4vw,40px);
}
[data-design="a"] .ws-survey__kicker {
  font-family:var(--font-data); font-size:13px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--cattail); margin:0 0 var(--space-stream);
}
[data-design="a"] .ws-survey__title {
  font-family:var(--font-survey); font-weight:700; font-size:clamp(28px,5vw,40px);
  line-height:1.08; margin:0 0 var(--space-bank); color:var(--ink);
}
[data-design="a"] .ws-survey__course { width:100%; height:8px; display:block; }
[data-design="a"] .ws-survey__bed {
  fill:none; stroke:color-mix(in oklab,var(--cattail),transparent 78%); stroke-width:2;
}
[data-design="a"] .ws-survey__fill {
  fill:none; stroke:var(--cattail); stroke-width:2.6; stroke-linecap:round;
  stroke-dasharray:1; stroke-dashoffset:1;
  transition:stroke-dashoffset var(--dur-flow) var(--ease-flow);
}
[data-design="a"] .ws-survey__count {
  font-family:var(--font-data); font-size:12px; letter-spacing:.08em;
  color:var(--muted); margin:var(--space-em) 0 var(--space-bank);
}

[data-design="a"] .ws-step { border:none; margin:0; padding:0; min-inline-size:0; }
[data-design="a"] .ws-step.is-active { animation:ws-step-in var(--dur-flow) var(--ease-flow) both; }
@keyframes ws-step-in {
  from { opacity:0.92; transform:translateY(8px); }
  to   { opacity:1; transform:none; }
}
[data-design="a"] .ws-step__legend {
  font-family:var(--font-display); font-weight:600; font-size:clamp(20px,3.5vw,24px);
  margin-bottom:var(--space-bank); color:var(--ink); display:block;
}
[data-design="a"] .ws-step__sub {
  font-weight:400; font-size:clamp(14px,2vw,16px); color:var(--muted);
}
[data-design="a"] .ws-step__hint {
  font-family:var(--font-display); font-style:italic; color:var(--critical);
  margin-top:var(--space-stream); font-size:14px;
}

/* Chips — all funnel options rest at opacity:1 (entrances are transform-only) */
[data-design="a"] .ws-chips { display:flex; flex-wrap:wrap; gap:var(--space-stream); }
[data-design="a"] .ws-chips--route { flex-direction:column; gap:var(--space-stream); }
[data-design="a"] .ws-chip {
  position:relative; display:inline-flex; align-items:center; gap:10px;
  padding:12px 16px; border:1px solid var(--rule); background:var(--bond);
  cursor:pointer; font-family:var(--font-body); font-size:16px;
  transition:border-color var(--dur-tick), background var(--dur-tick);
  min-height:44px; /* tap target */
  opacity:1; /* gate: never 0 */
}
[data-design="a"] .ws-chips--route .ws-chip {
  padding:16px 20px; flex-direction:row; align-items:flex-start; min-height:56px;
}
[data-design="a"] .ws-chip--route .ws-chip__body {
  display:flex; flex-direction:column; gap:4px;
}
[data-design="a"] .ws-chip--route .ws-chip__body strong {
  font-family:var(--font-display); font-weight:600; font-size:17px; color:var(--ink);
}
[data-design="a"] .ws-chip--route .ws-chip__body span {
  font-family:var(--font-body); font-size:14px; color:var(--ink-soft);
}
[data-design="a"] .ws-chip input[type="radio"],
[data-design="a"] .ws-chip input[type="checkbox"] { width:16px; height:16px; accent-color:var(--cattail); flex-shrink:0; }
[data-design="a"] .ws-chip:has(input:checked) {
  border-color:var(--cattail); background:color-mix(in oklab,var(--cattail),transparent 90%);
}
[data-design="a"] .ws-chip:has(input:focus-visible) { outline:2px solid var(--pool-amber); outline-offset:2px; }

/* Form fields */
[data-design="a"] .ws-field { display:block; margin-bottom:var(--space-bank); }
[data-design="a"] .ws-field__label {
  display:block; font-family:var(--font-survey); font-size:13px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--muted); margin-bottom:var(--space-em);
}
[data-design="a"] .ws-field__req { text-transform:none; letter-spacing:0; font-weight:400; }
[data-design="a"] .ws-field__wrap {
  display:flex; align-items:center; gap:var(--space-em);
  border:1px solid var(--rule); background:var(--bond); padding:0 14px;
}
[data-design="a"] .ws-field__wrap:focus-within { border-color:var(--cattail); border-width:2px; padding:0 13px; }
[data-design="a"] .ws-field input,
[data-design="a"] .ws-field textarea {
  flex:1; min-width:0; border:none; background:none;
  padding:12px 0; font-family:var(--font-body); font-size:17px; color:var(--ink); outline:none;
}
[data-design="a"] .ws-field__wrap--textarea {
  padding:12px 14px; align-items:flex-start;
}
[data-design="a"] .ws-field textarea { resize:vertical; padding:0; }

/* Funnel navigation */
[data-design="a"] .ws-funnel__nav {
  display:flex; flex-wrap:wrap; gap:var(--space-stream); margin-top:var(--space-bend);
}
[data-design="a"] .ws-trace {
  padding:14px 28px; border:1px solid var(--ink); background:var(--bond);
  color:var(--ink); font-family:var(--font-display); font-weight:600;
  letter-spacing:.08em; text-transform:uppercase; cursor:pointer;
}
[data-design="a"] .ws-trace:focus-visible { outline:2px solid var(--pool-amber); outline-offset:3px; }
[data-design="a"] .ws-next,
[data-design="a"] .ws-submit { border:none; }

/* Done state */
[data-design="a"] .ws-done { text-align:center; padding:var(--space-bend) 0; }
[data-design="a"] .ws-done__mark { width:64px; height:64px; }
[data-design="a"] .ws-done__mark path {
  fill:none; stroke:var(--cattail); stroke-width:5; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:1; stroke-dashoffset:1;
  animation:ws-done-draw var(--dur-survey) var(--ease-draw) forwards;
}
@keyframes ws-done-draw { to { stroke-dashoffset:0; } }
[data-design="a"] .ws-done__title {
  font-family:var(--font-survey); font-weight:700; font-size:24px;
  margin:var(--space-stream) 0 var(--space-em); color:var(--ink);
}
[data-design="a"] .ws-done__body {
  font-family:var(--font-body); font-size:17px; line-height:1.6;
  color:var(--ink-soft); max-width:48ch; margin:0 auto;
}

/* Funnel trust footer */
[data-design="a"] .ws-funnel__trust {
  margin-top:var(--space-bend); padding-top:var(--space-bank);
  border-top:1px solid color-mix(in oklab,var(--rule),transparent 60%);
  font-family:var(--font-data); font-size:13px; letter-spacing:.04em; color:var(--muted);
  display:flex; flex-direction:column; gap:var(--space-em);
}
[data-design="a"] .ws-funnel__phone {
  font-family:var(--font-data); font-size:16px; color:var(--cattail);
  text-decoration:none; letter-spacing:.06em;
}

/* ═══════════════════════════════════════════════════════════════
   HOW IT WORKS — maintenance process
   ═══════════════════════════════════════════════════════════════ */
[data-design="a"] .ws-process {
  padding:clamp(64px,8vw,96px) clamp(16px,4vw,40px);
  border-top:1px solid color-mix(in oklab,var(--rule),transparent 70%);
}
[data-design="a"] .ws-process__inner {
  max-width:1280px; margin:0 auto;
}
[data-design="a"] .ws-section-kicker {
  font-family:var(--font-data); font-size:12px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--cattail); margin:0 0 var(--space-stream);
}
[data-design="a"] .ws-section-title {
  font-family:var(--font-survey); font-weight:700; font-size:clamp(26px,4.5vw,38px);
  line-height:1.1; margin:0 0 clamp(32px,5vw,56px); color:var(--ink);
  max-width:28ch;
}
[data-design="a"] .ws-process__steps {
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:40px;
}
[data-design="a"] .ws-process__step {
  display:flex; flex-direction:column; gap:var(--space-stream);
  padding-top:var(--space-bank); border-top:2px solid var(--cattail);
}
[data-design="a"] .ws-process__num {
  font-family:var(--font-data); font-size:12px; letter-spacing:.14em; color:var(--muted);
}
[data-design="a"] .ws-process__step strong {
  font-family:var(--font-display); font-weight:600; font-size:17px; color:var(--ink);
}
[data-design="a"] .ws-process__step p {
  font-family:var(--font-body); font-size:16px; line-height:1.6; color:var(--ink-soft);
  margin:0;
}

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 4 — Ambient B: Services section with contour-survey rings
   ═══════════════════════════════════════════════════════════════ */
[data-design="a"] .ws-contour {
  position:relative; overflow:hidden; background:var(--bond-deep);
  border-top:1px solid var(--rule); border-bottom:1px solid var(--rule);
  padding:clamp(64px,8vw,96px) clamp(16px,4vw,40px);
}
[data-design="a"] .ws-contour__motion {
  position:absolute; inset:0; z-index:0; pointer-events:none;
}
[data-design="a"] .ws-rings { width:100%; height:100%; display:block; }
[data-design="a"] .ws-rings__ring {
  fill:none; stroke:var(--contour-brown); stroke-width:1.2; opacity:0;
  stroke-dasharray:1; stroke-dashoffset:1;
  animation:ws-contour-draw 18s var(--ease-draw) infinite;
  animation-delay:calc(var(--i) * 0.55s);
}
@keyframes ws-contour-draw {
  0%   { stroke-dashoffset:1; opacity:0; }
  12%  { opacity:.38; }
  52%  { stroke-dashoffset:0; opacity:.38; }
  84%  { stroke-dashoffset:0; opacity:.38; }
  100% { stroke-dashoffset:0; opacity:0; }
}
[data-design="a"] .ws-contour[data-paused] .ws-rings__ring { animation-play-state:paused; }
[data-design="a"] .ws-contour__content {
  position:relative; z-index:1; max-width:1280px; margin:0 auto;
}
[data-design="a"] .ws-contour__kicker {
  font-family:var(--font-data); font-size:13px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--contour-brown); margin:0 0 var(--space-stream);
}
[data-design="a"] .ws-contour__title {
  font-family:var(--font-display); font-weight:600; font-size:clamp(28px,5vw,40px);
  line-height:1.1; margin:0 0 var(--space-bend); max-width:26ch; color:var(--ink);
}
[data-design="a"] .ws-services-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:32px;
  margin-bottom:var(--space-bend);
}
[data-design="a"] .ws-service-card {
  background:var(--bond); padding:var(--space-bank); border:1px solid color-mix(in oklab,var(--rule),transparent 50%);
}
[data-design="a"] .ws-service-card h3 {
  font-family:var(--font-display); font-weight:600; font-size:17px;
  margin:0 0 var(--space-em); color:var(--ink); letter-spacing:.02em;
}
[data-design="a"] .ws-service-card p {
  font-family:var(--font-body); font-size:16px; line-height:1.6;
  color:var(--ink-soft); margin:0;
}
[data-design="a"] .ws-services__cta-wrap { display:flex; }

/* ═══════════════════════════════════════════════════════════════
   SERVICE AREA
   ═══════════════════════════════════════════════════════════════ */
[data-design="a"] .ws-area {
  padding:clamp(64px,8vw,96px) clamp(16px,4vw,40px);
  border-top:1px solid color-mix(in oklab,var(--rule),transparent 70%);
}
[data-design="a"] .ws-area__inner { max-width:1280px; margin:0 auto; }
[data-design="a"] .ws-area__desc {
  font-family:var(--font-body); font-size:17px; line-height:1.65;
  color:var(--ink-soft); max-width:60ch; margin:0 0 var(--space-bank);
}
[data-design="a"] .ws-area__list {
  list-style:none; padding:0; margin:0 0 var(--space-bank);
  display:flex; flex-wrap:wrap; gap:var(--space-em) var(--space-bank);
}
[data-design="a"] .ws-area__list li {
  font-family:var(--font-data); font-size:14px; letter-spacing:.06em;
  color:var(--ink); padding:6px 14px; border:1px solid var(--rule); background:var(--bond-deep);
}
[data-design="a"] .ws-area__rate {
  font-family:var(--font-body); font-size:17px; color:var(--ink-soft);
}
[data-design="a"] .ws-area__rate strong { color:var(--ink); }

/* ═══════════════════════════════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════════════════════════════ */
[data-design="a"] .ws-contact {
  padding:clamp(64px,8vw,96px) clamp(16px,4vw,40px);
  background:var(--bond-deep); border-top:1px solid var(--rule);
}
[data-design="a"] .ws-contact__inner { max-width:1280px; margin:0 auto; }
[data-design="a"] .ws-contact__grid {
  display:grid; grid-template-columns:1fr auto; gap:clamp(24px,4vw,64px);
  align-items:start; margin-top:var(--space-bend);
}
[data-design="a"] .ws-contact__item {
  font-family:var(--font-data); font-size:16px; letter-spacing:.06em; color:var(--ink);
  margin:0 0 var(--space-stream);
}
[data-design="a"] .ws-contact__item a { color:var(--ink); text-decoration:none; border-bottom:1px solid var(--contour-brown); }
[data-design="a"] .ws-contact__hours {
  font-family:var(--font-body); font-size:16px; line-height:1.7; color:var(--ink-soft);
  margin:0;
}

/* ═══════════════════════════════════════════════════════════════
   FOOTER — Imprint sheet
   ═══════════════════════════════════════════════════════════════ */
[data-design="a"] .ws-footer {
  background:var(--ink); color:var(--bond);
  padding:clamp(40px,6vw,80px) clamp(16px,4vw,40px);
  border-top:3px solid var(--cattail);
}
[data-design="a"] .ws-footer__inner {
  max-width:1280px; margin:0 auto;
  display:flex; flex-direction:column; gap:var(--space-bank);
}
[data-design="a"] .ws-footer__brand {
  display:flex; flex-direction:column; gap:var(--space-em);
}
[data-design="a"] .ws-footer .ws-logo__mark {
  color:var(--bond); font-size:18px;
}
[data-design="a"] .ws-footer__sub {
  font-family:var(--font-data); font-size:12px; letter-spacing:.12em;
  color:color-mix(in oklab,var(--bond),transparent 40%); text-transform:uppercase;
}
[data-design="a"] .ws-footer__info {
  display:flex; flex-direction:column; gap:var(--space-em);
  font-family:var(--font-data); font-size:13px; letter-spacing:.04em;
  color:color-mix(in oklab,var(--bond),transparent 35%);
}
[data-design="a"] .ws-footer__info a { color:var(--bond); text-decoration:none; }
[data-design="a"] .ws-footer__info p { margin:0; }
[data-design="a"] .ws-footer__copy {
  font-family:var(--font-data); font-size:11px; letter-spacing:.06em;
  color:color-mix(in oklab,var(--bond),transparent 55%); margin:0;
}

/* ═══════════════════════════════════════════════════════════════
   SCROLL-LINKED PREMIUM MOTION (TRIAD-2)
   Parallax on hero: scroll-linked translateY on the backdrop
   Implemented via CSS scroll-timeline where supported;
   JS fallback in script.js
   ═══════════════════════════════════════════════════════════════ */
@supports (animation-timeline: scroll()) {
  [data-design="a"] .ws-hero__backdrop {
    animation: ws-hero-parallax linear both;
    animation-timeline: scroll(root);
    animation-range: 0% 40%;
  }
  @keyframes ws-hero-parallax {
    from { transform: translateY(0); }
    to   { transform: translateY(28%); }
  }
}

/* ═══════════════════════════════════════════════════════════════
   REDUCED MOTION
   ═══════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .ws-header__flow { animation:none; stroke-dasharray:none; }
  [data-design="a"] .ws-logo__pin { animation:none; }
  [data-design="a"] .ws-drawer,
  [data-design="a"] .ws-drawer__panel { transition:none; }
  [data-design="a"] .ws-cta { animation:none; transform:none; }
  [data-design="a"] .ws-cta__course,
  [data-design="a"] .ws-cta__arrow { transition:none; }
  [data-design="a"] .ws-hero__wash { animation:none; }
  [data-design="a"] .ws-gl { animation:none; clip-path:none; }
  [data-design="a"] .ws-stripe { animation:none; transform:none; }
  [data-design="a"] .ws-hero__lot { animation:none; stroke-dashoffset:0; }
  [data-design="a"] .ws-hero__pin { animation:none; transform:none; }
  [data-design="a"] .ws-hero__drain { animation:none; stroke-dasharray:none; opacity:.55; }
  [data-design="a"] .ws-pointer__line { animation:none; stroke-dashoffset:0; }
  [data-design="a"] .ws-pointer__tick { animation:none; transform:scaleY(1); }
  [data-design="a"] .ws-rings__ring { animation:none; stroke-dashoffset:0; opacity:.38; }
  [data-design="a"] .ws-step.is-active { animation:none; }
  [data-design="a"] .ws-survey__fill { transition:none; }
  [data-design="a"] .ws-done__mark path { animation:none; stroke-dashoffset:0; }
  [data-design="a"] .ws-hero__backdrop { animation:none; }
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:768px) {
  [data-design="a"] .ws-hero {
    grid-template-columns:1fr;
    min-height:auto;
    padding-top:clamp(40px,7vw,72px);
  }
  [data-design="a"] .ws-contact__grid { grid-template-columns:1fr; }
}
@media (max-width:390px) {
  [data-design="a"] .ws-cta { width:100%; justify-content:center; font-size:15px; }
  [data-design="a"] .ws-funnel__nav { flex-direction:column-reverse; }
  [data-design="a"] .ws-funnel__nav .ws-cta,
  [data-design="a"] .ws-funnel__nav .ws-trace { width:100%; justify-content:center; text-align:center; }
  [data-design="a"] .ws-hero__title { font-size:34px; }
}
@media (max-width:320px) {
  [data-design="a"] .ws-hero { padding-left:14px; padding-right:14px; }
  [data-design="a"] .ws-survey__inner { padding-left:14px; padding-right:14px; }
  [data-design="a"] .ws-logo__mark { font-size:13px; letter-spacing:.08em; }
  [data-design="a"] .ws-process,
  [data-design="a"] .ws-contour,
  [data-design="a"] .ws-area,
  [data-design="a"] .ws-contact { padding-left:14px; padding-right:14px; }
}

/* 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; }
