/* ==========================================================================
   Design A — Law Office of Brandon Mayfield LLC
   Design system: Pinpoint (citation-engine aesthetic)
   Every selector scoped under [data-design="a"]; keyframes prefixed pp-.
   ========================================================================== */

[data-design="a"] {
  /* --- color ------------------------------------------------------------ */
  --pp-bg:         #0c1116;
  --pp-bg-2:       #10171f;
  --pp-surface:    #161e28;
  --pp-surface-2:  #1d2632;
  --pp-ink:        #e8edf4;
  --pp-ink-2:      #c5cdd9;
  --pp-muted:      #7c8696;
  --pp-faint:      #4b5566;
  --pp-hairline:   #222b38;
  --pp-hairline-2: #2d3949;
  --pp-accent:     #20c5a8;
  --pp-accent-2:   #0e8a76;
  --pp-critical:   #ff6f6f;
  --pp-success:    #58d68d;

  /* design accent exposed for the brand bar */
  --design-a-primary: #20c5a8;

  /* --- type ------------------------------------------------------------- */
  --pp-font-sans:  "Söhne", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --pp-font-serif: "Tiempos Text", "Charter", "Iowan Old Style", Georgia, serif;
  --pp-font-mono:  "Berkeley Mono", "JetBrains Mono", "IBM Plex Mono", ui-monospace, Menlo, monospace;

  /* --- spacing ---------------------------------------------------------- */
  --pp-stitch:  4px;
  --pp-pin:     8px;
  --pp-cite:   12px;
  --pp-line:   20px;
  --pp-block:  32px;
  --pp-stanza: 56px;
  --pp-section: 112px;
  --pp-bay:    160px;

  /* --- motion ----------------------------------------------------------- */
  --pp-d-tick:   90ms;
  --pp-d-stream: 240ms;
  --pp-d-snap:   180ms;
  --pp-d-draw:   520ms;
  --pp-d-pour:   720ms;
  --pp-ease-stream: cubic-bezier(0.16, 0.84, 0.44, 1);
  --pp-ease-snap:   cubic-bezier(0.34, 1.6, 0.5, 1);
  --pp-ease-draw:   cubic-bezier(0.65, 0, 0.35, 1);

  /* --- radius ----------------------------------------------------------- */
  --pp-r-chip:  3px;
  --pp-r-card: 10px;
  --pp-r-pill: 999px;

  /* --- elevation -------------------------------------------------------- */
  --pp-elev-1: 0 0 0 1px var(--pp-hairline);
  --pp-elev-2: 0 0 0 1px var(--pp-hairline-2), 0 1px 0 #0006;
  --pp-elev-glow: 0 0 0 1px var(--pp-accent), 0 0 24px -6px color-mix(in oklab, var(--pp-accent), transparent 60%);
}

/* --- base ----------------------------------------------------------------- */
[data-design="a"].dq-design {
  background: var(--pp-bg);
  color: var(--pp-ink);
  font-family: var(--pp-font-sans);
  -webkit-font-smoothing: antialiased;
  font-size: 17px;
  line-height: 1.6;
}
[data-design="a"] *,
[data-design="a"] *::before,
[data-design="a"] *::after { box-sizing: border-box; }
[data-design="a"] p { margin: 0; }
[data-design="a"] a { color: var(--pp-accent); }
[data-design="a"] ::selection { background: color-mix(in oklab, var(--pp-accent), transparent 70%); color: var(--pp-ink); }

[data-design="a"] .pp-eyebrow {
  font-family: var(--pp-font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--pp-muted);
  margin: 0 0 18px;
}

/* ==========================================================================
   ELEMENT 1 — Animated minimalist header
   ========================================================================== */
[data-design="a"] .pp-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in oklab, var(--pp-bg), transparent 12%);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--pp-hairline);
  overflow: hidden;
}
[data-design="a"] .pp-header__bar {
  display: flex; align-items: center; justify-content: space-between;
  height: 72px; padding: 0 clamp(20px, 4vw, 56px);
  position: relative; z-index: 2;
}
[data-design="a"] .pp-logo {
  font-family: var(--pp-font-sans);
  font-size: clamp(15px, 2.4vw, 18px); font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--pp-ink); text-decoration: none;
  white-space: nowrap;
}
[data-design="a"] .pp-logo__mark::after {
  content: "·";
  margin-left: 8px;
  color: var(--pp-accent);
  animation: pp-cursor-pulse 1.6s steps(2, end) infinite;
}
[data-design="a"] .pp-burger {
  flex: 0 0 auto;
  width: 44px; height: 44px; border: 1px solid var(--pp-hairline);
  border-radius: var(--pp-r-chip); background: transparent;
  display: grid; place-items: center; gap: 4px; cursor: pointer;
  margin-left: 16px;
  transition: border-color var(--pp-d-tick) var(--pp-ease-snap);
}
[data-design="a"] .pp-burger:hover,
[data-design="a"] .pp-burger:focus-visible { border-color: var(--pp-accent); outline: none; }
[data-design="a"] .pp-burger__line { display: block; width: 16px; height: 1px; background: var(--pp-ink); }

[data-design="a"] .pp-header__stream {
  position: absolute; left: 0; right: 0; bottom: 0; height: 22px;
  display: flex; gap: 56px; white-space: nowrap;
  animation: pp-stream-drift 31s linear infinite;
  opacity: 0.42; pointer-events: none;
  overflow: hidden;
  font-family: var(--pp-font-mono); font-size: 11px; color: var(--pp-faint);
}
[data-design="a"] .pp-cite-ghost {
  flex: 0 0 auto; padding: 2px 8px;
  border: 1px solid var(--pp-hairline); border-radius: var(--pp-r-chip);
}
@keyframes pp-stream-drift {
  from { transform: translateX(8%); }
  to   { transform: translateX(-92%); }
}
@keyframes pp-cursor-pulse {
  0%, 50% { opacity: 1; } 51%, 100% { opacity: 0.15; }
}

