/* CFS – Custom Finish Selector v1.3
   Fix #2: High-specificity hover rules to override Elementor theme pink
   Fix #3: Card description on second line
   Fix #5: Description line-clamp
   Fix #7: Responsive layout overflow from card descriptions
   ─────────────────────────────────────────────────────────────────── */

/* ── Reset ───────────────────────────────────────────────────────── */
.cfs-configurator *,
.cfs-configurator *::before,
.cfs-configurator *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Root ────────────────────────────────────────────────────────── */
.cfs-configurator {
    --cfs-radius:    14px;
    --cfs-radius-sm: 9px;
    --cfs-ease:      0.22s cubic-bezier(0.4, 0, 0.2, 1);
    font-family: var(--cfs-body-font, 'Jost', system-ui, sans-serif);
    font-size: 14px;
    color: var(--cfs-body_text);
    background: var(--cfs-widget_bg, transparent);
    padding: clamp(24px, 5vw, 52px) clamp(18px, 4vw, 48px);
    border-radius: var(--cfs-radius);
}

/* ── Header ──────────────────────────────────────────────────────── */
.cfs-configurator .cfs-header { text-align: center; margin-bottom: clamp(28px, 5vw, 48px); }

.cfs-configurator .cfs-overline {
    display: flex; align-items: center; justify-content: center; gap: 14px;
    font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
    color: var(--cfs-step_num); margin-bottom: 10px;
    font-family: var(--cfs-body-font, system-ui, sans-serif);
}
.cfs-configurator .cfs-overline::before,
.cfs-configurator .cfs-overline::after {
    content: ''; display: block; width: 32px; height: 1px;
    background: var(--cfs-accent); opacity: .5;
}

.cfs-configurator .cfs-title {
    font-family: var(--cfs-heading-font, 'Cormorant Garamond', Georgia, serif);
    font-size: clamp(28px, 5vw, 46px);
    font-weight: 400; line-height: 1.15;
    color: var(--cfs-heading); letter-spacing: -.01em;
}
.cfs-configurator .cfs-title em { font-style: italic; color: var(--cfs-accent); }

/* ── Steps grid ──────────────────────────────────────────────────── */

/* Container query context — responds to widget width, not viewport */
.cfs-configurator { container-type: inline-size; container-name: cfs; }

