/* Global Theme Styles for Congreso Psicología 2026 */

:root {
    /* Color Palette - Updated to match template.html */
    --cp-primary: #1D4ED8;
    /* bg-blue-700 */
    --cp-primary-dark: #1E40AF;
    /* bg-blue-800 */
    --cp-primary-light: #EFF6FF;
    /* bg-blue-50 */
    --cp-secondary: #F59E0B;
    /* bg-amber-500 */
    --cp-secondary-dark: #D97706;
    /* bg-amber-600 */
    --cp-secondary-light: #FEF3C7;
    /* bg-amber-50 */
    --cp-bg: #FFFFFF;
    --cp-surface-light: #F8FAFC;
    /* bg-slate-50 */
    --cp-surface: #F1F5F9;
    /* bg-slate-100 */
    --cp-surface-dark: #0F172A;
    /* bg-slate-900 */
    --cp-text: #334155;
    /* text-slate-700 */
    --cp-text-dark: #1e293b;
    /* text-gray-900 */
    --cp-text-light: #64748B;
    /* text-slate-500 */
    --cp-border: #E2E8F0;
    /* border-slate-200 */

    /* Typography */
    --font-heading: 'Outfit', system-ui, sans-serif;
    --font-body: 'Inter', system-ui, sans-serif;

    /* Global Styles */
    --container-width: 1280px;
    /* max-w-7xl */
    --border-radius: 0.5rem;
    /* rounded-lg */
    --transition: all 0.3s ease;
}

/* Base Reset Extendido */
*,
*::before,
*::after {
    box-sizing: border-box;
}

body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
    margin: 0;
}

body {
    min-height: 100vh;
    text-rendering: optimizeSpeed;
    line-height: 1.6;
    font-family: var(--font-body);
    color: var(--cp-text);
    background-color: var(--cp-bg);
    overflow-x: hidden;
}

a:not([class]) {
    text-decoration-skip-ink: auto;
}

img,
picture {
    max-width: 100%;
    display: block;
    height: auto;
}

/* Typography Base */
h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--font-heading);
    color: var(--cp-text-dark);
    line-height: 1.2;
    margin-bottom: 1rem;
    font-weight: 700;
}

a {
    color: var(--cp-primary);
    text-decoration: none;
    transition: var(--transition);
}

a:hover {
    color: var(--cp-primary-dark);
}

/* Layout - Mobile First */
.container {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem;
}

