/**
 * Estilos para el mostrador público de clasificaciones publicadas.
 * Optimizado para filtros laterales fijos y listado de publicaciones en grilla de 4 columnas en escritorio.
 */

/* Contenedor Principal y Layout en Escritorio */
.vem-public-classification-board {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    color: #1e293b;
    max-width: 1400px;
    margin: 20px auto;
    padding: 0 20px;
    box-sizing: border-box;
    
    /* Grid estructural para pantallas grandes */
    display: grid;
    grid-template-columns: 280px minmax(0, 1fr);
    gap: 20px 24px;
}

.vem-public-classification-board *,
.vem-public-classification-board *::before,
.vem-public-classification-board *::after {
    box-sizing: border-box;
}

/* Elementos de Ancho Completo en la Grilla Superior e Inferior */
.vem-public-classification-board .vem-pcb-status {
    grid-column: 1 / -1;
    grid-row: 2;
}

/* Cabecera Institucional (Hero) - Configurado como contenedor Flex real */
.vem-public-classification-board .vem-pcb-header {
    grid-column: 1 / -1;
    grid-row: 1;
    background: linear-gradient(135deg, #1e3a8a, #2563eb);
    padding: 24px; /* Padding equilibrado e integrado al layout */
    border-radius: 8px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    min-height: 82px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

/* Bloque contenedor del contenido textual del Hero */
.vem-public-classification-board .vem-pcb-header-content {
    flex: 1;
    min-width: 0;
}

.vem-public-classification-board .vem-pcb-title {
    margin: 0 0 6px 0;
    font-size: 26px;
    font-weight: 800;
    letter-spacing: -0.5px;
    color: #ffffff;
}

.vem-public-classification-board .vem-pcb-subtitle {
    margin: 0;
    font-size: 14px;
    color: #93c5fd;
    font-weight: 400;
    line-height: 1.4;
}

/* Barra de Herramientas (Toolbar) - Reglas normales de hijo flex */
.vem-public-classification-board .vem-pcb-toolbar {
    position: static;
    transform: none;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-shrink: 0;
    margin: 0;
    padding: 0;
}

/* Botón de Actualización */
.vem-public-classification-board .vem-pcb-refresh {
    background-color: #10b981;
    color: #ffffff;
    border: 1px solid #059669;
    padding: 10px 18px;
    font-size: 13px;
    font-weight: 700;
    border-radius: 20px;
    cursor: pointer;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    transition: all 0.15s ease-in-out;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}

.vem-public-classification-board .vem-pcb-refresh::before {
    content: "↻";
    font-size: 15px;
    font-weight: 800;
    display: inline-block;
}

.vem-public-classification-board .vem-pcb-refresh:hover {
    background-color: #059669;
    border-color: #047857;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.15);
    transform: translateY(-1px);
}

.vem-public-classification-board .vem-pcb-refresh:active {
    transform: translateY(0);
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1);
}

/* ==========================================================
    ÁREA 0: SOLAPAS DE INSTANCIA
   ========================================================== */
.vem-public-classification-board .vem-pcb-instance-tabs {
    grid-column: 2;
    grid-row: 3;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    column-gap: 28px;
	row-gap: 18px;
    margin: 4px 0 8px 0;
    padding: 6px 0 10px 0;
}

.vem-public-classification-board .vem-pcb-instance-tab {
    appearance: none;
    position: relative;
    border: 2px solid #cbd5e1;
    background-color: #ffffff;
    color: #334155;
    border-radius: 999px;
    width: 185px;
    min-width: 185px;
    max-width: 185px;
    min-height: 54px;
    padding: 12px 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: 0.2px;
    cursor: pointer;
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease;
    box-shadow:
        inset 0 0 0 2px rgba(255, 255, 255, 0.92),
        0 2px 6px rgba(15, 23, 42, 0.06);
    white-space: normal;
    overflow-wrap: anywhere;
}

/* Hover general */
.vem-public-classification-board .vem-pcb-instance-tab:hover {
    transform: translateY(-1px);
    box-shadow:
        inset 0 0 0 2px rgba(255, 255, 255, 0.96),
        0 6px 14px rgba(15, 23, 42, 0.10);
}

/* Foco accesible */
.vem-public-classification-board .vem-pcb-instance-tab:focus-visible {
    outline: none;
    box-shadow:
        inset 0 0 0 2px rgba(255, 255, 255, 0.96),
        0 0 0 3px rgba(37, 99, 235, 0.22),
        0 6px 14px rgba(15, 23, 42, 0.10);
}

/* Solapa activa: muy evidente visualmente */
.vem-public-classification-board .vem-pcb-instance-tab.vem-pcb-instance-tab-active {
    color: #0f172a;
    transform: translateY(-1px) scale(1.02);
    box-shadow:
        inset 0 0 0 2px rgba(255, 255, 255, 0.98),
        0 0 0 2px rgba(15, 23, 42, 0.10),
        0 8px 18px rgba(15, 23, 42, 0.14);
}

.vem-public-classification-board .vem-pcb-instance-tab.vem-pcb-instance-tab-active::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -7px;
    width: 28px;
    height: 4px;
    border-radius: 999px;
    background-color: currentColor;
    transform: translateX(-50%);
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.18);
}

