/* ── VARIABLES ─────────────────────────────────────────────── */
:root{
  --brand:#1A7FD4;--brand-d:#1260A8;--brand-l:#4DC3F7;
  --red:#D42B2B;--red-l:#FF6B6B;
  --dark:#08112B;--dark2:#0C1835;--dark3:#112040;--dark4:#162650;
  --text:#F0F4FF;--muted:#7A9AC5;--dim:#3A5A8A;
  --border:rgba(26,127,212,.18);--borderB:rgba(26,127,212,.38);
  --card:#0E1E3A;--surface:#0C1835;--radius:5px;
  --fd:'Bebas Neue',sans-serif;--fb:'DM Sans',sans-serif;
}

/* ── TEMA CLARO ─────────────────────────────────────────────── */
body.light{
  --brand:#1260A8;--brand-d:#0D4D8A;--brand-l:#1A7FD4;
  --red:#B71C1C;--red-l:#D42B2B;
  --dark:#F4F7FB;--dark2:#E8EDF5;--dark3:#FFFFFF;--dark4:#DDE4EF;
  --text:#0D1B2E;--muted:#4A6080;--dim:#8BA3C0;
  --border:rgba(26,100,180,.18);--borderB:rgba(26,100,180,.35);
  --card:#FFFFFF;--surface:#F4F7FB;
  background:#F4F7FB;color:#0D1B2E;
}
body.light ::-webkit-scrollbar-track{background:#E8EDF5}
body.light ::-webkit-scrollbar-thumb{background:#1A7FD4}
body.light nav{background:rgba(255,255,255,.88);border-bottom:1px solid var(--border)}
body.light .mob-menu{background:rgba(244,247,251,.98)}
body.light .overlay,.light .modal{background:rgba(255,255,255,.98)}
body.light .btn{color:#0D1B2E}
body.light .btn-cancel{background:#E8EDF5;color:#4A6080;border-color:var(--border)}
body.light .btn-cancel:hover{background:#DDE4EF}
body.light .btn-sm{background:rgba(26,100,180,.08);color:var(--brand)}
body.light .btn-danger{background:rgba(180,26,26,.08);color:var(--red)}
body.light .t-card{background:#FFFFFF;border-color:var(--border)}
body.light .t-card.pasado{background:#F4F7FB}
body.light .modal{background:#FFFFFF;border:1px solid var(--border);box-shadow:0 8px 40px rgba(0,0,0,.15)}
body.light input,body.light select,body.light textarea{background:#FFFFFF;color:#0D1B2E;border-color:var(--border)}
body.light input::placeholder{color:var(--dim)}
body.light .det-tab{background:#E8EDF5;color:var(--muted);border-color:var(--border)}
body.light .det-tab.active{background:var(--brand);color:#fff;border-color:var(--brand)}
body.light .cuadro-match{background:#F4F7FB;border-color:var(--border)}
body.light .cuadro-grupo-header{background:#E8EDF5}
body.light .cuadro-score-btn,body.light .cuadro-score-static{background:#FFFFFF;border-color:var(--border);color:#0D1B2E}
body.light .assign-row{background:#F4F7FB;border-color:var(--border)}
body.light .assign-row.asignada{background:#E8EDF5}

/* ── HERO tema claro: foto con overlay claro azulado ─────────── */
body.light #hero{
  background:
    linear-gradient(rgba(220,235,255,.72), rgba(200,222,255,.80)),
    url('../../uploads/cancha-bg.jpg') center center/cover no-repeat;
  color:#0D1B2E;
}
body.light #hero .sec-label{color:#1260A8}
body.light #hero .sec-title{color:#0D1B2E}
body.light #hero .hero-sub,
body.light #hero p{color:#1A3A5C}
body.light .hero-bg{display:none}
/* Nav claro */
body.light nav{background:rgba(238,244,255,.92);border-bottom:1px solid rgba(26,100,180,.15)}
body.light nav .nav-links a{color:#3A5A8A}
body.light nav .nav-links a:hover{color:#1260A8}
body.light nav .nav-logo-text .t1{color:#0D1B2E}
body.light nav .nav-logo-text .t2{color:#1260A8}
body.light nav .nav-ham span{background:#0D1B2E}
body.light .mob-menu{background:rgba(238,244,255,.98)}
body.light .mob-menu a{color:#3A5A8A;border-color:rgba(26,100,180,.15)}
body.light .nav-login-btn{border-color:rgba(26,100,180,.25);color:#3A5A8A}
body.light .nav-admin-badge{background:rgba(18,96,168,.1);border-color:rgba(18,96,168,.3);color:#1260A8}
body.light .nav-cta{background:#1260A8}

/* botón toggle */
.theme-toggle{
  background:none;border:1px solid var(--border);color:var(--muted);
  font-size:.78rem;padding:5px 10px;border-radius:var(--radius);
  cursor:pointer;transition:all .2s;line-height:1;
}
.theme-toggle:hover{border-color:var(--brand);color:var(--brand)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--dark);color:var(--text);font-family:var(--fb);font-weight:300;line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
button,input,select,textarea{font-family:var(--fb)}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--dark2)}
::-webkit-scrollbar-thumb{background:#1A4B8A;border-radius:4px}

/* ── NAV ────────────────────────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:60px;background:rgba(3,10,28,.72);backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-logo img{height:30px;object-fit:contain}
.nav-logo-text{display:flex;flex-direction:column;line-height:1.1}
.nav-logo-text .t1{font-size:.95rem;letter-spacing:3px;color:#fff;font-family:var(--fd)}
.nav-logo-text .t2{font-size:.62rem;letter-spacing:3px;color:var(--brand-l);font-weight:400}
.nav-links{display:flex;gap:1.8rem;list-style:none}
.nav-links a{font-size:.78rem;font-weight:400;letter-spacing:1px;text-transform:uppercase;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--brand-l)}
.nav-right{display:flex;align-items:center;gap:8px}
.nav-cta{background:var(--brand);color:#fff;font-weight:700;font-size:.76rem;letter-spacing:1px;text-transform:uppercase;padding:8px 18px;border:none;cursor:pointer;border-radius:var(--radius);transition:opacity .15s}
.nav-cta:hover{opacity:.85}
.nav-admin-badge{display:none;align-items:center;gap:6px;background:rgba(26,127,212,.12);border:1px solid var(--borderB);color:var(--brand-l);font-size:.68rem;font-weight:500;letter-spacing:1px;text-transform:uppercase;padding:5px 12px;border-radius:var(--radius);cursor:pointer;transition:background .2s}
.nav-admin-badge:hover{background:rgba(26,127,212,.22)}
.nav-admin-badge .dot{width:6px;height:6px;background:var(--brand-l);border-radius:50%}
.nav-login-btn{background:transparent;border:1px solid var(--border);color:var(--muted);font-size:.7rem;letter-spacing:1px;text-transform:uppercase;padding:6px 14px;cursor:pointer;border-radius:var(--radius);transition:border-color .2s,color .2s}
.nav-login-btn:hover{border-color:var(--brand);color:var(--brand)}
.nav-ham{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav-ham span{width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}
.mob-menu{display:none;position:fixed;top:68px;left:0;right:0;background:rgba(8,17,43,.98);border-bottom:1px solid var(--border);padding:1.5rem;z-index:999;backdrop-filter:blur(12px)}
.mob-menu.open{display:block}
.mob-menu ul{list-style:none;display:flex;flex-direction:column;gap:.75rem}
.mob-menu a{font-size:.95rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);display:block;padding:.5rem 0;border-bottom:1px solid var(--border)}
.mob-menu a:hover{color:var(--brand-l)}
.mob-actions{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}

/* ── SECTIONS ───────────────────────────────────────────────── */
section{scroll-margin-top:68px}
.sec-label{font-size:.68rem;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:var(--brand);display:block;margin-bottom:.65rem}
.sec-title{font-family:var(--fd);font-size:clamp(2.2rem,5vw,3.8rem);color:var(--text);letter-spacing:1px;line-height:1}
.sec-head{margin-bottom:2.5rem}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s,transform .6s}
.reveal.visible{opacity:1;transform:none}

/* ── BUTTONS ────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;cursor:pointer;border-radius:var(--radius);font-family:var(--fb);font-weight:500;letter-spacing:.8px;text-transform:uppercase;transition:all .15s;border:none;white-space:nowrap}
.btn-primary{
  background:linear-gradient(135deg,#1A7FD4,#289CFF);
  color:#fff;
  font-size:.82rem;
  padding:12px 26px;
  font-weight:700;
  border:none;
  position:relative;
  overflow:hidden;

  box-shadow:
    0 0 0 1px rgba(255,255,255,.05),
    0 8px 28px rgba(26,127,212,.45),
    0 0 18px rgba(26,127,212,.35);

  transition:
    transform .15s,
    box-shadow .2s,
    opacity .2s;
}

.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:
    0 12px 34px rgba(26,127,212,.55),
    0 0 26px rgba(26,127,212,.5);
}

.btn-outline{
  background:rgba(5,15,35,.82);
  backdrop-filter:blur(10px);

  color:#fff;
  font-size:.82rem;
  padding:12px 26px;

  border:1px solid rgba(255,255,255,.12);

  box-shadow:
    0 8px 24px rgba(0,0,0,.35),
    inset 0 0 0 1px rgba(255,255,255,.02);

  transition:
    border-color .2s,
    transform .15s,
    background .2s;
}

.btn-outline:hover{
  border-color:var(--brand);
  background:rgba(10,22,48,.92);
  transform:translateY(-2px);
}
.btn-sm{background:rgba(26,127,212,.1);color:var(--brand-l);font-size:.7rem;padding:6px 14px;border:1px solid var(--borderB)}
.btn-sm:hover{background:rgba(26,127,212,.22)}
.btn-edit{background:rgba(26,127,212,.06);color:var(--muted);font-size:.68rem;padding:6px 12px;border:1px solid var(--border)}
.btn-edit:hover{border-color:var(--brand);color:var(--brand-l)}
.btn-danger{background:rgba(212,43,43,.1);color:var(--red-l);font-size:.68rem;padding:6px 12px;border:1px solid rgba(212,43,43,.25)}
.btn-danger:hover{background:rgba(212,43,43,.22)}
.btn-green{background:var(--brand);color:#fff;font-size:.72rem;padding:7px 15px;font-weight:700}
.btn-green:hover{opacity:.85}
.btn-cancel{background:transparent;color:var(--muted);font-size:.76rem;padding:9px 18px;border:1px solid var(--border)}
.btn-cancel:hover{border-color:var(--muted);color:var(--text)}
.add-btn{display:flex;align-items:center;gap:7px;width:100%;background:transparent;border:1px dashed rgba(255,255,255,.09);border-radius:var(--radius);color:var(--dim);font-size:.75rem;letter-spacing:1px;text-transform:uppercase;padding:.85rem 1.1rem;cursor:pointer;margin-top:4px;transition:border-color .2s,color .2s;text-align:left;font-family:var(--fb)}
.add-btn:hover{border-color:rgba(26,127,212,.4);color:var(--brand-l)}

/* ── HERO ───────────────────────────────────────────────────── */
#hero{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  position:relative;
  overflow:hidden;
  padding:120px 1.5rem 80px;

  /* Fondo cancha */
  background:
    linear-gradient(rgba(3,10,28,.78), rgba(3,10,28,.88)),
    url('../../uploads/cancha-bg.jpg') center center/cover no-repeat;
}

/* Overlay azul extra */
.hero-bg{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none; /* IMPORTANTE */
  background:
    radial-gradient(circle at center,
      rgba(26,127,212,.18) 0%,
      rgba(8,17,43,.92) 70%);
}
/* Líneas animadas */
.hero-bg::before{
  content:'';
  position:absolute;
  inset:-200%;
  pointer-events:none;
  background:
    repeating-linear-gradient(
      -45deg,
      rgba(255,255,255,.025) 0px,
      rgba(255,255,255,.025) 2px,
      transparent 2px,
      transparent 90px
    );
  animation:moveLines 20s linear infinite;
  opacity:.45;
}

/* Glow ambiental */
.hero-bg::after{
  content:'';
  position:absolute;
  width:700px;
  height:700px;
  left:50%;
  top:45%;
  pointer-events:none;
  transform:translate(-50%,-50%);
  background:
    radial-gradient(circle,
      rgba(26,127,212,.25) 0%,
      rgba(212,43,43,.10) 35%,
      transparent 70%);
  filter:blur(70px);
  opacity:.9;
}

@keyframes moveLines{
  from{
    transform:translateY(0);
  }
  to{
    transform:translateY(120px);
  }
}

.hero-content{
  animation:heroFade 1.2s ease;
}

@keyframes heroFade{
  from{
    opacity:0;
    transform:translateY(25px);
  }
  to{
    opacity:1;
    transform:none;
  }
}

/* CONTENEDOR LOGO */
.hero-logo{
  position:relative;
  margin:0 auto 1.5rem;
  width:max-content;
}


.hero-title{
  font-family:var(--fd);
  font-size:clamp(1.8rem,4.5vw,4rem);
  line-height:1;
  margin-bottom:.7rem;
  color:#F0F4FF;
  text-transform:uppercase;
  letter-spacing:.5px;

  /* MÁS CUERPO */
  text-shadow:
    0 2px 2px rgba(0,0,0,.45),
    0 4px 12px rgba(0,0,0,.55),
    0 0 18px rgba(26,127,212,.18);

  filter:
    drop-shadow(0 0 1px rgba(255,255,255,.15));
}

.hero-title em{
  color:var(--brand-l);
  font-style:normal;
}


/* HALO DETRÁS DEL LOGO */
.hero-logo::before{
  content:'';
  position:absolute;
  left:50%;
  top:50%;
  width:260px;
  height:260px;
  transform:translate(-50%,-50%);
  background:
    radial-gradient(circle,
      rgba(26,127,212,.45) 0%,
      rgba(212,43,43,.18) 40%,
      transparent 72%);
  filter:blur(45px);
  z-index:-1;
  animation:pulseGlow 4s ease-in-out infinite;
}

@keyframes pulseGlow{
  0%,100%{
    transform:translate(-50%,-50%) scale(1);
    opacity:.85;
  }
  50%{
    transform:translate(-50%,-50%) scale(1.08);
    opacity:1;
  }
}

.hero-logo img{
  height:clamp(200px,18vw,190px);
  width:auto;
  margin:0 auto;
  position:relative;
  z-index:2;
  filter:
    drop-shadow(0 0 22px rgba(26,127,212,.55))
    drop-shadow(0 0 40px rgba(212,43,43,.22));
}

/* Escritorio */
@media(min-width: 1024px){

  .hero-logo img{
    height:340px;
  }

}

/* ── GALERÍA ────────────────────────────────────────────────── */
#galeria{padding:90px 2rem;background:var(--dark2)}
.gal-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:8px;min-height:200px}
.gal-item{border-radius:var(--radius);overflow:hidden;background:var(--dark4);position:relative;transition:transform .3s}
.gal-item:hover{transform:scale(1.01);z-index:2}
.gal-item:nth-child(1){grid-column:span 7;grid-row:span 2}
.gal-item:nth-child(2),.gal-item:nth-child(3){grid-column:span 5}
.gal-item:nth-child(n+4){grid-column:span 4}
.gal-img{width:100%;height:100%;min-height:200px;object-fit:cover;display:block}
.gal-empty{grid-column:span 12;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:180px;border:1px dashed rgba(255,255,255,.07);border-radius:var(--radius);color:var(--dim);font-size:.78rem;letter-spacing:1px;text-transform:uppercase}
.gal-overlay{position:absolute;inset:0;background:rgba(8,17,43,.72);opacity:0;transition:opacity .2s;display:flex;align-items:flex-end;justify-content:flex-end;padding:8px}
.gal-item:hover .gal-overlay{opacity:1}
.gal-del{background:rgba(212,43,43,.9);border:none;color:#fff;width:30px;height:30px;border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center}
.gal-del:hover{background:var(--red)}
.gal-upload-row{margin-top:1.1rem;display:flex;gap:.75rem;flex-wrap:wrap}

/* ── TORNEOS ────────────────────────────────────────────────── */
#torneos{padding:90px 2rem}
.torneos-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.75rem;margin-top:2.5rem}
.col-title{font-family:var(--fd);font-size:1.15rem;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:1.1rem;display:flex;align-items:center;gap:8px}
.col-title::after{content:'';flex:1;height:1px;background:var(--border)}
.t-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;overflow:hidden;transition:border-color .2s}
.t-card:hover{border-color:rgba(26,127,212,.38)}
.t-card.proximo{border-left:3px solid var(--brand)}
.t-card.pasado{border-left:3px solid var(--dim)}
.t-banner{width:100%;height:130px;object-fit:cover;display:block}
.t-body{padding:.9rem 1.1rem;display:flex;flex-direction:column;gap:5px}
.t-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.6rem}
.t-nombre{font-weight:500;font-size:.92rem;color:var(--text)}
.t-badge{font-size:.62rem;font-weight:500;letter-spacing:1px;text-transform:uppercase;padding:3px 8px;border-radius:2px;white-space:nowrap;flex-shrink:0}
.badge-abierto{background:rgba(26,127,212,.15);color:var(--brand-l);border:1px solid var(--borderB)}
.badge-cerrado{background:rgba(255,255,255,.05);color:var(--dim);border:1px solid var(--border)}
.badge-finalizado{background:rgba(212,43,43,.1);color:#FF7070;border:1px solid rgba(212,43,43,.25)}
.badge-envivo{background:rgba(220,38,38,.18);color:#ff4444;border:1px solid rgba(220,38,38,.4);animation:livepulse 2s infinite}
@keyframes livepulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.35)}50%{box-shadow:0 0 0 6px rgba(220,38,38,0)}}
.live-dot-badge{display:inline-block;width:7px;height:7px;border-radius:50%;background:#ff4444;margin-right:5px;animation:livepulse 1.2s infinite}

/* ── SHEET LIVE MODAL ───────────────────────────────────────── */
.sheet-modal-bg{position:fixed;inset:0;z-index:2000;background:rgba(4,9,22,.88);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s}
.sheet-modal{background:var(--dark2);border:1px solid var(--borderB);border-radius:10px;width:100%;max-width:1100px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.6)}
.sheet-modal-head{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--dark3)}
.sheet-modal-head h3{flex:1;font-family:var(--fd);font-size:1.3rem;letter-spacing:2px;color:#fff;margin:0}
.sheet-modal-close{background:none;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);font-size:13px;padding:5px 12px;cursor:pointer;transition:border-color .2s,color .2s}
.sheet-modal-close:hover{border-color:var(--brand-l);color:var(--brand-l)}
.sheet-modal-body{flex:1;overflow-y:auto;padding:20px}
.sheet-refresh{font-size:.68rem;color:var(--dim);letter-spacing:.5px}
/* Grupos y partidos dentro del modal */
.sg-grupo{margin-bottom:28px}
.sg-grupo-title{font-family:var(--fd);font-size:1.4rem;letter-spacing:3px;color:var(--brand-l);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.sg-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.sg-grid{grid-template-columns:1fr}}
.sg-sec-lbl{font-size:.65rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}
/* Posiciones */
.sg-table{width:100%;border-collapse:collapse;font-size:.78rem}
.sg-table th{padding:6px 8px;text-align:left;color:var(--muted);font-weight:500;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border)}
.sg-table td{padding:8px;border-bottom:1px solid rgba(26,127,212,.07);color:var(--text)}
.sg-table tr:last-child td{border-bottom:none}
.sg-rank{font-weight:700;font-size:.75rem}
/* Partidos */
.sg-match{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:10px 13px;margin-bottom:7px;position:relative;overflow:hidden}
.sg-match.played{border-color:rgba(26,127,212,.4)}
.sg-match.played::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--brand)}
.sg-match-meta{font-size:.62rem;color:var(--dim);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px}
.sg-teams{display:flex;align-items:center;gap:6px}
.sg-team{flex:1;padding:8px 10px;background:var(--dark3);border:1px solid var(--border);border-radius:var(--radius);font-size:.82rem;font-weight:600;color:var(--text);transition:all .15s}
.sg-team.w{background:rgba(26,127,212,.1);border-color:var(--borderB);color:var(--brand-l)}
.sg-score{min-width:70px;text-align:center}
.sg-set{font-size:.85rem;font-weight:800;color:var(--text);letter-spacing:.04em}
.sg-pending{font-size:.62rem;font-weight:700;color:var(--dim);text-transform:uppercase;letter-spacing:.08em}
.sg-no-data{text-align:center;padding:40px 0;color:var(--dim);font-size:.85rem}
.sg-loading{text-align:center;padding:50px 0;color:var(--muted);font-size:.85rem}
.t-cat{font-size:.65rem;color:var(--brand);font-weight:500;letter-spacing:1px;text-transform:uppercase}
.t-meta{display:flex;gap:.9rem;font-size:.74rem;color:var(--muted);flex-wrap:wrap}
.t-champ{font-size:.74rem;color:var(--muted)}
.t-champ strong{color:var(--text);font-weight:500}
.t-btns{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px;padding-top:7px;border-top:1px solid var(--border)}

/* ── RANKING ────────────────────────────────────────────────── */
#ranking{padding:90px 2rem;background:var(--dark2)}
.ranking-layout{display:grid;grid-template-columns:250px 1fr;gap:1.5rem;margin-top:2.5rem}
.cat-tabs{
  display:none;
}
.ranking-mobile-select{
  display:block;
  margin-bottom:1rem;
  width:100%;
}

.ranking-mobile-select select{
  width:100%;
  background:var(--card);
  border:1px solid var(--borderB);
  color:var(--text);
  padding:16px 18px;
  border-radius:8px;
  font-size:1rem;
  font-weight:500;
  outline:none;
  cursor:pointer;
  transition:.2s;
}

.ranking-mobile-select select:hover{
  border-color:var(--brand);
}

.ranking-mobile-select select:focus{
  border-color:var(--brand-l);
  box-shadow:0 0 0 3px rgba(26,127,212,.15);
}

@media(max-width:680px){

  .ranking-mobile-select{
    display:block;
  }

  .desktop-cats,
  .cat-tabs{
    display:none !important;
  }

}

/* ─────────────────────────────────────────────
   NUEVO RANKING
───────────────────────────────────────────── */

.ranking-box{
  display:flex;
  flex-direction:column;
  gap:1rem;
  margin-top:2rem;
}

.ranking-select-wrap select{
  width:100%;
  background:var(--card);
  border:1px solid var(--borderB);
  color:var(--text);
  padding:16px;
  border-radius:8px;
  font-size:1rem;
  outline:none;
}

.ranking-table-wrap{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
}
.cat-tab{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:11px 14px;cursor:pointer;transition:border-color .2s;position:relative}
.cat-tab:hover,.cat-tab.active{border-color:rgba(26,127,212,.45);background:rgba(26,127,212,.05)}
.cat-tab.active .cat-name{color:var(--brand-l)}
.cat-name{font-weight:500;font-size:.88rem;display:block}
.cat-sub{font-size:.7rem;color:var(--muted);display:block;margin-top:2px}
.cat-cnt{font-size:.65rem;color:var(--dim);display:block;margin-top:1px}
.cat-actions{position:absolute;right:7px;top:50%;transform:translateY(-50%);display:none;gap:3px}
.cat-tab:hover .cat-actions{display:flex}
.ico-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:3px;display:inline-flex;align-items:center;color:var(--muted);transition:all .15s}
.ico-btn:hover{background:rgba(255,255,255,.07);color:var(--text)}
.ico-btn.red:hover{background:rgba(212,43,43,.15);color:var(--red-l)}
.rk-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.rk-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.5rem}
.rk-title{font-family:var(--fd);font-size:1.45rem;letter-spacing:2px}
.rk-sub{font-size:.68rem;color:var(--dim);margin-top:2px}
.rk-head-btns{display:flex;gap:5px;flex-wrap:wrap}
table{width:100%;border-collapse:collapse}
thead th{padding:9px 13px;text-align:left;font-size:.65rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim);background:var(--dark3);border-bottom:1px solid var(--border);font-weight:400}
tbody tr{border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s}
tbody tr:hover{background:rgba(255,255,255,.02)}
tbody tr:last-child{border-bottom:none}
td{padding:10px 13px;font-size:.84rem;vertical-align:middle}
.pos{font-family:var(--fd);font-size:1.2rem;color:var(--dim);min-width:30px;text-align:center}
.pos.g{color:#FFD700}.pos.s{color:#C0C0C0}.pos.b{color:#CD7F32}
.pname{font-weight:500;color:var(--text);font-size:.88rem}
.pclub{font-size:.7rem;color:var(--muted);margin-top:1px}
.pts{font-family:var(--fd);font-size:1.2rem;color:var(--brand-l)}
.row-acts{display:flex;gap:3px}
.rk-foot{padding:.85rem 1.2rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.rk-note{font-size:.68rem;color:var(--dim)}

/* ── SPONSORS ───────────────────────────────────────────────── */
#sponsors{padding:80px 2rem}
.sp-head{text-align:center;margin-bottom:3rem}
.sp-tiers{display:flex;flex-direction:column;gap:2.5rem}
.sp-lbl{font-size:.67rem;letter-spacing:3px;text-transform:uppercase;color:var(--dim);text-align:center;margin-bottom:1rem;display:flex;align-items:center;gap:1rem}
.sp-lbl::before,.sp-lbl::after{content:'';flex:1;height:1px;background:var(--border)}
.sp-row{display:flex;align-items:center;justify-content:center;gap:1.2rem;flex-wrap:wrap}
.sp-slot{background:var(--card);border:1px dashed rgba(255,255,255,.1);border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:.7rem;letter-spacing:1px;text-transform:uppercase;transition:border-color .2s,color .2s;font-family:var(--fb)}
.sp-slot:hover{border-color:rgba(26,127,212,.35);color:var(--brand-l)}
.sp-slot.g{width:240px;height:96px;font-size:.78rem}
.sp-slot.s{width:190px;height:76px}
.sp-slot.b{width:145px;height:64px;font-size:.67rem}
.sp-filled{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--muted);letter-spacing:2px;width:240px;height:96px;font-size:.95rem}

/* ── FOOTER ─────────────────────────────────────────────────── */
footer{background:var(--dark2);border-top:1px solid var(--border);padding:56px 2rem 36px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
.fb{font-family:var(--fd);font-size:1.7rem;letter-spacing:2px;color:var(--brand);margin-bottom:.7rem}
.fb span{color:var(--brand-l);font-size:1.3rem}
.fdesc{font-size:.82rem;color:var(--muted);line-height:1.8;max-width:240px}
.fcol-title{font-size:.65rem;letter-spacing:2px;text-transform:uppercase;color:var(--dim);margin-bottom:1rem}
.flinks{list-style:none}
.flinks li{margin-bottom:6px}
.flinks a{font-size:.8rem;color:var(--muted);transition:color .2s}
.flinks a:hover{color:var(--brand-l)}
.f-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:1.5rem;border-top:1px solid var(--border);font-size:.73rem;color:var(--dim);flex-wrap:wrap;gap:.5rem}
.socials{display:flex;gap:.6rem}
.socials a{width:32px;height:32px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.72rem;transition:all .2s}
.socials a:hover{border-color:var(--brand);color:var(--brand-l)}

/* ── MODALS ─────────────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.86);align-items:center;justify-content:center;backdrop-filter:blur(7px);padding:1rem}
.overlay.open{display:flex}
.modal{background:var(--dark2);border:1px solid var(--border);border-radius:8px;padding:1.6rem;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;position:relative}
.modal.wide{max-width:740px}
.modal h3{font-family:var(--fd);font-size:1.8rem;letter-spacing:2px;color:var(--brand-l);margin-bottom:1.3rem}
.mc{position:absolute;top:.9rem;right:.9rem;background:none;border:none;color:var(--dim);cursor:pointer;font-size:1.2rem;line-height:1;padding:4px;transition:color .2s}
.mc:hover{color:var(--text)}
.fr{margin-bottom:.85rem}
.fr label{display:block;font-size:.67rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.fr input,.fr select,.fr textarea{width:100%;background:var(--dark3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.86rem;padding:9px 12px;outline:none;transition:border-color .2s}
.fr input:focus,.fr select:focus,.fr textarea:focus{border-color:var(--brand)}
.fr select option{background:var(--dark3)}
.fr textarea{resize:vertical;min-height:70px}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.f-actions{display:flex;gap:.7rem;justify-content:flex-end;margin-top:1.2rem;flex-wrap:wrap}
.file-prev{display:none;margin-top:.5rem;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.file-prev img{width:100%;height:130px;object-fit:cover;display:block}
.file-prev.show{display:block}
/* fotos modal */
.fotos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:7px;margin-bottom:1.1rem}
.fthumb{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:var(--dark3)}
.fthumb img{width:100%;height:100%;object-fit:cover}
.fthumb-del{position:absolute;top:4px;right:4px;background:rgba(212,43,43,.88);border:none;color:#fff;width:26px;height:26px;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.fthumb-del:hover{background:var(--red)}
.upload-area{border:2px dashed rgba(26,127,212,.22);border-radius:var(--radius);padding:1.1rem;text-align:center;cursor:pointer;transition:border-color .2s}
.upload-area:hover{border-color:rgba(26,127,212,.5)}
.upload-area p{font-size:.76rem;color:var(--dim);margin-top:.4rem}

/* ── LOGIN ──────────────────────────────────────────────────── */
.l-overlay{display:none;position:fixed;inset:0;z-index:5000;background:rgba(0,0,0,.92);align-items:center;justify-content:center;backdrop-filter:blur(12px);padding:1rem}
.l-overlay.open{display:flex}
.l-box{background:var(--dark2);border:1px solid var(--border);border-radius:8px;padding:2.1rem;width:100%;max-width:360px;position:relative}
.l-logo{text-align:center;margin-bottom:.25rem}
.l-logo img{height:68px;margin:0 auto}
.l-sub{text-align:center;font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--dim);margin:.4rem 0 1.5rem}
.l-f{margin-bottom:.85rem}
.l-f label{display:block;font-size:.67rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.l-f input{width:100%;background:var(--dark3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;padding:10px 12px;outline:none;transition:border-color .2s}
.l-f input:focus{border-color:var(--brand)}
.l-err{font-size:.76rem;color:#FF6B50;text-align:center;margin-top:.6rem;min-height:1rem}
.l-btn{width:100%;background:var(--brand);color:#fff;font-family:var(--fb);font-weight:700;font-size:.86rem;letter-spacing:1px;text-transform:uppercase;padding:12px;border:none;cursor:pointer;border-radius:var(--radius);margin-top:1rem;transition:opacity .15s}
.l-btn:hover{opacity:.85}
.l-close{position:absolute;top:.85rem;right:.85rem;background:none;border:none;color:var(--dim);cursor:pointer;font-size:1.2rem;line-height:1;padding:4px}
.l-close:hover{color:var(--text)}

/* ── ADMIN BAR ──────────────────────────────────────────────── */
.abar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:900;background:rgba(8,17,43,.98);border-top:1px solid var(--borderB);backdrop-filter:blur(12px);padding:8px 2rem;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.4rem}
.abar-lbl{font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--brand-l)}
.abar-user{font-size:.76rem;color:var(--muted)}
.btn-logout{background:transparent;border:1px solid rgba(255,75,43,.3);color:#FF6B50;font-family:var(--fb);font-size:.7rem;font-weight:500;letter-spacing:1px;text-transform:uppercase;padding:6px 14px;cursor:pointer;border-radius:var(--radius);transition:background .2s}
.btn-logout:hover{background:rgba(255,75,43,.12)}

/* ── ADMIN VISIBILITY ───────────────────────────────────────── */
.ao{display:none!important}
body.admin .ao{display:inline-flex!important}
body.admin .ao-flex{display:flex!important}
body.admin .abar{display:flex}
body.admin .nav-admin-badge{display:flex}
body.admin .nav-login-btn{display:none}

/* ── TOAST ──────────────────────────────────────────────────── */
.toast{position:fixed;bottom:2rem;right:2rem;z-index:9999;font-weight:700;font-size:.8rem;letter-spacing:.5px;padding:10px 20px;border-radius:var(--radius);transform:translateY(80px);opacity:0;transition:all .3s;pointer-events:none}
.toast.ok{background:var(--brand);color:#fff}
.toast.err{background:var(--red);color:#fff}
.toast.show{transform:none;opacity:1}
.spin{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.ld{padding:2rem;text-align:center;color:var(--dim);font-size:.82rem}

/* ── CATEGORÍAS PILLS ───────────────────────────────────────────── */
.t-cats{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}
.cat-pill{display:inline-flex;align-items:center;font-size:.64rem;font-weight:500;letter-spacing:.5px;padding:2px 8px;border-radius:2px;white-space:nowrap}
.cat-pill.cab{background:rgba(26,127,212,.15);color:var(--brand-l);border:1px solid rgba(26,127,212,.25)}
.cat-pill.dam{background:rgba(200,60,180,.12);color:#D070C8;border:1px solid rgba(200,60,180,.22)}
.t-nombre-link{cursor:pointer;transition:color .2s}
.t-nombre-link:hover{color:var(--brand-l)}
/* Checkboxes de categorías en formulario torneo */
.cat-chk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:5px;margin-top:5px}
.cat-chk{display:flex;align-items:center;gap:5px;font-size:.76rem;color:var(--muted);cursor:pointer;padding:4px 7px;border:1px solid var(--border);border-radius:3px;transition:all .15s;user-select:none}
.cat-chk:hover{border-color:var(--brand);color:var(--text)}
.cat-chk input{accent-color:var(--brand);width:13px;height:13px;cursor:pointer;flex-shrink:0}
/* Modal detalle torneo — tabs */
.det-tabs{display:flex;gap:2px;margin-bottom:1.1rem;border-bottom:1px solid var(--border);padding-bottom:0}
.det-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-family:var(--fb);font-size:.76rem;font-weight:500;letter-spacing:.8px;text-transform:uppercase;padding:.5rem .9rem;cursor:pointer;transition:all .2s;margin-bottom:-1px}
.det-tab:hover{color:var(--text)}
.det-tab.active{color:var(--brand-l);border-bottom-color:var(--brand-l)}
.det-panel{animation:fadeIn .2s}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.det-row{display:flex;flex-direction:column;gap:2px;padding:.45rem .6rem;background:rgba(255,255,255,.03);border-radius:3px;border:1px solid var(--border)}
.det-lbl{font-size:.63rem;letter-spacing:1px;text-transform:uppercase;color:var(--dim)}

/* ── INSCRIPCIONES BADGE ────────────────────────────────────── */
.ins-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(77,195,247,.1);border:1px solid rgba(77,195,247,.25);color:var(--brand-l);font-size:.68rem;letter-spacing:1px;text-transform:uppercase;padding:4px 9px;border-radius:2px}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:900px){
  .torneos-cols{grid-template-columns:1fr}
.ranking-layout{
  display:flex;
  flex-direction:column;
  gap:1rem;
  margin-top:2.5rem;
}
  .cat-tabs{display:grid;grid-template-columns:1fr 1fr;gap:4px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .gal-item:nth-child(1){grid-column:span 12;grid-row:span 1}
  .gal-item:nth-child(2),.gal-item:nth-child(3){grid-column:span 6}
  .gal-item:nth-child(n+4){grid-column:span 6}
}
@media(max-width:680px){
  nav{padding:0 1rem}
  .nav-links,.nav-right .nav-cta{display:none}
  .nav-ham{display:flex}
  #hero,#galeria,#torneos,#ranking,#sponsors{padding-left:1rem;padding-right:1rem}
  footer{padding-left:1rem;padding-right:1rem}
  .gal-grid{grid-template-columns:1fr 1fr;gap:5px}
  .gal-item{grid-column:span 1!important;grid-row:span 1!important}
  .hero-stats{gap:1.2rem}
  .footer-grid{grid-template-columns:1fr}
  .f2{grid-template-columns:1fr}
  .modal{padding:1.1rem}
  .cat-tabs{grid-template-columns:1fr}
  .cat-actions{display:flex!important}
  .t-meta{flex-direction:column;gap:.2rem}
  .rk-head{flex-direction:column;align-items:flex-start}
}
@media(max-width:400px){
  .hero-actions{flex-direction:column;align-items:center}
  .stat-num{font-size:2rem}
  .hero-stats{gap:.8rem}
}

.hero-actions .btn{
  position:relative;
  z-index:10;
}

/* ═══════════════════════════════════════════════════
   GALERÍA — Tabs de categoría
   ═══════════════════════════════════════════════════ */
.gal-tabs-wrap {
  max-width: 1200px;
  margin: 0 auto 1.4rem;
  padding: 0 1.5rem;
}

.gal-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.gal-tab {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--muted);
  border-radius: 20px;
  padding: .35rem 1rem;
  font-size: .78rem;
  font-weight: 500;
  letter-spacing: .04em;
  cursor: pointer;
  transition: all .18s;
  font-family: inherit;
}

.gal-tab:hover {
  border-color: var(--brand-l);
  color: var(--brand-l);
}

.gal-tab.active {
  background: var(--brand);
  border-color: var(--brand);
  color: #fff;
}

/* Badge de categoría sobre la foto */
.gal-item {
  position: relative;     /* asegurarse de que ya lo tenía */
}

.gal-cat-badge {
  position: absolute;
  top: .6rem;
  left: .6rem;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(4px);
  color: #fff;
  font-size: .65rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: .22rem .55rem;
  border-radius: 4px;
  pointer-events: none;
  z-index: 2;
}

/* Cursor pointer en las fotos */
.gal-item {
  cursor: zoom-in;
}

/* ═══════════════════════════════════════════════════
   LIGHTBOX
   ═══════════════════════════════════════════════════ */
#gal-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(0,0,0,.93);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s;
}

#gal-lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.lb-img-wrap {
  max-width: 88vw;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .7rem;
}

#lb-img {
  max-width: 100%;
  max-height: 80vh;
  object-fit: contain;
  border-radius: 6px;
  box-shadow: 0 8px 40px rgba(0,0,0,.6);
  transition: opacity .15s;
}

.lb-caption {
  color: rgba(255,255,255,.7);
  font-size: .8rem;
  text-align: center;
}

.lb-cat {
  display: inline-block;
  background: var(--brand);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: .15rem .5rem;
  border-radius: 3px;
}

.lb-counter {
  position: fixed;
  bottom: 1.2rem;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,.4);
  font-size: .75rem;
  letter-spacing: .08em;
}

.lb-close {
  position: fixed;
  top: 1rem;
  right: 1.2rem;
  background: rgba(255,255,255,.1);
  border: none;
  color: #fff;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  font-size: 1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s;
  z-index: 1;
}
.lb-close:hover { background: rgba(255,255,255,.22); }

.lb-nav {
  background: rgba(255,255,255,.08);
  border: none;
  color: #fff;
  font-size: 2.5rem;
  line-height: 1;
  width: 50px;
  height: 70px;
  border-radius: 8px;
  cursor: pointer;
  transition: background .15s;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lb-nav:hover { background: rgba(255,255,255,.18); }

@media (max-width: 600px) {
  .lb-nav { width: 36px; height: 52px; font-size: 1.8rem; }
  .lb-img-wrap { max-width: 94vw; }
}