/* ============================================================
   Dan's Gutter Service Cincinnati — Design A (Exposure, remapped)
   Slot-scoped [data-design="a"]. Trade: gutter (estimator-primary).
   ============================================================ */

[data-design="a"] {
  --design-a-primary: #A8552B;
  --xp-bone: #F5F0E6;
  --xp-paper: #ECE4D4;
  --xp-spruce: #26221B;
  --xp-driftwood: #8B8171;
  --xp-cedar: #A8552B;
  --xp-cedar-deep: #7C3A1D;
  --xp-flash: #3E6E63;
  --xp-felt: #3A342B;
  --xp-critical: #A33224;
  --xp-success: #4E7A54;

  --xp-nail: 4px; --xp-lap: 8px; --xp-reveal: 16px; --xp-exposure: 24px;
  --xp-course: 40px; --xp-plane: 64px; --xp-eave: 96px; --xp-ridge: 128px;

  --xp-settle: cubic-bezier(0.2, 0.7, 0.2, 1);
  --xp-lift: cubic-bezier(0.32, 1.2, 0.38, 1);

  background: var(--xp-bone);
  color: var(--xp-spruce);
  font-family: "Public Sans", "Helvetica Neue", Arial, sans-serif;
}

/* ---------- Header (Element 1) ---------- */
[data-design="a"] .xp-header {
  position: sticky; top: 0; z-index: 60;
  background: var(--xp-bone);
}
[data-design="a"] .xp-header__bar {
  max-width: 1320px; margin-inline: auto;
  padding: 16px clamp(20px, 5vw, 48px);
  display: flex; align-items: center; justify-content: space-between;
}
[data-design="a"] .xp-logo { text-decoration: none; }
[data-design="a"] .xp-logo__mark {
  font-family: "Fraunces", "Iowan Old Style", Georgia, serif;
  font-weight: 640; font-size: clamp(1.05rem, 2.6vw, 1.35rem);
  line-height: 1.15; color: var(--xp-spruce); letter-spacing: 0.01em;
}
[data-design="a"] .xp-burger {
  display: inline-flex; flex-direction: column; gap: 5px;
  width: 44px; height: 44px; align-items: center; justify-content: center;
  background: none; border: 0; cursor: pointer; border-radius: 2px;
}
[data-design="a"] .xp-burger__lap {
  display: block; width: 22px; height: 2px; background: var(--xp-spruce);
  transition: transform 240ms var(--xp-settle), opacity 240ms var(--xp-settle);
}
[data-design="a"] .xp-burger[aria-expanded="true"] .xp-burger__lap:nth-child(1) { transform: translateY(7px) rotate(45deg); }
[data-design="a"] .xp-burger[aria-expanded="true"] .xp-burger__lap:nth-child(2) { opacity: 0; }
[data-design="a"] .xp-burger[aria-expanded="true"] .xp-burger__lap:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
[data-design="a"] .xp-burger:focus-visible { outline: 2px solid var(--xp-flash); outline-offset: 2px; }
[data-design="a"] .xp-header__eave {
  position: relative; height: 1px; background: var(--xp-driftwood);
  overflow: hidden;
}
[data-design="a"] .xp-header__eave-light {
  position: absolute; inset: 0 auto 0 0; width: 34%;
  background: linear-gradient(90deg, transparent, var(--xp-cedar), transparent);
  animation: xp-eave-drift-a 26s linear infinite;
}
@keyframes xp-eave-drift-a {
  from { transform: translateX(-110%); }
  to   { transform: translateX(320%); }
}
[data-design="a"] .xp-drawer {
  position: fixed; inset: 0; z-index: 55; background: var(--xp-felt);
  display: grid; place-items: center;
  opacity: 0; transform: translateY(-3%);
  transition: opacity 260ms var(--xp-settle), transform 260ms var(--xp-settle);
}
[data-design="a"] .xp-drawer[hidden] { display: none; }
[data-design="a"] .xp-drawer.is-open { display: grid; opacity: 1; transform: translateY(0); }
[data-design="a"] .xp-drawer__inner { display: grid; gap: 8px; padding: 24px; width: min(92vw, 420px); }
[data-design="a"] .xp-drawer__link {
  position: relative; color: var(--xp-bone); text-decoration: none;
  font-family: "Fraunces", Georgia, serif; font-size: 1.75rem; font-weight: 560;
  padding: 10px 0; min-height: 44px; display: flex; align-items: center;
}
[data-design="a"] .xp-drawer__link::after {
  content: ""; position: absolute; left: 0; bottom: 6px; height: 2px; width: 48px;
  background: var(--xp-cedar); transform: scaleX(0); transform-origin: left;
  transition: transform 240ms var(--xp-settle);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .xp-drawer__link:hover::after { transform: scaleX(1); }
}
[data-design="a"] .xp-drawer__link:focus-visible::after { transform: scaleX(1); }
[data-design="a"] .xp-drawer__link:focus-visible { outline: 2px solid var(--xp-flash); outline-offset: 4px; }
[data-design="a"] .xp-drawer__actions {
  margin-top: 24px; padding-top: 24px; display: grid; gap: 12px;
  border-top: 1px solid rgba(245, 240, 230, 0.25);
}
[data-design="a"] .xp-drawer__cta {
  background: var(--xp-cedar); color: var(--xp-bone); text-decoration: none;
  padding: 14px 20px; text-align: center; border-radius: 2px;
  font-weight: 600; box-shadow: 0 3px 0 var(--xp-cedar-deep);
  display: inline-flex; align-items: center; justify-content: center; min-height: 44px;
}
[data-design="a"] .xp-drawer__phone {
  color: var(--xp-bone); text-decoration: none; text-align: center;
  font-family: "IBM Plex Mono", monospace; letter-spacing: 0.06em;
  padding: 12px; min-height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
}
@media (max-width: 560px) {
  [data-design="a"] .xp-header__bar { padding-block: 12px; }
}

