/* ============================================================
   Maxfit Header Category v2.2 — Frontend Carousel CSS
   ============================================================ */

/* ── Full-bleed breakout ─────────────────────────────────── */
.mf-premium-carousel {
    position: relative !important;
    width: 100vw !important;
    max-width: 100vw !important;
    left: 50% !important;
    right: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
}

.entry-content .vc_row:has(.mf-premium-carousel),
.wpb-content-wrapper .vc_row:has(.mf-premium-carousel),
.vc_row.vc_row-fluid:has(.mf-premium-carousel) {
    left: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* ── Hide old row ────────────────────────────────────────── */
.vc_row.four_block.vc_custom_1776767582686 {
    display: none !important;
}

/* ============================================================
   MAIN CAROUSEL
   ============================================================ */
.mf-premium-carousel {
    --mf-visible:      4.5;
    --mf-gap:          28px;
    --mf-arrow-space:  120px;
    --mf-card-height:  440px;
    --mf-image-height: 70%;

    --mf-bg-card:    #efefef;
    --mf-accent:     #f5b400;
    --mf-text:       #1a1a1a;
    --mf-text-muted: #666666;
    --mf-divider:    #d0d0d0;

    background: transparent !important;
    padding: 40px 0 90px !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Inter', 'Helvetica Neue', Arial, sans-serif !important;
    box-sizing: border-box !important;
}

.mf-premium-carousel *,
.mf-premium-carousel *::before,
.mf-premium-carousel *::after {
    box-sizing: border-box;
}

.mf-carousel-inner {
    width: 100% !important;
    max-width: 1860px !important;
    margin: 0 auto !important;
    padding: 0 var(--mf-arrow-space) !important;
    position: relative !important;
}

/* ── Track — NO scroll-snap, NO scroll-behavior (JS controls scroll) */
.mf-carousel-viewport {
    position: relative !important;
}

.mf-carousel-track {
    display: flex !important;
    gap: var(--mf-gap) !important;
    overflow-x: scroll !important;
    /* scroll-snap intentionally OFF — rAF infinite loop handles positioning */
    scroll-snap-type: none !important;
    scroll-behavior: auto !important;
    padding: 0 !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    cursor: grab !important;
}

.mf-carousel-track::-webkit-scrollbar {
    display: none !important;
}

.mf-carousel-track.is-dragging {
    cursor: grabbing !important;
}

/* ── Card — completely static, zero hover effects ────────── */
.mf-carousel-card {
    flex: 0 0 calc((100% - (3.5 * var(--mf-gap))) / var(--mf-visible)) !important;
    width:  calc((100% - (3.5 * var(--mf-gap))) / var(--mf-visible)) !important;
    height: var(--mf-card-height) !important;

    background: var(--mf-bg-card) !important;
    border-radius: 20px !important;
    box-shadow: none !important;

    text-decoration: none !important;
    color: var(--mf-text) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;

    padding: 0 !important;
    position: relative !important;
    overflow: hidden !important;
    border: 0 !important;
    transition: none !important;
    user-select: none !important;
    -webkit-user-select: none !important;
}

/* Absolutely no card-level hover change */
.mf-carousel-card:hover,
.mf-carousel-card:focus,
.mf-carousel-card:active {
    box-shadow: none !important;
    transform: none !important;
    outline: none !important;
    background: var(--mf-bg-card) !important;
}

/* ── Image area — smooth zoom on hover ──────────────────── */
.mf-card-image {
    flex: 0 0 var(--mf-image-height) !important;
    width: 100% !important;

    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-color: transparent !important;

    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    padding: 24px !important;

    /* GPU layer for smooth zoom */
    will-change: transform !important;
    transform: translateZ(0) scale(1) !important;
    transform-origin: center center !important;
    transition: transform .65s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
}

/* Smooth zoom on card hover — image only */
.mf-carousel-card:hover .mf-card-image {
    transform: translateZ(0) scale(1.06) !important;
}

/* The separator line between image and title — static, never moves */
.mf-card-image::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 50% !important;
    /* static translate only, no hover change */
    transform: translateX(-50%) !important;
    width: 80% !important;
    height: 1px !important;
    background: linear-gradient(to right, transparent, rgba(0,0,0,.10), transparent) !important;
    pointer-events: none !important;
    /* No transition — line never moves */
    transition: none !important;
}

/* ── Content area ────────────────────────────────────────── */
.mf-card-content {
    flex: 1 !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 16px 22px !important;
    text-align: center !important;
}

.mf-card-title {
    font-size: 13px !important;
    font-weight: 600 !important;
    letter-spacing: 2px !important;
    color: var(--mf-text) !important;
    margin: 0 0 14px !important;
    text-transform: uppercase !important;
    line-height: 1.4 !important;
}

