/* ================================================================
   EARTHSENTINEL.ORG — components.css
   Buttons | Cards | Badges | Tables | Escalation Ladder |
   Status Indicators | Compliance Bars | Forms | Zone Indicators
   CED v3.2.1
================================================================ */

/* ---- BUTTONS ---- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0.7rem 1.6rem;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.03em;
  border-radius: var(--r-sm);
  cursor: pointer;
  text-decoration: none;
  transition: all var(--transition);
  border: 1px solid transparent;
  white-space: nowrap;
}

.btn--primary {
  background: var(--blue-accent);
  color: var(--white);
  border-color: var(--blue-accent);
}

.btn--primary:hover {
  background: #4489ff;
  border-color: #4489ff;
  color: var(--white);
  box-shadow: var(--shadow-accent);
}

.btn--outline {
  background: transparent;
  color: var(--steel);
  border-color: var(--border-active);
}

.btn--outline:hover {
  color: var(--white);
  border-color: var(--border-accent);
  background: var(--blue-dim);
}

.btn--ghost {
  background: transparent;
  color: var(--blue-accent);
  border-color: transparent;
}

.btn--ghost:hover {
  background: var(--blue-dim);
  color: var(--white);
}

.btn--danger {
  background: var(--status-red);
  color: var(--white);
  border-color: var(--status-red);
}

.btn--sm {
  padding: 0.4rem 0.9rem;
  font-size: var(--text-xs);
}

.btn--lg {
  padding: 0.9rem 2.2rem;
  font-size: var(--text-md);
}

.btn--icon-only {
  padding: 0.6rem;
  width: 36px;
  height: 36px;
}

/* ---- STATUS BADGES ---- */
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0.22rem 0.65rem;
  border-radius: var(--r-xs);
  font-family: var(--font-mono);
  font-size: 0.63rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.status-badge::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
}

.status-badge--green {
  background: var(--status-green-bg);
  color: var(--status-green);
  border: 1px solid rgba(29, 185, 84, 0.25);
}
.status-badge--green::before { background: var(--status-green); }

.status-badge--yellow {
  background: var(--status-yellow-bg);
  color: var(--status-yellow);
  border: 1px solid rgba(245, 158, 11, 0.25);
}
.status-badge--yellow::before { background: var(--status-yellow); animation: blink 1.5s ease-in-out infinite; }

.status-badge--orange {
  background: var(--status-orange-bg);
  color: var(--status-orange);
  border: 1px solid rgba(249, 115, 22, 0.25);
}
.status-badge--orange::before { background: var(--status-orange); animation: blink 1.2s ease-in-out infinite; }

.status-badge--red {
  background: var(--status-red-bg);
  color: var(--status-red);
  border: 1px solid rgba(239, 68, 68, 0.25);
}
.status-badge--red::before { background: var(--status-red); animation: blink 0.9s ease-in-out infinite; }

.status-badge--blue {
  background: var(--blue-dim);
  color: var(--blue-accent);
  border: 1px solid var(--border-accent);
}
.status-badge--blue::before { background: var(--blue-accent); }

.status-badge--operational {
  background: var(--status-green-bg);
  color: var(--status-green);
  border: 1px solid rgba(29, 185, 84, 0.25);
}
.status-badge--operational::before { background: var(--status-green); animation: blink 2s ease-in-out infinite; }

/* ---- METRIC CARDS ---- */
.metric-card {
  background: var(--navy-mid);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-6);
  transition: border-color var(--transition);
}

.metric-card:hover {
  border-color: var(--border-active);
}

.metric-card__label {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: var(--space-3);
  opacity: 0.7;
}

.metric-card__value {
  font-family: var(--font-mono);
  font-size: var(--text-3xl);
  font-weight: 500;
  color: var(--white);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-2);
}

.metric-card__value--accent { color: var(--blue-accent); }
.metric-card__value--green  { color: var(--status-green); }
.metric-card__value--red    { color: var(--status-red); }
.metric-card__value--warn   { color: var(--status-yellow); }

.metric-card__delta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  display: flex;
  align-items: center;
  gap: 4px;
}

.metric-card__delta--up   { color: var(--status-green); }
.metric-card__delta--down { color: var(--status-red); }

.metric-card__sub {
  font-size: var(--text-xs);
  color: var(--steel);
  opacity: 0.6;
  margin-top: var(--space-2);
}

/* ---- ESCALATION LADDER ---- */
.escalation-ladder {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}

.escalation-rung {
  display: grid;
  grid-template-columns: 80px 1fr 180px;
  border-bottom: 1px solid var(--border);
  transition: background var(--transition);
}

.escalation-rung:last-child {
  border-bottom: none;
}

.escalation-rung:hover {
  background: rgba(255, 255, 255, 0.02);
}

.escalation-rung--active {
  background: var(--blue-dim);
  border-color: var(--border-accent);
}

.escalation-rung__level {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-5);
  border-right: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.06em;
}

.escalation-rung__body {
  padding: var(--space-5) var(--space-6);
}

.escalation-rung__name {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-1);
}

.escalation-rung__desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.6;
}

.escalation-rung__impact {
  padding: var(--space-5);
  border-left: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--steel);
}

/* Level Color Coding */
.escalation-rung--l0 .escalation-rung__level { color: var(--status-green); }
.escalation-rung--l1 .escalation-rung__level { color: var(--status-yellow); }
.escalation-rung--l2 .escalation-rung__level { color: var(--status-orange); }
.escalation-rung--l3 .escalation-rung__level { color: var(--status-red); }
.escalation-rung--l4 .escalation-rung__level { color: #dc2626; }
.escalation-rung--l5 .escalation-rung__level { color: #7f1d1d; }

/* Sub-phases (nested inside L3) */
.escalation-sub {
  background: rgba(0, 0, 0, 0.15);
}

.escalation-sub .escalation-rung__level {
  font-size: 0.65rem;
  opacity: 0.8;
  padding-left: var(--space-8);
  justify-content: flex-start;
}

/* ---- COMPLIANCE BAR ---- */
.compliance-bar {
  width: 100%;
}

.compliance-bar__label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-2);
}

.compliance-bar__name {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  color: var(--white);
}

.compliance-bar__pct {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--steel);
}

.compliance-bar__track {
  height: 6px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  overflow: hidden;
  display: flex;
}

.compliance-bar__fill {
  height: 100%;
  border-radius: 3px;
  transition: width 1.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.compliance-bar__fill--green  { background: var(--status-green); }
.compliance-bar__fill--yellow { background: var(--status-yellow); }
.compliance-bar__fill--orange { background: var(--status-orange); }
.compliance-bar__fill--red    { background: var(--status-red); }

/* ---- DATA TABLE ---- */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.data-table thead tr {
  border-bottom: 1px solid var(--border-active);
}

.data-table th {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--steel);
  opacity: 0.6;
  padding: 0 var(--space-4) var(--space-3);
  text-align: left;
  font-weight: 400;
  white-space: nowrap;
}

.data-table th:first-child { padding-left: 0; }
.data-table th.align-right { text-align: right; }

.data-table td {
  padding: var(--space-4) var(--space-4);
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--steel);
}

.data-table td:first-child {
  padding-left: 0;
  color: var(--white);
  font-weight: 500;
}

.data-table td.align-right {
  text-align: right;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
}

.data-table td.mono {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
}

.data-table tbody tr:hover {
  background: rgba(255, 255, 255, 0.02);
}

