/* ================================================================
   Watershed design — landscaping-pittsburgh design-a
   All selectors scoped: [data-design="a"].dq-design
   Keyframes prefixed: ws-
   ================================================================ */

/* ── Token binding ───────────────────────────────────────────── */
[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);

  color:var(--ink); background:var(--bond);
  font-family:var(--font-body);
  font-size:17px; line-height:1.65;
}
@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 clip / overflow guard ───────────────────────────── */
[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 — 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(--watercourse);
  box-shadow:0 0 0 3px color-mix(in oklab,var(--watercourse),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(13px,2vw,18px); letter-spacing:.1em;
  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;
  pointer-events:none;
}
[data-design="a"] .ws-header__bed{
  fill:none; stroke:color-mix(in oklab,var(--watercourse),transparent 80%); stroke-width:1.5;
}
[data-design="a"] .ws-header__flow{
  fill:none; stroke:var(--watercourse); 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; }
}

/* Burger */
[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; }

/* Drawer */
[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:24px 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); overflow-y:auto;
}
[data-design="a"] .ws-drawer.is-open .ws-drawer__panel{ transform:none; }
[data-design="a"] .ws-drawer__close{
  align-self:flex-end; width:44px; height:44px; display:inline-flex;
  align-items:center; justify-content:center; font-size:18px;
  border:1px solid var(--rule); background:var(--bond); cursor:pointer; color:var(--ink);
}
[data-design="a"] .ws-drawer__close:focus-visible{ outline:2px solid var(--pool-amber); outline-offset:2px; }
[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(18px,4vw,24px);
  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(--watercourse),var(--watercourse));
  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{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-display); font-weight:600; font-size:18px;
  letter-spacing:.06em; text-decoration:none; color:var(--ink); padding:14px 0;
}
[data-design="a"] .ws-drawer__phone-icon{ font-size:20px; }

/* drawer nav hover — fine pointer only */
@media (hover:hover) and (pointer:fine){
  [data-design="a"] .ws-drawer__nav a:hover,
  [data-design="a"] .ws-drawer__nav a:focus-visible{ background-size:100% 2px; outline:none; }
}

/* ================================================================
   ELEMENT 3 — Hero (lot survey backdrop + text banner)
   isolation:isolate ensures text is topmost at its center
   ================================================================ */
[data-design="a"] .ws-hero{
  isolation:isolate;
  display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(24px,5vw,64px);
  align-items:center; max-width:1280px; margin:0 auto;
  padding:clamp(40px,8vw,var(--space-river)) clamp(16px,4vw,40px);
  min-height:70vh; position:relative;
}
/* Survey figure — backdrop layer (behind text via grid order) */
[data-design="a"] .ws-hero__survey{
  position:relative; z-index:1; margin:0;
  /* Scroll-driven parallax via transform (GPU-composited — TRIAD-2) */
  will-change:transform;
}
/* Hero text — explicitly above every backdrop layer */
[data-design="a"] .ws-hero__banner{
  position:relative; z-index:10;
}

[data-design="a"] .ws-hero__kicker{
  font-family:var(--font-data); font-size:13px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--watercourse); 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.04;
  font-size:clamp(32px,6vw,62px); letter-spacing:-.01em;
  margin:0 0 var(--space-stream); text-wrap:balance; opacity:1; color:var(--ink);
}
[data-design="a"] .ws-hero__deck{
  font-family:var(--font-body); font-size:clamp(17px,2vw,20px); line-height:1.6;
  color:var(--ink-soft); max-width:46ch; 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;
}