/* --- the hamburger drawer ------------------------------------------------- */
[data-design="a"] .pp-drawer {
  position: fixed; inset: 0; z-index: 100;
  background: color-mix(in oklab, var(--pp-bg), transparent 12%);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: grid; grid-template-columns: 1fr min(420px, 88vw);
}
[data-design="a"] .pp-drawer[hidden] { display: none; }
[data-design="a"] .pp-drawer__panel {
  grid-column: 2; background: var(--pp-surface);
  border-left: 1px solid var(--pp-hairline);
  padding: 24px;
  display: flex; flex-direction: column;
  transform: translateX(8%);
  opacity: 0;
  animation: pp-drawer-in var(--pp-d-stream) var(--pp-ease-stream) forwards;
  overflow-y: auto;
}
@keyframes pp-drawer-in {
  to { transform: translateX(0); opacity: 1; }
}
[data-design="a"] .pp-drawer__close {
  align-self: flex-end;
  font-family: var(--pp-font-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--pp-muted); background: transparent;
  border: 1px solid var(--pp-hairline); border-radius: var(--pp-r-chip);
  cursor: pointer; padding: 10px 14px;
  min-height: 44px;
  transition: border-color var(--pp-d-tick) var(--pp-ease-snap), color var(--pp-d-tick) var(--pp-ease-snap);
}
[data-design="a"] .pp-drawer__close:hover,
[data-design="a"] .pp-drawer__close:focus-visible { border-color: var(--pp-accent); color: var(--pp-ink); outline: none; }
[data-design="a"] .pp-drawer__nav { display: flex; flex-direction: column; gap: 4px; margin-top: 28px; }
[data-design="a"] .pp-drawer__nav a {
  display: grid; grid-template-columns: 32px 1fr 16px;
  align-items: center; padding: 16px 0;
  border-top: 1px solid var(--pp-hairline);
  font-family: var(--pp-font-serif); font-size: 18px;
  color: var(--pp-ink); text-decoration: none;
  min-height: 44px;
  transition: color var(--pp-d-tick) var(--pp-ease-snap);
}
[data-design="a"] .pp-drawer__nav a::before {
  content: attr(data-index); font-family: var(--pp-font-mono);
  font-size: 11px; color: var(--pp-muted); letter-spacing: 0.08em;
}
[data-design="a"] .pp-drawer__nav a::after { content: "→"; color: var(--pp-faint); }
[data-design="a"] .pp-drawer__nav a:hover,
[data-design="a"] .pp-drawer__nav a:focus-visible { color: var(--pp-accent); outline: none; }
[data-design="a"] .pp-drawer__nav a:hover::after,
[data-design="a"] .pp-drawer__nav a:focus-visible::after { color: var(--pp-accent); }
[data-design="a"] .pp-drawer__meta {
  margin-top: 18px;
  font-family: var(--pp-font-mono); font-size: 12px;
  letter-spacing: 0.04em; color: var(--pp-muted);
  display: flex; gap: 8px; flex-wrap: wrap;
}
[data-design="a"] .pp-drawer__meta a { color: var(--pp-ink-2); text-decoration: none; }
[data-design="a"] .pp-drawer__meta a:hover { color: var(--pp-accent); }

/* ==========================================================================
   ELEMENT 2 — Animated CTA (inside the drawer)
   ========================================================================== */
[data-design="a"] .pp-cta {
  position: relative; display: inline-flex; align-items: baseline; gap: 6px;
  margin-top: 28px;
  padding: 16px 28px 16px 24px;
  background: var(--pp-accent); color: var(--pp-bg);
  border-radius: var(--pp-r-card);
  font-family: var(--pp-font-sans); font-size: 16px; font-weight: 500;
  letter-spacing: -0.005em; text-decoration: none;
  box-shadow: var(--pp-elev-glow);
  align-self: flex-start;
  min-height: 44px;
  transition: transform var(--pp-d-tick) var(--pp-ease-snap),
              background var(--pp-d-tick) var(--pp-ease-snap);
  overflow: hidden;
}
[data-design="a"] .pp-cta:hover { background: color-mix(in oklab, var(--pp-accent), white 8%); }
[data-design="a"] .pp-cta:active { transform: translateY(1px); background: var(--pp-accent-2); }
[data-design="a"] .pp-cta:focus-visible { outline: 2px solid var(--pp-ink); outline-offset: 3px; }
[data-design="a"] .pp-cta__cite {
  font-family: var(--pp-font-mono); font-size: 11px;
  align-self: flex-start; margin-top: 2px;
  animation: pp-cite-breath 4.2s var(--pp-ease-stream) infinite;
}
[data-design="a"] .pp-cta__rule {
  position: absolute; left: 24px; right: 24px; bottom: 10px;
  height: 1px; background: var(--pp-bg);
  transform: scaleX(0); transform-origin: left center;
  transition: transform var(--pp-d-stream) var(--pp-ease-stream);
}
[data-design="a"] .pp-cta:hover .pp-cta__rule { transform: scaleX(1); }
@keyframes pp-cite-breath {
  0%, 100% { opacity: 0.25; transform: translateY(0); }
  40%      { opacity: 1;    transform: translateY(-1px); }
  70%      { opacity: 0.45; transform: translateY(0); }
}

/* ==========================================================================
   HERO — themed-movement schematic. ONE animated substrate layer.
   ========================================================================== */
