/* JoyPartnersOS public website — commercial architecture v2 (Option B).
   Local-only, static, no JavaScript, no external assets, no external network references.
   Multi-page enterprise healthcare-operations-substrate posture.
   Original design system. Not derived from athenaOne, athenahealth, or any third-party site. */


/* ─── Design tokens ─── */

:root {

  /* Palette — original JoyPartnersOS commercial system.
     Deep navy authority base, healthcare blue primary accent, evidence green
     secondary, warm neutral background. Intentionally distinct from
     athenaOne's purple-dominant system. */
  --paper:            #f7f5ef;          /* warm neutral page background */
  --paper-soft:       #ecebe2;          /* alternate surface tone */
  --paper-elevated:   #ffffff;          /* preview surfaces (product UI mockups) */
  --paper-blue:       #eef3fa;          /* blue-tinted accent surface */
  --rule:             #d6cfbf;          /* hairline rules */
  --rule-strong:      #b8b0a0;          /* stronger rule */
  --rule-cool:        #cad6e2;          /* cool blue-gray rule for product previews */

  --ink:              #0d1a2c;          /* primary text, deep navy */
  --ink-soft:         #354158;          /* secondary text */
  --ink-muted:        #5a6377;          /* tertiary text, eyebrow, footnotes */

  --accent:           #1e60c8;          /* healthcare blue, primary accent */
  --accent-strong:    #154a9c;          /* accent hover/active */
  --accent-soft:      #d6e1f5;          /* accent surface tint */

  --evidence:         #1f6b4a;          /* evidence green, secondary accent */
  --evidence-strong:  #134d33;
  --evidence-soft:    #d6e9de;

  --warning:          #8a5a18;          /* amber warning */
  --warning-soft:     #f5e7c7;

  --critical:         #8c2c2c;          /* red critical */
  --critical-soft:    #f4d6d6;

  --focus:            #1e60c8;          /* focus ring */

  /* Spacing scale */
  --s-1:  0.25rem;
  --s-2:  0.5rem;
  --s-3:  0.75rem;
  --s-4:  1rem;
  --s-5:  1.5rem;
  --s-6:  2rem;
  --s-7:  3rem;
  --s-8:  4rem;
  --s-9:  6rem;
  --s-10: 8rem;

  /* Layout */
  --max-width:        72rem;
  --max-width-narrow: 48rem;
  --reading-width:    38rem;
  --gutter:           clamp(1rem, 3vw, 2rem);
  --section-y:        clamp(4rem, 8vw, 7rem);
  --section-y-hero:   clamp(5rem, 11vw, 11rem);

  /* Typography */
  --type-display:     clamp(2.25rem, 5vw, 4rem);
  --type-h2:          clamp(1.65rem, 3.3vw, 2.5rem);
  --type-h3:          1.25rem;
  --type-h4:          1.05rem;
  --type-eyebrow:     0.78rem;
  --type-lede:        1.15rem;
  --type-body:        1rem;
  --type-small:       0.88rem;
  --type-mono:        0.92rem;

  /* Radii */
  --r-1: 4px;
  --r-2: 8px;
  --r-3: 12px;

  /* Shadow */
  --shadow-card:      0 1px 0 var(--rule), 0 1px 2px rgba(13, 26, 44, 0.04);
}


/* ─── Reset / base ─── */

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

html {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               Oxygen, Ubuntu, Cantarell, "Helvetica Neue", Arial, sans-serif;
  font-size: 100%;
  line-height: 1.6;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-size: var(--type-body);
  min-height: 100vh;
}

img, svg, video {
  max-width: 100%;
  height: auto;
}

a {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
}

a:hover, a:focus-visible {
  color: var(--accent-strong);
  text-decoration-thickness: 2px;
}

:focus-visible {
  outline: 3px solid var(--focus);
  outline-offset: 3px;
  border-radius: var(--r-1);
}

code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: var(--type-mono);
  background: var(--paper-soft);
  padding: 0.1em 0.4em;
  border-radius: var(--r-1);
}


/* ─── Skip link ─── */

.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--ink);
  color: var(--paper);
  padding: var(--s-3) var(--s-4);
  z-index: 1000;
  text-decoration: none;
}

.skip-link:focus {
  top: 0;
}


/* ─── Layout primitives ─── */

.container {
  width: 100%;
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.container--narrow {
  max-width: var(--max-width-narrow);
}

.container--reading {
  max-width: var(--reading-width);
}


/* ─── Site header ─── */

.site-header {
  background: var(--paper);
  border-bottom: 1px solid var(--rule);
  position: sticky;
  top: 0;
  z-index: 50;
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-5);
  padding-block: var(--s-4);
  flex-wrap: wrap;
}

.site-mark {
  display: inline-flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--ink);
  line-height: 1.2;
}

.site-mark:hover, .site-mark:focus-visible {
  color: var(--ink);
  text-decoration: none;
}

.site-mark__name {
  font-weight: 700;
  font-size: 1.1rem;
  letter-spacing: -0.005em;
}

.site-mark__byline {
  font-size: 0.75rem;
  color: var(--ink-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-top: 0.15em;
}

.site-nav {
  flex: 1;
}

.site-nav ul {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--s-3) var(--s-5);
  list-style: none;
  margin: 0;
  padding: 0;
}

.site-nav a {
  color: var(--ink-soft);
  text-decoration: none;
  font-size: 0.92rem;
  letter-spacing: 0.005em;
  padding: var(--s-2) 0;
  border-bottom: 2px solid transparent;
}

.site-nav a:hover,
.site-nav a:focus-visible {
  color: var(--ink);
  border-bottom-color: var(--accent);
  text-decoration: none;
}

.site-nav a[aria-current="page"] {
  color: var(--ink);
  border-bottom-color: var(--accent);
}

.site-nav__icon {
  display: inline-flex;
  align-items: center;
  gap: var(--s-1);
}

.site-nav__icon::before {
  /* Search icon glyph as pure CSS (no SVG, no image). */
  content: "⌕";
  font-size: 1.1rem;
  color: var(--ink-muted);
}

.site-nav__cta {
  background: var(--ink);
  color: var(--paper) !important;
  padding: var(--s-2) var(--s-4) !important;
  border-radius: var(--r-2);
  font-weight: 600;
  border-bottom: 2px solid var(--ink) !important;
}

.site-nav__cta:hover,
.site-nav__cta:focus-visible {
  background: var(--accent-strong);
  border-bottom-color: var(--accent-strong) !important;
}


/* ─── Sections ─── */

.section {
  padding-block: var(--section-y);
}

.section--hero {
  padding-block: var(--section-y-hero);
  background: linear-gradient(180deg, var(--paper) 0%, var(--paper) 60%, var(--paper-soft) 100%);
}

.section--alt {
  background: var(--paper-soft);
}

.section--cool {
  background: var(--paper-blue);
}

.section--disclaimer {
  background: var(--paper-soft);
  border-block: 1px solid var(--rule);
}

.eyebrow {
  font-size: var(--type-eyebrow);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin: 0 0 var(--s-4) 0;
  font-weight: 600;
}

.eyebrow--accent {
  color: var(--accent);
}

.display {
  font-size: var(--type-display);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 700;
  margin: 0 0 var(--s-5) 0;
  color: var(--ink);
  text-wrap: balance;
  max-width: 22ch;
}

h1, h2, h3, h4 {
  color: var(--ink);
}

h2 {
  font-size: var(--type-h2);
  line-height: 1.15;
  letter-spacing: -0.015em;
  font-weight: 700;
  margin: 0 0 var(--s-5) 0;
  text-wrap: balance;
  max-width: 26ch;
}

h3 {
  font-size: var(--type-h3);
  font-weight: 600;
  margin: var(--s-6) 0 var(--s-3) 0;
  letter-spacing: -0.005em;
}

h4 {
  font-size: var(--type-h4);
  font-weight: 600;
  margin: var(--s-5) 0 var(--s-2) 0;
}

p {
  margin: 0 0 var(--s-5) 0;
  color: var(--ink-soft);
  max-width: 42rem;
}