/* Lot survey SVG */
[data-design="a"] .ws-lot-map{
  width:100%; height:auto; max-width:100%; display:block;
  background:var(--bond-deep); box-shadow:var(--shadow-map);
}
[data-design="a"] .ws-lot-map__cap{
  font-family:var(--font-data); font-size:11px; letter-spacing:.06em;
  color:var(--muted); margin-top:var(--space-em); display:block;
}
/* Contour rings */
[data-design="a"] .ws-lot__contour{
  fill:none; stroke:var(--contour-brown); stroke-width:1; opacity:.45;
  stroke-dasharray:1; stroke-dashoffset:1;
  animation:ws-lot-contour-draw 20s var(--ease-draw) infinite;
  animation-delay:calc(var(--ci) * 0.8s);
}
@keyframes ws-lot-contour-draw{
  0%  { stroke-dashoffset:1; opacity:0; }
  15% { opacity:.45; }
  60% { stroke-dashoffset:0; opacity:.45; }
  88% { stroke-dashoffset:0; opacity:.45; }
  100%{ stroke-dashoffset:0; opacity:0; }
}
/* Lot boundary */
[data-design="a"] .ws-lot__boundary{
  fill:none; stroke:var(--ink); stroke-width:1.2; opacity:.5;
}
/* Planting beds */
[data-design="a"] .ws-lot__bed{
  fill:color-mix(in oklab,var(--cattail),transparent 75%);
  stroke:var(--cattail); stroke-width:1.2;
}
/* Retaining walls */
[data-design="a"] .ws-lot__wall{
  stroke:var(--contour-brown); stroke-width:2.4; stroke-linecap:square;
}
/* Paver path (the "watercourse" — footpath) */
[data-design="a"] .ws-lot__path-bed{
  fill:none; stroke:color-mix(in oklab,var(--contour-brown),transparent 70%); stroke-width:2;
}
[data-design="a"] .ws-lot__path{
  fill:none; stroke:var(--contour-brown); stroke-width:2.6; stroke-linecap:round;
  stroke-dasharray:14 300; stroke-dashoffset:0;
  animation:ws-lot-path-pulse var(--dur-ambient) var(--ease-pulse) infinite;
}
@keyframes ws-lot-path-pulse{
  0%,100%{ stroke-dashoffset:0; opacity:.6; }
  50%{ stroke-dashoffset:-314; opacity:1; }
}
/* Tree circles */
[data-design="a"] .ws-lot__tree{
  fill:color-mix(in oklab,var(--cattail),transparent 60%);
  stroke:var(--cattail); stroke-width:1.2;
  animation:ws-lot-tree-breath 12s var(--ease-pulse) infinite;
  transform-box:fill-box; transform-origin:center;
}
@keyframes ws-lot-tree-breath{
  0%,100%{ transform:scale(1); }
  50%{ transform:scale(1.08); }
}
/* Survey pin */
[data-design="a"] .ws-lot__pin{
  fill:var(--contour-brown);
  animation:ws-map-pin 6s var(--ease-pulse) infinite;
  transform-box:fill-box; transform-origin:center;
}
@keyframes ws-map-pin{
  0%,100%{ transform:scale(1); }
  50%{ transform:scale(1.3); }
}
/* SVG text labels */
[data-design="a"] .ws-lot__label{
  font-family:var(--font-map); font-size:13px; fill:var(--ink-soft);
}
[data-design="a"] .ws-lot__elev{
  font-family:var(--font-data); font-size:9px; fill:var(--muted);
  letter-spacing:.08em; text-transform:uppercase;
}
/* Pause animations when hero scrolls out of view */
[data-design="a"] .ws-hero[data-paused] .ws-lot__contour,
[data-design="a"] .ws-hero[data-paused] .ws-lot__path,
[data-design="a"] .ws-hero[data-paused] .ws-lot__tree,
[data-design="a"] .ws-hero[data-paused] .ws-lot__pin{
  animation-play-state:paused;
}

/* ================================================================
   ELEMENT 2 — CTA (Survey button)
   All resting opacity:1; entrance via transform only
   ================================================================ */
[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(--watercourse); 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;
  opacity:1;
}
[data-design="a"] .ws-cta__label{ opacity:1; }
[data-design="a"] .ws-cta__arrow{ transition:transform var(--dur-flow) var(--ease-flow); opacity:1; }
[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__course{
  position:absolute; left:0; bottom:0; height:2px; width:100%;
  background:color-mix(in oklab,var(--bond),var(--watercourse) 12%);
  transform:scaleX(0); transform-origin:left center;
  transition:transform var(--dur-flow) var(--ease-flow);
  opacity:1;
}
[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); }
@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(--watercourse),transparent 84%); }
}
/* hover — fine pointer only */
@media (hover:hover) and (pointer:fine){
  [data-design="a"] .ws-cta:hover{
    background:color-mix(in oklab,var(--watercourse),black 4%); 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); }
}

/* ================================================================
   ELEMENT 6 — Pointer (contour-line draw-in toward funnel)
   Static bbox ≥24px; opacity:1; NOT a button
   ================================================================ */
