/*
Theme Name:  Dobre Systemy Child
Template:    kadence
Version:     1.0.0
Text Domain: dobre-systemy-child
Author:      DigiPigi / GMB Media
Description: Child theme for dobre-systemy.pl — Allegro-inspired design
*/

/* ============================================================
   CSS VARIABLES — Design Tokens
   ============================================================ */
:root {
    --ds-bg:              #f1f1f1;
    --ds-white:           #ffffff;
    --ds-orange:          #EE6C00;
    --ds-orange-dark:     #cc5c00;
    --ds-orange-light:    #fff3ea;
    --ds-text:            #111111;
    --ds-text-secondary:  #767676;
    --ds-text-light:      #999999;
    --ds-border:          #dedede;
    --ds-border-hover:    #b0b0b0;
    --ds-green:           #00813a;
    --ds-green-light:     #e8f5ee;
    --ds-price:           #111111;
    --ds-price-sale:      #cc2200;
    --ds-price-old:       #767676;
    --ds-card-radius:     4px;
    --ds-card-shadow:     0 1px 3px rgba(0,0,0,0.08);
    --ds-card-shadow-hover: 0 3px 12px rgba(0,0,0,0.13);
    --ds-font:            -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --ds-font-size-base:  14px;
    --ds-transition:      0.15s ease;
}

/* ============================================================
   RESET / BASE
   ============================================================ */
html,
body,
#page,
.site,
.site-content,
.wp-site-blocks,
#content,
#primary,
main.site-main {
    background-color: var(--ds-bg) !important;
    font-family: var(--ds-font) !important;
}

/* Header stays white */
#masthead,
.site-header,
.kadence-header {
    background-color: var(--ds-white) !important;
}

/* Remove Kadence section backgrounds from row layouts */
div[class*="kb-row-layout-id"],
div[class*="kb-row-layout-id"] > .kt-row-column-wrap {
    border: none !important;
    border-width: 0 !important;
    border-color: transparent !important;
    outline: none !important;
    box-shadow: none !important;
    background-color: transparent !important;
}

/* ============================================================
   PRODUCT CARD — ds-product-card
   ============================================================ */
.ds-product-card {
    list-style: none;
    background: var(--ds-white);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-card-radius);
    box-shadow: var(--ds-card-shadow);
    transition: box-shadow var(--ds-transition), border-color var(--ds-transition);
    display: flex;
    flex-direction: column;
    position: relative;
    overflow: hidden;
    height: 100%;
}

.ds-product-card:hover {
    box-shadow: var(--ds-card-shadow-hover);
    border-color: var(--ds-border-hover);
}

/* Image area */
.ds-product-card__image {
    position: relative;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--ds-white);
    border-bottom: 1px solid #f0f0f0;
}

.ds-product-card__image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 8px;
    transition: transform 0.2s ease;
}

.ds-product-card:hover .ds-product-card__image img {
    transform: scale(1.03);
}

/* Sale badge */
.ds-badge {
    position: absolute;
    top: 8px;
    left: 0;
    z-index: 2;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.4;
    padding: 3px 8px 3px 6px;
    border-radius: 0 3px 3px 0;
    pointer-events: none;
}

.ds-badge--sale {
    background: var(--ds-green);
    color: var(--ds-white);
}

.ds-badge--hot {
    background: var(--ds-orange);
    color: var(--ds-white);
}

/* Wishlist */
.ds-product-card__wishlist {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 2;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
}

