/* ======================================================================
   Eternal Atlas — black-tie modernism
   Obsidian + ivory + brass. Cormorant + Inter + JetBrains Mono.
   ====================================================================== */

:root {
  /* Obsidian palette (default) */
  --bg-deep:   #07090d;
  --bg:        #0b0e14;
  --bg-soft:   #11151d;
  --bg-elev:   #161b25;
  --line:      rgba(236, 228, 211, 0.08);
  --line-2:    rgba(236, 228, 211, 0.16);
  --line-3:    rgba(236, 228, 211, 0.28);
  --ink:       #ece4d3;
  --ink-soft:  rgba(236, 228, 211, 0.72);
  --ink-mute:  rgba(236, 228, 211, 0.48);
  --ink-faint: rgba(236, 228, 211, 0.28);
  --brass:     #b89968;
  --brass-soft:#8a7449;
  --oxblood:   #6b1e25;
  --land:      rgba(236, 228, 211, 0.045);
  --land-edge: rgba(236, 228, 211, 0.18);
  --ocean-1:   #07090d;
  --ocean-2:   #0c1018;
  --grid:      rgba(236, 228, 211, 0.05);
  --pin-soft:  rgba(184, 153, 104, 0.18);

  --serif: "Cormorant Garamond", "Cormorant", "EB Garamond", Garamond, "Times New Roman", serif;
  --sans:  "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono:  "JetBrains Mono", "SFMono-Regular", ui-monospace, Menlo, Consolas, monospace;

  --ease: cubic-bezier(.22, .61, .36, 1);
  --ease-slow: cubic-bezier(.16, .84, .26, 1);
}

/* Sepia palette */
[data-palette="sepia"] {
  --bg-deep:   #1a140b;
  --bg:        #221a0e;
  --bg-soft:   #2a2113;
  --bg-elev:   #322617;
  --line:      rgba(236, 220, 188, 0.10);
  --line-2:    rgba(236, 220, 188, 0.18);
  --line-3:    rgba(236, 220, 188, 0.30);
  --ink:       #ecdcbc;
  --ink-soft:  rgba(236, 220, 188, 0.74);
  --ink-mute:  rgba(236, 220, 188, 0.50);
  --ink-faint: rgba(236, 220, 188, 0.30);
  --brass:     #c9a878;
  --brass-soft:#9c8254;
  --oxblood:   #7a2a2c;
  --land:      rgba(236, 220, 188, 0.06);
  --land-edge: rgba(236, 220, 188, 0.22);
  --ocean-1:   #1a140b;
  --ocean-2:   #261c10;
  --grid:      rgba(236, 220, 188, 0.06);
  --pin-soft:  rgba(201, 168, 120, 0.20);
}

/* Ivory palette */
[data-palette="ivory"] {
  --bg-deep:   #ece4d1;
  --bg:        #f1ebd9;
  --bg-soft:   #e7dfc9;
  --bg-elev:   #ddd4bb;
  --line:      rgba(28, 24, 16, 0.10);
  --line-2:    rgba(28, 24, 16, 0.18);
  --line-3:    rgba(28, 24, 16, 0.32);
  --ink:       #1c1810;
  --ink-soft:  rgba(28, 24, 16, 0.74);
  --ink-mute:  rgba(28, 24, 16, 0.52);
  --ink-faint: rgba(28, 24, 16, 0.32);
  --brass:     #8a6b32;
  --brass-soft:#6e5527;
  --oxblood:   #6b1e25;
  --land:      rgba(28, 24, 16, 0.07);
  --land-edge: rgba(28, 24, 16, 0.26);
  --ocean-1:   #ece4d1;
  --ocean-2:   #e1d8c0;
  --grid:      rgba(28, 24, 16, 0.06);
  --pin-soft:  rgba(138, 107, 50, 0.16);
}

* { box-sizing: border-box; }

html, body, #root {
  height: 100%;
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow: hidden;
  transition: background .9s var(--ease-slow), color .9s var(--ease-slow);
}

button { font: inherit; color: inherit; background: transparent; border: 0; cursor: pointer; padding: 0; }
input { font: inherit; color: inherit; background: transparent; border: 0; outline: none; }

/* ======================================================================
   APP SHELL
   ====================================================================== */

.atlas {
  position: fixed;
  inset: 0;
  display: grid;
  grid-template-columns: 340px 1fr;
  background: radial-gradient(ellipse 90% 70% at 50% 50%, var(--ocean-2) 0%, var(--ocean-1) 70%, var(--bg-deep) 100%);
  overflow: hidden;
}

.main {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto;
  grid-template-areas:
    "top"
    "stage"
    "bottom";
  min-width: 0;
  min-height: 0;
  overflow: hidden;
}
.main > .stage { grid-area: stage; }
.main > .chrome-top { grid-area: top; }
.main > .bottom-panel { grid-area: bottom; }

/* subtle film grain */
.atlas::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.93  0 0 0 0 0.89  0 0 0 0 0.83  0 0 0 0.04 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: .35;
  mix-blend-mode: overlay;
  z-index: 1;
}
[data-palette="ivory"] .atlas::after { mix-blend-mode: multiply; opacity: .25; }

/* vignette */
.vignette {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(ellipse 80% 80% at 50% 50%, transparent 50%, rgba(0,0,0,.35) 100%);
  z-index: 2;
}
[data-palette="ivory"] .vignette {
  background: radial-gradient(ellipse 80% 80% at 50% 50%, transparent 55%, rgba(20,16,8,.12) 100%);
}

.stage {
  position: relative;
  z-index: 3;
  min-height: 0;
  overflow: hidden;
  contain: layout paint style;
}


/* ======================================================================
   MAP / GLOBE
   ====================================================================== */

.map-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  cursor: grab;
  contain: layout paint style;
  touch-action: none;
}
.map-canvas:active { cursor: grabbing; }

.map-canvas .graticule {
  fill: none;
  stroke: var(--grid);
  stroke-width: 0.5;
}

.map-canvas .land {
  fill: var(--land);
  stroke: var(--land-edge);
  stroke-width: 0.6;
  stroke-linejoin: round;
}

.map-canvas .country {
  fill: var(--land);
  stroke: var(--land-edge);
  stroke-width: 0.7;
  stroke-linejoin: round;
  cursor: pointer;
  transition: fill .35s var(--ease), fill-opacity .6s var(--ease), stroke-opacity .35s var(--ease);
}
.map-canvas.map-overview .country:hover,
.map-canvas.map-overview .country.hover {
  fill: rgba(184, 153, 104, 0.10);
  stroke: var(--brass);
  stroke-opacity: 0.85;
}
.map-canvas .country.muted {
  fill-opacity: 0.25;
  stroke-opacity: 0.25;
  transition-duration: .8s;
}
.map-canvas.map-overview .country.focus {
  fill: rgba(184, 153, 104, 0.18);
  stroke: var(--brass);
  stroke-width: 0.9;
  stroke-opacity: 1;
}
.map-canvas .country.no-targets {
  cursor: default;
}
.map-canvas.map-overview .country.no-targets:hover,
.map-canvas.map-overview .country.no-targets.hover {
  fill: var(--land);
  stroke: var(--land-edge);
  stroke-opacity: inherit;
}
[data-palette="ivory"] .map-canvas.map-overview .country:hover,
[data-palette="ivory"] .map-canvas.map-overview .country.hover {
  fill: rgba(138, 107, 50, 0.10);
}
[data-palette="ivory"] .map-canvas.map-overview .country.focus {
  fill: rgba(138, 107, 50, 0.16);
}

/* Administrative subdivisions (states / provinces / regions) — only render
   while a country is focused.  vector-effect: non-scaling-stroke keeps lines
   pixel-thin even at city-zoom scale. */
.map-canvas .subdivision {
  fill: none;
  stroke: var(--brass);
  stroke-opacity: 0.32;
  stroke-width: 0.6;
  stroke-linejoin: round;
  pointer-events: none;
  vector-effect: non-scaling-stroke;
  opacity: 0;
  animation: subdivIn .8s var(--ease-slow) .9s forwards;
}
@keyframes subdivIn { to { opacity: 1; } }
[data-palette="ivory"] .map-canvas .subdivision { stroke-opacity: 0.45; }

/* Hyperdetailed city map layers — fade in alongside admin1.  All
   non-interactive; vector-effect keeps line widths constant at any zoom. */
.map-canvas .urban-area {
  fill: var(--brass);
  fill-opacity: 0.06;
  stroke: none;
  pointer-events: none;
  opacity: 0;
  animation: subdivIn .8s var(--ease-slow) .9s forwards;
}
.map-canvas .lake {
  fill: var(--ocean-1);
  stroke: var(--brass);
  stroke-opacity: 0.18;
  stroke-width: 0.4;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
  opacity: 0;
  animation: subdivIn .8s var(--ease-slow) .9s forwards;
}
.map-canvas .river {
  fill: none;
  stroke: var(--brass);
  stroke-opacity: 0.32;
  stroke-width: 0.5;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
  opacity: 0;
  animation: subdivIn .8s var(--ease-slow) .9s forwards;
}
.map-canvas .road {
  fill: none;
  stroke: var(--ink-faint);
  stroke-opacity: 0.45;
  stroke-width: 0.4;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
  opacity: 0;
  animation: subdivIn 1s var(--ease-slow) 1.1s forwards;
}
[data-palette="ivory"] .map-canvas .urban-area {
  fill: var(--brass-soft);
  fill-opacity: 0.10;
}
[data-palette="ivory"] .map-canvas .road {
  stroke: var(--ink-mute);
  stroke-opacity: 0.35;
}

/* OSM-derived hyperdetail (city focus only) — parks, water, streets, waterways. */
.map-canvas .osm-park {
  fill: var(--brass);
  fill-opacity: 0.13;
  stroke: none;
  pointer-events: none;
}
.map-canvas .osm-water {
  fill: var(--ocean-1);
  stroke: var(--brass);
  stroke-opacity: 0.36;
  stroke-width: 0.55;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
}
.map-canvas .osm-waterway {
  fill: none;
  stroke: var(--brass);
  stroke-opacity: 0.58;
  stroke-width: 0.6;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
}
.map-canvas .osm-street {
  fill: none;
  stroke: var(--ink-mute);
  stroke-opacity: 0.62;
  stroke-width: 0.46;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
}
[data-palette="ivory"] .map-canvas .osm-park {
  fill: var(--brass-soft);
  fill-opacity: 0.12;
}
[data-palette="ivory"] .map-canvas .osm-street {
  stroke: var(--ink-mute);
  stroke-opacity: 0.4;
}

