
:root{
  --bg:#050805;
  --bg2:#08120d;
  --panel:#0c1511;
  --panel2:#101b16;
  --card:#0f1a15;
  --gold:#d4af37;
  --gold2:#ffe07a;
  --green:#17c964;
  --green2:#0f8f46;
  --white:#ffffff;
  --text:#f8fafc;
  --muted:#b6c2bb;
  --line:rgba(212,175,55,.30);
  --danger:#ef4444;
  --warning:#facc15;
  --shadow:0 22px 65px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,Helvetica,sans-serif;
  background:
    radial-gradient(circle at top left, rgba(23,201,100,.20), transparent 34%),
    radial-gradient(circle at top right, rgba(212,175,55,.18), transparent 26%),
    linear-gradient(135deg,var(--bg),#020403 70%);
  color:var(--text);
}
body::before{
  content:"";
  position:fixed; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:42px 42px;
  pointer-events:none;
}
.public-nav{
  position:sticky; top:0; z-index:50;
  display:flex; gap:8px; justify-content:center; flex-wrap:wrap;
  padding:12px;
  background:rgba(5,8,5,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.public-nav a{
  color:var(--text); text-decoration:none; font-weight:800;
  padding:9px 13px; border-radius:999px;
  border:1px solid transparent;
}
.public-nav a:hover{
  color:var(--gold2); border-color:var(--line); background:rgba(212,175,55,.08);
}
.hero{
  min-height:430px;
  display:flex; align-items:center; justify-content:center; text-align:center;
  padding:65px 18px 95px;
  color:var(--white);
  background:
    linear-gradient(rgba(5,8,5,.55), rgba(5,8,5,.9)),
    radial-gradient(circle at center, rgba(23,201,100,.30), rgba(212,175,55,.14) 35%, transparent 60%);
}
.hero-overlay{max-width:980px; position:relative}
.portal-logo{
  width:116px;height:116px;object-fit:contain;margin:0 auto 16px;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.45));
}
.tag{
  display:inline-block;
  padding:8px 16px;
  border:1px solid var(--line);
  border-radius:999px;
  background:linear-gradient(135deg,rgba(212,175,55,.18),rgba(23,201,100,.10));
  color:var(--gold2);
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
h1{
  font-size:clamp(40px,7vw,84px);
  line-height:.95;
  margin:14px 0;
  letter-spacing:-.04em;
  text-shadow:0 4px 20px rgba(0,0,0,.55);
}
.hero p{
  color:#e7eee9;
  font-size:clamp(16px,2.2vw,20px);
  max-width:760px;
  margin:0 auto;
}
.hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:26px}
.btn,button{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  background:linear-gradient(135deg,var(--green),var(--green2));
  color:#fff;
  border:1px solid rgba(255,255,255,.10);
  border-radius:14px;
  padding:13px 18px;
  font-weight:900;
  text-decoration:none;
  cursor:pointer;
  font-size:15px;
  box-shadow:0 12px 30px rgba(23,201,100,.16);
}
button{width:100%;margin:8px 0}
.btn:hover,button:hover{filter:brightness(1.05); transform:translateY(-1px)}
.btn-outline{
  background:rgba(255,255,255,.04);
  border:1px solid var(--gold);
  color:var(--gold2);
  box-shadow:none;
}
.btn-secondary{background:linear-gradient(135deg,#2563eb,#1e40af)}
.btn-dark{background:linear-gradient(135deg,#1f2937,#111827)}
.container{
  position:relative;
  width:min(1220px,calc(100% - 28px));
  margin:-58px auto 45px;
}
.status-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  margin-bottom:18px;
}
.stat-card,.card{
  background:linear-gradient(145deg,rgba(15,26,21,.96),rgba(5,8,5,.94));
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow);
}
.stat-card{
  padding:22px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  min-height:128px;
  text-align:center;
}
.stat-card span{
  display:block;
  font-size:42px;
  line-height:1;
  font-weight:950;
  color:var(--gold2);
  text-shadow:0 8px 22px rgba(212,175,55,.18);
}
.stat-card small{color:var(--muted);font-weight:900;margin-top:7px;text-transform:uppercase;font-size:12px}
.card{padding:24px;margin-bottom:18px}
.section-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;margin-bottom:18px;
}
.section-head h2{
  margin:0;
  font-size:clamp(24px,3vw,32px);
  color:var(--text);
}
.section-head p{margin:0;color:var(--muted);max-width:580px}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.table-wrap{overflow-x:auto; border-radius:16px; border:1px solid rgba(255,255,255,.06)}
table{width:100%;border-collapse:collapse;min-width:760px;background:rgba(255,255,255,.02)}
th,td{
  padding:14px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  text-align:left;
  vertical-align:middle;
  color:var(--text);
}
th{
  background:rgba(212,175,55,.13);
  color:#fff6c9;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.05em;
}
td strong{color:#fff}
.pos{text-align:center;font-weight:950;color:var(--green)}
.positivo{color:#3dff8c;font-weight:900}
.negativo{color:#ff6b6b;font-weight:900}
.team-cell,.team-line,.match-line{
  display:flex; align-items:center; gap:10px;
}
.team-logo,.team-logo-sm{
  flex:0 0 auto;
  width:34px;height:34px;border-radius:50%;
  object-fit:cover;
  border:1px solid var(--gold);
  background:#101820;
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--gold2); font-weight:950; font-size:12px;
}
.team-logo-sm{width:28px;height:28px;font-size:10px}
.match-list{display:grid;gap:12px}
.match{
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  padding:16px;
  background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
}
.match strong{display:block;font-size:17px;margin-bottom:6px;color:#fff}
.match small{color:var(--muted);line-height:1.45}
.score{
  display:inline-block;
  background:linear-gradient(135deg,var(--gold2),var(--gold));
  color:#111827;
  border-radius:999px;
  padding:7px 14px;
  font-weight:950;
  margin-top:9px;
}
.badge{display:inline-block;padding:6px 11px;border-radius:999px;font-size:12px;font-weight:950}
.badge.amarilla{background:#facc15;color:#241a00}
.badge.roja{background:#ef4444;color:#fff}
input,select{
  width:100%;
  padding:14px 15px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#07110c;
  color:#fff;
  font-size:15px;
  margin:8px 0;
  outline:none;
}
input::placeholder{color:#9fb0a7}
select option{background:#07110c;color:#fff}
.acciones-inline{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.scanner-box{
  min-height:42px;
  margin-top:10px;
  border:2px dashed var(--line);
  border-radius:18px;
  padding:10px;
  background:rgba(255,255,255,.03);
}
.alert{padding:13px 15px;border-radius:14px;margin:10px 0;font-weight:900;border:1px solid transparent}
.alert-ok{background:rgba(23,201,100,.15);color:#d1ffe2;border-color:rgba(23,201,100,.3)}
.alert-error{background:rgba(239,68,68,.14);color:#fecaca;border-color:rgba(239,68,68,.35)}
.alert-warning{background:rgba(250,204,21,.14);color:#fff2a6;border-color:rgba(250,204,21,.35)}
.oculto{display:none!important}
.credential-empty{
  min-height:280px;
  border:2px dashed var(--line);
  border-radius:20px;
  padding:22px;
  color:var(--muted);
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  background:rgba(255,255,255,.03);
}
.credencial-digital{
  background:linear-gradient(180deg,#ffffff,#f3fff7);
  color:#111827;
  border-radius:28px;
  overflow:hidden;
  border:2px solid var(--gold);
  max-width:410px;
  margin:0 auto 18px;
  box-shadow:0 24px 70px rgba(0,0,0,.42);
}
.credencial-header{
  background:linear-gradient(135deg,#07110c,#1f2a13);
  color:#fff;
  text-align:center;
  padding:18px 14px;
  border-bottom:3px solid var(--gold);
}
.credencial-header h3{margin:4px 0 0;font-size:24px;color:#fff}
.credencial-header p{margin:3px 0 0;color:#f8fafc}
.credencial-logo-public{width:68px;height:68px;object-fit:contain;margin:0 auto 6px;display:block}
.foto-jugador,.foto-placeholder{
  width:138px;height:138px;border-radius:50%;
  margin:24px auto 12px;
  border:5px solid var(--gold);
  box-shadow:0 18px 35px rgba(0,0,0,.18);
}
.foto-jugador{object-fit:cover;display:block;background:#f3f4f6}
.foto-placeholder{
  display:flex;align-items:center;justify-content:center;
  color:#111827;background:#f8fafc;font-size:44px;font-weight:950;
}
.credencial-body{text-align:center;padding:0 24px 24px}
.credencial-body h2{font-size:28px;margin:10px 0;color:#111827}
.credencial-body p{color:#1f2937}
.numero{
  display:inline-block;
  background:linear-gradient(135deg,var(--gold2),var(--gold));
  color:#111827;
  border-radius:999px;
  padding:8px 15px;
  font-weight:950;
}
.mini-stats{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:8px;
  margin-top:16px;
}
.mini-stats div{
  background:#f1f5f9;
  border:1px solid #e5e7eb;
  border-radius:14px;
  padding:10px 6px;
}
.mini-stats strong{display:block;color:#111827;font-size:19px}
.mini-stats small{color:#475569;font-weight:800}
.historial-publico{margin-top:18px}
.historial-publico h3{color:#fff;margin:22px 0 10px}
.asistencia-si{color:#3dff8c;font-weight:900}
.asistencia-no{color:#ff5c7a;font-weight:900}
.asistencia-pendiente{color:#ffe07a;font-weight:900}
.player-grid-public{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:14px;
  margin-top:16px;
}
.player-card-public{
  display:flex;
  gap:14px;
  align-items:center;
  border:1px solid rgba(255,255,255,.10);
  border-radius:20px;
  background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.025));
  padding:15px;
}
.player-card-public h3{margin:0 0 4px;color:#fff}
.player-card-public p{margin:3px 0;color:var(--muted)}
.player-avatar-public{
  width:72px;height:72px;border-radius:50%;
  object-fit:cover;
  flex:0 0 auto;
  display:flex; align-items:center; justify-content:center;
  background:#f8fafc;
  color:#111827;
  border:3px solid var(--green);
  font-weight:950;
  font-size:23px;
}
.player-card-public button{padding:10px 12px;margin-top:8px;font-size:13px}
.bracket-publico{
  overflow-x:auto;
  padding:8px 2px 4px;
}
.bracket-rounds{
  display:grid;
  grid-template-columns:repeat(3,minmax(240px,1fr));
  gap:18px;
  min-width:760px;
}
.bracket-round{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  padding:14px;
}
.bracket-round h3{
  margin:0 0 12px;
  color:var(--gold2);
  text-transform:uppercase;
  font-size:14px;
  letter-spacing:.08em;
}
.bracket-match{
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px;
  margin-bottom:10px;
  background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
}
.bracket-team{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:8px;border-radius:12px;
}
.bracket-team.winner{background:rgba(23,201,100,.14);border:1px solid rgba(23,201,100,.26)}
.bracket-team.eliminated{opacity:.55}
.bracket-team-name{display:flex;align-items:center;gap:8px}
.bracket-status{color:var(--gold2);font-weight:950;font-size:12px}
footer{
  color:var(--muted);
  text-align:center;
  padding:25px 18px 35px;
  border-top:1px solid var(--line);
  background:rgba(0,0,0,.25);
}
@media (max-width:900px){
  .status-grid{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
  .section-head{display:block}
  .section-head p{margin-top:6px}
}
@media (max-width:640px){
  .public-nav{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap}
  .public-nav a{white-space:nowrap;font-size:13px}
  .hero{padding-top:40px;min-height:390px}
  .container{width:min(100% - 18px,1220px);margin-top:-42px}
  .status-grid{grid-template-columns:1fr 1fr;gap:10px}
  .stat-card{padding:16px;min-height:100px}
  .stat-card span{font-size:32px}
  .card{padding:16px;border-radius:18px}
  .mini-stats{grid-template-columns:repeat(2,1fr)}
  .acciones-inline{grid-template-columns:1fr}
  table{min-width:0}
  .table-wrap{border:none;overflow:visible}
  .card table,.card thead,.card tbody,.card th,.card td,.card tr{display:block}
  .card thead{display:none}
  .card tr{
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.08);
    border-radius:16px;
    margin-bottom:10px;
    padding:10px;
  }
  .card td{
    display:flex;
    justify-content:space-between;
    gap:12px;
    border-bottom:1px solid rgba(255,255,255,.06);
    padding:10px 4px;
  }
  .card td:last-child{border-bottom:none}
  .card td::before{
    content:attr(data-label);
    color:var(--gold2);
    font-weight:950;
    margin-right:12px;
  }
  .player-grid-public{grid-template-columns:1fr}
  .player-card-public{align-items:flex-start}
}


.football-ambient{position:fixed;z-index:0;pointer-events:none;opacity:.12;filter:drop-shadow(0 10px 18px rgba(0,0,0,.35));animation:floatBall 11s ease-in-out infinite}
.football-ambient-1{left:2%;top:18%;font-size:28px;animation-delay:0s}
.football-ambient-2{right:3%;top:64%;font-size:34px;animation-delay:2s}
.football-ambient-3{right:8%;top:28%;font-size:48px;color:var(--gold2);opacity:.16;animation-duration:9s}
.hero-mini-live,.bracket-live-badge{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(23,201,100,.22);background:rgba(255,255,255,.04);padding:10px 14px;border-radius:999px;color:#dff7e9;font-weight:800;backdrop-filter:blur(10px)}
.hero-mini-live{margin-top:16px}
.section-head-bracket{align-items:flex-start}
.live-dot{width:10px;height:10px;border-radius:50%;background:#32ff88;box-shadow:0 0 0 rgba(50,255,136,.75);animation:pulseLive 1.8s infinite}
.bracket-card{overflow:hidden}
.bracket-publico{overflow:auto;padding:12px 4px 8px;position:relative}
.bracket-stage{position:relative;min-width:860px;padding:4px 6px 8px}
.bracket-svg{position:absolute;inset:0;z-index:1;overflow:visible;pointer-events:none}
.path-line{fill:none;stroke:url(#bracketGlow);stroke-width:4;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 8px rgba(50,255,136,.42));stroke-dasharray:12 8;animation:dashMove 8s linear infinite}
.path-line-soft{fill:none;stroke:rgba(255,224,122,.18);stroke-width:8;stroke-linecap:round;stroke-linejoin:round;filter:blur(2px)}
.bracket-rounds{display:grid;grid-template-columns:repeat(3,minmax(240px,1fr));gap:18px;min-width:820px;position:relative;z-index:2}
.bracket-round{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:14px;position:relative}
.bracket-round::before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(180deg,rgba(23,201,100,.04),transparent 25%,rgba(212,175,55,.03));pointer-events:none}
.bracket-round h3{position:relative;z-index:1}
.bracket-match{position:relative;border:1px solid var(--line);border-radius:18px;padding:12px;margin-bottom:14px;background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));box-shadow:0 10px 24px rgba(0,0,0,.18);transition:transform .25s ease,border-color .25s ease}
.bracket-match:hover{transform:translateY(-2px);border-color:rgba(212,175,55,.5)}
.bracket-match.match-live{animation:cardPulse 2.4s ease-in-out infinite}
.bracket-team{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px;border-radius:12px;transition:all .25s ease}
.bracket-team.winner{background:linear-gradient(90deg,rgba(23,201,100,.20),rgba(23,201,100,.08));border:1px solid rgba(23,201,100,.28);box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
.bracket-team.winner .bracket-status{animation:winnerGlow 1.8s ease-in-out infinite}
.bracket-team.eliminated{opacity:.55;filter:saturate(.7)}
.bracket-team-name{display:flex;align-items:center;gap:8px}
.bracket-status{color:var(--gold2);font-weight:950;font-size:12px}
.bracket-footnote{font-size:11px;color:var(--muted);margin-top:6px}
@keyframes pulseLive{0%{box-shadow:0 0 0 0 rgba(50,255,136,.7)}70%{box-shadow:0 0 0 12px rgba(50,255,136,0)}100%{box-shadow:0 0 0 0 rgba(50,255,136,0)}}
@keyframes dashMove{to{stroke-dashoffset:-240}}
@keyframes floatBall{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-14px) rotate(10deg)}}
@keyframes winnerGlow{0%,100%{transform:scale(1);text-shadow:0 0 0 rgba(255,224,122,.2)}50%{transform:scale(1.06);text-shadow:0 0 12px rgba(255,224,122,.5)}}
@keyframes cardPulse{0%,100%{box-shadow:0 10px 24px rgba(0,0,0,.18)}50%{box-shadow:0 0 0 1px rgba(23,201,100,.16),0 16px 34px rgba(23,201,100,.14)}}
@media (max-width:900px){
  .section-head-bracket{gap:10px}
  .bracket-live-badge,.hero-mini-live{font-size:12px;padding:8px 12px}
  .bracket-stage{min-width:100%;padding:0}
  .bracket-svg{display:none}
  .bracket-rounds{min-width:100%;grid-template-columns:1fr;gap:14px}
  .bracket-round{padding:14px}
  .bracket-match{margin-bottom:12px}
}


/* Ajustes V2.2: responsive credencial/historial y limpieza visual */
.football-ambient{display:none !important}
body::after{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 20%,rgba(23,201,100,.12),transparent 28%),radial-gradient(circle at 84% 22%,rgba(212,175,55,.10),transparent 26%),radial-gradient(circle at 50% 90%,rgba(23,201,100,.08),transparent 32%);z-index:0}
.public-nav,.hero,.container,footer{position:relative;z-index:1}
#resultadoCredencial{min-width:0;overflow:hidden}
.credential-empty{overflow:hidden}
.credencial-digital{width:100%;max-width:min(410px,100%);}
.credencial-body{min-width:0;overflow:hidden}
.credencial-body h2{overflow-wrap:anywhere;word-break:normal;hyphens:auto;line-height:1.12;padding:0 4px}
.credencial-body p{overflow-wrap:anywhere}
.historial-publico{width:100%;min-width:0;overflow:hidden}
.historial-publico .table-wrap{max-width:100%;overflow-x:auto}
.historial-publico table{width:100%}
.btn-ver-todos{margin-top:12px;width:100%;background:linear-gradient(135deg,rgba(212,175,55,.95),rgba(255,224,122,.88));color:#111827;border:1px solid rgba(255,224,122,.55);box-shadow:0 14px 28px rgba(212,175,55,.12)}
.btn-ver-todos:hover{filter:brightness(1.05)}
.match-list .match:nth-child(n+5){animation:fadeInResult .25s ease both}
@keyframes fadeInResult{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:900px){
  #credencialActiva .grid-2{grid-template-columns:1fr}
  #resultadoCredencial{width:100%}
  .credencial-digital{margin-left:auto;margin-right:auto}
}
@media (max-width:640px){
  .credencial-digital{border-radius:22px}
  .credencial-header{padding:15px 10px}
  .credencial-header h3{font-size:20px;line-height:1.15}
  .foto-jugador,.foto-placeholder{width:116px;height:116px;margin:18px auto 10px;font-size:34px;border-width:4px}
  .credencial-body{padding:0 14px 18px}
  .credencial-body h2{font-size:22px;margin:8px 0 6px}
  .credencial-body p{font-size:14px;margin:7px 0}
  .numero{padding:7px 13px}
  .mini-stats{grid-template-columns:1fr 1fr;gap:8px}
  .mini-stats div{padding:9px 6px}
  .mini-stats strong{font-size:17px}
  .mini-stats small{font-size:12px}
  .historial-publico h3{font-size:18px;margin:18px 0 10px}
  .historial-publico .card td,.historial-publico td{font-size:13px;align-items:flex-start;text-align:right;overflow-wrap:anywhere}
  .historial-publico .team-line{justify-content:flex-end;text-align:right;flex-wrap:wrap}
  .match-line{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
  .match-line .team-line{max-width:100%}
}
@media (max-width:420px){
  .container{width:calc(100% - 12px)}
  .card{padding:12px}
  .credencial-body h2{font-size:20px}
  .mini-stats{grid-template-columns:1fr}
}

/* V2.1.1 Ajuste visual de líneas del mapa inteligente */
.bracket-stage{isolation:isolate;padding:10px 12px 14px !important;}
.bracket-svg{z-index:0 !important;opacity:.72 !important;}
.bracket-rounds{z-index:3 !important;gap:34px !important;}
.bracket-round{background:linear-gradient(180deg,rgba(15,26,21,.98),rgba(5,8,5,.98)) !important;z-index:4 !important;}
.bracket-match{background:linear-gradient(135deg,rgba(16,27,22,.99),rgba(8,18,13,.99)) !important;z-index:6 !important;box-shadow:0 14px 32px rgba(0,0,0,.38) !important;}
.bracket-match::before{content:"";position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(135deg,rgba(23,201,100,.09),rgba(212,175,55,.06));z-index:-1;}
.path-line{stroke-width:3 !important;opacity:.55 !important;filter:none !important;}
.path-line-soft{stroke-width:10 !important;opacity:.18 !important;}
.bracket-match.match-tiebreak{border-color:rgba(212,175,55,.62) !important;box-shadow:0 0 0 1px rgba(212,175,55,.18),0 14px 32px rgba(0,0,0,.38) !important;}
.bracket-match.match-tiebreak .bracket-status{color:#ffe07a !important;}
@media (max-width:900px){.bracket-rounds{gap:14px !important}.bracket-stage{padding:0 !important}}

/* === Portal público animado: hero premium === */
.hero{
  position:relative;
  overflow:hidden;
  min-height:520px;
  padding:78px 18px 125px;
}
.hero::before{
  content:"";
  position:absolute;
  inset:-20% -10%;
  background:
    radial-gradient(circle at 18% 28%, rgba(23,201,100,.20), transparent 22%),
    radial-gradient(circle at 78% 22%, rgba(212,175,55,.18), transparent 20%),
    radial-gradient(circle at 50% 88%, rgba(255,255,255,.06), transparent 26%);
  animation:heroShift 16s ease-in-out infinite alternate;
  pointer-events:none;
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, transparent 0%, rgba(255,255,255,.05) 48%, transparent 100%);
  transform:translateX(-120%);
  animation:heroSweep 9s ease-in-out infinite;
  pointer-events:none;
}
.hero-overlay{z-index:2; animation:fadeSlideUp .9s ease both;}
.hero-bg-orb{
  position:absolute; border-radius:50%; filter:blur(8px); opacity:.55; pointer-events:none;
}
.orb-1{width:260px; height:260px; left:-40px; top:70px; background:radial-gradient(circle, rgba(23,201,100,.55), rgba(23,201,100,0)); animation:floatOrb 13s ease-in-out infinite;}
.orb-2{width:220px; height:220px; right:8%; top:80px; background:radial-gradient(circle, rgba(212,175,55,.32), rgba(212,175,55,0)); animation:floatOrb 16s ease-in-out infinite reverse;}
.orb-3{width:320px; height:320px; right:-60px; bottom:-50px; background:radial-gradient(circle, rgba(255,255,255,.12), rgba(255,255,255,0)); animation:floatOrb 18s ease-in-out infinite;}
.hero-spotlight{
  position:absolute; left:50%; top:-80px; transform:translateX(-50%);
  width:560px; height:560px; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.11), rgba(255,255,255,0) 62%);
  pointer-events:none; filter:blur(4px);
}
.logo-stage{position:relative; width:132px; height:132px; margin:0 auto 18px; display:flex; align-items:center; justify-content:center;}
.logo-ring{
  position:absolute; inset:0; border-radius:50%;
  border:1px solid rgba(255,255,255,.24); box-shadow:0 0 0 6px rgba(255,255,255,.04), 0 0 24px rgba(23,201,100,.18);
  animation:ringPulse 3.8s ease-in-out infinite;
}
.logo-ring-2{inset:10px; border-color:rgba(212,175,55,.35); animation-delay:1.3s;}
.portal-logo{position:relative; z-index:2; width:100px; height:100px; border-radius:50%; background:rgba(255,255,255,.08); padding:10px; backdrop-filter:blur(10px);}
.hero-badges{display:flex; justify-content:center; gap:10px; flex-wrap:wrap; margin-top:22px;}
.hero-badge{
  display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14); color:#fff; font-size:13px; font-weight:800;
  box-shadow:0 10px 24px rgba(0,0,0,.15); backdrop-filter:blur(10px); animation:badgeFloat 8s ease-in-out infinite;
}
.hero-badge:nth-child(2){animation-delay:1.1s}
.hero-badge:nth-child(3){animation-delay:2.2s}
.scroll-cue{
  display:inline-flex; flex-direction:column; align-items:center; gap:4px; margin-top:26px; text-decoration:none;
  color:#fff; opacity:.92; font-weight:700; font-size:13px;
}
.scroll-cue strong{font-size:28px; line-height:1; animation:bounceDown 1.8s ease-in-out infinite;}
.hero-mini-live{animation:fadeSlideUp 1s ease both .2s;}
.public-nav{animation:fadeSlideDown .6s ease both;}
.card,.stat-card,.match,.player-card-public,.section-head,.table-wrap{transition:transform .25s ease, box-shadow .25s ease;}
.card:hover,.stat-card:hover,.match:hover,.player-card-public:hover{transform:translateY(-3px); box-shadow:0 20px 42px rgba(0,0,0,.22);}
.reveal-on-scroll{opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s ease;}
.reveal-on-scroll.is-visible{opacity:1; transform:none;}
.status-grid .stat-card:nth-child(1){animation:fadeSlideUp .7s ease both .05s}
.status-grid .stat-card:nth-child(2){animation:fadeSlideUp .7s ease both .15s}
.status-grid .stat-card:nth-child(3){animation:fadeSlideUp .7s ease both .25s}
.status-grid .stat-card:nth-child(4){animation:fadeSlideUp .7s ease both .35s}
@keyframes heroSweep{0%{transform:translateX(-120%)}45%,100%{transform:translateX(140%)}}
@keyframes heroShift{0%{transform:translateY(0) scale(1)}100%{transform:translateY(20px) scale(1.03)}}
@keyframes floatOrb{0%,100%{transform:translate(0,0)}50%{transform:translate(18px,-18px)}}
@keyframes ringPulse{0%,100%{transform:scale(1); opacity:.75}50%{transform:scale(1.06); opacity:1}}
@keyframes badgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes bounceDown{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}
@keyframes fadeSlideUp{0%{opacity:0; transform:translateY(22px)}100%{opacity:1; transform:none}}
@keyframes fadeSlideDown{0%{opacity:0; transform:translateY(-14px)}100%{opacity:1; transform:none}}
@media (max-width:900px){
  .hero{min-height:500px; padding:72px 16px 110px;}
  .hero-badges{gap:8px}
  .hero-badge{font-size:12px; padding:9px 12px}
  .logo-stage{width:116px; height:116px}
  .portal-logo{width:88px; height:88px}
  .scroll-cue{margin-top:20px}
}
@media (max-width:640px){
  .hero{min-height:480px; padding:66px 14px 95px;}
  .hero-badges{flex-direction:column; align-items:center}
  .hero-badge{width:min(100%,310px); justify-content:center}
  .hero p{padding:0 4px}
  .scroll-cue span{font-size:12px}
  .hero-mini-live{font-size:12px}
}
