
:root {
  --bg: #f5f7f8;
  --surface: #ffffff;
  --ink: #17202a;
  --muted: #667085;
  --line: #d8e0e8;
  --teal: #0f766e;
  --blue: #275f9f;
  --gold: #a15c05;
  --red: #b42318;
  --soft: #edf4f2;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--bg); color: var(--ink); font-family: Arial, sans-serif; line-height: 1.45; }
.topbar { position: sticky; top: 0; z-index: 20; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 10px 22px; border-bottom: 1px solid var(--line); background: rgba(255,255,255,.96); }
.brand { font-family: Georgia, serif; font-weight: 700; font-size: 1.05rem; white-space: nowrap; }
.view-tabs { display: flex; gap: 6px; overflow-x: auto; }
.view-tabs button { border: 1px solid var(--line); background: #fff; color: var(--ink); border-radius: 6px; padding: 7px 10px; font-size: .82rem; cursor: pointer; white-space: nowrap; }
.view-tabs button.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.shell { max-width: 1240px; margin: 0 auto; padding: 22px 18px 54px; }
.hero { display: grid; grid-template-columns: minmax(0, 1.35fr) 320px; gap: 18px; align-items: end; padding: 8px 0 18px; border-bottom: 1px solid var(--line); margin-bottom: 14px; }
.eyebrow { color: var(--teal); font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; margin-bottom: 4px; }
h1, h2, h3 { font-family: Georgia, serif; letter-spacing: 0; margin: 0; }
h1 { font-size: 2rem; line-height: 1.1; margin-bottom: 8px; }
h2 { font-size: 1.28rem; margin-bottom: 8px; }
p { margin: 0 0 8px; }
.lead { max-width: 820px; color: #344054; font-size: 1rem; }
.muted { color: var(--muted); font-size: .86rem; }
.hero-meta, .panel { background: var(--surface); border: 1px solid var(--line); border-radius: 8px; padding: 14px; }
.meta-line { display: flex; justify-content: space-between; gap: 10px; border-bottom: 1px solid #edf1f5; padding: 6px 0; font-size: .88rem; }
.meta-line:last-child { border-bottom: 0; }
.control-row { display: grid; grid-template-columns: 120px 220px minmax(240px, 1fr) minmax(240px, 1fr); gap: 10px; margin: 0 0 14px; align-items: end; }
.theme-panel { margin: 0 0 14px; }
.theme-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
.theme-card { display: flex; flex-direction: column; gap: 3px; text-align: left; padding: 11px 13px; border: 1px solid var(--line); border-radius: 12px; background: #fff; cursor: pointer; transition: border-color .12s ease, box-shadow .12s ease, transform .12s ease; }
.theme-card:hover { border-color: #1B6CA8; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(15,23,42,.08); }
.theme-card.is-active { border-color: #1B6CA8; box-shadow: 0 0 0 2px rgba(27,108,168,.20); }
.theme-card__name { font-weight: 700; font-size: .92rem; color: var(--ink); }
.theme-card__count { font-size: .68rem; color: var(--muted); text-transform: uppercase; letter-spacing: .03em; }
.theme-card__lead { font-size: .78rem; color: var(--muted); }
.subtheme-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.subtheme-chip { border: 1px solid var(--line); background: #fff; border-radius: 999px; padding: 6px 13px; font-size: .82rem; cursor: pointer; color: var(--ink); display: inline-flex; gap: 6px; align-items: center; transition: border-color .12s, background .12s; }
.subtheme-chip:hover { border-color: #1B6CA8; }
.subtheme-chip.is-active { background: #1B6CA8; color: #fff; border-color: #1B6CA8; }
.subtheme-chip__n { opacity: .65; font-size: .72rem; }
.indicator-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--line); }
.indicator-chip { border: 1px solid var(--line); background: #fbfcfd; border-radius: 8px; padding: 7px 12px; font-size: .82rem; cursor: pointer; color: var(--ink); text-align: left; transition: border-color .12s, box-shadow .12s; }
.indicator-chip:hover { border-color: #1B6CA8; }
.indicator-chip.is-active { border-color: #1B6CA8; box-shadow: 0 0 0 2px rgba(27,108,168,.18); font-weight: 700; }
.fw-filter-row { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; align-items: center; }
.fw-filter-row__label { font-size: .72rem; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; margin-right: 6px; }
.fw-filter { padding: 5px 12px; border-radius: 999px; border: 1px solid var(--line); background: #fff; cursor: pointer; font-size: .78rem; color: var(--ink); transition: background .12s, border-color .12s; }
.fw-filter:hover { border-color: #1B6CA8; }
.fw-filter.is-active { background: #1B6CA8; color: #fff; border-color: #1B6CA8; }
.fw-badge { display: inline-block; font-size: .65rem; padding: 2px 7px; border-radius: 4px; margin-left: 5px; font-weight: 600; vertical-align: middle; }
.fw-badge.fw-sdg { background: #dbeafe; color: #1d4ed8; }
.fw-badge.fw-rpjmn { background: #fef3c7; color: #a16207; }
.fw-badge.fw-spm { background: #dcfce7; color: #15803d; }
.indicator-chip.is-dim { opacity: 0.35; }
label { color: var(--muted); font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; }
select { width: 100%; margin-top: 4px; border: 1px solid var(--line); border-radius: 6px; background: #fff; color: var(--ink); padding: 8px 9px; font-size: .9rem; }
.view { display: none; }
.view.active { display: block; }
.map-grid { display: grid; grid-template-columns: minmax(0, 1.55fr) 390px; gap: 14px; margin-bottom: 14px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin-bottom: 14px; }
.panel { margin-bottom: 14px; }
.panel-head { display: flex; justify-content: space-between; gap: 12px; align-items: start; }
.selected-panel { align-self: stretch; display: flex; flex-direction: column; }
.map-wrap { width: 100%; min-height: 390px; border: 1px solid #eef2f5; background: #fbfcfd; border-radius: 8px; overflow: hidden; }
.map-panel { position: relative; }
.map-tip { position: absolute; z-index: 30; pointer-events: none; background: rgba(23,32,42,.96); color: #fff; font-size: .78rem; padding: 6px 9px; border-radius: 6px; max-width: 250px; line-height: 1.35; box-shadow: 0 4px 14px rgba(0,0,0,.25); }
.map-tip[hidden] { display: none; }
svg.map { width: 100%; height: auto; display: block; overflow: visible; }
.base-map { fill: #e8edf2; stroke: #c7d2dd; stroke-width: .25; vector-effect: non-scaling-stroke; }
.district-path {
  stroke: rgba(255,255,255,.58);
  stroke-width: .28;
  stroke-linejoin: round;
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
  cursor: pointer;
  transition: fill .12s, stroke .12s;
}
.province-map .district-path {
  stroke: rgba(71,85,105,.28);
  stroke-width: .22;
}
.district-path:hover { stroke: #1f2937; stroke-width: .9; }
.district-path.selected { stroke: #111827; stroke-width: 1.15; }
.subdistrict-path {
  stroke: rgba(71,85,105,.36);
  stroke-width: .32;
  stroke-linejoin: round;
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
}
.subdistrict-path:hover { stroke: #111827; stroke-width: .9; }
.province-outline {
  fill: none;
  stroke: #344054;
  stroke-width: 1;
  stroke-opacity: .55;
  stroke-linejoin: round;
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
  pointer-events: none;
}
.legend { min-width: 160px; font-size: .78rem; color: var(--muted); }
.legend-bar { height: 8px; border-radius: 999px; background: linear-gradient(90deg, #e7f2ef, #83c5bb, #0f766e); margin: 4px 0; }
.kpi-stack { display: grid; gap: 8px; }
.kpi-card { border: 1px solid #edf1f5; border-radius: 7px; padding: 10px; background: #fbfcfd; }
.kpi-label { color: var(--muted); font-size: .76rem; text-transform: uppercase; letter-spacing: .03em; }
.kpi-value { font-weight: 700; font-size: 1.15rem; margin-top: 2px; overflow-wrap: anywhere; }
.context-box { margin-top: 12px; padding: 11px; border-left: 4px solid var(--teal); background: var(--soft); border-radius: 6px; font-size: .88rem; }
.drilldown-panel { margin-top: -2px; }
.drilldown-summary { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 8px; max-width: 520px; }
.summary-pill { border: 1px solid var(--line); border-radius: 8px; background: #fbfcfd; padding: 8px 10px; min-width: 118px; }
.summary-pill span { display: block; color: var(--muted); font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; }
.summary-pill strong { display: block; margin-top: 2px; font-size: .95rem; }
.metric-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; }
.metric-card { border: 1px solid var(--line); border-radius: 8px; padding: 11px; background: #fff; }
.metric-card .small { color: var(--muted); font-size: .76rem; margin-top: 5px; }
.policy-signal-grid { margin: 10px 0 14px; }
.inner-panel { margin-bottom: 0; background: #fbfcfd; }
.bar-list { display: grid; gap: 12px; }
.bar-row { display: grid; gap: 6px; }
.bar-title { display: flex; justify-content: space-between; gap: 10px; font-size: .84rem; }
.bar-track { height: 10px; border-radius: 999px; background: #e8edf2; overflow: hidden; }
.bar-fill { height: 100%; border-radius: 999px; background: var(--teal); }
.bar-fill.national { background: #94a3b8; }
.bar-pair { display: grid; grid-template-columns: 1fr; gap: 4px; }
.recommendation-list { display: grid; gap: 8px; }
.recommendation-card { border: 1px solid var(--line); border-radius: 8px; padding: 10px; background: #fff; }
.recommendation-card.high { border-left: 4px solid var(--red); }
.recommendation-card.medium { border-left: 4px solid var(--gold); }
.recommendation-card.watch { border-left: 4px solid var(--blue); }
.recommendation-card strong { display: block; margin-bottom: 3px; }
.table-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: 8px; background: #fff; }
.full-table { max-height: 430px; overflow: auto; }
table { width: 100%; border-collapse: collapse; font-size: .82rem; }
th, td { text-align: left; border-bottom: 1px solid #e8edf2; padding: 8px; vertical-align: top; }
th { background: #f8fafc; color: #344054; font-weight: 700; }
.full-table th { position: sticky; top: 0; z-index: 1; }
.full-table tr:hover td { background: #fbfcfd; }
.chip { display: inline-block; border-radius: 999px; padding: 2px 8px; border: 1px solid var(--line); background: #fff; font-size: .76rem; white-space: nowrap; }
.chip.warn { border-color: #fedf89; background: #fffaeb; color: #93370d; }
.chip.good { border-color: #abefc6; background: #ecfdf3; color: #067647; }
.chip.review { border-color: #fecdca; background: #fff1f3; color: #b42318; }
.note { border-left: 4px solid var(--gold); background: #fff8e6; }
@media (max-width: 940px) {
  .hero, .map-grid, .grid-2, .control-row { grid-template-columns: 1fr; }
  .metric-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .topbar { align-items: flex-start; flex-direction: column; }
  .drilldown-summary { justify-content: flex-start; max-width: none; }
}
@media (max-width: 560px) {
  .metric-grid { grid-template-columns: 1fr; }
  h1 { font-size: 1.55rem; }
}

/* ARC workbench redesign layer, adapted from UHC Costing visual patterns. */
:root {
  --paper: #f5f6f3;
  --paper-deep: #ebece8;
  --surface: #ffffff;
  --surface-alt: #fafbf9;
  --ink: #162230;
  --ink-soft: #364254;
  --muted: #697583;
  --ink-faint: #c2c8d1;
  --line: rgba(0, 33, 71, 0.12);
  --line-soft: rgba(0, 33, 71, 0.06);
  --accent: #002147;
  --accent-hover: #1a3a6a;
  --accent-tint: #e6edf5;
  --teal: #0f766e;
  --blue: #275f9f;
  --gold: #a15c05;
  --red: #b42318;
  --soft: #edf4f2;
  --shadow-sm: 0 4px 14px rgba(0, 33, 71, 0.04);
  --shadow-md: 0 8px 24px rgba(0, 33, 71, 0.06);
  --shadow-lg: 0 14px 44px rgba(0, 33, 71, 0.08);
  --r-md: 12px;
  --r-lg: 20px;
  --r-card: 24px;
}

body {
  background: var(--paper);
  color: var(--ink);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3 {
  color: var(--ink);
  font-weight: 500;
  letter-spacing: 0;
}

h1 { font-size: 2.4rem; font-weight: 500; }
h2 { font-size: 1.45rem; }
h3 { font-size: 1.05rem; }

.eyebrow {
  color: var(--ink-mute, var(--muted));
  letter-spacing: 0;
  font-size: .74rem;
}

.app-loading {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: linear-gradient(135deg, #001a3a 0%, #002147 56%, #1a3a6a 100%);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .3s ease;
}
.app-loading.is-done { opacity: 0; pointer-events: none; }
.app-loading.is-error .app-loading__bar-fill { background: #ef4444; }
.app-loading__inner {
  text-align: center;
  width: min(480px, calc(100vw - 48px));
  padding: 32px;
}
.app-loading__logo {
  width: 72px;
  height: 72px;
  margin-bottom: 18px;
}
.app-loading__eyebrow {
  font: 700 11px/1.4 Arial, Helvetica, sans-serif;
  letter-spacing: 0;
  opacity: .74;
  margin: 0 0 8px;
}
.app-loading__title {
  font: 600 30px/1.15 Georgia, "Times New Roman", serif;
  margin: 0 0 24px;
  color: #ffffff;
}
.app-loading__bar {
  width: 100%;
  height: 4px;
  background: rgba(255,255,255,.15);
  border-radius: 999px;
  overflow: hidden;
  margin-bottom: 12px;
}
.app-loading__bar-fill {
  height: 100%;
  width: 5%;
  background: #ffffff;
  border-radius: 999px;
  transition: width .25s ease-out;
}
.app-loading__hint {
  font: 400 13px/1.5 Arial, Helvetica, sans-serif;
  opacity: .78;
  margin: 0;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 30;
  min-height: 82px;
  padding: 12px 24px;
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  box-shadow: none;
}
.topbar__brand {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}
.topbar__logo {
  width: 58px;
  height: 58px;
  object-fit: contain;
  flex: 0 0 auto;
}
.topbar__title { min-width: 0; }
.topbar__title .eyebrow {
  margin: 0 0 3px;
  color: var(--muted);
}
.topbar__title h1 {
  margin: 0;
  font-size: 1.35rem;
  line-height: 1.15;
  white-space: nowrap;
}
.top-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}
.status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 6px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface-alt);
  color: var(--ink-soft);
  font-size: .78rem;
  font-weight: 700;
  white-space: nowrap;
}

.tabs {
  display: flex;
  gap: 6px;
  padding: 12px 24px;
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  overflow-x: auto;
  position: sticky;
  top: 82px;
  z-index: 25;
}
.view-tabs button {
  border: 0;
  background: transparent;
  color: var(--ink-soft);
  border-radius: 999px;
  padding: 10px 18px;
  min-height: 36px;
  font: 600 .86rem/1 Arial, Helvetica, sans-serif;
}
.view-tabs button:hover {
  background: var(--paper-deep);
  color: var(--ink);
}
.view-tabs button.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.shell {
  max-width: 1220px;
  padding: 24px 18px 64px;
}

.hero {
  border: 0;
  border-radius: var(--r-card);
  padding: 44px 42px 40px;
  margin: 0 0 18px;
  background: linear-gradient(135deg, #001a3a 0%, #002147 58%, #1a3a6a 100%);
  color: #fff;
  box-shadow: 0 18px 52px rgba(0, 33, 71, 0.20);
  align-items: center;
}
.hero h1 {
  color: #fff;
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 1.05;
  margin-bottom: 12px;
}
.hero .eyebrow {
  color: rgba(255,255,255,.72);
}
.lead {
  color: rgba(255,255,255,.86);
  font-size: 1.05rem;
  line-height: 1.55;
}
.hero-meta {
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.22);
  color: #fff;
  border-radius: var(--r-lg);
  backdrop-filter: blur(8px);
}
.meta-line {
  border-bottom-color: rgba(255,255,255,.18);
  color: rgba(255,255,255,.78);
}
.meta-line strong { color: #fff; }

.control-row {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-card);
  box-shadow: var(--shadow-sm);
  padding: 16px;
  margin-bottom: 18px;
}
label {
  color: var(--muted);
  letter-spacing: 0;
  font-size: .72rem;
}
select {
  border-color: var(--line);
  border-radius: var(--r-md);
  min-height: 38px;
  padding: 8px 11px;
  font-weight: 500;
}
select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-tint);
}

.panel,
.hero-meta {
  border-color: var(--line);
  border-radius: var(--r-card);
}
.panel {
  padding: 20px;
  box-shadow: var(--shadow-sm);
}
.inner-panel {
  background: var(--surface-alt);
  box-shadow: none;
}
.panel-head {
  align-items: flex-start;
  margin-bottom: 12px;
}
.map-grid {
  grid-template-columns: minmax(0, 1.55fr) 390px;
  gap: 16px;
}
.map-wrap {
  min-height: 420px;
  border-color: var(--line-soft);
  border-radius: var(--r-lg);
  background: #fbfcfd;
}
.province-path,
.district-path,
.subdistrict-path {
  transition: fill .14s ease, stroke .14s ease, opacity .14s ease;
}
.province-path:hover,
.district-path:hover,
.subdistrict-path:hover {
  stroke: var(--accent);
}
.legend {
  min-width: 170px;
  color: var(--muted);
}
.legend-bar {
  background: linear-gradient(90deg, #edf4f2, #83c5bb, #0f766e);
}

.kpi-stack,
.metric-grid,
.recommendation-list {
  gap: 10px;
}
.kpi-card,
.metric-card,
.recommendation-card,
.summary-pill {
  border-color: var(--line);
  border-radius: var(--r-lg);
  background: var(--surface-alt);
}
.kpi-card,
.metric-card {
  padding: 14px;
}
.kpi-label {
  color: var(--muted);
  letter-spacing: 0;
}
.kpi-value {
  color: var(--ink);
  font-size: 1.18rem;
}
.context-box {
  margin-top: 14px;
  border-left-color: var(--teal);
  background: #edf4f2;
  border-radius: var(--r-md);
}
.summary-pill {
  padding: 9px 12px;
}
.summary-pill span {
  letter-spacing: 0;
}
.drilldown-panel {
  margin-top: 0;
}

.bar-track {
  background: #e7ebef;
}
.bar-fill {
  background: var(--teal);
}
.bar-fill.national {
  background: #9aa8b8;
}
.recommendation-card {
  padding: 14px;
  background: #fff;
}
.recommendation-card p {
  margin-bottom: 0;
}

.table-wrap {
  border-color: var(--line);
  border-radius: var(--r-lg);
}
table {
  font-size: .84rem;
}
th {
  background: #f7f8f6;
  color: var(--ink-soft);
}
th, td {
  border-bottom-color: rgba(0,33,71,.08);
  padding: 10px;
}
.chip {
  border-radius: 999px;
  letter-spacing: 0;
}
.note {
  background: #fff8e6;
  border-left-color: var(--gold);
}

@media (max-width: 940px) {
  .topbar { min-height: 0; }
  .topbar__title h1 { white-space: normal; }
  .tabs { position: sticky; top: 0; }
  .map-grid { grid-template-columns: 1fr; }
  .hero { padding: 34px 24px 28px; }
}

@media (max-width: 560px) {
  .topbar { padding: 12px 14px; }
  .topbar__logo { width: 46px; height: 46px; }
  .tabs { padding: 10px 12px; }
  .view-tabs button { padding: 9px 12px; }
  .shell { padding: 14px 10px 44px; }
  .hero { border-radius: 20px; }
  .panel { padding: 16px; }
  h1 { font-size: 1.8rem; }
  .map-wrap { min-height: 300px; }
}

