/* =============================================
   VARIABLES Y ESTILOS GLOBALES
   ============================================= */
:root {
    --color-background: #111111;
    --color-text-primary: #FFFFFF;
    --color-text-secondary: #A0A0A0;
    --color-accent: #1b5d9e;
    --color-nav-bg: rgba(28, 28, 28, 0.7);
    --color-nav-border: #333333;
    --font-primary: 'Poppins', sans-serif;
    --font-display: 'Montserrat', sans-serif; 
}

/* Reseteo básico */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    font-size: 62.5%;
    /* 1 rem = 10px */
    scroll-behavior: smooth;
}

body {
    background-color: var(--color-background);
    font-family: var(--font-primary);
    color: var(--color-text-primary);
    font-size: 1.6rem;
    overflow-x: hidden;
}

a {
    text-decoration: none;
    color: inherit;
}

ul {
    list-style: none;
}
/* =============================================
   TEMA CLARO (LIGHT THEME)
   ============================================= */

/* --- Transición suave al cambiar de tema --- */
body, .card, .pricing-card, .post-card, .footer, .popup-content, .accordion__item {
    transition: background-color 0.4s ease, color 0.4s ease, border-color 0.4s ease;
}

/* Cuando el body tiene la clase .light-theme, estas reglas se aplican */
body.light-theme {
    /* 1. Cambiamos las variables de color principales */
    --color-background: #f1f1f1;
    --color-text-primary: #3a3a3a;
    --color-text-secondary: #555555;
    --color-nav-bg: rgba(255, 255, 255, 0.7);
    --color-nav-border: #DDDDDD;
}

/* 2. Movemos el interruptor del tema */
body.light-theme .theme-switcher__toggle {
    transform: translateX(30px);
    background-color: var(--color-accent);
}

/* 3. Ajustamos los fondos de las tarjetas y otros elementos */
body.light-theme .card--testimonial,
body.light-theme .pricing-card,
body.light-theme .popup-content {
    background-color: #FFFFFF; /* Mantenemos el fondo blanco para estas tarjetas */
    border-color: #EAEAEA;
}

/* 4. Ajustamos el acordeón para que no tenga fondo (sea "transparente") */
body.light-theme .accordion__item {
    /* Al no definir un 'background-color', heredará el del body (#F1F1F1) */
    border-color: #EAEAEA; /* Mantenemos el borde para la separación visual */
}

/* 5. Ajustamos el fondo de los formularios */
body.light-theme .footer__contact-form textarea,
body.light-theme .popup-form-container select {
    background-color: #EAEAEA;
    border-color: #D0D0D0;
    color: var(--color-text-primary);
}

/* 6. Ajustamos el color de los títulos de las tarjetas de precios */
body.light-theme .pricing-card__title {
    color: var(--color-text-primary);
}
/* =============================================
   HEADER / NAVEGACIÓN
   ============================================= */
.header {
    position: fixed;
    top: 2rem;
    left: 50%;
    transform: translateX(-50%);
    width: 95%;
    max-width: 500px;
    z-index: 100;
}

.navbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    background-color: var(--color-nav-bg);
    border: 1px solid var(--color-nav-border);
    border-radius: 50px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    /* Para Safari */
}

.navbar__logo img {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
}

.navbar__menu {
    display: flex;
    gap: 2rem;
}

.navbar__link {
    font-size: 1.4rem;
    color: var(--color-text-secondary);
    transition: color 0.3s ease;
}

.navbar__link:hover {
    color: var(--color-text-primary);
}

.navbar__cta {
    background-color: var(--color-text-primary);
    color: var(--color-background);
    padding: 0.8rem 1.8rem;
    border-radius: 30px;
    font-size: 1.4rem;
    font-weight: 500;
    transition: transform 0.3s ease;
}

.navbar__cta:hover {
    transform: scale(1.05);
}
/* --- Estilos para el Menú de Idiomas --- */

/* --- Estilos para el Menú de Idiomas (VERSIÓN CORREGIDA) --- */
.nav-item--language {
    position: relative;
}

/* El nuevo envoltorio invisible */
.language-dropdown-wrapper {
    position: absolute;
    top: 50%; /* Lo alineamos con el ícono */
    left: 50%;
    transform: translateX(-50%);
    padding-top: 1.5rem; /* Este padding es el "puente" invisible */
    
    /* Lo hacemos invisible e inactivo por defecto */
    display: none;
    pointer-events: none; 
}

/* El menú desplegable dentro del envoltorio */
.language-dropdown {
    background-color: var(--color-nav-bg);
    border: 1px solid var(--color-nav-border);
    border-radius: 10px;
    padding: 0.5rem;
    list-style: none;
    z-index: 120;
    pointer-events: auto; /* Hacemos que el menú sí sea clickeable */
}

/* LA MAGIA: Mostramos el envoltorio (y por tanto el menú) al hacer hover sobre el <li> */
.nav-item--language:hover .language-dropdown-wrapper {
    display: block;
}

