/* === Base Reset & Theme === */
:root {
  --bg-primary: #060E1A;
  --bg-secondary: #0A1525;
  --bg-card: #0f1d33;
  --bg-card-hover: #15263f;
  --bg-inset: #081426;
  --border: #1a2a44;
  --border-light: #2a4060;
  --text-primary: #eef3fb;
  --text-secondary: #a8bdd6;
  --text-muted: #6b8bb0;         /* small uppercase labels (9–11px) — preserved for hierarchy */
  --text-muted-large: #8fb3d8;   /* 12–14px muted body / helper text — lighter to hit WCAG AA 4.5:1 on --bg-primary */
  --accent-blue: #5a9eff;
  --accent-red: #f25c5c;        /* Republican / partisan red — do not repurpose */
  --accent-purple: #b88cff;
  --accent-green: #34d399;
  --accent-amber: #fbbf24;
  --accent-cyan: #22d3ee;
  --accent-teal: #2dd4bf;
  --brand-red: #be2039;         /* ElectIQ primary brand red (logo) */
  --brand-blue: #2176b7;        /* ElectIQ logo blue (subtle accents) */
  --state-error: #ef4444;       /* True UI error / destructive state */
  --glow-blue: rgba(90, 158, 255, 0.15);
  --glow-purple: rgba(184, 140, 255, 0.12);

  /* Accent alpha bands — theme-relevant tints used for badges,
     soft backgrounds, hover states. NOT for partisan viz:
     rgba(78,143,247,...) and rgba(242,92,92,...) remain hardcoded
     as partisan Dem/GOP invariants. See claude-audits.md Phase 0. */
  --accent-blue-soft: rgba(90, 158, 255, 0.08);
  --accent-amber-soft: rgba(251, 191, 36, 0.15);
  --accent-green-soft: rgba(52, 211, 153, 0.15);
  --state-error-soft: rgba(239, 68, 68, 0.1);
  --subtle-hover-bg: rgba(255, 255, 255, 0.03);
  --overlay-strong: rgba(0, 0, 0, 0.4);

  /* Body gradient end stop (slightly darker than --bg-primary) */
  --bg-gradient-end: #04080f;

  --radius: 14px;
  --shadow: 0 4px 32px rgba(3, 10, 22, 0.5);
  --shadow-glow: 0 0 30px var(--accent-blue-soft);
}

/* === Light theme override ===
   Activated by setting [data-theme="light"] on <html>. The first-paint
   inline script in <head> reads localStorage('electiq.theme') and the
   OS prefers-color-scheme to set this attribute before stylesheet load,
   preventing flash-of-wrong-theme. See claude-audits.md "Light Theme
   Feasibility" for the full palette rationale.

   Brand and partisan colors stay invariant across themes:
   - --brand-red, --brand-blue (ElectIQ logo)
   - --accent-red (#f25c5c) (partisan GOP red, used in race/finance/polling cards)
   - The hardcoded #4e8ff7 / rgba(78,143,247,...) family (partisan Dem blue)
*/
:root[data-theme="light"] {
  --bg-primary: #fafbfc;
  --bg-secondary: #f0f3f7;
  --bg-card: #ffffff;
  --bg-card-hover: #f8f9fb;
  --bg-inset: #f5f7fa;
  --border: #d4d9e3;
  --border-light: #e8ecf1;
  --text-primary: #1a1a2e;
  --text-secondary: #4a5568;
  --text-muted: #8a94a3;
  --text-muted-large: #6b7689;
  --accent-blue: #1854cc;
  --accent-purple: #8b5bbf;
  --accent-green: #1e8e5e;
  --accent-amber: #b87a04;
  --accent-cyan: #0d7ea8;
  --accent-teal: #0a8f6c;
  --state-error: #c92a2a;
  /* Partisan GOP red — deeper variant for contrast on light bg.
     Still semantically "Republican red" but readable. Brand red and
     brand blue stay invariant via inheritance from :root. */
  --accent-red: #cc2222;

  --glow-blue: rgba(24, 84, 204, 0.10);
  --glow-purple: rgba(139, 91, 191, 0.10);
  --accent-blue-soft: rgba(24, 84, 204, 0.08);
  --accent-amber-soft: rgba(184, 122, 4, 0.12);
  --accent-green-soft: rgba(30, 142, 94, 0.12);
  --state-error-soft: rgba(201, 42, 42, 0.10);
  --subtle-hover-bg: rgba(0, 0, 0, 0.04);
  --overlay-strong: rgba(0, 0, 0, 0.20);

  --bg-gradient-end: #f3f6f9;

  --shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  --shadow-glow: 0 0 20px rgba(24, 84, 204, 0.06);
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
  background: linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-gradient-end) 100%);
  color: var(--text-primary);
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
}

/* === Accessibility: global keyboard-focus ring ===
   Targets buttons, anchors, and role=button elements that don't have
   their own explicit focus treatment. Inputs / selects / textareas
   use explicit box-shadow + border-color focus styling elsewhere and
   are exempted so we don't double-render focus indicators.
   Uses :focus-visible so mouse clicks don't show focus rings on macOS.
*/
button:focus-visible,
a:focus-visible,
summary:focus-visible,
[role="button"]:focus-visible,
[tabindex]:not([tabindex="-1"]):focus-visible {
  outline: 2px solid var(--accent-blue);
  outline-offset: 2px;
  border-radius: 4px;
}

/* === Loading Overlay === */
#loading-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: linear-gradient(135deg, var(--bg-primary), var(--bg-secondary) 50%, var(--bg-card));
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  transition: opacity 0.8s cubic-bezier(0.4,0,0,1), visibility 0.8s;
}
#loading-overlay.hidden { opacity: 0; visibility: hidden; }
.loader-content { text-align: center; color: var(--text-secondary); }
.loader-title { font-size: 24px; font-weight: 700; color: var(--text-primary); margin-bottom: 4px; letter-spacing: -0.5px; }
.loader-sub { font-size: 13px; color: var(--text-muted-large); margin-bottom: 24px; }
.loader-ring { width: 64px; height: 64px; margin: 0 auto 20px; position: relative; }
.loader-ring div { position: absolute; width: 100%; height: 100%; border-radius: 50%; border: 3px solid transparent; }
.loader-ring div:nth-child(1) { border-top-color: var(--accent-blue); animation: ring-spin 1.2s cubic-bezier(0.5,0,0.5,1) infinite; }
.loader-ring div:nth-child(2) { border-right-color: var(--accent-purple); animation: ring-spin 1.2s cubic-bezier(0.5,0,0.5,1) infinite; animation-delay: -0.15s; }
.loader-ring div:nth-child(3) { border-bottom-color: var(--accent-cyan); animation: ring-spin 1.2s cubic-bezier(0.5,0,0.5,1) infinite; animation-delay: -0.3s; }
@keyframes ring-spin { to { transform: rotate(360deg); } }
.loader-bar { width: 200px; height: 3px; background: var(--border); border-radius: 3px; overflow: hidden; margin: 0 auto; }
.loader-bar-fill { height: 100%; width: 0%; background: linear-gradient(90deg, var(--accent-blue), var(--accent-purple), var(--accent-cyan)); border-radius: 3px; animation: loader-fill 1.5s ease-out forwards; }
@keyframes loader-fill { 0% { width: 0%; } 60% { width: 70%; } 100% { width: 95%; } }

/* === Header === */
.dashboard-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 32px; border-bottom: 1px solid var(--border);
  flex-wrap: wrap; gap: 16px; position: sticky; top: 0; z-index: 1000;
  min-height: 64px; box-sizing: border-box;
  opacity: 0; transform: translateY(-20px);
  animation: header-enter 0.7s cubic-bezier(0.16,1,0.3,1) 0.3s forwards;
  backdrop-filter: blur(12px); background: rgba(8, 26, 48, 0.95);
}
@keyframes header-enter { to { opacity: 1; transform: translateY(0); } }
.header-left { display: flex; align-items: center; gap: 12px; }
.header-left h1 { font-size: 26px; font-weight: 700; letter-spacing: -0.5px; line-height: 1.2; }
.header-left .accent { color: var(--accent-blue); }
.badge {
  display: inline-block; background: var(--glow-blue); color: var(--accent-blue);
  padding: 3px 10px; border-radius: 20px; font-size: 12px; font-weight: 500;
}

/* District Selector */
.header-center { flex: 0 1 auto; }
.district-selector { display: flex; flex-direction: column; gap: 2px; }
.selector-label { font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); }
.selector-row { display: flex; align-items: center; gap: 8px; }
.copy-link-btn {
  position: relative; width: 36px; height: 36px; flex-shrink: 0;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.copy-link-btn:hover { color: var(--text-primary); border-color: var(--accent-blue); background: var(--bg-card-hover); }
.copy-link-btn svg { width: 18px; height: 18px; }
.copy-tooltip {
  position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%) translateY(4px);
  background: var(--accent-green); color: #fff; font-size: 11px; font-weight: 600;
  padding: 4px 10px; border-radius: 6px; white-space: nowrap;
  opacity: 0; visibility: hidden; transition: opacity 0.2s, transform 0.2s, visibility 0.2s;
  pointer-events: none;
}
.copy-tooltip::after {
  content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  border: 5px solid transparent; border-top-color: var(--accent-green);
}
.copy-tooltip.show { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.copy-tooltip.error { background: var(--state-error) !important; }
.copy-tooltip.error::after { border-top-color: var(--state-error) !important; }
.district-selector select {
  background: var(--bg-card); color: var(--text-primary); border: 1px solid var(--border);
  border-radius: 8px; padding: 8px 32px 8px 12px; font-size: 13px; font-family: inherit;
  cursor: pointer; appearance: none; min-width: 200px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' stroke='%236d7590' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.district-selector select:hover { border-color: var(--accent-blue); }
.district-selector select:focus { outline: none; border-color: var(--accent-blue); box-shadow: 0 0 0 3px var(--glow-blue); }

.header-right { display: flex; gap: 28px; align-items: center; min-width: 0; flex-shrink: 1; }
.header-stat { text-align: right; }

/* Mobile info toggle (hidden on desktop) */
.header-info-btn {
  display: none;
  width: 34px; height: 34px; border-radius: 50%;
  border: 1px solid var(--border); background: var(--bg-card);
  color: var(--text-muted); cursor: pointer;
  align-items: center; justify-content: center;
  transition: all 0.2s;
  flex-shrink: 0; padding: 0;
}
.header-info-btn:hover, .header-info-btn.active {
  color: var(--accent-blue); border-color: var(--accent-blue);
  background: rgba(90, 158, 255, 0.1);
}

/* Mobile stats drawer */
.mobile-stats-drawer {
  display: none;
  overflow: hidden;
  max-height: 0;
  background: rgba(8, 26, 48, 0.95);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: sticky;
  z-index: 999;
}
.mobile-stats-drawer.open {
  max-height: 80px;
}
.mobile-stats-row {
  display: flex; justify-content: space-around; align-items: center;
  padding: 10px 16px;
}
.mobile-stat { text-align: center; }
.mobile-stat .stat-label { font-size: 9px; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); display: block; }
.mobile-stat .stat-value { font-size: 15px; font-weight: 700; display: block; }

/* Header User Avatar & Dropdown */
.header-user-menu { position: relative; }
.header-avatar-btn {
  width: 40px; height: 40px; border-radius: 50%; border: 2px solid var(--border);
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.2s; padding: 0; overflow: hidden;
  font-size: 14px; font-weight: 700; color: #fff; text-transform: uppercase;
}
.header-avatar-btn:hover { border-color: var(--accent-blue); transform: scale(1.05); }
.header-avatar {
  width: 100%; height: 100%; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background-size: cover; background-position: center;
}
.header-dropdown {
  position: absolute; top: calc(100% + 8px); right: 0;
  width: 220px; background: var(--bg-secondary);
  border: 1px solid var(--border); border-radius: 12px;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.5);
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
  z-index: 1100; overflow: hidden;
}
.header-dropdown.open { opacity: 1; visibility: visible; transform: translateY(0); }
.header-dropdown-user { padding: 14px 16px; }
.header-dropdown-name { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.header-dropdown-role {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px;
}
.header-dropdown-role.role-admin { color: var(--accent-red); }
.header-dropdown-role.role-manager { color: var(--accent-amber); }
.header-dropdown-role.role-viewer { color: var(--accent-blue); }
.header-dropdown-divider { height: 1px; background: var(--border); }
.header-dropdown-item {
  display: flex; align-items: center; gap: 10px; width: 100%;
  padding: 10px 16px; font-size: 13px; font-weight: 500; font-family: inherit;
  background: transparent; border: none; color: var(--text-secondary);
  cursor: pointer; transition: all 0.15s; text-align: left;
}
.header-dropdown-item:hover { background: rgba(255, 255, 255, 0.05); color: var(--text-primary); }
.header-dropdown-item svg { opacity: 0.6; flex-shrink: 0; }
.header-dropdown-item:hover svg { opacity: 1; }
.header-dropdown-logout:hover { color: var(--state-error); }
.header-dropdown-logout:hover svg { opacity: 1; }

/* Notification Bell */
.header-notify { position: relative; }
.header-notify-btn {
  width: 40px; height: 40px; border-radius: 50%; border: 1px solid var(--border);
  background: transparent; color: var(--text-muted); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; position: relative;
}
.header-notify-btn:hover { color: var(--text-primary); border-color: var(--accent-blue); background: var(--bg-card); }
.header-notify-badge {
  position: absolute; top: -2px; right: -2px; min-width: 18px; height: 18px;
  background: var(--accent-red); color: #fff; font-size: 10px; font-weight: 700;
  border-radius: 9px; display: flex; align-items: center; justify-content: center;
  padding: 0 4px; box-sizing: border-box;
}
.header-notify-dropdown {
  position: absolute; top: calc(100% + 8px); right: 0;
  width: 380px; max-height: 520px; background: var(--bg-secondary);
  border: 1px solid var(--border); border-radius: 12px;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.5);
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
  z-index: 1100; overflow: hidden; display: flex; flex-direction: column;
}
.header-notify-dropdown.open { opacity: 1; visibility: visible; transform: translateY(0); }
.notify-dropdown-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
}
.notify-dropdown-title { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.notify-mark-read-btn {
  font-size: 11px; color: var(--text-muted); background: none; border: none;
  cursor: pointer; font-family: inherit; padding: 4px 8px; border-radius: 4px;
  transition: color 0.2s;
}
.notify-mark-read-btn:hover { color: var(--accent-blue); }
.notify-settings-btn {
  background: none; border: none; color: var(--text-muted);
  cursor: pointer; padding: 4px; border-radius: 4px; display: flex;
  align-items: center; transition: color 0.2s;
}
.notify-settings-btn:hover { color: var(--accent-blue); }
.notify-settings-panel {
  padding: 16px; border-bottom: 1px solid var(--border);
  background: var(--bg-inset, rgba(0,0,0,0.15));
  animation: fadeSlideDown 0.2s ease-out;
}
.notify-settings-title {
  font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 12px;
}
.notify-settings-group { margin-bottom: 12px; }
.notify-settings-label {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--text-muted); margin-bottom: 6px;
}
.notify-setting-toggle {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--text-secondary); padding: 3px 0; cursor: pointer;
}
.notify-setting-toggle input[type="checkbox"] {
  accent-color: var(--accent-blue); width: 14px; height: 14px; cursor: pointer;
}
.notify-settings-select {
  width: 100%; padding: 6px 10px; border-radius: 6px;
  background: var(--bg-card); border: 1px solid var(--border);
  color: var(--text-primary); font-size: 12px; cursor: pointer;
  outline: none; font-family: inherit;
}
.notify-settings-select:focus { border-color: var(--accent-blue); }
.notify-settings-save {
  width: 100%; padding: 8px; border-radius: 6px; border: none;
  background: var(--accent-blue); color: #fff; font-size: 12px;
  font-weight: 600; cursor: pointer; font-family: inherit;
  transition: background 0.2s;
}
.notify-settings-save:hover { background: #3a7de8; }
.notify-dropdown-filters {
  display: flex; gap: 4px; padding: 10px 16px; border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.notify-dropdown-filters .alert-filter-btn { font-size: 11px; padding: 4px 10px; }
.notify-dropdown-feed {
  overflow-y: auto; max-height: 380px; flex: 1;
}
.notify-dropdown-feed.feed-animate {
  animation: feedFadeIn 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes feedFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
.notify-dropdown-feed .alert-item { padding: 12px 16px; }
.notify-dropdown-feed .alert-title { font-size: 12px; }
.notify-dropdown-feed .alert-message { font-size: 11px; }
.notify-empty { text-align: center; padding: 40px 16px; color: var(--text-muted); }
@media (max-width: 500px) {
  .header-notify-dropdown { width: calc(100% - 24px); right: 0; left: 12px; position: fixed; }
}
.anim-stat { opacity: 0; animation: stat-pop 0.5s cubic-bezier(0.16,1,0.3,1) forwards; }
.anim-stat:nth-child(1) { animation-delay: 0.8s; }
.anim-stat:nth-child(2) { animation-delay: 0.95s; }
.anim-stat:nth-child(3) { animation-delay: 1.1s; }
@keyframes stat-pop { 0% { opacity: 0; transform: translateY(8px) scale(0.95); } 100% { opacity: 1; transform: translateY(0) scale(1); } }
.stat-label { display: block; font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); }
.stat-value { font-size: 20px; font-weight: 700; color: var(--text-primary); }
.stat-value.swing-dem { color: var(--accent-blue); }
.stat-value.swing-rep { color: var(--accent-red); }
.stat-value.swing-toss { color: var(--accent-purple); }

/* === Sidebar === */
.sidebar {
  position: fixed; top: 0; left: 0; bottom: 0;
  width: 240px; background: var(--bg-secondary);
  border-right: 1px solid var(--border);
  z-index: 1100; display: flex; flex-direction: column;
  transform: translateX(-100%);
  transition: transform 0.3s cubic-bezier(0.16,1,0.3,1);
  overflow-y: auto; overflow-x: hidden;
}
.sidebar.open { transform: translateX(0); }
.sidebar-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.5); z-index: 1099;
  opacity: 0; visibility: hidden; transition: opacity 0.3s, visibility 0.3s;
}
.sidebar-overlay.open { opacity: 1; visibility: visible; }
.sidebar-header {
  display: flex; align-items: center;
  padding: 16px; border-bottom: 1px solid var(--border);
  box-sizing: border-box;
}
.sidebar-brand {
  display: flex; align-items: center; gap: 12px;
  font-size: 18px; font-weight: 700; color: var(--text-primary);
  letter-spacing: 0.5px;
}
.sidebar-brand-logo {
  height: 36px; width: auto; max-width: 100%; object-fit: contain;
}
.sidebar-close {
  width: 28px; height: 28px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border); border-radius: 6px;
  color: var(--text-muted); cursor: pointer; transition: all 0.2s;
}
.sidebar-close:hover { color: var(--text-primary); border-color: var(--border-light); background: var(--bg-card); }
.sidebar-section { padding: 12px 12px 4px; }
.sidebar-section-label {
  font-size: 10px; text-transform: uppercase; letter-spacing: 1.2px;
  color: var(--text-muted); padding: 0 8px 8px; font-weight: 600;
}
.sidebar-item {
  display: flex; align-items: center; gap: 10px; width: 100%;
  padding: 10px 12px; font-size: 13px; font-weight: 500; font-family: inherit;
  color: var(--text-secondary); background: transparent; border: none;
  border-radius: 8px; cursor: pointer; transition: all 0.15s; text-align: left;
}
.sidebar-item:hover { color: var(--text-primary); background: var(--bg-card); }
.sidebar-item.active {
  color: #fff; background: rgba(190, 32, 57, 0.18);
  border-left: 3px solid var(--brand-red);
  padding-left: 13px;
  font-weight: 600;
}
.sidebar-item.active::before { display: none; }
.sidebar-item svg { flex-shrink: 0; opacity: 0.5; }
.sidebar-item.active svg { opacity: 1; }
.sidebar-item.sidebar-item-active {
  color: #fff; border-left: 3px solid var(--brand-red);
  padding-left: 13px; background: rgba(190, 32, 57, 0.18);
  font-weight: 600;
}
.sidebar-item.sidebar-item-active svg { opacity: 1; }
.sidebar-item:disabled { opacity: 0.4; cursor: default; }
.sidebar-item:disabled:hover { background: transparent; color: var(--text-secondary); }
/* Election Switcher — compact dropdown replacing 5 sidebar buttons */
.election-switcher-section { padding-bottom: 4px !important; }
.election-switcher-btn {
  display: flex; align-items: center; gap: 8px; width: 100%;
  padding: 8px 10px; font-size: 13px; font-weight: 600; font-family: inherit;
  color: var(--accent-blue); background: rgba(78, 143, 247, 0.10);
  border: 1px solid rgba(78, 143, 247, 0.25); border-radius: 8px;
  cursor: pointer; transition: all 0.15s; text-align: left; position: relative;
}
.election-switcher-btn:hover {
  background: rgba(78, 143, 247, 0.18);
  border-color: rgba(78, 143, 247, 0.4);
}
.election-switcher-btn svg { flex-shrink: 0; }
.election-switcher-icon { display: flex; align-items: center; }
.election-switcher-label { flex: 1; }
.election-switcher-chevron {
  flex-shrink: 0; transition: transform 0.2s;
}
.election-switcher-btn.open .election-switcher-chevron {
  transform: rotate(180deg);
}
.election-switcher-dropdown {
  display: none; flex-direction: column; gap: 2px;
  margin-top: 4px; padding: 4px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; overflow: hidden;
}
.election-switcher-dropdown.open { display: flex; }
.election-switcher-option {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; font-size: 12px; font-weight: 500; font-family: inherit;
  color: var(--text-secondary); background: transparent; border: none;
  border-radius: 6px; cursor: pointer; transition: all 0.12s; text-align: left; width: 100%;
}
.election-switcher-option:hover {
  color: var(--text-primary); background: var(--bg-secondary);
}
.election-switcher-option.active {
  color: var(--accent-blue); background: rgba(78, 143, 247, 0.10); font-weight: 600;
}
.election-switcher-option svg { flex-shrink: 0; opacity: 0.5; }
.election-switcher-option.active svg { opacity: 1; }

.sidebar-badge {
  margin-left: auto; font-size: 10px; padding: 2px 6px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 4px; color: var(--text-muted); font-weight: 600;
}
.sidebar-footer {
  margin-top: auto; padding: 12px 16px; border-top: 1px solid var(--border);
}
.sidebar-features-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; border-radius: 8px;
  font-size: 13px; font-weight: 600; color: var(--text-muted);
  text-decoration: none; transition: all 0.2s;
  border: 1px solid var(--border);
}
.sidebar-features-btn:hover { color: var(--accent-blue); border-color: var(--accent-blue); background: var(--accent-blue-soft); }
.sidebar-features-btn svg { flex-shrink: 0; }
.sidebar-version { font-size: 11px; color: var(--text-muted); margin-top: 8px; }

