﻿/* =============================================
   LUXURY LINE — Text With Image block
   ============================================= */

.twi-section {
    padding: var(--spacing-xxl) 0;
    background-color: var(--color-background-light, #ebe6e1);
}

.twi-section--cream {
    background-color: var(--color-background-light, #ebe6e1);
}

.twi-section--dark {
    background-color: var(--color-background-dark);
}

.twi-section--dark .twi-title {
    color: var(--color-text-white, #ebe6e1);
}

.twi-section--dark .twi-body {
    color: rgba(255, 255, 255, 0.75);
}

.twi-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
    align-items: center;
}

/* Image on right (default) */
.twi-layout--img-right .twi-text {
    order: 1;
}

.twi-layout--img-right .twi-image-wrap {
    order: 2;
}

/* Image on left */
.twi-layout--img-left .twi-text {
    order: 2;
}

.twi-layout--img-left .twi-image-wrap {
    order: 1;
}

.twi-title {
    font-size: clamp(28px, 3.5vw, 42px);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    line-height: 1.2;
    letter-spacing: -1px;
    margin-bottom: var(--spacing-md);
}

.twi-body {
    font-size: 17px;
    line-height: 1.7;
    color: var(--color-text-light);
    margin-bottom: var(--spacing-lg);
}

.twi-cta {
    display: inline-block;
    padding: 14px 32px;
    background-color: var(--color-accent);
    color: var(--color-text-white, #ebe6e1);
    font-size: 14px;
    font-weight: var(--font-weight-semibold);
    letter-spacing: 0.02em;
    text-transform: none;
    text-decoration: none;
    border-radius: 4px;
    transition: background-color var(--transition-fast), transform var(--transition-fast);
}

.twi-cta:hover {
    background-color: var(--color-accent-dark, #721d2c);
    transform: translateY(-2px);
}

.twi-image-wrap {
    overflow: hidden;
    border-radius: 4px;
    aspect-ratio: 4 / 3;
}

.twi-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
    display: block;
}

.twi-image-wrap:hover .twi-image {
    transform: scale(1.04);
}

@media (max-width: 991px) {
    .twi-layout {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }

    .twi-layout--img-right .twi-text,
    .twi-layout--img-left .twi-text {
        order: 2;
    }

    .twi-layout--img-right .twi-image-wrap,
    .twi-layout--img-left .twi-image-wrap {
        order: 1;
    }
}