/* City cluster pin (≥2 institutions in same city, country-focus mode only). */
.cluster-pin { cursor: pointer; }
.cluster-halo { fill: var(--brass); fill-opacity: 0.06; transition: fill-opacity .35s var(--ease); }
.cluster-ring { fill: none; stroke: var(--brass); stroke-opacity: 0.7; stroke-width: 1.2; transition: stroke-opacity .35s var(--ease); }
.cluster-core { fill: var(--brass); fill-opacity: 0.95; }
.cluster-pin:hover .cluster-halo { fill-opacity: 0.20; }
.cluster-pin:hover .cluster-ring { stroke-opacity: 1; stroke-width: 1.6; }
.city-state-pin.is-rimmed .cluster-ring {
  stroke-dasharray: 2 3;
}
.city-state-pin.is-rimmed .cluster-core {
  fill-opacity: 0.82;
}
.cluster-count {
  fill: var(--bg);
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
  pointer-events: none;
}
.cluster-label {
  fill: var(--ink);
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  letter-spacing: .01em;
  paint-order: stroke;
  stroke: var(--bg);
  stroke-width: 4px;
  stroke-linejoin: round;
  pointer-events: none;
  opacity: 1;
  transition: opacity .2s var(--ease);
}
[data-palette="ivory"] .cluster-count { fill: var(--bg); }

.map-canvas .sphere {
  fill: var(--ocean-1);
  stroke: var(--line-2);
  stroke-width: 1;
}

.map-canvas .sphere-glow {
  fill: url(#sphereGlow);
  pointer-events: none;
}

/* Pins */
.pin-layer { pointer-events: auto; }

.pin {
  cursor: pointer;
  transform-origin: center;
  transition: transform .4s var(--ease);
}

.pin .halo {
  fill: var(--brass);
  fill-opacity: 0;
  transition: fill-opacity .6s var(--ease);
}

.pin .ring {
  fill: none;
  stroke: var(--brass);
  stroke-opacity: .55;
  stroke-width: 0.7;
  transition: stroke-opacity .4s var(--ease);
}

.pin .core {
  fill: var(--ink);
  transition: fill .3s var(--ease);
}

.pin.eternal .core { fill: var(--brass); }
.pin.trophy .core { fill: var(--ink-soft); }
.pin.unownable .core { fill: var(--ink-faint); }
.pin.avoid .core { fill: var(--oxblood); opacity: .55; }

.pin.high .halo {
  fill-opacity: .1;
  animation: breathe 4s var(--ease-slow) infinite;
}

.pin:hover .ring,
.pin.hovered .ring { stroke-opacity: 1; }
.pin:hover .halo,
.pin.hovered .halo { fill-opacity: .18; }

.pin.selected .ring { stroke-opacity: 1; stroke-width: 1.2; }
.pin.selected .core { fill: var(--brass); }
.pin.selected .halo { fill-opacity: .25; animation: none; }

.pin.dimmed { opacity: .15; pointer-events: none; }

@keyframes breathe {
  0%, 100% { opacity: .55; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.35); }
}

/* Pin label (selected only) */
.pin-label {
  pointer-events: none;
  fill: var(--ink);
  font-family: var(--serif);
  font-size: 13px;
  font-style: italic;
  letter-spacing: .01em;
  paint-order: stroke;
  stroke: var(--bg);
  stroke-width: 3px;
  stroke-linejoin: round;
}

/* Pin label shown for every pin inside a focused country.  Sized in viewBox
   units (~22 ≈ 12 px on screen at typical scale) so the label stays readable
   against the now-larger landmass.  Paint-order stroke against var(--bg)
   keeps it legible across all three palettes. */
.pin-focus-label {
  pointer-events: none;
  fill: var(--ink);
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  letter-spacing: .01em;
  paint-order: stroke;
  stroke: var(--bg);
  stroke-width: 4.5px;
  stroke-linejoin: round;
  opacity: 0;
  animation: focusLabelIn .8s var(--ease-slow) .9s forwards;
}
.pin.in-focus .core { fill: var(--brass); }
.pin.in-focus .ring { stroke-opacity: 1; }
@keyframes focusLabelIn {
  to { opacity: 1; }
}

/* ======================================================================
   HOVER PREVIEW CARD
   ====================================================================== */

.hover-card {
  position: fixed;
  z-index: 40;
  background: var(--bg-elev);
  border: 1px solid var(--line-2);
  padding: 14px 16px 13px;
  width: 280px;
  pointer-events: none;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .25s var(--ease), transform .25s var(--ease);
  will-change: transform, opacity;
  box-shadow: 0 24px 60px rgba(0,0,0,.55), 0 1px 0 rgba(255,255,255,.02) inset;
}
.hover-card.visible { opacity: 1; transform: translateY(0); }

.hover-card .hc-eyebrow {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  color: var(--brass);
  text-transform: uppercase;
}
.hover-card .hc-title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 22px;
  line-height: 1.05;
  margin: 6px 0 4px;
  letter-spacing: .005em;
}
.hover-card .hc-place {
  font-family: var(--sans);
  font-size: 11.5px;
  color: var(--ink-mute);
  letter-spacing: .04em;
}
.hover-card .hc-rule {
  height: 1px;
  background: var(--line-2);
  margin: 11px 0 10px;
}
.hover-card .hc-row {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.hover-card .hc-row b { color: var(--ink); font-weight: 500; }

/* ======================================================================
   TOP CHROME
   ====================================================================== */

.chrome {
  position: relative;
  z-index: 20;
  pointer-events: none;
}
.chrome > * { pointer-events: auto; }

.chrome-top {
  position: relative;
  padding: 22px 36px 18px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  z-index: 20;
  pointer-events: auto;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(0,0,0,.18), transparent);
}
[data-palette="ivory"] .chrome-top {
  background: linear-gradient(180deg, rgba(241,235,217,.5), transparent);
}

.wordmark {
  display: flex;
  align-items: center;
  gap: 16px;
}
.atlas-seal {
  flex-shrink: 0;
  display: block;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.2));
}
[data-palette="ivory"] .atlas-seal {
  filter: drop-shadow(0 0 0.5px rgba(0,0,0,.15));
}
.wordmark-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: flex-start;
  border-left: 1px solid var(--line-2);
  padding-left: 16px;
}
.wordmark .mark {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: 22px;
  letter-spacing: -.005em;
  color: var(--ink);
  line-height: 1;
  white-space: nowrap;
}
.wordmark .sub {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-mute);
  white-space: nowrap;
}
.wordmark .folio {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  color: var(--brass);
  border-left: 1px solid var(--line-2);
  padding-left: 14px;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}

/* search */
.search {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
}
.search-trigger {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 1px solid var(--line-2);
  background: rgba(11, 14, 20, .55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  transition: border-color .3s var(--ease), color .3s var(--ease);
}
[data-palette="ivory"] .search-trigger { background: rgba(241, 235, 217, .55); }
.search-trigger:hover { border-color: var(--line-3); color: var(--ink); }
.search-trigger > span:first-child { white-space: nowrap; }

.method-trigger {
  display: flex;
  align-items: center;
  padding: 10px 14px;
  border: 1px solid var(--line-2);
  background: transparent;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  transition: border-color .3s var(--ease), color .3s var(--ease);
  cursor: pointer;
}
.method-trigger:hover { border-color: var(--line-3); color: var(--ink); }
.search-trigger .kbd {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .1em;
  color: var(--ink-faint);
  border: 1px solid var(--line);
  padding: 2px 5px;
  margin-left: 4px;
}

.search-panel {
  position: absolute;
  top: 0; right: 0;
  width: 380px;
  background: var(--bg-elev);
  border: 1px solid var(--line-2);
  padding: 14px 16px 0;
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  transition: opacity .35s var(--ease), transform .35s var(--ease);
  will-change: transform, opacity;
  box-shadow: 0 24px 60px rgba(0,0,0,.55);
}
.search-panel.open { opacity: 1; transform: translateY(0); pointer-events: auto; }
.search-panel input {
  width: 100%;
  font-family: var(--serif);
  font-size: 22px;
  font-style: italic;
  font-weight: 300;
  padding: 6px 0 12px;
  border-bottom: 1px solid var(--line-2);
  color: var(--ink);
}
.search-panel input::placeholder { color: var(--ink-faint); font-style: italic; }
.search-results {
  max-height: 360px;
  overflow-y: auto;
  padding: 8px 0 14px;
  scrollbar-width: thin;
  scrollbar-color: var(--line-2) transparent;
}
.search-result {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  padding: 12px 8px;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background .2s var(--ease);
}
.search-result:last-child { border-bottom: 0; }
.search-section-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-faint);
  padding: 14px 8px 6px;
}
.search-section-label:first-child { padding-top: 4px; }
.search-result-country .sr-name {
  font-family: var(--serif);
  font-style: italic;
  color: var(--brass);
  font-size: 17px;
}
.search-result-country .sr-meta {
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}
.search-result:hover, .search-result.active {
  background: rgba(184,153,104,.06);
}
.search-result .sr-name {
  font-family: var(--serif);
  font-size: 16px;
  color: var(--ink);
}
.search-result .sr-meta {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.search-empty {
  padding: 20px 4px;
  font-family: var(--serif);
  font-style: italic;
  color: var(--ink-faint);
  font-size: 14px;
}

/* ======================================================================
   LEFT FILTER RAIL
   ====================================================================== */

.chrome-left {
  position: absolute;
  left: 36px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 18;
  pointer-events: auto;
}
.rail {
  display: flex;
  flex-direction: column;
  gap: 24px;
  max-height: 70vh;
}
.rail-section { display: flex; flex-direction: column; gap: 10px; }
.rail-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .28em;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.rail-chips {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 40vh;
  overflow-y: auto;
  padding-right: 4px;
  scrollbar-width: thin;
  scrollbar-color: var(--line-2) transparent;
}
.rail-chip {
  font-family: var(--sans);
  font-size: 11.5px;
  letter-spacing: .04em;
  color: var(--ink-mute);
  padding: 4px 0;
  text-align: left;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  transition: color .25s var(--ease);
  border-bottom: 1px solid transparent;
}
.rail-chip > span:first-child {
  min-width: 0;
  overflow-wrap: break-word;
  word-break: break-word;
  line-height: 1.3;
}
.rail-chip .count { flex: 0 0 auto; white-space: nowrap; }
.rail-chip:hover { color: var(--ink); }
.rail-chip.active { color: var(--ink); }
.rail-chip.active .dot { background: var(--brass); }
.rail-chip .dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--ink-faint);
  margin-right: 8px;
  vertical-align: middle;
  transition: background .25s var(--ease);
}
.rail-chip .count {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .12em;
  color: var(--ink-faint);
}