[data-design="a"] .ws-pointer{
  display:flex; flex-direction:column; align-items:center; gap:var(--space-stream);
  padding:clamp(24px,4vw,48px) clamp(16px,4vw,40px);
  text-align:center; opacity:1; min-height:80px;
}
[data-design="a"] .ws-pointer__line{
  width:clamp(200px,50vw,320px); height:48px; display:block; overflow:visible;
}
[data-design="a"] .ws-pointer__contour{
  fill:none; stroke:var(--contour-brown); stroke-width:1.4; stroke-linecap:round;
  stroke-dasharray:1; stroke-dashoffset:1;
}
[data-design="a"] .ws-pointer__c1{
  animation:ws-pointer-draw1 3.2s var(--ease-draw) infinite;
}
[data-design="a"] .ws-pointer__c2{
  animation:ws-pointer-draw1 3.2s var(--ease-draw) infinite;
  animation-delay:.4s;
}
@keyframes ws-pointer-draw1{
  0%  { stroke-dashoffset:1; opacity:0; }
  20% { opacity:.7; }
  60% { stroke-dashoffset:0; opacity:.7; }
  85% { stroke-dashoffset:0; opacity:.7; }
  100%{ stroke-dashoffset:0; opacity:0; }
}
[data-design="a"] .ws-pointer__dot{
  fill:var(--contour-brown); opacity:1;
  animation:ws-pointer-dot 3.2s var(--ease-pulse) infinite;
  transform-box:fill-box; transform-origin:center;
}
@keyframes ws-pointer-dot{
  0%,100%{ transform:scale(1); opacity:.8; }
  50%{ transform:scale(1.5); opacity:1; }
}
[data-design="a"] .ws-pointer__label{
  font-family:var(--font-data); font-size:12px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--muted); margin:0;
  display:flex; align-items:center; gap:8px; opacity:1;
}
[data-design="a"] .ws-pointer__datum{ font-size:10px; opacity:.7; }

/* ================================================================
   ELEMENT 5 — Routing qualifying funnel
   ================================================================ */
[data-design="a"] .ws-survey{
  max-width:760px; margin:0 auto;
  padding:clamp(48px,8vw,var(--space-river)) 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(--watercourse); 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);
}
[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(--watercourse),transparent 78%); stroke-width:2;
}
[data-design="a"] .ws-survey__fill{
  fill:none; stroke:var(--watercourse); 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);
}

/* Steps */
[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:1; transform:translateY(10px); }
  to{ opacity:1; transform:none; }
}
[data-design="a"] .ws-step__legend{
  font-family:var(--font-display); font-weight:600; font-size:clamp(18px,3vw,24px);
  margin-bottom:var(--space-bank); color:var(--ink); padding:0; display:block;
}
[data-design="a"] .ws-step__hint{
  font-family:var(--font-display); font-style:italic;
  color:var(--critical); margin-top:var(--space-stream); font-size:15px;
}

/* Chips — radio + checkbox */
[data-design="a"] .ws-chips{ display:flex; flex-wrap:wrap; gap:var(--space-stream); }
[data-design="a"] .ws-chip{
  position:relative; display:inline-flex; align-items:flex-start; gap:10px;
  padding:14px 16px; border:1px solid var(--rule); background:var(--bond);
  cursor:pointer; font-family:var(--font-body); font-size:16px; line-height:1.4;
  min-height:56px;
  transition:border-color var(--dur-tick), background var(--dur-tick);
}
[data-design="a"] .ws-chip input{ width:18px; height:18px; margin-top:2px; flex:0 0 auto; accent-color:var(--watercourse); }
[data-design="a"] .ws-chip__icon{ font-size:18px; flex:0 0 auto; margin-top:1px; }
[data-design="a"] .ws-chip__text{ font-weight:600; }
[data-design="a"] .ws-chip__sub{
  font-size:13px; color:var(--muted); display:block; margin-top:2px;
}
[data-design="a"] .ws-chip--radio{ flex-direction:column; min-width:180px; }
[data-design="a"] .ws-chip--radio input{ position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; }
[data-design="a"] .ws-chip:has(input:checked){
  border-color:var(--watercourse);
  background:color-mix(in oklab,var(--watercourse),transparent 90%);
}
[data-design="a"] .ws-chip:has(input:focus-visible){ outline:2px solid var(--pool-amber); outline-offset:2px; }

