*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

@font-face {
  font-family: "Fort Yukon Round";
  src: url("../font/fort-yukon-round-regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@property --contorno-angulo {
  syntax: "<angle>";
  inherits: false;
  initial-value: 0turn;
}

html {
  min-height: 100%;
}

body {
  min-height: 100vh;
  background:
    linear-gradient(135deg, rgba(255, 0, 127, 0.25), transparent 60%),
    linear-gradient(315deg, rgba(0, 240, 255, 0.20), transparent 60%),
    linear-gradient(180deg, rgba(255, 230, 0, 0.12), transparent 70%),
    #120c1f;
  color: #f8f7ff;
  font-family: Arial, Helvetica, sans-serif;
}
.bg{
  position: relative;
  width: 100%;
}
.bg::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url(../img/fondo.jpg);
    background-size: auto;
    background-position: center;
    opacity: 0.6;
    z-index: -1;
}

button,
select {
  font: inherit;
}

.logo-superior {
  position: fixed;
  top: clamp(0.75rem, 2vw, 1.5rem);
  left: clamp(0.75rem, 2vw, 1.5rem);
  z-index: 20;
  display: block;
  width: clamp(7rem, 13vw, 12rem);
  height: auto;
  pointer-events: none;
  filter: drop-shadow(0 0 0.65rem rgba(0, 0, 0, 0.38));
}

.app {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 2rem;
}

.panel-predictor {
  width: min(100%, 58rem);
  display: grid;
  gap: 1.5rem;
  justify-items: center;
  text-align: center;
}

.etiqueta {
  color: #00f0ff;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 15px;
  text-transform: uppercase;
}

h1 {
  color: #ffefef;
  font-size: clamp(2.25rem, 8vw, 3.75rem);
  line-height: 0.95;
  text-shadow:
    0 0 1.25rem rgba(255, 0, 127, 0.55),
    0 0 2.25rem rgba(0, 240, 255, 0.28);
}

#titulo-app {
  font-family: "Fort Yukon Round", Arial, Helvetica, sans-serif;
  font-weight: 400;
}

.arena-prediccion {
  --vuelo-marcadamus: clamp(9rem, 29vw, 17.5rem);
  --flotacion-marcadamus: clamp(-4.45rem, -6vw, -2.9rem);
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(8rem, 0.7fr) minmax(0, 1fr);
  gap: clamp(1rem, 3.2vw, 1.8rem);
  align-items: center;
  overflow: visible;
  padding-block: clamp(0.45rem, 1.6vw, 0.9rem);
}

.card-equipo {
  --card-accent: #00f0ff;
  --card-accent-2: #ff007f;
  --card-accent-3: #ffffff;
  --card-accent-4: #ffe600;
  --card-wash: rgba(0, 240, 255, 0.11);
  --card-glow: rgba(0, 240, 255, 0.28);
  --card-bandera: linear-gradient(180deg, var(--card-accent), var(--card-accent-2));
  --card-bandera-horizontal: linear-gradient(90deg, var(--card-accent), var(--card-accent-2));
  --card-bandera-diagonal: linear-gradient(135deg, var(--card-wash), rgba(255, 255, 255, 0.08));
  position: relative;
  isolation: isolate;
  overflow: visible;
  min-height: 11.25rem;
  display: grid;
  gap: 0.85rem;
  align-content: stretch;
  text-align: left;
  border: 0.1rem solid rgba(255, 255, 255, 0.14);
  border-radius: 0.5rem;
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.035)),
    var(--card-bandera-diagonal),
    linear-gradient(180deg, var(--card-wash), transparent 68%),
    rgba(255, 255, 255, 0.07);
  padding: clamp(1rem, 2.6vw, 1.35rem);
  padding-left: clamp(1.25rem, 3vw, 1.7rem);
  opacity: 0;
  transform: translateY(0.7rem) scale(0.98);
  transition:
    opacity 0.35s ease,
    transform 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease,
    background 0.35s ease,
    filter 0.35s ease;
}