[data-design="a"] .pp-hero {
  position: relative;
  padding: clamp(56px, 9vw, 104px) clamp(20px, 4vw, 56px);
  /* an EXPLICIT (definite) hero height — not min-height. Two jobs:
     (1) a deliberate full-presence hero opening, and
     (2) a definite height so the ledger SVG's height:100% resolves and the
         substrate genuinely fills the hero (a % height on a replaced SVG
         silently falls back to the viewBox aspect against an auto parent).
     Text is flex-centred; overflow is clipped defensively. */
  height: clamp(468px, 64vh, 624px);
  display: flex;
  align-items: center;
  overflow: hidden;
  isolation: isolate;
}
[data-design="a"] .pp-hero__substrate {
  position: absolute; inset: 0;
  z-index: 0;
  pointer-events: none;
  /* static low-chroma wash sits beneath the one animated layer — defined
     linear stops, no soft radial bloom (a bloom both washes out the ledger's
     hairline contrast and adds zero hard-edged structure). A single faint
     teal index-tint anchors the brand without lifting the substrate mean. */
  background:
    linear-gradient(160deg,
      color-mix(in oklab, var(--pp-accent), transparent 94%) 0%,
      transparent 30%),
    linear-gradient(172deg, var(--pp-surface) 0%, var(--pp-bg-2) 54%, var(--pp-bg) 100%);
}
/* ── The ONE moving layer — the citation-index ledger ───────────────────────
   A CSS-composed indexed-authority panel that fills the hero behind the text.
   Composed in CSS (not a fixed-viewBox SVG) so the hard-edged structure stays
   precise and the chip text never distorts across the 320→1440 width range.
   Hard-edged structure: a bordered panel, a header band, five full-width
   authority rules at REAL contrast, indexed numerals, connecting hairlines and
   bordered citation chips — this is what clears the edge-density floor.
   It draws/settles in within ~2s on load, then the whole ledger holds a single
   quiet at-rest breath (opacity + a slow vertical drift). Baseline scale 1.04
   overscans the hero so the breath drift never exposes a hero edge. */
[data-design="a"] .pp-hero__ledger {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  padding: clamp(20px, 3.4vw, 44px) clamp(18px, 3vw, 40px);
  gap: clamp(14px, 2.4vw, 26px);
  /* the bordered ledger panel — a large hard-edged backdrop */
  border: 2.25px solid #5a6d86;
  border-radius: var(--pp-r-card);
  background: color-mix(in oklab, var(--pp-surface-2), transparent 30%);
  transform-origin: 56% 50%;
  will-change: transform, opacity;
  opacity: 0;
  animation:
    pp-ledger-arrive 1.5s var(--pp-ease-draw) 0.15s forwards,
    pp-ledger-breath 6s ease-in-out 1.9s infinite;
}
/* header band — two tag rects above a crisp divider rule */
[data-design="a"] .pp-ledger__head {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 12px;
  padding-bottom: clamp(12px, 2vw, 22px);
  border-bottom: 2.5px solid #6a7d95;
}
[data-design="a"] .pp-ledger__head-tag {
  height: clamp(22px, 3.4vw, 30px);
  width: clamp(70px, 12vw, 104px);
  border: 2px solid #66798f;
  border-radius: var(--pp-r-chip);
  background: color-mix(in oklab, var(--pp-surface), transparent 8%);
  transform-origin: left center;
  transform: scaleX(0);
  animation: pp-ledger-wipe 0.7s var(--pp-ease-draw) 0.2s forwards;
}
[data-design="a"] .pp-ledger__head-tag--wide {
  width: clamp(104px, 17vw, 150px);
  margin-left: auto;
  transform-origin: right center;
  animation-delay: 0.3s;
}
/* the indexed authority list — distributes its rows down the panel */
[data-design="a"] .pp-ledger__index {
  list-style: none;
  margin: 0; padding: 0;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
}
/* one indexed row — numeral | connecting hairline | citation chip.
   The row's bottom border is the full-width authority rule. */