/* Sidebar User Profile */
.sidebar-user {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0; margin-bottom: 4px;
}
.sidebar-user-avatar {
  width: 34px; height: 34px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; color: #fff;
  flex-shrink: 0; text-transform: uppercase;
}
.sidebar-user-info { flex: 1; min-width: 0; }
.sidebar-user-name {
  font-size: 13px; font-weight: 600; color: var(--text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sidebar-user-role {
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.8px;
  font-weight: 600;
}
.sidebar-user-role.role-admin { color: var(--accent-red); }
.sidebar-user-role.role-manager { color: var(--accent-amber); }
.sidebar-user-role.role-viewer { color: var(--accent-blue); }
.sidebar-logout-btn {
  width: 28px; height: 28px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border); border-radius: 6px;
  color: var(--text-muted); cursor: pointer; transition: all 0.2s; flex-shrink: 0;
}
.sidebar-logout-btn:hover { color: var(--state-error); border-color: var(--state-error); background: var(--state-error-soft); }
.sidebar-login-btn {
  display: flex; align-items: center; gap: 8px; width: 100%;
  padding: 10px 12px; font-size: 13px; font-weight: 600; font-family: inherit;
  color: var(--accent-blue); background: rgba(78, 143, 247, 0.1);
  border: 1px solid rgba(78, 143, 247, 0.25); border-radius: 8px;
  cursor: pointer; transition: all 0.2s; margin-bottom: 8px;
}
.sidebar-login-btn:hover { background: rgba(78, 143, 247, 0.18); border-color: var(--accent-blue); }

/* === Auth Modal === */
.auth-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.6); backdrop-filter: blur(4px);
  z-index: 2000; opacity: 0; visibility: hidden; transition: opacity 0.3s, visibility 0.3s;
}
.auth-overlay.open { opacity: 1; visibility: visible; }
.auth-modal {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0.95);
  width: 400px; max-width: 92vw; max-height: 90vh; overflow-y: auto;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 16px; z-index: 2001; padding: 36px 32px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.5);
  opacity: 0; visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s, transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.auth-modal.open { opacity: 1; visibility: visible; transform: translate(-50%, -50%) scale(1); }
.auth-modal-close {
  position: absolute; top: 12px; right: 12px; width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); font-size: 18px; cursor: pointer; transition: all 0.2s;
}
.auth-modal-close:hover { color: var(--text-primary); border-color: var(--border-light); background: var(--bg-card); }
.auth-modal-brand {
  display: flex; align-items: center; justify-content: center; margin-bottom: 28px;
  padding: 16px 0 8px;
}
.auth-brand-logo {
  height: 160px; width: auto; max-width: 100%; object-fit: contain;
}
.auth-title { font-size: 22px; font-weight: 700; color: var(--text-primary); margin-bottom: 4px; }
.auth-subtitle { font-size: 13px; color: var(--text-muted-large); margin-bottom: 20px; }
.auth-field { margin-bottom: 16px; }
.auth-field label {
  display: block; font-size: 12px; font-weight: 600; color: var(--text-secondary);
  margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.5px;
}
.auth-field input, .auth-field select {
  width: 100%; padding: 10px 14px; font-size: 14px; font-family: inherit;
  background: var(--bg-inset); border: 1px solid var(--border);
  border-radius: 8px; color: var(--text-primary); transition: border-color 0.2s;
  outline: none;
}
.auth-field input:focus, .auth-field select:focus { border-color: var(--accent-blue); }
.auth-field input::placeholder { color: var(--text-muted); }
.password-input-wrap { position: relative; display: block; }
.password-input-wrap input { padding-right: 42px; width: 100%; box-sizing: border-box; }
.pw-toggle-btn {
  position: absolute; right: 10px; top: 0; bottom: 0; margin: auto 0;
  background: none; border: none; cursor: pointer; padding: 0;
  color: var(--text-muted);
  width: 24px; height: 24px;
  -webkit-appearance: none; appearance: none;
}
.pw-toggle-btn:hover { color: var(--text-primary); }
.pw-toggle-btn svg { width: 20px; height: 20px; vertical-align: middle; }
.auth-field select { cursor: pointer; }
.auth-field select option { background: var(--bg-secondary); color: var(--text-primary); }
.auth-btn {
  width: 100%; padding: 11px; font-size: 14px; font-weight: 600; font-family: inherit;
  border-radius: 8px; cursor: pointer; transition: all 0.2s; border: none;
}
.auth-btn-primary {
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  color: #fff;
}
.auth-btn-primary:hover { opacity: 0.9; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(78, 143, 247, 0.3); }
.auth-btn-ghost {
  background: transparent; color: var(--text-secondary);
  border: 1px solid var(--border);
}
.auth-btn-ghost:hover { color: var(--text-primary); border-color: var(--border-light); background: var(--bg-card); }
.auth-divider {
  display: flex; align-items: center; gap: 12px; margin: 16px 0;
  font-size: 11px; color: var(--text-muted); text-transform: uppercase;
}
.auth-divider::before, .auth-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}
.auth-link {
  display: block; width: 100%; text-align: center; margin-top: 12px;
  font-size: 12px; color: var(--text-muted); background: none; border: none;
  cursor: pointer; font-family: inherit; transition: color 0.2s;
}
.auth-link:hover { color: var(--accent-blue); }
.auth-error {
  display: none; padding: 10px 14px; margin-bottom: 14px;
  background: var(--state-error-soft); border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: 8px; font-size: 13px; color: var(--state-error);
}
.auth-error.show { display: block; }
.auth-success {
  display: none; padding: 10px 14px; margin-bottom: 14px;
  background: rgba(52, 211, 153, 0.1); border: 1px solid rgba(52, 211, 153, 0.3);
  border-radius: 8px; font-size: 13px; color: var(--accent-green);
}
.auth-success.show { display: block; }

/* === Admin Panel === */
/* === Full-Screen Panel Overlays === */
.fullscreen-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: var(--bg-primary); z-index: 4000;
  opacity: 0; visibility: hidden; transition: opacity 0.3s ease;
  overflow-y: auto;
}
.fullscreen-overlay.open { opacity: 1; visibility: visible; }
.fullscreen-overlay.fade-out { opacity: 0; transition: opacity 0.4s ease; }
body.panel-open { overflow: hidden; }

/* Panel header bar (shared) */
.panel-topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 32px; background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
}
.panel-topbar-title {
  font-size: 18px; font-weight: 700; color: var(--text-primary);
  display: flex; align-items: center; gap: 10px;
}
.panel-topbar-title svg { opacity: 0.6; }
.panel-close-btn {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); font-size: 20px; cursor: pointer; transition: all 0.2s;
  font-family: inherit;
}
.panel-close-btn:hover { color: var(--text-primary); border-color: var(--border-light); background: var(--bg-card); }
.member-remove-btn {
  width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); font-size: 16px; line-height: 1; cursor: pointer; transition: all 0.2s;
  font-family: inherit; padding: 0;
}
.member-remove-btn:hover { color: var(--text-primary); border-color: var(--border-light); background: var(--bg-card); }
.panel-refresh-btn {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); cursor: pointer; transition: all 0.2s;
}
.panel-refresh-btn:hover { color: var(--accent-blue); border-color: var(--accent-blue); background: var(--bg-card); }
.panel-refresh-btn.spinning svg { animation: syncSpin 0.8s linear infinite; }
.panel-topbar-actions { display: flex; align-items: center; gap: 8px; }