@media (min-width: 640px) {
    .container {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

@media (min-width: 1024px) {
    .container {
        padding-left: 2rem;
        padding-right: 2rem;
        max-width: var(--container-width);
    }
}

/* Grid System */
.grid {
    display: grid;
}

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

@media (min-width: 768px) {
    .md-grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

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

@media (min-width: 1024px) {
    .lg-grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

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

/* Sections & Spacing */
.section-padding {
    padding: 5rem 1rem;
}

.section-padding-y {
    padding-top: 5rem;
    padding-bottom: 5rem;
}

@media (min-width: 1024px) {
    .section-padding {
        padding: 6rem 2rem;
    }

    .section-padding-y {
        padding-top: 7rem;
        padding-bottom: 7rem;
    }
}

/* Component: Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    border-radius: var(--border-radius);
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
    text-align: center;
    border: none;
    text-decoration: none;
    font-family: var(--font-body);
}

.btn-primary {
    background-color: var(--cp-primary);
    color: #fff;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

.btn-primary:hover {
    background-color: var(--cp-primary-dark);
    color: #fff;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

.btn-secondary {
    background-color: var(--cp-secondary);
    color: #fff;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

.btn-secondary:hover {
    background-color: var(--cp-secondary-dark);
    color: #fff;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

.btn-outline {
    background-color: transparent;
    border: 2px solid #fff;
    color: #fff;
}

.btn-outline:hover {
    background-color: #fff;
    color: var(--cp-text-dark);
}

.btn-outline.dark-mode {
    border-color: var(--cp-primary);
    color: var(--cp-primary);
}

.btn-outline.dark-mode:hover {
    background-color: var(--cp-primary-light);
}

.btn-ghost {
    background-color: transparent;
    color: var(--cp-primary);
}

.btn-ghost:hover {
    background-color: var(--cp-primary-light);
}

/* Animations */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-fade-in {
    animation: fadeIn 0.6s ease-out forwards;
}

/* Header Navbar — duración unificada para evitar micro-saltos entre propiedades */
.site-header {
    width: 100%;
    /* Altura real del header para menú overlay móvil (actualizada por JS si existe) */
    --site-header-offset: 88px;
    z-index: 1000;
    --header-transition-duration: 0.4s;
    --header-transition-ease: cubic-bezier(0.4, 0, 0.2, 1);
    transition: background-color var(--header-transition-duration) var(--header-transition-ease);
    position: sticky;
    top: 0;
    background-color: #fff;
    overflow-anchor: none;
    will-change: contents;
}

/* Smooth height collapse: grid 1fr → 0fr (avoids janky max-height transitions) */
.header-top-section {
    display: grid;
    grid-template-rows: 1fr;
    transition: grid-template-rows var(--header-transition-duration) var(--header-transition-ease);
}

.header-top-section-inner {
    min-height: 0;
    overflow: hidden;
    overflow-anchor: none;
}

.site-header.scrolled .header-top-section {
    grid-template-rows: 0fr;
    pointer-events: none;
}

.header-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 0.75rem 0;
}

.header-bottom-section {
    z-index: 1001;
    background-color: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid rgba(0, 0, 0, 0.05);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    transition:
        background-color var(--header-transition-duration) var(--header-transition-ease),
        box-shadow var(--header-transition-duration) var(--header-transition-ease);
}

.site-header.scrolled .header-bottom-section {
    background-color: rgba(255, 255, 255, 1);
    box-shadow: 0 10px 30px -10px rgba(0, 0, 0, 0.1);
    /* Blur durante scroll + transición es costoso; fondo ya es opaco */
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
}

.header-bottom {
    display: flex;
    justify-content: center;
    padding: 0.75rem 0;
    /* Sin transición: menos reflow acoplado al colapso del bloque superior */
}

.site-header.scrolled .header-bottom {
    padding: 0.5rem 0;
}

/* Mobile / base: flex row; desktop ≥1024px uses 3-column grid so the nav stays visually centered when the sticky logo animates */
.sticky-nav-content {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}

.sticky-header-logo-img {
    display: block;
    height: 2.25rem;
    width: auto;
    max-width: 100%;
    object-fit: contain;
}

.sticky-logo-link {
    box-sizing: border-box;
    width: auto;
    max-width: 0;
    margin-right: 0;
    opacity: 0;
    overflow: hidden;
    flex-shrink: 0;
    transition:
        max-width var(--header-transition-duration) var(--header-transition-ease),
        opacity var(--header-transition-duration) var(--header-transition-ease),
        transform var(--header-transition-duration) var(--header-transition-ease);
    transform: translateX(-8px);
    display: flex;
    align-items: center;
    text-decoration: none;
}

.site-header.scrolled .sticky-logo-link {
    max-width: min(88vw, 22rem);
    opacity: 1;
    transform: translateX(0);
}

@media (min-width: 1024px) {
    .sticky-header-logo-img {
        height: 2.5rem;
    }

    /*
     * Escritorio: slot fijo para logo horizontal — el menú no se desplaza al animar solo opacidad/escala
     * (evita temblor lateral por animar width en flex/grid).
     */
    .sticky-logo-link {
        width: 11rem;
        min-width: 11rem;
        max-width: 11rem;
        overflow: visible;
        opacity: 0;
        transform: scale(0.92);
        pointer-events: none;
    }

    .site-header.scrolled .sticky-logo-link {
        opacity: 1;
        transform: scale(1);
        pointer-events: auto;
    }
    .sticky-nav-content {
        display: grid;
        grid-template-columns: 1fr auto 1fr;
        align-items: center;
        column-gap: 1rem;
    }

    .sticky-nav-content .sticky-logo-link {
        grid-column: 1;
        justify-self: start;
    }

    .sticky-nav-content .main-navigation {
        grid-column: 2;
        justify-self: center;
    }

    /* Desktop Navigation Dropdowns */
    .main-navigation .sub-menu {
        display: flex; /* Reset from none */
        position: absolute;
        top: 100%;
        left: 50%;
        transform: translateX(-50%) translateY(10px);
        min-width: 240px;
        background: #ffffff;
        border: 1px solid rgba(0, 0, 0, 0.05);
        box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
        border-radius: 1rem;
        padding: 0.75rem;
        opacity: 0;
        visibility: hidden;
        flex-direction: column;
        z-index: 1000;
        margin-top: 0.5rem;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .main-navigation li:hover>.sub-menu {
        opacity: 1;
        visibility: visible;
        transform: translateX(-50%) translateY(0);
    }

    .main-navigation .sub-menu li {
        width: 100%;
    }

    .main-navigation .sub-menu a {
        padding: 0.75rem 1rem;
        border-radius: 0.625rem;
        font-size: 0.875rem;
        width: 100%;
    }

    .main-navigation .sub-menu a:hover {
        background-color: var(--cp-surface-light);
        color: var(--cp-primary);
    }
}

.mini-logo {
    width: 2.5rem !important;
    height: 2.5rem !important;
    font-size: 1.125rem !important;
}

.header-actions-wrapper {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.site-branding {
    display: flex;
    align-items: center;
    gap: 1rem;
    cursor: pointer;
}

.site-logo {
    width: 3rem;
    height: 3rem;
    background-color: var(--cp-primary);
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: #fff;
    font-weight: 800;
    font-size: 1.5rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

.site-title-group {
    display: flex;
    flex-direction: column;
}

.site-title {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--cp-text-dark);
    margin: 0;
    line-height: 1.1;
}

.site-subtitle {
    font-size: 0.8125rem;
    color: var(--cp-primary);
    font-weight: 700;
    letter-spacing: 0.05em;
    margin-top: 0.25rem;
}

/* Navigation Dropdowns */
.main-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 0.5rem;
}

.main-navigation li {
    position: relative;
}

.main-navigation a {
    padding: 0.625rem 1rem;
    border-radius: 0.75rem;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--cp-text-dark);
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 0.375rem;
    text-decoration: none;
    position: relative;
}

.main-navigation a::before {
    content: '';
    position: absolute;
    bottom: 0.25rem;
    left: 50%;
    width: 0;
    height: 2px;
    background-color: var(--cp-primary);
    transition: all 0.3s ease;
    transform: translateX(-50%);
    border-radius: 2px;
}

.main-navigation a:hover::before,
.main-navigation .current-menu-item>a::before {
    width: 1.5rem;
}

.main-navigation a:hover {
    color: var(--cp-primary);
    background-color: transparent;
    /* Remove background on top row links for cleaner look */
}

.main-navigation .current-menu-item>a,
.main-navigation .current-page-ancestor>a {
    color: var(--cp-primary);
    background-color: var(--cp-primary-light);
    font-weight: 600;
}

/* Sub-menus: escritorio en @media (min-width: 1024px) arriba; móvil cuando el panel está cerrado */
.main-navigation .sub-menu {
    list-style: none;
    margin: 0;
    padding: 0;
}

@media (max-width: 1023px) {
    .main-navigation:not(.toggled) .sub-menu {
        display: none;
    }
}

.header-logos-mini {
    display: none;
    align-items: center;
    gap: 1.5rem;
    margin-right: 1.5rem;
}

@media (min-width: 1024px) {
    .header-logos-mini {
        display: flex;
    }
}

.header-logos-mini a:hover img {
    filter: grayscale(0%);
    opacity: 1;
    transform: translateY(-2px);
}

.menu-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--cp-text);
}

.mobile-menu-backdrop {
    display: none;
}

@media (max-width: 1023px) {
    .site-header.scrolled .header-top-section {
        grid-template-rows: 1fr;
        pointer-events: auto;
    }

    .header-top {
        gap: 1rem;
        padding: 0.5rem 0;
    }

    .site-logo-official img {
        max-width: min(68vw, 18rem);
    }

    .header-actions-wrapper {
        margin-left: auto;
    }

    .header-bottom-section {
        border: none;
        background: transparent;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
    }

    .header-bottom {
        display: block;
        padding: 0;
        border: none;
        background: transparent;
        position: static;
    }

    .site-header.scrolled .header-bottom {
        padding: 0;
    }

    .sticky-logo-link {
        display: none;
    }

    .main-navigation {
        box-sizing: border-box;
        display: block;
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        width: min(86vw, 22rem);
        max-width: 100vw;
        height: 100dvh;
        min-height: 100vh;
        background: #fff;
        z-index: 10060;
        padding: calc(1.25rem + env(safe-area-inset-top, 0px)) 1.25rem calc(1.5rem + env(safe-area-inset-bottom, 0px));
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        box-shadow: -18px 0 45px rgba(15, 23, 42, 0.18);
        transform: translateX(105%);
        visibility: hidden;
        pointer-events: none;
        transition:
            transform 0.45s cubic-bezier(0.16, 1, 0.3, 1),
            visibility 0.45s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .header-actions {
        display: none;
    }

    .menu-toggle {
        display: flex;
        align-self: center;
        align-items: center;
        justify-content: center;
        width: 2.75rem;
        height: 2.75rem;
        padding: 0;
        border: 1px solid rgba(15, 23, 42, 0.12);
        border-radius: 9999px;
        background-color: #fff;
        box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
        line-height: 1;
        z-index: 10080;
        transition: background-color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, transform 0.2s ease;
    }

    .menu-toggle:active {
        transform: scale(0.95);
    }

    .menu-toggle svg line {
        transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.3s ease;
        transform-origin: center;
    }

    .menu-toggle svg {
        display: block;
        width: 1.5rem;
        height: 1.5rem;
    }

    body.mobile-menu-open .menu-toggle .line-top {
        transform: translateY(6px) rotate(45deg);
    }

    body.mobile-menu-open .menu-toggle .line-mid {
        opacity: 0;
        transform: scaleX(0);
    }

    body.mobile-menu-open .menu-toggle .line-bot {
        transform: translateY(-6px) rotate(-45deg);
    }

    body.mobile-menu-open .site-header {
        z-index: 10070;
    }

    .main-navigation.toggled {
        transform: translateX(0);
        visibility: visible;
        pointer-events: auto;
    }

    .mobile-menu-backdrop {
        display: block;
        position: fixed;
        inset: 0;
        width: 100%;
        min-height: 100vh;
        min-height: 100dvh;
        border: 0;
        padding: 0;
        background: rgba(15, 23, 42, 0.48);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        z-index: 10050;
        cursor: pointer;
        transition:
            opacity 0.4s ease,
            visibility 0.4s ease;
    }

    body.mobile-menu-open .mobile-menu-backdrop {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .main-navigation.toggled ul {
        flex-direction: column;
        gap: 0;
    }

    .main-navigation.toggled a {
        justify-content: space-between;
        font-size: 1rem;
        padding: 0.875rem 0.25rem;
        border-bottom: 1px solid var(--cp-border);
        border-radius: 0;
    }

    .main-navigation.toggled a::before {
        display: none;
    }

    .main-navigation.toggled .sub-menu {
        position: static;
        display: flex;
        flex-direction: column;
        opacity: 1;
        visibility: visible;
        box-shadow: none;
        border: none;
        background: transparent;
        padding: 0.5rem 0 0.5rem 1.25rem; /* Increased indentation */
        margin: 0;
        gap: 0;
        transform: none;
        transition: none;
    }

    .main-navigation.toggled .sub-menu a {
        color: #64748b;
        font-size: 0.9375rem;
        padding: 0.625rem 0.25rem;
        border-bottom: none;
        width: auto;
    }

    .main-navigation.toggled .sub-menu a:hover {
        background: transparent;
        transform: none;
    }

    /* Staggered entrance for menu items */
    .main-navigation > ul > li {
        opacity: 0;
        transform: translateY(10px);
        transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.6s ease;
    }

    .main-navigation.toggled > ul > li {
        opacity: 1;
        transform: translateY(0);
    }

    .main-navigation.toggled > ul > li:nth-child(1) { transition-delay: 0.1s; }
    .main-navigation.toggled > ul > li:nth-child(2) { transition-delay: 0.15s; }
    .main-navigation.toggled > ul > li:nth-child(3) { transition-delay: 0.2s; }
    .main-navigation.toggled > ul > li:nth-child(4) { transition-delay: 0.25s; }
    .main-navigation.toggled > ul > li:nth-child(5) { transition-delay: 0.3s; }
    .main-navigation.toggled > ul > li:nth-child(6) { transition-delay: 0.35s; }
    .main-navigation.toggled > ul > li:nth-child(7) { transition-delay: 0.4s; }
    .main-navigation.toggled > ul > li:nth-child(8) { transition-delay: 0.45s; }
}

/* Speakers Section */
.speakers-grid {
    display: flex !important;
    /* Force flex for Swiper bundle across all sizes */
    gap: 0;
}

.speakers-grid .speaker-card {
    height: auto;
}

.swiper-pagination {
    margin-top: 2rem;
    display: flex;
    justify-content: center;
    gap: 0.5rem;
}


.swiper-pagination-bullet {
    background: #64748B;
    opacity: 0.5;
    width: 10px;
    height: 10px;
}

.swiper-pagination-bullet-active {
    background: var(--cp-secondary) !important;
    opacity: 1;
}

/* Internal Pages Utilities */
.page-template-template-el-congreso .site-main,
.page-template-template-organizacion .site-main {
    background-color: var(--cp-surface-light);
}

/* Home — Hero */
.hero-section {
    position: relative;
    overflow: hidden;
    background-color: var(--cp-surface-dark);
    padding-top: clamp(5.5rem, calc(12vw + 3rem), 10rem);
    padding-bottom: clamp(3rem, 6vw, 5rem);
}

.hero-bg-video-wrap {
    position: absolute;
    inset: 0;
    z-index: 0;
}

.hero-video-fallback-bg {
    position: absolute;
    inset: 0;
    background-color: var(--cp-surface-dark);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.hero-bg-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero-bg-overlay {
    position: absolute;
    inset: 0;
}

.hero-bg-overlay-multiply {
    background-color: rgba(15, 23, 42, 0.5);
    mix-blend-mode: multiply;
}

.hero-bg-overlay-gradient {
    background: linear-gradient(to top, rgba(15, 23, 42, 1), transparent);
}

@media (max-width: 768px), (prefers-reduced-motion: reduce) {
    .hero-bg-video-wrap .hero-bg-video {
        display: none !important;
    }
}

.hero-section-inner {
    position: relative;
    z-index: 10;
    color: white;
    text-align: center;
}

.hero-meta-badge {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.375rem 0.75rem;
    width: fit-content;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: clamp(1.25rem, 4vw, 2rem);
    padding: 0.5rem 1rem;
    border-radius: 9999px;
    background: rgba(30, 64, 175, 0.5);
    border: 1px solid rgba(96, 165, 250, 0.3);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.hero-meta-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    max-width: 100%;
    justify-content: center;
}

.hero-meta-chip svg {
    flex-shrink: 0;
}

.hero-meta-text {
    font-size: clamp(0.75rem, calc(2.9vw + 0.62rem), 0.875rem);
    font-weight: 500;
    text-wrap: balance;
}

.hero-meta-divider {
    color: #93c5fd;
    margin-inline: 0.125rem;
    flex-shrink: 0;
}

@media (max-width: 440px) {
    .hero-meta-badge {
        flex-direction: column;
        align-items: center;
        gap: 0.5rem;
        border-radius: 1rem;
        padding: 0.625rem 0.875rem;
    }

    .hero-meta-divider {
        display: none;
    }

    .hero-meta-chip {
        justify-content: center;
        max-width: 100%;
    }
}

.hero-title {
    font-size: clamp(2rem, 5vw, 4.5rem);
    font-weight: 800;
    line-height: 1.1;
    margin-bottom: 1.5rem;
    color: white;
}

.hero-title-accent {
    background: linear-gradient(to right, #fcd34d, #f59e0b);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.hero-lede {
    margin-top: 1rem;
    font-size: clamp(1rem, calc(1.5vw + 0.92rem), 1.5rem);
    color: #dbeafe;
    max-width: 48rem;
    margin-inline: auto;
    font-weight: 300;
    line-height: 1.6;
    margin-bottom: clamp(1.75rem, 5vw, 3rem);
}

.hero-cta-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 1rem;
}

.hero-cta-btn {
    font-size: clamp(1rem, calc(0.35vw + 0.95rem), 1.125rem);
    padding: clamp(0.75rem, 1vw, 1rem) clamp(1.25rem, 3vw, 2rem);
}

/* Home — Bienvenida */
.home-bienvenida-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
    gap: clamp(2rem, 5vw, 3rem);
    align-items: center;
}

.home-bienvenida-visual {
    position: relative;
}

.home-bienvenida-stat {
    position: absolute;
    bottom: -1.5rem;
    left: -1.5rem;
    right: auto;
    max-width: calc(100% - 1.5rem);
    background: #fff;
    padding: 1.5rem;
    border-radius: 0.75rem;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    display: flex;
    align-items: center;
    gap: 1rem;
}

@media (max-width: 639px) {
    .home-bienvenida-stat {
        position: relative;
        left: auto;
        bottom: auto;
        margin-top: 1.25rem;
        max-width: 100%;
    }
}

[id] {
    scroll-margin-top: calc(env(safe-area-inset-top, 0px) + 112px);
}

@media (max-width: 1023px) {
    [id] {
        scroll-margin-top: calc(env(safe-area-inset-top, 0px) + 84px);
    }
}

/* Axis Cards (Ejes Temáticos) */
.axis-card {
    background: white;
    padding: 2rem;
    border-radius: 1.5rem;
    border: 1px solid var(--cp-border);
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 1.25rem;
}

.axis-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    border-color: var(--cp-primary-light);
}

.axis-icon {
    width: 3.5rem;
    height: 3.5rem;
    background-color: var(--cp-primary-light);
    color: var(--cp-primary);
    border-radius: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.axis-card:hover .axis-icon {
    background-color: var(--cp-primary);
    color: white;
    transform: rotate(10deg);
}

.axis-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--cp-text-dark);
    line-height: 1.2;
    margin-bottom: 0.75rem;
}

@media (max-width: 1024px) {
    .site-header .main-navigation ul {
        gap: 0;
    }
}

/* Footer — logo del congreso en blanco sobre fondo oscuro */
.site-footer-brand-logo {
    display: block;
    height: 60px;
    width: auto;
    max-width: 100%;
    object-fit: contain;
    filter: brightness(0) invert(1);
}

/* Página Historia — layout responsive */
.historia-hero {
    background: linear-gradient(135deg, var(--cp-primary) 0%, #1e3a8a 100%);
    color: #fff;
    text-align: center;
    position: relative;
    overflow: hidden;
    padding: 2.75rem 0 3rem;
}

@media (min-width: 640px) {
    .historia-hero {
        padding: 4rem 0;
    }
}

@media (min-width: 1024px) {
    .historia-hero {
        padding: 6rem 0;
    }
}

.historia-hero__pattern {
    position: absolute;
    inset: 0;
    opacity: 0.1;
    background-image: radial-gradient(#fff 1px, transparent 1px);
    background-size: 30px 30px;
    pointer-events: none;
}

.historia-hero__inner {
    position: relative;
    z-index: 1;
}

.historia-hero__title {
    font-family: var(--font-heading);
    font-size: clamp(1.875rem, 5.5vw + 0.4rem, 4rem);
    font-weight: 800;
    line-height: 1.15;
    margin-bottom: 0.75rem;
    color: #fff;
}

.historia-hero__lead {
    font-size: clamp(0.9375rem, 2.2vw, 1.25rem);
    line-height: 1.55;
    font-weight: 300;
    opacity: 0.92;
    max-width: 32rem;
    margin-inline: auto;
    padding-inline: 0.25rem;
}

.historia-content {
    background-color: var(--cp-surface-light);
    padding: 2.75rem 0 3rem;
}

@media (min-width: 1024px) {
    .historia-content {
        padding: 6rem 0;
    }
}

.historia-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(2rem, 4vw, 4rem);
    align-items: start;
}

@media (min-width: 1024px) {
    .historia-layout {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    }
}

.historia-body {
    font-size: 1rem;
    line-height: 1.75;
    color: var(--cp-text);
    min-width: 0;
}

@media (min-width: 640px) {
    .historia-body {
        font-size: 1.125rem;
        line-height: 1.8;
    }
}

.historia-body > p:last-child {
    margin-bottom: 0;
}

.historia-body p {
    margin-bottom: 1.25rem;
}

@media (min-width: 640px) {
    .historia-body p {
        margin-bottom: 1.5rem;
    }
}

.historia-brand {
    color: var(--cp-primary);
}

.historia-pullquote {
    background-color: var(--cp-bg);
    border-left: 4px solid var(--cp-primary);
    padding: 1.125rem 1.125rem 1.125rem 1rem;
    margin: 1.5rem 0;
    border-radius: 0 0.5rem 0.5rem 0;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.05);
}

@media (min-width: 640px) {
    .historia-pullquote {
        padding: 1.75rem 2rem;
        margin: 2rem 0;
    }
}

.historia-pullquote p {
    font-style: italic;
    color: var(--cp-text-dark);
}

.historia-tagline {
    color: var(--cp-primary);
    font-weight: 700;
}

.historia-aside {
    position: static;
    min-width: 0;
}

@media (min-width: 1024px) {
    .historia-aside {
        position: sticky;
        top: calc(env(safe-area-inset-top, 0px) + 100px);
    }
}

.historia-highlight-card {
    background-color: var(--cp-bg);
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

.historia-highlight-card img {
    width: 100%;
    height: min(52vw, 220px);
    max-height: 280px;
    object-fit: cover;
    object-position: top;
}

@media (min-width: 640px) {
    .historia-highlight-card img {
        height: 260px;
        max-height: none;
    }
}

@media (min-width: 1024px) {
    .historia-highlight-card img {
        height: 300px;
    }
}

.historia-highlight-card__body {
    padding: 1.25rem 1.25rem 1.35rem;
}

@media (min-width: 640px) {
    .historia-highlight-card__body {
        padding: 2rem 2.5rem;
    }
}

.historia-highlight-card__title {
    font-family: var(--font-heading);
    font-size: clamp(1.0625rem, 2vw, 1.25rem);
    font-weight: 700;
    margin-bottom: 0.75rem;
    color: var(--cp-text-dark);
    line-height: 1.25;
}

@media (min-width: 640px) {
    .historia-highlight-card__title {
        margin-bottom: 1rem;
    }
}

.historia-highlight-card__text {
    color: var(--cp-text-light);
    font-size: 0.9375rem;
    line-height: 1.6;
    margin-bottom: 1.25rem;
}

@media (min-width: 640px) {
    .historia-highlight-card__text {
        font-size: 1rem;
        margin-bottom: 1.5rem;
    }
}

.historia-highlight-card__footnote {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    color: var(--cp-primary);
    font-weight: 600;
    font-size: 0.8125rem;
    line-height: 1.45;
}

@media (min-width: 640px) {
    .historia-highlight-card__footnote {
        align-items: center;
        font-size: 1rem;
    }
}

.historia-highlight-card__footnote svg {
    flex-shrink: 0;
    margin-top: 0.1rem;
}

@media (min-width: 640px) {
    .historia-highlight-card__footnote svg {
        margin-top: 0;
    }
}

.historia-collage {
    margin: 1.5rem 0 0;
}

@media (min-width: 1024px) {
    .historia-collage {
        margin-top: 2rem;
    }
}

.historia-collage img {
    width: 100%;
    height: auto;
    display: block;
    border: none;
    border-radius: 0;
    box-shadow: none;
}

/* Página Saludo Directora */
.saludo-directora-content {
    background-color: var(--cp-surface-light);
    padding: 2.75rem 0 3rem;
}

@media (min-width: 1024px) {
    .saludo-directora-content {
        padding: 6rem 0;
    }
}

.saludo-directora-card {
    background-color: var(--cp-bg);
    border-radius: 1rem;
    border: 1px solid var(--cp-border);
    overflow: hidden;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
    padding: 1.25rem 1rem 1.5rem;
    max-width: 64rem;
    margin-inline: auto;
}

@media (min-width: 640px) {
    .saludo-directora-card {
        padding: 2rem 1.75rem;
    }
}

@media (min-width: 1024px) {
    .saludo-directora-card {
        padding: 4rem;
    }
}

.saludo-directora-layout {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.75rem;
}

@media (min-width: 1024px) {
    .saludo-directora-layout {
        flex-direction: row;
        align-items: flex-start;
        gap: clamp(2.5rem, 4vw, 4rem);
    }
}

.saludo-directora-profile {
    margin: 0;
    flex-shrink: 0;
    width: 100%;
    max-width: min(260px, 88vw);
}

@media (min-width: 1024px) {
    .saludo-directora-profile {
        max-width: 240px;
    }
}

.saludo-directora-photo-wrap {
    width: 100%;
    aspect-ratio: 4 / 5;
    max-height: 320px;
    border-radius: 1.25rem;
    background-color: var(--cp-surface);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border: 1px solid var(--cp-border);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
}

@media (min-width: 1024px) {
    .saludo-directora-photo-wrap {
        border-radius: 1.5rem;
        max-height: none;
        height: 300px;
        aspect-ratio: auto;
        width: 240px;
    }
}

.saludo-directora-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
}

.saludo-directora-photo-wrap--isotype {
    background-color: var(--cp-primary-light);
    padding: clamp(1.5rem, 5vw, 2.5rem);
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 1 / 1;
}

@media (min-width: 1024px) {
    .saludo-directora-photo-wrap--isotype {
        height: 240px;
        width: 240px;
        aspect-ratio: 1 / 1;
    }
}

.saludo-directora-photo--isotype {
    width: 100%;
    height: auto;
    max-height: 180px;
    object-fit: contain;
    filter: drop-shadow(0 10px 12px rgba(29, 78, 216, 0.15));
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.saludo-directora-photo-wrap--isotype:hover .saludo-directora-photo--isotype {
    transform: scale(1.05) rotate(3deg);
}

.saludo-directora-caption {
    text-align: center;
    margin-top: 1rem;
}

@media (min-width: 640px) {
    .saludo-directora-caption {
        margin-top: 1.25rem;
    }
}

.saludo-directora-name {
    font-weight: 700;
    color: var(--cp-text-dark);
    font-size: clamp(1rem, 2.8vw, 1.125rem);
    margin-bottom: 0.25rem;
    line-height: 1.3;
}

.saludo-directora-role {
    color: var(--cp-text-light);
    font-size: 0.8125rem;
    line-height: 1.45;
}

@media (min-width: 640px) {
    .saludo-directora-role {
        font-size: 0.875rem;
        line-height: 1.4;
    }
}

.saludo-directora-body {
    flex: 1;
    min-width: 0;
    width: 100%;
    font-size: 1rem;
    line-height: 1.75;
    color: var(--cp-text);
}

@media (min-width: 640px) {
    .saludo-directora-body {
        font-size: 1.125rem;
        line-height: 1.8;
    }
}

.saludo-directora-quote-icon {
    color: var(--cp-primary);
    margin-bottom: 1.125rem;
    line-height: 0;
}

.saludo-directora-quote-icon svg {
    width: clamp(2rem, 7vw, 3rem);
    height: clamp(2rem, 7vw, 3rem);
}

@media (min-width: 1024px) {
    .saludo-directora-quote-icon {
        margin-bottom: 2rem;
    }

    .saludo-directora-quote-icon svg {
        width: 3rem;
        height: 3rem;
    }
}

.saludo-directora-lede {
    margin-bottom: 1.25rem;
    font-size: clamp(1.05rem, 2.8vw, 1.25rem);
    color: var(--cp-text-dark);
    font-weight: 500;
    line-height: 1.55;
}

@media (min-width: 640px) {
    .saludo-directora-lede {
        margin-bottom: 1.5rem;
        line-height: 1.6;
    }
}

.saludo-directora-body > p {
    margin-bottom: 1.25rem;
}

@media (min-width: 640px) {
    .saludo-directora-body > p {
        margin-bottom: 1.5rem;
    }
}

.saludo-directora-body > p:last-of-type {
    margin-bottom: 0;
}

.saludo-directora-signoff {
    margin-top: 2rem;
    padding-top: 1.35rem;
    border-top: 1px solid var(--cp-surface);
}

@media (min-width: 1024px) {
    .saludo-directora-signoff {
        margin-top: 3rem;
        padding-top: 2rem;
    }
}

.saludo-directora-signoff__line {
    color: var(--cp-text-light);
    margin-bottom: 0.35rem;
    font-size: 0.9375rem;
}

@media (min-width: 640px) {
    .saludo-directora-signoff__line {
        margin-bottom: 0.5rem;
        font-size: 1rem;
    }
}

.saludo-directora-signoff__name {
    font-weight: 700;
    color: var(--cp-text-dark);
    font-size: clamp(1.0625rem, 2.5vw, 1.25rem);
    margin-bottom: 0;
}

/* Páginas Comité Científico y Organizador */
.comite-hero {
    background: linear-gradient(135deg, #0f172a 0%, #172554 100%);
    color: #fff;
    text-align: center;
    position: relative;
    overflow: hidden;
    padding: 2.75rem 0 3rem;
}

@media (min-width: 640px) {
    .comite-hero {
        padding: 4rem 0;
    }
}

@media (min-width: 1024px) {
    .comite-hero {
        padding: 6rem 0;
    }
}

.comite-hero__inner {
    position: relative;
    z-index: 1;
}

.comite-hero__title {
    font-family: var(--font-heading);
    font-size: clamp(1.875rem, 5.5vw + 0.4rem, 4rem);
    font-weight: 800;
    line-height: 1.15;
    margin-bottom: 0.75rem;
    color: #fff;
}

.comite-hero__lead {
    font-size: clamp(0.9375rem, 2.5vw, 1.25rem);
    line-height: 1.55;
    font-weight: 300;
    opacity: 0.92;
    max-width: 36rem;
    margin-inline: auto;
    padding-inline: 0.25rem;
}

.comite-page-section {
    background-color: var(--cp-bg);
    padding: 2.75rem 0 3rem;
}

@media (min-width: 1024px) {
    .comite-page-section {
        padding: 6rem 0;
    }
}

.comite-section-intro {
    text-align: center;
    margin-bottom: 2rem;
}

@media (min-width: 640px) {
    .comite-section-intro {
        margin-bottom: 2.5rem;
    }
}

@media (min-width: 1024px) {
    .comite-section-intro {
        margin-bottom: 4rem;
    }
}

.comite-section-intro__title {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 4vw, 2.25rem);
    font-weight: 700;
    color: var(--cp-text-dark);
    margin-bottom: 0.75rem;
    line-height: 1.2;
}

@media (min-width: 640px) {
    .comite-section-intro__title {
        margin-bottom: 1rem;
    }
}

.comite-section-intro__rule {
    width: 4rem;
    height: 4px;
    background-color: var(--cp-primary);
    margin: 0 auto;
}

.comite-members-stack {
    margin-bottom: 2.25rem;
}

@media (min-width: 1024px) {
    .comite-members-stack {
        margin-bottom: 5rem;
    }
}

.comite-members-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(17.5rem, 100%), 1fr));
    gap: 1.25rem;
}

