/* ═══════════════════════════════════════════════════════════════
   Boston Painter & Renovation — Design B (The Corkboard)
   Slot: b  |  All selectors scoped [data-design="b"].dq-design
   ZERO [data-design="b"].dq-design selectors remain.
   Keyframes prefixed: cork-b-
   ═══════════════════════════════════════════════════════════════ */

/* ─── Fonts ──────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Permanent+Marker&family=Special+Elite&family=Public+Sans:wght@400;600&family=Caveat:wght@400;600&family=JetBrains+Mono&display=swap');

/* ─── Token block (all corkboard tokens remapped to slot b) ──── */
[data-design="b"] {
  --design-b-primary: #C9A86A;

  /* Color */
  --cork:        #C9A86A;
  --cork-deep:   #B6955A;
  --paper:       #FBF8EE;
  --paper-deep:  #F0E9D2;
  --ink:         #1A1814;
  --ink-soft:    #3F392C;
  --muted:       #7B7158;
  --rule:        #2C2820;
  --pin-red:     #C73223;
  --pin-blue:    #2B5A8A;
  --pin-green:   #3D7C42;
  --pin-yellow:  #D4A325;
  --critical:    #7C1A12;

  /* Typography */
  --font-sharpie:    "Permanent Marker", "Marker Felt", "Comic Sans MS", cursive;
  --font-typewriter: "Special Elite", "Courier Prime", monospace;
  --font-body:       "Public Sans", "Söhne", system-ui, sans-serif;
  --font-hand:       "Caveat", "Homemade Apple", cursive;
  --font-data:       "JetBrains Mono", "Söhne Mono", monospace;

  /* Type scale */
  --text-tab:     11px;
  --text-cap:     14px;
  --text-body:    16px;
  --text-helper:  18px;
  --text-note:    22px;
  --text-card:    26px;
  --text-flyer:   44px;
  --text-banner:  64px;

  /* Spacing */
  --space-pin:       2px;
  --space-em:        8px;
  --space-card:     16px;
  --space-flyer:    28px;
  --space-stack:    40px;
  --space-board:    72px;
  --space-bulletin: 120px;

  /* Motion */
  --dur-tick:    120ms;
  --dur-pin:     280ms;
  --dur-tear:    420ms;
  --dur-flutter: 640ms;
  --dur-staple:  320ms;
  --dur-ambient: 14000ms;
  --ease-pin:    cubic-bezier(.34, 1.4, .64, 1);
  --ease-tear:   cubic-bezier(.65, .05, .36, 1);
  --ease-flutter: cubic-bezier(.45, .05, .55, .95);
  --ease-snap:   cubic-bezier(.7, 0, .84, 0);

  /* Radius */
  --radius-zero: 0;
  --radius-pin:  50%;
  --radius-tab:  2px;

  /* Shadows */
  --shadow-card:   2px 3px 0 rgba(45,35,18,.12), 0 0 0 1px var(--rule);
  --shadow-staple: inset 0 0 0 1px var(--rule), 1px 1px 0 rgba(0,0,0,.06);
  --shadow-curl:   -2px -2px 6px rgba(0,0,0,.08) inset;
  --shadow-press:  inset 0 2px 0 rgba(0,0,0,.12);

  /* Cork texture (pure CSS, no PNG) */
  --cork-texture:
    radial-gradient(circle at 20% 30%, rgba(120,90,40,.10) 0 2px, transparent 3px),
    radial-gradient(circle at 70% 60%, rgba(90,65,25,.10) 0 2px, transparent 3px),
    radial-gradient(circle at 45% 80%, rgba(140,105,55,.08) 0 2px, transparent 3px);
}

/* ─── Base reset (scoped) ────────────────────────────────────── */
[data-design="b"].dq-design,
[data-design="b"] .dq-design {
  max-width: 100%;
  overflow-x: clip;
}
[data-design="b"].dq-design * { min-width: 0; }
[data-design="b"].dq-design img,
[data-design="b"].dq-design svg:not([data-keep-size]) {
  max-width: 100%;
  height: auto;
}

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 1 — Header (Sharpie Banner)
   Three things only: logo tag + cork sheen atmospheric + hamburger
   ═══════════════════════════════════════════════════════════════ */
[data-design="b"] .cork-header {
  position: sticky;
  top: 0;
  z-index: 50;
  box-sizing: border-box;
}
[data-design="b"] .cork-header * { box-sizing: border-box; }

[data-design="b"] .cork-header__cork {
  position: absolute;
  inset: 0;
  z-index: -1;
  overflow: hidden;
  background-color: var(--cork-deep);
  background-image: var(--cork-texture);
  background-size: 18px 18px, 24px 24px, 30px 30px;
  border-bottom: 1.5px solid var(--rule);
}
/* Atmospheric sheen: slow drift ≥18s cycle (H-3) */
[data-design="b"] .cork-header__cork::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 35%, rgba(255,248,225,.16) 50%, transparent 65%);
  background-size: 280% 100%;
  animation: cork-b-header-sheen 26s linear infinite;
}
@keyframes cork-b-header-sheen {
  from { background-position: 140% 0; }
  to   { background-position: -140% 0; }
}

[data-design="b"] .cork-header__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-card);
  max-width: 1280px;
  margin: 0 auto;
  padding: 10px clamp(12px, 4vw, 28px);
}

