/* ============================================================================
 * Cinematic Slider — shared cinema-style centered carousel.
 * BEM root: .cinema-slider with modifier classes for variant + theme.
 *   variant: pricing | switch | enterprise (default = bare)
 *   theme:   light | dark
 * CSS variables (--cs-*) expose theming knobs; variant blocks override them.
 * ========================================================================= */

.cinema-slider {
    --cs-card-bg: #ffffff;
    --cs-card-fg: #050505;
    --cs-card-muted: rgba(5, 5, 5, 0.8);
    --cs-card-stroke: #d3d3d3;
    --cs-nav-bg: #ffffff;
    --cs-nav-fg: #050505;
    --cs-card-width: min(1300px, 90vw);
    --cs-card-padding: 60px 40px;
    --cs-card-gap: 40px;
    --cs-card-text-gap: 24px;
    --cs-track-gap: 40px;
    --cs-dot-active-width: 40px;
    --cs-easing: cubic-bezier(0.22, 1, 0.36, 1);

    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 32px;
    width: 100%;
}

.cinema-slider__viewport {
    width: 100%;
    overflow: hidden;
}

.cinema-slider__track {
    display: flex;
    gap: var(--cs-track-gap);
    align-items: stretch;
    transition: transform 0.6s var(--cs-easing);
    will-change: transform;
}

.cinema-slider__card {
    flex: 0 0 var(--cs-card-width);
    box-sizing: border-box;
    background: var(--cs-card-bg);
    color: var(--cs-card-fg);
    padding: var(--cs-card-padding);
    display: flex;
    flex-direction: column;
    gap: var(--cs-card-gap);
    opacity: 0.5;
    transition: opacity 0.4s ease;
}

.cinema-slider__card.is-active {
    opacity: 1;
}

.cinema-slider__card-text {
    display: flex;
    flex-direction: column;
    gap: var(--cs-card-text-gap);
    min-width: 0;
}

.cinema-slider__logo {
    height: 24px;
    width: auto;
    object-fit: contain;
    display: block;
    align-self: flex-start;
}

