:root{
  --flag-red:#d2102e;
  --mint-leaf:#0ea5a4;
  --golden-orange:#f59e0b;
  --yale-blue:#1d446c;
  --platinum:#f3f4f6;
  --blue-violet:#7c3aed;
  --charcoal-blue:#4b5563;
  --yale-blue-2:#1d446c;
  --white:#ffffff;
  --prussian-blue:#011234;
  --surface-shadow:rgba(1,18,52,.08);
  --line-soft:rgba(75,85,99,.18);
  --hero-gradient:linear-gradient(120deg,var(--prussian-blue) 0%,var(--yale-blue) 55%,var(--flag-red) 100%);
  --page-gradient:
    radial-gradient(circle at top right, rgba(210,16,46,.09), transparent 26%),
    radial-gradient(circle at top left, rgba(14,165,164,.11), transparent 28%),
    linear-gradient(180deg,var(--platinum) 0%,var(--white) 38%);
}

*{box-sizing:border-box}

body{
  margin:0;
  font-family:"Segoe UI",Arial,sans-serif;
  background:var(--page-gradient);
  color:var(--prussian-blue);
  padding:24px;
}

img{display:block;max-width:100%}

.hero,
.container{max-width:1600px;margin:0 auto}

.hero{
  background:var(--hero-gradient);
  color:var(--white);
  padding:22px 26px;
  border-radius:28px;
  box-shadow:0 22px 48px rgba(1,18,52,.2);
  margin-bottom:24px;
}

.hero-main{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
}

.hero-title-block{
  flex:1 1 420px;
}

.hero-side{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:0;
  flex:0 1 auto;
  margin-left:auto;
}

.hero-logo-wrap{
  display:flex;
  justify-content:flex-end;
  align-items:flex-start;
  min-width:0;
}

.hero-logo{
  width:min(100%,230px);
  height:auto;
  object-fit:contain;
  padding:0;
  border-radius:0;
  background:none;
  box-shadow:none;
}

.hero-title{
  margin:0;
  font-size:clamp(1.35rem,2vw,2.1rem);
  letter-spacing:.02em;
  white-space:nowrap;
}

.hero-update{
  margin-top:10px;
  color:rgba(255,255,255,.86);
  font-size:.97rem;
}

.tabs{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin:20px 0 24px;
}

.tab-btn{
  width:auto;
  padding:12px 20px;
  border:1px solid rgba(29,68,108,.14);
  border-radius:999px;
  background:rgba(255,255,255,.84);
  color:var(--yale-blue);
  font-weight:700;
  box-shadow:0 12px 24px rgba(1,18,52,.06);
}

.tab-btn.active{
  background:var(--mint-leaf);
  color:var(--white);
  border:none;
  box-shadow:0 12px 24px rgba(14,165,164,.22);
  transform:translateY(-1px);
}

.topbar{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
  margin-bottom:24px;
  flex-wrap:wrap;
}

.section-title{
  margin:0;
  color:var(--prussian-blue);
  font-size:1.45rem;
}

.section-copy{
  margin:.35rem 0 0;
  color:var(--charcoal-blue);
}

.panel{
  background:rgba(255,255,255,.94);
  border:1px solid rgba(29,68,108,.12);
  border-radius:24px;
  padding:22px;
  box-shadow:0 14px 40px var(--surface-shadow);
  margin-bottom:20px;
}

.kpi-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(180px,1fr));
  gap:16px;
  margin-bottom:20px;
}

.kpi-card{
  padding:16px 18px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(29,68,108,.06), rgba(255,255,255,.92));
  border:1px solid rgba(29,68,108,.12);
}

.kpi-label{
  display:block;
  margin-bottom:8px;
  color:var(--charcoal-blue);
  font-size:.82rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
}

.kpi-value{
  color:var(--prussian-blue);
  font-size:1.7rem;
  font-weight:800;
}

.filters{
  display:grid;
  grid-template-columns:repeat(4,minmax(180px,1fr));
  gap:12px;
  align-items:end;
}

label{
  display:block;
  margin-bottom:6px;
  color:var(--charcoal-blue);
  font-size:.9rem;
  font-weight:700;
}

button{
  width:100%;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(29,68,108,.18);
  background:var(--white);
  color:var(--prussian-blue);
  font:inherit;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background-color .18s ease;
}

button:focus{
  outline:none;
  border-color:var(--blue-violet);
  box-shadow:0 0 0 4px rgba(124,58,237,.14);
}

