/* --- Variables Globales del Plugin --- */
:root {
    --calendario-color-primary: var(--c-azul);
    --calendario-color-light-gray: var(--c-softgrayazul);
    --calendario-color-medium-gray: var(--c-gris);
    --calendario-color-dark-gray: var(--c-grismedio);
    --escuela-color-default: var(--c-turquesa);
    --calendario-color-border: var(--escuela-color-default);
    --calendario-spacing-large: var(--espacio-sm);
    --calendario-spacing-medium: var(--espacio-xs);
    --calendario-spacing-small: var(--espacio-xxs);
    --calendario-border-radius-sm: 5px;
    --calendario-border-radius-md: 7px;
    --calendario-border-radius-lg: 10px;
    --calendario-border-radius-round: 50%;
}

/* --- Barra de Búsqueda Principal --- */
.calendario-barra-busqueda {
    margin-bottom: var(--espacio-sm);
    padding-block: var(--espacio-md);
    background-color: var(--c-azul);
    /*overflow: visible;*/
    position: relative;

    width: 100vw; /* Ocupa todo el ancho de la ventana */
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
}
.calendario-barra-busqueda > .wrapper {
    max-width: 1200px; /* Limita el ancho del contenido interno */
    margin: 0 auto;
    padding: 0 var(--calendario-spacing-medium);
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    gap: var(--espacio-sm);
}
.calendario-barra-busqueda > .widebg {
    display: block;
    position: absolute;
    width: 300vw;
    top: 0;
    left: -100vw;
    height: calc(var(--espacio-md) * 2 + var(--espacio-xs) * 2 + var(--lh-md));
    background: var(--c-azul);
    z-index: -1;
}
.calendario-barra-busqueda input[type="search"] {
    flex-grow: 1;
    padding: var(--espacio-xs);
    padding-left: var(--espacio-md);
    border: none;
    border-radius: var(--calendario-border-radius-sm);
    font-size: var(--fs-md);
    outline: none;
    margin: 0;
    background-color: var(--c-blanco);
    color: var(--c-azul);
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-search" viewBox="0 0 16 16"><path d="M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z"/></svg>');
    background-repeat: no-repeat;
    background-position: var(--espacio-xs) center;
    background-size: var(--fs-sm);
}

/* --- Áreas de Formación (Rediseñado) --- */
.calendario-areas-formacion {
    background-color: transparent; /* Sin fondo gris */
    padding: 0;
    margin-bottom: var(--calendario-spacing-large);
    padding-bottom: var(--calendario-spacing-medium);
}
.calendario-areas-formacion .areas-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--calendario-spacing-medium);
}
.calendario-areas-formacion h4 {
    margin: 0;
    font-size: var(--fs-md);
    font-weight: var(--fw-light);
    color: #333;
    text-transform: uppercase;
}
.calendario-areas-formacion .area-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: var(--calendario-spacing-small);
}
.calendario-areas-formacion .area-button {
    background-color: var(--calendario-color-light-gray);
    border: 1px solid var(--calendario-color-medium-gray);
    padding: 10px 15px;
    border-radius: 20px;
    cursor: pointer;
    transition: all 0.1s ease;
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-width: 31ch;
    font-size: var(--fs-sm);
    font-weight: var(--fw-medium);
}
.calendario-areas-formacion .area-button .check-icon {
    width: 16px;
    height: 16px;
    margin-left: 10px;
    fill: white;
    display: inline-block;
    visibility: hidden;
    background: var(--c-blanco);
    color: var(--c-azul);
    fill: var(--c-azul);
}
.calendario-areas-formacion .area-button.active {
    background-color: var(--calendario-color-primary);
    color: white;
    border-color: var(--calendario-color-primary);
}
.calendario-areas-formacion .area-button.active .check-icon {
    visibility: visible;
}
.calendario-borrar-filtros {
    padding: 0.5rem 3rem;
    font-size: var(--fs-sm);
}

/* --- Layout Principal (Sidebar y Resultados) --- */
.calendario-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: var(--calendario-spacing-large);
}