@media (min-width: 640px) {
    .comite-members-grid {
        gap: 2rem;
    }
}

@media (min-width: 1024px) {
    .comite-members-grid {
        gap: 2.5rem;
    }
}

.member-card {
    background-color: var(--cp-surface-light);
    border-radius: 1rem;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
    border: 1px solid var(--cp-border);
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
    .member-card:hover {
        transform: translateY(-8px);
        box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
        border-color: var(--cp-primary);
    }
}

.member-card__media {
    aspect-ratio: 1 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--cp-surface);
    color: var(--cp-text-light);
    overflow: hidden;
}

.committee-photo {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top;
    filter: grayscale(100%);
    transition: filter 0.5s ease, transform 0.5s ease;
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
    .member-card:hover .committee-photo {
        filter: grayscale(0%);
        transform: scale(1.05);
    }
}

@media (prefers-reduced-motion: reduce) {

    .member-card,
    .committee-photo {
        transition: none;
    }
}

.member-card__body {
    padding: 1rem 1rem 1.25rem;
    text-align: center;
}

@media (min-width: 640px) {
    .member-card__body {
        padding: 1.5rem;
    }
}

.member-card__name {
    font-family: var(--font-heading);
    font-size: 1.0625rem;
    font-weight: 700;
    color: var(--cp-text-dark);
    margin-bottom: 0.35rem;
    line-height: 1.3;
}

@media (min-width: 640px) {
    .member-card__name {
        font-size: 1.125rem;
        margin-bottom: 0.5rem;
    }
}

.member-card__role {
    color: var(--cp-primary);
    font-weight: 600;
    font-size: 0.8125rem;
    margin-bottom: 0.35rem;
    line-height: 1.35;
    text-transform: none;
    letter-spacing: 0.02em;
}

@media (min-width: 640px) {
    .member-card__role {
        font-size: 0.75rem;
        margin-bottom: 0.25rem;
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }
}

.member-card__uni {
    color: var(--cp-text-light);
    font-size: 0.8125rem;
    font-style: italic;
    line-height: 1.45;
}

.comite-info-section {
    background-color: var(--cp-bg);
    padding-bottom: 2.75rem;
}

@media (min-width: 1024px) {
    .comite-info-section {
        padding-bottom: 6rem;
    }
}

.comite-info-box {
    background-color: var(--cp-surface);
    border-radius: 1rem;
    padding: 1.5rem 1.125rem;
}

@media (min-width: 640px) {
    .comite-info-box {
        border-radius: 1.5rem;
        padding: 2.5rem 2rem;
    }
}

@media (min-width: 1024px) {
    .comite-info-box {
        border-radius: 2rem;
        padding: 4rem;
    }
}

.comite-info-box__inner {
    max-width: 48rem;
    margin: 0 auto;
    text-align: center;
}

.comite-info-box__title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 3.5vw, 1.875rem);
    font-weight: 700;
    color: var(--cp-surface-dark);
    margin-bottom: 1rem;
    line-height: 1.25;
}

@media (min-width: 640px) {
    .comite-info-box__title {
        margin-bottom: 1.5rem;
    }
}

.comite-info-box__text {
    font-size: 1rem;
    color: var(--cp-text);
    line-height: 1.65;
}

@media (min-width: 640px) {
    .comite-info-box__text {
        font-size: 1.125rem;
        line-height: 1.7;
    }
}

/* Fechas importantes — home y página dedicada */
.fecha-ruta-home {
    padding: 2.75rem 0 3rem;
}

@media (min-width: 1024px) {
    .fecha-ruta-home {
        padding: 5rem 0;
    }
}

.fecha-ruta--page {
    background-color: var(--cp-surface-light);
    padding: 2.75rem 0 3rem;
}

@media (min-width: 1024px) {
    .fecha-ruta--page {
        padding: 6rem 0;
    }
}

.fecha-ruta-intro {
    text-align: center;
    margin-bottom: 2rem;
}

@media (min-width: 640px) {
    .fecha-ruta-intro {
        margin-bottom: 2.25rem;
    }
}

@media (min-width: 1024px) {
    .fecha-ruta-intro {
        margin-bottom: 4rem;
    }
}

.fecha-ruta-intro--home {
    margin-bottom: clamp(2rem, 5vw, 3rem);
}

@media (min-width: 1024px) {
    .fecha-ruta-intro--home {
        margin-bottom: 4rem;
    }
}

.fecha-ruta-intro__title {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 4.5vw, 2.5rem);
    font-weight: 800;
    color: var(--cp-surface-dark);
    margin-bottom: 0.65rem;
    line-height: 1.15;
}

.fecha-ruta-intro__title--home {
    font-size: clamp(1.375rem, 4vw, 1.875rem);
    font-weight: 700;
}

.fecha-ruta-intro__lead {
    color: var(--cp-text-light);
    font-size: clamp(1rem, 2.6vw, 1.125rem);
    max-width: 32rem;
    margin: 0 auto 1rem;
    line-height: 1.5;
}

.fecha-ruta-intro__lead--home {
    max-width: none;
    margin: 0;
}

@media (min-width: 640px) {
    .fecha-ruta-intro__lead {
        margin-bottom: 1.25rem;
    }
}

.fecha-ruta-intro__rule {
    width: 4rem;
    height: 4px;
    margin: 0 auto;
    background-color: var(--cp-primary);
}

.fecha-card:nth-child(odd) {
    --fecha-accent: var(--cp-primary);
}

.fecha-card:nth-child(even) {
    --fecha-accent: var(--cp-secondary);
}

.fecha-ruta-grid {
    display: grid;
    gap: clamp(1.25rem, 3vw, 2.5rem);
}

