/* ============================================================
   DESIGN B — Opinionated Counsel (remapped to [data-design="b"])
   Law Office of Roger K. Evans, PC · Salem, OR
   Signature: chunky display sans · sapphire stamp · square corners ·
   block-shadows (no blur) · declarative motion (snap / stamp / bite)
   ============================================================ */

/* ---- Tokens ---- */
[data-design="b"] {
  --oc-canvas: #F5F5F4;
  --oc-paper: #FFFFFF;
  --oc-ink: #171717;
  --oc-ink-2: #3F3F3E;
  --oc-muted: #7A7A78;
  --oc-rule: #1A1A1A;
  --oc-soft: #E5E4E1;
  --oc-stamp: #1A47B8;
  --oc-stamp-deep: #102E78;
  --oc-stamp-on: #FFFFFF;
  --oc-warn: #C2410C;
  --oc-warn-soft: #FBE9DC;
  --oc-success: #15803D;

  /* Exposed slot-scope primary */
  --design-b-primary: var(--oc-stamp);

  --oc-font-display: "Söhne Breit", "Inter Display", -apple-system,
                     BlinkMacSystemFont, "SF Pro Display", system-ui, sans-serif;
  --oc-font-body: "Söhne", "Inter", -apple-system,
                  BlinkMacSystemFont, "SF Pro Text", system-ui, sans-serif;
  --oc-font-mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, Menlo, monospace;

  --oc-space-hair: 2px;
  --oc-space-tick: 4px;
  --oc-space-bite: 8px;
  --oc-space-gap: 12px;
  --oc-space-stub: 16px;
  --oc-space-block: 24px;
  --oc-space-tile: 32px;
  --oc-space-bay: 48px;
  --oc-space-deck: 80px;
  --oc-space-yard: 128px;

  --oc-dur-snap: 120ms;
  --oc-dur-stamp: 220ms;
  --oc-dur-settle: 360ms;
  --oc-dur-breathe: 4400ms;
  --oc-dur-scrub: 22000ms;
  --oc-ease-decide: cubic-bezier(.22,.61,.36,1);
  --oc-ease-stamp: cubic-bezier(.34,1.42,.64,1);
  --oc-ease-bite: cubic-bezier(.55,.06,.68,.19);
  --oc-ease-scrub: cubic-bezier(.65,.05,.35,.95);

  --oc-radius-sm: 4px;
  --oc-radius-md: 8px;
  --oc-radius-lg: 12px;
  --oc-radius-stamp: 2px;

  --oc-elev-stamp: 0 4px 0 0 var(--oc-rule);

  background: var(--oc-canvas);
  color: var(--oc-ink);
  font-family: var(--oc-font-body);
  -webkit-font-smoothing: antialiased;
}
[data-design="b"].dq-design { display: block; }
[data-design="b"] *, [data-design="b"] *::before, [data-design="b"] *::after { box-sizing: border-box; }

/* ---- E1 · Header ---- */
[data-design="b"].oc-header {
  position: sticky; top: 0; z-index: 20;
  background: var(--oc-canvas); border-bottom: 2px solid var(--oc-rule);
}
[data-design="b"] .rf-header__bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--oc-space-stub) clamp(20px, 4vw, 48px);
  gap: var(--oc-space-stub); box-sizing: border-box; max-width: 100%;
}
[data-design="b"] .oc-logo { text-decoration: none; color: var(--oc-ink); }
[data-design="b"] .oc-logo__mark {
  font-family: var(--oc-font-display); font-weight: 800;
  font-size: clamp(20px, 2.4vw, 26px); letter-spacing: -0.015em; line-height: 1;
}
[data-design="b"] .oc-hamburger {
  appearance: none; background: transparent;
  border: 2px solid var(--oc-rule); border-radius: var(--oc-radius-sm);
  padding: 10px 12px; min-width: 44px; min-height: 44px;
  display: inline-flex; flex-direction: column; gap: 4px; justify-content: center;
  cursor: pointer;
  transition: background var(--oc-dur-snap) var(--oc-ease-decide),
              transform var(--oc-dur-snap) var(--oc-ease-bite);
}
[data-design="b"] .oc-hamburger__bar { display: block; width: 22px; height: 2px; background: var(--oc-ink); }
[data-design="b"] .oc-hamburger:hover { background: var(--oc-soft); }
[data-design="b"] .oc-hamburger:active { transform: translateY(1px); }
[data-design="b"] .oc-hamburger[aria-expanded="true"] { background: var(--oc-ink); border-color: var(--oc-ink); }
[data-design="b"] .oc-hamburger[aria-expanded="true"] .oc-hamburger__bar { background: var(--oc-canvas); }

