:root {
    --color-snte-naranja: #F37021; /* Naranja institucional SNTE */
    --color-snte-naranja-oscuro: #D15F1C; /* Naranja más oscuro para hover */
    --color-texto-oscuro: #2c3e50;
    --color-texto-suave: #607d8b;
    --color-blanco: #ffffff;
    --color-fondo-pagina: #f8f9f9; /* Blanco roto muy claro para el fondo */
}
/* =========================================
   Estilos Base del Nuevo Menú
   ========================================= */
.menu-toggle { display: none; }
.menu-close { display: none; }
.logo-menu-movil { display: none; }
.texto-menu-movil{ display: none; }
.nombre-red { display: none; /* Oculto en escritorio */ }

.menu-navegacion {
    display: flex;
    flex: 1;
    justify-content: space-between;
    align-items: center;
}

.item-red {
    display: flex;
    align-items: center;
    text-decoration: none;
}

/* =========================================
   7. Diseño Responsivo (Hamburguesa Avanzada)
   ========================================= */
@media (max-width: 1024px) { 
    
    /* Botón Hamburguesa */
    .menu-toggle {
        display: block;
        background: transparent;
        border: none;
        font-size: 2rem;
        color: var(--color-snte-naranja);
        cursor: pointer;
    }

    /* Diseño del Panel Deslizante */
    .menu-navegacion {
        position: fixed;
        top: 0;
        right: -100%; /* Oculto a la derecha */
        width: 300px;
        height: 100vh;
        background-color: var(--color-blanco);
        box-shadow: -5px 0 25px rgba(0,0,0,0.15);
        flex-direction: column;
        justify-content: flex-start; /* Alineamos todo hacia arriba */
        align-items: flex-start;
        padding: 80px 30px 40px 30px; /* Espacio interno de la tarjeta */
        transition: right 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);
        z-index: 1000;
    }

    /* Clase para mostrar el menú */
    .menu-navegacion.activo { right: 0; }

    /* Botón de la X incrustado adentro */
    .menu-close {
        display: block;
        position: absolute;
        top: 20px;
        right: 25px;
        background: transparent;
        border: none;
        font-size: 2rem;
        color: var(--color-snte-naranja);
        cursor: pointer;
        transition: color 0.3s;
    }
    .menu-close:hover { color: var(--color-snte-naranja); }

    /* Ajuste del botón de bases para el móvil */
    .centro-header { 
        width: 100%; 
        margin-bottom: 30px; 
        text-align: center; 
        flex: none; /* <--- ESTA ES LA CLAVE: Evita que se estire verticalmente */
    }
    
    .btn-bases { 
        width: 100%; 
        justify-content: center; 
        padding: 12px 0; 
        border-radius: 50px; /* Aseguramos que mantenga la forma redondita */
    }

    /* Formato Vertical de Redes Sociales */
    .redes-sociales {
        flex-direction: column;
        gap: 20px;
        width: 100%;
        margin-bottom: 20px;
    }

    .item-red {
        gap: 15px; /* Separación entre el círculo y el texto */
    }

    .nombre-red {
        display: block; /* Mostramos el texto en celular */
        font-size: 1.1rem;
        font-weight: 600;
        color: var(--color-texto-oscuro);
        transition: color 0.3s;
    }
    
    .item-red:hover .nombre-red {
        color: var(--color-snte-naranja);
    }

    /* Logo anclado hasta abajo */
    .logo-menu-movil {
        display: block;
        margin-top: auto; /* Empuja el logo mágicamente hasta el fondo */
        width: 100%;
        text-align: center;
        border-top: 1px solid #eee;
        padding-top: 30px;
    }

    .logo-menu-movil img {
        height: 90px;
        width: auto;
        opacity: 0.9;
    }

    /* Ajustes para el logo de la barra principal */
    .identidad-institucional { flex: 1; gap: 10px; }
    .logo-snte-grande { height: 50px; }
    .nombre-completo-sindicato { font-size: 0.75rem; }
    .seccion-institucional-ipn { font-size: 1.25rem; }
    /* Ocultamos el texto redundante en móviles para limpiar la barra */
    .panel-texto-identidad {
        display: none;
    }

    /* Le damos un poco más de tamaño al logo para que luzca bien */
    .logo-snte-grande { 
        height: 65px; /* Un tamaño ideal para que se lea todo lo que dice la imagen */
    }

    /* Aseguramos que el logo y la hamburguesa se separen a los extremos */
    .contenedor-header { 
        padding: 0 20px; 
        justify-content: space-between;
    }
    .panel-texto-identidad { 
        display: none; 
    }

    /* 2. Le damos espacio al logo superior para que luzca solo */
    .logo-snte-grande { 
        height: 65px; 
    }

    /* 3. Estilos para el bloque del logo y texto DENTRO del menú de hamburguesa */
    .texto-menu-movil {
        display: flex;
        flex-direction: column;
        align-items: center;
        margin-top: auto; /* Anclado al fondo */
        width: 100%;
        text-align: center;
        padding-bottom: 15px;
    }

    .logo-menu-movil img {
        height: 80px;
        width: auto;
        opacity: 0.95;
        margin-bottom: 15px; /* Separación con el texto */
    }

    .texto-menu-movil {
        display: flex;
        flex-direction: column;
        gap: 5px;
    }

    .nombre-sindicato-movil {
        font-size: 0.8rem;
        color: var(--color-texto-suave);
        font-weight: 500;
        line-height: 1.2;
    }

    .seccion-ipn-movil {
        font-size: 1rem;
        font-weight: 800;
        color: var(--color-snte-naranja);
    }
    .encabezado-pagina h1 {
        font-size: 2rem; /* Título principal más grande y prominente */
    }
}

.btn-bases {
    display: inline-flex;
    align-items: center;
    justify-content: center; 
    background-color: transparent;
    color: var(--color-snte-naranja); 
    text-decoration: none;
    
    /* ¡LA MAGIA DE CLAMP! 
       padding: arriba/abajo(10px) izquierda/derecha(dinámico) 
       Mínimo 20px, ideal 5vw (5% de la pantalla), Máximo 100px */
    padding: 10px clamp(20px, 5vw, 100px); 
    
    /* Quitamos el width: 100% y el max-width para que el clamp haga el trabajo */
    white-space: nowrap; 

    border: 2px solid var(--color-snte-naranja); 
    border-radius: 50px; 
    font-weight: 600;
    font-size: 0.95rem;
    letter-spacing: 0.5px; 
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1); 
}

/* Efecto al pasar el cursor (se llena de color) */
.btn-bases:hover {
    background-color: var(--color-snte-naranja); /* Fondo naranja */
    color: var(--color-blanco); /* Texto blanco */
    transform: translateY(-3px); /* Se eleva un poco más */
    box-shadow: 0 6px 15px rgba(243, 112, 33, 0.25); /* Sombra naranja resplandeciente */
}

/* Efecto al hacer clic */
.btn-bases:active {
    transform: translateY(0);
    box-shadow: 0 2px 5px rgba(243, 112, 33, 0.15);
}
