/* ============================================================
   ARDORE.CZ - Custom CSS v4
   Vlozit do: Vzhled a obsah → Editor → HTML kod → Zahlavi
   jako: <link href="/user/documents/upload/ardore-custom.css?v=8" rel="stylesheet" />
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&family=Open+Sans:wght@300;400;600;700&display=swap');

/* ============================================================
   1. CSS VARIABLES
   ============================================================ */
:root {
    --ardore-pink: #eb65b0;
    --ardore-pink-dark: #c02482;
    --ardore-pink-light: #f5a0d0;
    --ardore-black: #000;
    --ardore-dark: #333;
    --ardore-gray: #545454;
    --ardore-gray-light: #c4c7c8;
    --ardore-gray-bg: #f1f1f1;
    --ardore-white: #fff;
    --ardore-red: #e35c5c;
    --ardore-green: #10ac82;
    --ardore-radius: 5px;
    --ardore-shadow: 0 2px 15px rgba(0,0,0,0.08);
    --ardore-shadow-hover: 0 4px 20px rgba(0,0,0,0.13);
    --ardore-transition: all 0.25s ease;
}

body {
    font-family: 'Poppins', 'Open Sans', Arial, sans-serif !important;
    color: var(--ardore-dark);
    -webkit-font-smoothing: antialiased;
}

a { transition: var(--ardore-transition); }
a:hover { color: var(--ardore-pink); }

/* ============================================================
   2. HEADER - KOSIK KOMPAKTNI + IKONA PROFILU
   ============================================================ */
