/* 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 ───── */
.cfs-configurator .cfs-cards {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 15px;
    min-width: 0;
}
/* Tablet: 4-col */
@container cfs (max-width: 900px) {
    .cfs-configurator .cfs-cards { grid-template-columns: repeat(4, 1fr); }
}
/* Mobile: 2-col */
@container cfs (max-width: 480px) {
    .cfs-configurator .cfs-cards { grid-template-columns: repeat(2, 1fr); }
}
@supports not (container-type: inline-size) {
    @media (max-width: 960px) {
        .cfs-configurator .cfs-cards { grid-template-columns: repeat(4, 1fr); }
    }
    @media (max-width: 540px) {
        .cfs-configurator .cfs-cards { grid-template-columns: repeat(2, 1fr); }
    }
}

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

/* ── 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; width: 100%; margin-top: 16px; padding: 14px 20px;
    background: var(--cfs-btn_bg) !important;
    color: var(--cfs-btn_text) !important;
    text-align: center; text-decoration: none !important;
    font-family: var(--cfs-body-font, system-ui, sans-serif);
    font-size: 11px; font-weight: 600;
    letter-spacing: .18em; text-transform: uppercase;
    border-radius: var(--cfs-radius-sm); border: none; cursor: pointer;
    transition: background var(--cfs-ease), color var(--cfs-ease),
                transform var(--cfs-ease), box-shadow var(--cfs-ease);
}
.cfs-configurator .cfs-cta-btn:hover,
.cfs-configurator .cfs-cta-btn:focus-visible {
    background: var(--cfs-btn_hover_bg,  var(--cfs-accent))  !important;
    color:      var(--cfs-btn_hover_text, #fff)               !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, .14);
    text-decoration: none !important;
    outline: none;
}
.cfs-configurator .cfs-cta-btn:active {
    transform: translateY(0);
}

/* ── Empty state ─────────────────────────────────────────────────── */
.cfs-configurator .cfs-empty {
    text-align: center; padding: 40px;
    color: var(--cfs-body_text); opacity: .6; font-size: 14px;
}
.cfs-configurator .cfs-empty a { color: var(--cfs-accent); }

/* ── Animations ──────────────────────────────────────────────────── */
@keyframes cfs-fadein {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.cfs-configurator .cfs-card { animation: cfs-fadein .28s ease both; }
