:root{
  --royal:#0051BA;
  --royal-deep:#003865;
  --royal-soft:#2d6fca;
  --silver:#B2B3B2;
  --white:#FFFFFF;
  --black:#000000;
  --bg:#06101f;
  --bg-2:#0a1630;
  --panel:#0e1d39;
  --panel-2:#13284d;
  --ink:#f7f9fc;
  --muted:#c1cad8;
  --line:rgba(255,255,255,.12);
  --line-strong:rgba(178,179,178,.3);
  --shadow:0 16px 36px rgba(0,0,0,.3);
  --radius:20px;
  --radius-sm:14px;
  --max:1280px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,Arial,Helvetica,sans-serif;
  min-height:100vh;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(0,81,186,.28), transparent 26%),
    radial-gradient(circle at top right, rgba(178,179,178,.12), transparent 22%),
    linear-gradient(180deg, #040b16 0%, #091122 35%, #081120 100%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button, input, select{font:inherit}
.container{width:min(calc(100% - 32px), var(--max)); margin:0 auto}

.site-header{
  position:sticky; top:0; z-index:20;
  backdrop-filter:blur(14px);
  background:rgba(4,11,22,.82);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; padding:14px 0;
}
.brand{display:flex; align-items:center; gap:16px; min-width:0}
.brand img{
  width:72px; height:72px; object-fit:contain;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border-radius:16px; padding:6px;
  box-shadow:var(--shadow);
  border:1px solid rgba(178,179,178,.25);
}
.brand-title{display:flex; flex-direction:column; gap:4px; min-width:0}
.brand-title strong{font-size:1.14rem; letter-spacing:.02em}
.brand-title span{color:var(--muted); font-size:.92rem}

.top-nav{display:flex; gap:10px; flex-wrap:wrap}
.top-nav a{
  padding:10px 14px; border:1px solid var(--line); border-radius:999px;
  color:var(--muted); background:rgba(255,255,255,.02); transition:.18s ease;
}
.top-nav a.active,.top-nav a:hover{
  color:var(--white);
  border-color:rgba(178,179,178,.38);
  background:linear-gradient(180deg, rgba(0,81,186,.42), rgba(0,56,101,.72));
}

.hero{padding:34px 0 20px}
.hero-card{
  background:linear-gradient(135deg, rgba(0,81,186,.22), rgba(10,22,48,.96) 42%, rgba(7,16,31,.98));
  border:1px solid rgba(178,179,178,.18);
  border-radius:30px;
  padding:30px;
  box-shadow:var(--shadow);
}
.hero-card h1{margin:0 0 10px; font-size:clamp(2rem,4vw,3rem); line-height:1.06}
.hero-card p{margin:0; color:var(--muted); max-width:860px; line-height:1.58}

.section{padding:0 0 40px}
.panel{
  background:linear-gradient(180deg, rgba(14,29,57,.94), rgba(9,20,39,.94));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.panel{padding:20px}
.hidden{display:none !important;}

.controls-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.controls-grid-search{grid-template-columns:2fr 1fr 1fr 1fr 1.2fr}
.leaders-grid-controls{grid-template-columns:repeat(3, minmax(0,1fr))}
label{display:block}
label > span,
.label{
  display:block; margin-bottom:6px; font-size:.82rem;
  text-transform:uppercase; letter-spacing:.06em; color:var(--muted);
}
input[type="search"], select, .columns-button{
  width:100%; padding:12px 14px; border-radius:12px;
  border:1px solid var(--line); background:#091325; color:var(--ink);
  outline:none;
}
input[type="search"]:focus, select:focus, .columns-button:focus{border-color:rgba(178,179,178,.42)}
.columns-button{cursor:pointer; text-align:left}
input[type="range"]{width:100%; accent-color:var(--royal-soft)}
small{display:block; margin-top:6px; color:var(--muted)}

.segmented{display:flex; flex-wrap:wrap; gap:10px}
.segmented button{
  border:1px solid var(--line); background:#091325; color:var(--muted);
  padding:10px 14px; border-radius:999px; cursor:pointer; font-weight:700;
  transition:.18s ease;
}
.segmented button.active{
  color:var(--white);
  background:linear-gradient(180deg, rgba(45,111,202,.95), rgba(0,81,186,.92));
  border-color:rgba(178,179,178,.35);
}
.segmented button:hover{color:var(--white); border-color:rgba(178,179,178,.28)}

.columns-panel{margin-bottom:18px; padding:18px}
.columns-panel-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:14px;
}
.columns-actions{display:flex; gap:10px; flex-wrap:wrap}
.mini-button{
  border:1px solid var(--line); background:#091325; color:var(--ink);
  padding:8px 12px; border-radius:999px; cursor:pointer;
}
.column-checkbox-grid{
  display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:10px 14px;
}
.column-option{
  display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:12px;
  border:1px solid var(--line); background:rgba(255,255,255,.02);
}
.column-option input{margin:0}

.kpi-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.kpi-grid-search{grid-template-columns:repeat(3, minmax(0,1fr))}
.kpi-card{
  padding:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
}
.kpi-card span{
  display:block; font-size:.82rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted);
}
.kpi-card strong{
  display:block; margin-top:8px; font-size:1.9rem; font-weight:800; color:var(--white);
}