/* ---------- Hero (Element 3 + Element 2 CTA) ---------- */
[data-design="a"] .xp-hero {
  position: relative; min-height: min(78vh, 760px); display: flex; align-items: center;
  overflow: hidden; background: var(--xp-bone);
  isolation: isolate; /* HARD: hero text must be topmost paint */
}
[data-design="a"] .xp-hero__plane {
  position: absolute; inset: 0; display: flex; flex-direction: column; z-index: 0;
}
[data-design="a"] .xp-course {
  flex: 1 1 0;
  background:
    repeating-linear-gradient(90deg,
      transparent 0, transparent calc(148px + (var(--i) * 37px)),
      rgba(38, 34, 27, 0.10) calc(148px + (var(--i) * 37px)),
      rgba(38, 34, 27, 0.10) calc(150px + (var(--i) * 37px))),
    linear-gradient(180deg,
      rgba(168, 85, 43, calc(0.16 + var(--i) * 0.035)),
      rgba(139, 129, 113, calc(0.20 + var(--i) * 0.03)));
  box-shadow: 0 3px 0 rgba(38, 34, 27, 0.30);
  opacity: 0; transform: translateY(-12px);
  animation: xp-lay-in-a 520ms var(--xp-settle) forwards;
  animation-delay: calc((6 - var(--i)) * 90ms);
}
@keyframes xp-lay-in-a {
  to { opacity: 1; transform: translateY(0); }
}
[data-design="a"] .xp-hero__rake {
  position: absolute; top: -20%; left: -30%; width: 42%; height: 140%;
  background: linear-gradient(105deg, transparent 30%, rgba(245, 240, 230, 0.5) 50%, transparent 70%);
  transform: translateX(-60%) rotate(8deg);
  animation: xp-rake-a 14s linear infinite;
  animation-delay: 1.7s;
}
@keyframes xp-rake-a {
  0%   { transform: translateX(-70%) rotate(8deg); opacity: 0; }
  12%  { opacity: 1; }
  62%  { transform: translateX(320%) rotate(8deg); opacity: 1; }
  70%, 100% { transform: translateX(340%) rotate(8deg); opacity: 0; }
}
[data-design="a"] .xp-hero__breath {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(38, 34, 27, 0.10), rgba(38, 34, 27, 0) 55%);
  animation: xp-shadow-breath-a 9s ease-in-out infinite;
}
@keyframes xp-shadow-breath-a {
  0%, 100% { opacity: 0.45; }
  50%      { opacity: 1; }
}
[data-design="a"] .xp-hero__content {
  position: relative; z-index: 5; width: 100%; /* explicit z-index above every backdrop layer */
  max-width: 1320px; margin-inline: auto;
  padding: 96px clamp(20px, 5vw, 48px);
}
[data-design="a"] .xp-hero__headline {
  font-family: "Fraunces", Georgia, serif; font-weight: 640;
  font-size: clamp(2.1rem, 5.2vw, 3.8rem); line-height: 1.1;
  color: var(--xp-spruce); max-width: 18ch; margin: 0 0 24px; text-wrap: balance;
  opacity: 1;
}
[data-design="a"] .xp-hero__subtitle {
  font-size: clamp(1.125rem, 2vw, 1.375rem); line-height: 1.5;
  color: var(--xp-spruce); max-width: 46ch; margin: 0 0 16px;
  opacity: 1;
}
[data-design="a"] .xp-hero__proof {
  font-family: "IBM Plex Mono", monospace; font-size: 0.875rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--xp-cedar-deep); margin: 0 0 32px;
  opacity: 1;
}
@media (max-width: 560px) {
  [data-design="a"] .xp-hero { min-height: 100svh; }
  [data-design="a"] .xp-hero__content { padding-block: 64px; }
}

