/* css/styles.css */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap');

:root {
    --jomicel-blue: #1a2a5a;
}

body {
    font-family: 'Space Grotesk', sans-serif;
    overflow-x: hidden; /* Evita scroll horizontal por la imagen inclinada */
}

/* === HERO SECTION (Fondo Negro y Recorte) === */
/* === HERO SECTION (Fondo Negro y Recorte Estilo React) === */
.hero-bg {
    background-color: #000000; /* Fondo negro sólido */
    min-height: 650px;         /* Altura mínima */
    position: relative;        /* Necesario para el recorte */
    overflow: hidden;          /* CORTA todo lo que se salga del contenedor */
    display: flex;
    align-items: center;       /* Centra verticalmente el contenido */
}

.hero-title {
    font-size: 3.5rem; /* Tamaño grande estilo editorial */
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -1px;
    text-transform: uppercase;
}

/* Contenedor Inclinado (El Marco) */
.hero-img-wrapper {
    position: absolute;
    /* Posicionamiento exacto para imitar tu versión de React */
    top: -15%;     /* La subimos un poco para cortar arriba */
    right: -35%;   /* La empujamos fuerte a la derecha para cortar el lado */
    width: 140%;   /* Muy ancha para que cubra el hueco */
    height: 135%;  /* Muy alta */
    transform: rotate(-12deg); /* LA INCLINACIÓN CLAVE */

    /* Estética limpia sin bordes */
    border-radius: 30px; /* Esquinas redondeadas suaves */
    overflow: hidden;    /* Corta la imagen para que tome la forma del marco */
    z-index: 1;
    background-color: #222; /* Color de fondo por si la imagen tarda en cargar */
    /* SIN BORDES */
}

/* La Imagen dentro del marco */
.hero-img-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;   /* Llena el espacio sin deformarse */
    object-position: center;
    /* IMPORTANTE: Sin transformaciones aquí. La imagen sigue la inclinación del wrapper. */
}
/* === CARDS === */
.card-smooth {
    border-radius: 30px;
    overflow: hidden;
    position: relative;
    height: 450px;
    transition: transform 0.3s ease;
}
.card-smooth:hover { transform: scale(1.02); }
.card-smooth img { width: 100%; height: 100%; object-fit: cover; }
.card-gradient {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.9), transparent);
}
.card-content { position: absolute; bottom: 0; padding: 2rem; width: 100%; }
/* === FOOTER STYLES === */
.footer-icon-wrapper {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    padding: 1rem;
    border-radius: 50%;
    background-color: #f3f4f6; /* bg-gray-100 */
    color: var(--jomicel-blue);
    transition: all 0.3s ease;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

/* === ACERCA DE (REDISEÑO EXACTO) === */

/* 1. La Mancha Negra (Fondo) */
.about-shape-bg {
    position: absolute;
    top: 0;
    right: 0;
    width: 600px; 
    height: 600px;
    background-color: #0a0a0a; /* Negro casi puro */
    /* La curva suave en la esquina inferior izquierda */
    border-bottom-left-radius: 200px; 
    /* La posición y rotación exacta de React */
    transform: translate(20%, -15%) rotate(12deg); 
    z-index: 0;
    box-shadow: -20px 20px 60px rgba(0,0,0,0.3);
}



/* 3. Título con Línea Vertical (Limpio, sin cajas) */
.about-title-border {
    border-left: 5px solid var(--jomicel-blue);
    padding-left: 1.5rem;
    margin-bottom: 2rem;
}

.about-title {
    font-size: 3.5rem;
    font-weight: 800;
    line-height: 1;
    color: var(--jomicel-blue);
    text-transform: uppercase;
    letter-spacing: -1px;
}

/* 4. Imagen Flotante (Sin bordes blancos, solo sombra) */
.about-image-wrapper {
    position: relative;
    border-radius: 30px; /* Bordes muy redondeados */
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5); /* Sombra fuerte para profundidad */
    z-index: 10; /* Encima de la mancha negra */
    transform: perspective(1000px) rotateY(-5deg); /* Un toquecito 3D sutil */
    transition: transform 0.5s ease;
}

.about-image-wrapper:hover {
    transform: perspective(1000px) rotateY(0deg) scale(1.02);
}

.about-image-wrapper img {
    width: 100%;
    height: auto;
    display: block;
}

/* Efecto Hover del Grupo */
.footer-item:hover .footer-icon-wrapper {
    background-color: var(--jomicel-blue);
    color: white;
    transform: translateY(-2px);
}

.tracking-wider { letter-spacing: 0.05em; }
/* === TEXTOS === */
.text-jomicel { color: var(--jomicel-blue); }