/* Estilos especificos de la pagina inicial IEEN. */
:root {
    --ieen-magenta: var(--site-color-secondary, #c45c91);
    --ieen-morado: var(--site-color-primary, #532680);
    --ieen-morado-oscuro: var(--site-color-primary-dark, #3f1d61);
    --ieen-lila: var(--site-color-surface-soft, #faf6fa);
    --ieen-rosa: var(--site-color-surface-alt, #fff9fc);
    --ieen-fondo: var(--site-color-surface-soft, #faf6fa);
    --ieen-texto: var(--site-color-neutral, #52525a);
    --ieen-gris: var(--site-color-muted, #6f6875);
    --ieen-borde: var(--site-color-border, #e8e1ea);
    --blanco: var(--site-color-surface, #ffffff);
    --ieen-wine: var(--ieen-morado);
    --ieen-wine-dark: var(--ieen-morado-oscuro);
    --ieen-gold: var(--ieen-magenta);
    --ieen-ink: var(--ieen-texto);
    --ieen-muted: var(--ieen-gris);
    --ieen-soft: var(--ieen-fondo);
    --ieen-line: var(--ieen-borde);
    --ieen-white: var(--blanco);
}

.ieen-home {
    color: var(--ieen-ink);
    background: var(--ieen-fondo);
    font-family: Roboto, Arial, sans-serif;
    overflow-x: hidden;
}

.ieen-home *,
.ieen-home *::before,
.ieen-home *::after {
    box-sizing: border-box;
}

.ieen-home img,
.ieen-home iframe {
    max-width: 100%;
}

.ieen-home h1,
.ieen-home h2,
.ieen-home h3,
.ieen-home p,
.ieen-home a,
.ieen-home span {
    overflow-wrap: break-word;
}

.ieen-home p,
.ieen-home li {
    text-align: justify;
    text-justify: inter-word;
}

#app .v-app-bar {
    z-index: 1000 !important;
    background: #fff !important;
}

.ieen-container {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
}

.ieen-hero {
    position: relative;
    overflow: hidden;
    background:
        radial-gradient(circle at 88% 74%, color-mix(in srgb, var(--site-color-neutral-soft) 34%, transparent), transparent 24%),
        linear-gradient(120deg, var(--site-color-primary-dark) 0%, var(--site-color-primary) 48%, var(--site-color-secondary) 78%, var(--site-color-neutral-soft) 100%);
    color: var(--ieen-white);
}

.ieen-hero::after {
    content: "";
    position: absolute;
    inset: auto -8% -34% 46%;
    height: 420px;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 50%;
    background: color-mix(in srgb, var(--site-color-neutral-soft) 12%, transparent);
    pointer-events: none;
}

.ieen-hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 42px;
    align-items: stretch;
    min-height: 520px;
    padding: 76px 0 54px;
}

.ieen-kicker {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 33px;
    font-size: clamp(22px, 5vw, 22px);
    font-weight: 800;
    letter-spacing: .04em;
    text-transform: uppercase;
}

.ieen-kicker::before {
    content: "";
    width: 46px;
    height: 3px;
    background: var(--ieen-gold);
}

.ieen-hero h1 {
    max-width: 780px;
    margin: 0;
    font-size: clamp(34px, 5vw, 33px);
    font-weight: 800;
    line-height: 1.04;
}

.ieen-hero-copy {
    max-width: 720px;
    margin: 33px 0 0;
    color: rgba(255, 255, 255, .88);
    font-size: clamp(17px, 2vw, 21px);
    line-height: 1.62;
}

.ieen-actions,
.ieen-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}

.ieen-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 11px 18px;
    border-radius: 6px;
    font-weight: 800;
    text-decoration: none;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.ieen-btn:hover {
    transform: translateY(-1px);
    text-decoration: none;
}

.ieen-btn-primary {
    background: var(--ieen-magenta);
    color: var(--ieen-white) !important;
    box-shadow: 0 14px 30px rgba(0, 0, 0, .16);
}

.ieen-btn-secondary {
    border: 1px solid rgba(255, 255, 255, .58);
    color: var(--ieen-white) !important;
}

.ieen-btn-light {
    background: var(--ieen-white);
    color: var(--ieen-wine) !important;
    border: 1px solid var(--ieen-line);
}

.ieen-highlight {
    background: rgba(255, 255, 255, .96);
    color: var(--ieen-ink);
    border-top: 5px solid var(--ieen-magenta);
    border-radius: 8px;
    box-shadow: 0 22px 60px rgba(20, 24, 30, .20);
    padding: 24px;
}

.ieen-highlight-logo {
    width: 126px;
    max-width: 100%;
    margin-bottom: 18px;
}

.ieen-highlight h2 {
    margin: 0 0 10px;
    color: var(--ieen-wine);
    font-size: 24px;
    font-weight: 800;
    line-height: 1.2;
}

.ieen-highlight p {
    margin: 0;
    color: var(--ieen-muted);
    line-height: 1.6;
}

.ieen-strip {
    background: var(--ieen-morado-oscuro);
    color: var(--ieen-white);
}

.ieen-strip-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    background: rgba(255, 255, 255, .14);
}

.ieen-strip a {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 86px;
    padding: 18px;
    background: var(--ieen-morado-oscuro);
    color: var(--ieen-white) !important;
    font-weight: 800;
    text-decoration: none;
}

.ieen-strip i {
    color: var(--ieen-gold);
    font-size: 24px;
}

.ieen-section {
    padding: 30px 0;
}

.ieen-section-compact {
    padding: 34px 0;
    background:
        linear-gradient(180deg, var(--site-color-surface-soft) 0%, var(--site-color-surface) 100%);
}

.ieen-section-compact .ieen-section-head {
    margin-bottom: 16px;
}

.ieen-section-compact .ieen-section-head h2 {
    font-size: clamp(24px, 2.6vw, 32px);
}

.ieen-section-compact .ieen-section-head p {
    margin-top: 5px;
    line-height: 1.45;
}

.ieen-section-muted {
    background: var(--ieen-lila);
}

.ieen-section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 22px;
    margin-bottom: 26px;
}

.ieen-section-head h2 {
    margin: 0;
    color: var(--ieen-wine);
    font-size: clamp(27px, 3vw, 38px);
    font-weight: 900;
    line-height: 1.12;
}

.ieen-section-head p {
    max-width: 100%;
    margin: 8px 0 0;
    color: var(--ieen-muted);
    font-size: 16px;
    line-height: 1.65;
}

.ieen-grid {
    display: grid;
    gap: 18px;
}

.ieen-grid-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ieen-grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ieen-service,
.ieen-news,
.ieen-session,
.ieen-banner-card {
    display: block;
    height: 100%;
    border: 1px solid var(--ieen-line);
    border-radius: 8px;
    background: var(--ieen-white);
    color: var(--ieen-ink);
    text-decoration: none;
    box-shadow: 0 10px 28px rgba(31, 41, 55, .06);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.ieen-service:hover,
.ieen-news:hover,
.ieen-session:hover,
.ieen-banner-card:hover {
    border-color: rgba(122, 23, 52, .38);
    box-shadow: 0 16px 36px rgba(31, 41, 55, .10);
    color: var(--ieen-ink);
    text-decoration: none;
    transform: translateY(-2px);
}

.ieen-service {
    padding: 24px;
}

.ieen-icon {
    display: inline-grid;
    place-items: center;
    width: 46px;
    height: 46px;
    margin-bottom: 16px;
    border-radius: 50%;
    background: var(--ieen-rosa);
    color: var(--ieen-wine);
    font-size: 23px;
}

.ieen-service h3,
.ieen-news h3,
.ieen-session h3 {
    margin: 0 0 8px;
    color: var(--ieen-ink);
    font-size: 20px;
    font-weight: 800;
    line-height: 1.25;
}

.ieen-service p,
.ieen-news p,
.ieen-session p {
    margin: 0;
    color: var(--ieen-muted);
    line-height: 1.6;
}

.ieen-banner-feature {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(300px, 1.6fr);
    gap: 26px;
    align-items: stretch;
}

.ieen-election-countdown {
    display: grid;
    grid-template-columns: minmax(170px, .48fr) minmax(0, 1.52fr);
    gap: 16px;
    align-items: stretch;
}

.ieen-election-card,
.ieen-countdown-card {
    overflow: hidden;
    border: 1px solid var(--ieen-line);
    border-radius: 8px;
    background: var(--ieen-white);
    box-shadow: 0 14px 34px rgba(31, 41, 55, .08);
}

.ieen-election-card {
    display: block;
    min-height: 100%;
    color: var(--ieen-ink);
    text-decoration: none;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.ieen-election-card:hover {
    transform: translateY(-2px);
    border-color: rgba(225, 0, 122, .36);
    box-shadow: 0 18px 42px rgba(31, 41, 55, .12);
    color: var(--ieen-ink);
    text-decoration: none;
}

.ieen-election-card img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 170px;
    object-fit: cover;
}

.ieen-countdown-card {
    padding: 16px;
    background:
        radial-gradient(circle at 92% 18%, rgba(225, 0, 122, .12), transparent 28%),
        linear-gradient(135deg, #fff 0%, #fff7fb 100%);
}

.ieen-countdown-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
    color: var(--ieen-magenta);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.ieen-countdown-card h2 {
    margin: 0 0 5px;
    color: var(--ieen-wine);
    font-size: clamp(20px, 2.2vw, 24px);
    font-weight: 900;
    line-height: 1.1;
}

.ieen-countdown-card p {
    margin: 0;
    color: var(--ieen-muted);
    line-height: 1.6;
}

.ieen-election-status {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 10px 0 12px;
    padding: 8px 11px;
    border-radius: 8px;
    background: var(--ieen-wine);
    color: var(--ieen-white);
    font-size: clamp(15px, 1.8vw, 18px);
    font-weight: 900;
}

.ieen-election-status i {
    color: var(--ieen-magenta);
}

.ieen-election-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-top: 10px;
}

.ieen-election-summary-item {
    min-height: 58px;
    padding: 10px;
    border: 1px solid rgba(232, 221, 234, .95);
    border-radius: 8px;
    background: rgba(255, 255, 255, .88);
}

.ieen-election-summary-item span {
    display: block;
    margin-bottom: 4px;
    color: var(--ieen-magenta);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.ieen-election-summary-item strong {
    display: block;
    color: var(--ieen-wine);
    font-size: 14px;
    line-height: 1.25;
}

.ieen-countdown-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-top: 22px;
}

.ieen-countdown-unit {
    min-height: 112px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 14px 10px;
    border: 1px solid rgba(232, 221, 234, .95);
    border-radius: 8px;
    background: rgba(255, 255, 255, .86);
    text-align: center;
}

.ieen-countdown-number {
    color: var(--ieen-wine);
    font-size: clamp(30px, 4vw, 46px);
    font-weight: 900;
    line-height: 1;
}

.ieen-countdown-label {
    display: block;
    margin-top: 8px;
    color: var(--ieen-muted);
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
}

.ieen-countdown-status {
    margin-top: 18px;
    padding: 12px 14px;
    border-left: 4px solid var(--ieen-magenta);
    border-radius: 6px;
    background: var(--ieen-rosa);
    color: var(--ieen-wine);
    font-weight: 800;
}

.ieen-countdown-card.is-finished .ieen-countdown-grid,
.ieen-countdown-card.is-finished .ieen-countdown-status {
    display: none;
}

.ieen-election-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 12px;
}

.ieen-election-actions .ieen-btn {
    min-height: 38px;
    padding: 9px 14px;
}

.ieen-election-spotlight {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 210px;
    gap: 14px;
    align-items: center;
    padding: 16px 18px;
    border: 1px solid var(--site-color-border);
    border-radius: var(--site-radius-card);
    background:
        radial-gradient(circle at 90% 18%, color-mix(in srgb, var(--site-color-secondary) 16%, transparent), transparent 30%),
        linear-gradient(135deg, var(--site-color-surface) 0%, var(--site-color-surface) 58%, var(--site-color-surface-alt) 100%);
    box-shadow: var(--site-shadow-sm);
}

.ieen-election-spotlight::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 7px;
    background: linear-gradient(180deg, var(--site-color-secondary), var(--site-color-primary));
}

.ieen-election-copy {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.ieen-election-topline {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin-bottom: 6px;
}

.ieen-election-badge,
.ieen-election-state {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 28px;
    padding: 5px 9px;
    border-radius: 8px;
    font-size: 11px;
    font-weight: 800;
    line-height: 1.2;
}

.ieen-election-badge {
    background: var(--site-color-primary);
    color: var(--site-color-surface) !important;
    letter-spacing: .03em;
    text-transform: uppercase;
}

.ieen-election-state {
    background: var(--site-color-surface-alt);
    color: var(--site-color-primary) !important;
}

.ieen-election-spotlight h2 {
    margin: 0;
    color: var(--site-color-primary);
    font-size: clamp(22px, 2.2vw, 28px);
    font-weight: 800;
    line-height: 1.14;
}

.ieen-election-spotlight p {
    max-width: 720px;
    margin: 5px 0 0;
    color: var(--site-color-muted);
    line-height: 1.5;
    font-size: 15px;
}

.ieen-election-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 9px;
}

.ieen-election-timer {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 11px;
    max-width: 620px;
    margin-top: 8px;
    padding: 8px;
    border-radius: var(--site-radius-control);
    background: var(--site-color-surface-soft);
}

.ieen-election-time {
    min-height: 66px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 8px 7px;
    border: 1px solid var(--site-color-border);
    border-radius: var(--site-radius-control);
    background: var(--site-color-surface);
    text-align: center;
    box-shadow: var(--site-shadow-sm);
}

.ieen-election-time.is-primary {
    align-items: center;
    padding-left: 8px;
    background: linear-gradient(135deg, var(--site-color-primary), var(--site-color-primary-dark));
    color: var(--site-color-surface);
    text-align: center;
}

.ieen-election-time strong {
    display: block;
    color: var(--site-color-primary);
    font-size: clamp(25px, 3vw, 36px);
    font-weight: 800;
    line-height: 1;
}

.ieen-election-time.is-primary strong {
    color: var(--site-color-surface);
    font-size: clamp(30px, 3.6vw, 44px);
}

.ieen-election-time span {
    display: block;
    margin-top: 4px;
    color: var(--site-color-muted);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .03em;
    text-transform: uppercase;
}

.ieen-election-time.is-primary span {
    color: rgba(255, 255, 255, .86);
}

.ieen-election-meta span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 30px;
    padding: 6px 9px;
    border: 1px solid var(--site-color-border);
    border-radius: var(--site-radius-control);
    background: var(--site-color-surface);
    color: var(--site-color-primary);
    font-size: 12px;
    font-weight: 700;
    line-height: 1.2;
}

.ieen-election-meta i {
    color: var(--site-color-secondary);
}

.ieen-election-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 36px;
    margin-top: 0;
    padding: 8px 14px;
    border-radius: var(--site-radius-control);
    background: var(--site-color-secondary);
    color: var(--site-color-surface) !important;
    font-weight: 800;
    font-size: 13px;
    text-decoration: none;
    box-shadow: var(--site-shadow-sm);
}

.ieen-election-cta:hover {
    color: var(--site-color-surface) !important;
    text-decoration: none;
    background: var(--site-color-primary);
}

.ieen-election-side {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 10px;
    align-content: center;
}

.ieen-election-side .ieen-election-cta {
    width: 100%;
}

.ieen-election-preview {
    display: grid;
    place-items: center;
    overflow: hidden;
    padding: 10px;
    border: 1px solid var(--site-color-border);
    border-radius: var(--site-radius-control);
    background:
        linear-gradient(180deg, var(--site-color-surface), var(--site-color-surface-soft));
    box-shadow: var(--site-shadow-sm);
    text-decoration: none;
    color: inherit !important;
}

.ieen-election-sessions-card {
    min-height: 164px;
    padding: 18px;
    text-align: center;
}

.ieen-election-sessions-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    margin-bottom: 12px;
    border-radius: var(--site-radius-icon);
    background: var(--site-color-primary);
    color: var(--site-color-surface);
    font-size: 30px;
    box-shadow: var(--site-shadow-sm);
}

.ieen-election-sessions-card strong {
    display: block;
    color: var(--site-color-primary);
    font-size: 18px;
    font-weight: 800;
    line-height: 1.2;
}

.ieen-election-sessions-card span {
    display: block;
    margin-top: 6px;
    color: var(--site-color-neutral);
    font-size: 13px;
    font-weight: 600;
    line-height: 1.35;
}

.ieen-election-preview:hover {
    text-decoration: none;
    color: inherit !important;
}

.ieen-election-preview img {
    display: block;
    width: 100%;
    max-width: 154px;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: var(--site-radius-icon);
    border: 1px solid var(--site-color-border);
}

#sesiones-calendarizadas {
    scroll-margin-top: 155px;
}

