
:root {
  --navy: #0b1b3f;
  --navy-2: #132d5f;
  --blue: #225aa6;
  --teal: #118a7e;
  --gold: #b98b37;
  --brown: #6d411e;
  --violet: #7543a6;
  --cream: #fbf7ee;
  --paper: #fffdf8;
  --mist: #eef4f1;
  --line: rgba(11, 27, 63, 0.14);
  --line-strong: rgba(11, 27, 63, 0.24);
  --text: #132036;
  --muted: #5b6577;
  --shadow: 0 24px 70px rgba(11, 27, 63, 0.12);
  --radius-xl: 34px;
  --radius-lg: 26px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --max: 1180px;
  --header-h: 82px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 0 0, rgba(185, 139, 55, 0.18), transparent 38rem),
    radial-gradient(circle at 100% 12%, rgba(17, 138, 126, 0.12), transparent 33rem),
    linear-gradient(180deg, #fffaf0 0%, #f7f9fb 45%, #fffdf8 100%);
  line-height: 1.58;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.045;
  background-image:
    linear-gradient(rgba(11, 27, 63, 0.55) 1px, transparent 1px),
    linear-gradient(90deg, rgba(11, 27, 63, 0.55) 1px, transparent 1px);
  background-size: 42px 42px;
  z-index: -2;
}
img { max-width: 100%; display: block; }
a { color: inherit; }
button, input, select, textarea { font: inherit; }
.container { width: min(var(--max), calc(100vw - 40px)); margin: 0 auto; }
.skip-link {
  position: absolute; top: -42px; left: 1rem; z-index: 99;
  padding: 0.75rem 1rem; background: var(--navy); color: #fff;
  border-radius: 999px; transition: top 0.2s ease;
}
.skip-link:focus { top: 1rem; }
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.site-header {
  position: sticky; top: 0; z-index: 60;
  backdrop-filter: blur(18px);
  background: rgba(255, 253, 248, 0.9);
  border-bottom: 1px solid var(--line);
}
.header-grid { min-height: var(--header-h); display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.brand { display: flex; align-items: center; gap: 0.78rem; text-decoration: none; }
.brand img { width: 48px; height: 48px; object-fit: cover; border-radius: 50%; box-shadow: 0 10px 24px rgba(109,65,30,0.16); }
.brand strong {
  display: block; letter-spacing: 0.16em; text-transform: uppercase; color: var(--brown);
  font-family: Georgia, "Times New Roman", serif; font-size: 1rem;
}
.brand small { display: block; color: var(--muted); margin-top: -0.1rem; letter-spacing: 0.03em; }
.primary-nav { display: flex; align-items: center; gap: 0.2rem; }
.primary-nav a {
  text-decoration: none; font-size: 0.9rem; font-weight: 800; color: var(--navy);
  padding: 0.66rem 0.74rem; border-radius: 999px; transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}
.primary-nav a:hover, .primary-nav a:focus-visible { background: rgba(17,138,126,0.1); color: var(--teal); outline: none; }
.primary-nav a[aria-current="page"] { background: rgba(11,27,63,0.08); color: var(--navy); }
.primary-nav .nav-cta { background: var(--navy); color: #fff; box-shadow: 0 10px 20px rgba(11,27,63,0.18); }
.primary-nav .nav-cta:hover, .primary-nav .nav-cta:focus-visible { background: var(--teal); color: #fff; transform: translateY(-1px); }
.nav-toggle { display: none; width: 44px; height: 44px; border: 1px solid var(--line); border-radius: 999px; background: #fff; padding: 0.75rem; }
.nav-toggle span:not(.sr-only) { display: block; height: 2px; width: 100%; background: var(--navy); margin: 4px 0; border-radius: 999px; }

.section, .section-panel { padding: 90px 0; }
.section.compact { padding: 58px 0; }
.muted { background: linear-gradient(180deg, rgba(238,244,241,0.66), rgba(255,253,248,0.86)); border-top: 1px solid rgba(11,27,63,0.07); border-bottom: 1px solid rgba(11,27,63,0.07); }
.hero { min-height: calc(88vh - var(--header-h)); display: flex; align-items: center; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(330px, 0.88fr); align-items: center; gap: 54px; }
.eyebrow { margin: 0 0 0.85rem; color: var(--teal); font-weight: 900; text-transform: uppercase; letter-spacing: 0.13em; font-size: 0.78rem; }
h1, h2, h3, h4, p { margin-top: 0; }
h1 { font-size: clamp(3rem, 6.5vw, 6rem); line-height: 0.95; letter-spacing: -0.07em; color: var(--navy); margin-bottom: 1.25rem; }
h2 { font-size: clamp(2rem, 4vw, 4rem); line-height: 1; letter-spacing: -0.055em; color: var(--navy); margin-bottom: 1rem; }
h3 { color: var(--navy); line-height: 1.16; letter-spacing: -0.025em; }
h4 { color: var(--navy); margin-bottom: 0.45rem; }
.hero-lede { font-size: clamp(1.08rem, 1.65vw, 1.34rem); color: #27344c; max-width: 780px; margin-bottom: 1.2rem; }
.binding-sentence {
  display: inline-flex; gap: 0.6rem; align-items: start; max-width: 840px;
  padding: 1rem 1.1rem; border-radius: 18px; background: rgba(255,255,255,0.72); border: 1px solid var(--line);
  box-shadow: 0 14px 38px rgba(11,27,63,0.08); font-weight: 850; color: var(--navy);
}
.binding-sentence span { color: var(--gold); font-size: 1.15rem; line-height: 1.2; }
.hero-actions { display: flex; gap: 0.85rem; flex-wrap: wrap; margin: 1.55rem 0; }
.btn {
  display: inline-flex; justify-content: center; align-items: center; min-height: 46px; gap: 0.5rem;
  border: 0; border-radius: 999px; padding: 0.84rem 1.12rem; text-decoration: none; font-weight: 850;
  cursor: pointer; transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}
.btn:hover, .btn:focus-visible { transform: translateY(-1px); outline: none; }
.btn.primary { color: #fff; background: linear-gradient(135deg, var(--navy), var(--blue)); box-shadow: 0 16px 32px rgba(34,90,166,0.22); }
.btn.secondary { color: var(--navy); background: #fff; border: 1px solid var(--line); box-shadow: 0 14px 26px rgba(11,27,63,0.08); }
.btn.ghost { color: var(--navy); background: rgba(11,27,63,0.06); }
.btn.full { width: 100%; }

.authority-strip, .callout, .formula-box, .governance-anchor, .why-block {
  padding: 1.08rem 1.12rem; border-radius: 18px; color: #263247;
}
.authority-strip { max-width: 820px; background: rgba(11,27,63,0.06); border-left: 4px solid var(--gold); }
.callout { border: 1px solid rgba(17,138,126,0.28); background: rgba(17,138,126,0.08); color: #143a43; }
.why-block { background: linear-gradient(135deg, rgba(185,139,55,0.12), rgba(17,138,126,0.10)); border: 1px solid rgba(185,139,55,0.26); }
.governance-anchor { background: rgba(11,27,63,0.075); border: 1px solid rgba(11,27,63,0.14); color: var(--navy); font-weight: 900; }
.governance-anchor small { display: block; color: var(--muted); font-weight: 700; margin-top: 0.25rem; }

.hero-card {
  position: relative; background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(255,253,248,0.98));
  border: 1px solid rgba(109,65,30,0.15); border-radius: var(--radius-xl); padding: 1.2rem; box-shadow: var(--shadow); overflow: hidden;
}
.hero-card::after { content: ""; position: absolute; right: -90px; bottom: -110px; width: 260px; height: 260px; border-radius: 50%; border: 42px solid rgba(17,138,126,0.08); }
.hero-logo-wrap { position: relative; z-index: 1; width: min(260px, 72%); margin: 0 auto 1rem; border-radius: 50%; overflow: hidden; box-shadow: 0 22px 60px rgba(109,65,30,0.14); }
.metric-stack { position: relative; z-index: 1; display: grid; gap: 0.8rem; }
.metric-stack div { padding: 1rem; background: rgba(255,255,255,0.8); border: 1px solid var(--line); border-radius: 18px; }
.metric-stack span { display: inline-flex; width: 2.15rem; height: 2.15rem; align-items: center; justify-content: center; margin-bottom: 0.5rem; border-radius: 50%; background: var(--navy); color: #fff; font-size: 0.72rem; font-weight: 900; }
.metric-stack strong { display: block; color: var(--navy); font-size: 1.03rem; }
.metric-stack p { color: var(--muted); margin: 0.25rem 0 0; font-size: 0.94rem; }

.section-heading { max-width: 780px; text-align: center; margin: 0 auto 3rem; }
.section-heading.left { text-align: left; margin-left: 0; }
.section-heading p:not(.eyebrow) { color: var(--muted); font-size: 1.05rem; }

.page-map { padding: 0 0 36px; margin-top: -18px; }
.summary-grid, .page-grid, .cards, .tier-grid, .principle-grid, .routing-grid, .fund-grid, .split-grid, .pricing-grid, .timeline-grid, .demo-grid { display: grid; gap: 1rem; }
.summary-grid { grid-template-columns: repeat(3, 1fr); padding: 1rem; border-radius: 24px; background: rgba(255,255,255,0.75); box-shadow: 0 18px 54px rgba(11,27,63,0.09); border: 1px solid var(--line); }
.summary-item { padding: 1rem; border-radius: 18px; background: rgba(11,27,63,0.035); }
.summary-item.accent { background: rgba(17,138,126,0.1); }
.summary-item span { display: block; color: var(--muted); font-size: 0.78rem; text-transform: uppercase; font-weight: 900; letter-spacing: 0.11em; margin-bottom: 0.35rem; }
.summary-item strong { display: block; color: var(--navy); line-height: 1.25; }

.cards.four { grid-template-columns: repeat(4, 1fr); }
.cards.three, .tier-grid, .principle-grid { grid-template-columns: repeat(3, 1fr); }
.info-card, .tier-card, .flow-card, .fund-card, .pricing-figure, .dashboard-shell, .intake-form, .timeline-item, .matrix-card, .sequence-card, .brief-panel, .route-card {
  background: rgba(255,255,255,0.82); border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: 0 20px 60px rgba(11,27,63,0.08);
}
.info-card, .route-card, .matrix-card, .sequence-card, .brief-panel { position: relative; padding: 1.35rem; overflow: hidden; }
.info-card::before, .route-card::before, .matrix-card::before, .sequence-card::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 5px; background: linear-gradient(90deg, var(--gold), var(--teal));
}
.icon-circle { width: 58px; height: 58px; display: grid; place-items: center; margin-bottom: 1rem; border-radius: 50%; background: linear-gradient(135deg, var(--navy), var(--teal)); color: #fff; font-weight: 950; letter-spacing: -0.04em; }
.info-card p, .route-card p, .matrix-card p, .sequence-card p, .brief-panel p { color: var(--muted); }
.info-card ul, .clean-list { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; gap: 0.45rem; }
.info-card li, .clean-list li { display: flex; align-items: start; gap: 0.46rem; font-size: 0.93rem; color: #28364f; }
.info-card li::before, .clean-list li::before { content: ""; flex: 0 0 8px; width: 8px; height: 8px; margin-top: 0.48rem; border-radius: 50%; background: var(--gold); }

.split-grid { grid-template-columns: minmax(0,0.86fr) minmax(0,1.14fr); gap: 3rem; align-items: center; }
.data-flow { display: grid; gap: 0.85rem; min-width: 0; overflow: hidden; padding: 1rem; background: rgba(255,255,255,0.82); border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: 0 20px 60px rgba(11,27,63,0.08); }
.flow-row { display: grid; grid-template-columns: minmax(112px,0.95fr) minmax(48px,0.34fr) minmax(124px,1fr) minmax(48px,0.34fr) minmax(112px,0.95fr); gap: 0.55rem; align-items: center; min-width: 0; }
.flow-node { min-width: 0; padding: 0.95rem; border-radius: 18px; color: #fff; min-height: 112px; display: flex; flex-direction: column; justify-content: center; }
.flow-node span { display: block; opacity: 0.78; font-size: 0.73rem; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 900; margin-bottom: 0.42rem; }
.flow-node strong { display: block; font-size: clamp(0.92rem, 1vw, 1.08rem); line-height: 1.15; overflow-wrap: break-word; hyphens: auto; }
.flow-node.hub { background: linear-gradient(135deg, var(--brown), var(--gold)); }
.flow-node.spine { background: linear-gradient(135deg, var(--navy), var(--teal)); }
.flow-node.output { background: linear-gradient(135deg, var(--navy-2), var(--blue)); }
.flow-arrow { min-width: 0; display: flex; align-items: center; justify-content: center; min-height: 50px; color: var(--teal); font-weight: 950; text-transform: uppercase; letter-spacing: 0.08em; font-size: clamp(0.58rem, 0.72vw, 0.72rem); text-align: center; }
.flow-arrow::before, .flow-arrow::after { content: ""; height: 1px; flex: 1; background: var(--teal); opacity: 0.7; }
.flow-arrow span { padding: 0 0.3rem; }
.feed-list, .deliverables, .pack-output, .programme-tags, .chip-row { display: flex; flex-wrap: wrap; gap: 0.55rem; }
.feed-list span, .deliverables span, .pack-output span, .programme-tags span, .chip-row span, .pill {
  display: inline-flex; align-items: center; border-radius: 999px; padding: 0.42rem 0.68rem; background: rgba(11,27,63,0.06); color: var(--navy); font-size: 0.82rem; font-weight: 850;
}
.pill.accent, .chip-row span:first-child { background: rgba(17,138,126,0.1); color: var(--teal); }
.boundary-lines { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.7rem; }
.boundary-lines div { min-width: 0; padding: 0.9rem; border-radius: 16px; background: rgba(11,27,63,0.04); border: 1px solid rgba(11,27,63,0.08); }
.boundary-lines strong { display: block; color: var(--navy); margin-bottom: 0.2rem; }
.boundary-lines span { display: block; color: var(--muted); font-size: 0.9rem; }

.tier-card { padding: 1.45rem; position: relative; overflow: hidden; min-height: 315px; }
.tier-card::after { content: ""; position: absolute; right: -60px; bottom: -60px; width: 170px; height: 170px; border-radius: 50%; background: rgba(255,255,255,0.38); }
.tier-label { display: inline-flex; padding: 0.44rem 0.72rem; background: rgba(255,255,255,0.8); border-radius: 999px; font-weight: 950; color: var(--navy); margin-bottom: 1rem; }
.tier-card h3 { font-size: 1.55rem; margin-bottom: 0.75rem; }
.tier-card p, .tier-card .route-line { position: relative; z-index: 1; }
.tier-card p { color: #263247; }
.route-line { margin-top: 1.25rem; padding-top: 1rem; border-top: 1px solid rgba(11,27,63,0.16); font-weight: 850; color: var(--navy); }
.tier-one { background: linear-gradient(160deg, rgba(185,139,55,0.2), rgba(255,255,255,0.88)); }
.tier-two { background: linear-gradient(160deg, rgba(17,138,126,0.2), rgba(255,255,255,0.88)); }
.tier-three { background: linear-gradient(160deg, rgba(34,90,166,0.22), rgba(255,255,255,0.88)); }
.routing-grid { grid-template-columns: 0.9fr 1.1fr; gap: 1.2rem; align-items: stretch; }
.routing-logic { padding: 1.3rem; border-radius: var(--radius-lg); background: var(--navy); color: #fff; box-shadow: var(--shadow); }
.routing-logic h3 { color: #fff; }
.routing-logic p { color: rgba(255,255,255,0.72); }
.routing-logic .chip-row span { color: #fff; background: rgba(255,255,255,0.12); }
.matrix-card { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.8rem; }
.matrix-item { padding: 0.95rem; border-radius: 16px; background: rgba(11,27,63,0.04); border: 1px solid rgba(11,27,63,0.08); }
.matrix-item strong { display: block; color: var(--navy); }
.matrix-item span { color: var(--muted); font-size: 0.92rem; }

.fund-grid { grid-template-columns: repeat(5, 1fr); }
.fund-card { padding: 1rem; }
.fund-card span { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 50%; background: var(--navy); color: #fff; font-weight: 950; font-size: 0.8rem; margin-bottom: 0.75rem; }
.fund-card strong { display: block; color: var(--navy); font-size: 1.02rem; margin-bottom: 0.2rem; }
.fund-card p { margin: 0; color: var(--muted); font-size: 0.93rem; }
.fund-card.highlighted { background: linear-gradient(135deg, rgba(17,138,126,0.12), rgba(185,139,55,0.12)); }
.pricing-grid { grid-template-columns: minmax(0,0.65fr) minmax(480px,1.35fr); gap: 2rem; align-items: center; }
.formula-box { display: grid; gap: 0.45rem; margin-top: 1.2rem; border: 1px solid rgba(17,138,126,0.28); background: rgba(17,138,126,0.08); }
.formula-box strong { color: var(--navy); }
.formula-box span { color: #263247; font-weight: 750; }
.pricing-figure { padding: 1rem; margin: 0; }
.pricing-figure img { border-radius: 20px; border: 1px solid var(--line); background: #fff; }
.pricing-figure figcaption { color: var(--muted); font-size: 0.88rem; margin: 0.75rem 0.4rem 0; }

.timeline-grid { max-width: 990px; margin: 0 auto; }
.timeline-item { display: grid; grid-template-columns: 64px 1fr; gap: 1rem; position: relative; padding: 1rem; }
.timeline-marker { width: 64px; height: 64px; display: grid; place-items: center; border-radius: 50%; color: #fff; background: var(--navy); font-weight: 950; font-size: 1.2rem; box-shadow: 0 10px 28px rgba(11,27,63,0.2); }
.timeline-item h3 { margin: 0 0 0.25rem; font-size: 1.28rem; }
.duration { color: var(--teal); font-weight: 950; margin-bottom: 0.45rem; }
.parallel .timeline-marker { background: linear-gradient(135deg, var(--violet), var(--blue)); }

.dashboard-shell { overflow: hidden; display: grid; grid-template-columns: 292px 1fr; background: #f7faf9; }
.dashboard-sidebar { padding: 1.2rem; background: linear-gradient(180deg, var(--navy), #12366c); color: #fff; display: flex; flex-direction: column; gap: 0.8rem; }
.dash-title { margin-bottom: 1rem; }
.dash-title span { display: block; opacity: 0.74; text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.76rem; font-weight: 900; }
.dash-title strong { display: block; font-size: 1.35rem; letter-spacing: -0.04em; }
.dashboard-sidebar label { display: grid; gap: 0.35rem; font-size: 0.83rem; font-weight: 850; letter-spacing: 0.02em; }
.dashboard-sidebar select { width: 100%; border: 1px solid rgba(255,255,255,0.22); border-radius: 14px; background: rgba(255,255,255,0.1); color: #fff; padding: 0.82rem 0.85rem; outline: none; }
.dashboard-sidebar option { color: var(--navy); background: #fff; }
.dashboard-main { min-width: 0; padding: 1.2rem; }
.dashboard-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.8rem; margin-bottom: 1rem; }
.kpi-card { padding: 1rem; border-radius: 18px; background: #fff; border: 1px solid var(--line); }
.kpi-card span { display: block; color: var(--muted); font-size: 0.78rem; font-weight: 850; margin-bottom: 0.35rem; }
.kpi-card strong { display: block; color: var(--navy); font-size: 1.55rem; letter-spacing: -0.04em; }
.programme-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0.8rem; }
.programme-card { position: relative; border: 1px solid var(--line); border-radius: 20px; padding: 1rem; background: #fff; cursor: pointer; transition: transform 0.2s ease, box-shadow 0.2s ease, border 0.2s ease; }
.programme-card:hover, .programme-card:focus-visible, .programme-card.selected { transform: translateY(-2px); box-shadow: 0 18px 34px rgba(11,27,63,0.1); border-color: rgba(17,138,126,0.5); outline: none; }
.programme-card header { display: flex; justify-content: space-between; gap: 1rem; margin-bottom: 0.75rem; }
.programme-card h3 { margin: 0; font-size: 1.02rem; }
.programme-card .country { display: block; color: var(--muted); font-size: 0.82rem; margin-top: 0.2rem; }
.readiness-ring { flex: 0 0 62px; width: 62px; height: 62px; display: grid; place-items: center; border-radius: 50%; color: var(--navy); font-weight: 950; background: conic-gradient(var(--teal) var(--progress), rgba(11,27,63,0.08) 0); position: relative; }
.readiness-ring::before { content: ""; position: absolute; inset: 7px; border-radius: 50%; background: #fff; }
.readiness-ring span { position: relative; z-index: 1; font-size: 0.96rem; }
.programme-meta { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.5rem; margin-bottom: 0.75rem; }
.programme-meta div { padding: 0.7rem; border-radius: 14px; background: rgba(11,27,63,0.04); }
.programme-meta span { display: block; color: var(--muted); font-size: 0.75rem; font-weight: 850; }
.programme-meta strong { display: block; color: var(--navy); font-size: 0.92rem; }
.programme-tags span:first-child { background: rgba(17,138,126,0.1); color: var(--teal); }
.gap-list { margin: 0.75rem 0 0; padding: 0; list-style: none; display: grid; gap: 0.3rem; }
.gap-list li { color: var(--muted); font-size: 0.83rem; }
.gap-list li::before { content: "• "; color: var(--gold); font-weight: 950; }
.routing-panel { margin-top: 1rem; padding: 1.35rem; border: 1px solid rgba(17,138,126,0.22); border-radius: 20px; background: linear-gradient(135deg, rgba(17,138,126,0.08), rgba(255,255,255,0.9)); display: grid; grid-template-columns: 1fr 1.2fr; gap: 1.25rem; align-items: start; }
.routing-panel h3 { margin-bottom: 0.45rem; }
.routing-panel p { color: var(--muted); }
.pack-output span.active { background: var(--navy); color: #fff; }
.pack-detail { grid-column: 1 / -1; display: grid; gap: 0.8rem; margin-top: 0.9rem; padding-top: 1.1rem; border-top: 1px solid rgba(11,27,63,0.1); }
.pack-detail strong { display: block; color: var(--navy); margin-bottom: 0.1rem; }
.pack-detail span { display: block; padding: 0.9rem 1.05rem; border-radius: 24px; background: rgba(11,27,63,0.05); color: var(--navy); font-size: 0.96rem; font-weight: 800; line-height: 1.5; }
.pack-detail b { display: inline-block; min-width: 96px; margin-right: 0.5rem; color: var(--navy); }

.demo-programmes { display: grid; gap: 0.7rem; margin-top: 1rem; }
details.programme-detail { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 0.75rem 0.9rem; }
details.programme-detail summary { cursor: pointer; font-weight: 900; color: var(--navy); }
details.programme-detail p { margin: 0.55rem 0 0; color: var(--muted); }

.intake-grid { display: grid; grid-template-columns: minmax(0,0.9fr) minmax(360px,1.1fr); gap: 3rem; align-items: start; }
.intake-form { padding: 1.2rem; display: grid; gap: 0.9rem; }
.intake-form label { display: grid; gap: 0.35rem; font-weight: 850; color: var(--navy); }
.intake-form input, .intake-form select, .intake-form textarea { width: 100%; border: 1px solid var(--line); border-radius: 14px; padding: 0.85rem 0.9rem; background: #fff; color: var(--text); outline: none; }
.intake-form input:focus, .intake-form select:focus, .intake-form textarea:focus { border-color: var(--teal); box-shadow: 0 0 0 4px rgba(17,138,126,0.1); }

.sidebar-note { margin-top: 0.4rem; padding: 0.85rem; border: 1px solid rgba(255,255,255,0.18); border-radius: 16px; background: rgba(255,255,255,0.08); }
.sidebar-note strong { display: block; font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.1em; opacity: 0.86; margin-bottom: 0.32rem; }
.sidebar-note span { display: block; color: rgba(255,255,255,0.74); font-size: 0.83rem; line-height: 1.45; }
.wide-chips { justify-content: center; max-width: 980px; margin: 0 auto; }

.site-footer { padding: 40px 0; background: var(--navy); color: #fff; }
.footer-grid { display: grid; grid-template-columns: 0.9fr 1.4fr 0.7fr; gap: 1.6rem; align-items: start; }
.site-footer p { color: rgba(255,255,255,0.7); margin: 0.35rem 0 0; font-size: 0.92rem; }
.site-footer a, .print-button { display: inline-flex; color: #fff; text-decoration: none; font-weight: 850; margin-bottom: 0.6rem; }
.print-button { border: 1px solid rgba(255,255,255,0.18); border-radius: 999px; background: rgba(255,255,255,0.08); padding: 0.65rem 0.9rem; cursor: pointer; }
.footer-links { display: grid; gap: 0.25rem; }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }


#boundary .container { width: min(1320px, calc(100vw - 48px)); }
#boundary .section-heading h2 { font-size: clamp(2.25rem, 4.2vw, 4.6rem); }

@media (max-width: 1320px) {
  #boundary .split-grid { gap: 2rem; }
  .flow-row { grid-template-columns: minmax(104px,0.95fr) minmax(40px,0.28fr) minmax(114px,1fr) minmax(40px,0.28fr) minmax(104px,0.95fr); gap: 0.45rem; }
  .flow-node { padding: 0.82rem; }
}
@media (max-width: 1120px) {
  .cards.four, .dashboard-kpis, .fund-grid { grid-template-columns: repeat(2, 1fr); }
  .cards.three, .tier-grid, .principle-grid, .footer-grid, .summary-grid, .routing-grid, .boundary-lines { grid-template-columns: 1fr; }
  .pricing-grid, .split-grid, .intake-grid { grid-template-columns: 1fr; }
  .flow-row { grid-template-columns: 1fr; }
  .flow-arrow { min-height: 32px; }
}
@media (max-width: 940px) {
  .nav-toggle { display: inline-block; }
  .primary-nav { position: fixed; inset: var(--header-h) 20px auto 20px; display: none; flex-direction: column; align-items: stretch; gap: 0.4rem; padding: 1rem; border: 1px solid var(--line); border-radius: 22px; background: rgba(255,253,248,0.98); box-shadow: var(--shadow); }
  .primary-nav.open { display: flex; }
  .primary-nav a { border-radius: 14px; }
  .hero-grid { grid-template-columns: 1fr; padding-top: 1.2rem; }
  .hero-card { max-width: 560px; }
  .dashboard-shell { grid-template-columns: 1fr; }
  .dashboard-sidebar { display: grid; grid-template-columns: repeat(2, 1fr); align-items: end; }
  .dash-title { grid-column: 1 / -1; }
}
@media (max-width: 720px) {
  .container { width: min(var(--max), calc(100vw - 24px)); }
  .section, .section-panel { padding: 66px 0; }
  .hero { min-height: auto; }
  .hero-actions, .routing-panel, .dashboard-sidebar { grid-template-columns: 1fr; }
  .btn, .hero-actions .btn { width: 100%; }
  .cards.four, .cards.three, .tier-grid, .programme-grid, .dashboard-kpis, .programme-meta, .fund-grid, .matrix-card { grid-template-columns: 1fr; }
  .timeline-item { grid-template-columns: 52px 1fr; padding: 0.8rem; }
  .timeline-marker { width: 52px; height: 52px; }
  .brand strong { font-size: 0.86rem; }
  h1 { font-size: clamp(2.65rem, 14vw, 4.2rem); }
}
@media print {
  .site-header, .hero-actions, .dashboard-sidebar, .intake-section, .print-button, .skip-link { display: none !important; }
  body { background: #fff; }
  .section, .section-panel { padding: 28px 0; }
  .reveal { opacity: 1 !important; transform: none !important; }
  .dashboard-shell, .info-card, .tier-card, .timeline-item, .fund-card, .data-flow, .pricing-figure, .matrix-card, .sequence-card, .brief-panel { box-shadow: none; break-inside: avoid; }
}

/* Reviewer-grade surgical system architecture refinements */
.system-hero { min-height: calc(82vh - var(--header-h)); }
.definition-block {
  display: grid;
  gap: 0.48rem;
  max-width: 840px;
  padding: 1.2rem;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(11, 27, 63, 0.14);
  box-shadow: 0 18px 48px rgba(11, 27, 63, 0.08);
}
.definition-block strong {
  color: var(--teal);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.78rem;
  font-weight: 950;
}
.definition-block p {
  margin: 0;
  color: #28364f;
  font-weight: 760;
}

.institutional-chain-block {
  display: grid;
  gap: 0.42rem;
  max-width: 840px;
  margin-top: 1rem;
  padding: 1.15rem 1.18rem;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(11,27,63,0.075), rgba(17,138,126,0.075));
  border: 1px solid rgba(17, 138, 126, 0.24);
  box-shadow: 0 18px 48px rgba(11, 27, 63, 0.08);
}
.institutional-chain-block strong {
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.78rem;
  font-weight: 950;
}
.institutional-chain-block p {
  margin: 0;
  color: #28364f;
  font-weight: 820;
  line-height: 1.42;
}
.reviewer-route { padding: 1.05rem; }
.route-kicker {
  color: var(--teal);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 950;
  font-size: 0.76rem;
  margin-bottom: 0.85rem;
}
.reviewer-route ol { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.58rem; position: relative; z-index: 1; }
.reviewer-route li {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  grid-template-rows: auto auto;
  column-gap: 0.72rem;
  row-gap: 0.12rem;
  align-items: center;
  padding: 0.72rem 0.78rem;
  border-radius: 18px;
  border: 1px solid rgba(11,27,63,0.1);
  background: rgba(255,255,255,0.72);
}
.reviewer-route li span {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: #fff;
  background: linear-gradient(135deg, var(--navy), var(--teal));
  font-weight: 950;
  font-size: 0.78rem;
}
.reviewer-route li span { grid-row: 1 / span 2; }
.reviewer-route li strong { display: block; grid-column: 2; color: var(--navy); line-height: 1.12; }
.reviewer-route li small { display: block; grid-column: 2; color: var(--muted); font-weight: 750; margin-top: 0; line-height: 1.32; }

.governance-chain {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) 34px minmax(120px, 1fr) 34px minmax(120px, 1fr) 34px minmax(120px, 1fr) 34px minmax(140px, 1.08fr) 34px minmax(140px, 1.08fr);
  gap: 0.54rem;
  align-items: stretch;
  padding: 1rem;
  border-radius: 28px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.8);
  box-shadow: 0 20px 60px rgba(11,27,63,0.08);
}
.chain-node {
  min-width: 0;
  min-height: 126px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.42rem;
  padding: 1rem;
  border-radius: 20px;
  color: #fff;
}
.chain-node span {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  opacity: 0.78;
  font-weight: 950;
}
.chain-node strong { display: block; line-height: 1.16; font-size: clamp(0.95rem, 1.1vw, 1.15rem); overflow-wrap: break-word; }
.chain-node.evidence { background: linear-gradient(135deg, var(--brown), var(--gold)); }
.chain-node.review { background: linear-gradient(135deg, #20345d, var(--blue)); }
.chain-node.authorization { background: linear-gradient(135deg, var(--navy), #304d82); }
.chain-node.verification { background: linear-gradient(135deg, var(--teal), #0d6b62); }
.chain-node.funding { background: linear-gradient(135deg, var(--navy), var(--teal)); }
.chain-node.capital { background: linear-gradient(135deg, var(--navy-2), var(--blue)); }
.chain-arrow {
  display: grid;
  place-items: center;
  color: var(--teal);
  font-size: 1.35rem;
  font-weight: 950;
}
.why-panel { text-align: center; max-width: 980px; margin: 0 auto; }

.module-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1.1rem; }
.module-card {
  position: relative;
  min-width: 0;
  padding: 1.35rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.84);
  box-shadow: 0 20px 60px rgba(11,27,63,0.08);
  overflow: hidden;
}
.module-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 5px;
  background: linear-gradient(90deg, var(--gold), var(--teal), var(--blue));
}
.module-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 0.85rem; }
.module-number, .module-code { display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; font-weight: 950; }
.module-number { width: 42px; height: 42px; background: var(--navy); color: #fff; font-size: 0.78rem; }
.module-code { min-width: 58px; height: 42px; padding: 0 0.9rem; background: rgba(17,138,126,0.1); color: var(--teal); letter-spacing: 0.08em; }
.module-card h3 { font-size: 1.55rem; margin-bottom: 0.45rem; }
.governing-sentence {
  margin-bottom: 1rem;
  color: var(--navy);
  font-weight: 900;
  line-height: 1.32;
}
.module-structure { display: grid; gap: 0.72rem; }
.module-structure > div {
  padding: 0.86rem;
  border-radius: 16px;
  background: rgba(11,27,63,0.04);
  border: 1px solid rgba(11,27,63,0.08);
}
.module-structure strong { display: block; color: var(--teal); text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.72rem; margin-bottom: 0.28rem; }
.module-structure span { display: block; color: #28364f; font-weight: 720; }
.module-structure ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 0.24rem; }
.module-structure li { color: #28364f; font-size: 0.92rem; }
.module-structure li::before { content: "• "; color: var(--gold); font-weight: 950; }
.boundary-does-not {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 1.25rem;
}
.boundary-does-not span {
  display: inline-flex;
  border-radius: 999px;
  padding: 0.54rem 0.76rem;
  background: rgba(11,27,63,0.08);
  color: var(--navy);
  font-weight: 900;
  font-size: 0.85rem;
}
#authority-boundary .container { width: min(1320px, calc(100vw - 48px)); }
#authority-boundary .section-heading h2 { font-size: clamp(2.25rem, 4.2vw, 4.6rem); }
.compact-flow .flow-node { min-height: 104px; }

.output-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
}
.output-card {
  min-width: 0;
  padding: 1rem;
  border-radius: 20px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.84);
  box-shadow: 0 18px 46px rgba(11,27,63,0.07);
}
.output-card span {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  background: linear-gradient(135deg, var(--navy), var(--teal));
  font-weight: 950;
  font-size: 0.78rem;
  margin-bottom: 0.72rem;
}
.output-card strong { display: block; color: var(--navy); font-size: 1.02rem; margin-bottom: 0.25rem; }
.output-card p { margin: 0; color: var(--muted); font-size: 0.91rem; }
.link-cards { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.link-card {
  display: block;
  min-width: 0;
  padding: 1.2rem;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.82);
  box-shadow: 0 18px 46px rgba(11,27,63,0.07);
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.link-card:hover, .link-card:focus-visible { transform: translateY(-2px); box-shadow: 0 24px 54px rgba(11,27,63,0.11); border-color: rgba(17,138,126,0.45); outline: none; }
.link-card span { display: block; color: var(--teal); text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.76rem; font-weight: 950; margin-bottom: 0.45rem; }
.link-card strong { display: block; color: var(--navy); line-height: 1.25; }

@media (max-width: 1320px) {
  .governance-chain { grid-template-columns: repeat(6, minmax(0, 1fr)); }
  .governance-chain .chain-arrow { display: none; }
}
@media (max-width: 1120px) {
  .module-grid, .output-grid, .link-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  #authority-boundary .split-grid { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .governance-chain { grid-template-columns: 1fr; }
  .chain-node { min-height: 98px; }
  .module-grid, .output-grid, .link-cards { grid-template-columns: 1fr; }
  .reviewer-route li { grid-template-columns: 38px minmax(0, 1fr); }
  .reviewer-route li span { width: 38px; height: 38px; }
}

/* Surgical Capital Architecture refinements */
.capital-hero { min-height: calc(84vh - var(--header-h)); }
.capital-definition { margin-top: 1.05rem; }
.capital-definition p + p { padding-top: 0.42rem; border-top: 1px solid rgba(11,27,63,0.09); }
.capital-hero-card { display: grid; gap: 0.9rem; }
.dependency-flow,
.capital-dependency-wide {
  display: grid;
  gap: 0.65rem;
  align-items: stretch;
}
.compact-dependency { grid-template-columns: 1fr 34px 1fr 34px 1fr; }
.capital-dependency-wide { grid-template-columns: 1fr 34px 1fr 34px 1fr 34px 1fr; }
.dep-node {
  min-width: 0;
  min-height: 116px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.42rem;
  padding: 1rem;
  border-radius: 20px;
  color: #fff;
}
.dep-node span { display: block; text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.7rem; opacity: 0.78; font-weight: 950; }
.dep-node strong { display: block; line-height: 1.16; font-size: clamp(0.92rem, 1.05vw, 1.08rem); overflow-wrap: break-word; }
.dep-node.hub { background: linear-gradient(135deg, var(--brown), var(--gold)); }
.dep-node.spine { background: linear-gradient(135deg, var(--navy), var(--teal)); }
.dep-node.capital { background: linear-gradient(135deg, var(--navy-2), var(--blue)); }
.dep-node.institution { background: linear-gradient(135deg, #20345d, var(--violet)); }
.dep-arrow { display: grid; place-items: center; color: var(--teal); font-size: 1.35rem; font-weight: 950; }
.mini-boundary,
.authority-box {
  padding: 0.95rem 1rem;
  border-radius: 18px;
  border: 1px solid rgba(185,139,55,0.24);
  background: rgba(185,139,55,0.1);
  color: var(--navy);
  font-weight: 880;
}
.top-boundary { margin-top: 1rem; }
.capital-shell-section { padding-top: 34px; }
.capital-shell { display: grid; grid-template-columns: 230px minmax(0, 1fr); gap: 1.35rem; align-items: start; }
.capital-rail {
  position: sticky;
  top: calc(var(--header-h) + 18px);
  display: grid;
  gap: 0.55rem;
  padding: 1rem;
  border-radius: 24px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.82);
  box-shadow: 0 18px 48px rgba(11,27,63,0.08);
}
.capital-rail strong { color: var(--navy); margin-bottom: 0.35rem; }
.capital-rail a {
  display: grid;
  grid-template-columns: 34px minmax(0,1fr);
  align-items: center;
  gap: 0.55rem;
  text-decoration: none;
  color: var(--navy);
  font-weight: 880;
  padding: 0.58rem;
  border-radius: 16px;
  transition: background 0.2s ease, color 0.2s ease;
}
.capital-rail a:hover,
.capital-rail a:focus-visible { background: rgba(17,138,126,0.1); color: var(--teal); outline: none; }
.capital-rail a span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--navy), var(--teal));
  color: #fff;
  font-size: 0.72rem;
  font-weight: 950;
}
.capital-content { display: grid; gap: 1.15rem; min-width: 0; }
.architecture-section {
  padding: clamp(1.1rem, 2vw, 1.55rem);
  border-radius: var(--radius-xl);
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.82);
  box-shadow: 0 20px 60px rgba(11,27,63,0.08);
  overflow: hidden;
  scroll-margin-top: calc(var(--header-h) + 18px);
}
.architecture-section.muted-card { background: linear-gradient(180deg, rgba(238,244,241,0.72), rgba(255,253,248,0.9)); }
.section-heading.tight { margin-bottom: 1.25rem; max-width: 900px; }
.section-heading.tight h2 { font-size: clamp(2rem, 3.5vw, 3.45rem); }
.routing-flow {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.75rem;
  position: relative;
}
.routing-flow div {
  min-width: 0;
  padding: 1rem;
  border-radius: 20px;
  border: 1px solid rgba(11,27,63,0.11);
  background: rgba(255,255,255,0.82);
}
.routing-flow span {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  margin-bottom: 0.65rem;
  border-radius: 999px;
  background: var(--navy);
  color: #fff;
  font-size: 0.74rem;
  font-weight: 950;
}
.routing-flow strong { display: block; color: var(--navy); line-height: 1.15; margin-bottom: 0.35rem; }
.routing-flow p { margin: 0; color: var(--muted); font-size: 0.9rem; }
.routing-boundary { margin-top: 1rem; }
.compact-tiers .tier-card { min-height: 255px; padding: 1.25rem; }
.compact-tiers .tier-card h3 { font-size: 1.35rem; }
.compact-tiers .tier-card p { font-size: 0.94rem; }
.tier-diagram {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
  margin-top: 1rem;
  padding: 0.9rem 1rem;
  border-radius: 18px;
  background: rgba(11,27,63,0.055);
  border: 1px solid rgba(11,27,63,0.09);
}
.tier-diagram span,
.tier-diagram strong {
  display: inline-flex;
  border-radius: 999px;
  padding: 0.48rem 0.74rem;
  font-weight: 920;
}
.tier-diagram span { background: #fff; color: var(--navy); border: 1px solid rgba(11,27,63,0.08); }
.tier-diagram strong { background: linear-gradient(135deg, var(--navy), var(--teal)); color: #fff; }
.tier-diagram i { width: 32px; height: 1px; background: var(--teal); opacity: 0.7; }
.interface-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.8rem;
}
.interface-card {
  min-width: 0;
  padding: 1rem;
  border-radius: 20px;
  border: 1px solid rgba(11,27,63,0.1);
  background: rgba(255,255,255,0.82);
}
.interface-card strong { display: block; color: var(--navy); font-size: 1.02rem; margin-bottom: 0.35rem; }
.interface-card p { margin: 0; color: var(--muted); font-size: 0.92rem; }
.interface-card.authority { background: linear-gradient(135deg, rgba(11,27,63,0.08), rgba(185,139,55,0.12)); border-color: rgba(185,139,55,0.28); }
.actor-grid-compact .info-card { padding: 1.05rem; }
.actor-grid-compact .info-card h3 { font-size: 1.08rem; }
.actor-grid-compact .icon-circle { width: 48px; height: 48px; font-size: 0.78rem; margin-bottom: 0.78rem; }
.capital-output-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.capital-links { margin-top: 1rem; }

@media (max-width: 1280px) {
  .compact-dependency,
  .capital-dependency-wide { grid-template-columns: 1fr; }
  .compact-dependency .dep-arrow,
  .capital-dependency-wide .dep-arrow { min-height: 24px; }
  .dep-node { min-height: 96px; }
  .routing-flow { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .interface-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 1120px) {
  .capital-shell { grid-template-columns: 1fr; }
  .capital-rail { position: static; grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .capital-rail strong { grid-column: 1 / -1; }
  .capital-output-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .capital-rail,
  .routing-flow,
  .interface-grid,
  .capital-output-grid { grid-template-columns: 1fr; }
  .tier-diagram i { display: none; }
}

/* Reviewer-route Funding Spine tightening */
.utility-strip {
  position: sticky;
  top: var(--header-h);
  z-index: 50;
  border-bottom: 1px solid rgba(11,27,63,0.08);
  background: rgba(255,253,248,0.86);
  backdrop-filter: blur(16px);
}
.utility-strip-grid {
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.utility-strip span {
  color: var(--muted);
  font-weight: 900;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.utility-strip div div {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.45rem;
}
.utility-strip a,
.print-button.small {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.42rem 0.68rem;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 900;
  font-size: 0.78rem;
  color: var(--navy);
  border: 1px solid rgba(11,27,63,0.12);
  background: rgba(255,255,255,0.72);
  margin: 0;
}
.print-button.small {
  cursor: pointer;
}
.route-hero { min-height: calc(78vh - var(--header-h)); padding-top: 72px; }
.route-hero-grid { align-items: start; }
.hero-lede.smaller {
  font-size: clamp(1rem, 1.2vw, 1.12rem);
  color: var(--muted);
  max-width: 720px;
}
.top-authority-statement {
  display: grid;
  gap: 0.22rem;
  max-width: 760px;
  margin-top: 1rem;
  padding: 1rem 1.08rem;
  border-radius: 20px;
  border: 1px solid rgba(185,139,55,0.28);
  background: rgba(185,139,55,0.11);
  box-shadow: 0 16px 38px rgba(11,27,63,0.07);
}
.top-authority-statement strong {
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.76rem;
  font-weight: 950;
}
.top-authority-statement span {
  color: #263247;
  font-weight: 850;
  line-height: 1.35;
}
.governed-route-card {
  padding: 1rem;
  overflow: hidden;
}
.governed-route-list {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.55rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.governed-route-list::before {
  content: "";
  position: absolute;
  left: 20px;
  top: 28px;
  bottom: 28px;
  width: 2px;
  background: linear-gradient(180deg, rgba(185,139,55,0.62), rgba(17,138,126,0.62), rgba(34,90,166,0.5));
}
.governed-route-list li {
  position: relative;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 0.72rem;
  align-items: start;
  padding: 0.74rem;
  border-radius: 18px;
  border: 1px solid rgba(11,27,63,0.1);
  background: rgba(255,255,255,0.78);
}
.governed-route-list li span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  color: #fff;
  background: linear-gradient(135deg, var(--navy), var(--teal));
  font-weight: 950;
  font-size: 0.78rem;
  box-shadow: 0 10px 24px rgba(11,27,63,0.14);
}
.governed-route-list strong {
  display: block;
  color: var(--navy);
  line-height: 1.18;
  margin-bottom: 0.12rem;
}
.governed-route-list small {
  display: block;
  color: var(--muted);
  font-weight: 740;
  line-height: 1.35;
}
.anchor-visual {
  display: grid;
  grid-template-columns: minmax(150px,1fr) 36px minmax(150px,1fr) 36px minmax(150px,1fr) 36px minmax(150px,1fr);
  gap: 0.65rem;
  align-items: stretch;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 30px;
  background: rgba(255,255,255,0.84);
  box-shadow: 0 22px 62px rgba(11,27,63,0.08);
}
.anchor-node {
  min-width: 0;
  min-height: 128px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.42rem;
  padding: 1.05rem;
  border-radius: 22px;
  color: #fff;
}
.anchor-node span {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.72rem;
  opacity: 0.8;
  font-weight: 950;
}
.anchor-node strong {
  display: block;
  line-height: 1.16;
  font-size: clamp(0.98rem, 1.12vw, 1.18rem);
}
.anchor-node.hub { background: linear-gradient(135deg, var(--brown), var(--gold)); }
.anchor-node.reviewer { background: linear-gradient(135deg, #20345d, var(--blue)); }
.anchor-node.spine { background: linear-gradient(135deg, var(--navy), var(--teal)); }
.anchor-node.capital { background: linear-gradient(135deg, var(--navy-2), var(--violet)); }
.anchor-arrow {
  display: grid;
  place-items: center;
  color: var(--teal);
  font-size: 1.5rem;
  font-weight: 950;
}
.anchor-boundary-box {
  max-width: 980px;
  margin: 1rem auto 0;
  padding: 1rem 1.15rem;
  border-radius: 20px;
  border: 1px solid rgba(185,139,55,0.28);
  background: rgba(185,139,55,0.1);
  color: var(--navy);
}
.anchor-boundary-box strong {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.76rem;
  font-weight: 950;
  margin-bottom: 0.35rem;
}
.anchor-boundary-box p { margin: 0; font-weight: 820; }
.institutional-chain-wide {
  display: grid;
  grid-template-columns: minmax(260px, 0.8fr) minmax(0, 1.2fr);
  gap: 1.2rem;
  align-items: center;
  padding: 1.3rem;
  border-radius: 30px;
  border: 1px solid rgba(17,138,126,0.25);
  background: linear-gradient(135deg, rgba(255,255,255,0.9), rgba(17,138,126,0.08));
  box-shadow: 0 20px 58px rgba(11,27,63,0.08);
}
.chain-title h2 { margin-bottom: 0; }
.chain-statements {
  display: grid;
  gap: 0.62rem;
}
.chain-statements p {
  margin: 0;
  padding: 0.78rem 0.9rem;
  border-radius: 18px;
  border: 1px solid rgba(11,27,63,0.09);
  background: rgba(255,255,255,0.76);
  color: #263247;
  font-weight: 780;
}
.chain-statements strong { color: var(--navy); }
.definition-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.72fr) minmax(0, 1.28fr);
  gap: 2.2rem;
  align-items: start;
}
.definition-stack {
  display: grid;
  gap: 0.86rem;
}
.definition-stack article {
  padding: 1.05rem 1.1rem;
  border-radius: 20px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.82);
  box-shadow: 0 18px 46px rgba(11,27,63,0.07);
}
.definition-stack strong {
  display: block;
  color: var(--teal);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.76rem;
  font-weight: 950;
  margin-bottom: 0.32rem;
}
.definition-stack p { margin: 0; color: #28364f; font-weight: 760; }
.bounded-module-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.05rem;
}
.bounded-module-card {
  position: relative;
  min-width: 0;
  padding: 1.25rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.86);
  box-shadow: 0 20px 60px rgba(11,27,63,0.08);
  overflow: hidden;
}
.bounded-module-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 5px;
  background: linear-gradient(90deg, var(--gold), var(--teal), var(--blue));
}
.bounded-module-card h3 {
  font-size: 1.42rem;
  margin-bottom: 0.42rem;
}
.module-boundary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.62rem;
}
.module-boundary-grid div {
  min-width: 0;
  padding: 0.8rem;
  border-radius: 16px;
  background: rgba(11,27,63,0.04);
  border: 1px solid rgba(11,27,63,0.08);
}
.module-boundary-grid strong {
  display: block;
  color: var(--teal);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.7rem;
  font-weight: 950;
  margin-bottom: 0.25rem;
}
.module-boundary-grid span {
  display: block;
  color: #28364f;
  font-weight: 720;
  font-size: 0.92rem;
  line-height: 1.42;
}
.authority-statement-box {
  display: grid;
  gap: 0.38rem;
  margin-top: 1.1rem;
  padding: 1rem 1.08rem;
  border-radius: 20px;
  border: 1px solid rgba(185,139,55,0.28);
  background: rgba(185,139,55,0.1);
}
.authority-statement-box strong { color: var(--navy); font-size: 1rem; }
.authority-statement-box span { color: #263247; font-weight: 760; }
.outputs-topline {
  max-width: 1040px;
  margin: 0 auto 1rem;
  display: grid;
  gap: 0.3rem;
  padding: 1rem 1.1rem;
  border-radius: 20px;
  border: 1px solid rgba(17,138,126,0.25);
  background: rgba(17,138,126,0.08);
  box-shadow: 0 18px 46px rgba(11,27,63,0.07);
}
.outputs-topline strong {
  color: var(--teal);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.76rem;
  font-weight: 950;
}
.outputs-topline span { color: var(--navy); font-weight: 850; }
.output-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
  max-width: 1040px;
  margin: 0 auto;
}
.output-detail-grid details {
  min-width: 0;
  padding: 0.95rem;
  border-radius: 20px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.86);
  box-shadow: 0 18px 46px rgba(11,27,63,0.07);
}
.output-detail-grid summary {
  cursor: pointer;
  color: var(--navy);
  font-weight: 950;
  list-style-position: outside;
}
.output-detail-grid ul {
  margin: 0.72rem 0 0;
  padding-left: 1.1rem;
  display: grid;
  gap: 0.45rem;
}
.output-detail-grid li { color: var(--muted); font-size: 0.93rem; }
.output-detail-grid li strong { color: var(--navy); }
.nav-spine-section {
  display: grid;
  grid-template-columns: minmax(280px, 0.72fr) minmax(0, 1.28fr);
  gap: 2rem;
  align-items: start;
}
.architecture-nav-spine {
  position: relative;
  display: grid;
  gap: 0.75rem;
}
.architecture-nav-spine::before {
  content: "";
  position: absolute;
  left: 23px;
  top: 24px;
  bottom: 24px;
  width: 2px;
  background: linear-gradient(180deg, rgba(185,139,55,0.6), rgba(17,138,126,0.6), rgba(34,90,166,0.48));
}
.architecture-nav-spine a {
  position: relative;
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  column-gap: 0.85rem;
  row-gap: 0.12rem;
  min-width: 0;
  padding: 0.9rem 1rem;
  border-radius: 20px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.86);
  box-shadow: 0 18px 46px rgba(11,27,63,0.07);
  text-decoration: none;
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
.architecture-nav-spine a:hover,
.architecture-nav-spine a:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(17,138,126,0.45);
  box-shadow: 0 24px 54px rgba(11,27,63,0.11);
  outline: none;
}
.architecture-nav-spine span {
  grid-row: 1 / span 2;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  color: #fff;
  background: linear-gradient(135deg, var(--navy), var(--teal));
  font-weight: 950;
  box-shadow: 0 10px 24px rgba(11,27,63,0.14);
}
.architecture-nav-spine strong { display: block; color: var(--navy); line-height: 1.18; }
.architecture-nav-spine small { display: block; color: var(--muted); font-weight: 760; line-height: 1.34; }

@media (max-width: 1180px) {
  .anchor-visual { grid-template-columns: repeat(4, minmax(0, 1fr)); }
  .anchor-arrow { display: none; }
  .output-detail-grid { grid-template-columns: 1fr; }
}
@media (max-width: 940px) {
  .utility-strip { position: static; }
  .utility-strip-grid { align-items: flex-start; flex-direction: column; padding: 0.65rem 0; }
  .institutional-chain-wide,
  .definition-grid,
  .nav-spine-section { grid-template-columns: 1fr; }
  .bounded-module-grid { grid-template-columns: 1fr; }
  .module-boundary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  .route-hero { padding-top: 50px; }
  .anchor-visual { grid-template-columns: 1fr; }
  .anchor-node { min-height: 98px; }
  .module-boundary-grid { grid-template-columns: 1fr; }
  .governed-route-list li { grid-template-columns: 38px minmax(0, 1fr); }
  .governed-route-list li span { width: 38px; height: 38px; }
  .utility-strip div div { width: 100%; }
  .utility-strip a,
  .print-button.small { flex: 1 1 auto; justify-content: center; }
}
@media print {
  .utility-strip { display: none !important; }
}

/* Micro-corrections: reviewer-route visual tightening */
.institutional-chain-wide {
  grid-template-columns: minmax(260px, 0.45fr) minmax(0, 1.55fr);
  align-items: stretch;
}
.institutional-chain-visual {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) 24px minmax(120px, 1fr) 24px minmax(120px, 1fr) 24px minmax(120px, 1fr);
  gap: 0.55rem;
  align-items: stretch;
}
.chain-step {
  min-width: 0;
  display: grid;
  gap: 0.22rem;
  align-content: center;
  padding: 0.86rem;
  border-radius: 18px;
  border: 1px solid rgba(11,27,63,0.1);
  background: rgba(255,255,255,0.82);
  box-shadow: 0 12px 30px rgba(11,27,63,0.06);
}
.chain-step span {
  color: var(--teal);
  font-size: 0.7rem;
  font-weight: 950;
  letter-spacing: 0.12em;
}
.chain-step strong {
  color: var(--navy);
  font-size: 0.98rem;
  line-height: 1.14;
}
.chain-step small {
  color: var(--muted);
  font-weight: 750;
  line-height: 1.32;
}
.chain-link {
  display: grid;
  place-items: center;
  color: var(--teal);
  font-weight: 950;
  font-size: 1.25rem;
}
.compact-definition-stack { gap: 0.78rem; }
.institutional-summary-line {
  color: var(--navy) !important;
  font-weight: 920 !important;
  margin-bottom: 0.42rem !important;
}
.module-boundary-grid .cannot-produce {
  border-color: rgba(185,139,55,0.26);
  background: rgba(185,139,55,0.08);
}
.module-boundary-grid .cannot-produce span {
  min-height: 2.6em;
  display: flex;
  align-items: center;
  color: var(--navy);
  font-weight: 820;
}
.nav-spine-section {
  grid-template-columns: 1fr;
  gap: 1.15rem;
}
.nav-spine-section .section-heading.left {
  max-width: 900px;
}
.architecture-nav-spine {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.95rem;
  align-items: stretch;
}
.architecture-nav-spine::before {
  left: 8%;
  right: 8%;
  top: 33px;
  bottom: auto;
  width: auto;
  height: 2px;
  background: linear-gradient(90deg, rgba(185,139,55,0.62), rgba(17,138,126,0.64), rgba(34,90,166,0.52));
}
.architecture-nav-spine a {
  min-height: 128px;
  align-content: start;
}

@media (max-width: 1180px) {
  .institutional-chain-wide { grid-template-columns: 1fr; }
  .institutional-chain-visual {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .institutional-chain-visual .chain-link { display: none; }
}
@media (max-width: 940px) {
  .architecture-nav-spine { grid-template-columns: 1fr; }
  .architecture-nav-spine::before {
    left: 23px;
    right: auto;
    top: 24px;
    bottom: 24px;
    width: 2px;
    height: auto;
    background: linear-gradient(180deg, rgba(185,139,55,0.6), rgba(17,138,126,0.6), rgba(34,90,166,0.48));
  }
  .architecture-nav-spine a { min-height: auto; }
}
@media (max-width: 720px) {
  .institutional-chain-visual { grid-template-columns: 1fr; }
  .module-boundary-grid .cannot-produce span { min-height: 0; }
}

/* Secure Institution Portal */
.hidden { display: none !important; }
.secure-hero .hero-lede { max-width: 840px; }
.portal-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: 0 auto 1.2rem;
  padding: 0.95rem 1.05rem;
  border-radius: 999px;
  border: 1px solid rgba(11, 27, 63, 0.14);
  background: rgba(255,255,255,0.78);
  box-shadow: 0 12px 30px rgba(11,27,63,0.07);
  color: var(--navy);
}
.portal-status strong { font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--teal); }
.portal-status span { font-weight: 850; text-align: right; }
.auth-gate {
  margin-top: 1.3rem;
  padding: 1.15rem;
  border-radius: var(--radius-xl);
  border: 1px solid rgba(11,27,63,0.12);
  background: rgba(255,255,255,0.82);
  box-shadow: var(--shadow);
}
.auth-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.auth-card {
  padding: 1.25rem;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,253,248,0.94), rgba(255,255,255,0.98));
}
.auth-card.wide { max-width: 820px; margin: 0 auto; }
.auth-card h3 { margin-bottom: 0.85rem; }
.auth-card label, .dashboard-sidebar label {
  display: grid;
  gap: 0.42rem;
  color: var(--navy);
  font-weight: 850;
  font-size: 0.9rem;
}
.auth-card input, .auth-card select, .auth-card textarea,
.dashboard-sidebar select {
  width: 100%;
  border: 1px solid rgba(11,27,63,0.18);
  border-radius: 14px;
  background: #fff;
  color: var(--text);
  padding: 0.78rem 0.88rem;
  font-weight: 700;
}
.auth-card label + label { margin-top: 0.85rem; }
.auth-card .btn { margin-top: 1rem; }
.form-status {
  min-height: 1.5rem;
  margin: 0.8rem 0 0;
  color: var(--muted);
  font-weight: 750;
}
.portal-workspace { margin-top: 1.4rem; }
.session-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  padding: 0.9rem 1rem;
  border-radius: 20px;
  border: 1px solid rgba(17,138,126,0.22);
  background: rgba(17,138,126,0.07);
  color: var(--navy);
}
.session-bar strong { display: block; letter-spacing: 0.1em; text-transform: uppercase; font-size: 0.76rem; color: var(--teal); }
.session-bar span { display: block; font-weight: 850; }
.internal-section { padding-bottom: 0 !important; }
.empty-state { grid-column: 1 / -1; }
.authority-strip.compact { max-width: none; margin-top: 1rem; }

@media (max-width: 820px) {
  .auth-grid { grid-template-columns: 1fr; }
  .portal-status { align-items: flex-start; border-radius: 20px; flex-direction: column; }
  .portal-status span { text-align: left; }
  .session-bar { align-items: flex-start; flex-direction: column; }
}

/* Surgical institutional strengthening — system architecture page */
.micro-definition {
  max-width: 820px;
  margin: -0.25rem 0 1rem;
  color: var(--navy);
  font-size: clamp(1rem, 1.18vw, 1.12rem);
  line-height: 1.45;
}
.compact-authority-bar span + span {
  display: block;
  margin-top: 0.18rem;
  color: #263247;
  font-weight: 780;
}
.governance-sequence-strip {
  max-width: 860px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin: 0.95rem 0 0;
  padding: 0.86rem 0.95rem;
  border: 1px solid rgba(11,27,63,0.13);
  border-radius: 18px;
  background: rgba(255,255,255,0.72);
  box-shadow: 0 14px 34px rgba(11,27,63,0.06);
}
.governance-sequence-strip span {
  color: var(--teal);
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.72rem;
}
.governance-sequence-strip b {
  color: var(--navy);
  font-size: 0.9rem;
}
.governance-sequence-strip em {
  color: var(--gold);
  font-style: normal;
  font-weight: 950;
}
.enables-panel {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}
.enables-panel div {
  min-width: 0;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(255,255,255,0.84);
  box-shadow: 0 16px 44px rgba(11,27,63,0.07);
}
.enables-panel strong {
  display: block;
  color: var(--navy);
  margin-bottom: 0.24rem;
  font-size: 1rem;
}
.enables-panel span {
  display: block;
  color: var(--muted);
  font-weight: 740;
  line-height: 1.42;
  font-size: 0.92rem;
}
.closing-statement-section {
  padding: 34px 0 70px;
}
.closing-institutional-line {
  max-width: 1040px;
  margin: 0 auto;
  padding: 1rem 1.15rem;
  border-radius: 20px;
  border: 1px solid rgba(185,139,55,0.3);
  background: linear-gradient(135deg, rgba(185,139,55,0.12), rgba(17,138,126,0.08));
  color: var(--navy);
  font-weight: 900;
  text-align: center;
  box-shadow: 0 16px 44px rgba(11,27,63,0.07);
}
@media (max-width: 900px) {
  .enables-panel { grid-template-columns: 1fr; }
}
.compact-authority-bar {
  max-width: 860px;
  display: block;
  padding: 0.9rem 1rem;
  border-radius: 18px;
  border: 1px solid rgba(185,139,55,0.30);
  background: rgba(185,139,55,0.11);
  color: var(--navy);
  box-shadow: 0 14px 34px rgba(11,27,63,0.06);
}
.compact-authority-bar strong {
  display: inline;
  color: var(--navy);
  font-weight: 950;
}
.compact-authority-bar span {
  color: #263247;
  font-weight: 850;
}


/* Institution portal posture correction */
.portal-definition {
  margin-top: 0.85rem;
  padding: 0.85rem 1rem;
  border-left: 4px solid var(--gold);
  border-radius: 16px;
  background: rgba(255,255,255,0.68);
}
.session-bar small {
  display: block;
  margin-top: 0.15rem;
  color: var(--muted);
  font-weight: 750;
}
.boundary-note {
  border: 1px solid rgba(255,255,255,0.2);
  background: rgba(255,255,255,0.09);
}
.programme-sample-note {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin: 0 0 0.85rem;
  padding: 0.85rem 1rem;
  border: 1px solid rgba(11,27,63,0.12);
  border-radius: 18px;
  background: rgba(255,255,255,0.9);
  color: var(--navy);
}
.programme-sample-note strong {
  flex: 0 0 auto;
  letter-spacing: 0.02em;
}
.programme-sample-note span {
  color: var(--muted);
  font-weight: 750;
  text-align: right;
}
.sample-programme-list {
  grid-template-columns: 1fr;
}
.route-badge {
  flex: 0 0 150px;
  padding: 0.66rem 0.75rem;
  border-radius: 16px;
  border: 1px solid rgba(17,138,126,0.22);
  background: rgba(17,138,126,0.08);
  color: var(--navy);
  text-align: right;
}
.route-badge span {
  display: block;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.route-badge strong {
  display: block;
  font-size: 0.88rem;
  margin-top: 0.12rem;
}
.micro-note {
  margin: 0 0 0.55rem;
  padding: 0.55rem 0.7rem;
  border-left: 3px solid var(--gold);
  border-radius: 12px;
  background: rgba(185,139,55,0.09);
  color: var(--navy) !important;
  font-weight: 850;
}
.authority-overview .kpi-card strong {
  font-size: 1.14rem;
}
@media (max-width: 760px) {
  .programme-sample-note { flex-direction: column; }
  .programme-sample-note span { text-align: left; }
  .route-badge { flex-basis: auto; text-align: left; }
}

/* Institution Portal interaction correction */
.anchor-target { display: block; position: relative; top: -92px; visibility: hidden; }
.action-stack button {
  appearance: none;
  border: 1px solid var(--line);
  background: #fff;
  color: inherit;
  text-align: left;
  border-radius: 22px;
  padding: 1rem;
  cursor: pointer;
  box-shadow: none;
  width: 100%;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.action-stack button:hover,
.action-stack button:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(17, 138, 126, .42);
  background: rgba(17, 138, 126, .04);
  outline: none;
}
.action-stack button span { display: block; color: var(--teal); font-size: .74rem; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; }
.action-stack button strong { display: block; margin-top: .25rem; }
.action-stack button p { margin: .35rem 0 0; color: var(--muted); }
.filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: .38rem;
  margin: -.35rem 0 .85rem;
}
.filter-pills button {
  appearance: none;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 999px;
  padding: .42rem .66rem;
  font-size: .78rem;
  font-weight: 750;
  color: var(--muted);
  cursor: pointer;
  transition: background .18s ease, border-color .18s ease, color .18s ease;
}
.filter-pills button:hover,
.filter-pills button:focus-visible {
  border-color: rgba(17, 138, 126, .42);
  color: var(--teal);
  outline: none;
}
.filter-pills button.active {
  background: rgba(17, 138, 126, .1);
  border-color: rgba(17, 138, 126, .35);
  color: var(--teal);
}
.loading-state h3::after {
  content: "";
  display: inline-block;
  width: .72em;
  height: .72em;
  margin-left: .45rem;
  border: 2px solid rgba(17, 138, 126, .24);
  border-top-color: var(--teal);
  border-radius: 50%;
  animation: tv-spin .9s linear infinite;
  vertical-align: -.08em;
}
@keyframes tv-spin { to { transform: rotate(360deg); } }

@media (max-width: 640px) {
  .pack-detail span { padding: 1rem 1.05rem; border-radius: 22px; }
  .pack-detail b { display: block; min-width: 0; margin: 0 0 0.25rem; }
}

.condition-micro-label {
  margin-top: -0.25rem;
  padding: 0.65rem 0.75rem;
  border-radius: 14px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.16);
  color: rgba(255,255,255,0.82);
  font-size: 0.78rem;
  font-weight: 850;
  line-height: 1.35;
}
.output-count-card small {
  display: block;
  margin-top: 0.2rem;
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 850;
}
.output-count-card strong {
  font-size: 1.25rem;
}
.programme-sample-note span {
  line-height: 1.5;
}


/* Funding Spine next secured layers */
.workflow-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0.9rem; }
.workflow-card { display: block; padding: 1.15rem; border: 1px solid var(--line); border-radius: 20px; background: #fff; text-decoration: none; color: var(--text); box-shadow: 0 18px 42px rgba(11,27,63,0.07); transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease; }
.workflow-card:hover, .workflow-card:focus-visible { transform: translateY(-2px); border-color: rgba(17,138,126,0.35); box-shadow: 0 22px 48px rgba(11,27,63,0.1); outline: none; }
.workflow-card span { width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; background: var(--navy); color: #fff; font-weight: 950; margin-bottom: 0.85rem; }
.workflow-card strong { display: block; color: var(--navy); font-size: 1.05rem; margin-bottom: 0.35rem; }
.workflow-card p { margin: 0; color: var(--muted); font-size: 0.93rem; }

.metric-stack a.metric-link { width: 100%; text-align: left; border: 1px solid rgba(11,27,63,0.08); border-radius: 18px; background: rgba(255,255,255,0.84); padding: 0.95rem; color: var(--text); text-decoration: none; cursor: pointer; transition: transform 0.18s ease, border 0.18s ease; }
.metric-stack a.metric-link:hover, .metric-stack a.metric-link:focus-visible { transform: translateY(-1px); border-color: rgba(17,138,126,0.45); outline: none; }
.metric-stack a.metric-link span { display: inline-flex; padding: 0.35rem 0.55rem; border-radius: 999px; background: rgba(17,138,126,0.1); color: var(--teal); font-size: 0.72rem; font-weight: 950; letter-spacing: 0.08em; margin-bottom: 0.55rem; }
.metric-stack a.metric-link strong { display: block; color: var(--navy); }
.metric-stack a.metric-link p { margin: 0.25rem 0 0; color: var(--muted); font-size: 0.9rem; }

.admin-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 1rem; }
.admin-panel { padding: 1rem; border: 1px solid var(--line); border-radius: 22px; background: #fff; box-shadow: 0 18px 42px rgba(11,27,63,0.07); }
.admin-panel.full-span { grid-column: 1 / -1; }
.panel-heading { margin-bottom: 0.9rem; }
.panel-heading h3 { margin: 0 0 0.35rem; }
.panel-heading span { color: var(--muted); font-size: 0.92rem; }
.admin-table { display: grid; gap: 0.65rem; }
.admin-row { display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 0.8rem; align-items: center; padding: 0.85rem; border: 1px solid rgba(11,27,63,0.08); border-radius: 16px; background: rgba(11,27,63,0.025); }
.admin-row-main strong { display: block; color: var(--navy); }
.admin-row-main span { display: block; color: var(--muted); font-size: 0.86rem; margin-top: 0.15rem; }
.admin-row-main small { display: inline-flex; margin-top: 0.5rem; padding: 0.25rem 0.48rem; border-radius: 999px; background: rgba(17,138,126,0.1); color: var(--teal); font-weight: 850; }
.admin-actions { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 0.35rem; }
.admin-actions button { border: 1px solid rgba(11,27,63,0.12); background: #fff; color: var(--navy); padding: 0.5rem 0.65rem; border-radius: 999px; font-size: 0.78rem; font-weight: 900; cursor: pointer; }
.admin-actions button:hover { border-color: rgba(17,138,126,0.5); color: var(--teal); }
.status-pill { display: inline-flex; padding: 0.22rem 0.48rem; border-radius: 999px; font-weight: 900; background: rgba(11,27,63,0.07); color: var(--navy); }
.status-pill.approved, .status-pill.validated { background: rgba(17,138,126,0.12); color: var(--teal); }
.status-pill.pending_review, .status-pill.review_required { background: rgba(185,139,55,0.16); color: #8a651d; }
.status-pill.suspended, .status-pill.rejected, .status-pill.superseded { background: rgba(150,42,42,0.1); color: #8f2d2d; }

.mandate-form { max-width: 860px; margin: 0 auto; }
.mandate-form label, .evidence-map-grid label { display: grid; gap: 0.35rem; font-weight: 850; color: var(--navy); }
.mandate-form input, .mandate-form select, .mandate-form textarea, .evidence-map-grid input, .evidence-map-grid select, .evidence-map-grid textarea {
  width: 100%; border: 1px solid var(--line); border-radius: 14px; padding: 0.85rem 0.9rem; background: #fff; color: var(--text); outline: none;
}
.mandate-form input:focus, .mandate-form select:focus, .mandate-form textarea:focus, .evidence-map-grid input:focus, .evidence-map-grid select:focus, .evidence-map-grid textarea:focus {
  border-color: var(--teal); box-shadow: 0 0 0 4px rgba(17,138,126,0.1);
}
.evidence-map-grid { display: grid; grid-template-columns: minmax(360px,0.9fr) minmax(0,1.1fr); gap: 1rem; align-items: start; }
.form-status.success { color: var(--teal); }
.form-status.error { color: #8f2d2d; }

@media (max-width: 980px) {
  .workflow-grid, .admin-grid, .evidence-map-grid { grid-template-columns: 1fr; }
  .admin-row { grid-template-columns: 1fr; }
  .admin-actions { justify-content: flex-start; }
}

.admin-row .admin-row-main strong:has(+ span) { overflow-wrap: anywhere; }
.admin-table .admin-row:only-child { min-height: 74px; }

.admin-row.empty-state { background: rgba(11,27,63,0.035); border-style: dashed; }
.admin-row.empty-state .admin-row-main strong { color: var(--navy); }
.admin-row.empty-state .admin-row-main span { color: var(--muted); }

#evidenceProgramme option { color: var(--navy); }
.evidence-map-grid .admin-table { min-height: 120px; }


/* Institutional Chain compacting: reduce whitespace in chain cards */
#institutional-chain {
  padding-block: clamp(2.2rem, 4vw, 3.4rem);
}
#institutional-chain .institutional-chain-wide {
  grid-template-columns: minmax(220px, 0.42fr) minmax(0, 1.58fr);
  gap: 1rem;
  align-items: start;
  padding: 1.05rem;
}
#institutional-chain .chain-title h2 {
  max-width: 340px;
  font-size: clamp(2.05rem, 3vw, 3.25rem);
  line-height: 1.02;
  letter-spacing: -0.055em;
}
#institutional-chain .institutional-chain-visual {
  align-items: start;
}
#institutional-chain .chain-step {
  min-height: 154px;
  align-content: center;
  padding: 1rem;
  border-radius: 18px;
}
#institutional-chain .chain-step strong {
  font-size: 1rem;
}
#institutional-chain .chain-step small {
  font-size: 0.88rem;
}
#institutional-chain .chain-link {
  min-height: 154px;
  align-items: center;
}

@media (max-width: 1180px) {
  #institutional-chain .institutional-chain-wide {
    grid-template-columns: 1fr;
  }
  #institutional-chain .chain-title h2 {
    max-width: 100%;
  }
  #institutional-chain .institutional-chain-visual {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  #institutional-chain .chain-step {
    min-height: 132px;
  }
}
@media (max-width: 720px) {
  #institutional-chain .institutional-chain-visual {
    grid-template-columns: 1fr;
  }
  #institutional-chain .chain-step {
    min-height: 0;
  }
}


/* Capital institution first-read callout */
.capital-value-section {
  padding-block: clamp(2.2rem, 4vw, 3.6rem);
  background:
    radial-gradient(circle at 12% 12%, rgba(17,138,126,0.08), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,0.96), rgba(11,27,63,0.035));
}
.capital-value-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1.22fr);
  gap: 1.45rem;
  align-items: stretch;
}
.capital-output-callout {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.78rem;
}
.capital-output-callout article {
  position: relative;
  min-width: 0;
  min-height: 185px;
  display: grid;
  align-content: start;
  gap: 0.44rem;
  padding: 1.08rem;
  border-radius: 22px;
  border: 1px solid rgba(17,138,126,0.22);
  background: rgba(255,255,255,0.88);
  box-shadow: 0 16px 42px rgba(11,27,63,0.08);
}
.capital-output-callout article::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 5px;
  border-radius: 22px 22px 0 0;
  background: linear-gradient(90deg, var(--gold), var(--teal));
}
.capital-output-callout span {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(17,138,126,0.1);
  color: var(--teal);
  font-size: 0.76rem;
  font-weight: 950;
  letter-spacing: 0.08em;
}
.capital-output-callout strong {
  display: block;
  color: var(--navy);
  font-size: 1.02rem;
  line-height: 1.15;
}
.capital-output-callout p {
  margin: 0;
  color: var(--muted);
  font-size: 0.91rem;
  font-weight: 720;
  line-height: 1.44;
}
.capital-value-boundary {
  display: grid;
  gap: 0.3rem;
  margin-top: 1rem;
  padding: 0.92rem 1rem;
  border-radius: 18px;
  border: 1px solid rgba(185,139,55,0.3);
  background: rgba(185,139,55,0.1);
}
.capital-value-boundary strong {
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.76rem;
  font-weight: 950;
}
.capital-value-boundary span {
  color: #28364f;
  font-size: 0.92rem;
  font-weight: 780;
  line-height: 1.42;
}

@media (max-width: 1080px) {
  .capital-value-grid { grid-template-columns: 1fr; }
  .capital-output-callout { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .capital-output-callout article { min-height: 155px; }
}
@media (max-width: 640px) {
  .capital-output-callout { grid-template-columns: 1fr; }
  .capital-output-callout article { min-height: 0; }
}


/* Role separation */
.hidden, .admin-only.hidden, [data-admin-only].hidden { display: none !important; }
.investor-access-sequence .workflow-card[href="#capital-outputs"] { cursor: pointer; }


/* Capital Interest Route */
.interest-route-grid {
  display: grid;
  grid-template-columns: minmax(380px, 0.95fr) minmax(0, 1.05fr);
  gap: 1rem;
  align-items: start;
}
.interest-form label {
  display: grid;
  gap: 0.35rem;
  font-weight: 850;
  color: var(--navy);
}
.interest-form input,
.interest-form select,
.interest-form textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 0.85rem 0.9rem;
  background: #fff;
  color: var(--text);
  outline: none;
}
.interest-form input:focus,
.interest-form select:focus,
.interest-form textarea:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 4px rgba(17,138,126,0.1);
}
.interest-route-panel {
  border-color: rgba(185,139,55,0.28);
  background: linear-gradient(135deg, rgba(185,139,55,0.1), rgba(255,255,255,0.92));
}
.interest-route-panel .pack-detail {
  margin-bottom: 0.5rem;
}
@media (max-width: 980px) {
  .interest-route-grid { grid-template-columns: 1fr; }
}


/* Project/programme interest confirmation */
.selected-record-note {
  margin-top: -0.2rem;
  padding: 0.8rem 0.9rem;
  border-radius: 16px;
  border: 1px solid rgba(17,138,126,0.22);
  background: rgba(17,138,126,0.08);
  color: var(--navy);
  font-size: 0.92rem;
  font-weight: 800;
  line-height: 1.45;
}
.confirmation-box {
  display: grid;
  gap: 0.34rem;
  margin-top: 0.4rem;
  padding: 1rem;
  border-radius: 18px;
  border: 1px solid rgba(17,138,126,0.28);
  background: rgba(17,138,126,0.1);
  color: var(--navy);
}
.confirmation-box strong {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.76rem;
  font-weight: 950;
  color: var(--teal);
}
.confirmation-box span {
  display: block;
  color: #28364f;
  font-size: 0.94rem;
  font-weight: 780;
  line-height: 1.42;
}
