/* ==========================================================================
   OFFCANVAS CART & SEARCH STYLES (ЧИСТИЙ МІНІМАЛІЗМ)
   ========================================================================== */

/* --- ПЛАВАЮЧІ ІКОНКИ --- */
html body .wlc-floating-container .wlc-float-item svg {
    width: calc(var(--wlc-float-size, 50px) * 0.45) !important;
    height: calc(var(--wlc-float-size, 50px) * 0.45) !important;
    min-width: 20px !important;
    min-height: 20px !important;
    stroke: var(--wlc-float-color, #333333) !important;
    stroke-width: 2 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
    fill: none !important;
    display: block !important;
    margin: 0 auto !important;
    opacity: 1 !important;
    visibility: visible !important;
}

html body .wlc-floating-container .wlc-float-item i {
    color: var(--wlc-float-color, #333333) !important;
    font-size: calc(var(--wlc-float-size, 50px) * 0.4) !important;
}

html body .wlc-floating-container .wlc-float-item .wlc-cart-count,
html body .wlc-floating-container .wlc-float-item .wlc-fav-count {
    position: absolute !important;
    top: -2px !important;
    right: -2px !important;
    background-color: var(--wlc-accent-color, #e0a240) !important;
    color: #fff !important;
    font-size: 11px !important;
    font-weight: bold !important;
    width: 20px !important;
    height: 20px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    pointer-events: none !important;
    line-height: 1 !important;
    z-index: 10 !important;
}

/* --- МІНІМАЛІСТИЧНИЙ ПОШУК --- */
#wlc-search-overlay {
    position: fixed !important;
    top: 0 !important; left: 0 !important; width: 100vw !important; height: 100vh !important;
    background-color: rgba(0, 0, 0, 0.6) !important; 
    backdrop-filter: blur(3px) !important;
    z-index: 9999999 !important;
    display: flex !important;
    align-items: flex-start !important; 
    justify-content: center !important;
    padding-top: 12vh !important; 
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.3s ease, visibility 0.3s ease !important;
    font-family: var(--wlc-font-family, inherit) !important;
}
#wlc-search-overlay.open { opacity: 1 !important; visibility: visible !important; }

#wlc-search-close { display: none !important; }

#wlc-search-overlay .wlc-search-inner {
    width: 90% !important;
    max-width: 500px !important; 
    background: var(--wlc-card-bg, #ffffff) !important;
    border-radius: var(--wlc-inp-radius, 8px) !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.15) !important;
    padding: 10px 20px !important;
    transform: translateY(-20px) !important;
    transition: transform 0.4s ease !important;
}
#wlc-search-overlay.open .wlc-search-inner { transform: translateY(0) !important; }

#wlc-search-overlay form { 
    display: flex !important; width: 100% !important; margin: 0 !important; 
    align-items: center !important; gap: 10px !important;
}

#wlc-search-overlay input[type="search"],
#wlc-search-overlay input[type="text"] {
    flex-grow: 1 !important; padding: 10px 0 !important; font-size: 1.2rem !important;
    border: none !important; background: transparent !important; outline: none !important; 
    color: var(--wlc-text-color, #333) !important; border-radius: 0 !important; 
    box-shadow: none !important; margin: 0 !important;
}

/* ФІКС: ЗНИЩУЄМО КАСТОМНУ ЛУПУ, ХОВАЄМО ТЕКСТ, ЗАЛИШАЄМО СТАНДАРТНУ ЛУПУ ТЕМИ */
#wlc-search-overlay button,
#wlc-search-overlay input[type="submit"] {
    position: relative !important;
    width: 40px !important; 
    height: 40px !important;
    border: none !important; 
    background: transparent !important;
    box-shadow: none !important;
    cursor: pointer !important;
    padding: 0 !important; 
    margin: 0 !important;
    font-size: 0 !important; /* Жорстко ховаємо слово "Search" */
    color: transparent !important; /* Робимо текст прозорим */
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

#wlc-search-overlay button *,
#wlc-search-overlay button::before,
#wlc-search-overlay button::after,
#wlc-search-overlay form::before,
#wlc-search-overlay form::after {
    font-size: 20px !important;
    color: var(--wlc-text-color, #333) !important;
    display: block !important;
}