.table-panel{padding:0; overflow:hidden}
.table-wrap{overflow:auto; border-radius:inherit}
table{width:100%; border-collapse:collapse; min-width:1000px}
th,td{padding:12px 14px; border-bottom:1px solid var(--line); text-align:left; white-space:nowrap}
th{
  font-size:.82rem; text-transform:uppercase; letter-spacing:.06em; color:var(--muted);
  background:rgba(0,0,0,.2); position:sticky; top:0
}
tbody tr:hover{background:rgba(0,81,186,.12)}
.sortable-head{cursor:pointer; user-select:none;}
.sortable-head:hover{color:var(--white); background:rgba(0,81,186,.26);}

.rank{font-weight:800; color:var(--silver)}
.empty{
  padding:28px; text-align:center; color:var(--muted);
  border:1px dashed var(--line-strong); border-radius:14px; margin:12px;
}

.leader-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:16px;
}
.leader-card{
  border:1px solid var(--line); border-radius:18px; overflow:hidden;
  background:linear-gradient(180deg, rgba(9,19,37,.85), rgba(7,16,31,.9));
}
.leader-card h3{
  margin:0; padding:14px 16px;
  background:linear-gradient(90deg, rgba(0,81,186,.18), rgba(178,179,178,.12));
  border-bottom:1px solid var(--line);
}
.leader-card table{min-width:0}
.leader-card th,.leader-card td{padding:10px 12px}
.footer{padding:0 0 32px; color:var(--muted)}

@media (max-width: 1100px){
  .controls-grid-search{grid-template-columns:repeat(2, minmax(0,1fr))}
  .column-checkbox-grid{grid-template-columns:repeat(3, minmax(0,1fr))}
}
@media (max-width: 1024px){
  .controls-grid,.kpi-grid,.leader-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .leaders-grid-controls{grid-template-columns:repeat(2, minmax(0,1fr))}
}
@media (max-width: 720px){
  .header-inner{align-items:flex-start; flex-direction:column}
  .brand img{width:62px;height:62px}
  .controls-grid,.kpi-grid,.leader-grid,.leaders-grid-controls,.column-checkbox-grid{grid-template-columns:1fr}
  .hero-card{padding:24px}
  .columns-panel-head{flex-direction:column; align-items:flex-start}
}

