/* ============================================
       FICHA ESPECIALIZACIÓN — Tokens y data-area
       heredados de shared-components.css
       ============================================ */

    /* ============================================
       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;
    }
    
    @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: 1024px) {
        .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;
        }
    }
    
    /* ============================================
       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: 2.5rem 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: 1024px) {
        .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(--color-area-light, 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: 480px;
    }
    
    .hero-tags-row {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: var(--space-3);
        margin-bottom: var(--space-2);
    }
    
    .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-lighter);
        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: var(--color-area);
    }
    
    .meta-cursada .meta-value {
        color: var(--dorado-claro, #d4a853);
        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: #ffd4b8;
    }
    
    .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%, #7a6025 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: 1024px) {
        .content-wrapper {
            grid-template-columns: 1fr;
        }
    }
    
    .main-content {
        min-width: 0;
    }
    
    /* Sidebar Sticky */
    .sidebar {
        position: sticky;
        top: 100px;
        height: fit-content;
    }
    
    @media (max-width: 1024px) {
        .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;
    }

    .direccion-grid .autoridad-card:only-child { width: 100%; }
    .direccion-grid .autoridad-card { flex: 1 1 calc(50% - 0.75rem); min-width: 280px; }

    .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-card {
        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-foto--placeholder {
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--uba-azul, #1b4f72);
    }

    .autoridad-iniciales {
        font-size: 1.5rem;
        font-weight: 700;
        color: #fff;
        letter-spacing: 0.05em;
    }
    
    .autoridad-info {
        flex: 1;
    }
    
    @media (max-width: 480px) {
        .autoridad-card {
            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: heredado de shared-components.css */

    /* ============================================
       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: 480px;
        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: #7a6025;
        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: 480px;
        line-height: 1.6;
    }
    
    .diferencial-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-4);
    }
    
    @media (max-width: 768px) {
        .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: 768px) {
        .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: 768px) {
        .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: 1024px) {
        .footer-grid {
            grid-template-columns: 1fr 1fr;
        }
        .footer-brand {
            grid-column: 1 / -1;
        }
    }
    
    @media (max-width: 768px) {
        .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: 768px) {
        .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: heredado de shared-components.css */

    /* ============================================
       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: 768px) {
        .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: 2px;
        color: var(--color-area);
    }
    .competencia-icon svg {
        width: 20px;
        height: 20px;
    }
    .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, #6b1e4d 0%, #952B6C 100%);
        color: #ffffff;
    }
    .badge-sustentabilidad {
        background: linear-gradient(135deg, #4a9a2a 0%, #6bbf3a 100%);
        color: #1d2554;
    }
.badge-proyecto {
        background: linear-gradient(135deg, #e0671c 0%, #ff7621 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);
    }
    /* ═══ 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;
        }
    }

    
    /* === CORRECCIONES DE ACCESIBILIDAD WCAG 2.1 AA === */
    
    /* Botón inscripción - usa color de área para coherencia visual */
    .btn-inscripcion-abierta {
        background: linear-gradient(135deg, var(--color-area-dark) 0%, var(--color-area) 100%) !important;
    }
    
    /* Badges de área - texto oscuro para colores claros */
    .badge-urbanismo,
    .badge-proyecto,
    .badge-gestion,
    .badge-sustentabilidad {
        color: #1f2937 !important;
    }
    
    /* Badges de área - texto blanco para colores oscuros */
    .badge-diseno,
    .badge-patrimonio {
        color: #ffffff !important;
    }
    
    /* Slogan del hero - asegurar legibilidad */
    .hero-slogan {
        text-shadow: 0 1px 2px rgba(0,0,0,0.1);
    }

    
    /* Rankings numbers - fondo con contraste */
    .ranking-number {
        text-shadow: 0 1px 1px rgba(0,0,0,0.1);
    }
    
    /* CTA highlight - asegurar contraste */
    .cta-final-highlight {
        text-shadow: 0 1px 2px rgba(0,0,0,0.2);
    }
    
    /* Formando Futuro - dorado institucional */
    .formando-futuro {
        color: var(--dorado-claro) !important;
    }

    
    
    /* ═══ 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: 480px;
        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;
    }


/* ═══ FAQs ═══ */
    .faq-section {
        padding: 2.5rem 0;
        background: var(--gris-50);
    }
    
    .faq-list {
        max-width: 800px;
        margin: 0 auto;
    }
    
    .faq-item {
        background: var(--blanco);
        border-radius: 8px;
        margin-bottom: var(--space-2);
        box-shadow: var(--shadow-sm);
        overflow: hidden;
    }
    
    .faq-question {
        width: 100%;
        padding: var(--space-3) var(--space-5);
        background: none;
        border: none;
        cursor: pointer;
        display: flex;
        justify-content: space-between;
        align-items: center;
        font-size: var(--font-size-base);
        font-weight: 500;
        color: var(--texto-principal);
        text-align: left;
        transition: background var(--transition-base);
    }
    
    .faq-question:hover {
        background: var(--gris-50);
    }
    
    .faq-icon {
        font-size: 1.5rem;
        color: var(--azul-uba);
        transition: transform var(--transition-base);
    }
    
    .faq-item.active .faq-icon {
        transform: rotate(45deg);
    }
    
    .faq-answer {
        max-height: 0;
        overflow: hidden;
        transition: max-height 0.3s ease, padding 0.3s ease;
    }
    
    .faq-item.active .faq-answer {
        display: block;
        max-height: 500px;
        padding: 0 var(--space-5) var(--space-4);
    }
    
    .faq-answer p {
        color: var(--texto-secundario);
        line-height: 1.7;
    }
    .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;
    }

    

    /* 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);
    }

    /* ============================================
       PRODUCCIÓN ACADÉMICA — hereda de ficha-maestria
       Duplicado para especializaciones que lo necesiten
       ============================================ */
    .produccion-subtitle {
        font-size: var(--font-size-lg);
        font-weight: 600;
        color: var(--azul-uba);
        margin: var(--space-6) 0 var(--space-3);
    }

    .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)); }

    .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: 480px) {
        .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;
}