.cfs-configurator .cfs-steps {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* ── Step card ───────────────────────────────────────────────────── */
.cfs-configurator .cfs-step {
    background: var(--cfs-card_bg);
    border: 1px solid var(--cfs-border) !important;
    border-radius: var(--cfs-radius);
    padding: clamp(16px, 3vw, 26px);
    overflow: hidden;          /* Fix: prevent inner content from bleeding outside */
    min-width: 0;              /* Fix: allow grid cell to shrink below content size */
    transition: box-shadow var(--cfs-ease);
}
.cfs-configurator .cfs-step:hover {
    box-shadow: 0 4px 24px rgba(0, 0, 0, .06);
}

.cfs-configurator .cfs-step-header {
    display: flex; align-items: baseline; flex-wrap: wrap; gap: 8px;
    margin-bottom: 8px;
    border-bottom: 1.5px solid var(--cfs-border) !important;
    padding-bottom: 10px;
}
.cfs-configurator .cfs-step-num {
    font-size: 11px; font-weight: 600; letter-spacing: .12em;
    color: var(--cfs-step_num); min-width: 24px;
}
.cfs-configurator .cfs-step-title {
    font-family: var(--cfs-heading-font, 'Cormorant Garamond', Georgia, serif);
    font-size: clamp(17px, 2.5vw, 22px);
    font-weight: 500; color: var(--cfs-heading); flex: 1; line-height: 1.25;
}
.cfs-configurator .cfs-step-desc {
    font-size: 12px; line-height: 1.6;
    color: var(--cfs-body_text); opacity: .8; margin-bottom: 16px;
}

/* ── Category filter ─────────────────────────────────────────────── */
.cfs-configurator .cfs-cat-filter {
    font-family: var(--cfs-body-font, system-ui, sans-serif);
    font-size: 12px; padding: 4px 28px 4px 10px;
    border: 1px solid var(--cfs-border) !important; border-radius: 6px;
    background: var(--cfs-bg); color: var(--cfs-body_text);
    cursor: pointer; -webkit-appearance: none; appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23999'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 8px center;
    margin-left: auto;
    transition: border-color var(--cfs-ease);
}
.cfs-configurator .cfs-cat-filter:focus {
    outline: 2px solid var(--cfs-selected_ring); outline-offset: 1px;
}

/* ── Swatches ────────────────────────────────────────────────────── */


/* ── Cards ── Fix #2: high-specificity hover to beat Elementor ───── */

/* Desktop: 8-col grid */
.cfs-configurator .cfs-cards {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 15px;
    min-width: 0;
}

/* ── Tablet / Mobile: horizontal scroll-snap carousel ── */
@container cfs (max-width: 900px) {
    .cfs-configurator .cfs-cards {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        gap: 12px;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;          /* Firefox */
        padding-bottom: 6px;            /* room for scroll shadow */
    }
    .cfs-configurator .cfs-cards::-webkit-scrollbar { display: none; }
    .cfs-configurator .cfs-card {
        flex: 0 0 clamp(140px, 38vw, 220px);
        width: clamp(140px, 38vw, 220px) !important;
        scroll-snap-align: start;
        scroll-snap-stop: always;
    }
}
@container cfs (max-width: 520px) {
    .cfs-configurator .cfs-card {
        flex: 0 0 clamp(130px, 70vw, 200px);
        width: clamp(130px, 70vw, 200px) !important;
    }
}

/* Fallback for browsers without container queries */
@supports not (container-type: inline-size) {
    @media (max-width: 960px) {
        .cfs-configurator .cfs-cards {
            display: flex; flex-direction: row; flex-wrap: nowrap;
            gap: 12px; overflow-x: auto;
            scroll-snap-type: x mandatory;
            -webkit-overflow-scrolling: touch;
            scrollbar-width: none; padding-bottom: 6px;
        }
        .cfs-configurator .cfs-cards::-webkit-scrollbar { display: none; }
        .cfs-configurator .cfs-card {
            flex: 0 0 clamp(140px, 38vw, 220px);
            width: clamp(140px, 38vw, 220px) !important;
            scroll-snap-align: start;
        }
    }
    @media (max-width: 540px) {
        .cfs-configurator .cfs-card {
            flex: 0 0 clamp(130px, 70vw, 200px);
            width: clamp(130px, 70vw, 200px) !important;
        }
    }
}

.cfs-configurator .cfs-card {
    position: relative;
    display: block;
    aspect-ratio: 1 / 1;
    padding: 0;
    border: 2px solid transparent !important;
    border-radius: var(--cfs-radius-sm);
    cursor: pointer;
    background: var(--cfs-border) !important;
    color: inherit !important;
    text-align: left;
    width: 100%;
    min-width: 0;
    overflow: hidden;
    isolation: isolate;                /* clean stacking context — prevents blur from mixed GPU layers */
    transition: border-color var(--cfs-ease), box-shadow var(--cfs-ease);
}

/* Fix #2: explicit hover with !important on background to override Elementor pink */
.cfs-configurator .cfs-card:hover,
.cfs-configurator .cfs-card:focus-visible {
    border-color: var(--cfs-accent) !important;
    box-shadow:   0 4px 18px rgba(0, 0, 0, .18);
    outline: none;
}
.cfs-configurator .cfs-card[aria-pressed="true"] {
    border-color: var(--cfs-selected_ring) !important;
    box-shadow:   0 0 0 2px var(--cfs-selected_ring);
}
.cfs-configurator .cfs-card[aria-pressed="true"]:hover,
.cfs-configurator .cfs-card[aria-pressed="true"]:focus-visible {
    border-color: var(--cfs-selected_ring) !important;
    box-shadow:   0 0 0 2px var(--cfs-selected_ring), 0 4px 18px rgba(0, 0, 0, .18);
}

/* ── Square image-grid card layout ─────────────────────────────── */

/* Image fills the entire square card */
.cfs-configurator .cfs-card-thumb {
    position: absolute;
    inset: 0;
    background: var(--cfs-border);
    overflow: hidden;
}
.cfs-configurator .cfs-card-thumb img {
    width: 100%; height: 100%; object-fit: cover; display: block;
    /* Render at native pixel density — no GPU compositing tricks that cause blur */
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
}

/* Title bar — frosted overlay pinned to bottom of card */
.cfs-configurator .cfs-card-info {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    background: linear-gradient(to top, rgba(0,0,0,.52) 0%, rgba(0,0,0,.0) 100%);
    backdrop-filter: blur(0px);
}

.cfs-configurator .cfs-card-title {
    font-size: 12px; font-weight: 600;
    color: #ffffff;
    line-height: 1.3;
    font-family: var(--cfs-body-font, system-ui, sans-serif);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    flex: 1;
    text-shadow: 0 1px 3px rgba(0,0,0,.4);
}

/* Description — hidden */
.cfs-configurator .cfs-card-desc { display: none; }

/* Radio dot — in the title overlay bar */
.cfs-configurator .cfs-card-radio {
    width: 18px; height: 18px; border-radius: 50%;
    border: 2px solid rgba(255,255,255,.7) !important;
    flex-shrink: 0;
    align-self: center;
    position: relative;
    background: transparent;
    transition: border-color var(--cfs-ease), background var(--cfs-ease);
}
.cfs-configurator .cfs-card-radio::after {
    content: ''; position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%) scale(0);
    width: 9px; height: 9px; border-radius: 50%;
    background: #fff;
    transition: transform var(--cfs-ease);
}
.cfs-configurator .cfs-card[aria-pressed="true"] .cfs-card-radio {
    border-color: #fff !important;
    background: var(--cfs-selected_ring);
}
.cfs-configurator .cfs-card[aria-pressed="true"] .cfs-card-radio::after {
    transform: translate(-50%, -50%) scale(1);
}