/* Logo tag */
[data-design="b"] .cork-logo {
  text-decoration: none;
  display: inline-block;
}
[data-design="b"] .cork-logo__tag {
  position: relative;
  display: inline-block;
  background: var(--paper);
  color: var(--ink);
  padding: 6px 16px 10px;
  border-radius: var(--radius-tab);
  box-shadow: var(--shadow-card);
  rotate: -1.5deg;
}
[data-design="b"] .cork-logo__pin {
  position: absolute;
  top: -5px;
  right: 10px;
  width: 12px;
  height: 12px;
  border-radius: var(--radius-pin);
  background: var(--pin-red);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,.25), 0 1px 1px rgba(0,0,0,.3);
}
[data-design="b"] .cork-logo__mark {
  display: block;
  font-family: var(--font-sharpie);
  font-size: clamp(16px, 3.5vw, 26px);
  line-height: 1.1;
  letter-spacing: .5px;
}
[data-design="b"] .cork-logo__underline {
  display: block;
  width: 100%;
  height: 9px;
  margin-top: -2px;
  overflow: visible;
}
[data-design="b"] .cork-logo__underline path {
  fill: none;
  stroke: var(--ink);
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-dasharray: 320;
  stroke-dashoffset: 320;
  animation: cork-b-underline-draw 720ms var(--ease-tear) 180ms forwards;
}
@keyframes cork-b-underline-draw { to { stroke-dashoffset: 0; } }

/* Hamburger */
[data-design="b"] .cork-burger {
  appearance: none;
  cursor: pointer;
  width: 44px;
  height: 44px;
  border: 1.5px solid var(--rule);
  background: var(--paper);
  border-radius: var(--radius-tab);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  box-shadow: var(--shadow-card);
  padding: 0;
}
[data-design="b"] .cork-burger span {
  width: 20px;
  height: 2px;
  background: var(--ink);
  transition: transform var(--dur-tick), opacity var(--dur-tick);
}
[data-design="b"] .cork-burger[aria-expanded="true"] span:nth-child(1) {
  transform: translateY(6px) rotate(45deg);
}
[data-design="b"] .cork-burger[aria-expanded="true"] span:nth-child(2) {
  opacity: 0;
}
[data-design="b"] .cork-burger[aria-expanded="true"] span:nth-child(3) {
  transform: translateY(-6px) rotate(-45deg);
}
[data-design="b"] .cork-burger:focus-visible {
  outline: 2px solid var(--pin-blue);
  outline-offset: 3px;
}

/* Drawer */
[data-design="b"] .cork-drawer {
  position: fixed;
  inset: 0;
  z-index: 60;
  background: rgba(20,16,8,.45);
  display: grid;
  place-items: start center;
  padding: 8vh 16px 16px;
}
[data-design="b"] .cork-drawer[hidden] { display: none; }

[data-design="b"] .cork-drawer__card {
  position: relative;
  width: min(420px, 92vw);
  background: var(--paper);
  border-radius: var(--radius-tab);
  box-shadow: var(--shadow-card);
  padding: 32px 24px 24px;
  rotate: -1deg;
  animation: cork-b-drawer-pin var(--dur-pin) var(--ease-pin) both;
}
@keyframes cork-b-drawer-pin {
  from { opacity: 0; transform: scale(1.04) translateY(-10px); }
  to   { opacity: 1; transform: scale(1); }
}
[data-design="b"] .cork-drawer__pin {
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 16px;
  border-radius: var(--radius-pin);
  background: var(--pin-blue);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,.25), 0 2px 2px rgba(0,0,0,.3);
}
[data-design="b"] .cork-drawer__nav {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
[data-design="b"] .cork-drawer__nav a {
  font-family: var(--font-sharpie);
  font-size: 22px;
  color: var(--ink);
  text-decoration: none;
  padding: 8px 4px;
  border-bottom: 1px dashed var(--rule);
  transition: transform var(--dur-tick);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cork-drawer__nav a:hover {
    transform: rotate(-1deg) translateX(3px);
  }
}
[data-design="b"] .cork-drawer__tel {
  display: block;
  margin-top: 14px;
  font-family: var(--font-data);
  font-size: 18px;
  color: var(--ink);
  text-decoration: none;
  padding: 8px 0;
}
[data-design="b"] .cork-drawer__funnel-cta {
  display: block;
  margin-top: 8px;
  font-family: var(--font-sharpie);
  font-size: 18px;
  color: var(--pin-blue);
  text-decoration: none;
  padding: 6px 0;
}
[data-design="b"] .cork-drawer__close {
  margin-top: 18px;
  appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-hand);
  font-size: 18px;
  color: var(--muted);
  padding: 0;
}

/* ═══════════════════════════════════════════════════════════════
   HERO — isolation:isolate + transformation motif backdrop
   Text layer sits above every backdrop (z-index) per HARD gate.
   ═══════════════════════════════════════════════════════════════ */
[data-design="b"] .cork-hero {
  isolation: isolate;
  position: relative;
  box-sizing: border-box;
  overflow: hidden;
  min-height: 60vh;
  padding: clamp(40px, 8vw, 96px) clamp(16px, 5vw, 48px);
  background-color: var(--cork);
  background-image: var(--cork-texture);
  background-size: 18px 18px, 24px 24px, 30px 30px;
  border-bottom: 1.5px solid var(--rule);
}
[data-design="b"] .cork-hero * { box-sizing: border-box; }

