:root {
  --border: #ddd;
  --text-muted: #555;
  --panel-bg: #fff;
  --page-bg: #f7f7f7;
}

html, body { margin: 0; min-height: 100%; font-family: system-ui, -apple-system, Segoe UI, sans-serif; color: #111; }
body { display: flex; flex-direction: column; background: var(--page-bg); }
a { color: #174ea6; }

.site-header { padding: 14px 18px; border-bottom: 1px solid var(--border); background: #fff; }
h1 { margin: 0 0 4px; font-size: 1.35rem; }
h2 { margin: 0 0 6px; font-size: 1.05rem; }
p { margin: 0 0 8px; color: #444; }
nav { display: flex; gap: 10px; flex-wrap: wrap; margin: 10px 0 0; }
nav a { text-decoration: none; border: 1px solid var(--border); border-radius: 999px; padding: 6px 11px; color: #222; background: #fff; }
nav a.active { font-weight: 700; border-color: #888; background: #f0f0f0; }
.stats-line { font-size: .9rem; color: #333; margin-top: 8px; }

.map-layout {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  height: clamp(560px, calc(100vh - 285px), 820px);
  min-height: 0;
  overflow: hidden;
  background: #fff;
}
.sidebar {
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
  padding: 12px;
  border-right: 1px solid var(--border);
}
#list {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  padding-right: 6px;
}
#map { height: 100%; min-height: 0; }
.country-heading { position: sticky; top: 0; z-index: 1; margin: 12px -12px 4px; padding: 6px 12px; background: #f2f4f7; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); font-size: .9rem; }
#search, #table-search { width: 100%; box-sizing: border-box; padding: 10px; margin: 0; border: 1px solid #bbb; border-radius: 6px; font-size: 1rem; }
.filter-row { display: flex; align-items: stretch; gap: 8px; width: 100%; margin-bottom: 10px; }
.filter-row input { min-width: 0; flex: 1 1 auto; }
.reset-button { flex: 0 0 auto; border: 1px solid #aaa; border-radius: 6px; background: #fff; color: #222; padding: 0 11px; font: inherit; font-size: .9rem; white-space: nowrap; cursor: pointer; }
.reset-button:hover:not(:disabled) { background: #f1f1f1; }
.reset-button:focus-visible { outline: 3px solid rgba(23, 78, 166, .35); outline-offset: 2px; }
.reset-button:disabled { cursor: default; opacity: .48; }
.check-row { display: block; color: #333; font-size: .9rem; margin: 2px 0 12px; }
.item { padding: 8px 0; border-bottom: 1px solid #eee; cursor: pointer; }
.item strong { display: block; }
.item span { color: var(--text-muted); font-size: .88rem; }

.page-layout { width: min(1220px, calc(100% - 28px)); margin: 14px auto 24px; display: grid; gap: 14px; }
.panel { background: var(--panel-bg); border: 1px solid var(--border); border-radius: 10px; padding: 14px; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.controls-panel { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.controls-panel .table-filter-row { flex: 0 1 540px; max-width: 540px; margin: 0; }
.controls-panel .check-row { margin: 0; }
.button-link { display: inline-block; border: 1px solid var(--border); padding: 9px 12px; border-radius: 6px; text-decoration: none; background: #fff; color: #222; }

.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; font-size: .9rem; background: #fff; }
th, td { padding: 8px 10px; border-bottom: 1px solid #eee; text-align: left; vertical-align: top; }
th { position: sticky; top: 0; background: #fafafa; border-bottom: 1px solid #ccc; cursor: pointer; white-space: nowrap; }
th.sorted::after { content: ' ↕'; color: #555; }
.numeric { text-align: right; }

.dashboard .cards { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.card { background: #fff; border: 1px solid var(--border); border-radius: 10px; padding: 14px; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.card span { display: block; color: var(--text-muted); font-size: .82rem; }
.card strong { display: block; font-size: 1.7rem; line-height: 1.1; margin-top: 6px; }
.caption { color: var(--text-muted); font-size: .9rem; }
.chart-box { position: relative; height: 390px; }
.country-chart { height: 980px; }
.two-column { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }

footer { padding: 8px 18px; font-size: .8rem; border-top: 1px solid var(--border); color: var(--text-muted); background: #fff; }

@media (max-width: 1000px) {
  .dashboard .cards { grid-template-columns: repeat(3, 1fr); }
  .two-column { grid-template-columns: 1fr; }
}
@media (max-width: 800px) {
  .map-layout { grid-template-columns: 1fr; height: auto; overflow: visible; }
  .sidebar { max-height: 300px; border-right: 0; border-bottom: 1px solid var(--border); }
  #list { min-height: 160px; }
  #map { height: 520px; min-height: 520px; }
  .dashboard .cards { grid-template-columns: repeat(2, 1fr); }
  .country-chart { height: 820px; }
}
@media (max-width: 520px) {
  .dashboard .cards { grid-template-columns: 1fr; }
}


.intro-panel { width: min(1220px, calc(100% - 28px)); margin: 14px auto; background: #fff; border: 1px solid var(--border); border-radius: 12px; padding: 16px 18px; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.intro-panel p { max-width: 980px; line-height: 1.45; }
.intro-panel.compact { margin-bottom: 0; }
.site-header { display: grid; grid-template-columns: 1fr auto; gap: 8px 18px; align-items: start; }
.site-header .stats-line { grid-column: 1 / -1; }
nav { justify-content: flex-end; margin-top: 2px; }


.segment-marker {
  background: transparent;
  border: 0;
}
.segment-dot {
  display: block;
  box-sizing: border-box;
  border-radius: 999px;
  border: 2px solid rgba(20, 40, 70, .9);
  background: rgba(23, 78, 166, .68);
  color: #fff;
  font-weight: 700;
  text-align: center;
  box-shadow: 0 1px 5px rgba(0, 0, 0, .28);
  user-select: none;
}

.notes-panel { font-size: .86rem; line-height: 1.42; }
.notes-panel ul { margin: 6px 0 0 1.1rem; padding: 0; }
.notes-panel li { margin: 0 0 6px; color: #444; }
.figure-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.figure-card img { width: 100%; max-height: 360px; object-fit: contain; background: #f3f3f3; border: 1px solid var(--border); border-radius: 8px; }
.figure-card figcaption { font-size: .85rem; color: var(--text-muted); margin-top: 6px; }
@media (max-width: 800px) { .figure-grid { grid-template-columns: 1fr; } }