.navigation-buttons .cart-count {
    background: transparent !important;
    color: var(--ardore-dark) !important;
    border: none !important;
    padding: 5px 8px !important;
    font-size: 14px !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px;
    position: relative;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.navigation-buttons .cart-count::before {
    content: "\e88e";
    font-family: 'shoptet-icons', 'shoptet' !important;
    font-size: 22px;
    color: var(--ardore-dark);
    transition: var(--ardore-transition);
}

.navigation-buttons .cart-count:hover::before {
    color: var(--ardore-pink);
}

.navigation-buttons .cart-count .cart-price {
    font-size: 14px !important;
    font-weight: 600;
    color: var(--ardore-dark) !important;
    background: none !important;
    padding: 0 !important;
}

.navigation-buttons .cart-count .cart-item-count {
    position: absolute;
    top: -2px;
    right: -4px;
    background: var(--ardore-pink) !important;
    color: var(--ardore-white) !important;
    border-radius: 50%;
    font-size: 10px;
    font-weight: 700;
    min-width: 16px;
    height: 16px;
    line-height: 16px;
    text-align: center;
    padding: 0 3px;
}

/* ============================================================
   3. MEGA MENU DROPDOWN - vzor ruzovyslon.cz
   Podkategorie vlevo ve 2 sloupcich
   ============================================================ */
.menu-level-1 > [role="none"].ext > .menu-level-2,
.menu-level-1 > li.ext > .menu-level-2 {
    display: none;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    top: 100% !important;
    width: 100% !important;
    min-width: 100% !important;
    max-width: none !important;
    background: var(--ardore-white) !important;
    border: none !important;
    border-top: 1px solid var(--ardore-gray-light) !important;
    box-shadow: 0 8px 30px rgba(0,0,0,0.08) !important;
    padding: 30px 40px !important;
    z-index: 10000;
    box-sizing: border-box;
    column-count: 2 !important;
    column-gap: 40px !important;
}

.menu-level-1 > [role="none"].ext:hover > .menu-level-2,
.menu-level-1 > li.ext:hover > .menu-level-2 {
    display: block !important;
}

.menu-level-2 > li {
    break-inside: avoid !important;
    page-break-inside: avoid !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 18px !important;
    padding: 0 !important;
    float: none !important;
}

.menu-level-2 > li > a.menu-image,
.menu-level-2 > li > a > img,
.menu-level-2 > li > .menu-image {
    display: none !important;
}

.menu-level-2 > li > a[role="menuitem"],
.menu-level-2 > li > a:not(.menu-image) {
    display: block !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    color: var(--ardore-black) !important;
    text-decoration: none !important;
    padding: 0 0 6px 0 !important;
    margin-bottom: 6px !important;
    border-bottom: 1px solid var(--ardore-gray-bg) !important;
    font-family: 'Poppins', 'Open Sans', Arial, sans-serif !important;
    background: none !important;
    text-align: left !important;
    line-height: 1.4 !important;
}

.menu-level-2 > li > a[role="menuitem"]:hover,
.menu-level-2 > li > a:not(.menu-image):hover {
    color: var(--ardore-pink) !important;
}

.menu-level-3 {
    display: block !important;
    position: static !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    columns: unset !important;
    width: auto !important;
    min-width: unset !important;
}

.menu-level-3 > li {
    display: block !important;
    width: auto !important;
    float: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.menu-level-3 > li > a {
    display: block !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    color: var(--ardore-dark) !important;
    padding: 3px 0 !important;
    text-decoration: none !important;
    background: none !important;
    line-height: 1.4 !important;
    font-family: 'Poppins', 'Open Sans', Arial, sans-serif !important;
}

.menu-level-3 > li > a:hover {
    color: var(--ardore-pink) !important;
}

.menu-level-3 > li > a > img,
.menu-level-3 > li > a.menu-image {
    display: none !important;
}

/* ============================================================
   4. NAVIGACE
   ============================================================ */

/* Menu piktogramy - jen Zeny, Muzi, Pary */
.ardore-menu-icon {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 18px !important;
    height: 18px !important;
    margin-right: 5px !important;
    vertical-align: middle !important;
    flex-shrink: 0 !important;
    position: relative !important;
    top: -1px !important;
}

.ardore-menu-icon svg {
    width: 100% !important;
    height: 100% !important;
}

/* Barevne odliseni - jen 3 hlavni kategorie */
.menu-item-718 > a { color: #d4609b !important; } /* Ženy */
.menu-item-727 > a { color: #6b7db3 !important; } /* Muži */
.menu-item-736 > a { color: #9b6bab !important; } /* Páry */

/* Hover - zesvětlit barvu u barevnych */
.menu-item-718:hover > a { color: #e878b3 !important; }
.menu-item-727:hover > a { color: #8595cc !important; }
.menu-item-736:hover > a { color: #b585c5 !important; }

/* Hover podtrzeni - pro VSECHNY polozky menu */
.menu-level-1 > [role="none"] > a[role="menuitem"] {
    border-bottom: 2px solid transparent !important;
    padding-bottom: 4px !important;
    transition: border-color 0.2s ease, color 0.2s ease !important;
}

.menu-level-1 > [role="none"]:hover > a[role="menuitem"] {
    border-bottom-color: currentColor !important;
}

nav[aria-label="Hlavni menu"],
.navigation-in {
    position: relative !important;
}

.navigation-in > .menu-level-1 {
    position: relative !important;
}

.menu-level-1 > [role="none"] > a[role="menuitem"] {
    font-family: 'Poppins', 'Open Sans', Arial, sans-serif !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    transition: var(--ardore-transition);
}

.menu-level-1 > [role="none"]:hover > a[role="menuitem"],
.menu-level-1 > [role="none"] > a[role="menuitem"]:hover {
    color: var(--ardore-pink) !important;
}

/* ============================================================
   5. CATEGORY HEADER - inspirace RuzovySlon.cz
   ============================================================ */
.category-top .category-title {
    font-family: 'Poppins', sans-serif !important;
    font-size: 32px !important;
    font-weight: 700 !important;
    color: var(--ardore-pink) !important;
    margin: 0 0 12px 0 !important;
    line-height: 1.2 !important;
}

.category-top .category-perex {
    font-size: 14px !important;
    color: var(--ardore-gray) !important;
    line-height: 1.6 !important;
    max-width: none !important;
    margin-bottom: 25px !important;
}

.category-top .category-perex p {
    margin: 0;
}

/* ============================================================
   5a. PODKATEGORIE - grid s obrazky
   ============================================================ */
.subcategories.with-image {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px 20px !important;
    padding: 0 !important;
    margin: 0 0 30px 0 !important;
    list-style: none !important;
}

.subcategories.with-image > li {
    width: calc(16.666% - 17px) !important;
    min-width: 110px !important;
    padding: 0 !important;
    margin: 0 !important;
    text-align: center !important;
    float: none !important;
    flex: none !important;
}

.subcategories.with-image > li a {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-decoration: none !important;
    padding: 12px 5px !important;
    border-radius: 10px !important;
    transition: all 0.25s ease !important;
}

.subcategories.with-image > li a:hover {
    background: #fdf2f8 !important;
    transform: translateY(-2px);
}

.subcategories.with-image > li img {
    width: 100px !important;
    height: 100px !important;
    object-fit: contain !important;
    margin-bottom: 10px !important;
}

.subcategories.with-image > li .subcategory-name,
.subcategories.with-image > li a > span {
    font-family: 'Poppins', sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--ardore-dark) !important;
    line-height: 1.3 !important;
}

/* ============================================================
   5b. PRODUKTOVE KARTY - .products-inline (Nejprodavanejsi)
   Struktura: .p > a.image + .p-in(.p-in-in(.name, .availability) + .p-bottom(.price))
   ============================================================ */

/* Grid 3 sloupce */
.products.products-inline {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
    flex-wrap: unset !important;
}

.products.products-inline > .product {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
    flex: none !important;
}

/* Karta */
.products.products-inline .p {
    background: #fff !important;
    border: 1px solid #eee !important;
    border-radius: 10px !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    transition: all 0.3s ease !important;
    overflow: hidden !important;
    position: relative !important;
}

.products.products-inline .p:hover {
    border-color: var(--ardore-pink-light) !important;
    box-shadow: 0 8px 30px rgba(235,101,176,0.12) !important;
    transform: translateY(-3px) !important;
}

/* Obrazek - CISTE BILE POZADI */
.products.products-inline .p > a.image {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 24px 20px !important;
    min-height: 250px !important;
    background: #fff !important;
    border-bottom: none !important;
}

.products.products-inline .p > a.image img {
    max-width: 100% !important;
    max-height: 230px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    transition: transform 0.4s ease !important;
    mix-blend-mode: multiply !important;
}

.products.products-inline .p:hover > a.image img {
    transform: scale(1.06) !important;
}

/* P-IN wrapper */
.products.products-inline .p .p-in {
    padding: 15px 18px 0 !important;
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
}

/* Nazev */
.products.products-inline .p .p-in-in .name {
    display: block !important;
    margin-bottom: 8px !important;
}

.products.products-inline .p .p-in-in .name a,
.products.products-inline .p .name span[data-micro="name"] {
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--ardore-pink-dark) !important;
    text-decoration: none !important;
    line-height: 1.45 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    white-space: normal !important;
}

.products.products-inline .p .p-in-in .name a:hover {
    color: var(--ardore-pink) !important;
}

/* Dostupnost */
.products.products-inline .p .availability {
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--ardore-green) !important;
    margin-bottom: 5px !important;
}

/* Hodnoceni */
.products.products-inline .p .ratings-wrapper {
    margin-bottom: 8px !important;
}

/* Spodni cast - cena */
.products.products-inline .p .p-bottom {
    margin-top: auto !important;
    padding: 12px 18px 18px !important;
    border-top: 1px solid #f5f5f5 !important;
}

.products.products-inline .p .price-final {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--ardore-dark) !important;
    font-family: 'Poppins', sans-serif !important;
    line-height: 1.2 !important;
}

.products.products-inline .p .price-standard-wrapper {
    font-size: 13px !important;
    color: #bbb !important;
}

/* Extra flags */
.products.products-inline .p .extra-flags {
    position: absolute !important;
    top: 10px !important;
    left: 10px !important;
    z-index: 3 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

/* ============================================================
   5c. PRODUKTOVE KARTY - .products-block (hlavni listing)
   Vzor: ruzovyslon.cz - ciste bile pozadi, nazev nahore,
   kratky popis, hvezdicky+skladem, cena, kompaktni kosik
   ============================================================ */

.products-page.products-block {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 22px !important;
}

.products-page.products-block > .product {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Karta */
.products-block .p {
    background: #fff !important;
    border: 1px solid #eee !important;
    border-radius: 10px !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    transition: all 0.3s ease !important;
    overflow: hidden !important;
    position: relative !important;
}

.products-block .p:hover {
    border-color: var(--ardore-pink-light) !important;
    box-shadow: 0 6px 24px rgba(235,101,176,0.10) !important;
    transform: translateY(-2px) !important;
}

/* Obrazek - CISTE BILE POZADI */
.products-block .p > a.image {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 24px 20px !important;
    min-height: 260px !important;
    background: #fff !important;
    border-bottom: none !important;
    overflow: hidden !important;
}

.products-block .p > a.image img {
    max-width: 100% !important;
    max-height: 240px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    transition: transform 0.4s ease !important;
    mix-blend-mode: multiply !important;
}

.products-block .p:hover > a.image img {
    transform: scale(1.05) !important;
}

.products-block .p > a.image .swap-image {
    max-width: 100% !important;
    max-height: 240px !important;
    object-fit: contain !important;
    mix-blend-mode: multiply !important;
}

/* Flags / badges */
.products-block .p .flags {
    position: absolute !important;
    top: 12px !important;
    left: 12px !important;
    z-index: 3 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 5px !important;
}

.products-block .p .flag {
    display: inline-block !important;
    padding: 4px 12px !important;
    border-radius: 4px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    font-family: 'Poppins', sans-serif !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    line-height: 1.3 !important;
}

/* P-IN wrapper */
.products-block .p .p-in {
    padding: 0 20px !important;
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
}

/* Nazev - nad popisem jako na Slonovi */
.products-block .p .p-in-in .name {
    display: block !important;
    margin-bottom: 6px !important;
}

.products-block .p .name a,
.products-block .p .name span[data-micro="name"] {
    font-family: 'Poppins', sans-serif !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    color: var(--ardore-pink-dark) !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    white-space: normal !important;
}

.products-block .p .name a:hover {
    color: var(--ardore-pink) !important;
}

/* Popis produktu - hlavni definice je v .p-bottom vyse */

/* Hvezdicky + Dostupnost na jednom radku */
.products-block .p .ratings-wrapper {
    margin-bottom: 6px !important;
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 6px 12px !important;
}

.products-block .p .availability {
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--ardore-green) !important;
    margin-bottom: 0 !important;
}

.products-block .p .stars-wrapper {
    display: inline-flex !important;
    align-items: center !important;
}

/* P-BOTTOM: flex container pro prerovnani - popis NAD kosik */
.products-block .p .p-bottom {
    margin-top: auto !important;
    padding: 14px 20px 18px !important;
    border-top: 1px solid #f0f0f0 !important;
}

/* Offer wrapper - flex column pro reorder prvku */
.products-block .p .p-bottom [data-micro="offer"] {
    display: flex !important;
    flex-direction: column !important;
}

/* Popis - presunout NAD p-tools (order: -1 = pred cenami a kosikem) */
.products-block .p .p-bottom .p-desc {
    order: 0 !important;
    font-size: 12.5px !important;
    color: #666 !important;
    line-height: 1.5 !important;
    margin: 0 0 10px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

/* Ceny - order 1 (za popisem) */
.products-block .p .p-bottom .prices {
    order: 1 !important;
}

/* P-tools (kosik) - order 2 (za cenou) */
.products-block .p .p-bottom .p-tools {
    order: 2 !important;
}

/* Cena */
.products-block .p .price-final {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--ardore-dark) !important;
    font-family: 'Poppins', sans-serif !important;
    line-height: 1.2 !important;
}

.products-block .p .price-standard-wrapper {
    font-size: 13px !important;
    color: #bbb !important;
    text-decoration: line-through !important;
}

.products-block .p .pr-list-unit {
    font-size: 11px !important;
    color: #aaa !important;
}

/* Kosik: quantity + button NA JEDNOM RADKU jako Slon */
.products-block .p .p-tools {
    margin-top: 10px !important;
}

.products-block .p .p-tools form,
.products-block .p .p-tools .pr-action {
    display: flex !important;
    flex-direction: row !important;
    gap: 8px !important;
    align-items: stretch !important;
}

.products-block .p .quantity {
    display: flex !important;
    align-items: center !important;
    border: 1px solid #e0e0e0 !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    width: auto !important;
    min-width: 80px !important;
    flex: 0 0 auto !important;
    justify-content: center !important;
}

.products-block .p .quantity .amount {
    text-align: center !important;
    border: none !important;
    width: 32px !important;
    max-width: 36px !important;
    font-size: 14px !important;
    padding: 8px 0 !important;
    background: #fff !important;
}

.products-block .p .quantity .increase,
.products-block .p .quantity .decrease {
    background: none !important;
    border: none !important;
    padding: 8px 8px !important;
    cursor: pointer !important;
    font-size: 13px !important;
    color: #888 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s ease !important;
}

.products-block .p .quantity .increase:hover,
.products-block .p .quantity .decrease:hover {
    color: var(--ardore-pink) !important;
    background: #fdf2f8 !important;
}

/* Tlacitko Do kosiku - zabira zbytek radku vedle quantity */
.products-block .p .btn-cart,
.products-block .p .add-to-cart-button {
    background: var(--ardore-pink) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 11px 14px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    font-family: 'Poppins', sans-serif !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    flex: 1 1 auto !important;
    cursor: pointer !important;
    transition: all 0.25s ease !important;
    text-align: center !important;
    white-space: nowrap !important;
    width: auto !important;
}

.products-block .p .btn-cart:hover,
.products-block .p .add-to-cart-button:hover {
    background: var(--ardore-pink-dark) !important;
    box-shadow: 0 4px 12px rgba(235,101,176,0.3) !important;
}

/* ============================================================
   5d. SIDEBAR FILTR - collapsible, bez ramecku, show more
   ============================================================ */

/* Odstranit ramecek kolem celeho filtru */
.box-filters {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    padding: 0 !important;
}

.box-filters .box-in,
.filters-wrapper,
#filters {
    border: none !important;
    background: transparent !important;
    padding: 0 !important;
}

/* Font pro sidebar */
.category-content .sidebar,
.content-wrapper .sidebar {
    font-family: 'Poppins', sans-serif;
}

/* Filtracni sekce - bez ramecku, oddelene ciste */
.filter-section {
    border: none !important;
    border-bottom: 1px solid #f0f0f0 !important;
    padding: 0 0 16px !important;
    margin-bottom: 16px !important;
}

.filter-section:last-child {
    border-bottom: none !important;
}

/* H4 nadpisy filtru - klikaci toggle */
.filter-section h4,
.slider-wrapper h4 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    color: var(--ardore-dark) !important;
    margin: 0 0 12px !important;
    padding: 0 !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    user-select: none !important;
    transition: color 0.2s ease !important;
}

.filter-section h4:hover,
.slider-wrapper h4:hover {
    color: var(--ardore-pink-dark) !important;
}

/* Sipka toggle */
.filter-section h4::after,
.slider-wrapper h4::after {
    content: '' !important;
    display: inline-block !important;
    width: 8px !important;
    height: 8px !important;
    border-right: 2px solid #999 !important;
    border-bottom: 2px solid #999 !important;
    transform: rotate(45deg) !important;
    transition: transform 0.25s ease !important;
    flex-shrink: 0 !important;
    margin-left: 8px !important;
}

/* Sipka otocena nahoru kdyz je OTEVRENO (default) */
.filter-section h4::after,
.slider-wrapper h4::after {
    transform: rotate(-135deg) !important;
}

/* Sipka dolu kdyz je ZAVRENO */
.filter-section.ardore-collapsed h4::after,
.slider-wrapper.ardore-collapsed h4::after {
    transform: rotate(45deg) !important;
}

/* Skryt obsah filtru kdyz je zavreny */
.filter-section.ardore-collapsed form,
.filter-section.ardore-collapsed fieldset,
.filter-section.ardore-collapsed .param-filter-top,
.slider-wrapper.ardore-collapsed .slider-header,
.slider-wrapper.ardore-collapsed .slider-content,
.slider-wrapper.ardore-collapsed + form {
    display: none !important;
}

/* Checkbox labely - cisty styl */
.filter-section fieldset > div {
    margin-bottom: 6px !important;
}

.filter-label {
    font-family: 'Poppins', sans-serif !important;
    font-size: 13px !important;
    color: var(--ardore-dark) !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    line-height: 1.4 !important;
}

.filter-label:hover {
    color: var(--ardore-pink-dark) !important;
}

.filter-count {
    font-size: 11px !important;
    color: #aaa !important;
    font-weight: 400 !important;
}

/* Cena slider */
.slider-wrapper {
    border-bottom: 1px solid #f0f0f0 !important;
    padding-bottom: 16px !important;
    margin-bottom: 16px !important;
}

.slider-header {
    font-size: 13px !important;
    color: var(--ardore-gray) !important;
    margin-bottom: 8px !important;
}

/* Na sklade checkbox */
.filter-section-boolean {
    padding: 12px 0 !important;
    border-bottom: 1px solid #f0f0f0 !important;
    margin-bottom: 16px !important;
}

/* Show More / Zobrazit vice tlacitko */
.ardore-show-more {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: var(--ardore-pink-dark) !important;
    cursor: pointer !important;
    border: none !important;
    background: none !important;
    padding: 6px 0 0 !important;
    transition: color 0.2s ease !important;
}

.ardore-show-more:hover {
    color: var(--ardore-pink) !important;
}

.ardore-show-more::after {
    content: '›' !important;
    font-size: 14px !important;
    transform: rotate(90deg) !important;
    display: inline-block !important;
}

.ardore-show-more.ardore-expanded::after {
    transform: rotate(-90deg) !important;
}

/* Skryte polozky filtru */
.filter-section fieldset > div.ardore-hidden {
    display: none !important;
}

.filter-section fieldset > div.ardore-hidden.ardore-visible {
    display: block !important;
}

/* ============================================================
   5e. NADPISY A RAZENI
   ============================================================ */
.products-top-heading,
.category-content h2 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--ardore-dark) !important;
    margin: 30px 0 15px !important;
}

.sorting,
.sort-by {
    font-family: 'Poppins', sans-serif !important;
}


/* ============================================================
   5g. CATEGORY TOP - ARDORE HERO BANNER
   HTML sablona: .ardore-hero > __left + __image + __aside
   Obrazek se nacita automaticky z og:image pres JS (initHeroImage)
   ============================================================ */

/* Skryt Shoptet nativni h1 pokud existuje ardore-hero */
.category-top:has(.ardore-hero) .category-title {
    display: none !important;
}

.category-top {
    margin-bottom: 25px !important;
    padding: 0 !important;
    background: none !important;
    max-width: none !important;
    width: 100% !important;
}

.category-top::before,
.category-top::after {
    display: none !important;
}

.category-top .category-perex {
    max-width: none !important;
    width: 100% !important;
    margin-bottom: 0 !important;
}

/* Hero wrapper - 3 sloupce */
.ardore-hero {
    display: grid !important;
    grid-template-columns: 1fr auto 340px !important;
    min-height: 340px !important;
    /* background: linear-gradient(135deg, #fdf2f8 0%, #fce7f3 50%, #f5d0e6 100%) !important;
    border-radius: 16px !important; */
    overflow: hidden !important;
    position: relative !important;
    max-width: 1178px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* LEVY SLOUPEC - nazev + popis */
.ardore-hero__left {
    padding: 20px 20px 40px 44px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: top !important;
    z-index: 2 !important;
    position: relative !important;
}

.ardore-hero__title {
    font-family: 'Poppins', sans-serif !important;
    font-size: 36px !important;
    font-weight: 800 !important;
    color: #1a1a1a !important;
    margin: 0 0 14px 0 !important;
    line-height: 1.15 !important;
}

.ardore-hero__text {
    font-family: 'Open Sans', sans-serif !important;
    font-size: 15px !important;
    line-height: 1.65 !important;
    color: #555 !important;
    margin: 0 0 10px 0 !important;
    max-width: 380px !important;
}

.ardore-hero__more {
    font-family: 'Poppins', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--ardore-pink-dark) !important;
    text-decoration: none !important;
}
.ardore-hero__more:hover { color: var(--ardore-pink) !important; }

/* STREDNI SLOUPEC - obrazek (JS vlozi z og:image) */
.ardore-hero__image {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 20px 10px !important;
    z-index: 1 !important;
    min-width: 280px !important;
}

.ardore-hero__image img {
    max-height: 300px !important;
    max-width: 100% !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
}

/* PRAVY SLOUPEC - info box (bile sklo) */
.ardore-hero__aside {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: center !important;
    background: rgba(255,255,255,0.92) !important;
    backdrop-filter: blur(12px) !important;
    border-radius: 14px !important;
    padding: 30px !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.06) !important;
    margin: 30px 35px 30px 0 !important;
    z-index: 2 !important;
}