/* quadrant toggles */
.quad-toggles { display: flex; flex-direction: column; gap: 4px; }
.quad-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  font-family: var(--sans);
  font-size: 11.5px;
  letter-spacing: .03em;
  color: var(--ink-mute);
  transition: color .25s var(--ease);
  text-align: left;
}
.quad-toggle:hover { color: var(--ink); }
.quad-toggle.active { color: var(--ink); }
.quad-toggle .marker {
  width: 10px; height: 10px; flex: 0 0 auto;
  border: 1px solid var(--line-3);
  display: inline-block;
}
.quad-toggle.active .marker { background: var(--brass); border-color: var(--brass); }

/* ======================================================================
   BOTTOM TIMELINE
   ====================================================================== */

.chrome-bottom {
  position: absolute;
  left: 36px;
  right: 36px;
  bottom: 28px;
  z-index: 18;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 32px;
  pointer-events: none;
}
.chrome-bottom > * { pointer-events: auto; }

.timeline {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 720px;
}
.timeline-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .28em;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.timeline-head .year {
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  color: var(--brass);
  letter-spacing: 0;
  text-transform: none;
}
.timeline-track {
  position: relative;
  height: 28px;
  cursor: pointer;
}
.timeline-rail {
  position: absolute;
  left: 0; right: 0; top: 14px;
  height: 1px;
  background: var(--line-2);
}
.timeline-fill {
  position: absolute;
  left: 0; top: 14px;
  height: 1px;
  background: var(--brass);
  transition: width .12s linear;
}
.timeline-tick {
  position: absolute;
  top: 12px;
  width: 1px;
  height: 5px;
  background: var(--line-3);
  transform: translateX(-50%);
}
.timeline-tick.major {
  height: 9px;
  top: 8px;
  background: var(--line-3);
}
.timeline-tick-label {
  position: absolute;
  top: 22px;
  transform: translateX(-50%);
  font-family: var(--mono);
  font-size: 8.5px;
  letter-spacing: .14em;
  color: var(--ink-faint);
}
.timeline-handle {
  position: absolute;
  top: 14px;
  width: 12px;
  height: 12px;
  border: 1px solid var(--brass);
  background: var(--bg);
  transform: translate(-50%, -50%) rotate(45deg);
  pointer-events: none;
  transition: background .2s var(--ease);
}
.timeline-track:hover .timeline-handle { background: var(--brass); }
.timeline-pip {
  position: absolute;
  top: 14px;
  width: 2px;
  height: 2px;
  border-radius: 50%;
  background: var(--brass);
  opacity: .35;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

/* metric cluster (right of timeline) */
.metrics {
  display: flex;
  gap: 36px;
  padding: 0 0 4px;
}
.metric { display: flex; flex-direction: column; gap: 4px; }
.metric .v {
  font-family: var(--serif);
  font-style: italic;
  font-size: 32px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
  letter-spacing: 0;
}
.metric .v small {
  font-family: var(--mono);
  font-size: 11px;
  font-style: normal;
  letter-spacing: .14em;
  color: var(--ink-mute);
  margin-left: 4px;
}
.metric .l {
  font-family: var(--mono);
  font-size: 8.5px;
  letter-spacing: .26em;
  color: var(--ink-mute);
  text-transform: uppercase;
}

/* ======================================================================
   INDEX DRAWER (right edge)
   ====================================================================== */

.index-tab {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 17;
  writing-mode: vertical-rl;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding: 22px 14px;
  border-left: 1px solid var(--line-2);
  background: rgba(11, 14, 20, .35);
  backdrop-filter: blur(6px);
  transition: color .3s var(--ease), background .3s var(--ease), border-color .3s var(--ease);
}
[data-palette="ivory"] .index-tab { background: rgba(241, 235, 217, .35); }
.index-tab:hover { color: var(--ink); border-color: var(--line-3); }

.drawer {
  /* legacy drawer (deprecated) */
  display: none;
}
.drawer-removed-block {
  right: 0;
  width: 440px;
  z-index: 30;
  background: var(--bg-soft);
  border-left: 1px solid var(--line-2);
  transform: translateX(100%);
  transition: transform .8s var(--ease-slow);
  overflow: hidden;
  display: none;
  flex-direction: column;
  box-shadow: -32px 0 80px rgba(0,0,0,.45);
}
.drawer.open { transform: translateX(0); }
.drawer-head {
  padding: 28px 32px 22px;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  border-bottom: 1px solid var(--line);
}
.drawer-head h2 {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: 28px;
  margin: 0;
  letter-spacing: .005em;
}
.drawer-head .sub {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-top: 6px;
}
.drawer-close {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--ink-mute);
  text-transform: uppercase;
  transition: color .25s var(--ease);
}
.drawer-close:hover { color: var(--ink); }

.drawer-sort {
  padding: 14px 32px;
  display: flex;
  gap: 18px;
  border-bottom: 1px solid var(--line);
}
.sort-btn {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  transition: color .25s var(--ease);
}
.sort-btn.active { color: var(--brass); }
.sort-btn:hover { color: var(--ink); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }
}

.drawer-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px 32px 32px;
  scrollbar-width: thin;
  scrollbar-color: var(--line-2) transparent;
}
.entry {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr) auto;
  gap: 12px;
  padding: 16px 0;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background .25s var(--ease);
  align-items: start;
}
.entry:hover { background: rgba(184,153,104,.04); }
.entry.active { background: rgba(184,153,104,.08); }
.entry .num {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .14em;
  color: var(--ink-faint);
  padding-top: 5px;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}
.entry .body { min-width: 0; overflow: hidden; }
.entry .name {
  font-family: var(--serif);
  font-size: 19px;
  font-weight: 400;
  letter-spacing: .003em;
  line-height: 1.15;
  color: var(--ink);
  margin-bottom: 6px;
  word-break: break-word;
}
.entry .meta {
  display: grid;
  grid-template-rows: auto auto;
  row-gap: 2px;
  min-width: 0;
  min-height: 32px;
}
.entry .meta-line {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .18em;
  color: var(--ink-mute);
  text-transform: uppercase;
  min-width: 0;
}
.entry .meta-place {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}
.entry .meta-year {
  color: var(--ink-faint);
  flex: 0 0 auto;
}
.entry .meta-year::before {
  content: "·";
  margin-right: 8px;
  color: var(--ink-faint);
}
.entry .meta-cat {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .16em;
  color: var(--ink-faint);
  text-transform: uppercase;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.entry .score {
  font-family: var(--serif);
  font-style: italic;
  font-size: 18px;
  color: var(--brass);
  align-self: start;
  padding-top: 2px;
  letter-spacing: 0;
  min-width: 32px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}

/* ======================================================================
   DETAIL SPREAD (full-bleed editorial)
   ====================================================================== */

.spread {
  position: absolute;
  inset: 0;
  z-index: 50;
  background: var(--bg);
  opacity: 0;
  pointer-events: none;
  transition: opacity 1.1s var(--ease-slow);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--line-2) transparent;
}
.spread.open { opacity: 1; pointer-events: auto; }

.spread-frame {
  position: relative;
  min-height: 100%;
  padding: 56px 88px 88px;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: 0;
}

.spread-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--line-2);
}
.spread-folio {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.spread-folio { font-variant-numeric: tabular-nums; font-feature-settings: "tnum"; }
.spread-folio .num { color: var(--brass); }
.spread-back {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink-mute);
  display: flex;
  align-items: center;
  gap: 10px;
  transition: color .25s var(--ease);
}
.spread-back:hover { color: var(--ink); }
.spread-back .ar { font-family: var(--serif); font-style: italic; font-size: 16px; letter-spacing: 0; }

.spread-title-block {
  padding: 56px 0 48px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
.spread-eyebrow {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--brass);
}
.spread-title {
  font-family: var(--serif);
  font-weight: 300;
  font-style: normal;
  font-size: clamp(64px, 9vw, 132px);
  line-height: .95;
  letter-spacing: -.012em;
  margin: 0;
  color: var(--ink);
  text-wrap: balance;
}
.spread-subtitle {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.3;
  color: var(--ink-soft);
  margin: 0;
  max-width: 56ch;
  letter-spacing: .003em;
}

/* Three-row spread layout: narrative+scoring → meta band → evidence banner.
   Each row carries its own border-top so missing rows don't leave dangling rules. */
.spread-narrative {
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
  gap: 72px;
  padding-top: 48px;
  margin-top: 16px;
  border-top: 1px solid var(--line-2);
}
.spread-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 56px;
  padding-top: 48px;
  margin-top: 56px;
  border-top: 1px solid var(--line-2);
}
.spread-evidence {
  padding-top: 48px;
  margin-top: 56px;
  border-top: 1px solid var(--line-2);
  margin-bottom: 56px;
}
.spread-evidence-grid {
  display: grid;
  grid-template-columns: minmax(180px, auto) minmax(0, 1fr) minmax(220px, auto);
  gap: 48px;
  align-items: start;
}
@media (max-width: 1100px) {
  .spread-evidence-grid { grid-template-columns: 1fr; gap: 28px; }
}
.evi-block { display: flex; flex-direction: column; gap: 10px; }
.evi-block .k {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.evi-block .v {
  font-family: var(--serif);
  font-size: 16px;
  line-height: 1.5;
  color: var(--ink);
  letter-spacing: .002em;
}
.evi-block .v.v-italic { font-style: italic; color: var(--ink-soft); }

.spread-narrative h4,
.spread-meta-card h4,
.spread-evidence h4 {
  font-family: var(--mono);
  font-size: 9.5px;
  font-weight: 500;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--brass);
  margin: 0 0 18px;
  clear: both;
}
.spread-narrative-prose h4 + h4,
.spread-meta-card h4 + h4 { margin-top: 36px; }
.spread-narrative-prose h4:not(:first-child) { margin-top: 32px; }
.spread-narrative-prose h4:first-child,
.spread-meta-card h4:first-child,
.spread-evidence h4:first-child { margin-top: 0; }