/* ---------- CTA group (Element 2) ---------- */
[data-design="a"] .xp-cta-group {
  display: flex; flex-wrap: wrap; align-items: center; gap: 16px;
  position: relative; z-index: 5;
}
[data-design="a"] .xp-cta {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  min-height: 56px; padding: 16px 32px; border-radius: 2px;
  background: var(--xp-cedar); color: var(--xp-bone); text-decoration: none;
  font-family: "Public Sans", Arial, sans-serif; font-weight: 600; font-size: 1.0625rem;
  box-shadow: 0 3px 0 var(--xp-cedar-deep);
  transition: transform 120ms var(--xp-settle), box-shadow 120ms var(--xp-settle);
  opacity: 1;
}
[data-design="a"] .xp-cta__drip {
  position: absolute; left: 8%; right: 8%; bottom: -9px; height: 1px;
  background: var(--xp-cedar);
  animation: xp-drip-breath-a 5s ease-in-out infinite;
}
@keyframes xp-drip-breath-a {
  0%, 100% { opacity: 0.25; transform: scaleX(0.72); }
  50%      { opacity: 0.9;  transform: scaleX(1); }
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .xp-cta:hover { transform: translateY(1px); box-shadow: 0 2px 0 var(--xp-cedar-deep); }
}
[data-design="a"] .xp-cta:focus-visible { outline: 2px solid var(--xp-flash); outline-offset: 3px; }
[data-design="a"] .xp-cta:active { transform: translateY(2px); box-shadow: 0 1px 0 var(--xp-cedar-deep); }

[data-design="a"] .xp-cta-repeat {
  display: flex; justify-content: center; padding: var(--xp-eave) clamp(20px, 5vw, 48px);
  background: var(--xp-bone);
}

/* ---------- Pointer (Element 6) ---------- */
[data-design="a"] .xp-pointer {
  display: grid; justify-items: center; gap: 8px;
  padding: 40px 20px 24px;
  opacity: 1;
}
[data-design="a"] .xp-pointer__course {
  display: block; height: 3px; border-radius: 0;
  width: calc(72px - var(--p) * 20px);
  background: var(--xp-cedar);
  box-shadow: 0 1px 0 rgba(38, 34, 27, 0.25);
  transform: scaleX(0); transform-origin: center;
  animation: xp-pointer-lay-a 5.5s var(--xp-settle) infinite;
  animation-delay: calc(var(--p) * 340ms);
}
@keyframes xp-pointer-lay-a {
  0%        { transform: scaleX(0); opacity: 0; }
  10%, 72%  { transform: scaleX(1); opacity: 1; }
  88%, 100% { transform: scaleX(1); opacity: 0; }
}
[data-design="a"] .xp-pointer__label {
  margin-top: 8px;
  font-family: "IBM Plex Mono", monospace; font-size: 0.8125rem;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--xp-driftwood);
  opacity: 1; min-height: 1em;
}

/* ---------- Funnel / Estimator (Element 5) ---------- */
[data-design="a"] .xp-funnel { background: var(--xp-bone); padding: 96px 0; }
[data-design="a"] .xp-funnel__inner {
  max-width: 880px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="a"] .xp-funnel__heading {
  font-family: "Fraunces", Georgia, serif; font-weight: 640;
  font-size: clamp(1.75rem, 3.6vw, 2.4rem); line-height: 1.2; color: var(--xp-spruce);
  margin: 0 0 8px;
}
[data-design="a"] .xp-funnel__sub { color: var(--xp-driftwood); font-size: 1.0625rem; line-height: 1.6; margin: 0 0 32px; max-width: 58ch; }

