:root {
  --fondo: #f5f3f0;
  --fondo-degradado-1: #ebe6df;
  --fondo-degradado-2: #faf9f7;
  --panel: #ffffff;
  --input-bg: #faf9f7;
  --borde: #d6d0c8;
  --texto: #292524;
  --texto-suave: #78716c;
  --acento: #b45309;
  --acento-hover: #92400e;
  --acento-suave: rgba(180, 83, 9, 0.1);
  --nav-hover: #f5efe6;
  --exito: #92400e;
  --resultado-ganador: #15803d;
  --error: #b91c1c;
  --advertencia: #b45309;
  --sombra: 0 8px 28px rgba(41, 37, 36, 0.08);
  --sombra-focus: 0 0 0 3px rgba(180, 83, 9, 0.22);
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 75%;
}

html.pendiente-acceso body {
  visibility: hidden;
}

body {
  font-family: "Segoe UI", system-ui, sans-serif;
  background: linear-gradient(165deg, var(--fondo-degradado-1) 0%, var(--fondo-degradado-2) 45%, var(--fondo) 100%);
  color: var(--texto);
  min-height: 100vh;
  line-height: 1.5;
}

.contenedor {
  max-width: 825px;
  margin: 0 auto;
  padding: 2rem 1.25rem 3rem;
}

.encabezado {
  margin-bottom: 2rem;
  text-align: center;
}

.encabezado h1 {
  font-size: 1.85rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--acento);
}

.encabezado p {
  color: var(--texto-suave);
  margin-top: 0.35rem;
}

.nav-paginas {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.nav-paginas a {
  padding: 0.5rem 1rem;
  border-radius: 999px;
  border: 1px solid var(--borde);
  background: var(--panel);
  color: var(--texto-suave);
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 600;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.nav-paginas a:hover {
  background: var(--nav-hover);
  color: var(--texto);
  border-color: var(--acento);
}

.nav-paginas a.activo {
  background: var(--acento);
  border-color: var(--acento);
  color: #fff;
}

.fecha-stepper {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.fecha-valor {
  min-width: 2.5rem;
  text-align: center;
  font-size: 1.25rem;
  font-weight: 700;
  padding: 0.45rem 0.65rem;
  background: var(--input-bg);
  border: 1px solid var(--borde);
  border-radius: 8px;
  color: var(--acento);
}

.btn-stepper {
  min-width: 2.5rem;
  padding: 0.45rem 0.55rem;
  font-size: 0.85rem;
  line-height: 1;
}

.btn-stepper:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.resumen-filtro {
  margin-top: 1rem;
  color: var(--texto-suave);
  font-size: 0.9rem;
}

th.col-goles,
td.col-goles {
  text-align: center;
}

td.col-goles {
  font-weight: 600;
  color: var(--texto);
}

.panel {
  background: var(--panel);
  border: 1px solid var(--borde);
  border-radius: 16px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  box-shadow: var(--sombra);
}

.panel h2 {
  font-size: 1.15rem;
  margin-bottom: 1.25rem;
  color: var(--acento);
}

.grid-formulario {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 1rem;
}

.campo label {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--texto-suave);
  margin-bottom: 0.35rem;
  letter-spacing: 0.02em;
}

.campo select,
.campo input[type="text"],
.filtros select {
  width: 100%;
  padding: 0.55rem 0.65rem;
  border: 1px solid var(--borde);
  border-radius: 8px;
  background: var(--input-bg);
  color: var(--texto);
  font-size: 0.95rem;
}

.campo select:focus,
.campo input[type="text"]:focus,
.filtros select:focus {
  outline: none;
  border-color: var(--acento);
  box-shadow: var(--sombra-focus);
}

.acciones-formulario {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.25rem;
}

.btn {
  padding: 0.55rem 1.1rem;
  border: none;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s, color 0.15s;
}

.btn:active {
  transform: scale(0.98);
}

.btn-primario {
  background: var(--acento);
  color: #fff;
}

.btn-primario:hover {
  background: var(--acento-hover);
}

.btn-secundario {
  background: var(--nav-hover);
  color: var(--texto);
  border: 1px solid var(--borde);
}

.btn-secundario:hover {
  background: var(--borde);
  color: var(--texto);
}

.btn-editar {
  background: #fff8eb;
  color: var(--advertencia);
  border: 1px solid var(--advertencia);
  padding: 0.35rem 0.65rem;
  font-size: 0.8rem;
}

.btn-editar:hover {
  background: var(--advertencia);
  color: #fff;
}

.btn-eliminar {
  background: #fef2f2;
  color: var(--error);
  border: 1px solid var(--error);
  padding: 0.35rem 0.65rem;
  font-size: 0.8rem;
}

.btn-eliminar:hover {
  background: var(--error);
  color: #fff;
}

.mensaje {
  margin-top: 1rem;
  min-height: 1.25rem;
  font-size: 0.9rem;
}

.mensaje.exito {
  color: var(--exito);
}

.mensaje.error {
  color: var(--error);
}

.barra-listado {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.filtros {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
}

.filtros label {
  font-size: 0.8rem;
  color: var(--texto-suave);
}

.filtros select {
  min-width: 75px;
}

.listado-por-grupo {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.bloque-grupo .titulo-grupo {
  font-size: 1rem;
  font-weight: 700;
  color: var(--acento);
  margin-bottom: 0.5rem;
}

.tabla-contenedor {
  overflow-x: auto;
  border-radius: 10px;
  border: 1px solid var(--borde);
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  background: var(--panel);
}

thead th {
  text-align: left;
  padding: 0.65rem 0.5rem;
  border-bottom: 2px solid var(--borde);
  background: var(--nav-hover);
  color: var(--acento);
  font-size: 0.8rem;
  letter-spacing: 0.02em;
}

tbody td {
  padding: 0.6rem 0.5rem;
  border-bottom: 1px solid var(--borde);
}

tbody tr:hover {
  background: var(--acento-suave);
}

th.col-num,
td.col-num {
  text-align: center;
  white-space: nowrap;
}

td.col-puntos {
  font-weight: 700;
}

tr.posicion-lider td {
  font-weight: 600;
}

tr.posicion-lider td.col-puntos {
  color: var(--acento);
}

.resultado-ganador {
  color: var(--resultado-ganador);
  font-weight: 700;
}

.resultado-perdedor {
  color: var(--error);
  font-weight: 700;
}

td.col-goles.resultado-ganador {
  color: var(--resultado-ganador);
  font-weight: 700;
}

td.col-goles.resultado-perdedor {
  color: var(--error);
  font-weight: 700;
}

.vacio {
  text-align: center;
  color: var(--texto-suave);
  padding: 2rem !important;
}

.acciones-celda {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}

@media (max-width: 600px) {
  .encabezado h1 {
    font-size: 1.45rem;
  }

  .barra-listado {
    flex-direction: column;
    align-items: stretch;
  }
}
