.statsPage{
  --panel:#0f172a;
  --panel-2:#111b31;
  --panel-3:#0c1427;
  --border:rgba(255,255,255,.08);
  --accent:#2f6fed;
  --accent-2:#34d399;
  --warn:#f59e0b;
  --danger:#ef4444;
  --text:#e5e7eb;
  --muted:#9aa4b2;
  --control-h:30px;
  background:#0b1220;
  color:var(--text);
}

.statsPage .main{ width:100%; margin:0 auto; }
.statsPage .statsMain{ max-width:1024px; margin:0 auto; }
.statsPage .statsFrame{
  border:1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  padding: 16px;
  background: rgb(15 23 42 / 98%);
  box-shadow: var(--shadow);
}
.statsPage .topbarRow{ display:flex; align-items:center; gap:12px; width:100%; justify-content:space-between; }
.statsPage .backLink{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color: var(--danger);
  text-decoration:none;
  font-size:14px;
  opacity:.85;
}
.statsPage .backLink:hover{ opacity:1; }
.statsPage .backLink svg{ width:16px; height:16px; }
.statsPage .menuBtn{ margin-left:auto; }
.statsPage .menuWrap{ margin-left:auto; }
.statsLoading{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background: rgba(11,18,32,.92);
  z-index: 80;
}
.statsLoading.open{ display:flex; }
.statsLoading .splashInner{
  background: rgba(15,23,42,.96);
  border:1px solid rgba(255,255,255,.10);
  color: rgba(229,231,235,.95);
  padding: 16px 18px;
  border-radius: 14px;
  box-shadow: 0 12px 28px rgba(0,0,0,.45);
  max-width: min(520px, calc(100vw - 24px));
  text-align:center;
}

.statsPage .filters{ display:grid; grid-template-columns: 1.2fr 1fr 1fr 1fr 1fr 1fr; gap:10px; margin-bottom:12px; }
.statsPage .filters .btn{ height:42px; }
.statsPage .filters .btnText{ gap:6px; }

