/* ===================================================
   WC Linked Variants — Frontend Swatches v1.2
   =================================================== */

.wclv-root {
    margin: 14px 0 20px;
    font-family: inherit;
    line-height: 1;
}

/* ---- Wiersz jednego atrybutu ---- */
.wclv-attr-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 12px;
}
.wclv-attr-row:last-of-type {
    margin-bottom: 0;
}

.wclv-attr-label {
    font-size: 12px;
    font-weight: 700;
    color: #6b7280;
    text-transform: uppercase;
    letter-spacing: .07em;
    min-width: 70px;
    flex-shrink: 0;
}

.wclv-swatches {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    align-items: center;
}

/* ---- Info o wybranym wariancie ---- */
.wclv-selected-info {
    margin-top: 11px;
    font-size: 13px;
    color: #374151;
    padding-top: 10px;
    border-top: 1px solid #f1f5f9;
}
.wclv-selected-info strong {
    color: #0f172a;
    font-weight: 600;
}
.wclv-info-sep {
    color: #d1d5db;
    margin: 0 2px;
}

/* =====================================================
   WSPÓLNE STYLE SWATCHÓW
   ===================================================== */
.wclv-swatch {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform .18s ease, box-shadow .18s ease, opacity .15s ease;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
}

/* Zablokowane (OOS lub niedostępna kombinacja) */
.wclv-swatch--oos,
.wclv-swatch--unavail {
    cursor: not-allowed;
    pointer-events: none; /* brak kliknięcia */
}

/* =====================================================
   PRÓBKI KOLORÓW
   ===================================================== */
.wclv-swatch--color {
    width: 42px;
    height: 42px;
}

.wclv-swatch__dot {
    display: block;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 2px solid rgba(0,0,0,.1);
    transition: transform .2s ease, box-shadow .2s ease;
    overflow: hidden;
    flex-shrink: 0;
}

/* Hover */
.wclv-swatch--color:not(.wclv-swatch--oos):not(.wclv-swatch--unavail):hover .wclv-swatch__dot {
    transform: scale(1.12);
    box-shadow: 0 4px 12px rgba(0,0,0,.2);
}

/* Aktywny */
.wclv-swatch--color.wclv-swatch--active .wclv-swatch__dot {
    box-shadow: 0 0 0 2.5px #fff, 0 0 0 5px #1a1a2e;
    transform: scale(1.06);
}

/* OOS/Niedostępny — kolor */
.wclv-swatch--color.wclv-swatch--oos .wclv-swatch__dot,
.wclv-swatch--color.wclv-swatch--unavail .wclv-swatch__dot {
    opacity: .35;
    filter: grayscale(.6);
}

/* Przekreślenie dla koloru */
.wclv-swatch__x {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 28px;
    height: 2px;
    background: rgba(100,100,100,.7);
    border-radius: 2px;
    transform: translate(-50%, -50%) rotate(-45deg);
    pointer-events: none;
}

/* =====================================================
   PRÓBKI ROZMIARU / TEKSTU
   ===================================================== */
.wclv-swatch--size,
.wclv-swatch--text {
    position: relative;
    min-width: 46px;
    height: 40px;
    padding: 0 13px;
    border: 2px solid #d1d5db;
    border-radius: 8px;
    background: #fff;
    overflow: hidden;
}

.wclv-swatch__txt {
    font-size: 13px;
    font-weight: 700;
    color: #374151;
    letter-spacing: .02em;
    transition: color .15s;
    position: relative;
    z-index: 1;
}

/* Hover — rozmiar */
.wclv-swatch--size:not(.wclv-swatch--oos):not(.wclv-swatch--unavail):hover,
.wclv-swatch--text:not(.wclv-swatch--oos):not(.wclv-swatch--unavail):hover {
    border-color: #1a1a2e;
    transform: translateY(-1px);
    box-shadow: 0 3px 8px rgba(0,0,0,.1);
}
.wclv-swatch--size:not(.wclv-swatch--oos):not(.wclv-swatch--unavail):hover .wclv-swatch__txt,
.wclv-swatch--text:not(.wclv-swatch--oos):not(.wclv-swatch--unavail):hover .wclv-swatch__txt {
    color: #1a1a2e;
}

/* Aktywny */
.wclv-swatch--size.wclv-swatch--active,
.wclv-swatch--text.wclv-swatch--active {
    background: #1a1a2e;
    border-color: #1a1a2e;
    box-shadow: 0 2px 8px rgba(26,26,46,.25);
}
.wclv-swatch--size.wclv-swatch--active .wclv-swatch__txt,
.wclv-swatch--text.wclv-swatch--active .wclv-swatch__txt {
    color: #fff;
}

/* OOS/Niedostępny — rozmiar */
.wclv-swatch--size.wclv-swatch--oos .wclv-swatch__txt,
.wclv-swatch--size.wclv-swatch--unavail .wclv-swatch__txt,
.wclv-swatch--text.wclv-swatch--oos .wclv-swatch__txt,
.wclv-swatch--text.wclv-swatch--unavail .wclv-swatch__txt {
    color: #c4c8cf;
}

.wclv-swatch--size.wclv-swatch--oos,
.wclv-swatch--size.wclv-swatch--unavail,
.wclv-swatch--text.wclv-swatch--oos,
.wclv-swatch--text.wclv-swatch--unavail {
    border-color: #eaecef;
    background: #f9fafb;
}

/* Przekreślenie dla rozmiaru */
.wclv-swatch__line {
    position: absolute;
    top: 50%;
    left: -4px;
    right: -4px;
    height: 1.5px;
    background: #d1d5db;
    transform: rotate(-18deg);
    pointer-events: none;
}

/* Niedostępna kombinacja: lekko inna stylistyka */
.wclv-swatch--unavail {
    opacity: .5;
}

/* =====================================================
   Responsive
   ===================================================== */
@media (max-width: 480px) {
    .wclv-attr-label { min-width: 60px; font-size: 11px; }

    .wclv-swatch--color { width: 36px; height: 36px; }
    .wclv-swatch__dot   { width: 32px; height: 32px; }

    .wclv-swatch--size,
    .wclv-swatch--text {
        min-width: 40px;
        height: 36px;
        padding: 0 10px;
    }
    .wclv-swatch__txt { font-size: 12px; }
}