/* the .v-* helpers replace the old inline-style overrides */
.spread-fact .v.v-mono { font-family: var(--mono); font-size: 13px; letter-spacing: .04em; }
.spread-fact .v.v-secondary { font-size: 13.5px; line-height: 1.55; color: var(--ink-soft); }
.spread-fact .v.v-italic { font-style: italic; font-size: 13.5px; line-height: 1.5; color: var(--ink-soft); }
.spread-fact .v .v-aside {
  font-style: italic;
  color: var(--ink-mute);
  font-size: 14px;
  display: block;
  margin-top: 2px;
}

/* ticker pill for holding company exchange:ticker */
.ticker-pill {
  display: inline-block;
  padding: 2px 9px 2px 9px;
  margin-left: 10px;
  background: rgba(184,153,104,0.07);
  border: 1px solid var(--line);
  color: var(--brass);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  vertical-align: 2px;
  font-variant-numeric: tabular-nums;
}

/* last-verified caption inside Confidence cell */
.last-verified {
  display: inline-block;
  margin-left: 12px;
  color: var(--ink-faint);
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .04em;
  font-variant-numeric: tabular-nums;
}

/* ======================================================================
   COUNTRY DETAIL — slide-in left rail when a country is focused on the globe
   ====================================================================== */
.country-detail {
  position: fixed;
  left: 0;
  top: 0;
  bottom: 0;
  width: 340px;
  z-index: 30;
  background: var(--bg);
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  transform: translateX(-100%);
  transition: transform .6s var(--ease-slow);
  pointer-events: none;
}
.country-detail.open {
  transform: translateX(0);
  pointer-events: auto;
}
.country-detail-head {
  padding: 22px 28px 20px;
  border-bottom: 1px solid var(--line);
}
.country-detail-head .spread-back {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 24px;
}
.country-eyebrow {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 8px;
}
.country-name {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: 36px;
  line-height: 1.04;
  letter-spacing: -.005em;
  color: var(--ink);
  margin: 0 0 12px;
}
.country-sub {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
}
.country-region {
  color: var(--ink-faint);
}
.country-quad-strip {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 18px;
}
.country-quad-badge {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.country-quad-badge .dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--brass-soft);
  flex-shrink: 0;
}
.country-quad-badge.eternal .dot { background: var(--brass); }
.country-quad-badge.trophy .dot { background: var(--ink-soft); }
.country-quad-badge.unownable .dot { background: var(--ink-faint); }
.country-quad-badge.avoid .dot { background: var(--oxblood); opacity: 0.7; }
.country-quad-badge .cnt {
  margin-left: auto;
  color: var(--brass);
  font-variant-numeric: tabular-nums;
}
.country-detail-list {
  flex: 1;
  overflow-y: auto;
  padding: 0 28px 28px;
  scrollbar-width: thin;
  scrollbar-color: var(--line-2) transparent;
}

.spread-thesis {
  font-family: var(--serif);
  font-size: clamp(20px, 1.5vw, 24px);
  line-height: 1.45;
  font-weight: 400;
  color: var(--ink);
  margin: 0 0 28px;
  text-wrap: pretty;
  letter-spacing: .002em;
}
.spread-thesis::first-letter {
  font-family: var(--serif);
  float: left;
  font-size: 4.6em;
  line-height: .82;
  margin: 0.05em 0.08em 0 -0.04em;
  font-weight: 400;
  color: var(--brass);
}
.spread-prose {
  font-family: var(--serif);
  font-size: 17px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 18px;
  text-wrap: pretty;
}

.spread-facts {
  border-top: 1px solid var(--line);
}
.spread-fact {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 24px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.spread-fact .k {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.spread-fact .v {
  font-family: var(--serif);
  font-size: 17px;
  color: var(--ink);
  letter-spacing: .002em;
}
.spread-fact .v em {
  font-style: italic;
  color: var(--ink-soft);
  font-size: 15px;
  display: block;
  margin-top: 2px;
}

/* score grid */
.score-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--line-2);
  border-left: 1px solid var(--line-2);
  margin-bottom: 28px;
}
.score-cell {
  padding: 22px 20px;
  border-right: 1px solid var(--line-2);
  border-bottom: 1px solid var(--line-2);
  display: flex;
  flex-direction: column;
  min-height: 132px;
}
.score-cell .lab {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 8px;
}
.score-cell .val {
  font-family: var(--serif);
  font-size: 44px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
  letter-spacing: -.005em;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}
.score-cell .val small {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .14em;
  color: var(--ink-mute);
  margin-left: 4px;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}
.score-cell .bar {
  height: 1px;
  background: var(--line);
  margin-top: auto;
  position: relative;
  overflow: hidden;
}
.score-cell-quadrant .val {
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: 0;
  font-style: italic;
}
.score-cell .bar::after {
  content: "";
  position: absolute;
  left: 0; top: 0; height: 100%;
  background: var(--brass);
  width: var(--p, 0%);
  transition: width 1.4s var(--ease-slow) .3s;
}

.scoring-rationale {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px dashed var(--line-2);
}
.scoring-rationale h5 {
  font-family: var(--mono);
  font-size: 9.5px;
  font-weight: 500;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--brass);
  margin: 0 0 12px;
}
.scoring-rationale p {
  font-family: var(--serif);
  font-size: 15.5px;
  line-height: 1.65;
  color: var(--ink-soft);
  margin: 0;
  letter-spacing: .002em;
}

.spread-disclaimer {
  margin-top: 56px;
  padding: 28px 32px;
  border: 1px solid var(--line-2);
  border-left: 3px solid var(--brass);
  background: rgba(180, 140, 80, 0.03);
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 20px;
  align-items: start;
  margin-bottom: 28px;
}
.disclaimer-mark {
  font-size: 22px;
  color: var(--brass);
  line-height: 1.2;
  font-family: var(--serif);
}
.disclaimer-body h4 {
  font-family: var(--mono);
  font-size: 9.5px;
  font-weight: 500;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--brass);
  margin: 0 0 14px;
}
.disclaimer-body p {
  font-family: var(--serif);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0 0 12px;
  letter-spacing: .003em;
}
.disclaimer-body p:last-child { margin-bottom: 0; }
.disclaimer-body .disclaimer-foot {
  font-size: 12.5px;
  color: var(--ink-mute);
  font-style: italic;
}

.spread-bottom {
  border-top: 1px solid var(--line-2);
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}

/* ======================================================================
   COMPASS (top-right corner of map)
   ====================================================================== */

.compass {
  position: absolute;
  z-index: 16;
  pointer-events: none;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .22em;
  color: var(--ink-faint);
  text-transform: uppercase;
}

/* ======================================================================
   MAP MODE TOGGLE (bottom-right of map area)
   ====================================================================== */

.mode-toggle {
  position: absolute;
  right: 36px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 16;
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--line-2);
}
.mode-toggle.shifted { right: 480px; }
.mode-toggle button {
  display: block;
  padding: 14px 16px;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-mute);
  border-bottom: 1px solid var(--line-2);
  transition: color .25s var(--ease), background .25s var(--ease);
  background: rgba(11,14,20,.35);
  backdrop-filter: blur(6px);
  writing-mode: vertical-rl;
  min-height: 80px;
}
[data-palette="ivory"] .mode-toggle button { background: rgba(241,235,217,.35); }
.mode-toggle button:last-child { border-bottom: 0; }
.mode-toggle button.active { color: var(--brass); background: rgba(184,153,104,.08); }
.mode-toggle button:hover { color: var(--ink); }

/* ======================================================================
   TWEAKS PANEL OVERRIDES (subtle, fits the design)
   ====================================================================== */

.tweaks-host {
  font-family: var(--sans);
}

/* loader */
.loader {
  position: fixed;
  inset: 0;
  z-index: 100;
  background:
    radial-gradient(ellipse 70% 55% at 50% 45%, var(--ocean-2) 0%, var(--ocean-1) 62%, var(--bg-deep) 100%);
  display: grid;
  place-items: center;
  color: var(--ink-mute);
  transition: opacity .8s var(--ease-slow);
}
.loader.fade { opacity: 0; pointer-events: none; }
.loader::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(ellipse 80% 80% at 50% 50%, transparent 52%, rgba(0,0,0,.32) 100%);
}
.loader-card {
  position: relative;
  z-index: 1;
  width: min(420px, calc(100vw - 48px));
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
}
.loader-card .atlas-seal { margin-bottom: 8px; }
.loader-kicker {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--brass);
}
.loader-title {
  font-family: var(--serif);
  font-size: 30px;
  font-style: italic;
  font-weight: 300;
  line-height: 1.05;
  color: var(--ink);
}
.loader-label {
  min-height: 18px;
  max-width: 100%;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.loader-bar {
  width: 100%;
  height: 1px;
  margin-top: 12px;
  background: var(--line-2);
  overflow: hidden;
}
.loader-bar span {
  display: block;
  height: 100%;
  background: var(--brass);
  transition: width .35s var(--ease);
}
.loader-meta {
  width: 100%;
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .22em;
  color: var(--ink-faint);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}

/* utility */
.hide { display: none !important; }

/* scrollbars */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--line-2); border-radius: 0; }
::-webkit-scrollbar-thumb:hover { background: var(--line-3); }

@media (max-width: 1100px) {
  .chrome-top { padding: 20px 24px; }
  .spread-frame { padding: 40px 40px 56px; }
  .spread-narrative { grid-template-columns: 1fr; gap: 32px; }
  .chrome-left { display: none; }
  .drawer { width: 100%; }
}

/* ======================================================================
   NEW LAYOUT: SIDEBAR + BOTTOM PANEL
   ====================================================================== */

.index-tab { display: none !important; }