/* Live ballpark readout (EST-4) */
[data-design="a"] .xp-funnel__readout {
  background: var(--xp-paper); border-radius: 4px; padding: 20px 24px;
  margin: 0 0 32px; box-shadow: var(--xp-butt, 0 2px 0 rgba(38,34,27,0.28));
  display: grid; gap: 4px;
}
[data-design="a"] .xp-funnel__readout-label {
  font-family: "IBM Plex Mono", monospace; font-size: 0.75rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--xp-driftwood);
}
[data-design="a"] .xp-funnel__readout-range {
  font-family: "Fraunces", Georgia, serif; font-weight: 640; font-size: clamp(1.5rem, 3.2vw, 2rem);
  color: var(--xp-cedar-deep);
}
[data-design="a"] .xp-funnel__readout-note {
  font-size: 0.8125rem; color: var(--xp-driftwood); line-height: 1.5;
}

[data-design="a"] .xp-funnel__courses { display: flex; gap: 4px; margin: 0 0 40px; }
[data-design="a"] .xp-funnel__course-seg {
  flex: 1; height: 6px; background: var(--xp-paper); border-radius: 0;
  box-shadow: 0 1px 0 rgba(38, 34, 27, 0.22); overflow: hidden; position: relative;
}
[data-design="a"] .xp-funnel__course-seg::after {
  content: ""; position: absolute; inset: 0; background: var(--xp-cedar);
  transform: scaleX(0); transform-origin: left;
  transition: transform 420ms var(--xp-settle);
}
[data-design="a"] .xp-funnel__course-seg.is-laid::after { transform: scaleX(1); }

