/* ============================================
       VARIABLES CSS - Sistema FADU 2026
       Sincronizado con index.html
       ============================================ */
    :root {
        /* ═══ Azules UBA - Paleta oficial ═══ */
        --azul-uba: #1d2554;           /* PANTONE 288 C */
        --azul-hover: #2e3a6e;
        --azul-claro: #3d4a7a;
        --azul-profundo: #141a3a;
        
        /* ═══ Celestes UBA - Paleta oficial ═══ */
        --celeste-uba: #91bde1;        /* PANTONE 278 C */
        --celeste-medio: #91bde1;
        --celeste-claro: #bdd7ed;      /* PANTONE 278 C 60% */
        --celeste-muy-claro: #e8f4f8;
        
        /* ═══ Dorados - Acento ═══ */
        --dorado-oscuro: #8b6914;
        --dorado: #a67c00;
        --dorado-medio: #c9a227;
        --dorado-claro: #d4af37;
        --dorado-suave: #e8d08a;
        --dorado-bg: #fdf8e8;
        
        /* ═══ Morado FADU - Paleta oficial ═══ */
        --morado-fadu: #6861ac;        /* PANTONE 272 C */
        --morado-claro: #9d95d4;
        --morado-muy-claro: #e8e6f5;
        
        /* ═══ Colores por Área Temática - Paleta oficial ═══ */
        --color-sustentabilidad: #6bbf3a;      /* PANTONE 3252 C - Verde agua */
        --color-sustentabilidad-bg: #e6f7e0;
        
        --color-patrimonio: #952B6C;           /* PANTONE 253 C - Magenta */
        --color-patrimonio-bg: #f5e8f0;
        
        --color-urbanismo: #00b8db;            /* PANTONE 306 C - Cyan */
        --color-urbanismo-bg: #e0f7fb;
        
        --color-diseno: #6861ac;               /* PANTONE 272 C - Morado FADU */
        --color-diseno-bg: #e8e6f5;
        
        --color-proyecto: #ff7621;             /* PANTONE 151 C - Naranja */
        --color-proyecto-bg: #fff3e8;
        
        --color-gestion: #2eb39a;              /* PANTONE 3252 C - Verde agua */
        --color-gestion-bg: #e0f7f1;
        
        /* ═══ Estados ═══ */
        --verde-inscripcion: #3d7d00;
        --verde-inscripcion-hover: #2d6a00;
        --verde-inscripcion-bg: #f0f8e6;
        --naranja-proximo: #ff7621;
        
        /* ═══ Neutrales ═══ */
        --blanco: #ffffff;
        --gris-50: #fafafa;
        --gris-100: #f5f5f5;
        --gris-200: #eeeeee;
        --gris-300: #e0e0e0;
        --gris-400: #bdbdbd;
        --gris-500: #9e9e9e;
        --gris-600: #757575;
        --gris-700: #616161;
        --gris-800: #424242;
        --gris-900: #212121;
        
        /* ═══ Texto ═══ */
        --texto-principal: #1a1a1a;
        --texto-primario: #1a1a1a;
        --texto-secundario: #4a4a4a;
        --texto-terciario: #6b7280;
        
        /* ═══ Tipografía ═══ */
        --font-primary: 'Bitter', Georgia, 'Times New Roman', serif;
        --font-size-xs: 0.75rem;
        --font-size-sm: 0.875rem;
        --font-size-base: 1rem;
        --font-size-lg: 1.125rem;
        --font-size-xl: 1.25rem;
        --font-size-2xl: 1.5rem;
        --font-size-3xl: 1.875rem;
        --font-size-4xl: 2.25rem;
        --font-size-5xl: 3rem;
        
        /* ═══ Espaciado ═══ */
        --space-1: 0.25rem;
        --space-2: 0.5rem;
        --space-3: 0.75rem;
        --space-4: 1rem;
        --space-5: 1.25rem;
        --space-6: 1.5rem;
        --space-8: 2rem;
        --space-10: 2.5rem;
        --space-12: 3rem;
        --space-16: 4rem;
        --space-20: 5rem;
        
        /* ═══ Sombras ═══ */
        --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
        --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
        --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
        --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
        
        /* ═══ Bordes ═══ */
        --radius-sm: 2px;
        --radius-md: 4px;
        --radius-lg: 8px;
        --radius-xl: 16px;
        --radius-full: 9999px;
        
        /* ═══ Transiciones ═══ */
        --transition-fast: 150ms ease;
        --transition-base: 250ms ease;
        --transition-slow: 350ms ease;
        
        /* ═══ Z-index ═══ */
        --z-dropdown: 10001;
        --z-sticky: 200;
        --z-fixed: 300;
        --z-modal: 400;
    }

    /* ============================================
       SISTEMA DE COLORES POR ÁREA TEMÁTICA
       Activado por data-area en <html>
       ============================================ */

    :root {
        /* Fallback si no hay data-area */
        --color-area: var(--azul-uba);
        --color-area-dark: var(--azul-profundo);
        --color-area-bg: var(--celeste-muy-claro);
        --color-area-radial: rgba(29, 37, 84, 0.15);
        --color-area-light: #91bde1;
        --color-area-lighter: #bdd7ed;
        --color-area-rgb: 29, 37, 84;
    }

    [data-area="urbanismo"] {
        --color-area: #00b8db;
        --color-area-dark: #0d4f5a;
        --color-area-bg: #e0f7fb;
        --color-area-radial: rgba(0, 184, 219, 0.15);
        --color-area-light: #7dd8e8;
        --color-area-lighter: #a8e4ef;
        --color-area-rgb: 0, 184, 219;
    }
    [data-area="diseno"] {
        --color-area: #6861ac;
        --color-area-dark: #4a4080;
        --color-area-bg: #e8e6f5;
        --color-area-radial: rgba(104, 97, 172, 0.15);
        --color-area-light: #9d95d4;
        --color-area-lighter: #c5c0e8;
        --color-area-rgb: 104, 97, 172;
    }
    [data-area="gestion"] {
        --color-area: #2eb39a;
        --color-area-dark: #1a6b5a;
        --color-area-bg: #e0f7f1;
        --color-area-radial: rgba(46, 179, 154, 0.15);
        --color-area-light: #9ed9cc;
        --color-area-lighter: #c8ebe4;
        --color-area-rgb: 46, 179, 154;
    }
    [data-area="patrimonio"] {
        --color-area: #952B6C;
        --color-area-dark: #6b1e4d;
        --color-area-bg: #f5e8f0;
        --color-area-radial: rgba(149, 43, 108, 0.15);
        --color-area-light: #c46da0;
        --color-area-lighter: #dfa8c8;
        --color-area-rgb: 149, 43, 108;
    }
    [data-area="proyecto"] {
        --color-area: #ff7621;
        --color-area-dark: #a34d15;
        --color-area-bg: #fff3e8;
        --color-area-radial: rgba(255, 118, 33, 0.15);
        --color-area-light: #ffaa6e;
        --color-area-lighter: #ffc9a0;
        --color-area-rgb: 255, 118, 33;
    }
    [data-area="sustentabilidad"] {
        --color-area: #6bbf3a;
        --color-area-dark: #3a6b1a;
        --color-area-bg: #e6f7e0;
        --color-area-radial: rgba(107, 191, 58, 0.15);
        --color-area-light: #a3d97d;
        --color-area-lighter: #c5e8aa;
        --color-area-rgb: 107, 191, 58;
    }


    
    /* ============================================
       RESET & BASE
       ============================================ */
    *, *::before, *::after {
        box-sizing: border-box;
        margin: 0;
        padding: 0;
    }
    
    html {
        scroll-behavior: smooth;
    }
    
    body {
        font-family: var(--font-primary);
        font-weight: 400;
        font-size: var(--font-size-base);
        line-height: 1.7;
        color: var(--texto-principal);
        background: var(--blanco);
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }
    
    img {
        max-width: 100%;
        height: auto;
        display: block;
    }
    
    a {
        color: var(--azul-uba);
        text-decoration: none;
        transition: color var(--transition-base);
    }
    
    a:hover {
        color: var(--dorado);
    }
    
    /* ============================================
       ACCESIBILIDAD
       ============================================ */
    .skip-link {
        position: absolute;
        top: -100px;
        left: 50%;
        transform: translateX(-50%);
        background: var(--azul-uba);
        color: var(--blanco);
        padding: var(--space-3) var(--space-6);
        border-radius: var(--radius-sm);
        z-index: 10000;
        font-weight: 700;
    }
    
    .skip-link:focus {
        top: var(--space-4);
        color: var(--blanco);
    }
    
    .sr-only {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
    }
    
    /* ============================================
       CONTAINER
       ============================================ */
    .container {
        width: 100%;
        max-width: 1200px;
        margin: 0 auto;
        padding: 0 40px;
    }