.card-derecha {
  --card-accent: #ffe600;
  --card-accent-2: #00f0ff;
  --card-accent-3: #ffffff;
  --card-accent-4: #ff007f;
  --card-wash: rgba(255, 230, 0, 0.1);
  --card-glow: rgba(255, 230, 0, 0.28);
  --card-bandera: linear-gradient(180deg, var(--card-accent), var(--card-accent-2));
  --card-bandera-horizontal: linear-gradient(90deg, var(--card-accent), var(--card-accent-2));
  --card-bandera-diagonal: linear-gradient(135deg, var(--card-wash), rgba(255, 255, 255, 0.08));
}

.card-equipo > * {
  position: relative;
  z-index: 3;
}

.card-equipo::before {
  content: "";
  position: absolute;
  inset: 0.75rem auto 0.75rem 0.65rem;
  width: 0.28rem;
  border-radius: 99rem;
  background: var(--card-bandera);
  box-shadow: 0 0 0.9rem var(--card-glow);
  opacity: 0.86;
  pointer-events: none;
  transition:
    opacity 0.25s ease,
    box-shadow 0.25s ease,
    width 0.25s ease;
}

.card-equipo::after {
  --contorno-angulo: 0turn;
  content: "";
  position: absolute;
  z-index: 2;
  inset: -0.18rem;
  border-radius: 0.65rem;
  padding: 0.13rem;
  background:
    conic-gradient(
      from var(--contorno-angulo),
      transparent 0turn,
      transparent 0.62turn,
      rgba(255, 230, 0, 0.18) 0.72turn,
      #ffffff 0.78turn,
      #ffe600 0.85turn,
      transparent 0.96turn,
      transparent 1turn
    );
  filter:
    drop-shadow(0 0 0.35rem rgba(255, 255, 255, 0.78))
    drop-shadow(0 0 0.55rem rgba(255, 230, 0, 0.62));
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  mask-composite: exclude;
}