.data-table tbody tr:last-child td {
  border-bottom: none;
}

/* ---- ZONE INDICATORS ---- */
.zone-indicator {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0.18rem 0.55rem;
  border-radius: var(--r-xs);
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
}

.zone-indicator--1 {
  background: rgba(29, 185, 84, 0.08);
  color: var(--status-green);
  border: 1px solid rgba(29, 185, 84, 0.20);
}

.zone-indicator--2 {
  background: rgba(245, 158, 11, 0.08);
  color: var(--status-yellow);
  border: 1px solid rgba(245, 158, 11, 0.20);
}

.zone-indicator--3 {
  background: rgba(30, 111, 255, 0.08);
  color: var(--blue-accent);
  border: 1px solid rgba(30, 111, 255, 0.20);
}

/* ---- CGCI CHIPS ---- */
.cgci-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.8rem;
  background: var(--navy-mid);
  border: 1px solid var(--border);
  border-radius: 20px;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.06em;
  color: var(--steel);
  cursor: pointer;
  text-decoration: none;
  transition: all var(--transition);
}

.cgci-chip:hover,
.cgci-chip--active {
  border-color: var(--blue-accent);
  color: var(--white);
  background: var(--blue-dim);
}

/* ---- CARDS ---- */
.card {
  background: var(--navy-mid);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.card:hover {
  border-color: var(--border-active);
}

.card__header {
  padding: var(--space-6) var(--space-8);
  border-bottom: 1px solid var(--border);
}

.card__body {
  padding: var(--space-8);
}

.card__footer {
  padding: var(--space-5) var(--space-8);
  border-top: 1px solid var(--border);
  background: rgba(0,0,0,0.15);
}

.card--accent {
  border-color: var(--border-accent);
  background: var(--blue-dim);
}

/* ---- INSTITUTION CARDS ---- */
.institution-card {
  padding: var(--space-8);
  background: var(--navy-mid);
  border: 1px solid var(--border);
  transition: background var(--transition), border-color var(--transition);
}

.institution-card:hover {
  background: var(--surface-3);
  border-color: var(--border-active);
}

.institution-card__abbr {
  font-family: var(--font-mono);
  font-size: var(--text-2xl);
  font-weight: 500;
  color: var(--blue-accent);
  letter-spacing: -0.02em;
  margin-bottom: var(--space-1);
}

.institution-card__name {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--steel);
  opacity: 0.5;
  margin-bottom: var(--space-5);
}

.institution-card__desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.75;
  margin-bottom: var(--space-6);
}

.institution-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

/* ---- TAG (generic) ---- */
.tag {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.55rem;
  font-family: var(--font-mono);
  font-size: 0.60rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--steel);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: var(--r-xs);
}

/* ---- FORMS ---- */
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}

.form-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--steel);
}

.form-input,
.form-select,
.form-textarea {
  background: var(--graphite);
  border: 1px solid var(--border-active);
  border-radius: var(--r-sm);
  padding: 0.65rem var(--space-4);
  color: var(--white);
  font-size: var(--text-base);
  transition: border-color var(--transition), box-shadow var(--transition);
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
}

.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--steel);
  opacity: 0.4;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--blue-accent);
  box-shadow: 0 0 0 3px var(--blue-dim);
}

.form-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238A9BAE' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.9rem center;
  padding-right: 2.5rem;
  cursor: pointer;
}

.form-select option {
  background: var(--graphite);
}

.form-textarea {
  min-height: 120px;
  resize: vertical;
  line-height: 1.6;
}

.form-hint {
  font-size: var(--text-xs);
  color: var(--steel);
  opacity: 0.6;
}

.form-error {
  font-size: var(--text-xs);
  color: var(--status-red);
}

/* Slider */
.form-slider {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 4px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
}

.form-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--blue-accent);
  cursor: pointer;
  border: 2px solid var(--navy);
  box-shadow: var(--shadow-accent);
}

.form-slider::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--blue-accent);
  cursor: pointer;
  border: 2px solid var(--navy);
}

/* ---- COALITION SCENARIO CARDS ---- */
.coalition-card {
  background: var(--navy-mid);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-8);
  transition: all var(--transition);
  cursor: pointer;
}

.coalition-card:hover {
  border-color: var(--border-accent);
  background: var(--surface-3);
}

.coalition-card--target {
  border-color: var(--border-accent);
  background: var(--blue-dim);
}

.coalition-card__label {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: var(--space-2);
  opacity: 0.6;
}

.coalition-card__title {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-6);
}

.coalition-card--target .coalition-card__title {
  color: var(--blue-accent);
}

.coalition-card__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.coalition-stat__value {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--white);
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: var(--space-1);
}

.coalition-card--target .coalition-stat__value {
  color: var(--blue-accent);
}

.coalition-stat__label {
  font-family: var(--font-mono);
  font-size: 0.60rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--steel);
  opacity: 0.5;
}

/* ---- PIPELINE STEPS ---- */
.pipeline-steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  position: relative;
  margin-top: var(--space-12);
}

.pipeline-steps::before {
  content: '';
  position: absolute;
  top: 42px;
  left: 8%;
  right: 8%;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--border-accent) 15%,
    var(--blue-accent) 50%,
    var(--border-accent) 85%,
    transparent 100%
  );
}

.pipeline-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 var(--space-4);
}

.pipeline-step__num {
  font-family: var(--font-mono);
  font-size: 0.58rem;
  letter-spacing: 0.12em;
  color: var(--steel);
  opacity: 0.5;
  margin-bottom: var(--space-3);
}

.pipeline-step__icon {
  width: 52px;
  height: 52px;
  border: 1px solid var(--border-active);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--navy-mid);
  position: relative;
  z-index: 1;
  margin-bottom: var(--space-5);
  font-size: 1.2rem;
  transition: border-color var(--transition), background var(--transition);
}

.pipeline-step:hover .pipeline-step__icon {
  border-color: var(--blue-accent);
  background: var(--blue-dim);
}

.pipeline-step__title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-2);
}

.pipeline-step__desc {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.65;
}

/* ---- TRL PROGRESS CARDS ---- */
.trl-card {
  background: var(--navy-mid);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-6);
  transition: border-color var(--transition);
}

.trl-card:hover {
  border-color: var(--border-active);
}

.trl-card__component {
  font-family: var(--font-mono);
  font-size: 0.60rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--steel);
  opacity: 0.5;
  margin-bottom: var(--space-2);
}

.trl-card__tech {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-5);
}

.trl-card__bar-wrap {
  height: 3px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: var(--space-2);
}

.trl-card__bar {
  height: 100%;
  border-radius: 2px;
  transition: width 1.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.trl-card__bar--full    { background: var(--status-green); }
.trl-card__bar--partial { background: var(--status-yellow); }

.trl-card__meta {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  color: var(--steel);
  opacity: 0.6;
}

.trl-card__meta strong {
  color: var(--status-green);
  opacity: 1;
}

.trl-card__meta strong.warn {
  color: var(--status-yellow);
}

/* ---- AUTH MODAL ---- */
.auth-overlay {
  position: fixed;
  inset: 0;
  background: rgba(8, 20, 28, 0.90);
  backdrop-filter: blur(8px);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-5);
}

.auth-modal {
  background: var(--navy-mid);
  border: 1px solid var(--border-active);
  border-radius: var(--r-xl);
  padding: var(--space-12);
  max-width: 440px;
  width: 100%;
  box-shadow: var(--shadow-lg);
}

