:root {
  --red:#e51b2b;
  --red-soft:#ff6873;
  --dark-red:#a40e1c;
  --ink:#130d0f;
  --glass:rgba(255,255,255,.075);
  --glass-strong:rgba(255,255,255,.12);
  --stroke:rgba(255,255,255,.14);
  --text:#ffffff;
  --muted:#caa9ad;
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  margin:0;
  overflow-x:hidden;
  min-height:100vh;
  color:var(--text);
  font-family:"DM Sans",sans-serif;
  background:
    radial-gradient(circle at 18% 12%, rgba(229,27,43,.34), transparent 31%),
    radial-gradient(circle at 78% 22%, rgba(255,104,115,.16), transparent 28%),
    linear-gradient(135deg,#130d0f,#261014 58%,#130d0f);
  background-attachment:fixed;
}
body::before {
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.13;
  background-image:linear-gradient(rgba(255,255,255,.45) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.45) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:linear-gradient(180deg,#000,transparent 82%);
}
a { color:inherit; text-decoration:none; }
button,input { font:inherit; }
input,button,a { -webkit-tap-highlight-color:rgba(255,104,115,.18); }
.competition-header {
  position:sticky;
  top:0;
  z-index:5;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  height:78px;
  margin:18px 5vw 0;
  padding:0 18px;
  color:white;
  border:1px solid var(--stroke);
  border-radius:24px;
  background:rgba(19,13,15,.68);
  box-shadow:0 20px 60px rgba(0,0,0,.24);
  backdrop-filter:blur(18px);
}
.logo { display:flex; align-items:center; gap:11px; }
.logo-number { display:grid; place-items:center; width:44px; height:47px; border-radius:14px; background:linear-gradient(145deg,var(--red),#ff5964); color:white; font:20px "Archivo Black"; box-shadow:0 12px 24px rgba(229,27,43,.28); transform:skew(-6deg); }
.logo span:last-child { display:grid; }
.logo b { font:19px/1 "Archivo Black"; letter-spacing:1px; }
.logo small,.round-title span,.round-title small { margin-top:4px; color:#e9a1a6; font:700 8px "DM Sans"; letter-spacing:1.5px; }
.round-title { display:flex; align-items:center; gap:12px; padding:9px 14px; border:1px solid var(--stroke); border-radius:999px; background:rgba(255,255,255,.05); }
.round-title b { color:white; font:30px "Archivo Black"; }
.status { justify-self:end; display:flex; align-items:center; gap:10px; color:#ffb0b5; font-size:10px; font-weight:800; letter-spacing:1.5px; }
.status i { width:8px; height:8px; border-radius:50%; background:var(--red); box-shadow:0 0 0 5px rgba(229,27,43,.18); }
.user-status { max-width:430px; }
.user-status span { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.user-status a { padding:8px 11px; border:1px solid rgba(255,255,255,.12); border-radius:999px; background:rgba(229,27,43,.18); color:white; }
.dashboard { position:relative; max-width:1500px; margin:auto; padding:34px 5vw 54px; }
.dashboard-top { display:flex; align-items:end; justify-content:space-between; gap:28px; }
.label { margin:0; color:#ff858d; font-size:10px; font-weight:800; letter-spacing:2px; }
h1 { margin:8px 0 0; color:white; font:43px/.98 "Archivo Black"; letter-spacing:-2px; }
h1 em { color:var(--red-soft); font:inherit; }
.stat-grid { display:flex; overflow:hidden; border:1px solid var(--stroke); border-radius:22px; background:rgba(255,255,255,.06); box-shadow:0 18px 46px rgba(0,0,0,.18); backdrop-filter:blur(16px); }
.stat-grid article { min-width:122px; padding:13px 15px; border-left:1px solid var(--stroke); }
.stat-grid article:first-child { border-left:0; }
.stat-grid span { display:block; color:var(--muted); font-size:8px; font-weight:800; letter-spacing:1.3px; }
.stat-grid b { display:block; margin-top:5px; color:#ff7a83; font:25px "Archivo Black"; }
.rule-bar { display:flex; align-items:center; gap:18px; margin:22px 0 14px; padding:13px 16px; border:1px solid rgba(255,255,255,.16); border-radius:22px; background:linear-gradient(135deg,rgba(229,27,43,.72),rgba(229,27,43,.32)); color:white; font-size:10px; letter-spacing:.8px; box-shadow:0 18px 42px rgba(0,0,0,.2); backdrop-filter:blur(16px); }
.rule-bar strong { padding-right:16px; border-right:1px solid rgba(255,255,255,.45); font-family:"Archivo Black"; }
.rule-bar span { flex:1; color:#ffe5e7; }
.rule-bar b { padding:6px 9px; border-radius:999px; background:rgba(0,0,0,.18); font-size:9px; letter-spacing:1px; }
.competition-grid { display:grid; grid-template-columns:minmax(0,1fr) 350px; gap:16px; align-items:start; }
.competition-grid.prediction-only { grid-template-columns:1fr; }
.match-console,.standings,.entry-card,.fixture-list { min-width:0; }
.panel-title { display:flex; justify-content:space-between; align-items:center; padding:15px 17px; color:white; border-bottom:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.045); }
.panel-title div { display:flex; align-items:center; gap:10px; }
.panel-title span { color:#ff7d85; font:20px "Archivo Black"; }
.panel-title b { font-family:"Archivo Black"; font-size:14px; letter-spacing:.7px; }
.panel-title small { color:#d3a6aa; font-size:9px; font-weight:800; letter-spacing:1.3px; }
.fixture-list {
  display:grid;
  gap:10px;
  padding:14px;
  border:1px solid var(--stroke);
  border-radius:24px;
  background:rgba(255,255,255,.06);
  box-shadow:0 22px 62px rgba(0,0,0,.22);
  backdrop-filter:blur(18px);
}
.fixture-row { display:grid; grid-template-columns:55px minmax(175px,240px) 1fr 70px; align-items:center; min-height:74px; padding:0 14px; border:1px solid rgba(255,255,255,.11); border-radius:18px; background:rgba(255,255,255,.07); transition:.15s; }
.fixture-row:hover { transform:translateY(-2px); background:rgba(255,255,255,.105); }
.fixture-row.active { position:relative; border-color:rgba(255,104,115,.55); background:linear-gradient(135deg,rgba(229,27,43,.32),rgba(255,255,255,.08)); box-shadow:0 16px 34px rgba(229,27,43,.14), inset 0 0 0 1px rgba(255,255,255,.08); }
.fixture-row time { display:grid; text-align:center; border-right:1px solid rgba(255,255,255,.12); }
.fixture-row time b { color:white; font:21px "Archivo Black"; }
.fixture-row time span { color:var(--muted); font-size:9px; font-weight:800; letter-spacing:1px; text-transform:uppercase; }
.fixture-teams { display:flex; justify-content:center; align-items:center; gap:10px; }
.fixture-teams div { display:flex; align-items:center; gap:7px; }
.fixture-teams strong { font-size:27px; filter:drop-shadow(0 5px 10px rgba(0,0,0,.2)); }
.fixture-teams .fi { width:32px; height:24px; border-radius:6px; box-shadow:0 8px 16px rgba(0,0,0,.2); }
.fixture-teams b { color:white; font:17px "Archivo Black"; }
.fixture-teams i { color:#d6b8bb; font-size:9px; font-weight:800; }
.fixture-info { display:grid; padding-left:16px; border-left:1px solid rgba(255,255,255,.12); }
.fixture-info b { color:#fff0f1; font-family:"Barlow Condensed"; font-size:20px; }
.fixture-info span { overflow:hidden; max-width:210px; color:var(--muted); font-size:10px; text-overflow:ellipsis; white-space:nowrap; }
.fixture-row em { justify-self:end; padding:6px 9px; border-radius:999px; background:rgba(229,27,43,.18); color:#ff9299; font-size:8px; font-style:normal; font-weight:800; letter-spacing:1px; }
.entry-card { margin-top:16px; overflow:hidden; border:1px solid var(--stroke); border-radius:24px; background:rgba(255,255,255,.065); color:white; box-shadow:0 24px 65px rgba(0,0,0,.25); backdrop-filter:blur(18px); }
.dark-title { background:rgba(255,255,255,.055); }
.alert { margin:12px 16px 0; padding:11px 12px; border-radius:14px; font-size:11px; font-weight:700; }
.alert p { margin:0; }
.success { background:rgba(220,255,213,.9); color:#23621d; }
.error { background:rgba(255,224,224,.94); color:#9f111b; }
.scoreboard { display:flex; justify-content:center; align-items:center; gap:17px; padding:28px 16px 22px; }
.team { display:flex; align-items:center; gap:10px; width:155px; padding:12px; border:1px solid rgba(255,255,255,.1); border-radius:18px; background:rgba(255,255,255,.045); }
.team.away { flex-direction:row-reverse; text-align:right; }
.team strong { font-size:40px; }
.team .fi { width:48px; height:36px; border-radius:8px; box-shadow:0 10px 22px rgba(0,0,0,.22); }
.team div { display:grid; }
.team b { color:white; font:23px "Archivo Black"; }
.team span { color:#d1aeb2; font-size:10px; }
.score-input input { width:68px; height:68px; border:1px solid rgba(255,255,255,.18); border-radius:18px; outline:0; background:rgba(0,0,0,.22); color:white; font:31px "Archivo Black"; text-align:center; box-shadow:inset 0 1px 18px rgba(0,0,0,.18); }
.score-input input:focus { border-color:#ff7a83; box-shadow:0 0 0 4px rgba(229,27,43,.16); }
.score-input span { display:block; margin-top:7px; color:#d1aeb2; font-size:8px; font-weight:800; letter-spacing:1px; text-align:center; }
.scoreboard>i { color:#ff747d; font:29px "Archivo Black"; }
.player-fields,.staff-card { display:grid; grid-template-columns:1fr 1fr 1.35fr; gap:9px; padding:16px; border-top:1px solid rgba(255,255,255,.1); background:rgba(0,0,0,.13); }
.player-fields span,.staff-card span { display:block; margin-bottom:5px; color:#d7aeb2; font-size:8px; font-weight:800; letter-spacing:1.2px; }
.player-fields input { width:100%; padding:12px 11px; border:1px solid rgba(255,255,255,.14); border-radius:14px; outline:0; background:rgba(0,0,0,.22); color:white; font-size:12px; }
.player-fields input:focus { border-color:#ff7a83; }
.staff-card { grid-template-columns:1fr 1fr; }
.staff-card div { padding:12px; border:1px solid rgba(255,255,255,.12); border-radius:16px; background:rgba(0,0,0,.18); }
.staff-card b { overflow:hidden; color:white; font-size:12px; text-overflow:ellipsis; white-space:nowrap; }
.locked-entry { display:grid; gap:8px; margin:16px; padding:38px 16px; border:1px solid rgba(255,255,255,.12); border-radius:20px; background:rgba(0,0,0,.14); text-align:center; }
.locked-entry b { color:#ff7880; font:22px "Archivo Black"; }
.locked-entry span { color:#d1b0b3; font-size:12px; }
.submit { display:flex; width:calc(100% - 32px); align-items:center; justify-content:space-between; margin:0 16px 16px; padding:14px 16px; border:0; border-radius:16px; cursor:pointer; background:linear-gradient(135deg,var(--red),#ff5964); color:white; box-shadow:0 16px 34px rgba(229,27,43,.24); }
.submit span { font-size:9px; font-weight:700; letter-spacing:1px; }
.submit b { font-size:11px; letter-spacing:1.5px; }
.submit:hover { background:linear-gradient(135deg,#ff5964,var(--dark-red)); }
.standings { overflow:hidden; border:1px solid var(--stroke); border-radius:24px; background:rgba(255,255,255,.065); color:white; box-shadow:0 24px 65px rgba(0,0,0,.25); backdrop-filter:blur(18px); }
.standings-title { background:linear-gradient(135deg,rgba(229,27,43,.72),rgba(229,27,43,.28)); }
.standings-title span,.standings-title small { color:white; }
.table-head,.table-row { display:grid; grid-template-columns:42px 1fr 38px 42px; align-items:center; padding:11px 13px; }
.table-head { color:#d5aeb1; font-size:8px; font-weight:800; letter-spacing:1.1px; }
.table-row { margin:0 10px 8px; min-height:54px; border:1px solid rgba(255,255,255,.09); border-radius:16px; background:rgba(255,255,255,.045); }
.table-row strong { color:#ff7b84; font:16px "Archivo Black"; }
.table-row div { display:grid; }
.table-row b { color:white; font-size:12px; }
.table-row small { margin-top:3px; color:#c4a3a6; font-size:9px; }
.table-row span { color:#e0c9cb; font-size:12px; }
.table-row em { color:#ff747d; font:17px "Archivo Black"; }
.empty-table { display:grid; gap:5px; margin:10px; padding:32px 15px; border:1px solid rgba(255,255,255,.09); border-radius:18px; background:rgba(255,255,255,.045); text-align:center; }
.empty-table b { color:#ff7c84; font:15px "Archivo Black"; }
.empty-table span { color:#c0a0a3; font-size:11px; }
.standings-note { margin:10px; padding:12px; border:1px solid rgba(255,255,255,.08); border-radius:14px; color:#c6a4a7; font-size:8px; font-weight:800; letter-spacing:1.3px; text-align:center; }
.view-all { display:grid; place-items:center; min-height:48px; margin:10px; border-radius:15px; background:linear-gradient(135deg,var(--red),#ff5964); color:white; font-size:10px; font-weight:800; letter-spacing:1.3px; }
.view-all:hover { background:linear-gradient(135deg,#ff5964,var(--dark-red)); }
.empty { padding:18px; color:#d0adb1; font-size:12px; }
footer { display:flex; justify-content:space-between; margin:0 5vw 20px; padding:16px 18px; border:1px solid var(--stroke); border-radius:20px; background:rgba(19,13,15,.56); color:#caa9ad; font-size:9px; font-weight:800; letter-spacing:1.4px; backdrop-filter:blur(18px); }
footer span { color:#ff8b92; }
footer p { margin:0; }
.login-body { min-height:100vh; background:#130d0f; color:white; }
.login-screen { min-height:100vh; display:grid; grid-template-columns:minmax(0,1fr) 420px; align-items:center; gap:22px; padding:5vw; background:radial-gradient(circle at 20% 20%, rgba(229,27,43,.26), transparent 34%), linear-gradient(135deg,#130d0f,#261014); }
.login-board { padding:36px; border:1px solid rgba(255,255,255,.1); border-radius:28px; background:rgba(255,255,255,.055); box-shadow:0 26px 80px rgba(0,0,0,.28); backdrop-filter:blur(18px); }
.login-brand { display:flex; align-items:center; gap:12px; margin-bottom:36px; }
.login-brand b { display:block; font:23px "Archivo Black"; letter-spacing:1px; }
.login-brand small { color:#e6878e; font-size:8px; font-weight:800; letter-spacing:1.8px; }
.login-board h1 { color:white; font-size:50px; }
.login-board h1 em { color:#ff6873; }
.login-copy { max-width:570px; color:#c5a9ac; font-size:14px; line-height:1.7; }
.login-rules { display:flex; flex-wrap:wrap; gap:8px; margin-top:24px; }
.login-rules span { padding:8px 10px; border-radius:999px; background:rgba(229,27,43,.16); color:#ff9aa0; font-size:9px; font-weight:800; letter-spacing:1.3px; }
.login-form { overflow:hidden; border:1px solid rgba(255,255,255,.12); border-radius:28px; background:rgba(255,255,255,.065); box-shadow:0 26px 80px rgba(0,0,0,.28); backdrop-filter:blur(18px); }
.login-form label { display:block; padding:0 16px 13px; }
.login-form label:first-of-type { padding-top:16px; }
.login-form label span { display:block; margin-bottom:6px; color:#d7aeb2; font-size:8px; font-weight:800; letter-spacing:1.2px; }
.login-form input { width:100%; min-height:46px; padding:13px 11px; border:1px solid rgba(255,255,255,.16); border-radius:14px; background:rgba(0,0,0,.22); color:white; outline:0; font-size:16px; }
.login-form input:focus { border-color:#ff7a83; }
.leaderboard-page { max-width:1320px; }
.leaderboard-hero { align-items:center; }
.leader-search { display:grid; grid-template-columns:minmax(210px,320px) auto auto; gap:8px; align-items:end; padding:12px; border:1px solid var(--stroke); border-radius:22px; background:rgba(255,255,255,.06); box-shadow:0 18px 46px rgba(0,0,0,.18); backdrop-filter:blur(16px); }
.leader-search label { grid-column:1 / -1; color:#d7aeb2; font-size:8px; font-weight:800; letter-spacing:1.4px; }
.leader-search input { min-height:46px; padding:0 13px; border:1px solid rgba(255,255,255,.16); border-radius:15px; background:rgba(0,0,0,.22); color:white; outline:0; font-size:16px; }
.leader-search input:focus { border-color:#ff7a83; }
.leader-search button,.leader-search a { min-height:46px; display:grid; place-items:center; padding:0 13px; border:0; border-radius:15px; background:linear-gradient(135deg,var(--red),#ff5964); color:white; cursor:pointer; font-size:10px; font-weight:800; letter-spacing:1.2px; }
.leader-search a { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); }
.podium { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:20px 0 16px; align-items:end; }
.podium-card { position:relative; overflow:hidden; min-height:188px; padding:22px; border:1px solid var(--stroke); border-radius:28px; background:rgba(255,255,255,.065); box-shadow:0 24px 65px rgba(0,0,0,.25); backdrop-filter:blur(18px); }
.podium-card::before { content:""; position:absolute; inset:auto -20% -45% -20%; height:120px; background:radial-gradient(circle,rgba(255,104,115,.42),transparent 68%); }
.podium-1 { min-height:222px; border-color:rgba(255,216,115,.42); background:linear-gradient(145deg,rgba(255,211,89,.16),rgba(255,255,255,.07)); }
.podium-2 { min-height:202px; }
.podium-3 { min-height:194px; }
.medal { display:inline-grid; place-items:center; min-width:50px; min-height:31px; padding:0 9px; border-radius:999px; background:rgba(229,27,43,.22); color:#ff9aa0; font:15px "Archivo Black"; }
.podium-1 .medal { background:rgba(255,211,89,.2); color:#ffd978; }
.podium-card b { display:block; margin-top:22px; color:white; font-size:18px; }
.podium-card small { display:block; margin-top:5px; color:#caa9ad; font-size:10px; }
.podium-card div { display:flex; align-items:end; gap:7px; margin-top:18px; }
.podium-card strong { color:#ff747d; font:38px/1 "Archivo Black"; }
.podium-1 strong { color:#ffd978; font-size:46px; }
.podium-card div span { color:#caa9ad; font-size:9px; font-weight:800; letter-spacing:1.2px; }
.podium-card p { margin:12px 0 0; color:#d5b6b9; font-size:11px; }
.podium-card em,.full-table-row em { display:inline-grid; place-items:center; width:max-content; min-height:22px; padding:0 8px; border-radius:999px; background:#ff747d; color:white; font-size:8px; font-style:normal; font-weight:800; letter-spacing:1px; }
.podium-card em { position:absolute; right:18px; top:18px; }
.self-player { border-color:rgba(255,104,115,.75) !important; box-shadow:0 0 0 1px rgba(255,104,115,.24),0 24px 65px rgba(229,27,43,.16) !important; }
.leaderboard-full { overflow:hidden; border:1px solid var(--stroke); border-radius:24px; background:rgba(255,255,255,.065); color:white; box-shadow:0 24px 65px rgba(0,0,0,.25); backdrop-filter:blur(18px); }
.leaderboard-full .full-table-scroll { max-height:min(62vh,680px); overflow-y:auto; overscroll-behavior:contain; padding-bottom:2px; scrollbar-color:#ff747d rgba(255,255,255,.08); scrollbar-width:thin; }
.leaderboard-full .full-table-scroll::-webkit-scrollbar { width:9px; }
.leaderboard-full .full-table-scroll::-webkit-scrollbar-track { background:rgba(255,255,255,.06); border-radius:999px; }
.leaderboard-full .full-table-scroll::-webkit-scrollbar-thumb { background:#ff747d; border-radius:999px; }
.full-table-head,.full-table-row { display:grid; grid-template-columns:70px minmax(160px,1.4fr) minmax(100px,.75fr) 82px 82px 86px; align-items:center; gap:10px; padding:12px 16px; }
.full-table-head { color:#d5aeb1; font-size:8px; font-weight:800; letter-spacing:1.2px; }
.full-table-row { margin:0 12px 10px; min-height:62px; border:1px solid rgba(255,255,255,.09); border-radius:17px; background:rgba(255,255,255,.045); }
.full-table-row strong { color:#ff7b84; font:18px "Archivo Black"; }
.full-table-row div { display:flex; align-items:center; gap:8px; min-width:0; }
.full-table-row b { overflow:hidden; color:white; font-size:13px; text-overflow:ellipsis; white-space:nowrap; }
.full-table-row span { color:#d9c0c3; font-size:12px; }
.full-table-row i { color:#ff747d; font:19px "Archivo Black"; font-style:normal; }
.podium-empty { grid-column:1 / -1; }
@media(max-width:980px){.competition-grid{grid-template-columns:1fr}.standings{order:2}.table-head,.table-row{grid-template-columns:52px 1fr 50px 50px}}
@media(max-width:860px){.login-screen{grid-template-columns:1fr}.login-board h1{font-size:39px}.user-status span{display:none}.competition-header{grid-template-columns:1fr auto}.round-title{display:none}.leaderboard-hero{display:block}.leader-search{margin-top:16px}.podium{grid-template-columns:1fr}.podium-card,.podium-1,.podium-2,.podium-3{min-height:0}.full-table-head,.full-table-row{grid-template-columns:52px 1fr 60px 62px}.full-table-head span:nth-child(3),.full-table-head span:nth-child(5),.full-table-row>span:nth-of-type(1),.full-table-row>span:nth-of-type(3){display:none}}
@media(max-width:680px){
  body { background-attachment:scroll; }
  body::before { background-size:42px 42px; }
  .competition-header { grid-template-columns:1fr auto; height:66px; margin:10px 3.5vw 0; padding:0 10px; border-radius:20px; }
  .logo { gap:8px; min-width:0; }
  .logo-number { width:38px; height:40px; border-radius:12px; font-size:20px; }
  .logo b { font-size:16px; }
  .logo small { max-width:136px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-size:7px; }
  .user-status { gap:6px; }
  .user-status i { display:none; }
  .user-status a { min-height:40px; display:grid; place-items:center; padding:0 10px; }
  .dashboard { padding:20px 3.5vw 34px; }
  .dashboard-top { display:block; }
  h1 { font-size:31px; letter-spacing:-1.4px; }
  .label { font-size:9px; }
  .stat-grid { display:grid; grid-template-columns:repeat(3,1fr); margin-top:15px; border-radius:18px; }
  .stat-grid article { min-width:0; padding:10px 8px; }
  .stat-grid span { min-height:20px; font-size:7px; line-height:1.25; }
  .stat-grid b { font-size:22px; }
  .rule-bar { display:grid; gap:7px; margin:16px 0 12px; padding:13px; border-radius:18px; }
  .rule-bar strong { border:0; padding:0; }
  .rule-bar b { display:none; }
  .panel-title { padding:12px; border-radius:18px 18px 0 0; }
  .panel-title div { min-width:0; }
  .panel-title span { font-size:17px; }
  .panel-title b { font-size:12px; }
  .panel-title small { max-width:118px; overflow:hidden; text-align:right; text-overflow:ellipsis; white-space:nowrap; font-size:8px; }
  .fixture-list { gap:9px; padding:10px; border-radius:20px; }
  .fixture-row { grid-template-columns:42px minmax(0,1fr) 54px; min-height:70px; padding:0 8px; border-radius:16px; }
  .fixture-info { display:none; }
  .fixture-row time b { font-size:18px; }
  .fixture-row time span { font-size:8px; }
  .fixture-teams { gap:7px; min-width:0; }
  .fixture-teams div { gap:5px; min-width:0; }
  .fixture-teams strong { font-size:22px; }
  .fixture-teams .fi { width:28px; height:21px; border-radius:5px; }
  .fixture-teams b { font-size:15px; }
  .fixture-row em { padding:6px 7px; font-size:7px; }
  .entry-card,.standings { border-radius:20px; }
  .scoreboard { display:grid; grid-template-columns:1fr 58px 16px 58px 1fr; gap:6px; padding:18px 10px 16px; }
  .team { display:grid; align-content:center; width:auto; min-width:0; min-height:78px; gap:1px; padding:8px 5px; text-align:center; }
  .team.away { display:grid; text-align:center; }
  .team strong { font-size:30px; }
  .team .fi { width:38px; height:29px; margin:auto; }
  .team b { font-size:18px; }
  .team span { display:none; }
  .score-input input { width:58px; height:58px; border-radius:16px; font-size:28px; }
  .scoreboard>i { font-size:24px; text-align:center; }
  .staff-card { grid-template-columns:1fr; padding:10px; }
  .staff-card div { padding:11px; border-radius:14px; }
  .submit { width:calc(100% - 20px); min-height:50px; margin:0 10px 10px; border-radius:15px; }
  .submit span { font-size:8px; }
  .table-head,.table-row { grid-template-columns:40px 1fr 38px 44px; padding:10px; }
  .table-row { margin:0 8px 8px; }
  .table-row b { font-size:12px; }
  .standings-note { margin:8px; }
  footer { display:grid; gap:7px; margin:0 3.5vw 14px; padding:14px; border-radius:18px; text-align:center; }
  .login-screen { display:grid; align-content:start; min-height:100svh; padding:14px 3.5vw 28px; }
  .login-board { padding:22px 18px; border-radius:24px; }
  .login-brand { margin-bottom:24px; }
  .login-brand b { font-size:20px; }
  .login-board h1 { font-size:34px; letter-spacing:-1px; }
  .login-copy { font-size:13px; line-height:1.6; }
  .login-rules { gap:6px; }
  .login-rules span { font-size:8px; }
  .login-form { min-width:0; border-radius:24px; }
  .login-form label { padding-inline:14px; }
  .login-form .submit { width:calc(100% - 28px); margin-inline:14px; }
  .leader-search { grid-template-columns:1fr auto; padding:10px; border-radius:18px; }
  .leader-search input { grid-column:1 / -1; }
  .leader-search button,.leader-search a { min-height:44px; }
  .podium { gap:10px; margin-top:14px; }
  .podium-card { padding:18px; border-radius:22px; }
  .podium-card b { margin-top:16px; font-size:16px; }
  .podium-card strong,.podium-1 strong { font-size:34px; }
  .leaderboard-full { border-radius:20px; }
  .leaderboard-full .full-table-scroll { max-height:58vh; }
  .full-table-head,.full-table-row { grid-template-columns:40px 1fr 42px 48px; gap:7px; padding:10px; }
  .full-table-row { margin:0 8px 8px; }
  .full-table-row b { font-size:12px; }
  .full-table-row i { font-size:17px; }
}
@media(max-width:420px){
  .competition-header { height:62px; }
  .logo small { display:none; }
  h1 { font-size:27px; }
  .stat-grid { gap:0; }
  .fixture-row { grid-template-columns:38px 1fr; grid-template-areas:"date teams" "date action"; row-gap:3px; min-height:86px; padding:9px; }
  .fixture-row time { grid-area:date; align-self:stretch; place-content:center; padding-right:7px; }
  .fixture-teams { grid-area:teams; justify-content:space-around; }
  .fixture-row em { grid-area:action; justify-self:center; }
  .scoreboard { grid-template-columns:1fr 54px 12px 54px 1fr; padding-inline:8px; }
  .score-input input { width:54px; height:56px; }
  .team { min-height:72px; }
  .team strong { font-size:28px; }
  .team b { font-size:16px; }
  .login-board h1 { font-size:30px; }
}
