/* Shipwreck — design-b — Cut Line (schema 0.6.0), remapped [data-design="b"] -> [data-design="b"] */
@import url('https://fonts.googleapis.com/css2?family=Big+Shoulders+Display:wght@500;700;800&family=Archivo:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

[data-design="b"] {
  --design-b-primary: #C8311E;

  --cl-paper        : #F7F5F1;
  --cl-paper-warm   : #EFEAE0;
  --cl-paper-dark   : #0F0F0F;
  --cl-ink          : #0F0F0F;
  --cl-ink-soft     : #2B2A28;
  --cl-muted        : #6B6863;
  --cl-rule         : #0F0F0F;
  --cl-rule-soft    : #C8C2B6;

  --cl-chip-01      : #C8311E;
  --cl-chip-02      : #F2C200;
  --cl-chip-03      : #1E5C8A;
  --cl-chip-04      : #6F7A3A;

  --cl-chip-01-snap : #B22916;
  --cl-chip-02-snap : #E5B500;
  --cl-chip-03-snap : #174B73;
  --cl-chip-04-snap : #5D6730;

  --cl-critical     : #C8311E;
  --cl-success      : #6F7A3A;

  --cl-surface      : var(--cl-paper);
  --cl-surface-sunk : var(--cl-paper-warm);
  --cl-text         : var(--cl-ink);
  --cl-text-soft    : var(--cl-ink-soft);
  --cl-text-mute    : var(--cl-muted);
  --cl-brand        : var(--cl-chip-01);
  --cl-brand-snap   : var(--cl-chip-01-snap);
  --cl-accent       : var(--cl-chip-02);
  --cl-accent-deep  : var(--cl-chip-03);
  --cl-accent-quiet : var(--cl-chip-04);

  --cl-font-display : 'Big Shoulders Display', 'Archivo', 'Impact', sans-serif;
  --cl-font-body    : 'Archivo', -apple-system, 'Helvetica Neue', sans-serif;
  --cl-font-mono    : 'JetBrains Mono', 'SFMono-Regular', 'Menlo', monospace;

  --cl-type-sign     : clamp(56px, 10vw, 148px);
  --cl-type-display  : clamp(40px, 6vw, 80px);
  --cl-type-headline : clamp(24px, 3vw, 36px);
  --cl-type-body-lg  : clamp(18px, 1.6vw, 21px);
  --cl-type-body     : clamp(16px, 1.4vw, 18px);
  --cl-type-caption  : 14px;
  --cl-type-stamp    : 12px;

  --cl-hairline : 1px;
  --cl-stitch   : 4px;
  --cl-cut      : 8px;
  --cl-stroke   : 16px;
  --cl-block    : 24px;
  --cl-bay      : 40px;
  --cl-wall     : 64px;
  --cl-room     : 96px;
  --cl-storefront : 160px;

  --cl-dur-snap     : 280ms;
  --cl-dur-press    : 140ms;
  --cl-dur-settle   : 220ms;
  --cl-dur-wipe     : 520ms;
  --cl-dur-shuffle  : 9000ms;
  --cl-dur-shuffle2 : 13000ms;
  --cl-dur-cue      : 4000ms;
  --cl-dur-pointer  : 5600ms;

  --cl-ease-snap    : cubic-bezier(.85, 0, .1, 1);
  --cl-ease-press   : cubic-bezier(.4, 0, .6, 1);
  --cl-ease-settle  : cubic-bezier(.2, 0, 0, 1);

  --cl-radius-block : 0;
  --cl-radius-tab   : 2px;
  --cl-radius-btn   : 4px;
  --cl-radius-pill  : 999px;

  background: var(--cl-paper);
  color: var(--cl-ink);
  font-family: var(--cl-font-body);
  display: block;
}

/* ===== Header ===== */
[data-design="b"] .cl-header { position: sticky; top: 0; z-index: 50; background: var(--cl-paper); }
[data-design="b"] .cl-header__bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--cl-stroke) clamp(var(--cl-stroke), 4vw, var(--cl-bay));
  min-height: 68px;
}
[data-design="b"] .cl-header__logo { text-decoration: none; color: var(--cl-ink); }
[data-design="b"] .cl-header__mark {
  font-family: var(--cl-font-display); font-weight: 800; font-size: 28px;
  letter-spacing: -0.015em; line-height: 1; text-transform: uppercase;
}
[data-design="b"] .cl-header__menu {
  appearance: none; background: var(--cl-ink); border: 0;
  border-radius: var(--cl-radius-btn); width: 48px; height: 48px;
  display: grid; place-content: center; gap: 4px; cursor: pointer; padding: 0 12px;
}
[data-design="b"] .cl-header__menu-bar { display: block; width: 22px; height: 2px; background: var(--cl-paper); }
[data-design="b"] .cl-header__menu:focus-visible { outline: 4px solid var(--cl-brand); outline-offset: 0; }