#wlc-search-overlay button:hover *,
#wlc-search-overlay button:hover::before,
#wlc-search-overlay button:hover::after {
    color: var(--wlc-accent-color, #e0a240) !important;
}


/* --- SIDE CART OVERLAY --- */
#wlc-cart-overlay, #wlc-fav-overlay {
    position: fixed !important;
    top: 0 !important; left: 0 !important; width: 100vw !important; height: 100vh !important;
    background-color: rgba(0, 0, 0, 0.5) !important;
    z-index: 9999998 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: opacity 0.3s ease, visibility 0.3s ease !important;
}
#wlc-cart-overlay.open, #wlc-fav-overlay.open { opacity: 1 !important; visibility: visible !important; }

/* --- SIDE CART PANEL --- */
#wlc-side-cart, #wlc-side-fav, #wlc-side-cart *, #wlc-side-fav * { box-sizing: border-box !important; }

#wlc-side-cart, #wlc-side-fav {
    position: fixed !important;
    top: 0 !important; right: -100% !important;
    width: 400px !important;
    max-width: 100vw !important;
    height: 100vh !important;
    background-color: var(--wlc-card-bg, #ffffff) !important;
    z-index: 9999999 !important;
    box-shadow: -5px 0 25px rgba(0,0,0,0.1) !important;
    display: flex !important;
    flex-direction: column !important;
    transition: right 0.4s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
    font-family: var(--wlc-font-family, inherit) !important;
}
#wlc-side-cart.open, #wlc-side-fav.open { right: 0 !important; }

#wlc-side-cart::after, #wlc-side-fav::after {
    content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(255,255,255,0.7); z-index: 99; opacity: 0; visibility: hidden; transition: 0.2s;
}
#wlc-side-cart.wlc-loading::after, #wlc-side-fav.wlc-loading::after { opacity: 1; visibility: visible; }

#wlc-side-cart .wlc-side-cart-header, #wlc-side-fav .wlc-side-cart-header {
    display: flex !important; align-items: center !important; justify-content: space-between !important;
    padding: 20px !important; border-bottom: 1px solid var(--wlc-border-color, #eee) !important;
}
#wlc-side-cart .wlc-side-cart-title, #wlc-side-fav .wlc-side-cart-title { font-size: 1.2rem !important; font-weight: 700 !important; color: var(--wlc-text-color, #333) !important; margin: 0 !important; }
#wlc-side-cart .wlc-side-cart-close, #wlc-side-fav .wlc-side-cart-close { font-size: 28px !important; cursor: pointer !important; color: var(--wlc-text-color, #333) !important; line-height: 1 !important; transition: color 0.2s !important; }
#wlc-side-cart .wlc-side-cart-close:hover, #wlc-side-fav .wlc-side-cart-close:hover { color: var(--wlc-accent-color, #e0a240) !important; }

#wlc-side-cart .wlc-side-cart-body, #wlc-side-fav .wlc-side-cart-body { flex-grow: 1 !important; padding: 20px !important; display: flex !important; flex-direction: column !important; overflow: hidden !important; }
#wlc-side-cart .widget_shopping_cart_content { display: flex !important; flex-direction: column !important; height: 100% !important; width: 100% !important; }

/* Список товарів (Скролл) */
#wlc-side-cart ul.woocommerce-mini-cart, #wlc-side-fav ul.woocommerce-mini-cart {
    flex-grow: 1 !important; 
    padding: 0 20px !important; /* Відсуваємо товари назад */
    margin: 0 -20px 20px -20px !important; /* Притискаємо скрол до самих країв панелі */
    list-style: none !important;
    overflow-y: auto !important; 
    overflow-x: hidden !important;
    scrollbar-width: thin !important; /* Тонкий скрол для Firefox */
    scrollbar-color: #dddddd transparent !important; /* Колір для Firefox */
}