[data-design="b"] .oc-scrubber { position: relative; height: 2px; background: var(--oc-soft); overflow: hidden; }
[data-design="b"] .oc-scrubber__head {
  position: absolute; inset: 0 auto 0 0; width: 18%;
  background: linear-gradient(90deg, transparent 0%, var(--oc-ink) 22%,
    var(--oc-stamp) 60%, var(--oc-stamp) 78%, transparent 100%);
  animation: oc-header-scrub var(--oc-dur-scrub) var(--oc-ease-scrub) infinite;
  will-change: transform;
}
@keyframes oc-header-scrub { 0% { transform: translateX(-30%); } 100% { transform: translateX(620%); } }

/* ---- Drawer ---- */
[data-design="b"].oc-drawer {
  position: fixed; inset: 0; background: var(--oc-canvas); z-index: 30;
  display: flex; flex-direction: column;
  transform: translateY(-100%);
  transition: transform var(--oc-dur-settle) var(--oc-ease-decide);
}
[data-design="b"].oc-drawer[data-open="true"] { transform: translateY(0); }
[data-design="b"] .oc-drawer__bar {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--oc-space-stub) clamp(20px, 4vw, 48px); border-bottom: 2px solid var(--oc-rule);
}
[data-design="b"] .oc-drawer__brand { font-family: var(--oc-font-display); font-weight: 800; font-size: 22px; letter-spacing: -0.015em; }
[data-design="b"] .oc-drawer__close {
  background: transparent; border: 0; font-size: 36px; line-height: 1;
  color: var(--oc-ink); cursor: pointer; padding: 0 8px; min-width: 44px; min-height: 44px;
}
[data-design="b"] .oc-drawer__nav {
  display: flex; flex-direction: column; gap: var(--oc-space-stub);
  padding: var(--oc-space-bay) clamp(20px, 4vw, 48px);
  max-width: 100%; box-sizing: border-box; overflow-y: auto;
}
[data-design="b"] .oc-nav-link {
  font-family: var(--oc-font-display); font-weight: 800;
  font-size: clamp(36px, 7vw, 56px); letter-spacing: -0.025em; line-height: 1;
  color: var(--oc-ink); text-decoration: none; position: relative;
  padding-bottom: 6px; width: max-content; max-width: 100%;
}
[data-design="b"] .oc-nav-link::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 4px;
  width: 0; background: var(--oc-stamp);
  transition: width var(--oc-dur-settle) var(--oc-ease-decide);
}
[data-design="b"] .oc-nav-link:hover, [data-design="b"] .oc-nav-link:focus-visible { color: var(--oc-stamp); outline: none; }
[data-design="b"] .oc-nav-link:hover::after, [data-design="b"] .oc-nav-link:focus-visible::after { width: 100%; }
[data-design="b"] .oc-drawer__phone {
  font-family: var(--oc-font-mono); font-size: 17px; letter-spacing: 0.04em;
  color: var(--oc-ink-2); text-decoration: none; margin-top: var(--oc-space-bite);
  padding: 10px 0; min-height: 44px; display: inline-flex; align-items: center;
}
[data-design="b"] .oc-drawer__phone:hover { color: var(--oc-stamp); }
[data-design="b"] .oc-cta--drawer { margin-top: var(--oc-space-gap); align-self: flex-start; }

/* ---- E2 · Animated CTA ---- */
[data-design="b"] .oc-cta {
  display: inline-flex; align-items: center; gap: var(--oc-space-gap);
  font-family: var(--oc-font-display); font-weight: 800;
  font-size: clamp(17px, 1.6vw, 20px); letter-spacing: -0.015em;
  padding: 18px 26px; min-height: 44px;
  background: var(--oc-stamp); color: var(--oc-stamp-on);
  text-decoration: none; border-radius: var(--oc-radius-md);
  border: 2px solid var(--oc-rule); box-shadow: var(--oc-elev-stamp);
  transform: translateY(0);
  transition: transform var(--oc-dur-snap) var(--oc-ease-decide),
              box-shadow var(--oc-dur-snap) var(--oc-ease-decide),
              background var(--oc-dur-snap) var(--oc-ease-decide);
  animation: oc-cta-breath var(--oc-dur-breathe) var(--oc-ease-decide) infinite;
}
[data-design="b"] .oc-cta__arrow { display: inline-block; transition: transform var(--oc-dur-snap) var(--oc-ease-decide); }
[data-design="b"] .oc-cta[data-lean="true"],
[data-design="b"] .oc-cta:hover,
[data-design="b"] .oc-cta:focus-visible {
  background: var(--oc-stamp-deep); box-shadow: 0 6px 0 0 var(--oc-rule);
  transform: translateY(-2px); animation-play-state: paused; outline: none;
}
[data-design="b"] .oc-cta:hover .oc-cta__arrow,
[data-design="b"] .oc-cta:focus-visible .oc-cta__arrow { transform: translateX(8px); }
[data-design="b"] .oc-cta:active {
  transform: translateY(4px); box-shadow: 0 0 0 0 var(--oc-rule);
  transition-duration: var(--oc-dur-snap); transition-timing-function: var(--oc-ease-bite);
}
@keyframes oc-cta-breath {
  0%, 100% { box-shadow: var(--oc-elev-stamp), 0 0 0 0 var(--oc-stamp); }
  50%      { box-shadow: var(--oc-elev-stamp), 0 0 0 8px rgba(26,71,184,0.18); }
}

