/* ==========================================================
   AMA Leadership Guide — Components
   ========================================================== */

/* ----- Layout primitives ----- */
.container { width: min(100% - 3rem, var(--content-wide)); margin-inline: auto; }
.container-narrow { width: min(100% - 3rem, var(--content-narrow)); margin-inline: auto; }
.container-default { width: min(100% - 3rem, var(--content-default)); margin-inline: auto; }

section { padding-block: clamp(var(--space-16), 9vw, var(--space-32)); }
section + section { border-top: 1px solid var(--color-divider); }

/* ----- Header ----- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--color-bg) 88%, transparent);
  backdrop-filter: saturate(1.4) blur(14px);
  -webkit-backdrop-filter: saturate(1.4) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--transition-interactive), background var(--transition-interactive);
}
.site-header.is-scrolled { border-bottom-color: var(--color-divider); }
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-6);
  padding: var(--space-4) 0;
}
.brand { display: flex; align-items: center; gap: var(--space-3); font-size: var(--text-sm); font-weight: 500; letter-spacing: 0.02em; }
.brand__mark { color: var(--color-primary); }
.brand__name { font-family: var(--font-display); font-size: var(--text-base); letter-spacing: -0.01em; }
.nav { display: flex; align-items: center; gap: var(--space-6); font-size: var(--text-sm); }
.nav a { color: var(--color-text-muted); }
.nav a:hover { color: var(--color-text); }
.nav-toggle {
  display: grid; place-items: center;
  width: 36px; height: 36px; border-radius: var(--radius-full);
  color: var(--color-text-muted);
}
.nav-toggle:hover { background: var(--color-surface-offset); color: var(--color-text); }
.nav__links { display: flex; gap: var(--space-6); }
@media (max-width: 820px) {
  .nav__links { display: none; }
}

/* ----- Hero ----- */
.hero { padding-block: clamp(var(--space-24), 14vw, var(--space-32)); position: relative; overflow: hidden; }
.hero__eyebrow {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-family: var(--font-body); font-size: var(--text-xs); font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--color-accent);
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-full);
  background: var(--color-accent-highlight);
  margin-bottom: var(--space-8);
}
.hero h1 {
  font-size: var(--text-hero);
  font-weight: 300;
  letter-spacing: -0.025em;
  line-height: 0.98;
}
.hero h1 em {
  font-style: italic;
  font-weight: 300;
  color: var(--color-accent);
}
.hero__lede {
  margin-top: var(--space-8);
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  max-width: 62ch;
  line-height: 1.55;
}
.hero__meta {
  margin-top: var(--space-12);
  display: flex; flex-wrap: wrap; gap: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-divider);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.hero__meta strong { color: var(--color-text); font-weight: 500; }

/* decorative diagonal rule */
.hero__rule {
  position: absolute; inset: auto 0 0 0;
  height: 1px; background: var(--color-divider);
}

/* ----- Section headers ----- */
.section-head { margin-bottom: clamp(var(--space-12), 6vw, var(--space-20)); max-width: 60ch; }
.section-head__number {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-4);
  display: flex; align-items: center; gap: var(--space-3);
}
.section-head__number::after {
  content: ''; flex: 0 0 56px; height: 1px; background: var(--color-accent);
}
.section-head h2 { font-size: var(--text-2xl); font-weight: 350; letter-spacing: -0.02em; }
.section-head p { margin-top: var(--space-5); color: var(--color-text-muted); font-size: var(--text-lg); line-height: 1.5; max-width: 58ch; }

