/* ============================================================
   Blue Dot Maps — Landing styles. Component CSS on top of tokens.
   ============================================================ */

/* --- Typeface imports (swapped via data-typeface) ------------ */

* { box-sizing: border-box; }
body { margin: 0; min-height: 100vh; background: var(--bg); color: var(--fg); }
#root { min-height: 100vh; display: flex; flex-direction: column; }

/* --- Typeface variants ---------------------------------------
   Default (no attr) = original system (Fraunces + Source Sans).
   Each variant rebinds --font-display / --font-body via root scope
   and adjusts tracking/weight so the display headlines don't feel
   over-designed. */
:root[data-typeface="newsreader"] {
  --font-display: 'Newsreader', Georgia, serif;
  --font-body:    'Inter Tight', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --display-weight: 400;
  --display-tracking: -0.02em;
  --display-variation: 'opsz' 72;
}
:root[data-typeface="sourceserif"] {
  --font-display: 'Source Serif 4', Georgia, serif;
  --font-body:    'Source Sans 3', -apple-system, BlinkMacSystemFont, sans-serif;
  --display-weight: 400;
  --display-tracking: -0.02em;
  --display-variation: 'opsz' 60;
}
:root[data-typeface="sans"] {
  --font-display: 'Instrument Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body:    'Instrument Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --display-weight: 500;
  --display-tracking: -0.03em;
  --display-variation: normal;
}
:root[data-typeface="instrument"] {
  --font-display: 'Instrument Serif', Georgia, serif;
  --font-body:    'Instrument Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --display-weight: 400;
  --display-tracking: -0.01em;
  --display-variation: normal;
}
:root[data-typeface="spectral"] {
  --font-display: 'Spectral', Georgia, serif;
  --font-body:    'Inter Tight', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --display-weight: 400;
  --display-tracking: -0.02em;
  --display-variation: normal;
}
:root[data-typeface="plex"] {
  --font-display: 'IBM Plex Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body:    'IBM Plex Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono:    'IBM Plex Mono', ui-monospace, monospace;
  --display-weight: 500;
  --display-tracking: -0.025em;
  --display-variation: normal;
}
:root[data-typeface="grotesk"] {
  --font-display: 'Space Grotesk', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body:    'Instrument Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --display-weight: 500;
  --display-tracking: -0.025em;
  --display-variation: normal;
}
:root[data-typeface="fraunces"] {
  /* default tokens already set by design system */
  --display-weight: 300;
  --display-tracking: -0.03em;
  --display-variation: 'opsz' 144, 'SOFT' 40;
}
:root { /* fallback if no attr */
  --display-weight: 400;
  --display-tracking: -0.02em;
  --display-variation: normal;
}

/* --- Accent override (teal) --------------------------------- */
:root[data-accent="teal"] {
  --accent: var(--teal-400);
  --accent-hover: var(--teal-500);
  --accent-press: var(--teal-600);
  --accent-subtle: var(--teal-100);
  --border-focus: var(--teal-500);
}
:root[data-theme="dark"][data-accent="teal"] {
  --accent: var(--teal-300);
  --accent-hover: var(--teal-200);
  --accent-press: var(--teal-400);
  --accent-subtle: rgba(73, 170, 177, 0.18);
  --border-focus: var(--teal-300);
}

/* --- Shared primitives --------------------------------------- */
.bdm-dot {
  display: inline-block; width: 14px; height: 14px; border-radius: 50%;
  background: var(--accent); flex-shrink: 0;
  box-shadow: 0 0 0 1px rgba(31,42,63,.10) inset;
}
.bdm-dot--xs { width: 7px; height: 7px; }
.mono { font-family: var(--font-mono); font-feature-settings: 'tnum' 1; }
.eyebrow {
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-muted);
}
.bdm-link {
  font-family: var(--font-body); font-size: 14px; color: var(--accent);
  border-bottom: 1px solid var(--accent); cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out);
}
.bdm-link:hover { color: var(--accent-hover); }
.bdm-link--back { display: inline-block; margin-bottom: 28px; }

