@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap");

:root {
  --radius: 0.65rem;
  --background: oklch(1 0 0);
  --foreground: oklch(0.141 0.005 285.823);
  --card: oklch(1 0 0);
  --card-foreground: oklch(0.141 0.005 285.823);
  --popover: oklch(1 0 0);
  --popover-foreground: oklch(0.141 0.005 285.823);
  --primary: oklch(0.488 0.243 264.376);
  --primary-foreground: oklch(0.97 0.014 254.604);
  --secondary: oklch(0.967 0.001 286.375);
  --secondary-foreground: oklch(0.21 0.006 285.885);
  --muted: oklch(0.967 0.001 286.375);
  --muted-foreground: oklch(0.552 0.016 285.938);
  --accent: oklch(0.967 0.001 286.375);
  --accent-foreground: oklch(0.21 0.006 285.885);
  --destructive: oklch(0.577 0.245 27.325);
  --border: oklch(0.92 0.004 286.32);
  --input: oklch(0.92 0.004 286.32);
  --ring: oklch(0.708 0 0);
  --chart-1: oklch(0.809 0.105 251.813);
  --chart-2: oklch(0.623 0.214 259.815);
  --chart-3: oklch(0.546 0.245 262.881);
  --chart-4: oklch(0.488 0.243 264.376);
  --chart-5: oklch(0.424 0.199 265.638);
  --sidebar: oklch(0.985 0 0);
  --sidebar-foreground: oklch(0.141 0.005 285.823);
  --sidebar-primary: oklch(0.546 0.245 262.881);
  --sidebar-primary-foreground: oklch(0.97 0.014 254.604);
  --sidebar-accent: oklch(0.967 0.001 286.375);
  --sidebar-accent-foreground: oklch(0.21 0.006 285.885);
  --sidebar-border: oklch(0.92 0.004 286.32);
  --sidebar-ring: oklch(0.708 0 0);
}

.dark {
  --background: oklch(0.141 0.005 285.823);
  --foreground: oklch(0.985 0 0);
  --card: oklch(0.21 0.006 285.885);
  --card-foreground: oklch(0.985 0 0);
  --popover: oklch(0.21 0.006 285.885);
  --popover-foreground: oklch(0.985 0 0);
  --primary: oklch(0.488 0.243 264.376);
  --primary-foreground: oklch(0.97 0.014 254.604);
  --secondary: oklch(0.274 0.006 286.033);
  --secondary-foreground: oklch(0.985 0 0);
  --muted: oklch(0.274 0.006 286.033);
  --muted-foreground: oklch(0.705 0.015 286.067);
  --accent: oklch(0.274 0.006 286.033);
  --accent-foreground: oklch(0.985 0 0);
  --destructive: oklch(0.704 0.191 22.216);
  --border: oklch(1 0 0 / 10%);
  --input: oklch(1 0 0 / 15%);
  --ring: oklch(0.556 0 0);
  --chart-1: oklch(0.809 0.105 251.813);
  --chart-2: oklch(0.623 0.214 259.815);
  --chart-3: oklch(0.546 0.245 262.881);
  --chart-4: oklch(0.488 0.243 264.376);
  --chart-5: oklch(0.424 0.199 265.638);
  --sidebar: oklch(0.21 0.006 285.885);
  --sidebar-foreground: oklch(0.985 0 0);
  --sidebar-primary: oklch(0.623 0.214 259.815);
  --sidebar-primary-foreground: oklch(0.97 0.014 254.604);
  --sidebar-accent: oklch(0.274 0.006 286.033);
  --sidebar-accent-foreground: oklch(0.985 0 0);
  --sidebar-border: oklch(1 0 0 / 10%);
  --sidebar-ring: oklch(0.439 0 0);
}


/* ── Reset ── */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  max-width: 100%;
  overflow-x: clip;
}

body {
  font-family: "Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;
  color: var(--foreground);
  background: var(--background);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: inherit;
  text-decoration: none;
}

/* ── Shell / Layout ── */
.app-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 100%;
  overflow-x: clip;
}

/* ── Top Bar ── */
.app-topbar {
  background: var(--sidebar);
  border-bottom: 1px solid var(--sidebar-border);
  position: sticky;
  top: 0;
  z-index: 30;
  backdrop-filter: blur(8px);
}

.app-topbar-inner {
  padding: 0.75rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  flex-wrap: wrap;
}

.app-brand-block {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.app-brand-pill {
  display: inline-flex;
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius);
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.75rem;
  letter-spacing: 0.02em;
  color: var(--primary-foreground);
  background: var(--primary);
}

