:root {
  --azul-oscuro: #123a91;
  --azul: #2f6fed;
  --azul-claro: #4f8ff7;
  --dorado: #d4a017;
  --gris-claro: #f4f6f5;
}

body {
  background-color: var(--gris-claro);
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
}

.navbar {
  background: linear-gradient(90deg, var(--azul-oscuro), var(--azul));
}

.navbar .nav-link {
  font-weight: 500;
}

.navbar .nav-link:hover {
  color: var(--dorado) !important;
}

.badge-grupo {
  background-color: var(--azul);
  color: #fff;
  font-weight: 600;
}

.card-grupo .card-header {
  background-color: var(--azul);
  color: #fff;
  font-weight: 600;
}

.tabla-posiciones thead {
  background-color: var(--azul-oscuro);
  color: #fff;
}

.fila-clasifica {
  border-left: 4px solid var(--dorado);
}

.partido-card {
  border-left: 4px solid var(--azul);
}

.partido-jugado {
  border-left-color: var(--dorado);
}

.marcador {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--azul-oscuro);
}

.btn-torneo {
  background-color: var(--azul);
  border-color: var(--azul);
  color: #fff;
}

.btn-torneo:hover {
  background-color: var(--azul-oscuro);
  border-color: var(--azul-oscuro);
  color: #fff;
}

.llave-box {
  background: #fff;
  border: 1px solid #dee2e6;
  border-radius: .5rem;
  padding: .75rem 1rem;
  min-width: 220px;
}

.llave-box .equipo.ganador {
  font-weight: 700;
  color: var(--azul-oscuro);
}

.llave-columna {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  gap: 1.5rem;
}

.hero-torneo {
  background: linear-gradient(120deg, var(--azul-oscuro), var(--azul));
  color: #fff;
  border-radius: .75rem;
  padding: 2.5rem 2rem;
}

/* ===== Pantalla de login estilo "Campeonato" ===== */
.pantalla-login {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--azul-oscuro), var(--azul-claro));
  padding: 1.5rem;
}

.tarjeta-login {
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, .35);
  padding: 3rem 2.75rem;
  width: 100%;
  max-width: 440px;
  text-align: center;
}

.tarjeta-login .trofeo {
  font-size: 3.25rem;
  color: var(--azul);
  margin-bottom: .5rem;
}

.tarjeta-login h1 {
  font-weight: 800;
  font-size: 1.8rem;
  color: #1c1c1c;
  margin-bottom: .25rem;
}

.tarjeta-login .subtitulo {
  color: #6c757d;
  margin-bottom: 1.75rem;
}

.tarjeta-login label {
  text-align: left;
  display: block;
  font-weight: 600;
  font-size: .9rem;
  margin-bottom: .35rem;
  color: #333;
}

.tarjeta-login .form-control {
  border-radius: .6rem;
  padding: .7rem .9rem;
  border: 1px solid #dcdfe4;
}

.tarjeta-login .form-control:focus {
  border-color: var(--azul);
  box-shadow: 0 0 0 .2rem rgba(47, 111, 237, .18);
}

.tarjeta-login .btn-ingresar {
  background: var(--azul);
  border: none;
  color: #fff;
  font-weight: 700;
  border-radius: .6rem;
  padding: .8rem;
  width: 100%;
}

.tarjeta-login .btn-ingresar:hover {
  background: var(--azul-oscuro);
  color: #fff;
}

.tarjeta-login .toggle-password {
  border: 1px solid #dcdfe4;
  border-left: none;
  background: #fff;
}

.tarjeta-login .pie {
  margin-top: 1.75rem;
  color: #8a8f98;
  font-size: .85rem;
  line-height: 1.4;
}