.filter-summary:focus,
.filter-summary:focus-visible{
  outline:none;
  border-color:var(--blue-violet);
  box-shadow:0 0 0 4px rgba(124,58,237,.14);
}

.filter-field{
  position:relative;
}

.filter-dropdown{
  position:relative;
}

.filter-summary{
  list-style:none;
  width:100%;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(29,68,108,.18);
  background:var(--white);
  color:var(--prussian-blue);
  font:inherit;
  cursor:pointer;
  user-select:none;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset;
}

.filter-summary::-webkit-details-marker{
  display:none;
}

.filter-summary::after{
  content:'▾';
  float:right;
  color:var(--charcoal-blue);
  font-size:.9rem;
}

.filter-dropdown[open] .filter-summary{
  border-color:var(--blue-violet);
  box-shadow:0 0 0 4px rgba(124,58,237,.14);
}

.filter-dropdown[open] .filter-summary::after{
  content:'▴';
}

.filter-options{
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  right:0;
  z-index:20;
  max-height:260px;
  overflow:auto;
  padding:8px;
  border:1px solid rgba(29,68,108,.18);
  border-radius:18px;
  background:rgba(255,255,255,.98);
  box-shadow:0 18px 34px rgba(1,18,52,.14);
}

.filter-option{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin:0;
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
}

.filter-option:hover{
  background:rgba(29,68,108,.06);
}

.filter-option input{
  margin-top:2px;
  accent-color:var(--mint-leaf);
}

.filter-option span{
  color:var(--prussian-blue);
  font-size:.92rem;
  line-height:1.25;
}

button:hover{transform:translateY(-1px)}

.btns{
  display:flex;
  gap:10px;
  align-items:stretch;
}

.btn-primary{
  background:var(--flag-red);
  color:var(--white);
  border:none;
  box-shadow:0 12px 24px rgba(210,16,46,.22);
}

.btn-secondary{
  background:var(--mint-leaf);
  color:var(--white);
  border:none;
  box-shadow:0 12px 24px rgba(14,165,164,.22);
}

.chart-wrap canvas{width:100%!important;height:620px!important}
.chart-wrap.medium canvas{height:480px!important}

.legend-inline{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:14px;
  color:var(--charcoal-blue);
}

.legend-groups{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:0 0 16px;
}

.legend-group{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px 14px;
  border-radius:16px;
  background:rgba(29,68,108,.06);
  border:1px solid rgba(29,68,108,.12);
}

.legend-group-text{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.legend-group-title{
  color:var(--prussian-blue);
  font-size:.9rem;
  font-weight:800;
  line-height:1.1;
}

.legend-group-copy{
  color:var(--charcoal-blue);
  font-size:.88rem;
  line-height:1.25;
}

.legend-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:.94rem;
}

.legend-swatch{
  display:inline-block;
  width:12px;
  height:12px;
  border-radius:999px;
}

.table-wrap{
  overflow:auto;
  max-height:600px;
  border:1px solid rgba(29,68,108,.12);
  border-radius:20px;
  background:var(--white);
}

table{width:100%;border-collapse:collapse;min-width:900px}

th,td{
  padding:12px 14px;
  border-bottom:1px solid rgba(75,85,99,.12);
  text-align:left;
}

th{
  position:sticky;
  top:0;
  background:var(--platinum);
  color:var(--yale-blue);
}

tbody tr:nth-child(even){background:rgba(243,244,246,.55)}

.sub{
  color:var(--charcoal-blue);
  margin-top:0;
}

@media (max-width:1080px){
  .filters{grid-template-columns:repeat(2,minmax(180px,1fr))}
  .kpi-grid{grid-template-columns:repeat(2,minmax(180px,1fr))}
  .hero-main{
    flex-direction:column;
    align-items:flex-start;
  }
  .hero-side{
    width:100%;
    justify-content:flex-start;
  }
}

@media (max-width:768px){
  body{padding:16px}
  .hero{padding:20px}
  .hero-main,
  .hero-side{flex-direction:column;align-items:flex-start}
  .hero-logo-wrap{justify-content:flex-start}
  .kpi-grid,
  .filters{grid-template-columns:1fr}
  .btns{flex-direction:column}
  .chart-wrap canvas{height:420px!important}
  .chart-wrap.medium canvas{height:360px!important}
  .legend-groups{gap:10px}
  .legend-group{width:100%}
}