.fecha-ruta-grid--fit {
    grid-template-columns: repeat(auto-fill, minmax(min(17.5rem, 100%), 1fr));
}

.fecha-ruta-grid--home {
    padding-top: 0.5rem;
}

@media (min-width: 768px) {
    .fecha-ruta-grid--home {
        padding-top: 1rem;
    }
}

.fecha-card {
    position: relative;
    background: var(--cp-bg);
    border: 1px solid var(--cp-border);
    text-align: center;
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
    .fecha-card:hover {
        box-shadow: 0 12px 20px -6px rgba(0, 0, 0, 0.1);
    }
}

.fecha-card--page {
    padding: clamp(1.5rem, 4vw, 2.25rem) clamp(1.25rem, 3vw, 2rem);
    border-radius: 1.25rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
    .fecha-card--page:hover {
        transform: translateY(-5px);
        box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.08);
        border-color: var(--fecha-accent);
    }
}

.fecha-card__icon--page {
    width: 3.5rem;
    height: 3.5rem;
    margin: 0 auto 1.125rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--fecha-accent);
    color: #fff;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.08);
}

.fecha-card__date--page {
    color: var(--fecha-accent);
    font-weight: 800;
    font-size: clamp(0.75rem, 2vw, 0.875rem);
    letter-spacing: 0.03em;
    text-transform: uppercase;
    margin-bottom: 0.65rem;
    line-height: 1.35;
    word-break: break-word;
}

.fecha-card__heading {
    font-family: var(--font-heading);
    font-size: clamp(1.0625rem, 3vw, 1.25rem);
    font-weight: 700;
    color: var(--cp-surface-dark);
    margin-top: 0;
    margin-bottom: 0.65rem;
    line-height: 1.3;
}

.fecha-card__text {
    font-size: clamp(0.875rem, 2vw, 0.9375rem);
    line-height: 1.55;
    color: var(--cp-text-light);
}

@media (min-width: 640px) {
    .fecha-card__text {
        line-height: 1.6;
    }
}

.fecha-card__heading--overlap {
    margin-bottom: 0.5rem;
}

.fecha-card--overlap {
    margin-top: 2rem;
    padding: 2.25rem clamp(1.125rem, 3vw, 2rem) 1.75rem;
    border-radius: 1rem;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

@media (min-width: 640px) {
    .fecha-card--overlap {
        margin-top: 2.25rem;
        padding-top: 2.5rem;
    }
}

.fecha-card__icon--overlap {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--fecha-accent);
    color: #fff;
    border: 4px solid var(--cp-surface-light);
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
}

@media (min-width: 640px) {
    .fecha-card__icon--overlap {
        width: 3.5rem;
        height: 3.5rem;
    }
}

.fecha-card__body--overlap {
    padding-top: 0.25rem;
}

.fecha-card__date:not(.fecha-card__date--page) {
    color: var(--fecha-accent);
    font-weight: 700;
    font-size: clamp(0.75rem, 2vw, 0.875rem);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 0.5rem;
    line-height: 1.35;
    word-break: break-word;
}

/* Página Inscripciones */
.inscrip-pricing-section {
    background-color: var(--cp-surface-light);
    padding: 2.75rem 0 3rem;
}

@media (min-width: 1024px) {
    .inscrip-pricing-section {
        padding: 6rem 0;
    }
}

.inscrip-pricing-intro {
    margin-bottom: 1.75rem;
}

@media (min-width: 1024px) {
    .inscrip-pricing-intro {
        margin-bottom: 3rem;
    }
}

.inscrip-pricing-card {
    max-width: 56rem;
    margin: 0 auto;
    background: var(--cp-bg);
    border-radius: clamp(1rem, 3vw, 2rem);
    overflow: hidden;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.08);
    border: 1px solid var(--cp-border);
}

.inscrip-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

@media (max-width: 767px) {
    .inscrip-table-wrap {
        overflow-x: visible;
        padding: 0.5rem;
    }
}

.inscrip-table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
    font-variant-numeric: tabular-nums;
}

@media (max-width: 767px) {
    .inscrip-table thead {
        position: absolute;
        height: 1px;
        width: 1px;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
    }

    .inscrip-table tbody tr {
        display: block;
        margin-bottom: 1rem;
        border-radius: 0.875rem;
        border: 1px solid var(--cp-border);
        overflow: hidden;
        background: var(--cp-bg);
    }

    .inscrip-table tbody td {
        display: flex;
        justify-content: space-between;
        align-items: baseline;
        gap: 1rem;
        padding: 0.875rem 1rem;
        font-size: 1rem;
        border-bottom: 1px solid var(--cp-border);
        text-align: right;
        color: var(--cp-text);
    }

    .inscrip-table tbody td:last-child {
        border-bottom: none;
    }

    .inscrip-table tbody td::before {
        content: attr(data-label);
        font-weight: 600;
        font-size: 0.8125rem;
        color: var(--cp-text-dark);
        text-align: left;
        line-height: 1.35;
        max-width: 58%;
        text-transform: none;
    }

    .inscrip-table tbody td:first-child {
        display: block;
        text-align: center;
        font-weight: 700;
        color: var(--cp-text-dark);
        background-color: var(--cp-surface-light);
        padding: 0.9rem 0.85rem;
    }

    .inscrip-table tbody td:first-child::before {
        display: none;
    }

    .inscrip-table tbody td:nth-child(2) {
        font-weight: 700;
        font-size: 1.0625rem;
        color: var(--cp-primary);
    }

    .inscrip-table tbody td:nth-child(3) {
        font-weight: 600;
        font-size: 1.0625rem;
    }
}

.inscrip-table thead tr {
    background-color: #1e3a8a;
    color: #fff;
}

.inscrip-table th {
    padding: clamp(1rem, 3vw, 1.5rem) clamp(1rem, 2.8vw, 2rem);
    font-weight: 600;
    font-size: clamp(0.9375rem, 2vw, 1.125rem);
    vertical-align: top;
}

.inscrip-table th:not(:first-child) {
    text-align: center;
}

.inscrip-table__th-meta {
    font-size: 0.8125rem;
    font-weight: 400;
    opacity: 0.85;
    display: inline-block;
    margin-top: 0.35rem;
    line-height: 1.35;
}

.inscrip-table tbody tr {
    border-bottom: 1px solid var(--cp-border);
}

.inscrip-table tbody tr:nth-child(even) {
    background-color: var(--cp-surface-light);
}

@media (max-width: 767px) {
    .inscrip-table tbody tr:nth-child(even) {
        background-color: var(--cp-bg);
    }
}

.inscrip-table tbody td {
    padding: clamp(1rem, 2.8vw, 1.5rem) clamp(1rem, 2.8vw, 2rem);
}

.inscrip-table tbody td:first-child {
    font-weight: 600;
    color: var(--cp-text-dark);
}

.inscrip-table tbody td:nth-child(2) {
    text-align: center;
    font-size: 1.25rem;
    color: var(--cp-primary);
    font-weight: 700;
}

.inscrip-table tbody td:nth-child(3) {
    text-align: center;
    font-size: 1.25rem;
}

@media (max-width: 767px) {
    .inscrip-table tbody td:nth-child(2),
    .inscrip-table tbody td:nth-child(3) {
        text-align: right;
        font-size: 1rem;
    }
}

.inscrip-notice {
    margin-top: clamp(1.75rem, 5vw, 4rem);
    max-width: 56rem;
    margin-inline: auto;
    padding: 1rem 1.125rem;
    background: var(--cp-secondary-light);
    border: 1px solid #fde68a;
    border-radius: clamp(1rem, 3vw, 1.5rem);
    display: flex;
    gap: 1rem;
    align-items: flex-start;
}

@media (min-width: 640px) {
    .inscrip-notice {
        padding: 1.75rem;
        gap: 1.5rem;
    }
}

@media (max-width: 479px) {
    .inscrip-notice {
        flex-direction: column;
        align-items: flex-start;
    }
}

.inscrip-notice__icon {
    flex-shrink: 0;
    background: #fef3c7;
    color: #92400e;
    padding: 0.625rem;
    border-radius: 1rem;
    line-height: 0;
}

.inscrip-notice__title {
    font-family: var(--font-heading);
    font-size: 1.0625rem;
    font-weight: 700;
    color: #92400e;
    margin-bottom: 0.4rem;
    line-height: 1.25;
}

.inscrip-notice__text {
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.55;
    color: #92400e;
}

@media (min-width: 640px) {
    .inscrip-notice__text {
        font-size: 1rem;
        line-height: 1.6;
    }
}

.inscrip-notice__link {
    font-weight: 700;
    text-decoration: underline;
    color: #b45309;
    overflow-wrap: anywhere;
}

.inscrip-how-section {
    background-color: var(--cp-bg);
    padding: 2.75rem 0 3rem;
}

@media (min-width: 1024px) {
    .inscrip-how-section {
        padding: 6rem 0;
    }
}

.inscrip-how-inner {
    max-width: 64rem;
    margin: 0 auto;
}

.inscrip-steps-layout {
    display: grid;
    gap: 2rem;
    align-items: start;
}

@media (min-width: 1024px) {
    .inscrip-steps-layout {
        grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
        gap: clamp(2rem, 4vw, 4rem);
        align-items: center;
    }
}

.inscrip-steps-title {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 4vw, 2rem);
    font-weight: 800;
    color: var(--cp-surface-dark);
    margin-bottom: 1.35rem;
    line-height: 1.15;
}

@media (min-width: 1024px) {
    .inscrip-steps-title {
        margin-bottom: 2rem;
    }
}

.inscrip-steps-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.inscrip-step {
    display: flex;
    gap: 1rem;
    margin-bottom: 1.35rem;
    align-items: flex-start;
}

@media (min-width: 640px) {
    .inscrip-step {
        gap: 1.5rem;
        margin-bottom: 1.75rem;
    }
}

.inscrip-step:last-child {
    margin-bottom: 0;
}

.inscrip-step__num {
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--cp-primary);
    color: #fff;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9375rem;
}

.inscrip-step__heading {
    font-family: var(--font-heading);
    font-weight: 700;
    color: var(--cp-text-dark);
    font-size: 1rem;
    margin-top: 0;
    margin-bottom: 0.2rem;
    line-height: 1.35;
}

@media (min-width: 640px) {
    .inscrip-step__heading {
        font-size: 1.05rem;
    }
}

.inscrip-step__badge {
    display: inline;
    font-size: clamp(0.75rem, 2vw, 0.875rem);
    color: #b45309;
    font-weight: 600;
    margin-left: 0.2rem;
}

.inscrip-step__text {
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.5;
    color: var(--cp-text-light);
}

.inscrip-pay-box {
    background: linear-gradient(135deg, var(--cp-surface) 0%, #e2e8f0 100%);
    padding: clamp(1.5rem, 5vw, 3rem);
    border-radius: clamp(1.25rem, 3vw, 2rem);
    text-align: center;
    border: 1px solid #cbd5e1;
}

.inscrip-pay-box__icon {
    width: 4rem;
    height: 4rem;
    margin: 0 auto 1.25rem;
    background: var(--cp-bg);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.08);
}

.inscrip-pay-box__title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    font-weight: 700;
    color: var(--cp-surface-dark);
    margin-bottom: 0.65rem;
}

.inscrip-pay-box__lead {
    margin: 0 0 1.5rem;
    color: var(--cp-text);
    font-size: 0.9375rem;
    line-height: 1.55;
}

@media (min-width: 640px) {
    .inscrip-pay-box__lead {
        margin-bottom: 2rem;
    }
}

.inscrip-pay-box__btn {
    width: 100%;
    padding: clamp(1rem, 3vw, 1.25rem);
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.08);
}

.inscrip-pay-box__note {
    margin-top: 1rem;
    font-size: 0.75rem;
    color: #94a3b8;
}

.inscrip-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(15, 23, 42, 0.8);
    padding: 0;
    align-items: flex-end;
    justify-content: center;
}

@media (min-width: 480px) {
    .inscrip-modal {
        padding: 1rem;
        align-items: center;
    }
}

.inscrip-modal__dialog {
    position: relative;
    width: 100%;
    max-width: 32rem;
    background: var(--cp-bg);
    border-radius: 1rem 1rem 0 0;
    padding: 1.5rem clamp(1.125rem, 4vw, 2.25rem);
    padding-top: max(3rem, env(safe-area-inset-top, 0px));
    padding-bottom: max(1.5rem, env(safe-area-inset-bottom, 0px));
    box-shadow: 0 -12px 40px rgba(0, 0, 0, 0.2);
    max-height: min(calc(100vh - env(safe-area-inset-bottom, 0px)), 90vh);
    overflow-y: auto;
}

@media (min-width: 480px) {
    .inscrip-modal__dialog {
        border-radius: 1.5rem;
        padding: clamp(2rem, 5vw, 2.5rem);
        padding-top: 2.5rem;
        max-height: min(85vh, 36rem);
        box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    }
}

.inscrip-modal__close {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--cp-text-light);
    padding: 0.5rem;
    line-height: 0;
}

.inscrip-modal__title-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
    color: #b45309;
}

.inscrip-modal__title-row svg {
    flex-shrink: 0;
}

.inscrip-modal__title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    font-weight: 800;
    margin: 0;
    color: var(--cp-text-dark);
}

.inscrip-modal__body {
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    color: var(--cp-text);
    line-height: 1.55;
    margin-bottom: 0.85rem;
}

.inscrip-modal__mailto {
    margin: 0 0 1.5rem;
}

.inscrip-modal__mailto-link {
    color: var(--cp-primary);
    font-weight: 700;
    text-decoration: underline;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.inscrip-modal__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    justify-content: stretch;
}