.ardore-hero__aside-title {
    font-family: 'Poppins', sans-serif !important;
    font-size: 19px !important;
    font-weight: 700 !important;
    color: #1a1a1a !important;
    margin: 0 0 18px 0 !important;
    line-height: 1.3 !important;
}

/* Odkazy v aside boxu */
.ardore-hero__links {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 22px 0 !important;
}

.ardore-hero__links li {
    margin-bottom: 14px !important;
}

.ardore-hero__links li::before {

    display: inline !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    color: var(--ardore-pink-dark) !important;

}

.ardore-hero__links a {
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--ardore-pink-dark) !important;
    text-decoration: none !important;
    line-height: 1.45 !important;
}
.ardore-hero__links a:hover { color: var(--ardore-pink) !important; }

/* Tlacitko */
.ardore-hero__btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 14px 30px !important;
    border: 2px solid #1a1a1a !important;
    border-radius: 50px !important;
    background: transparent !important;
    color: #1a1a1a !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1.5px !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
}
.ardore-hero__btn:hover {
    background: var(--ardore-pink) !important;
    border-color: var(--ardore-pink) !important;
    color: #fff !important;
}

/* Breadcrumb */
.breadcrumbs {
    margin-bottom: 0 !important;
    padding: 10px 0 !important;
}
.breadcrumbs a {
    color: #999 !important;
    font-size: 13px !important;
}