.app-brand-title {
  margin: 0;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--sidebar-foreground);
}

.app-brand-subtitle {
  margin: 0.1rem 0 0;
  color: var(--muted-foreground);
  font-size: 0.75rem;
}

/* ── Nav ── */
.app-nav {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: wrap;
}

.app-nav-desktop {
  display: flex;
}

.app-nav-link {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--secondary-foreground);
  font-weight: 500;
  font-size: 0.875rem;
  padding: 0.42rem 0.68rem;
  background: var(--secondary);
  transition: background 150ms ease, color 150ms ease, border-color 150ms ease;
}

.app-nav-link:hover {
  background: var(--accent);
  color: var(--accent-foreground);
}

.app-nav-link.is-active {
  background: var(--primary);
  color: var(--primary-foreground);
  border-color: var(--primary);
  font-weight: 600;
}

.app-nav-icon {
  width: 1rem;
  height: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.app-nav-icon svg {
  width: 1rem;
  height: 1rem;
  display: block;
}

.app-mobile-menu {
  display: none;
  position: relative;
}

.app-mobile-trigger {
  list-style: none;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--secondary);
  color: var(--secondary-foreground);
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.42rem 0.68rem;
  cursor: pointer;
}

.app-mobile-trigger::-webkit-details-marker {
  display: none;
}

.app-mobile-panel {
  position: absolute;
  top: calc(100% + 0.45rem);
  right: 0;
  z-index: 40;
  width: min(19rem, calc(100dvw - 1rem));
  max-width: calc(100dvw - 1rem);
  max-height: 70vh;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--card);
  box-shadow: 0 10px 30px oklch(0 0 0 / 0.14);
  padding: 0.35rem;
  display: grid;
  gap: 0.2rem;
}

.app-mobile-link {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  border: 1px solid transparent;
  border-radius: var(--radius);
  padding: 0.48rem 0.56rem;
  font-size: 0.875rem;
  color: var(--foreground);
  background: transparent;
}

.app-mobile-link:hover {
  background: var(--accent);
  color: var(--accent-foreground);
}

.app-mobile-link.is-active {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--primary-foreground);
}

/* ── Main ── */
.app-main {
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: var(--background);
  width: 100%;
  max-width: 100%;
}

.app-header {
  padding: 1.5rem 1.5rem 1rem;
  border-bottom: 1px solid var(--border);
}

.app-pretitle {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--muted-foreground);
}

.app-title {
  margin: 0.125rem 0 0;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: var(--foreground);
  line-height: 1.2;
}

.app-content {
  padding: 1.5rem;
  flex: 1;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-x: clip;
}

/* ── Alerts ── */
.app-alert {
  border-radius: var(--radius);
  padding: 0.75rem 1rem;
  font-weight: 500;
  margin-bottom: 1rem;
  font-size: 0.875rem;
  border: 1px solid transparent;
}

.app-alert.success {
  background: oklch(0.95 0.05 145);
  color: oklch(0.35 0.1 145);
  border-color: oklch(0.88 0.08 145);
}

.app-alert.danger {
  background: oklch(0.95 0.04 25);
  color: oklch(0.45 0.15 25);
  border-color: oklch(0.88 0.08 25);
}

.app-footer {
  margin-top: auto;
  padding: 1rem 1.5rem;
  color: var(--muted-foreground);
  font-size: 0.8125rem;
  border-top: 1px solid var(--border);
}

/* ── Dashboard Grid ── */
.dashboard-grid {
  display: grid;
  gap: 1rem;
  min-width: 0;
}

.dashboard-grid > * {
  min-width: 0;
}

/* ── Stats ── */
.stats-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.stat-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
  min-width: 0;
  box-shadow: 0 1px 2px oklch(0 0 0 / 0.03);
}

.stat-label {
  margin: 0;
  color: var(--muted-foreground);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 0.6875rem;
  font-weight: 600;
}

.stat-value {
  margin: 0.25rem 0 0;
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--foreground);
  line-height: 1;
  letter-spacing: -0.02em;
}

/* ── Card ── */
.surface-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.25rem;
  min-width: 0;
  box-shadow: 0 1px 2px oklch(0 0 0 / 0.04);
}

.section-header {
  margin-bottom: 0.75rem;
}

.section-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: var(--card-foreground);
  letter-spacing: -0.01em;
}

.section-subtitle {
  margin: 0.25rem 0 0;
  font-size: 0.875rem;
  color: var(--muted-foreground);
}