/* Permanent left sidebar (Index) */
.sidebar {
  position: relative;
  z-index: 25;
  background: var(--bg-soft);
  border-right: 1px solid var(--line-2);
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.sidebar-head {
  padding: 22px 28px 18px;
  border-bottom: 1px solid var(--line);
}
.sidebar-head h2 {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: 28px;
  margin: 0;
  letter-spacing: .005em;
  color: var(--ink);
  line-height: 1;
}
.sidebar-head .sub {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .14em;
  color: var(--ink-faint);
  text-transform: uppercase;
  margin-top: 7px;
}
.sidebar-sort {
  padding: 10px 28px 12px;
  display: flex;
  gap: 16px;
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.sidebar-list {
  flex: 1;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--line-2) transparent;
}
.sidebar-list .entry {
  padding: 16px 28px;
  border-bottom: 1px solid var(--line);
}
.sidebar-list .entry .name { font-size: 17px; }

/* Sidebar filters — between head and sort */
.sidebar-filters {
  padding: 12px 28px 12px;
  border-bottom: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 220px;
  overflow-y: auto;
  scrollbar-width: thin;
  flex: 0 0 auto;
}
.sidebar-filters .rail-section { gap: 5px; }
.sidebar-filters .rail-label { margin-bottom: 2px; }
.sidebar-filters .quad-toggles { gap: 8px; }
.sidebar-filters .quad-toggle { padding: 3px 0; font-size: 11px; line-height: 1.35; align-items: flex-start; }
.sidebar-filters .quad-toggle .marker { margin-top: 3px; flex: 0 0 10px; }
.sidebar-filters .rail-chips { gap: 6px; max-height: none; }
.sidebar-filters .rail-chip { padding: 3px 0; font-size: 11px; border-bottom: 0; line-height: 1.3; }

/* Bottom panel: timeline+metrics | mode toggle */
.bottom-panel {
  position: relative;
  z-index: 20;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0;
  border-top: 1px solid var(--line-2);
  background: var(--bg-soft);
  padding: 14px 28px 16px;
  align-items: stretch;
  max-height: 160px;
}
.bp-center {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-right: 24px;
  border-right: 1px solid var(--line);
  min-width: 0;
}
.bp-mode {
  padding-left: 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 130px;
  justify-content: flex-start;
}
.mode-toggle-inline {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mode-toggle-inline button {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  background: transparent;
  border: 1px solid var(--line);
  padding: 9px 12px;
  cursor: pointer;
  transition: color .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
  text-align: left;
}
.mode-toggle-inline button:hover { color: var(--ink); border-color: var(--line-2); }
.mode-toggle-inline button.active { color: var(--brass); border-color: var(--brass); background: rgba(184,153,104,.06); }

.rotation-toggle {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--line);
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .14em;
  text-align: left;
  text-transform: uppercase;
  color: var(--ink-mute);
  background: rgba(11,14,20,.32);
  backdrop-filter: blur(6px);
  transition: color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.rotation-toggle:hover {
  color: var(--ink);
  border-color: var(--line-2);
}
.rotation-toggle.active {
  color: var(--brass);
  border-color: var(--brass);
  background: rgba(184,153,104,.08);
}
[data-palette="ivory"] .rotation-toggle { background: rgba(241,235,217,.35); }

/* hide the old absolute mode-toggle if it ever renders */
.mode-toggle { display: none !important; }
.chrome-left { display: none !important; }

/* timeline tweaks for bottom-panel context */
.bottom-panel .timeline { max-width: none; }

/* metrics inline */
.bottom-panel .metrics { padding: 0; }

@media (max-width: 1000px) {
  .atlas { grid-template-columns: 280px 1fr; }
  .bottom-panel { grid-template-columns: 1fr; gap: 12px; padding: 12px 18px; max-height: none; }
  .bp-center { border-right: 0; padding: 0; }
  .bp-mode { padding-left: 0; flex-direction: row; align-items: center; }
  .mode-toggle-inline { flex-direction: row; }
}
@media (max-width: 800px) {
  .atlas { grid-template-columns: 1fr; grid-template-rows: 1fr; }
  .sidebar { display: none; }
}

/* ======================================================================
   METHODOLOGY OVERLAY
   ====================================================================== */
.methodology {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: var(--bg);
  overflow-y: auto;
  overscroll-behavior: contain;
  opacity: 0;
  pointer-events: none;
  transition: opacity 1.0s var(--ease);
  will-change: opacity;
}
.methodology.open { opacity: 1; pointer-events: auto; }

.method-frame {
  position: relative;
  min-height: 100%;
  max-width: 1240px;
  margin: 0 auto;
  padding: 56px 80px 80px;
  display: grid;
  grid-template-rows: auto auto 1fr auto auto;
  gap: 40px;
}

.method-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--line-2);
  padding-bottom: 20px;
}
.method-eyebrow {
  display: flex;
  gap: 18px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.method-close {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  background: transparent;
  border: 1px solid var(--line-2);
  padding: 10px 16px;
  cursor: pointer;
  transition: color .25s var(--ease), border-color .25s var(--ease);
}
.method-close:hover { color: var(--ink); border-color: var(--line-3); }
.method-close .ar { display: inline-block; margin-right: 6px; }

.method-title-block {
  max-width: 820px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 36px;
}
.method-kicker {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 18px;
}
.method-title {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 76px;
  line-height: 1.02;
  letter-spacing: -0.012em;
  color: var(--ink);
  margin: 0 0 22px 0;
}
.method-lede {
  font-family: var(--serif);
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0;
  text-wrap: pretty;
}
.method-lede b { font-weight: 500; color: var(--brass); font-style: normal; }
.method-lede i { color: var(--ink); }

.method-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
}
.method-col h4 {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 0 0 18px 0;
}
.method-col h4 + .method-block,
.method-col h4 + p,
.method-col h4 + ul { margin-top: 6px; }
.method-col h4:not(:first-child) {
  margin-top: 44px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}

.method-block + .method-block {
  margin-top: 32px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.method-block { margin-bottom: 0; padding-bottom: 0; border-bottom: 0; }
.method-axis {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.ax-label {
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  color: var(--ink);
  line-height: 1.2;
}
.ax-scale {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--ink-mute);
}
.method-block p {
  font-family: var(--serif);
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink);
  margin: 6px 0 14px 0;
  text-wrap: pretty;
}

.method-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.method-list li {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: 12px;
  padding: 6px 0;
  border-bottom: 1px solid var(--line);
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--ink-mute);
  align-items: baseline;
}
.method-list li:last-child { border-bottom: 0; }
.method-list .k {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  color: var(--brass);
}


.method-source {
  list-style: none;
  margin: 0;
  padding: 0;
}
.method-source li {
  display: grid;
  grid-template-columns: 1fr 120px;
  gap: 18px;
  align-items: center;
  padding: 9px 0;
  border-bottom: 1px solid var(--line);
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--ink-mute);
}
.method-source li:last-child { border-bottom: 0; }
.method-source .bar {
  display: block;
  height: 3px;
  background: linear-gradient(to right, var(--brass) var(--p, 0%), rgba(184,153,104,.12) var(--p, 0%));
}

.method-disclaim {
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-mute);
  margin: 0;
  text-wrap: pretty;
}

.method-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line-2);
  border-bottom: 1px solid var(--line-2);
  padding: 22px 0;
}
.ms-cell {
  text-align: center;
  border-right: 1px solid var(--line);
}
.ms-cell:last-child { border-right: 0; }
.ms-v {
  font-family: var(--serif);
  font-style: italic;
  font-size: 48px;
  color: var(--brass);
  line-height: 1;
  margin-bottom: 6px;
}
.ms-l {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.method-bottom {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink-faint);
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

@media (max-width: 1100px) {
  .method-frame { padding: 44px 40px 56px; }
  .method-body { grid-template-columns: 1fr; gap: 36px; }
  .method-title { font-size: 56px; }
  .method-stats { grid-template-columns: repeat(2, 1fr); }
  .ms-cell:nth-child(2) { border-right: 0; }
}

/* =====================================================================
   Methodology — expanded apparatus (sections A–L)
   ===================================================================== */

.method-eyebrow > span + span::before {
  content: "·";
  margin-right: 18px;
  color: var(--ink-faint);
}

.method-statline {
  display: flex;
  gap: 36px;
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
}
.method-statline > div { display: flex; align-items: baseline; gap: 10px; }
.method-statline .ms-v-i {
  font-family: var(--serif);
  font-style: italic;
  font-size: 34px;
  line-height: 1;
  color: var(--brass);
}
.method-statline .ms-l-i {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* Document shell: sticky TOC + scrollable doc */
.method-doc-shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 56px;
  align-items: start;
}

.method-toc {
  position: sticky;
  top: 24px;
  align-self: start;
  contain: layout paint style;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  padding: 18px 16px 16px;
  max-height: calc(100vh - 60px);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--line-2) transparent;
}
.method-toc .toc-label {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink-faint);
  padding-bottom: 12px;
  margin-bottom: 10px;
  border-bottom: 1px solid var(--line);
}
.method-toc ol {
  list-style: none;
  margin: 0;
  padding: 0;
}
.method-toc li button {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 10px;
  width: 100%;
  text-align: left;
  padding: 8px 6px;
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--ink-mute);
  border-bottom: 1px solid transparent;
  transition: color .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
}
.method-toc li:last-child button { border-bottom: 0; }
.method-toc li button:hover { color: var(--ink); }
.method-toc li.active button {
  color: var(--ink);
  background: linear-gradient(90deg, rgba(184,153,104,.08), transparent 80%);
  border-bottom-color: var(--line);
}
.method-toc .toc-num {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .12em;
  color: var(--brass);
}
.method-toc li:not(.active) .toc-num { color: var(--ink-faint); }
.method-toc .toc-foot {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .18em;
  color: var(--ink-faint);
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
  line-height: 1.6;
}

/* Doc — scrolls with the modal, not internally */
.method-doc {
  min-width: 0;
}

.m-section {
  padding: 8px 0 36px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 28px;
  contain: paint;
}
.m-section:last-child { border-bottom: 0; }
.m-section-head {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 16px;
  align-items: end;
  padding-bottom: 18px;
  margin-bottom: 22px;
  border-bottom: 1px solid var(--line);
}
.m-num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 44px;
  line-height: 1;
  color: var(--brass);
}
.m-h2 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 32px;
  line-height: 1.05;
  color: var(--ink);
  margin: 0 0 4px 0;
  letter-spacing: -0.005em;
}
.m-sub {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.m-section-body p.m-p {
  font-family: var(--serif);
  font-size: 16px;
  line-height: 1.65;
  color: var(--ink);
  margin: 0 0 14px 0;
  text-wrap: pretty;
  max-width: 64ch;
}
.m-section-body p.m-p i { color: var(--ink); }
.m-section-body p.m-p b { color: var(--brass); font-weight: 500; }

.m-h5 {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin: 22px 0 12px 0;
  padding-bottom: 7px;
  border-bottom: 1px solid var(--line);
}
.m-h5:first-child { margin-top: 0; }

.m-aside {
  font-family: var(--serif);
  font-style: italic;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink-mute);
  margin: 16px 0 0 0;
  padding: 12px 14px;
  border-left: 2px solid var(--brass-soft);
  background: rgba(184,153,104,.04);
  text-wrap: pretty;
}