/* EST-8 HARD: exactly one scope step group visible at a time */
[data-design="a"] .xp-step { border: 0; padding: 0; margin: 0; }
[data-design="a"] .xp-step[hidden] { display: none !important; visibility: hidden; }
[data-design="a"] .xp-step.is-current { display: block; animation: xp-step-lay-a 240ms var(--xp-settle); }
@keyframes xp-step-lay-a {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}
[data-design="a"] .xp-step__title {
  font-family: "Fraunces", Georgia, serif; font-weight: 560; font-size: 1.375rem;
  line-height: 1.35; color: var(--xp-spruce); margin: 0 0 24px; padding: 0;
}
[data-design="a"] .xp-step__tabs {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px;
}
[data-design="a"] .xp-tab {
  position: relative; display: block; cursor: pointer; border-radius: 2px;
  perspective: 620px;
}
[data-design="a"] .xp-tab input {
  position: absolute; opacity: 0; width: 1px; height: 1px;
}
[data-design="a"] .xp-tab__underlay {
  position: absolute; inset: 0; border-radius: 2px; background: var(--xp-felt);
}
[data-design="a"] .xp-tab__face {
  position: relative; display: flex; align-items: center; justify-content: center;
  min-height: 56px; padding: 14px 18px; text-align: center;
  background: var(--xp-bone); color: var(--xp-spruce); border-radius: 2px;
  border-top: 1px solid var(--xp-driftwood);
  box-shadow: 0 2px 0 rgba(38, 34, 27, 0.28);
  font-weight: 600; font-size: 1rem; line-height: 1.3;
  transform-origin: top center;
  transition: transform 100ms var(--xp-lift), background-color 100ms linear, color 100ms linear, box-shadow 100ms var(--xp-lift);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .xp-tab:hover .xp-tab__face {
    transform: rotateX(6deg);
    box-shadow: 0 10px 24px -12px rgba(38, 34, 27, 0.35);
  }
}
[data-design="a"] .xp-tab input:focus-visible ~ .xp-tab__face {
  outline: 2px solid var(--xp-flash); outline-offset: 2px;
  transform: rotateX(6deg); box-shadow: 0 10px 24px -12px rgba(38, 34, 27, 0.35);
}
[data-design="a"] .xp-tab:active .xp-tab__face { transform: rotateX(0deg) translateY(1px); }
[data-design="a"] .xp-tab__nail {
  position: absolute; top: 6px; left: 50%; width: 6px; height: 6px; margin-left: -3px;
  border-radius: 50%; background: var(--xp-cedar-deep);
  opacity: 0; transform: scale(0.4);
  transition: opacity 100ms var(--xp-settle), transform 100ms var(--xp-lift);
}
[data-design="a"] .xp-tab input:checked ~ .xp-tab__face {
  background: var(--xp-cedar); color: var(--xp-bone);
  transform: rotateX(0deg) translateY(1px); box-shadow: 0 1px 0 var(--xp-cedar-deep);
}
[data-design="a"] .xp-tab input:checked ~ .xp-tab__face .xp-tab__nail {
  opacity: 1; transform: scale(1); background: var(--xp-bone);
}
[data-design="a"] .xp-funnel__summary {
  font-size: 0.9375rem; color: var(--xp-driftwood); margin: 0 0 24px; line-height: 1.5;
}
[data-design="a"] .xp-step__fields { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
[data-design="a"] .xp-field--wide { grid-column: 1 / -1; }
[data-design="a"] .xp-field { display: grid; gap: 6px; }
[data-design="a"] .xp-field__label {
  font-family: "IBM Plex Mono", monospace; font-size: 0.8125rem;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--xp-driftwood);
}
[data-design="a"] .xp-field__input {
  border: 0; border-bottom: 1px solid var(--xp-driftwood); background: transparent;
  padding: 10px 2px; font: inherit; color: var(--xp-spruce); border-radius: 0;
  transition: border-color 160ms linear;
}
[data-design="a"] .xp-field__input:focus { outline: none; border-bottom: 2px solid var(--xp-cedar); margin-bottom: -1px; }
[data-design="a"] .xp-funnel__error { color: var(--xp-critical); font-size: 0.9375rem; margin: 16px 0 0; }
[data-design="a"] .xp-funnel__submit { margin-top: 32px; }
/* Advance/nav controls never overlap the choice chips — back sits below the tab grid, own row */
[data-design="a"] .xp-funnel__back {
  margin-top: 24px; background: none; border: 0; cursor: pointer; min-height: 44px;
  color: var(--xp-driftwood); font: inherit; padding: 8px 4px;
  display: block; position: static;
}
[data-design="a"] .xp-funnel__back:focus-visible { outline: 2px solid var(--xp-flash); outline-offset: 2px; }
[data-design="a"] .xp-funnel__done { text-align: left; padding: 24px 0; position: relative; }
[data-design="a"] .xp-funnel__done-stamp {
  display: inline-block; width: 56px; height: 56px; border: 2px solid var(--xp-success);
  border-radius: 50%; position: relative; margin-bottom: 16px;
  animation: xp-done-stamp-a 360ms var(--xp-lift);
}
[data-design="a"] .xp-funnel__done-stamp::after {
  content: ""; position: absolute; left: 18px; top: 26px; width: 16px; height: 9px;
  border-left: 2.5px solid var(--xp-success); border-bottom: 2.5px solid var(--xp-success);
  transform: rotate(-45deg);
}
@keyframes xp-done-stamp-a {
  from { opacity: 0; transform: scale(0.95); }
  to   { opacity: 1; transform: scale(1); }
}
[data-design="a"] .xp-funnel__done-title { font-family: "Fraunces", Georgia, serif; font-size: 1.75rem; margin: 0 0 8px; color: var(--xp-spruce); }
[data-design="a"] .xp-funnel__done-body { color: var(--xp-spruce); line-height: 1.65; max-width: 52ch; }
@media (max-width: 560px) {
  [data-design="a"] .xp-funnel { padding: 64px 0; }
  [data-design="a"] .xp-step__tabs { grid-template-columns: 1fr 1fr; }
  [data-design="a"] .xp-step__fields { grid-template-columns: 1fr; }
}
@media (max-width: 360px) {
  [data-design="a"] .xp-step__tabs { grid-template-columns: 1fr; }
}