.inscrip-modal__btn {
    flex: 1 1 calc(50% - 0.325rem);
    min-width: 8rem;
    padding: 0.75rem 1rem;
    border-radius: 9999px;
    font-weight: 600;
    text-align: center;
    cursor: pointer;
    text-decoration: none;
    transition: opacity 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.inscrip-modal__btn-cancel {
    border: 1px solid #cbd5e1;
    background: var(--cp-bg);
    color: var(--cp-text);
}

.inscrip-modal__btn-cancel:hover {
    background: var(--cp-surface);
}

.inscrip-modal__btn-accept {
    background: var(--cp-primary);
    color: #fff;
    border: none;
}

.inscrip-modal__btn-accept:hover {
    opacity: 0.92;
}

@media (max-width: 379px) {
    .inscrip-modal__btn {
        flex-basis: 100%;
    }
}

/* Modal: estructura del abstract (home modalidades) */
.mod-abstract-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(15, 23, 42, 0.8);
    padding: 0;
    align-items: flex-end;
    justify-content: center;
}

.mod-abstract-modal.is-open {
    display: flex;
}

@media (min-width: 480px) {
    .mod-abstract-modal {
        padding: 1rem;
        align-items: center;
    }
}

.mod-abstract-modal__dialog {
    position: relative;
    width: 100%;
    max-width: 36rem;
    background: var(--cp-bg);
    border-radius: 1rem 1rem 0 0;
    padding: 1.5rem clamp(1.125rem, 4vw, 2.25rem);
    padding-top: max(3rem, env(safe-area-inset-top, 0px));
    padding-bottom: max(1.5rem, env(safe-area-inset-bottom, 0px));
    box-shadow: 0 -12px 40px rgba(0, 0, 0, 0.2);
    max-height: min(calc(100vh - env(safe-area-inset-bottom, 0px)), 90vh);
    overflow-y: auto;
}

@media (min-width: 480px) {
    .mod-abstract-modal__dialog {
        border-radius: 1.5rem;
        padding: clamp(2rem, 5vw, 2.5rem);
        padding-top: 2.5rem;
        max-height: min(90vh, 42rem);
        box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    }
}

.mod-abstract-modal__close {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--cp-text-light);
    padding: 0.5rem;
    line-height: 0;
}

.mod-abstract-modal__title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 3vw, 1.5rem);
    font-weight: 800;
    margin: 0 2rem 0.5rem 0;
    color: var(--cp-text-dark);
}

.mod-abstract-modal__subtitle {
    font-size: 1rem;
    color: var(--cp-primary);
    font-weight: 600;
    margin: 0 0 1rem;
}

.mod-abstract-modal__subtitle:empty {
    display: none;
}

.mod-abstract-modal__note {
    margin: 0 0 1.25rem;
    padding: 1rem 1.125rem;
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    border-radius: 0.75rem;
    font-size: 0.9375rem;
    line-height: 1.55;
    color: var(--cp-text);
}

.mod-abstract-modal__note[hidden] {
    display: none !important;
}

.mod-abstract-modal__intro {
    font-size: 1rem;
    color: var(--cp-text);
    margin: 0 0 1rem;
    line-height: 1.5;
}

.mod-abstract-structure {
    list-style: none;
    margin: 0 0 1.5rem;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.mod-abstract-structure__item {
    padding: 0.875rem 1rem;
    background: var(--cp-surface-light);
    border: 1px solid var(--cp-border);
    border-radius: 0.5rem;
    font-size: 1rem;
    color: var(--cp-text);
    line-height: 1.5;
}

.mod-abstract-structure__optional,
.mod-abstract-structure__range {
    font-weight: 400;
    color: var(--cp-text-light);
    font-size: 0.9375rem;
}

.mod-abstract-structure__range {
    display: block;
    margin-top: 0.25rem;
}

.mod-abstract-structure__sublist {
    margin: 0.75rem 0 0;
    padding-left: 1.25rem;
    list-style: disc;
}

.mod-abstract-structure__sublist li {
    margin-bottom: 0.35rem;
    color: var(--cp-text);
    font-weight: 400;
}

.mod-abstract-modal__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.mod-abstract-modal__btn-close,
.mod-abstract-modal__btn-envio {
    flex: 1 1 auto;
    min-width: 8rem;
    text-align: center;
}

.mod-abstract-modal__btn-envio {
    border-color: var(--cp-primary);
    color: var(--cp-primary);
}

/* Modal Tab Styles */
.mod-abstract-modal__tabs {
    display: flex;
    gap: 0.35rem;
    margin: 1.25rem 0 1.75rem;
    justify-content: center;
    border-bottom: 2px solid var(--cp-border);
    padding-bottom: 0.75rem;
    flex-wrap: wrap;
}

.mod-abstract-modal__tab-btn {
    padding: 0.5rem 1.15rem;
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--cp-text-light);
    background: none;
    border: none;
    border-radius: 9999px;
    cursor: pointer;
    transition: all 0.22s ease-in-out;
}

.mod-abstract-modal__tab-btn:hover {
    color: var(--cp-primary-dark);
    background-color: var(--cp-primary-light);
}

.mod-abstract-modal__tab-btn.active {
    color: #fff !important;
    background-color: var(--cp-primary);
    box-shadow: 0 4px 10px rgba(29, 78, 216, 0.25);
}

.inscrip-help-section {
    background-color: var(--cp-bg);
    padding: 0 0 2.75rem;
}

@media (min-width: 1024px) {
    .inscrip-help-section {
        padding-bottom: 6rem;
    }
}

.inscrip-help-box {
    background-color: var(--cp-surface-dark);
    border-radius: clamp(1rem, 3vw, 2rem);
    padding: clamp(1.75rem, 6vw, 4rem);
    color: #fff;
}

.inscrip-help-inner {
    max-width: 48rem;
    margin: 0 auto;
    text-align: center;
}

.inscrip-help-title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 4vw, 1.875rem);
    font-weight: 700;
    margin-bottom: 1rem;
    color: inherit;
}

@media (min-width: 640px) {
    .inscrip-help-title {
        margin-bottom: 1.5rem;
    }
}

.inscrip-help-text {
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    opacity: 0.85;
    line-height: 1.6;
    margin-bottom: clamp(1.25rem, 4vw, 2.5rem);
}

.inscrip-help-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1rem 1.5rem;
}

.inscrip-help-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
    color: inherit;
    text-decoration: none;
    padding: 0.65rem 0.75rem;
    border-radius: 0.75rem;
    transition: background 0.2s ease;
}

.inscrip-help-link:hover {
    background: rgba(255, 255, 255, 0.08);
}

/* Llamado de trabajos (home modalidades + envío de trabajos) */
#ejes-tematicos {
    scroll-margin-top: clamp(5rem, 14vw, 7.5rem);
}

.llamado-trabajos-section {
    background-color: var(--cp-surface-light);
}

.llamado-trabajos-section.section-padding {
    padding-top: clamp(2.25rem, 5vw, 3.5rem);
    padding-bottom: clamp(2.25rem, 5vw, 3.5rem);
}

#modalidades .llamado-trabajos {
    margin-bottom: clamp(2rem, 4vw, 3rem);
}

.llamado-trabajos {
    max-width: 52rem;
    margin-inline: auto;
}

.llamado-trabajos--card {
    background: #fff;
    border: 1px solid var(--cp-border);
    border-radius: clamp(1.25rem, 3vw, 1.75rem);
    box-shadow: 0 10px 30px -15px rgba(0, 0, 0, 0.1);
    padding: clamp(1.5rem, 4vw, 2.5rem) clamp(1.25rem, 4vw, 2.25rem);
}

.llamado-trabajos__header {
    text-align: center;
    margin-bottom: clamp(1.25rem, 3vw, 1.75rem);
}

.llamado-trabajos__title {
    font-size: clamp(1.5rem, 4vw, 1.875rem);
    font-weight: 800;
    color: var(--cp-text-dark);
    margin: 0 0 0.75rem;
    line-height: 1.2;
}

.llamado-trabajos__rule {
    width: 4rem;
    height: 4px;
    background: var(--cp-secondary);
    margin: 0 auto 1.25rem;
    border-radius: 9999px;
}

.llamado-trabajos__lead {
    font-size: clamp(1.0625rem, 2.5vw, 1.125rem);
    line-height: 1.55;
    color: var(--cp-text-light);
    margin: 0 auto 1.25rem;
    max-width: 40rem;
}

.llamado-trabajos__cta-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem;
}

/* Unified styling for both buttons in the llamado block to guarantee identical dimensions and layout */
.llamado-trabajos__open-modal,
.llamado-trabajos__btn-ejes {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 3.25rem !important;
    padding: 0 1.75rem !important;
    border-radius: 9999px !important;
    font-family: var(--font-body) !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.015em !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    text-decoration: none !important;
    margin: 0 !important;
    gap: 0.625rem !important;
    min-width: 17.5rem !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    transition: transform 0.25s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.25s ease, background-color 0.25s ease, border-color 0.25s ease, background 0.25s ease !important;
}

.llamado-trabajos__btn-ejes {
    border: 2px solid var(--cp-primary) !important;
    color: var(--cp-primary) !important;
    background: transparent !important;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.02) !important;
}

.llamado-trabajos__btn-ejes:hover {
    background: var(--cp-primary-light) !important;
    color: var(--cp-primary-dark) !important;
    border-color: var(--cp-primary-dark) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 15px rgba(29, 78, 216, 0.08) !important;
}

.llamado-trabajos__btn-ejes:active {
    transform: translateY(1px) !important;
}

.llamado-trabajos__btn-ejes-icon {
    flex-shrink: 0 !important;
    transition: transform 0.25s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
}

.llamado-trabajos__btn-ejes:hover .llamado-trabajos__btn-ejes-icon {
    transform: translateX(4px) !important;
}

.llamado-trabajos__prose {
    border-top: 1px solid var(--cp-border);
    padding-top: clamp(1.25rem, 3vw, 1.75rem);
}

.llamado-trabajos__p {
    font-size: clamp(1rem, 2.2vw, 1.0625rem);
    line-height: 1.75;
    color: var(--cp-text);
    text-align: left;
    margin: 0 0 1rem;
}

.llamado-trabajos__p:last-child {
    margin-bottom: 0;
}

.llamado-trabajos__ejes-link {
    color: var(--cp-primary);
    font-weight: 600;
    text-decoration: underline;
    text-underline-offset: 2px;
}

.llamado-trabajos__ejes-link:hover {
    color: var(--cp-primary-dark);
}

.llamado-trabajos__idioma {
    margin: clamp(1.25rem, 3vw, 1.75rem) 0 0;
    padding-top: clamp(1rem, 2.5vw, 1.25rem);
    border-top: 1px solid var(--cp-border);
    text-align: center;
}

.llamado-trabajos__idioma-badge {
    display: inline-block;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--cp-primary-dark);
    background: var(--cp-primary-light);
    padding: 0.5rem 1rem;
    border-radius: 9999px;
    border: 1px solid rgba(37, 99, 235, 0.15);
}

/* Llamado de trabajos: modo compacto (Home) + contenido en modal */
.llamado-trabajos--compact {
    text-align: center;
    padding: 0.25rem 0 0.5rem;
}

.llamado-trabajos__hint {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.625rem;
    font-size: clamp(0.9rem, 2vw, 0.975rem);
    line-height: 1.5;
    color: var(--cp-primary-dark);
    background: var(--cp-primary-light);
    border: 1px solid rgba(29, 78, 216, 0.15);
    padding: 0.65rem 1.35rem;
    border-radius: 9999px;
    margin: 0 auto 1.75rem;
    max-width: 90%;
    font-weight: 600;
    box-shadow: 0 4px 15px -3px rgba(29, 78, 216, 0.05);
    transition: all 0.3s ease;
}

.llamado-trabajos__hint:hover {
    background: rgba(29, 78, 216, 0.08);
    border-color: rgba(29, 78, 216, 0.25);
    transform: translateY(-1px);
}

.llamado-trabajos__hint-icon {
    flex-shrink: 0;
    color: var(--cp-primary);
    animation: pulseIcon 2s infinite ease-in-out;
}

@keyframes pulseIcon {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.08); opacity: 0.85; }
}

.llamado-trabajos__cta-row--compact {
    justify-content: center;
    align-items: center;
    gap: 1rem !important;
}

/* Premium Styles for the Primary Button */
.llamado-trabajos__open-modal {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, var(--cp-primary) 0%, #3b82f6 100%) !important;
    border: 2px solid transparent !important;
    color: #fff !important;
    box-shadow: 0 8px 20px -6px rgba(29, 78, 216, 0.4), 0 4px 6px -4px rgba(29, 78, 216, 0.2) !important;
}

.llamado-trabajos__open-modal:hover {
    background: linear-gradient(135deg, var(--cp-primary-dark) 0%, #2563eb 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 12px 24px -5px rgba(29, 78, 216, 0.5), 0 6px 12px -5px rgba(29, 78, 216, 0.3) !important;
}

.llamado-trabajos__open-modal:active {
    transform: translateY(1px) !important;
    box-shadow: 0 6px 15px -5px rgba(29, 78, 216, 0.4) !important;
}

.llamado-trabajos__btn-icon {
    flex-shrink: 0 !important;
    transition: transform 0.25s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
}

.llamado-trabajos__open-modal:hover .llamado-trabajos__btn-icon {
    transform: rotate(-8deg) scale(1.15) !important;
}

/* Revamped Llamado de Trabajos Modal Styles */
.llamado-trabajos-modal {
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    background: rgba(15, 23, 42, 0.45) !important;
    transition: opacity 0.4s ease;
}

.llamado-trabajos-modal.is-open {
    display: flex;
    animation: chamadoModalFadeIn 0.35s ease-out forwards;
}

.llamado-trabajos-modal .mod-abstract-modal__dialog {
    border-radius: 1.5rem !important;
    border: 1px solid rgba(255, 255, 255, 0.8);
    box-shadow: 0 25px 60px -15px rgba(15, 23, 42, 0.3) !important;
    padding: clamp(2rem, 5vw, 2.5rem) !important;
    padding-top: 3.25rem !important;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%) !important;
    opacity: 0;
    transform: scale(0.95) translateY(15px);
    max-width: min(42rem, 100%) !important;
}

