:root {
  --bg: #f1f5f9;
  --panel: #ffffff;
  --border: #e2e8f0;
  --text: #0f172a;
  --muted: #64748b;
  --navy-700: #1e3a8a;
  --navy-900: #0f172a;
  --teal-600: #0e7490;
  --sidebar-from: #1e3a8a;
  --sidebar-to: #1e40af;
  --sidebar-text: #ffffff;

  --main-pad-x: 22px;
  --main-pad-y: 18px;
  --gap: 14px;
  --kpi-pad: 14px 16px;
  --kpi-size: 26px;
  --h1-size: 17px;
  --panel-head: 12px 16px 8px;
  --panel-body: 12px 16px 14px;
  --bar-h: 16px;
  --sidebar-w: 280px;
}

* { box-sizing: border-box; }
html, body, #root { margin: 0; padding: 0; height: 100%; }
body {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 13px;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  transition: background 0.25s, color 0.25s;
}

.dash {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: 100vh;
  background: var(--bg);
  color: var(--text);
  transition: background 0.25s, color 0.25s, grid-template-columns 0.24s ease;
}
/* Collapsed (hamburger) — --sidebar-w is driven to 0 in JS so the grid column closes;
   the sidebar itself slides out and fades. Main content reflows full-width. */
.dash.sidebar-collapsed > .sidebar {
  padding-left: 0; padding-right: 0;
  transform: translateX(-100%);
  opacity: 0; pointer-events: none;
}

/* Theme accents on editorial mono — quieter sidebar text divider */
.theme-mono .seg-row { color: #fafaf9; }
.theme-midnight .panel { box-shadow: 0 1px 2px rgba(0,0,0,0.4); }

/* Dark / glass themes: accent-coloured headings can be low-contrast on dark panels —
   force them to the theme's adaptive text colour (light on dark, dark on light glass). */
.glassy .topbar h1, .theme-midnight .topbar h1,
.glassy .panel-title, .theme-midnight .panel-title,
.glassy .section-mini-title, .theme-midnight .section-mini-title,
.glassy .chart-title-mini, .theme-midnight .chart-title-mini { color: var(--text); }
.glassy .topbar-sub, .theme-midnight .topbar-sub { color: var(--teal-600); }
/* KPI / hero numbers: white on dark themes for contrast (accent-coloured on light). */
.glassy .kpi-value, .theme-midnight .kpi-value,
.glassy .hero-value, .theme-midnight .hero-value { color: var(--text); }
/* Checkboxes follow the theme accent (e.g. Export modal, Settings). */
input[type="checkbox"] { accent-color: var(--navy-700); }

/* ===== Glass (glassmorphism) themes ===== */
/* Translucent --panel + a frosted backdrop on every panel-like surface. The vivid
   gradient set on --bg (the .dash background) shows through the blur. */
.glassy .dash, .glassy { background-attachment: fixed; }
.glassy .panel,
.glassy .kpi,
.glassy .topbar {
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  backdrop-filter: blur(16px) saturate(140%);
  box-shadow: 0 8px 32px rgba(31, 38, 135, 0.12);
}
.glassy .sidebar {
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  backdrop-filter: blur(18px) saturate(150%);
}
.glassy .panel:hover { box-shadow: 0 12px 40px rgba(31, 38, 135, 0.18); }
.glassy .topbar-icon { background: rgba(255,255,255,0.25); }

/* 3D graph style (Global HR CSS bars) — extruded glass look: top highlight + depth shadow,
   plus the same gradient sheen the Budget dashboard's 3D bars use (cssGrad lighten→base). */
.graph-3d .bar-fill, .graph-3d .seg-bar-fill, .graph-3d .cl-bar-fill, .graph-3d .col-bar, .graph-3d .stk-seg, .graph-3d .lolli-line {
  border-radius: 3px;
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.42), inset 0 -3px 4px rgba(0,0,0,0.15), 0 3px 0 rgba(0,0,0,0.3), 2px 0 0 rgba(0,0,0,0.18);
}
.graph-3d .bar-fill, .graph-3d .seg-bar-fill, .graph-3d .cl-bar-fill, .graph-3d .stk-seg, .graph-3d .lolli-line {
  background-image: linear-gradient(to bottom, rgba(255,255,255,0.30), rgba(255,255,255,0) 65%);
}
.graph-3d .col-bar {
  background-image: linear-gradient(to right, rgba(255,255,255,0.26), rgba(255,255,255,0) 60%);
}