.auth-modal__logo {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--blue-accent);
  letter-spacing: 0.08em;
  margin-bottom: var(--space-8);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.auth-modal__logo::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--blue-accent);
  border-radius: 50%;
}

.auth-modal__title {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--white);
  letter-spacing: -0.025em;
  margin-bottom: var(--space-2);
}

.auth-modal__subtitle {
  font-size: var(--text-sm);
  color: var(--steel);
  margin-bottom: var(--space-8);
}

.auth-google-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  width: 100%;
  padding: 0.85rem;
  background: var(--white);
  color: var(--graphite);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--r-sm);
  font-size: var(--text-base);
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: all var(--transition);
  margin-bottom: var(--space-6);
}

.auth-google-btn:hover {
  background: #eaeaea;
  color: var(--graphite);
}

.auth-google-btn__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.auth-divider {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.auth-divider::before,
.auth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

.auth-divider span {
  font-family: var(--font-mono);
  font-size: 0.60rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--steel);
  opacity: 0.4;
}

.auth-terms {
  font-size: 0.70rem;
  color: var(--steel);
  opacity: 0.5;
  text-align: center;
  line-height: 1.6;
  margin-top: var(--space-6);
}

/* ---- NOTIFICATION FLASH ---- */
.flash {
  padding: var(--space-4) var(--space-6);
  border-radius: var(--r-sm);
  font-size: var(--text-sm);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}

.flash--success {
  background: var(--status-green-bg);
  border: 1px solid rgba(29, 185, 84, 0.25);
  color: var(--status-green);
}

.flash--error {
  background: var(--status-red-bg);
  border: 1px solid rgba(239, 68, 68, 0.25);
  color: var(--status-red);
}

.flash--info {
  background: var(--blue-dim);
  border: 1px solid var(--border-accent);
  color: var(--blue-accent);
}

/* ---- OPERATIONAL PANEL ---- */
.ops-panel {
  background: var(--blue-dim);
  border: 1px solid var(--border-accent);
  border-radius: var(--r-md);
  padding: var(--space-5) var(--space-8);
  display: flex;
  align-items: center;
  gap: var(--space-6);
}

.ops-panel__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--blue-accent);
  white-space: nowrap;
  border-right: 1px solid var(--border-accent);
  padding-right: var(--space-6);
  flex-shrink: 0;
}

.ops-panel__text {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.65;
}

.ops-panel__text strong {
  color: var(--blue-accent);
}

/* ---- SYSTEM STATUS BAR ---- */
.system-status-bar {
  background: var(--navy-mid);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-4) var(--space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  flex-wrap: wrap;
  margin-bottom: var(--space-8);
}

.system-status-bar__left {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.system-status-bar__sync {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  color: var(--steel);
  opacity: 0.5;
}

.system-status-bar__right {
  display: flex;
  align-items: center;
  gap: var(--space-5);
}

.system-status-bar__metric {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.system-status-bar__metric-val {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--white);
}

.system-status-bar__metric-lbl {
  font-family: var(--font-mono);
  font-size: 0.55rem;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--steel);
  opacity: 0.4;
}

/* ---- API CODE BLOCK ---- */
.api-endpoint {
  margin-bottom: var(--space-10);
}

.api-endpoint__header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.api-method {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  padding: 0.2rem 0.65rem;
  border-radius: var(--r-xs);
  letter-spacing: 0.06em;
}

.api-method--get {
  background: rgba(29, 185, 84, 0.12);
  color: var(--status-green);
  border: 1px solid rgba(29, 185, 84, 0.25);
}

.api-method--post {
  background: var(--blue-dim);
  color: var(--blue-accent);
  border: 1px solid var(--border-accent);
}

.api-path {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--white);
  letter-spacing: 0.03em;
}

/* ---- RESPONSIVE ---- */
@media (max-width: 900px) {
  .pipeline-steps { grid-template-columns: 1fr 1fr; }
  .pipeline-steps::before { display: none; }
  .escalation-rung { grid-template-columns: 60px 1fr; }
  .escalation-rung__impact { display: none; }
  .coalition-card__stats { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 600px) {
  .pipeline-steps { grid-template-columns: 1fr; }
  .coalition-card__stats { grid-template-columns: 1fr; }
  .ops-panel { flex-direction: column; align-items: flex-start; }
  .ops-panel__label { border-right: none; border-bottom: 1px solid var(--border-accent); padding-right: 0; padding-bottom: var(--space-4); width: 100%; }
  .auth-modal { padding: var(--space-8); }
}

/* ================================================================
   DASHBOARD-SPECIFIC COMPONENTS — CED v3.2.1
   Added for /public/dashboard.php
================================================================ */

/* ---- STATUS BAR ---- */
.dash-statusbar {
  background: var(--navy-mid);
  border-bottom: 1px solid var(--border-accent);
  padding: var(--space-3) 0;
  position: sticky;
  top: 64px;
  z-index: 90;
}

.dash-statusbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.dash-statusbar__left { display: flex; align-items: center; gap: var(--space-3); }
.dash-statusbar__right { display: flex; align-items: center; gap: var(--space-3); }

.dash-statusbar__center {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.dash-statusbar__label {
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--steel);
}

.dash-statusbar__value {
  font-size: 11px;
  color: var(--white);
  font-family: var(--font-mono);
}

.dash-statusbar__sep {
  color: var(--border-accent);
  font-size: 11px;
}

.dash-statusbar__phase {
  font-size: 11px;
  color: var(--steel);
  font-family: var(--font-mono);
}

/* ---- STATUS BADGE VARIANTS ---- */
.status-badge--pre {
  background: rgba(30, 111, 255, 0.12);
  color: var(--blue-accent);
  border-color: rgba(30, 111, 255, 0.3);
}

.status-badge--operational {
  background: rgba(29, 185, 84, 0.12);
  color: var(--status-green);
  border-color: rgba(29, 185, 84, 0.3);
}

.status-badge--operational::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--status-green);
  margin-right: var(--space-2);
  animation: blink 2s ease-in-out infinite;
  vertical-align: middle;
}

/* ---- METRICS GRID ---- */
.metrics-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}

.metric-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}

.metric-card__target {
  font-size: 10px;
  color: var(--steel);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.metric-card__bar {
  margin-top: var(--space-3);
}

.metric-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border-accent);
}

.metric-card__inline-value {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--white);
}

.metric-card--alert { border-color: rgba(239, 68, 68, 0.3); }
.metric-card--alert .metric-card__value { color: var(--status-red); }

.metric-card--highlight { border-color: rgba(30, 111, 255, 0.4); }
.metric-card--highlight .metric-card__value { color: var(--blue-accent); }

.metric-card--critical { border-color: rgba(239, 68, 68, 0.4); }

/* Compliance bar fill extension */
.compliance-bar__fill--blue { background: var(--blue-accent); }

/* ---- ESCALATION LADDER EXTENSIONS ---- */
.escalation-rung__header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-2);
}

.escalation-rung__trigger {
  font-size: var(--text-xs);
  color: var(--steel);
  font-style: italic;
}

.escalation-rung__detail {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.6;
}