.llamado-trabajos-modal.is-open .mod-abstract-modal__dialog {
    animation: chamadoModalScaleUp 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes chamadoModalFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes chamadoModalScaleUp {
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

/* Animations for Mobile sheet style */
@media (max-width: 479px) {
    .llamado-trabajos-modal .mod-abstract-modal__dialog {
        border-radius: 2rem 2rem 0 0 !important;
        transform: translateY(100%);
    }
    .llamado-trabajos-modal.is-open .mod-abstract-modal__dialog {
        animation: llamadoModalSheetUp 0.45s cubic-bezier(0.16, 1, 0.3, 1) forwards;
    }
}

@keyframes llamadoModalSheetUp {
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Close Button styling */
.llamado-trabajos-modal .mod-abstract-modal__close {
    top: 1.25rem;
    right: 1.25rem;
    background: #f1f5f9;
    color: var(--cp-text-light);
    border-radius: 50%;
    width: 2.25rem;
    height: 2.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    border: 1px solid rgba(0, 0, 0, 0.05);
}

.llamado-trabajos-modal .mod-abstract-modal__close:hover {
    background: #e2e8f0;
    color: var(--cp-text-dark);
    transform: rotate(90deg);
}

/* Category Badge in Modal */
.llamado-trabajos-modal__badge {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--cp-secondary-dark);
    background: var(--cp-secondary-light);
    padding: 0.25rem 0.75rem;
    border-radius: 9999px;
    margin-bottom: 0.75rem;
    width: fit-content;
}

.llamado-trabajos-modal .mod-abstract-modal__title {
    font-size: clamp(1.5rem, 4vw, 1.875rem) !important;
    font-weight: 850;
    letter-spacing: -0.02em;
    margin-bottom: 1.5rem;
    background: linear-gradient(135deg, var(--cp-text-dark) 30%, var(--cp-primary-dark) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Prose refinement */
.llamado-trabajos-modal .llamado-trabajos__p {
    font-size: clamp(0.975rem, 2.2vw, 1.05rem) !important;
    line-height: 1.8 !important;
    color: var(--cp-text) !important;
    margin-bottom: 1.25rem;
}

.llamado-trabajos-modal .llamado-trabajos__p:first-of-type {
    font-size: clamp(1.05rem, 2.4vw, 1.125rem) !important;
    font-weight: 550;
    color: var(--cp-primary-dark) !important;
    border-left: 4px solid var(--cp-primary);
    padding-left: 1.15rem;
    margin-bottom: 1.5rem;
}

.llamado-trabajos__prose--modal {
    border-top: none;
    padding-top: 0.5rem;
    margin-bottom: 0;
}

/* Language Badge in Modal */
.llamado-trabajos-modal .llamado-trabajos__idioma--modal {
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--cp-border);
    text-align: center;
}

.llamado-trabajos-modal .llamado-trabajos__idioma-badge {
    background: rgba(29, 78, 216, 0.08) !important;
    border-color: rgba(29, 78, 216, 0.18) !important;
    color: var(--cp-primary-dark) !important;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1.25rem;
    font-weight: 700;
}

/* Modal Actions and swapped button styles */
.llamado-trabajos-modal .mod-abstract-modal__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 2rem;
    border-top: 1px solid var(--cp-border);
    padding-top: 1.5rem;
    justify-content: center; /* Center the buttons */
}

.llamado-trabajos-modal .llamado-modal-btn-close {
    background: #f1f5f9 !important;
    color: var(--cp-text) !important;
    border: 1px solid #cbd5e1 !important;
    border-radius: 9999px !important;
    padding: 0.8rem 1.75rem !important;
    font-weight: 600 !important;
    box-shadow: none !important;
    transition: all 0.2s ease !important;
    flex: 0 1 auto !important; /* Do not stretch */
    min-width: 8rem;
}

.llamado-trabajos-modal .llamado-modal-btn-close:hover {
    background: #e2e8f0 !important;
    color: var(--cp-text-dark) !important;
    transform: translateY(-1px);
}

.llamado-trabajos-modal .llamado-modal-btn-ejes {
    background: linear-gradient(135deg, var(--cp-primary) 0%, #3b82f6 100%) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 9999px !important;
    padding: 0.8rem 1.75rem !important;
    font-weight: 700 !important;
    flex: 0 1 auto !important; /* Do not stretch */
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    box-shadow: 0 6px 15px -3px rgba(29, 78, 216, 0.3) !important;
    transition: all 0.25s ease !important;
    text-decoration: none !important;
    min-width: 12rem; /* Give it a compact elegant width */
}

.llamado-trabajos-modal .llamado-modal-btn-ejes:hover {
    background: linear-gradient(135deg, var(--cp-primary-dark) 0%, #2563eb 100%) !important;
    box-shadow: 0 10px 20px -3px rgba(29, 78, 216, 0.4) !important;
    transform: translateY(-2px);
}

.llamado-trabajos-modal .llamado-modal-btn-ejes:hover .llamado-trabajos__btn-ejes-icon {
    transform: translateX(4px);
}

@media (max-width: 479px) {
    .llamado-trabajos-modal .mod-abstract-modal__actions {
        flex-direction: column-reverse; /* Stack them nicely on mobile */
        align-items: stretch;
    }
    .llamado-trabajos-modal .llamado-modal-btn-close,
    .llamado-trabajos-modal .llamado-modal-btn-ejes {
        flex: 1 1 auto !important;
        width: 100%;
    }
}

@media (min-width: 480px) {
    .llamado-trabajos-modal .mod-abstract-modal__dialog {
        max-height: min(90vh, 46rem) !important;
    }
}

/* Página Envío de Trabajos */
.envio-modalidades {
    padding: 2.75rem 0 3rem;
    background-color: var(--cp-bg);
}

@media (min-width: 1024px) {
    .envio-modalidades {
        padding: 6rem 0;
    }
}

.envio-modalidades__intro {
    margin-bottom: 2rem;
}

@media (min-width: 640px) {
    .envio-modalidades__intro {
        margin-bottom: 3rem;
    }
}

@media (min-width: 1024px) {
    .envio-modalidades__intro {
        margin-bottom: 4rem;
    }
}

.envio-modalidades__grid {
    display: grid;
    gap: clamp(1.25rem, 3vw, 2rem);
    grid-template-columns: repeat(auto-fill, minmax(min(17rem, 100%), 1fr));
}

.envio-modalidad-card {
    padding: clamp(1.5rem, 5vw, 2.25rem);
    background: var(--cp-surface-light);
    border-radius: clamp(1rem, 2.8vw, 1.5rem);
    border: 1px solid var(--cp-border);
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
    .envio-modalidad-card:hover {
        transform: translateY(-5px);
        box-shadow: 0 16px 24px -8px rgba(0, 0, 0, 0.1);
        border-color: rgba(29, 78, 216, 0.35);
    }
}

.envio-modalidad-card__icon {
    color: var(--cp-primary);
    margin-bottom: 1.125rem;
    line-height: 0;
}

.envio-modalidad-card__title {
    font-family: var(--font-heading);
    font-size: clamp(1.1rem, 3vw, 1.25rem);
    font-weight: 700;
    color: var(--cp-surface-dark);
    margin-top: 0;
    margin-bottom: 0.65rem;
    line-height: 1.25;
    min-width: 0;
}

.envio-modalidad-card__text {
    margin: 0;
    color: var(--cp-text);
    font-size: 0.9375rem;
    line-height: 1.65;
    min-width: 0;
}

.envio-cronograma {
    padding: 2.75rem 0 3rem;
    background-color: var(--cp-surface);
}

@media (min-width: 1024px) {
    .envio-cronograma {
        padding: 6rem 0;
    }
}

.envio-cronograma__intro {
    margin-bottom: 2rem;
}

@media (min-width: 640px) {
    .envio-cronograma__intro {
        margin-bottom: 2.5rem;
    }
}

@media (min-width: 1024px) {
    .envio-cronograma__intro {
        margin-bottom: 4rem;
    }
}

.envio-deadlines {
    max-width: 48rem;
    margin: 0 auto;
    padding: 0;
    list-style: none;
    display: grid;
    gap: clamp(0.875rem, 3vw, 1.25rem);
}

.envio-deadline {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.4rem;
    padding: clamp(1rem, 4vw, 1.125rem) clamp(1rem, 4vw, 2rem);
    background: var(--cp-bg);
    border-radius: 1rem;
    border: 1px solid var(--cp-border);
    border-left-width: 4px;
    border-left-color: var(--cp-primary);
}

@media (min-width: 640px) {
    .envio-deadline {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
    }
}

.envio-deadline--destacado {
    border-left-color: #ef4444;
}

.envio-deadline__label {
    font-weight: 600;
    color: #1e3a8a;
    line-height: 1.35;
    font-size: clamp(0.9375rem, 2.4vw, 1rem);
}

.envio-deadline__fecha {
    font-weight: 700;
    color: var(--cp-text-light);
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}

@media (min-width: 640px) {
    .envio-deadline__fecha {
        margin-left: auto;
        text-align: right;
    }
}

.envio-deadline__fecha--destacado {
    color: #ef4444;
}

.envio-easychair {
    padding: 2.75rem 0 3rem;
    background-color: var(--cp-bg);
}

@media (min-width: 1024px) {
    .envio-easychair {
        padding: 6rem 0;
    }
}

.envio-easychair__shell {
    margin: 0 auto;
    max-width: 64rem;
    background-color: var(--cp-surface-dark);
    border-radius: clamp(1rem, 3vw, 2rem);
    padding: clamp(1.35rem, 6vw, 2.5rem);
    color: #fff;
    display: grid;
    gap: clamp(1.5rem, 5vw, 2.75rem);
    align-items: start;
}

@media (min-width: 1024px) {
    .envio-easychair__shell {
        grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
        gap: clamp(2rem, 4vw, 4rem);
        align-items: center;
        padding: clamp(3rem, 5vw, 4rem);
    }
}

.envio-easychair__title {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 4vw, 2.25rem);
    font-weight: 800;
    margin-top: 0;
    margin-bottom: 1rem;
    line-height: 1.2;
    color: #fcd34d;
}

.envio-easychair__lead {
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    opacity: 0.88;
    line-height: 1.65;
    margin-bottom: 1.35rem;
}

@media (min-width: 640px) {
    .envio-easychair__lead {
        margin-bottom: 1.75rem;
    }
}

.envio-easychair__main {
    min-width: 0;
}

.envio-easychair-steps {
    margin: 0 0 clamp(1.5rem, 4vw, 2.25rem);
    padding: 0;
    list-style: none;
}

.envio-easychair-step {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1rem;
    align-items: flex-start;
}

.envio-easychair-step:last-child {
    margin-bottom: 0;
}

@media (min-width: 640px) {
    .envio-easychair-step {
        gap: 1rem;
        margin-bottom: 1.35rem;
    }
}

.envio-easychair-step__num {
    flex-shrink: 0;
    width: 1.5rem;
    height: 1.5rem;
    border-radius: 50%;
    background: #fbbf24;
    color: var(--cp-surface-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 0.6875rem;
}

.envio-easychair-step__text {
    font-size: clamp(0.9375rem, 2vw, 1rem);
    line-height: 1.55;
    opacity: 0.92;
}

.envio-easychair-step__text strong {
    font-weight: 700;
}

.envio-step-link {
    color: #fcd34d;
    text-decoration: underline;
    text-underline-offset: 4px;
    font-weight: 700;
    transition: all 0.25s ease;
}

.envio-step-link:hover {
    color: #fbbf24;
    text-shadow: 0 0 8px rgba(251, 191, 36, 0.5);
}

.envio-easychair__btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: clamp(1rem, 3vw, 1.25rem);
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    font-weight: 700;
    box-sizing: border-box;
}

.envio-easychair-aside {
    align-self: stretch;
    margin: 0;
    padding: clamp(1.35rem, 5vw, 2rem);
    border-radius: clamp(1rem, 2.8vw, 2rem);
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.12);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.envio-easychair-aside__title {
    font-family: var(--font-heading);
    font-weight: 700;
    color: #fbbf24;
    margin-top: 0;
    margin-bottom: 0.75rem;
    font-size: clamp(1rem, 2.8vw, 1.0625rem);
}

.envio-easychair-aside__text {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.65;
    opacity: 0.78;
}

.envio-easychair-aside__support {
    margin-top: 1.5rem;
    padding-top: 1.35rem;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.envio-easychair-aside__support-label {
    font-size: 0.6875rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--cp-text-light);
    font-weight: 600;
    margin-bottom: 0.35rem;
}

.envio-easychair-aside__mail {
    color: inherit;
    font-weight: 700;
    text-decoration: none;
    overflow-wrap: anywhere;
}

.envio-easychair-aside__mail:hover {
    text-decoration: underline;
}

.btn-outline-primary {
    background: transparent;
    border: 2px solid var(--cp-primary);
    color: var(--cp-primary);
    text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease;
}

.btn-outline-primary:hover {
    background: var(--cp-primary);
    color: #fff;
}

/* Invitados especiales */
.comite-hero--invitados {
    background: linear-gradient(135deg, #0f172a 0%, #1e3a8a 100%);
}

.invitados-list {
    padding: 2.75rem 0 3rem;
    background-color: var(--cp-surface-light);
}

@media (min-width: 1024px) {
    .invitados-list {
        padding: 6rem 0;
    }
}

.invitados-list__inner {
    display: flex;
    flex-direction: column;
    gap: clamp(2.5rem, 6vw, 6rem);
}

.guest-stack {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    background: var(--cp-bg);
    border-radius: clamp(1.25rem, 3vw, 2rem);
    overflow: hidden;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.08);
    border: 1px solid var(--cp-border);
}

@media (min-width: 1024px) {
    .guest-stack {
        flex-direction: row;
        min-height: 0;
    }

    .guest-stack:nth-child(even) {
        flex-direction: row-reverse;
    }
}

.guest-stack:nth-child(odd) {
    --guest-accent: var(--cp-primary);
}

.guest-stack:nth-child(even) {
    --guest-accent: var(--cp-secondary);
}

.guest-stack__media {
    flex: 1 1 auto;
    min-height: min(52vw, 320px);
    max-height: 420px;
    position: relative;
    overflow: hidden;
}

@media (min-width: 1024px) {
    .guest-stack__media {
        min-height: 400px;
        max-height: none;
    }
}

.guest-stack__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
}

.guest-stack__body {
    flex: 1 1 auto;
    padding: clamp(1.5rem, 5vw, 3.5rem);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

@media (min-width: 1024px) {
    .guest-stack__body {
        flex: 1 1 55%;
        min-width: 0;
        padding: clamp(2rem, 4vw, 4rem);
    }
}

.guest-stack__header {
    margin-bottom: 1.25rem;
}

.guest-stack__name {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 4.5vw, 2.25rem);
    font-weight: 800;
    color: var(--cp-surface-dark);
    margin: 0 0 0.35rem;
    line-height: 1.15;
}

.guest-stack__affiliation {
    font-size: clamp(0.8125rem, 2vw, 1.125rem);
    color: var(--guest-accent);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin: 0;
    line-height: 1.35;
}

.guest-stack__rule {
    width: 3rem;
    height: 3px;
    background: var(--guest-accent);
    margin-top: 1rem;
}

.guest-stack__bio {
    font-size: clamp(1rem, 2.5vw, 1.0625rem);
    line-height: 1.75;
    color: var(--cp-text);
    min-width: 0;
}

.guest-stack__bio p {
    margin: 0 0 1rem;
}

.guest-stack__bio p:last-child {
    margin-bottom: 0;
}

/* Locación del congreso */
.locacion-block {
    padding: 2.75rem 0 3rem;
}

@media (min-width: 1024px) {
    .locacion-block {
        padding: 5rem 0;
    }
}

.locacion-block--surface {
    background-color: var(--cp-surface-light);
}

.locacion-block--white {
    background-color: var(--cp-bg);
}

.locacion-main-grid {
    display: grid;
    gap: clamp(1.75rem, 5vw, 4rem);
    align-items: start;
}

@media (min-width: 1024px) {
    .locacion-main-grid {
        grid-template-columns: minmax(0, 1fr) minmax(260px, 1fr);
        align-items: start;
    }
}

.locacion-icon-ring {
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 1rem;
    background: rgba(30, 58, 138, 0.1);
    color: var(--cp-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
}

.locacion-heading {
    font-family: var(--font-heading);
    font-size: clamp(1.5rem, 4vw, 2.25rem);
    font-weight: 800;
    color: var(--cp-text-dark);
    margin: 0 0 1rem;
    line-height: 1.2;
}

.locacion-heading--center {
    text-align: center;
}

.locacion-heading--transport {
    text-align: center;
    margin-bottom: 2rem;
}

@media (min-width: 1024px) {
    .locacion-heading--transport {
        margin-bottom: 3rem;
    }
}

.locacion-lead {
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    color: var(--cp-text-light);
    line-height: 1.6;
    margin: 0 0 1.5rem;
}

.locacion-address-card {
    background: var(--cp-bg);
    padding: clamp(1.25rem, 4vw, 2rem);
    border-radius: 1.25rem;
    border: 1px solid var(--cp-border);
    margin-bottom: 1.5rem;
}

.locacion-address-card__title {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--cp-text-dark);
    margin: 0 0 0.75rem;
}

.locacion-address-card__text {
    margin: 0;
    font-size: 1rem;
    color: var(--cp-text);
    line-height: 1.55;
}

.locacion-nav-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1rem;
}

.locacion-nav-btn {
    padding: clamp(0.85rem, 2.5vw, 1rem) clamp(1.25rem, 4vw, 2rem);
    font-weight: 700;
    border-radius: 9999px;
}

.locacion-map-frame {
    border-radius: clamp(1rem, 3vw, 2rem);
    overflow: hidden;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.08);
    border: 1px solid var(--cp-border);
    line-height: 0;
    min-height: 0;
}