/* Paleta pastel por posición */
.vem-public-classification-board .vem-pcb-instance-tab:nth-child(1) {
    background-color: #f8fafc;
    border-color: #cbd5e1;
    color: #334155;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(2) {
    background-color: #fee2e2;
    border-color: #fca5a5;
    color: #9f1239;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(3) {
    background-color: #fef3c7;
    border-color: #fcd34d;
    color: #92400e;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(4) {
    background-color: #dcfce7;
    border-color: #86efac;
    color: #166534;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(5) {
    background-color: #dbeafe;
    border-color: #93c5fd;
    color: #1d4ed8;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(6) {
    background-color: #ede9fe;
    border-color: #c4b5fd;
    color: #6d28d9;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(7) {
    background-color: #fae8ff;
    border-color: #e9a8fd;
    color: #a21caf;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(8) {
    background-color: #cffafe;
    border-color: #67e8f9;
    color: #0f766e;
}

/* Estado activo reforzado, manteniendo el color de cada solapa */
.vem-public-classification-board .vem-pcb-instance-tab:nth-child(1).vem-pcb-instance-tab-active {
    border-color: #64748b;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(2).vem-pcb-instance-tab-active {
    border-color: #e11d48;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(3).vem-pcb-instance-tab-active {
    border-color: #d97706;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(4).vem-pcb-instance-tab-active {
    border-color: #16a34a;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(5).vem-pcb-instance-tab-active {
    border-color: #2563eb;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(6).vem-pcb-instance-tab-active {
    border-color: #7c3aed;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(7).vem-pcb-instance-tab-active {
    border-color: #c026d3;
}

.vem-public-classification-board .vem-pcb-instance-tab:nth-child(8).vem-pcb-instance-tab-active {
    border-color: #0f766e;
}

/* ==========================================================
    ÁREA 1: FILTROS (Módulo Lateral Independiente)
   ========================================================== */
.vem-public-classification-board .vem-pcb-filters {
    grid-column: 1;
    grid-row: 4 / 30;
    align-self: start;
    position: sticky;
    top: 20px;
    z-index: 10;
    background-color: #f8fafc;
    border: 2px solid #cbd5e1;
    border-radius: 8px;
    padding: 18px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
}

.vem-public-classification-board .vem-pcb-filters-help {
    font-size: 12px;
    line-height: 1.4;
    color: #64748b;
    margin: 0 0 14px 0;
    font-weight: 500;
}

.vem-public-classification-board .vem-pcb-filter-label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    color: #334155;
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.vem-public-classification-board .vem-pcb-search {
    margin-bottom: 12px;
}

.vem-public-classification-board input.vem-pcb-filter-field {
    width: 100%;
    padding: 8px 12px;
    font-size: 13px;
    border: 1px solid #cbd5e1;
    border-radius: 6px;
    background-color: #ffffff;
    transition: border-color 0.15s ease;
}

.vem-public-classification-board input.vem-pcb-filter-field:focus {
    outline: none;
    border-color: #2563eb;
    box-shadow: 0 0 0 1px #2563eb;
}