/* --- Filtros de Búsqueda (Sidebar) --- */
.calendario-sidebar-filtros h4 {
    font-size: var(--fs-md);
    font-weight: var(--fw-light);
    margin-bottom: var(--calendario-spacing-small);
    text-transform: uppercase;
}
.calendario-sidebar-filtros fieldset {
    border: none;
    padding: 0;
    margin: 0 0 var(--calendario-spacing-medium) 0;
}
.calendario-sidebar-filtros legend {
    font-weight: var(--fw-semibold);
    padding: 0;
    margin-bottom: 0.5em;
    border: 0 none;
}
.calendario-sidebar-filtros label {
    display: flex;
    align-items: center;
    margin-bottom: 0.5em;
    cursor: pointer;
    font-size: var(--fs-sm);
}
.calendario-sidebar-filtros input[type="radio"],
.calendario-sidebar-filtros input[type="checkbox"] {
    margin-right: 0.5em;
    padding: 1rem;
    width: auto;
}
/* Oculta el radio button original */
.calendario-sidebar-filtros label input[type="radio"],
.calendario-sidebar-filtros label input[type="checkbox"] {
    display: none;
}

/* Estilo para el contenedor del checkbox simulado (el span) */
.calendario-sidebar-filtros label span {
    display: grid;
    align-items: center;
    position: relative;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    grid-template-columns: var(--lh-sm) auto;
    column-gap: var(--espacio-xxxs);
    font-weight: var(--fw-light);
}

/* Crea el cuadro del checkbox */
.calendario-sidebar-filtros label span::before {
    content: '';
    display: inline-block;
    width: var(--lh-sm);
    height: var(--lh-sm);
    border: 1px solid var(--calendario-color-medium-gray);
    border-radius: 0;
    margin-right: 8px;
    background-color: var(--c-blanco);
    transition: all 0.1s ease;
    grid-column: 1 / 2;
    grid-row: 1 / 2;
}
.calendario-sidebar-filtros label input[type="radio"]:checked + span,
.calendario-sidebar-filtros label input[type="checkbox"]:checked + span {
    font-weight: var(--fw-medium);
}

/* Cambia el estilo cuando el radio está seleccionado */
.calendario-sidebar-filtros label input[type="radio"]:checked + span::before,
.calendario-sidebar-filtros label input[type="checkbox"]:checked + span::before {
    background-color: var(--c-azul); /* Color de fondo cuando está seleccionado */
    border-color: var(--c-azul);
}

/* Agrega la marca de "check" */
.calendario-sidebar-filtros label input[type="radio"]:checked + span::after,
.calendario-sidebar-filtros label input[type="checkbox"]:checked + span::after {
    content: '✔';
    position: relative;
    font-size: var(--fs-sm);
    color: var(--c-blanco);
    display: flex;
    width: var(--lh-sm);
    height: auto;
    justify-content: center;
    align-items: center;
    grid-column: 1 / 2;
    grid-row: 1 / 2;
}

/* --- Listado de Resultados --- */
.calendario-resultados-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 2em;
}
.calendario-edicion-card {
    border: 1px solid transparent;
    border-radius: 0 var(--calendario-border-radius-lg) var(--calendario-border-radius-lg) var(--calendario-border-radius-lg);
    display: flex;
    position: relative;
    /*overflow: hidden;*/
    transition: border-color 0s !important;
    background-color: #D9D9D933;
    padding: 0;
    margin-top: 1em;
    box-shadow: 0 3px 3px rgba(from var(--c-azul) r g b / 0.25);
}

.card-border {
    width: 12px;
    flex-shrink: 0;
    border-radius: 0px 0 6px 6px;
    max-height: 15rem;
    flex-shrink: 0;
    background-color: var(--escuela-color, var(--calendario-color-border));
    margin: -1px 0 0 -1px;
}
.card-content {
    padding: var(--calendario-spacing-medium);
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    font-size: var(--fs-xs);
    line-height: var(--lh-xs);
}
.card-content h4 {
    margin-top: 0;
    font-size: var(--fs-sm);
    line-height: var(--lh-sm);
    min-height: calc(var(--lh-sm)*4);
}
.card-description {
    flex-grow: 1;
    color: var(--calendario-color-dark-gray);
    font-size: var(--fs-xs);
    line-height: var(--lh-xs);
    min-height: calc(var(--lh-xs)*4);
}
.card-description p {
    font-size: var(--fs-xs);
    line-height: var(--lh-xs);
    margin-bottom: 0;
}
.card-meta {
    list-style: none;
    padding: 0;
    margin: var(--calendario-spacing-small) 0;
    font-size: var(--fs-xs);
    line-height: var(--lh-xs);
    color: #333;
}
.card-meta li {
    display: flex;
    align-items: center;
    margin-bottom: 0.5em;
}
.card-meta li img {
    max-width: var(--lh-sm);
    margin-right: var(--espacio-xxxs);
}
.card-footer {
    display: flex;
    justify-content: space-between;
    align-items: start;
    margin-block: var(--calendario-spacing-small);
}
.card-cta {
    display: flex;
    justify-content: space-between;
    align-items: start;
    margin-top: var(--calendario-spacing-small);
}
.card-logo img {
    max-height: 30px;
    max-width: 100px;
    filter: grayscale(100%);
    transition: filter 0.1s ease;
}
.card-button {
    background-color: var(--calendario-color-primary);
    color: white;
    padding: 10px 20px;
    text-decoration: none;
    border-radius: 0 var(--calendario-border-radius-sm) 0 0;
}