/* ---- HERO · 3 text + ONE ambient backdrop (E3 grammar, no directional primitive) ---- */
[data-design="b"] .oc-hero {
  position: relative; overflow: hidden;
  background: var(--oc-canvas); border-bottom: 2px solid var(--oc-rule);
  padding: clamp(72px, 12vh, 144px) clamp(20px, 4vw, 48px);
  min-height: clamp(420px, 68vh, 760px);
  display: flex; align-items: center;
}
[data-design="b"] .oc-hero__backdrop { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
[data-design="b"] .oc-hero__wash {
  position: absolute; inset: -20%;
  background: radial-gradient(60% 70% at 78% 30%, rgba(26,71,184,0.16) 0%, rgba(26,71,184,0.05) 42%, transparent 72%);
  animation: oc-hero-wash 9s ease-in-out infinite alternate;
  will-change: transform, opacity;
}
[data-design="b"] .oc-hero__drift {
  position: absolute; font-family: var(--oc-font-display); font-weight: 800;
  letter-spacing: -0.04em; line-height: 0.8; text-transform: lowercase;
  color: var(--oc-ink); white-space: nowrap; user-select: none;
  font-size: clamp(110px, 26vw, 360px);
}
/* three coprime drift cycles — continuous, perceptible ambient motion */
[data-design="b"] .oc-hero__drift--1 {
  top: -4%; left: -6%; opacity: 0.05;
  animation: oc-hero-drift-1 19s var(--oc-ease-scrub) infinite alternate;
}
[data-design="b"] .oc-hero__drift--2 {
  bottom: -16%; right: -10%; opacity: 0.06; color: var(--oc-stamp);
  animation: oc-hero-drift-2 23s var(--oc-ease-scrub) infinite alternate;
}
[data-design="b"] .oc-hero__drift--3 {
  top: 34%; left: 30%; opacity: 0.04; font-size: clamp(80px, 16vw, 220px);
  animation: oc-hero-drift-3 17s var(--oc-ease-scrub) infinite alternate;
}
@keyframes oc-hero-drift-1 { from { transform: translate3d(0,0,0); } to { transform: translate3d(48px, 26px, 0); } }
@keyframes oc-hero-drift-2 { from { transform: translate3d(0,0,0); } to { transform: translate3d(-58px, -30px, 0); } }
@keyframes oc-hero-drift-3 { from { transform: translate3d(0,0,0); } to { transform: translate3d(34px, -40px, 0); } }
@keyframes oc-hero-wash {
  0%   { transform: translate3d(-3%, -2%, 0) scale(1);    opacity: 0.85; }
  100% { transform: translate3d(4%, 3%, 0) scale(1.12);   opacity: 1; }
}
[data-design="b"] .oc-hero__inner { position: relative; z-index: 1; max-width: 18ch; }
[data-design="b"] .oc-hero__headline {
  font-family: var(--oc-font-display); font-weight: 800;
  font-size: clamp(48px, 9vw, 132px); letter-spacing: -0.035em; line-height: 0.94;
  margin: 0; color: var(--oc-ink); opacity: 1;
}
[data-design="b"] .oc-hero__subtitle {
  font-family: var(--oc-font-body); font-weight: 500;
  font-size: clamp(18px, 2.4vw, 26px); line-height: 1.4;
  margin: var(--oc-space-block) 0 0; color: var(--oc-ink-2); max-width: 30ch; opacity: 1;
}
[data-design="b"] .oc-hero__proof {
  font-family: var(--oc-font-mono); font-size: clamp(13px, 1.4vw, 15px);
  letter-spacing: 0.04em; line-height: 1.5;
  margin: var(--oc-space-stub) 0 0; color: var(--oc-muted); max-width: 46ch; opacity: 1;
}

/* ---- E6 · Pointer (wayfinding; VISIBLY rendered: opacity 1, height >= 8px) ---- */
[data-design="b"] .oc-pointer {
  display: flex; align-items: center; gap: clamp(12px, 3vw, 28px);
  padding: clamp(20px, 4vw, 32px) clamp(20px, 4vw, 48px);
  background: var(--oc-paper); border-bottom: 2px solid var(--oc-rule);
  text-decoration: none; color: var(--oc-ink);
  opacity: 1; min-height: 64px;
}
[data-design="b"] .oc-pointer__label {
  font-family: var(--oc-font-display); font-weight: 800;
  font-size: clamp(17px, 2vw, 26px); letter-spacing: -0.01em;
  white-space: nowrap; flex-shrink: 0;
}
[data-design="b"] .oc-pointer__rule {
  position: relative; flex: 1; height: 4px; min-width: 40px;
  background: var(--oc-soft); border-radius: 2px; overflow: hidden;
}
[data-design="b"] .oc-pointer__rule-fill {
  position: absolute; inset: 0 auto 0 0; width: 30%;
  background: var(--oc-stamp);
  animation: oc-pointer-draw 5.5s var(--oc-ease-scrub) infinite;
}
[data-design="b"] .oc-pointer__chev {
  font-family: var(--oc-font-display); font-weight: 800;
  font-size: clamp(22px, 3vw, 34px); color: var(--oc-stamp); flex-shrink: 0;
  animation: oc-pointer-breath 5s ease-in-out infinite;
}
[data-design="b"] .oc-pointer:hover .oc-pointer__chev,
[data-design="b"] .oc-pointer:focus-visible .oc-pointer__chev { color: var(--oc-stamp-deep); }
@keyframes oc-pointer-draw { 0% { width: 8%; } 60% { width: 100%; } 100% { width: 100%; opacity: 0.35; } }
@keyframes oc-pointer-breath { 0%, 100% { transform: translateY(0); opacity: 0.7; } 50% { transform: translateY(5px); opacity: 1; } }

/* ---- E5 · Funnel ---- */
[data-design="b"] .oc-funnel { background: var(--oc-canvas); padding: var(--oc-space-deck) clamp(20px, 4vw, 48px); }
[data-design="b"] .oc-funnel__kicker {
  font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--oc-muted); margin: 0 0 var(--oc-space-gap);
}
[data-design="b"] .oc-funnel__title {
  font-family: var(--oc-font-display); font-weight: 800;
  font-size: clamp(36px, 6vw, 56px); letter-spacing: -0.025em; line-height: 1.02;
  margin: 0 0 var(--oc-space-bay); color: var(--oc-ink); max-width: 22ch;
}
[data-design="b"] .oc-funnel__progress {
  height: 4px; background: var(--oc-soft); border-radius: 0; overflow: hidden; margin-bottom: var(--oc-space-gap);
}
[data-design="b"] .oc-funnel__progress-bar {
  display: block; height: 100%; width: 25%; background: var(--oc-stamp);
  transition: width var(--oc-dur-settle) var(--oc-ease-decide);
}
[data-design="b"] .oc-funnel__progress-bar[data-step="2"] { width: 50%; }
[data-design="b"] .oc-funnel__progress-bar[data-step="3"] { width: 75%; }
[data-design="b"] .oc-funnel__progress-bar[data-step="4"] { width: 100%; }
[data-design="b"] .oc-funnel__counter {
  font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.06em;
  color: var(--oc-muted); margin: 0 0 var(--oc-space-bay);
}
[data-design="b"] .oc-funnel__form {
  background: var(--oc-paper); border: 2px solid var(--oc-rule);
  border-radius: var(--oc-radius-lg); padding: var(--oc-space-tile);
  position: relative; overflow: hidden; max-width: 100%; box-sizing: border-box;
}
[data-design="b"] .oc-funnel__step { border: 0; padding: 0; margin: 0; display: none; animation: oc-step-in var(--oc-dur-settle) var(--oc-ease-stamp); }
[data-design="b"] .oc-funnel__step[aria-hidden="false"] { display: block; }
[data-design="b"] .oc-funnel__legend {
  font-family: var(--oc-font-display); font-weight: 800;
  font-size: clamp(20px, 2.4vw, 26px); letter-spacing: -0.01em; color: var(--oc-ink);
  margin: 0 0 var(--oc-space-bay); padding: 0; max-width: 38ch;
}
[data-design="b"] .oc-funnel__tiles {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(min(220px, 100%), 1fr));
  gap: var(--oc-space-stub); margin-bottom: var(--oc-space-bay);
}
[data-design="b"] .oc-tile-radio { display: block; cursor: pointer; }
[data-design="b"] .oc-tile-radio input { position: absolute; opacity: 0; pointer-events: none; }
[data-design="b"] .oc-tile-radio__face {
  display: flex; flex-direction: column; gap: 4px;
  padding: var(--oc-space-stub); min-height: 44px;
  background: var(--oc-paper); color: var(--oc-ink);
  border: 2px solid var(--oc-rule); border-radius: var(--oc-radius-md); position: relative;
  transition: transform var(--oc-dur-stamp) var(--oc-ease-stamp),
              background var(--oc-dur-stamp) var(--oc-ease-stamp),
              color var(--oc-dur-stamp) var(--oc-ease-stamp);
}
[data-design="b"] .oc-tile-radio__face::after {
  content: "✓"; position: absolute; top: 8px; right: 10px;
  font-family: var(--oc-font-display); font-weight: 800; font-size: 18px;
  color: var(--oc-stamp-on); opacity: 0; transform: scale(0.4);
  transition: opacity var(--oc-dur-stamp) var(--oc-ease-stamp), transform var(--oc-dur-stamp) var(--oc-ease-stamp);
}
[data-design="b"] .oc-tile-radio:hover .oc-tile-radio__face { transform: translateY(-2px); background: var(--oc-soft); }
[data-design="b"] .oc-tile-radio input:focus-visible + .oc-tile-radio__face { box-shadow: 0 0 0 3px rgba(26,71,184,0.32); }
[data-design="b"] .oc-tile-radio input:checked + .oc-tile-radio__face {
  background: var(--oc-stamp); color: var(--oc-stamp-on);
  border-color: var(--oc-stamp); transform: scale(1.02) translateY(-1px);
}
[data-design="b"] .oc-tile-radio input:checked + .oc-tile-radio__face::after { opacity: 1; transform: scale(1); }
[data-design="b"] .oc-tile-radio__title { font-family: var(--oc-font-display); font-weight: 800; font-size: 17px; letter-spacing: -0.005em; }
[data-design="b"] .oc-tile-radio__meta { font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.04em; color: var(--oc-muted); }
[data-design="b"] .oc-tile-radio input:checked + .oc-tile-radio__face .oc-tile-radio__meta { color: rgba(255,255,255,0.78); }