.lede {
  font-size: var(--type-lede);
  line-height: 1.55;
  color: var(--ink);
  max-width: 36rem;
}

.section__intro {
  margin-bottom: var(--s-7);
  max-width: 42rem;
}


/* ─── Hero ─── */

.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: var(--s-7);
  align-items: center;
}

.hero__cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-top: var(--s-5);
}

.hero__cta-row .cta-link {
  font-size: 0.95rem;
}

.hero-media {
  position: relative;
  aspect-ratio: 4 / 3;
  background: linear-gradient(135deg, #1a2a47 0%, #0d1a2c 100%);
  border-radius: var(--r-3);
  overflow: hidden;
  box-shadow: 0 8px 28px rgba(13, 26, 44, 0.18);
}

.hero-media__inner {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-rows: auto 1fr auto;
  padding: var(--s-5);
  color: var(--paper);
}

.hero-media__label {
  font-size: var(--type-eyebrow);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #9bb8e4;
  font-weight: 600;
}

.hero-media__title {
  font-size: 1.3rem;
  line-height: 1.25;
  font-weight: 600;
  max-width: 22ch;
  color: var(--paper);
  text-wrap: balance;
}

.hero-media__caption {
  font-size: var(--type-small);
  color: #b5c8e0;
  margin: 0;
}

.hero-media__play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.hero-media__play::before {
  content: "";
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.4);
}

.hero-media__play::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  border-left: 16px solid var(--paper);
  border-top: 11px solid transparent;
  border-bottom: 11px solid transparent;
  margin-left: 4px;
}

.hero-media__placeholder-note {
  position: absolute;
  bottom: var(--s-3);
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.72rem;
  color: rgba(255, 255, 255, 0.6);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
}


/* ─── Buttons & CTAs ─── */

.btn {
  display: inline-block;
  background: var(--ink);
  color: var(--paper);
  padding: var(--s-3) var(--s-5);
  border-radius: var(--r-2);
  text-decoration: none;
  font-weight: 600;
  letter-spacing: 0.005em;
  font-size: 0.96rem;
  border: 1px solid var(--ink);
}

.btn:hover,
.btn:focus-visible {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
  color: var(--paper);
  text-decoration: none;
}

.btn--accent {
  background: var(--accent);
  border-color: var(--accent);
}

.btn--accent:hover,
.btn--accent:focus-visible {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
}

.btn--ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--rule-strong);
}

.btn--ghost:hover,
.btn--ghost:focus-visible {
  background: var(--paper-soft);
  border-color: var(--ink);
  color: var(--ink);
}

.cta-link {
  display: inline-block;
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--accent);
  padding: 0.2em 0;
  font-weight: 600;
}

.cta-link:hover,
.cta-link:focus-visible {
  color: var(--accent-strong);
  border-bottom-color: var(--accent-strong);
  border-bottom-width: 2px;
  padding-bottom: calc(0.2em - 1px);
}

.cta-link__arrow {
  color: var(--accent);
  margin-left: 0.15em;
}


/* ─── Funnel cards ─── */

.funnel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--s-5);
  margin-block: var(--s-6);
}

.funnel-card {
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: var(--r-3);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}

.funnel-card__eyebrow {
  font-size: var(--type-eyebrow);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--accent);
  font-weight: 600;
  margin: 0;
}

.funnel-card__title {
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0;
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.2;
}

.funnel-card__body {
  font-size: 0.98rem;
  color: var(--ink-soft);
  margin: 0;
}

.funnel-card__cta {
  margin-top: auto;
  padding-top: var(--s-3);
}


/* ─── Feature band ─── */

.feature-band {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--s-5);
  margin-block: var(--s-6);
}

.feature {
  border-top: 2px solid var(--accent);
  padding-top: var(--s-4);
}

.feature__eyebrow {
  font-size: var(--type-eyebrow);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin: 0;
  font-weight: 600;
}

.feature__title {
  font-size: 1.2rem;
  margin: var(--s-2) 0 var(--s-2) 0;
  font-weight: 600;
  letter-spacing: -0.005em;
  line-height: 1.25;
}

.feature__body {
  font-size: 0.95rem;
  color: var(--ink-soft);
  margin: 0;
}


/* ─── Ledger grid ─── */

.ledger-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--s-4);
  margin-block: var(--s-6);
}

.ledger {
  border: 1px solid var(--rule-cool);
  border-radius: var(--r-2);
  padding: var(--s-5);
  background: var(--paper-elevated);
}

.ledger__label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-muted);
  margin: 0;
  font-weight: 600;
}

.ledger__name {
  font-size: 1.1rem;
  margin: var(--s-2) 0;
  font-weight: 700;
  letter-spacing: -0.005em;
  color: var(--ink);
}

.ledger__body {
  font-size: 0.92rem;
  color: var(--ink-soft);
  margin: 0;
}


/* ─── Product preview surfaces (originals; not derived from any third-party UI) ─── */

.preview {
  background: var(--paper-elevated);
  border: 1px solid var(--rule-cool);
  border-radius: var(--r-3);
  box-shadow: var(--shadow-card);
  margin-block: var(--s-6);
  overflow: hidden;
}

.preview__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--ink);
  color: var(--paper);
  padding: var(--s-3) var(--s-4);
  font-size: var(--type-small);
  letter-spacing: 0.02em;
}

.preview__bar-title {
  font-weight: 600;
}

.preview__bar-meta {
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.preview__body {
  padding: var(--s-5);
}

.preview__caption {
  background: var(--paper-soft);
  border-top: 1px solid var(--rule-cool);
  padding: var(--s-3) var(--s-4);
  font-size: 0.82rem;
  color: var(--ink-muted);
  font-style: italic;
}


/* Operations Inbox preview */

.inbox {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(0, 2.2fr);
  gap: var(--s-5);
}

.inbox__queues {
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
}

.inbox__queue {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--s-2) var(--s-3);
  border-radius: var(--r-1);
  font-size: 0.9rem;
  color: var(--ink-soft);
  border-left: 3px solid transparent;
}

.inbox__queue--active {
  background: var(--paper-blue);
  border-left-color: var(--accent);
  color: var(--ink);
  font-weight: 600;
}

.inbox__count {
  background: var(--paper-soft);
  color: var(--ink);
  border-radius: 999px;
  padding: 0 0.5em;
  font-size: 0.78rem;
  font-weight: 600;
  min-width: 1.4em;
  text-align: center;
}

.inbox__count--accent {
  background: var(--accent);
  color: var(--paper);
}

.inbox__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.inbox__table th,
.inbox__table td {
  text-align: left;
  padding: var(--s-2) var(--s-3);
  border-bottom: 1px solid var(--rule-cool);
}

.inbox__table th {
  color: var(--ink-muted);
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.inbox__table tbody tr:last-child td {
  border-bottom: 0;
}


/* Status chips */

.chip {
  display: inline-flex;
  align-items: center;
  font-size: 0.76rem;
  font-weight: 600;
  padding: 0.2em 0.6em;
  border-radius: 999px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.4;
  white-space: nowrap;
}

.chip--pending  { background: var(--warning-soft);  color: var(--warning); }
.chip--review   { background: var(--accent-soft);   color: var(--accent-strong); }
.chip--approved { background: var(--evidence-soft); color: var(--evidence-strong); }
.chip--blocked  { background: var(--critical-soft); color: var(--critical); }
.chip--neutral  { background: var(--paper-soft);    color: var(--ink-soft); }
.chip--ledger   { background: var(--paper-soft);    color: var(--ink-muted); font-size: 0.7rem; letter-spacing: 0.08em; }


/* Client Command Header preview */

.client-header {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-4);
  align-items: center;
  padding: var(--s-4);
  background: var(--paper-soft);
  border: 1px solid var(--rule-cool);
  border-radius: var(--r-2);
  margin-bottom: var(--s-4);
}

.client-header__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--paper);
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: 0.02em;
}

.client-header__meta {
  display: grid;
  gap: 0.1em;
}

.client-header__title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0;
}