/* (El resto de tus estilos para los botones no necesita cambios) */
.language-dropdown li button {
    background: none;
    border: none;
    color: var(--color-text-secondary);
    padding: 0.8rem 1.5rem;
    cursor: pointer;
    font-size: 1.4rem;
    font-family: var(--font-primary);
    width: 100%;
    text-align: left;
    border-radius: 5px;
    transition: background-color 0.2s, color 0.2s;
}

.language-dropdown li button:hover {
    background-color: var(--color-accent);
    color: var(--color-background);
}
/* =============================================
   HEADER DINÁMICO CON SCROLL
   ============================================= */

/* Ajustes al contenedor principal del header */
.header {
    transition: all 0.4s ease-in-out;
}

.navbar, .status-bar {
    transition: opacity 0.4s ease, transform 0.4s ease;
}


/* --- Estilo de la barra de estado "Available for work" --- */
.status-bar {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    opacity: 0;
    pointer-events: none; /* No se puede hacer clic cuando está oculta */
}

.status-bar__link {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.8rem 1.5rem;
    background-color: var(--color-nav-bg);
    border: 1px solid var(--color-nav-border);
    border-radius: 50px;
    backdrop-filter: blur(10px);
}

.status-bar__avatar {
    width: 30px;
    height: 30px;
    border-radius: 50%;
}

.status-bar__text {
    font-size: 1.4rem;
    font-weight: 500;
    color: var(--color-text-primary);
}

.status-bar__indicator {
    width: 8px;
    height: 8px;
    background-color: #25D366; /* Verde brillante */
    border-radius: 50%;
    animation: blink 1.5s infinite ease-in-out;
}

/* --- Animación del punto parpadeante --- */
@keyframes blink {
    0%, 100% {
        opacity: 1;
        box-shadow: 0 0 5px #25D366;
    }
    50% {
        opacity: 0.3;
        box-shadow: none;
    }
}


/* --- Lógica de visibilidad controlada por JS --- */
/* Cuando el header tiene la clase .header--scrolled-down... */

/* 1. Ocultamos la barra de navegación completa */
.header--scrolled-down .navbar {
    opacity: 0;
    transform: translateY(-20px);
    pointer-events: none;
}

/* 2. Mostramos la barra de estado */
.header--scrolled-down .status-bar {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
}
/* =============================================
   AJUSTES DE TIPOGRAFÍA PARA TÍTULOS DISPLAY
   ============================================= */
.services__title,
.accordion__title,
.faq__title, /* <-- Apliquémoslo también al título de FAQ para consistencia */
.testimonials__title, /* <-- Y al de testimonios */
.blog__title, /* <-- Y al de cursos */
.featured-projects__title, /* <-- Y a los de proyectos */
.projects__title { /* <-- Y a los de más proyectos */
    font-family: var(--font-display);
    font-weight: 900; /* Usa 900 para el grosor 'Black'. Si prefieres un poco menos, usa 800 */
    text-transform: uppercase; /* Para asegurar que siempre estén en mayúsculas */
    letter-spacing: 0.05em; /* Un poco de espacio extra entre letras, como en la referencia */
}
/* =============================================
   SECCIÓN PRINCIPAL / HERO
   ============================================= */
.hero {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    padding: 8rem 2rem;
    /* Espacio para el header */
}

.hero__content {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 3rem;
    position: relative;
}

.hero__title {
    font-size: clamp(4rem, 10vw, 12rem);
    /* Tamaño de fuente adaptable */
    font-weight: 900;
    letter-spacing: 0.1em;
    color: var(--color-text-primary);
}

.hero__image-wrapper {
    position: relative;
    flex-shrink: 0; /* Mantenemos esta propiedad importante */
    /* Hereda el tamaño del contenedor de la imagen para no romper el layout */
    width: clamp(200px, 30vw, 320px);
    height: clamp(280px, 42vw, 450px);
}


/* MODIFICA LA REGLA EXISTENTE '.hero__image-container' */
.hero__image-container {
    /* position: relative; Ya no necesita esta línea, la hemos movido al wrapper */
    width: 100%; /* Hacemos que ocupe todo el espacio del nuevo wrapper */
    height: 100%; /* Hacemos que ocupe todo el espacio del nuevo wrapper */
    border-radius: 25px;
    overflow: hidden; /* Esto es lo que causaba el problema, pero ahora no afecta al ícono */
    /* flex-shrink: 0; Ya no necesita esta línea, la hemos movido al wrapper */
    box-shadow: 0 8px 30px var(--color-text-primary);
}

.hero__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Busca esta regla en tu styles.css */
.hero__icon-float {
    position: absolute;
    bottom: 2rem;
    left: -3rem;
    width: 80px;
    height: 80px;
    background-color: var(--color-accent);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 3rem;
    color: var(--color-background);
    cursor: pointer;
    transition: transform 0.3s ease;
    z-index: 5; /* <--- AÑADE ESTA LÍNEA */
}

.hero__icon-float:hover {
    transform: scale(1.1) rotate(-15deg);
}
/* Modifica esta regla para que el texto sea visible por defecto */
.hero__icon-text {
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--color-background);
    position: absolute; /* Mantenemos esto */
    transition: opacity 0.4s ease, transform 0.4s ease; /* Mantenemos esto */
    /* Nos aseguramos de que no tenga opacity: 0 ni transform: scale(0.5) */
}