.cinema-slider__quote-block {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.cinema-slider__quote-icon {
    display: block;
    width: 20px;
    height: 16px;
    color: var(--cs-card-fg);
}

.cinema-slider__quote-icon svg {
    display: block;
    width: 100%;
    height: 100%;
}

.cinema-slider__quote-title {
    margin: 0;
    font-weight: 600;
    font-size: 22px;
    line-height: 1.3;
    color: var(--cs-card-fg);
}

.cinema-slider__quote {
    margin: 0;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.4;
    color: var(--cs-card-fg);
}

.cinema-slider__quote p {
    margin: 0;
}

.cinema-slider__stat {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cinema-slider__stat-number {
    margin: 0;
    font-weight: 400;
    font-size: 48px;
    line-height: 1.15;
    color: var(--cs-card-fg);
}

.cinema-slider__stat-label {
    margin: 0;
    font-weight: 500;
    font-size: 14px;
    line-height: 1;
    color: var(--cs-card-muted);
}

.cinema-slider__author {
    display: flex;
    align-items: center;
    gap: 16px;
}

.cinema-slider__author--side {
    flex-direction: column;
    align-items: flex-end;
    gap: 12px;
    text-align: right;
}

.cinema-slider__avatar {
    width: 64px;
    height: 57px;
    object-fit: cover;
    display: block;
    flex: 0 0 auto;
}

.cinema-slider__author-meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.cinema-slider__name {
    margin: 0;
    font-weight: 500;
    font-size: 16px;
    line-height: 1;
    color: var(--cs-card-fg);
}

.cinema-slider__role {
    margin: 0;
    font-weight: 500;
    font-size: 12px;
    line-height: 1;
    text-transform: uppercase;
    color: var(--cs-card-muted);
}

.cinema-slider__image {
    width: 100%;
    overflow: hidden;
    display: flex;
}

.cinema-slider__image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cinema-slider__controls {
    display: flex;
    align-items: center;
    gap: 16px;
}

.cinema-slider__nav {
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid var(--cs-card-stroke);
    background: var(--cs-nav-bg);
    color: var(--cs-nav-fg);
    border-radius: 100px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
    transition: background-color 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
}

.cinema-slider__nav:hover {
    border-color: var(--cs-card-fg);
}

.cinema-slider__nav svg {
    width: 16px;
    height: 16px;
    display: block;
}

.cinema-slider__progress {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
}

.cinema-slider__dot {
    width: 12px;
    height: 12px;
    border: 0;
    border-radius: 100px;
    padding: 0;
    background: var(--cs-card-stroke);
    cursor: pointer;
    transition: width 0.3s ease, background-color 0.3s ease;
}

.cinema-slider__dot.is-active {
    width: var(--cs-dot-active-width);
    background: var(--cs-card-fg);
}

/* ============================================================================
 * Theme: dark
 * ========================================================================= */
.cinema-slider--theme-dark {
    --cs-card-bg: #1a1a1a;
    --cs-card-fg: #ffffff;
    --cs-card-muted: rgba(255, 255, 255, 0.8);
    --cs-card-stroke: rgba(255, 255, 255, 0.2);
    --cs-nav-bg: #050505;
    --cs-nav-fg: #ffffff;
}

/* ============================================================================
 * Variant: pricing  (Round5 / feature page — was .pt-*)
 * Card has image side on desktop. Author inline (no avatar). Quote has h3 title.
 * ========================================================================= */
.cinema-slider--variant-pricing {
    --cs-card-bg: var(--3rd-bg, #fdf9fa);
    --cs-card-fg: var(--1st-fg, #050505);
    --cs-card-muted: var(--2nd-fg, rgba(5, 5, 5, 0.8));
    --cs-card-stroke: var(--stroke, #d3d3d3);
    --cs-nav-bg: var(--2nd-btn-bg, #ffffff);
    --cs-nav-fg: var(--1st-fg, #050505);
    --cs-card-width: 85%;
    --cs-card-padding: 32px 20px;
    --cs-card-gap: 32px;
    --cs-card-text-gap: 24px;
}

.cinema-slider--variant-pricing .cinema-slider__card {
    max-width: 400px;
    font-family: 'DM Sans', sans-serif;
}

.cinema-slider--variant-pricing .cinema-slider__nav:hover {
    background-color: #f6f5f4;
}

.cinema-slider--variant-pricing .cinema-slider__quote-icon {
    width: 24px;
    height: 24px;
}

.cinema-slider--variant-pricing .cinema-slider__quote-title {
    font-family: 'DM Sans', sans-serif;
}

.cinema-slider--variant-pricing .cinema-slider__quote {
    font-family: 'DM Sans', sans-serif;
}

.cinema-slider--variant-pricing .cinema-slider__author {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    margin-top: auto;
}

.cinema-slider--variant-pricing .cinema-slider__image {
    aspect-ratio: 600 / 400;
    background-color: var(--2nd-bg, #ffffff);
    border-radius: 8px;
}

@media (min-width: 768px) {
    .cinema-slider--variant-pricing {
        --cs-card-width: 700px;
        --cs-card-padding: 40px;
    }

    .cinema-slider--variant-pricing .cinema-slider__card {
        max-width: none;
    }

    .cinema-slider--variant-pricing .cinema-slider__quote-icon {
        width: 32px;
        height: 32px;
    }

    .cinema-slider--variant-pricing .cinema-slider__quote-title {
        font-size: 24px;
    }

    .cinema-slider--variant-pricing .cinema-slider__quote {
        font-size: 18px;
    }
}

@media (min-width: 1024px) {
    .cinema-slider--variant-pricing {
        --cs-card-width: 1200px;
        --cs-card-padding: 60px;
        --cs-card-gap: 60px;
        --cs-card-text-gap: 40px;
    }

    .cinema-slider--variant-pricing .cinema-slider__card--has-image {
        display: grid;
        grid-template-columns: 1fr 540px;
        gap: 60px;
        align-items: center;
    }

    .cinema-slider--variant-pricing .cinema-slider__card-side--image {
        width: 540px;
    }

    .cinema-slider--variant-pricing .cinema-slider__image {
        width: 540px;
        height: 360px;
        aspect-ratio: auto;
        background: transparent;
    }

    .cinema-slider--variant-pricing .cinema-slider__quote-title {
        font-size: 28px;
    }

    .cinema-slider--variant-pricing .cinema-slider__quote {
        font-size: 20px;
    }

    .cinema-slider--variant-pricing .cinema-slider__role {
        font-size: 14px;
    }
}

/* ============================================================================
 * Variant: switch  (Round11 homepage — was .switch-card / .switch-card-*)
 * Card grid (text | image-square) on desktop. Author inline with avatar.
 * Image hidden on small mobile.
 * ========================================================================= */
.cinema-slider--variant-switch {
    --cs-card-bg: var(--color-2nd-bg, #ffffff);
    --cs-card-fg: var(--color-1st-fg, #050505);
    --cs-card-muted: var(--color-2nd-fg, rgba(5, 5, 5, 0.8));
    --cs-card-stroke: var(--color-stroke, #d3d3d3);
    --cs-nav-bg: var(--color-2nd-btn-bg, #ffffff);
    --cs-nav-fg: var(--color-2nd-btn-fg, #050505);
    --cs-card-width: min(1300px, 80vw);
    --cs-card-padding: 0;
    --cs-card-gap: var(--var-60, 60px);
    --cs-card-text-gap: var(--var-40, 40px);
    --cs-track-gap: var(--var-40, 40px);
    --cs-dot-active-width: var(--var-40, 40px);
    gap: var(--var-40, 40px);
}

.cinema-slider--variant-switch .cinema-slider__card {
    max-width: 1300px;
}

.cinema-slider--variant-switch .cinema-slider__card-text {
    padding: var(--var-40, 40px);
}

.cinema-slider--variant-switch .cinema-slider__quote {
    font-family: var(--font-body);
    font-size: var(--fs-quote, 24px);
    line-height: 1.4;
}

.cinema-slider--variant-switch .cinema-slider__name {
    font-family: var(--font-body);
    font-size: var(--fs-label-lg, 16px);
}

.cinema-slider--variant-switch .cinema-slider__role {
    font-family: var(--font-body);
    font-size: var(--fs-label-md, 14px);
    text-transform: uppercase;
    color: var(--cs-card-muted);
}

.cinema-slider--variant-switch .cinema-slider__author-meta {
    gap: var(--var-12, 12px);
}

.cinema-slider--variant-switch .cinema-slider__image {
    aspect-ratio: 1 / 1;
}

@media (min-width: 1025px) {
    .cinema-slider--variant-switch .cinema-slider__card--has-image {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--var-60, 60px);
        align-items: center;
    }
}

@media (max-width: 1024px) {
    .cinema-slider--variant-switch {
        --cs-card-width: 80vw;
    }

    .cinema-slider--variant-switch .cinema-slider__card--has-image {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--var-40, 40px);
        align-items: center;
    }

    .cinema-slider--variant-switch .cinema-slider__quote {
        font-size: 22px;
    }
}

@media (max-width: 768px) {
    .cinema-slider--variant-switch {
        --cs-card-width: 300px;
        --cs-card-padding: var(--var-32, 32px) var(--var-24, 24px);
        --cs-track-gap: var(--var-24, 24px);
        --cs-card-gap: var(--var-32, 32px);
        --cs-card-text-gap: var(--var-32, 32px);
    }

    .cinema-slider--variant-switch .cinema-slider__card {
        max-width: 300px;
    }

    .cinema-slider--variant-switch .cinema-slider__card--has-image {
        display: flex;
        flex-direction: column;
    }

    .cinema-slider--variant-switch .cinema-slider__card-text {
        padding: 0;
    }

    .cinema-slider--variant-switch .cinema-slider__card-side--image {
        display: none;
    }

    .cinema-slider--variant-switch .cinema-slider__quote {
        font-size: var(--fs-label-lg, 16px);
    }

    .cinema-slider--variant-switch .cinema-slider__author {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--var-16, 16px);
    }
}

/* ============================================================================
 * Variant: enterprise  (Round10 / enterprise page — was .enterprise-final-highlight__*)
 * Card row (text-main | author-right). No image, no avatar; has stat number.
 * ========================================================================= */
.cinema-slider--variant-enterprise {
    --cs-card-bg: var(--color-2nd-bg, #1a1a1a);
    --cs-card-fg: var(--color-1st-fg, #ffffff);
    --cs-card-muted: var(--color-2nd-fg, rgba(255, 255, 255, 0.8));
    --cs-card-stroke: var(--color-stroke, rgba(255, 255, 255, 0.2));
    --cs-nav-bg: var(--color-reverse-bg, #050505);
    --cs-nav-fg: var(--color-reverse-fg, #ffffff);
    --cs-card-width: min(1300px, 90vw);
    --cs-card-padding: var(--var-60, 60px) var(--var-40, 40px);
    --cs-card-gap: var(--var-40, 40px);
    --cs-card-text-gap: var(--var-60, 60px);
    --cs-track-gap: var(--var-40, 40px);
    --cs-dot-active-width: var(--var-40, 40px);
    gap: var(--var-40, 40px);
}

.cinema-slider--variant-enterprise .cinema-slider__viewport {
    /* Variant enterprise dùng align="left" — chỉ peek phía phải. Cho viewport
       overflow tự nhiên, body { overflow-x: hidden } đảm nhận clip tại mép window.
       Tránh "width + margin-right" trick (xung đột với flex align-items: center của
       .cinema-slider làm peek không nhất quán giữa các slide khi navigate). */
    overflow: visible;
}

.cinema-slider--variant-enterprise .cinema-slider__card--author-side {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
}

.cinema-slider--variant-enterprise .cinema-slider__card-text {
    flex: 1 1 0;
}

.cinema-slider--variant-enterprise .cinema-slider__card-side--author {
    flex: 0 0 300px;
    display: flex;
    justify-content: flex-end;
}

.cinema-slider--variant-enterprise .cinema-slider__quote {
    font-family: var(--font-body);
    font-size: var(--fs-quote, 24px);
    line-height: 1.4;
}

.cinema-slider--variant-enterprise .cinema-slider__stat-number {
    font-family: var(--font-display);
    font-size: var(--fs-h1, 48px);
}

.cinema-slider--variant-enterprise .cinema-slider__stat-label {
    font-family: var(--font-body);
    font-size: var(--fs-label-lg, 16px);
    text-transform: uppercase;
    color: var(--cs-card-muted);
}

.cinema-slider--variant-enterprise .cinema-slider__name {
    font-family: var(--font-body);
    font-size: var(--fs-label-lg, 16px);
}

.cinema-slider--variant-enterprise .cinema-slider__role {
    font-family: var(--font-body);
    font-size: var(--fs-label-md, 14px);
    text-transform: uppercase;
}

@media (max-width: 1024px) {
    .cinema-slider--variant-enterprise {
        --cs-card-width: 80vw;
        --cs-card-padding: var(--var-40, 40px) var(--var-24, 24px);
        --cs-card-gap: var(--var-24, 24px);
        --cs-card-text-gap: var(--var-40, 40px);
        --cs-track-gap: var(--var-24, 24px);
    }

    .cinema-slider--variant-enterprise .cinema-slider__quote-block {
        gap: var(--var-24, 24px);
    }

    .cinema-slider--variant-enterprise .cinema-slider__card-side--author {
        flex: 0 0 200px;
    }
}

@media (max-width: 768px) {
    .cinema-slider--variant-enterprise {
        /* 80px = section padding-left (20) + track-gap (24) + target peek (~36) so next slide peeks consistently below 640px breakpoint */
        --cs-card-width: min(600px, calc(100vw - 80px));
        --cs-card-padding: var(--var-32, 32px) var(--var-24, 24px);
        --cs-card-gap: var(--var-40, 40px);
        --cs-card-text-gap: var(--var-52, 52px);
    }

    .cinema-slider--variant-enterprise .cinema-slider__card {
        max-width: 320px;
        flex-direction: column;
    }

    .cinema-slider--variant-enterprise .cinema-slider__card--author-side {
        flex-direction: column;
    }

    .cinema-slider--variant-enterprise .cinema-slider__author--side {
        align-items: flex-start;
        text-align: left;
    }

    .cinema-slider--variant-enterprise .cinema-slider__author-meta {
        text-align: left;
    }
}

@media (max-width: 480px) {
    .cinema-slider--variant-enterprise {
        --cs-card-gap: var(--var-24, 24px);
    }

    .cinema-slider--variant-enterprise .cinema-slider__card-side--author {
        flex: 0 0 120px;
    }
}