[data-design="b"] .cl-header__paint {
  position: relative; height: 8px; background: var(--cl-brand); overflow: hidden;
}
[data-design="b"] .cl-header__snap {
  position: absolute; left: 0; top: 0; bottom: 0; width: 100%;
  background: var(--cl-accent);
  clip-path: inset(0 100% 0 0);
  animation: b-header-snap 18s var(--cl-ease-snap) infinite;
}
@keyframes b-header-snap {
  0%,  20% { clip-path: inset(0 100% 0 0); }
  22%      { clip-path: inset(0   0% 0 0); }
  32%      { clip-path: inset(0   0% 0 0); }
  34%      { clip-path: inset(0 100% 0 0); }
  100%     { clip-path: inset(0 100% 0 0); }
}

[data-design="b"] .cl-drawer { position: fixed; inset: 0; z-index: 60; background: rgba(15,15,15,0.48); }
[data-design="b"] .cl-drawer[hidden] { display: none; }
[data-design="b"] .cl-drawer__panel {
  position: absolute; left: 0; right: 0; top: 0;
  background: var(--cl-paper);
  border-bottom: 8px solid var(--cl-brand);
  padding: 24px clamp(var(--cl-stroke), 4vw, var(--cl-bay));
  display: flex; flex-direction: column; gap: var(--cl-bay);
  transform: translateY(-100%); transition: transform var(--cl-dur-wipe) var(--cl-ease-snap);
}
[data-design="b"] .cl-drawer.is-open .cl-drawer__panel { transform: translateY(0); }
[data-design="b"] .cl-drawer__close {
  appearance: none; background: var(--cl-ink); color: var(--cl-paper); border: 0;
  font-family: var(--cl-font-mono); font-size: 22px;
  align-self: flex-end; width: 48px; height: 48px; cursor: pointer;
  border-radius: var(--cl-radius-btn);
}
[data-design="b"] .cl-drawer__nav { display: flex; flex-direction: column; gap: 0; border-top: 3px solid var(--cl-ink); }
[data-design="b"] .cl-drawer__nav a {
  font-family: var(--cl-font-display); font-size: 40px; font-weight: 800; text-transform: uppercase;
  color: var(--cl-ink); text-decoration: none; padding: 16px 0;
  border-bottom: 3px solid var(--cl-ink); letter-spacing: -0.015em; line-height: 1;
  display: block;
}
[data-design="b"] .cl-drawer__nav a:hover { color: var(--cl-brand); }
[data-design="b"] .cl-drawer__actions { display: flex; flex-wrap: wrap; gap: var(--cl-cut); }

@media (max-width: 380px) {
  [data-design="b"] .cl-header__mark { font-size: 22px; }
}

