/* =========================================================
   CLASIFICACIONES – styles (TEMA MORADO FINAL)
========================================================= */

:root{
  --ab-primary:#A025A2;
  --ab-primary-dark:#7e1d82;

  --ab-bg:#ffffff;
  --ab-text:rgba(0,0,0,.88);
  --ab-muted:rgba(0,0,0,.60);

  --ab-border:rgba(0,0,0,.10);
  --ab-shadow:0 10px 30px rgba(0,0,0,.08);

  --ab-glass:rgba(255,255,255,.82);
  --ab-glass-head:rgba(255,255,255,.92);
}

/* =========================================================
   CONTENEDOR
========================================================= */

.viewer-card{
  background:var(--ab-glass);
  border:1px solid rgba(0,0,0,.06);
  border-radius:12px;
  box-shadow:0 14px 38px rgba(0,0,0,.08);
  overflow:hidden;
  backdrop-filter:blur(6px);
}

/* =========================================================
   CABECERA
========================================================= */

.classif-head{
  background:var(--ab-glass-head);
  border-bottom:1px solid rgba(0,0,0,.06);
  padding:18px;
}

.head-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}

.head-title{
  margin:0;
  font-weight:900;
  letter-spacing:.3px;
  font-size:18px;
  text-transform:uppercase;
  color:var(--ab-text);
}

/* controles derecha */

.head-controls{
  display:flex;
  align-items:center;
}

.ctrl-group{
  display:flex;
  align-items:center;
  gap:10px;
}

/* =========================================================
   BOTONES ETAPA
========================================================= */

.circle-btn{
  width:42px;
  height:42px;
  border-radius:999px;
  border:none;
  background:var(--ab-primary);
  color:#fff;
  font-size:22px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:.15s;
}

.circle-btn:hover{
  background:var(--ab-primary-dark);
}

/* =========================================================
   SELECTS
========================================================= */

.form-control{
  border-radius:12px;
  padding:10px 14px;
  border:1px solid rgba(0,0,0,.14);
  font-weight:800;
  font-size:13px;
  background:#fff;
}

.form-control:focus{
  border-color:var(--ab-primary);
  box-shadow:0 0 0 4px rgba(160,37,162,.15);
}

/* =========================================================
   TABS GENERAL / ETAPA
========================================================= */

.scope-tabs{
  display:flex;
  gap:20px;
  margin-top:15px;
  border-bottom:1px solid rgba(0,0,0,.10);
}

.scope-tabs input{
  display:none;
}

.scope-tab{
  padding:10px 4px 12px;
  font-weight:900;
  font-size:13px;
  text-transform:uppercase;
  color:rgba(0,0,0,.55);
  border-bottom:3px solid transparent;
  cursor:pointer;
}

.scope-tabs input:checked + .scope-tab{
  color:var(--ab-primary);
  border-bottom-color:var(--ab-primary);
}

/* =========================================================
   TABS CATEGORIAS
========================================================= */

.type-tabs{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap:10px;
  padding-top:14px;
  width:100%;
}
.type-tabs input{
  display:none;
}

.type-tab{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.12);
  background:#fff;
  font-weight:900;
  font-size:12px;
  text-transform:uppercase;
  cursor:pointer;
  transition:.15s;
}

.type-tab:hover{
  background:#f7ecf7;
}

.type-tabs input:checked + .type-tab{
  background:var(--ab-primary);
  color:#fff;
  border-color:var(--ab-primary);
}

/* icono */

.type-ico{
  width:22px;
  height:22px;
  border-radius:7px;
  border:1px solid rgba(0,0,0,.15);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:12px;
}

.type-tabs input:checked + .type-tab .type-ico{
  background:#fff;
  color:var(--ab-primary);
  border-color:#fff;
}

/* =========================================================
   BODY
========================================================= */

.classif-body{
  padding:14px;
  background:#fff;
}

/* =========================================================
   RESULTADOS
========================================================= */

.results-wrap{
  border-top:1px solid rgba(0,0,0,.06);
  max-height:calc(100vh - 260px);
  min-height:650px;
  overflow:auto;
}

/* =========================================================
   CABECERA TABLA
========================================================= */

.r-head{
  position:sticky;
  top:0;

  display:grid;
  grid-template-columns:52px 1.2fr 1.2fr 0.9fr;

  gap:12px;
  padding:12px;

  background:#fff;
  border-bottom:1px solid rgba(0,0,0,.10);

  font-weight:900;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.4px;

  color:var(--ab-primary);
}

.r-head .rh-right{
  text-align:right;
}

/* =========================================================
   FILAS
========================================================= */

#resultsRows{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding-top:12px;
}

.r-row{
  display:grid;
  grid-template-columns:52px 1.2fr 1.2fr 0.9fr;
  gap:12px;

  align-items:center;

  padding:14px 12px;

  border:1px solid rgba(0,0,0,.10);
  border-radius:12px;
  background:#fff;
}

/* alternancia */

#resultsRows .r-row:nth-child(even){
  background:rgba(0,0,0,.02);
}

/* =========================================================
   POSICION
========================================================= */

.r-rank{
  width:38px;
  height:38px;
  border-radius:10px;

  display:flex;
  align-items:center;
  justify-content:center;

  font-weight:900;

  background:#000;
  color:#fff;
}

/* =========================================================
   TEXTO
========================================================= */

.r-name{
  font-weight:950;
  font-size:13px;
  text-transform:uppercase;
}

.muted{
  font-size:12px;
  opacity:.7;
}

.r-team{
  font-weight:850;
  font-size:12px;
  text-transform:uppercase;
}

/* =========================================================
   TIEMPO
========================================================= */

.r-time{
  font-weight:950;
  font-size:12px;
  text-align:right;
}

/* =========================================================
   MENSAJES (CENTRADO PERFECTO)
========================================================= */

.r-empty,
.r-loading{

  display:flex;
  align-items:center;
  justify-content:center;

  text-align:center;

  padding:30px;

  border-radius:12px;

  font-weight:800;

}

.r-empty{
  border:1px dashed rgba(0,0,0,.18);
}

/* =========================================================
   SECCIONES MONTAÑA
========================================================= */

.r-section{
  position:sticky;
  top:44px;

  padding:10px 12px;

  border-radius:12px;

  background:rgba(160,37,162,.12);
  border:1px solid rgba(160,37,162,.30);

  font-weight:950;
  text-transform:uppercase;
}

/* =========================================================
   LIDER
========================================================= */

.r-top1 .r-row{
  background:var(--ab-primary) !important;
  color:#fff;
}

.r-top1 .r-row .r-rank{
  background:#fff;
  color:var(--ab-primary);
}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width:768px){

.r-row,
.r-head{
  grid-template-columns:44px 1fr 90px;
}

.head-row{
  flex-direction:column;
  align-items:flex-start;
}

.ctrl-group{
  margin-top:8px;
}

}