[data-design="a"] .pp-ledger__row {
  flex: 1 1 0;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(10px, 2.2vw, 22px);
  border-bottom: 2.25px solid #62758d;
  min-height: 0;
}
[data-design="a"] .pp-ledger__row:last-child { border-bottom: 0; }
/* the brand-teal authority rule — one signal line in the index */
[data-design="a"] .pp-ledger__row--accent {
  border-bottom-color: color-mix(in oklab, var(--pp-accent), #5a6d86 26%);
  border-bottom-width: 3px;
}
/* index numeral */
[data-design="a"] .pp-ledger__num {
  font-family: var(--pp-font-mono);
  font-size: clamp(15px, 2.6vw, 24px);
  font-weight: 500;
  color: #8294aa;
  letter-spacing: 0.04em;
}
/* connecting hairline — runs from the numeral toward the citation chip */
[data-design="a"] .pp-ledger__rule {
  height: 2.25px;
  background: #5d7088;
  transform-origin: left center;
  transform: scaleX(0);
  animation: pp-ledger-wipe 0.9s var(--pp-ease-draw) forwards;
}
/* bordered citation chip — hard-edged, settles in after its rule */
[data-design="a"] .pp-ledger__chip {
  font-family: var(--pp-font-mono);
  font-size: clamp(12px, 2.1vw, 21px);
  color: #9aaabd;
  white-space: nowrap;
  padding: clamp(5px, 1vw, 9px) clamp(9px, 1.6vw, 16px);
  border: 2.25px solid #6c8099;
  border-radius: var(--pp-r-chip);
  background: color-mix(in oklab, var(--pp-surface), white 4%);
  opacity: 0;
  transform: translateY(9px);
  animation: pp-glyph-settle 0.85s var(--pp-ease-stream) forwards;
}
/* the OSB-number chip carries the single brand-teal signal */
[data-design="a"] .pp-ledger__chip--accent {
  color: var(--pp-accent);
  border-color: var(--pp-accent);
  background: color-mix(in oklab, var(--pp-accent), var(--pp-bg) 82%);
}
/* per-row stagger — rules wipe, then chips settle, within ~2s */
[data-design="a"] .pp-ledger__row:nth-child(1) .pp-ledger__rule { animation-delay: 0.24s; }
[data-design="a"] .pp-ledger__row:nth-child(2) .pp-ledger__rule { animation-delay: 0.36s; }
[data-design="a"] .pp-ledger__row:nth-child(3) .pp-ledger__rule { animation-delay: 0.48s; }
[data-design="a"] .pp-ledger__row:nth-child(4) .pp-ledger__rule { animation-delay: 0.60s; }
[data-design="a"] .pp-ledger__row:nth-child(5) .pp-ledger__rule { animation-delay: 0.72s; }
[data-design="a"] .pp-ledger__row:nth-child(1) .pp-ledger__chip { animation-delay: 0.70s; }
[data-design="a"] .pp-ledger__row:nth-child(2) .pp-ledger__chip { animation-delay: 0.88s; }
[data-design="a"] .pp-ledger__row:nth-child(3) .pp-ledger__chip { animation-delay: 1.06s; }
[data-design="a"] .pp-ledger__row:nth-child(4) .pp-ledger__chip { animation-delay: 1.24s; }
[data-design="a"] .pp-ledger__row:nth-child(5) .pp-ledger__chip { animation-delay: 1.42s; }
/* arrival keyframes */
@keyframes pp-ledger-wipe {
  to { transform: scaleX(1); }
}
@keyframes pp-glyph-settle {
  from { opacity: 0; transform: translateY(9px); }
  to   { opacity: 1; transform: translateY(0); }
}
/* arrival — the whole ledger fades + lifts into its rest position.
   Rest scale is 1.04 (not 1.0): the ledger overscans the hero box so the
   breath's vertical drift never exposes a hero edge. */
@keyframes pp-ledger-arrive {
  from { opacity: 0;    transform: translateY(26px) scale(1.02); }
  to   { opacity: 0.97; transform: translateY(0)    scale(1.04); }
}
/* at-rest breath — the ONE motion the gate samples in the settled phase.
   Quiet and slow: a 6s cycle. Motion is carried mainly by a vertical drift
   + a faint scale (every hairline physically moves frame-to-frame), with
   only a small opacity sway — the ledger stays near-full opacity so its
   hard-edged structure reads clearly at every frame. Never flashy. */
@keyframes pp-ledger-breath {
  0%, 100% { opacity: 0.97; transform: translateY(0)     scale(1.04); }
  50%      { opacity: 0.86; transform: translateY(-18px) scale(1.062); }
}
/* static legibility scrim — sits above the ledger, below the text.
   Two jobs: (1) hold the text column crisp and let the ledger recede behind
   it — a citation chip sitting under a line of copy should read as quiet
   backdrop, not clutter; (2) on the right (clear of text) stay light so the
   ledger's indexed structure reads as a designed element, not a smudge.
   Left/centre carries a stronger wash; the right edge releases to clear.
   No animation — the one-moving-layer rule holds. */
[data-design="a"] .pp-hero::after {
  content: "";
  position: absolute; inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(95deg,
      var(--pp-bg) 0%,
      color-mix(in oklab, var(--pp-bg), transparent 16%) 40%,
      color-mix(in oklab, var(--pp-bg), transparent 44%) 62%,
      color-mix(in oklab, var(--pp-bg), transparent 78%) 84%,
      transparent 96%),
    linear-gradient(0deg,
      color-mix(in oklab, var(--pp-bg), transparent 46%) 0%,
      transparent 30%);
}
[data-design="a"] .pp-hero__inner {
  position: relative; z-index: 1;
  max-width: 920px;
}
[data-design="a"] .pp-hero__title {
  font-family: var(--pp-font-sans);
  font-size: clamp(30px, 6vw, 64px);
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--pp-ink);
  margin: 0 0 24px;
  overflow-wrap: anywhere;
  text-wrap: balance;
}
[data-design="a"] .pp-hero__subtitle {
  font-family: var(--pp-font-serif);
  font-size: clamp(17px, 2.6vw, 22px);
  line-height: 1.5;
  color: var(--pp-ink-2);
  margin: 0 0 20px;
  max-width: 38ch;
}
[data-design="a"] .pp-hero__proof {
  font-family: var(--pp-font-mono);
  font-size: clamp(11.5px, 2.1vw, 13px);
  letter-spacing: 0.02em;
  line-height: 1.6;
  color: var(--pp-muted);
  margin: 0;
  overflow-wrap: anywhere;
}

/* ==========================================================================
   ELEMENT 6 — Animated pointer (hero → consultation)
   ========================================================================== */
[data-design="a"] .pp-pointer {
  display: flex; justify-content: center;
  padding: clamp(32px, 7vw, 72px) 16px clamp(48px, 9vw, 88px);
  color: var(--pp-muted);
}
[data-design="a"] .pp-pointer__hit {
  display: inline-flex; flex-direction: column; align-items: center;
  gap: 14px;
  text-decoration: none; color: currentColor;
  opacity: 0.78;
  transition: opacity 320ms ease;
}
[data-design="a"] .pp-pointer__hit:hover,
[data-design="a"] .pp-pointer__hit:focus-visible { opacity: 1; outline: none; }
[data-design="a"] .pp-pointer__rule {
  display: block; width: 1px; height: 48px;
  background: currentColor;
  transform-origin: top center;
  animation: pp-pointer-draw 5s ease-in-out infinite;
}
[data-design="a"] .pp-pointer__label {
  font-family: var(--pp-font-mono);
  font-size: 12px; letter-spacing: 0.16em;
  text-transform: uppercase; opacity: 0.85;
}
[data-design="a"] .pp-pointer__chevron {
  display: block; color: var(--pp-accent);
  animation: pp-pointer-breath 5s ease-in-out infinite;
}
@keyframes pp-pointer-draw {
  0%, 100% { transform: scaleY(0.6); opacity: 0.35; }
  50%      { transform: scaleY(1);   opacity: 0.85; }
}
@keyframes pp-pointer-breath {
  0%, 100% { transform: translateY(-2px); opacity: 0.6; }
  50%      { transform: translateY(4px);  opacity: 1; }
}