[data-design="b"] .oc-field { display: flex; flex-direction: column; gap: var(--oc-space-bite); margin-bottom: var(--oc-space-stub); }
[data-design="b"] .oc-field__label { font-family: var(--oc-font-display); font-weight: 700; font-size: 17px; color: var(--oc-ink); }
[data-design="b"] .oc-field__input,
[data-design="b"] .oc-field__textarea {
  font-family: var(--oc-font-body); font-size: 17px;
  background: transparent; color: var(--oc-ink);
  border: 0; border-bottom: 2px solid var(--oc-rule); border-radius: 0;
  padding: 8px 0; outline: none; min-height: 44px;
  transition: border-color var(--oc-dur-snap) var(--oc-ease-decide);
  width: 100%; box-sizing: border-box;
}
[data-design="b"] .oc-field__textarea { resize: vertical; min-height: 120px; }
[data-design="b"] .oc-field__input:focus,
[data-design="b"] .oc-field__textarea:focus { border-bottom-color: var(--oc-stamp); border-bottom-width: 3px; }
[data-design="b"] .oc-field__help { font-family: var(--oc-font-mono); font-size: 13px; color: var(--oc-muted); }

[data-design="b"] .oc-funnel__nav { display: flex; gap: var(--oc-space-gap); align-items: center; flex-wrap: wrap; margin-top: var(--oc-space-bay); }
[data-design="b"] .oc-btn {
  font-family: var(--oc-font-display); font-weight: 800; font-size: 17px; letter-spacing: -0.005em;
  padding: 14px 22px; min-height: 44px; border-radius: var(--oc-radius-md);
  border: 2px solid var(--oc-rule); cursor: pointer;
  background: var(--oc-paper); color: var(--oc-ink);
  box-shadow: var(--oc-elev-stamp); transform: translateY(0);
  transition: transform var(--oc-dur-snap) var(--oc-ease-decide),
              box-shadow var(--oc-dur-snap) var(--oc-ease-decide),
              background var(--oc-dur-snap) var(--oc-ease-decide);
}
[data-design="b"] .oc-btn--primary { background: var(--oc-stamp); color: var(--oc-stamp-on); }
[data-design="b"] .oc-btn--ghost { background: transparent; box-shadow: none; border-color: transparent; color: var(--oc-ink-2); }
[data-design="b"] .oc-btn:hover:not(:disabled) { transform: translateY(-2px); box-shadow: 0 6px 0 0 var(--oc-rule); }
[data-design="b"] .oc-btn--ghost:hover:not(:disabled) { background: var(--oc-soft); box-shadow: none; }
[data-design="b"] .oc-btn:active:not(:disabled) { transform: translateY(4px); box-shadow: 0 0 0 0 var(--oc-rule); }
[data-design="b"] .oc-btn:disabled { opacity: 0.4; cursor: not-allowed; }