.ieen-section-compact .ieen-election-countdown {
    display: none;
}

.ieen-feature-panel {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 320px;
    padding: 34px;
    border-radius: 8px;
    background: linear-gradient(135deg, var(--ieen-morado), var(--ieen-morado-oscuro));
    color: var(--ieen-white);
}

.ieen-feature-panel h2 {
    margin: 0 0 12px;
    font-size: clamp(28px, 3vw, 33px);
    font-weight: 900;
    line-height: 1.1;
}

.ieen-feature-panel p {
    margin: 0;
    color: rgba(255, 255, 255, .86);
    font-size: 17px;
    line-height: 1.65;
}

.ieen-banner-card {
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: 8px;
}

.ieen-banner-card img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 320px;
    object-fit: contain;
    background: var(--ieen-soft);
}

.ieen-banner-carousel {
    position: relative;
    overflow: hidden;
    border-radius: 8px;
    background: var(--ieen-white);
    box-shadow: 0 10px 28px rgba(31, 41, 55, .06);
}

.ieen-banner-slide {
    display: none;
}

.ieen-banner-slide.is-active {
    display: block;
}

.ieen-banner-controls {
    position: absolute;
    right: 14px;
    bottom: 14px;
    display: flex;
    gap: 8px;
    z-index: 2;
}