/* === Election Switcher Dynamic === */
.election-switcher-divider { height: 1px; background: var(--border); margin: 4px 8px; }
.election-switcher-option.coming-soon { opacity: 0.6; }
.election-switcher-option.coming-soon:hover { opacity: 0.85; }
.coming-soon-badge { font-size: 9px; text-transform: uppercase; letter-spacing: 0.5px; background: var(--accent-amber-soft); color: var(--accent-amber, #fbbf24); padding: 2px 6px; border-radius: 4px; margin-left: auto; font-weight: 600; }

/* === Coming Soon Overlay === */
.coming-soon-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.7); backdrop-filter: blur(8px); z-index: 2000; display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.3s ease; }
.coming-soon-overlay.visible { opacity: 1; }
.coming-soon-content { background: var(--bg-card); border: 1px solid var(--border); border-radius: 16px; padding: 40px; max-width: 420px; width: 90%; text-align: center; }
.coming-soon-icon { margin-bottom: 16px; color: var(--accent-blue); }
.coming-soon-icon svg { width: 48px; height: 48px; }
.coming-soon-content h2 { font-size: 22px; font-weight: 700; color: var(--text-primary); margin: 0 0 8px; }
.coming-soon-tag { display: inline-block; font-size: 11px; text-transform: uppercase; letter-spacing: 1px; background: var(--accent-amber-soft); color: var(--accent-amber, #fbbf24); padding: 4px 12px; border-radius: 6px; font-weight: 700; margin-bottom: 16px; }
.coming-soon-content p { color: var(--text-secondary); font-size: 14px; line-height: 1.6; margin: 0 0 20px; }
.coming-soon-features { display: flex; flex-direction: column; gap: 8px; text-align: left; margin-bottom: 24px; }
.coming-soon-feature { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text-secondary); }
.coming-soon-feature svg { color: var(--accent-green, #34d399); flex-shrink: 0; }
.coming-soon-dismiss { background: var(--accent-blue); color: white; border: none; padding: 10px 32px; border-radius: 8px; font-size: 14px; font-weight: 600; cursor: pointer; transition: background 0.2s; }
.coming-soon-dismiss:hover { background: #3d7ce6; }

/* === Platform Config (Super Admin) === */
.config-toggle { position: relative; display: inline-block; width: 36px; height: 20px; cursor: pointer; }
.config-toggle input { opacity: 0; width: 0; height: 0; }
.config-toggle-slider { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: var(--border); border-radius: 20px; transition: background 0.2s; }
.config-toggle-slider::before { content: ''; position: absolute; height: 16px; width: 16px; left: 2px; bottom: 2px; background: white; border-radius: 50%; transition: transform 0.2s; }
.config-toggle input:checked + .config-toggle-slider { background: var(--accent-blue); }
.config-toggle input:checked + .config-toggle-slider::before { transform: translateX(16px); }
.config-flags-grid { display: flex; flex-direction: column; gap: 8px; }
.config-flag-row { display: flex; align-items: center; justify-content: space-between; padding: 8px 12px; border-radius: 8px; background: var(--subtle-hover-bg); border: 1px solid var(--border); font-size: 13px; }
.config-flag-row span { color: var(--text-secondary); }
.role-super_admin { color: var(--accent-gold, #f5a623); border-color: var(--accent-gold, #f5a623); }

/* === Data Collection Panel === */
.data-collection-summary { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 12px; }
.data-stat { display: flex; flex-direction: column; align-items: center; padding: 12px 20px; border-radius: 8px; background: var(--subtle-hover-bg); border: 1px solid var(--border); min-width: 80px; }
.data-stat-num { font-size: 24px; font-weight: 700; color: var(--text-primary); }
.data-stat-label { font-size: 11px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 2px; }
.data-collection-actions { display: flex; gap: 8px; margin-bottom: 8px; }
.btn-sm { padding: 6px 14px; font-size: 12px; border-radius: 6px; border: none; cursor: pointer; font-weight: 500; transition: all 0.2s; }
.btn-primary { background: var(--accent); color: #fff; }
.btn-primary:hover { filter: brightness(1.1); }
.btn-xs { padding: 3px 10px; font-size: 11px; border-radius: 4px; cursor: pointer; font-weight: 500; transition: all 0.2s; }
.btn-outline { background: transparent; border: 1px solid var(--border); color: var(--text-secondary); }
.btn-outline:hover { border-color: var(--accent); color: var(--accent); }
.text-success { color: var(--accent-green); }
.text-danger { color: #f87171; }
.text-warning { color: var(--accent-amber); }
.schedule-select { background: var(--card-bg, #1a1a2e); color: var(--text-primary); border: 1px solid var(--border); border-radius: 4px; padding: 3px 6px; font-size: 12px; cursor: pointer; }
.schedule-select:focus { outline: none; border-color: var(--accent); }
.review-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 20px; height: 20px; padding: 0 6px; border-radius: 10px; background: #f87171; color: #fff; font-size: 11px; font-weight: 700; margin-left: 8px; vertical-align: middle; }
.review-filter-tabs { display: flex; gap: 4px; flex-wrap: wrap; }
.review-tab { padding: 5px 12px; font-size: 12px; border-radius: 6px; border: 1px solid var(--border); background: transparent; color: var(--text-muted); cursor: pointer; transition: all 0.2s; }
.review-tab:hover { border-color: var(--accent); color: var(--text-secondary); }
.review-tab-active { background: var(--accent); color: #fff; border-color: var(--accent); }
.review-row:hover { background: var(--subtle-hover-bg); }
.review-row-expanded { background: var(--subtle-hover-bg); }
.review-detail-content { padding: 12px 16px; background: rgba(0,0,0,0.15); border-radius: 8px; margin: 4px 0; }
.review-meta { display: flex; gap: 16px; flex-wrap: wrap; font-size: 12px; color: var(--text-muted-large); margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--border); }
.review-data-table { width: 100%; font-size: 13px; border-collapse: collapse; }
.review-data-table td, .review-data-table th { padding: 5px 10px; border-bottom: 1px solid rgba(255,255,255,0.05); text-align: left; }
.review-data-label { color: var(--text-muted); font-weight: 500; white-space: nowrap; width: 120px; }
.info-tooltip { cursor: help; color: var(--text-muted); font-size: 14px; position: relative; }
.info-tooltip:hover { color: var(--accent); }
.info-tooltip[title] { position: relative; }
.info-tooltip::after { content: attr(title); position: absolute; bottom: 120%; left: 50%; transform: translateX(-50%); background: var(--card-bg, #1a1a2e); border: 1px solid var(--border); color: var(--text-secondary); padding: 8px 12px; border-radius: 6px; font-size: 12px; white-space: pre-line; width: 280px; pointer-events: none; opacity: 0; transition: opacity 0.2s; z-index: 100; line-height: 1.5; }
.info-tooltip:hover::after { opacity: 1; }
.audit-data-pre { font-size: 11px; overflow-x: auto; max-height: 200px; padding: 8px; background: rgba(0,0,0,0.2); border-radius: 6px; border: 1px solid rgba(255,255,255,0.05); line-height: 1.4; white-space: pre-wrap; word-break: break-word; }

/* === Billing Panel === */
.billing-help-btn {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); cursor: pointer; transition: all 0.2s;
}
.billing-help-btn:hover { color: var(--accent-blue); border-color: var(--accent-blue); background: var(--accent-blue-soft); }

.billing-plan-badge {
  display: inline-block; padding: 4px 12px; border-radius: 20px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase;
}
.billing-plan-badge.free { background: var(--accent-green-soft); color: var(--accent-green); }
.billing-plan-badge.trial { background: var(--accent-amber-soft); color: var(--accent-amber); }
.billing-plan-badge.paid { background: rgba(90, 158, 255, 0.15); color: var(--accent-blue); }

.billing-free-state {
  text-align: center; padding: 60px 24px;
}
.billing-free-state svg { margin-bottom: 16px; opacity: 0.3; }
.billing-free-state h3 { font-size: 20px; margin-bottom: 8px; }
.billing-free-state p { color: var(--text-muted-large); font-size: 14px; line-height: 1.6; max-width: 400px; margin: 0 auto; }

.billing-invoice-table {
  width: 100%; border-collapse: separate; border-spacing: 0;
  font-size: 13px; margin-top: 16px;
}
.billing-invoice-table th {
  text-align: left; font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--text-muted); padding: 10px 14px;
  border-bottom: 1px solid var(--border);
}
.billing-invoice-table td {
  padding: 14px; border-bottom: 1px solid var(--border-dark, rgba(26, 56, 96, 0.3));
  color: var(--text-secondary);
}
.billing-invoice-table tr:hover td { background: rgba(90, 158, 255, 0.04); }
.billing-invoice-table .invoice-amount { font-weight: 600; color: var(--text-primary); }
.billing-invoice-table .invoice-download {
  color: var(--accent-blue); text-decoration: none; font-weight: 600; font-size: 12px;
  display: inline-flex; align-items: center; gap: 4px;
}
.billing-invoice-table .invoice-download:hover { text-decoration: underline; }

/* Help drawer */
.billing-help-drawer {
  display: none; position: fixed; right: 0; top: 0; bottom: 0; width: 380px;
  background: var(--bg-secondary); border-left: 1px solid var(--border);
  z-index: 1002; overflow-y: auto; box-shadow: -4px 0 24px rgba(0,0,0,0.3);
  transition: transform 0.3s ease;
}
.billing-help-drawer.open { display: block; }
.billing-help-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
}
.billing-help-header h3 { font-size: 16px; font-weight: 600; margin: 0; }
.billing-help-close {
  width: 32px; height: 32px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); font-size: 18px; cursor: pointer; font-family: inherit;
}
.billing-help-close:hover { color: var(--text-primary); }
.billing-help-options { padding: 16px 20px; }
.billing-help-option {
  display: flex; align-items: flex-start; gap: 14px; padding: 16px;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px;
  cursor: pointer; width: 100%; text-align: left; color: var(--text-primary);
  transition: all 0.2s; font-family: inherit;
}
.billing-help-option:hover { border-color: var(--accent-blue); background: rgba(90, 158, 255, 0.06); }
.billing-help-option svg { flex-shrink: 0; margin-top: 2px; color: var(--accent-blue); }
.billing-help-option strong { display: block; font-size: 14px; margin-bottom: 2px; }
.billing-help-option span { font-size: 12px; color: var(--text-muted-large); }
.billing-help-divider { height: 1px; background: var(--border); margin: 16px 0; }
.billing-help-ticket h4 { font-size: 15px; font-weight: 600; margin-bottom: 4px; }
.billing-help-ticket p { font-size: 13px; color: var(--text-muted-large); margin-bottom: 16px; }
.billing-help-ticket textarea {
  width: 100%; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 10px 12px; color: var(--text-primary);
  font-family: inherit; font-size: 13px; resize: vertical;
}
.billing-help-ticket select {
  width: 100%; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 10px 12px; color: var(--text-primary);
  font-family: inherit; font-size: 13px;
}

@media (max-width: 500px) {
  .billing-help-drawer { width: 100%; }
  .billing-invoice-table { font-size: 11px; }
  .billing-invoice-table th, .billing-invoice-table td { padding: 10px 8px; }
  .billing-invoice-table .invoice-download { font-size: 10px; }
}
@media (max-width: 380px) {
  .billing-help-drawer { width: 100%; }
}

/* Panel body with constrained width */
.panel-body { max-width: 1100px; margin: 0 auto; padding: 28px 32px 48px; }
.panel-body-narrow { max-width: 780px; }

/* Panel section cards */
.panel-section {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 14px; padding: 24px 28px; margin-bottom: 20px;
}
.panel-section-title {
  font-size: 14px; font-weight: 700; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.5px;
  margin: 0 0 20px; padding-bottom: 12px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 8px;
}
.panel-section-title svg { opacity: 0.5; }

/* === Admin Panel — Full-Screen === */
.admin-overlay, .profile-overlay { /* legacy compat — now unused overlays */
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  z-index: -1; opacity: 0; visibility: hidden;
}

/* Admin tabs — horizontal pill style */
.admin-tabs {
  display: flex; gap: 6px; margin-bottom: 24px;
}
.admin-tab {
  padding: 10px 20px; font-size: 13px; font-weight: 600; font-family: inherit;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); cursor: pointer; transition: all 0.2s;
}
.admin-tab:hover { color: var(--text-secondary); border-color: var(--border-light); }
.admin-tab.active { background: var(--accent-blue); border-color: var(--accent-blue); color: #fff; }
.admin-tab-content { display: none; }
.admin-tab-content.active { display: block; }

/* Admin User Table */
.admin-user-table {
  width: 100%; border-collapse: separate; border-spacing: 0;
}
.admin-user-table th {
  text-align: left; padding: 10px 14px; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted);
  border-bottom: 1px solid var(--border); white-space: nowrap;
}
.admin-user-table td {
  padding: 14px; border-bottom: 1px solid rgba(30, 63, 106, 0.4);
  font-size: 13px; color: var(--text-primary); vertical-align: middle;
}
.admin-user-table tr:hover td { background: rgba(255, 255, 255, 0.02); }
.admin-user-table tr:last-child td { border-bottom: none; }

/* Admin user cell layout */
.admin-user-cell {
  display: flex; align-items: center; gap: 12px;
}
.admin-user-cell-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; color: #fff; flex-shrink: 0;
  text-transform: uppercase;
}
.admin-user-cell-name { font-weight: 600; }
.admin-user-cell-email { font-size: 12px; color: var(--text-muted-large); }

/* Shared badge styles */
.admin-role-badge {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
  padding: 3px 8px; border-radius: 4px; display: inline-block;
}
.admin-role-badge.role-admin { background: rgba(242, 92, 92, 0.15); color: var(--accent-red); }
.admin-role-badge.role-manager { background: var(--accent-amber-soft); color: var(--accent-amber); }
.admin-role-badge.role-viewer { background: rgba(78, 143, 247, 0.15); color: var(--accent-blue); }
.admin-status-badge {
  font-size: 10px; font-weight: 600; padding: 3px 8px; border-radius: 4px; display: inline-block;
}
.admin-status-badge.status-active { background: var(--accent-green-soft); color: var(--accent-green); }
.admin-status-badge.status-invited { background: var(--accent-amber-soft); color: var(--accent-amber); }
.admin-status-badge.status-suspended { background: rgba(239, 68, 68, 0.15); color: var(--state-error); }
.admin-status-badge.status-expired { background: rgba(242, 92, 92, 0.1); color: var(--text-muted); }
.admin-status-badge.status-trialing { background: rgba(78, 143, 247, 0.15); color: var(--accent-blue); }

/* Action buttons in table */
.admin-user-actions { display: flex; gap: 4px; }
.admin-action-btn {
  width: 30px; height: 30px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid var(--border); border-radius: 6px;
  color: var(--text-muted); cursor: pointer; transition: all 0.2s; font-size: 12px;
}
.admin-action-btn:hover { color: var(--text-primary); border-color: var(--border-light); background: var(--bg-card-hover); }
.admin-action-btn.danger:hover { color: var(--state-error); border-color: var(--state-error); background: var(--state-error-soft); }
.admin-google-badge, .admin-2fa-badge {
  font-size: 10px; font-weight: 700; padding: 2px 6px; border-radius: 3px;
  background: rgba(78, 143, 247, 0.1); color: var(--accent-blue);
}

/* Role dropdown in table */
.admin-role-select {
  font-size: 11px; padding: 4px 8px; background: var(--bg-inset);
  border: 1px solid var(--border); border-radius: 4px;
  color: var(--text-primary); font-family: inherit; cursor: pointer;
}

/* Admin stats bar */
.admin-stats-bar {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 24px;
}
.admin-stat-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px;
  padding: 16px 18px; text-align: center;
}
.admin-stat-value { font-size: 28px; font-weight: 700; color: var(--text-primary); line-height: 1.1; }
.admin-stat-label { font-size: 12px; font-weight: 600; color: var(--text-muted-large); margin-top: 4px; }

/* Invite form in full-screen */
.admin-invite-form {
  max-width: 480px;
}

/* === Profile Panel — Full-Screen === */
.profile-content { padding: 0; }
.profile-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
.profile-avatar-large {
  width: 80px; height: 80px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; font-weight: 700; color: #fff;
  text-transform: uppercase; flex-shrink: 0;
}
.profile-identity-row {
  display: flex; align-items: center; gap: 20px; margin-bottom: 20px;
}
.profile-identity-info { flex: 1; }
.profile-divider { height: 1px; background: var(--border); margin: 24px 0; }
.profile-section-title { font-size: 15px; font-weight: 600; color: var(--text-primary); margin-bottom: 16px; }

@media (max-width: 768px) {
  .panel-topbar { padding: 14px 20px; }
  .panel-body { padding: 20px 16px 40px; }
  .profile-grid { grid-template-columns: 1fr; }
  .admin-stats-bar { grid-template-columns: repeat(2, 1fr); }
  .admin-user-table th:nth-child(4),
  .admin-user-table td:nth-child(4) { display: none; }
}

/* Toast notification */
.auth-toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px);
  padding: 12px 24px; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; font-size: 13px; font-weight: 500; color: var(--text-primary);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3); z-index: 3000;
  opacity: 0; visibility: hidden; transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.auth-toast.show { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }

/* === Analytics Dashboard === */
.analytics-toolbar {
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 24px;
}
.analytics-period-btns { display: flex; gap: 4px; }
.analytics-period-btn {
  padding: 6px 14px; font-size: 12px; font-weight: 600; font-family: inherit;
  background: transparent; border: 1px solid var(--border); border-radius: 6px;
  color: var(--text-muted); cursor: pointer; transition: all 0.2s;
}
.analytics-period-btn:hover { border-color: var(--border-light); color: var(--text-secondary); }
.analytics-period-btn.active { background: var(--accent-blue); border-color: var(--accent-blue); color: #fff; }
.analytics-realtime {
  display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-muted);
}
.analytics-realtime-dot {
  width: 8px; height: 8px; border-radius: 50%; background: #22c55e;
  animation: analyticsPulse 2s infinite;
}
@keyframes analyticsPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }
.analytics-content { padding: 0; }
.analytics-loading { text-align: center; padding: 40px; color: var(--text-muted-large); font-size: 14px; }
.analytics-kpi-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 16px; }
.analytics-kpi {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px;
  padding: 16px; text-align: center;
}
.analytics-kpi-value { font-size: 28px; font-weight: 700; color: var(--text-primary); line-height: 1.1; }
.analytics-kpi-label { font-size: 12px; font-weight: 600; color: var(--text-secondary); margin-top: 4px; }
.analytics-kpi-sub { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.analytics-charts-row { display: grid; grid-template-columns: 1.6fr 1fr; gap: 12px; margin-bottom: 12px; }
.analytics-chart-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px;
  padding: 16px; overflow: hidden;
}
.analytics-chart-card.analytics-chart-full { grid-column: 1 / -1; }
.analytics-chart-title { font-size: 13px; font-weight: 600; color: var(--text-secondary); margin-bottom: 12px; }
.analytics-chart-wrap { position: relative; height: 180px; width: 100%; }
.analytics-list { display: flex; flex-direction: column; gap: 6px; max-height: 240px; overflow-y: auto; }
.analytics-list-item {
  position: relative; display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px; border-radius: 6px; overflow: hidden;
}
.analytics-list-bar {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: rgba(78, 143, 247, 0.12); border-radius: 6px; z-index: 0;
}
.analytics-list-bar-green { background: rgba(34, 197, 94, 0.12); }
.analytics-list-label { position: relative; z-index: 1; font-size: 12px; color: var(--text-primary); font-weight: 500; }
.analytics-list-value { position: relative; z-index: 1; font-size: 12px; color: var(--text-muted); font-weight: 600; }
.analytics-user-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 8px; transition: background 0.2s;
}
.analytics-user-item:hover { background: var(--subtle-hover-bg); }
.analytics-user-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; color: #fff; flex-shrink: 0;
}
.analytics-user-info { flex: 1; min-width: 0; }
.analytics-user-name { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.analytics-user-detail { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.analytics-activity-feed { display: flex; flex-direction: column; gap: 4px; max-height: 200px; overflow-y: auto; }
.analytics-feed-item {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px; font-size: 12px; border-radius: 6px;
}
.analytics-feed-item:hover { background: var(--subtle-hover-bg); }
.analytics-feed-user { font-weight: 600; color: var(--accent-blue); }
.analytics-feed-event { color: var(--text-primary); }
.analytics-feed-detail { color: var(--text-muted); }
.analytics-feed-time { margin-left: auto; color: var(--text-muted); font-size: 11px; white-space: nowrap; }
.analytics-feature-bars { display: flex; flex-direction: column; gap: 6px; }
@media (max-width: 600px) {
  .analytics-kpi-row { grid-template-columns: repeat(2, 1fr); }
  .analytics-charts-row { grid-template-columns: 1fr; }
  .analytics-kpi-value { font-size: 22px; }
}

/* === Paywall & Trial Banner === */
.paywall-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0, 0, 0, 0.85); backdrop-filter: blur(8px);
  z-index: 5000; display: flex; align-items: center; justify-content: center;
}
.paywall-modal {
  width: 600px; max-width: 94vw; max-height: 90vh; overflow-y: auto;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: 16px; box-shadow: 0 24px 80px rgba(0, 0, 0, 0.6);
}
.paywall-header {
  padding: 28px 32px 16px; text-align: center;
  border-bottom: 1px solid var(--border);
}
.paywall-logo { height: 48px; width: auto; }
.paywall-body { padding: 28px 32px 32px; }
.paywall-body h2 { font-size: 22px; font-weight: 700; color: var(--text-primary); margin: 0 0 8px; text-align: center; }
.paywall-body p { font-size: 14px; color: var(--text-secondary); margin: 0 0 24px; text-align: center; }
.paywall-plans { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 24px; }
.paywall-plan {
  position: relative; padding: 24px 20px; background: var(--bg-card);
  border: 2px solid var(--border); border-radius: 12px; text-align: center;
  transition: border-color 0.2s;
}
.paywall-plan:hover { border-color: var(--accent-blue); }
.paywall-plan-badge {
  position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
  background: var(--accent-blue); color: #fff; font-size: 11px; font-weight: 700;
  padding: 3px 12px; border-radius: 10px; white-space: nowrap;
}
.paywall-plan-price { font-size: 36px; font-weight: 800; color: var(--text-primary); line-height: 1; margin-top: 8px; }
.paywall-plan-period { font-size: 13px; color: var(--text-muted-large); margin: 4px 0 12px; }
.paywall-plan-desc { font-size: 12px; color: var(--text-secondary); margin-bottom: 16px; line-height: 1.5; }
.paywall-plan-btn {
  width: 100%; padding: 12px; font-size: 14px; font-weight: 600; font-family: inherit;
  background: var(--accent-blue); color: #fff; border: none; border-radius: 8px;
  cursor: pointer; transition: all 0.2s;
}
.paywall-plan-btn:hover { background: #3d7de6; }
.paywall-plan-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.paywall-plan-btn-outline {
  background: transparent; border: 2px solid var(--accent-blue); color: var(--accent-blue);
}
.paywall-plan-btn-outline:hover { background: rgba(78, 143, 247, 0.1); }
.paywall-features {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  padding-top: 20px; border-top: 1px solid var(--border);
}
.paywall-feature { font-size: 13px; color: var(--text-secondary); padding: 4px 0; }
.paywall-header { position: relative; }
.paywall-close-btn {
  position: absolute; top: 16px; right: 16px;
  background: transparent; border: 1px solid var(--border); color: var(--text-secondary);
  font-size: 22px; line-height: 1; width: 36px; height: 36px;
  border-radius: 8px; cursor: pointer; transition: all 0.2s;
  display: flex; align-items: center; justify-content: center; font-family: inherit;
}
.paywall-close-btn:hover { background: var(--bg-card); color: var(--text-primary); border-color: var(--border-light); }
.paywall-continue-btn {
  display: block; width: 100%; margin-top: 20px; padding: 12px;
  background: transparent; border: none; color: var(--text-muted);
  font-size: 14px; font-family: inherit; cursor: pointer; transition: color 0.2s;
  text-align: center;
}
.paywall-continue-btn:hover { color: var(--text-primary); }

/* Welcome Card (post-payment) */
.welcome-overlay { animation: welcomeFadeIn 0.4s ease; }
.welcome-overlay.welcome-fade-out { animation: welcomeFadeOut 0.4s ease forwards; }
@keyframes welcomeFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes welcomeFadeOut { from { opacity: 1; } to { opacity: 0; } }
.welcome-card {
  width: 480px; max-width: 92vw; background: var(--bg-secondary);
  border: 1px solid var(--border); border-radius: 16px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.6); padding: 48px 40px;
  text-align: center; animation: welcomeSlideUp 0.5s ease;
}
@keyframes welcomeSlideUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
.welcome-icon {
  width: 72px; height: 72px; margin: 0 auto 20px;
  background: linear-gradient(135deg, var(--accent-green), #2ab885);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 36px; color: #fff; box-shadow: 0 4px 24px rgba(52, 211, 153, 0.3);
}
.welcome-card h2 { font-size: 24px; font-weight: 700; color: var(--text-primary); margin: 0 0 12px; }
.welcome-card p { font-size: 14px; color: var(--text-secondary); margin: 0 0 28px; line-height: 1.6; }
.welcome-features {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
  margin-bottom: 32px;
}
.welcome-feature-item {
  padding: 10px 12px; font-size: 13px; font-weight: 500; color: var(--text-primary);
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px;
}
.welcome-btn {
  width: 100%; padding: 14px; font-size: 15px; font-weight: 600; font-family: inherit;
  background: linear-gradient(135deg, var(--accent-blue), #3d7de6);
  color: #fff; border: none; border-radius: 10px; cursor: pointer;
  transition: all 0.2s; box-shadow: 0 4px 16px rgba(78, 143, 247, 0.25);
}
.welcome-btn:hover { transform: translateY(-1px); box-shadow: 0 6px 24px rgba(78, 143, 247, 0.35); }

/* Trial Banner */
.trial-banner {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1500;
  background: linear-gradient(90deg, #1a3760, #2a5298); padding: 0;
  transition: transform 0.3s;
}
.trial-banner-hidden { transform: translateY(-100%); }
body.has-trial-banner .dashboard-header { top: 40px; }
body.has-trial-banner .sidebar { top: 40px; height: calc(100vh - 40px); }
.main-content { max-width: 100%; overflow-x: hidden; }
body.has-trial-banner .main-content { padding-top: 40px; }
.trial-banner-warning { background: linear-gradient(90deg, #92400e, #b45309); }
.trial-banner-urgent { background: linear-gradient(90deg, #991b1b, #dc2626); }
.trial-banner-content {
  display: flex; align-items: center; justify-content: center; gap: 16px;
  padding: 10px 20px; max-width: 1200px; margin: 0 auto;
}
.trial-banner-text { font-size: 13px; color: #fff; }
.trial-banner-btn {
  padding: 6px 16px; font-size: 12px; font-weight: 600; font-family: inherit;
  background: #fff; color: #1a3760; border: none; border-radius: 6px;
  cursor: pointer; white-space: nowrap; transition: all 0.2s;
}
.trial-banner-btn:hover { background: #e5e7eb; }
.trial-banner-close {
  background: none; border: none; color: rgba(255,255,255,0.7); font-size: 18px;
  cursor: pointer; padding: 0 4px; line-height: 1;
}
.trial-banner-close:hover { color: #fff; }

@media (max-width: 600px) {
  .paywall-plans { grid-template-columns: 1fr; }
  .paywall-features { grid-template-columns: 1fr; }
  .trial-banner-content { flex-wrap: wrap; justify-content: center; gap: 8px; }
}

/* Google Sign-In Button */
.auth-btn-google {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  background: #fff; color: #3c4043; border: 1px solid #dadce0;
  font-weight: 500;
}
.auth-btn-google:hover { background: #f8f9fa; border-color: #c6c9cc; }
.auth-btn-sm { padding: 8px 14px; font-size: 12px; width: auto; display: inline-flex; }
.auth-btn-danger { color: var(--state-error); border-color: rgba(239, 68, 68, 0.3); }
.auth-btn-danger:hover { background: var(--state-error-soft); border-color: var(--state-error); color: var(--state-error); }
.auth-invite-note {
  text-align: center; font-size: 11px; color: var(--text-muted); margin-top: 16px;
  padding-top: 12px; border-top: 1px solid var(--border);
}
.auth-legal-links {
  text-align: center; font-size: 11px; color: var(--text-muted); margin-top: 8px;
}
.auth-legal-links a { color: var(--text-muted); text-decoration: none; }
.auth-legal-links a:hover { color: var(--accent-blue); text-decoration: underline; }
.admin-plan-badge {
  display: inline-block; font-size: 10px; font-weight: 600; text-transform: uppercase;
  padding: 3px 8px; border-radius: 6px; letter-spacing: 0.5px;
  background: rgba(78, 143, 247, 0.15); color: var(--accent-blue); border: 1px solid rgba(78, 143, 247, 0.3);
}
.auth-checkbox-label {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text-secondary); cursor: pointer;
}
.auth-checkbox-label input[type="checkbox"] {
  width: 16px; height: 16px; accent-color: var(--accent-green); cursor: pointer;
}
.auth-code-input {
  font-size: 24px !important; letter-spacing: 8px; text-align: center;
  font-family: 'SF Mono', 'Fira Code', monospace;
}

/* Password Strength Indicator */
.pw-strength {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
}
.pw-strength-track {
  flex: 1; height: 4px; background: var(--bg-inset);
  border-radius: 2px; overflow: hidden;
}
.pw-strength-bar {
  height: 100%; width: 0; border-radius: 2px;
  transition: width 0.3s ease, background 0.3s ease;
}
.pw-strength-bar.pw-weak { background: var(--state-error); }
.pw-strength-bar.pw-medium { background: var(--accent-amber); }
.pw-strength-bar.pw-strong { background: var(--accent-green); }
.pw-strength-label {
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px;
  min-width: 52px; text-align: right;
}
.pw-strength-label.pw-weak { color: var(--state-error); }
.pw-strength-label.pw-medium { color: var(--accent-amber); }
.pw-strength-label.pw-strong { color: var(--accent-green); }
.pw-rules { margin-bottom: 16px; }
.pw-rule {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; color: var(--text-muted); padding: 3px 0;
  transition: color 0.2s;
}
.pw-rule.met { color: var(--accent-green); }
.pw-rule svg { flex-shrink: 0; }

/* Profile Image Section */
#profile-image-preview {
  width: 80px; height: 80px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; font-weight: 700; color: #fff;
  text-transform: uppercase; flex-shrink: 0;
  background-size: cover; background-position: center;
}

/* Google & 2FA Status */
.profile-linked-row {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
.profile-google-status, .profile-2fa-status {
  font-size: 12px; color: var(--text-muted-large); font-weight: 500;
}
.profile-google-status.linked, .profile-2fa-status.enabled {
  color: var(--accent-green);
}

/* 2FA Setup */
.profile-2fa-setup {
  margin-top: 14px; padding: 16px; background: var(--bg-inset);
  border: 1px solid var(--border); border-radius: 10px;
}
.profile-2fa-totp-info {
  font-size: 12px; color: var(--text-muted-large); padding: 10px 12px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; margin-bottom: 12px; line-height: 1.5;
  font-family: 'SF Mono', 'Fira Code', monospace; word-break: break-all;
}

/* Admin badges for Google & 2FA */
/* Auth Gate — blur dashboard when not logged in */
body.auth-locked .main-content,
body.auth-locked .dashboard-header,
body.auth-locked .claude-fab { filter: blur(8px); pointer-events: none; user-select: none; }
body.auth-locked .sidebar { pointer-events: none; opacity: 0.5; }
body.auth-locked .sidebar .sidebar-login-btn { pointer-events: auto; }

/* Account Setup (Invite) */
.setup-welcome-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px; margin-bottom: 20px;
  text-align: center;
}
.setup-welcome-card p { margin: 4px 0; font-size: 14px; color: var(--text-secondary); }
.setup-welcome-card strong { color: var(--text-primary); }
.setup-email-label { font-size: 12px !important; color: var(--text-muted) !important; margin-top: 8px !important; }
.setup-role-badge {
  display: inline-block; font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.5px; padding: 2px 8px; border-radius: 4px;
}
.setup-role-badge.role-admin { background: rgba(242, 92, 92, 0.15); color: var(--accent-red); }
.setup-role-badge.role-manager { background: var(--accent-amber-soft); color: var(--accent-amber); }
.setup-role-badge.role-viewer { background: rgba(78, 143, 247, 0.15); color: var(--accent-blue); }

/* Invite Email Preview */
.invite-email-preview {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; overflow: hidden; margin-bottom: 12px;
}
.invite-email-header {
  padding: 10px 14px; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.8px;
  color: var(--text-muted); border-bottom: 1px solid var(--border);
  background: var(--bg-inset);
}
.invite-email-body {
  padding: 14px; font-size: 12px; color: var(--text-secondary); line-height: 1.6;
}
.invite-link-box { margin-top: 8px; }
.invite-link-box label { font-size: 11px; color: var(--text-muted); display: block; margin-bottom: 4px; }
.invite-link-input {
  width: 100%; padding: 8px 10px; font-size: 11px;
  background: var(--bg-inset); border: 1px solid var(--border);
  border-radius: 6px; color: var(--accent-blue);
  font-family: 'SF Mono', 'Fira Code', monospace; cursor: text;
}

.admin-google-badge, .admin-2fa-badge {
  font-size: 9px; font-weight: 700; padding: 2px 5px;
  border-radius: 3px; text-transform: uppercase; letter-spacing: 0.3px;
}
.admin-google-badge { background: rgba(66, 133, 244, 0.15); color: #4285F4; }
.admin-2fa-badge { background: var(--accent-green-soft); color: var(--accent-green); }

/* Sidebar toggle in header */
.sidebar-toggle {
  width: 36px; height: 36px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); cursor: pointer; transition: all 0.2s;
}
.sidebar-toggle:hover { color: var(--text-primary); border-color: var(--accent-blue); background: var(--bg-card-hover); }

/* Desktop pinned sidebar */
@media (min-width: 1200px) {
  .sidebar { transform: translateX(0); }
  body.sidebar-collapsed .sidebar { transform: translateX(-100%); }
  .sidebar-overlay { display: none; }
  .main-content { margin-left: 240px; transition: margin-left 0.3s cubic-bezier(0.16,1,0.3,1); }
  body.sidebar-collapsed .main-content { margin-left: 0; }
  .dashboard-header { margin-left: 240px; transition: margin-left 0.3s cubic-bezier(0.16,1,0.3,1); }
  body.sidebar-collapsed .dashboard-header { margin-left: 0; }
}

/* === Main Grid === */
.dashboard-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
  padding: 24px 32px; max-width: 1480px; margin: 0 auto;
}

/* === Dashboard Section Headers === */
.dashboard-section-header {
  grid-column: 1 / -1;
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 8px 0 4px;
  margin-top: 12px;
  border-bottom: 1px solid var(--border);
}
.dashboard-section-header:first-child { margin-top: 0; }
.dashboard-section-header h2 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin: 0;
  white-space: nowrap;
}
.dashboard-section-subtitle {
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 400;
}
.overview-default-label {
  margin-left: auto;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  white-space: nowrap;
}
.overview-default-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 4px 14px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: rgba(15, 23, 42, 0.6);
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  white-space: nowrap;
}
.overview-default-btn:hover {
  color: var(--text-primary);
  background: rgba(90, 158, 255, 0.1);
  border-color: var(--accent-blue);
}
.overview-default-btn svg {
  flex-shrink: 0;
}

/* Year tab bar */
.year-tab-bar {
  display: flex;
  gap: 4px;
  margin-left: auto;
  background: rgba(15, 23, 42, 0.6);
  border-radius: 8px;
  padding: 3px;
  border: 1px solid var(--border);
}
.year-tab {
  padding: 5px 18px;
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.year-tab:hover {
  color: var(--text-primary);
  background: var(--accent-blue-soft);
}
.year-tab.active {
  background: var(--accent-blue);
  color: #fff;
  box-shadow: 0 2px 8px rgba(90, 158, 255, 0.3);
}

/* Year panels */
.year-panel {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.year-panel > .card-wide,
.year-panel > .card-house-race,
.year-panel > .card-confirmed-candidates {
  grid-column: 1 / -1;
}
.year-panel-animate .card {
  animation: yearPanelFadeIn 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes yearPanelFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .year-panel-animate .card { animation: none; }
}

/* === Cards === */
.card {
  background: linear-gradient(165deg, var(--bg-card) 0%, #0e2541 100%);
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 24px; box-shadow: var(--shadow); min-width: 0; overflow: hidden;
  transition: border-color 0.3s, box-shadow 0.3s, transform 0.7s cubic-bezier(0.16,1,0.3,1), opacity 0.7s cubic-bezier(0.16,1,0.3,1);
  opacity: 0;
}
.card:hover { border-color: var(--border-light); box-shadow: var(--shadow), var(--shadow-glow); background: linear-gradient(165deg, var(--bg-card-hover) 0%, var(--bg-card) 100%); }
.card[data-anim="slide-right"] { transform: translateX(-40px); }
.card[data-anim="slide-left"] { transform: translateX(40px); }
.card[data-anim="slide-up"] { transform: translateY(40px); }
.card[data-anim="scale"] { transform: scale(0.92); }
.card.anim-visible { opacity: 1 !important; transform: none !important; }

.card-header { margin-bottom: 16px; }
.card-header h2, .card-header h3 { font-size: 16px; font-weight: 600; color: var(--text-primary); }
.card-subtitle { font-size: 12px; color: var(--text-secondary); }
.card-header-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; }

/* === Chart Menu (... dropdown) === */
.chart-menu-wrap { position: relative; flex-shrink: 0; }
.chart-menu-btn {
  width: 32px; height: 28px; display: flex; align-items: center; justify-content: center;
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); cursor: pointer; font-size: 18px; font-weight: 700;
  letter-spacing: 2px; line-height: 1; transition: all 0.2s;
}
.chart-menu-btn:hover { color: var(--text-primary); border-color: var(--accent-blue); background: var(--bg-card-hover); }
.chart-menu {
  position: absolute; top: calc(100% + 6px); right: 0;
  background: var(--bg-card); border: 1px solid var(--border-light); border-radius: 10px;
  padding: 4px; min-width: 160px; z-index: 50;
  box-shadow: 0 8px 32px var(--overlay-strong);
  opacity: 0; visibility: hidden; transform: translateY(-8px) scale(0.95);
  transition: all 0.2s cubic-bezier(0.16,1,0.3,1);
}
.chart-menu.open { opacity: 1; visibility: visible; transform: translateY(0) scale(1); }
.chart-menu-item {
  display: block; width: 100%; padding: 8px 14px; border: none; background: none;
  color: var(--text-secondary); font-size: 13px; font-family: inherit;
  text-align: left; border-radius: 6px; cursor: pointer; transition: all 0.15s;
}
.chart-menu-item:hover { background: var(--bg-inset); color: var(--text-primary); }
.chart-menu-item.active { color: var(--accent-blue); background: var(--glow-blue); }

/* Map */
.card-map { grid-column: 1 / 2; position: relative; z-index: 1; }
.card-map .card-header { position: relative; }
.card-map .card-header { padding-right: 48px; }
.map-fullscreen-btn {
  position: absolute; top: 50%; right: 12px; transform: translateY(-50%);
  width: 32px; height: 32px; border-radius: 8px;
  background: var(--bg-card); border: 1px solid var(--border);
  color: var(--text-muted); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; z-index: 2;
}
.map-fullscreen-btn:hover { color: var(--text-primary); border-color: var(--accent-blue); background: var(--bg-card-hover); }
#map { height: 420px; border-radius: 10px; overflow: hidden; border: 1px solid var(--border); isolation: isolate; }
.map-legend { display: flex; gap: 16px; margin-top: 12px; font-size: 12px; color: var(--text-secondary); flex-wrap: wrap; }
.legend-item { display: flex; align-items: center; gap: 6px; }
.legend-color { width: 12px; height: 12px; border-radius: 3px; display: inline-block; }

/* Map Fullscreen */
.card-map.map-fullscreen {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  z-index: 6000; margin: 0; border-radius: 0;
  background: var(--bg-primary);
  padding: 0; display: flex; flex-direction: column;
  grid-column: 1 / -1;
}
.card-map.map-fullscreen .card-header {
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  flex-shrink: 0; background: var(--bg-secondary);
}
.card-map.map-fullscreen .map-fullscreen-btn { top: 50%; transform: translateY(-50%); right: 16px; }
.card-map.map-fullscreen .fs-expand { display: none; }
.card-map.map-fullscreen .fs-collapse { display: block !important; }
.card-map.map-fullscreen #map {
  flex: 1; height: auto; border-radius: 0; border: none;
}
.card-map.map-fullscreen .map-legend {
  padding: 10px 20px; flex-shrink: 0;
  background: var(--bg-secondary); border-top: 1px solid var(--border);
  margin-top: 0;
}
body.map-is-fullscreen { overflow: hidden; }

/* Metrics */
.card-metrics { grid-column: 2 / 3; }
.metrics-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.metric-tile {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  padding: 14px 16px; transition: border-color 0.25s, transform 0.25s, box-shadow 0.25s;
  opacity: 0; transform: translateY(12px);
}
.metric-tile.anim-visible { opacity: 1; transform: translateY(0); transition: opacity 0.4s ease, transform 0.4s ease, border-color 0.25s, box-shadow 0.25s; }
.metric-tile:hover { border-color: var(--accent-blue); transform: translateY(-2px); box-shadow: 0 4px 16px rgba(78,143,247,0.08); }
.metric-tile .metric-label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.8px; color: var(--text-muted); margin-bottom: 4px; }
.metric-tile .metric-value { font-size: 22px; font-weight: 700; }
.metric-tile .metric-sub { font-size: 11px; color: var(--text-secondary); margin-top: 2px; }
.metric-value.blue { color: var(--accent-blue); }
.metric-value.red { color: var(--accent-red); }
.metric-value.green { color: var(--accent-green); }
.metric-value.amber { color: var(--accent-amber); }
.metric-value.purple { color: var(--accent-purple); }
.metric-value.cyan { color: var(--accent-cyan); }

/* House Race Results */
.card-house-race { grid-column: 1 / -1; }
.race-summary {
  display: flex; gap: 12px; align-items: stretch; flex-shrink: 0;
}
.race-summary-item {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  padding: 8px 16px; text-align: center; min-width: 90px;
}
.race-summary-item .race-label {
  font-size: 9px; text-transform: uppercase; letter-spacing: 0.8px;
  color: var(--text-muted); margin-bottom: 2px;
}
.race-summary-item .race-value {
  font-size: 18px; font-weight: 700; line-height: 1.2;
}
#house-race-results { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 12px; }
.race-candidate-card {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  padding: 18px 20px; display: flex; gap: 14px; align-items: center;
  transition: border-color 0.25s, transform 0.25s;
  opacity: 0; transform: translateY(16px);
}
.race-candidate-card.anim-visible { opacity: 1; transform: translateY(0); transition: opacity 0.4s ease, transform 0.4s ease, border-color 0.25s; }
.race-candidate-card:hover { transform: translateY(-2px) !important; }
.race-candidate-card.winner { border-color: var(--accent-green); }
.race-candidate-card.winner:hover { box-shadow: 0 4px 16px rgba(52,211,153,0.1); }
.race-candidate-card.dem { border-left: 3px solid var(--accent-blue); }
.race-candidate-card.rep { border-left: 3px solid var(--accent-red); }
.race-candidate-card.lib { border-left: 3px solid var(--accent-amber); }
.race-candidate-card.grn { border-left: 3px solid var(--accent-green); }
.race-candidate-card.oth { border-left: 3px solid var(--accent-purple); }
.race-avatar {
  width: 48px; height: 48px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 700; color: #fff;
}
.race-avatar.dem { background: linear-gradient(135deg, var(--accent-blue), #3b7be0); }
.race-avatar.rep { background: linear-gradient(135deg, var(--accent-red), #d04040); }
.race-avatar.lib { background: linear-gradient(135deg, var(--accent-amber), #e08a00); }
.race-avatar.grn { background: linear-gradient(135deg, var(--accent-green), #20a070); }
.race-avatar.oth { background: linear-gradient(135deg, var(--accent-purple), #8a5cf7); }
.race-info { flex: 1; min-width: 0; }
.race-info .race-name { font-size: 15px; font-weight: 600; color: var(--text-primary); display: flex; align-items: center; gap: 8px; }
.race-winner-badge {
  display: inline-block; background: var(--accent-green-soft); color: var(--accent-green);
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
  padding: 3px 8px; border-radius: 4px;
}
.race-info .race-party { font-size: 11px; text-transform: uppercase; letter-spacing: 0.8px; margin-top: 2px; }
.race-party.dem { color: var(--accent-blue); }
.race-party.rep { color: var(--accent-red); }
.race-party.lib { color: var(--accent-amber); }
.race-party.grn { color: var(--accent-green); }
.race-party.oth { color: var(--accent-purple); }
.race-votes {
  text-align: right; flex-shrink: 0;
}
.race-votes .race-vote-count { font-size: 18px; font-weight: 700; color: var(--text-primary); }
.race-votes .race-vote-pct { font-size: 12px; color: var(--text-secondary); }
.race-bar-wrap { margin-top: 10px; }
.race-bar-track { height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; }
.race-bar-fill { height: 100%; border-radius: 3px; transition: width 1.2s cubic-bezier(0.4,0,0.2,1); width: 0; }
.race-bar-fill.dem { background: linear-gradient(90deg, var(--accent-blue), #5a9ef8); }
.race-bar-fill.rep { background: linear-gradient(90deg, var(--accent-red), #f77); }
.race-bar-fill.lib { background: linear-gradient(90deg, var(--accent-amber), #fcd34d); }
.race-bar-fill.grn { background: linear-gradient(90deg, var(--accent-green), #6ee7b7); }
.race-bar-fill.oth { background: linear-gradient(90deg, var(--accent-purple), #c4a5f7); }
.race-unopposed-note {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  padding: 16px 20px; font-size: 13px; color: var(--text-secondary);
  grid-column: 1 / -1;
}
/* Candidate drilldown detail */
.race-candidate-card { flex-wrap: wrap; }
.race-candidate-card.expanded { border-color: var(--accent-blue); box-shadow: 0 4px 20px rgba(90,158,255,0.1); }
.race-candidate-detail {
  width: 100%; padding-top: 14px; margin-top: 14px;
  border-top: 1px solid var(--border);
  animation: detailExpand 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes detailExpand {
  from { opacity: 0; transform: translateY(-12px); max-height: 0; }
  to { opacity: 1; transform: translateY(0); max-height: 200px; }
}
.race-detail-stats {
  display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 12px;
}
.race-detail-stat {
  display: flex; flex-direction: column; gap: 2px;
}
.race-detail-label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); }
.race-detail-value { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.race-detail-analyze-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border: 1px solid var(--accent-purple); border-radius: 8px;
  background: rgba(184,140,255,0.08); color: var(--accent-purple);
  font-size: 12px; font-weight: 600; cursor: pointer; font-family: inherit;
  transition: background 0.2s, border-color 0.2s;
}
.race-detail-analyze-btn:hover { background: rgba(184,140,255,0.15); }

/* Charts */
.card-chart { min-height: 340px; position: relative; }
.chart-container { height: 280px; position: relative; }
.chart-container-wide { height: 300px; }
.card-wide { grid-column: 1 / -1; }

/* Vote Goals */
.card-goals { grid-column: 1 / -1; }
.goals-summary {
  display: flex; gap: 12px; align-items: stretch; flex-shrink: 0;
}
.goals-summary-item {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  padding: 8px 16px; text-align: center; min-width: 90px;
}
.goals-summary-item .goals-label {
  font-size: 9px; text-transform: uppercase; letter-spacing: 0.8px;
  color: var(--text-muted); margin-bottom: 2px;
}
.goals-summary-item .goals-value {
  font-size: 18px; font-weight: 700; line-height: 1.2;
}
.goals-value.cyan { color: var(--accent-cyan); }
.goals-value.green { color: var(--accent-green); }
.goals-value.amber { color: var(--accent-amber); }
#vote-goals { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; }
.goal-card {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px; padding: 16px;
  opacity: 0; transform: translateY(16px); transition: opacity 0.5s ease, transform 0.5s ease;
}
.goal-card.anim-visible { opacity: 1; transform: translateY(0); }
.goal-card .goal-precinct { font-size: 14px; font-weight: 600; margin-bottom: 8px; }
.goal-bar-track { height: 8px; background: var(--border); border-radius: 4px; overflow: hidden; margin-bottom: 8px; }
.goal-bar-fill { height: 100%; border-radius: 4px; transition: width 1.5s cubic-bezier(0.4,0,0.2,1); width: 0; }
.goal-bar-fill.on-track { background: linear-gradient(90deg, var(--accent-green), var(--accent-teal)); }
.goal-bar-fill.close { background: linear-gradient(90deg, var(--accent-amber), #f59e0b); }
.goal-bar-fill.behind { background: linear-gradient(90deg, var(--accent-red), #f87171); }
.goal-numbers { display: flex; justify-content: space-between; font-size: 12px; color: var(--text-secondary); }
.goal-numbers .goal-target { color: var(--accent-green); font-weight: 600; }

/* Scenario Simulator */
.card-scenario { grid-column: 1 / -1; }
.scenario-summary {
  display: flex; gap: 12px; align-items: stretch; flex-shrink: 0;
}
.scenario-summary-item {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  padding: 8px 16px; text-align: center; min-width: 100px;
}
.scenario-summary-item .scenario-label {
  font-size: 9px; text-transform: uppercase; letter-spacing: 0.8px;
  color: var(--text-muted); margin-bottom: 2px;
}
.scenario-summary-item .scenario-value {
  font-size: 18px; font-weight: 700; line-height: 1.2;
}
.scenario-value.green { color: var(--accent-green); }
.scenario-value.amber { color: var(--accent-amber); }
.scenario-value.red { color: var(--accent-red); }
.scenario-value.cyan { color: var(--accent-cyan); }
.scenario-controls {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px;
  padding: 4px 0 16px;
}
.scenario-slider-group {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 12px;
  padding: 16px;
}
.scenario-slider-header {
  display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px;
}
.scenario-slider-header label {
  font-size: 13px; font-weight: 600; color: var(--text-primary);
}
.scenario-slider-value {
  font-size: 14px; font-weight: 700; color: var(--accent-cyan);
  background: rgba(34,211,238,0.1); padding: 2px 10px; border-radius: 6px;
}
.scenario-range {
  -webkit-appearance: none; appearance: none; width: 100%; height: 6px;
  border-radius: 3px; background: var(--border); outline: none; cursor: pointer;
}
.scenario-range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none; width: 20px; height: 20px;
  border-radius: 50%; background: var(--accent-blue); border: 3px solid var(--bg-card);
  box-shadow: 0 2px 8px rgba(78,143,247,0.4); cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
}
.scenario-range::-webkit-slider-thumb:hover {
  transform: scale(1.2); box-shadow: 0 2px 12px rgba(78,143,247,0.6);
}
.scenario-range::-moz-range-thumb {
  width: 20px; height: 20px; border-radius: 50%; background: var(--accent-blue);
  border: 3px solid var(--bg-card); box-shadow: 0 2px 8px rgba(78,143,247,0.4); cursor: pointer;
}
.scenario-slider-labels {
  display: flex; justify-content: space-between;
  font-size: 10px; color: var(--text-muted); margin-top: 6px;
}
.scenario-reset-btn {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  color: var(--text-secondary); font-size: 13px; font-weight: 600; cursor: pointer;
  padding: 16px; transition: border-color 0.2s, color 0.2s;
  display: flex; align-items: center; justify-content: center; font-family: inherit;
}
.scenario-reset-btn:hover { border-color: var(--state-error); color: var(--state-error); }
.scenario-result-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px;
  margin-bottom: 16px;
}
.scenario-result-card {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  padding: 14px; text-align: center; transition: border-color 0.3s;
}
.scenario-result-card.highlight { border-color: var(--accent-green); }
.scenario-result-card.negative { border-color: var(--accent-red); }
.scenario-result-card .sr-label {
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.6px;
  color: var(--text-muted); margin-bottom: 4px;
}
.scenario-result-card .sr-value {
  font-size: 22px; font-weight: 700; line-height: 1.2;
}
.scenario-result-card .sr-delta {
  font-size: 11px; font-weight: 600; margin-top: 2px;
}
.sr-delta.up { color: var(--accent-green); }
.sr-delta.down { color: var(--accent-red); }
.sr-delta.neutral { color: var(--text-muted); }
.scenario-chart-wrap { height: 280px; position: relative; margin-bottom: 16px; }
.scenario-verdict {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 12px;
  padding: 16px 20px; font-size: 14px; line-height: 1.7; color: var(--text-secondary);
}
.scenario-verdict strong { color: var(--text-primary); }
.scenario-verdict .verdict-win { color: var(--accent-green); font-weight: 700; }
.scenario-verdict .verdict-close { color: var(--accent-amber); font-weight: 700; }
.scenario-verdict .verdict-unlikely { color: var(--accent-red); font-weight: 700; }

/* Walkability */
.card-walkability { grid-column: 1 / -1; }
.walk-filter-bar {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 14px;
  padding: 4px;
  background: rgba(15, 23, 42, 0.5);
  border-radius: 10px;
  border: 1px solid var(--border);
}
.walk-filter-btn {
  padding: 7px 16px;
  border-radius: 7px;
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  white-space: nowrap;
}
.walk-filter-btn:hover {
  color: var(--text-primary);
  background: var(--accent-blue-soft);
}
.walk-filter-btn.active {
  background: var(--accent-blue);
  color: #fff;
  box-shadow: 0 2px 8px rgba(90, 158, 255, 0.3);
}
#walkability-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 12px; }
.walk-card {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  padding: 16px; display: flex; gap: 12px; align-items: flex-start;
  transition: border-color 0.25s, transform 0.25s;
  opacity: 0; transform: translateY(16px);
}
.walk-card.anim-visible { opacity: 1; transform: translateY(0); transition: opacity 0.4s ease, transform 0.4s ease, border-color 0.25s; }
.walk-card:hover { border-color: var(--accent-cyan); transform: translateY(-2px) !important; }
.walk-icon {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center; font-size: 20px; flex-shrink: 0;
}
.walk-icon.walkable { background: rgba(52,211,153,0.12); }
.walk-icon.partially_walkable { background: rgba(251,191,36,0.12); }
.walk-icon.dense_urban { background: rgba(176,124,247,0.12); }
.walk-icon.rural_spread { background: rgba(242,92,92,0.12); }
.walk-info h3 { font-size: 14px; font-weight: 600; margin-bottom: 2px; }
.walk-info .walk-rating { font-size: 11px; text-transform: uppercase; letter-spacing: 0.8px; margin-bottom: 4px; }
.walk-rating.walkable { color: var(--accent-green); }
.walk-rating.partially_walkable { color: var(--accent-amber); }
.walk-rating.dense_urban { color: var(--accent-purple); }
.walk-rating.rural_spread { color: var(--accent-red); }
.walk-info .walk-detail { font-size: 12px; color: var(--text-secondary); line-height: 1.5; }
.walk-info .walk-stats { font-size: 11px; color: var(--text-muted); margin-top: 4px; }

/* Reputation Scanner */
.card-reputation {
  grid-column: 1 / -1;
  border-color: rgba(34,211,238,0.2);
  background: linear-gradient(135deg, var(--bg-card) 0%, rgba(34,211,238,0.03) 100%);
}
.card-reputation:hover { border-color: rgba(34,211,238,0.35); box-shadow: var(--shadow), 0 0 40px rgba(34,211,238,0.06); }
.reputation-input-bar {
  display: flex; gap: 10px; margin-bottom: 16px;
}
.reputation-input-bar input {
  flex: 1; padding: 12px 16px; background: var(--bg-inset);
  border: 1px solid var(--border); border-radius: 10px;
  color: var(--text-primary); font-size: 14px; font-family: inherit;
}
.reputation-input-bar input:focus { outline: none; border-color: var(--accent-cyan); box-shadow: 0 0 0 3px rgba(34,211,238,0.12); }
.reputation-input-bar input::placeholder { color: var(--text-muted); }
.reputation-scan-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 24px; border: none; border-radius: 10px;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  color: #fff; font-size: 14px; font-weight: 600; font-family: inherit;
  cursor: pointer; transition: opacity 0.2s, transform 0.2s; flex-shrink: 0;
}
.reputation-scan-btn:hover { opacity: 0.9; transform: scale(1.02); }
.reputation-scan-btn:disabled { opacity: 0.5; cursor: default; transform: none; }
.reputation-scan-btn svg { flex-shrink: 0; }
.reputation-results { min-height: 0; }

/* Rep Loading */
.rep-loading {
  text-align: center; padding: 48px 16px;
}
.rep-loading-spinner {
  width: 40px; height: 40px; margin: 0 auto 16px;
  border: 3px solid var(--border); border-top-color: var(--accent-cyan);
  border-radius: 50%; animation: ring-spin 0.8s linear infinite;
}
.rep-loading-text { font-size: 15px; font-weight: 600; color: var(--text-primary); margin-bottom: 4px; }
.rep-loading-sub { font-size: 12px; color: var(--text-muted-large); }

/* Rep Error */
.rep-error {
  padding: 16px; background: rgba(239, 68, 68, 0.08); border: 1px solid rgba(239, 68, 68, 0.2);
  border-radius: 10px; color: var(--state-error); font-size: 13px; text-align: center;
}

/* Rep Notice */
.rep-notice {
  padding: 10px 16px; border-radius: 8px; font-size: 12px; margin-bottom: 16px;
}
.rep-notice.amber { background: rgba(251,191,36,0.08); border: 1px solid rgba(251,191,36,0.2); color: var(--accent-amber); }
.rep-notice.green { background: rgba(52,211,153,0.08); border: 1px solid rgba(52,211,153,0.2); color: var(--accent-green); }

/* Rep Sections */
.rep-section {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  margin-bottom: 12px; overflow: hidden;
}
.rep-section-header {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px; cursor: pointer; user-select: none;
  transition: background 0.15s;
}
.rep-section-header:hover { background: var(--bg-card-hover); }
.rep-section-icon { display: flex; align-items: center; flex-shrink: 0; }
.rep-section-icon.blue { color: var(--accent-blue); }
.rep-section-icon.red { color: var(--accent-red); }
.rep-section-icon.amber { color: var(--accent-amber); }
.rep-section-icon.green { color: var(--accent-green); }
.rep-section-title { font-size: 14px; font-weight: 600; color: var(--text-primary); flex: 1; }
.rep-risk-count {
  font-size: 11px; padding: 2px 10px; border-radius: 12px;
  background: rgba(242,92,92,0.12); color: var(--accent-red); font-weight: 600;
}
.rep-chevron { font-size: 10px; color: var(--text-muted); transition: transform 0.2s; }
.rep-section-body {
  max-height: 0; overflow: hidden; transition: max-height 0.35s ease, padding 0.35s ease;
  padding: 0 16px;
}
.rep-section-body.open {
  max-height: 2000px; padding: 0 16px 16px;
}
.rep-section-body p { font-size: 13px; color: var(--text-secondary); line-height: 1.7; margin: 0 0 8px; }
.rep-section-body ul { margin: 6px 0 10px 20px; font-size: 13px; color: var(--text-secondary); }
.rep-section-body li { margin-bottom: 4px; line-height: 1.6; }
.rep-section-body strong { color: var(--text-primary); }

/* Rep Tags */
.rep-tags { display: flex; flex-wrap: wrap; gap: 6px; margin: 8px 0; }
.rep-tag {
  padding: 3px 10px; border-radius: 12px; font-size: 11px; font-weight: 500;
}
.rep-tag.blue { background: rgba(78,143,247,0.12); color: var(--accent-blue); }

/* Rep Risk Cards */
.rep-risk-card {
  padding: 12px 16px; border-radius: 8px; margin-bottom: 10px;
  border-left: 3px solid var(--border);
}
.rep-risk-card.high { background: rgba(242,92,92,0.06); border-left-color: var(--accent-red); }
.rep-risk-card.medium { background: rgba(251,191,36,0.06); border-left-color: var(--accent-amber); }
.rep-risk-card.low { background: rgba(78,143,247,0.06); border-left-color: var(--accent-blue); }
.rep-risk-header { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; flex-wrap: wrap; }
.rep-risk-header strong { font-size: 14px; color: var(--text-primary); }
.rep-severity {
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
  padding: 2px 8px; border-radius: 4px;
}
.rep-severity.high { background: rgba(242,92,92,0.15); color: var(--accent-red); }
.rep-severity.medium { background: var(--accent-amber-soft); color: var(--accent-amber); }
.rep-severity.low { background: rgba(78,143,247,0.15); color: var(--accent-blue); }
.rep-risk-card p { font-size: 13px; color: var(--text-secondary); line-height: 1.6; margin: 0; }
.rep-risk-source { font-size: 11px; color: var(--text-muted); margin-top: 6px; font-style: italic; }

/* Rep Strategy Cards */
.rep-strategy-card {
  padding: 12px 16px; background: rgba(251,191,36,0.04);
  border: 1px solid rgba(251,191,36,0.12); border-radius: 8px; margin-bottom: 10px;
}
.rep-strategy-issue {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--accent-amber); font-weight: 600; margin-bottom: 6px;
}
.rep-talking-points { margin-top: 8px; }
.rep-talking-points strong { font-size: 12px; }

/* Rep Positive Cards */
.rep-positive-card {
  padding: 12px 16px; background: rgba(52,211,153,0.04);
  border: 1px solid rgba(52,211,153,0.12); border-radius: 8px; margin-bottom: 10px;
}
.rep-leverage { color: var(--text-muted) !important; font-style: italic; }
.rep-none { color: var(--text-muted) !important; font-style: italic; }

/* Rep Sources */
.rep-sources { margin-bottom: 12px; }
.rep-source-list { display: flex; flex-wrap: wrap; gap: 6px; }
.rep-source-link {
  display: inline-block; padding: 4px 10px; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: 6px;
  font-size: 11px; color: var(--accent-cyan); text-decoration: none;
  max-width: 300px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  transition: border-color 0.2s;
}
.rep-source-link:hover { border-color: var(--accent-cyan); }

/* Rep Disclaimer */
.rep-disclaimer {
  font-size: 11px; color: var(--text-muted); text-align: center;
  padding: 12px; border-top: 1px solid var(--border); margin-top: 4px;
}

/* Analyzer Reset Button */
.analyzer-reset-btn {
  display: flex; align-items: center; gap: 5px; padding: 6px 14px;
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-muted); font-size: 12px; font-weight: 600; font-family: inherit;
  cursor: pointer; transition: border-color 0.2s, color 0.2s; flex-shrink: 0;
}
.analyzer-reset-btn:hover { border-color: var(--state-error); color: var(--state-error); }
.analyzer-reset-btn svg { flex-shrink: 0; }

/* Candidate Analyzer */
.card-candidate { grid-column: 1 / -1; }
.candidate-input-bar {
  display: flex; gap: 10px; margin-bottom: 16px;
}
.candidate-input-bar input {
  flex: 1; background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  padding: 10px 16px; color: var(--text-primary); font-size: 13px; font-family: inherit;
  transition: border-color 0.2s;
}
.candidate-input-bar input:focus { outline: none; border-color: var(--accent-blue); }
.candidate-input-bar input::placeholder { color: var(--text-muted); }
.candidate-analyze-btn {
  display: flex; align-items: center; gap: 8px; padding: 10px 20px;
  background: linear-gradient(135deg, var(--accent-blue), #6b5ce7);
  color: #fff; border: none; border-radius: 10px; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: transform 0.15s, box-shadow 0.15s; white-space: nowrap;
}
.candidate-analyze-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(107,92,231,0.3); }
.candidate-analyze-btn:disabled { opacity: 0.5; cursor: default; transform: none; box-shadow: none; }
.candidate-results { min-height: 0; }
.cand-takeaways {
  background: linear-gradient(135deg, rgba(78,143,247,0.06), rgba(107,92,231,0.06));
  border: 1px solid rgba(78,143,247,0.2); border-radius: 12px;
  padding: 16px 20px; margin-bottom: 16px;
}
.cand-takeaways-title {
  font-size: 14px; font-weight: 700; color: var(--text-primary); margin-bottom: 10px;
}
.cand-takeaway-item {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 6px;
}
.cand-takeaway-num {
  width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0;
  background: var(--accent-blue); color: #fff; font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center; margin-top: 2px;
}
.cand-profile-grid { display: flex; flex-direction: column; gap: 16px; }
.cand-profile-main p { font-size: 13px; color: var(--text-secondary); line-height: 1.6; margin: 0 0 8px; }
.cand-meta { font-size: 12px; color: var(--text-muted); }
.cand-meta strong { color: var(--text-primary); }
.cand-strengths-weaknesses { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.cand-sw-title { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; margin-bottom: 8px; }
.cand-sw-title.green { color: var(--accent-green); }
.cand-sw-title.red { color: var(--accent-red); }
.cand-sw-item {
  font-size: 12px; line-height: 1.5; padding: 6px 10px; border-radius: 6px; margin-bottom: 4px;
}
.cand-sw-item.green { background: rgba(52,211,153,0.08); color: var(--accent-green); border: 1px solid var(--accent-green-soft); }
.cand-sw-item.red { background: rgba(242,92,92,0.08); color: var(--accent-red); border: 1px solid rgba(242,92,92,0.15); }
.cand-score-badge {
  font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 4px;
}
.cand-score-badge.green { background: var(--accent-green-soft); color: var(--accent-green); }
.cand-score-badge.amber { background: var(--accent-amber-soft); color: var(--accent-amber); }
.cand-score-badge.red { background: rgba(242,92,92,0.15); color: var(--accent-red); }
.cand-msg-primary { font-size: 14px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 10px; padding: 12px; background: var(--bg-inset); border-radius: 8px; border: 1px solid var(--border); }
.cand-msg-primary strong { color: var(--text-primary); }
.cand-msg-secondary { margin-bottom: 10px; font-size: 13px; color: var(--text-secondary); }
.cand-msg-secondary strong { color: var(--text-primary); }
.cand-gaps ul { margin: 6px 0; padding-left: 20px; }
.cand-gaps li { font-size: 12px; color: var(--text-secondary); margin-bottom: 4px; line-height: 1.5; }
.cand-policy-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px;
  padding: 12px; margin-bottom: 8px;
}
.cand-policy-header { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; }
.cand-policy-card p { font-size: 12px; color: var(--text-secondary); margin: 4px 0; line-height: 1.5; }
.cand-policy-card p strong { color: var(--text-primary); }
.cand-policy-gop {
  background: rgba(242,92,92,0.05); border-left: 3px solid var(--accent-red);
  padding: 6px 10px; border-radius: 0 6px 6px 0; margin-top: 6px;
}
.cand-website-link { margin-bottom: 12px; font-size: 13px; }
.cand-website-link a { color: var(--accent-blue); text-decoration: none; }
.cand-website-link a:hover { text-decoration: underline; }
.cand-difficulty {
  font-size: 11px; font-weight: 700; padding: 2px 10px; border-radius: 4px; text-transform: uppercase;
}
.cand-difficulty.green { background: var(--accent-green-soft); color: var(--accent-green); }
.cand-difficulty.amber { background: var(--accent-amber-soft); color: var(--accent-amber); }
.cand-difficulty.red { background: rgba(242,92,92,0.15); color: var(--accent-red); }
.cand-gop-strategy {
  background: rgba(242,92,92,0.05); border: 1px solid rgba(242,92,92,0.15);
  border-radius: 8px; padding: 12px; margin-top: 8px; font-size: 13px;
  color: var(--text-secondary); line-height: 1.6;
}
.cand-gop-strategy strong { color: var(--accent-red); }
.cand-vulns ul { margin: 6px 0; padding-left: 20px; }
.cand-vulns li { font-size: 12px; color: var(--text-secondary); margin-bottom: 4px; line-height: 1.5; }
.cand-improvements ul { margin: 6px 0; padding-left: 20px; }
.cand-improvements li { font-size: 12px; color: var(--text-secondary); margin-bottom: 4px; line-height: 1.5; }
@media (max-width: 600px) {
  .candidate-input-bar { flex-direction: column; }
  .cand-strengths-weaknesses { grid-template-columns: 1fr; }
}

/* Social Media Analyzer */
.card-social { grid-column: 1 / -1; }
.social-input-bar {
  display: flex; gap: 10px; margin-bottom: 16px;
}
.social-input-bar input {
  flex: 1; background: var(--bg-inset); border: 1px solid var(--border); border-radius: 10px;
  padding: 10px 16px; color: var(--text-primary); font-size: 13px; font-family: inherit;
  transition: border-color 0.2s;
}
.social-input-bar input:focus { outline: none; border-color: var(--accent-blue); }
.social-input-bar input::placeholder { color: var(--text-muted); }
.social-scan-btn {
  display: flex; align-items: center; gap: 8px; padding: 10px 20px;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-cyan));
  color: #fff; border: none; border-radius: 10px; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: transform 0.15s, box-shadow 0.15s; white-space: nowrap;
}
.social-scan-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(78,143,247,0.3); }
.social-scan-btn:disabled { opacity: 0.5; cursor: default; transform: none; box-shadow: none; }
.social-results { min-height: 0; }
.social-score-bar {
  display: flex; gap: 20px; align-items: center;
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 12px;
  padding: 20px; margin-bottom: 16px;
}
.social-score-ring {
  width: 80px; height: 80px; border-radius: 50%; display: flex; flex-direction: column;
  align-items: center; justify-content: center; flex-shrink: 0;
  border: 4px solid var(--border); background: var(--bg-card);
}
.social-score-ring.green { border-color: var(--accent-green); }
.social-score-ring.amber { border-color: var(--accent-amber); }
.social-score-ring.red { border-color: var(--accent-red); }
.social-score-num { font-size: 28px; font-weight: 800; line-height: 1; }
.social-score-ring.green .social-score-num { color: var(--accent-green); }
.social-score-ring.amber .social-score-num { color: var(--accent-amber); }
.social-score-ring.red .social-score-num { color: var(--accent-red); }
.social-score-of { font-size: 11px; color: var(--text-muted); }
.social-score-text { flex: 1; }
.social-score-text strong { color: var(--text-primary); font-size: 15px; }
.social-score-text p { margin: 6px 0 0; font-size: 13px; color: var(--text-secondary); line-height: 1.5; }
.social-platform-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px;
}
.social-platform-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px; padding: 14px;
}
.social-platform-header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.social-platform-icon { color: var(--text-secondary); display: flex; }
.social-platform-name { font-weight: 600; color: var(--text-primary); font-size: 14px; }
.social-platform-status {
  margin-left: auto; font-size: 11px; font-weight: 600; padding: 2px 8px;
  border-radius: 4px; text-transform: uppercase; letter-spacing: 0.5px;
}
.social-platform-status.green { background: var(--accent-green-soft); color: var(--accent-green); }
.social-platform-status.amber { background: var(--accent-amber-soft); color: var(--accent-amber); }
.social-platform-status.red { background: rgba(242,92,92,0.15); color: var(--accent-red); }
.social-platform-assess { font-size: 12px; color: var(--text-secondary); margin: 0 0 6px; line-height: 1.5; }
.social-platform-link {
  font-size: 11px; color: var(--accent-blue); text-decoration: none; word-break: break-all;
  display: block; margin-bottom: 4px;
}
.social-platform-link:hover { text-decoration: underline; }
.social-platform-followers { font-size: 11px; color: var(--text-muted); margin-bottom: 6px; }
.social-platform-scorebar {
  display: flex; align-items: center; gap: 8px;
  background: var(--border); border-radius: 2px; height: 4px; position: relative; margin-top: 8px;
}
.social-platform-scorebar span {
  position: absolute; right: -36px; top: -6px;
  font-size: 11px; color: var(--text-muted); font-weight: 600;
}
.social-platform-scorefill { height: 100%; border-radius: 2px; transition: width 0.6s ease; }
.social-platform-scorefill.green { background: var(--accent-green); }
.social-platform-scorefill.amber { background: var(--accent-amber); }
.social-platform-scorefill.red { background: var(--accent-red); }
.social-privacy-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px;
  padding: 12px; margin-bottom: 8px;
}
.social-privacy-header { display: flex; align-items: center; gap: 10px; margin-bottom: 6px; }
.social-privacy-card p { font-size: 12px; color: var(--text-secondary); margin: 4px 0; line-height: 1.5; }
.social-cs-item { margin-bottom: 14px; font-size: 13px; color: var(--text-secondary); line-height: 1.6; }
.social-cs-item strong { color: var(--text-primary); }
.social-cs-hawaii {
  background: rgba(78,143,247,0.06); border: 1px solid rgba(78,143,247,0.2);
  border-radius: 8px; padding: 12px;
}
.social-content-mix { margin-top: 8px; }
.social-mix-item { margin-bottom: 12px; }
.social-mix-bar-track { height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; margin-bottom: 4px; }
.social-mix-bar-fill { height: 100%; background: linear-gradient(90deg, var(--accent-green), var(--accent-teal)); border-radius: 3px; }
.social-mix-label { font-size: 12px; color: var(--text-primary); }
.social-mix-desc { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.social-cadence-timeline { display: flex; flex-direction: column; gap: 12px; }
.social-cadence-phase {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 10px; padding: 14px;
}
.social-cadence-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.social-cadence-label { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.social-cadence-freq { font-size: 13px; font-weight: 700; color: var(--accent-cyan); }
.social-cadence-bar-track { height: 8px; background: var(--border); border-radius: 4px; overflow: hidden; margin-bottom: 8px; }
.social-cadence-bar-fill { height: 100%; border-radius: 4px; transition: width 0.8s ease; }
.social-cadence-bar-fill.phase-1 { background: linear-gradient(90deg, var(--accent-blue), #6ea8ff); }
.social-cadence-bar-fill.phase-2 { background: linear-gradient(90deg, var(--accent-cyan), #5de8f5); }
.social-cadence-bar-fill.phase-3 { background: linear-gradient(90deg, var(--accent-amber), #f5c842); }
.social-cadence-bar-fill.phase-4 { background: linear-gradient(90deg, var(--accent-red), #ff7070); }
.social-cadence-focus { font-size: 12px; color: var(--text-secondary); margin: 0; line-height: 1.5; }
.social-action-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px;
  padding: 12px; margin-bottom: 8px;
}
.social-action-header { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.social-action-card p { font-size: 13px; color: var(--text-secondary); margin: 4px 0; line-height: 1.5; }
.social-action-card p strong { color: var(--text-primary); }
.social-action-detail { font-size: 12px; }
@media (max-width: 600px) {
  .social-input-bar { flex-direction: column; }
  .social-score-bar { flex-direction: column; text-align: center; }
}

/* AI Summary */
.card-ai, .card-ai-steps {
  grid-column: 1 / -1;
  border-color: rgba(184,140,255,0.25);
  background: linear-gradient(135deg, var(--bg-card) 0%, rgba(184,140,255,0.05) 100%);
}
.card-ai:hover, .card-ai-steps:hover { border-color: rgba(184,140,255,0.4); box-shadow: var(--shadow), 0 0 40px rgba(184,140,255,0.08); }
.ai-icon { color: var(--accent-purple); margin-right: 4px; font-size: 10px; vertical-align: middle; }
.ai-summary { font-size: 14px; line-height: 1.8; color: var(--text-secondary); min-height: 60px; position: relative; }
.ai-summary p { margin-bottom: 12px; }
.ai-summary strong { color: var(--text-primary); font-weight: 600; }
.ai-summary ul { list-style: none; margin: 8px 0 12px 0; padding: 0; }
.ai-summary li {
  margin-bottom: 10px; padding: 10px 14px; padding-left: 30px;
  background: var(--bg-inset); border-radius: 8px; border: 1px solid var(--border);
  position: relative; line-height: 1.6;
}
.ai-summary li::before {
  content: ''; position: absolute; left: 14px; top: 16px;
  width: 6px; height: 6px; border-radius: 50%; background: var(--accent-purple);
}
.ai-cursor {
  display: inline-block; width: 8px; height: 16px; background: var(--accent-purple);
  animation: blink 0.8s infinite; vertical-align: text-bottom; margin-left: 2px; border-radius: 1px;
}
.ai-cursor.hidden { display: none; }
.ai-summary .ai-reveal { opacity: 0; transform: translateY(8px); transition: opacity 0.5s ease, transform 0.5s ease; }
.ai-summary .ai-reveal.visible { opacity: 1; transform: translateY(0); }
@keyframes blink { 0%, 50% { opacity: 1; } 51%, 100% { opacity: 0; } }

/* Leaflet popup override */
.leaflet-popup-content-wrapper { background: var(--bg-card) !important; color: var(--text-primary) !important; border: 1px solid var(--border) !important; border-radius: 10px !important; box-shadow: var(--shadow) !important; }
.leaflet-popup-tip { background: var(--bg-card) !important; border: 1px solid var(--border) !important; }
.leaflet-popup-content { font-size: 13px !important; line-height: 1.6 !important; }
.leaflet-popup-content strong { color: var(--accent-blue); }
.popup-stat { display: flex; justify-content: space-between; padding: 2px 0; }
.popup-stat .label { color: var(--text-muted); }

/* === Modal === */
.modal-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center; z-index: 10000;
  opacity: 0; visibility: hidden; transition: opacity 0.3s, visibility 0.3s;
}
.modal-overlay.visible { opacity: 1; visibility: visible; }
.modal-content {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 16px;
  padding: 32px 40px; text-align: center; max-width: 400px;
  transform: scale(0.9) translateY(20px);
  transition: transform 0.3s cubic-bezier(0.16,1,0.3,1);
  box-shadow: 0 20px 60px var(--overlay-strong);
}
.modal-overlay.visible .modal-content { transform: scale(1) translateY(0); }
.modal-icon { font-size: 48px; margin-bottom: 12px; }
.modal-content h3 { font-size: 20px; font-weight: 700; margin-bottom: 8px; }
.modal-content p { font-size: 14px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 20px; }
.modal-close {
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  color: #fff; border: none; border-radius: 8px; padding: 10px 28px;
  font-size: 14px; font-weight: 600; cursor: pointer; transition: opacity 0.2s, transform 0.2s;
}
.modal-close:hover { opacity: 0.9; transform: scale(1.02); }

/* === Campaign Finance === */
.card-finance, .card-polling { overflow: hidden; min-width: 0; }
.finance-overview, .polling-overview { padding: 0 20px 20px; min-width: 0; max-width: 100%; overflow-x: hidden; }
/* Reusable empty state component */
.empty-state { text-align: center; padding: 48px 24px; color: var(--text-muted); }
.empty-state-icon { font-size: 32px; margin-bottom: 12px; opacity: 0.5; }
.empty-state-title { font-size: 14px; font-weight: 600; color: var(--text-secondary); margin-bottom: 6px; }
.empty-state-msg { font-size: 13px; line-height: 1.5; max-width: 320px; margin: 0 auto; }

.finance-empty, .polling-empty { text-align: center; padding: 40px 20px; color: var(--text-muted); }
.finance-empty-sub, .polling-empty-sub { font-size: 12px; margin-top: 8px; opacity: 0.7; }
.finance-section-title, .polling-section-title {
  font-size: 13px; font-weight: 600; color: var(--text-secondary); text-transform: uppercase;
  letter-spacing: 0.5px; margin: 20px 0 12px; padding-bottom: 8px; border-bottom: 1px solid var(--border);
}
.finance-source-badges { display: flex; gap: 6px; }
.finance-src-badge {
  font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 4px;
  letter-spacing: 0.5px;
}
.finance-src-fec { background: rgba(78,143,247,0.15); color: #4e8ff7; }
.finance-src-hicfb { background: var(--accent-green-soft); color: var(--accent-green); }

/* Finance comparison bars */
.finance-comparison { margin-bottom: 20px; }
.finance-candidate-row { margin-bottom: 12px; }
.finance-candidate-info { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.finance-candidate-name { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.finance-party-badge {
  font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 10px;
  text-transform: uppercase; letter-spacing: 0.5px;
}
.finance-party-badge.party-dem { background: rgba(78,143,247,0.15); color: #4e8ff7; }
.finance-party-badge.party-rep { background: rgba(242,92,92,0.15); color: #f25c5c; }
.finance-party-badge.party-oth { background: rgba(168,177,199,0.15); color: #a8b1c7; }
.finance-bar-wrap { position: relative; height: 28px; background: var(--bg-tertiary); border-radius: 6px; overflow: hidden; }
.finance-bar {
  height: 100%; border-radius: 6px; transition: width 1s cubic-bezier(0.16,1,0.3,1);
  min-width: 4px;
}
.finance-bar-dem { background: linear-gradient(90deg, rgba(78,143,247,0.3), rgba(78,143,247,0.7)); }
.finance-bar-rep { background: linear-gradient(90deg, rgba(242,92,92,0.3), rgba(242,92,92,0.7)); }
.finance-bar-label {
  position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
  font-size: 13px; font-weight: 700; color: var(--text-primary);
}

/* Finance metrics grid */
.finance-metrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; margin-bottom: 20px; }
.finance-metric-card {
  background: var(--bg-tertiary); border-radius: 10px; padding: 14px;
  border: 1px solid var(--border);
}
.finance-metric-dem { border-left: 3px solid #4e8ff7; }
.finance-metric-rep { border-left: 3px solid #f25c5c; }
.finance-metric-name { font-size: 13px; font-weight: 700; color: var(--text-primary); margin-bottom: 10px; text-transform: uppercase; letter-spacing: 0.5px; }
.finance-metric-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.finance-metric { display: flex; flex-direction: column; }
.finance-metric-label { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.3px; }
.finance-metric-value { font-size: 15px; font-weight: 700; color: var(--text-primary); }

/* Donor source stacked bars */
.finance-donor-charts { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.finance-donor-chart { }
.finance-donor-name { font-size: 12px; font-weight: 600; color: var(--text-secondary); margin-bottom: 6px; }
.finance-stacked-bar { display: flex; height: 20px; border-radius: 4px; overflow: hidden; margin-bottom: 6px; }
.finance-stack-individual { background: #4e8ff7; }
.finance-stack-pac { background: #b07cf7; }
.finance-stack-self { background: var(--accent-amber); }
.finance-donor-legend { display: flex; gap: 12px; flex-wrap: wrap; }
.finance-legend-item { font-size: 11px; color: var(--text-muted); display: flex; align-items: center; gap: 4px; }
.finance-legend-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.finance-legend-individual { background: #4e8ff7; }
.finance-legend-pac { background: #b07cf7; }
.finance-legend-self { background: var(--accent-amber); }

/* Top donors table */
.finance-top-donors { margin-bottom: 16px; }
.finance-donor-list { margin-bottom: 16px; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.finance-donor-list-header {
  font-size: 12px; font-weight: 700; padding: 6px 10px; border-radius: 6px 6px 0 0;
  text-transform: uppercase; letter-spacing: 0.5px;
}
.finance-donor-list-header.party-dem { background: rgba(78,143,247,0.15); color: #4e8ff7; }
.finance-donor-list-header.party-rep { background: rgba(242,92,92,0.15); color: #f25c5c; }
.finance-donor-table { width: 100%; border-collapse: collapse; font-size: 12px; table-layout: fixed; word-break: break-word; }
.finance-donor-table th { text-align: left; padding: 8px 10px; color: var(--text-muted); font-weight: 600; border-bottom: 1px solid var(--border); text-transform: uppercase; font-size: 10px; letter-spacing: 0.5px; }
.finance-donor-table td { padding: 7px 10px; border-bottom: 1px solid var(--border); color: var(--text-secondary); }
.finance-type-badge {
  font-size: 9px; font-weight: 600; padding: 2px 6px; border-radius: 4px;
  text-transform: uppercase; letter-spacing: 0.3px;
}
.finance-type-pac { background: rgba(176,124,247,0.15); color: #b07cf7; }
.finance-type-individual { background: rgba(78,143,247,0.15); color: #4e8ff7; }
.finance-type-self { background: var(--accent-amber-soft); color: var(--accent-amber); }

/* Industry bars */
.finance-industry-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; }
.finance-industry-row { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.finance-industry-name { font-size: 11px; color: var(--text-muted); min-width: 120px; flex-shrink: 0; }
.finance-industry-bar-wrap { flex: 1; height: 14px; background: var(--bg-tertiary); border-radius: 3px; overflow: hidden; }
.finance-industry-bar { height: 100%; border-radius: 3px; transition: width 0.8s ease; }
.finance-industry-amount { font-size: 11px; font-weight: 600; color: var(--text-secondary); min-width: 50px; text-align: right; }

/* Show more / expand button */
.finance-donor-count { font-weight: 400; font-size: 10px; opacity: 0.7; text-transform: none; letter-spacing: 0; }
.finance-donor-extra { display: none; }
.finance-table-expanded .finance-donor-extra { display: table-row; }
.finance-show-more-btn {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  width: 100%; padding: 8px; margin-top: 2px;
  background: var(--bg-tertiary); border: 1px solid var(--border); border-top: none;
  border-radius: 0 0 8px 8px; color: var(--accent-blue); font-size: 12px;
  font-weight: 600; font-family: inherit; cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.finance-show-more-btn:hover { background: rgba(78,143,247,0.08); }
.finance-show-more-icon { transition: transform 0.3s; }
.finance-show-more-btn.expanded .finance-show-more-icon { transform: rotate(180deg); }

/* Quarterly fundraising */
.finance-quarterly-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; }
.finance-quarterly-row { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.finance-quarterly-label { font-size: 11px; color: var(--text-muted); min-width: 56px; flex-shrink: 0; }
.finance-quarterly-bar-wrap { flex: 1; height: 16px; background: var(--bg-tertiary); border-radius: 4px; overflow: hidden; }
.finance-quarterly-bar { height: 100%; border-radius: 4px; transition: width 0.8s ease; }
.finance-quarterly-amount { font-size: 11px; font-weight: 600; color: var(--text-secondary); min-width: 50px; text-align: right; }

.finance-source { font-size: 11px; color: var(--text-muted); margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--border); }

/* Contribution Limits */
.finance-limits-section {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.finance-limits-section .finance-section-title {
  display: flex;
  align-items: center;
  gap: 10px;
}
.finance-limits-cycle {
  font-size: 11px;
  font-weight: 500;
  color: var(--accent-blue);
  background: rgba(90, 158, 255, 0.1);
  padding: 2px 8px;
  border-radius: 4px;
}
.finance-limits-table-wrap {
  overflow-x: auto;
  margin: 10px 0;
}
.finance-limits-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.finance-limits-table th {
  text-align: left;
  padding: 8px 12px;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border);
}
.finance-limits-table td {
  padding: 8px 12px;
  color: var(--text-secondary);
  border-bottom: 1px solid rgba(47, 53, 80, 0.3);
}
.finance-limits-table .finance-limits-note {
  font-size: 11px;
  color: var(--text-muted);
  font-style: italic;
}
.finance-limits-active {
  background: var(--accent-blue-soft);
  border-left: 3px solid var(--accent-blue);
}
.finance-limits-active td {
  color: var(--text-primary);
  font-weight: 600;
}
.finance-limits-notes {
  margin: 10px 0;
  padding: 10px 14px;
  background: rgba(15, 23, 42, 0.4);
  border-radius: 8px;
  border: 1px solid rgba(47, 53, 80, 0.3);
}
.finance-limits-note-item {
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.7;
}
.finance-limits-source {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 8px;
}
.finance-limits-source a {
  color: var(--accent-blue);
  text-decoration: none;
}
.finance-limits-source a:hover { text-decoration: underline; }

/* === Polling Aggregation === */
.polling-average {
  background: var(--bg-tertiary); border-radius: 12px; padding: 20px;
  margin-bottom: 20px; border: 1px solid var(--border); text-align: center;
}
.polling-avg-header { font-size: 11px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.polling-avg-candidates { display: flex; justify-content: center; align-items: center; gap: 24px; margin-bottom: 16px; }
.polling-avg-dem, .polling-avg-rep { text-align: center; }
.polling-avg-dem .polling-avg-pct { font-size: 32px; font-weight: 800; color: #4e8ff7; }
.polling-avg-rep .polling-avg-pct { font-size: 32px; font-weight: 800; color: #f25c5c; }
.polling-avg-label { display: block; font-size: 11px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; margin-top: 2px; }
.polling-avg-margin {
  font-size: 16px; font-weight: 800; padding: 6px 16px; border-radius: 8px;
}
.polling-margin-safe { background: rgba(78,143,247,0.15); color: #4e8ff7; }
.polling-margin-likely { background: rgba(78,143,247,0.1); color: #6ba3f7; }
.polling-margin-lean { background: rgba(176,124,247,0.15); color: #b07cf7; }
.polling-margin-tossup { background: var(--accent-amber-soft); color: var(--accent-amber); }

.polling-margin-bar { display: flex; height: 12px; border-radius: 6px; overflow: hidden; }
.polling-margin-dem { background: linear-gradient(90deg, #4e8ff7, rgba(78,143,247,0.6)); }
.polling-margin-rep { background: linear-gradient(90deg, rgba(242,92,92,0.6), #f25c5c); }

/* Actual result */
.polling-result {
  background: var(--bg-tertiary); border-radius: 12px; padding: 20px;
  margin-bottom: 20px; border: 1px solid var(--border); text-align: center;
  border-left: 3px solid var(--accent-green);
}
.polling-result-header { font-size: 11px; font-weight: 700; color: var(--accent-green); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.polling-result-margin { font-size: 16px; font-weight: 800; padding: 6px 16px; border-radius: 8px; background: var(--accent-green-soft); color: var(--accent-green); }
.polling-error { font-size: 12px; color: var(--text-muted); margin-top: 10px; font-style: italic; }

/* Rating timeline */
.polling-rating-timeline { display: flex; gap: 12px; flex-wrap: wrap; }
.polling-rating-item { display: flex; align-items: center; gap: 8px; padding: 8px 12px; background: var(--bg-tertiary); border-radius: 8px; border: 1px solid var(--border); }
.polling-rating-date { font-size: 11px; color: var(--text-muted); }
.polling-rating-badge {
  font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 4px;
  text-transform: uppercase; letter-spacing: 0.5px;
}
.rating-safe-d { background: rgba(78,143,247,0.2); color: #4e8ff7; }
.rating-likely-d { background: rgba(78,143,247,0.12); color: #6ba3f7; }
.rating-lean-d { background: rgba(176,124,247,0.15); color: #b07cf7; }
.rating-toss-up, .rating-tossup { background: var(--accent-amber-soft); color: var(--accent-amber); }
.rating-lean-r { background: rgba(242,92,92,0.1); color: #f78080; }
.rating-likely-r { background: rgba(242,92,92,0.15); color: #f25c5c; }
.rating-safe-r { background: rgba(242,92,92,0.2); color: #e03e3e; }
.polling-rating-source { font-size: 10px; color: var(--text-muted); font-style: italic; }

/* Polling trend chart */
.polling-chart-container { height: 250px; position: relative; max-width: 100%; }

/* Polling table */
.polling-table-section { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.polling-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.polling-table th { text-align: left; padding: 8px 10px; color: var(--text-muted); font-weight: 600; border-bottom: 1px solid var(--border); text-transform: uppercase; font-size: 10px; letter-spacing: 0.5px; }
.polling-table td { padding: 8px 10px; border-bottom: 1px solid var(--border); color: var(--text-secondary); }
.polling-pollster { font-weight: 500; color: var(--text-primary); word-break: break-word; }
.polling-dem-cell { color: #4e8ff7; font-weight: 700; }
.polling-rep-cell { color: #f25c5c; font-weight: 700; }
.polling-margin-badge {
  font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 4px;
}
.polling-grade { font-size: 11px; font-weight: 700; color: var(--text-secondary); background: var(--bg-tertiary); padding: 2px 6px; border-radius: 4px; }

/* === Tier 1: Voter Registration & Turnout === */
.voter-reg-overview, .election-history-overview, .demographics-overview { padding: 0 20px 20px; min-width: 0; max-width: 100%; overflow-x: hidden; }
.tier1-section-title {
  font-size: 13px; font-weight: 600; color: var(--text-secondary); text-transform: uppercase;
  letter-spacing: 0.5px; margin: 20px 0 12px; padding-bottom: 8px; border-bottom: 1px solid var(--border);
}
.tier1-empty { text-align: center; padding: 40px 20px; color: var(--text-muted); }
.tier1-empty-sub { font-size: 12px; margin-top: 8px; opacity: 0.7; }
.tier1-empty code { background: rgba(78,143,247,0.1); padding: 2px 8px; border-radius: 4px; font-size: 12px; color: var(--accent-cyan); }

/* Registration gauge */
.reg-gauge-section { display: flex; gap: 20px; flex-wrap: wrap; margin-bottom: 20px; }
.reg-gauge-card {
  flex: 1; min-width: 200px; background: var(--bg-tertiary); border-radius: 12px;
  padding: 20px; border: 1px solid var(--border); text-align: center;
}
.reg-gauge-label { font-size: 11px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; }
.reg-gauge-value { font-size: 32px; font-weight: 800; color: var(--text-primary); }
.reg-gauge-sub { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.reg-gauge-bar { height: 10px; background: var(--bg-inset); border-radius: 5px; overflow: hidden; margin-top: 12px; }
.reg-gauge-fill { height: 100%; border-radius: 5px; transition: width 1s ease; }
.reg-gauge-fill-blue { background: linear-gradient(90deg, #4e8ff7, #6ba3f7); }
.reg-gauge-fill-green { background: linear-gradient(90deg, var(--accent-green), #6ee7b7); }
.reg-gauge-fill-amber { background: linear-gradient(90deg, var(--accent-amber), #fcd34d); }
.reg-gauge-fill-red { background: linear-gradient(90deg, #f25c5c, #f78080); }

/* Turnout comparison */
.turnout-compare { display: flex; gap: 16px; margin-bottom: 20px; flex-wrap: wrap; }
.turnout-compare-item {
  flex: 1; min-width: 180px; background: var(--bg-tertiary); border-radius: 10px;
  padding: 14px; border: 1px solid var(--border);
}
.turnout-compare-label { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 4px; }
.turnout-compare-value { font-size: 24px; font-weight: 800; }
.turnout-compare-bar { height: 8px; background: var(--bg-inset); border-radius: 4px; overflow: hidden; margin-top: 8px; }
.turnout-compare-fill { height: 100%; border-radius: 4px; transition: width 1s ease; }

/* Registration Rate (redesigned) */
.reg-rate-card {
  background: var(--bg-tertiary);
  border-radius: 10px;
  padding: 16px;
  border: 1px solid var(--border);
}
.reg-rate-numbers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}
.reg-rate-stat { text-align: center; }
.reg-rate-value {
  font-size: 22px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  display: block;
}
.reg-rate-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  margin-top: 4px;
}
.reg-rate-bar-wrap {
  height: 8px;
  background: var(--bg-inset);
  border-radius: 4px;
  overflow: hidden;
}
.reg-rate-bar {
  height: 100%;
  border-radius: 4px;
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Turnout: District vs Statewide (redesigned) */
.turnout-vs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.turnout-vs-card {
  background: var(--bg-tertiary);
  border-radius: 10px;
  padding: 16px;
  border: 1px solid var(--border);
}
.turnout-vs-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  margin-bottom: 6px;
}
.turnout-vs-value {
  font-size: 22px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.turnout-vs-bar-wrap {
  height: 6px;
  background: var(--bg-inset);
  border-radius: 3px;
  overflow: hidden;
  margin-top: 10px;
}
.turnout-vs-bar {
  height: 100%;
  border-radius: 3px;
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.turnout-vs-diff-card { border-style: dashed; }
.turnout-vs-diff-note {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 4px;
}

/* Demographics Key Statistics (redesigned) */
.demo-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}
.demo-stat-card {
  background: var(--bg-tertiary);
  border-radius: 10px;
  padding: 16px;
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 12px;
}
.demo-stat-icon {
  font-size: 22px;
  opacity: 0.7;
  flex-shrink: 0;
}
.demo-stat-content { min-width: 0; }
.demo-stat-value {
  font-size: 20px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
}
.demo-stat-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  margin-top: 2px;
}
@media (max-width: 900px) {
  .reg-rate-numbers { grid-template-columns: 1fr; gap: 8px; }
  .turnout-vs-grid { grid-template-columns: 1fr; }
  .demo-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .reg-rate-value, .turnout-vs-value, .demo-stat-value { font-size: 18px; }
}

/* Vote share chart section */
.vote-share-section { display: grid; grid-template-columns: 200px 1fr; gap: 20px; margin-bottom: 20px; align-items: center; }
.vote-share-chart-wrap { width: 200px; height: 200px; position: relative; }

/* Precinct turnout heatmap */
.precinct-heatmap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.precinct-heatmap table { width: 100%; border-collapse: collapse; font-size: 12px; }
.precinct-heatmap th { text-align: left; padding: 8px 10px; color: var(--text-muted); font-weight: 600; border-bottom: 1px solid var(--border); text-transform: uppercase; font-size: 10px; letter-spacing: 0.5px; }
.precinct-heatmap td { padding: 6px 10px; border-bottom: 1px solid var(--border); color: var(--text-secondary); }
.precinct-heatmap tr.turnout-high { border-left: 3px solid var(--accent-green); }
.precinct-heatmap tr.turnout-mid { border-left: 3px solid var(--accent-amber); }
.precinct-heatmap tr.turnout-low { border-left: 3px solid #f25c5c; }
.precinct-heatmap .turnout-val-high { color: var(--accent-green); font-weight: 700; }
.precinct-heatmap .turnout-val-mid { color: var(--accent-amber); font-weight: 700; }
.precinct-heatmap .turnout-val-low { color: #f25c5c; font-weight: 700; }
.gap-cell { color: #f25c5c; font-weight: 600; }

/* Election-by-Election Comparison table */
.election-compare-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.election-compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.election-compare-table thead th {
  text-align: left;
  padding: 10px 14px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  border-bottom: 2px solid var(--border);
  white-space: nowrap;
}
.election-compare-table tbody tr {
  border-bottom: 1px solid rgba(47, 53, 80, 0.3);
  transition: background 0.2s;
}
.election-compare-table tbody tr:hover { background: rgba(90, 158, 255, 0.05); }
.election-compare-latest { background: rgba(90, 158, 255, 0.06); }
.election-compare-latest td { font-weight: 700; }
.election-compare-year {
  padding: 10px 14px;
  font-weight: 700;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.election-compare-dem {
  padding: 10px 14px;
  color: #4e8ff7;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.election-compare-rep {
  padding: 10px 14px;
  color: #f25c5c;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.election-compare-margin {
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.election-compare-margin-bar-wrap {
  width: 60px;
  height: 8px;
  background: var(--bg-inset);
  border-radius: 4px;
  overflow: hidden;
  flex-shrink: 0;
}
.election-compare-margin-bar {
  height: 100%;
  border-radius: 4px;
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.election-compare-turnout {
  padding: 10px 14px;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.election-compare-swing {
  padding: 10px 14px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  text-align: right;
}

/* Income vs Statewide (redesigned) */
.income-compare-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}
.income-compare-card {
  background: var(--bg-tertiary);
  border-radius: 10px;
  padding: 16px;
  border: 1px solid var(--border);
}
.income-compare-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  margin-bottom: 6px;
}
.income-compare-value {
  font-size: 22px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.income-compare-bar-wrap {
  height: 6px;
  background: var(--bg-inset);
  border-radius: 3px;
  overflow: hidden;
  margin-top: 10px;
}
.income-compare-bar {
  height: 100%;
  border-radius: 3px;
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.income-compare-diff-card {
  border-style: dashed;
}
.income-compare-diff-note {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 4px;
}
.income-home-value {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--bg-tertiary);
  border-radius: 10px;
  border: 1px solid var(--border);
}
.income-home-value-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.income-home-value-amount {
  font-size: 20px;
  font-weight: 800;
  color: var(--accent-amber);
  font-variant-numeric: tabular-nums;
}
@media (max-width: 900px) {
  .income-compare-grid { grid-template-columns: 1fr; }
  .income-compare-value { font-size: 18px; }
}

/* Turnout heatmap table (redesigned) */
.turnout-heatmap-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 0 -4px;
}
.turnout-heatmap-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.turnout-heatmap-table thead th {
  text-align: left;
  padding: 10px 14px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  border-bottom: 2px solid var(--border);
  white-space: nowrap;
}
.turnout-heatmap-th-turnout { min-width: 180px; }
.turnout-heatmap-table tbody tr {
  border-bottom: 1px solid rgba(47, 53, 80, 0.3);
  transition: background 0.2s;
}
.turnout-heatmap-table tbody tr:hover {
  background: rgba(90, 158, 255, 0.05);
}
.turnout-heatmap-precinct {
  padding: 10px 14px;
  font-weight: 700;
  color: var(--text-primary);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.turnout-heatmap-num {
  padding: 10px 14px;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
  text-align: right;
}
.turnout-heatmap-turnout {
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.turnout-heatmap-bar-wrap {
  flex: 1;
  height: 8px;
  background: var(--bg-inset);
  border-radius: 4px;
  overflow: hidden;
  min-width: 80px;
}
.turnout-heatmap-bar {
  height: 100%;
  border-radius: 4px;
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.turnout-heatmap-pct {
  font-weight: 700;
  font-size: 13px;
  min-width: 48px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.turnout-heatmap-gap {
  padding: 10px 14px;
  text-align: right;
  white-space: nowrap;
}
.turnout-heatmap-gap-num {
  font-weight: 600;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
}
.turnout-heatmap-gap-label {
  font-size: 11px;
  color: var(--text-muted);
  margin-left: 4px;
}

/* Mobilization opportunity */
.mobilization-summary {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin-top: 16px;
}
.mobilization-stat {
  background: var(--bg-tertiary); border-radius: 10px; padding: 14px;
  border: 1px solid var(--border); text-align: center;
}
.mobilization-stat-value { font-size: 22px; font-weight: 800; color: var(--text-primary); }
.mobilization-stat-label { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 4px; }

/* === Tier 1: Election History === */
.history-trend-chart { height: 280px; position: relative; max-width: 100%; margin-bottom: 20px; }
.history-swing-badge {
  display: inline-block; font-size: 14px; font-weight: 800; padding: 6px 16px;
  border-radius: 8px; margin-bottom: 16px;
}
.history-swing-d { background: rgba(78,143,247,0.15); color: #4e8ff7; }
.history-swing-r { background: rgba(242,92,92,0.15); color: #f25c5c; }
.history-swing-flat { background: rgba(168,177,199,0.15); color: #a8b1c7; }
.history-table { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.history-table table { width: 100%; border-collapse: collapse; font-size: 12px; }
.history-table th { text-align: left; padding: 8px 12px; color: var(--text-muted); font-weight: 600; border-bottom: 1px solid var(--border); text-transform: uppercase; font-size: 10px; letter-spacing: 0.5px; }
.history-table td { padding: 8px 12px; border-bottom: 1px solid var(--border); color: var(--text-secondary); }
.history-table td.dem-val { color: #4e8ff7; font-weight: 700; }
.history-table td.rep-val { color: #f25c5c; font-weight: 700; }

/* Election year selector */
.election-year-selector {
  display: flex; gap: 4px; margin-left: auto;
}
.election-year-btn {
  padding: 4px 12px; border-radius: 6px; font-size: 12px; font-weight: 600;
  font-family: inherit; border: 1px solid var(--border); background: var(--bg-tertiary);
  color: var(--text-muted); cursor: pointer; transition: all 0.2s;
}
.election-year-btn:hover { border-color: var(--accent-blue); color: var(--text-secondary); }
.election-year-btn.active { background: var(--accent-blue); border-color: var(--accent-blue); color: #fff; }

/* === Tier 1: Demographics === */
.demo-stats-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 12px; margin-bottom: 20px;
}
.demo-stat {
  background: var(--bg-tertiary); border-radius: 10px; padding: 14px;
  border: 1px solid var(--border); text-align: center;
}
.demo-stat-value { font-size: 20px; font-weight: 800; color: var(--text-primary); }
.demo-stat-label { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 4px; }
.demo-charts-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; }
.demo-chart-wrap { position: relative; }
.demo-chart-canvas { height: 220px; max-width: 100%; }
.demo-income-compare {
  display: flex; gap: 16px; flex-wrap: wrap;
}
.demo-income-item {
  flex: 1; min-width: 150px; background: var(--bg-tertiary); border-radius: 10px;
  padding: 14px; border: 1px solid var(--border); text-align: center;
}
.demo-income-value { font-size: 22px; font-weight: 800; }
.demo-income-label { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 4px; }
.demo-income-district { color: var(--accent-blue); }
.demo-income-state { color: var(--text-muted); }

/* Responsive additions for Tier 1 */
@media (max-width: 900px) {
  .vote-share-section { grid-template-columns: 1fr; }
  .vote-share-chart-wrap { width: 160px; height: 160px; margin: 0 auto; }
  .demo-charts-row { grid-template-columns: 1fr; }
  .reg-gauge-value { font-size: 26px; }
  .turnout-compare-value { font-size: 20px; }
}
@media (max-width: 500px) {
  .voter-reg-overview, .election-history-overview, .demographics-overview { padding: 0 10px 16px; }
  .reg-gauge-value { font-size: 22px; }
  .reg-gauge-card { padding: 14px; }
  .mobilization-summary { grid-template-columns: 1fr 1fr; }
  .demo-stats-grid { grid-template-columns: 1fr 1fr; }
  .history-trend-chart { height: 220px; }
  .demo-chart-canvas { height: 180px; }
  .election-year-btn { padding: 3px 8px; font-size: 11px; }
  .reg-gauge-card { min-width: 0; }
  .turnout-compare-item { min-width: 0; }
  .reg-gauge-section, .turnout-compare { gap: 10px; }
}

/* Footer */
.dashboard-footer {
  padding: 20px 32px 24px; color: var(--text-muted); font-size: 12px;
  border-top: 1px solid var(--border);
  margin-bottom: 60px; /* clear chat fab button */
}
.footer-row {
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px;
  margin-bottom: 12px;
}
.footer-content { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.footer-copyright {
  font-size: 10px;
  color: var(--text-muted);
  opacity: 0.6;
  line-height: 1.5;
}
.footer-copyright a { color: var(--text-muted); text-decoration: none; }
.footer-copyright a:hover { color: var(--text-secondary); text-decoration: underline; }
.footer-brand-logo { height: 20px; width: auto; object-fit: contain; }
.footer-separator { color: var(--text-muted); font-size: 14px; }
.footer-version {
  font-size: 10px; font-weight: 600; padding: 2px 8px;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 4px;
  color: var(--text-muted); letter-spacing: 0.5px;
}
.powered-by-klete {
  display: flex; align-items: center; gap: 6px;
  text-decoration: none; color: var(--text-muted); font-size: 11px;
  transition: color 0.2s, opacity 0.2s; opacity: 0.7;
}
.powered-by-klete:hover { opacity: 1; color: var(--text-secondary); }
.powered-by-klete img { display: block; }
.powered-by-klete strong { color: var(--text-secondary); font-weight: 600; }

/* === Accessibility: Reduced Motion === */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .card { opacity: 1 !important; transform: none !important; }
}

/* === Responsive === */
@media (max-width: 1100px) {
  .header-center { order: 3; flex-basis: 100%; }
  .district-selector select { width: 100%; }
}
@media (max-width: 900px) {
  .dashboard-grid { grid-template-columns: 1fr; padding: 16px; gap: 16px; }
  .card-map, .card-metrics, .card-goals, .card-scenario, .card-walkability, .card-ai, .card-ai-steps, .card-wide, .card-house-race, .card-candidate, .card-reputation, .card-social { grid-column: 1 / -1; }
  .reputation-input-bar { flex-direction: column; }
  .reputation-scan-btn { justify-content: center; }
  .dashboard-header { padding: 12px 16px; gap: 12px; }
  .header-left h1 { font-size: 22px; }
  .header-right { gap: 10px; flex-wrap: nowrap; }
  .header-avatar-btn { width: 34px; height: 34px; font-size: 12px; }
  .header-info-btn { display: flex; }
  .header-stat { display: none; }
  .mobile-stats-drawer { display: block; }
  .header-dropdown {
    position: fixed; top: auto; right: 0; left: 0; bottom: 0;
    width: 100%; max-width: 100%; border-radius: 16px 16px 0 0;
    transform: translateY(100%);
  }
  .header-dropdown.open { transform: translateY(0); }
  .header-dropdown-item { padding: 14px 20px; font-size: 15px; }
  .header-dropdown-user { padding: 18px 20px; }
  .card { padding: 16px; }
  .card-header-row { position: relative; }
  .card-header-row .chart-menu-wrap { position: absolute; top: 0; right: 0; }
  #map { height: 300px; }
  .chart-container, .chart-container-wide { height: 250px; }
  .metrics-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .metric-tile { padding: 10px 12px; }
  .metric-tile .metric-value { font-size: 18px; }
  #vote-goals { grid-template-columns: 1fr 1fr; }
  #walkability-cards { grid-template-columns: 1fr; }
  .map-legend { gap: 10px; font-size: 11px; }
  .dashboard-section-header h2 { font-size: 13px; letter-spacing: 1.2px; }
  .dashboard-section-subtitle { font-size: 11px; }
  .year-panel { grid-template-columns: 1fr; }
  .year-tab { padding: 5px 14px; font-size: 12px; }
  /* Finance/Polling responsive - tablet */
  .finance-metrics { grid-template-columns: 1fr; }
  .finance-metric-grid { grid-template-columns: repeat(3, 1fr); }
  .finance-donor-charts { grid-template-columns: 1fr; }
  .finance-industry-grid { grid-template-columns: 1fr; }
  .finance-quarterly-grid { grid-template-columns: 1fr; }
  .polling-avg-pct { font-size: 26px !important; }
  .polling-avg-margin, .polling-result-margin { font-size: 14px; }
  .polling-table { font-size: 11px; }
  .polling-table th, .polling-table td { padding: 6px 6px; }
  .finance-donor-table { font-size: 11px; }
  .finance-donor-table th, .finance-donor-table td { padding: 6px 8px; }
}
@media (max-width: 500px) {
  .dashboard-grid { padding: 10px; gap: 12px; }
  .dashboard-header { padding: 10px 12px; }
  .header-left h1 { font-size: 18px; }
  .header-center { padding: 0 4px; }
  .district-selector select { min-width: 0; width: 100%; font-size: 12px; padding: 6px 28px 6px 10px; }
  .header-right { gap: 8px; }
  .header-avatar-btn { width: 32px; height: 32px; font-size: 11px; }
  .header-info-btn { width: 32px; height: 32px; }
  .metrics-grid { grid-template-columns: 1fr; }
  #vote-goals { grid-template-columns: 1fr; }
  .card { padding: 14px; border-radius: 10px; }
  #map { height: 240px; }
  .chart-container, .chart-container-wide { height: 220px; }
  .ai-summary li { padding: 8px 10px 8px 26px; font-size: 13px; }
  .ai-summary li::before { left: 10px; top: 14px; }
  .modal-content { padding: 24px 20px; margin: 0 16px; }
  .claude-fab { bottom: 16px; right: 16px; width: 48px; height: 48px; }
  .claude-fab svg { width: 26px; height: 26px; }
  .claude-drawer { width: 100%; right: -100%; }
  .claude-drawer.open { right: 0; }
  .dashboard-section-header { flex-direction: column; gap: 2px; align-items: flex-start; }
  .overview-default-label { margin-left: 0; font-size: 11px; }
  /* Touch targets: minimum 44px for mobile accessibility */
  .chart-menu-btn { min-width: 44px; min-height: 44px; }
  .sidebar-close, .sidebar-logout-btn { width: 44px; height: 44px; }
  .copy-link-btn { min-width: 44px; min-height: 44px; }
  .admin-action-btn { width: 44px; height: 44px; }
  .analyzer-reset-btn { min-height: 44px; padding: 8px 14px; }
  .scenario-reset-btn { min-height: 44px; padding: 8px 16px; }
  .scenario-range::-webkit-slider-thumb { width: 28px; height: 28px; }
  .scenario-range::-moz-range-thumb { width: 28px; height: 28px; }
  .claude-header-btn, .claude-drawer-close { min-width: 44px; min-height: 44px; }
  .claude-send-btn { min-width: 44px; min-height: 44px; }
  .pw-toggle-btn { min-width: 44px; min-height: 44px; }
  .panel-close-btn { min-width: 44px; min-height: 44px; }
  .dashboard-section-header h2 { font-size: 12px; }
  /* Finance/Polling responsive - mobile */
  .finance-overview, .polling-overview { padding: 0 10px 16px; }
  .finance-metric-grid { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .finance-metric-value { font-size: 13px; }
  .finance-metric-label { font-size: 9px; }
  .finance-candidate-name { font-size: 12px; }
  .finance-party-badge { font-size: 9px; padding: 1px 6px; }
  .finance-bar-wrap { height: 24px; }
  .finance-bar-label { font-size: 11px; right: 6px; }
  .finance-stacked-bar { height: 16px; }
  .finance-legend-item { font-size: 10px; }
  .finance-donor-table th, .finance-donor-table td { padding: 5px 6px; font-size: 10px; }
  .finance-type-badge { font-size: 8px; padding: 1px 4px; }
  .finance-section-title, .polling-section-title { font-size: 11px; margin: 16px 0 8px; }
  .finance-industry-name { min-width: 80px; font-size: 10px; }
  .finance-industry-amount { font-size: 10px; min-width: 40px; }
  .finance-quarterly-label { font-size: 10px; min-width: 48px; }
  .finance-quarterly-amount { font-size: 10px; min-width: 40px; }
  .polling-avg-candidates { gap: 12px; }
  .polling-avg-pct { font-size: 22px !important; }
  .polling-avg-margin, .polling-result-margin { font-size: 12px; padding: 4px 10px; }
  .polling-avg-label { font-size: 9px; }
  .polling-rating-timeline { gap: 6px; }
  .polling-rating-item { padding: 6px 8px; gap: 4px; }
  .polling-rating-date { font-size: 9px; }
  .polling-rating-badge { font-size: 9px; padding: 2px 5px; }
  .polling-rating-source { font-size: 9px; }
  .polling-chart-container { height: 200px; }
  .polling-table { font-size: 10px; }
  .polling-table th, .polling-table td { padding: 5px 4px; }
  .polling-table th:nth-child(3), .polling-table td:nth-child(3) { display: none; }
  .polling-table th:nth-child(7), .polling-table td:nth-child(7) { display: none; }
  .polling-margin-badge { font-size: 9px; padding: 1px 5px; }
  .dashboard-footer { padding: 16px 12px 20px; }
  .footer-row { flex-direction: column; align-items: flex-start; gap: 8px; }
  .footer-content { gap: 8px; }
  .footer-brand-logo { height: 16px; }
  .powered-by-klete { font-size: 10px; }
}

/* === Revere AI Drawer — FAB + label === */
.claude-fab {
  position: fixed; bottom: 24px; right: 24px; z-index: 1100;
  width: 60px; height: 60px; border-radius: 50%;
  background: linear-gradient(135deg, var(--brand-red), #8c1729);
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 24px rgba(190, 32, 57, 0.45);
  transition: transform 0.3s, box-shadow 0.3s;
}
.claude-fab:hover { transform: scale(1.1); box-shadow: 0 6px 32px rgba(190, 32, 57, 0.6); }
.claude-fab:hover .claude-fab-label { opacity: 1; transform: translateX(0); }
.claude-fab svg { width: 40px; height: 40px; position: relative; z-index: 2; }

/* Strobing pulse ring behind the robot */
.claude-fab-pulse {
  position: absolute; width: 100%; height: 100%; border-radius: 50%;
  background: rgba(190, 32, 57, 0.35);
  animation: fab-pulse 2s ease-out infinite;
}
@keyframes fab-pulse { 0% { transform: scale(1); opacity: 0.7; } 100% { transform: scale(1.8); opacity: 0; } }

/* "Ask Revere" pill label to the left of the FAB. Pulses gently
   to draw attention, expands on hover/focus. */
.claude-fab-label {
  position: absolute;
  right: calc(100% + 14px);
  top: 50%;
  transform: translateY(-50%) translateX(6px);
  background: var(--bg-card);
  color: var(--text-primary);
  border: 1px solid var(--brand-red);
  padding: 8px 14px;
  border-radius: 24px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.3px;
  white-space: nowrap;
  box-shadow: 0 4px 16px rgba(190, 32, 57, 0.25);
  pointer-events: none;
  opacity: 0.92;
  animation: fab-label-float 3.2s ease-in-out infinite;
  transition: opacity 0.2s, transform 0.25s cubic-bezier(0.22, 1, 0.36, 1);
}
.claude-fab-label::after {
  /* small triangular pointer to the FAB */
  content: '';
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  border: 6px solid transparent;
  border-left-color: var(--brand-red);
}
@keyframes fab-label-float {
  0%, 100% { transform: translateY(-50%) translateX(0); }
  50% { transform: translateY(-50%) translateX(-4px); }
}

@media (max-width: 700px) {
  .claude-fab-label { display: none; }
}

.claude-drawer-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 1500;
  background: rgba(0,0,0,0.5); backdrop-filter: blur(3px);
  opacity: 0; visibility: hidden; transition: opacity 0.3s, visibility 0.3s;
}
.claude-drawer-overlay.open { opacity: 1; visibility: visible; }

.claude-drawer {
  position: fixed; top: 0; bottom: 0; right: -400px; z-index: 1600;
  width: 400px; background: var(--bg-secondary);
  border-left: 1px solid var(--border);
  display: flex; flex-direction: column;
  box-shadow: -8px 0 40px var(--overlay-strong);
  transition: right 0.35s cubic-bezier(0.16,1,0.3,1);
}
.claude-drawer.open { right: 0; }

.claude-drawer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; border-bottom: 1px solid var(--border);
  background: var(--bg-card); flex-shrink: 0;
}
.claude-drawer-header h3 { font-size: 15px; font-weight: 600; display: flex; align-items: baseline; gap: 8px; }
.claude-drawer-header h3 svg { width: 26px; height: 26px; color: var(--brand-red); align-self: center; }
.claude-drawer-header h3 .revere-title { font-size: 16px; font-weight: 700; color: var(--text-primary); letter-spacing: 0.2px; }
.claude-drawer-header h3 .revere-subtitle { font-size: 11px; font-weight: 500; color: var(--text-muted-large); text-transform: uppercase; letter-spacing: 0.8px; }
.claude-drawer-close {
  width: 32px; height: 32px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--bg-inset); color: var(--text-muted); cursor: pointer;
  display: flex; align-items: center; justify-content: center; font-size: 18px;
  transition: all 0.2s;
}
.claude-drawer-close:hover { color: var(--text-primary); border-color: var(--accent-blue); }

/* Claude Chat - Drawer Layout */
.claude-drawer-actions { display: flex; align-items: center; gap: 6px; }
.claude-header-btn {
  width: 32px; height: 32px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--bg-inset); color: var(--text-muted); cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.claude-header-btn:hover { color: var(--text-primary); border-color: var(--accent-blue); }

/* Settings Panel */
.claude-settings-panel {
  padding: 0; max-height: 0; overflow: hidden;
  border-bottom: none; background: var(--bg-card);
  transition: max-height 0.3s ease, padding 0.3s ease, border-bottom 0.3s ease;
}
.claude-settings-panel.open {
  padding: 16px 20px; max-height: 300px;
  border-bottom: 1px solid var(--border);
}
.claude-settings-field { margin-bottom: 10px; }
.claude-settings-field label {
  display: block; font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.8px; color: var(--text-muted); margin-bottom: 4px;
}
.claude-settings-field input {
  width: 100%; padding: 8px 12px; background: var(--bg-inset);
  border: 1px solid var(--border); border-radius: 8px;
  color: var(--text-primary); font-size: 13px; font-family: inherit;
}
.claude-settings-field input:focus { outline: none; border-color: var(--accent-blue); }
.claude-settings-actions { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.claude-settings-save {
  padding: 6px 16px; background: linear-gradient(135deg, var(--brand-red), #8c1729);
  border: none; border-radius: 6px; color: #fff; font-size: 12px;
  font-weight: 600; cursor: pointer; transition: opacity 0.2s;
}
.claude-settings-save:hover { opacity: 0.9; }
.claude-save-note {
  font-size: 12px; color: var(--accent-green); font-weight: 600;
  opacity: 0; transition: opacity 0.2s;
}
.claude-save-note.show { opacity: 1; }
.claude-settings-note { font-size: 11px; color: var(--text-muted); margin: 0; }

/* Messages */
.claude-messages {
  flex: 1; overflow-y: auto; padding: 16px 20px;
  display: flex; flex-direction: column; gap: 12px;
}
.claude-msg {
  padding: 10px 14px; border-radius: 12px; font-size: 13px; line-height: 1.6;
  max-width: 90%; word-wrap: break-word; animation: msg-in 0.2s ease;
}
@keyframes msg-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
.claude-msg.user {
  align-self: flex-end; background: var(--glow-blue); color: var(--accent-blue);
  border-bottom-right-radius: 4px; white-space: pre-wrap;
}
.claude-msg.assistant {
  position: relative;
  align-self: flex-start; background: var(--bg-inset); color: var(--text-secondary);
  border-bottom-left-radius: 4px; border: 1px solid var(--border);
}
.claude-msg.assistant p { margin: 0 0 8px 0; }
.claude-msg.assistant p:last-child { margin-bottom: 0; }
.claude-msg.assistant strong { color: var(--text-primary); }
.claude-msg.assistant h3 { font-size: 14px; color: var(--text-primary); margin: 12px 0 6px; }
.claude-msg.assistant h4 { font-size: 13px; color: var(--text-primary); margin: 10px 0 4px; }
.claude-msg.assistant ul, .claude-msg.assistant ol {
  margin: 6px 0; padding-left: 20px;
}
.claude-msg.assistant li { margin-bottom: 4px; }
.claude-msg.assistant code {
  background: rgba(78,143,247,0.1); padding: 1px 5px; border-radius: 3px;
  font-size: 12px; color: var(--accent-cyan);
}
.claude-msg.error {
  align-self: center; background: var(--state-error-soft); color: var(--state-error);
  border: 1px solid rgba(239, 68, 68, 0.2); border-radius: 8px; text-align: center;
  max-width: 100%; font-size: 12px;
}

/* Typing indicator */
.claude-typing { display: flex; gap: 4px; padding: 4px 0; }
.claude-typing span {
  width: 6px; height: 6px; border-radius: 50%; background: var(--text-muted);
  animation: typing-dot 1.2s ease-in-out infinite;
}
.claude-typing span:nth-child(2) { animation-delay: 0.2s; }
.claude-typing span:nth-child(3) { animation-delay: 0.4s; }
@keyframes typing-dot { 0%, 60%, 100% { opacity: 0.3; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-4px); } }

/* Welcome screen */
.claude-welcome { text-align: center; padding: 24px 8px; }
.claude-welcome-icon { margin: 0 auto 16px; }
.claude-welcome-icon svg { width: 56px; height: 56px; color: var(--brand-red); }
/* Shared Revere R monogram — resolves currentColor via the containing
   element's `color` so the same SVG works on FAB, drawer header, and
   welcome card with different fill colors per context. */
.revere-r-icon { color: var(--brand-red); }
.claude-fab .revere-r-icon { color: #fff; }
.claude-fab .revere-r-icon text {
  /* Subtle drop shadow to separate the R from the red background */
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.25));
}
.claude-welcome h4 { font-size: 16px; font-weight: 700; color: var(--text-primary); margin-bottom: 8px; }
.claude-welcome p { font-size: 13px; color: var(--text-secondary); line-height: 1.6; margin-bottom: 20px; }
.claude-suggestions { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.claude-suggestion {
  padding: 8px 14px; background: var(--bg-inset); border: 1px solid var(--border);
  border-radius: 20px; color: var(--text-secondary); font-size: 12px;
  font-family: inherit; cursor: pointer; transition: all 0.2s;
}
.claude-suggestion:hover { border-color: var(--brand-red); color: var(--brand-red); background: rgba(190, 32, 57, 0.08); }

/* Input bar */
.claude-input-bar {
  display: flex; align-items: flex-end; gap: 8px;
  padding: 12px 16px; border-top: 1px solid var(--border);
  background: var(--bg-card); flex-shrink: 0;
}
.claude-input-bar textarea {
  flex: 1; padding: 10px 14px; background: var(--bg-inset);
  border: 1px solid var(--border); border-radius: 10px;
  color: var(--text-primary); font-size: 13px; font-family: inherit;
  resize: none; line-height: 1.4; max-height: 120px;
}
.claude-input-bar textarea:focus { outline: none; border-color: var(--brand-red); }
.claude-input-bar textarea::placeholder { color: var(--text-muted); }
.claude-send-btn {
  width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--brand-red), #8c1729);
  border: none; color: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: opacity 0.2s, transform 0.2s;
}
.claude-send-btn:hover { transform: scale(1.05); }
.claude-send-btn:disabled { opacity: 0.5; cursor: default; transform: none; }

/* Chat message copy button */
.claude-msg-copy {
  position: sticky; bottom: 4px; float: right;
  margin-top: -4px; margin-right: -4px;
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--accent-blue); border: none;
  color: #fff; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.2s, background 0.2s, transform 0.15s;
  box-shadow: 0 2px 8px rgba(78,143,247,0.3);
}
.claude-msg:hover .claude-msg-copy { opacity: 0.85; }
.claude-msg-copy:hover { opacity: 1 !important; background: var(--accent-cyan); transform: scale(1.1); }

/* ============================================================
   TIER 2: Candidate Tracker
   ============================================================ */
.tracker-overview { padding: 0 4px; }
.tracker-stats {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px;
  margin-bottom: 20px;
}
.tracker-stat {
  background: var(--bg-inset); border-radius: 10px; padding: 14px 12px;
  text-align: center; border: 1px solid var(--border);
}
.tracker-stat-value { font-size: 22px; font-weight: 700; color: var(--text-primary); }
.tracker-stat-label { font-size: 11px; color: var(--text-muted); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.5px; }

.tracker-toolbar {
  display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
  margin-bottom: 16px; padding: 12px 14px;
  background: var(--bg-inset); border-radius: 10px; border: 1px solid var(--border);
}
.tracker-search-wrap {
  position: relative; flex: 1; min-width: 180px;
}
.tracker-search-icon { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); color: var(--text-muted); pointer-events: none; }
.tracker-search {
  width: 100%; padding: 8px 10px 8px 32px; border-radius: 6px;
  background: var(--bg-card); border: 1px solid var(--border); color: var(--text-primary);
  font-size: 13px; outline: none; box-sizing: border-box;
}
.tracker-search:focus { border-color: var(--accent-blue); }
.tracker-filter {
  padding: 8px 10px; border-radius: 6px; background: var(--bg-card);
  border: 1px solid var(--border); color: var(--text-primary); font-size: 12px;
  cursor: pointer; outline: none;
}
.tracker-filter:focus { border-color: var(--accent-blue); }
.tracker-add-btn {
  display: flex; align-items: center; gap: 6px; padding: 8px 16px;
  background: var(--accent-blue); border: none; border-radius: 6px;
  color: #fff; font-size: 12px; font-weight: 600; cursor: pointer;
  white-space: nowrap; transition: background 0.2s; font-family: inherit;
}
.tracker-add-btn:hover { background: #3a7de8; }

/* Sync button */
.tracker-sync-btn {
  display: flex; align-items: center; gap: 6px; padding: 8px 14px;
  background: rgba(90, 158, 255, 0.12); border: 1px solid var(--accent-blue);
  border-radius: 6px; color: var(--accent-blue); font-size: 12px;
  font-weight: 600; cursor: pointer; white-space: nowrap;
  transition: background 0.2s, opacity 0.2s; font-family: inherit;
}
.tracker-sync-btn:hover { background: rgba(90, 158, 255, 0.22); }
.tracker-sync-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.tracker-sync-btn svg.spin { animation: syncSpin 1s linear infinite; }
@keyframes syncSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* Sync status area */
.tracker-sync-status {
  padding: 10px 14px; border-radius: 8px; font-size: 12px;
  margin-bottom: 12px; animation: fadeSlideDown 0.25s ease-out;
}
.tracker-sync-status.syncing {
  background: var(--accent-blue-soft); border: 1px solid rgba(90, 158, 255, 0.2);
  color: var(--accent-blue);
}
.tracker-sync-status.sync-success {
  background: rgba(72, 199, 142, 0.08); border: 1px solid rgba(72, 199, 142, 0.2);
  color: #48c78e;
}
.tracker-sync-status.sync-error {
  background: rgba(255, 99, 71, 0.08); border: 1px solid rgba(255, 99, 71, 0.2);
  color: #ff6347;
}
.sync-step { padding: 2px 0; }
.sync-done::before { content: '✓ '; }
.sync-error::before { content: '✗ '; }

/* Add form */
.tracker-add-form {
  background: var(--bg-inset); border: 1px solid var(--accent-blue);
  border-radius: 10px; padding: 20px; margin-bottom: 16px;
  animation: fadeSlideDown 0.25s ease-out;
}
@keyframes fadeSlideDown { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.tracker-form-title { font-size: 14px; font-weight: 700; color: var(--text-primary); margin-bottom: 14px; }
.tracker-form-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin-bottom: 14px; }
.tracker-input {
  padding: 9px 12px; border-radius: 6px; background: var(--bg-card);
  border: 1px solid var(--border); color: var(--text-primary); font-size: 13px;
  outline: none; box-sizing: border-box;
}
.tracker-input:focus { border-color: var(--accent-blue); }
.tracker-form-actions { display: flex; justify-content: flex-end; gap: 10px; }
.tracker-form-cancel {
  padding: 8px 18px; border-radius: 6px; background: transparent;
  border: 1px solid var(--border); color: var(--text-secondary); cursor: pointer;
  font-size: 13px; font-family: inherit;
}
.tracker-form-cancel:hover { border-color: var(--text-muted); }
.tracker-form-save {
  padding: 8px 20px; border-radius: 6px; background: var(--accent-green);
  border: none; color: #fff; font-weight: 600; cursor: pointer; font-size: 13px; font-family: inherit;
}
.tracker-form-save:hover { background: #2bc48a; }

/* Candidate cards grid */
.tracker-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 14px; }
.tracker-card {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 12px;
  overflow: hidden; transition: border-color 0.2s, box-shadow 0.2s, transform 0.2s;
  position: relative;
}
.tracker-card:hover { border-color: var(--border-light); box-shadow: 0 4px 20px rgba(0,0,0,0.25); transform: translateY(-2px); }
.tracker-card.party-dem { border-left: 3px solid var(--accent-blue); }
.tracker-card.party-rep { border-left: 3px solid var(--accent-red); }
.tracker-card.party-other { border-left: 3px solid var(--accent-purple); }

.tracker-card-header { display: flex; align-items: center; gap: 12px; padding: 14px 16px 10px; }
.tracker-avatar {
  width: 40px; height: 40px; border-radius: 50%; display: flex;
  align-items: center; justify-content: center; font-weight: 700;
  font-size: 14px; color: #fff; flex-shrink: 0;
}
.tracker-avatar.party-dem { background: var(--accent-blue); }
.tracker-avatar.party-rep { background: var(--accent-red); }
.tracker-avatar.party-other { background: var(--accent-purple); }
.tracker-card-info { flex: 1; min-width: 0; }
.tracker-card-name { font-size: 14px; font-weight: 700; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tracker-card-office { font-size: 11px; color: var(--text-muted); margin-top: 1px; }
.tracker-card-badges { display: flex; gap: 6px; flex-shrink: 0; }
.tracker-status-badge {
  font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 4px;
  text-transform: uppercase; letter-spacing: 0.3px;
}
.status-filed { background: var(--accent-green-soft); color: var(--accent-green); }
.status-active { background: rgba(78,143,247,0.15); color: var(--accent-blue); }
.status-likely { background: var(--accent-amber-soft); color: var(--accent-amber); }
.status-exploring { background: rgba(176,124,247,0.15); color: var(--accent-purple); }
.status-withdrawn { background: rgba(239, 68, 68, 0.15); color: var(--state-error); }
.tracker-incumbent-badge {
  font-size: 10px; font-weight: 600; padding: 3px 8px; border-radius: 4px;
  background: rgba(34,211,238,0.12); color: var(--accent-cyan);
  text-transform: uppercase; letter-spacing: 0.3px;
}

.tracker-card-body {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px 16px;
  padding: 0 16px 14px;
}
.tracker-card-detail { display: flex; justify-content: space-between; align-items: center; }
.tracker-detail-label { font-size: 11px; color: var(--text-muted); }
.tracker-detail-value { font-size: 12px; font-weight: 600; color: var(--text-secondary); }
.tracker-detail-value.party-dem { color: var(--accent-blue); }
.tracker-detail-value.party-rep { color: var(--accent-red); }
.tracker-detail-value.party-other { color: var(--accent-purple); }

.tracker-card-actions {
  position: absolute; top: 10px; right: 10px;
}
.tracker-delete-btn {
  background: transparent; border: 1px solid transparent; border-radius: 4px;
  color: var(--text-muted); cursor: pointer; padding: 4px 6px;
  opacity: 0; transition: opacity 0.2s, color 0.2s;
}
.tracker-card:hover .tracker-delete-btn { opacity: 0.6; }
.tracker-delete-btn:hover { opacity: 1 !important; color: var(--state-error); border-color: var(--state-error); }

.tracker-footer {
  margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--border);
  text-align: center; font-size: 11px; color: var(--text-muted);
}
.tracker-empty {
  text-align: center; padding: 40px 20px; color: var(--text-muted); font-size: 14px;
}
/* Tracker card drilldown */
.tracker-card.expanded { border-color: var(--accent-blue); box-shadow: 0 4px 20px rgba(90,158,255,0.1); }
.tracker-card-drilldown {
  padding: 14px 16px 4px; border-top: 1px solid var(--border);
  animation: detailExpand 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.tracker-card-drilldown .race-detail-stats { margin-bottom: 10px; }
.tracker-card-drilldown .race-detail-analyze-btn { margin-bottom: 10px; }


/* ============================================================
   TIER 2: Candidate Scorecards
   ============================================================ */
.scorecard-overview { padding: 0 4px; }
.scorecard-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: 16px; }
.scorecard-card {
  background: var(--bg-inset); border: 1px solid var(--border); border-radius: 14px;
  overflow: hidden; padding: 20px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.scorecard-card:hover { border-color: var(--border-light); box-shadow: 0 4px 20px rgba(0,0,0,0.2); }
.scorecard-card.party-dem { border-top: 3px solid var(--accent-blue); }
.scorecard-card.party-rep { border-top: 3px solid var(--accent-red); }
.scorecard-card.party-other { border-top: 3px solid var(--accent-purple); }

.scorecard-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.scorecard-candidate { display: flex; align-items: center; gap: 12px; }
.scorecard-avatar {
  width: 44px; height: 44px; border-radius: 50%; display: flex;
  align-items: center; justify-content: center; font-weight: 700;
  font-size: 15px; color: #fff;
}
.scorecard-avatar.party-dem { background: var(--accent-blue); }
.scorecard-avatar.party-rep { background: var(--accent-red); }
.scorecard-avatar.party-other { background: var(--accent-purple); }
.scorecard-name { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.scorecard-party { font-size: 11px; color: var(--text-muted); margin-top: 2px; }

.scorecard-ring-wrap { flex-shrink: 0; }
.scorecard-ring { position: relative; width: 80px; height: 80px; }
.scorecard-ring-svg { width: 100%; height: 100%; }
.scorecard-ring-progress { transition: stroke-dashoffset 1s ease-out; }
.scorecard-ring-value {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -60%);
  font-size: 22px; font-weight: 800; color: var(--text-primary);
}
.scorecard-ring-label {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, 50%);
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
}
.score-safe { color: var(--accent-green); }
.score-likely { color: var(--accent-blue); }
.score-lean { color: var(--accent-amber); }
.score-tossup { color: var(--accent-purple); }
.score-underdog { color: var(--accent-red); }

.scorecard-components { margin-bottom: 16px; }
.scorecard-comp { margin-bottom: 10px; }
.scorecard-comp-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.scorecard-comp-label { font-size: 12px; color: var(--text-secondary); }
.scorecard-comp-weight { font-size: 10px; color: var(--text-muted); }
.scorecard-comp-value { font-size: 13px; font-weight: 700; color: var(--text-primary); }
.scorecard-comp-bar-bg {
  height: 6px; background: rgba(47,53,80,0.6); border-radius: 3px; overflow: hidden;
}
.scorecard-comp-bar {
  height: 100%; border-radius: 3px; transition: width 0.8s ease-out;
}
.scorecard-comp-detail { font-size: 10px; color: var(--text-muted); margin-top: 2px; }
.scorecard-radar-wrap { height: 200px; margin-top: 8px; }
.scorecard-empty { text-align: center; padding: 40px 20px; color: var(--text-muted); }
.scorecard-empty-sub { font-size: 12px; margin-top: 8px; color: var(--text-muted); }

/* ============================================================
   TIER 2: District Comparison Mode
   ============================================================ */
.comparison-overview { padding: 0 4px; }
.comparison-selectors {
  display: flex; gap: 12px; align-items: center; justify-content: center;
  margin-bottom: 20px; flex-wrap: wrap;
}
.comparison-select-group { display: flex; align-items: center; gap: 8px; }
.comparison-select-label {
  font-size: 12px; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.5px;
}
.comparison-select {
  padding: 8px 12px; border-radius: 8px; background: var(--bg-inset);
  border: 1px solid var(--border); color: var(--text-primary); font-size: 13px;
  cursor: pointer; outline: none; min-width: 80px;
}
.comparison-select:focus { border-color: var(--accent-blue); }
.comparison-vs {
  font-size: 16px; font-weight: 800; color: var(--accent-purple);
  padding: 0 8px;
}
.comparison-grid {
  display: grid; grid-template-columns: 1fr 60px 1fr; gap: 0;
}
.comparison-col { }
.comparison-divider {
  display: flex; flex-direction: column; align-items: center;
  padding-top: 10px;
}
.comparison-divider-line {
  width: 2px; flex: 1; background: var(--border);
}
.comparison-row {
  display: contents;
}
.comparison-metric {
  padding: 10px 16px; border-bottom: 1px solid rgba(30,63,106,0.4);
  display: flex; flex-direction: column;
}
.comparison-metric-label {
  font-size: 10px; color: var(--text-muted); text-transform: uppercase;
  letter-spacing: 0.5px; margin-bottom: 4px;
}
.comparison-metric-value {
  font-size: 18px; font-weight: 700; color: var(--text-primary);
}
.comparison-metric-sub { font-size: 11px; color: var(--text-muted); }
.comparison-delta-label {
  font-size: 9px; color: var(--text-muted); text-transform: uppercase;
  letter-spacing: 0.5px; margin-bottom: 2px; text-align: center;
}
.comparison-delta {
  padding: 10px 4px; border-bottom: 1px solid rgba(30,63,106,0.4);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}
.comparison-delta.positive { color: var(--accent-green); }
.comparison-delta.negative { color: var(--accent-red); }
.comparison-delta.neutral { color: var(--text-muted); }
.comparison-header-row {
  display: contents;
}
.comparison-header-cell {
  background: var(--bg-inset); padding: 14px 16px; border-radius: 10px 10px 0 0;
  border: 1px solid var(--border); border-bottom: none;
  text-align: center;
}
.comparison-header-district {
  font-size: 16px; font-weight: 700; color: var(--text-primary);
}
.comparison-header-sub { font-size: 11px; color: var(--text-muted); }
.comparison-empty { text-align: center; padding: 40px 20px; color: var(--text-muted); }
.comparison-charts-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 20px;
}
.comparison-chart-wrap {
  background: var(--bg-inset); border-radius: 10px; border: 1px solid var(--border);
  padding: 16px;
}
.comparison-chart-title {
  font-size: 12px; font-weight: 700; color: var(--text-secondary);
  margin-bottom: 10px; text-align: center;
}
.comparison-chart-canvas { height: 180px; }

/* ============================================================
   TIER 2: Ballot Tracker
   ============================================================ */
.ballot-overview { padding: 0 4px; }
.ballot-countdown {
  display: flex; gap: 16px; align-items: center; justify-content: center;
  margin-bottom: 24px; padding: 20px;
  background: linear-gradient(135deg, rgba(78,143,247,0.08), rgba(176,124,247,0.08));
  border-radius: 14px; border: 1px solid var(--border);
}
.ballot-countdown-unit {
  text-align: center; min-width: 60px;
}
.ballot-countdown-value {
  font-size: 32px; font-weight: 800; color: var(--text-primary);
  line-height: 1;
}
.ballot-countdown-label {
  font-size: 10px; color: var(--text-muted); text-transform: uppercase;
  letter-spacing: 0.5px; margin-top: 4px;
}
.ballot-countdown-colon {
  font-size: 28px; font-weight: 700; color: var(--text-muted); margin-top: -8px;
}
.ballot-status-banner {
  text-align: center; padding: 16px; margin-bottom: 20px;
  background: var(--bg-inset); border-radius: 10px; border: 1px solid var(--border);
}
.ballot-status-text {
  font-size: 13px; color: var(--text-secondary); line-height: 1.6;
}
.ballot-status-text strong { color: var(--accent-cyan); }
.ballot-mock-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px;
}
.ballot-precinct-card {
  background: var(--bg-inset); border-radius: 10px; border: 1px solid var(--border);
  padding: 14px; opacity: 0.5;
}
.ballot-precinct-header {
  display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px;
}
.ballot-precinct-name { font-size: 13px; font-weight: 700; color: var(--text-primary); }
.ballot-precinct-pct { font-size: 14px; font-weight: 700; color: var(--text-muted); }
.ballot-precinct-bar-bg {
  height: 8px; background: rgba(47,53,80,0.6); border-radius: 4px; overflow: hidden;
}
.ballot-precinct-bar {
  height: 100%; border-radius: 4px; background: var(--text-muted);
  transition: width 0.6s ease-out;
}
.ballot-precinct-detail {
  display: flex; justify-content: space-between; font-size: 10px;
  color: var(--text-muted); margin-top: 6px;
}
.ballot-phase-timeline {
  display: flex; gap: 0; margin: 24px 0; position: relative;
}
.ballot-phase {
  flex: 1; text-align: center; padding: 14px 8px;
  background: var(--bg-inset); border: 1px solid var(--border);
  position: relative;
}
.ballot-phase:first-child { border-radius: 10px 0 0 10px; }
.ballot-phase:last-child { border-radius: 0 10px 10px 0; }
.ballot-phase.active {
  border-color: var(--brand-red);
  background: rgba(190, 32, 57, 0.10);
}
.ballot-phase-label {
  font-size: 11px; font-weight: 700; color: var(--text-secondary);
}
.ballot-phase-date {
  font-size: 10px; color: var(--text-muted); margin-top: 2px;
}
.ballot-phase.active .ballot-phase-label { color: var(--brand-red); }

/* ============================================================
   TIER 2: Alert System
   ============================================================ */
.alert-overview { padding: 0 4px; }
.alert-toolbar {
  display: flex; gap: 10px; align-items: center; margin-bottom: 16px;
  flex-wrap: wrap;
}
.alert-filter-btn {
  padding: 6px 14px; border-radius: 6px; background: var(--bg-inset);
  border: 1px solid var(--border); color: var(--text-secondary);
  font-size: 12px; cursor: pointer; transition: all 0.2s;
}
.alert-filter-btn.active {
  background: rgba(78,143,247,0.12); border-color: var(--accent-blue);
  color: var(--accent-blue); font-weight: 600;
}
.alert-filter-btn:hover { border-color: var(--border-light); }
.alert-clear-btn {
  margin-left: auto; padding: 6px 14px; border-radius: 6px;
  background: transparent; border: 1px solid var(--border);
  color: var(--text-muted); font-size: 12px; cursor: pointer; font-family: inherit;
}
.alert-clear-btn:hover { color: var(--state-error); border-color: var(--state-error); }

.alert-feed { max-height: 500px; overflow-y: auto; }
.alert-item {
  display: flex; gap: 14px; padding: 14px 16px;
  border-bottom: 1px solid rgba(30,63,106,0.3);
  transition: background 0.15s;
}
.alert-item:hover { background: rgba(78,143,247,0.04); }
.alert-item.unread { border-left: 3px solid var(--accent-blue); }

/* Severity color-coded left border */
.alert-item.alert-severity-critical.unread { border-left-color: #e74c3c; }
.alert-item.alert-severity-warning.unread { border-left-color: #f39c12; }
.alert-item.alert-severity-info.unread { border-left-color: var(--accent-blue); }

/* Severity badge in alert title row */
.alert-title-row { display: flex; align-items: center; gap: 6px; }
.alert-severity-badge {
  font-size: 9px; font-weight: 700; letter-spacing: 0.5px;
  padding: 1px 6px; border-radius: 3px; text-transform: uppercase;
  flex-shrink: 0;
}
.alert-sev-critical { background: rgba(231,76,60,0.15); color: #e74c3c; }
.alert-sev-warning { background: rgba(243,156,18,0.15); color: #f39c12; }

.alert-icon-wrap {
  width: 36px; height: 36px; border-radius: 10px; display: flex;
  align-items: center; justify-content: center; flex-shrink: 0;
}
.alert-icon-wrap.alert-type-candidate { background: rgba(78,143,247,0.12); color: var(--accent-blue); }
.alert-icon-wrap.alert-type-finance { background: rgba(52,211,153,0.12); color: var(--accent-green); }
.alert-icon-wrap.alert-type-polling { background: rgba(176,124,247,0.12); color: var(--accent-purple); }
.alert-icon-wrap.alert-type-filing { background: rgba(251,191,36,0.12); color: var(--accent-amber); }
.alert-icon-wrap.alert-type-system { background: rgba(34,211,238,0.12); color: var(--accent-cyan); }
.alert-icon-wrap.alert-type-activity { background: rgba(78,143,247,0.12); color: var(--accent-blue); }
.alert-icon-wrap.alert-type-announcement { background: rgba(243,156,18,0.12); color: var(--accent-amber); }
.alert-body { flex: 1; min-width: 0; }
.alert-title { font-size: 13px; font-weight: 700; color: var(--text-primary); }
.alert-message { font-size: 12px; color: var(--text-secondary); margin-top: 3px; line-height: 1.4; }
.alert-time { font-size: 10px; color: var(--text-muted); margin-top: 4px; }
.alert-dismiss {
  align-self: center; background: none; border: none; color: var(--text-muted);
  cursor: pointer; padding: 4px; opacity: 0; transition: opacity 0.2s;
}
.alert-item:hover .alert-dismiss { opacity: 0.6; }
.alert-dismiss:hover { opacity: 1 !important; color: var(--state-error); }
.alert-empty {
  text-align: center; padding: 40px 20px; color: var(--text-muted); font-size: 14px;
}

/* Notification dropdown actions row */
.notify-dropdown-actions { display: flex; gap: 8px; align-items: center; }
.notify-clear-all-btn {
  background: none; border: none; color: var(--text-muted);
  font-size: 11px; cursor: pointer; padding: 4px 8px; border-radius: 4px;
  transition: color 0.2s, background 0.2s; font-family: inherit;
}
.notify-clear-all-btn:hover { color: var(--state-error); background: rgba(239, 68, 68, 0.08); }

/* Alert Toast Notifications */
.alert-toast-container {
  position: fixed; bottom: 24px; right: 24px; z-index: 9000;
  display: flex; flex-direction: column-reverse; gap: 8px;
  pointer-events: none;
}
.alert-toast {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 20px; border-radius: 10px; font-size: 13px;
  color: #fff; pointer-events: auto; max-width: 380px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.3);
  opacity: 0; transform: translateX(20px);
  transition: opacity 0.3s, transform 0.3s;
}
.alert-toast.show { opacity: 1; transform: translateX(0); }
.alert-toast-icon { flex-shrink: 0; display: flex; }
.alert-toast-text { flex: 1; line-height: 1.4; }
.alert-toast-info { background: var(--bg-card); border: 1px solid var(--accent-blue); color: var(--text-primary); }
.alert-toast-warning { background: linear-gradient(135deg, #7a5000, #5a3a00); border: 1px solid #f39c12; }
.alert-toast-critical { background: linear-gradient(135deg, #7a1a1a, #5a0e0e); border: 1px solid #e74c3c; }
@media (max-width: 500px) {
  .alert-toast-container { left: 12px; right: 12px; bottom: 12px; }
  .alert-toast { max-width: 100%; }
}

/* ============================================================
   TIER 3: Card Toggle Panel
   ============================================================ */
.card-toggle-panel {
  position: fixed; top: 0; right: -340px; width: 320px; height: 100vh;
  background: var(--bg-secondary); border-left: 1px solid var(--border);
  z-index: 1100; transition: right 0.3s cubic-bezier(0.4,0,0.2,1);
  display: flex; flex-direction: column;
  box-shadow: -8px 0 40px var(--overlay-strong);
}
.card-toggle-panel.open { right: 0; }
.toggle-panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 18px; border-bottom: 1px solid var(--border);
}
.toggle-panel-title {
  font-size: 14px; font-weight: 700; color: var(--text-primary);
  text-transform: uppercase; letter-spacing: 0.5px;
}
.toggle-panel-actions { display: flex; align-items: center; gap: 8px; }
.toggle-show-all {
  font-size: 11px; padding: 4px 10px; border-radius: 6px;
  background: rgba(78,143,247,0.12); color: var(--accent-blue);
  border: 1px solid rgba(78,143,247,0.2); cursor: pointer;
  transition: background 0.2s;
}
.toggle-show-all:hover { background: rgba(78,143,247,0.22); }
.toggle-panel-close {
  background: none; border: none; color: var(--text-muted);
  cursor: pointer; padding: 4px; display: flex; align-items: center;
  transition: color 0.2s;
}
.toggle-panel-close:hover { color: var(--text-primary); }
.toggle-panel-body {
  flex: 1; overflow-y: auto; padding: 12px 18px;
  scrollbar-width: thin; scrollbar-color: var(--border) transparent;
}
.toggle-section { margin-bottom: 16px; }
.toggle-section-label {
  font-size: 10px; text-transform: uppercase; letter-spacing: 1px;
  color: var(--text-muted); margin-bottom: 8px; font-weight: 600;
}
.toggle-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0; cursor: pointer; user-select: none;
}
.toggle-item-label { font-size: 13px; color: var(--text-secondary); }
.toggle-item:hover .toggle-item-label { color: var(--text-primary); }
.toggle-checkbox { display: none; }
.toggle-switch {
  width: 36px; height: 20px; background: var(--bg-inset);
  border-radius: 10px; position: relative; transition: background 0.2s;
  border: 1px solid var(--border); flex-shrink: 0;
}
.toggle-knob {
  position: absolute; top: 2px; left: 2px; width: 14px; height: 14px;
  background: var(--text-muted); border-radius: 50%;
  transition: transform 0.2s, background 0.2s;
}
.toggle-checkbox:checked + .toggle-switch {
  background: rgba(78,143,247,0.25); border-color: var(--accent-blue);
}
.toggle-checkbox:checked + .toggle-switch .toggle-knob {
  transform: translateX(16px); background: var(--accent-blue);
}
.toggle-panel-footer {
  padding: 12px 18px; border-top: 1px solid var(--border);
  font-size: 11px; color: var(--text-muted); text-align: center;
}

/* ============================================================
   TIER 3: Per-Card Export Buttons
   ============================================================ */
.card { position: relative; }
.card-export-btn {
  position: absolute; top: 12px; right: 12px;
  background: rgba(78,143,247,0.1); border: 1px solid rgba(78,143,247,0.25);
  color: var(--accent-blue); cursor: pointer;
  padding: 5px 8px; border-radius: 6px;
  opacity: 0; transition: opacity 0.2s, background 0.2s;
  display: flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 600; z-index: 5;
}
.card-export-btn span { text-transform: uppercase; letter-spacing: 0.5px; }
.card:hover .card-export-btn { opacity: 0.8; }
.card-export-btn:hover { opacity: 1 !important; background: rgba(78,143,247,0.2); border-color: var(--accent-blue); }
.card-export-btn:disabled { pointer-events: none; }
@keyframes export-spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
.export-spin { animation: export-spin 0.8s linear infinite; }

/* ============================================================
   TIER 2 + 3: Responsive
   ============================================================ */
@media (max-width: 900px) {
  .tracker-stats { grid-template-columns: repeat(3, 1fr); }
  .tracker-toolbar { flex-direction: column; }
  .tracker-search-wrap { min-width: 100%; }
  .tracker-form-grid { grid-template-columns: 1fr 1fr; }
  .tracker-grid { grid-template-columns: 1fr; }
  .scorecard-cards { grid-template-columns: 1fr; }
  .comparison-selectors { flex-direction: column; }
  .comparison-charts-row { grid-template-columns: 1fr; }
  .ballot-mock-grid { grid-template-columns: 1fr; }
  .ballot-countdown-value { font-size: 24px; }
  .card-toggle-panel { width: 280px; right: -300px; }
}
@media (max-width: 500px) {
  .tracker-stats { grid-template-columns: repeat(2, 1fr); }
  .tracker-form-grid { grid-template-columns: 1fr; }
  .scorecard-header { flex-direction: column; align-items: flex-start; gap: 12px; }
  .scorecard-ring-wrap { align-self: center; }
  .comparison-grid { grid-template-columns: 1fr; gap: 8px; }
  .comparison-divider { display: none; }
  .ballot-phase-timeline { flex-direction: column; }
  .ballot-phase:first-child { border-radius: 10px 10px 0 0; }
  .ballot-phase:last-child { border-radius: 0 0 10px 10px; }
}

/* ===================================================================
   Welcome / Onboarding Page
   =================================================================== */
.welcome-page-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: var(--bg-primary); z-index: 4000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.4s ease;
  overflow-y: auto;
}
.welcome-page-overlay.welcome-page-visible { opacity: 1; }
.welcome-page-overlay.welcome-page-fade-out { opacity: 0; transition: opacity 0.5s ease; }

.welcome-page {
  width: 680px; max-width: 94vw; padding: 48px 32px 40px;
  animation: welcomeSlideUp 0.6s ease;
}

.welcome-page-header { text-align: center; margin-bottom: 36px; }
.welcome-page-logo { height: 52px; width: auto; }

.welcome-page-title {
  font-size: 28px; font-weight: 700; color: var(--text-primary);
  text-align: center; margin: 0 0 8px; letter-spacing: -0.5px;
}
.welcome-page-subtitle {
  font-size: 15px; color: var(--text-secondary);
  text-align: center; margin: 0 0 32px; line-height: 1.5;
}

/* Election Type Cards */
.welcome-type-grid {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px;
  margin-bottom: 12px;
}
.welcome-type-card {
  background: var(--bg-card); border: 2px solid var(--border);
  border-radius: 14px; padding: 24px 16px 20px; text-align: center;
  cursor: pointer; transition: all 0.25s ease;
  font-family: inherit; color: var(--text-primary);
}
.welcome-type-card:hover {
  border-color: var(--accent-blue); background: var(--bg-card-hover);
  transform: translateY(-2px); box-shadow: 0 8px 32px rgba(78, 143, 247, 0.12);
}
.welcome-type-card:active { transform: translateY(0); }
.welcome-type-icon { font-size: 32px; margin-bottom: 10px; line-height: 1; }
.welcome-type-label {
  font-size: 15px; font-weight: 600; color: var(--text-primary); margin-bottom: 4px;
}
.welcome-type-desc { font-size: 12px; color: var(--text-muted); line-height: 1.4; }

/* District Picker */
.welcome-back-btn {
  background: none; border: none; color: var(--text-muted);
  font-size: 14px; font-family: inherit; cursor: pointer;
  padding: 0; margin-bottom: 16px; transition: color 0.2s;
}
.welcome-back-btn:hover { color: var(--text-primary); }

.welcome-district-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px;
  max-height: 420px; overflow-y: auto; padding: 4px;
  margin-bottom: 24px;
}
.welcome-district-btn {
  display: flex; align-items: center; gap: 12px;
  background: var(--bg-card); border: 2px solid var(--border);
  border-radius: 10px; padding: 12px 14px; text-align: left;
  cursor: pointer; transition: all 0.2s; font-family: inherit;
  color: var(--text-primary);
}
.welcome-district-btn:hover { border-color: var(--border-light); background: var(--bg-card-hover); }
.welcome-district-btn.selected {
  border-color: var(--accent-blue); background: rgba(78, 143, 247, 0.08);
  box-shadow: 0 0 0 1px var(--accent-blue);
}
.welcome-district-num {
  font-size: 18px; font-weight: 700; color: var(--accent-blue);
  min-width: 28px; text-align: center;
}
.welcome-district-name { font-size: 13px; font-weight: 500; color: var(--text-primary); }
.welcome-district-area { font-size: 11px; color: var(--text-muted); }

.welcome-district-actions { text-align: center; }
.welcome-start-btn {
  padding: 14px 48px; font-size: 15px; font-weight: 600; font-family: inherit;
  background: linear-gradient(135deg, var(--accent-blue), #3d7de6);
  color: #fff; border: none; border-radius: 10px; cursor: pointer;
  transition: all 0.2s; box-shadow: 0 4px 16px rgba(78, 143, 247, 0.25);
}
.welcome-start-btn:hover:not(:disabled) {
  transform: translateY(-1px); box-shadow: 0 6px 24px rgba(78, 143, 247, 0.35);
}
.welcome-start-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.welcome-loading {
  text-align: center; padding: 40px; color: var(--text-muted); font-size: 14px;
}

/* District grid scrollbar */
.welcome-district-grid::-webkit-scrollbar { width: 6px; }
.welcome-district-grid::-webkit-scrollbar-track { background: transparent; }
.welcome-district-grid::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

/* Profile section helpers */
.profile-section-divider { height: 1px; background: var(--border); margin: 16px 0; }
.profile-section-label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); margin-bottom: 8px; }


@media (max-width: 600px) {
  .welcome-page { padding: 32px 20px; }
  .welcome-type-grid { grid-template-columns: 1fr 1fr; }
  .welcome-page-title { font-size: 22px; }
  .welcome-district-grid { grid-template-columns: 1fr 1fr; }
}