.badge-suspendida {
        background: linear-gradient(135deg, #d32f2f 0%, #f44336 100%);
        color: #ffffff;
    }
@media (max-width: 768px) {
        .container {
            padding: 0 20px;
        }
    }
    
    /* ============================================
       HEADER - Sistema principal
       ============================================ */
    .header {
        position: sticky;
        top: 0;
        z-index: 1100; /* Mayor que breadcrumb */
        background: var(--azul-uba);
        padding: 12px 0;
        box-shadow: var(--shadow-md);
    }
    
    .header-content {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    
    .header-logo {
        display: flex;
        align-items: center;
        gap: 12px;
        color: var(--blanco);
    }

    .header-logo a {
        text-decoration: none;
        color: inherit;
        display: flex;
        align-items: center;
        gap: 6px;
    }

    .header-logo-link-fadu {
        border-right: 1px solid rgba(255,255,255,0.3);
        padding-right: 12px;
    }
    
    .header-logo-uba {
        font-size: 1.5rem;
        font-weight: 300;
    }
    
    .header-logo-fadu {
        font-size: 1.5rem;
        font-weight: 600;
        color: var(--celeste-medio);
    }
    
    .header-logo-text {
        font-size: 0.75rem;
        opacity: 0.9;
        border-left: 1px solid rgba(255,255,255,0.3);
        padding-left: 12px;
        line-height: 1.3;
    }
    
    .header-nav {
        display: flex;
        align-items: center;
        gap: 24px;
    }
    
    .header-nav a {
        color: #ffffff;
        font-size: 0.9rem;
        font-weight: 500;
        opacity: 0.85;
        position: relative;
        padding: 0.5rem 0;
        transition: all 0.3s ease;
    }
    
    .header-nav a::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 50%;
        width: 0;
        height: 2px;
        background: var(--celeste-medio);
        transition: all 0.3s ease;
        transform: translateX(-50%);
    }
    
    .header-nav a:hover {
        opacity: 1;
        color: var(--celeste-medio);
        transform: translateY(-2px);
    }
    
    .header-nav a:hover::after {
        width: 100%;
    }
    
    /* Dropdown navegación */
    .nav-dropdown {
        position: relative;
        display: inline-block;
    }
    
    .nav-dropdown-trigger {
        display: flex;
        align-items: center;
        gap: 4px;
    }
    
    .dropdown-arrow {
        font-size: 0.7em;
        transition: transform 0.3s ease;
    }
    
    .nav-dropdown:hover .dropdown-arrow {
        transform: rotate(180deg);
    }
    
    .nav-dropdown-content {
        position: absolute;
        top: 100%;
        left: 50%;
        transform: translateX(-50%);
        background: #1e2a3a;
        min-width: 260px;
        border-radius: 8px;
        box-shadow: 0 8px 32px rgba(0,0,0,0.3);
        opacity: 0;
        visibility: hidden;
        transition: all 0.3s ease;
        padding: 0.5rem 0;
        margin-top: 0.5rem;
        z-index: var(--z-dropdown);
    }
    
    .nav-dropdown:hover .nav-dropdown-content {
        opacity: 1;
        visibility: visible;
        margin-top: 0;
    }
    
    .nav-dropdown-content::before {
        content: '';
        position: absolute;
        top: -6px;
        left: 50%;
        transform: translateX(-50%);
        border-left: 6px solid transparent;
        border-right: 6px solid transparent;
        border-bottom: 6px solid #1e2a3a;
    }
    
    .nav-dropdown-content a {
        display: block;
        padding: 0.75rem 1.25rem;
        color: rgba(255,255,255,0.85);
        font-size: 0.9rem;
        transition: all 0.2s ease;
        white-space: nowrap;
    }
    
    .nav-dropdown-content a:hover {
        background: rgba(145, 189, 225, 0.15);
        color: var(--celeste-medio);
        padding-left: 1.5rem;
    }
    
    /* Menu Mobile */
    .menu-toggle {
        display: none;
        flex-direction: column;
        gap: 5px;
        background: none;
        border: none;
        padding: 8px;
        cursor: pointer;
    }
    
    .menu-toggle span {
        width: 24px;
        height: 2px;
        background: var(--blanco);
        transition: all var(--transition-fast);
    }
    
    @media (max-width: 968px) {
        .header-nav {
            display: none;
            position: absolute;
            top: 100%;
            left: 0;
            right: 0;
            background: #1e2a3a;
            flex-direction: column;
            padding: 24px;
            gap: 16px;
        }
        
        .header-nav.active {
            display: flex;
        }
        
        .menu-toggle {
            display: flex;
        }
        
        .header-logo-text {
            display: none;
        }
    }
    
    /* BREADCRUMB: heredado de shared-components.css */
    
    /* ============================================
       HERO MAESTRÍA
       ============================================ */
    .hero-maestria {
        background: linear-gradient(135deg, var(--azul-profundo) 0%, var(--azul-uba) 100%);
        border-top: 5px solid var(--color-area);
        color: var(--blanco);
        padding: var(--space-16) 0;
        position: relative;
        overflow: hidden;
    }
    
    .hero-maestria::before {
        content: '';
        position: absolute;
        top: 0;
        right: -5%;
        width: 45%;
        height: 100%;
        background: radial-gradient(ellipse at 70% 30%, rgba(var(--color-area-rgb), 0.22) 0%, transparent 65%);
    }
    
    .hero-grid {
        display: grid;
        grid-template-columns: 1fr 380px;
        gap: var(--space-12);
        align-items: start;
        position: relative;
        z-index: 1;
    }
    
    @media (max-width: 968px) {
        .hero-grid {
            grid-template-columns: 1fr;
        }
    }
    
    .hero-badges {
        display: flex;
        flex-wrap: wrap;
        gap: var(--space-2);
        margin-bottom: var(--space-4);
    }
    
    .badge {
        display: inline-flex;
        align-items: center;
        gap: var(--space-2);
        padding: 6px 12px;
        border-radius: var(--radius-sm);
        font-size: var(--font-size-xs);
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }
.badge-inscripcion {
        background: linear-gradient(135deg, var(--color-area-dark) 0%, var(--color-area) 100%);
        color: #ffffff;
        font-weight: 600;
    }
    
    .badge-coneau {
        background: rgba(255,255,255,0.15);
        color: var(--blanco);
        border: 1px solid rgba(255,255,255,0.3);
    }
    
    .badge-modalidad {
        background: rgba(145, 189, 225, 0.2);
        color: var(--celeste-claro);
    }
    
    .hero-acronimo {
        font-size: var(--font-size-xs);
        font-weight: 500;
        color: rgba(255, 255, 255, 0.6);
        text-transform: uppercase;
        letter-spacing: 2px;
        margin-bottom: var(--space-2);
    }
    
    .hero-area {
        font-size: var(--font-size-sm);
        font-weight: 600;
        color: var(--celeste-medio);
        text-transform: uppercase;
        letter-spacing: 1px;
        margin-bottom: var(--space-3);
    }
    
    .hero-title {
        font-size: clamp(1.75rem, 4vw, 2.5rem);
        font-weight: 800;
        line-height: 1.15;
        margin-bottom: var(--space-4);
    }
    
    .hero-title-prefix {
        display: block;
        font-size: 0.45em;
        font-weight: 500;
        color: var(--celeste-claro);
        margin-bottom: 0.3em;
        letter-spacing: 1px;
        text-transform: uppercase;
    }
    
    .hero-title-name {
        display: block;
        color: var(--blanco);
    }
    
    @media (max-width: 768px) {
        .hero-title {
            font-size: var(--font-size-2xl);
        }
    }
    
    .hero-slogan {
        font-size: var(--font-size-lg);
        font-weight: 500;
        font-style: italic;
        color: var(--color-area-light);
        margin-bottom: var(--space-4);
        border-left: 4px solid var(--color-area-light);
        padding-left: var(--space-4);
    }

    
    .hero-subtitle {
        font-size: var(--font-size-base);
        font-weight: 400;
        opacity: 0.9;
        line-height: 1.7;
        margin-bottom: var(--space-6);
        max-width: 600px;
    }
    
    .hero-tags-row {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: var(--space-3);
        margin-bottom: var(--space-6);
    }
    
    .hero-tag-virtual {
        display: inline-flex;
        align-items: center;
        gap: var(--space-2);
        background: rgba(var(--color-area-rgb), 0.15);
        border: 1px solid rgba(var(--color-area-rgb), 0.3);
        color: var(--color-area-light);
        padding: 8px 16px;
        border-radius: var(--radius-md);
        font-size: var(--font-size-sm);
        font-weight: 600;
    }
    
    .hero-tag-virtual svg {
        width: 18px;
        height: 18px;
        color: var(--color-area-light);
    }
    
    .hero-instagram {
        display: inline-flex;
        align-items: center;
        gap: var(--space-2);
        color: rgba(255, 255, 255, 0.6);
        font-size: var(--font-size-sm);
        font-weight: 500;
        padding: 8px 14px;
        background: rgba(255, 255, 255, 0.08);
        border: 1px solid rgba(255, 255, 255, 0.15);
        border-radius: var(--radius-md);
        transition: all var(--transition-base);
        text-decoration: none;
    }
    
    .hero-instagram:hover {
        background: rgba(255, 255, 255, 0.08);
        border-color: rgba(255, 255, 255, 0.3);
        color: var(--blanco);
        transform: translateY(-1px);
    }
    
    .hero-instagram svg {
        border-radius: 5px;
    }

    .hero-instagram:active {
        background: rgba(255, 255, 255, 0.15);
    }

    .hero-instagram svg path {
        fill: currentColor !important;
    }

    
    .hero-meta {
        display: flex;
        flex-wrap: wrap;
        gap: var(--space-6);
        margin-bottom: var(--space-6);
    }
    
    .meta-item {
        display: flex;
        align-items: center;
        gap: var(--space-2);
    }
    
    .meta-icon {
        width: 20px;
        height: 20px;
        opacity: 0.7;
    }
    
    .meta-label {
        font-size: var(--font-size-sm);
        opacity: 0.7;
    }
    
    .meta-value {
        font-size: var(--font-size-sm);
        font-weight: 600;
    }
    
    .meta-cohorte .meta-value strong {
        color: #10b981;
    }
    
    .meta-cursada .meta-value {
        color: var(--dorado-claro);
        font-weight: 500;
    }
    
    /* Card Acción Sidebar */
    .hero-action-card {
        background: var(--blanco);
        border-radius: var(--radius-lg);
        padding: var(--space-8);
        color: var(--texto-primario);
        box-shadow: var(--shadow-xl);
    }
    
    .action-card-header {
        text-align: center;
        margin-bottom: var(--space-5);
    }
    
    /* Badge Descuento */
    .descuento-badge {
        display: flex;
        align-items: center;
        gap: var(--space-2);
        background: linear-gradient(135deg, var(--color-area-dark) 0%, var(--color-area) 100%);
        color: var(--blanco);
        padding: 10px 14px;
        border-radius: 2px;
        margin-bottom: var(--space-4);
        font-size: var(--font-size-sm);
        line-height: 1.4;
    }
    
    .descuento-icon {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 28px;
        height: 28px;
        min-width: 28px;
        background: rgba(255, 255, 255, 0.2);
        border-radius: 2px;
        font-weight: 800;
        font-size: 0.9rem;
    }
    
    .descuento-texto {
        flex: 1;
    }
    
    .descuento-texto strong {
        color: var(--color-area-lighter);
    }
    
    .action-card-title {
        font-size: var(--font-size-xl);
        font-weight: 700;
        color: var(--azul-uba);
        margin-bottom: var(--space-4);
    }
    
    .action-card-text {
        font-size: var(--font-size-sm);
        color: var(--texto-secundario);
        line-height: 1.6;
        margin-bottom: var(--space-2);
    }
    
    .action-card-text strong {
        color: var(--texto-primario);
    }
    
    .action-card-cta-text {
        font-size: var(--font-size-sm);
        color: var(--texto-terciario);
        margin-bottom: var(--space-5);
    }
    
    .action-card-ciclo {
        font-size: var(--font-size-sm);
        color: var(--texto-secundario);
    }
    
    .action-card-ciclo strong {
        color: var(--dorado);
    }
    
    .action-card-features {
        list-style: none;
        margin-bottom: var(--space-6);
    }
    
    .action-card-features li {
        display: flex;
        align-items: flex-start;
        gap: var(--space-3);
        padding: var(--space-3) 0;
        font-size: var(--font-size-sm);
        border-bottom: 1px solid var(--gris-100);
    }
    
    .action-card-features li:last-child {
        border-bottom: none;
    }
    
    .feature-icon {
        color: var(--dorado);
        font-size: 1.1rem;
        flex-shrink: 0;
    }
    
    .action-card-buttons {
        display: flex;
        flex-direction: column;
        gap: var(--space-3);
    }
    
    .btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: var(--space-2);
        font-family: var(--font-primary);
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        border: none;
        border-radius: var(--radius-sm);
        cursor: pointer;
        transition: all var(--transition-base);
        text-decoration: none;
    }
    
    .btn-large {
        padding: var(--space-4) var(--space-6);
        font-size: var(--font-size-sm);
    }
    
    .btn-medium {
        padding: var(--space-3) var(--space-5);
        font-size: var(--font-size-sm);
    }
    
    .btn-dorado {
        background: linear-gradient(90deg, var(--dorado-medio) 0%, var(--dorado-claro) 25%, var(--dorado-medio) 50%, var(--dorado-oscuro) 75%, var(--dorado-medio) 100%);
        background-size: 200% 100%;
        color: var(--azul-uba);
        animation: shimmer 3.2s ease-in-out infinite;
        transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
    }
    
    .btn-dorado:hover {
        animation: shimmer 1.5s ease-in-out infinite;
        box-shadow: 0 8px 25px rgba(201,162,39,0.4);
        transform: translateY(-2px);
        color: var(--azul-uba);
    }
    
    .btn-inscripcion {
        background: linear-gradient(135deg, var(--color-area-dark) 0%, var(--color-area) 100%);
        color: #ffffff;
        font-weight: 600;
        transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
    }
    
    .btn-inscripcion:hover {
        background: var(--color-area-dark);
        box-shadow: 0 6px 20px rgba(67, 160, 71, 0.4);
        transform: translateY(-2px);
        color: #ffffff;
    }
    
    @keyframes shimmer {
        0% { background-position: 100% 0; }
        100% { background-position: -100% 0; }
    }
    
    .btn-primary {
        background: var(--azul-uba);
        color: var(--blanco);
        transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
    }
    
    .btn-primary:hover {
        background: var(--azul-hover);
        color: var(--blanco);
        transform: translateY(-2px);
        box-shadow: 0 8px 20px rgba(29,37,84,0.3);
    }
    
    .btn-outline {
        background: transparent;
        color: var(--azul-uba);
        border: 2px solid var(--azul-uba);
        transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
    }
    
    .btn-outline:hover {
        background: var(--azul-uba);
        color: var(--blanco);
        transform: translateY(-1px);
        box-shadow: 0 4px 12px rgba(29, 37, 84, 0.15);
    }
    
    .btn-full {
        width: 100%;
    }
    
    /* ============================================
       CONTENIDO PRINCIPAL CON SIDEBAR
       ============================================ */
    .content-wrapper {
        display: grid;
        grid-template-columns: 1fr 350px;
        gap: var(--space-12);
        padding: var(--space-12) 0;
    }
    
    @media (max-width: 968px) {
        .content-wrapper {
            grid-template-columns: 1fr;
        }
    }
    
    .main-content {
        min-width: 0;
    }
    
    /* Sidebar Sticky */
    .sidebar {
        position: sticky;
        top: 100px;
        height: fit-content;
    }
    
    @media (max-width: 968px) {
        .sidebar {
            position: static;
        }
    }
    
    .sidebar-card {
        background: var(--blanco);
        border: 1px solid var(--gris-200);
        border-radius: var(--radius-sm);
        padding: 1.25rem;
        margin-bottom: var(--space-6);
        box-shadow: var(--shadow-sm);
        border-left: 3px solid var(--color-area);
    }
    
    .sidebar-card-title {
        font-size: 0.9rem;
        font-weight: 600;
        color: var(--azul-uba);
        margin-bottom: 1rem;
        padding-bottom: 0;
        border-bottom: none;
    }
    
    .sidebar-links {
        list-style: none;
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: 0.625rem;
    }
    
    .sidebar-links li a {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        font-size: 0.875rem;
        color: #4b5563;
        text-decoration: none;
        transition: color 0.2s;
    }
    
    .sidebar-links li a:hover {
        color: #208192;
    }
    
    .sidebar-links li a svg {
        width: 16px;
        height: 16px;
        flex-shrink: 0;
        color: var(--color-area);
        opacity: 0.8;
    }
    
    .sidebar-links li a:hover svg {
        color: #208192;
        opacity: 1;
    }
    
    /* ============================================
       SECCIONES DE CONTENIDO
       ============================================ */
    .content-section {
        margin-bottom: var(--space-12);
    }
    
    .section-title {
        font-size: 1.5rem;
        font-weight: 700;
        color: var(--azul-uba);
        margin-bottom: var(--space-6);
    }
    
    .section-title--decorated {
        position: relative;
        padding-bottom: var(--space-3);
    }
    
    .section-title--decorated::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        width: 60px;
        height: 4px;
        background: var(--dorado-medio);
        border-radius: 2px;
    }
    
    .section-subtitle {
        font-size: var(--font-size-xl);
        font-weight: 700;
        color: var(--azul-uba);
        margin-bottom: var(--space-4);
    }
    
    .section-text {
        font-size: var(--font-size-base);
        line-height: 1.8;
        color: var(--texto-secundario);
        margin-bottom: var(--space-4);
    }
    
    /* Sección ¿Qué vas a lograr? */
    .logros-content p {
        font-size: 0.95rem;
        line-height: 1.75;
        color: #4b5563;
        margin-bottom: 1.25rem;
    }
    
    .logros-content p:last-child {
        margin-bottom: 0;
    }
    
    .logros-content strong {
        color: #1f2937;
        font-weight: 600;
    }
    
    /* Sidebar Info Académica */
    .info-academica-card {
        background: var(--blanco);
        border: 1px solid var(--gris-200);
        border-radius: var(--radius-sm);
        overflow: hidden;
        box-shadow: var(--shadow-sm);
        margin-bottom: var(--space-6);
        border-top: 3px solid var(--color-area);
    }
    
    .info-academica-header {
        background: var(--color-area-light);
        color: var(--azul-profundo);
        padding: 0.875rem 1.25rem;
        font-size: 0.9rem;
        font-weight: 600;
    }
    
    .info-academica-body {
        padding: 0;
    }
    
    .info-academica-row {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        padding: 0.875rem 1.25rem;
        border-bottom: 1px solid #f3f4f6;
        gap: var(--space-3);
    }
    
    .info-academica-row:last-child {
        border-bottom: none;
    }
    
    .info-academica-label {
        font-size: 0.875rem;
        color: #6b7280;
        font-weight: 400;
        flex-shrink: 0;
    }
    
    .info-academica-value {
        font-size: 0.875rem;
        font-weight: 600;
        color: #111827;
        text-align: right;
    }
    
    /* ============================================
       COMPONENTE: EQUIPO DOCENTE MAESTRÍAS
       ============================================ */
    .equipo-docente-maestria {
        font-family: var(--font-primary);
        color: var(--texto-primario);
        line-height: 1.6;
    }
    
    /* Dirección — layout flexible según cantidad de autoridades */
    .direccion-grid {
        display: flex;
        flex-wrap: wrap;
        gap: 1.5rem;
        margin-bottom: 1.5rem;
    }

    /* 1 solo director: ancho completo */
    .direccion-grid .autoridad-card:only-child {
        width: 100%;
    }

    /* 2 autoridades: lado a lado */
    .direccion-grid .autoridad-card {
        flex: 1 1 calc(50% - 0.75rem);
        min-width: 280px;
    }

    /* 3+ autoridades: scroll horizontal (carrusel) */
    .direccion-grid:has(.autoridad-card:nth-child(3)) {
        flex-wrap: nowrap;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 8px;
    }

    .direccion-grid:has(.autoridad-card:nth-child(3)) .autoridad-card {
        flex: 0 0 320px;
        scroll-snap-align: start;
    }

    .direccion-grid::-webkit-scrollbar { height: 4px; }
    .direccion-grid::-webkit-scrollbar-track { background: var(--gris-200, #e5e7eb); border-radius: 2px; }
    .direccion-grid::-webkit-scrollbar-thumb { background: var(--azul-uba, #1b4f72); border-radius: 2px; }

    @media (max-width: 768px) {
        .direccion-grid .autoridad-card {
            flex: 1 1 100%;
        }
    }
    
    .autoridad-card {
        background: var(--blanco);
        padding: 1.75rem;
        border-radius: 2px;
        border-left: 3px solid var(--color-area);
        box-shadow: var(--shadow-sm);
    }
    
    .autoridad-con-foto {
        display: flex;
        gap: var(--space-4);
        align-items: flex-start;
    }
    
    .autoridad-foto {
        width: 80px;
        height: 80px;
        min-width: 80px;
        border-radius: 2px;
        overflow: hidden;
        background: var(--gris-100);
    }
    
    .autoridad-foto img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        filter: grayscale(0%);
    }
    
    .autoridad-info {
        flex: 1;
    }
    
    @media (max-width: 480px) {
        .autoridad-con-foto {
            flex-direction: column;
            align-items: center;
            text-align: center;
        }
        
        .autoridad-foto {
            width: 100px;
            height: 100px;
        }
    }
    
    .autoridad-role {
        display: block;
        font-size: 0.75rem;
        text-transform: uppercase;
        letter-spacing: 1.5px;
        color: var(--texto-terciario);
        margin-bottom: 0.5rem;
    }
    
    .autoridad-name {
        font-size: 1.2rem;
        font-weight: 600;
        margin: 0 0 0.75rem 0;
        line-height: 1.3;
        color: var(--texto-primario);
    }
    
    .autoridad-bio {
        color: var(--texto-secundario);
        font-size: 0.875rem;
        line-height: 1.65;
        margin: 0;
    }
    
    /* Desplegables */
    .desplegable-seccion {
        margin-bottom: 0.75rem;
    }
    
    .desplegable-toggle {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        padding: 1rem 1.25rem;
        background: var(--blanco);
        border-radius: var(--radius-md);
        cursor: pointer;
        font-size: 0.9rem;
        font-weight: 500;
        color: var(--texto-primario);
        list-style: none;
        transition: background 0.2s;
        box-shadow: var(--shadow-sm);
    }
    
    .desplegable-toggle::-webkit-details-marker {
        display: none;
    }
    
    .desplegable-toggle:hover {
        background: var(--gris-50);
    }
    
    .icono-flecha {
        transition: transform 0.3s ease;
        color: var(--texto-terciario);
    }
    
    details[open] .icono-flecha {
        transform: rotate(180deg);
    }
    
    .desplegable-contenido {
        background: var(--blanco);
        border-radius: 0 0 var(--radius-md) var(--radius-md);
        margin-top: -4px;
        padding: 0.5rem 0;
        box-shadow: var(--shadow-sm);
    }
    
    /* Lista de miembros */
    .lista-miembros {
        list-style: none;
        margin: 0;
        padding: 0;
    }
    
    .miembro-item {
        display: flex;
        flex-direction: column;
        padding: 0.75rem 1.25rem;
        border-left: 3px solid transparent;
        transition: all 0.2s ease;
    }
    
    .miembro-item:hover {
        background: var(--gris-50);
        border-left-color: var(--color-area);
    }
    
    .miembro-item strong {
        font-size: 0.875rem;
        font-weight: 500;
        color: var(--texto-primario);
    }
    
    .miembro-item span {
        font-size: 0.8rem;
        color: var(--texto-terciario);
        margin-top: 0.1rem;
    }
    
    /* Grid de áreas */
    .areas-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
        gap: 1rem;
        padding: 1rem;
    }
    
    @media (max-width: 768px) {
        .areas-grid {
            grid-template-columns: 1fr;
            padding: 0.5rem;
        }
    }
    
    .area-grupo {
        background: var(--blanco);
        border-radius: var(--radius-md);
        overflow: hidden;
        border: 1px solid var(--gris-200);
    }
    
    .area-titulo {
        font-size: 0.85rem;
        font-weight: 600;
        color: var(--texto-primario);
        padding: 1rem 1.25rem;
        margin: 0;
        background: var(--gris-50);
        border-left: 3px solid var(--color-area);
    }
    
    /* Lista de docentes */
    .lista-docentes {
        list-style: none;
        margin: 0;
        padding: 0;
    }
    
    .docente-item {
        display: flex;
        flex-direction: column;
        padding: 0.875rem 1.25rem;
        border-left: 3px solid transparent;
        border-bottom: 1px solid var(--gris-100);
        transition: all 0.2s ease;
    }
    
    .docente-item:last-child {
        border-bottom: none;
    }
    
    .docente-item:hover {
        background: var(--gris-50);
        border-left-color: var(--color-area);
    }
    
    .docente-item strong {
        font-size: 0.9rem;
        font-weight: 500;
        color: var(--texto-primario);
    }
    
    .docente-rol {
        font-size: 0.8rem;
        color: var(--texto-secundario);
        margin-top: 0.15rem;
    }
    
    .docente-materia {
        font-size: 0.75rem;
        color: var(--texto-terciario);
        margin-top: 0.1rem;
    }
    
    /* ============================================
       COORDINACIÓN
       ============================================ */
    .coordinacion-card {
        background: linear-gradient(135deg, var(--color-area-light), var(--color-area-lighter));
        color: var(--azul-profundo);
        border-radius: var(--radius-sm);
        padding: var(--space-5);
        border-left: 4px solid var(--color-area);
        margin-bottom: var(--space-6);
    }
    
    .coordinacion-title {
        font-size: var(--font-size-base);
        font-weight: 600;
        margin-bottom: var(--space-4);
        color: var(--azul-profundo);
    }
    
    .coordinacion-item {
        margin-bottom: var(--space-4);
    }
    
    .coordinacion-item:last-child {
        margin-bottom: 0;
    }
    
    .coordinacion-label {
        font-size: 0.7rem;
        opacity: 0.8;
        text-transform: uppercase;
        letter-spacing: 1px;
        margin-bottom: var(--space-1);
        color: var(--azul-profundo);
    }
    
    .coordinacion-value {
        font-size: var(--font-size-sm);
    }
    
    .coordinacion-value a {
        color: var(--azul-profundo);
        font-weight: 600;
    }
    
    .coordinacion-value a:hover {
        color: var(--blanco);
        text-decoration: underline;
    }
    
    /* ============================================
       FAQ
       ============================================ */
    .faq-list {
        display: flex;
        flex-direction: column;
        gap: var(--space-4);
    }
    
    .faq-item {
        background: var(--blanco);
        border: 1px solid var(--gris-200);
        border-radius: var(--radius-md);
        overflow: hidden;
    }
    
    .faq-question {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: var(--space-4) var(--space-5);
        cursor: pointer;
        font-weight: 600;
        color: var(--azul-uba);
        transition: background var(--transition-base);
    }
    
    .faq-question:hover {
        background: var(--gris-50);
    }
    
    .faq-answer {
        display: none;
        padding: 0 var(--space-5) var(--space-5);
        color: var(--texto-secundario);
        line-height: 1.7;
    }
    
    .faq-item.open .faq-answer {
        display: block;
    }
    
    
    /* ============================================
       EQUIPO DOCENTE - Acordeón
       ============================================ */
    .equipo-accordion {
        margin-top: var(--space-5);
    }
    
    .equipo-accordion details {
        border: 1px solid var(--gris-200);
        border-radius: var(--radius-sm);
        margin-bottom: var(--space-3);
        overflow: hidden;
    }
    
    .equipo-accordion details[open] {
        border-color: var(--color-area);
    }
    
    .equipo-accordion summary {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: var(--space-3) var(--space-4);
        cursor: pointer;
        font-weight: 600;
        font-size: var(--font-size-base);
        color: var(--azul-uba);
        background: var(--gris-50, #f8f9fa);
        list-style: none;
        user-select: none;
        transition: background 0.2s ease;
    }
    
    .equipo-accordion summary::-webkit-details-marker {
        display: none;
    }
    
    .equipo-accordion summary::after {
        content: "▾";
        color: var(--color-area);
        font-size: 1.2rem;
        transition: transform 0.2s ease;
    }
    
    .equipo-accordion details[open] summary::after {
        transform: rotate(180deg);
    }
    
    .equipo-accordion summary:hover {
        background: var(--color-area-bg);
    }
    
    .equipo-accordion .equipo-panel {
        padding: var(--space-4);
    }
    
    .equipo-accordion .equipo-subcategoria {
        margin-bottom: var(--space-4);
    }
    
    .equipo-accordion .equipo-subcategoria:last-child {
        margin-bottom: 0;
    }
    
    .equipo-accordion .equipo-subcategoria-title {
        font-size: var(--font-size-sm);
        font-weight: 700;
        color: var(--azul-uba);
        margin-bottom: var(--space-2);
        padding-bottom: var(--space-1);
        border-bottom: 2px solid var(--color-area);
    }
    
    .equipo-accordion .equipo-list {
        list-style: disc;
        padding-left: var(--space-4);
        margin: 0;
    }
    
    .equipo-accordion .equipo-list li {
        padding: var(--space-1) 0;
        font-size: var(--font-size-sm);
        line-height: 1.5;
        color: var(--texto-principal);
    }
    
    .equipo-accordion .equipo-list li strong {
        color: var(--azul-uba);
    }
    
    .equipo-accordion .equipo-list li span {
        color: var(--texto-secundario);
    }


    /* ============================================
       CHARLA INFORMATIVA - Calendar Integration
       ============================================ */
    .hero-charla-container {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: var(--space-3);
    }
    
    .charla-calendar-panel {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: var(--space-2);
    }
    
    .charla-date {
        font-size: var(--font-size-xs);
        color: rgba(255, 255, 255, 0.7);
        font-weight: 500;
    }
    
    .charla-pending {
        font-size: var(--font-size-xs);
        color: rgba(255, 255, 255, 0.5);
        font-style: italic;
    }
    
    .charla-cal-buttons {
        display: flex;
        gap: var(--space-1);
    }
    
    .charla-cal-btn {
        display: inline-flex;
        align-items: center;
        gap: 4px;
        padding: 4px 10px;
        font-size: 0.7rem;
        font-weight: 600;
        color: rgba(255, 255, 255, 0.85);
        background: rgba(255, 255, 255, 0.1);
        border: 1px solid rgba(255, 255, 255, 0.2);
        border-radius: var(--radius-sm);
        text-decoration: none;
        transition: all 0.2s ease;
    }
    
    .charla-cal-btn:hover {
        background: rgba(255, 255, 255, 0.2);
        color: #fff;
        border-color: rgba(255, 255, 255, 0.4);
        transform: translateY(-1px);
    }
    
    .charla-cal-btn svg {
        opacity: 0.8;
    }
    
    @media (max-width: 768px) {
        .hero-charla-container {
            flex-direction: column;
            align-items: flex-start;
        }
        .charla-cal-buttons {
            flex-wrap: wrap;
        }
    }

    /* ============================================
       CTA FINAL
       ============================================ */
    .cta-final {
        background: linear-gradient(135deg, var(--azul-profundo) 0%, var(--azul-uba) 50%, var(--color-area-dark) 100%);
        color: var(--blanco);
        padding: var(--space-16) 0;
        text-align: center;
        position: relative;
        overflow: hidden;
    }
    
    .cta-final::before {
        content: '';
        position: absolute;
        top: 0;
        right: 0;
        width: 60%;
        height: 100%;
        background: radial-gradient(circle at 80% 50%, var(--color-area-radial) 0%, transparent 60%);
    }
    
    .cta-final .container {
        position: relative;
        z-index: 1;
    }
    
    .cta-final-title {
        font-size: var(--font-size-3xl);
        font-weight: 700;
        margin-bottom: var(--space-2);
        line-height: 1.3;
    }
    
    
    
    .cta-final-subtitle {
        font-size: var(--font-size-lg);
        opacity: 0.9;
        margin-bottom: var(--space-4);
        max-width: 600px;
        margin-left: auto;
        margin-right: auto;
    }
    
    .cta-final-text {
        font-size: var(--font-size-base);
        opacity: 0.85;
        margin-bottom: var(--space-8);
        max-width: 550px;
        margin-left: auto;
        margin-right: auto;
    }
    
    .cta-final-buttons {
        display: flex;
        justify-content: center;
        gap: var(--space-3);
        flex-wrap: wrap;
        margin-bottom: var(--space-8);
    }
    
    .cta-final-buttons .btn {
        padding: var(--space-3) var(--space-5);
        font-size: var(--font-size-sm);
    }
    
    @media (max-width: 768px) {
        .cta-final-buttons {
            flex-direction: column;
            align-items: center;
        }
        
        .cta-final-buttons .btn {
            width: 100%;
            max-width: 280px;
        }
    }
    
    .cta-final .btn-primary {
        background: var(--blanco);
        color: var(--azul-uba);
        font-weight: 600;
        border: none;
    }
    
    .cta-final .btn-primary:hover {
        background: var(--dorado-claro);
        color: var(--azul-profundo);
    }
    
    .cta-final .btn-outline {
        background: transparent;
        color: var(--blanco);
        border: 2px solid rgba(255,255,255,0.5);
    }
    
    .cta-final .btn-outline:hover {
        background: var(--blanco);
        color: var(--azul-uba);
        border-color: var(--blanco);
    }
    
    .cta-final .btn-inscripcion {
        background: linear-gradient(135deg, var(--color-area-dark) 0%, var(--color-area) 100%);
        color: #ffffff;
        font-weight: 600;
        border: none;
    }
    
    .cta-final .btn-inscripcion:hover {
        background: var(--color-area-dark);
        box-shadow: 0 6px 20px rgba(67, 160, 71, 0.4);
        transform: translateY(-2px);
        color: #ffffff;
    }
    
    .cta-final-tagline {
        font-size: var(--font-size-sm);
        font-style: italic;
        opacity: 0.8;
        color: var(--celeste-claro);
    }
    
    /* ============================================
       DIFERENCIAL - Componentes internos
       ============================================ */
    .diferencial-title {
        font-size: 1.5rem;
        font-weight: 700;
        color: var(--azul-uba);
        margin-bottom: var(--space-6);
    }
    
    .diferencial-intro {
        font-size: var(--font-size-sm);
        color: var(--texto-secundario);
        margin-bottom: var(--space-5);
        max-width: 600px;
        line-height: 1.6;
    }
    
    .diferencial-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-4);
    }
    
    @media (max-width: 640px) {
        .diferencial-grid {
            grid-template-columns: 1fr;
        }
    }
    
    .diferencial-card {
        display: flex;
        gap: var(--space-3);
        align-items: flex-start;
    }
    
    .diferencial-icon {
        width: 36px;
        height: 36px;
        min-width: 36px;
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--color-area-bg);
        border-radius: 2px;
        color: var(--color-area);
    }
    
    .diferencial-icon svg {
        width: 20px;
        height: 20px;
    }
    
    .diferencial-card-content {
        flex: 1;
    }
    
    .diferencial-card-title {
        font-size: var(--font-size-sm);
        font-weight: 600;
        margin-bottom: var(--space-1);
        color: var(--texto-primario);
    }
    
    .diferencial-card-text {
        font-size: var(--font-size-sm);
        color: var(--texto-secundario);
        line-height: 1.5;
    }
    
    .diferencial-rankings {
        margin-top: var(--space-5);
        padding-top: var(--space-5);
        border-top: 1px solid var(--gris-200);
    }
    
    .diferencial-rankings-title {
        font-size: 0.7rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 1px;
        color: var(--texto-terciario);
        margin-bottom: var(--space-3);
    }
    
    .diferencial-rankings-grid {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: var(--space-4);
    }
    
    @media (max-width: 640px) {
        .diferencial-rankings-grid {
            grid-template-columns: repeat(2, 1fr);
        }
    }
    
    .diferencial-rankings .ranking-item {
        text-align: center;
    }
    
    .diferencial-rankings .ranking-number {
        font-size: var(--font-size-xl);
        font-weight: 700;
        color: var(--color-area);
        line-height: 1;
        display: block;
    }
    
    .diferencial-rankings .ranking-label {
        font-size: 0.7rem;
        color: var(--texto-terciario);
        line-height: 1.3;
        display: block;
        margin-top: 2px;
    }
    
    /* ============================================
       POR QUÉ ELEGIR FADU UBA - Versión ligera
       ============================================ */
    .porque-fadu {
        background: var(--gris-50);
        padding: var(--space-6);
        border-radius: 2px;
        margin-top: var(--space-6);
        margin-bottom: var(--space-6);
    }
    
    .porque-fadu-title {
        font-size: var(--font-size-lg);
        font-weight: 700;
        margin-bottom: var(--space-4);
        color: var(--texto-primario);
    }
    
    .porque-fadu-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--space-3);
        margin-bottom: var(--space-5);
    }
    
    .porque-card {
        display: flex;
        align-items: flex-start;
        gap: var(--space-3);
    }
    
    .porque-card-icon {
        width: 32px;
        height: 32px;
        min-width: 32px;
        background: var(--blanco);
        border: 1px solid var(--gris-200);
        border-radius: 2px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    
    .porque-card-icon svg {
        width: 18px;
        height: 18px;
        color: var(--color-area);
    }
    
    .porque-card-content {
        flex: 1;
    }
    
    .porque-card-title {
        font-size: var(--font-size-sm);
        font-weight: 600;
        color: var(--texto-primario);
        margin-bottom: 2px;
    }
    
    .porque-card-text {
        font-size: var(--font-size-sm);
        color: var(--texto-secundario);
        line-height: 1.5;
        margin: 0;
    }
    
    /* Rankings */
    .rankings-section {
        border-top: 1px solid var(--gris-200);
        padding-top: var(--space-4);
    }
    
    .rankings-title {
        font-size: 0.7rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 1px;
        color: var(--texto-terciario);
        margin-bottom: var(--space-3);
    }
    
    .rankings-grid {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: var(--space-2);
    }
    
    @media (max-width: 640px) {
        .rankings-grid {
            grid-template-columns: repeat(2, 1fr);
        }
    }
    
    .ranking-item {
        text-align: center;
    }
    
    .ranking-number {
        font-size: var(--font-size-lg);
        font-weight: 700;
        color: var(--color-area);
        line-height: 1.1;
    }
    
    .ranking-label {
        font-size: 0.7rem;
        font-weight: 500;
        color: var(--texto-terciario);
        line-height: 1.2;
    }
    
    /* ============================================
       FOOTER - Sistema principal
       ============================================ */
    .footer {
        background: #1e2a3a;
        color: #ffffff;
        padding: 60px 0 30px;
    }
    
    .footer-grid {
        display: grid;
        grid-template-columns: 1.5fr 1fr 1fr 1fr;
        gap: 40px;
        margin-bottom: 40px;
    }
    
    @media (max-width: 968px) {
        .footer-grid {
            grid-template-columns: 1fr 1fr;
        }
        .footer-brand {
            grid-column: 1 / -1;
        }
    }
    
    @media (max-width: 640px) {
        .footer-grid {
            grid-template-columns: 1fr;
        }
    }
    
    .footer-logo {
        display: flex;
        align-items: center;
        gap: 0.25rem;
        margin-bottom: 1rem;
    }
    
    .footer-logo-uba {
        font-size: 1.4rem;
        font-weight: 700;
        color: #8899aa;
        letter-spacing: -0.5px;
        text-decoration: underline;
        text-underline-offset: 3px;
    }
    
    .footer-logo-fadu {
        font-size: 1.4rem;
        font-weight: 700;
        color: #ffffff;
        letter-spacing: -0.5px;
    }
    
    .footer-brand p {
        font-size: 0.875rem;
        color: #8899aa;
        line-height: 1.6;
        margin-bottom: 0;
    }
    
    .footer-tagline {
        font-size: 0.875rem;
        font-weight: 600;
        color: #5ebbbb;
        margin-top: 1rem;
        margin-bottom: 0.5rem;
    }
    
    .footer-hashtag {
        font-size: 0.875rem;
        font-weight: 600;
        color: #8899aa;
    }
    
    .footer-social {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        color: #8899aa;
        text-decoration: none;
        font-size: 0.875rem;
        margin-top: 1.25rem;
        padding: 8px 14px;
        background: transparent;
        border: 1px solid rgba(255,255,255,0.15);
        border-radius: 6px;
        transition: all 0.2s ease;
    }
    
    .footer-social:hover {
        background: rgba(255,255,255,0.05);
        border-color: rgba(255,255,255,0.25);
        color: #ffffff;
    }
    
    .footer-social svg {
        flex-shrink: 0;
        width: 16px;
        height: 16px;
    }
    
    .footer-links h3 {
        font-size: 0.75rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 1px;
        margin-bottom: 1rem;
        color: #ffffff;
    }
    
    .footer-links ul {
        list-style: none;
    }
    
    .footer-links li {
        margin-bottom: 0.625rem;
    }
    
    .footer-links a {
        font-size: 0.875rem;
        color: #8899aa;
        transition: color 0.2s ease;
    }
    
    .footer-links a:hover {
        color: #ffffff;
    }
    
    .footer-bottom {
        padding-top: 30px;
        border-top: 1px solid rgba(255,255,255,0.1);
        text-align: center;
    }
    
    .footer-bottom p {
        font-size: 0.8rem;
        color: #667788;
        margin-bottom: 4px;
    }
    
    .footer-ror a {
        color: #e67e22;
        text-decoration: none;
    }
    
    .footer-ror a:hover {
        text-decoration: underline;
    }
    
    .footer-accesibilidad {
        font-size: 0.75rem;
        font-style: italic;
    }
    


    /* ============================================
       FAQ ACCORDION (details/summary nativo)
       ============================================ */
    .faq-group-title {
        font-size: var(--font-size-sm);
        font-weight: 700;
        color: var(--color-area);
        text-transform: uppercase;
        letter-spacing: 0.08em;
        margin-top: var(--space-6);
        margin-bottom: 0;
        padding-bottom: var(--space-2);
        border-bottom: 2px solid var(--color-area);
        display: inline-block;
    }
    .faq-group-title:first-child { margin-top: 0; }

    .faq-item-accordion {
        background: var(--blanco);
        border: 1px solid var(--gris-200);
        border-radius: var(--radius-md);
        overflow: hidden;
        transition: box-shadow var(--transition-base);
    }
    .faq-item-accordion[open] {
        box-shadow: var(--shadow-md);
        border-color: var(--color-area);
    }

    .faq-accordion-trigger {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: var(--space-4) var(--space-5);
        cursor: pointer;
        font-family: var(--font-primary);
        font-size: var(--font-size-sm);
        font-weight: 600;
        color: var(--azul-uba);
        list-style: none;
        transition: background var(--transition-base);
    }
    .faq-accordion-trigger::-webkit-details-marker { display: none; }
    .faq-accordion-trigger::marker { display: none; }
    .faq-accordion-trigger:hover { background: var(--gris-50); }

    .faq-arrow {
        transition: transform 0.3s ease;
        color: var(--texto-terciario);
        flex-shrink: 0;
        margin-left: var(--space-3);
    }
    details[open] .faq-arrow {
        transform: rotate(180deg);
        color: var(--color-area);
    }

    .faq-accordion-content {
        padding: 0 var(--space-5) var(--space-5);
    }
    .faq-accordion-content p {
        font-size: var(--font-size-sm);
        color: var(--texto-secundario);
        line-height: 1.7;
        margin: 0;
    }

    .faq-ver-mas {
        display: inline-block;
        font-size: var(--font-size-sm);
        font-weight: 600;
        color: var(--color-area);
        text-decoration: none;
        transition: color var(--transition-base);
    }
    .faq-ver-mas:hover {
        color: var(--azul-uba);
        text-decoration: underline;
    }

    /* ============================================
       TESTIMONIOS
       ============================================ */
    .testimonios-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-6);
    }
    @media (max-width: 640px) {
        .testimonios-grid { grid-template-columns: 1fr; }
    }

    .testimonio-card {
        background: var(--blanco);
        border: 1px solid var(--gris-200);
        border-left: 3px solid var(--color-area);
        border-radius: var(--radius-sm);
        padding: var(--space-6);
        margin: 0;
        position: relative;
    }
    .testimonio-card::before {
        content: '\201C';
        position: absolute;
        top: 12px;
        left: 16px;
        font-size: 3rem;
        line-height: 1;
        color: var(--color-area);
        opacity: 0.2;
        font-family: Georgia, serif;
    }

    .testimonio-texto {
        font-size: var(--font-size-base);
        line-height: 1.7;
        color: var(--texto-principal);
        font-style: italic;
        margin-bottom: var(--space-4);
        padding-top: var(--space-2);
    }

    .testimonio-autor {
        display: flex;
        flex-direction: column;
        gap: 2px;
    }
    .testimonio-nombre {
        font-size: var(--font-size-sm);
        font-weight: 600;
        color: var(--azul-uba);
    }
    .testimonio-cohorte {
        font-size: var(--font-size-xs);
        color: var(--color-area);
        font-weight: 500;
    }
    .testimonio-detalle {
        font-size: var(--font-size-xs);
        color: var(--texto-secundario);
    }

    /* ============================================
       HERO CHARLA (link a charla informativa)
       ============================================ */
    .hero-charla {
        display: inline-flex;
        align-items: center;
        gap: var(--space-2);
        color: rgba(255, 255, 255, 0.6);
        font-size: var(--font-size-sm);
        font-weight: 500;
        padding: 8px 14px;
        background: transparent;
        border: 1px solid rgba(255, 255, 255, 0.15);
        border-radius: var(--radius-md);
        transition: all var(--transition-base);
        text-decoration: none;
        margin-top: var(--space-4);
    }
    .hero-charla:hover {
        background: rgba(255, 255, 255, 0.08);
        border-color: rgba(255, 255, 255, 0.3);
        color: #ffffff;
    }
    .hero-charla:active { background: rgba(255, 255, 255, 0.15); }

    .charla-badge {
        font-size: 10px;
        font-weight: 700;
        letter-spacing: 0.05em;
        background: rgba(255, 255, 255, 0.15);
        color: rgba(255, 255, 255, 0.85);
        padding: 2px 7px;
        border-radius: 3px;
        line-height: 1;
    }
    .hero-charla:hover .charla-badge {
        background: rgba(255, 255, 255, 0.25);
        color: #ffffff;
    }

    /* ============================================
       DIFERENCIAL - variante con data-area
       ============================================ */
    .diferencial-cirfs,
    .diferencial-ciudades,
    .diferencial-dicom,
    .diferencial-gam,
    .diferencial-invproy,
    .diferencial-ltf,
    .diferencial-mahcadu,
    .diferencial-mapa,
    .diferencial-meuval,
    .diferencial-mhypual,
    .diferencial-mpu,
    .diferencial-opendesign,
    .diferencial-propur,
    .diferencial-sau {
        background: var(--blanco);
        padding: var(--space-6) 0;
        margin-top: var(--space-6);
        margin-bottom: var(--space-6);
        border-top: 1px solid var(--gris-200);
        border-bottom: 1px solid var(--gris-200);
    }
    .diferencial-cirfs + .diferencial-cirfs,
    .diferencial-ciudades + .diferencial-ciudades,
    .diferencial-dicom + .diferencial-dicom,
    .diferencial-gam + .diferencial-gam,
    .diferencial-invproy + .diferencial-invproy,
    .diferencial-ltf + .diferencial-ltf,
    .diferencial-mahcadu + .diferencial-mahcadu,
    .diferencial-mapa + .diferencial-mapa,
    .diferencial-meuval + .diferencial-meuval,
    .diferencial-mhypual + .diferencial-mhypual,
    .diferencial-mpu + .diferencial-mpu,
    .diferencial-opendesign + .diferencial-opendesign,
    .diferencial-propur + .diferencial-propur,
    .diferencial-sau + .diferencial-sau { border-top: none; margin-top: 0; }
    .main-content > .diferencial-cirfs:first-child,
    .main-content > .diferencial-ciudades:first-child,
    .main-content > .diferencial-dicom:first-child,
    .main-content > .diferencial-gam:first-child,
    .main-content > .diferencial-invproy:first-child,
    .main-content > .diferencial-ltf:first-child,
    .main-content > .diferencial-mahcadu:first-child,
    .main-content > .diferencial-mapa:first-child,
    .main-content > .diferencial-meuval:first-child,
    .main-content > .diferencial-mhypual:first-child,
    .main-content > .diferencial-mpu:first-child,
    .main-content > .diferencial-opendesign:first-child,
    .main-content > .diferencial-propur:first-child,
    .main-content > .diferencial-sau:first-child { border-top: none; margin-top: var(--space-2); }

    /* ============================================
       COMPETENCIAS CLAVE
       ============================================ */
    .competencias-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-5);
    }
    @media (max-width: 640px) {
        .competencias-grid { grid-template-columns: 1fr; }
    }

    .competencia-card {
        display: flex;
        gap: var(--space-4);
        align-items: flex-start;
        padding: var(--space-5);
        background: var(--blanco);
        border-radius: var(--radius-sm);
        border-left: 3px solid var(--color-area);
    }
    .competencia-icon {
        width: 40px;
        height: 40px;
        min-width: 40px;
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--color-area-bg);
        border-radius: var(--radius-sm);
        color: var(--color-area);
        font-size: 1.25rem;
    }
    .competencia-titulo {
        font-size: var(--font-size-sm);
        font-weight: 600;
        color: var(--texto-primario);
        margin-bottom: var(--space-1);
    }
    .competencia-texto {
        font-size: var(--font-size-sm);
        color: var(--texto-secundario);
        line-height: 1.5;
    }


    /* ============================================
       BADGES POR ÁREA TEMÁTICA
       ============================================ */
    .badge-urbanismo {
        background: linear-gradient(135deg, #009fc0 0%, #00b8db 100%);
        color: #1d2554;
    }
    .badge-diseno {
        background: linear-gradient(135deg, #5a54a0 0%, #6861ac 100%);
        color: #ffffff;
    }
    .badge-gestion {
        background: linear-gradient(135deg, #259a84 0%, #2eb39a 100%);
        color: #1d2554;
    }
    .badge-patrimonio {
        background: linear-gradient(135deg, #7a235a 0%, #952B6C 100%);
        color: #ffffff;
    }
    .badge-proyecto {
        background: linear-gradient(135deg, #e0671c 0%, #ff7621 100%);
        color: #1d2554;
    }
    .badge-sustentabilidad {
        background: linear-gradient(135deg, #5aa830 0%, #6bbf3a 100%);
        color: #1d2554;
    }

    /* Tipo de posgrado */
    .badge-maestria {
        background: linear-gradient(135deg, var(--dorado-medio), var(--dorado-claro));
        color: var(--azul-uba);
    }
    .badge-especializacion {
        background: linear-gradient(135deg, var(--celeste-uba), #7aadd0);
        color: var(--azul-profundo);
    }
    .badge-programa-actualizacion {
        background: linear-gradient(135deg, var(--gris-600), var(--gris-700));
        color: #ffffff;
    }

    .badge-cohorte {
        background: rgba(255,255,255,0.12);
        color: #ffffff;
        font-weight: 700;
        border: 1.5px solid rgba(255,255,255,0.55);
        letter-spacing: 0.02em;
    }


    /* ============================================
       STICKY CTA MOBILE
       ============================================ */
    .sticky-cta-mobile {
        display: none;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: var(--blanco);
        padding: var(--space-3) var(--space-4);
        box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.15);
        z-index: 9999;
        border-top: 1px solid var(--gris-200);
    }
    
    .sticky-cta-content {
        display: flex;
        gap: var(--space-2);
        max-width: 500px;
        margin: 0 auto;
    }
    
    .sticky-cta-mobile .btn {
        flex: 1;
        text-align: center;
        padding: 12px 16px;
        font-size: var(--font-size-sm);
        border-radius: 2px;
    }
    
    .sticky-cta-mobile .btn-primary {
        background: var(--verde-inscripcion);
        color: var(--blanco);
        border: none;
    }
    
    .sticky-cta-mobile .btn-outline {
        background: transparent;
        color: var(--azul-uba);
        border: 1px solid var(--azul-uba);
    }
    
    @media (max-width: 768px) {
        .sticky-cta-mobile {
            display: block;
        }
        
        /* Agregar padding al body para que el contenido no quede tapado */
        body {
            padding-bottom: 70px;
        }
    }

        /* === INSCRIPCIÓN ABIERTA - Verde CAP unificado + dot pulsante === */
    .badge-inscripcion-abierta {
        background: #12883e;
        color: #ffffff;
        font-weight: 600;
        border: none;
        cursor: pointer;
        text-decoration: none;
        transition: background 0.2s ease;
    }
    
    .badge-inscripcion-abierta:hover {
        background: #0e6b30;
        text-decoration: none;
        color: #ffffff;
    }
    
    .badge-inscripcion-abierta .badge-dot {
        width: 8px;
        height: 8px;
        background: #4ade80;
        border-radius: 50%;
        display: inline-block;
        animation: badge-pulse 2s infinite;
    }
    
    @keyframes badge-pulse {
        0%, 100% { opacity: 1; transform: scale(1); }
        50% { opacity: 0.5; transform: scale(0.8); }
    }
    
    .badge-inscripcion-cerrada {
        background: rgba(255,255,255,0.15);
        color: #ffffff;
        font-weight: 600;
        border: 1px solid rgba(255,255,255,0.3);
    }
    
    /* ═══ Inline styles migrados al CSS — 13/03/2026 ═══ */
    
    /* Badge admisión (secondary) */
    .badge-admision {
        background: rgba(255,255,255,0.15);
        color: #ffffff;
        font-weight: 500;
        border: 1px solid rgba(255,255,255,0.35);
        font-size: var(--font-size-xs);
    }
    
    /* Botón inscripción en hero-action-card */
    .btn-inscripcion-action {
        background: #12883e !important;
        color: #ffffff !important;
        font-weight: 600;
        border: none;
        position: relative;
        overflow: hidden;
        transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
    }
    
    .btn-inscripcion-action:hover {
        background: #0e6b30 !important;
        transform: translateY(-1px);
        box-shadow: 0 4px 12px rgba(22, 163, 74, 0.35);
    }
    
    /* CTA final highlight — tono claro legible */
    .cta-final-highlight {
        display: block;
        color: var(--color-area-lighter) !important;
        font-size: clamp(1.1rem, 2.5vw, 1.35rem);
        font-weight: 500;
        margin-top: var(--space-2);
        line-height: 1.5;
    }
    
    /* CTA cierre inspiracional — tono más claro aún */
    .cta-cierre-inspiracional {
        font-style: italic;
        color: var(--color-area-lighter) !important;
        font-size: clamp(0.95rem, 2vw, 1.05rem);
        line-height: 1.6;
        margin: var(--space-4) auto var(--space-2);
        max-width: 600px;
        opacity: 0.95;
    }
    
    /* btn-primary — hereda color del área */
    .cta-final .btn-primary {
        background: var(--color-area) !important;
        color: #ffffff !important;
        font-weight: 600;
        border: none;
    }
    
    .cta-final .btn-primary:hover {
        background: var(--color-area-dark) !important;
        color: #ffffff !important;
    }
    
    /* section-text spacing */
    .section-text {
        margin-bottom: var(--space-6);
    }
    
    /* diferencial-intro spacing */
    .diferencial-intro {
        margin-top: var(--space-6);
        font-size: var(--font-size-sm);
        opacity: 0.85;
    }
    
    /* certificado-info */
    .certificado-info {
        margin-top: 1.5rem;
        padding: 1rem;
        background: linear-gradient(135deg, var(--gris-50, #fafafa) 0%, var(--gris-100, #f5f5f5) 100%);
        border-radius: var(--radius-md, 4px);
        border-left: 4px solid var(--color-area);
    }
    
    /* coordinacion-card — hereda del área */
    .coordinacion-card {
        background: linear-gradient(135deg, var(--color-area-lighter), var(--color-area-bg));
        border-left: 4px solid var(--color-area);
        border-radius: var(--radius-md, 4px);
        padding: var(--space-6);
        margin-bottom: var(--space-6);
    }
    
    .coordinacion-value {
        font-size: 0.95rem;
        line-height: 1.6;
    }


/* ═══ Badge states from Admin Panel ═══ */
    .badge-inscripcion-directo {
        background-color: #E8F5E9;
        color: #2E7D32;
    }
    .badge-inscripcion-admision {
        background-color: #FFF3E0;
        color: #c64500;
    }
    .badge-inscripcion-cupo {
        background-color: #FFEBEE;
        color: #C62828;
    }
    .badge-inscripcion-curso {
        background-color: #E3F2FD;
        color: #1565C0;
    }
    .badge-inscripcion-proxima {
        background-color: #FFFDE7;
        color: #b55d11;
    }
    .badge-inscripcion-cerrado {
        background-color: #ECEFF1;
        color: #546E7A;
    }
    .badge-inscripcion-suspendido {
        background-color: #ECEFF1;
        color: #546E7A;
    }
    .badge-inscripcion-sin_vacantes {
        background-color: #FFEBEE;
        color: #B71C1C;
    }
    
    .btn-inscripcion-abierta {
        background: linear-gradient(135deg, var(--color-area-dark) 0%, var(--color-area) 100%) !important;
        color: #ffffff !important;
        font-weight: 600;
        animation: pulse-btn 2s ease-in-out infinite;
        position: relative;
        overflow: hidden;
        transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
    }
    
    .btn-inscripcion-abierta::before {
        content: '';
        position: absolute;
        top: 0;
        left: -100%;
        width: 100%;
        height: 100%;
        background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
        animation: shine 3s ease-in-out infinite;
    }
    
    @keyframes shine {
        0% { left: -100%; }
        50%, 100% { left: 100%; }
    }
    
    @keyframes pulse-btn {
        0%, 100% { box-shadow: 0 4px 15px rgba(var(--color-area-rgb), 0.3); transform: scale(1); }
        50% { box-shadow: 0 6px 20px rgba(var(--color-area-rgb), 0.5); transform: scale(1.02); }
    }
    
    .btn-inscripcion-abierta:hover {
        background: var(--color-area-dark) !important;
        transform: scale(1.02);
        box-shadow: 0 8px 25px rgba(var(--color-area-rgb), 0.4);
    }
    
    .btn-inscripcion-cerrada {
        background: #727780 !important;
        color: #ffffff !important;
        font-weight: 600;
        cursor: not-allowed;
        opacity: 0.6;
        transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
    }
    
    .btn-inscripcion-cerrada:hover {
        background: #727780 !important;
        transform: none;
        cursor: not-allowed;
    }
    
    /* === #OrgulloUBA Section === */
    .orgullo-uba-section {
        margin-top: var(--space-8);
        padding-top: var(--space-6);
        border-top: 1px solid rgba(255,255,255,0.2);
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: var(--space-3);
    }
    
    .orgullo-uba-img {
        width: 120px;
        height: auto;
        border-radius: 2px;
        box-shadow: 0 4px 15px rgba(0,0,0,0.2);
        transition: transform 0.3s ease;
    }
    
    .orgullo-uba-img:hover {
        transform: scale(1.05);
    }
    
    .orgullo-uba-lema {
        font-size: var(--font-size-lg);
        font-weight: 600;
        color: var(--dorado-claro);
        letter-spacing: 0.05em;
        margin: 0;
    }


    /* Destacado Rankings UBA */
    .diferencial-rankings-title {
        font-size: var(--font-size-sm);
        font-weight: 700;
        color: var(--azul-uba);
        text-transform: uppercase;
        letter-spacing: 0.1em;
        margin-bottom: var(--space-4);
        padding-bottom: var(--space-2);
        border-bottom: 2px solid var(--color-area, var(--dorado-medio));
        display: inline-block;
    }
    
    /* Botón consultas académicas con color del área */
    .btn-consultas-academicas {
        background: transparent;
        border: 2px solid currentColor;
        color: inherit;
        transition: all 0.3s ease;
    }
    
    .btn-consultas-academicas:hover {
        background: var(--azul-hover);
        color: #ffffff;
    }
    
    /* Popup inscripción */
    .popup-overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 0.7);
        z-index: 9999;
        justify-content: center;
        align-items: center;
    }
    
    .popup-overlay.active {
        display: flex;
    }
    
    .popup-content {
        background: #ffffff;
        border-radius: 8px;
        padding: 2rem;
        max-width: 500px;
        width: 90%;
        max-height: 80vh;
        overflow-y: auto;
        position: relative;
        box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    }
    
    .popup-close {
        position: absolute;
        top: 1rem;
        right: 1rem;
        background: none;
        border: none;
        font-size: 1.5rem;
        cursor: pointer;
        color: #666;
    }
    
    .popup-close:hover {
        color: #000;
    }
    
    .popup-title {
        font-size: 1.25rem;
        font-weight: 700;
        color: var(--azul-uba);
        margin-bottom: 1rem;
    }
    
    .popup-steps {
        list-style: none;
        padding: 0;
        margin: 0;
    }
    
    .popup-steps li {
        display: flex;
        align-items: flex-start;
        gap: 1rem;
        margin-bottom: 1rem;
        padding-bottom: 1rem;
        border-bottom: 1px solid #e5e7eb;
    }
    
    .popup-steps li:last-child {
        border-bottom: none;
    }
    
    .step-number {
        background: var(--azul-uba);
        color: #ffffff;
        width: 28px;
        height: 28px;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        font-weight: 700;
        font-size: 0.875rem;
        flex-shrink: 0;
    }
    
    .step-content {
        flex: 1;
    }
    
    .step-title {
        font-weight: 600;
        color: #1f2937;
        margin-bottom: 0.25rem;
    }
    
    .step-desc {
        font-size: 0.875rem;
        color: #6b7280;
    }


    /* === BOTONES CTA CON DESCRIPCIÓN === */
    .cta-btn-group {
        display: flex;
        flex-wrap: wrap;
        gap: var(--space-4);
        justify-content: center;
        margin-bottom: var(--space-6);
    }
    
    .cta-btn-wrapper {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: var(--space-2);
        max-width: 200px;
    }
    
    .cta-btn-wrapper .btn {
        width: 100%;
        text-align: center;
    }
    
    .cta-btn-desc {
        font-size: 0.7rem;
        color: rgba(255, 255, 255, 0.7);
        text-align: center;
        line-height: 1.3;
        margin: 0;
    }
    
    .cta-secondary-buttons {
        display: flex;
        flex-wrap: wrap;
        gap: var(--space-3);
        justify-content: center;
        margin-bottom: var(--space-6);
    }
    
    @media (max-width: 768px) {
        .cta-btn-group {
            flex-direction: column;
            align-items: center;
        }
        
        .cta-btn-wrapper {
            width: 100%;
            max-width: 280px;
        }
    }
    .badge-inscripcion-temprana {
        background-color: #E8F5E9;
        color: #1B5E20;
    }
    .badge-inscripcion-regular {
        background-color: #E3F2FD;
        color: #0D47A1;
    }
    .badge-inscripcion-prorroga {
        font-weight: 700;
        background-color: #FFEBEE;
        color: #C62828;
    }
    .badge-inscripcion-fuera_de_termino {
        background-color: #E3F2FD;
        color: #1565C0;
    }
    .badge-inscripcion-proxima {
        background-color: #FFFDE7;
        color: #b55d11;
    }

    /* ============================================
       CLASES COMPLEMENTARIAS — sticky, popup, hero-content, cierre
       ============================================ */

    /* Wrapper interno del hero (primer hijo de .hero-grid) */
    .hero-content {
        display: flex;
        flex-direction: column;
        gap: var(--space-2);
    }

    /* Botón principal en el sticky mobile (reemplaza .sticky-cta-mobile .btn-primary) */
    .sticky-cta-btn {
        display: block;
        width: 100%;
        padding: 13px 20px;
        background: var(--color-area);
        color: var(--azul-profundo);
        font-weight: 700;
        font-size: var(--font-size-sm);
        text-align: center;
        text-transform: uppercase;
        letter-spacing: 0.5px;
        border-radius: var(--radius-sm);
        border: none;
        cursor: pointer;
        transition: opacity var(--transition-base), transform var(--transition-base);
        text-decoration: none;
    }

    .sticky-cta-btn:hover {
        opacity: 0.9;
        transform: translateY(-1px);
        color: var(--azul-profundo);
    }

    /* Footer del popup de inscripción */
    .popup-footer {
        margin-top: 1.25rem;
        padding-top: 1rem;
        border-top: 1px solid var(--gris-200);
        font-size: 0.8rem;
        color: var(--texto-terciario);
        text-align: center;
    }

    .popup-footer a {
        color: var(--azul-uba);
        font-weight: 500;
    }

    

    /* Estado "Próximamente" para maestrías con inscripción no abierta */
    .btn-inscripcion-proximamente {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: var(--space-2);
        padding: 14px 28px;
        background: var(--gris-200);
        color: var(--gris-600);
        font-weight: 600;
        font-size: var(--font-size-sm);
        text-transform: uppercase;
        letter-spacing: 0.5px;
        border-radius: var(--radius-sm);
        border: 1px solid var(--gris-300);
        cursor: not-allowed;
        text-decoration: none;
        opacity: 0.75;
        pointer-events: none;
    }

    /* Plan de estudios link wrapper */
    .plan-estudios-link {
        margin-top: var(--space-6);
    }
    
    /* Coordinación detail text */
    .coordinacion-detail {
        margin: 0;
        font-size: 0.9375rem;
        color: var(--azul-profundo);
    }

    /* ============================================
       DEFENSAS DE TESIS — Tesistas compactos + acordeón
       ============================================ */
    .defensas-lista {
        display: flex;
        flex-direction: column;
        gap: 8px;
        margin: var(--space-4) 0;
    }

    .defensa-tesista {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 10px 14px;
        background: var(--fondo-claro, #f8f9fa);
        border: 1px solid var(--gris-200);
        border-radius: var(--radius-md, 8px);
        transition: background 0.15s;
    }

    .defensa-tesista:hover {
        background: var(--gris-100, #f0f0f0);
    }

    .defensa-avatar {
        width: 40px;
        height: 40px;
        border-radius: 50%;
        object-fit: cover;
        flex-shrink: 0;
    }

    .defensa-tesista-info {
        flex: 1;
        min-width: 0;
    }

    .defensa-tesista-name {
        font-size: var(--font-size-sm);
        font-weight: 500;
        color: var(--azul-uba);
        display: block;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .defensa-tesista-actions {
        display: flex;
        gap: 6px;
        flex-shrink: 0;
    }

    .defensa-btn {
        display: inline-flex;
        align-items: center;
        gap: 4px;
        padding: 5px 10px;
        font-size: 0.75rem;
        font-weight: 500;
        border: 1px solid var(--color-area, var(--azul-uba));
        color: var(--color-area, var(--azul-uba));
        background: transparent;
        border-radius: 4px;
        cursor: pointer;
        transition: background 0.15s, color 0.15s;
        white-space: nowrap;
    }

    .defensa-btn:hover {
        background: var(--color-area-dark, var(--azul-hover)));
        color: #ffffff;
        transform: translateY(-1px);
    }

    .defensa-btn--eval {
        border-color: var(--gris-400);
        color: var(--gris-600);
        transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, color 0.18s ease;
    }

    .defensa-btn--eval:hover {
        background: var(--gris-600);
        color: #ffffff;
    }

    .defensa-dur {
        font-weight: 400;
        opacity: 0.7;
        font-size: 0.7rem;
    }

    /* Acordeón */
    .defensas-accordion {
        margin-top: 4px;
    }

    .defensas-accordion-toggle {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 10px 14px;
        font-size: var(--font-size-sm);
        font-weight: 500;
        color: var(--color-area, var(--azul-uba));
        cursor: pointer;
        border: 1px dashed var(--gris-300);
        border-radius: var(--radius-md, 8px);
        list-style: none;
        transition: background 0.15s;
    }

    .defensas-accordion-toggle:hover {
        background: var(--fondo-claro, #f8f9fa);
    }

    .defensas-accordion-toggle::before {
        content: "▸";
        transition: transform 0.2s;
    }

    .defensas-accordion[open] .defensas-accordion-toggle::before {
        transform: rotate(90deg);
    }

    .defensas-accordion-toggle::-webkit-details-marker {
        display: none;
    }

    .defensas-cta {
        text-align: center;
        margin-top: var(--space-4);
    }

    /* Video modal */
    .video-modal-overlay {
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0,0,0,0.85);
        z-index: 10000;
        align-items: center;
        justify-content: center;
        padding: var(--space-4);
    }

    .video-modal-overlay.active {
        display: flex;
    }

    .video-modal {
        width: 100%;
        max-width: 900px;
        position: relative;
    }

    .video-modal-close {
        position: absolute;
        top: -40px;
        right: 0;
        background: none;
        border: none;
        color: #ffffff;
        font-size: 2rem;
        cursor: pointer;
        line-height: 1;
        padding: 0 8px;
        transition: opacity 0.2s;
    }

    .video-modal-close:hover {
        opacity: 0.7;
    }

    .video-modal-title {
        color: #ffffff;
        font-size: var(--font-size-sm);
        margin-bottom: var(--space-2);
        opacity: 0.9;
    }

    .video-modal-container {
        position: relative;
        padding-bottom: 56.25%;
        height: 0;
        overflow: hidden;
        border-radius: var(--radius-md, 8px);
    }

    .video-modal-container iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border: none;
    }

    @media (max-width: 600px) {
        .defensa-tesista {
            flex-wrap: wrap;
        }
        .defensa-tesista-actions {
            width: 100%;
            margin-top: 4px;
        }
        .defensa-avatar {
            width: 32px;
            height: 32px;
        }
    }
    /* ============================================
       PRODUCCIÓN ACADÉMICA — Libros + Tesis publicadas
       Reutilizable en cualquier maestría
       ============================================ */
    .produccion-subtitle {
        font-size: var(--font-size-lg);
        font-weight: 600;
        color: var(--azul-uba);
        margin: var(--space-6) 0 var(--space-3);
    }

    /* Libros — grid horizontal */
    .produccion-libros {
        display: flex;
        flex-direction: column;
        gap: var(--space-4);
    }

    .libro-card {
        display: flex;
        gap: var(--space-4);
        padding: var(--space-4);
        background: var(--fondo-claro, #f8f9fa);
        border: 1px solid var(--gris-200);
        border-radius: var(--radius-md, 8px);
    }

    .libro-cover {
        width: 100px;
        flex-shrink: 0;
    }

    .libro-cover img {
        width: 100%;
        border-radius: 4px;
        box-shadow: 0 2px 8px rgba(0,0,0,0.15);
    }

    .libro-info {
        flex: 1;
    }

    .libro-titulo {
        font-size: var(--font-size-base);
        font-weight: 600;
        color: var(--azul-uba);
        margin-bottom: 4px;
    }

    .libro-autores {
        font-size: var(--font-size-sm);
        color: var(--gris-700);
        margin-bottom: 2px;
    }

    .libro-editorial {
        font-size: var(--font-size-sm);
        color: var(--gris-500);
        margin-bottom: 8px;
    }

    .libro-desc {
        font-size: var(--font-size-sm);
        color: var(--gris-600);
        line-height: 1.5;
        margin-bottom: 8px;
    }

    .libro-link {
        font-size: var(--font-size-sm);
        font-weight: 500;
        color: var(--color-area, var(--azul-uba));
    }

    /* Tesis publicadas — lista compacta */
    .produccion-tesis {
        display: flex;
        flex-direction: column;
        gap: 6px;
    }

    .tesis-pub-item {
        display: flex;
        align-items: baseline;
        gap: 8px;
        padding: 8px 12px;
        background: var(--fondo-claro, #f8f9fa);
        border-left: 3px solid var(--color-area, var(--azul-uba));
        border-radius: 0 var(--radius-md, 8px) var(--radius-md, 8px) 0;
        flex-wrap: wrap;
    }

    .tesis-pub-autor {
        font-size: var(--font-size-sm);
        font-weight: 500;
        color: var(--azul-uba);
        flex-shrink: 0;
    }

    .tesis-pub-titulo {
        font-size: var(--font-size-sm);
        color: var(--gris-700);
        font-style: italic;
        flex: 1;
        min-width: 200px;
    }

    .tesis-pub-meta {
        font-size: 0.75rem;
        color: var(--gris-500);
        flex-shrink: 0;
    }

    .tesis-pub-link {
        font-size: 0.75rem;
        font-weight: 500;
        color: var(--color-area, var(--azul-uba));
        flex-shrink: 0;
    }

    .produccion-placeholder {
        font-style: italic;
        opacity: 0.85;
    }

    @media (max-width: 600px) {
        .libro-card {
            flex-direction: column;
        }
        .libro-cover {
            width: 80px;
        }
        .tesis-pub-item {
            flex-direction: column;
            gap: 2px;
        }
    }


/* Comparador en dropdown - separado visualmente */
.nav-dropdown-content .nav-comparador {
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    margin-top: 4px;
    padding-top: 12px;
}
.nav-dropdown-content .nav-comparador::before {
    content: '⚖';
    margin-right: 6px;
    font-size: 0.85em;
}

/* ============================================
   STICKY MOBILE CTA BAR
   ============================================ */
.mobile-cta-bar {
    display: none;
}

@media (max-width: 768px) {
    .mobile-cta-bar {
        display: flex;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: var(--azul-uba);
        padding: 10px 16px;
        gap: 10px;
        z-index: 500;
        box-shadow: 0 -4px 12px rgba(0,0,0,0.15);
    }
    .mobile-cta-bar a {
        flex: 1;
        text-align: center;
        padding: 12px 8px;
        font-size: 0.85rem;
        font-weight: 700;
        text-decoration: none;
        border-radius: 2px;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }
    .mobile-cta-bar .mcta-primary {
        background: var(--dorado-medio);
        color: var(--azul-uba);
    }
    .mobile-cta-bar .mcta-secondary {
        background: transparent;
        color: var(--blanco);
        border: 1.5px solid rgba(255,255,255,0.5);
    }
    /* Prevent content from being hidden behind the bar */
    body:has(.mobile-cta-bar) .footer {
        padding-bottom: 70px;
    }
}