.locacion-map-frame__iframe {
    width: 100%;
    border: 0;
    height: clamp(260px, 55vw, 450px);
    display: block;
}

.locacion-intro-center {
    text-align: center;
    max-width: 48rem;
    margin: 0 auto clamp(2rem, 5vw, 4rem);
}

.locacion-sub {
    margin: 0;
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    color: var(--cp-text-light);
    line-height: 1.55;
}

.locacion-map-official-wrap {
    max-width: 50rem;
    margin: 0 auto;
}

.locacion-map-official-inner {
    background: var(--cp-surface);
    padding: clamp(0.75rem, 3vw, 1rem);
    border-radius: clamp(1rem, 3vw, 2rem);
    border: 1px solid var(--cp-border);
}

.locacion-map-official-img {
    width: 100%;
    height: auto;
    border-radius: clamp(1rem, 3vw, 1.5rem);
    cursor: pointer;
    transition: opacity 0.25s ease;
    display: block;
}

@media (hover: hover) {
    .locacion-map-official-img:hover {
        opacity: 0.92;
    }
}

.locacion-map-official-caption {
    margin: 1.25rem 0 0;
    text-align: center;
    font-size: 0.875rem;
    font-style: italic;
    color: #94a3b8;
}

.locacion-transport-grid {
    display: grid;
    gap: clamp(1.25rem, 4vw, 2rem);
    grid-template-columns: repeat(auto-fill, minmax(min(17.5rem, 100%), 1fr));
}

.locacion-transport-card {
    background: var(--cp-bg);
    border-radius: 1.5rem;
    padding: clamp(1.5rem, 4vw, 2.25rem);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.04);
    border: 1px solid var(--cp-border);
    height: 100%;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
    .locacion-transport-card:hover {
        transform: translateY(-5px);
        box-shadow: 0 16px 24px -8px rgba(0, 0, 0, 0.1);
    }
}

.locacion-transport-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.45rem 0.95rem;
    background: var(--cp-surface);
    border-radius: 9999px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--cp-text);
    margin-bottom: 0.85rem;
}

.locacion-transport-card__title {
    font-family: var(--font-heading);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--cp-text-dark);
    margin: 0 0 0.65rem;
}

.locacion-transport-card__text {
    margin: 0;
    color: var(--cp-text-light);
    line-height: 1.6;
}

.locacion-extra-cta {
    text-align: center;
}

.locacion-extra-inner {
    background: linear-gradient(135deg, var(--cp-primary) 0%, #172554 100%);
    padding: clamp(2rem, 8vw, 4rem);
    border-radius: clamp(1.5rem, 5vw, 3rem);
    color: #fff;
}

.locacion-extra-title {
    font-family: var(--font-heading);
    font-size: clamp(1.375rem, 4vw, 2rem);
    font-weight: 800;
    margin: 0 0 1rem;
}

.locacion-extra-text {
    font-size: clamp(1rem, 2.5vw, 1.125rem);
    opacity: 0.92;
    max-width: 36rem;
    margin: 0 auto 1.75rem;
    font-weight: 300;
    line-height: 1.6;
}

.locacion-extra-btns {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.75rem 1.25rem;
}

.locacion-extra-btn {
    padding: 1rem 1.75rem;
    border-radius: 9999px;
    font-weight: 700;
}

.locacion-extra-btn-outline.btn-outline {
    border-color: rgba(255, 255, 255, 0.5);
}

.locacion-extra-btn-outline.btn-outline:hover {
    background: #fff;
    color: var(--cp-text-dark);
}

/* Conoce el Maule */
.maule-hero {
    position: relative;
    background: linear-gradient(rgba(15, 23, 42, 0.62), rgba(15, 23, 42, 0.68)), var(--maule-hero-url) center/cover no-repeat;
    color: #fff;
    text-align: center;
    padding: clamp(5rem, 18vw, 12rem) 0;
}

.maule-hero__inner {
    position: relative;
    z-index: 1;
}

.maule-hero__title {
    font-family: var(--font-heading);
    font-size: clamp(2.25rem, 8vw, 5rem);
    font-weight: 900;
    margin: 0 0 1rem;
    color: #fff;
    text-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    line-height: 1.1;
}

.maule-hero__lead {
    font-size: clamp(1.05rem, 3vw, 1.5rem);
    opacity: 0.95;
    max-width: 42rem;
    margin: 0 auto;
    font-weight: 300;
    line-height: 1.55;
}

.maule-links-strip {
    background-color: var(--cp-surface);
    padding: 1.25rem 0;
    border-bottom: 1px solid var(--cp-border);
}

.maule-links-strip__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
    text-align: center;
}

@media (min-width: 768px) {
    .maule-links-strip__inner {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        text-align: left;
    }

    .maule-links-strip__label {
        margin-right: 0.5rem;
    }
}

.maule-links-strip__label {
    font-weight: 700;
    color: var(--cp-text-light);
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.1em;
}

.maule-links-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.65rem;
}

.maule-link-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    background: var(--cp-bg);
    padding: 0.65rem 1.125rem;
    border-radius: 9999px;
    border: 1px solid var(--cp-border);
    text-decoration: none;
    color: var(--cp-text-dark);
    font-weight: 600;
    font-size: 0.8125rem;
    transition: border-color 0.2s ease, color 0.2s ease;
}

@media (hover: hover) {
    .maule-link-pill:hover {
        border-color: var(--cp-primary);
        color: var(--cp-primary);
    }
}

.maule-link-pill__icon--red {
    color: #ef4444;
}

.maule-link-pill__icon--blue {
    color: #2563eb;
}

.maule-link-pill__icon--green {
    color: #22c55e;
}

.maule-intro {
    padding: clamp(2.75rem, 8vw, 6rem) 0;
    background-color: var(--cp-bg);
    border-bottom: 1px solid var(--cp-surface);
}

.maule-intro__inner {
    max-width: 52rem;
    margin: 0 auto;
    text-align: center;
}

.maule-intro__text {
    font-size: clamp(1.05rem, 2.8vw, 1.25rem);
    line-height: 1.75;
    color: var(--cp-text);
    margin: 0;
}

.maule-section {
    padding: clamp(3rem, 10vw, 8rem) 0;
    overflow: hidden;
}

.maule-section--muted {
    background-color: var(--cp-surface-light);
}

.maule-split {
    display: grid;
    gap: clamp(2rem, 6vw, 4rem);
    align-items: center;
    grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 992px) {
    .maule-split {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: clamp(3rem, 8vw, 6rem);
    }
}

.maule-split__col--text {
    min-width: 0;
}

.maule-split__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 5vw, 2.75rem);
    font-weight: 800;
    color: var(--cp-text-dark);
    margin: 0 0 1rem;
    line-height: 1.15;
}

.maule-kicker {
    display: inline-block;
    padding: 0.45rem 1.1rem;
    background: rgba(30, 58, 138, 0.1);
    color: var(--cp-primary);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 0.75rem;
    border-radius: 9999px;
    margin-bottom: 1rem;
}

.maule-kicker--dark {
    background: rgba(30, 58, 138, 0.12);
}

.maule-split__p {
    font-size: clamp(1rem, 2.4vw, 1.125rem);
    color: var(--cp-text-light);
    line-height: 1.7;
    margin: 0 0 1rem;
}

.maule-split__p:last-of-type {
    margin-bottom: 0;
}

.maule-checklist {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.85rem;
}

.maule-checklist li {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    font-weight: 600;
    color: var(--cp-text-dark);
    font-size: 0.975rem;
    line-height: 1.4;
}

.maule-checklist li::before {
    content: '✓';
    flex-shrink: 0;
    color: var(--cp-primary);
    font-weight: 800;
}

.maule-media {
    border-radius: clamp(1.5rem, 4vw, 2.5rem);
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.14);
}

.maule-media img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.55s ease;
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
    .maule-media:hover img {
        transform: scale(1.04);
    }
}

.maule-callout-box {
    background: var(--cp-bg);
    padding: clamp(1.35rem, 4vw, 2rem);
    border-radius: 1.35rem;
    border: 1px solid var(--cp-border);
    margin-top: 1.25rem;
}

.maule-callout-box__title {
    font-weight: 700;
    margin: 0 0 0.35rem;
    color: var(--cp-text-dark);
    font-size: 1rem;
}

.maule-callout-box__p {
    margin: 0;
    color: var(--cp-text-light);
    line-height: 1.6;
}

.maule-itinerary {
    padding: clamp(3.5rem, 10vw, 8rem) 0;
    background-color: var(--cp-surface-dark);
    color: #fff;
}

.maule-itinerary__intro {
    text-align: center;
    max-width: 48rem;
    margin: 0 auto clamp(2.25rem, 6vw, 5rem);
}

.maule-itinerary__title {
    font-family: var(--font-heading);
    font-size: clamp(1.875rem, 6vw, 3rem);
    font-weight: 800;
    margin: 0 0 1rem;
}

.maule-itinerary__lead {
    font-size: clamp(1rem, 2.5vw, 1.25rem);
    opacity: 0.85;
    margin: 0;
    font-weight: 300;
    line-height: 1.5;
}