/* ---------- Ledger / Gallery (Element 4) ---------- */
[data-design="a"] .xp-ledger {
  position: relative; background: var(--xp-paper);
  padding: 96px 0;
}
[data-design="a"] .xp-ledger__rule {
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: var(--xp-driftwood); overflow: hidden;
}
[data-design="a"] .xp-ledger__glint {
  position: absolute; inset: 0 auto 0 0; width: 22%;
  background: linear-gradient(90deg, transparent, var(--xp-flash), transparent);
  animation: xp-ledger-glint-a 20s linear infinite;
}
@keyframes xp-ledger-glint-a {
  from { transform: translateX(-120%); }
  to   { transform: translateX(560%); }
}
[data-design="a"] .xp-ledger__inner {
  max-width: 1320px; margin-inline: auto; position: relative;
  padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="a"] .xp-ledger__title {
  font-family: "Fraunces", Georgia, serif; font-weight: 560;
  font-size: clamp(1.75rem, 3.4vw, 2.2rem); line-height: 1.25;
  color: var(--xp-spruce); margin: 0 0 40px; max-width: 24ch;
}
[data-design="a"] .xp-ledger__rows { display: grid; gap: 40px; }
[data-design="a"] .xp-ledger__row {
  position: relative; display: grid; gap: 24px; padding-top: 24px;
  grid-template-columns: minmax(0, 7fr) minmax(0, 5fr); align-items: start;
}
[data-design="a"] .xp-ledger__row::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: var(--xp-cedar);
  transform: scaleX(0); transform-origin: left;
  transition: transform 640ms var(--xp-settle);
}
[data-design="a"] .xp-ledger__row.is-inview::before { transform: scaleX(1); }
[data-design="a"] .xp-ledger__row::after {
  content: ""; position: absolute; top: -3px; left: 38%; width: 2px; height: 7px;
  background: var(--xp-cedar-deep); opacity: 0;
  transition: opacity 300ms var(--xp-settle) 480ms;
}
[data-design="a"] .xp-ledger__row.is-inview::after { opacity: 1; }
[data-design="a"] .xp-ledger__row:nth-child(even)::after { left: 62%; }
[data-design="a"] .xp-ledger__frame {
  margin: 0; aspect-ratio: 3 / 2; overflow: hidden; border-radius: 2px;
  box-shadow: 0 2px 0 rgba(38, 34, 27, 0.28);
}
[data-design="a"] .xp-ledger__frame img { width: 100%; height: 100%; object-fit: cover; display: block; }
[data-design="a"] .xp-ledger__field {
  width: 100%; height: 100%;
  background: linear-gradient(160deg, rgba(168, 85, 43, 0.28), rgba(139, 129, 113, 0.34));
}
[data-design="a"] .xp-ledger__meta h3 {
  font-family: "Fraunces", Georgia, serif; font-weight: 560; font-size: 1.375rem;
  line-height: 1.35; color: var(--xp-spruce); margin: 0 0 8px;
}
[data-design="a"] .xp-ledger__meta p { font-size: 1.0625rem; line-height: 1.65; color: var(--xp-spruce); margin: 0 0 8px; max-width: 58ch; }
[data-design="a"] .xp-ledger__spec {
  font-family: "IBM Plex Mono", monospace; font-size: 0.8125rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--xp-driftwood);
}
[data-design="a"] .xp-stamp {
  position: absolute; right: clamp(20px, 5vw, 48px); top: -26px;
  width: 52px; height: 52px; background: none; border: 0; cursor: pointer;
  border-radius: 50%;
}
[data-design="a"] .xp-stamp__ring {
  position: absolute; inset: 4px; border: 1.5px solid var(--xp-flash); border-radius: 50%;
  display: block; transition: transform 120ms var(--xp-settle);
}
[data-design="a"] .xp-stamp__ring::after {
  content: "№1"; position: absolute; inset: 0; display: grid; place-items: center;
  font-family: "IBM Plex Mono", monospace; font-size: 0.75rem; color: var(--xp-flash);
}
[data-design="a"] .xp-stamp__ghost {
  position: absolute; inset: 4px; border: 1.5px solid var(--xp-flash); border-radius: 50%;
  opacity: 0; transform: translate(0, 0) scale(1); pointer-events: none;
}
[data-design="a"] .xp-stamp.is-pressed .xp-stamp__ring { transform: scale(0.9); }
[data-design="a"] .xp-stamp.is-pressed .xp-stamp__ghost { animation: xp-stamp-ghost-a 700ms var(--xp-settle); }
@keyframes xp-stamp-ghost-a {
  0%   { opacity: 0.7; transform: translate(0, 0) scale(1); }
  100% { opacity: 0;   transform: translate(10px, 8px) scale(1.06); }
}
[data-design="a"] .xp-stamp:focus-visible { outline: 2px solid var(--xp-flash); outline-offset: 2px; }
@media (max-width: 768px) {
  [data-design="a"] .xp-ledger { padding: 64px 0; }
  [data-design="a"] .xp-ledger__row { grid-template-columns: 1fr; }
}