/* Body */
.ds-product-card__body {
    padding: 10px 10px 6px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* Title */
.ds-product-card__title {
    font-size: 12px;
    font-weight: 600;
    color: var(--ds-text);
    line-height: 1.4;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 34px;
}

/* Price block */
.ds-product-card__price {
    margin-top: 2px;
}

.ds-product-card__price .price {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.ds-product-card__price ins,
.ds-product-card__price .woocommerce-Price-amount:not(del .woocommerce-Price-amount) {
    font-size: 18px;
    font-weight: 800;
    color: var(--ds-price-sale);
    text-decoration: none;
    display: block;
}

.ds-product-card__price del {
    font-size: 12px;
    color: var(--ds-price-old);
    text-decoration: line-through;
    display: block;
    order: -1;
}

/* No sale — normal price */
.ds-product-card__price > .price > .woocommerce-Price-amount {
    font-size: 18px;
    font-weight: 800;
    color: var(--ds-text);
}

/* Delivery */
.ds-product-card__delivery {
    font-size: 11px;
    color: var(--ds-text-secondary);
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 2px;
}

.ds-product-card__delivery strong {
    color: var(--ds-text);
    font-weight: 600;
}

/* Footer — add to cart */
.ds-product-card__footer {
    padding: 8px 10px 10px;
}

.ds-btn--cart {
    display: block;
    width: 100%;
    padding: 9px 12px;
    background: var(--ds-orange);
    color: var(--ds-white) !important;
    font-size: 12px;
    font-weight: 700;
    text-align: center;
    text-decoration: none !important;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: background var(--ds-transition);
    letter-spacing: 0.3px;
}

.ds-btn--cart:hover {
    background: var(--ds-orange-dark) !important;
    color: var(--ds-white) !important;
}

/* ============================================================
   PRODUCT GRID — shop/archive
   ============================================================ */
.woocommerce ul.products,
ul.products.columns-4 {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

ul.products li.product {
    margin: 0 !important;
    padding: 0 !important;
    float: none !important;
    width: auto !important;
}

/* ============================================================
   SINGLE PRODUCT PAGE
   ============================================================ */

/* Layout */
.woocommerce div.product {
    background: var(--ds-white);
    border-radius: 4px;
    padding: 24px;
    border: 1px solid var(--ds-border);
}

/* Product title */
.woocommerce div.product h1.product_title {
    font-size: 22px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    color: var(--ds-text) !important;
    margin-bottom: 12px !important;
}

/* Price on product page */
.woocommerce div.product p.price ins .woocommerce-Price-amount,
.woocommerce div.product p.price .woocommerce-Price-amount.amount {
    font-size: 28px !important;
    font-weight: 800 !important;
    color: var(--ds-price-sale) !important;
}

.woocommerce div.product p.price del .woocommerce-Price-amount {
    font-size: 16px !important;
    color: var(--ds-price-old) !important;
}

/* Add to cart button */
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button {
    background: var(--ds-orange) !important;
    color: var(--ds-white) !important;
    font-weight: 700 !important;
    border-radius: 4px !important;
    border: none !important;
    padding: 14px 24px !important;
    font-size: 15px !important;
    transition: background var(--ds-transition) !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

.woocommerce div.product form.cart .single_add_to_cart_button:hover {
    background: var(--ds-orange-dark) !important;
}

/* Stock status */
.woocommerce div.product .stock {
    font-size: 13px !important;
    font-weight: 600 !important;
}

.woocommerce div.product .in-stock {
    color: var(--ds-green) !important;
}

/* Tabs */
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    font-size: 14px;
    font-weight: 600;
    color: var(--ds-text-secondary);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
    color: var(--ds-orange);
    border-bottom-color: var(--ds-orange);
}

/* Product description */
.woocommerce div.product .woocommerce-product-details__short-description {
    font-size: 14px;
    line-height: 1.65;
    color: #444;
}

/* ============================================================
   BULK PRICING — ds-bulk-pricing (custom plugin styles)
   ============================================================ */
.ds-bulk-pricing {
    margin: 16px 0;
    padding: 14px;
    background: #fafafa;
    border: 1px solid var(--ds-border);
    border-radius: 6px;
}

.ds-bulk-pricing__label {
    font-size: 13px;
    font-weight: 600;
    color: var(--ds-text-secondary);
    margin-bottom: 10px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.ds-bulk-pricing__tiers {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.ds-bulk-pricing__tier {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 8px 14px;
    border: 2px solid var(--ds-border);
    border-radius: 6px;
    cursor: pointer;
    background: var(--ds-white);
    transition: all var(--ds-transition);
    min-width: 90px;
    text-align: center;
    position: relative;
}

.ds-bulk-pricing__tier:hover {
    border-color: var(--ds-orange);
    background: var(--ds-orange-light);
}

.ds-bulk-pricing__tier.is-active {
    border-color: var(--ds-orange);
    background: var(--ds-orange-light);
}

.ds-bulk-pricing__tier-qty {
    font-size: 13px;
    font-weight: 600;
    color: var(--ds-text);
}

.ds-bulk-pricing__tier-discount {
    font-size: 18px;
    font-weight: 800;
    color: var(--ds-green);
    line-height: 1.2;
}

.ds-bulk-pricing__tier-save {
    font-size: 10px;
    color: var(--ds-text-secondary);
    margin-top: 2px;
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.ds-breadcrumb {
    font-size: 12px;
    color: var(--ds-text-secondary);
    margin-bottom: 12px;
    padding: 8px 0;
}

.ds-breadcrumb ol {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
}

.ds-breadcrumb a {
    color: var(--ds-text-secondary);
    text-decoration: none;
}

.ds-breadcrumb a:hover {
    color: var(--ds-orange);
    text-decoration: underline;
}

.ds-breadcrumb__sep {
    color: var(--ds-text-light);
}

/* ============================================================
   HEADER — Kadence customization
   ============================================================ */

/* Search bar */
.header-search-bar input[type="search"],
.wp-block-search__input {
    border-radius: 4px 0 0 4px !important;
    border: 1.5px solid #111 !important;
    font-size: 14px !important;
}

/* Cart button orange */
.header-cart-button span.kadence-svg-iconset {
    background: var(--ds-orange) !important;
    padding: 10px 14px !important;
    border-radius: 8px !important;
}

/* Cart counter */
span.header-cart-total {
    background: #F54900 !important;
    color: #fff !important;
    font-weight: 700 !important;
    font-size: 11px !important;
}

/* Phone number */
.header-phone-number a {
    color: var(--ds-text) !important;
    font-weight: 600 !important;
}

/* ============================================================
   SECTION TITLES — Allegro style (just text + Więcej link)
   ============================================================ */
.ds-section-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--ds-border);
}

.ds-section-header__title {
    font-size: 18px;
    font-weight: 700;
    color: var(--ds-text);
    margin: 0;
}

.ds-section-header__more {
    font-size: 13px;
    color: var(--ds-orange);
    text-decoration: none;
    font-weight: 500;
}

.ds-section-header__more:hover {
    text-decoration: underline;
}

/* ============================================================
   FIBOSEARCH STYLING — Allegro-like results
   ============================================================ */
.dgwt-wcas-search-wrapp {
    max-width: 600px !important;
}

.dgwt-wcas-sf-wrapp input[type="search"] {
    border: 1.5px solid #111 !important;
    border-radius: 4px 0 0 4px !important;
    font-size: 14px !important;
    height: 44px !important;
    padding: 0 16px !important;
}

.dgwt-wcas-search-submit {
    background: var(--ds-orange) !important;
    border: none !important;
    border-radius: 0 4px 4px 0 !important;
    height: 44px !important;
    padding: 0 20px !important;
    color: #fff !important;
    font-weight: 700 !important;
    cursor: pointer !important;
}

.dgwt-wcas-search-submit:hover {
    background: var(--ds-orange-dark) !important;
}

.dgwt-wcas-suggestion {
    padding: 8px 14px !important;
    font-size: 13px !important;
}

.dgwt-wcas-suggestion:hover,
.dgwt-wcas-suggestion.selected {
    background: var(--ds-orange-light) !important;
}

.dgwt-wcas-sp__price {
    color: var(--ds-price-sale) !important;
    font-weight: 700 !important;
}

/* ============================================================
   PAGINATION
   ============================================================ */
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    border-color: var(--ds-border) !important;
    color: var(--ds-text) !important;
    border-radius: 4px !important;
}

.woocommerce nav.woocommerce-pagination ul li a:focus,
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
    background: var(--ds-orange) !important;
    color: var(--ds-white) !important;
    border-color: var(--ds-orange) !important;
}

/* ============================================================
   MESSAGES & NOTICES
   ============================================================ */
.woocommerce-message {
    border-top-color: var(--ds-orange) !important;
}

.woocommerce-message a.button {
    background: var(--ds-orange) !important;
    color: #fff !important;
}

/* ============================================================
   RESPONSIVE — Mobile (Allegro mobile style)
   ============================================================ */
@media (max-width: 767px) {

    /* Grid — 2 kolumny */
    .woocommerce ul.products,
    ul.products.columns-4 {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }

    /* Karta — dostosowania */
    .ds-product-card__image {
        aspect-ratio: 1 / 1;
    }

    .ds-product-card__body {
        padding: 8px 8px 4px;
    }

    .ds-product-card__title {
        font-size: 11px;
        min-height: 30px;
    }

    .ds-product-card__price ins,
    .ds-product-card__price .woocommerce-Price-amount:not(del .woocommerce-Price-amount) {
        font-size: 15px;
    }

    .ds-product-card__footer {
        padding: 6px 8px 8px;
    }

    .ds-btn--cart {
        font-size: 11px;
        padding: 8px 6px;
    }

    /* Single product */
    .woocommerce div.product {
        padding: 12px;
    }

    .woocommerce div.product h1.product_title {
        font-size: 18px !important;
    }

    /* Bulk pricing na mobile */
    .ds-bulk-pricing__tier {
        min-width: 80px;
        padding: 6px 10px;
    }

    .ds-bulk-pricing__tier-discount {
        font-size: 15px;
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
    .woocommerce ul.products,
    ul.products.columns-4 {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

/* ============================================================
   PRODUCT CARD — Modern / Less orange (Allegro-style update)
   ============================================================ */

/* Card — clean white, minimal border */
.ds-product-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    overflow: hidden;
    transition: border-color .15s, box-shadow .15s;
    height: 100%;
}
.ds-product-card:hover {
    border-color: #b0b0b0;
    box-shadow: 0 2px 10px rgba(0,0,0,.09);
}

.ds-product-card__link {
    display: flex;
    flex-direction: column;
    flex: 1;
    text-decoration: none;
    color: inherit;
}

.ds-product-card__body {
    flex: 1;
    padding: 8px 10px 4px;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

/* Title */
.ds-product-card__title {
    font-size: 12px;
    font-weight: 500;
    color: #111;
    line-height: 1.4;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 32px;
}
.ds-product-card:hover .ds-product-card__title { color: var(--ds-orange); }

/* Price */
.ds-product-card__price { margin-top: 4px; }
.ds-product-card__price .price { display: flex; flex-direction: column; gap: 1px; }
.ds-product-card__price ins,
.ds-product-card__price ins .woocommerce-Price-amount { font-size: 17px; font-weight: 700; color: #111; text-decoration: none; display: block; }
.ds-product-card__price del { font-size: 11px; color: #999; display: block; order: -1; }
/* Sale price — dark, not red (more Allegro) */
.ds-product-card__price ins .woocommerce-Price-amount { color: #0f2010; }

/* Delivery */
.ds-product-card__delivery {
    font-size: 11px;
    color: #555;
    display: flex;
    align-items: center;
    gap: 3px;
    flex-wrap: wrap;
}
.ds-product-card__delivery strong { color: #111; font-weight: 600; }

/* Footer — button */
.ds-product-card__footer { padding: 6px 8px 8px; margin-top: auto; }

/* Button — more subtle (Allegro-like, not dominant orange) */
.ds-btn--cart {
    display: block;
    width: 100%;
    padding: 8px 10px;
    background: #fff;
    color: var(--ds-orange) !important;
    border: 1.5px solid var(--ds-orange);
    border-radius: 4px;
    font-size: 12px;
    font-weight: 700;
    text-align: center;
    text-decoration: none !important;
    cursor: pointer;
    transition: background .15s, color .15s;
    font-family: 'Inter', sans-serif;
}
.ds-btn--cart:hover {
    background: var(--ds-orange) !important;
    color: #fff !important;
}

/* Badge — green like Allegro */
.ds-badge--sale {
    background: #00813a;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 3px;
    position: absolute;
    top: 8px; left: 0;
    z-index: 2;
    border-radius: 0 3px 3px 0;
}

/* Single product page */
.woocommerce div.product form.cart .single_add_to_cart_button {
    background: var(--ds-orange) !important;
    color: #fff !important;
    font-family: 'Inter', sans-serif !important;
    font-weight: 700 !important;
    border-radius: 4px !important;
    border: none !important;
    font-size: 15px !important;
    padding: 14px 24px !important;
    transition: background .15s !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover { background: var(--ds-orange-dark) !important; }