.eyebrow,.mini-label{
  display:inline-block; font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; color:var(--silver);
}
.hero-homepage{padding:36px 0 18px}
.hero-grid-home{
  display:grid; grid-template-columns:1.55fr .95fr; gap:18px; align-items:stretch;
}
.hero-copy-wide h1{font-family:Barlow,Inter,Arial,sans-serif; text-transform:uppercase; font-size:clamp(2.3rem,5vw,4.4rem); line-height:.94; margin:10px 0 14px}
.hero-copy-wide p{font-size:1.03rem}
.hero-actions{display:flex; flex-wrap:wrap; gap:12px; margin-top:22px}
.cta-button,.ghost-button{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 18px; border-radius:999px; font-weight:800; letter-spacing:.01em; transition:.18s ease;
}
.cta-button{
  color:var(--white); background:linear-gradient(180deg, rgba(45,111,202,.95), rgba(0,81,186,.92));
  border:1px solid rgba(178,179,178,.38);
}
.ghost-button{
  color:var(--white); border:1px solid var(--line); background:rgba(255,255,255,.03);
}
.cta-button:hover,.ghost-button:hover{transform:translateY(-1px)}
.hero-stack{display:grid; gap:14px}
.hero-stat strong{display:block; font-size:1.2rem; margin:8px 0 8px}
.hero-stat p{margin:0; color:var(--muted); line-height:1.5}
.section-ribbon{
  display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin:0 0 16px;
  padding:0 0 10px; border-bottom:1px solid var(--line);
}
.section-ribbon span{font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; color:var(--silver)}
.section-ribbon strong{font-family:Barlow,Inter,Arial,sans-serif; text-transform:uppercase; font-size:clamp(1.3rem,2.7vw,2.2rem)}
.callout-grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px}
.callout-card h2,.feature-band h2,.admin-card h2,.admin-user-card h2{margin:.35rem 0 .65rem; font-family:Barlow,Inter,Arial,sans-serif; text-transform:uppercase; letter-spacing:.01em}
.callout-card p,.feature-band p,.muted-copy{margin:0; color:var(--muted); line-height:1.58}
.callout-card-media{display:grid; grid-template-columns:1.2fr .8fr; gap:18px; align-items:center}
.content-image{
  width:100%; max-height:250px; object-fit:contain; border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid var(--line); padding:12px;
}
.home-center-action{display:flex; justify-content:center; margin-top:18px}
.feature-band{display:flex; justify-content:space-between; gap:18px; align-items:center}
.footer-bar{display:flex; justify-content:space-between; gap:14px; padding-top:18px; border-top:1px solid var(--line)}
.admin-grid,.admin-user-grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:16px}
.admin-card,.admin-user-card{display:flex; flex-direction:column; gap:12px}
.admin-alert{margin-bottom:16px; padding:14px 16px; border-radius:14px; border:1px solid var(--line)}
.admin-alert.success{background:rgba(39,174,96,.14); border-color:rgba(39,174,96,.32)}
.admin-editor{display:grid; gap:16px}
.admin-section{padding:22px}
.admin-section-locked{opacity:.72}
.admin-fields{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px}
.admin-field textarea,.admin-field input[type="text"]{
  width:100%; padding:12px 14px; border-radius:12px; border:1px solid var(--line); background:#091325; color:var(--ink);
}
.admin-actions-stick{position:sticky; bottom:0; padding:14px 0 4px; background:linear-gradient(180deg, rgba(6,16,31,0), rgba(6,16,31,.95) 40%)}
.admin-permissions{display:grid; gap:10px}
.permission-chip{display:flex; align-items:center; gap:10px; padding:10px 12px; border:1px solid var(--line); border-radius:14px; background:rgba(255,255,255,.03)}
@media (max-width: 1024px){
  .hero-grid-home,.callout-grid,.admin-grid,.admin-user-grid,.admin-fields,.callout-card-media,.feature-band{grid-template-columns:1fr}
  .feature-band{display:grid}
}
@media (max-width: 720px){
  .hero-actions,.footer-bar{flex-direction:column; align-items:flex-start}
}


.panel-tight{padding:18px}
.footer-bar{
  display:flex;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  padding-top:10px;
}
.hero-calendar{padding-bottom:14px}
.hero-card-calendar p{max-width:980px}
.section-calendar-shell{padding-top:0}
.calendar-shell{
  padding:26px;
  background:linear-gradient(180deg, rgba(10,22,48,.96), rgba(7,16,31,.96));
}
.calendar-shell[data-calendar-accent="boys"]{
  box-shadow:0 20px 40px rgba(0,81,186,.20);
}
.calendar-shell[data-calendar-accent="girls"]{
  box-shadow:0 20px 40px rgba(178,179,178,.15);
}
.calendar-shell[data-calendar-accent="school"]{
  box-shadow:0 20px 40px rgba(255,255,255,.10);
}
.calendar-shell[data-calendar-accent="middle-school"]{
  box-shadow:0 20px 40px rgba(45,111,202,.18);
}
.calendar-topbar{
  display:flex;
  justify-content:space-between;
  gap:20px;
  align-items:flex-start;
  margin-bottom:18px;
}
.calendar-topbar h2{
  margin:4px 0 8px;
  font-size:clamp(1.6rem, 2.7vw, 2.2rem);
}
.calendar-topbar p{margin:0; color:var(--muted); max-width:760px; line-height:1.55}
.calendar-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:12px;
}
.calendar-filter-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:18px;
}
.calendar-filter-pill{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  color:var(--muted);
  padding:11px 16px;
  border-radius:999px;
  cursor:pointer;
  font-weight:800;
  letter-spacing:.01em;
  transition:.18s ease;
}
.calendar-filter-pill:hover,
.calendar-filter-pill.active{
  color:var(--white);
  border-color:rgba(178,179,178,.38);
  background:linear-gradient(180deg, rgba(0,81,186,.44), rgba(0,56,101,.82));
}
.calendar-highlights-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:16px;
  margin-bottom:18px;
}
.calendar-info-card h3{margin:6px 0 10px; font-size:1.2rem}
.calendar-info-card p{margin:0; color:var(--muted); line-height:1.6}
.calendar-bullet-list{
  margin:14px 0 0;
  padding-left:18px;
  color:var(--ink);
}
.calendar-bullet-list li + li{margin-top:8px}
.calendar-tip-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}
.calendar-tip-badge{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--white);
  font-weight:700;
}
.calendar-embed-grid{
  display:grid;
  grid-template-columns:minmax(0, 2fr) minmax(320px, 1fr);
  gap:16px;
  align-items:start;
}
.calendar-panel-main,
.calendar-panel-side{
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  border:1px solid var(--line);
  border-radius:20px;
  padding:16px;
}
.calendar-panel-heading h3{
  margin:4px 0 12px;
  font-size:1.18rem;
}
.calendar-panel-heading-side{display:grid; gap:8px}
.calendar-side-copy{margin:0; color:var(--muted); line-height:1.55}
.calendar-iframe-wrap{
  width:100%;
  overflow:hidden;
  border-radius:18px;
  border:1px solid var(--line);
  background:#081120;
}
.calendar-iframe-wrap iframe{
  display:block;
  width:100%;
  border:0;
  background:#fff;
}
.calendar-iframe-wrap-main iframe{height:760px}