.m-bullets {
  list-style: none;
  margin: 0;
  padding: 0;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--ink);
}
.m-bullets li {
  padding: 7px 0 7px 18px;
  border-bottom: 1px solid var(--line);
  line-height: 1.55;
  position: relative;
}
.m-bullets li::before {
  content: "";
  position: absolute; left: 0; top: 14px;
  width: 8px; height: 1px;
  background: var(--brass-soft);
}
.m-bullets li:last-child { border-bottom: 0; }
.m-bullets li b { color: var(--brass); font-weight: 500; }
.m-bullets.tight li { padding-top: 5px; padding-bottom: 5px; font-size: 12.5px; }

/* Definitions */
.def-list {
  margin: 0; padding: 0;
}
.def {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 24px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
}
.def:last-child { border-bottom: 0; }
.def dt {
  font-family: var(--serif);
  font-style: italic;
  font-size: 18px;
  color: var(--ink);
  line-height: 1.25;
}
.def dd {
  font-family: var(--serif);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0;
  text-wrap: pretty;
}

/* Inclusion / Exclusion / Caveats key-value list */
.kv-list {
  list-style: none;
  margin: 0; padding: 0;
}
.kv-list li {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 22px;
  padding: 13px 0;
  border-bottom: 1px solid var(--line);
}
.kv-list li:last-child { border-bottom: 0; }
.kv-list .kv-k {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--brass);
  line-height: 1.5;
}
.kv-list .kv-v {
  font-family: var(--serif);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink);
  text-wrap: pretty;
}

/* Scoring rubric tables */
.axis-block {
  margin: 0 0 36px 0;
  padding: 22px 22px 18px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
}
.axis-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.axis-title {
  font-family: var(--serif);
  font-style: italic;
  font-size: 26px;
  color: var(--ink);
}
.axis-scale {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.axis-summary {
  font-family: var(--serif);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0 0 18px 0;
  text-wrap: pretty;
  max-width: 64ch;
}

.rubric-table {
  border: 1px solid var(--line);
  background: var(--bg);
}
.rubric-head, .rubric-row, .rubric-foot {
  display: grid;
  grid-template-columns: 44px 180px 1fr 1fr;
  gap: 0;
}
.rubric-head {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  border-bottom: 1px solid var(--line);
}
.rubric-head > div {
  padding: 10px 14px;
  border-right: 1px solid var(--line);
}
.rubric-head > div:last-child { border-right: 0; }
.rubric-row {
  border-bottom: 1px solid var(--line);
}
.rubric-row:last-child { border-bottom: 0; }
.rubric-row > div {
  padding: 14px;
  border-right: 1px solid var(--line);
  font-family: var(--sans);
  font-size: 12.5px;
  line-height: 1.55;
  color: var(--ink-soft);
}
.rubric-row > div:last-child { border-right: 0; }
.rubric-w {
  font-family: var(--mono) !important;
  font-size: 14px !important;
  color: var(--brass) !important;
  text-align: center;
  align-self: center;
}
.rubric-name {
  font-family: var(--serif) !important;
  font-style: italic;
  font-size: 15.5px !important;
  color: var(--ink) !important;
  line-height: 1.3 !important;
  align-self: center;
}
.rubric-meas .rubric-why {
  margin-top: 6px;
  color: var(--ink-mute);
  font-style: italic;
}
.rubric-good {
  display: grid;
  grid-template-rows: auto 1px auto;
  align-content: start;
}
.rubric-good > div { padding: 0; }
.rubric-good .sw-strong,
.rubric-good .sw-weak {
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 10px;
  align-items: start;
  padding: 4px 0;
}
.rubric-good .sw-divider {
  height: 1px;
  background: var(--line);
  margin: 4px 0;
}
.rubric-good .sw-text {
  display: block;
  line-height: 1.45;
}
.rubric-good .tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mono);
  font-size: 8.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: 3px 0;
  border: 1px solid var(--line-2);
  width: 60px;
  flex-shrink: 0;
  height: fit-content;
  margin-top: 1px;
}
.rubric-good .tag.good { color: var(--brass); border-color: rgba(184,153,104,.4); }
.rubric-good .tag.weak { color: var(--ink-mute); }

.rubric-head-strong-weak {
  display: flex !important;
  align-items: baseline;
  gap: 8px;
}
.rubric-head-strong-weak .sw-sep {
  color: var(--line-3);
  opacity: .8;
}

.rubric-foot {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--brass);
  border-top: 1px solid var(--line-2);
  background: rgba(184,153,104,.05);
}
.rubric-foot > div {
  padding: 14px;
  border-right: 1px solid var(--line);
  display: flex;
  align-items: center;
}
.rubric-foot > div:last-child { border-right: 0; }
.rubric-foot-w {
  font-family: var(--serif) !important;
  font-style: italic;
  font-weight: 400;
  font-size: 28px !important;
  letter-spacing: -.005em !important;
  color: var(--brass);
  text-transform: none;
  justify-content: center;
}
.rubric-foot-label {
  flex-direction: column;
  align-items: flex-start !important;
  gap: 3px;
  text-transform: uppercase;
}
.rubric-foot-label small {
  font-family: var(--serif);
  font-style: italic;
  font-size: 11px;
  letter-spacing: .005em;
  color: var(--ink-mute);
  text-transform: none;
}
.rubric-foot-bar {
  padding: 14px 18px !important;
}
.rubric-foot-bar-track {
  width: 100%;
  height: 3px;
  background: var(--line);
  position: relative;
  overflow: hidden;
}
.rubric-foot-bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: var(--brass);
  transition: width 1s var(--ease-slow);
}
.rubric-foot-max {
  font-family: var(--serif) !important;
  font-style: italic;
  font-size: 16px !important;
  text-transform: none;
  color: var(--ink-mute);
  justify-content: flex-end;
}

.scoring-rules {
  margin-top: 8px;
  padding: 18px;
  border: 1px dashed var(--line-2);
}
.rule-eyebrow {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--brass);
  margin-bottom: 10px;
}

/* Evidence & confidence */
.evidence-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 36px;
}
.evidence-list {
  list-style: none;
  margin: 0; padding: 0;
}
.evidence-list li {
  padding: 11px 0;
  border-bottom: 1px solid var(--line);
}
.evidence-list li:last-child { border-bottom: 0; }
.ev-row-top {
  display: grid;
  grid-template-columns: 1fr 100px;
  gap: 16px;
  align-items: center;
}
.ev-name {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
}
.ev-bar {
  display: block;
  height: 3px;
  background: rgba(184,153,104,.12);
}
.ev-bar > span {
  display: block;
  height: 100%;
  background: var(--brass);
}
.ev-desc {
  margin-top: 6px;
  font-family: var(--serif);
  font-size: 13.5px;
  color: var(--ink-mute);
  line-height: 1.55;
  text-wrap: pretty;
}

.confidence-list {
  list-style: none;
  margin: 0; padding: 0;
}
.confidence-list li {
  display: grid;
  grid-template-columns: 14px 110px 1fr;
  gap: 12px;
  align-items: baseline;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}
.confidence-list li:last-child { border-bottom: 0; }
.conf-dot {
  display: block;
  width: 10px; height: 10px;
  border-radius: 50%;
  margin-top: 4px;
}
.conf-tier {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--brass);
}
.conf-desc {
  font-family: var(--serif);
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.5;
  text-wrap: pretty;
}

/* Category notes */
.cat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 10px;
}
.cat-cell {
  background: var(--bg-soft);
  padding: 24px 26px 22px;
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
}
.cat-grid.exclusion .cat-cell {
  background: linear-gradient(180deg, var(--bg-soft), var(--bg));
}
.cat-grid.exclusion .cat-name {
  color: var(--ink-mute);
  font-style: italic;
}
.cat-grid.exclusion .cat-row p { color: var(--ink-mute); }

/* Seal cell — fills empty 2nd column when category count is odd */
.cat-seal-cell {
  background: transparent !important;
  border: 1px solid var(--line-2) !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center;
  padding: 40px 36px !important;
  gap: 20px;
  position: relative;
}
.cat-seal-cell::before,
.cat-seal-cell::after {
  content: "";
  position: absolute;
  left: 36px;
  right: 36px;
  height: 1px;
  background: var(--line-2);
}
.cat-seal-cell::before { top: 18px; }
.cat-seal-cell::after { bottom: 18px; }
.cat-seal-cell .atlas-seal {
  margin-bottom: 8px;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.15));
}
.cat-seal-text {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
}
.cat-seal-mark {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: 36px;
  letter-spacing: -.005em;
  color: var(--ink);
  line-height: 1;
}
.cat-seal-sub {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--brass);
}
.cat-seal-motto {
  font-family: var(--serif);
  font-size: 14px;
  color: var(--ink-mute);
  margin-top: 6px;
  letter-spacing: .01em;
}

.cat-name {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  letter-spacing: -.005em;
  color: var(--ink);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line-2);
  line-height: 1.15;
}
.cat-row {
  display: grid;
  grid-template-columns: 100% 1fr;
  grid-template-rows: auto auto;
  padding: 14px 0;
  border-bottom: 1px dashed var(--line);
  gap: 6px 0;
}
.cat-row:last-child { border-bottom: 0; padding-bottom: 0; }
.cat-row > span {
  grid-row: 1;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--brass);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.cat-row > span::before {
  content: "";
  display: inline-block;
  width: 6px; height: 1px;
  background: var(--brass);
  opacity: .6;
}
.cat-row.warn > span { color: var(--oxblood); }
.cat-row.warn > span::before { background: var(--oxblood); }
.cat-row p {
  grid-row: 2;
  font-family: var(--serif);
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0;
  letter-spacing: -.002em;
  text-wrap: pretty;
  max-width: 64ch;
}

/* Confidence pill (used in Spread + future Methodology) */
.conf-pill {
  display: inline-block;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  padding: 4px 10px;
  border: 1px solid var(--line-2);
  background: var(--bg-soft);
  color: var(--ink);
}
.conf-pill.conf-verified {
  color: var(--brass);
  border-color: rgba(184,153,104,.55);
  background: rgba(184,153,104,.08);
}
.conf-pill.conf-probable {
  color: rgba(184,153,104,.85);
  border-color: rgba(184,153,104,.35);
}
.conf-pill.conf-needs_source {
  color: var(--ink-mute);
  border-color: var(--line);
}
.conf-pill.conf-speculative {
  color: var(--ink-faint);
  border-color: var(--line);
  font-style: italic;
}