/* ----- Pathway timeline (career stages) ----- */
.pathway {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
  position: relative;
}
.pathway::before {
  content: ''; position: absolute;
  left: 5%; right: 5%; top: 36px; height: 2px;
  background: linear-gradient(90deg,
    var(--tier-student) 0%,
    var(--tier-resident) 33%,
    var(--tier-young) 66%,
    var(--tier-attending) 100%);
  z-index: 0;
  opacity: 0.35;
}
.stage {
  position: relative; z-index: 1;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-6) var(--space-6);
  display: flex; flex-direction: column;
  transition: transform var(--transition-interactive), box-shadow var(--transition-interactive);
}
.stage:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.stage__dot {
  width: 36px; height: 36px;
  border-radius: var(--radius-full);
  background: var(--tier-c, var(--color-primary));
  color: white;
  display: grid; place-items: center;
  font-family: var(--font-mono); font-size: 13px; font-weight: 600;
  box-shadow: 0 0 0 6px var(--color-bg);
  margin: -28px 0 var(--space-4);
}
.stage__label {
  font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--tier-c, var(--color-primary));
  margin-bottom: var(--space-2);
}
.stage h3 { font-size: var(--text-lg); line-height: 1.2; margin-bottom: var(--space-2); font-weight: 500; }
.stage p.meta { font-size: var(--text-xs); color: var(--color-text-muted); margin-bottom: var(--space-4); }
.stage ul { list-style: none; display: flex; flex-direction: column; gap: var(--space-2); }
.stage ul li {
  font-size: var(--text-sm);
  color: var(--color-text);
  padding-left: var(--space-4);
  position: relative;
  line-height: 1.45;
}
.stage ul li::before {
  content: ''; position: absolute; left: 0; top: 10px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--tier-c, var(--color-primary));
}
.stage.tier-student { --tier-c: var(--tier-student); border-top: 3px solid var(--tier-student); }
.stage.tier-resident { --tier-c: var(--tier-resident); border-top: 3px solid var(--tier-resident); }
.stage.tier-young { --tier-c: var(--tier-young); border-top: 3px solid var(--tier-young); }
.stage.tier-attending { --tier-c: var(--tier-attending); border-top: 3px solid var(--tier-attending); }
@media (max-width: 900px) {
  .pathway { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .pathway { grid-template-columns: 1fr; }
  .pathway::before { display: none; }
}

/* ----- AMA governance diagram ----- */
.gov-diagram {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  max-width: 900px;
  margin-inline: auto;
}
.gov-tier {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-8);
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: var(--space-8);
  align-items: start;
  position: relative;
}
.gov-tier::before {
  content: '↓';
  position: absolute;
  left: 50%;
  bottom: calc(var(--space-10) * -1 + 2px);
  height: calc(var(--space-10) - 4px);
  width: 24px;
  transform: translateX(-50%);
  font-size: 20px;
  font-weight: 500;
  color: var(--color-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}
.gov-tier:last-child::before { display: none; }
.gov-tier__label {
  font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: 0.16em;
  color: var(--color-accent);
  padding-top: var(--space-1);
}
.gov-tier h3 { font-size: var(--text-lg); font-weight: 500; margin-bottom: var(--space-2); }
.gov-tier p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.55; }
.gov-tier.is-top { background: var(--color-primary); color: var(--color-text-inverse); border-color: transparent; }
.gov-tier.is-top h3, .gov-tier.is-top p { color: var(--color-text-inverse); }
.gov-tier.is-top p { color: color-mix(in srgb, var(--color-text-inverse) 75%, transparent); }
/* Label color must contrast against the primary background in BOTH themes.
   Light mode: deep navy bg → gold label reads. Dark mode: light-blue bg →
   reuse the inverse text color so the label matches the heading and stays legible. */
.gov-tier.is-top .gov-tier__label { color: var(--color-accent); }
[data-theme="dark"] .gov-tier.is-top .gov-tier__label,
[data-theme="dark"] .gov-tier.is-top::before { color: var(--color-text-inverse); }
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .gov-tier.is-top .gov-tier__label,
  :root:not([data-theme="light"]) .gov-tier.is-top::before { color: var(--color-text-inverse); }
}

@media (max-width: 720px) {
  .gov-tier { grid-template-columns: 1fr; gap: var(--space-3); padding: var(--space-5); }
}

/* ----- Role cards ----- */
.roles-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-5);
}
.role {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex; flex-direction: column;
  gap: var(--space-3);
  transition: transform var(--transition-interactive), box-shadow var(--transition-interactive), border-color var(--transition-interactive);
}
.role:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--color-accent); }
.role__tag {
  align-self: flex-start;
  font-family: var(--font-mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.14em;
  padding: 4px 10px; border-radius: var(--radius-full);
  background: var(--color-surface-offset); color: var(--color-text-muted);
}
.role__tag.elected { background: var(--color-primary-highlight); color: var(--color-primary); }
.role__tag.appointed { background: var(--color-accent-highlight); color: var(--color-accent-hover); }
.role__tag.automatic { background: var(--color-success-highlight); color: var(--color-success); }
.role h3 { font-size: var(--text-lg); font-weight: 500; line-height: 1.2; }
.role p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.55; }
.role dl { display: grid; grid-template-columns: auto 1fr; gap: 4px var(--space-3); font-size: var(--text-xs); margin-top: auto; padding-top: var(--space-4); border-top: 1px dashed var(--color-divider); }
.role dt { color: var(--color-text-faint); text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--font-mono); }
.role dd { color: var(--color-text); }

