/* =========================================================================
   ESTADÍSTICAS — gráficos en CSS puro (sin librerías).
   Las barras crecen al entrar en pantalla (clase .is-visible vía home.js).
   ========================================================================= */

.cpeis-charts-2 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(330px, 1fr));
    gap: var(--cpeis-space-3);
}
/* Rejilla 2×2 con TODAS las tarjetas del mismo tamaño (filas a 1fr) y
   espaciado homogéneo. */
.cpeis-charts-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 1fr;
    gap: var(--cpeis-space-3);
}
@media (max-width: 600px) {
    .cpeis-charts-grid { grid-template-columns: 1fr; grid-auto-rows: auto; }
}

.cpeis-charts-2 { align-items: stretch; }
.cpeis-chartcard {
    display: flex;
    flex-direction: column;
    background: var(--cpeis-fondo);
    border: 1px solid var(--cpeis-borde);
    border-radius: var(--cpeis-radius-lg);
    box-shadow: var(--cpeis-shadow);
    padding: clamp(1.4rem, 3vw, 2.25rem);
}
/* Ancla el gráfico al fondo de la tarjeta: así las bases (eje X) de los
   gráficos de una misma fila quedan siempre al mismo nivel. */
.cpeis-chartcard .cpeis-vbars-scroll { margin-top: auto; }
/* Separación entre la tarjeta a ancho completo (Tipos) y las rejillas. */
.cpeis-chartcard + .cpeis-charts-2,
.cpeis-chartcard + .cpeis-charts-grid,
.cpeis-charts-2 + .cpeis-charts-grid { margin-top: var(--cpeis-space-3); }
.cpeis-chartcard__title { font-size: var(--cpeis-fs-grande); font-weight: 600; margin: 0 0 0.25rem; }
.cpeis-chartcard__sub { font-size: var(--cpeis-fs-pequeno); color: var(--cpeis-texto-secundario); margin: 0 0 clamp(1.25rem, 3vw, 1.75rem); }

/* --- Barras verticales --------------------------------------------------- */
.cpeis-vbars-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.cpeis-vbars {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    align-items: end;
    gap: clamp(0.25rem, 1vw, 0.7rem);
    height: 260px;
    padding-top: 1.6rem;
    min-width: 460px;
}
.cpeis-vbar {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    height: 100%;
    gap: 0.5rem;
    min-width: 0;
}
.cpeis-vbar__bar {
    width: 100%;
    max-width: 48px;
    margin-inline: auto;
    display: flex;
    align-items: flex-end;
    height: 100%;
}
.cpeis-vbar__fill {
    position: relative;
    width: 100%;
    height: 0;
    border-radius: 7px 7px 0 0;
    background: linear-gradient(180deg, var(--cpeis-acento), var(--cpeis-acento-oscuro));
    transition: height 1.1s cubic-bezier(0.16, 1, 0.3, 1);
}
.cpeis-chart.is-visible .cpeis-vbar__fill { height: var(--h); }
.cpeis-vbar.is-max .cpeis-vbar__fill {
    background: linear-gradient(180deg, var(--cpeis-oro), var(--cpeis-acento));
    box-shadow: 0 6px 18px rgba(206,16,25,0.3);
}
.cpeis-vbar__val {
    position: absolute;
    top: -1.35rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--cpeis-texto);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}
.cpeis-vbar__cat {
    font-size: 0.72rem;
    color: var(--cpeis-texto-secundario);
    text-align: center;
    line-height: 1.2;
}

/* --- Barras horizontales ------------------------------------------------- */
.cpeis-hbars { display: flex; flex-direction: column; gap: 0.7rem; }
.cpeis-hbar {
    display: grid;
    grid-template-columns: minmax(110px, 190px) 1fr auto;
    align-items: center;
    gap: 0.85rem;
}
.cpeis-hbar__label {
    font-size: var(--cpeis-fs-pequeno);
    font-weight: 600;
    color: var(--cpeis-texto);
    text-align: right;
    line-height: 1.2;
}
.cpeis-hbar__track {
    display: block;
    height: 14px;
    background: var(--cpeis-fondo-alt);
    border-radius: var(--cpeis-radius-pill);
    overflow: hidden;
}
.cpeis-hbar__fill {
    display: block;
    height: 100%;
    width: 0;
    border-radius: var(--cpeis-radius-pill);
    background: linear-gradient(90deg, var(--cpeis-acento-oscuro), var(--cpeis-acento));
    transition: width 1.1s cubic-bezier(0.16, 1, 0.3, 1);
}
.cpeis-chart.is-visible .cpeis-hbar__fill { width: var(--w); }
.cpeis-hbar.is-max .cpeis-hbar__fill { background: linear-gradient(90deg, var(--cpeis-acento), var(--cpeis-oro)); }
.cpeis-hbar__val {
    font-variant-numeric: tabular-nums;
    font-weight: 700;
    color: var(--cpeis-acento);
    font-size: var(--cpeis-fs-pequeno);
    min-width: 4ch;
    text-align: right;
}

@media (max-width: 560px) {
    .cpeis-hbar { grid-template-columns: minmax(88px, 130px) 1fr auto; gap: 0.5rem; }
    .cpeis-hbar__label { font-size: 0.8rem; }
}

/* Nota al pie de la sección de datos */
.cpeis-stats-note {
    margin-top: var(--cpeis-space-3);
    font-size: var(--cpeis-fs-pequeno);
    color: var(--cpeis-texto-secundario);
    text-align: center;
}