.statsPage .panelHeader{ display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-bottom:12px; }
.statsPage .filterRow{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.statsPage .filterBlock{ display:flex; flex-direction:column; gap:6px; min-width:180px; }
.statsPage .legend{ display:flex; flex-wrap:wrap; gap:10px 14px; margin-top:8px; }
.statsPage .legendItem{ display:flex; align-items:center; gap:6px; font-size:12px; color:var(--muted); }
.statsPage .legendSwatch{ width:12px; height:12px; border-radius:2px; }
.statsPage .cardControls{ display:flex; align-items:center; gap:8px; flex-wrap:nowrap; justify-content:flex-end; }
.statsPage .cardControls > *{ flex:0 0 auto; }
.statsPage .cardControls .badge{ height:var(--control-h); line-height:calc(var(--control-h) - 2px); box-sizing:border-box; }
.statsPage .cardControls select{ min-width: 88px; }
.statsPage .cardControls .cSelect{ width:auto; min-width:88px; }
.statsPage .stackBar{ display:flex; height:100%; width:100%; }
.statsPage .stackSeg{ height:100%; position:relative; }
.statsPage .stackSeg:first-child{ border-top-left-radius:4px; border-bottom-left-radius:4px; }
.statsPage .stackSeg:last-child{ border-top-right-radius:4px; border-bottom-right-radius:4px; }
.statsPage .stackSeg::after,
.statsPage .barFill::after{
  content: attr(data-label);
  position: absolute;
  left: 50%;
  bottom: calc(100% + 8px);
  transform: translateX(-50%) translateY(4px);
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
  background: rgba(6, 10, 18, 0.98);
  color: #e2e8f0;
  padding: 6px 8px;
  border-radius: 8px;
  font-size: 12px;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 10px 24px rgba(0,0,0,.45);
  transition: opacity .08s ease, transform .08s ease;
  z-index: 3;
}
.statsPage .barFill.noTip::after{
  content: none;
}
.statsPage .barFill.noTip:hover::after{
  opacity: 0;
  transform: translateX(-50%) translateY(0);
}
.statsPage .stackSeg:hover::after,
.statsPage .barFill:hover::after{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.statsPage .barFill{ position:relative; border-radius:4px; }

.statsPage .grid2{ display:grid; grid-template-columns: 1fr; gap:12px; }
.statsPage .grid3{ display:grid; grid-template-columns: repeat(3,1fr); gap:12px; }
.statsPage .grid4{ display:grid; grid-template-columns: repeat(4,1fr); gap:12px; }

.statsPage .card{ border:1px solid var(--border); border-radius:14px; padding:14px; background: rgb(15 23 42 / 98%); }
.statsPage .card.dark{ background:var(--panel); }
.statsPage .cardTitle{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:8px; flex-wrap:wrap; }
.statsPage .cardTitle > strong{ flex:1 1 auto; }
.statsPage .cardControls{ margin-left:auto; }
.statsPage .badge{
  font-size:12px;
  display:inline-flex;
  align-items:center;
  height:var(--control-h);
  padding:0 12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: var(--text);
  white-space:nowrap;
}
.statsPage .cSelectBtn{
  font-size:12px;
  height:var(--control-h);
  min-height:var(--control-h);
  padding:0 12px;
  line-height:calc(var(--control-h) - 2px);
}
.statsPage .cSelectOption{
  font-size:12px;
}

.statsPage .kpi strong{ font-size:20px; display:block; }
.statsPage .kpi small{ color:var(--muted); }

.statsPage .barRow{ display:flex; align-items:center; gap:10px; margin:8px 0; }
.statsPage .barDivider{ height:1px; background:rgba(255,255,255,.08); margin:10px 14px; }
.statsPage .barLabel{ width: 160px; font-size:12px; color: var(--muted); }
.statsPage .barTrack{ flex:1; height:12px; border-radius:4px; border:1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.04); overflow:visible; }
.statsPage .barFill{ height:100%; background: rgba(47,111,237,.85); }
.statsPage .barFill.green{ background: rgba(46,213,115,.85); }
.statsPage .barFill.orange{ background: rgba(255,159,67,.85); }
.statsPage .barValue{ width: 54px; text-align:right; font-size:12px; }
.statsPage .templateRow{ cursor:pointer; padding:6px 8px; border-radius:12px; border:1px solid transparent; }
.statsPage .templateRow.active{ border-color: rgba(47,111,237,.6); box-shadow: 0 0 0 1px rgba(47,111,237,.35) inset; background: rgba(15,23,42,.98); }
.statsPage .templateRow.active .barLabel{ color: var(--text); font-weight:600; }
.statsPage #schoolTotalBar{ background:#156480; }

.statsPage .table{ width:100%; border-collapse: collapse; font-size:13px; color: var(--muted); }
.statsPage .table th,.statsPage .table td{ border-bottom:1px solid rgba(255,255,255,.08); padding:8px 6px; text-align:left; vertical-align:top; color: var(--text); }
.statsPage .table th{ color: var(--text); font-weight:600; }

.statsPage .tags{ display:flex; flex-wrap:wrap; gap:6px; }
.statsPage .tag{ padding:4px 8px; border-radius:999px; border:1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.04); font-size:11px; color: var(--text); }
.statsPage .tag.arch{ border-color: rgba(255,107,107,.45); color:#ffb3b3; }
.statsPage .tag.year{ border-color: rgba(47,111,237,.4); color:#b7d0ff; }

.statsPage .schoolList{ display:grid; gap:10px; }
.statsPage .schoolCard{ border:1px solid rgba(255,255,255,.08); border-radius:12px; padding:12px; background: rgb(15 23 42 / 98%); cursor:pointer; }
.statsPage .schoolCard.active{ border-color: rgba(47,111,237,.6); box-shadow: 0 0 0 1px rgba(47,111,237,.35) inset; background: rgba(15,23,42,.98); }
.statsPage .detailYearBlock{
  margin-top:12px;
  padding:12px;
  border-radius:14px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
}
.statsPage .detailYearTitle{
  font-weight:800;
  margin-bottom:8px;
  letter-spacing:.02em;
}
.statsPage .detailHeader{ display:none; }
.statsPage .detailRow{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:10px 10px;
  border-bottom:1px solid rgba(255,255,255,.06);
  align-items:flex-start;
  text-align:left;
}
.statsPage .detailRow:last-child{ border-bottom:none; }
.statsPage .detailClass{ font-weight:700; }
.statsPage .detailCount{
  font-size:14px;
  color:var(--muted);
}
.statsPage .detailTitles{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
.statsPage .detailCountLabel{
  font-size:14px;
  color:var(--muted);
}
.statsPage .detailClass .classLabelGreen{
  font-size:14px;
  font-weight:700;
  padding:0;
  background:transparent;
}
.statsPage .detailClassWrap{
  display:flex;
  align-items:center;
  gap:8px;
}
.statsPage .detailArchived{
  font-size:12px;
  color:#f87171;
  border:1px solid rgba(248,113,113,.45);
  padding:2px 8px;
  border-radius:999px;
  background:rgba(248,113,113,.12);
}
.statsPage .detailPill{
  padding:4px 4px;
  border-radius:4px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.04);
  font-size:12px;
  color:var(--text);
  white-space:nowrap;
}

.statsPage .pdfTools{ display:flex; flex-wrap:wrap; gap:8px; }
.statsPage .pdfPreview{ border:1px dashed rgba(255,255,255,.15); border-radius:12px; padding:12px; background: rgba(255,255,255,.02); }

.statsPage .section{ margin-bottom:16px; }

@media (max-width: 1200px){
  .statsPage .filters{ grid-template-columns: 1fr 1fr 1fr; }
}
@media (max-width: 900px){
  .statsPage .grid4{ grid-template-columns: repeat(2, 1fr); }
  .statsPage .grid3,.statsPage .grid2{ grid-template-columns: 1fr; }
  .statsPage .cardTitle{ flex-direction:column; align-items:flex-start; }
  .statsPage .cardControls{ width:100%; justify-content:flex-start; flex-wrap:wrap; }
  .statsPage .cardControls select{ flex:1 1 140px; min-width: 0; }
  .statsPage .cardControls .cSelect{ flex:1 1 140px; min-width: 0; }
}
@media (max-width: 720px){
  .statsPage .barRow{ gap:8px; }
  .statsPage .barLabel{ width: 110px; font-size:11px; }
  .statsPage .barValue{ width: 36px; font-size:11px; }
  .statsPage .barTrack{ height:16px; }
  .statsPage .legend{ flex-direction:column; align-items:flex-start; gap:8px; }
  .statsPage .legendItem{ font-size:12px; }
  .statsPage .detailHeader{ display:none; }
  .statsPage .detailRow{
    display:flex;
    flex-direction:column;
    gap:6px;
    align-items:flex-start;
    text-align:left;
  }
  .statsPage .detailRow > div{
    width:100%;
    text-align:left;
  }
  .statsPage .detailTitles{
    flex-direction:column;
    align-items:flex-start;
  }
}
@media (min-width: 901px){
  .statsPage .cardTitle{ flex-wrap:nowrap; }
  .statsPage .cardTitle > strong{ white-space:nowrap; }
}
@media (min-width: 820px){
  .statsPage .detailHeader{
    display:grid;
    grid-template-columns: 130px 140px 1fr;
    gap:12px;
    align-items:center;
    padding:8px 10px;
    border-radius:10px;
    background:rgba(255,255,255,.04);
    font-size:12px;
    color:var(--muted);
    margin-bottom:6px;
    text-align:left;
  }
  .statsPage .detailRow{
    display:grid;
    grid-template-columns: 130px 140px 1fr;
    gap:12px;
    align-items:center;
  }
  .statsPage .detailTitles{
    flex-direction:row;
    flex-wrap:wrap;
    align-items:center;
  }
}