.client-header__sub {
  font-size: 0.82rem;
  color: var(--ink-muted);
  margin: 0;
}

.client-header__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  justify-content: flex-end;
}


/* Navigation Plan Workspace tabs + content */

.plan-tabs {
  display: flex;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--rule-cool);
  gap: 0;
  margin-bottom: var(--s-4);
}

.plan-tab {
  padding: var(--s-3) var(--s-4);
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--ink-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}

.plan-tab--active {
  color: var(--ink);
  border-bottom-color: var(--accent);
}

.plan-workspace {
  display: grid;
  grid-template-columns: 200px minmax(0, 1fr) 220px;
  gap: var(--s-5);
}

.plan-rail {
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  font-size: 0.88rem;
}

.plan-rail__group {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-muted);
  margin-top: var(--s-3);
  margin-bottom: var(--s-1);
  font-weight: 600;
}

.plan-rail__item {
  padding: 0.35em 0.6em;
  border-radius: var(--r-1);
  color: var(--ink-soft);
  cursor: default;
}

.plan-rail__item--active {
  background: var(--paper-blue);
  color: var(--ink);
  font-weight: 600;
}

.plan-cards {
  display: grid;
  gap: var(--s-4);
}

.plan-card {
  border: 1px solid var(--rule-cool);
  border-radius: var(--r-2);
  padding: var(--s-4);
  background: var(--paper-elevated);
}

.plan-card__title {
  font-size: 0.95rem;
  font-weight: 700;
  margin: 0 0 var(--s-2) 0;
  color: var(--ink);
}

.plan-card__body {
  font-size: 0.88rem;
  color: var(--ink-soft);
  margin: 0;
}

.plan-card__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-3);
  font-size: 0.88rem;
  padding: 0.4em 0;
  border-bottom: 1px solid var(--rule-cool);
}

.plan-card__row:last-child {
  border-bottom: 0;
}

.plan-side {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}

.plan-side__panel {
  border: 1px solid var(--rule-cool);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  background: var(--paper-elevated);
  font-size: 0.85rem;
}

.plan-side__title {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-muted);
  font-weight: 600;
  margin: 0 0 var(--s-2) 0;
}

.plan-side__line {
  margin: 0;
  color: var(--ink-soft);
}


/* Consent / readiness preview */

.consent {
  display: grid;
  gap: var(--s-3);
}

.consent__row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: var(--s-3);
  align-items: center;
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--rule-cool);
  border-radius: var(--r-2);
  background: var(--paper-elevated);
  font-size: 0.92rem;
}

.consent__row--warn {
  border-color: var(--warning);
  background: var(--warning-soft);
}

.consent__name {
  font-weight: 600;
  color: var(--ink);
}

.consent__note {
  font-size: 0.85rem;
  color: var(--ink-soft);
  margin-top: 0.1em;
}

.consent__banner {
  background: var(--warning-soft);
  border: 1px solid var(--warning);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  color: var(--warning);
  font-weight: 600;
  margin-bottom: var(--s-3);
}


/* Quick actions drawer */

.quick-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--s-3);
}

.quick-action {
  border: 1px solid var(--rule-cool);
  border-radius: var(--r-2);
  background: var(--paper-elevated);
  padding: var(--s-3) var(--s-4);
  display: grid;
  gap: 0.2em;
}

.quick-action__name {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--ink);
}

.quick-action__body {
  font-size: 0.82rem;
  color: var(--ink-muted);
}


/* Provider Review Queue preview */

.review-list {
  display: grid;
  gap: var(--s-3);
}

.review-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-3);
  align-items: center;
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--rule-cool);
  border-radius: var(--r-2);
  background: var(--paper-elevated);
}

.review-item__title {
  font-weight: 600;
  font-size: 0.96rem;
  margin: 0;
}

.review-item__sub {
  font-size: 0.84rem;
  color: var(--ink-muted);
  margin: 0;
}


/* Audit / evidence ledger preview */

.audit-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.audit-table th,
.audit-table td {
  text-align: left;
  padding: var(--s-2) var(--s-3);
  border-bottom: 1px solid var(--rule-cool);
}

.audit-table th {
  color: var(--ink-muted);
  font-weight: 600;
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.audit-table code {
  font-size: 0.82rem;
  background: var(--paper-soft);
}


/* ─── Page hero (non-homepage) ─── */

.page-hero {
  padding-block: clamp(3.5rem, 7vw, 6rem);
  border-bottom: 1px solid var(--rule);
}

.page-hero__title {
  font-size: clamp(1.85rem, 4vw, 3rem);
  line-height: 1.1;
  letter-spacing: -0.018em;
  font-weight: 700;
  margin: 0 0 var(--s-4) 0;
  color: var(--ink);
  max-width: 24ch;
}

.page-hero__lede {
  font-size: var(--type-lede);
  color: var(--ink-soft);
  max-width: 36rem;
  margin: 0;
}


/* ─── Audience / who-we-serve cards ─── */

.audience-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--s-5);
}

.audience-card {
  border-top: 2px solid var(--ink);
  padding-top: var(--s-4);
}

.audience-card__title {
  font-size: 1.2rem;
  font-weight: 700;
  margin: 0 0 var(--s-2) 0;
}

.audience-card__body {
  color: var(--ink-soft);
  font-size: 0.95rem;
  margin: 0 0 var(--s-3) 0;
}

.audience-card__eyebrow {
  font-size: var(--type-eyebrow);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-muted);
  margin: 0 0 var(--s-2) 0;
  font-weight: 600;
}


/* ─── Button system (additional variants) ─── */

.btn--primary {
  background: var(--accent);
  color: #ffffff;
  border-color: var(--accent);
}

.btn--primary:hover,
.btn--primary:focus-visible {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
  color: #ffffff;
}

.btn--primary[disabled] {
  background: var(--rule-strong);
  border-color: var(--rule-strong);
  color: var(--paper);
  cursor: not-allowed;
}

.btn--secondary {
  background: transparent;
  color: var(--ink);
  border-color: var(--ink);
}

.btn--secondary:hover,
.btn--secondary:focus-visible {
  background: var(--ink);
  color: var(--paper);
}


/* ─── Numbered & match lists ─── */

.numbered-list {
  margin: 0;
  padding-left: 1.2rem;
  color: var(--ink-soft);
  max-width: 44rem;
  line-height: 1.65;
}

.numbered-list li {
  margin-bottom: var(--s-4);
}

.numbered-list li strong {
  color: var(--ink);
  font-weight: 600;
}

.match-list {
  list-style: disc;
  margin: 0;
  padding-left: 1.2rem;
  color: var(--ink-soft);
  max-width: 44rem;
  line-height: 1.65;
}

.match-list li {
  margin-bottom: var(--s-3);
}

.match-list li strong {
  color: var(--ink);
  font-weight: 600;
}


/* ─── Resource grid (resources page) ─── */

.resource-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--s-5);
}

.resource-card {
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  box-shadow: var(--shadow-card);
}

.resource-card__eyebrow {
  font-size: var(--type-eyebrow);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  margin: 0;
  font-weight: 600;
}

.resource-card__title {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0 0 var(--s-1) 0;
  color: var(--ink);
}

.resource-card__body {
  color: var(--ink-soft);
  font-size: 0.95rem;
  margin: 0 0 var(--s-2) 0;
}

.resource-card__cta {
  color: var(--ink-muted);
  font-size: var(--type-small);
  margin: auto 0 0 0;
  font-style: italic;
}


/* ─── Contact page ─── */

.contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--s-5);
}

.contact-card {
  border-top: 2px solid var(--accent);
  padding-top: var(--s-4);
}

.contact-card__title {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0 0 var(--s-2) 0;
  color: var(--ink);
}

.contact-card__body {
  color: var(--ink-soft);
  font-size: 0.95rem;
  margin: 0 0 var(--s-2) 0;
}

.contact-card__note {
  color: var(--ink-muted);
  font-size: var(--type-small);
  font-style: italic;
  margin: 0;
}


/* ─── Form mock (static, non-functional) ─── */

