/* ============================================================
   carbono.css - Página "Productos de Fibra de Carbono"
   Estilos responsive (mobile-first) para mobile y desktop
   ============================================================ */

/* ========== 1. VARIABLES CSS (Design Tokens) ========== */

:root {
    /* Reutilizar variables de estilos.css */
    --color-primary: #02478c;
    --color-primary-light: #0e92c6;
    --color-primary-dark: #023a73;
    --color-text: #2d3748;
    --color-text-secondary: #4a5568;
    --color-bg-section: #f5f7fa;
    --spacing-sm: 1rem;
    --spacing-md: 1.5rem;
    --spacing-lg: 2rem;
    --spacing-xl: 3rem;
    --spacing-xxl: 5rem;
    --font-family-primary: 'Ubuntu', 'Verdana', system-ui, sans-serif;
    --font-size-sm: 0.875rem;  /* 14px */
    --font-size-base: 1rem;
    --font-size-h1: 1.875rem; /* 30px */
    --font-size-h2: 1.5rem;   /* 24px */
    --font-size-h3: 1.25rem;  /* 20px */
    --border-color: #e5e7eb;
    --border-radius-md: 0.75rem;
    --transition-base: 300ms ease-in-out;
}

/* ========== 2. CONTENEDOR PRINCIPAL (Mobile First) ========== */

.carbono-container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--spacing-lg) var(--spacing-sm);
}

/* ========== 3. CABECERA CON IMAGEN (Hero Section) ========== */

.contenedor-cabecera {
    position: relative;
    width: 100%;
    margin-bottom: var(--spacing-xl);
    text-align: center;
}

.imgCabecera {
    display: none; /* Oculto en mobile */
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: var(--border-radius-md);
}

.imgCabecera-mobile {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: var(--border-radius-md);
}

.contenedor-cabecera > div {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    z-index: 2;
}

.texto-encimaImagen {
    font-size: var(--font-size-h1);
    color: white;
    font-weight: 700;
    text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
    margin-bottom: var(--spacing-sm);
}

.texto-centradoImagen {
    font-size: var(--font-size-base);
    color: white;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5);
    line-height: 1.6;
}

.button-cabecera {
    display: inline-block;
    margin-top: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-lg);
    background-color: var(--color-primary);
    color: white;
    text-decoration: none;
    border-radius: var(--border-radius-md);
    transition: background-color var(--transition-base);
}

.button-cabecera:hover {
    background-color: var(--color-primary-light);
}

/* ========== 4. CONTENEDOR DOS PRODUCTOS (Cards) ========== */

.contenedorDosProductos {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.cajaProducto {
    background-color: var(--color-bg-section);
    border-radius: var(--border-radius-md);
    padding: var(--spacing-lg);
    text-align: center;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.cajaProducto:hover {
    transform: translateY(-4px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.cajaIcono {
    margin-bottom: var(--spacing-md);
}

.detalleProductoCarbono {
    width: 100%;
    max-width: 200px;
    height: auto;
    margin: 0 auto;
    object-fit: contain;
}

.titulitoDosProductos {
    font-size: var(--font-size-h3);
    color: var(--color-primary);
    font-weight: 600;
    margin-bottom: var(--spacing-md);
}

.button-seccion {
    display: inline-block;
    padding: var(--spacing-sm) var(--spacing-lg);
    background-color: var(--color-primary);
    color: white;
    text-decoration: none;
    border-radius: var(--border-radius-md);
    transition: background-color var(--transition-base);
    font-weight: 500;
}

.button-seccion:hover {
    background-color: var(--color-primary-light);
}

.button-seccion > div {
    color: white;
}

/* ========== 5. SECCIÓN IMAGEN Y TEXTO ========== */

.seccionImageTexto {
    width: 100%;
    margin-bottom: var(--spacing-xl);
}

.seccionImageTexto .container {
    width: 100%;
}

.descripFibra {
    text-align: center;
    margin-bottom: var(--spacing-xl);
    padding: var(--spacing-lg);
}

.titulo2 {
    font-size: var(--font-size-h2);
    color: var(--color-primary);
    font-weight: 700;
    margin-bottom: var(--spacing-md);
}

.textoCentrado {
    font-size: var(--font-size-base);
    color: var(--color-text);
    line-height: 1.8;
    max-width: 800px;
    margin: 0 auto;
}

/* ========== 6. CONTENEDOR GRANDE (Productos Detallados) ========== */

.contenedorGrande {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
}

.primeraCaja,
.segundaCaja {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    background-color: var(--color-bg-section);
    border-radius: var(--border-radius-md);
    padding: var(--spacing-lg);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

#contenedor1,
#contenedor2 {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.cajaTexto {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.etiquetaProducto {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
}

.sloganTitular {
    font-size: var(--font-size-h2);
    color: var(--color-primary);
    font-weight: 700;
    margin: 0;
}

.entradilla {
    font-size: var(--font-size-base);
    color: var(--color-text);
    line-height: 1.6;
    margin: 0;
}

#imgProducto1,
#imgProducto2 {
    width: 100%;
    max-width: 400px;
    height: auto;
    margin: 0 auto;
    object-fit: contain;
    border-radius: var(--border-radius-md);
}

/* ========== 7. MEDIA QUERIES (Desktop - min-width: 768px) ========== */

@media (min-width: 768px) {
    .carbono-container {
        padding: var(--spacing-xl) var(--spacing-lg);
    }

    .imgCabecera {
        display: block;
    }

    .imgCabecera-mobile {
        display: none;
    }

    .contenedorDosProductos {
        flex-direction: row;
        justify-content: space-between;
    }

    .cajaProducto {
        flex: 1 1 calc(50% - var(--spacing-lg) / 2);
    }

    .contenedorGrande {
        gap: var(--spacing-xxl);
    }

    .primeraCaja,
    .segundaCaja {
        flex-direction: row;
        align-items: center;
        padding: var(--spacing-xl);
    }

    .primeraCaja {
        flex-direction: row-reverse; /* Imagen a la derecha */
    }

    .segundaCaja {
        flex-direction: row; /* Imagen a la izquierda */
    }

    #contenedor1,
    #contenedor2 {
        flex: 1 1 50%;
    }

    #imgProducto1,
    #imgProducto2 {
        flex: 1 1 50%;
        max-width: 500px;
    }
}

@media (min-width: 992px) {
    .carbono-container {
        padding: var(--spacing-xxl) var(--spacing-xl);
    }

    .texto-encimaImagen {
        font-size: 2.5rem; /* 40px */
    }

    .titulo2 {
        font-size: 2rem; /* 32px */
    }

    .sloganTitular {
        font-size: 1.75rem; /* 28px */
    }
}

/* ========== 8. ACCESIBILIDAD Y UTILIDADES ========== */

/* Asegurar que los elementos enfocables sean visibles */
a:focus,
button:focus {
    outline: 2px solid var(--color-primary-light);
    outline-offset: 2px;
}

/* Estilos de impresión */
@media print {
    .carbono-container {
        max-width: none;
        padding: 0;
    }

    .contenedor-cabecera,
    .button-seccion,
    .button-cabecera {
        display: none;
    }

    .cajaProducto,
    .primeraCaja,
    .segundaCaja {
        box-shadow: none;
        border: 1px solid #ccc;
        page-break-inside: avoid;
    }
}