/* Podkategorie pod bannerem - horizontalni tlacitka */
.category-top .subcategories.with-image {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
    gap: 12px !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 25px auto 0 !important;
    max-width: 1178px !important;
}

.category-top .subcategories.with-image > li {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
    float: none !important;
}

.category-top .subcategories.with-image > li > a {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    text-align: left !important;
    background: #fdf2f8 !important;
    border-radius: 12px !important;
    padding: 14px 18px !important;
    gap: 14px !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
    border: none !important;
    height: auto !important;
}

.category-top .subcategories.with-image > li > a:hover {
    background: #fce7f3 !important;
    box-shadow: 0 4px 16px rgba(235,101,176,0.10) !important;
    transform: translateY(-1px) !important;
    border: none !important;
}

.category-top .subcategories.with-image .image {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 60px !important;
    height: 60px !important;
    min-width: 60px !important;
    margin-bottom: 0 !important;
    flex-shrink: 0 !important;
}

.category-top .subcategories.with-image .image img {
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    mix-blend-mode: multiply !important;
}

.category-top .subcategories.with-image .name,
.category-top .subcategories.with-image .category-name {
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
    line-height: 1.35 !important;
}

.category-top .subcategories.with-image .count {
    font-size: 11px !important;
    color: #999 !important;
    font-weight: 400 !important;
}