/* ---------- Materials & Guards ---------- */
[data-design="a"] .xp-materials { background: var(--xp-bone); padding: var(--xp-eave) 0; }
[data-design="a"] .xp-materials__inner {
  max-width: 1320px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="a"] .xp-materials__title {
  font-family: "Fraunces", Georgia, serif; font-weight: 560;
  font-size: clamp(1.75rem, 3.4vw, 2.2rem); color: var(--xp-spruce); margin: 0 0 40px;
}
[data-design="a"] .xp-materials__grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 32px;
}
[data-design="a"] .xp-materials__card {
  background: var(--xp-paper); border-radius: 4px; padding: 24px;
  box-shadow: 0 2px 0 rgba(38, 34, 27, 0.28);
}
[data-design="a"] .xp-materials__card h3 {
  font-family: "Fraunces", Georgia, serif; font-weight: 560; font-size: 1.25rem;
  color: var(--xp-spruce); margin: 0 0 8px;
}
[data-design="a"] .xp-materials__card p { font-size: 1rem; line-height: 1.6; color: var(--xp-spruce); margin: 0; max-width: 40ch; }
@media (max-width: 768px) {
  [data-design="a"] .xp-materials { padding: var(--xp-plane) 0; }
}

/* ---------- Shed / Process (Element 7 scroll choreography) ---------- */
[data-design="a"] .xp-shed {
  position: relative; background: var(--xp-bone); padding: 96px 0 64px;
}
[data-design="a"] .xp-shed__drip {
  position: absolute; top: 0; left: clamp(20px, 5vw, 48px); right: clamp(20px, 5vw, 48px);
  height: 2px; background: var(--xp-cedar);
  transform-origin: left; transform: scaleX(1);
}
[data-design="a"] .xp-shed__inner {
  max-width: 1320px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="a"] .xp-shed__title {
  font-family: "Fraunces", Georgia, serif; font-weight: 560;
  font-size: clamp(1.75rem, 3.4vw, 2.2rem); line-height: 1.25; color: var(--xp-spruce);
  margin: 0 0 16px; max-width: 26ch;
}
[data-design="a"] .xp-shed__body { max-width: 66ch; font-size: 1.0625rem; line-height: 1.65; color: var(--xp-spruce); }
@supports (animation-timeline: view()) {
  [data-design="a"] .xp-hero .xp-course {
    animation-name: xp-lay-in-a, xp-shed-up-a;
    animation-duration: 520ms, auto;
    animation-timing-function: var(--xp-settle), linear;
    animation-delay: calc((6 - var(--i)) * 90ms), 0s;
    animation-fill-mode: forwards, none;
    animation-timeline: auto, view();
    animation-range: normal, exit 0% exit 100%;
  }
  @keyframes xp-shed-up-a {
    to { transform: translateY(calc(-14px - (6 - var(--i)) * 10px)); }
  }
  [data-design="a"] .xp-shed__drip {
    transform: scaleX(0);
    animation: xp-drip-draw-a linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 60%;
  }
  @keyframes xp-drip-draw-a {
    from { transform: scaleX(0); }
    to   { transform: scaleX(1); }
  }
}

/* ---------- Service area ---------- */
[data-design="a"] .xp-service-area { background: var(--xp-paper); padding: var(--xp-eave) 0; }
[data-design="a"] .xp-service-area__inner {
  max-width: 1320px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="a"] .xp-area-title {
  font-family: "Fraunces", Georgia, serif; font-weight: 560;
  font-size: clamp(1.75rem, 3.4vw, 2.2rem); color: var(--xp-spruce); margin: 0 0 16px;
}
[data-design="a"] .xp-service-area__body { font-size: 1.0625rem; line-height: 1.6; color: var(--xp-spruce); margin: 0 0 8px; max-width: 66ch; }
[data-design="a"] .xp-service-area__note { font-size: 0.9375rem; color: var(--xp-driftwood); margin: 0; }
@media (max-width: 768px) {
  [data-design="a"] .xp-service-area { padding: var(--xp-plane) 0; }
}