/* AÑADE ESTA NUEVA CLASE que usará el JavaScript para la animación */
.hero__icon-text.is-fading {
    opacity: 0;
    transform: translateY(10px);
}
.hero__text-right {
    display: flex;
    flex-direction: column;
}

.hero__description {
    font-size: 1.6rem;
    color: var(--color-text-secondary);
    max-width: 25ch;
    /* Limita el ancho del texto */
    line-height: 1.6;
    margin-top: -1rem;
    /* Ajuste para acercarlo al título */
}

/* =============================================
   SWITCH DE TEMA
   ============================================= */
.theme-switcher {
    position: fixed;
    bottom: 3rem;
    left: 50%;
    transform: translateX(-50%);
    background-color: #252525;
    width: 60px;
    height: 30px;
    border-radius: 20px;
    padding: 5px;
    cursor: pointer;
    z-index: 10000;
}

.theme-switcher__toggle {
    width: 20px;
    height: 20px;
    background-color: #525252;
    border-radius: 50%;
    transition: transform 0.3s ease;
}


/* =============================================
   ESTILOS PARA EL MENÚ RESPONSIVE MÓVIL
   ============================================= */

/* Por defecto (escritorio), ocultamos el menú móvil */
.mobile-nav-container {
    display: none;
}
.mobile-menu {
    display: none;
}

/* --- Estilos para los botones de idioma en el menú móvil --- */
.mobile-menu__languages {
    display: flex;
    justify-content: center;
    gap: 1rem;
    padding: 1.5rem 0;
    border-top: 1px solid var(--color-nav-border);
    margin: 1rem 1rem 0 1rem;
}

.mobile-menu__languages .language-switcher {
    background: none;
    border: 1px solid var(--color-text-secondary);
    color: var(--color-text-secondary);
    padding: 0.8rem 1.2rem;
    font-size: 1.2rem;
    border-radius: 20px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.mobile-menu__languages .language-switcher:hover {
    background-color: var(--color-accent);
    border-color: var(--color-accent);
    color: var(--color-background);
}
/* =============================================
   SECCIÓN DE SERVICIOS / WHAT I CAN DO
   ============================================= */
.services {
    padding: 10rem 2rem;
    overflow: hidden;
    /* Evita que la imagen rotada cree scroll horizontal */
}

.services__container {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8rem;
    align-items: center;
}

.services__title {
    font-size: clamp(2.8rem, 5vw, 4rem);
    margin-bottom: 1.5rem;
}

.services__subtitle {
    font-size: 1.6rem;
    color: var(--color-text-secondary);
    max-width: 60ch;
    line-height: 1.7;
    margin-bottom: 4rem;
}

.services__image-container {
    border-radius: 25px;
    transition: transform 0.4s ease;
}

.services__image-container:hover {
    transform: rotate(6deg);
}

.services__image-container img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 25px;
}

/* --- Estilos del Acordeón --- */
.accordion {
    width: 100%;
}

.accordion__item {
    border-bottom: 1px solid var(--color-nav-border);
}

.accordion__item:first-child {
    border-top: 1px solid var(--color-nav-border);
}

.accordion__header {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 2.5rem 0;
    cursor: pointer;
    background: none;
    border: none;
    color: inherit;
    text-align: left;
}

.accordion__number {
    font-size: 1.6rem;
    font-weight: 500;
    color: var(--color-text-secondary);
    margin-right: 2rem;
    font-style: italic;
}
.accordion__bullet {
  font-size: 14px; /* Ajusta el tamaño de la bolita */
  margin-right: 10px; /* Añade espacio a la derecha */
  color: var(--color-accent); /* Cambia el color si quieres */
}
.accordion__title {
    font-size: 2.2rem;
    margin-right: auto;
}

.accordion__icon {
    font-size: 1.6rem;
    transition: transform 0.3s ease;
}

.accordion__content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease-out, padding 0.4s ease-out;
}

.accordion__list {
    list-style: none;
    padding: 0 0 2rem 4rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.accordion__list li {
    color: var(--color-text-secondary);
    font-size: 1.5rem;
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.accordion__list li i {
    color: var(--color-accent);
}

/* --- Estilos del Acordeón ACTIVO (Cuando se abre) --- */
.accordion__item.active .accordion__icon {
    transform: rotate(180deg);
}

.accordion__item.active .accordion__content {
    max-height: 300px;
    /* Un valor suficientemente grande para el contenido */
}

/* =======================================================
   CSS ADICIONAL PARA HOVER Y ESTADO ACTIVO DEL ACORDEÓN
   ======================================================= */

/* --- 1. Posicionamiento del item y de la imagen preview --- */

.accordion__item {
    position: relative;
    /* Indispensable para posicionar la imagen preview dentro */
}

.accordion__preview-img {
    position: absolute;
    bottom: -20%;
    /* Posición inicial, ligeramente debajo del item */
    right: 5%;
    width: 220px;
    height: 120px;
    border-radius: 15px;
    overflow: hidden;

    /* Estado inicial: Oculto */
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);

    /* Transición suave */
    transition: opacity 0.4s ease, transform 0.4s ease, visibility 0.4s;
    pointer-events: none;
    /* Para que no interfiera con el cursor */
}

.accordion__preview-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}