.form-mock {
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-6);
  max-width: 44rem;
  display: grid;
  gap: var(--s-4);
  box-shadow: var(--shadow-card);
}

.form-row {
  display: grid;
  gap: var(--s-2);
}

.form-row--actions {
  flex-direction: row;
  align-items: center;
  margin-top: var(--s-3);
}

.form-label {
  font-size: var(--type-small);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--ink-muted);
}

.form-field {
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  padding: var(--s-3) var(--s-4);
  background: var(--paper);
  color: var(--ink-soft);
  font-size: 0.95rem;
  font-family: inherit;
}

.form-field--readonly {
  background: var(--paper-soft);
  color: var(--ink-muted);
}

.form-field--multiline {
  min-height: 5rem;
}

.form-note {
  color: var(--ink-muted);
  font-size: var(--type-small);
  margin: 0 0 0 var(--s-3);
  font-style: italic;
}


/* ─── CTA section ─── */

.section--cta {
  background: var(--ink);
  color: var(--paper);
  text-align: left;
}

.section--cta h2 {
  color: var(--paper);
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  margin: 0 0 var(--s-4) 0;
  font-weight: 700;
}

.section--cta p {
  color: rgba(247, 245, 239, 0.82);
  max-width: 44rem;
  margin: 0 0 var(--s-4) 0;
}

.section--cta .btn--primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
}

.section--cta .btn--primary:hover,
.section--cta .btn--primary:focus-visible {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
}


/* ─── Disclaimer list ─── */

.disclaimer-list {
  margin: 0 0 var(--s-5) 0;
  padding-left: 1.1rem;
  color: var(--ink-soft);
  max-width: 42rem;
  line-height: 1.6;
}

.disclaimer-list li {
  margin-bottom: var(--s-3);
}


/* ─── Cookie banner (static, nonfunctional) ─── */

.cookie-banner {
  position: fixed;
  left: var(--s-3);
  right: var(--s-3);
  bottom: var(--s-3);
  z-index: 100;
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--r-2);
  padding: var(--s-4) var(--s-5);
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: var(--s-3);
  align-items: center;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
  font-size: 0.92rem;
  max-width: var(--max-width);
  margin-inline: auto;
}

.cookie-banner__copy {
  margin: 0;
  color: var(--paper);
}

.cookie-banner__copy a {
  color: var(--paper);
  text-decoration: underline;
}

.cookie-banner__btn {
  display: inline-block;
  padding: var(--s-2) var(--s-4);
  border-radius: var(--r-1);
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, 0.5);
  color: var(--paper);
  background: transparent;
}

.cookie-banner__btn--primary {
  background: var(--accent);
  border-color: var(--accent);
}

.cookie-banner__btn:hover,
.cookie-banner__btn:focus-visible {
  background: var(--accent-strong);
  border-color: var(--accent-strong);
  color: var(--paper);
  text-decoration: none;
}

.cookie-banner__note {
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
  margin: 0;
}


/* ─── Chat bubble (static, nonfunctional) ─── */

.chat-bubble {
  position: fixed;
  right: var(--s-4);
  bottom: 7rem;
  z-index: 90;
  background: var(--accent);
  color: var(--paper);
  border-radius: 999px;
  padding: 0.6em 1.2em;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  box-shadow: 0 6px 18px rgba(30, 96, 200, 0.32);
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
}

.chat-bubble::before {
  content: "◍";
  font-size: 1.1rem;
}

.chat-bubble:hover,
.chat-bubble:focus-visible {
  background: var(--accent-strong);
  color: var(--paper);
  text-decoration: none;
}


/* ─── Footer ─── */

.site-footer {
  border-top: 1px solid var(--rule);
  background: var(--paper-soft);
  padding-block: var(--s-8);
  color: var(--ink-muted);
}

.site-footer__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) repeat(3, minmax(0, 1fr));
  gap: var(--s-6);
  margin-bottom: var(--s-7);
}

.site-footer__mark {
  font-weight: 700;
  font-size: 1rem;
  color: var(--ink);
  display: block;
  margin-bottom: var(--s-2);
}

.site-footer__byline {
  font-size: 0.85rem;
  color: var(--ink-muted);
  margin: 0 0 var(--s-2) 0;
}

.site-footer__group-title {
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin: 0 0 var(--s-3) 0;
  font-weight: 600;
}

.site-footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--s-2);
}

.site-footer a {
  color: var(--ink-soft);
  text-decoration: none;
  font-size: 0.92rem;
}

.site-footer a:hover,
.site-footer a:focus-visible {
  color: var(--ink);
  text-decoration: underline;
}

.site-footer__bottom {
  border-top: 1px solid var(--rule);
  padding-top: var(--s-5);
  font-size: 0.82rem;
  color: var(--ink-muted);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--s-3);
}


/* ─── Callout ─── */

.callout {
  border-left: 3px solid var(--accent);
  padding: var(--s-4) var(--s-5);
  background: var(--paper-elevated);
  color: var(--ink);
  font-size: 1.05rem;
  line-height: 1.55;
  margin-block: var(--s-6);
  border-radius: 0 var(--r-2) var(--r-2) 0;
  max-width: 36rem;
}


/* ─── Sub-footer compliance band ─── */

.compliance-strip {
  background: var(--paper-soft);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: var(--s-4);
  font-size: 0.84rem;
  color: var(--ink-muted);
  text-align: center;
}


/* ─── Responsive ─── */

@media (max-width: 64rem) {
  .hero { grid-template-columns: 1fr; }
  .site-footer__inner { grid-template-columns: 1fr 1fr; }
  .plan-workspace { grid-template-columns: 1fr; }
  .inbox { grid-template-columns: 1fr; }
}

@media (max-width: 48rem) {
  .site-header { position: static; }
  .site-header__inner { flex-direction: column; align-items: flex-start; }
  .site-nav ul { justify-content: flex-start; gap: var(--s-3) var(--s-4); }
  .site-footer__inner { grid-template-columns: 1fr; }
  .cookie-banner {
    grid-template-columns: 1fr;
    gap: var(--s-2);
  }
  .chat-bubble { bottom: 11rem; }
  .client-header { grid-template-columns: auto 1fr; }
  .client-header__chips { grid-column: 1 / -1; justify-content: flex-start; }
  .display { font-size: clamp(2rem, 8vw, 2.5rem); }
}


/* ─── Reduced motion / print ─── */

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; scroll-behavior: auto !important; }
}

@media print {
  .site-header, .site-footer, .cookie-banner, .chat-bubble, .skip-link { display: none; }
  body { background: white; color: black; }
  .hero-media { background: white; border: 1px solid black; color: black; }
  .hero-media__inner { color: black; }
  a { color: black; text-decoration: underline; }
}


/* ═══════════════════════════════════════════════════════════════════
   ═  v2 PROTOTYPE DESIGN SYSTEM EXTENSION                            ═
   ═  Glass UI · Portal Chrome · Dashboards · Login Hub · Investors   ═
   ═  Original JoyPartnersOS work; not Apple/Athena trade dress.      ═
   ═══════════════════════════════════════════════════════════════════ */


/* ─── Extended palette tokens (additive, no overrides) ─── */