/* ============================================================
   5g-responsive. ARDORE HERO RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
    .ardore-hero {
        grid-template-columns: 1fr 300px !important;
    }
    .ardore-hero__image {
        position: absolute !important;
        right: 320px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        min-width: 0 !important;
        opacity: 0.25 !important;
    }
}

@media (max-width: 768px) {
    .ardore-hero {
        grid-template-columns: 1fr !important;
        min-height: auto !important;
    }
    .ardore-hero__left {
        padding: 28px 24px 10px !important;
    }
    .ardore-hero__image {
        position: relative !important;
        right: auto !important;
        top: auto !important;
        transform: none !important;
        opacity: 1 !important;
        padding: 10px 24px !important;
        min-width: 0 !important;
    }
    .ardore-hero__image img {
        max-height: 200px !important;
    }
    .ardore-hero__aside {
        margin: 0 18px 20px !important;
        padding: 24px !important;
    }
    .ardore-hero__title {
        font-size: 28px !important;
    }
    .category-top .subcategories.with-image {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
    }
    .category-top .subcategories.with-image .image {
        width: 48px !important;
        height: 48px !important;
        min-width: 48px !important;
    }
    .category-top .subcategories.with-image > li > a {
        padding: 10px 14px !important;
        gap: 10px !important;
    }
    .category-top .subcategories.with-image .name,
    .category-top .subcategories.with-image .category-name {
        font-size: 13px !important;
    }
}

/* Fallback pro kategorie BEZ ardore-hero (stary box-category styl) */
.box-category {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 1fr 380px !important;
    min-height: 340px !important;
    background: linear-gradient(135deg, #fdf2f8 0%, #fce7f3 50%, #f5d0e6 100%) !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    max-width: none !important;
}
.box-category__background {
    position: absolute !important;
    left: 48% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    max-height: 310px !important;
    max-width: 45% !important;
    object-fit: contain !important;
    z-index: 1 !important;
    pointer-events: none !important;
}
.box-category__description {
    position: relative !important;
    z-index: 2 !important;
    padding: 40px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}
.box-category__description__title,
.box-category__description h1 {
    font-family: 'Poppins', sans-serif !important;
    font-size: 34px !important;
    font-weight: 800 !important;
    color: #1a1a1a !important;
    margin: 0 0 14px !important;
}
.category-perex > .box-category__play-zone:not(.box-category__play-zone--desktop) {
    display: none !important;
}

   5f. RESPONSIVE - PRODUKTY
   ============================================================ */
@media (max-width: 991px) {
    .products.products-inline,
    .products-page.products-block {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 15px !important;
    }
    .subcategories.with-image > li {
        width: calc(25% - 15px) !important;
    }
}

@media (max-width: 576px) {
    .products.products-inline,
    .products-page.products-block {
        grid-template-columns: 1fr !important;
    }
    .category-top .category-title {
        font-size: 24px !important;
    }
    .subcategories.with-image > li {
        width: calc(33.333% - 14px) !important;
    }
    .products-block .p .price-final {
        font-size: 18px !important;
    }
}

/* ============================================================
   6. TLACITKA
   ============================================================ */
.btn-primary, .btn-cart, .add-to-cart, button[type="submit"].btn {
    background: var(--ardore-pink) !important;
    color: var(--ardore-white) !important;
    border: none !important;
    border-radius: var(--ardore-radius) !important;
    font-weight: 600;
    font-family: 'Poppins', 'Open Sans', Arial, sans-serif !important;
    transition: var(--ardore-transition);
}

.btn-primary:hover, .btn-cart:hover, .add-to-cart:hover {
    background: var(--ardore-pink-dark) !important;
    box-shadow: 0 4px 12px rgba(235, 101, 176, 0.3);
}

/* ============================================================
   6a2. KONTAKTNI SEKCE - asymetricky layout s levou bordou
   ============================================================ */
.ardore-contact-section {
    border-top: 1px solid #eee !important;
    padding: 50px 20px !important;
    margin-top: 30px !important;
}

.ardore-contact-inner {
    display: grid !important;
    grid-template-columns: 1fr 380px !important;
    gap: 50px !important;
    max-width: 1178px !important;
    margin: 0 auto !important;
    align-items: start !important;
}

/* Levy sloupec - odkazy na clanky */
.ardore-contact-left {
    padding-left: 24px !important;
    border-left: 3px solid var(--ardore-pink) !important;
}

.ardore-contact-heading {
    font-family: 'Poppins', sans-serif !important;
    font-size: 26px !important;
    font-weight: 800 !important;
    color: var(--ardore-dark) !important;
    margin: 0 0 22px 0 !important;
    line-height: 1.25 !important;
}

.ardore-contact-links {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 28px 0 !important;
    column-count: 2 !important;
    column-gap: 30px !important;
}

.ardore-contact-links li {
    margin-bottom: 14px !important;
    break-inside: avoid !important;
}

.ardore-contact-links li::before {
    content: '●' !important;
    color: var(--ardore-pink) !important;
    font-size: 8px !important;
    margin-right: 10px !important;
    vertical-align: middle !important;
}

.ardore-contact-links a {
    font-family: 'Poppins', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--ardore-pink-dark) !important;
    text-decoration: none !important;
    text-decoration-color: transparent !important;
    text-underline-offset: 3px !important;
    transition: all 0.2s ease !important;
}

.ardore-contact-links a:hover {
    text-decoration: underline !important;
    text-decoration-color: var(--ardore-pink) !important;
}

.ardore-contact-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 13px 30px !important;
    border: 2px solid var(--ardore-dark) !important;
    border-radius: 50px !important;
    background: transparent !important;
    color: var(--ardore-dark) !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1.2px !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
}

.ardore-contact-btn:hover {
    background: var(--ardore-pink) !important;
    border-color: var(--ardore-pink) !important;
    color: #fff !important;
}

/* Pravy sloupec - kontaktni karta */
.ardore-contact-card {
    background: linear-gradient(145deg, #fdf2f8 0%, #fce7f3 100%) !important;
    padding: 32px !important;
    position: relative !important;
}

/* Sikmy roh vlevo nahore misto border-radius */
.ardore-contact-card {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 0 24px, 24px 0) !important;
}

/* Fallback pro browsery bez clip-path */
@supports not (clip-path: polygon(0 0)) {
    .ardore-contact-card {
        border-radius: 4px 14px 14px 14px !important;
    }
}

.ardore-contact-card__title {
    font-family: 'Poppins', sans-serif !important;
    font-size: 20px !important;
    font-weight: 800 !important;
    color: var(--ardore-pink-dark) !important;
    margin: 0 0 20px 0 !important;
    line-height: 1.2 !important;
}

/* Osoba */
.ardore-contact-person {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    margin-bottom: 22px !important;
    padding-bottom: 18px !important;
    border-bottom: 1px solid rgba(192,36,130,0.12) !important;
}

.ardore-contact-person__avatar {
    width: 56px !important;
    height: 56px !important;
    flex-shrink: 0 !important;
    background: rgba(255,255,255,0.7) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.ardore-contact-person__avatar svg {
    width: 40px !important;
    height: 40px !important;
}

.ardore-contact-person__info strong {
    display: block !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--ardore-dark) !important;
    margin-bottom: 2px !important;
}

.ardore-contact-person__info span {
    font-size: 12px !important;
    color: #888 !important;
}

/* Kontaktni kanaly */
.ardore-contact-channels {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}

.ardore-contact-channel {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    text-decoration: none !important;
    transition: transform 0.2s ease !important;
}

.ardore-contact-channel:hover {
    transform: translateX(3px) !important;
}

.ardore-contact-channel svg {
    width: 22px !important;
    height: 22px !important;
    flex-shrink: 0 !important;
}

.ardore-contact-channel strong {
    display: block !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--ardore-dark) !important;
}

.ardore-contact-channel span {
    display: block !important;
    font-size: 12px !important;
    color: #999 !important;
    margin-top: 1px !important;
}

/* Responsive */
@media (max-width: 991px) {
    .ardore-contact-inner {
        grid-template-columns: 1fr !important;
        gap: 30px !important;
    }
    .ardore-contact-links {
        column-count: 1 !important;
    }
}

@media (max-width: 576px) {
    .ardore-contact-section {
        padding: 35px 16px !important;
    }
    .ardore-contact-heading {
        font-size: 22px !important;
    }
    .ardore-contact-card {
        padding: 24px !important;
    }
}

/* ============================================================
   6b. USP BLOK NAD FOOTEREM - fullwidth ruzove pozadi
   ============================================================ */
.ardore-usp {
    background: linear-gradient(135deg, #2d1f2e 0%, #3a2535 50%, #2d1f2e 100%) !important;
    padding: 60px 20px 60px !important;
    margin: 50px 0 0 0 !important;
    position: relative !important;
    overflow: hidden !important;
    max-width: none !important;
    width: 100% !important;
}

/* Dekorativni kruhy v pozadi */
.ardore-usp::before {
    content: '' !important;
    position: absolute !important;
    top: -60px !important;
    right: -40px !important;
    width: 300px !important;
    height: 300px !important;
    background: rgba(235, 101, 176, 0.06) !important;
    border-radius: 50% !important;
    pointer-events: none !important;
}

.ardore-usp::after {
    content: '' !important;
    position: absolute !important;
    bottom: -80px !important;
    left: 10% !important;
    width: 220px !important;
    height: 220px !important;
    background: rgba(192, 36, 130, 0.05) !important;
    border-radius: 50% !important;
    pointer-events: none !important;
}

/* Inner grid - omezeny na sirku contentu */
.ardore-usp__inner {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 24px !important;
    max-width: 1178px !important;
    margin: 0 auto !important;
    position: relative !important;
    z-index: 1 !important;
}

.ardore-usp__card {
    background: rgba(255,255,255,0.08) !important;
    backdrop-filter: blur(8px) !important;
    border-radius: 14px !important;
    padding: 32px 30px !important;
    transition: all 0.3s ease !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
}

.ardore-usp__card:hover {
    background: rgba(255,255,255,0.12) !important;
    box-shadow: 0 8px 30px rgba(0,0,0,0.2) !important;
    transform: translateY(-2px) !important;
}

.ardore-usp__icon {
    width: 52px !important;
    height: 52px !important;
    margin-bottom: 18px !important;
}

.ardore-usp__icon svg {
    width: 100% !important;
    height: 100% !important;
}

.ardore-usp__title {
    font-family: 'Poppins', sans-serif !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #fff !important;
    text-transform: uppercase !important;
    letter-spacing: 0.3px !important;
    margin: 0 0 12px 0 !important;
}

.ardore-usp__text {
    font-family: 'Open Sans', sans-serif !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: rgba(255,255,255,0.65) !important;
    margin: 0 0 16px 0 !important;
}

.ardore-usp__link {
    font-family: 'Poppins', sans-serif !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--ardore-pink) !important;
    text-decoration: none !important;
    display: inline-block !important;
}