.dashboard-hero {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1.3fr 0.7fr;
  border-color: color-mix(in oklch, var(--primary) 26%, var(--border));
  background:
    radial-gradient(85% 120% at 0% 0%, color-mix(in oklch, var(--primary) 11%, var(--background)) 0%, var(--card) 56%),
    var(--card);
}

.dashboard-hero-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.68rem;
  color: var(--muted-foreground);
  font-weight: 700;
}

.dashboard-hero-title {
  margin: 0.35rem 0 0;
  font-size: clamp(1.05rem, 1.9vw, 1.35rem);
  line-height: 1.25;
  letter-spacing: -0.02em;
  color: var(--foreground);
}

.dashboard-hero-subtitle {
  margin: 0.55rem 0 0;
  color: var(--muted-foreground);
  font-size: 0.9rem;
  line-height: 1.5;
}

.dashboard-hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.85rem;
}

.dashboard-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 0.3rem 0.6rem;
  background: color-mix(in oklch, var(--background) 85%, var(--primary) 15%);
  color: var(--foreground);
  font-size: 0.78rem;
  white-space: nowrap;
}

.dashboard-chip strong {
  color: var(--primary);
}

.dashboard-hero-actions {
  display: grid;
  align-content: center;
  gap: 0.55rem;
}

.command-center {
  gap: 1rem;
}

.command-hero {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1.35fr 0.65fr;
  border-color: color-mix(in oklch, var(--primary) 24%, var(--border));
  background:
    radial-gradient(90% 115% at 0% 0%, color-mix(in oklch, var(--primary) 10%, var(--background)) 0%, var(--card) 58%),
    var(--card);
}

.party-strength-grid {
  margin-top: 0.75rem;
  display: grid;
  gap: 0.6rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.party-strength-card {
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) - 1px);
  background: color-mix(in oklch, var(--card) 82%, var(--muted));
  padding: 0.7rem;
}

.party-strength-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.35rem;
}

.party-strength-head strong {
  font-size: 0.84rem;
  line-height: 1.3;
}

.party-strength-card p {
  margin: 0.18rem 0 0;
  font-size: 0.79rem;
  color: var(--muted-foreground);
}

.party-strength-card p strong {
  color: var(--foreground);
}

.command-toolbar {
  display: grid;
  gap: 0.65rem;
  grid-template-columns: minmax(180px, 260px) minmax(0, 1fr);
  align-items: end;
}

.command-toolbar.compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-bottom: 0.5rem;
}

.command-map-layout {
  margin-top: 0.65rem;
  display: grid;
  gap: 0.75rem;
  grid-template-columns: minmax(240px, 300px) minmax(0, 1fr);
  align-items: start;
}

.command-map-sidebar {
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) - 1px);
  background: color-mix(in oklch, var(--card) 86%, var(--muted));
  padding: 0.6rem;
  display: grid;
  gap: 0.65rem;
}

.command-side-title {
  margin: 0;
  font-size: 0.79rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted-foreground);
}

.command-side-name {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--foreground);
}

.command-side-metrics {
  margin: 0;
  display: grid;
  gap: 0.45rem;
}

.command-side-metrics div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.6rem;
  border-bottom: 1px dashed var(--border);
  padding-bottom: 0.25rem;
}

.command-side-metrics dt {
  margin: 0;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted-foreground);
}

.command-side-metrics dd {
  margin: 0;
  font-size: 0.84rem;
  font-weight: 600;
  color: var(--foreground);
}

.command-side-list {
  margin-top: 0.1rem;
}

.command-map-frame {
  min-height: 520px;
  height: clamp(520px, 62dvh, 760px);
}

.coverage-map-frame {
  min-height: 560px;
  height: clamp(560px, 66dvh, 820px);
}

.island-stats {
  margin-bottom: 0.75rem;
}

.issues-summary-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.battle-map-page {
  gap: 0.95rem;
}

.battle-map-main {
  padding: 1rem;
}

.battle-map-toolbar {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.battle-map-layout {
  grid-template-columns: minmax(260px, 330px) minmax(0, 1fr);
}

.battle-map-sidebar {
  gap: 0.65rem;
}

.battle-map-frame {
  height: clamp(860px, calc(100dvh - 120px), 1400px);
}

.battle-detail {
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) - 1px);
  background: color-mix(in oklch, var(--card) 82%, var(--muted));
  padding: 0.55rem;
}

.battle-detail h4 {
  margin: 0;
  font-size: 0.84rem;
  color: var(--foreground);
}

.battle-detail-name {
  margin: 0.3rem 0 0;
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--foreground);
}

.battle-detail dl {
  margin: 0.45rem 0 0;
  display: grid;
  gap: 0.35rem;
}