/* ==========================================================================
   ELEMENT 5 — The qualifying consultation funnel
   ========================================================================== */
[data-design="a"] .pp-funnel-wrap {
  padding: clamp(56px, 11vw, 112px) clamp(20px, 4vw, 56px);
  background: var(--pp-bg-2);
  border-top: 1px solid var(--pp-hairline);
}
[data-design="a"] .pp-funnel-head { max-width: 640px; margin-bottom: var(--pp-block); }
[data-design="a"] .pp-funnel-title {
  font-family: var(--pp-font-sans);
  font-size: clamp(24px, 3.4vw, 36px);
  font-weight: 500; letter-spacing: -0.02em;
  color: var(--pp-ink); margin: 0 0 16px;
  text-wrap: balance;
}
[data-design="a"] .pp-funnel-lede {
  font-family: var(--pp-font-serif);
  font-size: 17px; line-height: 1.55;
  color: var(--pp-ink-2);
  max-width: 60ch;
}
[data-design="a"] .pp-funnel {
  position: relative;
  max-width: 640px;
  background: var(--pp-surface);
  border: 1px solid var(--pp-hairline);
  border-radius: var(--pp-r-card);
  padding: clamp(20px, 4vw, 32px);
}
[data-design="a"] .pp-funnel__rail {
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: center; gap: 12px; margin-bottom: 24px;
  font-family: var(--pp-font-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--pp-muted);
}
[data-design="a"] .pp-funnel__pos { color: var(--pp-ink); }
[data-design="a"] .pp-funnel__matter { color: var(--pp-faint); text-align: right; }
[data-design="a"] .pp-funnel__bar {
  grid-column: 1 / -1; height: 1px;
  background: var(--pp-hairline);
  position: relative; overflow: hidden;
}
[data-design="a"] .pp-funnel__bar-fill {
  position: absolute; inset: 0 auto 0 0;
  background: var(--pp-accent); width: 20%;
  transition: width var(--pp-d-pour) var(--pp-ease-draw);
}
[data-design="a"] .pp-funnel__step { border: 0; padding: 0; margin: 0; display: none; min-inline-size: 0; }
[data-design="a"] .pp-funnel__step[data-active="true"] {
  display: block;
  animation: pp-step-in var(--pp-d-pour) var(--pp-ease-stream);
}
@keyframes pp-step-in {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}
[data-design="a"] .pp-funnel__legend {
  font-family: var(--pp-font-serif);
  font-size: clamp(19px, 3vw, 22px);
  color: var(--pp-ink); margin-bottom: 18px; padding: 0;
  line-height: 1.35;
}
[data-design="a"] .pp-funnel__opts { display: grid; gap: 8px; }
[data-design="a"] .pp-funnel__opt {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; border: 1px solid var(--pp-hairline);
  border-radius: var(--pp-r-chip); cursor: pointer;
  font-family: var(--pp-font-sans); font-size: 15px; color: var(--pp-ink-2);
  min-height: 44px;
  transition: border-color var(--pp-d-tick) var(--pp-ease-snap),
              color var(--pp-d-tick) var(--pp-ease-snap),
              background var(--pp-d-tick) var(--pp-ease-snap);
}
[data-design="a"] .pp-funnel__opt:hover { border-color: var(--pp-accent); color: var(--pp-ink); }
[data-design="a"] .pp-funnel__opt input { accent-color: var(--pp-accent); flex: 0 0 auto; }
[data-design="a"] .pp-funnel__opt:has(input:checked) {
  border-color: var(--pp-accent); color: var(--pp-ink);
  background: color-mix(in oklab, var(--pp-accent), transparent 92%);
}
[data-design="a"] .pp-funnel__opt:focus-within {
  border-color: var(--pp-accent);
  box-shadow: 0 0 0 1px var(--pp-accent);
}
[data-design="a"] .pp-funnel__note {
  font-family: var(--pp-font-sans);
  font-size: 13px; line-height: 1.55;
  color: var(--pp-muted);
  margin-top: 16px;
  padding-left: 12px;
  border-left: 1px solid var(--pp-hairline-2);
}
[data-design="a"] .pp-funnel__rows { display: grid; gap: 16px; margin-top: 18px; }
[data-design="a"] .pp-field { display: grid; gap: 6px; }
[data-design="a"] .pp-field[hidden] { display: none; }
[data-design="a"] .pp-field__label {
  font-family: var(--pp-font-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--pp-muted);
}
[data-design="a"] .pp-field input,
[data-design="a"] .pp-field textarea {
  width: 100%; box-sizing: border-box;
  background: transparent; border: 0;
  border-bottom: 1px solid var(--pp-hairline);
  padding: 10px 0;
  font-family: var(--pp-font-sans); font-size: 16px;
  color: var(--pp-ink);
  transition: border-color var(--pp-d-tick) var(--pp-ease-snap);
}
[data-design="a"] .pp-field textarea {
  resize: vertical; min-height: 88px; line-height: 1.5;
}
[data-design="a"] .pp-field input::placeholder,
[data-design="a"] .pp-field textarea::placeholder { color: var(--pp-faint); }
[data-design="a"] .pp-field input:focus,
[data-design="a"] .pp-field textarea:focus {
  outline: none; border-bottom-color: var(--pp-accent); border-bottom-width: 2px;
}
[data-design="a"] .pp-funnel__helper {
  font-family: var(--pp-font-mono); font-size: 12px;
  color: var(--pp-critical); margin-top: 12px;
}
[data-design="a"] .pp-funnel__helper[hidden] { display: none; }
[data-design="a"] .pp-funnel__nav {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 28px; gap: 12px;
}
[data-design="a"] .pp-btn {
  font-family: var(--pp-font-sans); font-size: 14px; font-weight: 500;
  padding: 13px 20px; border-radius: var(--pp-r-chip); cursor: pointer;
  border: 1px solid transparent; text-decoration: none;
  min-height: 44px;
  transition: transform var(--pp-d-tick) var(--pp-ease-snap),
              background var(--pp-d-tick) var(--pp-ease-snap),
              border-color var(--pp-d-tick) var(--pp-ease-snap);
}
[data-design="a"] .pp-btn--primary { background: var(--pp-accent); color: var(--pp-bg); }
[data-design="a"] .pp-btn--primary:hover { background: color-mix(in oklab, var(--pp-accent), white 8%); }
[data-design="a"] .pp-btn--primary:active { transform: translateY(1px); background: var(--pp-accent-2); }
[data-design="a"] .pp-btn--primary:focus-visible { outline: 2px solid var(--pp-ink); outline-offset: 2px; }
[data-design="a"] .pp-btn--primary:disabled,
[data-design="a"] .pp-btn--primary[disabled] {
  background: var(--pp-hairline); color: var(--pp-faint); cursor: not-allowed;
}
[data-design="a"] .pp-btn--ghost {
  background: transparent; color: var(--pp-ink-2); border-color: var(--pp-hairline);
}
[data-design="a"] .pp-btn--ghost:hover { border-color: var(--pp-accent); color: var(--pp-ink); }
[data-design="a"] .pp-btn--ghost:focus-visible { outline: 2px solid var(--pp-accent); outline-offset: 2px; }
[data-design="a"] .pp-btn--ghost[hidden] { display: none; }
[data-design="a"] .pp-btn[hidden] { display: none; }