[data-design="b"] .oc-funnel__verdict {
  display: flex; flex-direction: column; gap: var(--oc-space-stub);
  padding: var(--oc-space-tile); border-radius: var(--oc-radius-md); border: 2px solid var(--oc-rule);
}
[data-design="b"] .oc-funnel__verdict--ok { background: var(--oc-stamp); color: var(--oc-stamp-on); border-color: var(--oc-stamp); }
[data-design="b"] .oc-funnel__verdict--decline { background: var(--oc-warn-soft); color: var(--oc-ink); border-color: var(--oc-warn); }
[data-design="b"] .oc-funnel__verdict-stamp {
  align-self: flex-start; font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.12em;
  text-transform: uppercase; padding: 4px 10px; border: 2px solid currentColor;
  border-radius: var(--oc-radius-stamp); background: rgba(255,255,255,0.12);
}
[data-design="b"] .oc-funnel__verdict-stamp--warn { background: var(--oc-warn); color: var(--oc-stamp-on); border-color: var(--oc-warn); }
[data-design="b"] .oc-funnel__verdict-title { font-family: var(--oc-font-display); font-weight: 800; font-size: clamp(26px, 4vw, 36px); letter-spacing: -0.015em; line-height: 1.05; margin: 0; }
[data-design="b"] .oc-funnel__verdict-body { font-size: 17px; line-height: 1.5; margin: 0; }
[data-design="b"] .oc-funnel__verdict-link { color: inherit; text-decoration: underline; text-underline-offset: 3px; }