/* --- Buttons ------------------------------------------------- */
.bdm-btn {
  font-family: var(--font-body); font-size: 15px; font-weight: 500;
  padding: 11px 20px; border-radius: 4px; cursor: pointer;
  border: 1px solid transparent; line-height: 1; white-space: nowrap;
  appearance: none; -webkit-appearance: none;
  -webkit-text-fill-color: currentColor;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.bdm-btn--sm { font-size: 13px; padding: 9px 14px; }
.bdm-btn__label { display: inline-flex; align-items: center; color: inherit; }
.bdm-btn--primary { background: var(--accent); color: var(--fg-on-accent); }
.bdm-btn--primary .bdm-btn__label { color: var(--fg-on-accent); }
.bdm-btn--primary:hover { background: var(--accent-hover); }
.bdm-btn--primary:active { background: var(--accent-press); transform: translateY(1px); }
.bdm-btn--ghost { background: transparent; color: var(--fg); border-color: var(--border-strong); }
.bdm-btn--ghost .bdm-btn__label { color: var(--fg); }
.bdm-btn--ghost:hover { background: var(--bg-sunken); }

/* --- Nav ----------------------------------------------------- */
.bdm-nav {
  display: flex; align-items: center; gap: 32px;
  border-bottom: 1px solid var(--border);
  padding: 16px 56px; background: var(--bg);
  position: sticky; top: 0; z-index: 20;
}
.bdm-nav__mark { display:flex; align-items:center; gap: 12px; cursor: pointer; border: none; }
.bdm-nav__wordmark {
  font-family: var(--font-display); font-size: 20px;
  font-weight: var(--display-weight); letter-spacing: var(--display-tracking);
  color: var(--fg);
  font-variation-settings: var(--display-variation);
}
.bdm-nav__links { margin-left: auto; display: flex; gap: 28px; align-items: center; }
.bdm-nav__link {
  font-family: var(--font-body); font-size: 14px; cursor: pointer;
  color: var(--fg); padding-bottom: 2px; border-bottom: 1px solid transparent;
  transition: color var(--dur-fast) var(--ease-out);
}
.bdm-nav__link:hover { color: var(--accent); }
.bdm-nav__link.is-active { color: var(--accent); border-bottom-color: var(--accent); }
.bdm-theme-toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 4px; cursor: pointer;
  background: transparent; color: var(--fg-muted); border: 1px solid var(--border);
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
}
.bdm-theme-toggle:hover { color: var(--fg); border-color: var(--border-strong); background: var(--bg-elevated); }

/* --- Hero ---------------------------------------------------- */
.bdm-hero {
  max-width: 1280px; margin: 0 auto;
  padding: 80px 56px 56px;
  display: grid; grid-template-columns: 1fr 1.05fr; gap: 72px;
  align-items: start;
}
/* On MacBook-class widths the corner globe is shown; add top
   breathing room so the hero headline clears it. */
@media (min-width: 1101px) {
  .bdm-hero { padding-top: 138px; }
}
.bdm-hero__col--text { padding-top: 12px; }
.bdm-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-body); font-size: 12px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-muted);
}
.bdm-hero__title {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(52px, 6.8vw, 80px);
  line-height: 1.02; letter-spacing: var(--display-tracking);
  color: var(--fg); margin: 22px 0 0; max-width: 14ch;
  font-variation-settings: var(--display-variation);
  text-wrap: balance;
}
.bdm-hero__lede {
  font-family: var(--font-body); font-size: 18px; line-height: 1.6;
  color: var(--fg-muted); max-width: 52ch; margin: 26px 0 0;
}
.bdm-hero__ctas { display: flex; gap: 12px; margin-top: 32px; }

