:root{
  --accent:#0050c8;
  --accent-dim:#003c96;
  --bg:#fff;
  --fg:#111;
  --card:#f6f7fb;
  --muted:rgba(0,0,0,.6);
  --ring:rgba(0,80,200,.25);
}
[data-theme="dark"]{
  --bg:#121212; --fg:#eee; --card:#1b1c22; --muted:rgba(255,255,255,.65); --ring:rgba(0,120,255,.25);
}

.reports-page{background:var(--bg);color:var(--fg);font-family:"Inter","Segoe UI",sans-serif}

/* hero */
.rep-hero{padding:4.5rem 1rem 2rem;text-align:center;background:linear-gradient(180deg, rgba(0,80,200,.08), transparent)}
[data-theme="dark"] .rep-hero{background:linear-gradient(180deg, rgba(0,80,200,.16), transparent)}
.rep-title{font-weight:800;font-size:clamp(2.2rem,4vw + .5rem,3.2rem);margin:0 0 .4rem}
.rep-tag{max-width:60ch;margin:0 auto}
.rep-picker{margin-top:1.25rem;display:flex;gap:.75rem;justify-content:center;align-items:center;flex-wrap:wrap}
.picker-btn{width:40px;height:40px;border-radius:10px;border:1px solid rgba(0,0,0,.12);background:var(--bg);color:var(--fg);cursor:pointer}
[data-theme="dark"] .picker-btn{border-color:rgba(255,255,255,.12)}
.picker-select select{padding:.75rem 1rem;border-radius:10px;border:1px solid rgba(0,0,0,.12);background:var(--bg);color:var(--fg);min-width:180px}
[data-theme="dark"] .picker-select select{border-color:rgba(255,255,255,.12)}

/* KPIs */
.rep-kpis{max-width:1100px;margin:1.5rem auto 0;display:grid;gap:.9rem;padding:0 1rem;grid-template-columns:repeat(4,minmax(0,1fr))}
@media(max-width:900px){.rep-kpis{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.rep-kpis{grid-template-columns:1fr}}
.kpi{background:var(--card);border-radius:14px;padding:1rem 1.1rem;border:1px solid rgba(0,0,0,.06)}
[data-theme="dark"] .kpi{border-color:rgba(255,255,255,.08)}
.kpi-label{font-size:.9rem;color:var(--muted)}
.kpi-value{font-size:1.6rem;font-weight:800;margin-top:.25rem}

/* CHARTS */
.rep-charts{max-width:1100px;margin:2rem auto 0;padding:0 1rem;display:grid;gap:1rem;grid-template-columns:repeat(2, minmax(0,1fr))}
@media(max-width:900px){.rep-charts{grid-template-columns:1fr}}
.chart-card{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:1rem 1.1rem}
[data-theme="dark"] .chart-card{border-color:rgba(255,255,255,.08)}
.chart-card header h3{margin:.2rem 0 .2rem}
.muted{color:var(--muted)}
.chart-wrap{display:flex;gap:1rem;align-items:center;justify-content:center;flex-wrap:wrap}
.legend{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}
.legend li{display:flex;align-items:center;gap:.5rem}
.legend .swatch{width:12px;height:12px;border-radius:3px;border:1px solid rgba(0,0,0,.12)}
[data-theme="dark"] .legend .swatch{border-color:rgba(255,255,255,.15)}

/* IMPACT */
.rep-impact{max-width:1100px;margin:2rem auto 0;padding:0 1rem;display:grid;gap:1rem;grid-template-columns:1.15fr .85fr;align-items:start}
@media(max-width:900px){.rep-impact{grid-template-columns:1fr}}
.impact-text{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:1rem 1.1rem}
[data-theme="dark"] .impact-text{border-color:rgba(255,255,255,.08)}
.impact-figure{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:.6rem}
[data-theme="dark"] .impact-figure{border-color:rgba(255,255,255,.08)}
.impact-figure img{width:100%;height:auto;border-radius:10px}

/* STORIES */
.rep-stories{max-width:1100px;margin:2rem auto 0;padding:0 1rem}
.section-head{margin-bottom:1rem;text-align:center}
.story-grid{display:grid;gap:1rem;grid-template-columns:repeat(3, minmax(0,1fr))}
@media(max-width:900px){.story-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.story-grid{grid-template-columns:1fr}}
.story{background:var(--card);border:1px solid rgba(0,0,0,.06);border-radius:14px;overflow:hidden;display:flex;flex-direction:column}
[data-theme="dark"] .story{border-color:rgba(255,255,255,.08)}
.story img{width:100%;height:180px;object-fit:cover}
.story .s-body{padding:.8rem 1rem}
.story .s-title{font-weight:700;margin:0 0 .25rem}
.story .s-meta{font-size:.9rem;color:var(--muted);margin:0 0 .35rem}

/* CTA */
.rep-cta{padding:2.5rem 1rem;text-align:center}
.rep-cta .btn.primary{background:var(--accent);color:#fff;padding:1rem 2rem;border-radius:10px;text-decoration:none;display:inline-block;box-shadow:0 8px 20px var(--ring)}
.rep-cta .btn.primary:hover{background:var(--accent-dim)}

/* a11y */
.sr-only{position:absolute;left:-9999px}