@keyframes oc-step-in {
  0%   { opacity: 0; transform: translateX(24px) scale(0.98); }
  60%  { opacity: 1; transform: translateX(0) scale(1.005); }
  100% { opacity: 1; transform: translateX(0) scale(1); }
}

/* ---- E4 · Docket folio (Practice Areas) ---- */
[data-design="b"] .oc-docket { background: var(--oc-paper); padding: var(--oc-space-deck) clamp(20px, 4vw, 48px); border-top: 2px solid var(--oc-rule); border-bottom: 2px solid var(--oc-rule); }
[data-design="b"] .oc-docket__kicker { font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--oc-muted); margin: 0 0 var(--oc-space-gap); }
[data-design="b"] .oc-docket__title { font-family: var(--oc-font-display); font-weight: 800; font-size: clamp(36px, 6vw, 56px); letter-spacing: -0.025em; line-height: 1.02; margin: 0 0 var(--oc-space-bay); color: var(--oc-ink); max-width: 22ch; }
[data-design="b"] .oc-docket__list { list-style: none; margin: 0; padding: 0; max-width: 100%; box-sizing: border-box; }
[data-design="b"] .oc-docket__row {
  display: grid; grid-template-columns: 96px 1fr auto;
  align-items: start; gap: clamp(16px, 4vw, 48px);
  padding: var(--oc-space-tile) 0; border-bottom: 2px solid var(--oc-rule);
  animation: oc-b-breathe-rule 14s var(--oc-ease-scrub) infinite; position: relative;
}
[data-design="b"] .oc-docket__row:nth-child(2) { animation-delay: -3s; }
[data-design="b"] .oc-docket__row:nth-child(3) { animation-delay: -6s; }
[data-design="b"] .oc-docket__row:nth-child(4) { animation-delay: -9s; }
[data-design="b"] .oc-docket__num {
  font-family: var(--oc-font-display); font-weight: 800; font-size: 36px; letter-spacing: -0.02em;
  color: var(--oc-ink); display: inline-block; padding: 6px 10px;
  border: 2px solid var(--oc-rule); border-radius: var(--oc-radius-stamp);
  background: var(--oc-paper); line-height: 1; min-width: 56px; text-align: center;
  transition: background var(--oc-dur-stamp) var(--oc-ease-stamp),
              color var(--oc-dur-stamp) var(--oc-ease-stamp),
              transform var(--oc-dur-stamp) var(--oc-ease-stamp);
}
[data-design="b"] .oc-docket__row[data-stamped="true"] .oc-docket__num {
  background: var(--oc-stamp); color: var(--oc-stamp-on); border-color: var(--oc-stamp); transform: scale(1.06);
}
[data-design="b"] .oc-docket__body { display: flex; flex-direction: column; gap: var(--oc-space-gap); }
[data-design="b"] .oc-docket__name { font-family: var(--oc-font-display); font-weight: 700; font-size: clamp(20px, 2.4vw, 26px); letter-spacing: -0.01em; color: var(--oc-ink); }
[data-design="b"] .oc-docket__copy { font-family: var(--oc-font-body); font-size: 17px; line-height: 1.6; color: var(--oc-ink-2); margin: 0; max-width: 64ch; }
[data-design="b"] .oc-docket__meta { font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--oc-muted); white-space: nowrap; }
@keyframes oc-b-breathe-rule { 0%, 100% { border-bottom-color: var(--oc-rule); } 50% { border-bottom-color: var(--oc-soft); } }