/* ----- Stepper (how to get elected) ----- */
.stepper { display: grid; gap: var(--space-5); counter-reset: step; }
.step {
  display: grid; grid-template-columns: 72px 1fr;
  gap: var(--space-6); align-items: start;
  padding: var(--space-5) 0;
  border-bottom: 1px solid var(--color-divider);
  counter-increment: step;
}
.step:last-child { border-bottom: none; }
.step__number {
  font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 300;
  color: var(--color-accent); line-height: 1;
  padding-top: 4px;
}
.step__number::before { content: counter(step, decimal-leading-zero); }
.step h3 { font-size: var(--text-lg); font-weight: 500; margin-bottom: var(--space-2); }
.step p { color: var(--color-text-muted); font-size: var(--text-sm); line-height: 1.55; max-width: 62ch; }
.step__tag {
  display: inline-block; font-size: var(--text-xs);
  font-family: var(--font-mono); letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--color-text-muted);
  margin-top: var(--space-3);
  padding: 3px 8px; background: var(--color-surface-offset); border-radius: var(--radius-sm);
}
@media (max-width: 560px) {
  .step { grid-template-columns: 1fr; gap: var(--space-2); }
  .step__number { font-size: var(--text-xl); }
}

/* ----- Three-column ecosystem (AMA / State / Specialty) ----- */
.ecosystem {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}
.col {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  display: flex; flex-direction: column; gap: var(--space-5);
}
.col__tag {
  font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--color-accent);
}
.col h3 { font-size: var(--text-xl); font-weight: 400; letter-spacing: -0.01em; line-height: 1.15; }
.col > p.lede { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.55; }
.col h4 { font-family: var(--font-body); font-size: var(--text-sm); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text); margin-top: var(--space-2); }
.col ul { list-style: none; display: flex; flex-direction: column; gap: var(--space-2); }
.col ul li {
  font-size: var(--text-sm);
  padding-left: var(--space-4); position: relative;
  color: var(--color-text); line-height: 1.5;
}
.col ul li::before {
  content: ''; position: absolute; left: 0; top: 8px;
  width: 8px; height: 1px; background: var(--color-accent);
}
.col ul li strong { font-weight: 600; color: var(--color-text); }
@media (max-width: 960px) { .ecosystem { grid-template-columns: 1fr; } }

/* ----- Quote / pull block ----- */
.pullquote {
  margin-block: clamp(var(--space-12), 8vw, var(--space-20));
  padding: var(--space-10) var(--space-8);
  border-left: 3px solid var(--color-accent);
  background: color-mix(in srgb, var(--color-accent-highlight) 40%, transparent);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  max-width: 780px;
}
.pullquote p {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 300;
  font-style: italic;
  line-height: 1.3;
  color: var(--color-text);
}
.pullquote cite {
  display: block; margin-top: var(--space-4);
  font-family: var(--font-body); font-style: normal;
  font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--color-text-muted);
}

/* ----- Annotated diagram: HOD composition ----- */
.hod-composition {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  align-items: stretch;
}
.hod-panel {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
}
.hod-panel h3 { font-size: var(--text-lg); font-weight: 500; margin-bottom: var(--space-5); }
.hod-stat {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: var(--space-3) 0;
  border-bottom: 1px dashed var(--color-divider);
}
.hod-stat:last-child { border-bottom: none; }
.hod-stat__label { font-size: var(--text-sm); color: var(--color-text-muted); }
.hod-stat__value { font-family: var(--font-display); font-size: var(--text-lg); color: var(--color-primary); font-weight: 500; letter-spacing: -0.01em; }
@media (max-width: 760px) { .hod-composition { grid-template-columns: 1fr; } }

/* ----- Footer ----- */
.site-footer {
  padding-block: var(--space-16) var(--space-10);
  border-top: 1px solid var(--color-divider);
  background: var(--color-surface);
}
.site-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: var(--space-12);
  margin-bottom: var(--space-10);
}
.site-footer h4 {
  font-family: var(--font-body); font-size: var(--text-xs);
  font-weight: 600; text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}