/* --- Hero plate — floating frame treatment ------------------ */
.bdm-hero__col--plate { position: relative; }
.bdm-plate {
  margin: 0; cursor: pointer; background: transparent;
  border: none; padding: 0;
}
.bdm-plate:hover .bdm-plate__art {
  box-shadow:
    0 4px 8px rgba(31, 42, 63, 0.10),
    0 24px 56px rgba(31, 42, 63, 0.18),
    inset 0 0 0 1px rgba(31, 42, 63, 0.08);
  transform: translateY(-2px);
}
.bdm-plate__meta {
  display: flex; align-items: center; gap: 12px; margin-bottom: 14px;
  font-size: 11px; color: var(--fg-muted);
}
.bdm-plate__rule { flex: 1; height: 1px; background: var(--border); }
.bdm-plate__art {
  position: relative; aspect-ratio: 5 / 4; border-radius: 12px;
  overflow: hidden; background: var(--bg-elevated);
  box-shadow:
    0 2px 4px rgba(31, 42, 63, 0.06),
    0 16px 40px rgba(31, 42, 63, 0.14),
    inset 0 0 0 1px rgba(31, 42, 63, 0.06);
  transition: box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
:root[data-theme="dark"] .bdm-plate__art {
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.4),
    0 20px 48px rgba(0, 0, 0, 0.5),
    inset 0 0 0 1px rgba(255, 255, 255, 0.05);
}
:root[data-theme="dark"] .bdm-plate:hover .bdm-plate__art {
  box-shadow:
    0 4px 8px rgba(0, 0, 0, 0.5),
    0 28px 64px rgba(0, 0, 0, 0.6),
    inset 0 0 0 1px rgba(255, 255, 255, 0.07);
}
.bdm-plate__art > svg { border-radius: 12px; }
.bdm-plate__cap { display: flex; justify-content: space-between; align-items: baseline; gap: 20px; margin-top: 18px; padding: 0 4px; }
.bdm-plate__title {
  font-family: var(--font-display);
  font-size: 20px; font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking); color: var(--fg); line-height: 1.25;
  font-variation-settings: var(--display-variation);
  max-width: 24ch; text-wrap: balance;
}
.bdm-plate__coords { font-size: 11px; color: var(--fg-subtle); white-space: nowrap; }

/* --- Grid section ------------------------------------------- */
.bdm-grid-section {
  max-width: 1280px; margin: 0 auto; padding: 56px 56px 88px;
}
.bdm-grid-section__head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 24px; padding-bottom: 20px; margin-bottom: 28px;
  border-bottom: 1px solid var(--border);
}
.bdm-grid-section__title {
  font-family: var(--font-display);
  font-size: 32px; font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking); color: var(--fg);
  margin: 0; line-height: 1.1;
  font-variation-settings: var(--display-variation);
}
.bdm-grid { display: grid; }

/* --- Map card — floating frame treatment --------------------- */
.bdm-card {
  background: transparent; border: none;
  border-radius: 10px; overflow: visible; cursor: pointer;
  box-shadow: none;
  transition: transform var(--dur-base) var(--ease-out);
  display: flex; flex-direction: column;
}
.bdm-card.is-hover { transform: translateY(-2px); }
.bdm-card__art {
  aspect-ratio: 3 / 2; position: relative; overflow: hidden;
  background: var(--bg-elevated);
  border-radius: 10px;
  box-shadow:
    0 1px 2px rgba(31, 42, 63, 0.06),
    0 6px 16px rgba(31, 42, 63, 0.10),
    inset 0 0 0 1px rgba(31, 42, 63, 0.06);
  transition: box-shadow var(--dur-base) var(--ease-out);
}
.bdm-card.is-hover .bdm-card__art {
  box-shadow:
    0 2px 4px rgba(31, 42, 63, 0.08),
    0 14px 32px rgba(31, 42, 63, 0.16),
    inset 0 0 0 1px rgba(31, 42, 63, 0.08);
}
:root[data-theme="dark"] .bdm-card__art {
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.4),
    0 8px 24px rgba(0, 0, 0, 0.45),
    inset 0 0 0 1px rgba(255, 255, 255, 0.05);
}
:root[data-theme="dark"] .bdm-card.is-hover .bdm-card__art {
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.5),
    0 16px 40px rgba(0, 0, 0, 0.55),
    inset 0 0 0 1px rgba(255, 255, 255, 0.07);
}
.bdm-card__art > svg { border-radius: 10px; }
.bdm-card__art > svg {
  transition: transform var(--dur-slow) var(--ease-out);
  transform-origin: center;
}
.bdm-card.is-hover .bdm-card__art > svg { transform: scale(1.04); }
.bdm-card__body {
  flex: 1; display: flex; flex-direction: column;
  padding-top: 16px !important;
  padding-left: 4px !important; padding-right: 4px !important;
}
.bdm-card__peek {
  position: absolute; left: 10px; bottom: 10px; right: 10px;
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px; border-radius: 3px;
  background: rgba(245, 239, 225, 0.9); color: var(--ink-800);
  font-size: 11px; border: 1px solid rgba(31, 42, 63, 0.08);
  backdrop-filter: blur(6px);
  opacity: 0; transform: translateY(6px);
  transition: opacity var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
  pointer-events: none;
}
:root[data-theme="dark"] .bdm-card__peek {
  background: rgba(31, 32, 36, 0.82); color: var(--ink-200);
  border-color: rgba(224, 223, 213, 0.14);
}
.bdm-card.is-hover .bdm-card__peek { opacity: 1; transform: translateY(0); }
.bdm-card__peek-sep { opacity: 0.5; }