:root {
  --navy-deep:      #07111e;
  --navy-1:         #0a1830;
  --navy-2:         #122144;
  --navy-3:         #1a2e5c;
  --teal-1:         #1aa39a;
  --teal-2:         #0f6f70;
  --teal-soft:      #d2efee;
  --teal-glow:      rgba(26, 163, 154, 0.18);
  --glass-bg:       rgba(255, 255, 255, 0.62);
  --glass-bg-strong:rgba(255, 255, 255, 0.78);
  --glass-bg-dark:  rgba(7, 17, 30, 0.55);
  --glass-border:   rgba(255, 255, 255, 0.55);
  --glass-stroke:   rgba(13, 26, 44, 0.08);
  --glass-stroke-dark: rgba(255, 255, 255, 0.16);
  --shadow-soft:    0 1px 2px rgba(13, 26, 44, 0.04), 0 4px 18px rgba(13, 26, 44, 0.06);
  --shadow-pop:     0 12px 32px rgba(13, 26, 44, 0.10);
  --shadow-glass:   0 8px 28px rgba(13, 26, 44, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.6);
  --gradient-night: linear-gradient(135deg, #07111e 0%, #0a1830 50%, #122144 100%);
  --gradient-day:   linear-gradient(180deg, #f7f5ef 0%, #ffffff 60%, #eef3fa 100%);
  --gradient-teal:  linear-gradient(135deg, #1aa39a 0%, #0f6f70 100%);
  --gradient-glass: linear-gradient(180deg, rgba(255,255,255,0.72) 0%, rgba(255,255,255,0.42) 100%);
}


/* ─── Premium nav refresh (drop-in upgrade, doesn't break older pages) ─── */

.site-header--premium {
  background: rgba(247, 245, 239, 0.88);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid var(--glass-stroke);
}

.site-mark__name { letter-spacing: -0.01em; }
.site-mark__name::after {
  content: "";
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--teal-1);
  margin-left: 6px;
  vertical-align: 4px;
  box-shadow: 0 0 0 3px var(--teal-glow);
}


/* ─── Premium hero band (dark navy with glass card) ─── */

.hero-band {
  position: relative;
  isolation: isolate;
  padding: clamp(4.5rem, 8vw, 8rem) 0 clamp(4rem, 7vw, 6.5rem);
  background: var(--gradient-night);
  color: var(--paper);
  overflow: hidden;
}

.hero-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 80% at 80% 10%, var(--teal-glow), transparent 60%),
    radial-gradient(40% 60% at 0% 100%, rgba(30, 96, 200, 0.18), transparent 70%);
  z-index: -1;
}

.hero-band__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
}

.hero-band__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.16);
  color: var(--paper);
  padding: 0.32rem 0.85rem;
  border-radius: 999px;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
  margin: 0 0 1.25rem 0;
}

.hero-band__eyebrow::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--teal-1);
  box-shadow: 0 0 0 3px var(--teal-glow);
}

.hero-band__title {
  font-size: clamp(2.3rem, 4.8vw, 4.2rem);
  line-height: 1.04;
  letter-spacing: -0.024em;
  font-weight: 700;
  margin: 0 0 1.25rem 0;
  color: var(--paper);
  max-width: 22ch;
}

.hero-band__title em {
  font-style: normal;
  background: var(--gradient-teal);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero-band__lede {
  font-size: clamp(1.05rem, 1.4vw, 1.18rem);
  line-height: 1.6;
  color: rgba(247, 245, 239, 0.78);
  max-width: 38rem;
  margin: 0 0 var(--s-5) 0;
}

.hero-band__cta {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--s-3) var(--s-4);
  align-items: center;
}

.hero-band__meta {
  margin-top: var(--s-5);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4) var(--s-5);
  color: rgba(247, 245, 239, 0.66);
  font-size: 0.88rem;
  letter-spacing: 0.02em;
}

.hero-band__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.hero-band__meta-item::before {
  content: "";
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--teal-1);
}

.hero-glass {
  background: var(--gradient-glass);
  border: 1px solid var(--glass-border);
  border-radius: 22px;
  padding: var(--s-5);
  box-shadow: var(--shadow-glass);
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  color: var(--ink);
}

.hero-glass__bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--glass-stroke);
}

.hero-glass__title {
  font-size: 0.92rem;
  font-weight: 600;
  margin: 0;
  color: var(--ink);
  letter-spacing: 0.02em;
}

.hero-glass__chip {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  background: var(--evidence-soft);
  color: var(--evidence-strong);
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
}

.hero-glass__kpis {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-3);
  margin-bottom: var(--s-4);
}

.hero-glass__kpi {
  background: rgba(255, 255, 255, 0.65);
  border: 1px solid var(--glass-stroke);
  border-radius: 14px;
  padding: var(--s-3) var(--s-4);
}

.hero-glass__kpi-label {
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin: 0 0 0.2rem 0;
  font-weight: 600;
}

.hero-glass__kpi-value {
  font-size: 1.65rem;
  font-weight: 700;
  margin: 0;
  color: var(--ink);
  letter-spacing: -0.01em;
}

.hero-glass__kpi-delta {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.78rem;
  color: var(--evidence-strong);
  font-weight: 600;
  margin-top: 0.15rem;
}

.hero-glass__kpi-delta--down { color: var(--critical); }
.hero-glass__kpi-delta::before {
  content: "▲";
  font-size: 0.7rem;
}
.hero-glass__kpi-delta--down::before { content: "▼"; }

.hero-glass__journey {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--s-2);
}

.hero-glass__journey li {
  display: grid;
  grid-template-columns: 18px 1fr auto;
  gap: 0.6rem;
  align-items: center;
  font-size: 0.88rem;
  color: var(--ink-soft);
  padding: 0.45rem 0.6rem;
  border-radius: 10px;
  background: rgba(255,255,255,0.5);
}

.hero-glass__journey li::before {
  content: "";
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--evidence);
  margin-left: 4px;
}

.hero-glass__journey li[data-state="pending"]::before { background: var(--warning); }
.hero-glass__journey li[data-state="review"]::before { background: var(--accent); }
.hero-glass__journey li[data-state="open"]::before { background: var(--rule-strong); }

.hero-glass__journey small {
  color: var(--ink-muted);
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 600;
}


/* ─── Audience strip (3-up logos / trust line replacement) ─── */

.audience-strip {
  padding: var(--s-6) 0;
  background: var(--paper-blue);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}

.audience-strip__inner {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s-4) var(--s-6);
  align-items: center;
}

.audience-strip__label {
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-weight: 600;
  margin: 0;
}

.audience-strip__items {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3) var(--s-5);
}

.audience-strip__items li {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--ink);
  letter-spacing: -0.005em;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.audience-strip__items li::before {
  content: "";
  width: 18px;
  height: 18px;
  background: var(--gradient-teal);
  border-radius: 5px;
  display: inline-block;
}


/* ─── Section heading patterns ─── */

.section-head {
  max-width: 44rem;
  margin: 0 0 var(--s-6) 0;
}

.section-head__eyebrow {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--teal-2);
  font-weight: 700;
  margin: 0 0 var(--s-2) 0;
}

.section-head__title {
  font-size: clamp(1.6rem, 3vw, 2.5rem);
  line-height: 1.12;
  letter-spacing: -0.02em;
  font-weight: 700;
  margin: 0 0 var(--s-3) 0;
  color: var(--ink);
}

.section-head__lede {
  font-size: 1.1rem;
  color: var(--ink-soft);
  margin: 0;
  max-width: 44rem;
}


/* ─── Pillar grid (3- or 4-up service / capability cards) ─── */

.pillars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--s-5);
}

.pillar {
  position: relative;
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: 18px;
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
  overflow: hidden;
  isolation: isolate;
}

.pillar::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(120% 60% at 0% 0%, var(--teal-glow), transparent 60%);
  opacity: 0;
  transition: opacity 0.3s ease;
  z-index: -1;
}

.pillar:hover {
  box-shadow: var(--shadow-pop);
  border-color: var(--rule-cool);
  transform: translateY(-2px);
}
.pillar:hover::before { opacity: 1; }

.pillar__icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--paper-blue);
  display: grid;
  place-items: center;
  border: 1px solid var(--rule-cool);
}

.pillar__icon svg {
  width: 22px;
  height: 22px;
  color: var(--accent);
}

.pillar__title {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0;
  color: var(--ink);
  letter-spacing: -0.005em;
}

.pillar__body {
  color: var(--ink-soft);
  font-size: 0.95rem;
  margin: 0;
  line-height: 1.55;
}

.pillar__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.45rem;
  font-size: 0.88rem;
  color: var(--ink-soft);
}

.pillar__list li {
  display: grid;
  grid-template-columns: 16px 1fr;
  gap: 0.55rem;
  align-items: baseline;
}

.pillar__list li::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--teal-1);
  margin-top: 0.4rem;
}