/* Fila de filtros en panel lateral */
.vem-public-classification-board .vem-pcb-filter-row {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.vem-public-classification-board .vem-pcb-filter-field {
    width: 100%;
}

.vem-public-classification-board .vem-pcb-filter-select {
    width: 100%;
    padding: 8px 10px;
    font-size: 13px;
    color: #334155;
    border: 1px solid #cbd5e1;
    border-radius: 6px;
    background-color: #ffffff;
    cursor: pointer;
    transition: border-color 0.15s ease;
}

.vem-public-classification-board .vem-pcb-filter-select:focus {
    outline: none;
    border-color: #2563eb;
}

.vem-public-classification-board .vem-pcb-results-summary {
    font-size: 12px;
    color: #1e293b;
    margin-top: 14px;
    font-weight: 700;
    line-height: 1.4;
    border-top: 1px solid #cbd5e1;
    padding-top: 12px;
}

/* Columna Derecha del Layout Principal (Listado y Detalle) */
.vem-public-classification-board .vem-pcb-list,
.vem-public-classification-board .vem-pcb-detail {
    grid-column: 2;
}

.vem-public-classification-board .vem-pcb-list {
    grid-row: 4;
}

.vem-public-classification-board .vem-pcb-detail {
    grid-row: 5;
}

/* ==========================================================
    ÁREA 2: LISTADO DE TARJETAS (Módulo Independiente Enmarcado)
   ========================================================== */
.vem-public-classification-board .vem-pcb-list {
    display: block;
    margin: 0;
    background-color: #f1f5f9;
    border: 2px solid #e2e8f0;
    border-radius: 8px;
    padding: 16px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
}

/* Grilla de tarjetas */
.vem-public-classification-board .vem-pcb-context-list {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

/* Tarjetas Compactadas - Altura Uniforme Reducida y Estructura */
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background-color: #ffffff;
    border: 1px solid #cbd5e1;
    border-top: 4px solid #64748b;
    border-radius: 6px;
    padding: 10px;
    height: 225px;
    min-height: 225px;
    gap: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.02);
    transition: all 0.2s ease-in-out;
    overflow: hidden;
}

.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row:hover {
    border-color: #94a3b8;
    transform: translateY(-2px);
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
}

/* Bordes superiores coherentes por familia */
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row-team {
    border-top-color: #2563eb;
}
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row-athletic {
    border-top-color: #16a34a;
}
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row-individual {
    border-top-color: #7c3aed;
}

/* Hovers específicos por familia con paletas más identificables */
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row-team:hover {
    border-top-color: #1d4ed8;
    background-color: #eff6ff;
}
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row-athletic:hover {
    border-top-color: #15803d;
    background-color: #f0fdf4;
}
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row-individual:hover {
    border-top-color: #6d28d9;
    background-color: #f5f3ff;
}

/* Tarjeta Activa Seleccionada con fondo y bordes laterales neutros */
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row.vem-pcb-context-row-active {
    background-color: #f8fafc;
    border-color: #94a3b8;
    box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.10), 0 6px 12px rgba(15, 23, 42, 0.08);
}

/* Reglas específicas para restaurar y conservar el borde superior por categoría en estado activo */
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row-team.vem-pcb-context-row-active {
    border-top-color: #2563eb;
}
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row-athletic.vem-pcb-context-row-active {
    border-top-color: #16a34a;
}
.vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row-individual.vem-pcb-context-row-active {
    border-top-color: #7c3aed;
}

/* Encabezado Superior: Tipo de disciplina con estilos unificados base */
.vem-public-classification-board .vem-pcb-context-row-type {
    display: block;
    width: 100%;
    text-align: center;
    border: 1px solid #cbd5e1;
    padding: 5px 8px;
    border-radius: 4px;
    font-size: 10.5px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    line-height: 1.2;
}

/* Estilos para las franjas bases (Más identitarias y distinguibles) */
.vem-public-classification-board .vem-pcb-context-row-type-team {
    background-color: #bfdbfe;
    color: #1e3a8a;
    border-color: #60a5fa;
}
.vem-public-classification-board .vem-pcb-context-row-type-athletic {
    background-color: #bbf7d0;
    color: #14532d;
    border-color: #4ade80;
}
.vem-public-classification-board .vem-pcb-context-row-type-individual {
    background-color: #ddd6fe;
    color: #4c1d95;
    border-color: #a78bfa;
}

