/* Paleta de colores basada en la imagen azul */
:root {
    --azul-oscuro: #005187;
    --azul-medio: #4d82bc;
    --azul-claro: #84b6f4;
    --azul-muy-claro: #c4dafa;
    --blanco-puro: #fcffff;
    --gris-fondo-tarjeta: #f0f4f8;
}

/* Reset básico */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Segoe UI', Arial, sans-serif;
    /* Imagen de fondo tecnológica */
    background-image: url("../img/foto-fondo.png");
    background-size: cover;
    background-attachment: fixed;
    padding: 40px;
    color: #333;
}

/* CONTENEDOR TEXTO PERFIL */
.seccion-texto {
    margin-bottom: 25px;
}

/* CONTENEDOR PRINCIPAL */
.contenedor-principal {
    display: flex;
    max-width: 1000px;
    margin: 0 auto;
    border-radius: 30px;
    overflow: hidden;
    background-color: var(--azul-muy-claro);
    box-shadow: 0 10px 25px rgba(0,0,0,0.2);
}

/* SIDEBAR (Izquierda) */
.sidebar {
    width: 30%;
    padding: 50px 20px;
    display: flex;
    flex-direction: column;
    align-items: center; /* Centra todo el contenido del sidebar */
    text-align: center;
}

/* Centrado específico del bloque de perfil */
.perfil-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
}

.foto-perfil {
    width: 140px;
    height: 140px;
    background-color: white;
    border-radius: 50%;
    padding: 8px;
    margin-bottom: 25px;
    object-fit: cover;
    display: block; 
}

.enlaces-sidebar {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 20px;
}

.boton-link {
    background-color: white;
    color: var(--azul-medio);
    text-decoration: none;
    padding: 12px;
    border-radius: 12px;
    font-weight: bold;
    transition: 0.3s;
}

.boton-link:hover {
    background-color: var(--azul-oscuro);
    color: white;
}

/* CONTENIDO (Derecha) */
.contenido-blanco {
    width: 70%;
    background-color: white;
    padding: 50px;
}

.titulo-seccion {
    color: var(--azul-oscuro);
    border-left: 5px solid var(--azul-medio);
    padding-left: 15px;
    margin-bottom: 25px;
    font-size: 1.4rem;
}

/* Tarjetas */
.contenedor-flex {
    display: flex;
    flex-wrap: wrap; 
    gap: 20px;
    margin-bottom: 40px;
}
.detalle {
    display: flex;
    flex-wrap: wrap;
    margin-top: 5px;
}

.tarjeta {
    background-color: var(--gris-fondo-tarjeta);
    padding: 25px;
    border-radius: 18px;
    flex: 1 1 45%; 
    border-bottom: 20px solid var(--azul-claro);
}

/* HABILIDADES (Cajitas) */
/* CONTENEDOR DE HABILIDADES (Ajustado) */
.habilidades-tags {
    display: flex;
    flex-wrap: wrap;      /* Esto permite que las etiquetas bajen a la siguiente línea */
    gap: 12px;            /* Espacio entre etiquetas */
    justify-content: center; /* Centra las etiquetas en móviles para que se vea más limpio */
}

.habilidad-tag {
    background-color: var(--azul-muy-claro);
    color: var(--azul-oscuro);
    padding: 10px 20px;
    border-radius: 25px;
    font-size: 0.9rem;
    font-weight: bold;
    white-space: nowrap;  /* Evita que el texto de una etiqueta se rompa en dos líneas */
    transition: all 0.3s ease;
    border: 1px solid transparent;
}

.habilidad-tag {
    background-color: var(--azul-muy-claro);
    color: var(--azul-oscuro);
    padding: 8px 18px;
    border-radius: 25px;
    font-size: 0.85rem;
    font-weight: bold;
}

/* BARRAS DE PROGRESO */
.barra-item {
    flex: 0 1 45%;
    margin-bottom: 20px;
    min-width: 200p;
}

.barra-fondo {
    background-color: #e0e0e0;
    height: 10px;
    border-radius: 10px;
    margin-top: 8px;
}

.barra-relleno {
    background: linear-gradient(to right, var(--azul-oscuro), var(--azul-claro));
    height: 100%;
    border-radius: 10px;
}

/* FOOTER (Como el main, estilo cajón) */
.footer-cajon {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 1000px;
    margin: 30px auto; /* Separado del main */
    padding: 25px 50px;
    background-color: var(--azul-muy-claro);
    border-radius: 25px; /* Bordes redondeados como el main */
    box-shadow: 0 10px 25px rgba(0,0,0,0.1);
}

.footer-cajon p {
    font-size: 0.9rem;
    color: var(--azul-medio);
    font-weight: 500;
}

.links-footer {
    display: flex;
    gap: 20px;
}

.links-footer a {
    text-decoration: none;
    color: var(--azul-oscuro);
    font-weight: bold;
    font-size: 0.9rem;
    transition: color 0.3s;
}

.links-footer a:hover {
    color: var(--azul-claro);
}

/* --- MEDIA QUERY (Móvil) --- */
@media (max-width: 768px) {
    body { padding: 15px; }

    .contenedor-principal { flex-direction: column; }

    .sidebar, .contenido-blanco { width: 100%; }

    .tarjeta, .barra-item { flex: 1 1 100%; }

    .footer-cajon {
        flex-direction: column;
        gap: 20px;
        text-align: center;
        padding: 30px 20px;
        margin: 20px 0;
    }
    
    .links-footer {
        justify-content: center;
        width: 100%;
    }
    
}
/* --- EFECTO HOVER PARA TODAS LAS CAJITAS --- */

/* 1. Definimos qué elementos queremos animar y les damos suavidad */
.tarjeta, 
.boton-link,
.foto-perfil, 
.habilidad-tag, 
.links-footer a {
    transition: transform 0.3s ease, box-shadow 0.3s ease; /* Duración de 0.3 segundos */
    will-change: transform; /* Optimiza el rendimiento de la animación */
}

/* 2. Aplicamos el movimiento hacia arriba al pasar el ratón */
.tarjeta:hover, 
.boton-link:hover, 
.foto-perfil:hover,
.habilidad-tag:hover, 
.links-footer a:hover {
    transform: translateY(-10px); /* Se eleva 10 píxeles */
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.15); /* Añade una sombra más profunda para dar profundidad */
}

/* 3. Ajuste opcional para las etiquetas de habilidades (más sutil) */
.habilidad-tag:hover {
    transform: translateY(-4px); /* Un movimiento más pequeño para elementos pequeños */
    background-color: var(--azul-oscuro);
    color: white;
}