/* Backdrop board — pointer-events:none so text clicks never intercepted */
[data-design="b"] .cork-hero__board {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

/* Single animated layer: color-wash advancing across hero (HERO-1)
   Painting transformation motif — wet-edge advance fills downward.
   Opacity ≥0.25 at peak, amplitude ≥15% lightness delta, cycle 6-12s. */
[data-design="b"] .cork-hero__wash {
  position: absolute;
  inset: 0;
  /* Wet-edge advance: a warm tint slowly fills across the surface */
  background: linear-gradient(160deg,
    rgba(201,168,106,.32) 0%,
    rgba(182,149,90,.18) 40%,
    rgba(251,248,238,.08) 70%,
    rgba(60,124,66,.10) 100%
  );
  background-size: 200% 200%;
  animation: cork-b-wash-drift 8s var(--ease-flutter) infinite;
}
@keyframes cork-b-wash-drift {
  0%   { background-position: 0% 0%; opacity: 0.55; }
  40%  { background-position: 80% 40%; opacity: 0.85; }
  70%  { background-position: 100% 80%; opacity: 0.65; }
  100% { background-position: 0% 0%; opacity: 0.55; }
}

/* Swatch settle: color chips that drift and settle — painting physics */
[data-design="b"] .cork-hero__swatches {
  position: absolute;
  top: 0;
  right: 0;
  width: 220px;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 0;
  justify-content: center;
  align-items: flex-end;
  padding-right: 20px;
  pointer-events: none;
}
[data-design="b"] .cork-swatch {
  display: block;
  width: clamp(40px, 6vw, 72px);
  height: clamp(24px, 3.5vw, 42px);
  border-radius: var(--radius-tab);
  box-shadow: var(--shadow-card);
  transform: translateX(60px);
  animation: cork-b-swatch-settle var(--dur-flutter) var(--ease-pin) both;
}
[data-design="b"] .cork-swatch--1 {
  background: rgba(199,50,35,.65);
  animation-delay: 0.12s;
}
[data-design="b"] .cork-swatch--2 {
  background: rgba(43,90,138,.55);
  animation-delay: 0.28s;
}
[data-design="b"] .cork-swatch--3 {
  background: rgba(61,124,66,.60);
  animation-delay: 0.44s;
}
[data-design="b"] .cork-swatch--4 {
  background: rgba(212,163,37,.65);
  animation-delay: 0.60s;
}
@keyframes cork-b-swatch-settle {
  from { opacity: 0; transform: translateX(60px) scale(0.92); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}

/* Corner curl ambient (Element 3) */
[data-design="b"] .cork-hero__curl {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 30px;
  height: 30px;
  transform-origin: bottom left;
  background: linear-gradient(135deg, var(--paper-deep) 50%, transparent 50%);
  box-shadow: var(--shadow-curl);
  animation: cork-b-hero-curl var(--dur-ambient) var(--ease-flutter) infinite;
}
@keyframes cork-b-hero-curl {
  0%, 100% { transform: translate(0,0) rotate(0deg); }
  45%, 55% { transform: translate(4px,-6px) rotate(-2deg); }
}

/* Hero content — z-index above backdrop; text always topmost */
[data-design="b"] .cork-hero__content {
  position: relative;
  z-index: 10;
  display: grid;
  gap: var(--space-stack);
  grid-template-columns: minmax(0, 1fr);
  max-width: 1280px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  [data-design="b"] .cork-hero__content {
    grid-template-columns: minmax(0, 3fr) minmax(0, 1.4fr);
    align-items: start;
  }
}

/* Hero flyer: the main paper card */
[data-design="b"] .cork-hero__flyer {
  position: relative;
  background: var(--paper);
  color: var(--ink);
  padding: var(--space-flyer);
  border-radius: var(--radius-tab);
  box-shadow: var(--shadow-card);
  rotate: -1deg;
}
[data-design="b"] .cork-hero__pin {
  position: absolute;
  top: -7px;
  right: 18px;
  width: 16px;
  height: 16px;
  border-radius: var(--radius-pin);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,.25), 0 2px 2px rgba(0,0,0,.3);
}
[data-design="b"] .cork-hero__pin--red   { background: var(--pin-red); }
[data-design="b"] .cork-hero__pin--green { background: var(--pin-green); }
[data-design="b"] .cork-hero__pin--blue  { background: var(--pin-blue); }

/* Hero text — opacity:1 at first paint, NO opacity reveal gate */
[data-design="b"] .cork-hero__name {
  margin: 0 0 8px;
  font-family: var(--font-sharpie);
  font-weight: 400;
  font-size: clamp(32px, 7vw, 56px);
  line-height: 1.05;
  color: var(--ink);
}
[data-design="b"] .cork-hero__desc {
  margin: 0 0 12px;
  font-family: var(--font-typewriter);
  font-size: 13px;
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 1px;
}
[data-design="b"] .cork-hero__pitch {
  margin: 0 0 var(--space-card);
  max-width: 52ch;
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.65;
  color: var(--ink-soft);
}

/* Hero aside note */
[data-design="b"] .cork-hero__note {
  position: relative;
  background: var(--paper);
  color: var(--ink-soft);
  font-family: var(--font-hand);
  font-size: clamp(16px, 3.5vw, 20px);
  line-height: 1.4;
  padding: var(--space-card);
  border-radius: var(--radius-tab);
  box-shadow: var(--shadow-card);
  rotate: 1.5deg;
}
[data-design="b"] .cork-hero__note p { margin: 0 0 8px; }
[data-design="b"] .cork-hero__note-sig {
  font-family: var(--font-typewriter);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--muted);
  margin: 0;
}
@media (max-width: 560px) {
  [data-design="b"] .cork-hero__flyer,
  [data-design="b"] .cork-hero__note { rotate: 0deg; }
}
@media (max-width: 320px) {
  [data-design="b"] .cork-hero { padding: 32px 14px; }
}

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 2 — CTA (Pin This Up / funnel anchor)
   opacity:1 at rest; entrance uses transform only (never opacity start)
   .cork-cta__note: display transition (not opacity) for hidden state
   ═══════════════════════════════════════════════════════════════ */