/* Reglas específicas de hover para franjas superiores */
.vem-public-classification-board .vem-pcb-context-row-team:hover .vem-pcb-context-row-type-team {
    background-color: #93c5fd;
    color: #1e3a8a;
    border-color: #3b82f6;
}
.vem-public-classification-board .vem-pcb-context-row-athletic:hover .vem-pcb-context-row-type-athletic {
    background-color: #86efac;
    color: #14532d;
    border-color: #22c55e;
}
.vem-public-classification-board .vem-pcb-context-row-individual:hover .vem-pcb-context-row-type-individual {
    background-color: #c4b5fd;
    color: #4c1d95;
    border-color: #8b5cf6;
}

/* Reglas específicas para franjas superiores en tarjeta activa */
.vem-public-classification-board .vem-pcb-context-row-team.vem-pcb-context-row-active .vem-pcb-context-row-type-team {
    background-color: #93c5fd;
    color: #1e3a8a;
    border-color: #3b82f6;
}
.vem-public-classification-board .vem-pcb-context-row-athletic.vem-pcb-context-row-active .vem-pcb-context-row-type-athletic {
    background-color: #86efac;
    color: #14532d;
    border-color: #22c55e;
}
.vem-public-classification-board .vem-pcb-context-row-individual.vem-pcb-context-row-active .vem-pcb-context-row-type-individual {
    background-color: #c4b5fd;
    color: #4c1d95;
    border-color: #8b5cf6;
}

/* Contenido principal flexible */
.vem-public-classification-board .vem-pcb-context-row-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    width: 100%;
}

/* Cabecera de la Tarjeta (Disciplina + Etapa juntas) */
.vem-public-classification-board .vem-pcb-context-row-heading {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 6px;
    margin-bottom: 6px;
    width: 100%;
}

.vem-public-classification-board .vem-pcb-context-row-title {
    font-size: 13px;
    font-weight: 700;
    color: #0f172a;
    margin: 0;
    line-height: 1.3;
    flex: 1;
    min-width: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Etapa renderizada como Badge */
.vem-public-classification-board .vem-pcb-context-row-stage {
    font-size: 10px;
    font-weight: 700;
    background-color: #e2e8f0;
    color: #334155;
    padding: 2px 6px;
    border-radius: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 90px;
    display: inline-block;
    text-transform: uppercase;
    letter-spacing: 0.2px;
}

/* Ajuste neutro para la etiqueta de instancia en tarjeta activa */
.vem-public-classification-board .vem-pcb-context-row-active .vem-pcb-context-row-stage {
    background-color: #e2e8f0;
    color: #334155;
}

/* Bloque Meta en una Sola Columna Ordenada */
.vem-public-classification-board .vem-pcb-context-row-meta {
    font-size: 11px;
    color: #475569;
    line-height: 1.35;
    display: grid;
    grid-template-columns: 1fr;
    gap: 4px 0;
}

.vem-public-classification-board .vem-pcb-context-row-meta span {
    display: block;
}

.vem-public-classification-board .vem-pcb-context-row-meta span strong {
    color: #334155;
}

/* Alcance más grande, centrado y visible */
.vem-public-classification-board .vem-pcb-context-row-scope {
    text-align: center;
    font-size: 12px;
    font-weight: 800;
    color: #1e293b;
    line-height: 1.3;
    width: 100%;
    margin: 2px 0 4px 0;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
}

/* Ciudades  alineadas a la izquierda con máximo protagonismo (Hasta 3 líneas) */
.vem-public-classification-board .vem-pcb-context-row-cities {
    font-size: 12px;
    font-weight: 800;
    color: #1d4ed8;
    line-height: 1.3;
    margin-top: 2px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    white-space: normal;
    overflow-wrap: anywhere;
}

/* Bloque Inferior de Estadísticas Alineadas */
.vem-public-classification-board .vem-pcb-context-row-stats {
    font-size: 10.5px;
    color: #64748b;
    line-height: 1.3;
    padding: 4px 0 0 0;
    border-top: 1px dashed #cbd5e1;
    width: 100%;
    display: flex;
    justify-content: space-between;
    font-weight: 600;
}

.vem-public-classification-board .vem-pcb-context-row-action {
    width: 100%;
    margin-top: auto;
}

/* Botón de Selección Interno */
.vem-public-classification-board .vem-pcb-context-button {
    background-color: #ffffff;
    color: #2563eb;
    border: 1px solid #cbd5e1;
    padding: 6px 10px;
    font-size: 11px;
    font-weight: 700;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.15s ease;
    width: 100%;
    text-align: center;
}

.vem-public-classification-board .vem-pcb-context-row:hover .vem-pcb-context-button {
    background-color: #2563eb;
    color: #ffffff;
    border-color: #2563eb;
}

/* Botón Activo con versión azul neutra general */
.vem-public-classification-board .vem-pcb-context-row.vem-pcb-context-row-active .vem-pcb-context-button {
    background-color: #2563eb;
    color: #ffffff;
    border-color: #2563eb;
}

/* ==========================================================
    ÁREA 3: PANEL DE DETALLE (Módulo Independiente Enmarcado)
   ========================================================== */
.vem-public-classification-board .vem-pcb-detail {
    background-color: #ffffff;
    border: 2px solid #cbd5e1;
    border-radius: 8px;
    padding: 20px;
    margin-top: 16px;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03);
    /* Margen de desplazamiento superior para scrollIntoView() */
    scroll-margin-top: 24px;
}

