/* ═══════════════════════════════════════════════════════════
   REFONIO – WooCommerce Custom Styles
   Passt alle WooCommerce-Seiten ans Refonio-Design an
   ═══════════════════════════════════════════════════════════ */

/* ── 1. LAYOUT FIX: Inhalt unter der fixen Nav ──
   Astra setzt margin-top: 64px auf #primary (für Astras eigenen 64px Header).
   Unsere Nav ist 105px → wir brauchen 105-64 = 41px extra padding.
   NUR #primary bekommt padding, kein Stacking auf site-main etc. */
body.woocommerce-shop #primary,
body.woocommerce-page #primary,
body.woocommerce #primary {
    padding-top: 41px !important;
}

/* Reset: keine stacked paddings auf anderen Elementen */
body.woocommerce-shop .site-main,
body.woocommerce .site-main,
body.woocommerce-page .site-main {
    padding-top: 0 !important;
}

body.woocommerce .ast-woocommerce-container,
body.woocommerce-shop .ast-woocommerce-container {
    padding-top: 0 !important;
}

/* Top-Pagination (vor den Produkten) braucht Abstand nach oben */
.ast-woocommerce-container > nav.woocommerce-pagination:first-child,
.woocommerce-shop .woocommerce-pagination:first-of-type {
    padding-top: 110px !important;
}

/* ── 2. SEITEN-HINTERGRUND ── */
body.woocommerce,
body.woocommerce-shop,
body.woocommerce-page {
    background: #f5f5f5 !important;
}

/* ── 3. SHOP-WRAPPER ──
   In Astra ist ul.products direkt in .ast-woocommerce-container (kein .woocommerce div).
   Deshalb Padding + Max-Width direkt auf .ast-woocommerce-container. */
.ast-woocommerce-container {
    max-width: 1340px !important;
    margin: 0 auto !important;
    padding-left: 40px !important;
    padding-right: 40px !important;
    padding-bottom: 60px !important;
    box-sizing: border-box !important;
}

/* ── 4. SHOP PAGE HERO BANNER ── */
.woocommerce-products-header {
    background: #0c0c0c;
    margin: 0 0 32px 0;
    padding: 48px 40px;
    border-radius: 16px;
    text-align: center;
}

.woocommerce-products-header__title.page-title {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 42px !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 0 0 8px !important;
    letter-spacing: -0.5px;
}

.woocommerce-products-header__title.page-title::after {
    content: " 🔧";
}

/* ── 5. TOOLBAR (Ergebnisse + Sortierung) ── */
.woocommerce-result-count {
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    color: #777;
    margin-bottom: 0;
    align-self: center;
}

.woocommerce-ordering select {
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    padding: 10px 16px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    background: #fff;
    color: #333;
    cursor: pointer;
    outline: none;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='2' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
}

.woocommerce-ordering select:focus {
    border-color: #3EBD5A;
}

/* ── 6. PRODUKT-GRID ── */
ul.products {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 20px !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ── 7. PRODUKT-KARTE ── */
ul.products li.product {
    background: #fff !important;
    border-radius: 14px !important;
    overflow: hidden !important;
    border: none !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.07) !important;
    transition: transform 0.25s, box-shadow 0.25s !important;
    padding: 0 !important;
    margin: 0 !important;
    position: relative;
    display: flex;
    flex-direction: column;
}

ul.products li.product:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 8px 30px rgba(0,0,0,0.12) !important;
}

/* Produktbild – Astra nutzt .astra-shop-thumbnail-wrap als Wrapper */
ul.products li.product .astra-shop-thumbnail-wrap img,
ul.products li.product a img,
ul.products li.product .woocommerce-loop-product__link img {
    width: 100% !important;
    height: 200px !important;
    object-fit: contain !important;
    background: #f9f9f9 !important;
    padding: 20px !important;
    display: block !important;
    margin: 0 !important;
    border-bottom: 1px solid #f0f0f0 !important;
}

/* Thumbnail-Wrapper: Bild-Bereich abgrenzen */
ul.products li.product .astra-shop-thumbnail-wrap {
    background: #f9f9f9 !important;
    display: block !important;
}

/* Produkt-Body */
ul.products li.product .woocommerce-loop-product__link,
ul.products li.product > a {
    text-decoration: none !important;
    display: block !important;
}

/* Kategorie-Label */
ul.products li.product .ast-woo-product-category {
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    color: #3EBD5A !important;
    padding: 16px 20px 4px !important;
    display: block !important;
    font-family: 'DM Sans', sans-serif !important;
}

/* Produkttitel */
ul.products li.product .woocommerce-loop-product__title,
ul.products li.product h2 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #0c0c0c !important;
    padding: 4px 20px 12px !important;
    margin: 0 !important;
    line-height: 1.35 !important;
}

/* MwSt & Versand Info – WooCommerce Germanized Plugin Elemente ausblenden */
ul.products li.product .woocommerce-loop-product__link + .price::before,
ul.products li.product p.price + small,
.wc-gzd-additional-info,
p.wc-gzd-additional-info,
.wc-gzd-additional-info-loop {
    display: none !important;
}

/* Preis */
ul.products li.product .price {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 20px !important;
    font-weight: 800 !important;
    color: #3EBD5A !important;
    padding: 0 20px 4px !important;
    display: block !important;
    margin: 0 !important;
}

ul.products li.product .price del {
    font-size: 13px !important;
    font-weight: 400 !important;
    color: #aaa !important;
    margin-right: 6px !important;
}