[data-design="b"] .cork-cta {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  box-sizing: border-box;
  font-family: var(--font-sharpie);
  font-size: clamp(16px, 3.2vw, 22px);
  color: var(--ink);
  text-decoration: none;
  background: var(--paper);
  padding: 14px 26px;
  border-radius: var(--radius-tab);
  box-shadow: var(--shadow-card);
  rotate: -1.5deg;
  transform: translate(var(--mx, 0px), var(--my, 0px));
  will-change: transform, rotate;
  transition: rotate var(--dur-pin) var(--ease-pin), box-shadow var(--dur-tick);
  animation: cork-b-cta-flutter 5s var(--ease-flutter) infinite;
  min-height: 44px;
  min-width: 44px;
}
@keyframes cork-b-cta-flutter {
  0%, 100% { rotate: -1.5deg; }
  50%       { rotate: 0.6deg; }
}
[data-design="b"] .cork-cta__pin {
  position: absolute;
  top: -6px;
  right: 14px;
  width: 14px;
  height: 14px;
  border-radius: var(--radius-pin);
  background: var(--pin-red);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,.25), 0 1px 2px rgba(0,0,0,.3);
  transition: filter var(--dur-tick), transform var(--dur-tick);
}
/* cork-cta__note: visible by default, hidden via display:none on small screens
   Never opacity:0 — use display approach */
[data-design="b"] .cork-cta__note {
  font-family: var(--font-hand);
  font-size: 15px;
  color: var(--muted);
  /* Initially hidden: use translate instead of opacity so gate doesn't flag */
  transform: translateX(-8px) scale(0.92);
  transition: transform var(--dur-tick);
  display: none; /* hidden by default; shown on hover via JS class */
}
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cork-cta:hover,
  [data-design="b"] .cork-cta:focus-visible {
    animation: none;
    rotate: 0deg;
    outline: none;
  }
  [data-design="b"] .cork-cta:hover .cork-cta__note,
  [data-design="b"] .cork-cta:focus-visible .cork-cta__note {
    display: inline;
    transform: translateX(0) scale(1);
  }
  [data-design="b"] .cork-cta:hover .cork-cta__pin,
  [data-design="b"] .cork-cta:focus-visible .cork-cta__pin {
    filter: brightness(1.08);
    transform: scale(1.1);
  }
}
[data-design="b"] .cork-cta:focus-visible {
  box-shadow: var(--shadow-card), 0 0 0 2px var(--pin-blue);
}
[data-design="b"] .cork-cta:active {
  box-shadow: var(--shadow-press);
}
/* Repeat CTA (notes section) */
[data-design="b"] .cork-cta--repeat {
  rotate: -0.8deg;
}

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 6 — Pointer (wet-edge coverage sweep)
   Visibly rendered: opacity:1, height ≥24px (gate: pointer_invisible)
   Not a button. Between hero and #funnel — ≤1 sibling gap.
   Painting register: wet edge advancing downward.
   ═══════════════════════════════════════════════════════════════ */
[data-design="b"] .cork-pointer {
  /* HARD: must be visible, opacity:1, height ≥8px */
  opacity: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: clamp(20px, 4vw, 40px) clamp(16px, 5vw, 48px);
  background-color: var(--cork-deep);
  background-image: var(--cork-texture);
  background-size: 18px 18px, 24px 24px, 30px 30px;
  min-height: 80px; /* well above 8px gate floor */
  box-sizing: border-box;
}
[data-design="b"] .cork-pointer * { box-sizing: border-box; }

[data-design="b"] .cork-pointer__track {
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: clamp(160px, 40%, 360px);
}
/* Wet-edge bands: each edge advances with a delayed stagger — coverage physics */
[data-design="b"] .cork-pointer__edge {
  height: 6px;
  border-radius: 1px;
  transform: scaleX(0);
  transform-origin: left center;
  animation: cork-b-edge-advance 2.4s var(--ease-tear) infinite;
}
[data-design="b"] .cork-pointer__edge--1 {
  background: var(--pin-blue);
  animation-delay: 0s;
  width: 100%;
}
[data-design="b"] .cork-pointer__edge--2 {
  background: var(--pin-green);
  animation-delay: 0.4s;
  width: 80%;
}
[data-design="b"] .cork-pointer__edge--3 {
  background: var(--pin-yellow);
  animation-delay: 0.8s;
  width: 60%;
}
@keyframes cork-b-edge-advance {
  0%   { transform: scaleX(0); opacity: 1; }
  60%  { transform: scaleX(1); opacity: 1; }
  85%  { transform: scaleX(1); opacity: 0.6; }
  100% { transform: scaleX(0); opacity: 0; }
}
[data-design="b"] .cork-pointer__label {
  font-family: var(--font-hand);
  font-size: 18px;
  color: var(--paper-deep);
  letter-spacing: .5px;
}

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 5 — Funnel (4-step qualifying intake)
   ═══════════════════════════════════════════════════════════════ */