/* ── Zoom icon (desktop lightbox trigger) ───────────────────────── */
.cfs-configurator .cfs-card-zoom {
    position: absolute !important;
    top: 8px !important; right: 8px !important;
    width: 32px !important; height: 32px !important;
    border-radius: 50% !important;
    background: rgba(0,0,0,0.55) !important;
    background-color: rgba(0,0,0,0.55) !important;
    border: none !important; outline: none !important;
    cursor: zoom-in !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    opacity: 0 !important;
    pointer-events: auto !important;   /* must be auto so click fires */
    transition: opacity 0.18s ease !important;
    z-index: 5 !important;
    padding: 0 !important; margin: 0 !important;
    box-shadow: none !important;
    color: #fff !important;
}
.cfs-configurator .cfs-card-zoom svg {
    width: 15px !important; height: 15px !important;
    display: block !important;
    stroke: #fff !important; fill: none !important;
    stroke-width: 2.2 !important;
    stroke-linecap: round !important; stroke-linejoin: round !important;
    pointer-events: none !important;
}
/* Show on hover (desktop) and always on touch */
.cfs-configurator .cfs-card:hover .cfs-card-zoom { opacity: 1 !important; }
@media (hover: none) {
    .cfs-configurator .cfs-card-zoom { opacity: 0.85 !important; }
}

/* ── Carousel (tablet & mobile) ─────────────────────────────────── */
.cfs-configurator .cfs-carousel-wrap {
    position: relative;
}
.cfs-configurator .cfs-carousel-btn {
    position: absolute;
    top: 50%; transform: translateY(-50%);
    z-index: 10;
    width: 34px; height: 34px; border-radius: 50%;
    background: var(--cfs-card_bg);
    border: 1px solid var(--cfs-border) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.12);
    cursor: pointer;
    display: none;                  /* hidden on desktop */
    align-items: center; justify-content: center;
    transition: background var(--cfs-ease), box-shadow var(--cfs-ease);
}
.cfs-configurator .cfs-carousel-btn:hover {
    background: var(--cfs-accent) !important;
}
.cfs-configurator .cfs-carousel-btn:hover svg { stroke: #fff; }
.cfs-configurator .cfs-carousel-btn svg {
    width: 16px; height: 16px; stroke: var(--cfs-heading); fill: none;
    stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round;
    pointer-events: none;
}
.cfs-configurator .cfs-carousel-btn--prev { left: -14px; }
.cfs-configurator .cfs-carousel-btn--next { right: -14px; }

/* Dot indicators */
.cfs-configurator .cfs-carousel-dots {
    display: none;
    justify-content: center;
    gap: 6px;
    margin-top: 10px;
    flex-wrap: wrap;
}
.cfs-configurator .cfs-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--cfs-border);
    border: none; cursor: pointer; padding: 0;
    transition: background var(--cfs-ease), transform var(--cfs-ease);
    flex-shrink: 0;
}
.cfs-configurator .cfs-dot.active {
    background: var(--cfs-accent);
    transform: scale(1.3);
}