[data-design="a"] .pp-funnel__filed {
  margin-top: 24px; padding: 20px;
  background: var(--pp-bg-2); border: 1px solid var(--pp-accent);
  border-radius: var(--pp-r-chip);
  animation: pp-filed-in var(--pp-d-pour) var(--pp-ease-stream);
}
[data-design="a"] .pp-funnel__filed[hidden] { display: none; }
[data-design="a"] .pp-funnel__cite {
  font-family: var(--pp-font-mono); font-size: 13px;
  color: var(--pp-ink); margin: 8px 0 0; line-height: 1.5;
  overflow-wrap: anywhere;
}
[data-design="a"] .pp-funnel__followup {
  font-family: var(--pp-font-serif); font-size: 15px;
  color: var(--pp-ink-2); margin: 12px 0 0; line-height: 1.55;
}
[data-design="a"] .pp-funnel__followup a { color: var(--pp-accent); }
@keyframes pp-filed-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
[data-design="a"] .pp-intake-warning {
  max-width: 640px;
  margin: 18px 0 0;
  font-family: var(--pp-font-sans);
  font-size: 13px; line-height: 1.55;
  color: var(--pp-muted);
}

/* ==========================================================================
   PRACTICE AREAS — "Indexed authorities" folio  (Element 3 motion on intro)
   ========================================================================== */
[data-design="a"] .pp-folio-wrap {
  padding: clamp(56px, 11vw, 112px) clamp(20px, 4vw, 56px);
  border-top: 1px solid var(--pp-hairline);
  max-width: 1120px; margin: 0 auto;
}
[data-design="a"] .pp-folio-head { margin-bottom: var(--pp-block); max-width: 720px; }
[data-design="a"] .pp-folio-title {
  font-family: var(--pp-font-sans);
  font-size: clamp(24px, 3.2vw, 36px);
  font-weight: 500; letter-spacing: -0.02em;
  color: var(--pp-ink); margin: 0 0 16px;
  text-wrap: balance;
}
[data-design="a"] .pp-folio-lede {
  font-family: var(--pp-font-serif);
  font-size: 17px; line-height: 1.55;
  color: var(--pp-ink-2); max-width: 60ch;
}
[data-design="a"] .pp-folio { list-style: none; margin: 0; padding: 0; }
[data-design="a"] .pp-folio-row { border-top: 1px solid var(--pp-hairline); }
[data-design="a"] .pp-folio-row:last-child { border-bottom: 1px solid var(--pp-hairline); }
[data-design="a"] .pp-folio-row__head {
  width: 100%; background: transparent; border: 0; cursor: pointer;
  display: grid; grid-template-columns: 48px 1fr auto auto;
  align-items: center; gap: 16px;
  padding: 24px 4px; text-align: left;
  font-family: var(--pp-font-serif);
  font-size: clamp(19px, 2.6vw, 22px);
  color: var(--pp-ink);
}
[data-design="a"] .pp-folio-row__index {
  font-family: var(--pp-font-mono); font-size: 11px;
  letter-spacing: 0.08em; color: var(--pp-muted);
}
[data-design="a"] .pp-folio-row__title { display: block; }
[data-design="a"] .pp-folio-row__rule {
  display: block; height: 1px; background: var(--pp-hairline);
  transform: scaleX(0); transform-origin: left center;
  transition: transform var(--pp-d-draw) var(--pp-ease-draw),
              background var(--pp-d-draw) var(--pp-ease-draw);
  min-width: 60px; width: 100%;
}
[data-design="a"] .pp-folio-row[data-open="true"] .pp-folio-row__rule {
  transform: scaleX(1); background: var(--pp-accent);
}
[data-design="a"] .pp-folio-row__tag {
  font-family: var(--pp-font-mono); font-size: 11px;
  letter-spacing: 0.04em; color: var(--pp-muted);
  padding: 3px 8px; border: 1px solid var(--pp-hairline);
  border-radius: var(--pp-r-chip); white-space: nowrap;
}
[data-design="a"] .pp-folio-row__head[aria-expanded="true"] .pp-folio-row__tag {
  border-color: var(--pp-accent-2); color: var(--pp-ink-2);
}
[data-design="a"] .pp-folio-row__body {
  font-family: var(--pp-font-serif);
  font-size: 17px; line-height: 1.6;
  color: var(--pp-ink-2);
  padding: 0 4px 24px 64px; max-width: 64ch;
}
[data-design="a"] .pp-folio-row__body[hidden] { display: none; }
[data-design="a"] .pp-folio-row__body p + p { margin-top: var(--pp-line); }