.battle-detail dl div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.55rem;
  border-bottom: 1px dashed var(--border);
  padding-bottom: 0.22rem;
}

.battle-detail dt {
  margin: 0;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted-foreground);
}

.battle-detail dd {
  margin: 0;
  text-align: right;
  font-size: 0.79rem;
  color: var(--foreground);
  font-weight: 600;
}

.battle-detail .app-button {
  margin-top: 0.55rem;
  width: 100%;
}

.seat-risk-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  min-width: 2.4rem;
  height: 1.35rem;
  padding: 0 0.45rem;
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: 1px solid transparent;
}

.seat-risk-badge.risk-red {
  background: oklch(0.9 0.08 25);
  color: oklch(0.52 0.2 25);
  border-color: oklch(0.78 0.13 25);
}

.seat-risk-badge.risk-amber {
  background: oklch(0.95 0.07 75);
  color: oklch(0.45 0.12 75);
  border-color: oklch(0.85 0.1 75);
}

.seat-risk-badge.risk-green {
  background: oklch(0.93 0.06 150);
  color: oklch(0.38 0.11 150);
  border-color: oklch(0.82 0.09 150);
}

.battle-barbuda-grid {
  display: grid;
  gap: 0.55rem;
  grid-template-columns: 1fr;
}

.battle-positive {
  color: oklch(0.42 0.14 145);
  font-weight: 600;
}

.battle-negative {
  color: oklch(0.55 0.17 25);
  font-weight: 600;
}

.dashboard-chart-row {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.chart-container {
  position: relative;
  width: 100%;
}

.chart-container--medium {
  height: 300px;
}

.chart-container--tall {
  height: 420px;
}

.chart-container canvas {
  width: 100% !important;
  height: 100% !important;
}

.dashboard-map-card .section-header {
  margin-bottom: 1rem;
}

.map-launch-metrics {
  display: grid;
  gap: 0.6rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.map-launch-item {
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) - 1px);
  padding: 0.6rem 0.68rem;
  background: color-mix(in oklch, var(--card) 84%, var(--muted));
}

.map-launch-item p {
  margin: 0;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted-foreground);
  font-weight: 600;
}

.map-launch-item strong {
  display: block;
  margin-top: 0.28rem;
  font-size: 1.2rem;
  line-height: 1;
  color: var(--foreground);
}

.map-launch-item small {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.74rem;
  color: var(--muted-foreground);
}

.map-page {
  gap: 0.85rem;
}

.map-page-main {
  padding: 1rem;
}

.map-layout-full {
  grid-template-columns: minmax(230px, 280px) minmax(0, 1fr);
}

.map-full-frame {
  height: clamp(820px, calc(100dvh - 120px), 1400px);
}

.map-toolbar {
  display: grid;
  gap: 0.6rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: end;
}

.map-control {
  display: grid;
  gap: 0.3rem;
}

.map-control span {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--muted-foreground);
  font-weight: 600;
}

.map-select {
  margin: 0;
}

.map-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) - 1px);
  background: var(--muted);
  padding: 0.5rem 0.65rem;
  min-height: 2.25rem;
}

.map-toggle input {
  margin: 0;
}

.map-toggle span {
  color: var(--foreground);
  font-size: 0.8rem;
}

.map-status {
  margin: 0.7rem 0 0;
  color: var(--muted-foreground);
  font-size: 0.82rem;
}

.map-layout {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: minmax(0, 1fr) 300px;
  align-items: start;
  margin-top: 0.55rem;
}

.map-layout.map-layout-full {
  grid-template-columns: minmax(220px, 260px) minmax(0, 1fr);
}

.dashboard-map-frame {
  width: 100%;
  height: 100%;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid var(--border);
  overflow: hidden;
}

.dashboard-map-frame .leaflet-control-zoom a {
  color: var(--foreground);
}

.map-insights {
  display: grid;
  gap: 0.6rem;
}

.map-insights-left {
  position: sticky;
  top: 0.5rem;
  align-self: start;
}

.map-kpi-grid {
  display: grid;
  gap: 0.5rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.map-kpi-card {
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) - 1px);
  background: color-mix(in oklch, var(--card) 82%, var(--muted));
  padding: 0.5rem 0.55rem;
}

.map-kpi-card p {
  margin: 0;
  font-size: 0.7rem;
  color: var(--muted-foreground);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
  line-height: 1.2;
}

.map-kpi-card strong {
  display: block;
  margin-top: 0.35rem;
  font-size: 1.08rem;
  color: var(--foreground);
  line-height: 1;
}