.escalation-rung__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.escalation-rung__badge--green  { background: rgba(29,185,84,0.15); color: var(--status-green); border: 1px solid rgba(29,185,84,0.3); }
.escalation-rung__badge--yellow { background: rgba(245,158,11,0.15); color: var(--status-yellow); border: 1px solid rgba(245,158,11,0.3); }
.escalation-rung__badge--orange { background: rgba(249,115,22,0.15); color: var(--status-orange); border: 1px solid rgba(249,115,22,0.3); }
.escalation-rung__badge--red    { background: rgba(239,68,68,0.15);  color: var(--status-red);    border: 1px solid rgba(239,68,68,0.3); }
.escalation-rung__badge--critical { background: rgba(127,29,29,0.3); color: #fca5a5; border: 1px solid rgba(239,68,68,0.5); }

.escalation-rung__count {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 64px;
  padding: var(--space-3);
  border-left: 1px solid var(--border-accent);
  text-align: center;
}

.escalation-rung__count-label {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--steel);
  display: block;
  margin-bottom: var(--space-1);
}

.escalation-rung__count-value {
  font-family: var(--font-mono);
  font-size: var(--text-lg);
  color: var(--white);
}

/* Level-specific active highlight */
.escalation-rung--active {
  background: rgba(30, 111, 255, 0.06);
  border-color: rgba(30, 111, 255, 0.4);
}

/* Escalation sub-phases */
.escalation-subphases {
  margin-top: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.escalation-subphase {
  background: rgba(0,0,0,0.2);
  border: 1px solid var(--border-accent);
  border-radius: 4px;
  padding: var(--space-3) var(--space-4);
}

.escalation-subphase__header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-2);
}

.escalation-subphase__id {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--status-red);
  font-weight: 700;
  letter-spacing: 0.05em;
  min-width: 70px;
}

.escalation-subphase__name {
  font-size: var(--text-sm);
  color: var(--white);
  font-weight: 500;
}

.escalation-subphase__cost {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--status-orange);
  margin-left: auto;
}

.escalation-subphase__count {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--white);
  min-width: 30px;
  text-align: right;
}

.escalation-subphase__detail {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.6;
}

/* ---- MAP WRAPPER ---- */
.map-wrapper {
  position: relative;
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  overflow: hidden;
}

#cgci-map {
  width: 100%;
  height: 480px;
  background: var(--graphite);
}

.map-legend {
  position: absolute;
  bottom: var(--space-4);
  right: var(--space-4);
  background: rgba(11, 31, 42, 0.92);
  border: 1px solid var(--border-accent);
  border-radius: 4px;
  padding: var(--space-4);
  min-width: 220px;
  backdrop-filter: blur(8px);
  z-index: 999;
}

.map-legend__title {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--steel);
  margin-bottom: var(--space-3);
}

.map-legend__item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
  font-size: var(--text-xs);
  color: var(--white);
}

.map-legend__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.map-legend__dot--green  { background: var(--status-green); }
.map-legend__dot--yellow { background: var(--status-yellow); }
.map-legend__dot--orange { background: var(--status-orange); }
.map-legend__dot--red    { background: var(--status-red); }
.map-legend__dot--blue   { background: var(--blue-accent); }

/* ---- COMPLIANCE GRID ---- */
.compliance-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.compliance-card {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
}

.compliance-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.compliance-card__name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  flex: 1;
}

.compliance-card__area {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--steel);
}

.compliance-card__bars {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.compliance-bar-row {
  display: grid;
  grid-template-columns: 64px 1fr 40px;
  align-items: center;
  gap: var(--space-2);
}

.compliance-bar-row__label {
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--steel);
}

.compliance-bar-row__pct {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--white);
  text-align: right;
}

.compliance-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border-accent);
  font-size: var(--text-xs);
  color: var(--steel);
}

/* ---- STATUS DOT (inline label) ---- */
.status-dot::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
}

.status-dot--green::before  { background: var(--status-green); }
.status-dot--yellow::before { background: var(--status-yellow); }
.status-dot--orange::before { background: var(--status-orange); }
.status-dot--red::before    { background: var(--status-red); }

/* ---- CGCI CHIP CATEGORY VARIANTS ---- */
.cgci-chip--A { border-color: rgba(239,68,68,0.4); color: var(--status-red); }
.cgci-chip--B { border-color: rgba(245,158,11,0.4); color: var(--status-yellow); }
.cgci-chip--C { border-color: rgba(249,115,22,0.4); color: var(--status-orange); }
.cgci-chip--D { border-color: rgba(30,111,255,0.4); color: var(--blue-accent); }

/* ---- TRL BADGE ---- */
.trl-badge {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  padding: 2px 6px;
  border-radius: 3px;
  border: 1px solid;
}

.trl-badge--9 {
  background: rgba(29,185,84,0.12);
  color: var(--status-green);
  border-color: rgba(29,185,84,0.3);
}

.trl-badge--8 {
  background: rgba(29,185,84,0.08);
  color: var(--status-green);
  border-color: rgba(29,185,84,0.2);
}

.trl-badge--6 {
  background: rgba(245,158,11,0.12);
  color: var(--status-yellow);
  border-color: rgba(245,158,11,0.3);
}

/* ---- TABLE WRAPPER ---- */
.table-wrapper {
  overflow-x: auto;
  border: 1px solid var(--border-accent);
  border-radius: 6px;
}

.table-empty {
  text-align: center;
  padding: var(--space-8) !important;
  font-style: italic;
}

/* ---- DASHBOARD RESPONSIVE ---- */
@media (max-width: 1200px) {
  .metrics-grid { grid-template-columns: repeat(2, 1fr); }
  .compliance-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .metrics-grid { grid-template-columns: 1fr; }
  .compliance-grid { grid-template-columns: 1fr; }
  .dash-statusbar__center { display: none; }
  .escalation-rung__count { display: none; }
  .escalation-subphase__cost { display: none; }
  #cgci-map { height: 300px; }
  .map-legend { display: none; }
}

/* ================================================================
   GOVERNANCE PAGE COMPONENTS — CED v3.2.1
   Added for /public/governance.php
================================================================ */

/* ---- PAGE HERO ---- */
.page-hero { padding: var(--space-20) 0 var(--space-16); }

.page-hero__eyebrow { margin-bottom: var(--space-4); }

.page-hero__title {
  font-family: var(--font-mono);
  font-size: var(--text-4xl);
  color: var(--white);
  line-height: 1.1;
  margin-bottom: var(--space-5);
  letter-spacing: -0.02em;
}

.page-hero__desc {
  font-size: var(--text-lg);
  color: var(--steel);
  max-width: 720px;
  line-height: 1.7;
  margin-bottom: var(--space-8);
}

.page-hero__meta {
  display: flex;
  gap: var(--space-8);
  flex-wrap: wrap;
  padding-top: var(--space-6);
  border-top: 1px solid var(--border-accent);
}

.page-hero__meta-item { display: flex; flex-direction: column; gap: var(--space-1); }

.page-hero__meta-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--steel);
}

.page-hero__meta-value {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  color: var(--white);
  font-weight: 700;
}

.t-red   { color: var(--status-red) !important; }
.t-green { color: var(--status-green) !important; }
.t-accent { color: var(--blue-accent) !important; }
.t-steel  { color: var(--steel) !important; }
.t-white  { color: var(--white) !important; }

/* ---- GOVERNANCE PILLARS ---- */
.gov-pillars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}

.gov-pillar {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: border-color 0.2s ease;
}

.gov-pillar:hover { border-color: rgba(30,111,255,0.5); }

.gov-pillar__abbr {
  font-family: var(--font-mono);
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--blue-accent);
  line-height: 1;
}

.gov-pillar__name {
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--white);
  line-height: 1.3;
}