/* Switch to carousel on tablet/mobile */
@container cfs (max-width: 900px) {
    .cfs-configurator .cfs-cards {
        display: flex !important;
        flex-direction: row;
        overflow-x: scroll;
        scroll-snap-type: x mandatory;
        scroll-behavior: smooth;
        -webkit-overflow-scrolling: touch;
        gap: 12px;
        padding-bottom: 4px;          /* space for scrollbar */
        scrollbar-width: none;        /* Firefox */
    }
    .cfs-configurator .cfs-cards::-webkit-scrollbar { display: none; }
    .cfs-configurator .cfs-card {
        flex: 0 0 42%;                /* ~2.3 cards visible */
        width: 42%;
        scroll-snap-align: start;
        aspect-ratio: 1 / 1;
    }
    .cfs-configurator .cfs-carousel-btn { display: flex; }
    .cfs-configurator .cfs-carousel-dots { display: flex; }
}
@container cfs (max-width: 480px) {
    .cfs-configurator .cfs-card {
        flex: 0 0 72%;                /* ~1.3 cards visible on mobile */
        width: 72%;
    }
}
/* Fallback */
@supports not (container-type: inline-size) {
    @media (max-width: 960px) {
        .cfs-configurator .cfs-cards {
            display: flex !important;
            flex-direction: row;
            overflow-x: scroll;
            scroll-snap-type: x mandatory;
            scroll-behavior: smooth;
            -webkit-overflow-scrolling: touch;
            gap: 12px;
            padding-bottom: 4px;
            scrollbar-width: none;
        }
        .cfs-configurator .cfs-cards::-webkit-scrollbar { display: none; }
        .cfs-configurator .cfs-card { flex: 0 0 42%; width: 42%; scroll-snap-align: start; }
        .cfs-configurator .cfs-carousel-btn { display: flex; }
        .cfs-configurator .cfs-carousel-dots { display: flex; }
    }
    @media (max-width: 540px) {
        .cfs-configurator .cfs-card { flex: 0 0 72%; width: 72%; }
    }
}


/* ── Lightbox buttons — !important beats Elementor Hello theme resets ── */
.cfs-lightbox-close,
.cfs-lightbox-prev,
.cfs-lightbox-next {
    position: absolute !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    border: none !important;
    outline: none !important;
    cursor: pointer !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
    text-decoration: none !important;
    box-shadow: none !important;
    transition: background .18s !important;
}

/* Close — dark pill, top-right of panel */
.cfs-lightbox-close {
    top: 12px !important;
    right: 12px !important;
    width: 34px !important;
    height: 34px !important;
    background: rgba(0,0,0,.55) !important;
    background-color: rgba(0,0,0,.55) !important;
    color: #ffffff !important;
    z-index: 10 !important;
}
.cfs-lightbox-close:hover,
.cfs-lightbox-close:focus {
    background: rgba(0,0,0,.80) !important;
    background-color: rgba(0,0,0,.80) !important;
}

/* Prev / Next — frosted, on the backdrop */
.cfs-lightbox-prev,
.cfs-lightbox-next {
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 44px !important;
    height: 44px !important;
    background: rgba(255,255,255,.18) !important;
    background-color: rgba(255,255,255,.18) !important;
    border: 1.5px solid rgba(255,255,255,.35) !important;
    color: #ffffff !important;
    z-index: 10 !important;
}
.cfs-lightbox-prev { left: 14px !important; }
.cfs-lightbox-next { right: 14px !important; }
.cfs-lightbox-prev:hover,
.cfs-lightbox-prev:focus,
.cfs-lightbox-next:hover,
.cfs-lightbox-next:focus {
    background: rgba(255,255,255,.32) !important;
    background-color: rgba(255,255,255,.32) !important;
}
.cfs-lightbox-prev[disabled],
.cfs-lightbox-next[disabled] {
    opacity: .3 !important;
    cursor: default !important;
}

/* SVG icons inside all three */
.cfs-lightbox-close svg,
.cfs-lightbox-prev svg,
.cfs-lightbox-next svg {
    width: 18px !important;
    height: 18px !important;
    display: block !important;
    stroke: #ffffff !important;
    fill: none !important;
    stroke-width: 2.5 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
    pointer-events: none !important;
    flex-shrink: 0 !important;
}

