/* ============================================================
   Bridgemaker Wireframes — Components (static CSS, no @apply)
   Mirrors wf-components.js. Loaded via <link> so it works
   regardless of Tailwind CDN's processing order.
   ============================================================ */

/* ---------- Tokens (mirror of wf-tailwind.js) ---------- */
:root {
  --bm-purple: #6B4A94;
  --bm-deep-plum: #4A2D6B;
  --bm-lavender-on-dark: #AF94D2;
  --bm-purple-tint: #EDE3F5;

  --charcoal: #1C1C1E;
  --dark: #3D3D3A;
  --mid: #6B6B65;
  --light: #918F87;
  --off-white: #F5F1EB;

  --surface-stone: #E8E5DF;
  --surface-mauve: #E3E0E8;
  --surface-sage: #DDE4E0;
  --surface-sand: #E5E0D8;
  --border-subtle: #C5C0B8;

  --shadow-md: 0 6px 24px rgba(28,28,30,0.08);
  --shadow-lift: 0 1px 2px rgba(28,28,30,0.04), 0 0 0 1px rgba(28,28,30,0.03);
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- Pill buttons ---------- */
.bm-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; height: 44px; padding: 0 28px; border-radius: 999px; font-family: 'Inter', -apple-system, sans-serif; font-size: 15px; font-weight: 500; white-space: nowrap; transition: background-color 150ms var(--ease), color 150ms var(--ease); cursor: pointer; border: none; text-decoration: none; }
.bm-btn-sm { height: 36px; padding: 0 20px; font-size: 13px; }
.bm-btn-lg { height: 52px; padding: 0 36px; font-size: 16px; }
.bm-btn-primary { background: var(--charcoal); color: var(--off-white); }
.bm-btn-primary:hover { background: #000; }
.bm-btn-secondary { background: transparent; color: var(--bm-purple); box-shadow: inset 0 0 0 1.5px var(--bm-purple); }
.bm-btn-secondary:hover { background: var(--bm-purple-tint); }
.bm-btn-ghost { background: transparent; color: var(--charcoal); }
.bm-btn-ghost:hover { background: var(--surface-stone); }

/* ---------- Cards (bm-*) ---------- */
.bm-card { background: #fff; border-radius: 20px; padding: 32px; }
.bm-card-stone { background: var(--surface-stone); border-radius: 20px; padding: 32px; }
.bm-card-mauve { background: var(--surface-mauve); border-radius: 20px; padding: 32px; }
.bm-card-sage  { background: var(--surface-sage); border-radius: 20px; padding: 32px; }
.bm-card-sand  { background: var(--surface-sand); border-radius: 20px; padding: 32px; }
.bm-card-dark  { background: var(--charcoal); color: var(--off-white); border-radius: 20px; padding: 32px; }
.bm-lift { background: #fff; border-radius: 20px; box-shadow: var(--shadow-lift); }

/* ---------- Header ---------- */
.bm-header { position: fixed; top: 0; left: 0; right: 0; z-index: 50; height: 60px; background: rgba(245, 241, 235, 0.55); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid rgba(197, 192, 184, 0.6); }
.bm-header-inner { height: 100%; display: flex; align-items: center; justify-content: space-between; padding: 0 64px; }
.bm-header-brand { text-decoration: none; }
.bm-header-brand img { height: 16px; width: auto; display: block; }
.bm-header-pill { position: relative; }
.bm-header-pill-btn { display: inline-flex; align-items: center; gap: 10px; height: 36px; padding: 0 18px; border-radius: 999px; background: transparent; border: 1px solid var(--charcoal); font-size: 14px; color: var(--charcoal); cursor: pointer; transition: background-color 150ms var(--ease); font-family: 'Inter', sans-serif; }
.bm-header-pill-btn:hover { background: rgba(0,0,0,0.04); }
.bm-header-pill-menu { position: absolute; right: 0; top: calc(100% + 8px); min-width: 200px; background: #fff; border-radius: 16px; box-shadow: var(--shadow-md); border: 1px solid rgba(197, 192, 184, 0.7); padding: 6px; display: none; }
.bm-header-pill.is-open .bm-header-pill-menu { display: block; }
.bm-header-pill-menu a { display: block; padding: 8px 12px; border-radius: 12px; font-size: 14px; color: var(--charcoal); text-decoration: none; }
.bm-header-pill-menu a:hover { background: var(--surface-stone); }
.bm-header-pill-menu a.is-active { background: var(--surface-stone); font-weight: 500; }

/* ---------- Eyebrow ---------- */
.bm-eyebrow { font-size: 12px; line-height: 1.4; letter-spacing: 0.08em; text-transform: uppercase; color: var(--light); font-weight: 500; }

/* ---------- Wireframe page primitives ---------- */
/* Cards (wf-*) */
.wf-card { display: block; background: #fff; border-radius: 20px; padding: 32px; transition: box-shadow 150ms var(--ease), transform 150ms var(--ease), background-color 150ms var(--ease); text-decoration: none; color: inherit; }
.wf-card:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }
.wf-card-dark  { background: var(--charcoal); color: var(--off-white); }
.wf-card-dark:hover { background: #000; }
.wf-card-mauve { background: var(--surface-mauve); }
.wf-card-mauve:hover { background: #D8D4DE; }
.wf-card-sage  { background: var(--surface-sage); }
.wf-card-sand  { background: var(--surface-sand); }
.wf-card-stone { background: var(--surface-stone); }

.wf-card-tag { font-size: 12px; line-height: 1.4; letter-spacing: 0.08em; text-transform: uppercase; color: var(--bm-purple); font-weight: 500; margin-bottom: 16px; }
.wf-card-dark  .wf-card-tag { color: var(--bm-lavender-on-dark); }
.wf-card-mauve .wf-card-tag { color: var(--bm-deep-plum); }

.wf-card h3 { font-size: 24px; line-height: 1.3; letter-spacing: -0.5px; font-weight: 500; color: var(--charcoal); margin: 0 0 8px; }
.wf-card-dark  h3 { color: var(--off-white); }
.wf-card p  { font-size: 14px; line-height: 1.5; color: var(--mid); margin: 0 0 24px; }
.wf-card-dark  p { color: rgba(245, 241, 235, 0.75); }

.wf-arrow { display: inline-block; font-size: 14px; font-weight: 500; color: var(--bm-purple); }
.wf-card-dark  .wf-arrow { color: var(--bm-lavender-on-dark); }
.wf-card-mauve .wf-arrow { color: var(--bm-deep-plum); }

/* Module list rows */
.wf-mod { background: #fff; border-radius: 20px; padding: 28px 32px; display: grid; gap: 24px; align-items: baseline; grid-template-columns: 60px 1fr 220px; }
.wf-mod-num { font-family: 'JetBrains Mono', monospace; font-size: 12px; line-height: 1; color: var(--light); letter-spacing: 0.05em; }
.wf-mod-body h4 { font-size: 20px; line-height: 1.4; letter-spacing: -0.3px; font-weight: 600; color: var(--charcoal); margin: 0; }
.wf-mod-body p { font-size: 14px; line-height: 1.5; color: var(--mid); margin: 6px 0 0; max-width: 600px; }
.wf-mod-meta { font-family: 'JetBrains Mono', monospace; font-size: 11px; line-height: 1; text-transform: uppercase; letter-spacing: 0.05em; color: var(--light); text-align: right; }

/* Hero & section anchors */
.wf-hero { padding-bottom: 64px; margin-bottom: 64px; border-bottom: 1px solid var(--surface-stone); }
.wf-eyebrow { font-size: 12px; line-height: 1.4; letter-spacing: 0.08em; text-transform: uppercase; color: var(--light); font-weight: 500; margin-bottom: 24px; }
.wf-title { font-size: 88px; line-height: 1.05; letter-spacing: -2.8px; font-weight: 600; color: var(--charcoal); margin: 0; max-width: 900px; }
.wf-title-md { font-size: 64px; line-height: 1.05; letter-spacing: -1.9px; font-weight: 600; color: var(--charcoal); margin: 0; }
.wf-lede { font-size: 19px; line-height: 1.55; color: var(--dark); margin-top: 28px; max-width: 780px; }

.wf-section { display: grid; grid-template-columns: minmax(0, 280px) 1fr; gap: 48px; padding-top: 80px; margin-top: 80px; border-top: 1px solid var(--charcoal); align-items: start; }
.wf-section-num { font-family: 'JetBrains Mono', monospace; font-size: 11px; line-height: 1; color: var(--light); letter-spacing: 0.05em; margin-bottom: 16px; }
.wf-section h2 { font-size: 44px; line-height: 1.05; letter-spacing: -1.2px; font-weight: 600; color: var(--charcoal); margin: 0; }
.wf-section-desc { font-size: 17px; line-height: 1.55; color: var(--dark); max-width: 620px; }

/* Stats */
.wf-stat { border-radius: 20px; padding: 28px 32px; border: 1px solid var(--charcoal); background: transparent; }
.wf-stat-label { font-size: 12px; line-height: 1.4; letter-spacing: 0.08em; text-transform: uppercase; color: var(--light); font-weight: 500; margin-bottom: 12px; }
.wf-stat-num { font-size: 36px; line-height: 1.1; letter-spacing: -0.8px; font-weight: 600; color: var(--charcoal); }

/* Page nav */
.wf-pagenav { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 80px; padding-top: 32px; border-top: 1px solid var(--surface-stone); }
.wf-pagenav a { display: inline-flex; align-items: baseline; gap: 10px; font-size: 17px; line-height: 1.4; letter-spacing: -0.1px; font-weight: 500; color: var(--mid); text-decoration: none; transition: color 150ms var(--ease); }
.wf-pagenav a:hover { color: var(--bm-purple); }
.wf-pagenav .pn-dir { color: var(--light); }
.wf-pagenav .pn-end { justify-self: end; text-align: right; }

/* Footer */
.wf-footer { margin-top: 80px; padding-top: 40px; border-top: 1px solid var(--surface-stone); display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: 12px; font-size: 14px; color: var(--light); }

/* Note */
.wf-note { background: #fff; border-radius: 20px; padding: 28px 32px; margin-top: 32px; font-size: 15px; line-height: 1.6; color: var(--dark); }
.wf-note strong { color: var(--charcoal); font-weight: 600; }

/* Image placeholder */
.wf-ph { width: 100%; aspect-ratio: 16/9; border-radius: 20px; display: flex; align-items: center; justify-content: center; color: var(--mid); font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.05em; padding: 16px; text-align: center; background: repeating-linear-gradient(135deg, #E8E5DF 0 12px, #DDD9D2 12px 24px); }

/* Spacers */
.wf-spacer-s { height: 16px; }
.wf-spacer-m { height: 32px; }
.wf-spacer-l { height: 64px; }

/* Body base (since Tailwind base may not load) */
body { background: var(--off-white); color: var(--charcoal); font-family: 'Inter', -apple-system, sans-serif; margin: 0; padding-top: 60px; }
a { text-decoration: none; }

/* ---------- Tailwind-shaped utilities (subset used by these pages) ---------- */
.m-0 { margin: 0; }
.mt-8 { margin-top: 32px; }
.mt-20 { margin-top: 80px; }
.mx-auto { margin-left: auto; margin-right: auto; }
.px-12 { padding-left: 48px; padding-right: 48px; }
.px-16 { padding-left: 64px; padding-right: 64px; }
.pt-24 { padding-top: 96px; }
.pb-30 { padding-bottom: 120px; }

.max-w-container { max-width: 1200px; }

.grid { display: grid; }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.gap-3 { gap: 12px; }
.gap-4 { gap: 16px; }
.gap-6 { gap: 24px; }
.gap-8 { gap: 32px; }

.flex { display: flex; }
.items-center { align-items: center; }
.items-baseline { align-items: baseline; }
.justify-between { justify-content: space-between; }

.text-center { text-align: center; }

/* ---------- Mobile ---------- */
@media (max-width: 768px) {
  .bm-header-inner { padding: 0 20px; }
  .wf-section { grid-template-columns: 1fr; gap: 24px; }
  .wf-pagenav { grid-template-columns: 1fr; }
  .wf-pagenav .pn-end { justify-self: start; text-align: left; }
  .max-md\:grid-cols-1 { grid-template-columns: 1fr; }
  .max-md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .max-md\:px-5 { padding-left: 20px; padding-right: 20px; }
}


/* ============================================================
   Legacy bm- and wf- aliases used by 01..06 wireframes and deck
   (Imported from old wf-shared.css. Header rules from there
   are intentionally NOT duplicated — wf-components.css has them.)
   ============================================================ */

/* Page shell */
.wf-page { max-width: 1200px; margin: 0 auto; padding: 80px 48px 120px; }
@media (max-width: 720px) { .wf-page { padding: 48px 20px 80px; } }

/* Section anchor (Brandbook §) */
.wf-section-anchor {
  display: grid; grid-template-columns: minmax(0, 280px) 1fr; gap: 48px;
  padding-top: 80px; border-top: 1px solid var(--charcoal); margin-top: 80px;
  align-items: start;
}
.wf-section-anchor h2 {
  font: 600 44px/1.05 "Inter", sans-serif;
  letter-spacing: -1.2px; color: var(--charcoal); margin: 0;
}
@media (max-width: 768px) {
  .wf-section-anchor { grid-template-columns: 1fr; gap: 24px; }
}

/* bm-card (Brandbook style) */
.bm-card {
  background: #fff; border-radius: 20px; padding: 40px;
  text-decoration: none; color: inherit; display: block;
  transition: transform 150ms ease-out, box-shadow 150ms ease-out;
}
.bm-card.bm-card-link:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.bm-card-tag {
  font: 500 11px/1 "Inter", sans-serif;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--bm-purple); margin-bottom: 16px;
}
.bm-card h3 {
  font: 600 24px/1.3 "Inter", sans-serif;
  letter-spacing: -0.5px; color: var(--charcoal); margin: 0;
}
.bm-card p {
  font: 400 15px/1.55 "Inter", sans-serif;
  color: var(--mid); margin: 10px 0 0;
}
.bm-card .bm-arrow {
  display: inline-block; font: 500 14px/1 "Inter", sans-serif;
  color: var(--bm-purple); margin-top: 24px;
}
.bm-card-dark { background: var(--charcoal); }
.bm-card-dark h3 { color: var(--off-white); }
.bm-card-dark .bm-card-tag { color: #C9B8E8; }
.bm-card-dark p { color: #A8A69E; }
.bm-card-dark .bm-arrow { color: #C9B8E8; }
.bm-card-mauve { background: var(--surface-mauve); }
.bm-card-sage  { background: var(--surface-sage); }
.bm-card-sand  { background: var(--surface-sand); }
.bm-card-stone { background: var(--surface-stone); }

/* Card grids */
.bm-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.bm-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.bm-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 900px) {
  .bm-grid-2, .bm-grid-3, .bm-grid-4 { grid-template-columns: 1fr; }
}

/* Module list (cards-as-rows) */
.bm-modlist { display: flex; flex-direction: column; gap: 12px; margin-top: 24px; }
.bm-mod {
  background: #fff; border-radius: 20px; padding: 28px 32px;
  display: grid; grid-template-columns: 60px 1fr 220px;
  gap: 24px; align-items: baseline;
}
.bm-mod-num { font: 500 12px/1 "JetBrains Mono", monospace; color: var(--light); letter-spacing: 0.05em; }
.bm-mod-body h4 {
  font: 600 20px/1.3 "Inter", sans-serif; letter-spacing: -0.3px;
  color: var(--charcoal); margin: 0;
}
.bm-mod-body p {
  font: 400 14px/1.55 "Inter", sans-serif; color: var(--mid);
  margin: 6px 0 0; max-width: 600px;
}
.bm-mod-meta {
  font: 500 11px/1 "JetBrains Mono", monospace;
  color: var(--light); letter-spacing: 0.05em;
  text-transform: uppercase; text-align: right;
}
@media (max-width: 720px) {
  .bm-mod { grid-template-columns: 1fr; gap: 8px; }
  .bm-mod-meta { text-align: left; }
}

/* Badges */
.bm-badge {
  display: inline-flex; align-items: center;
  height: 28px; padding: 0 12px; border-radius: 999px;
  font: 500 12px/1 "Inter", sans-serif;
  background: var(--surface-stone); color: var(--charcoal);
}
.bm-badge-purple { background: var(--bm-purple-tint); color: var(--bm-purple); }
.bm-badge-berry  { background: #F5E0E8; color: #8A3050; }
.bm-badge-teal   { background: #E0F2F0; color: #1D6B66; }
.bm-badge-sage   { background: #E2E8DC; color: #4A5A3C; }

/* Stats row (legacy bm-* — ALSO supports the new wf-stat in same file) */
.bm-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.bm-stat { background: #fff; border-radius: 20px; padding: 28px 32px; }
.bm-stat-label { font: 500 11px/1 "Inter", sans-serif; text-transform: uppercase; letter-spacing: 0.08em; color: var(--light); margin-bottom: 12px; }
.bm-stat-num { font: 600 36px/1.1 "Inter", sans-serif; letter-spacing: -0.8px; color: var(--charcoal); }
@media (max-width: 720px) { .bm-stats { grid-template-columns: 1fr 1fr; } }

/* Image placeholder (legacy bm-ph) */
.bm-ph {
  width: 100%; aspect-ratio: 16/9; border-radius: 20px;
  background: repeating-linear-gradient(135deg, #E8E5DF 0 12px, #DDD9D2 12px 24px);
  display: flex; align-items: center; justify-content: center;
  color: var(--mid);
  font: 500 12px/1.4 "JetBrains Mono", monospace;
  letter-spacing: 0.02em; padding: 16px; text-align: center;
}

/* Matrix (4 quadrants) */
.wf-matrix-wrap { position: relative; width: 100%; max-width: 560px; margin: 48px auto; }
.wf-matrix {
  position: relative; display: grid; grid-template-columns: 1fr 1fr;
  border: 1px solid var(--charcoal); background: #fff;
  border-radius: 20px; overflow: hidden;
}
.wf-quad { padding: 28px 24px; min-height: 180px; display: flex; flex-direction: column; gap: 10px; }
.wf-quad:nth-child(2) { border-left: 1px solid var(--charcoal); }
.wf-quad:nth-child(3) { border-top: 1px solid var(--charcoal); }
.wf-quad:nth-child(4) { border-top: 1px solid var(--charcoal); border-left: 1px solid var(--charcoal); }
.wf-quad-name { font: 500 18px/1.3 "Inter", sans-serif; letter-spacing: -0.2px; color: var(--charcoal); }
.wf-quad-axis { font: 500 11px/1.4 "JetBrains Mono", monospace; text-transform: uppercase; letter-spacing: 0.06em; color: var(--light); }
.wf-matrix-center {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 96px; height: 96px; border-radius: 999px;
  background: #fff; border: 1px solid var(--charcoal);
  display: flex; align-items: center; justify-content: center;
  font: 500 14px/1.2 "JetBrains Mono", monospace; letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--charcoal); z-index: 2;
}
.wf-matrix-axes-bottom {
  display: flex; justify-content: space-between; margin-top: 12px;
  font: 500 11px/1 "JetBrains Mono", monospace;
  text-transform: uppercase; letter-spacing: 0.08em; color: var(--light);
}

/* Placeholder matrix wrapper (axes around bm-ph) */
.wf-ph-matrix { position: relative; margin-bottom: 48px; padding-left: 32px; padding-bottom: 28px; }
.wf-ph-axis {
  position: absolute; display: flex; justify-content: space-between;
  font: 500 11px/1 "JetBrains Mono", monospace;
  text-transform: uppercase; letter-spacing: 0.08em; color: var(--light);
}
.wf-ph-axis-x { left: 32px; right: 0; bottom: 0; }
.wf-ph-axis-y { left: 0; top: 0; bottom: 28px; flex-direction: column; writing-mode: vertical-rl; transform: rotate(180deg); }

/* Helpers */
.bm-mono { font-family: "JetBrains Mono", monospace; }
.bm-uc { text-transform: uppercase; letter-spacing: 0.08em; }