/* 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__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(--watercourse); 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;
  resize:vertical;
}
[data-design="a"] .ws-field__wrap--textarea{ align-items:flex-start; padding:12px 14px; }
[data-design="a"] .ws-field__wrap--textarea textarea{ padding:0; line-height:1.6; }

/* 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; margin:0 auto var(--space-stream); display:block; }
[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);
}
[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 var(--space-stream);
}
[data-design="a"] .ws-done__contact{
  font-family:var(--font-data); font-size:14px; color:var(--muted);
}
[data-design="a"] .ws-done__phone{
  color:var(--watercourse); text-decoration:underline;
}

/* Funnel nav */
[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; }

/* Below-funnel trust copy */
[data-design="a"] .ws-survey__below{
  margin-top:var(--space-bend); padding-top:var(--space-bank);
  border-top:1px solid var(--rule);
}
[data-design="a"] .ws-survey__trust{
  font-family:var(--font-data); font-size:13px; letter-spacing:.04em;
  color:var(--muted); margin:0 0 var(--space-em);
}
[data-design="a"] .ws-survey__phone-line{
  font-family:var(--font-body); font-size:16px; color:var(--ink-soft); margin:0;
}
[data-design="a"] .ws-inline-phone{ color:var(--watercourse); font-weight:600; }

/* ================================================================
   OUR WORK section
   ================================================================ */
[data-design="a"] .ws-work{
  padding:clamp(64px,8vw,var(--space-river)) clamp(16px,4vw,40px);
  border-top:1px solid var(--rule);
}
[data-design="a"] .ws-work__inner{
  max-width:1280px; margin:0 auto;
}
[data-design="a"] .ws-work__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-work__title{
  font-family:var(--font-display); font-weight:600; font-size:clamp(28px,5vw,40px);
  line-height:1.1; margin:0 0 var(--space-stream);
}
[data-design="a"] .ws-work__intro{
  font-size:clamp(17px,2vw,20px); line-height:1.6; color:var(--ink-soft);
  max-width:60ch; margin:0 0 var(--space-bend);
}
[data-design="a"] .ws-work__grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:clamp(24px,3vw,32px);
}
[data-design="a"] .ws-plate{
  background:var(--bond-deep); padding:clamp(24px,3vw,32px);
  border:1px solid var(--rule); border-top:2px solid var(--contour-brown);
  /* Scroll-reveal via transform — TRIAD-2 premium scroll motion */
  transform:translateY(32px); opacity:0;
  transition:transform var(--dur-fill) var(--ease-flow),
             opacity var(--dur-fill) var(--ease-flow);
}
[data-design="a"] .ws-plate.is-visible{
  transform:translateY(0); opacity:1;
}
[data-design="a"] .ws-plate__icon{
  width:48px; height:48px; margin-bottom:var(--space-bank);
  color:var(--contour-brown);
}
[data-design="a"] .ws-plate__icon svg{
  width:48px; height:48px; fill:none; stroke:currentColor; stroke-width:2;
  stroke-linecap:round; stroke-linejoin:round;
}
[data-design="a"] .ws-plate__title{
  font-family:var(--font-display); font-weight:600; font-size:18px;
  letter-spacing:.04em; text-transform:uppercase; margin:0 0 var(--space-stream);
}
[data-design="a"] .ws-plate__body{
  font-size:16px; line-height:1.65; color:var(--ink-soft); margin:0;
}
[data-design="a"] .ws-work__cta-block{
  margin-top:clamp(32px,4vw,48px); display:flex; justify-content:flex-start;
}

/* ================================================================
   ELEMENT 4 — Contour survey ambient (mid-page)
   ================================================================ */