.ieen-banner-controls button {
    display: grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border: 0;
    border-radius: 50%;
    background: rgba(59, 22, 88, .88);
    color: var(--ieen-white);
    box-shadow: 0 8px 18px rgba(36, 33, 42, .22);
}

.ieen-news {
    overflow: hidden;
}

.ieen-news-image {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    background: linear-gradient(135deg, var(--ieen-lila), var(--ieen-rosa));
}

.ieen-news-body {
    padding: 20px;
}

.ieen-date {
    display: inline-flex;
    margin-bottom: 12px;
    padding: 5px 10px;
    border-radius: 999px;
    background: var(--ieen-rosa);
    color: var(--ieen-wine);
    font-size: 13px;
    font-weight: 800;
}

.ieen-news-flow {
    overflow: hidden;
    border: 1px solid var(--ieen-line);
    border-radius: 8px;
    background: var(--ieen-white);
    box-shadow: 0 10px 28px rgba(31, 41, 55, .06);
}

.ieen-news-track {
    display: flex;
    width: max-content;
    animation: ieen-news-marquee 42s linear infinite;
}

.ieen-news-flow:hover .ieen-news-track {
    animation-play-state: paused;
}

.ieen-news-pill {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 360px;
    padding: 16px 18px;
    border-right: 1px solid var(--ieen-line);
    color: var(--ieen-ink);
    text-decoration: none;
}