.site-footer ul { list-style: none; display: flex; flex-direction: column; gap: var(--space-2); }
.site-footer a { color: var(--color-text); font-size: var(--text-sm); }
.site-footer a:hover { color: var(--color-accent); }
.site-footer__fine {
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-divider);
  display: flex; flex-wrap: wrap; gap: var(--space-4); justify-content: space-between;
  font-size: var(--text-xs); color: var(--color-text-faint);
}
@media (max-width: 720px) { .site-footer__grid { grid-template-columns: 1fr; gap: var(--space-8); } }

/* ----- Table of contents (on scroll) ----- */
.toc {
  position: sticky; top: 88px;
  padding: var(--space-5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
}
.toc h4 { text-transform: uppercase; letter-spacing: 0.14em; font-weight: 600; margin-bottom: var(--space-3); color: var(--color-text-muted); }
.toc ol { list-style: none; display: flex; flex-direction: column; gap: var(--space-2); counter-reset: toc; }
.toc li { counter-increment: toc; display: flex; gap: var(--space-3); }
.toc li::before { content: counter(toc, decimal-leading-zero); color: var(--color-accent); font-family: var(--font-mono); }
.toc a { color: var(--color-text-muted); }
.toc a:hover, .toc a.active { color: var(--color-text); }

/* ----- Comparison table ----- */
.compare {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.compare__row {
  display: grid;
  grid-template-columns: 200px repeat(3, 1fr);
  border-bottom: 1px solid var(--color-divider);
}
.compare__row:last-child { border-bottom: none; }
.compare__row > * {
  padding: var(--space-4) var(--space-5);
  font-size: var(--text-sm);
  border-right: 1px solid var(--color-divider);
}
.compare__row > *:last-child { border-right: none; }
.compare__row.head > * {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-muted);
  font-weight: 600;
  background: var(--color-surface-offset);
}
.compare__row .label { font-weight: 500; color: var(--color-text); }
@media (max-width: 820px) {
  .compare__row { grid-template-columns: 1fr; }
  .compare__row > * { border-right: none; border-bottom: 1px solid var(--color-divider); }
  .compare__row.head { display: none; }
  .compare__row .label { background: var(--color-surface-offset); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-text-muted); }
}

/* ----- Tips / principles grid ----- */
.principles {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-5);
}
.principle {
  padding: var(--space-6);
  border-top: 2px solid var(--color-accent);
  background: var(--color-surface);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
}
.principle__num {
  font-family: var(--font-mono); font-size: var(--text-xs);
  color: var(--color-accent);
  margin-bottom: var(--space-2);
}
.principle h3 { font-size: var(--text-base); font-weight: 600; font-family: var(--font-body); margin-bottom: var(--space-2); }
.principle p { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.55; }

/* ----- Call to action band ----- */
.cta-band {
  background: var(--color-primary);
  color: var(--color-text-inverse);
  border-radius: var(--radius-xl);
  padding: clamp(var(--space-12), 8vw, var(--space-20));
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-10);
  align-items: center;
}
.cta-band h2 { color: var(--color-text-inverse); font-size: var(--text-2xl); font-weight: 350; line-height: 1.1; }
.cta-band p { margin-top: var(--space-4); color: color-mix(in srgb, var(--color-text-inverse) 78%, transparent); font-size: var(--text-base); max-width: 52ch; }
.cta-band a.btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  background: var(--color-accent);
  color: #1a1200;
  padding: var(--space-4) var(--space-6);
  border-radius: var(--radius-full);
  font-size: var(--text-sm); font-weight: 600;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.cta-band a.btn:hover { background: var(--color-accent-hover); color: #fff; transform: translateY(-1px); }
@media (max-width: 720px) { .cta-band { grid-template-columns: 1fr; } }

/* ----- Fade-in utility ----- */
.reveal { opacity: 0; transform: translateY(18px); transition: opacity 700ms ease-out, transform 700ms cubic-bezier(0.16, 1, 0.3, 1); }
.reveal.is-visible { opacity: 1; transform: none; }

/* ----- Figure captions / source tags ----- */
.source {
  font-family: var(--font-mono); font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-4);
}
.source a { color: var(--color-accent); border-bottom: 1px dotted var(--color-accent); }
.source a:hover { color: var(--color-accent-hover); border-bottom-style: solid; }

/* ==========================================================
   Get Started wizard
   ========================================================== */