.map-kpi-filter {
  text-align: left;
  cursor: pointer;
  transition: border-color 150ms ease, background 150ms ease, transform 150ms ease;
}

.map-kpi-filter:hover {
  border-color: color-mix(in oklch, var(--primary) 44%, var(--border));
}

.map-kpi-filter.is-active {
  border-color: var(--primary);
  background: color-mix(in oklch, var(--primary) 12%, var(--card));
}

.map-hotspots {
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) - 1px);
  background: var(--card);
  padding: 0.55rem;
}

.map-hotspots h4 {
  margin: 0;
  font-size: 0.84rem;
  color: var(--foreground);
}

.map-hotspots p {
  margin: 0.25rem 0 0;
  font-size: 0.75rem;
  color: var(--muted-foreground);
}

.map-hotspot-list {
  display: grid;
  gap: 0.4rem;
  margin-top: 0.55rem;
}

.map-hotspot-item {
  text-align: left;
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) - 1px);
  background: color-mix(in oklch, var(--card) 78%, var(--secondary));
  padding: 0.45rem 0.5rem;
  cursor: pointer;
}

.map-hotspot-item:hover {
  border-color: color-mix(in oklch, var(--primary) 40%, var(--border));
}

.map-hotspot-title {
  display: block;
  color: var(--foreground);
  font-size: 0.8rem;
  font-weight: 600;
  line-height: 1.3;
}

.map-hotspot-meta {
  display: block;
  margin-top: 0.2rem;
  color: var(--muted-foreground);
  font-size: 0.73rem;
}

.map-hotspot-empty {
  margin: 0;
  color: var(--muted-foreground);
  font-size: 0.76rem;
}

.map-legend {
  border: 1px dashed var(--border);
  border-radius: calc(var(--radius) - 1px);
  background: var(--muted);
  padding: 0.5rem 0.55rem;
}

.map-legend p {
  margin: 0;
  font-size: 0.72rem;
  color: var(--muted-foreground);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
}

.map-legend div {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.42rem;
  margin-right: 0.6rem;
  font-size: 0.76rem;
  color: var(--foreground);
}

.legend-dot {
  width: 0.68rem;
  height: 0.68rem;
  border-radius: 999px;
  border: 1px solid oklch(0 0 0 / 0.22);
  display: inline-block;
}

.legend-dot.party-ablp {
  background: #EE3422;
}

.legend-dot.party-upp {
  background: #010F71;
}

.legend-dot.party-bpm {
  background: #FCD116;
}

.legend-dot.party-dna {
  background: #EB8123;
}

.legend-dot.party-mixed {
  background: #4b5563;
}

.legend-dot.party-und {
  background: #6b7280;
}

.map-popup {
  min-width: 185px;
}

.map-popup-title {
  margin: 0 0 0.2rem;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--foreground);
}

.map-popup-meta {
  margin: 0.15rem 0 0;
  font-size: 0.76rem;
  color: var(--muted-foreground);
}

.map-popup-breakdown {
  margin: 0.45rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.2rem;
}

.map-popup-breakdown li {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.6rem;
  font-size: 0.72rem;
  color: var(--muted-foreground);
}

.map-popup-breakdown strong {
  color: var(--foreground);
  font-weight: 600;
}

.map-popup-link {
  display: inline-block;
  margin-top: 0.45rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--primary);
  text-decoration: none;
}

.map-popup-link:hover {
  text-decoration: underline;
}

/* ── Table ── */
.party-table-wrap {
  display: block;
  width: 100%;
  overflow-x: auto;
  max-width: 100%;
  min-width: 0;
  -webkit-overflow-scrolling: touch;
}

.party-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 460px;
}

.party-table th,
.party-table td {
  text-align: left;
  padding: 0.625rem 0.75rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.875rem;
}

.party-table thead th {
  color: var(--muted-foreground);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.party-table tbody tr:last-child td {
  border-bottom: none;
}

.party-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  min-width: 3rem;
  padding: 0.2rem 0.5rem;
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  border: 1px solid oklch(0 0 0 / 0.08);
}

.activity-list {
  display: grid;
  gap: 0.55rem;
}

.activity-item {
  display: grid;
  gap: 0.65rem;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) - 1px);
  background: color-mix(in oklch, var(--muted) 68%, var(--card));
  padding: 0.625rem;
}

.activity-detail {
  min-width: 0;
}

.activity-text {
  margin: 0;
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--foreground);
  line-height: 1.35;
}

.activity-meta {
  margin: 0.2rem 0 0;
  font-size: 0.76rem;
  color: var(--muted-foreground);
  overflow-wrap: anywhere;
}