/* Encabezado del detalle */
.vem-public-classification-board .vem-pcb-detail-header {
    padding: 12px 16px;
    border-radius: 6px;
    margin-bottom: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    border: 1px solid #cbd5e1;
}

.vem-public-classification-board .vem-pcb-detail-header.vem-pcb-detail-status-provisional {
    background: linear-gradient(135deg, #fffbeb, #fef3c7);
    border-left: 5px solid #d97706;
}

.vem-public-classification-board .vem-pcb-detail-header.vem-pcb-detail-status-processed {
    background: linear-gradient(135deg, #f0fdf4, #dcfce7);
    border-left: 5px solid #16a34a;
}

.vem-public-classification-board .vem-pcb-detail-title {
    font-size: 18px;
    font-weight: 800;
    color: #0f172a;
    margin: 0 0 4px 0;
    letter-spacing: -0.3px;
}

.vem-public-classification-board .vem-pcb-detail-meta {
    font-size: 12px;
    color: #334155;
    margin: 0;
}

/* Etiqueta de Estado de Procesamiento */
.vem-public-classification-board .vem-pcb-detail-status-label {
    display: inline-block;
    padding: 3px 8px;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 12px;
}

.vem-public-classification-board .vem-pcb-detail-status-provisional .vem-pcb-detail-status-label {
    background-color: #f59e0b;
    color: #ffffff;
}

.vem-public-classification-board .vem-pcb-detail-status-processed .vem-pcb-detail-status-label {
    background-color: #16a34a;
    color: #ffffff;
}

/* Bloque de Leyenda Explicativa */
.vem-public-classification-board .vem-pcb-detail-legend {
    background-color: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    padding: 12px 16px;
    margin-bottom: 16px;
}

.vem-public-classification-board .vem-pcb-detail-legend-title {
    font-size: 11px;
    font-weight: 700;
    color: #475569;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 0 0 8px 0;
}

.vem-public-classification-board .vem-pcb-detail-legend-items {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px 20px;
}

.vem-public-classification-board .vem-pcb-detail-legend-item {
    font-size: 11.5px;
    line-height: 1.4;
    color: #334155;
    display: flex;
    align-items: center;
    gap: 8px;
}

.vem-public-classification-board .vem-pcb-detail-legend-dot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    font-size: 11px;
    font-weight: 800;
    background-color: #cbd5e1;
    color: #64748b;
    flex-shrink: 0;
}

.vem-public-classification-board .vem-pcb-detail-legend-dot-provisional {
    background-color: #f59e0b;
    border: 2px solid #d97706;
}

.vem-public-classification-board .vem-pcb-detail-legend-dot-classified {
    background-color: #16a34a;
    border: 2px solid #15803d;
}

/* Tabla interna unificada de Competidores */
.vem-public-classification-board .vem-pcb-unified-results {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* Círculo de Posición Base */
.vem-public-classification-board .vem-pcb-result-position {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 800;
    color: #ffffff;
    background-color: #1e3a8a;
    border: 1px solid #172554;
    width: 30px;
    height: 30px;
    min-width: 30px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* Métricas del Extremo Derecho */
.vem-public-classification-board .vem-pcb-result-metrics {
    display: flex;
    align-items: center;
    margin-left: auto;
    flex-shrink: 0;
    background-color: transparent;
    padding: 0;
}

/* Filas del Detalle Compartadas */
.vem-public-classification-board .vem-pcb-unified-results .vem-pcb-unified-row {
    display: flex;
    align-items: center;
    padding: 8px 14px;
    border: 1px solid #cbd5e1;
    border-radius: 6px;
    gap: 12px;
    transition: all 0.15s ease-in-out;
    background-color: #ffffff;
}

/* Cebreado alternado */
.vem-public-classification-board .vem-pcb-unified-results .vem-pcb-unified-row:not(.vem-pcb-unified-row-provisional):not(.vem-pcb-unified-row-classified):nth-child(even) {
    background-color: #f8fafc;
    border-color: #e2e8f0;
}

.vem-public-classification-board .vem-pcb-unified-results .vem-pcb-unified-row:not(.vem-pcb-unified-row-provisional):not(.vem-pcb-unified-row-classified):hover {
    background-color: #f1f5f9;
}

/* Cabecera interna del competidor - Nombre y Ciudad inline */
.vem-public-classification-board .vem-pcb-result-heading {
    display: block;
    line-height: 1.3;
    white-space: normal;
    word-break: break-word;
}

.vem-public-classification-board .vem-pcb-result-name {
    font-weight: 700;
    color: #0f172a;
    font-size: 14px;
    display: inline;
}

.vem-public-classification-board .vem-pcb-result-city-inline {
    font-size: 12px;
    color: #64748b;
    font-weight: 500;
    margin-left: 4px;
    display: inline;
}

/* Línea secundaria para Escuela o Equipo */
.vem-public-classification-board .vem-pcb-result-extra {
    display: block;
    font-size: 11.5px;
    color: #475569;
    margin-top: 1px;
    font-weight: 500;
    line-height: 1.2;
}

/* Chips de Fecha */
.vem-public-classification-board .vem-pcb-unified-dates {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 6px;
    margin-top: 4px;
    width: 100%;
}

.vem-public-classification-board .vem-pcb-unified-date {
    background-color: #f1f5f9;
    border: 1px solid #e2e8f0;
    border-radius: 4px;
    padding: 3px 8px;
    font-size: 11px;
    color: #334155;
    line-height: 1.3;
    font-weight: 500;
}

.vem-public-classification-board .vem-pcb-unified-row-provisional .vem-pcb-unified-date {
    background-color: #ffffff;
    border-color: #fef08a;
    color: #78350f;
}

.vem-public-classification-board .vem-pcb-unified-row-classified .vem-pcb-unified-date {
    background-color: #ffffff;
    border-color: #bbf7d0;
    color: #14532d;
}

/* Estado: Puesto Clasificatorio Provisional */
.vem-public-classification-board .vem-pcb-unified-results .vem-pcb-unified-row.vem-pcb-unified-row-provisional {
    background-color: #fffde6;
    border: 1px solid #fde047;
    border-left: 5px solid #eab308;
}

.vem-public-classification-board .vem-pcb-unified-results .vem-pcb-unified-row.vem-pcb-unified-row-provisional:hover {
    background-color: #fef9c3;
}

.vem-public-classification-board .vem-pcb-unified-row-provisional .vem-pcb-result-position {
    background-color: #f59e0b;
    color: #ffffff;
    border: 1px solid #d97706;
}

.vem-public-classification-board .vem-pcb-result-metrics-provisional {
    display: inline-block;
    background-color: #fef3c7;
    color: #b45309;
    border: 1px solid #fde68a;
    padding: 3px 8px;
    font-size: 10.5px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    border-radius: 12px;
    white-space: nowrap;
}

/* Estado: Clasificado Confirmado */
.vem-public-classification-board .vem-pcb-unified-results .vem-pcb-unified-row.vem-pcb-unified-row-classified {
    background-color: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-left: 5px solid #16a34a;
}

.vem-public-classification-board .vem-pcb-unified-results .vem-pcb-unified-row.vem-pcb-unified-row-classified:hover {
    background-color: #dcfce7;
}

.vem-public-classification-board .vem-pcb-unified-row-classified .vem-pcb-result-position {
    background-color: #16a34a;
    color: #ffffff;
    border: 1px solid #15803d;
}

.vem-public-classification-board .vem-pcb-result-metrics-classified {
    display: inline-block;
    background-color: #dcfce7;
    color: #14532d;
    border: 1px solid #bbf7d0;
    padding: 3px 8px;
    font-size: 10.5px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    border-radius: 12px;
    white-space: nowrap;
}

/* Puesto Neutro */
.vem-public-classification-board .vem-pcb-result-position.vem-pcb-result-position-neutral {
    background-color: #e2e8f0;
    color: #94a3b8;
    border: 1px solid #cbd5e1;
}

.vem-public-classification-board .vem-pcb-result-main {
    flex: 1;
    min-width: 0;
}

/* Estados de Control de Carga Rest (data-state) */
.vem-public-classification-board .vem-pcb-list[data-state="loading"],
.vem-public-classification-board .vem-pcb-detail[data-state="loading"] {
    position: relative;
    min-height: 100px;
    text-align: center;
    padding: 30px 14px;
    color: #64748b;
    font-weight: 500;
    font-size: 13px;
}

.vem-public-classification-board .vem-pcb-list[data-state="loading"]::before,
.vem-public-classification-board .vem-pcb-detail[data-state="loading"]::before {
    content: "";
    display: block;
    width: 20px;
    height: 20px;
    margin: 0 auto 8px auto;
    border-radius: 50%;
    background-color: #2563eb;
    opacity: 0.6;
    animation: vemPcbPulse 1.2s infinite ease-in-out;
}

.vem-public-classification-board .vem-pcb-detail[data-state="idle"] {
    display: none;
}

@keyframes vemPcbPulse {
    0% { transform: scale(0.6); opacity: 0.2; }
    50% { transform: scale(1.0); opacity: 0.8; }
    100% { transform: scale(0.6); opacity: 0.2; }
}

/* Mensajes Especiales de Alertas */
.vem-public-classification-board .vem-pcb-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 20px;
    color: #64748b;
    background-color: #f8fafc;
    border: 1px dashed #cbd5e1;
    border-radius: 6px;
    font-size: 13px;
}

.vem-public-classification-board .vem-pcb-error,
.vem-public-board-error {
    padding: 14px 18px;
    background-color: #fde8e8;
    color: #9b1c1c;
    border: 1px solid #f8b4b4;
    border-radius: 6px;
    font-weight: 600;
    font-size: 13px;
}

.vem-public-board-error {
    max-width: 1400px;
    margin: 20px auto;
}

/* Soporte para Vistas Heredadas */
.vem-public-classification-board .vem-pcb-context-card {
    background: #ffffff;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    padding: 12px;
    margin-bottom: 12px;
}

/* ==========================================================
    RESPONSIVE - BREAKPOINTS ADAPTATIVOS
   ========================================================== */

/* Laptop / Tablet Horizontal: Altura uniforme compactada adaptada */
@media (max-width: 1200px) {
    .vem-public-classification-board .vem-pcb-context-list {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row {
        height: 225px;
        min-height: 225px;
    }
}

/* Tablet Vertical: Bajada a 2 columnas y reordenamiento de módulos con altura optimizada */
@media (max-width: 950px) {
    .vem-public-classification-board {
        display: block;
    }
    
    .vem-public-classification-board .vem-pcb-instance-tabs {
		grid-column: auto;
		justify-content: center;
		column-gap: 20px;
		row-gap: 14px;
		margin-bottom: 18px;
	}
    
    .vem-public-classification-board .vem-pcb-header {
        display: flex; /* Garantiza mantener la disposición flexible dentro del hero */
    }

    .vem-public-classification-board .vem-pcb-filters {
        position: static;
        width: 100%;
        margin-bottom: 20px;
    }

    .vem-public-classification-board .vem-pcb-filter-row {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }
    
    .vem-public-classification-board .vem-pcb-list {
        margin-bottom: 20px;
    }

    .vem-public-classification-board .vem-pcb-context-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row {
        height: 235px;
        min-height: 235px;
    }
}

@media (max-width: 768px) {
    .vem-public-classification-board .vem-pcb-detail-legend-items {
        grid-template-columns: 1fr;
        gap: 10px;
    }
}

/* Dispositivos Móviles: Flujo en 1 columna y adaptaciones críticas */
@media (max-width: 650px) {
    .vem-public-classification-board {
        padding: 0 10px;
    }
    
    /* Adaptación de la distancia de scroll superior en móvil */
    .vem-public-classification-board .vem-pcb-detail {
        scroll-margin-top: 12px;
    }

    .vem-public-classification-board .vem-pcb-instance-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
        gap: 16px;
        padding: 2px 2px 8px 2px;
        margin-bottom: 14px;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
    }

    .vem-public-classification-board .vem-pcb-instance-tab {
        width: 150px;
        min-width: 150px;
        max-width: 150px;
        min-height: 48px;
        padding: 10px 16px;
        font-size: 13px;
        flex: 0 0 auto;
    }

    /* Adaptación del Hero en flujo block apilando elementos verticalmente */
    .vem-public-classification-board .vem-pcb-header {
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 16px;
    }

    .vem-public-classification-board .vem-pcb-toolbar {
        position: static;
        transform: none;
        width: 100%;
        margin: 14px 0 0;
        display: flex;
        justify-content: center;
    }

    .vem-public-classification-board .vem-pcb-refresh {
        width: 100%;
        max-width: 280px;
    }

    .vem-public-classification-board .vem-pcb-filter-row {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .vem-public-classification-board .vem-pcb-context-list {
        grid-template-columns: 1fr;
    }

    /* En móvil se permite altura auto para mayor seguridad del contenido */
    .vem-public-classification-board .vem-pcb-context-list .vem-pcb-context-row {
        height: auto;
        min-height: 0;
    }

    .vem-public-classification-board .vem-pcb-context-row-meta {
        grid-template-columns: 1fr;
    }

    .vem-public-classification-board .vem-pcb-unified-results .vem-pcb-unified-row {
        flex-wrap: wrap;
        padding: 12px;
        gap: 10px;
        align-items: flex-start;
    }
    
    .vem-public-classification-board .vem-pcb-unified-row .vem-pcb-result-position {
        order: 1;
    }
    
    .vem-public-classification-board .vem-pcb-unified-row .vem-pcb-result-main {
        order: 2;
        flex: 1;
        min-width: calc(100% - 46px);
    }

    .vem-public-classification-board .vem-pcb-result-name,
    .vem-public-classification-board .vem-pcb-result-city-inline {
        display: inline-block;
    }
    
    .vem-public-classification-board .vem-pcb-unified-row .vem-pcb-result-metrics {
        order: 3;
        width: 100%;
        margin-left: 0;
        margin-top: 4px;
    }

    .vem-public-classification-board .vem-pcb-result-metrics-provisional,
    .vem-public-classification-board .vem-pcb-result-metrics-classified {
        display: block;
        width: 100%;
        text-align: center;
    }
    
    .vem-public-classification-board .vem-pcb-unified-dates {
        flex-direction: column;
        width: 100%;
        order: 4;
        margin-top: 8px;
        gap: 4px;
    }
    
    .vem-public-classification-board .vem-pcb-unified-date {
        display: block;
        width: 100%;
        white-space: normal;
    }

    .vem-public-classification-board .vem-pcb-result-row {
        gap: 8px;
    }

    .vem-public-classification-board .vem-pcb-detail-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        padding: 12px;
    }
}