.gov-pillar__role {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--steel);
}

.gov-pillar__desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.6;
  flex: 1;
}

.gov-pillar__link {
  font-size: var(--text-sm);
  color: var(--blue-accent);
  text-decoration: none;
  margin-top: var(--space-2);
}

.gov-pillar__link:hover { text-decoration: underline; }

/* ---- GOVERNANCE SECTION BLOCKS ---- */
.gov-section-block {
  margin-bottom: var(--space-12);
}

.gov-section-block:last-child { margin-bottom: 0; }

.gov-block-title {
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border-accent);
  letter-spacing: 0.02em;
}

.gov-block-desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.7;
  margin-bottom: var(--space-5);
  max-width: 820px;
}

.gov-note {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.7;
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  border-left: 2px solid var(--border-accent);
  font-style: italic;
}

/* ---- CSC MEMBERS ---- */
.csc-members-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

.csc-member {
  background: rgba(0,0,0,0.2);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: var(--space-4);
  align-items: start;
}

.csc-member--permanent { border-color: rgba(30,111,255,0.3); }

.csc-member__flag {
  width: 48px;
  height: 48px;
  background: var(--blue-dim);
  border: 1px solid var(--border-accent);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--blue-accent);
  letter-spacing: 0.05em;
  flex-shrink: 0;
}

.csc-member__name {
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-1);
}

.csc-member__gdp {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--blue-accent);
  margin-bottom: var(--space-3);
}

.csc-member__threats {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

.gov-tag {
  font-size: 10px;
  padding: 2px 6px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border);
  border-radius: 3px;
  color: var(--steel);
}

.csc-member__badge { padding-top: 2px; }

/* ---- LEVERAGE GRID ---- */
.gov-leverage-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.gov-leverage-item {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
  text-align: center;
}

.gov-leverage-item__value {
  font-family: var(--font-mono);
  font-size: var(--text-3xl);
  color: var(--blue-accent);
  font-weight: 700;
  margin-bottom: var(--space-2);
}

.gov-leverage-item__label {
  font-size: var(--text-xs);
  color: var(--steel);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* ---- ISC COMPOSITION ---- */
.isc-composition-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}

.isc-block {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
}

.isc-block__header {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.isc-block__count {
  font-family: var(--font-mono);
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--blue-accent);
}

.isc-block__name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
}

.isc-block__bar { margin-bottom: var(--space-4); }

.isc-block__members {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.isc-block__member-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
}

.isc-block__member-role {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.4;
}

.isc-block__member-count {
  font-size: var(--text-sm);
  color: var(--white);
  flex-shrink: 0;
}

.isc-block__selection {
  font-size: var(--text-xs);
  color: var(--steel);
  font-style: italic;
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
}

/* ---- DISQUALIFICATION GRID ---- */
.disqualif-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.disqualif-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  background: rgba(239,68,68,0.05);
  border: 1px solid rgba(239,68,68,0.2);
  border-radius: 4px;
}

.disqualif-item__icon {
  color: var(--status-red);
  font-size: var(--text-lg);
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
}

.disqualif-item__text {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.5;
}

.disqualif-item__text strong { color: var(--white); }

/* ---- GPF COST GRID ---- */
.gpf-cost-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr 1fr;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}

.gpf-cost-item {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-4);
}

.gpf-cost-item--major { background: rgba(30,111,255,0.06); border-color: rgba(30,111,255,0.3); }

.gpf-cost-item__pct {
  font-family: var(--font-mono);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--blue-accent);
  margin-bottom: var(--space-1);
}

.gpf-cost-item__amount {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--white);
  margin-bottom: var(--space-2);
}

.gpf-cost-item__label {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-1);
}

.gpf-cost-item__calc {
  font-size: var(--text-xs);
  color: var(--steel);
  margin-bottom: var(--space-3);
  line-height: 1.4;
}

/* ---- ANTI-CORRUPTION GRID ---- */
.anticorrupt-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
}

.anticorrupt-item {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 4px;
  padding: var(--space-4);
}

.anticorrupt-item__label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-2);
}

.anticorrupt-item__desc {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.5;
}

/* ---- NIA CONSEQUENCES ---- */
.nia-consequences {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.nia-consequence {
  display: grid;
  grid-template-columns: 280px 40px 1fr;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4);
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 4px;
}

.nia-consequence__trigger {
  font-size: var(--text-sm);
  color: var(--white);
}

.nia-consequence__arrow {
  font-size: var(--text-xl);
  color: var(--steel);
  text-align: center;
}

.nia-consequence__result {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.nia-consequence__detail {
  font-size: var(--text-xs);
  color: var(--steel);
}

/* ---- GOVERNANCE RESPONSIVE ---- */
@media (max-width: 1200px) {
  .gov-pillars     { grid-template-columns: repeat(2, 1fr); }
  .isc-composition-grid { grid-template-columns: 1fr; }
  .gpf-cost-grid   { grid-template-columns: 1fr 1fr 1fr; }
  .anticorrupt-grid { grid-template-columns: repeat(2, 1fr); }
  .gov-leverage-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  .csc-members-grid { grid-template-columns: 1fr; }
  .disqualif-grid   { grid-template-columns: 1fr; }
  .nia-consequence  { grid-template-columns: 1fr; }
  .nia-consequence__arrow { display: none; }
}

@media (max-width: 768px) {
  .gov-pillars     { grid-template-columns: 1fr; }
  .gpf-cost-grid   { grid-template-columns: 1fr 1fr; }
  .anticorrupt-grid { grid-template-columns: 1fr; }
  .gov-leverage-grid { grid-template-columns: repeat(2, 1fr); }
  .page-hero__title { font-size: var(--text-3xl); }
  .csc-member      { grid-template-columns: 48px 1fr; }
  .csc-member__badge { grid-column: 2; }
}

/* ================================================================
   TECHNOLOGY PAGE COMPONENTS — CED v3.2.1
   Added for /public/technology.php
================================================================ */

/* ---- TRL SUMMARY CARDS ---- */
.trl-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}

.trl-summary-card {
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-6);
  background: var(--navy-mid);
}

.trl-summary-card--9 { border-color: rgba(29,185,84,0.35); background: rgba(29,185,84,0.04); }
.trl-summary-card--8 { border-color: rgba(29,185,84,0.2); }
.trl-summary-card--6 { border-color: rgba(245,158,11,0.35); background: rgba(245,158,11,0.04); }

.trl-summary-card__level {
  font-family: var(--font-mono);
  font-size: var(--text-2xl);
  font-weight: 700;
  margin-bottom: var(--space-1);
}

.trl-summary-card--9 .trl-summary-card__level { color: var(--status-green); }
.trl-summary-card--8 .trl-summary-card__level { color: var(--status-green); opacity: 0.8; }
.trl-summary-card--6 .trl-summary-card__level { color: var(--status-yellow); }

.trl-summary-card__label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-3);
}

.trl-summary-card__desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.6;
  margin-bottom: var(--space-4);
}

.trl-summary-card__systems {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

/* ---- TECH SUBSECTION ---- */
.tech-subsection {
  margin-bottom: var(--space-10);
}

.tech-subsection__title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border-accent);
  letter-spacing: 0.02em;
}

/* ---- TECH COVERAGE NOTE ---- */
.tech-coverage-note {
  background: rgba(30,111,255,0.06);
  border: 1px solid rgba(30,111,255,0.25);
  border-radius: 4px;
  padding: var(--space-5);
  margin-top: var(--space-6);
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: var(--space-4);
  align-items: start;
}