/* ===== Hero ===== */
[data-design="b"] .cl-hero {
  position: relative;
  isolation: isolate;
  min-height: 86vh;
  display: flex; align-items: center;
  overflow: hidden;
  background: var(--cl-paper);
  padding: var(--cl-room) clamp(var(--cl-stroke), 5vw, var(--cl-bay));
}
[data-design="b"] .cl-hero__blocks { position: absolute; inset: 0; z-index: 0; }
[data-design="b"] .cl-hero__block {
  position: absolute; width: 42%; height: 60%;
  transform-origin: center;
}
[data-design="b"] .cl-hero__block--a {
  top: 6%; left: 0; background: var(--cl-chip-01);
  animation: b-hero-shuffle-a 9s var(--cl-ease-snap) infinite;
}
[data-design="b"] .cl-hero__block--b {
  bottom: 4%; right: 0; background: var(--cl-chip-02);
  animation: b-hero-shuffle-b 13s var(--cl-ease-snap) infinite;
}
@keyframes b-hero-shuffle-a {
  0%, 40%   { clip-path: inset(0 0 0 0); background: var(--cl-chip-01); }
  46%       { clip-path: inset(0 0 0 0); background: var(--cl-chip-03); }
  52%, 100% { clip-path: inset(0 0 0 0); background: var(--cl-chip-01); }
}
@keyframes b-hero-shuffle-b {
  0%, 55%   { clip-path: inset(0 0 0 0); background: var(--cl-chip-02); }
  61%       { clip-path: inset(0 0 0 0); background: var(--cl-chip-04); }
  67%, 100% { clip-path: inset(0 0 0 0); background: var(--cl-chip-02); }
}
[data-design="b"] .cl-hero__inner {
  position: relative; z-index: 2;
  max-width: 1280px; margin-inline: auto; width: 100%;
  display: grid; gap: var(--cl-cut);
}
[data-design="b"] .cl-hero__kicker {
  font-family: var(--cl-font-mono); font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--cl-text-mute); margin: 0;
}
[data-design="b"] .cl-hero__title {
  font-family: var(--cl-font-display); font-weight: 800; font-size: var(--cl-type-sign);
  line-height: 0.98; letter-spacing: -0.02em; text-transform: uppercase; color: var(--cl-ink);
  margin: 0; opacity: 1;
}
[data-design="b"] .cl-hero__subtitle {
  font-family: var(--cl-font-body); font-size: var(--cl-type-body-lg); color: var(--cl-ink-soft);
  max-width: 52ch; margin: 8px 0 0; opacity: 1;
}
[data-design="b"] .cl-hero__actions {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--cl-stroke);
  margin-top: var(--cl-stroke);
}
[data-design="b"] .cl-hero__status {
  font-family: var(--cl-font-mono); font-size: 13px; color: var(--cl-text-mute);
  margin: var(--cl-cut) 0 0; opacity: 1; max-width: 48ch;
}

@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .cl-hero__block--a,
  [data-design="b"] .cl-hero__block--b { animation: none; }
}

@media (max-width: 640px) {
  [data-design="b"] .cl-hero { min-height: 92vh; }
  [data-design="b"] .cl-hero__title { font-size: clamp(48px, 15vw, 80px); }
}