.activity-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  min-width: 1.6rem;
  height: 1.6rem;
  padding: 0 0.45rem;
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: 1px solid transparent;
}

.badge-household {
  background: oklch(0.95 0.03 145);
  color: oklch(0.36 0.1 145);
  border-color: oklch(0.89 0.05 145);
}

.badge-person {
  background: oklch(0.95 0.03 30);
  color: oklch(0.4 0.15 30);
  border-color: oklch(0.89 0.06 30);
}

.badge-undeclared {
  background: var(--secondary);
  color: var(--secondary-foreground);
  border-color: var(--border);
}

.empty-state {
  margin: 0;
  border: 1px dashed var(--border);
  border-radius: calc(var(--radius) - 1px);
  background: var(--muted);
  color: var(--muted-foreground);
  padding: 0.7rem 0.8rem;
  font-size: 0.84rem;
}

.swatch {
  display: inline-block;
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 0.125rem;
  border: 1px solid var(--border);
  margin-right: 0.375rem;
  vertical-align: middle;
}

/* ── Model / Item List ── */
.model-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.5rem;
}

.model-item {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--muted);
  padding: 0.75rem;
}

.model-name {
  margin: 0;
  font-weight: 600;
  color: var(--foreground);
  font-size: 0.875rem;
}

.model-desc {
  margin: 0.25rem 0 0;
  color: var(--muted-foreground);
  font-size: 0.8125rem;
  line-height: 1.5;
}

/* ── Buttons ── */
.app-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: var(--radius);
  height: 2.25rem;
  padding: 0 1rem;
  font-weight: 500;
  text-decoration: none;
  font-size: 0.875rem;
  cursor: pointer;
  transition: background 150ms ease, opacity 150ms ease;
  font-family: inherit;
  line-height: 1;
  white-space: nowrap;
}

.app-button.primary {
  color: var(--primary-foreground);
  background: var(--primary);
}

.app-button.primary:hover {
  opacity: 0.9;
}

.app-button.ghost {
  color: var(--secondary-foreground);
  background: var(--secondary);
  border: 1px solid var(--border);
}

.app-button.ghost:hover {
  background: var(--accent);
}

.app-button.destructive {
  color: var(--primary-foreground);
  background: var(--destructive);
}

.app-button.destructive:hover {
  opacity: 0.9;
}

.app-button.sm {
  height: 1.75rem;
  padding: 0 0.625rem;
  font-size: 0.8125rem;
}

.quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.feature-list {
  margin: 0.75rem 0 0;
  padding-left: 1.25rem;
  color: var(--muted-foreground);
  font-size: 0.875rem;
  line-height: 1.6;
}

/* ── Form Controls (shared with CRUD + field entry) ── */
.entry-stack {
  display: grid;
  gap: 0.95rem;
  margin-top: 1rem;
}

.entry-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--foreground);
  margin-bottom: 0.5rem;
  display: block;
}

.entry-label.entry-label-error {
  color: var(--destructive);
}

.entry-input,
.entry-select,
.entry-textarea {
  width: 100%;
  border: 1px solid var(--input);
  border-radius: var(--radius);
  font-size: 0.875rem;
  padding: 0.625rem 0.9rem;
  color: var(--foreground);
  background: var(--background);
  font-family: inherit;
  height: 2.55rem;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}

.entry-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 0.5rem center;
  background-repeat: no-repeat;
  background-size: 1.25em 1.25em;
  padding-right: 2.2rem;
}

.entry-textarea {
  min-height: 110px;
  height: auto;
  resize: vertical;
}

.entry-mt {
  margin-top: 0.85rem;
}

.entry-input:focus,
.entry-select:focus,
.entry-textarea:focus {
  outline: none;
  border-color: var(--ring);
  box-shadow: 0 0 0 2px oklch(0.704 0.191 22.216 / 0.2);
}

.entry-input.has-error,
.entry-select.has-error,
.entry-textarea.has-error {
  border-color: var(--destructive);
  box-shadow: 0 0 0 3px oklch(0.577 0.245 27.325 / 0.18);
}

.entry-pills.has-error {
  border: 1px solid var(--destructive);
  border-radius: var(--radius);
  padding: 0.375rem;
  box-shadow: 0 0 0 3px oklch(0.577 0.245 27.325 / 0.14);
}

.entry-person-list.has-error {
  border: 1px solid var(--destructive);
  border-radius: var(--radius);
  padding: 0.625rem;
  box-shadow: 0 0 0 3px oklch(0.577 0.245 27.325 / 0.14);
}

