/* ============================================================
   Maxfit Premium Category — Frontend Carousel CSS
   Light card design: white card, bold black uppercase title
   (single line, ellipsis if too long), dark circular arrow
   button. No subtitle text, no underline accent. Desktop shows
   N full cards plus a partial peek of the next; mobile shows
   its own count.
   ============================================================ */

/* ── 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 legacy WPBakery row */
.vc_row.four_block.vc_custom_1776767582686 {
    display: none !important;
}

/* ============================================================
   MAIN CAROUSEL
   ============================================================ */
.mf-premium-carousel {
    /* --mf-visible-desktop / --mf-visible-mobile are set from the
       admin "visible cards" setting via inline CSS (includes/assets.php).
       Desktop adds +0.5 card width of "peek" automatically below. */
    --mf-visible-desktop: 4;
    --mf-visible-mobile:  3;

    --mf-gap:          24px;
    --mf-arrow-space:  110px;
    --mf-card-height:  320px;
    --mf-image-height: 62%;
    --mf-radius:       10px;

    --mf-bg-card:    #f7f7f7;
    --mf-accent:     #f5b400;
    --mf-text:       #1a1a1a;
    --mf-text-muted: #777777;
    --mf-divider:    #e2e2e2;

    background: transparent !important;
    padding: 36px 0 60px !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 ──────────────────────────────────────────────── */
.mf-carousel-viewport {
    position: relative !important;
}

.mf-carousel-track {
    display: flex !important;
    gap: var(--mf-gap) !important;
    overflow-x: scroll !important;
    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 — light design: white card shell, soft grey image area,
   white text panel (NOT dark), bold black title, grey subtitle.
   Desktop card width = (100% - gaps for N full + half-peek card)
   divided across (N + 0.5) slots, so the (N+1)th card always
   peeks in from the right edge — matching the reference image.
   ============================================================ */
.mf-carousel-card {
    flex: 0 0 calc((100% - ((var(--mf-visible-desktop) - 0.5) * var(--mf-gap))) / (var(--mf-visible-desktop) + 0.5)) !important;
    width:  calc((100% - ((var(--mf-visible-desktop) - 0.5) * var(--mf-gap))) / (var(--mf-visible-desktop) + 0.5)) !important;
    height: var(--mf-card-height) !important;

    background: #ffffff !important;
    border: 1px solid #ececec !important;
    border-radius: var(--mf-radius) !important;
    box-shadow: 0 1px 3px rgba(0,0,0,.04) !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;
    transition: border-color .3s ease, box-shadow .3s ease !important;
    user-select: none !important;
    -webkit-user-select: none !important;
}

/* Subtle border + shadow lift on hover for a premium tactile feel */
.mf-carousel-card:hover {
    border-color: #dcdcdc !important;
    box-shadow: 0 8px 20px rgba(0,0,0,.07) !important;
}
.mf-carousel-card:hover,
.mf-carousel-card:focus,
.mf-carousel-card:active {
    transform: none !important;
    outline: none !important;
    background: #ffffff !important;
}

/* ============================================================
   IMAGE — light grey background block, product image centred
   ============================================================ */
.mf-card-image-wrap {
    flex: 1 1 auto !important;
    width: 100% !important;
    overflow: hidden !important;
    position: relative !important;
    background: var(--mf-bg-card) !important;
}

.mf-card-image {
    width: 100% !important;
    height: 100% !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-color: transparent !important;
    padding: 18px !important;

    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;
}

/* HOVER #1 — smooth image zoom */
.mf-carousel-card:hover .mf-card-image {
    transform: translateZ(0) scale(1.06) !important;
}

/* ============================================================
   CONTENT — WHITE text panel under the image (light design).
   Category name only (single line) + dark circular arrow.
   Subtitle text and the underline divider have been removed
   per request — image gets the extra room instead.
   ============================================================ */
.mf-card-content {
    flex: 0 0 auto !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    padding: 14px 18px !important;
    background: #ffffff !important;
    position: relative !important;
    text-align: left !important;
    overflow: visible !important;
    color: var(--mf-text) !important;
}

/* Row: title on the left, circular arrow on the right. */
.mf-card-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    width: 100% !important;
    padding-bottom: 0 !important;
}

.mf-card-text {
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

/* ── Title — bold black uppercase, ALWAYS single line ── */
.mf-card-title {
    font-size: 16px !important;
    font-weight: 800 !important;
    letter-spacing: .3px !important;
    color: var(--mf-text) !important;
    margin: 0 !important;
    text-transform: uppercase !important;
    line-height: 1.25 !important;
    text-align: left !important;

    display: block !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.mf-card-title > span {
    display: inline !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    width: 100% !important;
}

/* ── Subtitle — removed from the design, kept hidden so the
   markup/back-compat fields don't need touching ── */
.mf-card-subtitle {
    display: none !important;
}

/* ============================================================
   GOLD ACCENT UNDERLINE — removed per request.
   ============================================================ */
.mf-card-accent {
    display: none !important;
}


/* ============================================================
   CIRCULAR ARROW — dark/black fill, white icon (matches image).
   Default:  Solid dark circle, white arrow.
   Hover:    Gold fill, dark arrow, subtle scale pop.
   ============================================================ */
.mf-card-arrow {
    flex: 0 0 auto !important;
    width: 38px !important;
    height: 38px !important;
    border: none !important;
    border-radius: 50% !important;
    background: #161616 !important;
    color: #ffffff !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    overflow: hidden !important;
    transform: scale(1) !important;
    transition: background-color .4s cubic-bezier(.4, 0, .2, 1),
                color .35s ease,
                transform .4s cubic-bezier(.34, 1.56, .64, 1) !important;
}

.mf-arrow-icon {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    width: 15px !important;
    height: 15px !important;
    transform: translate(-50%, -50%) !important;
    transition: transform .35s ease !important;
    backface-visibility: hidden !important;
}

.mf-arrow-icon-1 {
    transform: translate(-50%, -50%) !important;
}

.mf-arrow-icon-2 {
    display: none !important;
}

/* Hover — gold fill, dark arrow, subtle scale pop */
.mf-carousel-card:hover .mf-card-arrow {
    background: var(--mf-accent) !important;
    color: #161616 !important;
    transform: scale(1.08) !important;
}
.mf-carousel-card:hover .mf-arrow-icon-1 {
    transform: translate(-50%, -50%) scale(1.05) !important;
}

/* ── Legacy classes hidden (kept in markup for back-compat) ── */
.mf-card-cta,
.mf-card-divider {
    display: none !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: 1px solid #ececec !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: #161616 !important;
    border-color: var(--mf-accent) !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; }

/* Disabled state at the start/end edge (no more infinite loop) */
.mf-carousel-nav.is-disabled,
.mf-carousel-dots button.is-disabled {
    opacity: .35 !important;
    cursor: default !important;
    pointer-events: none !important;
    box-shadow: none !important;
}

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

/* Entrance fade */
.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-gap: 26px; --mf-arrow-space: 120px; --mf-card-height: 340px; }
}
@media (max-width: 1899px) and (min-width: 1600px) {
    .mf-premium-carousel { --mf-gap: 24px; --mf-arrow-space: 110px; --mf-card-height: 320px; }
}
@media (max-width: 1599px) and (min-width: 1200px) {
    .mf-premium-carousel { --mf-gap: 20px; --mf-arrow-space: 90px; --mf-card-height: 290px; }
    .mf-card-title    { font-size: 14px !important; }
    .mf-card-arrow    { width: 34px !important; height: 34px !important; }
    .mf-arrow-icon    { width: 13px !important; height: 13px !important; }
}

/* Tablet — uses desktop visible-count, looser spacing */
@media (max-width: 1199px) and (min-width: 768px) {
    .mf-premium-carousel {
        --mf-gap: 16px;
        --mf-arrow-space: 24px;
        --mf-card-height: 270px;
        padding: 28px 0 50px !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% - ((var(--mf-visible-desktop) - 0.7) * var(--mf-gap))) / (var(--mf-visible-desktop) + 0.4)) !important;
        width:  calc((100% - ((var(--mf-visible-desktop) - 0.7) * var(--mf-gap))) / (var(--mf-visible-desktop) + 0.4)) !important;
    }
    .mf-card-content  { padding: 11px 14px !important; }
    .mf-card-row      { padding-bottom: 0 !important; }
    .mf-card-title    { font-size: 13px !important; }
    .mf-card-arrow    { width: 30px !important; height: 30px !important; }
    .mf-arrow-icon    { width: 12px !important; height: 12px !important; }
}

