/**
 * Cubero — sekcja dodatków na karcie produktu leżaka
 * Stylowanie zaprojektowane na wzór dodatków na plakatach (zaokrąglone boxy,
 * ikona po lewej, label/cena po prawej).
 */

.cubero-lezak-addons {
    margin: 24px 0 16px;
    font-family: inherit;
}

.cubero-lezak-addons__title {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    margin: 0 0 10px;
    color: #888;
}

.cubero-lezak-addons__list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cubero-lezak-addons__item {
    display: grid;
    grid-template-columns: auto 56px 1fr auto;
    align-items: center;
    gap: 16px;
    padding: 14px 18px;
    border: 1px solid #e0d8cc;
    border-radius: 14px;
    background: #fff;
    cursor: pointer;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
    user-select: none;
}

.cubero-lezak-addons__item:hover {
    border-color: #c4a584;
    background: #fdfaf6;
}

.cubero-lezak-addons__checkbox {
    width: 22px;
    height: 22px;
    margin: 0;
    accent-color: #c4a584;
    cursor: pointer;
}

.cubero-lezak-addons__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    font-size: 28px;
    background: #f8f1e7;
    border-radius: 10px;
    line-height: 1;
}

.cubero-lezak-addons__body {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}

.cubero-lezak-addons__label {
    font-size: 16px;
    font-weight: 600;
    color: var(--rey-text-color, #1a1a1a);
    line-height: 1.3;
}

.cubero-lezak-addons__desc {
    font-size: 13px;
    color: #888;
    line-height: 1.4;
}

.cubero-lezak-addons__price {
    font-size: 16px;
    font-weight: 600;
    color: #1a1a1a;
    white-space: nowrap;
}

.cubero-lezak-addons__price .woocommerce-Price-amount {
    color: inherit;
    font-weight: inherit;
}

/* Stan zaznaczony */
.cubero-lezak-addons__item:has(.cubero-lezak-addons__checkbox:checked) {
    border-color: #1a1a1a;
    background: #fafafa;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}

/* Thumbnail w koszyku (dla addon line items) — main cart */
.cubero-cart-addon-thumb {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    font-size: 32px;
    background: #f8f1e7;
    border-radius: 10px;
    line-height: 1;
}

/* Mini-cart drawer (Rey side panel).
 * Addony to hidden products → Rey renderuje je bez linka, z osobnym blokiem
 * .rey-cartImg i tytułem POD nim (biała przestrzeń). Floatujemy .rey-cartImg
 * w lewo, żeby tytuł płynął OBOK ikony (jak przy zdjęciu leżaka).
 * Tylko addony mają .rey-cartImg jako dziecko LI (main items mają obrazek
 * w .woocommerce-mini-cart-thumbTitle), więc ten selektor trafia tylko w nie. */
.mini_cart_item .rey-cartImg {
    float: left;
    width: auto;            /* zwężamy z 80px do szerokości thumba (56px) */
    margin-right: 14px;
    margin-bottom: 6px;
}

/* Tytuł addonu — Rey daje margin-left:100px (pod 80px obrazek). Zmniejszamy,
 * bo nasz box to 56px + 14px margines = 70px. */
.mini_cart_item .woocommerce-mini-cart-item-title {
    margin-left: 70px;
}

.widget_shopping_cart .cubero-cart-addon-thumb,
.rey-headerCart .cubero-cart-addon-thumb,
.mini_cart_item .cubero-cart-addon-thumb {
    width: 56px;
    height: 56px;
    font-size: 28px;
}

/* Jednolite odstępy między pozycjami mini-cart (Rey daje niespójne marginesy —
 * main items 0, addony 20px → brak przerwy między leżakami). Normalizujemy.
 * display:flow-root domyka floatowaną ikonę addonu, żeby nie wyciekała do
 * sąsiednich pozycji i żeby padding/border tworzyły realną przerwę. */
.woocommerce-mini-cart .mini_cart_item {
    display: flow-root;
    margin: 0 !important;       /* Rey daje niespójne marginesy — zerujemy */
    padding: 18px 0 !important;
    /* border-top + !important żeby wygrać z regułami nth-child Rey'a i pokazać
     * divider między KAŻDĄ pozycją (też między dwoma leżakami) */
    border-top: 1px solid #ece6dc !important;
    border-bottom: none !important;
}

/* :last-child w DOM = wizualnie pierwsza pozycja (column-reverse) = bez górnej linii */
.woocommerce-mini-cart .mini_cart_item:last-child {
    border-top: none !important;
}

/* WordPress podmienia emoji na <img> z CDN s.w.org — zmuszamy poprawny rozmiar */
.cubero-cart-addon-thumb img.emoji,
.cubero-lezak-addons__icon img.emoji {
    width: 1em !important;
    height: 1em !important;
    max-width: 1em !important;
    max-height: 1em !important;
    margin: 0 !important;
    vertical-align: middle !important;
    display: inline-block !important;
    box-shadow: none !important;
}

/* Mini-cart Rey (drawer) odwraca kolejność (najnowsze na górze) — co stawia
 * dodatki nad głównym produktem. Odwracamy wizualnie z powrotem przez
 * column-reverse, żeby leżak (dodany pierwszy) był na górze, dodatki pod nim.
 * Dotyczy TYLKO mini-cart (.woocommerce-mini-cart-inner zawiera same <li>),
 * strona /cart/ (tabela) jest nietknięta. */
.woocommerce-mini-cart-inner {
    display: flex;
    flex-direction: column-reverse;
}

/* Hint "↳ Dodatek do leżaka" pod nazwą produktu w koszyku */
.cubero-addon-hint {
    display: block;
    margin-top: 4px;
    color: #888;
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0;
    text-transform: none;
}

/* Mobile */
@media (max-width: 640px) {
    .cubero-lezak-addons__item {
        grid-template-columns: auto 44px 1fr;
        grid-template-rows: auto auto;
        gap: 12px;
        padding: 12px 14px;
    }

    .cubero-lezak-addons__icon {
        width: 40px;
        height: 40px;
        font-size: 22px;
    }

    .cubero-lezak-addons__label {
        font-size: 14px;
    }

    .cubero-lezak-addons__price {
        grid-column: 3;
        grid-row: 2;
        font-size: 15px;
    }
}