/* ---- About / Attorney ---- */
[data-design="b"] .oc-about { background: var(--oc-canvas); padding: var(--oc-space-deck) clamp(20px, 4vw, 48px); }
[data-design="b"] .oc-about__grid { display: grid; grid-template-columns: 1fr; gap: var(--oc-space-bay); align-items: start; max-width: 100%; }
[data-design="b"] .oc-about__monolith {
  background: var(--oc-stamp); border: 2px solid var(--oc-rule); border-radius: var(--oc-radius-lg);
  aspect-ratio: 4 / 3; display: flex; align-items: center; justify-content: center; box-shadow: var(--oc-elev-stamp);
}
[data-design="b"] .oc-about__monolith-mark { font-family: var(--oc-font-display); font-weight: 800; font-size: clamp(64px, 12vw, 132px); letter-spacing: -0.04em; color: var(--oc-stamp-on); }
[data-design="b"] .oc-about__kicker { font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--oc-muted); margin: 0 0 var(--oc-space-gap); }
[data-design="b"] .oc-about__title { font-family: var(--oc-font-display); font-weight: 800; font-size: clamp(30px, 5vw, 56px); letter-spacing: -0.025em; line-height: 1.04; margin: 0 0 var(--oc-space-block); color: var(--oc-ink); }
[data-design="b"] .oc-about__lead { font-family: var(--oc-font-body); font-size: 20px; line-height: 1.6; color: var(--oc-ink-2); margin: 0 0 var(--oc-space-block); max-width: 64ch; }
[data-design="b"] .oc-about__pull { font-family: var(--oc-font-display); font-weight: 700; font-size: clamp(22px, 3vw, 36px); letter-spacing: -0.015em; line-height: 1.15; color: var(--oc-ink); margin: 0 0 var(--oc-space-bay); max-width: 26ch; }
[data-design="b"] .oc-about__vitae { margin: 0; display: flex; flex-direction: column; gap: var(--oc-space-stub); border-top: 2px solid var(--oc-rule); padding-top: var(--oc-space-block); }
[data-design="b"] .oc-about__vitae-row { display: grid; grid-template-columns: 1fr; gap: var(--oc-space-tick); }
[data-design="b"] .oc-about__vitae dt { font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--oc-muted); margin: 0; }
[data-design="b"] .oc-about__vitae dd { font-family: var(--oc-font-body); font-size: 17px; line-height: 1.5; color: var(--oc-ink); margin: 0; }