[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,var(--space-river)) 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-ring 18s var(--ease-draw) infinite;
  animation-delay:calc(var(--i) * 0.55s);
}
@keyframes ws-contour-ring{
  0%  { stroke-dashoffset:1; opacity:0; }
  12% { opacity:.42; }
  52% { stroke-dashoffset:0; opacity:.42; }
  84% { stroke-dashoffset:0; opacity:.42; }
  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-bank); max-width:22ch;
}
[data-design="a"] .ws-contour__body{
  font-family:var(--font-body); font-size:17px; line-height:1.65;
  color:var(--ink-soft); max-width:60ch;
}
[data-design="a"] .ws-services__list{
  columns:2; column-gap:var(--space-bend); padding:0; margin:var(--space-bank) 0 0;
  list-style:none;
}
[data-design="a"] .ws-services__list li{
  padding:6px 0 6px 20px; position:relative; break-inside:avoid; font-size:16px;
}
[data-design="a"] .ws-services__list li::before{
  content:""; position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:8px; height:8px; border-radius:var(--radius-pin);
  background:var(--watercourse);
}

/* ================================================================
   PROCESS section
   ================================================================ */
[data-design="a"] .ws-process{
  padding:clamp(64px,8vw,var(--space-river)) clamp(16px,4vw,40px);
  border-bottom:1px solid var(--rule);
}
[data-design="a"] .ws-process__inner{ max-width:1280px; margin:0 auto; }
[data-design="a"] .ws-process__kicker{
  font-family:var(--font-data); font-size:13px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--watercourse); margin:0 0 var(--space-stream);
}
[data-design="a"] .ws-process__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);
}
[data-design="a"] .ws-process__steps{
  list-style:none; padding:0; margin:0; display:flex; flex-direction:column;
  gap:clamp(24px,3vw,32px);
}
[data-design="a"] .ws-process__step{
  display:flex; align-items:flex-start; gap:var(--space-bank);
  padding-bottom:clamp(24px,3vw,32px);
  border-bottom:1px solid color-mix(in oklab,var(--rule),transparent 60%);
  /* Scroll-reveal — TRIAD-2 */
  transform:translateX(-24px); opacity:0;
  transition:transform var(--dur-fill) var(--ease-flow),
             opacity var(--dur-fill) var(--ease-flow);
}
[data-design="a"] .ws-process__step:last-child{ border-bottom:none; }
[data-design="a"] .ws-process__step.is-visible{
  transform:translateX(0); opacity:1;
}
[data-design="a"] .ws-process__num{
  font-family:var(--font-data); font-size:32px; letter-spacing:-.02em;
  color:var(--contour-brown); opacity:.7; flex:0 0 auto; width:56px;
  line-height:1;
}
[data-design="a"] .ws-process__content h3{
  font-family:var(--font-display); font-weight:600; font-size:clamp(18px,2.5vw,22px);
  letter-spacing:.04em; text-transform:uppercase; margin:0 0 var(--space-stream);
}
[data-design="a"] .ws-process__content p{
  font-size:17px; line-height:1.65; color:var(--ink-soft); margin:0;
}

/* ================================================================
   SERVICE AREA section
   ================================================================ */
[data-design="a"] .ws-area{
  background:var(--bond-deep); padding:clamp(64px,8vw,var(--space-river)) clamp(16px,4vw,40px);
  border-top:1px solid var(--rule);
}
[data-design="a"] .ws-area__inner{ max-width:1280px; margin:0 auto; }
[data-design="a"] .ws-area__kicker{
  font-family:var(--font-data); font-size:13px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--watercourse); margin:0 0 var(--space-stream);
}
[data-design="a"] .ws-area__title{
  font-family:var(--font-display); font-weight:600; font-size:clamp(28px,5vw,40px);
  line-height:1.1; margin:0 0 var(--space-bank);
}
[data-design="a"] .ws-area__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__tags{
  display:flex; flex-wrap:wrap; gap:var(--space-stream);
}
[data-design="a"] .ws-area__tag{
  font-family:var(--font-data); font-size:13px; letter-spacing:.08em;
  text-transform:uppercase; padding:8px 14px;
  border:1px solid var(--contour-brown); color:var(--contour-brown);
}

/* ================================================================
   FOOTER
   ================================================================ */