/* --- Efectos Hover --- */
.calendario-edicion-card:hover {
    border-color: var(--escuela-color, var(--calendario-color-primary));
}
.calendario-edicion-card:hover .card-border {
    background-color: var(--escuela-color);
}
.calendario-edicion-card:hover .card-logo img {
    filter: grayscale(0%);
}

/* Contenedor de resultados */
#calendario-resultados-container {
    transition: opacity 0.3s ease-in-out;
    position: relative; /* Necesario para posicionar el spinner si se añade */
}

/* Estado de carga */
#calendario-resultados-container.loading {
    opacity: 0.4;
    min-height: 400px; /* Previene que el layout se contraiga durante la carga */
    pointer-events: none; /* Evita clics mientras se carga */
}

/* Spinner de carga (opcional, pero recomendado) */
#calendario-resultados-container .loading-spinner {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 200px;
    font-size: var(--fs-md);
    color: var(--calendario-color-primary);
}

/* --- Paginación --- */
.calendario-pagination { margin-top: 2em; }
.calendario-pagination ul { display: flex; justify-content: center; list-style: none; padding: 0; }
.calendario-pagination li { margin: 0 5px; }
.calendario-pagination > .page-numbers:not(.btn) {
    padding: 8px 12px;
    border: 0;
    text-decoration: none;
    color: var(--c-azul);
}
.calendario-pagination > .page-numbers:not(.next, .prev, .dots) {
    border-bottom: 2px solid var(--c-amarillo);
}
.calendario-pagination .current { background-color: var(--calendario-color-primary); color: white; border-color: var(--calendario-color-primary); }
.calendario-pagination img {
    max-height: var(--fs-xl);
    display: inline-block;
    vertical-align: middle;
}


.calendario-pagination {
    margin-top: 2em;
    display: flex;
    justify-content: center;
}
.card-description { flex-grow: 1; color: #666; font-size: var(--fs-sm); }
.card-meta { list-style: none; padding: 0; margin: 1em 0; font-size: var(--fs-sm); color: #333; }
.card-meta li { display: flex; align-items: center; margin-bottom: 0.5em; }
.card-meta svg { width: 16px; height: 16px; margin-right: 0.5em; fill: #666; }
.card-footer { display: flex; justify-content: space-between; align-items: center; margin-top: 1em; }
.card-logo img { max-height: 30px; max-width: 100px; }
.card-button { background-color: #2a2d54; color: white; padding: 10px 20px; text-decoration: none; border-radius: 4px; }
.calendario-pagination ul { display: flex; justify-content: center; list-style: none; padding: 0; }
.calendario-pagination li { margin: 0 5px; }

.calendario-pagination .current { background-color: var(--c-amarillo); color: var(--c-azul); }


.tnf_calendar_tag.tnf_tag_bold {
    display: inline-block;
    padding: 1px var(--espacio-xxxs);
    background-color: var(--c-amarillo);
    color: var(--c-blanco);
    font-weight: var(--fw-bold);
}
.tnf_calendar_tag.tnf_tag_mini {
    display: inline-block;
    padding: 0px var(--espacio-xxxs);
    background-color: var(--c-amarillo);
    color: var(--c-blanco);
    font-weight: var(--fw-bold);
    font-size: 85%;
}
.tnf_calendar_tag.tnf_tag_strike {
    display: inline-block;
    opacity: 0.5;
    text-decoration: line-through;
    font-size: 95%;
    line-height: 95%;
}

@media (max-width: 991px) {
    .calendario-sidebar-filtros fieldset {
        display: flex;
        flex-wrap: wrap;
    }
    .calendario-sidebar-filtros fieldset legend {
        flex: 1 1 100%;
    }
    .calendario-sidebar-filtros fieldset div {
        flex: 0 1 auto;
    }
    .calendario-sidebar-filtros label {
        margin: 0 var(--calendario-spacing-small) var(--calendario-spacing-small) 0;
    }
}
@media (max-width: 768px) {
    .calendario-layout {
        grid-template-columns: 1fr; /* Stack vertical en mobile */
    }
}