.arena-prediccion.partido-activo .card-equipo {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.card-encabezado {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.card-etiqueta {
  color: #d9d4e8;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.card-codigo {
  width: 3.2rem;
  min-width: 3.2rem;
  min-height: 2.15rem;
  display: grid;
  place-items: center;
  border: 0.08rem solid var(--card-accent);
  border-radius: 0.42rem;
  background:
    var(--card-bandera-horizontal) top / 100% 0.22rem no-repeat,
    linear-gradient(135deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.05)),
    rgba(18, 12, 31, 0.72);
  color: #ffffff;
  font-size: 0.88rem;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 0 1rem var(--card-glow);
}

.card-nombre {
  color: #ffffff;
  font-size: clamp(1.2rem, 3.5vw, 1.95rem);
  line-height: 1.05;
  overflow-wrap: anywhere;
  align-self: center;
  text-shadow: 0 0 0.85rem rgba(255, 255, 255, 0.16);
}

.card-probabilidad {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 0.7rem;
  border-top: 0.08rem solid rgba(255, 255, 255, 0.12);
  padding-top: 0.75rem;
}

.card-probabilidad span {
  color: #bdb5d2;
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: uppercase;
}

.card-probabilidad-valor {
  color: #ffffff;
  font-size: clamp(1.25rem, 4vw, 1.75rem);
  font-weight: 900;
  line-height: 0.95;
  text-shadow:
    0 0 0.35rem rgba(255, 255, 255, 0.28),
    0 0 0.95rem rgba(255, 255, 255, 0.18);
}

.arena-prediccion.partido-activo .card-equipo.elegida {
  border-color: rgba(255, 230, 0, 0.60);
  background:
    var(--card-bandera-diagonal),
    linear-gradient(180deg, var(--card-wash), transparent 62%),
    rgba(255, 255, 255, 0.1);
  box-shadow:
    0 0 0.45rem rgba(255, 255, 255, 0.34),
    0 0 1.3rem rgba(255, 230, 0, 0.44),
    0 0 2.4rem rgba(255, 230, 0, 0.26);
  transform: translateY(-0.2rem) scale(1.03);
}

.arena-prediccion.partido-activo .card-equipo.elegida::before {
  width: 0.36rem;
  opacity: 1;
  box-shadow:
    0 0 0.75rem rgba(255, 255, 255, 0.42),
    0 0 1.4rem rgba(255, 230, 0, 0.36);
}

.arena-prediccion.partido-activo .card-equipo.elegida::after {
  opacity: 1;
}

.arena-prediccion.partido-activo .card-equipo.elegida::after {
  animation: recorrer-contorno 2.8s linear infinite;
}

.arena-prediccion.partido-activo .card-equipo.descartada {
  filter: saturate(0.72);
  opacity: 0.48;
  transform: translateY(0.1rem) scale(0.98);
}

.arena-prediccion.partido-activo .card-equipo.empate {
  border-color: rgba(0, 240, 255, 0.58);
  box-shadow:
    0 0 0.45rem rgba(255, 255, 255, 0.28),
    0 0 1.35rem rgba(0, 240, 255, 0.38),
    0 0 2.35rem rgba(0, 119, 255, 0.2);
  transform: translateY(-0.12rem) scale(1.015);
}

.arena-prediccion.partido-activo .card-equipo.empate::before {
  width: 0.36rem;
  opacity: 1;
  box-shadow:
    0 0 0.75rem rgba(255, 255, 255, 0.34),
    0 0 1.4rem rgba(0, 240, 255, 0.36);
}

.arena-prediccion.partido-activo .card-equipo.empate::after {
  background:
    conic-gradient(
      from var(--contorno-angulo),
      transparent 0turn,
      transparent 0.62turn,
      rgba(0, 240, 255, 0.2) 0.72turn,
      #ffffff 0.78turn,
      #00f0ff 0.85turn,
      transparent 0.96turn,
      transparent 1turn
    );
  filter:
    drop-shadow(0 0 0.35rem rgba(255, 255, 255, 0.68))
    drop-shadow(0 0 0.55rem rgba(0, 240, 255, 0.62));
  opacity: 1;
  animation: recorrer-contorno 2.8s linear infinite;
}

.arena-prediccion.consultando .card-equipo,
.arena-prediccion.pensando .card-equipo {
  opacity: 0.72;
}

.marcadamus {
  width: clamp(10.5rem, 24vw, 20rem);
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  overflow: visible;
  padding: clamp(0.25rem, 1vw, 0.55rem);
  justify-self: center;
  position: relative;
  z-index: 5;
  transition: transform 0.72s cubic-bezier(0.2, 0.85, 0.2, 1.2), box-shadow 0.35s ease;
  will-change: transform;
}

.marcadamus img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  transform-origin: center;
  filter:
    saturate(1.18)
    contrast(1.07)
    drop-shadow(0 0 0.4rem rgba(255, 255, 255, 0.38))
    drop-shadow(0 0 0.95rem rgba(255, 230, 0, 0.4))
    drop-shadow(0 0 1.45rem rgba(0, 240, 255, 0.22));
  animation: flotar-marcadamus 3.2s ease-in-out infinite alternate;
}

.arena-prediccion.consultando .marcadamus img {
  animation: aleteo 0.55s ease-in-out infinite alternate;
}

.arena-prediccion.pensando .marcadamus {
  transform: translateY(-0.35rem) scale(1.04);
}

.arena-prediccion.pensando .marcadamus img {
  animation: pensamiento-marcadamus 0.95s ease-in-out infinite alternate;
}

.arena-prediccion.elige-izquierda .marcadamus {
  transform: translateX(calc(var(--vuelo-marcadamus) * -1)) translateY(var(--flotacion-marcadamus)) scale(0.72) rotate(-5deg);
}

.arena-prediccion.elige-derecha .marcadamus {
  transform: translateX(var(--vuelo-marcadamus)) translateY(var(--flotacion-marcadamus)) scale(0.72) rotate(5deg);
}

.arena-prediccion.elige-empate .marcadamus {
  transform: translateY(-0.35rem) scale(1.02);
}

.controles {
  width: min(100%, 34rem);
  display: grid;
  gap: 0.85rem;
}

label {
  color: #d9d4e8;
  font-weight: 700;
  text-align: left;
}