/* --- 2. Color del título al estar ACTIVO o en HOVER --- */

.accordion__item.active .accordion__title,
.accordion__item:hover .accordion__title {
    color: var(--color-accent);
    transition: color 0.3s ease;
}


/* --- 3. Efecto de aparición de la imagen en HOVER (sólo si NO está activo) --- */

.accordion__item:not(.active):hover .accordion__preview-img {
    /* Estado final: Visible */
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}


/* =============================================
   SECCIÓN DE TESTIMONIOS
   ============================================= */
.testimonials {
    padding: 10rem 2rem;
}

.testimonials__container {
    max-width: 1200px;
    margin: 0 auto;
    text-align: center;
    /* Centra el título y subtítulo */
}

.testimonials__title {
    font-size: clamp(2.8rem, 5vw, 4rem);
    margin-bottom: 1.5rem;
}

.testimonials__subtitle {
    font-size: 1.6rem;
    color: var(--color-text-secondary);
    max-width: 70ch;
    line-height: 1.7;
    margin: 0 auto 5rem auto;
    /* Centra el párrafo y le da margen inferior */
}

/* --- Parrilla (Grid) de Tarjetas --- */
.testimonials__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.5rem;
    text-align: left;
    /* Alinea el texto de las tarjetas a la izquierda */
}

/* --- Estilo Base de las Tarjetas --- */
.card {
    padding: 3rem;
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    transition: transform 0.3s ease, border-color 0.3s ease;
    border: 1px solid var(--color-background);
}

/* --- Tarjeta de Testimonio --- */
.card--testimonial {
    background-color: #1C1C1C;
    /* Un gris oscuro, no negro puro */
}

.card:hover {
    transform: translateY(-10px);
    border-color: var(--color-accent);
}
.card__rating {
    margin-bottom: 2rem;
    color: #FFD700;
    /* Color dorado para las estrellas */
}

.card__text {
    color: var(--color-text-secondary);
    font-size: 1.5rem;
    line-height: 1.6;
    flex-grow: 1;
    /* Empuja al autor hacia abajo */
}

.card__author {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-top: 2.5rem;
}

.author__avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    object-fit: cover;
}

.author__info {
    display: flex;
    flex-direction: column;
}

.author__name {
    font-weight: 700;
    color: var(--color-text-primary);
}

.author__title {
    font-size: 1.4rem;
    color: var(--color-text-secondary);
}

/* --- Tarjeta de Estadística --- */
.card--stat {
    justify-content: center;
    gap: 0.5rem;
}

.card__intro {
    font-size: 1.6rem;
    line-height: 1.5;
}

.card__stat-number {
    font-size: clamp(6rem, 10vw, 8rem);
    font-weight: 900;
    line-height: 1;
}

.card__stat-label {
    font-size: 1.9rem;
    font-weight: 700;
    font-style: italic;
}

/* Modificadores de color para tarjetas de estadística */
.card--light {
    background-color: var(--color-text-primary);
    color: var(--color-background);
}

.card--accent {
    background-color: var(--color-accent);
    color: var(--color-background);
}



/* =============================================
   SECCIÓN DE FAQ
   ============================================= */
.faq {
    padding: 10rem 2rem;
}

.faq__container {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 2fr;
    /* Columna izquierda más pequeña */
    gap: 8rem;
    align-items: start;
    /* Alinea los items al inicio */
}

.faq__title {
    font-size: clamp(2.8rem, 5vw, 4rem);
    margin-bottom: 1.5rem;
    line-height: 1.2;
}

.faq__subtitle {
    font-size: 1.6rem;
    color: var(--color-text-secondary);
    line-height: 1.7;
}

/* En el acordeón de FAQ, el título es un poco más pequeño que en Servicios */
.faq .accordion__title {
    font-size: 1.8rem;
}



/* =============================================
   SECCIÓN DE PRECIOS
   ============================================= */
.pricing {
    padding: 10rem 2rem;
}

.pricing__container {
    max-width: 1200px;
    margin: 0 auto;
}

.pricing__header {
    display: flex;
    align-items: center;
    gap: 2.5rem;
    margin-bottom: 6rem;
}

.pricing__title {
    font-size: clamp(2.8rem, 5vw, 4rem);
    font-weight: 700;
    text-transform: capitalize;
    /* Para que sea "Pricing" y no "PRICING" */
    white-space: nowrap;
    /* Evita que el título se rompa en dos líneas */
}

.pricing__divider {
    width: 100%;
    height: 1px;
    background-color: var(--color-nav-border);
}

/* --- Parrilla (Grid) de Precios --- */
.pricing__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 3rem;
}