/* ---- Office / Jurisdictions + conversion CTA band ---- */
[data-design="b"] .oc-office { background: var(--oc-ink); color: var(--oc-canvas); padding: var(--oc-space-deck) clamp(20px, 4vw, 48px); }
[data-design="b"] .oc-office__grid { display: grid; grid-template-columns: 1fr; gap: var(--oc-space-bay); align-items: start; max-width: 100%; }
[data-design="b"] .oc-office__kicker { font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(245,245,244,0.6); margin: 0 0 var(--oc-space-gap); }
[data-design="b"] .oc-office__title { font-family: var(--oc-font-display); font-weight: 800; font-size: clamp(36px, 6vw, 56px); letter-spacing: -0.025em; line-height: 1.02; margin: 0 0 var(--oc-space-block); color: var(--oc-canvas); }
[data-design="b"] .oc-office__line { font-family: var(--oc-font-body); font-size: 18px; line-height: 1.5; margin: 0 0 var(--oc-space-gap); color: var(--oc-canvas); }
[data-design="b"] .oc-office__link { color: var(--oc-canvas); text-decoration: underline; text-underline-offset: 3px; }
[data-design="b"] .oc-office__link:hover { color: #9DB4F0; }
[data-design="b"] .oc-office__hours { font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.04em; color: rgba(245,245,244,0.7); margin: var(--oc-space-stub) 0 0; }
[data-design="b"] .oc-office__juris { font-family: var(--oc-font-body); font-size: 15px; line-height: 1.6; color: rgba(245,245,244,0.78); margin: var(--oc-space-block) 0 0; max-width: 56ch; }
[data-design="b"] .oc-office__cta-block { display: flex; flex-direction: column; gap: var(--oc-space-block); align-items: flex-start; padding-top: var(--oc-space-bite); }
[data-design="b"] .oc-office__cta-line { font-family: var(--oc-font-display); font-weight: 700; font-size: clamp(22px, 3vw, 36px); letter-spacing: -0.015em; line-height: 1.2; color: var(--oc-canvas); margin: 0; max-width: 24ch; }

/* ---- Footer (Imprint) ---- */
[data-design="b"] .oc-footer { background: var(--oc-canvas); border-top: 2px solid var(--oc-rule); padding: var(--oc-space-deck) clamp(20px, 4vw, 48px) var(--oc-space-bay); }
[data-design="b"] .oc-footer__grid { display: grid; grid-template-columns: 1fr; gap: var(--oc-space-bay); max-width: 100%; }
[data-design="b"] .oc-footer__brand { font-family: var(--oc-font-display); font-weight: 800; font-size: clamp(36px, 6vw, 56px); letter-spacing: -0.025em; line-height: 1; color: var(--oc-ink); }
[data-design="b"] .oc-footer__brandsub { font-family: var(--oc-font-body); font-size: 15px; color: var(--oc-ink-2); margin: var(--oc-space-bite) 0 0; }
[data-design="b"] .oc-footer__col { display: flex; flex-direction: column; gap: var(--oc-space-gap); }
[data-design="b"] .oc-footer__link { font-family: var(--oc-font-body); font-weight: 500; font-size: 17px; color: var(--oc-ink); text-decoration: none; min-height: 44px; display: inline-flex; align-items: center; }
[data-design="b"] .oc-footer__link:hover { color: var(--oc-stamp); }
[data-design="b"] .oc-footer__imprint { font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.03em; line-height: 1.6; color: var(--oc-ink-2); margin: 0 0 var(--oc-space-bite); }
[data-design="b"] .oc-footer__disclaimer { font-family: var(--oc-font-body); font-size: 13px; line-height: 1.6; color: var(--oc-muted); margin: var(--oc-space-stub) 0 0; max-width: 72ch; }
[data-design="b"] .oc-footer__copy { font-family: var(--oc-font-mono); font-size: 13px; letter-spacing: 0.03em; color: var(--oc-muted); margin: var(--oc-space-stub) 0 0; }

/* ---- Larger viewports ---- */
@media (min-width: 768px) {
  [data-design="b"] .oc-about__grid { grid-template-columns: minmax(220px, 0.8fr) 1.6fr; gap: var(--oc-space-yard); }
  [data-design="b"] .oc-about__vitae-row { grid-template-columns: 200px 1fr; gap: var(--oc-space-block); align-items: baseline; }
  [data-design="b"] .oc-office__grid { grid-template-columns: 1.4fr 1fr; gap: var(--oc-space-yard); align-items: center; }
  [data-design="b"] .oc-footer__grid { grid-template-columns: 1.1fr 0.8fr 1.6fr; }
}

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .oc-scrubber__head { animation: none; transform: translateX(40%); }
  [data-design="b"].oc-drawer { transition: none; }
  [data-design="b"] .oc-nav-link::after { transition: none; }
  [data-design="b"] .oc-cta { animation: none; }
  [data-design="b"] .oc-cta:hover { transform: none; }
  [data-design="b"] .oc-cta__arrow { transition: none; }
  [data-design="b"] .oc-hero__wash,
  [data-design="b"] .oc-hero__drift--1,
  [data-design="b"] .oc-hero__drift--2,
  [data-design="b"] .oc-hero__drift--3 { animation: none; }
  [data-design="b"] .oc-pointer__rule-fill { animation: none; width: 60%; }
  [data-design="b"] .oc-pointer__chev { animation: none; }
  [data-design="b"] .oc-funnel__step { animation: none; }
  [data-design="b"] .oc-funnel__progress-bar { transition: none; }
  [data-design="b"] .oc-tile-radio__face, [data-design="b"] .oc-tile-radio__face::after { transition: none; }
  [data-design="b"] .oc-docket__row { animation: none; }
  [data-design="b"] .oc-docket__num { transition: none; }
}

/* ---- Narrow viewports ---- */
@media (max-width: 560px) {
  [data-design="b"] .rf-header__bar { padding: 12px 16px; }
  [data-design="b"] .oc-funnel__form { padding: var(--oc-space-stub); }
  [data-design="b"] .oc-funnel__tiles { grid-template-columns: 1fr; }
  [data-design="b"] .oc-docket__row { grid-template-columns: 56px 1fr; row-gap: var(--oc-space-gap); }
  [data-design="b"] .oc-docket__meta { grid-column: 1 / -1; }
  [data-design="b"] .oc-docket__num { font-size: 24px; min-width: 44px; }
}
@media (max-width: 380px) {
  [data-design="b"] .oc-logo__mark { font-size: 18px; }
  [data-design="b"] .oc-pointer__label { font-size: 16px; white-space: normal; }
}

/* ============================================================
   MOBILE GUARDRAILS — appended at bottom per hard contract
   ============================================================ */
[data-design="b"].dq-design,[data-design="b"] .dq-design{max-width:100%;overflow-x:clip;}
[data-design="b"] *{min-width:0;}
[data-design="b"] img,[data-design="b"] svg:not([data-keep-size]){max-width:100%;height:auto;}

/* Phase-3.4 hero visibility floor (forge_assemble) */
[data-design="b"] [data-mf-role="hero"] :is(h1,h2,p,.headline,.subtitle,.proof,[class*="headline"],[class*="subtitle"],[class*="proof"]),
[data-design="b"] [data-mf-role="cta"] { opacity: 1 !important; }