/* ===== CTA ===== */
[data-design="b"] .cl-cta {
  position: relative; display: inline-flex; align-items: center; gap: 18px;
  padding: 18px 28px; min-height: 56px;
  background: var(--cl-brand); color: var(--cl-paper);
  font-family: var(--cl-font-display); font-weight: 800; font-size: 20px; text-transform: uppercase;
  letter-spacing: 0; text-decoration: none; border-radius: var(--cl-radius-btn);
  border-left: 3px solid var(--cl-ink); border-bottom: 3px solid var(--cl-ink);
  border-right: 0; border-top: 0;
  overflow: hidden; cursor: pointer; line-height: 1;
  transition: background-color var(--cl-dur-press) var(--cl-ease-press), border-color var(--cl-dur-press) var(--cl-ease-press), transform var(--cl-dur-press) var(--cl-ease-press);
}
[data-design="b"] .cl-cta__arrow {
  font-family: var(--cl-font-mono); font-size: 20px; line-height: 1; font-weight: 500;
  transition: transform var(--cl-dur-press) var(--cl-ease-snap);
}
[data-design="b"] .cl-cta__snap {
  position: absolute; inset: 0; pointer-events: none;
  background: var(--cl-brand-snap);
  clip-path: inset(0 100% 0 0);
  transition: clip-path var(--cl-dur-snap) var(--cl-ease-snap);
  z-index: 0;
}
[data-design="b"] .cl-cta__label, [data-design="b"] .cl-cta__arrow { position: relative; z-index: 1; }
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cl-cta:hover .cl-cta__snap { clip-path: inset(0 0% 0 0); }
  [data-design="b"] .cl-cta:hover .cl-cta__arrow { transform: translateX(6px); }
}
[data-design="b"] .cl-cta:focus-visible { outline: 4px solid var(--cl-ink); outline-offset: 0; }
[data-design="b"] .cl-cta:active {
  border-left: 0; border-bottom: 0;
  border-right: 3px solid var(--cl-ink); border-top: 3px solid var(--cl-ink);
  transform: translate(2px, 2px);
}

@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .cl-cta__snap { transition: none; }
  [data-design="b"] .cl-cta__arrow { transition: none; }
}

/* ===== Styled link chips (every external/tel/mailto anchor) ===== */
[data-design="b"] .cl-chip-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--cl-font-mono); font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--cl-ink); text-decoration: none;
  padding: 10px 16px; min-height: 44px;
  border: 1px solid var(--cl-ink); border-radius: var(--cl-radius-tab);
  background: var(--cl-paper);
  transition: background-color var(--cl-dur-press) var(--cl-ease-press), color var(--cl-dur-press) var(--cl-ease-press);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cl-chip-link:hover { background: var(--cl-ink); color: var(--cl-paper); }
}
[data-design="b"] .cl-chip-link:focus-visible { outline: 4px solid var(--cl-brand); outline-offset: 2px; }
[data-design="b"] .cl-chip-link--drawer { width: 100%; justify-content: space-between; }
[data-design="b"] .cl-chip-link--row {
  justify-content: space-between; width: 100%; padding: 20px 24px; min-height: 64px;
  border-width: 0 0 3px 0; border-radius: 0;
}
[data-design="b"] .cl-chip-link--row strong { font-family: var(--cl-font-display); font-size: 20px; font-weight: 700; text-transform: none; letter-spacing: 0; }
[data-design="b"] .cl-chip-link--footer { border-color: var(--cl-paper); color: var(--cl-paper); }
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cl-chip-link--footer:hover { background: var(--cl-paper); color: var(--cl-ink); }
}

/* ===== Pointer ===== */
[data-design="b"] .cl-pointer {
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  width: 100%; padding: var(--cl-bay) 0;
  color: var(--cl-ink); text-decoration: none;
  background: var(--cl-paper);
  opacity: 1;
}
[data-design="b"] .cl-pointer__svg { display: block; width: 32px; height: 160px; overflow: visible; }
[data-design="b"] .cl-pointer__bar {
  fill: var(--cl-ink);
  transform-origin: top;
  animation: b-pointer-plumb var(--cl-dur-pointer) var(--cl-ease-snap) infinite;
}
[data-design="b"] .cl-pointer__cap {
  fill: var(--cl-ink);
  opacity: 1;
  animation: b-pointer-cap var(--cl-dur-pointer) var(--cl-ease-snap) infinite;
}
[data-design="b"] .cl-pointer__hit {
  fill: var(--cl-brand);
  opacity: 1;
  transform-origin: left;
  transform: scaleX(0);
  animation: b-pointer-hit var(--cl-dur-pointer) var(--cl-ease-snap) infinite;
}
[data-design="b"] .cl-pointer__label { font-family: var(--cl-font-mono); font-size: 12px; letter-spacing: 0.14em; font-weight: 500; opacity: 1; }

