/* ═══════════════════════════════════════════════════════════
   El Couzina — Promo Carousel
   ═══════════════════════════════════════════════════════════ */

.promo-carousel {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-lg);
    background: var(--bg-alt);
}

.promo-track {
    display: flex;
    transition: transform var(--duration-slow) var(--ease);
    touch-action: pan-y;
}

.promo-slide {
    flex: 0 0 100%;
    min-height: 420px;
    position: relative;
    padding: var(--space-16) var(--space-10);
    display: flex;
    align-items: center;
    overflow: hidden;
    color: white;
}

.promo-slide[data-theme="terracotta"] {
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
}

.promo-slide[data-theme="olive"] {
    background: linear-gradient(135deg, var(--secondary) 0%, var(--secondary-dark) 100%);
}

.promo-slide[data-theme="gold"] {
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
    color: var(--bg-dark);
}

.promo-slide[data-theme="dark"] {
    background: linear-gradient(135deg, var(--bg-dark) 0%, #1B4965 100%);
}

.promo-slide::before {
    content: '';
    position: absolute;
    top: -20%;
    right: -10%;
    width: 50%;
    height: 140%;
    background: radial-gradient(ellipse at center, rgba(255, 255, 255, 0.12) 0%, transparent 70%);
    pointer-events: none;
}

.promo-slide-icon {
    position: absolute;
    right: var(--space-10);
    bottom: var(--space-6);
    font-size: clamp(6rem, 14vw, 10rem);
    opacity: 0.18;
    line-height: 1;
    pointer-events: none;
}

.promo-slide-content {
    position: relative;
    z-index: 2;
    max-width: 640px;
}

.promo-slide-eyebrow {
    display: inline-block;
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: var(--tracking-widest);
    padding: var(--space-2) var(--space-4);
    background: rgba(255, 255, 255, 0.18);
    backdrop-filter: blur(8px);
    border-radius: var(--radius-full);
    margin-bottom: var(--space-5);
}

.promo-slide[data-theme="gold"] .promo-slide-eyebrow {
    background: rgba(44, 24, 16, 0.15);
}

.promo-slide-title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4.5vw, 3.2rem);
    font-weight: 600;
    line-height: 1;
    margin-bottom: var(--space-4);
    color: inherit;
}

.promo-slide-subtitle {
    font-size: var(--text-lg);
    opacity: 0.9;
    margin-bottom: var(--space-6);
    line-height: var(--leading-relaxed);
}

.promo-slide-cta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    padding: var(--space-4) var(--space-6);
    background: white;
    color: var(--text);
    border-radius: var(--radius-full);
    transition: all var(--duration) var(--ease);
}

.promo-slide-cta:hover {
    transform: translateX(4px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

.promo-slide[data-theme="gold"] .promo-slide-cta {
    background: var(--bg-dark);
    color: white;
}

/* Dots navigation */
.promo-dots {
    position: absolute;
    bottom: var(--space-5);
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: var(--space-2);
    z-index: 10;
}

.promo-dot {
    width: 10px;
    height: 10px;
    border-radius: var(--radius-full);
    background: rgba(255, 255, 255, 0.35);
    cursor: pointer;
    transition: all var(--duration) var(--ease);
    border: none;
    padding: 0;
}

.promo-dot.active {
    background: white;
    width: 30px;
    border-radius: var(--radius-full);
}

/* Arrow controls */
.promo-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 48px;
    height: 48px;
    border-radius: var(--radius-full);
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--duration) var(--ease);
    z-index: 10;
    opacity: 0.8;
}

.promo-arrow:hover {
    background: rgba(255, 255, 255, 0.35);
    opacity: 1;
    transform: translateY(-50%) scale(1.05);
}

.promo-arrow-prev { left: var(--space-5); }
.promo-arrow-next { right: var(--space-5); }

.promo-arrow svg {
    width: 22px;
    height: 22px;
}

@media (max-width: 767px) {
    .promo-slide {
        min-height: 340px;
        padding: var(--space-10) var(--space-6);
    }
    .promo-slide-icon { display: none; }
    .promo-arrow { display: none; }
    .promo-dots { bottom: var(--space-4); }
}