/* --- Estilo de la Tarjeta de Precios --- */
.pricing-card {
    background-color: #1C1C1C;
    border: 1px solid #2a2a2a;
    border-radius: 20px;
    padding: 3rem;
    display: flex;
    flex-direction: column;
    transition: transform 0.3s ease, border-color 0.3s ease;
}

.pricing-card:hover {
    transform: translateY(-10px);
    border-color: var(--color-accent);
}

.pricing-card__title {
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--color-text-primary);
}

.pricing-card__description {
    font-size: 1.5rem;
    line-height: 1.6;
    color: var(--color-text-secondary);
    margin: 1rem 0 2.5rem 0;
}

.pricing-card__from {
    font-size: 1.4rem;
    color: var(--color-text-secondary);
}

.pricing-card__price {
    font-size: clamp(3.5rem, 5vw, 4.5rem);
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: 2.5rem;
}

.pricing-card__scope {
    font-size: 1.6rem;
    font-weight: 400;
    color: var(--color-text-secondary);
    margin-left: 0.5rem;
}

.pricing-card__features {
    list-style: none;
    margin-top: auto;
    /* Empuja la lista al fondo de la tarjeta */
    padding-top: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.pricing-card__features li {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 1.5rem;
    color: var(--color-text-secondary);
}
.pricing-card__features li:last-child {
    color: var(--color-text-primary); /* Cambia el color del texto a blanco/principal */
    font-style: italic;               /* Asegura que el texto esté en cursiva */
}

.pricing-card__features i.fa-check {
    color: var(--color-accent);
}

/* --- Nuevo Estilo de Botón Sólido --- */
.btn--solid {
    display: inline-block;
    width: 100%;
    text-align: center;
    padding: 1.4rem 3.5rem;
    background-color: var(--color-accent);
    color: var(--color-background);
    border: 2px solid var(--color-accent);
    border-radius: 50px;
    font-weight: 600;
    text-transform: uppercase;
    text-decoration: none;
    font-size: 1.4rem;
    transition: all 0.3s ease;
}

.btn--solid:hover {
    background-color: transparent;
    color: var(--color-accent);
}


/* =============================================
   SECCIÓN DEL BLOG
   ============================================= */
.blog {
    padding: 10rem 2rem;
}

.blog__container {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    /* Necesario para el círculo flotante */
}

.floating-dot {
    position: absolute;
    top: -2rem;
    left: -4rem;
    width: 25px;
    height: 25px;
    background-color: var(--color-accent);
    border-radius: 50%;
}

.blog__title {
    font-size: clamp(2.8rem, 5vw, 4rem);
    margin-bottom: 1.5rem;
}

.blog__subtitle {
    font-size: 1.6rem;
    color: var(--color-text-secondary);
    max-width: 75ch;
    line-height: 1.7;
}

/* --- Parrilla (Grid) de Posts --- */
.blog__posts-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 3rem;
    margin: 5rem 0;
}

/* --- Estilos de la Tarjeta del Post --- */
.post-card__image-link {
    display: block;
    overflow: hidden;
    border-radius: 15px;
}

.post-card__image {
    width: 100%;
    height: 280px;
    /* Altura fija para consistencia */
    object-fit: cover;
    border-radius: 15px;
    transition: transform 0.4s ease;
}

.post-card:hover .post-card__image {
    transform: scale(1.05);
}

.post-card__body {
    padding-top: 2rem;
}

.post-card__meta {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
    font-size: 1.4rem;
    color: var(--color-text-secondary);
}

.post-card__category {
    padding: 0.4rem 1.2rem;
    border-radius: 20px;
    background-color: rgba(196, 240, 73, 0.1);
    color: var(--color-accent);
    font-weight: 500;
}

.post-card__title a {
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--color-text-primary);
    text-decoration: none;
    transition: color 0.3s ease;
}

.post-card__title {
    margin-bottom: 1rem;
}

.post-card__title a:hover {
    color: var(--color-accent);
}

.post-card__excerpt {
    color: var(--color-text-secondary);
    font-size: 1.5rem;
    line-height: 1.6;
}


/* --- Botón de Llamada a la Acción (CTA) --- */
.blog__cta-container {
    text-align: center;
    margin-top: 2rem;
}

.btn--outline {
    display: inline-block;
    padding: 1.2rem 3.5rem;
    border: 2px solid var(--color-accent);
    color: var(--color-accent);
    background-color: transparent;
    border-radius: 50px;
    font-weight: 600;
    text-transform: uppercase;
    text-decoration: none;
    font-size: 1.4rem;
    transition: all 0.3s ease;
}

.btn--outline:hover {
    background-color: var(--color-accent);
    color: var(--color-background);
}



/* =============================================
   SECCIÓN DE PROYECTOS DESTACADOS (CON ANIMACIÓN)
   ============================================= */
.featured-projects {
    padding: 10rem 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4rem;
}

.featured-projects__container {
    width: 100%;
    max-width: 1100px;
}