@keyframes b-pointer-plumb {
  0%   { transform: scaleY(0.05); }
  6%   { transform: scaleY(0.1); }
  35%  { transform: scaleY(1); }
  90%  { transform: scaleY(1); }
  100% { transform: scaleY(0.05); }
}
@keyframes b-pointer-cap {
  0%, 5%  { transform: scale(0.4); }
  6%, 95% { transform: scale(1); }
  100%    { transform: scale(0.4); }
}
@keyframes b-pointer-hit {
  0%, 38% { transform: scaleX(0); }
  42%     { transform: scaleX(1); }
  90%     { transform: scaleX(1); }
  100%    { transform: scaleX(0); }
}

@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .cl-pointer__bar, [data-design="b"] .cl-pointer__cap, [data-design="b"] .cl-pointer__hit { animation: none; }
  [data-design="b"] .cl-pointer__bar { transform: scaleY(1); }
  [data-design="b"] .cl-pointer__cap { transform: scale(1); }
  [data-design="b"] .cl-pointer__hit { transform: scaleX(1); }
}

/* ===== Board (photo gallery, ambient A) ===== */
[data-design="b"] .cl-board {
  padding: var(--cl-room) clamp(var(--cl-stroke), 5vw, var(--cl-bay));
  background: var(--cl-paper);
  border-top: 8px solid var(--cl-ink);
  border-bottom: 8px solid var(--cl-ink);
}
[data-design="b"] .cl-board__head { max-width: 1280px; margin-inline: auto; margin-bottom: var(--cl-bay); display: grid; gap: var(--cl-cut); }
[data-design="b"] .cl-board__kicker { font-family: var(--cl-font-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--cl-text-mute); }
[data-design="b"] .cl-board__title { font-family: var(--cl-font-display); font-weight: 800; font-size: var(--cl-type-display); line-height: 0.95; letter-spacing: -0.02em; text-transform: uppercase; color: var(--cl-ink); margin: 0; max-width: 20ch; }
[data-design="b"] .cl-board__note { font-family: var(--cl-font-body); font-size: 14px; color: var(--cl-text-mute); margin: 0; max-width: 56ch; }
[data-design="b"] .cl-board__grid {
  list-style: none; padding: 0; margin-inline: auto; max-width: 1280px;
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 0;
  border-top: 3px solid var(--cl-ink); border-bottom: 3px solid var(--cl-ink); border-right: 3px solid var(--cl-ink);
}
[data-design="b"] .cl-board__tile {
  position: relative; aspect-ratio: 3/4;
  border-left: 3px solid var(--cl-ink);
  overflow: hidden;
  display: grid; align-items: end;
}
[data-design="b"] .cl-board__face {
  position: absolute; inset: 0;
  background: var(--cl-chip-01);
  transform: scale(1.02);
  transition: transform var(--cl-dur-wipe) var(--cl-ease-settle);
}
[data-design="b"] .cl-board__tile[data-chip="02"] .cl-board__face { background: var(--cl-chip-02); }
[data-design="b"] .cl-board__tile[data-chip="03"] .cl-board__face { background: var(--cl-chip-03); }
[data-design="b"] .cl-board__tile[data-chip="04"] .cl-board__face { background: var(--cl-chip-04); }
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cl-board__tile:hover .cl-board__face { transform: scale(1.08); }
}
[data-design="b"] .cl-board__file {
  position: relative; z-index: 1;
  font-family: var(--cl-font-mono); font-size: 10px; letter-spacing: 0.02em;
  color: var(--cl-paper); background: rgba(15,15,15,0.55);
  padding: 6px 8px; word-break: break-all;
}

@media (max-width: 920px) { [data-design="b"] .cl-board__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 420px) { [data-design="b"] .cl-board__grid { grid-template-columns: repeat(2, 1fr); } }

@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .cl-board__face { transition: none; }
}

