.reports-page {
  background: #f7f9fc;
  color: #243247;
}

.reports-page .header {
  position: relative;
  background: #081828;
}

.reports-page .header .navbar {
  padding: 16px 0;
}

.reports-page .header .navbar-nav .nav-item a {
  color: #d2d6dc;
}

.reports-page .header .navbar-nav .nav-item a:hover {
  color: #bfdbff;
}

.report-hero {
  background: #081828;
  border-top: 1px solid rgba(191, 219, 255, 0.2);
  color: #fff;
  padding: 88px 0 92px;
}

.report-kicker,
.section-label {
  color: #da4f91;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 12px;
  text-transform: uppercase;
}

.report-hero h1 {
  color: #fff;
  font-size: 52px;
  line-height: 1.12;
  margin-bottom: 22px;
  max-width: 780px;
}

.report-lead {
  color: #d2d6dc;
  font-size: 20px;
  line-height: 1.65;
  max-width: 800px;
}

.report-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 28px;
  margin-top: 34px;
}

.report-meta span {
  color: #bfdbff;
  font-size: 14px;
  font-weight: 600;
}

.report-meta i {
  margin-right: 7px;
}

.report-subnav {
  background: #fff;
  border-bottom: 1px solid #dfe5ec;
  position: sticky;
  top: 0;
  z-index: 20;
}

.report-subnav .container {
  display: flex;
  gap: 32px;
  overflow-x: auto;
  scrollbar-width: none;
}

.report-subnav .container::-webkit-scrollbar { display: none; }

.report-subnav a {
  color: #506176;
  flex: 0 0 auto;
  font-size: 13px;
  font-weight: 700;
  padding: 18px 0 15px;
  position: relative;
  text-transform: uppercase;
}