.calendar-events-status{
  margin:0 0 14px;
  color:var(--muted);
  font-size:.96rem;
  line-height:1.5;
}
.calendar-events-list{
  display:grid;
  gap:12px;
}
.calendar-event-card{
  display:grid;
  grid-template-columns:82px minmax(0,1fr);
  gap:14px;
  padding:14px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.035);
  box-shadow:0 12px 28px rgba(0,0,0,.16);
}
.calendar-event-date{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  min-height:98px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(0,81,186,.22), rgba(0,56,101,.12));
  text-align:center;
}
.calendar-event-weekday,
.calendar-event-month{
  font-size:.78rem;
  letter-spacing:.12em;
  font-weight:800;
  color:var(--muted);
}
.calendar-event-day{
  font-size:2rem;
  line-height:1;
  font-weight:800;
  color:var(--white);
}
.calendar-event-body h4{
  margin:0 0 8px;
  font-size:1.04rem;
}
.calendar-event-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:10px;
}
.calendar-event-chip{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  color:var(--ink);
  font-size:.88rem;
  font-weight:700;
}
.calendar-event-body p{
  margin:0 0 10px;
  color:var(--muted);
  line-height:1.55;
  font-size:.95rem;
}
.calendar-inline-link{
  color:var(--white);
  font-weight:700;
  text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.25);
}
.calendar-inline-link:hover{border-bottom-color:rgba(255,255,255,.72)}
.calendar-empty-state{
  padding:18px;
  border-radius:18px;
  border:1px dashed var(--line);
  background:rgba(255,255,255,.03);
}
.calendar-empty-state strong{display:block; margin-bottom:6px}
.calendar-empty-state p{margin:0 0 10px; color:var(--muted); line-height:1.55}
.calendar-event-card-skeleton{pointer-events:none}
.calendar-event-date-skeleton,
.calendar-skeleton-line{
  background:linear-gradient(90deg, rgba(255,255,255,.05), rgba(255,255,255,.15), rgba(255,255,255,.05));
  background-size:200% 100%;
  animation:calendarPulse 1.35s ease-in-out infinite;
}
.calendar-event-date-skeleton{
  min-height:98px;
  border-radius:16px;
}
.calendar-skeleton-line{
  height:12px;
  border-radius:999px;
  margin-bottom:10px;
}
.calendar-skeleton-line-title{width:72%; height:16px}
.calendar-skeleton-line-short{width:48%; margin-bottom:0}

@keyframes calendarPulse{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}

@media (max-width: 1024px){
  .calendar-topbar,
  .calendar-embed-grid,
  .calendar-highlights-grid{grid-template-columns:1fr}
  .calendar-topbar{display:grid}
  .calendar-actions{justify-content:flex-start}
}