/* ===== Recent (story, ambient B, guillotine) ===== */
[data-design="b"] .cl-recent {
  padding: var(--cl-room) clamp(var(--cl-stroke), 5vw, var(--cl-bay));
  background: var(--cl-paper-warm);
}
[data-design="b"] .cl-recent__head { max-width: 1280px; margin-inline: auto; margin-bottom: var(--cl-bay); display: grid; gap: var(--cl-cut); }
[data-design="b"] .cl-recent__grid { list-style: none; padding: 0; margin-inline: auto; max-width: 1280px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 3px solid var(--cl-ink); }
[data-design="b"] .cl-recent__panel { display: grid; gap: 0; background: var(--cl-paper); border-right: 3px solid var(--cl-ink); }
[data-design="b"] .cl-recent__panel:last-child { border-right: 0; }
[data-design="b"] .cl-recent__figure { position: relative; margin: 0; aspect-ratio: 4 / 5; background: var(--cl-ink-soft); overflow: hidden; border-bottom: 3px solid var(--cl-ink); display: grid; align-items: end; }
[data-design="b"] .cl-recent__file {
  position: relative; z-index: 1;
  font-family: var(--cl-font-mono); font-size: 11px; letter-spacing: 0.02em;
  color: var(--cl-paper); background: rgba(15,15,15,0.55);
  padding: 8px 10px; word-break: break-all;
  opacity: 0; transition: opacity var(--cl-dur-wipe) var(--cl-ease-settle);
  transition-delay: 120ms;
}
[data-design="b"] .cl-recent__mask {
  position: absolute; inset: 0;
  background: var(--cl-brand);
  clip-path: inset(0 0 0 0);
  transition: clip-path var(--cl-dur-wipe) var(--cl-ease-snap);
  z-index: 2;
}
[data-design="b"] .cl-recent__panel:nth-child(3n+2) .cl-recent__mask { background: var(--cl-accent-deep); }
[data-design="b"] .cl-recent__panel:nth-child(3n+3) .cl-recent__mask { background: var(--cl-accent-quiet); }
[data-design="b"] .cl-recent__panel.is-wiped .cl-recent__file  { opacity: 1; }
[data-design="b"] .cl-recent__panel.is-wiped .cl-recent__mask { clip-path: inset(0 0 0 100%); }
[data-design="b"] .cl-recent__panel:nth-child(2n).is-wiped .cl-recent__mask { clip-path: inset(0 100% 0 0); }
[data-design="b"] .cl-recent__meta { padding: var(--cl-block); display: flex; align-items: baseline; justify-content: space-between; gap: var(--cl-stroke); flex-wrap: wrap; }
[data-design="b"] .cl-recent__meta h3 { font-family: var(--cl-font-display); font-weight: 700; font-size: 20px; line-height: 1; letter-spacing: -0.01em; text-transform: uppercase; color: var(--cl-ink); margin: 0; max-width: 22ch; }
[data-design="b"] .cl-pill { display: inline-flex; align-items: center; padding: 5px 12px; border-radius: var(--cl-radius-pill); font-family: var(--cl-font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--cl-paper); }
[data-design="b"] .cl-pill--final { background: var(--cl-brand); }
[data-design="b"] .cl-pill--cued  { background: var(--cl-accent); color: var(--cl-ink); }
[data-design="b"] .cl-pill--done  { background: var(--cl-accent-quiet); }
[data-design="b"] .cl-recent__copy {
  max-width: 1280px; margin: var(--cl-bay) auto 0;
  font-size: var(--cl-type-body); color: var(--cl-ink-soft); line-height: 1.6;
}

@media (max-width: 920px) { [data-design="b"] .cl-recent__grid { grid-template-columns: repeat(2, 1fr); } [data-design="b"] .cl-recent__panel:nth-child(2) { border-right: 0; } [data-design="b"] .cl-recent__panel { border-bottom: 3px solid var(--cl-ink); } }
@media (max-width: 540px) { [data-design="b"] .cl-recent__grid { grid-template-columns: 1fr; } [data-design="b"] .cl-recent__panel { border-right: 0; } }