.ardore-usp__link:hover {
    color: var(--ardore-pink-light) !important;
}

@media (max-width: 991px) {
    .ardore-usp {
        padding: 40px 20px !important;
        margin-top: 40px !important;
    }
    .ardore-usp__inner {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }
    .ardore-usp__card {
        padding: 24px !important;
    }
}

/* ============================================================
   6c. DETAIL PRODUKTU - TABULKA PARAMETRU
   Jen tabulka pod popisem (ne shipping-options nad kosikem)
   ============================================================ */

/* ============================================================
   6e. HOMEPAGE - CATEGORY CARDS (Pro zeny / Pro muze / Pro pary)
   ============================================================ */
.ardore-hp-cards {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 16px !important;
    margin: 20px 0 30px !important;
    padding: 0 !important;
}

.ardore-hp-card {
    position: relative !important;
    display: flex !important;
    align-items: flex-end !important;
    min-height: 200px !important;
    border-radius: 14px !important;
    overflow: hidden !important;
    text-decoration: none !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
}

.ardore-hp-card:hover {
    transform: translateY(-5px) scale(1.02) !important;
    box-shadow: 0 16px 40px rgba(0,0,0,0.18) !important;
}

.ardore-hp-card:hover .ardore-hp-card__overlay {
    background: linear-gradient(to top, rgba(30,20,35,0.65) 0%, rgba(30,20,35,0.15) 50%, transparent 100%) !important;
}

.ardore-hp-card:hover .ardore-hp-card__icon {
    transform: scale(1.15) !important;
    color: rgba(255,255,255,0.9) !important;
}

/* Pozadi - realne fotky */
.ardore-hp-card--women {
    background: url('/user/documents/upload/zeny.jpg') center/cover no-repeat !important;
}

.ardore-hp-card--men {
    background: url('/user/documents/upload/muzi.jpg') center/cover no-repeat !important;
}

.ardore-hp-card--couples {
    background: url('/user/documents/upload/pary.jpg') center/cover no-repeat !important;
}

/* Jemny overlay dole */
.ardore-hp-card__overlay {
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(to top, rgba(30,20,35,0.50) 0%, rgba(30,20,35,0.08) 50%, transparent 100%) !important;
    z-index: 1 !important;
    transition: background 0.3s ease !important;
}

/* Content */
.ardore-hp-card__content {
    position: relative !important;
    z-index: 2 !important;
    padding: 24px 26px !important;
    width: 100% !important;
}

.ardore-hp-card__icon {
    display: inline-block !important;
    font-size: 42px !important;
    color: rgba(255,255,255,0.55) !important;
    margin-bottom: 6px !important;
    line-height: 1 !important;
    transition: transform 0.3s ease, color 0.3s ease !important;
}

.ardore-hp-card__title {
    font-family: 'Poppins', sans-serif !important;
    font-size: 28px !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 0 0 4px 0 !important;
    line-height: 1.1 !important;
    text-shadow: 0 1px 6px rgba(0,0,0,0.15) !important;
}

.ardore-hp-card__text {
    font-family: 'Open Sans', sans-serif !important;
    font-size: 13px !important;
    color: rgba(255,255,255,0.80) !important;
    margin: 0 !important;
    line-height: 1.4 !important;
}

@media (max-width: 768px) {
    .ardore-hp-cards {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }
    .ardore-hp-card {
        min-height: 160px !important;
    }
    .ardore-hp-card__title {
        font-size: 24px !important;
    }
}

/* ============================================================
   6d. SPACING & LAYOUT - kompaktni vzdusny design
   ============================================================ */

/* Detail produktu - hlavicka */
.p-detail {
    margin-bottom: 20px !important;
}

.p-detail-inner {
    gap: 20px !important;
}

/* Benefit banner pod galerií */
.benefitBanner {
    margin: 15px 0 10px !important;
    padding: 12px 0 !important;
}

/* Taby Popis / Diskuze */
.shp-tabs-wrapper,
.p-detail-tabs-wrapper {
    margin-top: 15px !important;
    margin-bottom: 0 !important;
}

.shp-tabs,
.p-detail-tabs {
    margin-bottom: 0 !important;
}

/* Tab content */
.tab-pane {
    padding-top: 20px !important;
}

/* Hlavni popis produktu */
.basic-description {
    margin-bottom: 20px !important;
}

.basic-description h2,
.basic-description h3 {
    font-family: 'Poppins', sans-serif !important;
    margin: 20px 0 10px !important;
}

.basic-description h2:first-child,
.basic-description h3:first-child {
    margin-top: 0 !important;
}

/* Extended description (parametry) */
.extended-description {
    margin-top: 10px !important;
    margin-bottom: 15px !important;
}

/* Sekce Souvisejici + Podobne produkty */
.products-header,
.products-related-header,
.products-alternative-header {
    font-family: 'Poppins', sans-serif !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--ardore-dark) !important;
    text-align: center !important;
    margin: 30px 0 18px !important;
}

.products-wrapper,
.products-related-wrapper,
.products-alternative-wrapper {
    margin-bottom: 15px !important;
}

/* Strankovani */
.paging-wrapper,
.pagination-wrapper {
    margin: 20px 0 !important;
}

/* Kategorie - mezery mezi sekcemi */
.category-top {
    margin-bottom: 20px !important;
}

.products-top-wrapper {
    margin-top: 10px !important;
    margin-bottom: 20px !important;
}

.products-top-header,
.products-top-heading {
    margin: 15px 0 12px !important;
}

/* Sidebar - kompaktnejsi */
.box-filters {
    margin-bottom: 15px !important;
}

/* USP - mene mezery nad */
.ardore-usp {
    margin-top: 30px !important;
}

/* Footer - tesne pod USP */
footer, #footer {
    margin-top: 0 !important;
}

/* Globalni H2 v contentu */
.content h2,
.category-content h2 {
    margin: 25px 0 12px !important;
}

/* Rate wrapper / hodnoceni v popisu */
.rate-wrapper {
    margin: 15px 0 !important;
}

/* Tip box */
.tip-box,
.alert-info {
    margin: 15px 0 !important;
    border-radius: 10px !important;
}

/* Objevte take: tagy */
.related-tags,
[class*="discover"] {
    margin: 15px 0 !important;
}

/* Skryt nadpis "Doplnkove parametry" */
.extended-description p:has(> strong) {
    display: none !important;
}
/* Fallback pro browsery bez :has */
.extended-description > p > strong {
    font-size: 0 !important;
    line-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
}