.wizard-wrap {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: clamp(var(--space-8), 5vw, var(--space-16));
  max-width: 920px;
  margin-inline: auto;
}
.wizard__progress {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-text-muted);
}
.wizard__progress-track {
  flex: 1;
  height: 3px;
  background: var(--color-surface-offset);
  border-radius: var(--radius-full);
  overflow: hidden;
}
.wizard__progress-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
  transition: width 400ms cubic-bezier(0.16, 1, 0.3, 1);
  width: 0%;
}
.wizard__step {
  display: none;
  animation: wizardFade 420ms ease-out;
}
.wizard__step.is-active { display: block; }
@keyframes wizardFade {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: none; }
}
.wizard__question {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 350;
  letter-spacing: -0.015em;
  line-height: 1.2;
  margin-bottom: var(--space-3);
}
.wizard__hint {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.55;
  margin-bottom: var(--space-8);
  max-width: 56ch;
}
.wizard__options {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
.wizard__option {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-5) var(--space-6);
  text-align: left;
  cursor: pointer;
  transition: transform var(--transition-interactive),
    border-color var(--transition-interactive),
    background var(--transition-interactive),
    box-shadow var(--transition-interactive);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  min-height: 100px;
}
.wizard__option:hover {
  border-color: var(--color-accent);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.wizard__option.is-selected {
  border-color: var(--color-primary);
  background: var(--color-primary-highlight);
}
.wizard__option strong {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  display: block;
  line-height: 1.2;
}
.wizard__option span {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.45;
}
.wizard__nav {
  margin-top: var(--space-8);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-divider);
}
.wizard__btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-muted);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  background: transparent;
  cursor: pointer;
  border: 1px solid var(--color-border);
  transition: color var(--transition-interactive), border-color var(--transition-interactive), background var(--transition-interactive);
}
.wizard__btn-ghost:hover {
  color: var(--color-text);
  border-color: var(--color-accent);
  background: var(--color-accent-highlight);
}
@media (max-width: 640px) {
  .wizard__options { grid-template-columns: 1fr; }
  .wizard__question { font-size: var(--text-lg); }
}

/* Wizard result */
.wizard__summary {
  padding: var(--space-6);
  border: 1px dashed var(--color-accent);
  background: color-mix(in srgb, var(--color-accent-highlight) 60%, transparent);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-8);
}
.wizard__summary h3 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin-bottom: var(--space-4);
}
.wizard__chips {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.wizard__chips li {
  font-size: var(--text-sm);
  color: var(--color-text);
  background: var(--color-surface);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  display: flex;
  gap: var(--space-2);
  align-items: baseline;
}
.wizard__chips li span {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-text-muted);
}
.wizard__plan {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  counter-reset: plan;
}
.wizard__action {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--space-5);
  padding: var(--space-5);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  align-items: start;
  transition: border-color var(--transition-interactive);
}
.wizard__action:hover { border-color: var(--color-accent); }
.wizard__action-num {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 300;
  color: var(--color-accent);
  line-height: 1;
  padding-top: 2px;
}
.wizard__action h4 {
  font-size: var(--text-base);
  font-weight: 600;
  margin-bottom: var(--space-2);
  line-height: 1.3;
}
.wizard__action p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.55;
}
.wizard__action-link {
  display: inline-block;
  margin-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-accent);
  border-bottom: 1px dotted var(--color-accent);
}
.wizard__action-link:hover {
  color: var(--color-accent-hover);
  border-bottom-style: solid;
}
.wizard__footer {
  margin-top: var(--space-8);
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}
@media (max-width: 560px) {
  .wizard__action { grid-template-columns: 1fr; gap: var(--space-2); }
}

/* ==========================================================
   State directory
   ========================================================== */