.featured-projects__header {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

.featured-projects__header .dot {
    width: 20px;
    height: 20px;
    background-color: var(--color-accent);
    border-radius: 50%;
    flex-shrink: 0;
}

.featured-projects__title {
    font-size: clamp(2.8rem, 5vw, 4rem);
}

.featured-projects__subtitle {
    font-size: 1.6rem;
    color: var(--color-text-secondary);
    max-width: 70ch;
    line-height: 1.7;
    margin-bottom: 4rem;
}

.project-showcase {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: 20px;
    overflow: hidden;
}

/* --- ESTILOS PARA LA ANIMACIÓN --- */
.project-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: translateY(100%); /* Estado inicial: abajo y fuera */
    transition: transform 0.8s cubic-bezier(0.77, 0, 0.175, 1);
    display: flex;
    align-items: flex-end;
    padding: 4rem;
}

.project-slide.active {
    transform: translateY(0%);
    z-index: 10;
}

.project-slide.previous {
    transform: translateY(0%);
    z-index: 5;
}

/* --- Contenido de cada diapositiva --- */
.project-showcase__bg-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: transform 1.2s ease;
}

.project-slide.active .project-showcase__bg-image {
    transform: scale(1.05);
}

.project-showcase__bg-image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 60%);
}

.project-showcase__content {
    position: relative;
    z-index: 2;
    max-width: 55ch;
    color: var(--color-text-primary);
}

.project-showcase__category {
    display: inline-block;
    padding: 0.6rem 1.4rem;
    background-color: var(--color-accent);
    color: var(--color-background);
    border-radius: 20px;
    font-size: 1.4rem;
    font-weight: 500;
    margin-bottom: 1.5rem;
}

.project-showcase__title {
    font-size: clamp(2.5rem, 4vw, 3.5rem);
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 1rem;
}

.project-showcase__description {
    font-size: 1.5rem;
    line-height: 1.6;
    color: var(--color-text-secondary);
}

.project-cta-container {
    text-align: center;
    padding: 2rem 0 8rem 0; /* Espacio arriba y abajo del botón */
}
/* =============================================
   SECCIÓN DE MÁS PROYECTOS
   ============================================= */
.projects {
    padding: 10rem 2rem;
}

.projects__container {
    max-width: 1200px;
    margin: 0 auto;
}

.projects__header {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 4rem;
}

.projects__header .dot {
    width: 20px;
    height: 20px;
    background-color: var(--color-accent);
    border-radius: 50%;
    flex-shrink: 0;
    /* Evita que el punto se encoja */
}

.projects__title {
    font-size: clamp(2.8rem, 5vw, 4rem);
}

/* Usamos una parrilla idéntica a la del blog */
.projects__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 3rem;
}

/* Pequeño ajuste para que los títulos de los proyectos estén en mayúsculas como en el diseño */
.projects .post-card__title a {
    text-transform: uppercase;
}



/* =============================================
   ESTILOS PARA LA SECCIÓN DE HERO DE PROYECTO
   ============================================= */

.project-hero {
    padding: 10rem 2rem;
    text-align: center; /* Centramos todo el contenido */
}

.project-hero__container {
    max-width: 1000px; /* Ancho máximo para el contenido */
    margin: 0 auto;
}

.project-hero__category {
    display: inline-block;
    padding: 0.6rem 1.4rem;
    border: 1px solid var(--color-accent);
    color: var(--color-accent);
    border-radius: 20px;
    font-size: 1.4rem;
    font-weight: 500;
    margin-bottom: 2.5rem;
}

.project-hero__title {
    font-family: var(--font-display);
    font-weight: 900;
    font-size: clamp(3.5rem, 8vw, 6.5rem); /* Tamaño de fuente grande y adaptable */
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 1.1;
    margin-bottom: 2rem;
}

.project-hero__subtitle {
    max-width: 65ch; /* Limita el ancho del párrafo para mejor legibilidad */
    margin: 0 auto 5rem auto;
    font-size: 1.6rem;
    color: var(--color-text-secondary);
    line-height: 1.7;
}

/* --- Rejilla de Metadatos --- */
.project-hero__meta-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    border-top: 1px solid var(--color-nav-border);
    border-bottom: 1px solid var(--color-nav-border);
    padding: 2.5rem 0;
    margin-bottom: 5rem;
}

.meta-item {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.meta-item__label {
    font-size: 1.4rem;
    color: var(--color-text-secondary);
}

.meta-item__value {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--color-text-primary);
}

/* --- Imagen Principal --- */
.project-hero__image-wrapper img {
    width: 100%;
    aspect-ratio: 16 / 9; /* Proporción panorámica */
    object-fit: cover;
    border-radius: 15px;
}

/* =============================================
   ESTILOS PARA EL CONTENIDO DETALLADO DEL PROYECTO
   ============================================= */

.project-content {
    padding: 5rem 2rem;
}

.project-content__container {
    max-width: 1000px; /* Un poco más estrecho para que el texto sea más fácil de leer */
    margin: 0 auto;
}

.content-block {
    margin-bottom: 5rem;
}

.content-block__title {
    font-family: var(--font-display);
    font-weight: 900;
    font-size: 2rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 2rem; /* Más espacio entre título y párrafo */
}