/* Source ID chips in Spread */
.src-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 6px;
}
.src-chip {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .1em;
  color: var(--brass);
  padding: 3px 7px;
  border: 1px solid var(--line);
  background: var(--bg);
}

/* AI thesis grid */
.ai-grid {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
}
.ai-grid li {
  background: var(--bg-soft);
  padding: 16px 18px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}
.ai-grid li b {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 17px;
  color: var(--brass);
}
.ai-grid li span {
  font-family: var(--serif);
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink);
  text-wrap: pretty;
}

/* Pipeline */
.pipeline-list {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: none;
}
.pipeline-list li {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 18px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
}
.pipeline-list li:last-child { border-bottom: 0; }
.pipeline-list .p-num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 30px;
  color: var(--brass);
  line-height: 1;
}
.pipeline-list .p-k {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 4px;
}
.pipeline-list .p-v {
  font-family: var(--serif);
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-soft);
  text-wrap: pretty;
}

/* Appendix */
.appx-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 36px;
}
.appx-cats {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 8px;
  margin: 4px 0 8px;
}
.appx-cat {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  padding: 4px 8px;
  border: 1px solid var(--line);
  background: var(--bg);
}
.appx-cat.dim {
  color: var(--ink-faint);
  font-style: italic;
  border-style: dashed;
}
.appx-groups {
  display: flex;
  flex-direction: column;
  gap: 22px;
}
.appx-group {
  border: 1px solid var(--line);
  background: var(--bg-soft);
}
.appx-group-label {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--brass);
  padding: 11px 16px 9px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(184,153,104,.06), transparent);
}
.appx-fields {
  list-style: none;
  margin: 0; padding: 0;
}
.appx-fields li {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 18px;
  padding: 11px 16px;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.appx-fields li:last-child { border-bottom: 0; }
.appx-k {
  font-family: var(--serif);
  font-style: italic;
  font-size: 15px;
  color: var(--ink);
  line-height: 1.3;
}
.appx-v {
  font-family: var(--serif);
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.55;
  text-wrap: pretty;
}

/* Responsive */
@media (max-width: 1100px) {
  .method-doc-shell { grid-template-columns: 1fr; gap: 28px; }
  .method-toc {
    position: relative;
    top: 0;
  }
  .method-toc ol {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }
  .method-toc li button {
    padding: 7px 10px;
    border: 1px solid var(--line);
    grid-template-columns: auto auto;
  }
  .method-toc .toc-foot { display: none; }
  .method-doc { max-height: none; padding-right: 0; }
  .def { grid-template-columns: 1fr; gap: 4px; }
  .kv-list li { grid-template-columns: 1fr; gap: 4px; }
  .evidence-grid { grid-template-columns: 1fr; gap: 28px; }
  .cat-grid { grid-template-columns: 1fr; }
  .ai-grid { grid-template-columns: 1fr; }
  .appx-grid { grid-template-columns: 1fr; }
  .rubric-head, .rubric-row, .rubric-foot {
    grid-template-columns: 36px 130px 1fr 1fr;
  }
}

@media (max-width: 740px) {
  .rubric-head, .rubric-row, .rubric-foot {
    grid-template-columns: 32px 1fr;
  }
  .rubric-head > div:nth-child(3),
  .rubric-head > div:nth-child(4),
  .rubric-row > div:nth-child(3),
  .rubric-row > div:nth-child(4) {
    grid-column: 1 / -1;
    border-top: 1px solid var(--line);
  }
  .appx-fields li { grid-template-columns: 1fr; gap: 4px; }
}

/* ======================================================================
   QuadrantField — every institution plotted on Cultural × Economic axes
   ====================================================================== */

.qfield {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  user-select: none;
}

/* Methodology variant — sits inline, scales to its container with breathing room */
.qf-exhibit-wrap {
  position: relative;
  margin: 6px 0 28px;
  padding: 14px 18px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  aspect-ratio: 16 / 9;
  max-height: 560px;
}
.qfield.qfield-exhibit {
  position: absolute;
  inset: 14px 18px;
  width: calc(100% - 36px);
  height: calc(100% - 28px);
}

/* Axis tick numerals + axis titles */
.qf-tick-text {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: .14em;
  fill: var(--ink-faint);
}
.qf-axis-title {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  fill: var(--ink-mute);
  letter-spacing: -.005em;
}

/* Threshold readout at the cross of the upper crosshair */
.qf-threshold-text {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .22em;
  fill: var(--brass);
}

/* Quadrant captions (italic serif) and sublabels (uppercase mono) */
.qf-caption {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 26px;
  fill: var(--ink);
  letter-spacing: -.005em;
}
.qf-caption-sub {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  fill: var(--ink-faint);
}
.qfield-exhibit .qf-caption { font-size: 22px; }
.qfield-exhibit .qf-caption-sub { font-size: 9.5px; }
.qf-cap-ec { fill: var(--brass); }
.qf-cap-tb { fill: rgba(184,153,104,.78); }
.qf-cap-su { fill: var(--ink); fill-opacity: .82; }
.qf-cap-ag { fill: var(--ink-mute); }

/* Pins.  Note: never apply a CSS `transform` to `.qf-pin` — it would
   override the SVG `transform` attribute that positions each pin and
   collapse them all to the SVG origin.  Hover/selected use stroke and
   halo opacity instead of scale. */
.qf-pin {
  cursor: pointer;
  opacity: 0;
  animation: qfFadeIn .55s var(--ease) forwards;
}
.qfield-exhibit .qf-pin {
  cursor: default;
  animation-duration: 0s;
  opacity: 1;
}
@keyframes qfFadeIn { from { opacity: 0; } to { opacity: 1; } }
.qf-pin .qf-halo {
  fill-opacity: 0;
  transition: fill-opacity .5s var(--ease);
  pointer-events: none;
}
.qf-pin .qf-ring {
  fill: none;
  stroke: var(--brass);
  stroke-opacity: .55;
  stroke-width: 0.7;
  transition: stroke-opacity .35s var(--ease), stroke-width .35s var(--ease);
}
.qf-pin .qf-core {
  fill: var(--ink);
  stroke: var(--brass);
  stroke-width: 0.6;
  transition: fill .35s var(--ease);
}
.qf-pin.eternal .qf-core   { fill: var(--brass); }
.qf-pin.trophy .qf-core    { fill: rgba(184,153,104,.55); }
.qf-pin.unownable .qf-core { fill: var(--ink-mute); }
.qf-pin.avoid .qf-core     { fill: transparent; stroke-opacity: .45; }

/* Confidence encoding — layered on top of quadrant fill.  Verified is the
   default solid look.  Probable is the same fill at 0.7 opacity.  Needs
   Source is ring-only (transparent fill, prominent stroke).  Speculative
   is a dashed ring. */
.qf-pin.qf-conf-probable .qf-core { fill-opacity: 0.7; }
.qf-pin.qf-conf-needs_source .qf-core {
  fill: transparent;
  stroke: var(--brass);
  stroke-opacity: .55;
  stroke-width: 1.1;
}
.qf-pin.qf-conf-needs_source.eternal .qf-core,
.qf-pin.qf-conf-needs_source.trophy .qf-core,
.qf-pin.qf-conf-needs_source.unownable .qf-core { fill: transparent; }
.qf-pin.qf-conf-speculative .qf-core {
  fill: transparent;
  stroke: var(--brass);
  stroke-opacity: .35;
  stroke-width: 0.9;
  stroke-dasharray: 3 2;
}

.qf-pin:hover .qf-ring,
.qf-pin.hovered .qf-ring { stroke-opacity: 1; stroke-width: 1.4; }
.qf-pin:hover .qf-halo,
.qf-pin.hovered .qf-halo { fill-opacity: .55; }
.qf-pin.selected .qf-ring { stroke-opacity: 1; stroke-width: 1.6; }
.qf-pin.selected .qf-halo { fill-opacity: .9; }
.qf-pin.dimmed { opacity: .18; pointer-events: none; }

/* Selected pin label (italic serif name floating above the dot) */
.qf-label {
  font-family: var(--serif);
  font-style: italic;
  font-size: 16px;
  fill: var(--ink);
  letter-spacing: -.002em;
}

/* === Methodology Section F — quadrant explainer (2×2 of paragraphs) === */
.qf-explainer {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 0;
  margin: 8px 0 18px;
}
.qf-axis-y-cap {
  grid-column: 1; grid-row: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0 56px;
}
.qf-axis-y-cap span {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-faint);
  white-space: nowrap;
}
.qf-explainer-grid {
  grid-column: 2; grid-row: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.qf-axis-x-cap {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-faint);
  padding: 0 4px 6px;
  border-bottom: 1px solid var(--line);
}
.qf-paragraphs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  margin: 0 0 8px;
}
.qf-paragraphs-spatial { /* identical to .qf-paragraphs but spatially ordered SU EC AG TB */
  margin: 0;
}
.qf-para {
  background: var(--bg-soft);
  padding: 18px 20px 16px;
}
.qf-para-head {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  grid-template-rows: auto auto;
  align-items: baseline;
  column-gap: 10px;
  row-gap: 4px;
  padding-bottom: 10px;
  margin-bottom: 12px;
  border-bottom: 1px dashed var(--line);
}
.qf-para-marker {
  width: 10px; height: 10px;
  border: 1px solid var(--line-3);
  align-self: center;
  grid-row: 1;
  grid-column: 1;
}
.qf-pm-ec { background: var(--brass); border-color: var(--brass); }
.qf-pm-tb { background: rgba(184,153,104,.55); border-color: rgba(184,153,104,.55); }
.qf-pm-su { background: var(--ink-mute); border-color: var(--ink-mute); }
.qf-pm-ag { background: transparent; }
.qf-para-title {
  grid-row: 1; grid-column: 2;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 21px;
  color: var(--ink);
  margin: 0;
  letter-spacing: -.005em;
}
.qf-para-count {
  grid-row: 1; grid-column: 3;
  display: inline-flex; align-items: baseline; gap: 6px;
}
.qf-para-count-n {
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  color: var(--brass);
  line-height: 1;
}
.qf-para-count-of {
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.qf-para-rule {
  grid-row: 2; grid-column: 2 / span 2;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--brass);
}
.qf-para-desc {
  font-family: var(--serif);
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin: 0 0 12px;
  text-wrap: pretty;
}
.qf-para-examples {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0 10px;
}
.qf-para-ex-label {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.qf-para-ex-list {
  font-family: var(--serif);
  font-size: 13.5px;
  color: var(--ink-soft);
  line-height: 1.55;
  font-style: italic;
}

/* "View these N institutions on the field →" — closes the methodology
   modal and applies the corresponding quadrant filter on the Field. */
.qf-para-jump {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 14px;
  padding: 7px 12px 7px 13px;
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  background: transparent;
  border: 1px solid var(--line-2);
  cursor: pointer;
  transition: color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.qf-para-jump:hover {
  color: var(--brass);
  border-color: rgba(184,153,104,.5);
  background: rgba(184,153,104,.05);
}
.qf-para-jump-arrow {
  font-family: var(--serif);
  font-style: italic;
  font-size: 12px;
  letter-spacing: 0;
  text-transform: none;
}

/* Trajectory pill in the Spread.  Three discrete states. */
.traj-pill {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  padding: 4px 10px;
  border: 1px solid var(--line-2);
  background: var(--bg-soft);
}
.traj-pill.traj-improving {
  color: var(--brass);
  border-color: rgba(184,153,104,.55);
  background: rgba(184,153,104,.08);
}
.traj-pill.traj-stable {
  color: var(--ink-mute);
}
.traj-pill.traj-degrading {
  color: var(--oxblood);
  border-color: rgba(107,30,37,.5);
  background: rgba(107,30,37,.08);
}

@media (max-width: 1100px) {
  .qf-paragraphs { grid-template-columns: 1fr; }
  .qf-axis-title { font-size: 16px; }
  .qf-caption { font-size: 18px; }
  .qf-caption-sub { font-size: 9px; }
  .qfield-exhibit .qf-caption { font-size: 16px; }
}

/* Country / City sidebar panels */
.rail-back {
  display: inline-block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  background: transparent;
  border: none;
  padding: 4px 0 14px;
  cursor: pointer;
  transition: color .25s var(--ease);
}
.rail-back:hover { color: var(--brass); }
.sidebar > .rail-section {
  padding-left: 28px;
  padding-right: 28px;
  border-bottom: 1px solid var(--line);
}
.rail-quaddist { padding-top: 14px; padding-bottom: 14px; }
.quaddist-row {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 5px 0;
  font-family: var(--sans);
  font-size: 12px;
  color: var(--ink-soft);
}
.quaddist-marker {
  width: 10px; height: 10px;
  border: 1px solid var(--ink-faint);
  display: inline-block;
}
.quaddist-marker.eternal { background: var(--brass); border-color: var(--brass); }
.quaddist-marker.trophy { background: rgba(184,153,104,.55); border-color: rgba(184,153,104,.55); }
.quaddist-marker.unownable { background: var(--ink-mute); border-color: var(--ink-mute); }
.quaddist-marker.avoid { background: var(--oxblood); border-color: var(--oxblood); opacity: .8; }
.quaddist-count {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--brass);
  letter-spacing: .12em;
}
.city-rail-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: 8px;
}
.city-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: padding .25s var(--ease);
}
.city-row:hover { padding-left: 6px; }
.city-row-name {
  font-family: var(--serif);
  font-size: 18px;
  color: var(--ink);
  letter-spacing: -.005em;
}
.city-row-meta {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.city-row-meta .dotsep::before {
  content: "·";
  color: var(--brass);
  margin: 0 .5em;
}
.quad-tag {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: 2px 6px;
  border: 1px solid var(--line-2);
  color: var(--ink-mute);
  margin-left: 8px;
}
.quad-tag.eternal { color: var(--brass); border-color: var(--brass); }
.quad-tag.trophy { color: var(--ink-soft); border-color: var(--line-3); }
.quad-tag.unownable { color: var(--ink-mute); }
.quad-tag.avoid { color: var(--oxblood); border-color: rgba(107,30,37,.6); }

/* ======================================================================
   City Map — Leaflet-based hyperdetailed plate of a city or location.
   Sits on top of .stage and takes over visually while city focus is active.
   ====================================================================== */

.citymap-wrap {
  position: absolute;
  inset: 0;
  z-index: 4;
  opacity: 0;
  pointer-events: none;
  transition: opacity .55s var(--ease, ease);
}
.citymap-wrap.is-visible {
  opacity: 1;
  pointer-events: auto;
}
.citymap-canvas {
  position: absolute;
  inset: 0;
  background: var(--bg);
}
[data-palette="parchment"] .citymap-canvas .leaflet-tile-pane {
  filter: sepia(0.18) saturate(0.85) brightness(0.97) contrast(0.95);
}
[data-palette="ivory"] .citymap-canvas .leaflet-tile-pane {
  filter: sepia(0.10) saturate(0.85) brightness(0.99) contrast(0.95);
}
[data-palette="obsidian"] .citymap-canvas .leaflet-tile-pane {
  filter: saturate(0.75) brightness(0.95) contrast(1.05);
}
.citymap-canvas .leaflet-control-zoom {
  border: 1px solid var(--line-2) !important;
  background: var(--bg);
  box-shadow: 0 6px 24px rgba(0,0,0,0.18);
}
.citymap-canvas .leaflet-control-zoom a {
  background: var(--bg) !important;
  color: var(--ink) !important;
  border-bottom: 1px solid var(--line-2) !important;
  font-family: var(--serif);
  font-size: 17px;
  width: 30px;
  height: 30px;
  line-height: 30px;
}
.citymap-canvas .leaflet-control-zoom a:hover { color: var(--brass) !important; }
.citymap-canvas .leaflet-control-attribution {
  background: rgba(0,0,0,0) !important;
  color: var(--ink-mute) !important;
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: .04em;
  padding: 2px 8px;
}
.citymap-canvas .leaflet-control-attribution a {
  color: var(--ink-soft) !important;
  text-decoration: none;
}
.citymap-cartouche {
  position: absolute;
  top: 72px;
  left: 36px;
  z-index: 1000;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(20,18,15,0.0) 0%, var(--bg) 14%, var(--bg) 100%);
  padding: 14px 22px 16px;
  border: 1px solid var(--line-2);
  border-top: none;
  min-width: 220px;
  box-shadow: 0 10px 32px rgba(0,0,0,0.22);
}
[data-palette="parchment"] .citymap-cartouche,
[data-palette="ivory"] .citymap-cartouche {
  background: var(--bg);
}
.citymap-cartouche .cmc-rule {
  position: absolute;
  top: -1px;
  left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--brass) 0%, var(--brass) 38%, transparent 100%);
}
.citymap-cartouche .cmc-eyebrow {
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 4px;
}
.citymap-cartouche .cmc-title {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 30px;
  line-height: 1;
  letter-spacing: -.01em;
  color: var(--ink);
  margin: 0;
}
.citymap-cartouche .cmc-sub {
  font-family: var(--serif);
  font-style: italic;
  font-size: 14px;
  color: var(--brass);
  letter-spacing: 0;
  margin-top: 4px;
}
.cmpin-wrap { background: transparent !important; border: 0 !important; }
.cmpin {
  position: relative;
  width: 0; height: 0;
}
.cmpin-halo,
.cmpin-dot,
.cmpin-stem {
  position: absolute;
  pointer-events: auto;
}
.cmpin-halo {
  left: -16px; top: -16px;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--brass);
  opacity: 0.10;
  transition: opacity .25s var(--ease, ease), transform .25s var(--ease, ease);
}
.cmpin-dot {
  left: -6px; top: -6px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--brass);
  border: 1.5px solid var(--bg);
  box-shadow: 0 0 0 1px var(--brass), 0 2px 6px rgba(0,0,0,0.35);
  cursor: pointer;
  transition: transform .22s var(--ease, ease), box-shadow .22s var(--ease, ease);
}
.cmpin-stem {
  left: 0; top: 6px;
  width: 1px;
  height: 14px;
  background: var(--brass);
  opacity: 0.55;
}
.cmpin-label {
  position: absolute;
  left: 18px;
  top: -10px;
  display: flex;
  flex-direction: column;
  gap: 1px;
  white-space: nowrap;
  pointer-events: none;
  background: var(--bg);
  padding: 4px 10px 5px;
  border-left: 1px solid var(--brass);
  box-shadow: 0 4px 14px rgba(0,0,0,0.22);
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity .25s var(--ease, ease), transform .25s var(--ease, ease);
}
.cmpin-name {
  font-family: var(--serif);
  font-size: 14px;
  font-weight: 400;
  letter-spacing: -.005em;
  color: var(--ink);
  line-height: 1.05;
}
.cmpin-meta {
  font-family: var(--sans);
  font-size: 9px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-mute);
}
.cmpin.qe .cmpin-dot { background: var(--brass); box-shadow: 0 0 0 1px var(--brass), 0 2px 6px rgba(0,0,0,0.35); }
.cmpin.qe .cmpin-halo { background: var(--brass); }
.cmpin.qt .cmpin-dot { background: var(--ink-soft); box-shadow: 0 0 0 1px var(--ink-soft), 0 2px 6px rgba(0,0,0,0.3); }
.cmpin.qt .cmpin-halo { background: var(--ink-soft); }
.cmpin.qs .cmpin-dot { background: var(--ink-faint); box-shadow: 0 0 0 1px var(--ink-faint), 0 2px 6px rgba(0,0,0,0.3); }
.cmpin.qs .cmpin-halo { background: var(--ink-faint); }
.cmpin.qa .cmpin-dot { background: var(--oxblood); box-shadow: 0 0 0 1px var(--oxblood), 0 2px 6px rgba(0,0,0,0.3); }
.cmpin.qa .cmpin-halo { background: var(--oxblood); }
.cmpin:hover .cmpin-halo,
.cmpin.is-sel .cmpin-halo {
  opacity: 0.32;
  transform: scale(1.25);
}
.cmpin:hover .cmpin-dot,
.cmpin.is-sel .cmpin-dot {
  transform: scale(1.15);
}
.cmpin:hover .cmpin-label,
.cmpin.is-sel .cmpin-label {
  opacity: 1;
  transform: translateX(0);
}
.cmpin.is-sel .cmpin-dot {
  box-shadow: 0 0 0 2px var(--brass), 0 0 0 5px rgba(184,153,104,0.25), 0 2px 8px rgba(0,0,0,0.35);
}

@media (max-width: 1100px) {
  .citymap-cartouche { left: 20px; top: 60px; min-width: 180px; padding: 12px 16px 14px; }
  .citymap-cartouche .cmc-title { font-size: 24px; }
}