.states-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
  flex-wrap: wrap;
}
.states-search {
  flex: 1;
  min-width: 280px;
  max-width: 520px;
  position: relative;
}
.states-search input {
  width: 100%;
  font-family: var(--font-body);
  font-size: var(--text-base);
  padding: var(--space-4) var(--space-5) var(--space-4) var(--space-10);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  color: var(--color-text);
  transition: border-color var(--transition-interactive), box-shadow var(--transition-interactive);
}
.states-search input::placeholder { color: var(--color-text-faint); }
.states-search input:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px var(--color-accent-highlight);
}
.states-search__icon {
  position: absolute;
  left: var(--space-4);
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-faint);
  pointer-events: none;
}
.states-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  white-space: nowrap;
}
.states-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-4);
}
.state-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: transform var(--transition-interactive), box-shadow var(--transition-interactive), border-color var(--transition-interactive);
  position: relative;
}
.state-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-accent);
}
.state-card__head {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: var(--space-4);
  align-items: start;
}
.state-card__abbr {
  display: grid;
  place-items: center;
  width: 44px; height: 44px;
  border-radius: var(--radius-md);
  background: var(--color-primary);
  color: var(--color-text-inverse);
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--text-sm);
  letter-spacing: 0.04em;
}
.state-card h3 {
  font-size: var(--text-base);
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 2px;
  font-family: var(--font-body);
}
.state-card__society {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.4;
  display: inline-block;
}
.state-card__society:hover { color: var(--color-accent); }
.state-card__sections {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--color-divider);
}
.state-card__sections > div {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-3);
  align-items: baseline;
}
.state-card__sections dt {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-faint);
}
.state-card__sections dd {
  font-size: var(--text-xs);
  text-align: right;
}
.state-card__sections dd a {
  color: var(--color-accent);
  border-bottom: 1px dotted var(--color-accent);
}
.state-card__sections dd a:hover {
  color: var(--color-accent-hover);
  border-bottom-style: solid;
}
.state-card__missing {
  color: var(--color-text-faint);
  font-style: italic;
}
.state-card__badge {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-success);
  background: var(--color-success-highlight);
  padding: 3px 8px;
  border-radius: var(--radius-full);
}
.states-note {
  margin-top: var(--space-8);
  padding: var(--space-5);
  background: var(--color-surface-offset);
  border-left: 3px solid var(--color-accent);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.55;
}
@media (max-width: 560px) {
  .state-card__head { grid-template-columns: 36px 1fr; }
  .state-card__abbr { width: 36px; height: 36px; font-size: 12px; }
}

/* ==========================================================
   Leadership Opportunity Map
   ========================================================== */
:root {
  --map-bg: #0a1f33;
  --map-bg-2: #061421;
  --map-fg: #e8d9b8;
  --map-fg-muted: rgba(232, 217, 184, 0.62);
  --map-fg-faint: rgba(232, 217, 184, 0.32);
  --map-line: rgba(232, 217, 184, 0.12);
  --map-glow: #a7762a;
  --map-edge: #a7762a;

  --map-auto: #e6c875;       /* warm gold */
  --map-auto-deep: #a7762a;
  --map-app: #7ab0c4;        /* cool blue */
  --map-app-deep: #3a7c93;
  --map-elect: #d8866f;      /* coral */
  --map-elect-deep: #b25638;
}
[data-theme="dark"] {
  --map-bg: #050d18;
  --map-bg-2: #02060d;
}

#leadership-map { padding-top: var(--space-2); }

.map-frame {
  border-radius: var(--radius-xl);
  background:
    radial-gradient(ellipse at 50% 0%, rgba(167, 118, 42, 0.12) 0%, transparent 55%),
    linear-gradient(180deg, var(--map-bg) 0%, var(--map-bg-2) 100%);
  border: 1px solid rgba(232, 217, 184, 0.1);
  overflow: hidden;
  box-shadow:
    0 30px 80px -30px rgba(0, 0, 0, 0.6),
    inset 0 1px 0 0 rgba(232, 217, 184, 0.05);
}