.content-block__text {
    font-size: 1.6rem;
    line-height: 1.8; /* Aumentamos la altura de línea para párrafos largos */
    color: var(--color-text-secondary);
}

.content-block__image {
    margin: 5rem 0; /* Espacio vertical alrededor de la imagen */
}

.content-block__image img {
    width: 100%;
    border-radius: 15px; /* Mismos bordes redondeados que en el resto del sitio */
}
.content-block__image-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* <--- Esta es la línea clave */
    gap: 2rem;
    margin: 5rem 0;
}

.content-block__image-grid img {
    width: 100%; /* La imagen ocupa todo el ancho de su columna */
    aspect-ratio: 4 / 5; /* Proporción ligeramente vertical, como en la referencia */
    object-fit: cover; /* Asegura que la imagen llene el espacio sin deformarse */
    border-radius: 15px;
}
/* ===================================== */
/* SECCIÓN DE ANIMACIÓN DE SKILLS MARQUEE */
/* ===================================== */

.skills-marquee {
    margin: 5rem 0; /* Espacio antes y después de la marquesina */
    overflow: hidden; /* Oculta el contenido que se sale de los límites */
    white-space: nowrap; /* Evita que las palabras se envuelvan a la siguiente línea */
    font-family: 'Montserrat', sans-serif; /* Fuente según tu imagen */
    font-weight: 900;
    font-size: clamp(6rem, 22vw, 14rem);
    color: var(--color-accent); /* Color de acento para las palabras */
    text-transform: uppercase;
    line-height: 0.9;
}

.marquee-row {
    display: flex; /* Para que los items estén en una fila */
    align-items: center;
    gap: 2rem; /* Espacio entre palabras y el separador */
    padding: 1rem 0; /* Un poco de padding vertical para cada fila */
}

.marquee-row--left {
    animation: scrollLeft 30s linear infinite; /* Animación hacia la izquierda */
}

.marquee-row--right {
    animation: scrollRight 30s linear infinite; /* Animación hacia la derecha */
}

.skill-item {
    display: inline-block; /* Para que cada palabra tenga su propio espacio */
    padding: 0 1rem; /* Espacio alrededor de cada palabra */
}

.skill-separator {
    height: 0.8em; /* Ajusta el tamaño del icono de diamante */
    vertical-align: middle; /* Alinea el icono con el texto */
    fill: var(--color-accent); /* Asegura que el SVG herede el color de acento si no está definido dentro del SVG */
    margin: 0 1rem;
}

/* Definición de las animaciones */
@keyframes scrollLeft {
    0% { transform: translateX(0%); }
    100% { transform: translateX(-50%); } /* Se desplaza el 50% de su ancho total para un loop perfecto */
}

@keyframes scrollRight {
    0% { transform: translateX(-50%); } /* Inicia en -50% para que el loop parezca que viene de la izquierda */
    100% { transform: translateX(0%); }
}

/* Tema Oscuro */
body.dark-mode .skill-item {
    color: var(--color-accent); /* El color de acento debería funcionar en dark mode también */
}
/* =============================================
   FOOTER
   ============================================= */
.footer {
    padding: 10rem 2rem 5rem 2rem;
    border-top: 1px solid var(--color-nav-border);
}

.footer__container {
    max-width: 1200px;
    margin: 0 auto;
}

/* --- Parte Superior del Footer --- */
.footer__top {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 3rem;
    padding-bottom: 5rem;
    margin-bottom: 5rem;
    border-bottom: 1px solid var(--color-nav-border);
}

.footer__title {
    color: var(--color-text-secondary);
    font-size: 1.4rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 2rem;
}

.footer__list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.footer__list a, .footer__list p {
    color: var(--color-text-primary);
    font-size: 1.8rem;
    text-decoration: none;
    transition: color 0.3s ease;
}

.footer__list a:hover {
    color: var(--color-accent);
}

/* --- Parte Inferior del Footer --- */
.footer__bottom {
    display: grid;
    grid-template-columns: 1fr 1.5fr; /* Damos más espacio al formulario */
    gap: 5rem;
    align-items: center;
}

.footer__logo {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    margin-bottom: 1.5rem;
}

.footer__copyright p {
    color: var(--color-text-secondary);
    font-size: 1.4rem;
    line-height: 1.6;
}

/* --- Formulario de Contacto en Footer --- */
.footer__contact-form form {
    width: 100%;
}

.footer__contact-form label {
    display: block;
    color: var(--color-accent);
    font-size: 1.8rem;
    font-weight: 500;
    margin-bottom: 1.5rem;
}

.footer__contact-form textarea {
    width: 100%;
    background-color: #1C1C1C;
    border: 1px solid var(--color-nav-border);
    border-radius: 20px;
    padding: 2rem;
    color: var(--color-text-primary);
    font-family: inherit;
    font-size: 1.6rem;
    resize: vertical;
    margin-bottom: 2rem;
}

.footer__contact-form .btn--outline {
    width: auto;
    padding: 1rem 3rem;
}

/* =============================================
   POPUP DE CONTACTO (ESTILO EVOKODE)
   ============================================= */