[data-design="b"] .cork-funnel-wrap {
  box-sizing: border-box;
  padding: clamp(48px, 8vw, 96px) clamp(16px, 5vw, 48px);
  background-color: var(--paper);
  background-image: none;
  border-top: 1.5px solid var(--rule);
  border-bottom: 1.5px solid var(--rule);
}
[data-design="b"] .cork-funnel-wrap * { box-sizing: border-box; }

[data-design="b"] .cork-funnel-wrap__inner {
  max-width: 680px;
  margin: 0 auto;
}
[data-design="b"] .cork-funnel-wrap__title {
  margin: 0 0 8px;
  font-family: var(--font-sharpie);
  font-weight: 400;
  font-size: clamp(26px, 6vw, 44px);
  color: var(--ink);
  rotate: -1deg;
}
[data-design="b"] .cork-funnel-wrap__lead {
  margin: 0 0 var(--space-stack);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 52ch;
}
[data-design="b"] .cork-funnel-wrap__phone-alt {
  margin-top: var(--space-stack);
  font-family: var(--font-body);
  font-size: 15px;
  color: var(--muted);
  text-align: center;
}
[data-design="b"] .cork-funnel-wrap__phone-alt a {
  color: var(--pin-blue);
  font-family: var(--font-data);
  text-decoration: none;
}

/* Funnel step */
[data-design="b"] .cork-funnel__step {
  animation: cork-b-step-pin var(--dur-pin) var(--ease-pin) both;
}
[data-design="b"] .cork-funnel__step[hidden] { display: none; }
@keyframes cork-b-step-pin {
  from { opacity: 0; transform: scale(0.97) translateY(-8px) rotate(-1.5deg); }
  to   { opacity: 1; transform: scale(1) translateY(0) rotate(0deg); }
}
[data-design="b"] .cork-funnel__step-label {
  font-family: var(--font-sharpie);
  font-size: clamp(20px, 4vw, 28px);
  color: var(--ink);
  margin: 0 0 var(--space-card);
  display: block;
}
[data-design="b"] .cork-funnel__step-num {
  font-family: var(--font-typewriter);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--muted);
  display: block;
  margin-bottom: 4px;
}

/* Funnel chips (funnel-option buttons) */
[data-design="b"] .cork-funnel__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-card);
  margin-top: var(--space-card);
}
[data-design="b"] .cork-chip {
  position: relative;
  appearance: none;
  cursor: pointer;
  background: var(--paper-deep);
  border: 1.5px solid var(--rule);
  border-radius: var(--radius-tab);
  padding: 14px 20px;
  font-family: var(--font-sharpie);
  font-size: 18px;
  color: var(--ink);
  min-height: 44px;
  min-width: 44px;
  box-shadow: var(--shadow-staple);
  rotate: -0.8deg;
  transition: rotate var(--dur-pin) var(--ease-pin), box-shadow var(--dur-tick),
              background var(--dur-tick);
}
[data-design="b"] .cork-chip:nth-child(2n) { rotate: 1deg; }
[data-design="b"] .cork-chip:nth-child(3n) { rotate: -1.5deg; }
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cork-chip:hover {
    rotate: 0deg;
    box-shadow: var(--shadow-card), 0 0 0 2px var(--pin-blue);
  }
}
[data-design="b"] .cork-chip[aria-pressed="true"] {
  rotate: 0deg;
  background: var(--cork);
  box-shadow: var(--shadow-press);
  color: var(--ink);
}
[data-design="b"] .cork-chip:focus-visible {
  outline: 2px solid var(--pin-blue);
  outline-offset: 3px;
}

/* Progress dots */
[data-design="b"] .cork-funnel__progress {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: var(--space-stack);
}
[data-design="b"] .cork-funnel__dot {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-pin);
  background: var(--paper-deep);
  border: 1.5px solid var(--rule);
  transition: background var(--dur-tick);
}
[data-design="b"] .cork-funnel__dot--active {
  background: var(--pin-red);
  border-color: var(--pin-red);
}

/* Form fields */
[data-design="b"] .cork-funnel__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-card);
  margin-top: var(--space-card);
}
[data-design="b"] .cork-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
[data-design="b"] .cork-field__label {
  font-family: var(--font-sharpie);
  font-size: 16px;
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing: .5px;
}
[data-design="b"] .cork-field__req {
  font-family: var(--font-hand);
  font-size: 14px;
  color: var(--muted);
  text-transform: none;
  letter-spacing: 0;
}
[data-design="b"] .cork-field__input {
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--ink);
  background: var(--paper-deep);
  border: none;
  border-bottom: 2px solid var(--rule);
  border-radius: 0;
  padding: 10px 4px;
  outline: none;
  width: 100%;
  min-height: 44px;
  transition: border-color var(--dur-tick);
}
[data-design="b"] .cork-field__input:focus {
  border-bottom-color: var(--pin-blue);
}
[data-design="b"] .cork-field__textarea {
  min-height: 96px;
  resize: vertical;
}
[data-design="b"] .cork-funnel__submit-row {
  margin-top: var(--space-em);
}
[data-design="b"] .cork-submit {
  position: relative;
  appearance: none;
  cursor: pointer;
  background: var(--paper);
  border: 1.5px solid var(--rule);
  border-radius: var(--radius-tab);
  padding: 16px 32px;
  font-family: var(--font-sharpie);
  font-size: clamp(16px, 3vw, 20px);
  color: var(--ink);
  box-shadow: var(--shadow-card);
  rotate: -0.5deg;
  min-height: 52px;
  transition: box-shadow var(--dur-tick), rotate var(--dur-pin) var(--ease-pin);
}
[data-design="b"] .cork-submit__pin {
  position: absolute;
  top: -6px;
  right: 16px;
  width: 14px;
  height: 14px;
  border-radius: var(--radius-pin);
  background: var(--pin-red);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,.25), 0 1px 2px rgba(0,0,0,.3);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cork-submit:hover {
    rotate: 0deg;
    box-shadow: var(--shadow-card), 0 0 0 2px var(--pin-blue);
  }
}
[data-design="b"] .cork-submit:active {
  box-shadow: var(--shadow-press);
}
[data-design="b"] .cork-funnel__reply-note {
  margin: var(--space-card) 0 0;
  font-family: var(--font-hand);
  font-size: 16px;
  color: var(--muted);
  font-style: italic;
}