/* --- Filter controls --- */
.map-controls {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
  padding: var(--space-6) var(--space-8);
  border-bottom: 1px solid rgba(232, 217, 184, 0.08);
  background: linear-gradient(180deg, rgba(232,217,184,0.02), transparent);
}
.map-filter {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
}
.map-filter__label {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--map-fg-muted);
  white-space: nowrap;
}
.map-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.map-chip {
  background: transparent;
  border: 1px solid rgba(232, 217, 184, 0.18);
  color: var(--map-fg);
  font-family: var(--font-body);
  font-size: 12px;
  padding: 5px 12px;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition:
    background var(--transition-interactive),
    border-color var(--transition-interactive),
    color var(--transition-interactive);
}
.map-chip:hover { background: rgba(232, 217, 184, 0.06); border-color: rgba(232, 217, 184, 0.36); }
.map-chip.is-on {
  background: var(--map-fg);
  color: var(--map-bg);
  border-color: var(--map-fg);
}
.map-chip--auto.is-on { background: var(--map-auto); color: #1b1306; border-color: var(--map-auto); }
.map-chip--app.is-on { background: var(--map-app); color: #06131a; border-color: var(--map-app); }
.map-chip--elect.is-on { background: var(--map-elect); color: #2a0d05; border-color: var(--map-elect); }

/* --- Canvas + side panel layout --- */
.map-canvas-wrap {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 0;
  min-height: 720px;
}
.map-svg {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 720px;
  cursor: default;
}
.map-detail {
  border-left: 1px solid rgba(232, 217, 184, 0.08);
  background: rgba(0, 0, 0, 0.18);
  padding: var(--space-6);
  color: var(--map-fg);
  overflow-y: auto;
  max-height: 800px;
}

/* --- SVG primitives --- */
.map-ring {
  stroke: var(--map-line);
  stroke-width: 1;
  stroke-dasharray: 2 6;
  fill: none;
}
.map-ring-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  fill: var(--map-fg-muted);
  text-anchor: end;
}
.map-ring-sub {
  font-family: var(--font-body);
  font-size: 10px;
  fill: var(--map-fg-faint);
  text-anchor: end;
  font-style: italic;
}
.map-org-eyebrow {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  fill: var(--map-fg-muted);
  text-anchor: middle;
}
.map-org-name {
  font-family: 'Fraunces', serif;
  font-size: 18px;
  font-weight: 350;
  fill: var(--map-fg);
  text-anchor: middle;
  letter-spacing: -0.01em;
}
.map-org-axis {
  stroke: rgba(232, 217, 184, 0.06);
  stroke-width: 1;
  stroke-dasharray: 1 4;
}

/* --- Edges --- */
.map-edge {
  fill: none;
  stroke-width: 1.2;
  opacity: 0.45;
  transition:
    opacity 280ms cubic-bezier(0.16, 1, 0.3, 1),
    stroke-width 280ms cubic-bezier(0.16, 1, 0.3, 1);
}
.map-edge.is-fade { opacity: 0.06; }
.map-edge.is-focus { opacity: 1; stroke-width: 2.2; }
.map-edge.is-dim { opacity: 0.05; }

/* --- Nodes --- */
.map-node {
  cursor: pointer;
  transition: opacity 280ms cubic-bezier(0.16, 1, 0.3, 1);
}
.map-node__halo {
  fill: var(--map-fg);
  opacity: 0;
  transition: opacity 280ms cubic-bezier(0.16, 1, 0.3, 1), r 280ms cubic-bezier(0.16, 1, 0.3, 1);
}
.map-node__dot {
  transition:
    fill 280ms cubic-bezier(0.16, 1, 0.3, 1),
    r 280ms cubic-bezier(0.16, 1, 0.3, 1),
    opacity 280ms cubic-bezier(0.16, 1, 0.3, 1);
}
.map-node__core {
  fill: var(--map-bg);
  opacity: 0.95;
}
.map-node--automatic .map-node__dot { fill: var(--map-auto); }
.map-node--automatic .map-node__halo { fill: var(--map-auto); }
.map-node--appointed .map-node__dot { fill: var(--map-app); }
.map-node--appointed .map-node__halo { fill: var(--map-app); }
.map-node--elected .map-node__dot { fill: var(--map-elect); }
.map-node--elected .map-node__halo { fill: var(--map-elect); }

.map-node:hover .map-node__halo,
.map-node.is-focus .map-node__halo { opacity: 0.22; }
.map-node:hover .map-node__dot,
.map-node.is-focus .map-node__dot {
  filter: brightness(1.18) drop-shadow(0 0 8px currentColor);
}
.map-node.is-focus .map-node__dot { r: 16; }
.map-node.is-focus .map-node__core { fill: var(--map-bg-2); }
.map-node.is-related .map-node__dot { filter: brightness(1.1); }
.map-node.is-fade { opacity: 0.32; }
.map-node.is-dim { opacity: 0.12; pointer-events: none; }
.map-node:focus { outline: none; }
.map-node:focus-visible .map-node__halo { opacity: 0.3; }

/* Subtle drift pulse for the largest (top-orbit) nodes */
@keyframes mapNodePulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.06); }
}
.map-node__dot { transform-box: fill-box; transform-origin: center; }

/* --- Detail / placeholder panel --- */
.map-detail__placeholder { display: flex; flex-direction: column; gap: var(--space-6); }
.map-detail__hint {
  display: flex; align-items: center; gap: var(--space-3);
  font-size: 13px;
  color: var(--map-fg-muted);
  font-style: italic;
}
.map-detail__bullet {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--map-auto);
  box-shadow: 0 0 12px var(--map-auto);
}
.map-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
.map-stat {
  padding: var(--space-4);
  background: rgba(232, 217, 184, 0.04);
  border: 1px solid rgba(232, 217, 184, 0.08);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.map-stat__num {
  font-family: 'Fraunces', serif;
  font-size: 28px;
  font-weight: 300;
  color: var(--map-fg);
  line-height: 1;
}
.map-stat__label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--map-fg-muted);
}
.map-legend {
  padding-top: var(--space-4);
  border-top: 1px dashed rgba(232, 217, 184, 0.12);
}
.map-legend__title {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--map-fg-muted);
  margin-bottom: var(--space-3);
}
.map-legend ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 12px;
  color: var(--map-fg);
}
.map-legend li {
  display: flex; align-items: center; gap: 8px;
}
.map-legend__swatch {
  width: 12px; height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}