.ieen-news-pill:hover {
    color: var(--ieen-morado);
    text-decoration: none;
}

.ieen-news-pill strong {
    display: block;
    color: var(--ieen-morado);
    font-size: 14px;
}

.ieen-news-pill span {
    display: block;
    color: var(--ieen-muted);
    font-size: 14px;
    line-height: 1.35;
}

@keyframes ieen-news-marquee {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

.ieen-public-grid {
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
    gap: 30px;
    align-items: center;
}

.ieen-public-panel {
    padding: 32px;
    border-radius: 8px;
    background: var(--ieen-white);
    border: 1px solid var(--ieen-line);
}

.ieen-public-panel h2 {
    margin: 0 0 12px;
    color: var(--ieen-wine);
    font-size: 32px;
    font-weight: 900;
}

.ieen-public-panel p {
    text-align: justify;
    text-justify: inter-word;
}

.ieen-link-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.ieen-link-list a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 80px;
    padding: 15px 16px;
    border: 1px solid var(--ieen-line);
    border-radius: 7px;
    background: var(--ieen-white);
    color: var(--ieen-ink) !important;
    font-weight: 800;
    text-decoration: none;
}

.ieen-link-list a::after {
    content: "\f105";
    color: var(--ieen-gold);
    font-family: FontAwesome;
}

.ieen-session {
    padding: 20px;
}

.ieen-session small {
    display: block;
    margin-bottom: 8px;
    color: var(--ieen-wine);
    font-weight: 900;
}

.ieen-calendar-shell {
    position: relative;
    z-index: 0;
    isolation: isolate;
    overflow: hidden;
    padding: 18px;
    border: 1px solid var(--ieen-line);
    border-radius: 16px;
    background: var(--ieen-white);
    box-shadow: 0 18px 38px rgba(36, 33, 42, .08);
}

.ieen-calendar-toolbar {
    position: relative;
    z-index: 3;
    display: grid;
    grid-template-columns: minmax(130px, .45fr) minmax(170px, .65fr) minmax(240px, 1fr) auto auto;
    gap: 14px;
    align-items: stretch;
    margin-bottom: 18px;
    padding: 12px;
    border: 1px solid rgba(91, 35, 128, .09);
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(96, 57, 134, .045), rgba(236, 0, 140, .025));
}

.ieen-calendar-field {
    position: relative;
    display: grid;
    gap: 6px;
    min-height: 62px;
    padding: 9px 42px 9px 46px;
    border: 1px solid var(--ieen-borde);
    border-radius: 12px;
    background: var(--ieen-white);
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.ieen-calendar-field:hover {
    border-color: rgba(91, 35, 128, .35);
    transform: translateY(-1px);
}

.ieen-calendar-field:focus-within {
    z-index: 20;
    border-color: var(--ieen-morado);
    box-shadow: 0 0 0 3px rgba(91, 35, 128, .1);
}

.ieen-calendar-field-icon {
    position: absolute;
    left: 14px;
    top: 50%;
    display: grid;
    place-items: center;
    width: 24px;
    height: 24px;
    border-radius: 7px;
    background: var(--ieen-lila);
    color: var(--ieen-morado);
    transform: translateY(-50%);
    pointer-events: none;
}

.ieen-calendar-field>label {
    color: var(--ieen-gris);
    font-size: 12px;
    line-height: 1;
}

.ieen-calendar-select {
    min-width: 0;
}

.ieen-calendar-select summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: var(--ieen-texto);
    font-size: 16px;
    font-weight: 700;
    cursor: pointer;
    list-style: none;
}

.ieen-calendar-select summary::-webkit-details-marker {
    display: none;
}

.ieen-calendar-select summary::after {
    content: '\f107';
    color: var(--ieen-morado);
    font-family: FontAwesome;
    font-size: 17px;
    transition: transform .18s ease;
}

.ieen-calendar-select[open] summary::after {
    transform: rotate(180deg);
}

.ieen-calendar-options {
    position: absolute;
    z-index: 30;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    display: grid;
    max-height: 285px;
    overflow-y: auto;
    padding: 7px;
    border: 1px solid rgba(91, 35, 128, .18);
    border-radius: 12px;
    background: var(--ieen-white);
    box-shadow: 0 18px 38px rgba(48, 23, 70, .18);
}

.ieen-calendar-option {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    min-height: 40px;
    padding: 9px 11px;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: var(--ieen-texto);
    font-size: 14px;
    font-weight: 700;
    text-align: left;
    cursor: pointer;
}

.ieen-calendar-option:hover,
.ieen-calendar-option.is-selected {
    background: var(--ieen-lila);
    color: var(--ieen-morado);
}

.ieen-calendar-option.is-selected {
    font-weight: 900;
}

.ieen-calendar-option i {
    color: var(--ieen-magenta);
}

.ieen-calendar-action {
    min-width: 118px;
    min-height: 62px;
    border: 0;
    border-radius: 10px;
    background: var(--ieen-morado);
    color: var(--ieen-white);
    font-weight: 900;
    text-transform: uppercase;
    box-shadow: 0 8px 18px rgba(91, 35, 128, .24);
    cursor: pointer;
    transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}

.ieen-calendar-action:hover:not(:disabled) {
    transform: translateY(-1px);
    box-shadow: 0 11px 24px rgba(91, 35, 128, .3);
}

.ieen-calendar-action:disabled {
    cursor: wait;
    opacity: .65;
}

.ieen-calendar-action.is-secondary {
    min-width: 94px;
    background: var(--ieen-white);
    color: var(--ieen-morado);
    border: 1px solid rgba(91, 35, 128, .28);
    box-shadow: none;
}

.ieen-calendar-loading {
    position: absolute;
    z-index: 5;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: rgba(255, 255, 255, .94);
}

.ieen-calendar-loading-card {
    display: grid;
    justify-items: center;
    gap: 12px;
    min-width: 230px;
    padding: 28px 34px;
    border: 1px solid rgba(91, 35, 128, .14);
    border-radius: 14px;
    background: var(--ieen-white);
    color: var(--ieen-morado-oscuro);
    box-shadow: 0 18px 45px rgba(59, 22, 88, .18);
    font-weight: 800;
    text-align: center;
}