.entry-field-error {
  display: none;
  margin: 0.375rem 0 0;
  color: var(--destructive);
  font-size: 0.8125rem;
  line-height: 1.3;
  font-weight: 500;
}

.entry-field-error.show {
  display: block;
}

.entry-form-error {
  display: none;
  margin-top: 0.75rem;
  border: 1px solid var(--destructive);
  border-radius: var(--radius);
  background: oklch(0.97 0.03 20);
  color: var(--destructive);
  font-size: 0.8125rem;
  padding: 0.625rem 0.75rem;
}

.entry-form-error.show {
  display: block;
}

/* ── Auth ── */
.auth-container {
  display: flex;
  justify-content: center;
  padding: 2rem 0;
}

.auth-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 2rem;
  width: 100%;
  max-width: 420px;
}

.auth-card-wide {
  max-width: 560px;
}

.auth-heading {
  margin: 0 0 0.25rem;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--foreground);
}

.auth-subtext {
  margin: 0 0 1.5rem;
  color: var(--muted-foreground);
  font-size: 0.875rem;
}

.auth-form {
  display: grid;
  gap: 1rem;
}

.auth-errors {
  background: oklch(0.97 0.03 20);
  border: 1px solid var(--destructive);
  border-radius: var(--radius);
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  font-size: 0.875rem;
  color: oklch(0.45 0.15 25);
}

.auth-errors h4 {
  margin: 0 0 0.5rem;
  font-size: 0.875rem;
}

.auth-errors ul {
  margin: 0;
  padding-left: 1.25rem;
}

.auth-errors li {
  margin-bottom: 0.25rem;
}

.auth-links {
  margin-top: 1rem;
  text-align: center;
}

.auth-link {
  color: var(--primary);
  font-size: 0.875rem;
  text-decoration: underline;
}

.auth-link:hover {
  opacity: 0.8;
}

/* ── Form Controls (Auth / Admin) ── */
.form-group {
  display: flex;
  flex-direction: column;
}

.form-label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--foreground);
  margin-bottom: 0.375rem;
}

.form-input {
  width: 100%;
  border: 1px solid var(--input);
  border-radius: var(--radius);
  font-size: 0.875rem;
  padding: 0.5rem 0.75rem;
  color: var(--foreground);
  background: var(--background);
  font-family: inherit;
  height: 2.25rem;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}

.form-input:focus {
  outline: none;
  border-color: var(--ring);
  box-shadow: 0 0 0 2px oklch(0.488 0.243 264.376 / 0.2);
}

.form-hint {
  margin: 0.25rem 0 0;
  font-size: 0.75rem;
  color: var(--muted-foreground);
}

.form-check {
  flex-direction: row;
  align-items: center;
  gap: 0.5rem;
}

.form-checkbox {
  width: 1rem;
  height: 1rem;
  accent-color: var(--primary);
}

.form-check-label {
  font-size: 0.875rem;
  margin: 0;
}

.form-row {
  display: flex;
  gap: 1rem;
}

.form-group-half {
  flex: 1;
}

.form-actions {
  display: flex;
  gap: 0.75rem;
  margin-top: 0.5rem;
}

/* ── Buttons (Auth / Admin) ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  border-radius: var(--radius);
  height: 2.25rem;
  padding: 0 1rem;
  font-weight: 500;
  text-decoration: none;
  font-size: 0.875rem;
  cursor: pointer;
  transition: background 150ms ease, opacity 150ms ease;
  font-family: inherit;
  line-height: 1;
  white-space: nowrap;
}

.btn-primary {
  color: var(--primary-foreground);
  background: var(--primary);
}

.btn-primary:hover {
  opacity: 0.9;
}

.btn-outline {
  color: var(--secondary-foreground);
  background: var(--secondary);
  border: 1px solid var(--border);
}

.btn-outline:hover {
  background: var(--accent);
}

.btn-danger {
  color: #fff;
  background: var(--destructive);
}

.btn-danger:hover {
  opacity: 0.9;
}

.btn-warning {
  color: #fff;
  background: oklch(0.65 0.17 55);
}

.btn-warning:hover {
  opacity: 0.9;
}

.btn-success {
  color: #fff;
  background: oklch(0.55 0.15 145);
}

.btn-success:hover {
  opacity: 0.9;
}

.btn-full {
  width: 100%;
}

.btn-sm {
  height: 1.75rem;
  padding: 0 0.625rem;
  font-size: 0.8125rem;
}

/* ── Admin Toolbar ── */
.admin-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
}