.bdm-card__meta {
  display: flex; gap: 6px; align-items: center;
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-muted);
  margin-bottom: 10px;
}
.bdm-card__dot { opacity: 0.5; }
.bdm-card__title {
  font-family: var(--font-display); font-weight: var(--display-weight);
  line-height: 1.2; letter-spacing: var(--display-tracking); color: var(--fg);
  margin: 0 0 8px; text-wrap: balance;
  font-variation-settings: var(--display-variation);
}
.bdm-card__blurb {
  font-family: var(--font-body); font-size: 14px; line-height: 1.55;
  color: var(--fg-muted); margin: 4px 0 0;
}

/* --- Detail -------------------------------------------------- */
.bdm-detail { max-width: 1100px; margin: 0 auto; padding: 48px 56px 96px; }
.bdm-detail__eyebrow {
  display: flex; gap: 8px; align-items: center;
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-muted);
}
.bdm-detail__title {
  font-family: var(--font-display);
  font-size: 52px; font-weight: var(--display-weight);
  line-height: 1.08; letter-spacing: var(--display-tracking); color: var(--fg);
  margin: 16px 0 18px; max-width: 18ch;
  font-variation-settings: var(--display-variation);
  text-wrap: balance;
}
.bdm-detail__lede {
  font-family: var(--font-body); font-size: 18px; line-height: 1.6;
  color: var(--fg-muted); max-width: 52ch; margin: 0 0 40px;
}
.bdm-detail__plate {
  position: relative;
  display: block; width: fit-content; max-width: 100%;
  margin: 0 auto 40px;
  padding: 10px;                       /* the frame: 10px matte around the map */
  border-radius: 8px;
  background: var(--bg-elevated);
  box-shadow:
    0 2px 4px rgba(31, 42, 63, 0.06),
    0 20px 48px rgba(31, 42, 63, 0.14),
    inset 0 0 0 1px rgba(31, 42, 63, 0.06);
}
:root[data-theme="dark"] .bdm-detail__plate {
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.4),
    0 24px 56px rgba(0, 0, 0, 0.5),
    inset 0 0 0 1px rgba(255, 255, 255, 0.05);
}
/* Fallback for generated-SVG (pending) maps: no intrinsic size,
   so give the frame a 16:9 box to fill. */
.bdm-detail__plate--art { width: 100%; aspect-ratio: 16 / 9; }
.bdm-detail__plate--art > svg { width: 100%; height: 100%; border-radius: 4px; }
.bdm-detail__body { display: grid; grid-template-columns: 220px 1fr; gap: 56px; }
.bdm-detail__prose {
  font-family: var(--font-body); font-size: 16px; line-height: 1.75;
  color: var(--fg); max-width: 62ch;
}
.bdm-detail__prose p { margin: 0 0 18px; }
.bdm-detail__source {
  margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--border);
  font-size: 13px; color: var(--fg-muted); line-height: 1.6;
}
.bdm-detail__actions { margin-top: 22px; display: flex; flex-direction: column; gap: 8px; }
.bdm-meta-row { margin-bottom: 16px; padding-bottom: 14px; border-bottom: 1px solid var(--border); }
.bdm-meta-row__val { font-size: 14px; color: var(--fg); margin-top: 6px; }