/* Neon Glass theme — faint tech grid behind the dark gradient (like the reference). */
.theme-neon .main, .theme-neon .sidebar {
  background-image:
    linear-gradient(rgba(56,189,248,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(56,189,248,0.05) 1px, transparent 1px);
  background-size: 42px 42px;
}

/* ===== Sidebar ===== */
.sidebar {
  background: linear-gradient(180deg, var(--sidebar-from) 0%, var(--sidebar-to) 100%);
  color: var(--sidebar-text);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 22px;
  /* Float: stay pinned to the viewport while the main content scrolls. */
  position: sticky;
  top: 0;
  align-self: start;
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  transition: background 0.25s, transform 0.24s ease, opacity 0.2s ease, padding 0.24s ease;
}
.dens-compact .sidebar { padding: 14px 14px; gap: 16px; }
.dens-spacious .sidebar { padding: 28px 26px; gap: 28px; }

/* Drag handle on the sidebar's right edge to resize its width. */
.sidebar-resizer {
  position: absolute; top: 0; right: 0; width: 7px; height: 100%;
  cursor: col-resize; z-index: 5;
  background: linear-gradient(to right, transparent, rgba(255,255,255,0.12));
  opacity: 0; transition: opacity 0.15s;
}
.sidebar:hover .sidebar-resizer { opacity: 1; }
.sidebar-resizer:hover, .sidebar-resizer:active { background: linear-gradient(to right, transparent, rgba(255,255,255,0.4)); }

/* Hamburger toggle in the topbar. */
.hamburger-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 34px; height: 34px; margin-right: 4px;
  background: var(--bg); border: 1px solid var(--border); border-radius: 8px;
  color: var(--text); cursor: pointer; flex-shrink: 0; transition: background 0.15s, border-color 0.15s;
}
.hamburger-btn:hover { background: color-mix(in srgb, var(--navy-700) 10%, var(--bg)); border-color: var(--navy-700); }

/* Marquee — labels that overflow scroll gently instead of truncating. */
.seg-name.mq { overflow: hidden; }
.seg-name .mq-inner { display: inline-block; white-space: nowrap; }
.seg-name.mq .mq-inner { animation: segMarquee 5s ease-in-out infinite alternate; }
.seg-row:hover .seg-name.mq .mq-inner { animation-play-state: running; }
@keyframes segMarquee {
  0%, 18% { transform: translateX(0); }
  82%, 100% { transform: translateX(calc(-1 * var(--mq-shift, 0px))); }
}

.brand { display: flex; gap: 12px; align-items: center; }
.brand-mark {
  width: 40px; height: 40px; border-radius: 8px;
  background: rgba(255,255,255,0.10);
  display: flex; align-items: center; justify-content: center;
}
.brand-title { font-size: 15px; font-weight: 700; letter-spacing: 0.2px; }
.brand-sub { font-size: 11px; opacity: 0.7; margin-top: 2px; }