.tech-coverage-note__label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--blue-accent);
  font-weight: 600;
  padding-top: 2px;
}

.tech-coverage-note__value {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.7;
}

/* ---- AI SPECS GRID ---- */
.ai-specs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.ai-spec-card {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
}

.ai-spec-card__metric {
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--blue-accent);
  margin-bottom: var(--space-2);
  line-height: 1;
}

.ai-spec-card__label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-3);
}

.ai-spec-card__desc {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.6;
}

/* ---- COMPLIANCE SCHEMA GRID ---- */
.compliance-schema-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}

.compliance-schema-card {
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
  background: var(--navy-mid);
}

.compliance-schema-card--green  { border-color: rgba(29,185,84,0.3);  background: rgba(29,185,84,0.04); }
.compliance-schema-card--yellow { border-color: rgba(245,158,11,0.3); background: rgba(245,158,11,0.04); }
.compliance-schema-card--orange { border-color: rgba(249,115,22,0.3); background: rgba(249,115,22,0.04); }
.compliance-schema-card--red    { border-color: rgba(239,68,68,0.3);  background: rgba(239,68,68,0.04); }

.compliance-schema-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}

.compliance-schema-card__rate {
  font-size: var(--text-sm);
  color: var(--white);
}

.compliance-schema-card__status {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-3);
}

.compliance-schema-card__desc {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.6;
  margin-bottom: var(--space-4);
}

.compliance-schema-card__market {
  font-size: var(--text-xs);
  color: var(--steel);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
}

.compliance-schema-card__market strong { color: var(--white); }

/* ---- PAYMENT FLOW ---- */
.payment-flow {
  max-width: 760px;
  margin: 0 auto;
}

.payment-flow__step {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: var(--space-5);
  align-items: start;
  padding: var(--space-5);
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
}

.payment-flow__step-num {
  width: 36px;
  height: 36px;
  background: var(--blue-dim);
  border: 1px solid var(--border-accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--blue-accent);
  flex-shrink: 0;
}

.payment-flow__step-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-2);
}

.payment-flow__step-desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.65;
}

.payment-flow__connector {
  text-align: center;
  font-size: var(--text-xl);
  color: var(--border-accent);
  padding: var(--space-2) 0;
  margin-left: 23px;
}

/* ---- ARCHITECTURE DIAGRAM ---- */
.arch-diagram {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
}

.arch-layer {
  border: 1px solid var(--border-accent);
  border-radius: 4px;
  padding: var(--space-4) var(--space-5);
  background: var(--navy-mid);
}

.arch-layer--top    { border-color: rgba(29,185,84,0.3); background: rgba(29,185,84,0.03); }
.arch-layer--bottom { border-color: rgba(30,111,255,0.3); background: rgba(30,111,255,0.04); }
.arch-layer--innovation {
  border-color: rgba(245,158,11,0.4);
  background: rgba(245,158,11,0.05);
  box-shadow: 0 0 20px rgba(245,158,11,0.08);
}

.arch-layer__label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--steel);
  margin-bottom: var(--space-3);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.arch-layer__nodes {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.arch-layer__nodes--col {
  flex-direction: column;
  gap: var(--space-1);
}

.arch-layer__spec {
  font-size: var(--text-xs);
  color: var(--steel);
  font-style: italic;
}

.arch-node {
  font-size: 11px;
  padding: 3px 8px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border);
  border-radius: 3px;
  color: var(--white);
  font-family: var(--font-mono);
}

.arch-node--highlight {
  background: rgba(245,158,11,0.1);
  border-color: rgba(245,158,11,0.3);
  color: var(--status-yellow);
}

.arch-arrow {
  text-align: center;
  font-size: var(--text-xl);
  color: var(--border-accent);
  padding: var(--space-2) 0;
  line-height: 1;
}

.arch-split {
  display: grid;
  grid-template-columns: 1fr 40px 1fr;
  gap: 0;
  align-items: stretch;
}

.arch-split-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--steel);
  font-size: var(--text-lg);
}

.arch-branch { display: flex; flex-direction: column; }

/* ---- TECHNOLOGY RESPONSIVE ---- */
@media (max-width: 1100px) {
  .trl-summary-grid       { grid-template-columns: 1fr; }
  .compliance-schema-grid { grid-template-columns: repeat(2, 1fr); }
  .ai-specs-grid          { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .compliance-schema-grid { grid-template-columns: 1fr; }
  .ai-specs-grid          { grid-template-columns: 1fr; }
  .arch-split             { grid-template-columns: 1fr; }
  .arch-split-divider     { display: none; }
  .tech-coverage-note     { grid-template-columns: 1fr; }
  .payment-flow__step     { grid-template-columns: 1fr; }
  .payment-flow__step-num { display: none; }
}

/* ================================================================
   COALITION, ABOUT, SINGAPORE, API-DOCS, CONTACT — CSS
   CED v3.2.1 — All remaining pages
================================================================ */

/* ---- COALITION: SCENARIO CARDS ---- */
.coalition-scenarios-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-3);
}

.coalition-scenario-card {
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
  background: var(--navy-mid);
  transition: border-color var(--transition);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.coalition-scenario-card.coalition-card--target,
.coalition-scenario-card:has(.status-badge--green) {
  border-color: var(--blue-accent);
  box-shadow: 0 0 0 1px var(--blue-accent);
}

.coalition-scenario-card__id {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--blue-accent);
  line-height: 1;
}

.coalition-scenario-card__name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
}

.coalition-scenario-card__range {
  font-size: var(--text-xs);
  color: var(--steel);
}

.coalition-scenario-card__members {
  font-size: var(--text-xs);
  color: var(--steel);
  padding-top: var(--space-2);
  border-top: 1px solid var(--border);
}

.coalition-scenario-card__defor {
  font-size: var(--text-xs);
  color: var(--steel);
}

.coalition-scenario-card__defor strong { color: var(--white); }

.coalition-scenario-card__cpp {
  font-size: var(--text-xs);
  color: var(--steel);
}

.coalition-scenario-card__cpp strong { color: var(--white); }

.coalition-scenario-card__level { margin-top: auto; padding-top: var(--space-3); }

/* ---- COALITION: SIMULATOR LAYOUT ---- */
.simulator-layout {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--space-8);
  align-items: start;
}

.simulator-inputs,
.simulator-outputs {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-7);
}

.simulator-inputs__title,
.simulator-outputs__title {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--steel);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border-accent);
}

/* Slider fields */
.sim-field {
  margin-bottom: var(--space-6);
}

.sim-field__label {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-3);
}

.sim-field__unit {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--blue-accent);
  font-weight: 700;
}

.sim-slider {
  width: 100%;
  height: 4px;
  -webkit-appearance: none;
  appearance: none;
  background: var(--border-accent);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
}

.sim-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--blue-accent);
  border: 2px solid var(--navy-mid);
  cursor: pointer;
}

.sim-slider::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--blue-accent);
  border: 2px solid var(--navy-mid);
  cursor: pointer;
}

.sim-slider__marks {
  display: flex;
  justify-content: space-between;
  margin-top: var(--space-2);
  font-size: 10px;
  color: var(--steel);
  font-family: var(--font-mono);
}

.sim-select {
  width: 100%;
  background: var(--navy);
  border: 1px solid var(--border-active);
  border-radius: 4px;
  color: var(--white);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  cursor: pointer;
  outline: none;
}