ul.products li.product .price ins {
    text-decoration: none !important;
    color: #3EBD5A !important;
}

/* MwSt-Zeile ausblenden */
ul.products li.product .woocommerce-Price-amount + small,
ul.products li.product p.posted_in,
.woocommerce ul.products li.product .price .tax_label {
    display: none !important;
}

/* "ANGEBOT!" Badge */
ul.products li.product .onsale {
    background: #0c0c0c !important;
    color: #fff !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 5px 10px !important;
    border-radius: 6px !important;
    top: 12px !important;
    left: 12px !important;
    min-height: unset !important;
    min-width: unset !important;
    line-height: 1 !important;
}

/* "Zum Warenkorb" Button */
ul.products li.product .button,
ul.products li.product a.button,
ul.products li.product .add_to_cart_button {
    background: #0c0c0c !important;
    color: #fff !important;
    border: none !important;
    border-radius: 0 0 14px 14px !important;
    padding: 14px 20px !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    text-decoration: none !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
    margin: auto 0 0 0 !important;
}

ul.products li.product .button:hover,
ul.products li.product a.button:hover,
ul.products li.product .add_to_cart_button:hover {
    background: #3EBD5A !important;
    color: #fff !important;
}

/* ── 8. PAGINATION ── */
.woocommerce-pagination ul {
    display: flex !important;
    gap: 8px !important;
    list-style: none !important;
    justify-content: center !important;
    padding: 40px 0 20px !important;
    margin: 0 !important;
    flex-wrap: wrap !important;
}

.woocommerce-pagination ul li {
    margin: 0 !important;
}

.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: 8px !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
    border: 2px solid #e0e0e0 !important;
    color: #555 !important;
    background: #fff !important;
    transition: all 0.2s !important;
}

.woocommerce-pagination ul li a:hover {
    border-color: #3EBD5A !important;
    color: #3EBD5A !important;
    background: #f0fdf4 !important;
}

.woocommerce-pagination ul li span.current {
    background: #3EBD5A !important;
    border-color: #3EBD5A !important;
    color: #fff !important;
}

/* ── 9. EINZELPRODUKT-SEITE ── */
.woocommerce-page.single-product #primary,
.single-product #primary {
    padding-top: 120px !important;
}

.woocommerce div.product {
    background: #fff;
    border-radius: 16px;
    padding: 40px;
    box-shadow: 0 2px 20px rgba(0,0,0,0.07);
    max-width: 1200px;
    margin: 0 auto;
}

.woocommerce div.product .product_title {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 32px !important;
    font-weight: 800 !important;
    color: #0c0c0c !important;
    line-height: 1.2 !important;
    margin-bottom: 12px !important;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 36px !important;
    font-weight: 800 !important;
    color: #3EBD5A !important;
}

.woocommerce div.product .single_add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
    background: #0c0c0c !important;
    color: #fff !important;
    border-radius: 10px !important;
    padding: 16px 32px !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    border: none !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
    letter-spacing: 0.3px;
}

.woocommerce div.product .single_add_to_cart_button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
    background: #3EBD5A !important;
}

/* ── 10. WARENKORB-SEITE ── */
.woocommerce-cart .woocommerce table.shop_table {
    border: none !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: #fff !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.07) !important;
}

.woocommerce-cart .woocommerce table.shop_table th {
    background: #0c0c0c !important;
    color: #fff !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    padding: 16px 20px !important;
    border: none !important;
}

.woocommerce-cart .woocommerce table.shop_table td {
    padding: 20px !important;
    border-color: #f0f0f0 !important;
    font-family: 'DM Sans', sans-serif !important;
    vertical-align: middle !important;
}

.woocommerce-cart .woocommerce .cart_totals {
    background: #fff;
    border-radius: 12px;
    padding: 30px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.07);
}

.woocommerce-cart .woocommerce .cart_totals h2 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-size: 22px !important;
    font-weight: 800 !important;
    color: #0c0c0c !important;
    margin-bottom: 20px !important;
}

/* ── 11. CHECKOUT-SEITE ── */
.woocommerce-checkout .woocommerce-checkout-heading,
.woocommerce-checkout h3 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    font-weight: 800 !important;
    color: #0c0c0c !important;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
    border: 2px solid #e0e0e0 !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 14px !important;
    transition: border-color 0.2s !important;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
    border-color: #3EBD5A !important;
    outline: none !important;
}

/* ── 12. ASTRA OVERRIDES ── */
.woocommerce ul.products.columns-4 {
    grid-template-columns: repeat(4, 1fr) !important;
}

/* Astra summary wrapper: enthält Kategorie, Titel, Preis, Button */
ul.products li.product .astra-shop-summary-wrap {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
    padding: 0 !important;
}

/* ── 13. RESPONSIVE ── */
@media (max-width: 1100px) {
    ul.products {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (max-width: 768px) {
    ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }

    body.woocommerce-shop #primary,
    body.woocommerce-page #primary,
    body.woocommerce #primary {
        padding-top: 90px !important;
    }

    .woocommerce-shop .woocommerce,
    .woocommerce-page .woocommerce {
        padding: 0 16px 40px;
    }

    .woocommerce-products-header {
        margin: 0 -16px 24px;
        padding: 32px 20px;
    }

    .woocommerce-products-header__title.page-title {
        font-size: 28px !important;
    }

    ul.products li.product a img,
    ul.products li.product .woocommerce-loop-product__link img {
        height: 160px !important;
    }
}

@media (max-width: 480px) {
    ul.products {
        grid-template-columns: repeat(1, 1fr) !important;
    }
}