/* --- Image rendering inside plates/cards ---------------------
   Real map exports often ship with their own paper border / matte.
   Rather than fighting it, we treat each map as a "floating frame":
   round corners on the image itself, drop a soft shadow underneath,
   and lighten the card chrome so the map plate becomes the focus. */
.bdm-card__img, .bdm-plate__img {
  display: block; width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(var(--map-zoom, 2.6));
  transform-origin: var(--map-focus, center);
  transition: transform var(--dur-slow) var(--ease-out);
}
.bdm-card.is-hover .bdm-card__img {
  transform: scale(calc(var(--map-zoom, 2.6) * 1.03));
}
.bdm-detail__img {
  display: block; max-width: 100%; max-height: 78vh;
  width: auto; height: auto;
  border-radius: 3px;
}

/* --- "Preview pending" tag on placeholder cards -------------- */
.bdm-card__tag {
  position: absolute; top: 10px; right: 10px; z-index: 2;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 9px; border-radius: 2px;
  background: rgba(31, 32, 36, 0.78); color: var(--creme-50);
  font: 600 10px/1 var(--font-body);
  letter-spacing: 0.1em; text-transform: uppercase;
  backdrop-filter: blur(4px);
}
.bdm-card__tag::before {
  content: ""; width: 5px; height: 5px; border-radius: 50%;
  background: var(--ochre);
}
.bdm-card__tag--big {
  top: 14px; right: 14px; padding: 6px 12px; font-size: 11px;
}