@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .cl-recent__mask, [data-design="b"] .cl-recent__file { transition: none; }
  [data-design="b"] .cl-recent__mask { clip-path: inset(0 0 0 100%); }
  [data-design="b"] .cl-recent__file { opacity: 1; }
}

/* ===== Picker -> the Spyglass (E5 interactive centerpiece, NO funnel) ===== */
[data-design="b"] .cl-picker {
  padding: var(--cl-room) clamp(var(--cl-stroke), 5vw, var(--cl-bay));
  background: var(--cl-paper);
  border-top: 8px solid var(--cl-ink);
}
[data-design="b"] .cl-picker__head { max-width: 1280px; margin-inline: auto; margin-bottom: var(--cl-bay); display: grid; gap: var(--cl-cut); }
[data-design="b"] .cl-picker__sheet { max-width: 1280px; margin-inline: auto; border: 3px solid var(--cl-ink); background: var(--cl-paper); }
[data-design="b"] .cl-picker__step { border: 0; padding: 0; margin: 0; display: none; }
[data-design="b"] .cl-picker__step.is-current { display: block; }
[data-design="b"] .cl-picker__legend { font-family: var(--cl-font-display); font-weight: 800; font-size: clamp(24px, 3.4vw, 38px); line-height: 1.1; letter-spacing: -0.01em; text-transform: uppercase; color: var(--cl-ink); padding: var(--cl-block); border-bottom: 3px solid var(--cl-ink); width: 100%; display: block; }
[data-design="b"] .cl-picker__row { display: grid; grid-template-columns: 1fr; }
[data-design="b"] .cl-picker__row--single { padding: var(--cl-room) var(--cl-block); display: flex; justify-content: center; }

[data-design="b"] .cl-picker__block--spyglass {
  appearance: none; cursor: pointer; border: 3px solid var(--cl-ink);
  background: var(--cl-paper-warm); color: var(--cl-ink);
  padding: var(--cl-bay) var(--cl-storefront);
  font-family: var(--cl-font-display); font-weight: 800; font-size: clamp(18px, 2vw, 24px);
  text-transform: uppercase; letter-spacing: -0.01em;
  display: flex; flex-direction: column; align-items: center; gap: var(--cl-stroke);
  min-height: 44px;
  transition: background-color var(--cl-dur-press) var(--cl-ease-press), color var(--cl-dur-press) var(--cl-ease-press);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cl-picker__block--spyglass:hover { background: var(--cl-ink); color: var(--cl-paper); }
}
[data-design="b"] .cl-picker__block--spyglass:focus-visible { outline: 4px solid var(--cl-brand); outline-offset: 4px; }

[data-design="b"] .cl-picker__spyglass {
  position: relative; width: 64px; height: 64px; display: block;
  transform: rotate(-8deg);
  transition: transform var(--cl-dur-settle) var(--cl-ease-settle);
}
[data-design="b"] .cl-picker__block--spyglass.is-scanning .cl-picker__spyglass {
  transform: rotate(8deg) scale(1.06);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cl-picker__block--spyglass:hover .cl-picker__spyglass {
    transform: rotate(8deg) scale(1.06);
  }
}
[data-design="b"] .cl-picker__lens {
  position: absolute; inset: 0;
  border: 6px solid currentColor; border-radius: 50%;
  background: transparent;
}
[data-design="b"] .cl-picker__lens::after {
  content: ""; position: absolute; right: -18px; bottom: -6px;
  width: 28px; height: 8px; background: currentColor;
  transform: rotate(45deg); transform-origin: left center;
}