.admin-filters {
  display: flex;
  gap: 0.5rem;
}

/* ── Data Table ── */
.table-wrap {
  display: block;
  width: 100%;
  overflow-x: auto;
  max-width: 100%;
  min-width: 0;
  -webkit-overflow-scrolling: touch;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 700px;
}

.data-table th,
.data-table td {
  text-align: left;
  padding: 0.625rem 0.75rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.875rem;
}

.data-table thead th {
  color: var(--muted-foreground);
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.data-table tbody tr:last-child td {
  border-bottom: none;
}

.actions-cell {
  display: flex;
  gap: 0.375rem;
  flex-wrap: wrap;
}

/* ── Badges ── */
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 0.15rem 0.6rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.badge-admin {
  background: oklch(0.92 0.04 280);
  color: oklch(0.4 0.15 280);
}

.badge-editor {
  background: oklch(0.92 0.04 200);
  color: oklch(0.4 0.15 200);
}

.badge-viewer {
  background: oklch(0.94 0.02 60);
  color: oklch(0.45 0.1 60);
}

.badge-active {
  background: oklch(0.92 0.06 145);
  color: oklch(0.4 0.12 145);
}

.badge-inactive {
  background: oklch(0.94 0.02 25);
  color: oklch(0.5 0.1 25);
}

/* ── Detail Card ── */
.detail-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem;
  max-width: 600px;
}

.detail-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.detail-header h3 {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 700;
}

.detail-badges {
  display: flex;
  gap: 0.5rem;
}

.detail-list {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.5rem 1.5rem;
  margin: 0 0 1.5rem;
  font-size: 0.875rem;
}

.detail-list dt {
  color: var(--muted-foreground);
  font-weight: 500;
}

.detail-list dd {
  margin: 0;
  color: var(--foreground);
}

.detail-actions {
  display: flex;
  gap: 0.75rem;
}

/* ── User Auth Bar ── */
.app-user-bar {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.8125rem;
}

.app-user-info {
  color: var(--muted-foreground);
  font-size: 0.75rem;
}

.app-user-info strong {
  color: var(--foreground);
  font-weight: 600;
}
/* ── Responsive ── */
@media (max-width: 960px) {
  .app-topbar-inner {
    padding: 0.75rem 1rem;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    flex-wrap: nowrap;
  }

  .app-brand-block {
    min-width: 0;
  }

  .app-brand-subtitle {
    display: none;
  }

  .app-brand-title {
    font-size: 0.8125rem;
  }

  .app-nav-desktop {
    display: none;
  }

  .app-mobile-menu {
    display: block;
    flex-shrink: 0;
  }

  .app-mobile-panel {
    width: min(19rem, calc(100dvw - 1rem));
    max-width: calc(100dvw - 1rem);
  }

  .app-content,
  .app-header,
  .app-footer {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .dashboard-hero {
    grid-template-columns: 1fr;
  }

  .command-hero {
    grid-template-columns: 1fr;
  }

  .dashboard-chart-row {
    grid-template-columns: 1fr;
  }

  .command-toolbar,
  .command-toolbar.compact {
    grid-template-columns: 1fr;
  }

  .command-map-layout {
    grid-template-columns: 1fr;
  }

  .command-map-frame {
    min-height: 420px;
    height: min(72dvh, 700px);
  }

  .coverage-map-frame {
    min-height: 440px;
    height: min(74dvh, 740px);
  }

  .map-toolbar {
    grid-template-columns: 1fr;
  }

  .battle-map-toolbar {
    grid-template-columns: 1fr;
  }

  .battle-map-layout {
    grid-template-columns: 1fr;
  }

  .battle-map-frame {
    height: min(76dvh, 980px);
  }

  .map-layout {
    grid-template-columns: 1fr;
  }

  .map-layout.map-layout-full {
    grid-template-columns: 1fr;
  }

  .map-insights-left {
    position: static;
  }

  .chart-container--tall {
    height: 330px;
  }

  .chart-container--medium {
    height: 280px;
  }
}

@media (max-width: 640px) {
  .surface-card,
  .stat-card {
    padding: 0.9rem;
  }

  .activity-item {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
  }

  .activity-item .app-button {
    width: 100%;
  }

  .map-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .party-strength-grid,
  .issues-summary-grid {
    grid-template-columns: 1fr;
  }

  .command-map-sidebar .app-button {
    width: 100%;
  }

  .map-launch-metrics {
    grid-template-columns: 1fr;
  }

  .map-full-frame {
    height: min(88dvh, 980px);
  }

  .battle-map-frame {
    height: min(78dvh, 920px);
  }
}