/* --- Mini globe (floating corner artifact) ------------------ */
.mini-globe {
  position: fixed; top: 58px; left: 28px;
  width: 124px; height: 124px; z-index: 30;
  display: block; cursor: pointer;
  border: none; text-decoration: none;
  animation: mg-float 8s ease-in-out infinite;
  filter: drop-shadow(0 18px 36px rgba(20, 21, 25, 0.34));
  -webkit-tap-highlight-color: transparent;
}
.mini-globe__stage {
  width: 100%; height: 100%;
  transition: transform 360ms var(--ease-out);
}
.mini-globe:hover .mini-globe__stage { transform: scale(1.04); }
.mini-globe-svg { display: block; overflow: visible; }
.mg-graticule { fill: none; stroke: #fff; stroke-opacity: 0.06; stroke-width: 0.5; }
.mg-land { fill: #3A3D45; stroke: #4A4D55; stroke-width: 0.35; }
.mg-dot { fill: var(--teal-300); stroke: var(--ink-950); stroke-width: 0.8; }
.mini-globe__cap {
  position: absolute; left: 0; right: 0; bottom: -2px;
  text-align: center;
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-muted);
  opacity: 0; transform: translateY(4px);
  transition: opacity 220ms var(--ease-out), transform 220ms var(--ease-out);
  pointer-events: none;
}
.mini-globe:hover .mini-globe__cap { opacity: 1; transform: translateY(0); color: var(--accent); }
@keyframes mg-float {
  0%   { transform: translateY(0) rotate(-1.5deg); }
  50%  { transform: translateY(-10px) rotate(1.5deg); }
  100% { transform: translateY(0) rotate(-1.5deg); }
}
@media (max-width: 1100px) {
  .mini-globe { display: none; }   /* desktop-only artifact */
}

/* --- Responsive --------------------------------------------- */

/* --- Footer -------------------------------------------------- */
.bdm-footer { border-top: 1px solid var(--border); background: var(--bg-sunken); }
.bdm-footer__inner {
  max-width: 1280px; margin: 0 auto; padding: 56px 56px 48px;
  display: grid; grid-template-columns: 220px 1fr 220px; gap: 48px;
  align-items: start;
}
.bdm-footer__mark { display:flex; align-items:center; gap:10px; }
.bdm-footer__wordmark {
  font-family: var(--font-display); font-size: 18px; color: var(--fg);
  font-weight: var(--display-weight); letter-spacing: var(--display-tracking);
  font-variation-settings: var(--display-variation);
}
.bdm-colophon__prose {
  font-family: var(--font-body); font-size: 15px; line-height: 1.7;
  color: var(--fg-muted); margin: 10px 0 20px; max-width: 66ch;
}
.bdm-colophon__prose strong { color: var(--fg); font-weight: 600; }
.bdm-colophon__tools {
  list-style: none; padding: 0; margin: 0; display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 6px 20px;
  padding-top: 14px; border-top: 1px solid var(--border);
  font-family: var(--font-body); font-size: 13px; color: var(--fg-muted);
}
.bdm-colophon__tools li { padding: 4px 0; }
.bdm-colophon__tools .mono { color: var(--fg); font-size: 12px; margin-right: 8px; }
.bdm-footer__sig {
  justify-self: end; font-size: 12px; color: var(--fg-subtle);
  text-align: right; line-height: 1.6;
}

/* --- Tweaks panel -------------------------------------------- */
.bdm-tweaks {
  position: fixed; right: 24px; bottom: 24px; z-index: 50;
  width: 288px; padding: 16px;
  background: var(--bg-elevated);
  border: 1px solid var(--border); border-radius: 8px;
  box-shadow: var(--shadow-lg);
  display: flex; flex-direction: column; gap: 14px;
  max-height: calc(100vh - 48px); overflow-y: auto;
}
.bdm-tweaks__head { display: flex; align-items: center; gap: 8px; }
.bdm-tweaks__row { display: flex; flex-direction: column; gap: 6px; }
.bdm-tweaks__label {
  font-family: var(--font-body); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-muted);
}
.bdm-seg {
  display: grid; grid-auto-flow: column; grid-auto-columns: 1fr;
  border: 1px solid var(--border); border-radius: 4px; overflow: hidden;
  background: var(--bg);
}
.bdm-seg--stack {
  grid-auto-flow: row; grid-auto-columns: auto;
  display: flex; flex-direction: column;
}
.bdm-seg__btn {
  font-family: var(--font-body); font-size: 12px; padding: 8px 6px;
  background: transparent; border: none; color: var(--fg-muted);
  cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  text-transform: capitalize;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  border-right: 1px solid var(--border);
}
.bdm-seg__btn:last-child { border-right: none; }
.bdm-seg__btn.is-active { background: var(--accent-subtle); color: var(--fg); font-weight: 600; }
.bdm-seg__btn:hover:not(.is-active) { background: var(--bg-sunken); color: var(--fg); }
.bdm-seg__btn--wide {
  flex-direction: column; align-items: flex-start; padding: 9px 12px;
  text-align: left; border-right: none; border-bottom: 1px solid var(--border);
  text-transform: none; gap: 2px;
}
.bdm-seg__btn--wide:last-child { border-bottom: none; }
.bdm-seg__primary { font-size: 13px; color: var(--fg); font-weight: 500; }
.bdm-seg__btn.is-active .bdm-seg__primary { color: var(--fg); }
.bdm-seg__btn:not(.is-active) .bdm-seg__primary { color: var(--fg-muted); }
.bdm-seg__note { font-size: 11px; color: var(--fg-subtle); }
.bdm-swatch {
  display: inline-block; width: 10px; height: 10px; border-radius: 50%;
  box-shadow: 0 0 0 1px rgba(31,42,63,.18) inset;
}
.bdm-tweaks__note {
  font-family: var(--font-body); font-size: 11px; color: var(--fg-subtle);
  line-height: 1.5; padding-top: 6px; border-top: 1px solid var(--border);
}

/* --- Apply typeface vars to design-system default selectors -- */
/* Override the h1/h2 font-variation-settings that colors_and_type.css
   hardcoded to Fraunces axes — they only make sense for Fraunces. */
h1, .h1, h2, .h2, h3, .h3, .display {
  font-variation-settings: var(--display-variation);
  font-weight: var(--display-weight);
  letter-spacing: var(--display-tracking);
}