/* ==========================================================================
   ABOUT — "The author column"
   ========================================================================== */
[data-design="a"] .pp-about {
  border-top: 1px solid var(--pp-hairline);
  background: var(--pp-bg-2);
}
[data-design="a"] .pp-about__inner {
  max-width: 1120px; margin: 0 auto;
  padding: clamp(56px, 11vw, 112px) clamp(20px, 4vw, 56px);
  display: grid; gap: clamp(32px, 6vw, 64px);
  grid-template-columns: 1fr;
}
[data-design="a"] .pp-about__title {
  font-family: var(--pp-font-sans);
  font-size: clamp(24px, 3.2vw, 36px);
  font-weight: 500; letter-spacing: -0.02em;
  color: var(--pp-ink); margin: 0 0 24px;
  text-wrap: balance;
}
[data-design="a"] .pp-about__bio {
  font-family: var(--pp-font-serif);
  font-size: clamp(17px, 2.4vw, 19px); line-height: 1.6;
  color: var(--pp-ink-2);
  max-width: 62ch;
}
[data-design="a"] .pp-about__bio p + p { margin-top: var(--pp-line); }
[data-design="a"] .pp-about__meta { align-self: start; }
[data-design="a"] .pp-meta-list { margin: 0; padding: 0; }
[data-design="a"] .pp-meta-row {
  display: grid; gap: 4px;
  padding: 16px 0;
  border-top: 1px solid var(--pp-hairline);
}
[data-design="a"] .pp-meta-row:last-child { border-bottom: 1px solid var(--pp-hairline); }
[data-design="a"] .pp-meta-row dt {
  font-family: var(--pp-font-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--pp-muted);
}
[data-design="a"] .pp-meta-row dd {
  margin: 0;
  font-family: var(--pp-font-sans); font-size: 15px;
  line-height: 1.55; color: var(--pp-ink);
}

/* ==========================================================================
   JURISDICTIONS — ELEMENT 4 motion (connecting hairline + ambient pulse)
   ========================================================================== */
[data-design="a"] .pp-juris-wrap {
  padding: clamp(56px, 11vw, 112px) clamp(20px, 4vw, 56px);
  border-top: 1px solid var(--pp-hairline);
  max-width: 1120px; margin: 0 auto;
}
[data-design="a"] .pp-juris { list-style: none; margin: 0; padding: 0; }
[data-design="a"] .pp-juris-row {
  display: grid;
  grid-template-columns: 48px 1fr auto auto;
  align-items: center; gap: 16px;
  padding: 24px 4px;
  border-top: 1px solid var(--pp-hairline);
}
[data-design="a"] .pp-juris-row:last-child { border-bottom: 1px solid var(--pp-hairline); }
[data-design="a"] .pp-juris-row__index {
  font-family: var(--pp-font-mono); font-size: 11px;
  letter-spacing: 0.08em; color: var(--pp-muted);
}
[data-design="a"] .pp-juris-row__body { display: grid; gap: 4px; min-width: 0; }
[data-design="a"] .pp-juris-row__name {
  font-family: var(--pp-font-serif);
  font-size: clamp(18px, 2.4vw, 21px);
  color: var(--pp-ink);
}
[data-design="a"] .pp-juris-row__note {
  font-family: var(--pp-font-sans); font-size: 14px;
  color: var(--pp-muted); line-height: 1.5;
}
[data-design="a"] .pp-juris-row__rule {
  display: block; height: 1px; background: var(--pp-hairline);
  min-width: 48px; width: 100%;
  transform-origin: left center;
}
/* the connecting hairline + ambient pulse runs when the section is in view */
[data-design="a"] .pp-juris.is-live .pp-juris-row__rule {
  animation: pp-ambient-pulse 14s var(--pp-ease-stream) infinite;
  animation-delay: calc(var(--row, 0) * 1.6s);
}
@keyframes pp-ambient-pulse {
  0%, 8%   { background: var(--pp-hairline); }
  12%, 18% { background: var(--pp-accent-2); }
  22%, 100%{ background: var(--pp-hairline); }
}
[data-design="a"] .pp-juris-row__pin {
  font-family: var(--pp-font-mono); font-size: 11px;
  letter-spacing: 0.04em; color: var(--pp-muted);
  padding: 3px 8px; border: 1px solid var(--pp-hairline);
  border-radius: var(--pp-r-chip); white-space: nowrap;
}

/* ==========================================================================
   FOOTER / IMPRINT
   ========================================================================== */