/* Divider below title — static */
.mf-card-divider {
    width: 32px !important;
    height: 0.5px !important;
    background: var(--mf-divider) !important;
    margin: 0 0 12px !important;
    transition: none !important;
}

/* EXPLORE — only thing that reacts to hover */
.mf-card-cta {
    display: inline-block !important;
    font-size: 10px !important;
    letter-spacing: 2px !important;
    font-weight: 500 !important;
    color: var(--mf-text-muted) !important;
    text-transform: uppercase !important;
    transition: color .35s ease, letter-spacing .35s ease !important;
}

.mf-carousel-card:hover .mf-card-cta {
    color: var(--mf-accent) !important;
    letter-spacing: 3px !important;
}

/* ── Navigation arrows ───────────────────────────────────── */
.mf-carousel-nav {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 50px !important;
    height: 50px !important;
    border-radius: 50% !important;
    background: #fff !important;
    border: 0 !important;
    color: var(--mf-text) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    z-index: 5 !important;
    box-shadow: 0 4px 12px rgba(0,0,0,.08) !important;
    transition: background .35s ease, color .35s ease,
                transform .35s ease, box-shadow .35s ease !important;
    padding: 0 !important;
}

.mf-carousel-nav:hover {
    background: var(--mf-accent) !important;
    color: #fff !important;
    transform: translateY(-50%) scale(1.1) !important;
    box-shadow: 0 8px 24px rgba(245,180,0,.25) !important;
}

.mf-carousel-prev { left:  calc((var(--mf-arrow-space) - 50px) / 2) !important; }
.mf-carousel-next { right: calc((var(--mf-arrow-space) - 50px) / 2) !important; }

/* ── Dots hidden ─────────────────────────────────────────── */
.mf-carousel-dots {
    display: none !important;
}

/* ── Entrance fade (opacity only) ────────────────────────── */
.mf-carousel-card.mf-entering {
    opacity: 0 !important;
}
.mf-carousel-card.mf-entered {
    opacity: 1 !important;
    transition: opacity .6s ease !important;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (min-width: 1900px) {
    .mf-premium-carousel {
        --mf-visible: 4.5; --mf-gap: 30px;
        --mf-arrow-space: 130px; --mf-card-height: 460px;
    }
}
@media (max-width: 1899px) and (min-width: 1600px) {
    .mf-premium-carousel {
        --mf-visible: 4.5; --mf-gap: 28px;
        --mf-arrow-space: 120px; --mf-card-height: 440px;
    }
}
@media (max-width: 1599px) and (min-width: 1200px) {
    .mf-premium-carousel {
        --mf-visible: 4.5; --mf-gap: 24px;
        --mf-arrow-space: 100px; --mf-card-height: 370px;
    }
}

/* Tablet */
@media (max-width: 1199px) and (min-width: 768px) {
    .mf-premium-carousel {
        --mf-visible: 3.5; --mf-gap: 16px;
        --mf-arrow-space: 24px; --mf-card-height: 340px;
        padding: 30px 0 70px !important;
    }
    .mf-carousel-inner { max-width: 100% !important; padding: 0 0 0 24px !important; }
    .mf-carousel-nav   { display: none !important; }
    .mf-carousel-card  {
        flex: 0 0 calc((100% - (2.5 * var(--mf-gap))) / var(--mf-visible)) !important;
        width:  calc((100% - (2.5 * var(--mf-gap))) / var(--mf-visible)) !important;
    }
}

/* Mobile */
@media (max-width: 767px) {
    .mf-premium-carousel {
        --mf-visible: 3.1; --mf-gap: 10px;
        --mf-arrow-space: 12px; --mf-image-height: 74%;
        padding: 20px 0 40px !important;
    }
    .mf-carousel-inner  { max-width: 100% !important; padding: 0 0 0 14px !important; }
    .mf-carousel-nav    { display: none !important; }
    .mf-card-cta        { display: none !important; }
    .mf-card-divider    { display: none !important; }
    .mf-carousel-card   {
        flex: 0 0 calc((100% - (2.1 * var(--mf-gap))) / var(--mf-visible)) !important;
        width:  calc((100% - (2.1 * var(--mf-gap))) / var(--mf-visible)) !important;
        height: auto !important;
        aspect-ratio: 1 / 1.2 !important;
    }
    .mf-card-image      { padding: 12px !important; }
    .mf-card-content    { padding: 0 8px 14px !important; }
    .mf-card-title      { font-size: 10px !important; letter-spacing: .8px !important; margin: 0 !important; }
    .mf-carousel-dots   { margin-top: 22px !important; }
}

@media (max-width: 380px) {
    .mf-card-title { font-size: 9px !important; letter-spacing: .5px !important; }
}
