/* ── Reset & base ──────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:         #f4fbff;
  --surface:    #ffffff;
  --surface-alt:#e9f6ff;
  --table-head: #e4f1f8;
  --table-row:  #f2f8fb;
  --border:     #7ea9c4;
  --text:       #16364e;
  --text-muted: #5c7b93;
  --font: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  --mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;

  /* Pipeline stage colours */
  --c-published:    #1f7a36;
  --c-qc-pass:      #1f7a36;
  --c-ready-for-nci:#b68500;
  --c-qc-checks:    #005ea8;
  --c-cmorised:     #c77700;
  --c-failed:       #b42318;
  --c-not-started:  #4b5563;
  --c-planned:      #7c8b96;

  --bg-published:    #2f9e44;
  --bg-qc-pass:      #2f9e44;
  --bg-ready-for-nci:#fff2c2;
  --bg-qc-checks:    #dff0fb;
  --bg-cmorised:     #fff0d6;
  --bg-failed:       #d92d20;
  --bg-not-started:  #cfd4da;
  --bg-planned:      #e5e7eb;
}

html { font-size: 14px; }
body {
  background:
    radial-gradient(circle at top right, rgba(39, 167, 232, 0.14), transparent 28%),
    radial-gradient(circle at top left, rgba(166, 206, 57, 0.14), transparent 24%),
    linear-gradient(180deg, #fbfeff 0%, var(--bg) 100%);
  color: var(--text);
  font-family: var(--font);
  line-height: 1.5;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
a { color: #005ea8; text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── Header ─────────────────────────────────────────────────────────────── */
header {
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(12px);
  position: sticky; top: 0; z-index: 100;
}
.header-inner {
  max-width: 1500px; margin: 0 auto;
  padding: 0.65rem 1.5rem;
  display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; justify-content: space-between;
}
.brand {
  display: flex;
  align-items: center;
  gap: 1rem;
  color: inherit;
  text-decoration: none;
}
.brand:hover { text-decoration: none; }
.brand-logo {
  height: 52px;
  width: auto;
  display: block;
}
.header-title { display: flex; flex-direction: column; }
.brand-kicker {
  color: #27a7e8;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
header h1 { font-size: 0.98rem; font-weight: 700; white-space: nowrap; }
.header-sub { font-size: 0.72rem; color: var(--text-muted); }
nav { display: flex; gap: 0.4rem; flex-wrap: wrap; }
.nav-btn {
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text-muted);
  border-radius: 999px; padding: 0.3rem 0.85rem;
  cursor: pointer; font-size: 0.82rem;
  transition: border-color 0.15s, color 0.15s, background 0.15s, transform 0.15s;
}
.nav-btn:hover { border-color: #27a7e8; color: var(--text); background: var(--surface-alt); transform: translateY(-1px); }
.nav-btn.active { border-color: #005ea8; color: var(--text); background: linear-gradient(135deg, rgba(39, 167, 232, 0.12), rgba(166, 206, 57, 0.14)); }
.qc-link {
  margin-left: auto; font-size: 0.8rem; white-space: nowrap;
  border: 1px solid var(--border); border-radius: 999px;
  padding: 0.3rem 0.7rem; color: var(--text-muted);
  background: var(--surface);
}
.qc-link:hover { border-color: #27a7e8; color: var(--text); background: var(--surface-alt); text-decoration: none; }

/* ── Main / Footer ──────────────────────────────────────────────────────── */
main { flex: 1; max-width: 1500px; width: 100%; margin: 0 auto; padding: 1.5rem; }
.intro-panel {
  margin-bottom: 1.25rem;
  padding: 0.9rem 1rem;
  border: 1px solid var(--border);
  border-radius: 16px;
  background:
    linear-gradient(135deg, rgba(39, 167, 232, 0.16), rgba(166, 206, 57, 0.12)),
    var(--surface);
  box-shadow: 0 10px 24px rgba(0, 94, 168, 0.06);
}
.intro-panel p {
  max-width: 78rem;
  color: var(--text);
  font-size: 0.9rem;
  line-height: 1.6;
}
.intro-actions {
  margin-top: 0.9rem;
}
footer {
  border-top: 1px solid var(--border);
  text-align: center; padding: 0.65rem;
  font-size: 0.78rem; color: var(--text-muted);
}
#loading { color: var(--text-muted); padding: 2rem 0; }

/* ── Controls ────────────────────────────────────────────────────────────── */
.controls {
  display: flex; gap: 1rem; align-items: center;
  flex-wrap: wrap; margin-bottom: 1.25rem;
}
.controls label { font-size: 0.82rem; color: var(--text-muted); }
.controls select, .controls input {
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text); border-radius: 10px;
  padding: 0.3rem 0.6rem; font-size: 0.82rem;
}

/* ── Section headings ────────────────────────────────────────────────────── */
.view-title { font-size: 1.1rem; font-weight: 600; margin-bottom: 0.5rem; padding-bottom: 0.5rem; border-bottom: 1px solid var(--border); }
.view-sub { color: var(--text-muted); font-size: 0.82rem; margin-bottom: 1.25rem; }

/* ── Pipeline stage chip ─────────────────────────────────────────────────── */
.stage {
  display: inline-block; border-radius: 4px;
  padding: 0.1rem 0.5rem; font-size: 0.72rem;
  font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em;
}
.stage-published    { background: var(--bg-published);    color: #ffffff;  border: 1px solid var(--c-published); }
.stage-qc_pass      { background: var(--bg-qc-pass);      color: #ffffff;  border: 1px solid var(--c-qc-pass); }
.stage-ready_for_nci{ background: var(--bg-ready-for-nci);color: #7a5600;  border: 1px solid var(--c-ready-for-nci); }
.stage-qc_checks    { background: var(--bg-qc-checks);    color: #0d5b90;  border: 1px solid var(--c-qc-checks); }
.stage-cmorised     { background: var(--bg-cmorised);     color: #8a5600;  border: 1px solid var(--c-cmorised); }
.stage-failed       { background: var(--bg-failed);       color: #ffffff;  border: 1px solid var(--c-failed); }
.stage-not_started  { background: var(--bg-not-started);  color: #111827; border: 1px solid var(--border); }
.stage-planned      { background: var(--bg-planned);      color: #475569; border: 1px dashed var(--border); }

/* ── Matrix cell colours (compact) ──────────────────────────────────────── */
.cell-published    { background: var(--bg-published);    color: #ffffff; }
.cell-ready_for_nci{ background: var(--bg-ready-for-nci);color: #7a5600; }
.cell-qc_checks    { background: var(--bg-qc-checks);    color: #0d5b90; }
.cell-cmorised     { background: var(--bg-cmorised);     color: #8a5600; }
.cell-planned      { background: var(--bg-planned);      color: #475569; }

/* ── Progress bar ────────────────────────────────────────────────────────── */
.progress-wrap { background: var(--bg); border-radius: 4px; height: 8px; overflow: hidden; min-width: 80px; display: flex; }
.progress-segment { height: 100%; transition: width 0.3s; }
.seg-published  { background: var(--c-published); }
.seg-ready-for-nci { background: var(--c-ready-for-nci); }
.seg-qc-checks  { background: var(--c-qc-checks); }
.seg-cmorised   { background: var(--c-cmorised); }
.seg-planned    { background: var(--c-planned); }

/* ── Overview cards ──────────────────────────────────────────────────────── */
.overview-section {
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}
.overview-section:first-of-type {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}
.overview-section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 1rem;
  margin-bottom: 0.85rem;
}
.overview-section-head h3 {
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.overview-section-head p {
  color: var(--text-muted);
  font-size: 0.76rem;
  text-align: right;
}
.overview-section-deck .overview-section-head h3 { color: #005ea8; }
.overview-section-fast-track .overview-section-head h3 { color: #9b6700; }
.overview-section-dummy .overview-section-head h3 { color: #c86711; }
.overview-section-dummy {
  border-top-color: rgba(200, 103, 17, 0.28);
}
.overview-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px,1fr)); gap: 1rem; }
.exp-card {
  background: #ffffff;
  border: 1px solid #7f9fb5;
  border-radius: 12px;
  padding: 1rem;
  position: relative;
  box-shadow: 0 12px 24px rgba(23, 63, 95, 0.07);
}
.exp-card-deck {
  background: #ffffff;
  border-color: #8eb7d1;
  border-top: 4px solid #5b9ac6;
  box-shadow:
    inset 0 0 0 1px #eef6fb,
    0 12px 28px rgba(23, 63, 95, 0.08);
}
.exp-card-fast-track {
  background: #ffffff;
  border-color: #d8bc72;
  border-top: 4px solid #cc9b37;
  box-shadow:
    inset 0 0 0 1px #fbf3dc,
    0 12px 28px rgba(92, 76, 21, 0.08);
}
.exp-card-labels {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  display: flex;
  gap: 0.35rem;
}
.exp-card-label {
  display: inline-flex;
  align-items: center;
  padding: 0.12rem 0.45rem;
  border-radius: 999px;
  border: 1px solid #a5d6ff;
  background: linear-gradient(180deg, rgba(31, 111, 235, 0.95), rgba(12, 74, 173, 0.98));
  color: #f0f7ff;
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  box-shadow: 0 6px 16px rgba(5, 29, 58, 0.3);
}
.exp-card-fast-track .exp-card-label {
  border-color: rgba(255, 236, 179, 0.7);
  background: linear-gradient(180deg, rgba(181, 124, 0, 0.96), rgba(122, 82, 8, 0.98));
  color: #fff8df;
}
.exp-card-label-secondary {
  border-color: rgba(255, 166, 166, 0.5);
  background: linear-gradient(180deg, rgba(190, 41, 41, 0.96), rgba(122, 18, 18, 0.98));
  color: #fff1f1;
}
.exp-card-fast-track .exp-card-label-secondary {
  border-color: rgba(185, 223, 255, 0.65);
  background: linear-gradient(180deg, rgba(31, 111, 235, 0.95), rgba(12, 74, 173, 0.98));
  color: #f0f7ff;
}
.exp-card h3 {
  font-size: 0.96rem;
  font-weight: 700;
  margin-bottom: 0.35rem;
  padding-right: 5.8rem;
  color: #14364f;
}
.exp-card-meta {
  display: flex;
  gap: 0.4rem;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 0.45rem;
}
.exp-card-category,
.exp-card-priority {
  display: inline-flex;
  align-items: center;
  padding: 0.08rem 0.42rem;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 600;
}
.exp-card-category {
  background: #d7ecfb;
  border: 1px solid #8eb7d1;
  color: #0d446d;
}
.exp-card-priority {
  background: #eef3f7;
  border: 1px solid #aebfcb;
  color: #456176;
  text-transform: capitalize;
}
.exp-card .members-table { width: 100%; border-collapse: collapse; margin-top: 0.75rem; font-size: 0.8rem; }
.exp-card .members-table th {
  text-align: left;
  padding: 0.28rem 0.4rem;
  color: #47657b;
  font-weight: 700;
  border-bottom: 1px solid #9db8c9;
}
.exp-card .members-table td {
  padding: 0.34rem 0.4rem;
  vertical-align: middle;
  border-top: 1px solid #d9e6ee;
  background: #ffffff;
}
.exp-card .members-table tr:hover td { background: #dcecf6; }
.exp-card .members-table td:last-child {
  background: #fbfdff;
}
.exp-card-fast-track .members-table td:last-child,
.exp-card-deck .members-table td:last-child {
  background: #fbfdff;
}
.member-label { font-family: var(--mono); font-size: 0.78rem; cursor: pointer; color: #005ea8; }
.member-label:hover { text-decoration: underline; }
.variable-link { display: inline-block; cursor: pointer; color: #005ea8; }
.variable-link:hover { text-decoration: underline; }
.timeline-qc-cell {
  display: inline-block;
  cursor: pointer;
}
.timeline-qc-cell:hover .stage {
  box-shadow: inset 0 0 0 2px #c52a2a;
}
.variable-label {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.variable-label span {
  font-family: var(--font);
  font-size: 0.68rem;
  line-height: 1.3;
  color: var(--text-muted);
}
.variable-resource-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--border);
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(0, 94, 168, 0.12), rgba(233, 246, 255, 0.98)),
    var(--surface);
  box-shadow: 0 14px 32px rgba(23, 63, 95, 0.08);
}
.variable-resource-title {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #005ea8;
}
.variable-resource-copy {
  margin-top: 0.2rem;
  color: var(--text-muted);
  font-size: 0.8rem;
}
.variable-resource-context {
  margin-top: 0.45rem;
  color: #0d5b90;
  font-size: 0.74rem;
  font-weight: 600;
}
.variable-resource-actions {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.resource-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.38rem 0.7rem;
  border-radius: 7px;
  border: 1px solid #005ea8;
  background: #005ea8;
  color: #ffffff;
  font-size: 0.8rem;
  font-weight: 600;
  text-decoration: none;
}
.resource-btn:hover {
  border-color: #00457b;
  background: #00457b;
  text-decoration: none;
}
.resource-btn-secondary {
  border-color: #9cb2c2;
  background: #ffffff;
  color: #24455e;
}
.resource-btn-secondary:hover {
  border-color: #6c8ca1;
  background: #edf5fa;
}
.count-chips { display: flex; gap: 0.3rem; flex-wrap: wrap; }
.count-chips .chip {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  border-radius: 999px;
  padding: 0.12rem 0.5rem;
  font-size: 0.7rem;
  font-weight: 700;
  border: 1px solid transparent;
  letter-spacing: 0.01em;
  background-image: none !important;
  box-shadow: none !important;
  opacity: 1 !important;
  mix-blend-mode: normal;
}
.count-chips .chip-published { background-color: #d9f2df !important; color: #14532d !important; border-color: #74b585 !important; }
.count-chips .chip-ready-for-nci { background-color: #fff2c2 !important; color: #7a5600 !important; border-color: #d8bb63 !important; }
.count-chips .chip-qc-checks { background-color: #e3f1fb !important; color: #0d5b90 !important; border-color: #8cb8db !important; }
.count-chips .chip-cmorised { background-color: #fff0d6 !important; color: #8a5600 !important; border-color: #e1b56a !important; }
.count-chips .chip-planned { background-color: #eceff3 !important; color: #475569 !important; border-color: #b8c1cb !important; }

/* ── Request view ────────────────────────────────────────────────────────── */
.request-summary-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
  padding: 0.95rem 1rem;
  border: 1px solid var(--border);
  border-radius: 12px;
  background:
    linear-gradient(135deg, rgba(166, 206, 57, 0.16), rgba(39, 167, 232, 0.12)),
    var(--surface);
  box-shadow: 0 12px 28px rgba(23, 63, 95, 0.08);
}
.request-gap-panel {
  margin-bottom: 1rem;
  padding: 0.95rem 1rem;
  border: 1px solid #d8bb63;
  border-radius: 12px;
  background: linear-gradient(180deg, #fffdf3, #fff7dc);
}
.request-gap-panel h3 {
  font-size: 0.9rem;
  margin-bottom: 0.25rem;
}
.request-gap-panel p {
  color: var(--text-muted);
  font-size: 0.8rem;
  margin-bottom: 0.8rem;
}
.request-gap-list {
  display: grid;
  gap: 0.65rem;
}
.request-gap-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(184, 145, 25, 0.25);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.78);
}
.request-gap-item span {
  margin-left: 0.5rem;
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: 0.78rem;
}
.request-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: 1rem;
}
.request-card {
  padding: 1rem;
  border: 1px solid #8eb7d1;
  border-radius: 14px;
  background: #ffffff;
  box-shadow: 0 12px 30px rgba(23, 63, 95, 0.08);
}
.request-card-warning {
  border-color: #d8bb63;
  box-shadow: 0 12px 30px rgba(141, 104, 12, 0.1);
}
.request-card-head {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 0.8rem;
  margin-bottom: 0.8rem;
}
.request-card-kicker {
  color: #005ea8;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.request-card h3 {
  font-size: 1rem;
  color: #14364f;
}
.request-card h3 span {
  font-family: var(--mono);
  font-size: 0.82rem;
  color: var(--text-muted);
}
.request-card-statuses {
  display: flex;
  flex-wrap: wrap;
  justify-content: end;
  gap: 0.35rem;
}
.request-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 0.8rem;
  margin-bottom: 0.8rem;
  font-size: 0.78rem;
  color: var(--text-muted);
}
.request-paths {
  display: grid;
  gap: 0.45rem;
  margin-bottom: 0.8rem;
  padding: 0.7rem 0.8rem;
  border-radius: 10px;
  background: #edf5fa;
  border: 1px solid #d2e4ef;
  font-size: 0.78rem;
}
.request-paths code {
  font-family: var(--mono);
  font-size: 0.76rem;
  word-break: break-all;
}
.request-notes {
  margin-bottom: 0.8rem;
  color: var(--text);
  font-size: 0.8rem;
}
.request-progress {
  margin-bottom: 0.85rem;
}
.request-progress-title {
  margin-bottom: 0.35rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #47657b;
}
.request-progress-copy {
  margin-top: 0.45rem;
}
.request-progress-empty {
  color: var(--text-muted);
  font-size: 0.78rem;
}
.request-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

/* ── Matrix table ────────────────────────────────────────────────────────── */
.scroll { overflow-x: auto; }
table.matrix { border-collapse: collapse; min-width: 100%; font-size: 0.8rem; }
table.matrix th, table.matrix td { border: 1px solid var(--border); padding: 0.3rem 0.5rem; white-space: nowrap; }
table.matrix thead th { background: var(--table-head); position: sticky; top: 0; font-weight: 600; }
table.matrix tbody th { background: #edf5fa; position: sticky; left: 0; z-index: 1; font-family: var(--mono); font-weight: 500; text-align: left; font-size: 0.78rem; }
table.matrix td {
  text-align: center;
  cursor: pointer;
  transition: box-shadow 0.16s ease, background-color 0.16s ease;
}
table.matrix td:hover {
  position: relative;
  z-index: 2;
  box-shadow: inset 0 0 0 2px #c52a2a;
}

/* ── Detail table ────────────────────────────────────────────────────────── */
table.detail { width: 100%; border-collapse: collapse; font-size: 0.82rem; }
table.detail th, table.detail td { border: 1px solid var(--border); padding: 0.45rem 0.65rem; text-align: left; }
table.detail thead th { background: var(--table-head); font-weight: 600; }
table.detail tbody tr:nth-child(even) { background: #edf5fa; }
table.detail code { font-family: var(--mono); font-size: 0.78rem; background: #dceaf3; padding: 0.1rem 0.3rem; border-radius: 3px; }

/* ── Legend ──────────────────────────────────────────────────────────────── */
.legend { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1rem; font-size: 0.78rem; }
.legend-item { display: flex; align-items: center; gap: 0.35rem; }
.legend-swatch { width: 12px; height: 12px; border-radius: 2px; flex-shrink: 0; }

@media (max-width: 600px) {
  .header-inner { gap: 0.5rem; }
  .brand {
    gap: 0.55rem;
  }
  .brand-logo {
    height: 32px;
  }
  .qc-link { display: none; }
  main { padding: 0.75rem; }
  .intro-panel {
    padding: 0.8rem 0.85rem;
  }
  .overview-section-head {
    display: block;
  }
  .variable-resource-card {
    display: block;
  }
  .request-summary-card,
  .request-gap-item,
  .request-card-head {
    display: block;
  }
  .request-card-statuses,
  .request-actions,
  .variable-resource-actions {
    margin-top: 0.75rem;
  }
  .variable-resource-actions {
    margin-top: 0.75rem;
  }
  .overview-section-head p {
    margin-top: 0.25rem;
    text-align: left;
  }
}