/* Wrapper s border a radius - JEN pro parametry, NE shipping */
.detail-parameters:not(.shipping-options-layout) {
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    font-family: 'Open Sans', sans-serif !important;
    margin: 15px 0 25px !important;
    border: 1px solid #e5e5e5 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}

.detail-parameters:not(.shipping-options-layout) tr {
    transition: background 0.15s ease !important;
}

.detail-parameters:not(.shipping-options-layout) tr:hover {
    background: #fdf2f8 !important;
}

/* Zebra striping */
.detail-parameters:not(.shipping-options-layout) tr:nth-child(even) {
    background: #fafafa !important;
}

.detail-parameters:not(.shipping-options-layout) tr:nth-child(even):hover {
    background: #fdf2f8 !important;
}

/* Header cell */
.detail-parameters:not(.shipping-options-layout) th {
    font-family: 'Poppins', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #666 !important;
    text-align: left !important;
    padding: 12px 20px !important;
    white-space: nowrap !important;
    vertical-align: top !important;
    width: 170px !important;
    border: none !important;
    border-bottom: 1px solid #f0f0f0 !important;
}

/* Odstranit Shoptet teckovany border za nazvem parametru */
.detail-parameters:not(.shipping-options-layout) th::after,
table.detail-parameters tbody tr th::after {
    display: none !important;
    border: none !important;
    content: none !important;
}

/* Value cell */
.detail-parameters:not(.shipping-options-layout) td {
    font-size: 14px !important;
    color: var(--ardore-dark) !important;
    padding: 12px 20px !important;
    vertical-align: top !important;
    line-height: 1.5 !important;
    border: none !important;
    border-bottom: 1px solid #f0f0f0 !important;
}

/* Posledni radek bez cary */
.detail-parameters:not(.shipping-options-layout) tr:last-child th,
.detail-parameters:not(.shipping-options-layout) tr:last-child td {
    border-bottom: none !important;
}

/* Odkazy */
.detail-parameters:not(.shipping-options-layout) td a {
    color: var(--ardore-pink-dark) !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

.detail-parameters:not(.shipping-options-layout) td a:hover {
    color: var(--ardore-pink) !important;
}

/* Skryt dvojtecku */
.detail-parameters:not(.shipping-options-layout) .row-header-label-colon {
    display: none !important;
}

/* RESPONSIVE */
@media (max-width: 576px) {
    .detail-parameters:not(.shipping-options-layout) {
        border-radius: 10px !important;
    }
    .detail-parameters:not(.shipping-options-layout) th {
        width: auto !important;
        white-space: normal !important;
        padding: 10px 14px !important;
        font-size: 12px !important;
    }
    .detail-parameters:not(.shipping-options-layout) td {
        padding: 10px 14px !important;
        font-size: 13px !important;
    }
}

/* ============================================================
   7. FOOTER
   ============================================================ */
footer, #footer, .footer, [role="contentinfo"] {
    background: var(--ardore-black) !important;
    color: var(--ardore-gray-light) !important;
    padding: 0 !important;
}

.ardore-footer-newsletter {
    background: #1a1a1a;
    border-bottom: 1px solid #2a2a2a;
    padding: 35px 20px;
    overflow: hidden;
    box-sizing: border-box;
}

.ardore-footer-newsletter .ardore-newsletter-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 30px;
    flex-wrap: wrap;
}

.ardore-footer-newsletter .ardore-nl-text {
    flex: 1;
    min-width: 250px;
}

.ardore-footer-newsletter .ardore-nl-text h3 {
    color: var(--ardore-white) !important;
    font-family: 'Poppins', sans-serif;
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 4px 0;
}

.ardore-footer-newsletter .ardore-nl-text p {
    color: #999;
    font-size: 13px;
    margin: 0;
}

.ardore-footer-newsletter .ardore-nl-form {
    display: flex;
    gap: 0;
    flex: 1;
    min-width: 0;
    max-width: 500px;
    box-sizing: border-box;
}

.ardore-footer-newsletter .ardore-nl-form input[type="email"] {
    flex: 1;
    min-width: 0;
    background: #2a2a2a !important;
    border: 1px solid #444 !important;
    border-right: none !important;
    border-radius: var(--ardore-radius) 0 0 var(--ardore-radius) !important;
    color: var(--ardore-white) !important;
    padding: 12px 16px !important;
    font-size: 14px;
    font-family: 'Poppins', sans-serif !important;
    outline: none;
    box-sizing: border-box;
}

.ardore-footer-newsletter .ardore-nl-form input[type="email"]::placeholder {
    color: #777;
}

.ardore-footer-newsletter .ardore-nl-form input[type="email"]:focus {
    border-color: var(--ardore-pink) !important;
    box-shadow: none !important;
}

.ardore-footer-newsletter .ardore-nl-form button {
    background: var(--ardore-pink);
    color: var(--ardore-white);
    border: none;
    border-radius: 0 var(--ardore-radius) var(--ardore-radius) 0;
    padding: 12px 28px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: var(--ardore-transition);
    white-space: nowrap;
}

.ardore-footer-newsletter .ardore-nl-form button:hover {
    background: var(--ardore-pink-dark);
}

.ardore-footer-columns {
    max-width: 1200px;
    margin: 0 auto;
    padding: 40px 20px 30px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
}

.ardore-footer-col h4 {
    color: var(--ardore-white) !important;
    font-family: 'Poppins', sans-serif;
    font-size: 15px;
    font-weight: 600;
    margin: 0 0 18px 0;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--ardore-pink);
    display: inline-block;
}

.ardore-footer-col ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ardore-footer-col ul li {
    margin-bottom: 8px;
}

.ardore-footer-col ul li a {
    color: #aaa !important;
    font-size: 13px;
    font-family: 'Poppins', sans-serif;
    text-decoration: none;
    transition: var(--ardore-transition);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.ardore-footer-col ul li a::before {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-left: 5px solid var(--ardore-pink);
    opacity: 0;
    transition: var(--ardore-transition);
    margin-left: -11px;
}

.ardore-footer-col ul li a:hover {
    color: var(--ardore-pink) !important;
    padding-left: 11px;
}

.ardore-footer-col ul li a:hover::before {
    opacity: 1;
    margin-left: 0;
}

.ardore-footer-col .ardore-contact-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 12px;
    color: #aaa;
    font-size: 13px;
    line-height: 1.5;
}

.ardore-footer-col .ardore-contact-item svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    margin-top: 2px;
    stroke: var(--ardore-pink);
    fill: none;
    stroke-width: 2;
}

.ardore-footer-col .ardore-contact-item a {
    padding-left: 0 !important;
}

.ardore-footer-col .ardore-contact-item a::before {
    display: none;
}

.ardore-footer-social {
    display: flex;
    gap: 10px;
    margin-top: 15px;
}

.ardore-footer-social a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #2a2a2a;
    transition: var(--ardore-transition);
    padding-left: 0 !important;
}

.ardore-footer-social a::before {
    display: none !important;
}

.ardore-footer-social a:hover {
    background: var(--ardore-pink);
    padding-left: 0 !important;
}

.ardore-footer-social a svg {
    width: 18px;
    height: 18px;
    fill: #aaa;
    transition: var(--ardore-transition);
}

.ardore-footer-social a:hover svg {
    fill: var(--ardore-white);
}

.ardore-footer-trust {
    border-top: 1px solid #2a2a2a;
    max-width: 1200px;
    margin: 0 auto;
    padding: 25px 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 25px;
}

.ardore-footer-trust .ardore-trust-item {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #fff;
    font-size: 20px;
    font-family: 'Poppins', sans-serif;
}

.ardore-footer-trust .ardore-trust-item svg {
    width: 20px;
    height: 20px;
    stroke: var(--ardore-pink);
    fill: none;
    stroke-width: 1.8;
}