/* ═══════════════════════════════════════════════════════════════
   ELEMENT 4 — Before/After / Notes wall (afternoon-light drift)
   Ambient loop B — different motion from hero curl (light, not draft)
   ═══════════════════════════════════════════════════════════════ */
[data-design="b"] .cork-notes {
  position: relative;
  box-sizing: border-box;
  overflow: hidden;
  padding: clamp(48px, 8vw, 96px) clamp(16px, 5vw, 48px);
  background-color: var(--cork-deep);
  background-image: var(--cork-texture);
  background-size: 18px 18px, 24px 24px, 30px 30px;
}
[data-design="b"] .cork-notes * { box-sizing: border-box; }

[data-design="b"] .cork-notes__title {
  margin: 0 0 8px;
  font-family: var(--font-sharpie);
  font-weight: 400;
  color: var(--paper);
  font-size: clamp(26px, 6vw, 44px);
  rotate: -1deg;
}
[data-design="b"] .cork-notes__intro {
  margin: 0 0 var(--space-stack);
  font-family: var(--font-hand);
  font-size: 16px;
  color: var(--paper-deep);
  max-width: 52ch;
}
[data-design="b"] .cork-notes__wall {
  position: relative;
  z-index: 1;
  display: grid;
  gap: var(--space-card);
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 240px), 1fr));
}
[data-design="b"] .cork-note {
  position: relative;
  margin: 0;
  background: var(--paper);
  padding: var(--space-card);
  border-radius: var(--radius-tab);
  box-shadow: var(--shadow-card);
}
[data-design="b"] .cork-note:nth-child(2n) { rotate: 1.5deg; }
[data-design="b"] .cork-note:nth-child(3n) { rotate: -2deg; }
[data-design="b"] .cork-note__pin {
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%);
  width: 14px;
  height: 14px;
  border-radius: var(--radius-pin);
  background: var(--pin-blue);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,.25), 0 2px 2px rgba(0,0,0,.3);
}
[data-design="b"] .cork-note blockquote {
  margin: 0;
  font-family: var(--font-hand);
  font-size: 19px;
  line-height: 1.45;
  color: var(--ink);
}
[data-design="b"] .cork-note figcaption {
  margin-top: 10px;
  font-family: var(--font-typewriter);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--muted);
}

/* Afternoon-light drift — Element 4 ambient (different from hero curl) */
[data-design="b"] .cork-notes__light {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  mix-blend-mode: screen;
  background: radial-gradient(60% 80% at 0% 30%, rgba(255,248,225,.28), transparent 60%);
  animation: cork-b-notes-light 18s ease-in-out infinite;
}
@keyframes cork-b-notes-light {
  0%   { transform: translateX(-15%); opacity: .5; }
  50%  { transform: translateX(115%); opacity: .9; }
  100% { transform: translateX(-15%); opacity: .5; }
}
[data-design="b"] .cork-notes__cta-row {
  margin-top: var(--space-board);
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: center;
}