.pillar__cta {
  margin-top: auto;
}


/* ─── Stat strip (number cards) ─── */

.stat-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--s-4);
}

.stat {
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: 16px;
  padding: var(--s-4);
  text-align: left;
}

.stat__value {
  font-size: clamp(1.85rem, 2.6vw, 2.4rem);
  font-weight: 700;
  letter-spacing: -0.022em;
  color: var(--ink);
  margin: 0;
  line-height: 1.05;
}

.stat__value em {
  font-style: normal;
  background: var(--gradient-teal);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.stat__label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-muted);
  font-weight: 600;
  margin: 0.35rem 0 0 0;
}

.stat__note {
  margin-top: 0.4rem;
  font-size: 0.85rem;
  color: var(--ink-soft);
}


/* ─── Investor / proof block ─── */

.investor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: var(--s-6);
  align-items: start;
}

.investor-card {
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: 18px;
  padding: var(--s-5);
  box-shadow: var(--shadow-soft);
}

.investor-card h3 {
  font-size: 1.15rem;
  margin: 0 0 var(--s-2) 0;
  color: var(--ink);
}

.investor-card__list {
  display: grid;
  gap: var(--s-3);
  margin: 0;
  padding: 0;
  list-style: none;
}

.investor-card__list li {
  border-top: 1px solid var(--rule);
  padding-top: var(--s-2);
  font-size: 0.95rem;
  color: var(--ink-soft);
}

.investor-card__list li strong { color: var(--ink); display: block; margin-bottom: 0.2rem; }


/* ─── Login Hub role-card grid ─── */

.role-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--s-5);
}

.role-card {
  position: relative;
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: 18px;
  padding: var(--s-5);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
  overflow: hidden;
  isolation: isolate;
}

.role-card::after {
  content: "→";
  position: absolute;
  top: var(--s-4);
  right: var(--s-4);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--paper-blue);
  display: grid;
  place-items: center;
  font-size: 0.9rem;
  color: var(--accent);
  font-weight: 700;
  transition: transform 0.2s ease, background 0.2s ease;
}

.role-card:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-pop);
  transform: translateY(-2px);
}

.role-card:hover::after {
  transform: translate(4px, 0);
  background: var(--accent);
  color: #ffffff;
}

.role-card__badge {
  align-self: flex-start;
  background: var(--paper-blue);
  color: var(--accent-strong);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.32rem 0.7rem;
  border-radius: 999px;
}

.role-card__badge--admin { background: rgba(140, 44, 44, 0.08); color: var(--critical); }
.role-card__badge--chw   { background: var(--evidence-soft); color: var(--evidence-strong); }
.role-card__badge--referral { background: rgba(138, 90, 24, 0.08); color: var(--warning); }

.role-card__title {
  font-size: 1.2rem;
  font-weight: 700;
  margin: 0;
  color: var(--ink);
}

.role-card__body {
  font-size: 0.95rem;
  color: var(--ink-soft);
  margin: 0;
  line-height: 1.55;
}

.role-card__demo {
  margin-top: auto;
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  font-size: 0.78rem;
  color: var(--ink-muted);
}

.role-card__demo code {
  background: var(--paper-soft);
  padding: 0.2rem 0.45rem;
  border-radius: 6px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 0.78rem;
  color: var(--ink-soft);
}


/* ─── Prototype banner (top-of-page demo notice) ─── */

.proto-banner {
  background: linear-gradient(90deg, #122144 0%, #1a2e5c 100%);
  color: var(--paper);
  font-size: 0.82rem;
  padding: 0.5rem var(--gutter);
  text-align: center;
  letter-spacing: 0.02em;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.proto-banner strong {
  color: var(--teal-1);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.74rem;
  margin-right: 0.4rem;
}

.proto-banner a {
  color: var(--paper);
  text-decoration: underline;
  text-decoration-color: rgba(255,255,255,0.4);
  text-underline-offset: 3px;
}


/* ═══════════════════════════════════════════════════════════════════
   ═  PORTAL CHROME — sidebar + topbar + workspace                    ═
   ═══════════════════════════════════════════════════════════════════ */

.portal-shell {
  display: grid;
  grid-template-columns: 16rem minmax(0, 1fr);
  min-height: 100vh;
  background: var(--paper);
  color: var(--ink);
}

.portal-shell .site-header,
.portal-shell .cookie-banner,
.portal-shell .chat-bubble { display: none; }

.portal-side {
  background: var(--gradient-night);
  color: var(--paper);
  padding: var(--s-4) var(--s-4) var(--s-6);
  border-right: 1px solid var(--glass-stroke-dark);
  position: sticky;
  top: 0;
  align-self: start;
  height: 100vh;
  overflow-y: auto;
}

.portal-side__brand {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0 0 var(--s-5) 0;
  padding-bottom: var(--s-3);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.portal-side__brand-mark {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--gradient-teal);
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 0.95rem;
  color: #ffffff;
  letter-spacing: -0.02em;
}

.portal-side__brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}

.portal-side__brand-name {
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: -0.005em;
}

.portal-side__brand-role {
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(247,245,239,0.55);
  font-weight: 600;
}

.portal-side__nav {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.portal-side__group {
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(247,245,239,0.42);
  font-weight: 600;
  margin: var(--s-4) 0 var(--s-2) 0;
  padding: 0 0.5rem;
}

.portal-side__link {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 0.7rem;
  border-radius: 10px;
  color: rgba(247,245,239,0.78);
  text-decoration: none;
  font-size: 0.92rem;
  font-weight: 500;
  transition: background 0.15s ease, color 0.15s ease;
}

.portal-side__link:hover {
  background: rgba(255,255,255,0.06);
  color: #ffffff;
}

.portal-side__link[aria-current="page"] {
  background: rgba(26, 163, 154, 0.18);
  color: #ffffff;
}

.portal-side__link[aria-current="page"]::before {
  content: "";
  width: 3px;
  align-self: stretch;
  background: var(--teal-1);
  border-radius: 999px;
  margin-right: -0.2rem;
}

.portal-side__link svg {
  width: 16px;
  height: 16px;
  opacity: 0.85;
}

.portal-side__pill {
  margin-left: auto;
  font-size: 0.7rem;
  font-weight: 600;
  background: rgba(255,255,255,0.08);
  color: rgba(247,245,239,0.85);
  padding: 0.12rem 0.42rem;
  border-radius: 999px;
}

.portal-side__pill--alert {
  background: rgba(140, 44, 44, 0.28);
  color: #ffd9d9;
}

.portal-side__footer {
  margin-top: auto;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: var(--s-3);
  font-size: 0.78rem;
  color: rgba(247,245,239,0.55);
  display: grid;
  gap: 0.35rem;
}

.portal-side__footer a {
  color: rgba(247,245,239,0.85);
  text-decoration: none;
}

.portal-side__footer a:hover { text-decoration: underline; }


/* ─── Portal main / topbar / workspace ─── */

.portal-main {
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: var(--paper);
}

.portal-top {
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(247, 245, 239, 0.88);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid var(--rule);
  padding: 0.85rem var(--s-5);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--s-4);
  align-items: center;
}

.portal-top__crumbs {
  font-size: 0.85rem;
  color: var(--ink-muted);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.portal-top__crumbs strong { color: var(--ink); font-weight: 600; }
.portal-top__crumbs span { opacity: 0.6; }

.portal-top__search {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: 10px;
  padding: 0.4rem 0.65rem;
  width: min(22rem, 40vw);
  color: var(--ink-muted);
  font-size: 0.85rem;
}

.portal-top__search::before {
  content: "⌕";
  font-size: 1rem;
  color: var(--ink-muted);
}

.portal-top__actions {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.portal-top__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 0.4rem 0.75rem;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--ink-soft);
  cursor: default;
}

.portal-top__btn--primary {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}

.portal-top__avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--gradient-teal);
  display: grid;
  place-items: center;
  color: #ffffff;
  font-weight: 700;
  font-size: 0.8rem;
}