.maule-itinerary-grid {
    display: grid;
    gap: clamp(1.25rem, 3vw, 2rem);
    grid-template-columns: repeat(auto-fill, minmax(min(17.5rem, 100%), 1fr));
}

.maule-it-card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    padding: clamp(1.35rem, 4vw, 2.25rem);
    border-radius: 1.65rem;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: inherit;
    transition: border-color 0.25s ease, transform 0.25s ease;
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
    .maule-it-card:hover {
        border-color: rgba(96, 165, 250, 0.6);
        transform: translateY(-4px);
    }
}

.maule-it-card__badge {
    color: var(--cp-primary-light);
    font-weight: 800;
    font-size: 0.8125rem;
    margin-bottom: 0.75rem;
}

.maule-it-card__title {
    font-family: var(--font-heading);
    font-size: clamp(1.15rem, 3vw, 1.55rem);
    font-weight: 700;
    margin: 0 0 0.85rem;
    color: #fff;
    line-height: 1.2;
}

.maule-it-card__desc {
    margin: 0 0 1.5rem;
    opacity: 0.78;
    font-size: 0.9625rem;
    line-height: 1.55;
    flex: 1 1 auto;
}

.maule-it-card__cta {
    margin-top: auto;
    font-weight: 700;
    color: var(--cp-primary-light);
}

.maule-rari {
    padding: clamp(3rem, 10vw, 8rem) 0;
    background: var(--cp-bg);
    text-align: center;
}

.maule-rari__inner {
    max-width: 50rem;
    margin: 0 auto;
}

.maule-rari__title {
    font-family: var(--font-heading);
    font-size: clamp(1.875rem, 6vw, 3rem);
    font-weight: 800;
    color: var(--cp-text-dark);
    margin-bottom: 1.25rem;
}

.maule-rari__text {
    font-size: clamp(1.05rem, 2.6vw, 1.25rem);
    color: var(--cp-text-light);
    line-height: 1.75;
    margin: 0 auto 2rem;
}

.maule-rari__btns {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.85rem;
}

.maule-rari-btn {
    padding: 1rem 2rem;
    border-radius: 9999px;
    font-weight: 700;
}

/* Programa */
.programa-hero .programa-hero__action {
    margin-top: clamp(1.5rem, 4vw, 2.5rem);
}

.programa-pdf-btn {
    padding: clamp(0.9rem, 3vw, 1.1rem) clamp(1.5rem, 5vw, 2.75rem);
    border-radius: 9999px;
    font-weight: 700;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.2);
}

.programa-body {
    padding: clamp(2rem, 6vw, 4rem) 0 clamp(3rem, 8vw, 5rem);
    background-color: var(--cp-bg);
}

.programa-inner {
    max-width: 64rem;
    margin: 0 auto;
}

.programa-tabs-scroll {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    gap: 0;
    border-bottom: 2px solid var(--cp-surface);
    margin-bottom: clamp(1.5rem, 4vw, 3rem);
    margin-left: -1rem;
    margin-right: -1rem;
    padding-bottom: 2px;
    padding-left: 1rem;
    padding-right: 1rem;
}

@media (min-width: 640px) {
    .programa-tabs-scroll {
        margin-left: -1.5rem;
        margin-right: -1.5rem;
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

@media (min-width: 1024px) {
    .programa-tabs-scroll {
        margin-left: 0;
        margin-right: 0;
        padding-left: 0;
        padding-right: 0;
    }
}

.programa-panel {
    background: var(--cp-bg);
    border-radius: clamp(1rem, 3vw, 2rem);
    border: 1px solid var(--cp-border);
    overflow: hidden;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.05);
}

.program-tab-btn {
    flex: 1 1 0;
    min-width: 10.5rem;
    padding: 1rem 0.85rem;
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
    color: var(--cp-text-light);
    font-weight: 700;
    font-size: clamp(0.875rem, 2.8vw, 1.0625rem);
    cursor: pointer;
    transition: color 0.2s ease, border-color 0.2s ease, background 0.2s ease;
    white-space: nowrap;
    font-family: var(--font-body);
}

.program-tab-btn.active {
    color: var(--cp-primary);
    border-bottom-color: var(--cp-primary);
    background: rgba(30, 58, 138, 0.04);
}

@media (max-width: 380px) {
    .program-tab-btn {
        min-width: 8.75rem;
        padding: 0.85rem 0.65rem;
    }
}

.program-day-content {
    display: none;
    animation: fadeIn 0.4s ease-out forwards;
}

.program-day-content.active {
    display: block;
}

.schedule-item {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: clamp(1.25rem, 4vw, 1.85rem);
    border-bottom: 1px solid var(--cp-surface);
    transition: background 0.2s ease;
}

@media (min-width: 769px) {
    .schedule-item {
        flex-direction: row;
        gap: clamp(1.25rem, 4vw, 2.5rem);
        padding: 2rem clamp(1.5rem, 4vw, 2.75rem);
    }
}

.schedule-item:last-child {
    border-bottom: none;
}

@media (hover: hover) {
    .schedule-item:hover {
        background: #fdfdfd;
    }
}

.schedule-item.keynote {
    background: linear-gradient(to right, var(--cp-surface-light), var(--cp-bg));
    border-left: 4px solid var(--cp-primary);
}

.schedule-item.break {
    background-color: #fafafa;
    opacity: 0.9;
}

.schedule-item__time {
    flex-shrink: 0;
    font-weight: 800;
    color: var(--cp-primary);
    font-size: clamp(1rem, 2.5vw, 1.0625rem);
    font-variant-numeric: tabular-nums;
    line-height: 1.3;
}

@media (min-width: 769px) {
    .schedule-item__time {
        width: 8.75rem;
    }
}

.schedule-item__info {
    flex: 1;
    min-width: 0;
}

.schedule-item__icon {
    width: 2.5rem;
    height: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--cp-surface);
    border-radius: 0.75rem;
    margin-bottom: 0.65rem;
    color: #94a3b8;
}

.keynote .schedule-item__icon {
    background: #fffbeb;
    color: #f59e0b;
}

.schedule-item__title {
    font-family: var(--font-heading);
    font-size: clamp(1.05rem, 2.8vw, 1.25rem);
    font-weight: 700;
    color: var(--cp-text-dark);
    margin: 0 0 0.35rem;
    line-height: 1.35;
}

.schedule-item__subtitle {
    margin: 0;
    color: var(--cp-primary);
    font-weight: 700;
    font-size: clamp(0.9375rem, 2.2vw, 1rem);
}

.programa-footnote {
    padding: 0 0 clamp(3rem, 8vw, 6rem);
    background-color: var(--cp-bg);
    text-align: center;
}

.programa-footnote__text {
    margin: 0;
    font-size: 0.875rem;
    font-style: italic;
    color: var(--cp-text-light);
}

/* Contacto */
.contacto-hero {
    position: relative;
    background: linear-gradient(135deg, var(--cp-primary) 0%, #172554 100%);
    padding: clamp(4rem, 14vw, 8rem) 0;
    color: #fff;
    text-align: center;
    overflow: hidden;
}

.contacto-hero__pattern {
    position: absolute;
    inset: 0;
    opacity: 0.1;
    background-image: radial-gradient(#fff 1px, transparent 1px);
    background-size: 30px 30px;
}

.contacto-hero .comite-hero__inner {
    position: relative;
    z-index: 1;
}

.contacto-hero__title {
    font-family: var(--font-heading);
    font-size: clamp(2.25rem, 7vw, 5rem);
    font-weight: 900;
    margin: 0 0 clamp(1rem, 3vw, 1.25rem);
    color: #fff;
    letter-spacing: -0.02em;
    line-height: 1.1;
}

.contacto-hero__lead {
    font-size: clamp(1rem, 2.6vw, 1.25rem);
    opacity: 0.92;
    max-width: 36rem;
    margin-inline: auto;
    font-weight: 300;
    line-height: 1.55;
}

.contacto-main {
    padding: clamp(2.75rem, 8vw, 8rem) 0 clamp(3rem, 8vw, 6rem);
    background-color: var(--cp-surface-light);
}

.contacto-grid {
    display: grid;
    gap: clamp(2rem, 6vw, 5rem);
    grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 1024px) {
    .contacto-grid {
        grid-template-columns: minmax(0, 1fr) minmax(260px, 420px);
    }
}

.contacto-info__title {
    font-family: var(--font-heading);
    font-size: clamp(1.625rem, 5vw, 2.5rem);
    font-weight: 800;
    color: var(--cp-surface-dark);
    margin: 0 0 clamp(1.5rem, 4vw, 2rem);
}

.contacto-info-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: clamp(1.75rem, 5vw, 2.5rem);
}

.contacto-info-item {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
}

.contacto-info-item__icon {
    width: 3.25rem;
    height: 3.25rem;
    border-radius: 1.15rem;
    background: var(--cp-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--cp-primary);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.05);
    flex-shrink: 0;
    border: 1px solid var(--cp-surface);
}

.contacto-info-item__label {
    font-family: var(--font-heading);
    margin: 0 0 0.35rem;
    font-weight: 700;
    color: var(--cp-text-dark);
    font-size: 1.05rem;
}

.contacto-info-item__text {
    margin: 0;
    color: var(--cp-text-light);
    line-height: 1.6;
    font-size: 0.9875rem;
}

.contacto-aside-tip {
    margin-top: clamp(2rem, 6vw, 4rem);
    padding: clamp(1.5rem, 4vw, 2.75rem);
    border-radius: 1.85rem;
    background: linear-gradient(135deg, #1e293b 0%, var(--cp-surface-dark) 100%);
    color: #fff;
}

.contacto-aside-tip__title {
    margin: 0 0 0.65rem;
    font-family: var(--font-heading);
    font-size: 1.05rem;
    font-weight: 700;
}

.contacto-aside-tip__text {
    margin: 0;
    font-size: 0.9325rem;
    line-height: 1.6;
    opacity: 0.88;
}

.contact-form-container {
    background: var(--cp-bg);
    padding: clamp(1.5rem, 6vw, 3.75rem);
    border-radius: clamp(1.5rem, 4vw, 2.75rem);
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.08);
    border: 1px solid var(--cp-surface);
}

.contacto-hp {
    display: none;
}

.contacto-grid .form-group {
    margin-bottom: 1.5rem;
}

.contacto-grid .form-group:last-of-type {
    margin-bottom: 0;
}

.contacto-grid .form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 600;
    color: var(--cp-text-dark);
    font-size: 0.925rem;
}

.contacto-grid .form-control {
    width: 100%;
    padding: 0.9rem 1.1rem;
    border: 1px solid var(--cp-border);
    border-radius: 1rem;
    transition: border-color 0.2s, background 0.2s;
    font-size: 1rem;
    background-color: var(--cp-surface-light);
}

.contacto-grid .form-control:focus {
    outline: none;
    border-color: var(--cp-primary);
    background-color: var(--cp-bg);
    box-shadow: 0 0 0 4px rgba(30, 58, 138, 0.05);
}

.contacto-form-row {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 1fr);
}

@media (min-width: 640px) {
    .contacto-form-row {
        grid-template-columns: repeat(auto-fit, minmax(min(12rem, 100%), 1fr));
        gap: 1.35rem;
    }
}

.contacto-grid .error-msg {
    display: none;
    color: #dc2626;
    font-size: 0.875rem;
    margin-top: 0.45rem;
}

.contacto-grid .error-msg.is-visible {
    display: block;
}

.contacto-grid .submit-btn {
    margin-top: 0.75rem;
    background-color: var(--cp-primary);
    color: white;
    padding: 1rem 2rem;
    border: none;
    border-radius: 1rem;
    font-weight: 700;
    cursor: pointer;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    transition: opacity 0.25s ease, transform 0.25s ease;
    font-size: clamp(1rem, 2.5vw, 1.125rem);
}

@media (hover: hover) {
    .contacto-grid .submit-btn:hover:not(:disabled) {
        opacity: 0.92;
        transform: translateY(-2px);
    }
}

.contacto-grid .submit-btn:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

.contacto-grid .spinner {
    width: 22px;
    height: 22px;
    border: 3px solid rgba(255, 255, 255, 0.35);
    border-radius: 50%;
    border-top-color: #fff;
    animation: spin 1s linear infinite;
    display: none;
}

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

#contact-response {
    margin-top: 2rem;
    padding: 1.25rem;
    border-radius: 1rem;
    display: none;
    font-weight: 500;
    line-height: 1.55;
}

#contact-response.success {
    background-color: #ecfdf5;
    color: #065f46;
    border: 1px solid #a7f3d0;
    display: block;
}

#contact-response.error {
    background-color: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
    display: block;
}

.contacto-reset-btn {
    padding: 0.85rem 2rem;
    border-radius: 9999px;
    font-weight: 700;
    border: 2px solid #059669;
    color: #059669;
    background: var(--cp-bg);
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
}

.contacto-reset-btn:hover {
    background: #059669;
    color: #fff;
}

.contacto-loc-banner {
    padding-bottom: clamp(3rem, 10vw, 8rem);
    background-color: var(--cp-surface-light);
}

.contacto-loc-inner {
    background-color: var(--cp-bg);
    padding: clamp(1.5rem, 5vw, 2.25rem);
    border-radius: clamp(1.25rem, 3vw, 2rem);
    border: 1px solid var(--cp-surface);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
}

@media (min-width: 640px) {
    .contacto-loc-inner {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
}

.contacto-loc-inner__title {
    margin: 0 0 0.25rem;
    font-family: var(--font-heading);
    font-weight: 700;
    color: var(--cp-text-dark);
}

.contacto-loc-inner__text {
    margin: 0;
    color: var(--cp-text-light);
    font-size: 0.9375rem;
}

.contacto-loc-btn {
    padding: 0.85rem 1.75rem;
    border-radius: 9999px;
    flex-shrink: 0;
}