.refreshed {
  border-top: 1px solid rgba(255,255,255,0.18);
  border-bottom: 1px solid rgba(255,255,255,0.18);
  padding: 14px 0;
}
.ref-label { font-size: 11px; opacity: 0.7; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
.ref-date { display: flex; align-items: baseline; gap: 8px; }
.ref-day { font-size: 28px; font-weight: 700; }
.dens-spacious .ref-day { font-size: 36px; }
.dens-compact .ref-day { font-size: 22px; }
.ref-month { font-size: 12px; opacity: 0.85; }

.hero-label { font-size: 11px; opacity: 0.75; text-transform: uppercase; letter-spacing: 1px; }
.hero-value {
  font-size: 32px; font-weight: 700; margin-top: 6px; line-height: 1;
  font-variant-numeric: tabular-nums;
}
.dens-spacious .hero-value { font-size: 44px; }
.dens-compact .hero-value { font-size: 24px; }
.hero-delta { font-size: 11px; margin-top: 6px; opacity: 0.9; }
.hero-delta.up { color: #86efac; }
.hero-delta.down { color: #fca5a5; }
.theme-mono .hero-delta.up { color: #d6d3d1; }
.theme-mono .hero-delta.down { color: #fca5a5; }

.filter-title { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; }
.filter-sub { font-size: 10.5px; opacity: 0.7; margin-top: 3px; margin-bottom: 10px; }

.seg-list { display: flex; flex-direction: column; gap: 4px; }
.seg-row {
  display: grid;
  grid-template-columns: 8px 1fr 60px 44px;
  align-items: center;
  gap: 8px;
  padding: 7px 6px;
  border-radius: 5px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--sidebar-text);
  cursor: pointer;
  text-align: left;
  font-size: 11.5px;
  transition: background 0.12s, border-color 0.12s;
}
.dens-compact .seg-row { padding: 5px 6px; font-size: 11px; }
.dens-spacious .seg-row { padding: 9px 8px; font-size: 12.5px; }
.seg-row:hover { background: rgba(255,255,255,0.07); }
.seg-row.active { background: rgba(255,255,255,0.14); border-color: rgba(255,255,255,0.28); }
.seg-dot { width: 8px; height: 8px; border-radius: 50%; }
.seg-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.seg-bar { background: rgba(255,255,255,0.14); height: 5px; border-radius: 3px; overflow: hidden; }
.seg-bar-fill { display: block; height: 100%; }
.seg-val { font-size: 10.5px; opacity: 0.92; text-align: right; font-variant-numeric: tabular-nums; }

.legend { font-size: 10.5px; opacity: 0.85; display: flex; flex-direction: column; gap: 6px; margin-top: auto; }
.legend-row { display: flex; align-items: center; gap: 8px; }
.legend-dot.map { width: 8px; height: 8px; border-radius: 50%; background: var(--sidebar-text); }
.legend-grad {
  width: 60px; height: 6px; border-radius: 3px;
  background: linear-gradient(90deg, rgba(255,255,255,0.25), var(--sidebar-text));
}

/* ===== Main ===== */
.main {
  padding: var(--main-pad-y) var(--main-pad-x) var(--main-pad-x);
  display: flex;
  flex-direction: column;
  gap: var(--gap);
  min-width: 0;
}

.topbar {
  display: flex; justify-content: space-between; align-items: center;
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 6px; padding: 10px 16px;
  transition: background 0.25s, border-color 0.25s;
}
.dens-compact .topbar { padding: 6px 12px; }
.dens-spacious .topbar { padding: 14px 22px; }
.topbar-left { display: flex; align-items: center; gap: 12px; }
.topbar-icon {
  width: 32px; height: 32px; background: var(--bg);
  border-radius: 6px; display: flex; align-items: center; justify-content: center;
}
.topbar-icon svg path { stroke: var(--text); }
.topbar h1 { font-size: var(--h1-size); font-weight: 700; margin: 0; color: var(--navy-700); letter-spacing: 0.2px; }
.topbar-sub { color: var(--teal-600); font-weight: 500; }
.topbar-right { display: flex; gap: 10px; align-items: center; }
.fy-pill {
  font-size: 11px; padding: 5px 10px;
  background: color-mix(in srgb, var(--navy-700) 12%, transparent);
  color: var(--navy-700); border-radius: 999px; font-weight: 600;
}
.toggle { display: flex; background: var(--bg); padding: 2px; border-radius: 5px; border: 1px solid var(--border); }
.toggle button {
  border: none; background: transparent; padding: 4px 12px;
  font-size: 11px; font-weight: 600; color: var(--muted);
  cursor: pointer; border-radius: 4px;
}
.toggle button.on { background: var(--navy-700); color: #ffffff; }

/* Moved-from-topbar controls, restyled for the dark sidebar. */
.sidebar-controls { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.sidebar-controls .toggle { background: rgba(255,255,255,0.10); border-color: rgba(255,255,255,0.18); }
.sidebar-controls .toggle button { color: rgba(255,255,255,0.72); }
.sidebar-controls .toggle button.on { background: #ffffff; color: #0f172a; }
.sidebar-controls .fy-pill { background: rgba(255,255,255,0.14); color: #ffffff; }
.sidebar-profile {
  display: flex; align-items: center; gap: 9px; width: 100%; margin-top: auto;
  background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.18);
  border-radius: 10px; padding: 7px 12px; cursor: pointer; color: var(--sidebar-text);
  transition: background 0.15s;
}
.sidebar-profile:hover { background: rgba(255,255,255,0.18); }
.sidebar-profile .sp-avatar {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, #38bdf8, #1d4ed8); color: #fff;
  display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 800;
}
.sidebar-profile .sp-name { flex: 1; font-size: 13px; font-weight: 600; text-align: left; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.kpis {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--gap);
}
.dens-compact .kpis { grid-template-columns: repeat(5, 1fr); gap: 8px; }
.kpi {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 6px; padding: var(--kpi-pad);
  transition: background 0.25s, border-color 0.25s;
}
.kpi-value {
  font-size: var(--kpi-size); font-weight: 700;
  color: var(--navy-700); line-height: 1;
  font-variant-numeric: tabular-nums;
}
.kpi-label { font-size: 11px; color: var(--muted); margin-top: 6px; text-transform: uppercase; letter-spacing: 0.6px; }
.kpi-sub { font-size: 11px; color: var(--muted); margin-top: 4px; display: flex; gap: 8px; align-items: center; }
.kpi-delta.up { color: #16a34a; font-weight: 600; }
.kpi-delta.down { color: #dc2626; font-weight: 600; }
.theme-midnight .kpi-delta.up { color: #4ade80; }
.theme-midnight .kpi-delta.down { color: #f87171; }

.grid-row { display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--gap); }
.grid-row.map-row { grid-template-columns: 1.6fr 1fr; }

.panel {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 6px; display: flex; flex-direction: column; min-width: 0;
  transition: background 0.25s, border-color 0.25s;
}
.panel-head { padding: var(--panel-head); border-bottom: 1px solid var(--border); }
.panel-title { font-size: 13px; font-weight: 700; color: var(--navy-700); }
.panel-sub { font-size: 11px; color: var(--muted); margin-top: 2px; }
.panel-body { padding: var(--panel-body); flex: 1; min-height: 0; }

/* Bar list */
.bar-list { display: flex; flex-direction: column; gap: 10px; }
.dens-spacious .bar-list { gap: 14px; }
.bar-row.hl, .sf-row.hl, .lolli-row.hl, .stk-row.hl, .col-pair.hl, .dl-row.hl {
  background: color-mix(in srgb, var(--navy-700) 6%, transparent);
  border-radius: 4px;
}
.dl-row.hl, .stk-row.hl { padding: 2px 4px; margin: -2px -4px; }

.lolli-tip {
  position: absolute; top: -22px; transform: translateX(-50%);
  background: var(--navy-700); color: #ffffff; padding: 3px 8px;
  border-radius: 3px; font-size: 10px; white-space: nowrap;
  font-variant-numeric: tabular-nums; pointer-events: none;
}

.donut-svg-wrap { display: flex; }
.donut-svg-wrap svg { overflow: visible; }
.dens-spacious .panel-title { font-size: 14px; letter-spacing: 0.3px; }
.dens-spacious .kpi-label { font-size: 11.5px; }
.dens-spacious .bar-row { grid-template-columns: 160px 1fr; }
.dens-spacious .sf-row { grid-template-columns: 160px 1fr 150px; }
.bar-row { display: grid; grid-template-columns: 130px 1fr; gap: 10px; align-items: center; }
.bar-label { font-size: 11.5px; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-weight: 500; }
.bar-label.sm { font-size: 10.5px; }
.bar-pair { display: flex; flex-direction: column; gap: 3px; }
.bar-track {
  position: relative; height: var(--bar-h);
  background: color-mix(in srgb, var(--text) 6%, var(--panel));
  border-radius: 3px;
}
.bar-fill { position: absolute; top: 0; left: 0; bottom: 0; border-radius: 3px; transition: width 0.3s; }
.bar-prev { background: linear-gradient(to bottom, color-mix(in srgb, var(--text) 14%, var(--panel)) 0%, color-mix(in srgb, var(--text) 28%, var(--panel)) 100%); }
.bar-cur { background: linear-gradient(to bottom, color-mix(in srgb, var(--navy-700) 70%, #ffffff) 0%, var(--navy-700) 70%); }
.bar-val {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  font-size: 10.5px; font-weight: 600; color: var(--text);
  font-variant-numeric: tabular-nums;
}
.bar-legend {
  display: flex; gap: 12px; align-items: center; font-size: 10.5px;
  color: var(--muted); margin-top: 6px; padding-top: 8px;
  border-top: 1px dashed var(--border);
}
.lg { display: inline-block; width: 10px; height: 10px; border-radius: 2px; margin-right: 4px; vertical-align: middle; }
.lg-prev { background: color-mix(in srgb, var(--text) 22%, var(--panel)); }
.lg-cur { background: var(--navy-700); }

/* Seg-FTE chart */
.seg-fte { display: flex; flex-direction: column; gap: 10px; }
.sf-row { display: grid; grid-template-columns: 130px 1fr 130px; gap: 10px; align-items: center; }
.sf-name { font-size: 11.5px; font-weight: 500; }
.sf-bar-wrap {
  position: relative; height: 18px;
  background: color-mix(in srgb, var(--text) 4%, var(--panel));
  border-radius: 3px; overflow: hidden;
}
.sf-bar-bg, .sf-bar-fg { position: absolute; top: 0; bottom: 0; left: 0; border-radius: 3px; }
.sf-nums { display: flex; gap: 8px; justify-content: flex-end; font-size: 10.5px; font-variant-numeric: tabular-nums; }
.sf-hc { font-weight: 700; color: var(--navy-700); }
.sf-fte { color: var(--muted); }
.sf-pct { color: #16a34a; font-weight: 600; min-width: 38px; text-align: right; }
.theme-midnight .sf-pct { color: #4ade80; }

/* Country list */
.country-list { display: flex; flex-direction: column; gap: 6px; max-height: 420px; overflow-y: auto; padding-right: 4px; }
.cl-row {
  display: grid;
  grid-template-columns: 22px 32px 1fr 60px 50px;
  gap: 10px;
  align-items: center;
  padding: 6px 8px;
  border-radius: 4px;
  font-size: 11.5px;
  cursor: pointer;
  transition: background 0.1s, transform 0.1s;
}
.cl-row:hover, .cl-row.hl { background: color-mix(in srgb, var(--navy-700) 10%, transparent); transform: translateX(2px); }
.cl-flag { font-size: 16px; line-height: 1; text-align: center; }
.cl-code {
  font-size: 9.5px; font-weight: 700; color: #ffffff;
  background: var(--navy-700); border-radius: 3px;
  padding: 2px 0; text-align: center; letter-spacing: 0.5px;
}
.cl-name { font-weight: 500; }
.cl-bar { background: color-mix(in srgb, var(--text) 6%, var(--panel)); height: 6px; border-radius: 3px; overflow: hidden; }
.cl-bar-fill { height: 100%; background: linear-gradient(to right, color-mix(in srgb, var(--navy-700) 65%, #ffffff) 0%, var(--navy-700) 100%); }
.cl-val { text-align: right; font-variant-numeric: tabular-nums; font-weight: 600; color: var(--navy-700); }
.empty { padding: 30px; text-align: center; color: var(--muted); }

.country-list::-webkit-scrollbar { width: 6px; }
.country-list::-webkit-scrollbar-thumb { background: color-mix(in srgb, var(--text) 25%, transparent); border-radius: 3px; }

/* Compact density tightens internal type */
.dens-compact .panel-title { font-size: 12px; }
.dens-compact .kpi-label { font-size: 10px; }
.dens-compact .bar-row { grid-template-columns: 110px 1fr; }
.dens-compact .sf-row { grid-template-columns: 110px 1fr 110px; }
/* Donut */
.donut-wrap { display: flex; gap: 18px; align-items: center; flex-wrap: wrap; }
.donut-legend { display: flex; flex-direction: column; gap: 6px; flex: 1; min-width: 180px; }
.dl-row { display: grid; grid-template-columns: 10px 1fr 60px 50px; gap: 8px; align-items: center; font-size: 11px; }
.dl-dot { width: 10px; height: 10px; border-radius: 50%; }
.dl-name { color: var(--text); }
.dl-val, .dl-pct { text-align: right; font-variant-numeric: tabular-nums; color: var(--muted); }
.dl-pct { color: var(--navy-700); font-weight: 600; }

/* Stacked */
.stacked { display: flex; flex-direction: column; gap: 12px; }
.stk-bar { display: flex; height: 26px; border-radius: 4px; overflow: hidden; }
.stk-slice { transition: opacity 0.15s; }
.stk-slice:hover { opacity: 0.85; }
.stk-legend { display: grid; grid-template-columns: repeat(2, 1fr); gap: 4px 14px; }
.stk-row { display: grid; grid-template-columns: 10px 1fr auto; gap: 8px; align-items: center; font-size: 11px; }
.stk-dot { width: 10px; height: 10px; border-radius: 2px; }
.stk-val { font-variant-numeric: tabular-nums; color: var(--muted); }
.stk-val em { color: var(--navy-700); font-style: normal; font-weight: 600; }

/* Columns */
.cols { display: flex; flex-direction: column; gap: 8px; }
.cols-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; align-items: end; height: 220px; padding-top: 6px; }
.col-pair { display: flex; flex-direction: column; align-items: center; gap: 4px; height: 100%; justify-content: flex-end; }
.col-bars { display: flex; gap: 2px; align-items: end; height: 100%; }
.col-bar { width: 14px; border-radius: 3px 3px 0 0; position: relative; min-height: 2px; transition: height 0.3s; }
.col-bar.prev { background: color-mix(in srgb, var(--text) 22%, var(--panel)); }
.col-bar.cur { background: var(--navy-700); }
.col-val { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); font-size: 9px; font-variant-numeric: tabular-nums; color: var(--muted); white-space: nowrap; }
.col-label { font-size: 10px; color: var(--muted); text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }

/* Radial */
.radial-wrap { display: flex; justify-content: center; align-items: center; padding: 8px; }

/* Lollipop */
.lolli { display: flex; flex-direction: column; gap: 10px; }
.lolli-row { display: grid; grid-template-columns: 130px 1fr 60px; gap: 10px; align-items: center; }
.lolli-label { font-size: 11.5px; font-weight: 500; }
.lolli-track { position: relative; height: 16px; background: color-mix(in srgb, var(--text) 5%, var(--panel)); border-radius: 3px; }
.lolli-line { position: absolute; top: 50%; transform: translateY(-50%); height: 3px; border-radius: 2px; }
.lolli-dot { position: absolute; top: 50%; width: 12px; height: 12px; border-radius: 50%; transform: translate(-50%, -50%); border: 2px solid var(--panel); }
.lolli-dot.prev { background: color-mix(in srgb, var(--text) 35%, var(--panel)); }
.lolli-dot.cur { background: var(--navy-700); }
.lolli-val { text-align: right; font-variant-numeric: tabular-nums; font-weight: 600; color: var(--navy-700); font-size: 11px; }

/* ===== Global HR world map — animated wires & pins (light + dark themes) ===== */
.hr-wire {
  stroke-dasharray: 5 7;
  animation: hrWireFlow 1.4s linear infinite;
  filter: drop-shadow(0 0 3px currentColor);
}
@keyframes hrWireFlow { to { stroke-dashoffset: -24; } }
.hr-comet { filter: drop-shadow(0 0 4px currentColor); pointer-events: none; }
.hr-wire-node {
  transform-box: fill-box; transform-origin: center;
  animation: hrNodeIn 0.35s cubic-bezier(.34,1.56,.64,1) backwards;
}
@keyframes hrNodeIn { from { transform: scale(0); opacity: 0; } }
.hr-pin {
  transform-box: fill-box; transform-origin: center;
  animation: hrPinIn 0.55s cubic-bezier(.34,1.56,.64,1) backwards;
  transition: opacity 0.2s ease;
}
@keyframes hrPinIn { from { transform: scale(0.2); opacity: 0; } }
.hr-pin.dim { opacity: 0.35; }
.hr-pin-pulse {
  transform-box: fill-box; transform-origin: center;
  animation: hrPinPulse 2.1s ease-out infinite; pointer-events: none;
}
@keyframes hrPinPulse {
  0%   { transform: scale(0.9); opacity: 0.6; }
  100% { transform: scale(2.1); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .hr-wire, .hr-comet, .hr-wire-node, .hr-pin, .hr-pin-pulse { animation: none; }
}

/* Fiscal-year filter chips in the HR sidebar (mirrors the Budget dashboard) */
.fy-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.fy-chip {
  padding: 6px 16px; border-radius: 999px; font-size: 12.5px; font-weight: 600;
  border: 1px solid rgba(255,255,255,0.28); background: transparent;
  color: var(--sidebar-text, #fff); cursor: pointer; transition: all 0.15s;
}
.fy-chip:hover { border-color: rgba(255,255,255,0.55); }
.fy-chip.active { background: #ffffff; color: #0f172a; border-color: #ffffff; }