/* ---------- Footer ---------- */
[data-design="a"] .xp-footer { background: var(--xp-felt); padding: var(--xp-eave) 0 var(--xp-course); position: relative; }
[data-design="a"] .xp-footer::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: var(--xp-cedar);
}
[data-design="a"] .xp-footer__inner {
  max-width: 1320px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px);
  display: grid; gap: 32px;
}
[data-design="a"] .xp-footer__mark { color: var(--xp-bone); }
[data-design="a"] .xp-footer__tag { color: var(--xp-driftwood); font-size: 0.9375rem; margin: 8px 0 0; }
[data-design="a"] .xp-footer__actions { display: flex; flex-wrap: wrap; gap: 16px; }
[data-design="a"] .xp-footer__legal {
  font-family: "IBM Plex Mono", monospace; font-size: 0.75rem; letter-spacing: 0.04em;
  color: var(--xp-driftwood); margin: 0; padding-top: 24px; border-top: 1px solid rgba(245,240,230,0.15);
}
@media (max-width: 768px) {
  [data-design="a"] .xp-footer { padding: var(--xp-plane) 0 var(--xp-course); }
}

/* ---------- Reduced motion (applies across all elements above) ---------- */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .xp-header__eave-light { animation: none; transform: translateX(90%); }
  [data-design="a"] .xp-drawer { transition: opacity 180ms linear; transform: none; }
  [data-design="a"] .xp-burger__lap { transition: none; }
  [data-design="a"] .xp-course { animation: none; opacity: 1; transform: none; }
  [data-design="a"] .xp-hero__rake { animation: none; opacity: 0.5; transform: translateX(120%) rotate(8deg); }
  [data-design="a"] .xp-hero__breath { animation: none; opacity: 0.7; }
  [data-design="a"] .xp-cta__drip { animation: none; opacity: 0.7; transform: scaleX(1); }
  [data-design="a"] .xp-cta { transition: none; }
  [data-design="a"] .xp-pointer__course { animation: none; transform: scaleX(1); opacity: 1; }
  [data-design="a"] .xp-step.is-current { animation: none; }
  [data-design="a"] .xp-tab__face { transition: background-color 100ms linear, color 100ms linear; }
  [data-design="a"] .xp-tab:hover .xp-tab__face,
  [data-design="a"] .xp-tab input:focus-visible ~ .xp-tab__face { transform: none; }
  [data-design="a"] .xp-funnel__course-seg::after { transition: none; }
  [data-design="a"] .xp-funnel__done-stamp { animation: none; }
  [data-design="a"] .xp-ledger__glint { animation: none; transform: translateX(180%); }
  [data-design="a"] .xp-ledger__row::before { transition: none; transform: scaleX(1); }
  [data-design="a"] .xp-ledger__row::after { transition: none; opacity: 1; }
  [data-design="a"] .xp-stamp.is-pressed .xp-stamp__ghost { animation: none; }
  [data-design="a"] .xp-hero .xp-course { animation: none !important; transform: none; opacity: 1; }
  [data-design="a"] .xp-shed__drip { animation: none !important; transform: scaleX(1); }
}

/* ============================================================
   MOBILE / OVERFLOW SAFETY — scoped to .dq-design, appended last
   ============================================================ */
[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; }

/* stranded-wrapper autofix (drain 2026-07-03): every fixed max-width column centers — gate content_uncentered_left_stranded */
[data-design="a"] .xp-hero__subtitle { margin-inline: auto; }
[data-design="a"] .xp-funnel__sub { margin-inline: auto; }
[data-design="a"] .xp-funnel__done-body { margin-inline: auto; }
[data-design="a"] .xp-ledger__meta p { margin-inline: auto; }
[data-design="a"] .xp-materials__card p { margin-inline: auto; }
[data-design="a"] .xp-shed__title { margin-inline: auto; }
[data-design="a"] .xp-shed__body { margin-inline: auto; }
[data-design="a"] .xp-service-area__body { margin-inline: auto; }

/* Phase-3.4 hero visibility floor (forge_assemble) */
[data-design="a"] [data-mf-role="hero"] :is(h1,h2,p,.headline,.subtitle,.proof,[class*="headline"],[class*="subtitle"],[class*="proof"]),
[data-design="a"] [data-mf-role="cta"] { opacity: 1 !important; }