/* Mobile — uses --mf-visible-mobile, compact, no arrow nav buttons.
   N full cards + a SMALL peek (~12%) of the next — keeps cards large
   and the image prominent, matching the desktop reference proportions
   instead of a deep 50% peek that shrank everything. */
@media (max-width: 767px) {
    .mf-premium-carousel {
        --mf-gap: 10px;
        --mf-arrow-space: 10px;
        --mf-image-height: 68%;
        padding: 18px 0 36px !important;
    }
    .mf-carousel-inner  { max-width: 100% !important; padding: 0 0 0 12px !important; }
    .mf-carousel-nav    { display: none !important; }

    /* Peek fraction = 0.12 (a sliver of the next card), so each of the
       3 visible cards gets as much width/height as possible. */
    .mf-carousel-card   {
        flex: 0 0 calc((100% - ((var(--mf-visible-mobile) - 0.12) * var(--mf-gap))) / (var(--mf-visible-mobile) + 0.12)) !important;
        width:  calc((100% - ((var(--mf-visible-mobile) - 0.12) * var(--mf-gap))) / (var(--mf-visible-mobile) + 0.12)) !important;
        height: auto !important;
        aspect-ratio: 1 / 1.14 !important;
    }
    .mf-card-image      { padding: 4px !important; }

    .mf-card-content    { padding: 7px 6px !important; }
    .mf-card-row        { padding-bottom: 0 !important; align-items: center !important; gap: 5px !important; }
    .mf-card-text       { text-align: left !important; flex: 1 1 auto !important; min-width: 0 !important; }

    .mf-card-title {
        font-size: 9.5px !important;
        font-weight: 800 !important;
        letter-spacing: .1px !important;
        line-height: 1.2 !important;
        margin: 0 !important;
        text-align: left !important;
        color: var(--mf-text) !important;
        display: block !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }
    .mf-card-title > span {
        display: inline !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    /* Arrow shown smaller on mobile, same vertical center as reference */
    .mf-card-arrow    { width: 22px !important; height: 22px !important; flex-shrink: 0 !important; }
    .mf-arrow-icon    { width: 10px !important; height: 10px !important; }

    .mf-carousel-dots   { margin-top: 18px !important; }
}

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