/* Робимо сучасний тонкий скролбар для Chrome / Safari / Edge */
#wlc-side-cart ul.woocommerce-mini-cart::-webkit-scrollbar, 
#wlc-side-fav ul.woocommerce-mini-cart::-webkit-scrollbar {
    width: 6px !important; /* Ширина скролбару */
}
#wlc-side-cart ul.woocommerce-mini-cart::-webkit-scrollbar-track, 
#wlc-side-fav ul.woocommerce-mini-cart::-webkit-scrollbar-track {
    background: transparent !important; /* Прозорий фон під скролом */
}
#wlc-side-cart ul.woocommerce-mini-cart::-webkit-scrollbar-thumb, 
#wlc-side-fav ul.woocommerce-mini-cart::-webkit-scrollbar-thumb {
    background: #e0e0e0 !important; /* Світло-сірий колір самого повзунка */
    border-radius: 10px !important; /* Закруглені краї */
}
#wlc-side-cart ul.woocommerce-mini-cart::-webkit-scrollbar-thumb:hover, 
#wlc-side-fav ul.woocommerce-mini-cart::-webkit-scrollbar-thumb:hover {
    background: #cccccc !important; /* Трохи темнішає при наведенні */
}

/* Елемент товару */
#wlc-side-cart .woocommerce-mini-cart-item, #wlc-side-fav .woocommerce-mini-cart-item {
    position: relative !important;
    padding: 0 0 15px 85px !important;
    margin: 0 0 15px 0 !important;
    border-bottom: 1px solid var(--wlc-border-color, #eee) !important;
    min-height: 85px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

/* Картинка товару */
#wlc-side-cart .woocommerce-mini-cart-item img, #wlc-side-fav .woocommerce-mini-cart-item img {
    position: absolute !important;
    top: 0 !important; left: 0 !important;
    width: 70px !important; height: 70px !important;
    min-width: 70px !important; max-width: 70px !important;
    object-fit: cover !important;
    border-radius: var(--wlc-border-radius, 6px) !important;
    margin: 0 !important; padding: 0 !important; box-shadow: none !important;
}

/* Назва товару */
#wlc-side-cart .woocommerce-mini-cart-item > a:not(.remove), #wlc-side-fav .woocommerce-mini-cart-item > a:not(.remove) {
    font-size: 14px !important; line-height: 1.3 !important; font-weight: 600 !important;
    color: var(--wlc-text-color, #333) !important; text-decoration: none !important;
    display: block !important; margin-bottom: 8px !important; padding-right: 25px !important;
}

/* Кнопка "Видалити" */
#wlc-side-cart .woocommerce-mini-cart-item a.remove, #wlc-side-fav .woocommerce-mini-cart-item a.remove {
    position: absolute !important; top: 0 !important; right: 0 !important;
    color: #ff4d4d !important; font-size: 22px !important; line-height: 1 !important;
    text-decoration: none !important; background: transparent !important;
    padding: 0 !important; margin: 0 !important; border: none !important; width: auto !important; height: auto !important;
}
#wlc-side-cart .woocommerce-mini-cart-item a.remove:hover, #wlc-side-fav .woocommerce-mini-cart-item a.remove:hover { color: #cc0000 !important; }

/* Блок з ціною та +/- */
#wlc-side-cart .wlc-mini-cart-meta, #wlc-side-fav .wlc-mini-cart-meta {
    display: flex !important; justify-content: space-between !important; align-items: center !important;
}
#wlc-side-cart .wlc-item-price .amount, #wlc-side-fav .wlc-item-price .amount {
    font-size: 15px !important; font-weight: bold !important; color: var(--wlc-accent-color, #e0a240) !important;
}

