/* ==========================================================================
   WSPÓŁDZIELONE STYLE DLA KARTY PRODUKTU I SIATKI (ZWIĘKSZONA SPECYFICZNOŚĆ)
   ========================================================================== */

/* 1. Karta produktu i link */
.woo-main .woo-main__content ul.products li.product {
    padding: 0;
    border: none;
    box-shadow: none;
    background: none;
    text-align: left;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
}
.woo-main .woo-main__content ul.products li.product a.woocommerce-LoopProduct-link {
    display: block;
    text-decoration: none;
    color: inherit;
}

/* 2. Obrazek produktu */
.woo-main .woo-main__content ul.products li.product a img {
	margin-bottom: 0.8rem;
	border-radius: var(--radius-3);
    transition: filter 0.3s ease-in-out;
	width: 100%;
	object-fit: cover;
	object-position: center;
	height: auto;
}

/* 3. Znaczek "Promocja!" */
.woo-main .woo-main__content ul.products li.product .onsale {	
	position: absolute;
    top: 1rem;
    right: 2rem;
    left: auto;
    background-color: var(--color-1);
    color: var(--white-1);
    font-size: 1.3rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 1;
    padding: 0.6rem 1.4rem;
    border-radius: var(--radius-full);
    margin: 0;
    z-index: 2;
    min-width: unset;
    min-height: unset;
}

/* 4. Tytuł produktu */
.woo-main .woo-main__content ul.products li.product .woocommerce-loop-product__title {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--font-color-2);
    margin-top: 2rem;
    margin-bottom: 0.8rem;
	padding: 0;
    text-decoration: underline;
    text-decoration-color: transparent;
    text-decoration-thickness: 1px; 
    transition: text-decoration-color 0.2s ease;
}
.woo-main .woo-main__content ul.products li.product a.woocommerce-loop-product__link:hover .woocommerce-loop-product__title {
	text-decoration-color: var(--font-color-2);
}

/* 5. Cena produktu */
.woo-main .woo-main__content ul.products li.product .price {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--font-color-1);
    margin-bottom: 1.5rem;
    line-height: 1.3;
	padding: 0;
}
.woo-main .woo-main__content ul.products li.product .price ins { text-decoration: none; background: none; }
.woo-main .woo-main__content ul.products li.product .price del {
    font-size: 1.6rem;
    font-weight: 400;
    color: var(--black-8);
    margin-right: 0.8rem;
    opacity: 0.8;
}
.woo-main .woo-main__content ul.products li.product .price .woocommerce-Price-amount + span {
    font-size: 1.6rem;
    font-weight: 300;
    color: var(--font-color-3);
    margin: 0 0.2em;
    vertical-align: text-top;
}

/* 6. Kontener na gwiazdki i opinie */
.woo-main .woo-main__content ul.products li.product .product-rating-wrap {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    margin-bottom: 1rem;
}

/* 7. Gwiazdki i opinie */
.woo-main .woo-main__content ul.products li.product .star-rating {
    display: flex;
    align-items: center;
    font-size: 1.6rem;
    margin-bottom: 0;
}
.woo-main .woo-main__content ul.products li.product .star-rating::before { color: var(--bg-2); }
.woo-main .woo-main__content ul.products li.product .star-rating span::before { color: var(--woo-star); }
.woo-main .woo-main__content ul.products li.product .review-count {
    display: inline;
    font-size: 1.6rem;
    color: var(--black-8);
}

/* 8. Ukrywanie domyślnych przycisków */
.woo-main .woo-main__content ul.products li.product > a.button {
    display: none !important;
}

/* ==========================================================================
   ANIMACJA: PRZYCISKI NA HOVERZE
   ========================================================================== */

@media (max-width: 1200px) {
    .woo-main .woo-main__content .product-hover-buttons {
        display: none;
    }
}