.ieen-calendar-spinner {
    width: 42px;
    height: 42px;
    border: 4px solid rgba(91, 35, 128, .16);
    border-top-color: var(--ieen-magenta);
    border-radius: 50%;
    animation: ieen-calendar-spin .75s linear infinite;
}

@keyframes ieen-calendar-spin {
    to {
        transform: rotate(360deg);
    }
}

.ieen-calendar-summary {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: start;
    margin-bottom: 22px;
    padding: 16px;
    border: 1px solid var(--ieen-line);
    border-radius: 14px;
    background: linear-gradient(135deg, #fbf8fd 0%, #fff 65%);
    box-shadow: inset 4px 0 0 var(--ieen-magenta);
}

.ieen-upcoming-title {
    margin: 0 0 10px;
    color: var(--ieen-morado-oscuro);
    font-size: 17px;
    font-weight: 900;
}

.ieen-upcoming-title i {
    margin-right: 7px;
    color: var(--ieen-magenta);
}

.ieen-upcoming-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.ieen-upcoming-card {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    min-height: 70px;
    padding: 10px;
    border: 1px solid var(--ieen-line);
    border-radius: 8px;
    background: var(--ieen-white);
    color: var(--ieen-texto);
    text-align: left;
    cursor: pointer;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.ieen-upcoming-card:hover {
    border-color: rgba(91, 35, 128, .35);
    box-shadow: 0 8px 18px rgba(59, 22, 88, .08);
    transform: translateY(-2px);
}

.ieen-upcoming-date {
    display: grid;
    place-items: center;
    width: 44px;
    height: 48px;
    border-radius: 8px;
    background: var(--ieen-lila);
    color: var(--ieen-morado);
    font-size: 18px;
    font-weight: 900;
}

.ieen-upcoming-card strong,
.ieen-upcoming-card small {
    display: block;
}

.ieen-upcoming-card strong {
    overflow: hidden;
    font-size: 13px;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ieen-upcoming-card small {
    margin-top: 4px;
    color: var(--ieen-gris);
    font-size: 11px;
}

.ieen-session-badges {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-bottom: 8px;
}

.ieen-session-kind {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 5px 10px;
    border: 1px solid rgba(91, 35, 128, .2);
    border-radius: 999px;
    background: var(--ieen-white);
    color: var(--ieen-morado);
    font-size: 11px;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.ieen-session-meta {
    display: inline-flex;
    flex-wrap: nowrap;
    align-items: stretch;
    gap: 6px;
    max-width: 100%;
}

.ieen-session-meta .ieen-session-kind {
    height: auto;
    margin: 0;
    text-align: center;
}

.ieen-calendar-legend {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px 12px;
    max-width: 330px;
}

.ieen-calendar-legend span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--ieen-gris);
    font-size: 11px;
    font-weight: 700;
}

.ieen-calendar-legend i {
    width: 9px;
    height: 9px;
    border-radius: 50%;
}

.ieen-calendar-legend .is-cle {
    background: var(--ieen-magenta);
}

.ieen-calendar-legend .is-pej {
    background: #7A4BC2;
}

.ieen-calendar-legend .is-jee {
    background: #C87900;
}

.ieen-calendar-legend .is-permanente {
    background: #5B2380;
}

.ieen-calendar-legend .is-temporal {
    background: #0F8B8D;
}

.ieen-calendar-legend .is-transparencia {
    background: #3B6FD8;
}

.ieen-calendar-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.8fr) minmax(300px, .9fr);
    gap: 24px;
}

.ieen-calendar-nav {
    display: grid;
    grid-template-columns: 42px 1fr 42px;
    align-items: center;
    margin-bottom: 12px;
}

.ieen-calendar-nav button {
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 50%;
    background: transparent;
    color: var(--ieen-morado);
    font-size: 22px;
}

.ieen-calendar-title {
    margin: 0;
    color: var(--ieen-morado-oscuro);
    font-size: 20px;
    font-weight: 900;
    text-align: center;
}

.ieen-calendar-weekdays,
.ieen-calendar-days {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.ieen-calendar-weekdays span {
    padding: 12px 8px;
    color: var(--ieen-gris);
    font-size: 13px;
    font-weight: 900;
    text-align: center;
}

.ieen-calendar-day {
    position: relative;
    min-height: 74px;
    border: 1px solid var(--ieen-borde);
    background: var(--ieen-white);
    color: var(--ieen-texto);
    font-size: 16px;
    font-weight: 900;
    transition: border-color .18s ease, background .18s ease;
}

.ieen-calendar-day:hover {
    background: var(--ieen-rosa);
    border-color: rgba(225, 0, 122, .35);
}

.ieen-calendar-day.is-muted {
    color: #b7aebe;
    background: #fbf9fc;
}

.ieen-calendar-day.is-selected {
    border: 2px solid var(--ieen-magenta);
    background: var(--ieen-rosa);
}

.ieen-calendar-day.is-today {
    box-shadow: inset 0 0 0 2px var(--ieen-morado);
}

.ieen-calendar-day.is-today::before {
    content: 'Hoy';
    position: absolute;
    top: 6px;
    right: 7px;
    padding: 2px 6px;
    border-radius: 999px;
    background: var(--ieen-morado);
    color: var(--ieen-white);
    font-size: 9px;
    font-weight: 900;
    line-height: 1.2;
    text-transform: uppercase;
}

.ieen-calendar-day.is-today.is-selected {
    border-color: var(--ieen-magenta);
    box-shadow: inset 0 0 0 2px var(--ieen-morado), 0 0 0 2px rgba(225, 0, 122, .12);
}

.ieen-calendar-dot {
    position: absolute;
    left: 50%;
    bottom: 14px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--ieen-magenta);
    transform: translateX(-50%);
}

.ieen-calendar-dot.is-cle,
.ieen-day-source.is-cle {
    background: var(--ieen-magenta);
    color: var(--ieen-white);
}

.ieen-calendar-dot.is-pej,
.ieen-day-source.is-pej {
    background: #7A4BC2;
    color: var(--ieen-white);
}

.ieen-calendar-dot.is-permanente,
.ieen-day-source.is-permanente {
    background: #5B2380;
    color: var(--ieen-white);
}