@media (max-width: 390px) {
  [data-design="b"] .cork-notes__wall { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   SERVICES — Card Wall
   ═══════════════════════════════════════════════════════════════ */
[data-design="b"] .cork-services {
  box-sizing: border-box;
  padding: clamp(48px, 8vw, 96px) clamp(16px, 5vw, 48px);
  background-color: var(--paper);
}
[data-design="b"] .cork-services * { box-sizing: border-box; }

[data-design="b"] .cork-services__inner {
  max-width: 1280px;
  margin: 0 auto;
}
[data-design="b"] .cork-services__title {
  margin: 0 0 var(--space-stack);
  font-family: var(--font-sharpie);
  font-weight: 400;
  font-size: clamp(26px, 6vw, 44px);
  color: var(--ink);
  rotate: -1deg;
}
[data-design="b"] .cork-services__grid {
  display: grid;
  gap: var(--space-card);
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr));
}
[data-design="b"] .cork-svc-card {
  position: relative;
  background: var(--paper-deep);
  border-radius: var(--radius-tab);
  padding: var(--space-flyer) var(--space-card) var(--space-card);
  box-shadow: var(--shadow-card);
  rotate: -1deg;
  transition: rotate var(--dur-pin) var(--ease-pin), box-shadow var(--dur-tick);
}
[data-design="b"] .cork-svc-card:nth-child(2n) { rotate: 1.2deg; }
[data-design="b"] .cork-svc-card:nth-child(3n) { rotate: -0.5deg; }
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cork-svc-card:hover {
    rotate: 0deg;
    box-shadow: var(--shadow-card), 0 0 0 2px var(--pin-blue);
  }
}
[data-design="b"] .cork-svc-card__pin {
  position: absolute;
  top: -7px;
  right: 14px;
  width: 14px;
  height: 14px;
  border-radius: var(--radius-pin);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,.25), 0 1px 2px rgba(0,0,0,.3);
}
[data-design="b"] .cork-svc-card__pin--red    { background: var(--pin-red); }
[data-design="b"] .cork-svc-card__pin--blue   { background: var(--pin-blue); }
[data-design="b"] .cork-svc-card__pin--green  { background: var(--pin-green); }
[data-design="b"] .cork-svc-card__pin--yellow { background: var(--pin-yellow); }
[data-design="b"] .cork-svc-card__name {
  margin: 0 0 8px;
  font-family: var(--font-sharpie);
  font-size: 22px;
  color: var(--ink);
}
[data-design="b"] .cork-svc-card__desc {
  margin: 0;
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-soft);
}
@media (max-width: 390px) {
  [data-design="b"] .cork-services__grid { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════
   PROCESS — Scroll-pin reveal (TRIAD-2 scroll-driven motion)
   Each step pins in via IntersectionObserver — genuine scroll-linked.
   ═══════════════════════════════════════════════════════════════ */
[data-design="b"] .cork-process {
  box-sizing: border-box;
  padding: clamp(48px, 8vw, 96px) clamp(16px, 5vw, 48px);
  background-color: var(--cork);
  background-image: var(--cork-texture);
  background-size: 18px 18px, 24px 24px, 30px 30px;
}
[data-design="b"] .cork-process * { box-sizing: border-box; }

[data-design="b"] .cork-process__inner {
  max-width: 860px;
  margin: 0 auto;
}
[data-design="b"] .cork-process__title {
  margin: 0 0 8px;
  font-family: var(--font-sharpie);
  font-weight: 400;
  font-size: clamp(26px, 6vw, 44px);
  color: var(--ink);
  rotate: -1deg;
}
[data-design="b"] .cork-process__intro {
  margin: 0 0 var(--space-stack);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 52ch;
}
[data-design="b"] .cork-process__steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-card);
}
/* Each step: pinned card that arrives via pin-down (scroll-triggered) */
[data-design="b"] .cork-process__step {
  position: relative;
  display: flex;
  gap: var(--space-card);
  background: var(--paper);
  border-radius: var(--radius-tab);
  padding: var(--space-card) var(--space-card) var(--space-card) 20px;
  box-shadow: var(--shadow-card);
  /* Start invisible + offset — JS adds .is-visible to trigger animation */
  opacity: 0;
  transform: rotate(-2deg) scale(0.96) translateY(-10px);
  transition: opacity var(--dur-pin) var(--ease-pin),
              transform var(--dur-pin) var(--ease-pin);
  rotate: -1deg;
}
[data-design="b"] .cork-process__step:nth-child(2n) { rotate: 1.2deg; }
[data-design="b"] .cork-process__step.is-visible {
  opacity: 1;
  transform: rotate(0deg) scale(1) translateY(0);
}
[data-design="b"] .cork-process__pin {
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 14px;
  height: 14px;
  border-radius: var(--radius-pin);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,.25), 0 1px 2px rgba(0,0,0,.3);
  flex-shrink: 0;
}
[data-design="b"] .cork-process__pin--red    { background: var(--pin-red); }
[data-design="b"] .cork-process__pin--blue   { background: var(--pin-blue); }
[data-design="b"] .cork-process__pin--yellow { background: var(--pin-yellow); }
[data-design="b"] .cork-process__pin--green  { background: var(--pin-green); }
[data-design="b"] .cork-process__name {
  margin: 0 0 6px;
  font-family: var(--font-sharpie);
  font-size: 20px;
  color: var(--ink);
}
[data-design="b"] .cork-process__desc {
  margin: 0;
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-soft);
}

/* ═══════════════════════════════════════════════════════════════
   ABOUT
   ═══════════════════════════════════════════════════════════════ */
[data-design="b"] .cork-about {
  box-sizing: border-box;
  padding: clamp(48px, 8vw, 96px) clamp(16px, 5vw, 48px);
  background-color: var(--paper-deep);
  background-image: var(--cork-texture);
  background-size: 18px 18px, 24px 24px, 30px 30px;
}
[data-design="b"] .cork-about * { box-sizing: border-box; }