@media (min-width: 1201px) {
	.woo-main .woo-main__content ul.products li.product:hover a img {
		filter: brightness(0.7);
	}
    .woo-main .woo-main__content ul.products li.product .product-hover-buttons {
        position: absolute;
        top: 1rem;
        left: 2rem;
        display: flex;
        flex-direction: column;
        gap: .8rem;
        z-index: 10;
        opacity: 0;
        visibility: hidden;
        transform: translateX(-0.6rem);
        transition: all 0.3s ease-in-out;
    }
    .woo-main .woo-main__content ul.products li.product:hover .product-hover-buttons {
        opacity: 1;
        visibility: visible;
        transform: translateX(0);
    }
    .woo-main .woo-main__content ul.products li.product .product-hover-buttons .button {
		position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 1rem;
		margin-top: 0;
        background-color: var(--white-1);
        color: var(--font-color-2);
        border-radius: var(--radius-3);
        text-decoration: none;
		box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
        transition: all 0.3s ease;
    }
    .woo-main .woo-main__content ul.products li.product .product-hover-buttons .button:hover {
		 background-color: var(--bg-2);
    }
    .woo-main .woo-main__content ul.products li.product .product-hover-buttons .button svg {
        width: 2.5rem;
        height: 2.5rem;
        fill: currentColor;
		transition: opacity .2s ease;
    }
    .woo-main .woo-main__content ul.products li.product .product-hover-buttons .button.add_to_cart_button.loading {
        opacity: 0.9;
        background-color: var(--white-2);
    }
    .woo-main .woo-main__content ul.products li.product .product-hover-buttons .button.add_to_cart_button.loading svg {
        opacity: 0;
    }
    .woo-main .woo-main__content ul.products li.product .product-hover-buttons .button.add_to_cart_button.loading::after {
        content: '';
        display: block;
        width: 1.6rem;
        height: 1.6rem;
        border-radius: 50%;
        border: 2px solid var(--font-color-4);
        border-top-color: var(--color-1);
        animation: woo-spin 1s infinite linear;
        position: absolute; 
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
    .woo-main .woo-main__content ul.products li.product .product-hover-buttons .added_to_cart {
        display: none !important;
    }
    .woo-main .woo-main__content ul.products li.product .product-hover-buttons .button.add_to_cart_button.added::after {
        content: '\e017';
        font-family: 'WooCommerce';
        font-size: .7rem;
        color: var(--alert-success);
        background-color: var(--white-1);
        border-radius: 50%;
        padding: 0.5rem;
        line-height: 1;
		margin: 0;
		box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
        position: absolute; 
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
}

/* ==========================================================================
   SIATKA PRODUKTÓW FLEXBOX
   ========================================================================== */
.woo-main .woo-main__content ul.products {
    display: flex;
    flex-wrap: wrap;
    margin-left: -1rem;
    margin-right: -1rem;
}
.woo-main .woo-main__content ul.products li.product {
    float: none !important;
    margin: 0 0 2rem 0;
    width: auto;
    padding-left: 1rem;
    padding-right: 1rem;
    box-sizing: border-box;
}

/*Podobne produkty*/
.woo-main .related.products > h2 {
    font-size: 2.2rem;
    margin-bottom: 1.5rem;
    font-weight: 400;
}

/* 4 kolumny na desktopach */
@media (min-width: 992px) {
    .woo-main .woo-main__content ul.products li.product {
        flex: 0 0 25%;
        max-width: 25%;
    }
}
/* 3 kolumny na tabletach */
@media (min-width: 768px) and (max-width: 991px) {
    .woo-main .woo-main__content ul.products li.product {
        flex: 0 0 33.333%;
        max-width: 33.333%;
    }
}
/* 2 kolumny na mniejszych tabletach */
@media (min-width: 480px) and (max-width: 767px) {
    .woo-main .woo-main__content ul.products li.product {
        flex: 0 0 50%;
        max-width: 50%;
    }
}
/* 1 kolumna na telefonach */
@media (max-width: 479px) {
    .woo-main .woo-main__content ul.products li.product {
        flex: 0 0 100%;
        max-width: 100%;
    }
}

/* Animacja dla spinnera */
@keyframes woo-spin {
    to {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}

/* ==========================================================================
   WYGLĄD POWIADOMIEŃ WOOCOMMERCE
   ========================================================================== */

/* --- 1. WSPÓLNA BAZA DLA WSZYSTKICH ALERTÓW --- */
.woo-main .woocommerce-message,
.woo-main .woocommerce-info,
.woo-main .woocommerce-error {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
    padding: 1.5rem 2rem 1.5rem 6rem;
    margin-bottom: 2rem !important;
    border-width: 1px;
    border-style: solid;
    border-radius: var(--radius-2) !important;
    font-size: 1.6rem;
    font-weight: 500;
    list-style: none !important;
    box-shadow: var(--shadow-1);
}

.woo-main .woocommerce-message:focus-visible {
	outline: 2px solid var(--alert-success-border);
}
.woo-main .woocommerce-info:focus-visible {
	outline: 2px solid var(--alert-info-border);
}
.woo-main .woocommerce-error:focus-visible {
	outline: 2px solid var(--alert-danger-border);
}

/* --- Ikona (::before) dla wszystkich alertów --- */
.woo-main .woocommerce-message::before,
.woo-main .woocommerce-info::before,
.woo-main .woocommerce-error::before {
    content: '';
    position: absolute;
    left: 2rem;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    mask-size: contain;
    mask-repeat: no-repeat;
    mask-position: center;
    display: block !important;
}

/* ==========================================================================
   RESPONSOWNOŚĆ
   ========================================================================== */
@media (max-width: 768px) {
    .woo-main .woocommerce-message,
    .woo-main .woocommerce-info,
    .woo-main .woocommerce-error {
        flex-direction: column;
        align-items: flex-start;
        padding: 1.5rem 2rem 1.5rem 5rem;
        gap: 1rem; 
    }

    .woo-main .woocommerce-message::before,
    .woo-main .woocommerce-info::before,
    .woo-main .woocommerce-error::before {
        width: 20px;
        height: 20px;
        left: 1.5rem;
    }
}

/* ==========================================================================
   2. STYLE SPECYFICZNE DLA KAŻDEGO TYPU ALERTU
   ========================================================================== */

/* --- SUCCESS (.woocommerce-message) --- */
.woo-main .woocommerce-message {
    background-color: var(--alert-success-bg);
    border-color: var(--alert-success-border);
    color: var(--alert-success);
}
.woo-main .woocommerce-message::before {
    background-color: var(--alert-success);
    mask-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2.5" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" d="M4.5 12.75l6 6 9-13.5" /></svg>');
}
.woo-main .woocommerce-message .button {
    background-color: var(--alert-success) !important;
    color: var(--white-1) !important;
}
.woo-main .woocommerce-message .button:hover {
    background-color: var(--alert-success_hover) !important;
}

/* --- DANGER/ERROR (.woocommerce-error) --- */
.woo-main .woocommerce-error {
    background-color: var(--alert-danger-bg);
    border-color: var(--alert-danger-border);
    color: var(--alert-danger);
}
.woo-main .woocommerce-error::before {
    background-color: var(--alert-danger);
    mask-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" d="M12 9v3.75m-9.303 3.376c-.866 1.5.217 3.374 1.948 3.374h14.71c1.73 0 2.813-1.874 1.948-3.374L13.949 3.378c-.866-1.5-3.032-1.5-3.898 0L2.697 16.126zM12 15.75h.007v.008H12v-.008z" /></svg>');
}
.woo-main .woocommerce-error .button {
    background-color: var(--alert-danger) !important;
    color: var(--white-1) !important;
}
.woo-main .woocommerce-error .button:hover {
    background-color: var(--alert-danger_hover) !important;
}

/* --- INFO (.woocommerce-info) --- */
.woo-main .woocommerce-info {
    background-color: var(--alert-info-bg);
    border-color: var(--alert-info-border);
    color: var(--alert-info);
}
.woo-main .woocommerce-info::before {
    background-color: var(--alert-info);
    mask-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" d="M11.25 11.25l.041-.02a.75.75 0 011.063.852l-.708 2.836a.75.75 0 001.063.853l.041-.021M21 12a9 9 0 11-18 0 9 9 0 0118 0zm-9-3.75h.008v.008H12V8.25z" /></svg>');
}
.woo-main .woocommerce-info .button {
    background-color: var(--alert-info) !important;
    color: var(--white-1) !important;
}
.woo-main .woocommerce-info .button:hover {
    background-color: var(--alert-info_hover) !important;
}

/* --- WSPÓLNY styl dla wszystkich przycisków w alertach --- */
.woo-main .woocommerce-message .button,
.woo-main .woocommerce-error .button,
.woo-main .woocommerce-info .button {
    border-radius: var(--radius-full);
    padding: 0.9rem 1.8rem;
    font-size: 1.4rem;
    font-weight: 600;
    white-space: nowrap;
    transition: background-color 0.2s ease;
    border: none;
}