.portal-workspace {
  padding: var(--s-5);
  display: grid;
  gap: var(--s-5);
  max-width: 88rem;
  margin: 0 auto;
  width: 100%;
}

.portal-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--s-4);
  align-items: end;
}

.portal-head__eyebrow {
  font-size: 0.76rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--teal-2);
  font-weight: 700;
  margin: 0 0 0.3rem 0;
}

.portal-head__title {
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  margin: 0;
  letter-spacing: -0.012em;
  color: var(--ink);
}

.portal-head__sub {
  color: var(--ink-soft);
  margin: 0.3rem 0 0 0;
  font-size: 0.95rem;
}

.portal-head__filters {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.portal-head__filter {
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 0.35rem 0.75rem;
  font-size: 0.82rem;
  color: var(--ink-soft);
  font-weight: 600;
}

.portal-head__filter--active {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}


/* ─── KPI grid (dashboard top cards) ─── */

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--s-4);
}

.kpi {
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: 16px;
  padding: var(--s-4);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.kpi::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(26, 163, 154, 0.05) 100%);
  z-index: -1;
}

.kpi__label {
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-muted);
  font-weight: 600;
  margin: 0 0 0.3rem 0;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.kpi__label svg {
  width: 14px;
  height: 14px;
  color: var(--accent);
}

.kpi__value {
  font-size: 1.95rem;
  font-weight: 700;
  letter-spacing: -0.018em;
  color: var(--ink);
  margin: 0;
  line-height: 1.05;
}

.kpi__sub {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.4rem;
  color: var(--ink-soft);
  font-size: 0.82rem;
}

.kpi__delta {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--evidence-strong);
}

.kpi__delta::before {
  content: "▲";
  font-size: 0.7rem;
}

.kpi__delta--down { color: var(--critical); }
.kpi__delta--down::before { content: "▼"; }

.kpi__delta--flat { color: var(--ink-muted); }
.kpi__delta--flat::before { content: "—"; }

.kpi__spark {
  display: flex;
  gap: 2px;
  align-items: flex-end;
  height: 28px;
  margin-top: 0.5rem;
}

.kpi__spark span {
  display: block;
  width: 6px;
  border-radius: 2px 2px 0 0;
  background: var(--accent-soft);
}

.kpi__spark span:nth-last-child(-n+3) {
  background: var(--accent);
}


/* ─── Panel system (workspace cards) ─── */

.panel-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--s-4);
}

.panel {
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: 16px;
  padding: var(--s-4);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  min-width: 0;
  grid-column: span 12;
}

.panel--6 { grid-column: span 6; }
.panel--7 { grid-column: span 7; }
.panel--5 { grid-column: span 5; }
.panel--4 { grid-column: span 4; }
.panel--8 { grid-column: span 8; }
.panel--3 { grid-column: span 3; }
.panel--9 { grid-column: span 9; }

.panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
}

.panel__title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0;
  color: var(--ink);
  letter-spacing: -0.005em;
}

.panel__sub {
  font-size: 0.82rem;
  color: var(--ink-muted);
  margin: 0;
}

.panel__action {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
}

.panel__action:hover { text-decoration: underline; }

.panel__body {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}

.panel__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--s-2);
  border-top: 1px solid var(--rule);
  font-size: 0.82rem;
  color: var(--ink-muted);
}


/* ─── Generic data table (queues, referrals, activity) ─── */

.dtable {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
}

.dtable th,
.dtable td {
  text-align: left;
  padding: 0.6rem 0.45rem;
  border-bottom: 1px solid var(--rule);
}

.dtable th {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-weight: 600;
}

.dtable td { color: var(--ink-soft); }
.dtable td strong { color: var(--ink); font-weight: 600; }

.dtable tbody tr:last-child td { border-bottom: 0; }

.dtable .micro {
  font-size: 0.72rem;
  color: var(--ink-muted);
  display: block;
}


/* ─── Status pills (refinements over chip) ─── */

.pill {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  background: var(--paper-soft);
  color: var(--ink-soft);
  font-size: 0.74rem;
  font-weight: 600;
  padding: 0.18rem 0.55rem;
  border-radius: 999px;
  letter-spacing: 0.02em;
}

.pill::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.7;
}

.pill--blue    { background: var(--accent-soft);    color: var(--accent-strong); }
.pill--green   { background: var(--evidence-soft);  color: var(--evidence-strong); }
.pill--amber   { background: var(--warning-soft);   color: var(--warning); }
.pill--red     { background: var(--critical-soft);  color: var(--critical); }
.pill--ledger  { background: var(--paper-blue);     color: var(--accent-strong); font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; font-size: 0.7rem; }


/* ─── Avatar / initials chip ─── */

.avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--gradient-teal);
  display: inline-grid;
  place-items: center;
  color: #ffffff;
  font-weight: 700;
  font-size: 0.74rem;
  vertical-align: middle;
}

.avatar--md { width: 36px; height: 36px; font-size: 0.85rem; }
.avatar--lg { width: 48px; height: 48px; font-size: 0.95rem; }


/* ─── Map placeholder (CSS-only field-visit map) ─── */

.fieldmap {
  position: relative;
  aspect-ratio: 16 / 10;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--rule);
  background:
    linear-gradient(135deg, #0a1830 0%, #122144 100%);
  isolation: isolate;
}

.fieldmap::before,
.fieldmap::after {
  content: "";
  position: absolute;
  inset: 0;
}

.fieldmap::before {
  background:
    radial-gradient(2px 2px at 20% 30%, rgba(26, 163, 154, 0.95) 50%, transparent 51%),
    radial-gradient(2px 2px at 45% 65%, rgba(26, 163, 154, 0.95) 50%, transparent 51%),
    radial-gradient(2px 2px at 70% 38%, rgba(255, 255, 255, 0.95) 50%, transparent 51%),
    radial-gradient(2px 2px at 82% 70%, rgba(26, 163, 154, 0.95) 50%, transparent 51%),
    radial-gradient(2px 2px at 35% 80%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(2px 2px at 60% 20%, rgba(255, 255, 255, 0.85) 50%, transparent 51%);
}

.fieldmap::after {
  background:
    linear-gradient(0deg, transparent 96%, rgba(255,255,255,0.05) 96.5%, transparent 97%),
    linear-gradient(90deg, transparent 96%, rgba(255,255,255,0.05) 96.5%, transparent 97%);
  background-size: 8% 8%;
}

.fieldmap__overlay {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-rows: auto 1fr auto;
  padding: var(--s-3);
  z-index: 1;
}

.fieldmap__header {
  display: flex;
  justify-content: space-between;
  color: rgba(247,245,239,0.85);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.fieldmap__route {
  display: grid;
  place-items: center;
}

.fieldmap__route svg {
  width: 100%;
  height: 100%;
  max-height: 100%;
  opacity: 0.85;
}

.fieldmap__legend {
  display: flex;
  gap: 0.8rem;
  font-size: 0.72rem;
  color: rgba(247,245,239,0.72);
}

.fieldmap__legend span {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}

.fieldmap__legend span::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--teal-1);
}

.fieldmap__legend span:nth-child(2)::before { background: #ffffff; }
.fieldmap__legend span:nth-child(3)::before { background: var(--warning); }


/* ─── Journey / care timeline ─── */

.journey {
  display: grid;
  gap: var(--s-3);
  position: relative;
}

.journey::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 13px;
  width: 2px;
  background: linear-gradient(180deg, var(--teal-soft) 0%, var(--rule) 100%);
  border-radius: 999px;
}

.journey__item {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 0.7rem;
  align-items: start;
  position: relative;
}

.journey__dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--paper-elevated);
  border: 2px solid var(--teal-1);
  display: grid;
  place-items: center;
  position: relative;
  z-index: 1;
  color: var(--teal-2);
  font-weight: 700;
  font-size: 0.78rem;
}

.journey__item[data-state="done"] .journey__dot {
  background: var(--evidence);
  border-color: var(--evidence);
  color: #ffffff;
}

.journey__item[data-state="active"] .journey__dot {
  background: var(--gradient-teal);
  border-color: var(--teal-1);
  color: #ffffff;
  box-shadow: 0 0 0 4px var(--teal-glow);
}