.sim-select:focus { border-color: var(--blue-accent); }

.sim-field__note {
  font-size: 11px;
  color: var(--steel);
  margin-top: var(--space-2);
  line-height: 1.6;
  font-style: italic;
}

/* Outputs */
.sim-output-scenario {
  background: var(--navy);
  border: 1px solid var(--border-accent);
  border-radius: 4px;
  padding: var(--space-4);
  margin-bottom: var(--space-5);
}

.sim-output-scenario__badge {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--blue-accent);
  margin-bottom: var(--space-1);
}

.sim-output-scenario__gdp {
  font-size: var(--text-sm);
  color: var(--white);
  margin-bottom: var(--space-2);
}

.sim-output-scenario__desc {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.6;
}

.sim-results-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.sim-result-card {
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: var(--space-4);
  background: var(--navy);
}

.sim-result-card--highlight {
  border-color: var(--border-active);
  background: rgba(30,111,255,0.05);
}

.sim-result-card__label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--steel);
  margin-bottom: var(--space-2);
}

.sim-result-card__value {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--white);
  margin-bottom: var(--space-2);
  line-height: 1.2;
}

.sim-result-card__desc {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.6;
}

.sim-recommendation {
  background: var(--navy);
  border: 1px solid var(--border-active);
  border-radius: 4px;
  padding: var(--space-5);
}

.sim-recommendation__label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--steel);
  margin-bottom: var(--space-3);
}

.sim-recommendation__text {
  font-size: var(--text-sm);
  color: var(--white);
  line-height: 1.7;
}

/* ---- ABOUT: STRUCTURAL REASON CARDS ---- */
.about-reasons-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.about-reason {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
}

.about-reason__num {
  font-size: var(--text-3xl);
  font-weight: 700;
  color: var(--border-active);
  line-height: 1;
  margin-bottom: var(--space-3);
}

.about-reason__title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-3);
}

.about-reason__desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.65;
}

/* ---- ABOUT: THREAT VECTORS ---- */
.threat-vectors-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.threat-vector {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
}

.threat-vector__category {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--blue-accent);
  margin-bottom: var(--space-2);
}

.threat-vector__title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-3);
}

.threat-vector__desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.65;
  margin-bottom: var(--space-4);
}

.threat-vector__data {
  font-size: var(--text-xs);
  color: var(--white);
  background: rgba(30,111,255,0.1);
  border: 1px solid rgba(30,111,255,0.2);
  border-radius: 3px;
  padding: 3px 8px;
  display: inline-block;
}

/* ---- ABOUT: CGCI DEFINITION ---- */
.about-cgci-def {
  background: var(--navy-mid);
  border: 1px solid var(--border-active);
  border-radius: 6px;
  padding: var(--space-6);
}

.about-cgci-def__criteria-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-4);
}

.about-cgci-def__criteria {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.about-cgci-def__criterion {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.6;
}

.about-cgci-def__criterion::before {
  content: '◆';
  color: var(--blue-accent);
  font-size: 8px;
  flex-shrink: 0;
  margin-top: 5px;
}

/* ---- ABOUT: PRINCIPLE ---- */
.about-quote {
  border-left: 3px solid var(--blue-accent);
  padding-left: var(--space-6);
  margin: 0 0 var(--space-2);
  font-size: var(--text-lg);
  color: var(--white);
  line-height: 1.7;
  font-style: normal;
}

.about-quote__source {
  font-size: var(--text-xs);
  color: var(--steel);
  padding-left: var(--space-6);
  margin-bottom: var(--space-10);
}

.about-principle__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}

.about-principle__item {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
}

.about-principle__item-label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-3);
}

.about-principle__item-desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.7;
}

/* ---- SINGAPORE: MANDATE GRID ---- */
.sgp-mandate-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}

.sgp-mandate-card {
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-6);
  background: var(--navy-mid);
}

.sgp-mandate-card--does    { border-color: rgba(29,185,84,0.3); background: rgba(29,185,84,0.04); }
.sgp-mandate-card--doesnot { border-color: rgba(239,68,68,0.2); background: rgba(239,68,68,0.03); }

.sgp-mandate-card__header { margin-bottom: var(--space-5); }

.sgp-mandate-card__items { display: flex; flex-direction: column; gap: var(--space-3); }

.sgp-mandate-card__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.5;
}

.sgp-mandate-card__check { color: var(--status-green); font-weight: 700; flex-shrink: 0; }
.sgp-mandate-card__cross { color: var(--status-red);   font-weight: 700; flex-shrink: 0; }

/* ---- SINGAPORE: QUALS ---- */
.sgp-quals-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}

.sgp-qual { background: var(--navy-mid); border: 1px solid var(--border-accent); border-radius: 6px; padding: var(--space-5); }

.sgp-qual__category {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--blue-accent);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border-accent);
}

.sgp-qual__points { display: flex; flex-direction: column; gap: var(--space-3); }

.sgp-qual__point {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.6;
  padding-left: var(--space-4);
  position: relative;
}

.sgp-qual__point::before {
  content: '–';
  position: absolute;
  left: 0;
  color: var(--border-active);
}

/* ---- SINGAPORE: PILOT PHASES ---- */
.pilot-phases { display: flex; flex-direction: column; gap: var(--space-5); }

.pilot-phase {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-6);
}

.pilot-phase__header {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border-accent);
  flex-wrap: wrap;
}

.pilot-phase__num {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--blue-accent);
}

.pilot-phase__title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--white);
  flex: 1;
}

.pilot-phase__timeline {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--steel);
  background: var(--navy);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 2px 8px;
}

.pilot-phase__cost {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--white);
}

.pilot-phase__objective {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-4);
}

.pilot-phase__actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.pilot-phase__action {
  font-size: var(--text-sm);
  color: var(--steel);
  padding-left: var(--space-5);
  position: relative;
  line-height: 1.6;
}

.pilot-phase__action::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--blue-accent);
}

.pilot-phase__infra {
  font-size: var(--text-xs);
  color: var(--steel);
  font-style: italic;
  padding: var(--space-3);
  background: var(--navy);
  border-radius: 3px;
  margin-bottom: var(--space-3);
  line-height: 1.6;
}

.pilot-phase__output {
  font-size: var(--text-sm);
  color: var(--white);
  font-weight: 500;
}

.pilot-phase__output-label {
  font-weight: 700;
  color: var(--blue-accent);
  margin-right: var(--space-2);
}

.pilot-phase__tlc { margin-top: var(--space-3); }

/* ---- SINGAPORE: SCALING TIMELINE ---- */
.scaling-timeline {
  display: flex;
  align-items: stretch;
  gap: 0;
  overflow-x: auto;
  padding-bottom: var(--space-4);
}

.scaling-step {
  flex: 1;
  min-width: 160px;
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.scaling-arrow {
  display: flex;
  align-items: center;
  padding: 0 var(--space-3);
  color: var(--border-active);
  font-size: var(--text-xl);
  flex-shrink: 0;
}

.scaling-step__year {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--blue-accent);
  font-weight: 700;
}

.scaling-step__label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
}

.scaling-step__desc {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.6;
  flex: 1;
}

.scaling-step__coverage {
  font-size: var(--text-xs);
  color: var(--white);
  background: rgba(30,111,255,0.1);
  border: 1px solid rgba(30,111,255,0.2);
  border-radius: 3px;
  padding: 2px 8px;
  align-self: flex-start;
  margin-top: auto;
}