.ieen-calendar-dot.is-temporal,
.ieen-day-source.is-temporal {
    background: #0F8B8D;
    color: var(--ieen-white);
}

.ieen-calendar-dot.is-jee,
.ieen-day-source.is-jee {
    background: #C87900;
    color: var(--ieen-white);
}

.ieen-calendar-dot.is-transparencia,
.ieen-day-source.is-transparencia {
    background: #3B6FD8;
    color: var(--ieen-white);
}

.ieen-day-panel {
    height: 520px;
    padding: 26px 24px;
    border: 1px solid var(--ieen-borde);
    border-radius: 8px;
    background: var(--ieen-white);
    overflow: hidden;
}

.ieen-day-scroll {
    max-height: 390px;
    overflow-y: auto;
    padding-right: 6px;
}

.ieen-day-scroll::-webkit-scrollbar {
    width: 8px;
}

.ieen-day-scroll::-webkit-scrollbar-track {
    background: var(--ieen-lila);
    border-radius: 999px;
}

.ieen-day-scroll::-webkit-scrollbar-thumb {
    background: var(--ieen-morado);
    border-radius: 999px;
}

.ieen-day-panel h3 {
    margin: 0 0 4px;
    color: var(--ieen-morado-oscuro);
    font-size: 30px;
    font-weight: 900;
}

.ieen-day-date {
    margin: 0 0 22px;
    color: var(--ieen-gris);
    font-size: 16px;
}

.ieen-day-session {
    padding: 14px 0;
    border-top: 1px solid var(--ieen-borde);
}

.ieen-day-source {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 5px 10px;
    border-radius: 999px;
    background: var(--ieen-lila);
    color: var(--ieen-morado);
    font-size: 11px;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.ieen-day-session h4 {
    margin: 0 0 6px;
    color: var(--ieen-morado-oscuro);
    font-size: 16px;
    font-weight: 900;
    line-height: 1.35;
}

.ieen-day-session p {
    margin: 0;
    color: var(--ieen-gris);
    line-height: 1.45;
}

.ieen-session-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}

.ieen-session-links a {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 7px 12px;
    border-radius: 6px;
    background: var(--ieen-morado);
    color: var(--ieen-white) !important;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .04em;
    text-decoration: none;
    text-transform: uppercase;
}

.ieen-session-video-menu {
    position: relative;
}

.ieen-session-video-menu summary {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 7px 12px;
    border-radius: 6px;
    background: var(--ieen-morado);
    color: var(--ieen-white);
    cursor: pointer;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .04em;
    list-style: none;
    text-transform: uppercase;
}

.ieen-session-video-menu summary::-webkit-details-marker {
    display: none;
}

.ieen-session-video-options {
    display: grid;
    gap: 5px;
    min-width: 165px;
    margin-top: 5px;
    padding: 6px;
    border: 1px solid var(--ieen-borde);
    border-radius: 8px;
    background: var(--ieen-white);
    box-shadow: 0 10px 24px rgba(48, 23, 70, .14);
}

.ieen-session-video-options a {
    justify-content: flex-start;
    background: transparent;
    color: var(--ieen-morado) !important;
}

.ieen-session-video-options a:hover {
    background: rgba(96, 57, 134, .08);
}

.ieen-video-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

.ieen-feature-links {
    display: grid;
    grid-template-columns: minmax(0, 1.55fr) minmax(280px, .9fr);
    gap: 24px;
    align-items: stretch;
}

.ieen-feature-video {
    overflow: hidden;
    border: 1px solid var(--ieen-line);
    border-radius: 8px;
    background: var(--ieen-white);
    box-shadow: 0 16px 34px rgba(36, 33, 42, .08);
}

.ieen-feature-video-frame {
    position: relative;
    aspect-ratio: 16 / 9;
    background: var(--ieen-morado-oscuro);
}

.ieen-feature-video-frame iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.ieen-feature-video-caption {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 16px 18px;
}

.ieen-feature-video-caption h3 {
    margin: 0;
    color: var(--ieen-morado);
    font-size: 20px;
    font-weight: 900;
}

.ieen-feature-video-caption p {
    margin: 4px 0 0;
    color: var(--ieen-gris);
    line-height: 1.4;
}

.ieen-feature-link-grid {
    display: grid;
    gap: 1px;
    overflow: hidden;
    border: 1px solid var(--ieen-line);
    border-radius: 8px;
    background: var(--ieen-line);
}

.ieen-feature-link {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 92px;
    padding: 16px;
    border: 0;
    border-radius: 0;
    background: var(--ieen-white);
    color: var(--ieen-morado) !important;
    text-decoration: none;
    box-shadow: none;
    transition: background .18s ease, color .18s ease;
}

.ieen-feature-link:hover {
    background: var(--ieen-rosa);
    color: var(--ieen-magenta);
    text-decoration: none;
}

.ieen-feature-link-icon {
    display: grid;
    place-items: center;
    flex: 0 0 50px;
    width: 58px;
    height: 58px;
    border-radius: 50%;
    background: var(--ieen-rosa);
    color: var(--ieen-magenta);
    font-size: 28px;
}

.ieen-feature-link h3 {
    margin: 0;
    color: currentColor;
    font-size: 16px;
    font-weight: 900;
    line-height: 1.25;
    text-transform: none;
}

.ieen-video-card {
    overflow: hidden;
    border: 1px solid var(--ieen-line);
    border-radius: 8px;
    background: var(--ieen-white);
    box-shadow: 0 10px 28px rgba(31, 41, 55, .06);
}

.ieen-video-frame {
    position: relative;
    aspect-ratio: 16 / 9;
    background: var(--ieen-morado-oscuro);
}

.ieen-video-frame iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.ieen-video-body {
    padding: 18px;
}

.ieen-video-body h3 {
    margin: 0 0 8px;
    color: var(--ieen-morado);
    font-size: 20px;
    font-weight: 900;
}

.ieen-video-body p {
    margin: 0;
    color: var(--ieen-muted);
    line-height: 1.55;
}