/* Capa oscura de fondo */
.popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(5px);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.popup-overlay.show {
    opacity: 1;
    pointer-events: auto;
}

/* Contenedor del contenido del popup */
.popup-content {
    background-color: var(--color-background, #111111);
    border: 1px solid var(--color-nav-border, #333333);
    color: var(--color-text-primary, #FFFFFF);
    width: 90%;
    max-width: 500px;
    padding: 4rem 3rem;
    border-radius: 20px;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.5);
    position: relative;
    text-align: center;
    /* Animación de entrada */
    transform: scale(0.95);
    transition: transform 0.3s ease;
}

.popup-overlay.show .popup-content {
    transform: scale(1);
}

/* Contenido del formulario */
.popup-form-container h2 {
    font-size: 2.8rem;
    font-weight: 700;
    margin-bottom: 1rem;
}

.popup-form-container p {
    font-size: 1.6rem;
    color: var(--color-text-secondary, #A0A0A0);
    margin-bottom: 2.5rem;
}

.popup-form-container form {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.popup-form-container label {
    font-weight: 500;
    text-align: left;
    font-size: 1.4rem;
    color: var(--color-text-secondary, #A0A0A0);
}

.popup-form-container select {
    padding: 1.2rem;
    font-size: 1.6rem;
    border-radius: 8px;
    border: 1px solid var(--color-nav-border, #333333);
    background-color: #252525;
    color: var(--color-text-primary, #FFFFFF);
    font-family: inherit;
}

.whatsapp-btn {
    margin-top: 1rem;
    background: #25D366;
    /* verde WhatsApp */
    color: #fff;
    border: none;
    padding: 1.2rem 0;
    font-size: 1.8rem;
    font-weight: 600;
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.2s ease, transform 0.2s ease;
}

.whatsapp-btn:hover {
    background: #1ebe57;
    transform: scale(1.03);
}

/* Botón de cierre */
.popup-close {
    position: absolute;
    top: 15px;
    right: 20px;
    background: transparent;
    border: none;
    font-size: 3rem;
    cursor: pointer;
    color: var(--color-text-secondary, #A0A0A0);
    line-height: 1;
    transition: transform 0.2s ease, color 0.2s ease;
}

.popup-close:hover {
    color: var(--color-text-primary, #FFFFFF);
    transform: scale(1.2);
}


/*ANIMACIONES DE ABOUT,BENEFITS*/
/* Estado inicial oculto (izquierda y derecha) */
.hidden-left,
.hide-left {
    opacity: 0;
    transform: translateX(-80px);
    transition: all 0.8s ease;
}

.hidden-right,
.hide-right {
    opacity: 0;
    transform: translateX(80px);
    transition: all 0.8s ease;
}

/* Estado visible */
.show-left {
    opacity: 1;
    transform: translateX(0);
    transition: all 0.8s ease;
}

.show-right {
    opacity: 1;
    transform: translateX(0);
    transition: all 0.8s ease;
}

/* Delay solo para benefits__item5 */
.benefits__item5.show-right {
    transition-delay: 0.3s;
}

/* Animaciones base */
.hidden-left,
.hide-left {
    opacity: 0;
    transform: translateX(-80px);
    transition: all 0.8s ease;
}

.hidden-right,
.hide-right {
    opacity: 0;
    transform: translateX(80px);
    transition: all 0.8s ease;
}

.hidden-up,
.hide-up {
    opacity: 0;
    transform: translateY(60px);
    transition: all 0.8s ease;
}

/* Visibles */
.show-left {
    opacity: 1;
    transform: translateX(0);
}

.show-right {
    opacity: 1;
    transform: translateX(0);
}

.show-up {
    opacity: 1;
    transform: translateY(0);
}


/* Animación fade + slide más elegante */
.hidden-soft-left,
.hide-soft-left {
    opacity: 0;
    transform: translateX(-60px) scale(0.98);
    transition: all 0.8s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.hidden-soft-right,
.hide-soft-right {
    opacity: 0;
    transform: translateX(60px) scale(0.98);
    transition: all 0.8s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.hidden-soft-up,
.hide-soft-up {
    opacity: 0;
    transform: translateY(40px) scale(0.98);
    transition: all 0.8s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.show-soft-left,
.show-soft-right,
.show-soft-up {
    opacity: 1;
    transform: translate(0, 0) scale(1);
}

/* Utilidades de reveal */
.hidden-left,
.hidden-right,
.hidden-up {
    opacity: 0;
    will-change: transform, opacity;
    transition:
        transform .75s cubic-bezier(.22, 1, .36, 1),
        opacity .75s cubic-bezier(.22, 1, .36, 1);
    transform: translate3d(0, 0, 0);
    filter: saturate(.9);
}

.hidden-left {
    transform: translateX(-36px);
}

.hidden-right {
    transform: translateX(36px);
}

.hidden-up {
    transform: translateY(36px);
}

.show-left,
.show-right,
.show-up {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    filter: saturate(1);
}

.hide-left,
.hide-right,
.hide-up {
    opacity: 0;
    transform: translateY(10px);
    /* salida sutil hacia abajo */
    transition-duration: .5s;
}