/* ---- SINGAPORE: BENEFITS GRID ---- */
.sgp-benefits-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

.sgp-benefit {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
}

.sgp-benefit__title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-3);
}

.sgp-benefit__desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.65;
}

/* ---- API DOCS LAYOUT ---- */
.api-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-10);
  align-items: start;
}

.api-sidebar {
  position: sticky;
  top: calc(var(--nav-height) + var(--space-6));
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.api-sidebar__section {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--steel);
  padding: var(--space-4) 0 var(--space-2);
  margin-top: var(--space-2);
  border-top: 1px solid var(--border);
}

.api-sidebar__section:first-child { border-top: none; margin-top: 0; }

.api-sidebar__link {
  font-size: var(--text-xs);
  color: var(--steel);
  text-decoration: none;
  padding: var(--space-1) var(--space-2);
  border-radius: 3px;
  transition: color var(--transition), background var(--transition);
}

.api-sidebar__link:hover {
  color: var(--white);
  background: var(--navy-mid);
}

.api-content { min-width: 0; }

.api-section {
  padding-bottom: var(--space-12);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--space-12);
}

.api-section:last-child { border-bottom: none; margin-bottom: 0; }

.api-section__title {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.api-section__desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.7;
  margin-bottom: var(--space-6);
}

.api-method {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 3px;
  letter-spacing: 0.05em;
}

.api-method--get {
  background: rgba(29,185,84,0.15);
  color: var(--status-green);
  border: 1px solid rgba(29,185,84,0.3);
}

.api-example {
  margin-bottom: var(--space-5);
}

.api-example__label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--steel);
  margin-bottom: var(--space-2);
}

.api-code {
  background: #060E14;
  border: 1px solid var(--border-accent);
  border-radius: 4px;
  padding: var(--space-5);
  font-family: var(--font-mono);
  font-size: 12px;
  color: #A8C8E0;
  line-height: 1.65;
  overflow-x: auto;
  white-space: pre;
  margin: 0;
}

.api-note {
  background: rgba(30,111,255,0.06);
  border: 1px solid rgba(30,111,255,0.2);
  border-radius: 4px;
  padding: var(--space-4);
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.7;
  margin-top: var(--space-4);
}

.api-params { margin-bottom: var(--space-5); }

.api-params__title,
.api-fields__title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-3);
}

.api-fields { margin-top: var(--space-5); }

.inline-code {
  font-family: var(--font-mono);
  font-size: 11px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 1px 5px;
  color: var(--white);
}

/* ---- CONTACT FORM ---- */
.contact-layout {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: var(--space-10);
  align-items: start;
}

.contact-info { display: flex; flex-direction: column; gap: var(--space-6); }

.contact-info__block {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-5);
}

.contact-info__block-title {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--steel);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border-accent);
}

.contact-info__item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: var(--space-3);
}

.contact-info__item:last-child { margin-bottom: 0; }

.contact-info__label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--steel);
}

.contact-info__value {
  font-size: var(--text-sm);
  color: var(--white);
  text-decoration: none;
}

a.contact-info__value:hover { text-decoration: underline; }

.contact-info__subjects { display: flex; flex-direction: column; gap: var(--space-3); }

.contact-subject__name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-1);
}

.contact-subject__desc {
  font-size: var(--text-xs);
  color: var(--steel);
  line-height: 1.6;
}

/* Form elements */
.contact-form-wrapper {
  background: var(--navy-mid);
  border: 1px solid var(--border-accent);
  border-radius: 6px;
  padding: var(--space-7);
}

.contact-form__row { margin-bottom: var(--space-5); }

.contact-form__row--2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}

.contact-form__field { display: flex; flex-direction: column; gap: var(--space-2); }

.contact-form__label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--white);
}

.contact-form__req { color: var(--blue-accent); }

.contact-form__input,
.contact-form__select,
.contact-form__textarea {
  background: var(--navy);
  border: 1px solid var(--border-active);
  border-radius: 4px;
  color: var(--white);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  padding: var(--space-3) var(--space-4);
  outline: none;
  transition: border-color var(--transition);
  width: 100%;
}

.contact-form__textarea { resize: vertical; line-height: 1.6; }

.contact-form__input:focus,
.contact-form__select:focus,
.contact-form__textarea:focus { border-color: var(--blue-accent); }

.contact-form__field-note {
  font-size: 11px;
  color: var(--steel);
  line-height: 1.6;
  font-style: italic;
}

.contact-form__footer {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid var(--border-accent);
}

.contact-form__disclaimer {
  font-size: 11px;
  color: var(--steel);
  line-height: 1.6;
  flex: 1;
}

.contact-form__submit {
  flex-shrink: 0;
  padding: var(--space-3) var(--space-7);
  background: var(--blue-accent);
  color: var(--white);
  border: none;
  border-radius: 4px;
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-body);
  transition: opacity var(--transition);
}

.contact-form__submit:hover { opacity: 0.85; }

.contact-form-error {
  background: rgba(239,68,68,0.1);
  border: 1px solid rgba(239,68,68,0.3);
  border-radius: 4px;
  padding: var(--space-4);
  font-size: var(--text-sm);
  color: var(--status-red);
  margin-bottom: var(--space-5);
}

.contact-form-success {
  text-align: center;
  padding: var(--space-12) var(--space-6);
}

.contact-form-success__icon {
  font-size: 3rem;
  color: var(--status-green);
  margin-bottom: var(--space-5);
}

.contact-form-success__title {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--white);
  margin-bottom: var(--space-3);
}

.contact-form-success__ref {
  font-size: var(--text-sm);
  color: var(--blue-accent);
  margin-bottom: var(--space-4);
}

.contact-form-success__desc {
  font-size: var(--text-sm);
  color: var(--steel);
  line-height: 1.7;
}

/* ---- RESPONSIVE — ALL REMAINING ---- */
@media (max-width: 1200px) {
  .coalition-scenarios-grid  { grid-template-columns: repeat(3, 1fr); }
  .sgp-quals-grid            { grid-template-columns: 1fr 1fr; }
  .api-layout                { grid-template-columns: 180px 1fr; }
}

@media (max-width: 960px) {
  .simulator-layout          { grid-template-columns: 1fr; }
  .about-reasons-grid        { grid-template-columns: 1fr 1fr; }
  .threat-vectors-grid       { grid-template-columns: 1fr 1fr; }
  .about-principle__grid     { grid-template-columns: 1fr; }
  .sgp-mandate-grid          { grid-template-columns: 1fr; }
  .contact-layout            { grid-template-columns: 1fr; }
  .api-layout                { grid-template-columns: 1fr; }
  .api-sidebar               { display: none; }
}

@media (max-width: 768px) {
  .coalition-scenarios-grid  { grid-template-columns: 1fr 1fr; }
  .about-reasons-grid        { grid-template-columns: 1fr; }
  .threat-vectors-grid       { grid-template-columns: 1fr; }
  .sgp-quals-grid            { grid-template-columns: 1fr; }
  .sgp-benefits-grid         { grid-template-columns: 1fr; }
  .sim-results-grid          { grid-template-columns: 1fr; }
  .contact-form__row--2col   { grid-template-columns: 1fr; }
  .contact-form__footer      { flex-direction: column; }
  .scaling-timeline          { flex-direction: column; }
  .scaling-arrow             { transform: rotate(90deg); align-self: center; }
  .t-orange                  { color: var(--status-orange); }
}