/* Кнопки +/- */
#wlc-side-cart .wlc-mini-cart-qty {
    display: inline-flex !important; align-items: center !important;
    border: 1px solid var(--wlc-inp-border, #ddd) !important; border-radius: var(--wlc-inp-radius, 4px) !important;
    background: var(--wlc-inp-bg, #fff) !important; overflow: hidden !important;
}
#wlc-side-cart .wlc-qty-btn {
    width: 28px !important; height: 28px !important; background: transparent !important; border: none !important;
    color: var(--wlc-inp-text, #333) !important; font-size: 16px !important; cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    padding: 0 !important; margin: 0 !important; line-height: 1 !important;
}
#wlc-side-cart .wlc-qty-btn:hover { background: rgba(0,0,0,0.05) !important; }

#wlc-side-cart .wlc-qty-input {
    width: 35px !important; height: 28px !important; border: none !important;
    border-left: 1px solid var(--wlc-inp-border, #ddd) !important; border-right: 1px solid var(--wlc-inp-border, #ddd) !important;
    text-align: center !important; font-size: 14px !important; padding: 0 !important; margin: 0 !important;
    background: transparent !important; color: var(--wlc-inp-text, #333) !important; border-radius: 0 !important;
    
    -webkit-appearance: none !important;
    -moz-appearance: textfield !important;
    appearance: textfield !important;
}

#wlc-side-cart .wlc-qty-input::-webkit-outer-spin-button,
#wlc-side-cart .wlc-qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none !important;
    appearance: none !important;
    margin: 0 !important;
}

/* ФУТЕР КОШИКА */
#wlc-side-cart .wlc-cart-footer,
#wlc-side-cart .woocommerce-mini-cart__total {
    margin-top: auto !important; 
    width: 100% !important;
}
#wlc-side-cart .woocommerce-mini-cart__total {
    padding: 20px 0 15px 0 !important; border-top: 2px solid var(--wlc-border-color, #eee) !important;
    display: flex !important; justify-content: space-between !important; align-items: center !important;
    font-size: 18px !important; font-weight: 700 !important; color: var(--wlc-text-color, #333) !important;
    background: var(--wlc-card-bg, #fff) !important;
}
#wlc-side-cart .woocommerce-mini-cart__total .amount {
    color: var(--wlc-accent-color, #e0a240) !important;
}

/* Кнопки Cart / Checkout */
#wlc-side-cart .woocommerce-mini-cart__buttons {
    padding: 0 !important; margin: 0 !important; display: flex !important; flex-direction: column !important; gap: 10px !important;
    background: var(--wlc-card-bg, #fff) !important;
}
#wlc-side-cart .woocommerce-mini-cart__buttons a {
    display: flex !important; justify-content: center !important; align-items: center !important;
    padding: 14px 20px !important; border-radius: var(--wlc-gbtn-radius, 8px) !important;
    font-weight: 600 !important; text-decoration: none !important; font-size: 15px !important;
    transition: all 0.3s ease !important; margin: 0 !important; width: 100% !important;
}
#wlc-side-cart .woocommerce-mini-cart__buttons a:not(.checkout) {
    background-color: transparent !important; color: var(--wlc-text-color, #333) !important; border: 2px solid var(--wlc-border-color, #ddd) !important;
}
#wlc-side-cart .woocommerce-mini-cart__buttons a:not(.checkout):hover {
    border-color: var(--wlc-accent-color, #e0a240) !important; color: var(--wlc-accent-color, #e0a240) !important;
}
#wlc-side-cart .woocommerce-mini-cart__buttons a.checkout {
    background-color: var(--wlc-gbtn-bg, #000) !important; color: var(--wlc-gbtn-text, #fff) !important;
    border: var(--wlc-gbtn-border, none) !important; box-shadow: 0 4px 15px rgba(0,0,0,0.1) !important;
}
#wlc-side-cart .woocommerce-mini-cart__buttons a.checkout:hover {
    background-color: var(--wlc-gbtn-hbg, #333) !important; color: var(--wlc-gbtn-htext, #fff) !important;
    transform: var(--wlc-gbtn-anim, translateY(-2px)) !important; box-shadow: 0 8px 20px rgba(0,0,0,0.15) !important;
}

#wlc-side-cart .woocommerce-mini-cart__empty-message, #wlc-side-fav .woocommerce-mini-cart__empty-message {
    text-align: center !important; color: var(--wlc-text-color, #333) !important; margin-top: 40px !important;
}

/* ДОДАНО: СТИЛЬ ДЛЯ УНІВЕРСАЛЬНОЇ КНОПКИ В ТВОЄМУ СЛОТІ */
.wlc-universal-fav {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    border: 1px solid #eee !important;
    border-radius: 50% !important;
    width: 36px !important;
    height: 36px !important;
    cursor: pointer !important;
    z-index: 99 !important;
    position: relative !important; /* Легко стає в твою полоску, не випадає */
    box-shadow: 0 2px 5px rgba(0,0,0,0.05) !important;
    font-size: 16px !important;
    transition: 0.2s !important;
    padding: 0 !important;
    line-height: 1 !important;
    user-select: none !important;
    -webkit-tap-highlight-color: transparent !important;
}
.wlc-universal-fav:hover { transform: scale(1.1) !important; }