@media (max-width: 720px){
  .calendar-shell{padding:20px}
  .calendar-iframe-wrap-main iframe{height:660px}
  .calendar-event-card{grid-template-columns:68px minmax(0,1fr); padding:12px}
  .calendar-event-date{min-height:84px}
  .calendar-event-day{font-size:1.7rem}
}


.hero-competitions .hero-card{padding-bottom:26px}
.competition-shell{padding:26px; background:linear-gradient(180deg, rgba(10,22,48,.96), rgba(7,16,31,.96));}
.competition-topbar{display:grid; gap:10px; margin-bottom:18px}
.competition-topbar h2{margin:4px 0 0; font-size:clamp(1.6rem, 2.7vw, 2.2rem)}
.competition-topbar p{margin:0; color:var(--muted); line-height:1.6; max-width:820px}
.competition-kpi-grid{display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:14px; margin-bottom:18px}
.competition-kpi-card strong{display:block; margin-top:8px; font-size:2rem; font-weight:800}
.competition-kpi-card p{margin:8px 0 0; color:var(--muted); line-height:1.55}
.competition-filter-panel{margin-bottom:18px; padding:18px; background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015))}
.competition-filter-grid{display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:14px; margin-bottom:14px}
.competition-filter-actions{display:flex; flex-wrap:wrap; gap:12px}
.competition-team-row,.competition-pill-row{display:flex; flex-wrap:wrap; gap:10px; margin-bottom:18px}
.competition-month-stack{display:grid; gap:22px}
.competition-month-group{display:grid; gap:14px}
.competition-month-ribbon{margin-bottom:0}
.competition-card-list{display:grid; gap:14px}
.competition-card{display:grid; grid-template-columns:100px minmax(0,1fr); gap:18px; align-items:start; background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.018))}
.competition-card-date{display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; min-height:132px; border-radius:18px; border:1px solid rgba(255,255,255,.12); background:linear-gradient(180deg, rgba(0,81,186,.22), rgba(0,56,101,.12)); text-align:center; padding:12px}
.competition-card-month,.competition-card-weekday{font-size:.8rem; letter-spacing:.12em; font-weight:800; color:var(--muted)}
.competition-card-date strong{font-size:2.3rem; line-height:1; font-weight:800}
.competition-card-date strong small{display:inline; font-size:1rem; color:var(--muted); margin-left:2px}
.competition-card-head{display:flex; justify-content:space-between; gap:16px; align-items:flex-start}
.competition-card-head h3{margin:0 0 6px; font-size:1.25rem}
.competition-date-line{margin:0; color:var(--muted); line-height:1.5}
.competition-meta-row{margin-bottom:12px}
.competition-location-chip{border-color:rgba(178,179,178,.22)}
.competition-badge-row,.competition-link-row{display:flex; flex-wrap:wrap; gap:10px; margin-bottom:12px}
.competition-badge,.competition-link-chip{display:inline-flex; align-items:center; min-height:34px; padding:7px 12px; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.04); font-size:.9rem; font-weight:700}
.competition-link-chip:hover{border-color:rgba(178,179,178,.38); background:rgba(255,255,255,.08)}
.competition-card-copy{margin:0 0 12px; color:var(--muted); line-height:1.6}
.competition-results-block{margin-top:4px; padding:14px; border-radius:16px; border:1px solid rgba(178,179,178,.16); background:rgba(255,255,255,.03)}
.competition-results-list{margin:8px 0 0; padding-left:18px; display:grid; gap:8px}
.competition-results-list li{color:var(--ink)}
.competition-empty-state{padding:22px; border:1px dashed var(--line-strong); background:rgba(255,255,255,.03)}
.competition-empty-state strong{display:block; margin-bottom:8px}
.competition-empty-state p{margin:0; color:var(--muted); line-height:1.55}
@media (max-width: 1024px){
  .competition-kpi-grid,.competition-filter-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .competition-card{grid-template-columns:84px minmax(0,1fr)}
  .competition-card-date{min-height:116px}
}
@media (max-width: 720px){
  .competition-shell{padding:20px}
  .competition-kpi-grid,.competition-filter-grid{grid-template-columns:1fr}
  .competition-filter-actions{flex-direction:column; align-items:flex-start}
  .competition-card{grid-template-columns:1fr}
  .competition-card-date{min-height:0; display:grid; grid-template-columns:repeat(3, auto); justify-content:flex-start; gap:10px 14px; padding:14px}
  .competition-card-date strong{font-size:1.8rem}
  .competition-card-date strong small{font-size:.9rem}
}
