:root {
    --grid-template-columns: 1fr 1.5fr repeat(6, 1fr);
    --font-size-tabla: clamp(9px, 2.5vw, 20px);
}

section {
    padding: 15px 0px;
}

.flex-container {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 1rem; /* Espacio entre los divs */
}

.flex-container > * {
    flex: 1 1 45%; /* que ocupen 45% en desktop y se adapten */
}

.filters {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-around;
    gap: 1rem; /* Espacio entre los divs */
}

.box { 
    background-color: white;
    padding: 20px;
    /* Border */
    border: 3px solid transparent;
    border-radius: 15px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    /* Alineacion */
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.filters-container {
    background-color: var(--color-secundario-claro);
}

/* Ajuste para el canvas */
#graficoGananciaPais {
    max-width: 100%;
}

/* Numbers */
.numbers-container {
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    align-content: space-around; 
}

.big_number {
    font-size: 6vw;
    font-size: clamp(30px, 8vw, 90px);
    text-align: center;
    white-space: nowrap;
}

.stat_num {
    font-size: 20px;
    text-align: center;
}

/* ---------- Listado de partidos ------------*/
.tabla-predicciones {
  width: 100%;
  font-family: sans-serif;
  border: 1px solid #ccc;
  border-radius: 6px;
  overflow: hidden;
}

.table-header, .table-row {
  display: grid;
  grid-template-columns: var(--grid-template-columns);
  border-bottom: 1px solid #eee;
  align-items: center;

  /* Font size */
  word-break: break-all;
  font-size: var(--font-size-tabla);
}

.table-header {
  background-color: #f5f5f5;
  font-weight: bold;
}

.teams {
  display: flex;
  flex-direction: column;
}

.result {
    /* Display & Position */
    display: flex;
    align-content: center;
    align-items: center;
    justify-content: center;

    /* Box model */
    margin: 0 auto;  /* Para centrar cuadrado horizontalmente en columna */
    height: 30px;/* Tamaño del cuadrado Mobile - Desktop*/  
    height: clamp(15px, 4vw, 30px);
    aspect-ratio: 1 / 1; /* Relación de aspecto 1:1 para un cuadrado */    
}

.result.positivo {
    /* estilos para el caso positivo */
    color: #fff;
    background-color: #4CAF50;
    border: 2px solid #4CAF50;
    border-radius: 50%;
}

.result.negativo {     
    /* estilos para el caso negativo */
    border-radius: 50%;
    color: #D70500;
    border: 2px solid #D70500;
}


/* Mobile: apilados */
@media (max-width: 768px) {
    .box {
        flex: 1 1 100%;
    }

    .filters {
        flex-direction: column;
    }
}