select {
  width: 100%;
  min-height: 3.25rem;
  border: 0.12rem solid rgba(0, 240, 255, 0.55);
  border-radius: 0.5rem;
  background: rgba(255, 255, 255, 0.09);
  color: #ffffff;
  padding: 0 1rem;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

select:focus {
  border-color: #00f0ff;
  box-shadow: 0 0 0 0.22rem rgba(0, 240, 255, 0.18);
}

option {
  background: #120c1f;
  color: #ffffff;
}

button {
  min-height: 3.35rem;
  border: 0;
  border-radius: 0.5rem;
  background: linear-gradient(135deg, #ff007f, #ffe600);
  color: #120c1f;
  cursor: pointer;
  font-weight: 800;
  padding: 0.9rem 1.2rem;
  box-shadow: 0 0.9rem 1.8rem rgba(255, 0, 127, 0.25);
  transition: transform 0.2s ease, filter 0.2s ease, box-shadow 0.2s ease;
}

button:hover:not(:disabled) {
  filter: brightness(1.12);
  transform: scale(1.03);
  box-shadow: 0 1.1rem 2.25rem rgba(255, 230, 0, 0.22);
}

button:disabled {
  cursor: wait;
  filter: grayscale(0.35) brightness(0.85);
}

.resultado {
  width: min(100%, 34rem);
  min-height: 8rem;
  display: grid;
  gap: 0.5rem;
  align-content: center;
  border: 0.12rem solid rgba(255, 255, 255, 0.12);
  border-radius: 0.5rem;
  background: rgba(255, 255, 255, 0.08);
  padding: 1.25rem;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.5s ease-in-out, visibility 0.5s ease-in-out;
}

.resultado.mostrar {
  opacity: 1;
  visibility: visible;
}

.resultado-titulo {
  color: #ffe600;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.resultado strong {
  color: #00f0ff;
  font-size: clamp(1.55rem, 6vw, 2.35rem);
}

.resultado p {
  color: #e7e2f5;
  line-height: 1.55;
}

@keyframes flotar-marcadamus {
  from {
    transform: translateY(0) rotate(-1.5deg) scale(1);
  }

  to {
    transform: translateY(-0.4rem) rotate(1.5deg) scale(1.02);
  }
}

@keyframes aleteo {
  from {
    transform: translateY(0) rotate(-3deg);
  }

  to {
    transform: translateY(-0.45rem) rotate(4deg);
  }
}

@keyframes pensamiento-marcadamus {
  from {
    transform: translateY(0) rotate(-2deg) scale(1);
  }

  to {
    transform: translateY(-0.75rem) rotate(2deg) scale(1.03);
  }
}

@keyframes recorrer-contorno {
  to {
    --contorno-angulo: 1turn;
  }
}

@media (max-width: 36rem) {
  .logo-superior {
    position: static;
    width: clamp(6.75rem, 45vw, 8.75rem);
    margin: auto;
    padding-top: 1em;
  }

  .app {
    min-height: auto;
    padding: 0.75rem 1rem 1rem;
  }

  .panel-predictor {
    gap: 1.15rem;
  }

  .arena-prediccion {
    --vuelo-marcadamus: clamp(5rem, 25vw, 8.5rem);
    --flotacion-marcadamus: clamp(3.35rem, 18vw, 5.4rem);
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0.85rem;
  }

  .arena-prediccion.ganador-compacto {
    --flotacion-marcadamus: clamp(1.5rem, 8vw, 2.75rem);
    row-gap: 0.35rem;
  }

  .marcadamus {
    grid-column: 1 / 3;
    grid-row: 1;
    width: clamp(9.5rem, 46vw, 12rem);
    transition:
      transform 0.72s cubic-bezier(0.2, 0.85, 0.2, 1.2),
      margin-bottom 0.35s ease,
      box-shadow 0.35s ease;
  }

  .arena-prediccion.ganador-compacto .marcadamus {
    margin-bottom: clamp(-4.5rem, -18vw, -3rem);
  }

  .card-equipo {
    min-height: 10rem;
    grid-row: 2;
    gap: 0.7rem;
    padding: 0.9rem;
    padding-left: 1.15rem;
  }

  .card-codigo {
    width: 2.85rem;
    min-width: 2.85rem;
    min-height: 1.95rem;
    font-size: 0.78rem;
  }

  .card-probabilidad {
    align-items: start;
    flex-direction: column;
    gap: 0.4rem;
  }
}