.report-subnav a:hover { color: #da4f91; }

.report-subnav a::after {
  background: #da4f91;
  bottom: 0;
  content: "";
  height: 3px;
  left: 0;
  position: absolute;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.2s ease;
  width: 100%;
}

.report-subnav a:hover::after { transform: scaleX(1); }

.report-section {
  padding: 92px 0;
}

.report-section h2 {
  color: #10233c;
  font-size: 36px;
  line-height: 1.25;
  margin-bottom: 22px;
}

.report-section h3 {
  color: #10233c;
  font-size: 21px;
  margin: 28px 0 16px;
}

.report-section p,
.report-list li {
  color: #506176;
  font-size: 16px;
  line-height: 1.75;
}

.section-heading {
  max-width: 820px;
  margin-bottom: 44px;
}

.report-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.report-list li {
  margin-bottom: 12px;
  padding-left: 26px;
  position: relative;
}

.report-list li::before {
  background: #36a887;
  content: "";
  height: 8px;
  left: 0;
  position: absolute;
  top: 10px;
  width: 8px;
}

.operation-section,
.research-section,
.disclosure-section {
  background: #fff;
}

.readiness-section {
  background: #10233c;
}

.readiness-section h2,
.readiness-section .trl-step h3 { color: #fff; }

.readiness-section .section-heading p,
.readiness-section .trl-step p { color: #c9d2dc; }

.trl-path {
  align-items: stretch;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 48px minmax(0, 1fr) 48px minmax(0, 1fr);
}

.trl-step {
  border: 1px solid rgba(255, 255, 255, 0.18);
  min-height: 230px;
  padding: 28px;
}

.trl-step h3 { margin: 24px 0 10px; }
.trl-step p { font-size: 14px; line-height: 1.65; margin: 0; }

.trl-number {
  color: #fff;
  display: inline-block;
  font-size: 18px;
  font-weight: 700;
  padding: 9px 12px;
}

.trl-complete .trl-number { background: #5f8fd8; }
.trl-current { background: #142b49; border-color: #36a887; }
.trl-current .trl-number { background: #36a887; }
.trl-next .trl-number { background: #66758a; }

.trl-connector {
  align-items: center;
  color: #36a887;
  display: flex;
  font-size: 22px;
  justify-content: center;
}

.trl-muted { color: #66758a; }

.evidence-caveat {
  color: #bfdbff !important;
  font-size: 13px !important;
  margin-top: 24px;
}

.evidence-caveat i { margin-right: 8px; }

.funding-panel,
.method-panel {
  background: #eef5ff;
  border-left: 4px solid #5f8fd8;
  padding: 30px;
}

.funding-panel img {
  background: #081828;
  display: block;
  height: auto;
  margin-bottom: 24px;
  max-width: 100%;
  padding: 18px;
  width: 320px;
}

.funding-panel h2 {
  font-size: 24px;
  margin-bottom: 14px;
}

.funding-panel a,
.doi-link {
  color: #1d5cab;
  display: block;
  font-size: 15px;
  font-weight: 700;
  margin-top: 16px;
}

.funding-panel a:hover,
.doi-link:hover {
  color: #da4f91;
}

.indicator-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 58px;
}

.indicator {
  background: #fff;
  border-top: 5px solid #506176;
  box-shadow: 0 12px 30px rgba(16, 35, 60, 0.08);
  min-height: 220px;
  padding: 26px 24px;
}

.indicator strong,
.indicator span {
  display: block;
}

.indicator strong {
  color: #10233c;
  font-size: 32px;
  line-height: 1.2;
}

.indicator span {
  color: #6a788b;
  font-size: 13px;
  font-weight: 700;
  margin: 6px 0 18px;
  text-transform: uppercase;
}

.indicator p {
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
}

.indicator-pink { border-color: #da4f91; }
.indicator-green { border-color: #36a887; }
.indicator-blue { border-color: #5f8fd8; }
.indicator-neutral { border-color: #7d8795; }

.chart-layout {
  align-items: stretch;
  display: grid;
  gap: 42px;
  grid-template-columns: minmax(0, 1.45fr) minmax(300px, 0.75fr);
}

.chart-layout h3 {
  margin-top: 0;
}

.chart-surface {
  background: #fff;
  box-shadow: 0 12px 30px rgba(16, 35, 60, 0.06);
  padding: 26px;
}

.chart-header {
  align-items: flex-start;
  display: flex;
  gap: 24px;
  justify-content: space-between;
}

.evidence-context {
  align-items: start;
  display: grid;
  gap: 42px;
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, 0.75fr);
}

.evidence-context h3 { margin-top: 0; }

.evidence-context strong { color: #10233c; }

.evidence-context dl {
  border-top: 0;
  margin-top: 0;
  padding-top: 0;
}

.chart-note {
  font-size: 13px !important;
  margin-bottom: 8px;
}

.plotly-chart {
  min-height: 390px;
  width: 100%;
}

.method-panel {
  background: #fff;
  border-color: #da4f91;
}

.method-panel p {
  font-size: 14px;
  line-height: 1.65;
}

.method-panel dl {
  border-top: 1px solid #dbe2ea;
  display: grid;
  font-size: 14px;
  grid-template-columns: 1fr 1fr;
  margin-top: 24px;
  padding-top: 18px;
}

.method-panel dt,
.method-panel dd {
  border-bottom: 1px solid #e8edf2;
  margin: 0;
  padding: 10px 0;
}

.method-panel dd {
  color: #10233c;
  font-weight: 700;
  text-align: right;
}

.accessible-data {
  margin-top: 42px;
}

.accessible-data caption {
  color: #66758a;
  font-size: 13px;
}

.accessible-data th {
  background: #10233c;
  color: #fff;
}

.accessible-data td,
.accessible-data th {
  border-color: #dfe5ec;
  padding: 14px 16px;
  vertical-align: middle;
}

.chtmad-section {
  background: #edf7f4;
}

.timeline-layout {
  grid-template-columns: minmax(0, 1.6fr) minmax(280px, 0.65fr);
}

.publication-panel {
  border-color: #36a887;
}

.publication-summary {
  max-width: 900px;
}

.publication-year {
  color: #36a887 !important;
  font-size: 13px !important;
  font-weight: 700;
  text-transform: uppercase;
}

.publication-panel h3 {
  font-size: 20px;
  line-height: 1.45;
}

.compact-list li {
  font-size: 14px;
  line-height: 1.55;
}

.support-section {
  background: #10233c;
}

.support-section h2,
.support-section .support-grid h3 {
  color: #fff;
}

.support-section .section-heading p,
.support-grid p {
  color: #c9d2dc;
}

.support-grid {
  display: grid;
  gap: 1px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  background: rgba(255, 255, 255, 0.15);
}

.support-grid article {
  background: #10233c;
  min-height: 190px;
  padding: 28px;
}

.support-grid article:nth-child(2),
.support-grid article:nth-child(5) {
  background: #142b49;
}

.support-grid h3 {
  font-size: 21px;
  margin: 0 0 12px;
}

.support-grid h3 a {
  color: #fff;
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.support-grid h3 a i {
  color: #bfdbff;
  font-size: 13px;
}

.support-grid h3 a:hover,
.support-grid h3 a:focus {
  color: #bfdbff;
}

.support-grid p {
  font-size: 14px;
  line-height: 1.65;
  margin: 0;
}

.disclosure-inner {
  align-items: start;
  display: grid;
  gap: 60px;
  grid-template-columns: minmax(260px, 0.7fr) minmax(0, 1.3fr);
}

.disclosure-inner h2 {
  margin-bottom: 0;
}

.report-footer {
  background: #081828;
  padding: 40px 0;
}

.report-footer .container {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.report-footer img {
  width: 180px;
}

.report-footer div {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 26px;
  justify-content: flex-end;
}

.report-footer a {
  color: #d2d6dc;
  font-size: 14px;
}

.report-footer a:hover {
  color: #bfdbff;
}

@media (max-width: 991px) {
  .report-hero h1 { font-size: 44px; }
  .indicator-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .chart-layout, .timeline-layout { grid-template-columns: 1fr; }
  .support-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .trl-path { grid-template-columns: 1fr; }
  .trl-connector { min-height: 42px; transform: rotate(90deg); }
  .evidence-context { grid-template-columns: 1fr; }
}

@media (max-width: 767px) {
  .report-hero { padding: 64px 0 68px; }
  .report-hero h1 { font-size: 36px; }
  .report-lead { font-size: 17px; }
  .report-section { padding: 68px 0; }
  .report-section h2 { font-size: 30px; }
  .indicator-grid, .support-grid, .disclosure-inner { grid-template-columns: 1fr; }
  .indicator { min-height: 0; }
  .plotly-chart { min-height: 360px; }
  .report-subnav .container { gap: 24px; }
  .chart-header { display: block; }
  .chart-surface { padding: 20px 14px; }
  .report-footer .container { align-items: flex-start; flex-direction: column; gap: 30px; }
  .report-footer div { justify-content: flex-start; }
}

@media print {
  .reports-page .header, .scroll-top, .modebar-container { display: none !important; }
  .report-hero { padding: 40px 0; }
  .report-section { break-inside: avoid; padding: 44px 0; }
  .support-section { background: #fff; }
  .support-section h2, .support-section .support-grid h3, .support-grid h3 a { color: #10233c; }
  .support-section .section-heading p, .support-grid p { color: #506176; }
  .support-grid, .support-grid article, .support-grid article:nth-child(2), .support-grid article:nth-child(5) { background: #fff; }
}