.journey__item[data-state="pending"] .journey__dot {
  background: var(--paper-soft);
  border-color: var(--rule-strong);
  color: var(--ink-muted);
}

.journey__title {
  font-weight: 600;
  font-size: 0.92rem;
  margin: 0 0 0.1rem 0;
  color: var(--ink);
}

.journey__meta {
  font-size: 0.78rem;
  color: var(--ink-muted);
}

.journey__body {
  font-size: 0.88rem;
  color: var(--ink-soft);
  margin: 0.2rem 0 0 0;
  line-height: 1.5;
}


/* ─── Visit / itinerary list (CHW) ─── */

.itinerary {
  display: grid;
  gap: var(--s-3);
}

.visit {
  display: grid;
  grid-template-columns: 70px 1fr auto;
  gap: var(--s-3);
  align-items: center;
  padding: var(--s-3);
  border: 1px solid var(--rule);
  border-radius: 12px;
  background: var(--paper-elevated);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.visit:hover {
  border-color: var(--accent);
  box-shadow: var(--shadow-soft);
}

.visit__time {
  text-align: center;
  font-weight: 700;
  color: var(--ink);
  font-size: 0.95rem;
  line-height: 1.1;
}

.visit__time small {
  display: block;
  font-size: 0.7rem;
  color: var(--ink-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 600;
  margin-top: 0.15rem;
}

.visit__title {
  font-weight: 600;
  margin: 0 0 0.15rem 0;
  color: var(--ink);
  font-size: 0.95rem;
}

.visit__meta {
  font-size: 0.82rem;
  color: var(--ink-soft);
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  align-items: center;
}

.visit__action {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  background: var(--paper-blue);
  color: var(--accent-strong);
  font-size: 0.82rem;
  font-weight: 600;
  padding: 0.4rem 0.75rem;
  border-radius: 999px;
  border: 1px solid var(--rule-cool);
  text-decoration: none;
}

.visit__action:hover { background: var(--accent); color: #ffffff; border-color: var(--accent); }


/* ─── Checklist (SDOH / barrier capture) ─── */

.checklist {
  display: grid;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.checklist li {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 0.7rem;
  border: 1px solid var(--rule);
  border-radius: 10px;
  background: var(--paper-elevated);
  font-size: 0.92rem;
  color: var(--ink-soft);
}

.checklist li::before {
  content: "✓";
  display: grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 6px;
  background: var(--evidence-soft);
  color: var(--evidence-strong);
  font-weight: 700;
  font-size: 0.85rem;
}

.checklist li[data-state="pending"]::before {
  content: "";
  background: var(--paper-soft);
  border: 1.5px dashed var(--rule-strong);
}

.checklist li[data-state="flag"]::before {
  content: "!";
  background: var(--warning-soft);
  color: var(--warning);
}


/* ─── Tabs (CSS-only via :target inside a section) ─── */

.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  border-bottom: 1px solid var(--rule);
  margin-bottom: var(--s-4);
}

.tabs__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.55rem 0.85rem;
  border-radius: 8px 8px 0 0;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--ink-soft);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}

.tabs__btn--active,
.tabs__btn:focus-visible {
  color: var(--ink);
  border-bottom-color: var(--accent);
  background: var(--paper-blue);
}

.tabs__count {
  background: var(--paper-soft);
  color: var(--ink-muted);
  font-size: 0.7rem;
  font-weight: 700;
  padding: 0.05rem 0.35rem;
  border-radius: 999px;
}

.tabs__btn--active .tabs__count {
  background: var(--accent);
  color: #ffffff;
}


/* ─── Mini-chart placeholders (SVG-friendly containers) ─── */

.chartbox {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 12px;
  padding: var(--s-3);
  min-height: 200px;
  display: grid;
}

.chartbox svg {
  width: 100%;
  height: 100%;
}


/* ─── Toggle switch (visual only, no JS) ─── */

.toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  color: var(--ink-soft);
  font-weight: 600;
}

.toggle__switch {
  width: 36px;
  height: 20px;
  border-radius: 999px;
  background: var(--rule-strong);
  position: relative;
  transition: background 0.2s ease;
}

.toggle__switch::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  background: #ffffff;
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0,0,0,0.2);
  transition: transform 0.2s ease;
}

.toggle--on .toggle__switch { background: var(--evidence); }
.toggle--on .toggle__switch::after { transform: translateX(16px); }


/* ─── Admin ledger separation cards ─── */

.ledger-board {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--s-4);
}

.ledger-card {
  border: 1px solid var(--rule);
  border-radius: 16px;
  padding: var(--s-4);
  background: var(--paper-elevated);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.ledger-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--accent);
}

.ledger-card--commercial::before { background: var(--evidence); }
.ledger-card--workforce::before  { background: var(--warning); }
.ledger-card--platform::before   { background: var(--ink); }

.ledger-card__name {
  font-size: 0.95rem;
  font-weight: 700;
  margin: 0.3rem 0 0.15rem 0;
  color: var(--ink);
}

.ledger-card__scope {
  font-size: 0.78rem;
  color: var(--ink-muted);
  margin: 0 0 var(--s-2) 0;
}

.ledger-card__stat {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--ink);
}

.ledger-card__sub {
  font-size: 0.78rem;
  color: var(--ink-soft);
}


/* ─── Premium button refresh ─── */

.btn--ghost-light {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: var(--paper);
}

.btn--ghost-light:hover,
.btn--ghost-light:focus-visible {
  background: rgba(255, 255, 255, 0.18);
  color: #ffffff;
}

.btn--big {
  font-size: 1rem;
  padding: 0.85rem 1.3rem;
}


/* ─── Investor / leadership block ─── */

.leaders {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--s-4);
}

.leader {
  background: var(--paper-elevated);
  border: 1px solid var(--rule);
  border-radius: 16px;
  padding: var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.leader__avatar {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background: var(--gradient-teal);
  color: #ffffff;
  font-weight: 700;
  display: grid;
  place-items: center;
  font-size: 1.05rem;
}

.leader__name {
  font-size: 1rem;
  font-weight: 700;
  margin: 0;
  color: var(--ink);
}

.leader__role {
  font-size: 0.82rem;
  color: var(--accent);
  font-weight: 600;
  letter-spacing: 0.02em;
}

.leader__body {
  font-size: 0.88rem;
  color: var(--ink-soft);
  margin: 0;
  line-height: 1.5;
}


/* ─── Demo notice (small footnote under prototype panels) ─── */

.demo-note {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  color: var(--ink-muted);
  font-style: italic;
}

.demo-note::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--teal-1);
  box-shadow: 0 0 0 3px var(--teal-glow);
}


/* ─── Responsive overrides for portal + new layouts ─── */

@media (max-width: 64rem) {
  .hero-band__grid { grid-template-columns: 1fr; }
  .investor-grid  { grid-template-columns: 1fr; }
  .panel--6, .panel--5, .panel--7, .panel--4, .panel--8, .panel--3, .panel--9 { grid-column: span 12; }
}

@media (max-width: 48rem) {
  .portal-shell { grid-template-columns: 1fr; }
  .portal-side {
    position: static;
    height: auto;
    border-right: 0;
    border-bottom: 1px solid var(--glass-stroke-dark);
  }
  .portal-top { grid-template-columns: 1fr; gap: 0.6rem; padding: 0.7rem var(--s-4); }
  .portal-top__search { width: 100%; }
  .portal-top__actions { justify-content: flex-end; }
  .portal-workspace { padding: var(--s-4); }
  .audience-strip__inner { grid-template-columns: 1fr; }
  .hero-glass__kpis { grid-template-columns: 1fr 1fr; }
  .visit { grid-template-columns: 60px 1fr; }
  .visit__action { grid-column: 1 / -1; justify-self: start; }
}


/* ─── Reduced motion: disable hover transforms ─── */
@media (prefers-reduced-motion: reduce) {
  .pillar, .role-card, .visit { transform: none !important; }
}