[data-design="a"] .pp-footer {
  border-top: 1px solid var(--pp-hairline);
  background: var(--pp-bg);
  padding: clamp(48px, 8vw, 80px) clamp(20px, 4vw, 56px) clamp(40px, 6vw, 56px);
}
[data-design="a"] .pp-footer__inner {
  max-width: 1120px; margin: 0 auto;
  display: flex; flex-wrap: wrap; gap: 20px 48px;
  justify-content: space-between; align-items: flex-start;
}
[data-design="a"] .pp-footer__id { display: grid; gap: 6px; }
[data-design="a"] .pp-footer__firm {
  font-family: var(--pp-font-sans); font-size: 16px; font-weight: 500;
  color: var(--pp-ink);
}
[data-design="a"] .pp-footer__line {
  font-family: var(--pp-font-mono); font-size: 12px;
  letter-spacing: 0.04em; color: var(--pp-muted);
}
[data-design="a"] .pp-footer__contact { display: grid; gap: 6px; }
[data-design="a"] .pp-footer__contact a {
  font-family: var(--pp-font-mono); font-size: 14px;
  color: var(--pp-ink); text-decoration: none;
}
[data-design="a"] .pp-footer__contact a:hover { color: var(--pp-accent); }
[data-design="a"] .pp-footer__addr {
  font-family: var(--pp-font-mono); font-size: 12px;
  color: var(--pp-muted);
}
[data-design="a"] .pp-imprint {
  max-width: 1120px; margin: clamp(32px, 6vw, 48px) auto 0;
  padding-top: 24px;
  border-top: 1px solid var(--pp-hairline);
}
[data-design="a"] .pp-imprint__disclaimer {
  font-family: var(--pp-font-sans); font-size: 13px;
  line-height: 1.6; color: var(--pp-muted);
  max-width: 72ch; margin: 0 0 12px;
}
[data-design="a"] .pp-imprint__line {
  font-family: var(--pp-font-mono); font-size: 12px;
  letter-spacing: 0.02em; color: var(--pp-muted);
  margin: 0 0 6px;
}
[data-design="a"] .pp-imprint__copy {
  font-family: var(--pp-font-mono); font-size: 12px;
  letter-spacing: 0.02em; color: var(--pp-faint);
  margin: 12px 0 0;
}

/* ==========================================================================
   TOKEN-STREAM reveal (Element 3 motion) — used on data-stream blocks
   ========================================================================== */
[data-design="a"] [data-stream] .pp-tok {
  opacity: 0; transform: translateY(4px);
  display: inline-block;
  animation: pp-tok-in var(--pp-d-stream) var(--pp-ease-stream) forwards;
  animation-delay: calc(var(--i, 0) * 26ms);
  animation-play-state: paused;
}
@keyframes pp-tok-in {
  to { opacity: 1; transform: translateY(0); }
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (min-width: 900px) {
  [data-design="a"] .pp-about__inner {
    grid-template-columns: minmax(0, 1.55fr) minmax(260px, 1fr);
    align-items: start;
  }
  [data-design="a"] .pp-about__meta { position: sticky; top: 96px; }
}
@media (max-width: 620px) {
  [data-design="a"] .pp-header__bar { height: 60px; padding: 0 16px; }
  [data-design="a"] .pp-header__stream { gap: 32px; }
  [data-design="a"] .pp-folio-row__head { grid-template-columns: 36px 1fr auto; }
  [data-design="a"] .pp-folio-row__rule { display: none; }
  [data-design="a"] .pp-folio-row__body { padding-left: 44px; }
  [data-design="a"] .pp-juris-row { grid-template-columns: 32px 1fr auto; }
  [data-design="a"] .pp-juris-row__rule { display: none; }
  [data-design="a"] .pp-funnel__nav { flex-wrap: wrap; }
  [data-design="a"] .pp-btn { flex: 1 1 auto; }
  /* hero at mobile — the text spans the full width, so the ledger reads as
     quieter behind-text texture. A stronger bottom-up scrim keeps the headline
     and proof column crisp; the ledger structure still reads clearly top + at
     the row ends (edge-density floor still clears with margin). */
  [data-design="a"] .pp-hero::after {
    background:
      linear-gradient(180deg,
        transparent 0%,
        color-mix(in oklab, var(--pp-bg), transparent 58%) 20%,
        color-mix(in oklab, var(--pp-bg), transparent 30%) 44%,
        color-mix(in oklab, var(--pp-bg), transparent 26%) 78%,
        color-mix(in oklab, var(--pp-bg), transparent 48%) 100%);
  }
}
@media (max-width: 380px) {
  [data-design="a"] .pp-folio-row__tag,
  [data-design="a"] .pp-juris-row__pin { display: none; }
}

/* ==========================================================================
   REDUCED MOTION — pause / replace every animation
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .pp-header__stream { animation: none; transform: translateX(-12%); }
  [data-design="a"] .pp-logo__mark::after { animation: none; opacity: 1; }
  [data-design="a"] .pp-drawer__panel { animation: none; transform: none; opacity: 1; }
  [data-design="a"] .pp-cta__cite { animation: none; opacity: 0.8; }
  [data-design="a"] .pp-cta__rule { transition: none; }
  /* the ledger substrate stays fully present + drawn — just not breathing.
     transform stays at the 1.04 overscan baseline so it still fills the hero. */
  [data-design="a"] .pp-hero__ledger {
    animation: none; opacity: 0.95; transform: scale(1.04);
  }
  [data-design="a"] .pp-ledger__head-tag,
  [data-design="a"] .pp-ledger__rule {
    animation: none; transform: scaleX(1);
  }
  [data-design="a"] .pp-ledger__chip {
    animation: none; opacity: 1; transform: none;
  }
  [data-design="a"] .pp-pointer__rule,
  [data-design="a"] .pp-pointer__chevron { animation: none; opacity: 0.8; }
  [data-design="a"] .pp-funnel__step[data-active="true"] { animation: none; }
  [data-design="a"] .pp-funnel__filed { animation: none; }
  [data-design="a"] .pp-funnel__bar-fill { transition: none; }
  [data-design="a"] .pp-folio-row__rule { transition: none; }
  [data-design="a"] .pp-juris.is-live .pp-juris-row__rule { animation: none; }
  [data-design="a"] [data-stream] .pp-tok {
    animation: none; opacity: 1; transform: none;
  }
}

/* ==========================================================================
   DEFENSIVE OVERFLOW BLOCK — no horizontal scroll at any width 320px+
   ========================================================================== */
[data-design="a"].dq-design, [data-design="a"] .dq-design { max-width: 100%; overflow-x: clip; }
[data-design="a"] * { min-width: 0; }
[data-design="a"] img, [data-design="a"] svg:not([data-keep-size]) { max-width: 100%; height: auto; }