@media (max-width: 600px) {
    .cfs-lightbox-prev,
    .cfs-lightbox-next { display: none !important; }
}

/* ── Summary ─────────────────────────────────────────────────────── */
.cfs-configurator .cfs-summary {
    margin-top: 24px;
}
.cfs-configurator .cfs-summary-inner {
    background: var(--cfs-summary_bg);
    border-radius: var(--cfs-radius);
    padding: 22px 24px;
}
.cfs-configurator .cfs-summary-heading {
    font-family: var(--cfs-heading-font, 'Cormorant Garamond', Georgia, serif);
    font-size: 13px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
    color: var(--cfs-heading); opacity: .6;
    margin-bottom: 16px;
}

/* 3-column card strip */
.cfs-configurator .cfs-summary-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}

/* Individual summary card */
.cfs-configurator .cfs-sum-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    background: var(--cfs-card_bg);
    border: 1px solid var(--cfs-border) !important;
    border-radius: var(--cfs-radius-sm);
    padding: 14px;
    min-height: 96px;
    transition: border-color var(--cfs-ease);
}
.cfs-configurator .cfs-sum-card.has-selection {
    border-color: var(--cfs-accent) !important;
}

/* Label (step name) */
.cfs-configurator .cfs-sum-label {
    font-size: 10px; font-weight: 600; letter-spacing: .10em;
    text-transform: uppercase;
    color: var(--cfs-body_text); opacity: .55;
    font-family: var(--cfs-body-font, system-ui);
}

/* Thumbnail in summary */
.cfs-configurator .cfs-sum-thumb {
    width: 52px; height: 52px;
    border-radius: var(--cfs-radius-sm);
    background: var(--cfs-border);
    overflow: hidden; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
}
.cfs-configurator .cfs-sum-thumb img {
    width: 100%; height: 100%; object-fit: cover; display: block;
}

/* Selected item name */
.cfs-configurator .cfs-sum-title {
    font-size: 13px; font-weight: 600;
    color: var(--cfs-heading);
    font-family: var(--cfs-body-font, system-ui);
    line-height: 1.3;
}

/* Empty placeholder */
.cfs-configurator .cfs-sum-empty {
    font-size: 12px; font-style: italic;
    color: var(--cfs-body_text); opacity: .4;
    margin-top: auto;
    font-family: var(--cfs-body-font, system-ui);
}

/* Responsive: stack to 1 col on narrow */
@media (max-width: 560px) {
    .cfs-configurator .cfs-summary-cards {
        grid-template-columns: 1fr;
    }
}

/* ── CTA button ── Fix #2: !important on hover to override Elementor */
.cfs-configurator .cfs-cta-btn {
    display: block !important;
    width: 100% !important;
    margin-top: 16px !important;
    padding: 14px 20px !important;
    background: var(--cfs-btn_bg, var(--cfs-accent, #551BE3)) !important;
    background-color: var(--cfs-btn_bg, var(--cfs-accent, #551BE3)) !important;
    color: var(--cfs-btn_text, #ffffff) !important;
    text-align: center !important;
    text-decoration: none !important;
    font-family: var(--cfs-body-font, system-ui, sans-serif) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: .18em !important;
    text-transform: uppercase !important;
    border-radius: var(--cfs-radius-sm) !important;
    border: none !important;
    outline: none !important;
    cursor: pointer !important;
    box-shadow: none !important;
    transform: none;
    transition: background .2s ease, transform .2s ease, box-shadow .2s ease !important;
    pointer-events: auto !important;
}
.cfs-configurator .cfs-cta-btn:hover,
.cfs-configurator .cfs-cta-btn:focus-visible {
    background: var(--cfs-btn_hover_bg, color-mix(in srgb, var(--cfs-accent, #551BE3) 88%, #000)) !important;
    background-color: var(--cfs-btn_hover_bg, color-mix(in srgb, var(--cfs-accent, #551BE3) 88%, #000)) !important;
    color: var(--cfs-btn_hover_text, #ffffff) !important;
    text-decoration: none !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 18px rgba(0,0,0,.18) !important;
    cursor: pointer !important;
    pointer-events: auto !important;
}