/* --- Banner (full-bleed map at top) ------------------------- */
.bdm-banner {
  position: relative;
  width: 100%;
  height: 460px;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
  background: var(--bg-sunken);
}
.bdm-banner__art {
  position: absolute; inset: 0; width: 100%; height: 100%;
  display: block;
}
.bdm-banner__overlay {
  position: absolute;
  left: max(56px, calc((100vw - 1280px) / 2 + 56px));
  top: 80px; max-width: 480px;
  display: flex; flex-direction: column; gap: 18px;
}
.bdm-banner__eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-body); font-size: 12px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-muted);
}
.bdm-banner__title {
  font-family: var(--font-display);
  font-weight: var(--display-weight);
  font-size: clamp(44px, 5.6vw, 64px);
  line-height: 1.02; letter-spacing: var(--display-tracking);
  color: var(--fg); margin: 0; max-width: 14ch;
  font-variation-settings: var(--display-variation);
  text-wrap: balance;
}
.bdm-banner__lede {
  font-family: var(--font-body); font-size: 17px; line-height: 1.55;
  color: var(--fg-muted); max-width: 44ch; margin: 0;
}
.bdm-banner__ctas { display: flex; gap: 12px; margin-top: 4px; }
.bdm-banner__sig {
  position: absolute; right: max(56px, calc((100vw - 1280px) / 2 + 56px));
  bottom: 24px; font-size: 11px; color: var(--fg-subtle);
  letter-spacing: 0.04em;
}

/* --- HeroLite (smaller featured section under banner) -------- */
.bdm-herolite {
  max-width: 1280px; margin: 0 auto;
  padding: 64px 56px 32px;
  display: flex; flex-direction: column; gap: 28px;
}
.bdm-herolite__head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 32px; padding-bottom: 20px; border-bottom: 1px solid var(--border);
}
.bdm-herolite__title {
  font-family: var(--font-display); font-weight: var(--display-weight);
  font-size: 36px; letter-spacing: var(--display-tracking); line-height: 1.1;
  color: var(--fg); margin: 6px 0 0; max-width: 22ch;
  font-variation-settings: var(--display-variation); text-wrap: balance;
}
.bdm-herolite__meta {
  font-size: 11px; color: var(--fg-subtle); text-align: right; line-height: 1.65;
  flex-shrink: 0;
}
.bdm-herolite__plate {
  margin: 0; cursor: pointer; display: grid;
  grid-template-columns: 1.4fr 1fr; gap: 32px; align-items: stretch;
}
.bdm-herolite__art {
  aspect-ratio: 16 / 9; border: 1px solid var(--border); border-radius: 6px;
  overflow: hidden; background: var(--bg-elevated);
  transition: box-shadow var(--dur-base) var(--ease-out);
}
.bdm-herolite__plate:hover .bdm-herolite__art { box-shadow: var(--shadow-md); }
.bdm-herolite__cap {
  display: flex; flex-direction: column; justify-content: center; gap: 20px;
  padding: 0 8px;
}
.bdm-herolite__cap p {
  font-family: var(--font-body); font-size: 18px; line-height: 1.55;
  color: var(--fg-muted); margin: 0;
}

@media (max-width: 900px) {
  .bdm-banner { height: 360px; }
  .bdm-banner__overlay { left: 32px; right: 32px; top: 48px; max-width: none; }
  .bdm-banner__sig { right: 32px; }
  .bdm-herolite { padding: 48px 32px 24px; }
  .bdm-herolite__plate { grid-template-columns: 1fr; }
  .bdm-herolite__head { flex-direction: column; align-items: flex-start; gap: 12px; }
  .bdm-herolite__meta { text-align: left; }
}
@media (max-width: 1000px) {
  .bdm-hero { grid-template-columns: 1fr; gap: 48px; padding: 48px 32px; }
  .bdm-grid-section { padding: 32px 32px 64px; }
  .bdm-nav { padding: 16px 32px; }
  .bdm-footer__inner { grid-template-columns: 1fr; padding: 40px 32px; }
  .bdm-footer__sig { justify-self: start; text-align: left; }
  .bdm-detail__body { grid-template-columns: 1fr; }
  .bdm-detail { padding: 32px; }
}
@media (max-width: 640px) {
  .bdm-grid { grid-template-columns: 1fr !important; }
  .bdm-hero__title { font-size: 48px; }
}