.map-legend__swatch--auto { background: var(--map-auto); box-shadow: 0 0 8px var(--map-auto); }
.map-legend__swatch--app { background: var(--map-app); box-shadow: 0 0 8px var(--map-app); }
.map-legend__swatch--elect { background: var(--map-elect); box-shadow: 0 0 8px var(--map-elect); }
.map-legend__dot {
  border-radius: 50%; flex-shrink: 0;
  background: var(--map-fg-muted);
  margin-right: 2px;
}
.map-legend__dot--sm { width: 6px; height: 6px; }
.map-legend__dot--md { width: 10px; height: 10px; }
.map-legend__dot--lg { width: 14px; height: 14px; }
.map-legend__line {
  width: 26px; height: 1px;
  background: var(--map-fg-muted);
  flex-shrink: 0;
  display: inline-block;
}

/* Detail panel for selected/hovered seat */
.map-detail__panel { display: flex; flex-direction: column; gap: var(--space-4); animation: detailFade 320ms cubic-bezier(0.16, 1, 0.3, 1); }
@keyframes detailFade {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: none; }
}
.map-detail__head { display: flex; flex-direction: column; gap: 6px; }
.map-detail__tag {
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  color: var(--map-bg);
}
.map-detail__tag--automatic { background: var(--map-auto); }
.map-detail__tag--appointed { background: var(--map-app); }
.map-detail__tag--elected { background: var(--map-elect); }
.map-detail__head h3 {
  font-family: 'Fraunces', serif;
  font-size: 20px;
  font-weight: 400;
  letter-spacing: -0.015em;
  line-height: 1.2;
  color: var(--map-fg);
}
.map-detail__org {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--map-fg-muted);
}
.map-detail__blurb {
  font-size: 13px;
  line-height: 1.55;
  color: var(--map-fg);
  opacity: 0.86;
}
.map-detail__meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2) var(--space-4);
  padding: var(--space-3) 0;
  border-top: 1px dashed rgba(232, 217, 184, 0.15);
  border-bottom: 1px dashed rgba(232, 217, 184, 0.15);
}
.map-detail__meta > div { display: flex; flex-direction: column; gap: 2px; }
.map-detail__meta dt {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--map-fg-faint);
}
.map-detail__meta dd {
  font-size: 12px;
  color: var(--map-fg);
  line-height: 1.4;
}
.map-detail__howto-label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--map-fg-muted);
  margin-bottom: 6px;
}
.map-detail__howto p {
  font-size: 13px;
  line-height: 1.55;
  color: var(--map-fg);
  opacity: 0.85;
}
.map-detail__link {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--map-auto);
  border-bottom: 1px dotted var(--map-auto);
  padding-bottom: 2px;
  align-self: flex-start;
}
.map-detail__link:hover { color: var(--map-auto); border-bottom-style: solid; }
.map-detail__close {
  margin-top: var(--space-2);
  align-self: flex-start;
  background: transparent;
  border: 1px solid rgba(232, 217, 184, 0.18);
  color: var(--map-fg-muted);
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  padding: 6px 12px;
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: color var(--transition-interactive), border-color var(--transition-interactive);
}
.map-detail__close:hover { color: var(--map-fg); border-color: var(--map-fg-muted); }

/* --- Responsive --- */
@media (max-width: 920px) {
  .map-canvas-wrap {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .map-svg { min-height: 540px; }
  .map-detail {
    border-left: none;
    border-top: 1px solid rgba(232, 217, 184, 0.08);
    max-height: none;
  }
}
@media (max-width: 560px) {
  .map-controls {
    padding: var(--space-4);
    gap: var(--space-3);
    flex-direction: column;
    align-items: flex-start;
  }
  .map-filter { flex-direction: column; align-items: flex-start; gap: 6px; }
  .map-svg { min-height: 480px; }
  .map-stats { grid-template-columns: 1fr 1fr; }
}
