/* Info Block Section */

.info-block-section {
    padding: var(--spacing-2xl) 0;
    width: 100%;
    overflow: hidden;
}

/* Background Colors */
.info-block-bg-white { background-color: var(--chickin-white); }
.info-block-bg-light { background-color: var(--chickin-offwhite); }
.info-block-bg-gray { background-color: #e5e5ea; }
.info-block-bg-tertiary { background-color: #fff9f0; } /* Un crema muy suave */

/* Container */
.info-block-container {
    max-width: var(--container-wide);
    margin: 0 auto;
    padding: 0 var(--spacing-sm);
    display: flex;
    gap: var(--spacing-2xl);
    align-items: center;
}

/* Layouts */
.info-block-layout-center .info-block-container {
    flex-direction: column;
    text-align: center;
}

.info-block-layout-center .info-block-content {
    max-width: 800px;
    margin: 0 auto;
}

.info-block-layout-left .info-block-container {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
}

.info-block-layout-left .info-block-content {
    max-width: 800px;
}

.info-block-layout-split-right {
    flex-direction: row;
}

.info-block-layout-split-left {
    flex-direction: row-reverse;
}

/* Typography */
.info-block-content {
    flex: 1;
    min-width: 300px;
}

.info-block-subtitle {
    display: inline-block;
    font-size: 0.875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--chickin-orange);
    margin-bottom: var(--spacing-sm);
}

.info-block-title {
    font-size: clamp(2rem, 4vw, 2.5rem);
    font-weight: 800;
    margin-bottom: var(--spacing-md);
    color: var(--chickin-anthracite);
    line-height: 1.15;
}

.info-block-text {
    font-size: 1.125rem;
    line-height: 1.7;
    color: var(--color-text-light);
    margin-bottom: var(--spacing-md);
}

.info-block-text p {
    margin-bottom: 1.5rem;
}

.info-block-text ul {
    margin-bottom: 1.5rem;
    padding-left: 1.5rem;
    list-style-type: disc;
}

.info-block-text li {
    margin-bottom: 0.5rem;
}

/* Image */
.info-block-image-wrapper {
    flex: 1;
    display: flex;
    justify-content: center;
    position: relative;
    max-width: 600px;
}

.info-block-image {
    width: 100%;
    height: auto;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--shadow-md);
    object-fit: cover;
    transition: transform 0.3s ease;
}

.info-block-image:hover {
    transform: translateY(-5px);
}

/* CTA */
.info-block-cta {
    margin-top: var(--spacing-md);
}

.info-block-buttons {
    display: flex;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 991px) {
    .info-block-container {
        flex-direction: column; /* Siempre stackeado en móvil */
        gap: var(--spacing-lg);
        text-align: left;
    }
    
    /* Excepción: Center se queda center */
    .info-block-layout-center .info-block-container {
        text-align: center;
    }

    .info-block-image-wrapper {
        width: 100%;
        max-width: 100%;
        margin-top: var(--spacing-md);
    }
    
    /* Si es split-left (img izq desktop), en móvil queremos img arriba usualmente */
    .info-block-layout-split-left .info-block-container {
        flex-direction: column-reverse; /* Img primero */
    }

    .info-block-layout-split-right .info-block-container {
        flex-direction: column; /* Texto primero */
    }
}