[data-design="a"] .ws-footer{
  background:var(--bond-deep); border-top:2px solid var(--rule);
  padding:clamp(48px,8vw,var(--space-river)) clamp(16px,4vw,40px);
}
[data-design="a"] .ws-footer__inner{
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:1fr auto; gap:var(--space-bend);
  align-items:start;
}
[data-design="a"] .ws-footer__brand{ grid-column:1/-1; }
[data-design="a"] .ws-footer__logo{
  font-family:var(--font-survey); font-weight:700; font-size:clamp(16px,2vw,20px);
  letter-spacing:.1em; text-transform:uppercase; display:block;
  margin-bottom:var(--space-stream);
}
[data-design="a"] .ws-footer__tagline{
  font-family:var(--font-data); font-size:13px; letter-spacing:.06em;
  color:var(--muted); margin:0;
}
[data-design="a"] .ws-footer__contact{
  grid-column:1/-1; display:flex; flex-wrap:wrap; align-items:center;
  gap:var(--space-bank);
}
[data-design="a"] .ws-footer__phone{
  font-family:var(--font-survey); font-weight:700; font-size:clamp(20px,3vw,28px);
  letter-spacing:.06em; text-decoration:none; color:var(--ink);
  border-bottom:2px solid var(--watercourse); padding-bottom:2px;
}
[data-design="a"] .ws-footer__copy{
  grid-column:1/-1; font-family:var(--font-data); font-size:12px;
  color:var(--muted); margin:var(--space-bank) 0 0;
}

/* ================================================================
   SCROLL-REVEAL — TRIAD-2 premium scroll motion
   (IntersectionObserver adds .is-visible, which transitions
   transform + opacity — GPU-only, motion-gate clean)
   ================================================================ */
/* stagger reveal items */
[data-design="a"] [data-reveal-item]:nth-child(2){ transition-delay:80ms; }
[data-design="a"] [data-reveal-item]:nth-child(3){ transition-delay:160ms; }
[data-design="a"] [data-reveal-item]:nth-child(4){ transition-delay:240ms; }
[data-design="a"] [data-reveal-item]:nth-child(5){ transition-delay:320ms; }
[data-design="a"] [data-reveal-item]:nth-child(6){ transition-delay:400ms; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:768px){
  [data-design="a"] .ws-hero{
    grid-template-columns:1fr; min-height:auto;
  }
  [data-design="a"] .ws-hero__survey{ order:-1; }
  [data-design="a"] .ws-hero__banner{ z-index:10; }
  [data-design="a"] .ws-footer__inner{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  [data-design="a"] .ws-services__list{ columns:1; }
  [data-design="a"] .ws-process__step{ flex-direction:column; gap:var(--space-stream); }
  [data-design="a"] .ws-process__num{ width:auto; }
}
@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:clamp(26px,8vw,36px); }
}
@media (max-width:320px){
  [data-design="a"] .ws-hero{ padding-left:14px; padding-right:14px; }
  [data-design="a"] .ws-survey{ padding-left:14px; padding-right:14px; }
  [data-design="a"] .ws-work{ padding-left:14px; padding-right:14px; }
  [data-design="a"] .ws-contour{ padding-left:14px; padding-right:14px; }
  [data-design="a"] .ws-logo__mark{ font-size:11px; }
  [data-design="a"] .ws-chip--radio{ min-width:100%; }
}

/* ================================================================
   REDUCED MOTION fallbacks
   ================================================================ */
@media (prefers-reduced-motion:reduce){
  [data-design="a"] .ws-header__flow,
  [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-lot__contour{ animation:none; stroke-dashoffset:0; opacity:.45; }
  [data-design="a"] .ws-lot__path{ animation:none; stroke-dasharray:none; opacity:1; }
  [data-design="a"] .ws-lot__tree,
  [data-design="a"] .ws-lot__pin{ animation:none; }

  [data-design="a"] .ws-cta{ animation:none; }
  [data-design="a"] .ws-cta__course{ transition:none; transform:scaleX(1); }
  [data-design="a"] .ws-cta__arrow{ transition:none; }

  [data-design="a"] .ws-pointer__contour,
  [data-design="a"] .ws-pointer__dot{ animation:none; stroke-dashoffset:0; opacity:.7; }

  [data-design="a"] .ws-rings__ring{ animation:none; stroke-dashoffset:0; opacity:.42; }

  [data-design="a"] .ws-survey__fill{ transition:none; }
  [data-design="a"] .ws-step.is-active{ animation:none; }
  [data-design="a"] .ws-done__mark path{ animation:none; stroke-dashoffset:0; }

  [data-design="a"] .ws-plate,
  [data-design="a"] .ws-process__step{
    transform:none; opacity:1; 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; }