.ieen-recommended-panel {
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.ieen-recommended-panel+.ieen-recommended-panel {
    margin-top: 14px;
}

.ieen-rec-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.ieen-rec-card {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 14px;
    min-height: 78px;
    padding: 16px 18px;
    border: 1px solid var(--ieen-line);
    border-radius: 8px;
    background: var(--ieen-white);
    color: var(--ieen-texto) !important;
    text-align: left;
    text-decoration: none;
    box-shadow: 0 8px 22px rgba(36, 33, 42, .05);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}

.ieen-rec-card:hover {
    border-color: rgba(225, 0, 122, .32);
    background: var(--ieen-rosa);
    color: var(--ieen-morado);
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 12px 26px rgba(36, 33, 42, .10);
}

.ieen-rec-card::after {
    content: "\f105";
    margin-left: auto;
    color: var(--ieen-magenta);
    font-family: FontAwesome;
    font-size: 20px;
}

.ieen-rec-icon {
    display: grid;
    place-items: center;
    flex: 0 0 42px;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: var(--ieen-lila);
    color: var(--ieen-magenta);
}

.ieen-rec-icon i {
    font-size: 20px;
    line-height: 1;
}

.ieen-rec-logo {
    display: block;
    width: auto;
    height: auto;
    border: 0;
    border-radius: 0;
    color: var(--ieen-magenta);
    font-size: 11px;
    font-weight: 900;
    line-height: 1.05;
    box-shadow: none;
    text-align: center;
}

.ieen-rec-logo span {
    display: block;
    color: var(--ieen-morado);
    font-size: 9px;
}

.ieen-rec-title {
    margin: 0;
    color: currentColor;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.25;
    text-transform: none;
}

.ieen-rec-title-small {
    font-size: 15px;
    font-weight: 900;
}

.ieen-institutions-panel {
    overflow: hidden;
    border: 1px solid var(--ieen-line);
    border-radius: 12px;
    background: var(--ieen-white);
    box-shadow: 0 18px 38px rgba(36, 33, 42, .08);
}

.ieen-institutions-head {
    padding: 22px 24px;
    background: linear-gradient(135deg, var(--ieen-morado), var(--ieen-morado-oscuro));
    color: var(--ieen-white);
    text-align: center;
}

.ieen-institutions-head h2 {
    margin: 0;
    color: inherit;
    font-size: 24px;
    font-weight: 900;
}

.ieen-institutions-head p {
    margin: 6px 0 0;
    color: rgba(255, 255, 255, .82);
}

.ieen-institutions-body {
    padding: 24px;
}

.ieen-institutions-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.ieen-institution-card {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 92px;
    padding: 16px;
    border: 1px solid var(--ieen-line);
    border-radius: 10px;
    background: var(--ieen-white);
    color: var(--ieen-texto) !important;
    text-decoration: none;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.ieen-institution-card:hover {
    border-color: rgba(91, 35, 128, .35);
    color: var(--ieen-morado);
    text-decoration: none;
    transform: translateY(-2px);
    box-shadow: 0 12px 26px rgba(59, 22, 88, .1);
}

.ieen-institution-logo {
    display: grid;
    place-items: center;
    flex: 0 0 58px;
    width: 58px;
    height: 58px;
    border-radius: 50%;
    background: var(--ieen-lila);
    color: var(--ieen-morado);
    font-size: 13px;
    font-weight: 900;
    text-align: center;
    overflow: hidden;
}

.ieen-institution-logo img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ieen-institution-card strong {
    display: block;
    font-size: 15px;
    line-height: 1.3;
}

.ieen-institution-card small {
    display: block;
    margin-top: 4px;
    color: var(--ieen-gris);
}

.ieen-institutions-more {
    margin-top: 14px;
}

.ieen-institutions-actions {
    display: flex;
    justify-content: center;
    margin-top: 20px;
}

.ieen-institutions-toggle {
    min-width: 150px;
    padding: 11px 20px;
    border: 1px solid var(--ieen-magenta);
    border-radius: 8px;
    background: var(--ieen-white);
    color: var(--ieen-magenta);
    font-weight: 900;
    cursor: pointer;
}

.ieen-modal {
    position: fixed;
    z-index: 10000;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 24px;
    background: rgba(16, 24, 32, .66);
}

.ieen-modal[hidden] {
    display: none;
}

.ieen-modal-dialog {
    width: min(760px, 100%);
    max-height: calc(100vh - 48px);
    overflow: auto;
    border-radius: 8px;
    background: var(--ieen-white);
    box-shadow: 0 30px 70px rgba(0, 0, 0, .28);
}

.ieen-modal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 16px 18px;
    border-bottom: 1px solid var(--ieen-line);
}

.ieen-modal-head strong {
    color: var(--ieen-wine);
    font-size: 18px;
}

.ieen-modal-close {
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 50%;
    background: var(--ieen-soft);
    color: var(--ieen-ink);
    cursor: pointer;
    font-size: 22px;
    line-height: 1;
}

.ieen-modal-body {
    padding: 18px;
}

.ieen-modal-body img {
    display: block;
    max-width: 100%;
    height: auto;
    margin: 0 auto;
    border-radius: 6px;
}

@media (max-width: 960px) {

    .ieen-hero-grid,
    .ieen-banner-feature,
    .ieen-election-countdown,
    .ieen-public-grid,
    .ieen-calendar-layout,
    .ieen-feature-links,
    .ieen-video-grid {
        grid-template-columns: 1fr;
    }

    .ieen-strip-grid,
    .ieen-grid-4,
    .ieen-grid-3,
    .ieen-rec-grid,
    .ieen-institutions-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ieen-calendar-toolbar {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ieen-calendar-summary {
        grid-template-columns: 1fr;
    }

    .ieen-calendar-legend {
        justify-content: flex-start;
        max-width: none;
    }

    .ieen-calendar-field:last-of-type {
        grid-column: 1 / -1;
    }

    .ieen-calendar-action {
        min-height: 58px;
    }

    .ieen-day-panel {
        height: auto;
        min-height: 280px;
    }

    .ieen-day-scroll {
        max-height: none;
    }
}

@media (max-width: 640px) {
    .ieen-container {
        width: min(100% - 24px, 1180px);
    }

    .ieen-link-list {
        grid-template-columns: 1fr;
    }

    .ieen-hero-grid {
        min-height: auto;
        gap: 28px;
        padding: 42px 0 30px;
    }

    .ieen-hero h1 {
        font-size: clamp(30px, 10vw, 42px);
        line-height: 1.08;
    }

    .ieen-hero-copy {
        margin-top: 16px;
        font-size: 17px;
        line-height: 1.5;
    }

    .ieen-highlight {
        padding: 20px;
    }

    .ieen-actions,
    .ieen-card-actions {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
    }

    .ieen-btn {
        width: 100%;
        text-align: center;
    }

    .ieen-strip-grid,
    .ieen-grid-4,
    .ieen-grid-3,
    .ieen-rec-grid,
    .ieen-institutions-grid {
        grid-template-columns: 1fr;
    }

    .ieen-section-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .ieen-section {
        padding: 42px 0;
    }

    .ieen-section-head h2 {
        font-size: clamp(25px, 8vw, 32px);
    }

    .ieen-strip a {
        min-height: 72px;
        padding: 14px 10px;
    }

    .ieen-calendar-toolbar {
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 10px;
    }

    .ieen-calendar-field:last-of-type {
        grid-column: auto;
    }

    .ieen-calendar-action,
    .ieen-calendar-action.is-secondary {
        width: 100%;
        min-width: 0;
        min-height: 50px;
    }

    .ieen-calendar-options {
        max-height: 230px;
    }

    .ieen-upcoming-list {
        grid-template-columns: 1fr;
    }

    .ieen-feature-panel,
    .ieen-public-panel {
        padding: 24px;
    }

    .ieen-calendar-shell {
        padding: 10px;
        border-radius: 12px;
    }

    .ieen-calendar-summary {
        gap: 14px;
        margin-bottom: 14px;
        padding: 14px 12px;
    }

    .ieen-upcoming-title {
        font-size: 16px;
        line-height: 1.35;
    }

    .ieen-calendar-legend {
        gap: 8px 12px;
    }

    .ieen-calendar-legend span {
        font-size: 10px;
    }

    .ieen-calendar-layout {
        gap: 16px;
    }

    .ieen-calendar-title {
        font-size: 18px;
    }

    .ieen-calendar-nav {
        grid-template-columns: 36px 1fr 36px;
        margin-bottom: 8px;
    }

    .ieen-calendar-nav button {
        width: 34px;
        height: 34px;
    }

    .ieen-calendar-weekdays span {
        padding: 7px 1px;
        font-size: 10px;
    }

    .ieen-calendar-day {
        min-height: 50px;
        padding: 7px 2px;
        font-size: 13px;
    }

    .ieen-calendar-day.is-today::before {
        top: 3px;
        right: 3px;
        padding: 1px 3px;
        font-size: 7px;
    }

    .ieen-calendar-dot {
        bottom: 6px;
    }

    .ieen-day-panel {
        min-height: 240px;
        padding: 18px 14px;
    }

    .ieen-day-panel h3 {
        font-size: 25px;
    }

    .ieen-session-badges {
        gap: 5px;
    }

    .ieen-day-source,
    .ieen-session-kind {
        min-height: 26px;
        padding: 5px 8px;
        font-size: 9px;
    }

    .ieen-session-meta {
        gap: 5px;
    }

    .ieen-session-links {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ieen-session-links>a,
    .ieen-session-video-menu,
    .ieen-session-video-menu summary {
        width: 100%;
    }

    .ieen-session-links a,
    .ieen-session-video-menu summary {
        justify-content: center;
        min-height: 40px;
        padding: 8px 9px;
        font-size: 10px;
        text-align: center;
    }

    .ieen-feature-link-grid {
        grid-template-columns: 1fr;
    }

    .ieen-feature-video-caption {
        align-items: flex-start;
        flex-direction: column;
    }

    .ieen-news-pill {
        width: min(300px, calc(100vw - 42px));
    }

    .ieen-recommended-panel {
        padding: 18px;
    }

    .ieen-banner-card img {
        min-height: 0;
        aspect-ratio: 16 / 9;
    }

    .ieen-countdown-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ieen-election-summary {
        grid-template-columns: 1fr;
    }

    .ieen-countdown-card {
        padding: 22px 18px;
    }

    .ieen-election-spotlight {
        grid-template-columns: 1fr;
        padding: 16px;
    }

    .ieen-election-preview {
        width: min(190px, 100%);
    }

    .ieen-election-timer {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: none;
    }

    .ieen-countdown-unit {
        min-height: 96px;
    }

    .ieen-banner-controls {
        right: 10px;
        bottom: 10px;
    }

    .ieen-feature-video-caption {
        padding: 14px;
    }

    .ieen-feature-link,
    .ieen-institution-card,
    .ieen-rec-card {
        padding: 14px;
    }

    .ieen-institutions-head,
    .ieen-institutions-body {
        padding: 18px 14px;
    }

    .ieen-institutions-toggle {
        width: 100%;
    }

    .ieen-modal {
        align-items: end;
        padding: 10px;
    }

    .ieen-modal-dialog {
        width: 100%;
        max-height: calc(100dvh - 20px);
        border-radius: 14px 14px 8px 8px;
    }

    .ieen-modal-body {
        padding: 12px;
    }
}

@media (max-width: 420px) {
    .ieen-container {
        width: calc(100% - 16px);
    }

    .ieen-kicker {
        gap: 8px;
        font-size: 11px;
    }

    .ieen-kicker::before {
        width: 28px;
    }

    .ieen-calendar-shell {
        padding: 8px;
    }

    .ieen-calendar-field {
        padding-right: 12px;
    }

    .ieen-upcoming-card {
        grid-template-columns: 40px minmax(0, 1fr);
        padding: 8px;
    }

    .ieen-upcoming-date {
        width: 40px;
        height: 44px;
    }

    .ieen-calendar-weekdays span {
        font-size: 9px;
    }

    .ieen-calendar-day {
        min-height: 46px;
        font-size: 12px;
    }

    .ieen-session-links {
        grid-template-columns: 1fr;
    }

    .ieen-feature-link-icon,
    .ieen-institution-logo {
        flex-basis: 48px;
        width: 48px;
        height: 48px;
    }

    .ieen-rec-card::after {
        display: none;
    }
}
/* Mejoras de accesibilidad y movimiento reducido. */
.ieen-home a:focus-visible,
.ieen-home button:focus-visible,
.ieen-home summary:focus-visible,
.ieen-modal a:focus-visible,
.ieen-modal button:focus-visible {
    outline: 3px solid var(--ieen-magenta);
    outline-offset: 3px;
}

.ieen-news-flow:focus-within .ieen-news-track {
    animation-play-state: paused;
}

.ieen-calendar-error {
    display: grid;
    justify-items: start;
    gap: 12px;
}

.ieen-calendar-error p {
    margin: 0;
}

@media (prefers-reduced-motion: reduce) {
    .ieen-home *,
    .ieen-home *::before,
    .ieen-home *::after {
        scroll-behavior: auto !important;
        transition-duration: .01ms !important;
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
    }

    .ieen-news-track {
        width: auto;
        animation: none;
    }
}