[data-design="b"] .cl-picker__step--final { background: var(--cl-accent); }
[data-design="b"] .cl-picker__step--final .cl-picker__legend { background: var(--cl-accent); }
[data-design="b"] .cl-picker__result { padding: var(--cl-bay) var(--cl-block); display: grid; gap: var(--cl-stroke); }
[data-design="b"] .cl-picker__result-line { margin: 0; font-family: var(--cl-font-mono); font-size: 14px; letter-spacing: 0.04em; color: var(--cl-ink); max-width: 46ch; }
[data-design="b"] .cl-picker__result-figure { margin: 0; font-family: var(--cl-font-display); font-weight: 800; font-size: clamp(36px, 6vw, 72px); line-height: 1; letter-spacing: -0.02em; text-transform: uppercase; color: var(--cl-ink); }
[data-design="b"] .cl-picker__result-note { margin: 0; font-size: 14px; color: var(--cl-ink); max-width: 56ch; }
[data-design="b"] .cl-picker__final-actions { padding: var(--cl-block); border-top: 3px solid var(--cl-ink); display: flex; flex-wrap: wrap; gap: var(--cl-stroke); align-items: center; }
[data-design="b"] .cl-picker__restart { appearance: none; background: transparent; border: 0; color: var(--cl-ink); font-family: var(--cl-font-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; text-decoration: underline; text-underline-offset: 4px; cursor: pointer; padding: 12px; min-height: 44px; }

@media (max-width: 640px) {
  [data-design="b"] .cl-picker__block--spyglass { padding: var(--cl-bay) var(--cl-block); width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .cl-picker__spyglass { transition: none; }
}

/* ===== Contact ===== */
[data-design="b"] .cl-contact {
  padding: var(--cl-room) clamp(var(--cl-stroke), 5vw, var(--cl-bay));
  background: var(--cl-paper-warm);
  border-top: 8px solid var(--cl-ink);
  border-bottom: 8px solid var(--cl-ink);
}
[data-design="b"] .cl-contact__sheet {
  max-width: 1280px; margin-inline: auto;
  border: 3px solid var(--cl-ink); background: var(--cl-paper);
  display: grid;
}

/* ===== Footer ===== */
[data-design="b"] .cl-footer { background: var(--cl-ink); color: var(--cl-paper); padding: var(--cl-room) clamp(var(--cl-stroke), 5vw, var(--cl-bay)); border-top: 8px solid var(--cl-brand); }
[data-design="b"] .cl-footer__inner { max-width: 1280px; margin-inline: auto; display: grid; gap: var(--cl-cut); }
[data-design="b"] .cl-footer__mark { font-family: var(--cl-font-display); font-weight: 800; font-size: 32px; text-transform: uppercase; margin: 0; }
[data-design="b"] .cl-footer__line { font-family: var(--cl-font-body); font-size: 14px; color: var(--cl-rule-soft); margin: 0; }
[data-design="b"] .cl-footer__links { display: flex; flex-wrap: wrap; gap: var(--cl-cut); margin-top: var(--cl-cut); }
[data-design="b"] .cl-footer__copy { font-family: var(--cl-font-mono); font-size: 12px; color: var(--cl-rule-soft); margin-top: var(--cl-bay); }

/* ===== Layout centering safety net ===== */
[data-design="b"] .cl-header__bar,
[data-design="b"] .cl-hero__inner,
[data-design="b"] .cl-board__head,
[data-design="b"] .cl-board__grid,
[data-design="b"] .cl-recent__head,
[data-design="b"] .cl-recent__grid,
[data-design="b"] .cl-recent__copy,
[data-design="b"] .cl-picker__head,
[data-design="b"] .cl-picker__sheet,
[data-design="b"] .cl-contact__sheet,
[data-design="b"] .cl-footer__inner {
  margin-inline: auto;
}

/* ===== Mobile / overflow guards (bottom, scoped to .dq-design only) ===== */
[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; }

/* stranded-wrapper autofix (drain 2026-07-03): every fixed max-width column centers — gate content_uncentered_left_stranded */
[data-design="b"] .cl-hero__subtitle { margin-inline: auto; }
[data-design="b"] .cl-hero__status { margin-inline: auto; }
[data-design="b"] .cl-board__note { margin-inline: auto; }
[data-design="b"] .cl-picker__result-line { margin-inline: auto; }
[data-design="b"] .cl-picker__result-note { margin-inline: 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; }