.ardore-footer-logos {
    border-top: 1px solid #2a2a2a;
    max-width: 1200px;
    margin: 0 auto;
    padding: 25px 20px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 35px;
}

.ardore-footer-logos .ardore-logos-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}

.ardore-footer-logos .ardore-logos-label {
    font-size: 12px;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-family: 'Poppins', sans-serif;
}

.ardore-footer-logos .ardore-logos-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
}

.ardore-footer-logos .ardore-logo-badge {
    background: #ffffff;
    border: 1px solid #333;
    border-radius: 4px;
    padding: 6px 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 36px;
}

.ardore-footer-logos .ardore-logo-badge:hover {
    border-color: #555;
}

.ardore-footer-logos .ardore-logo-badge svg,
.ardore-footer-logos .ardore-logo-badge img {
    height: 22px;
    width: auto;
    max-width: 80px;
    object-fit: contain;
}

.footer-bottom {
    border-top: 1px solid #2a2a2a;
    padding: 18px 0 !important;
}

.footer-bottom .container {
    max-width: 1200px;
    text-align: center;
}

.footer-bottom .copyright {
    color: #666 !important;
    font-size: 12px;
}

.footer-bottom .copyright strong {
    color: #999 !important;
}

.footer-bottom .copyright a {
    color: #666 !important;
}

.footer-bottom .copyright a:hover {
    color: var(--ardore-pink) !important;
}

#signature {
    display: none !important;
}

@media (max-width: 991px) {
    .ardore-footer-columns {
        grid-template-columns: repeat(2, 1fr);
        gap: 25px;
    }
}

@media (max-width: 768px) {
    .ardore-footer-newsletter .ardore-nl-form {
        width: 100%;
        max-width: 100%;
        min-width: 0;
    }
    .ardore-footer-newsletter .ardore-newsletter-inner {
        flex-direction: column;
        text-align: center;
        overflow: hidden;
    }
    .ardore-footer-columns {
        grid-template-columns: 1fr;
        gap: 20px;
        padding: 30px 20px 20px;
    }
    .ardore-footer-trust {
        gap: 15px;
    }
}

/* ============================================================
   8. FORMULARE
   ============================================================ */
input[type="text"], input[type="email"], input[type="password"],
input[type="search"], input[type="tel"], textarea, select {
    border: 1px solid var(--ardore-gray-light) !important;
    border-radius: var(--ardore-radius) !important;
    font-family: 'Poppins', 'Open Sans', Arial, sans-serif !important;
    transition: var(--ardore-transition);
}

input:focus, textarea:focus, select:focus {
    border-color: var(--ardore-pink) !important;
    box-shadow: 0 0 0 2px rgba(235, 101, 176, 0.15) !important;
    outline: none !important;
}

/* ============================================================
   9. BADGES
   ============================================================ */
.flag-discount, .flag-action {
    background: var(--ardore-pink) !important;
    color: var(--ardore-white) !important;
    border-radius: var(--ardore-radius);
    font-weight: 600;
    font-size: 12px;
}

.flag-new {
    background: var(--ardore-green) !important;
    color: var(--ardore-white) !important;
    border-radius: var(--ardore-radius);
}

/* ============================================================
   10. STRANKOVANI
   ============================================================ */
.pagination .active a, .paging .active a {
    background: var(--ardore-pink) !important;
    color: var(--ardore-white) !important;
    border-color: var(--ardore-pink) !important;
}

/* ============================================================
   11. TRUST BAR
   ============================================================ */
.trust-bar {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 30px;
    padding: 15px 20px;
    border-top: 1px solid var(--ardore-gray-light);
    border-bottom: 1px solid var(--ardore-gray-light);
    margin: 0 0 15px 0;
    background: var(--ardore-white);
}

.trust-bar .item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--ardore-dark);
}

.trust-bar .item strong { font-weight: 600; }

/* ============================================================
   12. AGE VERIFICATION OVERLAY
   ============================================================ */
.age-verify-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0,0,0,0.85);
    z-index: 99999;
    display: flex; align-items: center; justify-content: center;
    backdrop-filter: blur(5px);
}

.age-verify-box {
    background: var(--ardore-white);
    border-radius: 10px;
    padding: 40px;
    text-align: center;
    max-width: 420px; width: 90%;
    box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}

.age-verify-box h2 { font-size: 24px; margin-bottom: 15px; }
.age-verify-box p { color: var(--ardore-gray); margin-bottom: 20px; font-size: 14px; }

.age-verify-box .btn-yes {
    background: var(--ardore-pink); color: var(--ardore-white);
    border: none; border-radius: var(--ardore-radius);
    padding: 12px 40px; font-size: 16px; font-weight: 600;
    cursor: pointer; margin: 5px; transition: var(--ardore-transition);
}
.age-verify-box .btn-yes:hover { background: var(--ardore-pink-dark); }

.age-verify-box .btn-no {
    background: var(--ardore-gray-bg); color: var(--ardore-dark);
    border: none; border-radius: var(--ardore-radius);
    padding: 12px 40px; font-size: 16px; font-weight: 500;
    cursor: pointer; margin: 5px; transition: var(--ardore-transition);
}

/* ============================================================
   13. PROFIL + WISHLIST IKONY
   ============================================================ */
#ardore-profile-icon {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    cursor: pointer;
    color: var(--ardore-dark);
    font-size: 22px;
    transition: var(--ardore-transition);
    text-decoration: none;
    vertical-align: middle;
    margin-right: 8px;
    background: none;
    border: none;
    padding: 0;
    outline: none;
}

#ardore-profile-icon:hover {
    color: var(--ardore-pink);
}

#ardore-profile-icon svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
}

#ardore-wishlist-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    cursor: pointer;
    color: var(--ardore-dark);
    font-size: 22px;
    transition: var(--ardore-transition);
    text-decoration: none;
    vertical-align: middle;
    margin-right: 4px;
}

#ardore-wishlist-icon:hover {
    color: var(--ardore-pink);
}

#ardore-wishlist-icon svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.8;
}

/* ============================================================
   14. SELECTION & SCROLLBAR
   ============================================================ */
::selection { background: var(--ardore-pink); color: var(--ardore-white); }

::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--ardore-gray-bg); }
::-webkit-scrollbar-thumb { background: var(--ardore-gray-light); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--ardore-pink); }

html { scroll-behavior: smooth; }

/* ============================================================
   15. HIDE TOP NAV LOGIN/REGISTER
   ============================================================ */
.top-navigation-tools .top-nav-button-login,
.top-navigation-tools .top-nav-button-register {
    display: none !important;
}

/* ============================================================
   16. LOGIN PANEL REPOSITIONING
   ============================================================ */
@media (min-width: 992px) {
    .popup-widget.login-widget::before {
        right: 65px !important;
    }
    .scrolled .popup-widget.login-widget::before {
        right: 65px !important;
    }
    .popup-widget.login-widget {
        right: 0 !important;
        left: auto !important;
        margin-left: 0 !important;
    }
}

/* ============================================================
   17. RESPONSIVE - MENU + OSTATNI
   ============================================================ */
@media (max-width: 991px) {
    .menu-level-2 {
        column-count: 2 !important;
    }
}

@media (max-width: 768px) {
    .menu-level-2 {
        column-count: 1 !important;
        padding: 15px !important;
    }
    .trust-bar {
        flex-direction: column;
        align-items: center;
        gap: 10px;
    }
    #ardore-profile-icon,
    #ardore-wishlist-icon {
        width: 30px;
        height: 30px;
    }
}