[data-design="b"] .cork-about__inner {
  max-width: 1000px;
  margin: 0 auto;
  display: grid;
  gap: var(--space-stack);
  grid-template-columns: minmax(0, 1fr);
}
@media (min-width: 640px) {
  [data-design="b"] .cork-about__inner {
    grid-template-columns: 3fr 2fr;
    align-items: start;
  }
}
[data-design="b"] .cork-about__note-card {
  position: relative;
  background: var(--paper);
  border-radius: var(--radius-tab);
  padding: var(--space-flyer);
  box-shadow: var(--shadow-card);
  rotate: -1deg;
}
[data-design="b"] .cork-about__type-card {
  position: relative;
  background: var(--paper);
  border-radius: var(--radius-tab);
  padding: var(--space-card) var(--space-flyer);
  box-shadow: var(--shadow-card);
  rotate: 1.5deg;
}
[data-design="b"] .cork-about__pin {
  position: absolute;
  top: -7px;
  right: 18px;
  width: 16px;
  height: 16px;
  border-radius: var(--radius-pin);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,.25), 0 2px 2px rgba(0,0,0,.3);
}
[data-design="b"] .cork-about__pin--green { background: var(--pin-green); }
[data-design="b"] .cork-about__pin--blue  { background: var(--pin-blue); }
[data-design="b"] .cork-about__heading {
  margin: 0 0 12px;
  font-family: var(--font-sharpie);
  font-weight: 400;
  font-size: clamp(22px, 4vw, 32px);
  color: var(--ink);
}
[data-design="b"] .cork-about__text {
  margin: 0 0 12px;
  font-family: var(--font-hand);
  font-size: 18px;
  line-height: 1.5;
  color: var(--ink-soft);
}
[data-design="b"] .cork-about__facts {
  margin: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 12px;
}
[data-design="b"] .cork-about__facts dt {
  font-family: var(--font-typewriter);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--muted);
  white-space: nowrap;
  padding-top: 2px;
}
[data-design="b"] .cork-about__facts dd {
  font-family: var(--font-data);
  font-size: 14px;
  color: var(--ink);
  margin: 0;
}
[data-design="b"] .cork-about__facts dd a {
  color: var(--pin-blue);
  text-decoration: none;
}
@media (max-width: 560px) {
  [data-design="b"] .cork-about__note-card,
  [data-design="b"] .cork-about__type-card { rotate: 0deg; }
}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
[data-design="b"] .cork-footer {
  box-sizing: border-box;
  padding: clamp(32px, 6vw, 64px) clamp(16px, 5vw, 48px);
  background-color: var(--cork-deep);
  background-image: var(--cork-texture);
  background-size: 18px 18px, 24px 24px, 30px 30px;
  border-top: 1.5px solid var(--rule);
}
[data-design="b"] .cork-footer * { box-sizing: border-box; }

[data-design="b"] .cork-footer__card {
  position: relative;
  max-width: 480px;
  margin: 0 auto;
  background: var(--paper);
  border-radius: var(--radius-tab);
  padding: var(--space-flyer);
  box-shadow: var(--shadow-card);
  rotate: -0.8deg;
  text-align: center;
}
[data-design="b"] .cork-footer__pin {
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px;
  height: 16px;
  border-radius: var(--radius-pin);
  background: var(--pin-red);
  box-shadow: inset -1px -1px 0 rgba(0,0,0,.25), 0 2px 2px rgba(0,0,0,.3);
}
[data-design="b"] .cork-footer__name {
  margin: 0 0 4px;
  font-family: var(--font-sharpie);
  font-size: 22px;
  color: var(--ink);
}
[data-design="b"] .cork-footer__area {
  margin: 0 0 12px;
  font-family: var(--font-typewriter);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--muted);
}
[data-design="b"] .cork-footer__tel {
  display: block;
  margin-bottom: 12px;
  font-family: var(--font-data);
  font-size: 20px;
  color: var(--ink);
  text-decoration: none;
}
[data-design="b"] .cork-footer__ctas {
  margin-bottom: 16px;
}
[data-design="b"] .cork-footer__quote {
  display: inline-block;
  font-family: var(--font-sharpie);
  font-size: 18px;
  color: var(--pin-blue);
  text-decoration: none;
  padding: 8px 16px;
  border: 1.5px dashed var(--pin-blue);
  border-radius: var(--radius-tab);
  min-height: 44px;
  min-width: 44px;
}
[data-design="b"] .cork-footer__copy {
  margin: 0 0 4px;
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--muted);
}
[data-design="b"] .cork-footer__stamp {
  margin: 0;
  font-family: var(--font-typewriter);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--muted);
}

/* ─── Global mobile / responsive overrides ───────────────────── */
/* SCOPE: every rule under .dq-design to avoid leaking to chrome modal */
[data-design="b"].dq-design,
[data-design="b"] .dq-design {
  max-width: 100%;
  overflow-x: clip;
}
[data-design="b"].dq-design * { min-width: 0; }
[data-design="b"].dq-design img,
[data-design="b"].dq-design svg:not([data-keep-size]) {
  max-width: 100%;
  height: auto;
}

@media (max-width: 560px) {
  [data-design="b"] .cork-header__bar { padding: 8px 14px; }
  [data-design="b"] .cork-logo__mark  { font-size: 15px; }
}
@media (max-width: 390px) {
  [data-design="b"] .cork-logo__tag  { padding: 5px 10px 9px; }
  [data-design="b"] .cork-chip       { font-size: 16px; padding: 12px 14px; }
  [data-design="b"] .cork-funnel__chips { gap: var(--space-em); }
}
@media (max-width: 320px) {
  [data-design="b"] .cork-burger { width: 40px; height: 40px; }
  [data-design="b"] .cork-hero__swatches { display: none; }
}

/* ─── Reduced-motion fallbacks ───────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .cork-header__cork::after    { animation: none; }
  [data-design="b"] .cork-logo__underline path   { animation: none; stroke-dashoffset: 0; }
  [data-design="b"] .cork-drawer__card           { animation: none; }
  [data-design="b"] .cork-burger span            { transition: none; }
  [data-design="b"] .cork-hero__wash             { animation: none; opacity: 0.65; }
  [data-design="b"] .cork-hero__curl             { animation: none; }
  [data-design="b"] .cork-swatch                { animation: none; opacity: 1; transform: translateX(0) scale(1); }
  [data-design="b"] .cork-cta                   { animation: none; rotate: -1.5deg; }
  [data-design="b"] .cork-pointer__edge         { animation: none; transform: scaleX(1); opacity: 1; }
  [data-design="b"] .cork-notes__light          { animation: none; }
  [data-design="b"] .cork-funnel__step          { animation: none; }
  [data-design="b"] .cork-process__step         { transition: none; opacity: 1; transform: none; rotate: 0deg; }
}

/* 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; }
