@font-face {
  font-family: "Inter Variable";
  font-style: normal;
  font-weight: 200 700;
  font-display: optional;
  src: url("../../../../themes/europasaz/assets/fonts/InterVariable.woff2") format("woff2");
}

/* Przycisk "Więcej" → scroll do opisu */
.js-desc-more-link {
  font-size: 0.8rem;
  color: var(--color-text-secondary, #666);
  text-decoration: none;
  line-height: 1;
  padding: 0;
}


.js-desc-more-link:hover,
.js-desc-more-link:focus {
  color: var(--color-accent, #222);
  text-decoration: underline;
}

.js-desc-more-link .material-icons {
  transition: transform 0.2s ease;
}

.js-desc-more-link:hover .material-icons {
  transform: translateY(2px);
}

@font-face {
  font-family: "Inter Variable";
  font-style: italic;
  font-weight: 200 700;
  font-display: optional;
  src: url("../../../../themes/europasaz/assets/fonts/InterVariable-Italic.woff2") format("woff2");
}

:root {
  --bs-body-font-family: "Inter Variable", "Inter", sans-serif;
  --color-bg-main: #f8f5ef;
  --color-surface: #ffffff;
  --bs-card-bg: #fff;
  --swiper-theme-color: var(--color-accent);
  --color-bg-soft: #f2ede5;
  --color-bg-muted: #faf8f4;
  --color-border: #e2dacf;
  --color-text-main: #101010;
  --color-text-secondary: #625e58;
  --color-text-cta: #161616;
  --color-accent: #bea06c;
  --color-accent-dark: #8c7048;
  --color-success-bg: #ebf9f2;
  --color-success-text: #146e46;
  --color-checkout-accent: #6fae8c;
  --color-alert-bg: #fff3e8;
  --color-alert-text: #964628;
  --header-top-bg: var(--color-bg-main);
  --header-top-color: var(--color-text-secondary);
  --header-top-border-bottom: 1px solid var(--color-border);
  --header-bottom-border-bottom: 1px solid var(--color-border);
  --header-pill-radius: 999px;
  --bs-body-bg: var(--color-bg-main);
  --bs-body-color: var(--color-text-main);
  --bs-emphasis-color: var(--color-text-main);
  --bs-secondary-color: var(--color-text-secondary);
  --bs-secondary-color-rgb: 98, 94, 88;
  --bs-dark: var(--color-text-cta);
  --bs-dark-rgb: 22, 22, 22;
  --bs-primary: var(--color-accent);
  --bs-primary-rgb: 190, 160, 108;
  --bs-link-color: var(--color-text-main);
  --bs-link-hover-color: var(--color-accent-dark);
  --bs-focus-ring-color: rgba(190, 160, 108, 0.35);
  --bs-link-color-rgb: 190, 160, 108;
}

body,
.tooltip,
.popover {
  font-family: "Inter Variable", "Inter", sans-serif;
}

body {
  background-color: var(--color-surface);
  color: var(--color-text-main);
}
.card {
  background-color: #fff;
}
@media (min-width: 1200px) {
    .h4, h4 {
        font-size: 1.2rem;
    }
}


@media (min-width: 1440px) {
        .container, .container-lg, .container-md, .container-sm, .container-xl, .container-xs, .container-xxl {
       max-width: 1435px;
    }
    #login-form, .login__register-prompt, .register-form, .forgotten-password {
        width: 50vw;
        margin: auto;
    }
}

p, 
small, 
.product-description,
.product-description-short {
color: var(--color-text-main);
}
.text-muted,
.text-secondary,
.form-text,
.breadcrumb-item {
  color: var(--color-text-secondary);
}

a:not(.btn),
a:not(.btn):visited {
  color: #000;
  text-decoration: none;
}

a:not(.btn):hover,
a:not(.btn):focus {
  color: var(--color-accent);
  text-decoration: none;
}
.btn-dark {
  --bs-btn-bg: var(--color-text-cta);
  --bs-btn-border-color: var(--color-text-cta);
  --bs-btn-hover-bg: var(--color-text-main);
  --bs-btn-hover-border-color: var(--color-text-main);
  --bs-btn-active-bg: var(--color-text-main);
  --bs-btn-active-border-color: var(--color-text-main);
}

.page-item.active .page-link,
.form-check-input:checked,
.dropdown-item:active,
.list-group-item.active,
.nav-pills .nav-link.active {
  background-color: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-accent-dark);
}

.header-top {
  background-color: var(--header-top-bg);
  color: var(--header-top-color);
  border-bottom: var(--header-top-border-bottom);
}

.header {
  --header-bg: var(--header-top-bg);
  --header-color: var(--color-text-main);
  --header-top-bg: var(--color-bg-main);
  --header-top-color: var(--color-text-secondary);
}

.header__banner {
  margin: 0;
  padding: 0;
  background-color: var(--header-bg);
}

.header__banner:empty {
  display: none;
}

.header__banner > * {
  margin-top: 0;
  margin-bottom: 0;
}

.header-top a,
.header-top .btn,
.header-top .btn-link,
.header-top .material-icons {
  color: var(--header-top-color);
}

.header-top a:hover,
.header-top a:focus,
.header-top .btn-link:hover,
.header-top .btn-link:focus {
  color: var(--color-accent-dark);
}

.header-bottom {
  --header-bottom-border-bottom: 1px solid var(--color-border);
  background-color: var(--header-top-bg);
  border-bottom: var(--header-bottom-border-bottom);
}

/* Stabilizacja naglowka przy resize: bez skokow wynikajacych z max(50px, 10vh) */
.header-bottom.py-2 {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

.header-bottom.py-2 .navbar-brand .logo {
  display: block;
  width: auto;
}

.header-bottom__h1 {
  font-size: unset;
  min-height: 85px;
}

.checkout-steps-header {
  background-color: var(--header-top-bg);
  border-bottom: 1px solid var(--color-border);
}

.checkout-secure-strip {
  background: var(--color-checkout-accent);
  color: #fff;
  line-height: 2rem;
}

.checkout-secure-strip .material-icons {
  color: #fff;
  font-size: 0.825rem;
  vertical-align: text-bottom;
}

.checkout-secure-strip p {
  color: #fff;
}

.checkout-steps-header__logo .logo {
  max-height: 76px;
  width: auto;
}

.checkout-steps-header__item {
  padding: 0 0.35rem;
}

.checkout-steps-header__label {
  display: block;
  margin-bottom: 0.55rem;
  color: var(--color-text-secondary);
  font-size: 1.05rem;
  font-weight: 500;
  text-decoration: none;
}

.checkout-steps-header__track {
  display: block;
  width: 100%;
  height: 4px;
  border-radius: 999px;
  background-color: #7f6868;
}

.checkout-steps-header__item.is-done .checkout-steps-header__label,
.checkout-steps-header__item.is-current .checkout-steps-header__label,
.checkout-steps-header__item.is-done .checkout-steps-header__label:hover,
.checkout-steps-header__item.is-current .checkout-steps-header__label:hover {
  color: var(--color-checkout-accent);
  font-size: 0.925rem;
}

.checkout-steps-header__item.is-done .checkout-steps-header__track,
.checkout-steps-header__item.is-current .checkout-steps-header__track {
  background-color: var(--color-checkout-accent);
  font-size: 0.925rem;
}

.checkout-steps-header__item.is-todo .checkout-steps-header__label,
.checkout-steps-header__item.is-todo .checkout-steps-header__label:hover {
  color: #7f6868;
  font-size: 0.925rem;
}

@media (max-width: 991.98px) {
  .checkout-steps-header__label {
    font-size: 0.95rem;
  }

  .checkout-steps-header__track {
    height: 3px;
  }
}

@media (max-width: 767.98px) {
  .checkout-steps-header {
    display: block;
  }

  .checkout-steps-header .row {
    row-gap: 0;
    justify-content: center;
  }

  .checkout-steps-header__logo {
    text-align: center !important;
  }

  .checkout-steps-header__logo .logo {
    margin: 0 auto;
  }

  .checkout-steps-header__label {
    margin-bottom: 0.3rem;
  }

  .checkout-steps-header__track {
    width: 100%;
  }

  .page-product .product-actions__quantity .input-group {
    display: inline-flex;
    flex-wrap: nowrap;
    align-items: stretch;
    width: auto;
    max-width: 100%;
  }

  .page-product .product-actions__quantity .input-group > .btn {
    flex: 0 0 2.5rem;
    width: 2.5rem;
    min-width: 2.5rem;
    padding: 0.375rem 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .page-product .product-actions__quantity .input-group > .form-control {
    flex: 0 0 3rem;
    width: 3rem;
    min-width: 3rem;
    max-width: 3rem;
    text-align: center;
    padding-left: 0.25rem;
    padding-right: 0.25rem;
  }

  .page-product .product-actions__quantity .input-group .material-icons {
    font-size: 1rem;
    line-height: 1;
  }
}

#module-ph_simpleblog-single .simpleblog__post img,
#module-ph_simpleblog-single .simpleblog__post__content img {
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
}

.header-block__action-btn {
  background-color: var(--color-bg-muted);
  color: var(--header-top-color);
  border: 1px solid var(--color-border);
  border-radius: var(--header-pill-radius);
}

.header-block__action-btn:hover,
.header-block__action-btn:focus {
  background-color: var(--color-bg-soft);
  color: var(--color-accent-dark);
}
#search_widget form input {
    width: 100%;
    padding: 10px 15px;
    outline: none;
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--header-pill-radius);
}
button, input, optgroup, select, textarea {
    font-family: inherit;
    font-size: 0.825rem;
    line-height: inherit;
    margin: 0;
}

.form-control,
.modal.product-comment-modal .form-control,
.modal.product-comment-modal textarea, .form-select {
  background-color: var(--color-surface);
}

.header-top__left, .header-top__right {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    font-size: 0.825rem
}
.search-widgets__dropdown {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
    border-radius: var(--bs-border-radius-sm);
    box-shadow: 0 4px 8px rgba(0, 0, 0, .1);
    max-width: 30rem;
    overflow: hidden;
    position: absolute;
    right: 0;
    top: calc(100% + 1.5rem);
    width: 100vw;
}
@media only screen and (min-width: 767px) {
    #search_widget {
        min-width: 33rem;
    }
}
.section-title, .h2, h2, h3, .h3,
.page-product .product__infos .accordion-button
{
    font-size: calc(1rem + .3vw);
    font-weight: 700;
    margin: 1.5rem 0;
}

.main-menu__tree>li>a {
    outline-offset: -.5rem;
    padding: 1rem 0.5rem;
  text-decoration: none;
}

.main-menu__tree a:hover,
.main-menu__tree a:focus {
  text-decoration: none;
}
.header-top .form-select {
    text-transform: uppercase !important;
    font-size: 0.825rem;
}
.btn.btn-outline-primary,
.btn.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-border-color: #222;
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: color-mix(in srgb, #222 70%, var(--color-accent) 30%);
    --bs-btn-hover-border-color: color-mix(in srgb, #222 58%, var(--color-accent) 42%);
    --bs-btn-focus-shadow-rgb: 13,110,253;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: color-mix(in srgb, #222 62%, var(--color-accent) 38%);
    --bs-btn-active-border-color: color-mix(in srgb, #222 50%, var(--color-accent) 50%);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0,0,0,.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: #222;
    --bs-btn-disabled-border-color: #222;
    --bs-gradient: none;
    --bs-btn-bg: #222;
}

.btn.btn-outline-primary:hover,
.btn.btn-primary:hover,
.btn.btn-outline-primary:focus,
.btn.btn-primary:focus {
  background-color: color-mix(in srgb, #222 70%, var(--color-accent) 30%);
  border-color: color-mix(in srgb, #222 58%, var(--color-accent) 42%);
  color: #fff;
}

.btn.btn-outline-primary:active,
.btn.btn-primary:active,
.btn.btn-outline-primary.active,
.btn.btn-primary.active,
.show > .btn.btn-outline-primary.dropdown-toggle,
.show > .btn.btn-primary.dropdown-toggle {
  background-color: color-mix(in srgb, #222 62%, var(--color-accent) 38%);
  border-color: color-mix(in srgb, #222 50%, var(--color-accent) 50%);
  color: #fff;
}

#zapModal,
#zapModal .modal-content,
#zapModal .modal-content * {
  font-size: 0.825rem;
}

#zapModal .modal-content,
#zapModal .modal-header,
#zapModal .card,
#zapModal form,
#zapModal #zapytajo_body,
#zapModal .row,
#zapModal .form-group,
#zapModal .form-check,
#zapModal .form-check-label,
#zapModal .products-section-title,
#zapModal .modal-footer {
  background-color: #fff;
}

#zapModal .form-group {
  margin-bottom: 0.75rem;
}

#zapModal .form-label {
  display: block;
  margin-bottom: 0.375rem;
  font-weight: 400;
  line-height: 1.3;
}

#zapModal .form-check {
  margin-top: 0.25rem;
}

#zapModal .form-check-label {
  line-height: 1.35;
}

#zapModal .modal-footer {
  gap: 0.5rem;
  padding-top: 0.75rem;
}

.accordion,
.accordion-item,
.accordion-header,
.accordion-button,
.accordion-collapse,
.accordion-body {
  background-color: var(--color-surface);
}
.breadcrumb__wrapper {
  margin-bottom: 1rem;
  background: var(--bs-gray-50);
}
.accordion-button:not(.collapsed) {
    background-color: var(--color-surface);
    box-shadow: inset 0 calc(var(--bs-accordion-border-width) * -1) 0 var(--bs-accordion-border-color);
    color: var(--bs-accordion-active-color);
}
.footer .footer__block__content-contact a, .footer .footer__block__content-contact .material-icons {
    color: var(--footer-text-color);
    font-size: 0.825rem;
}
.footer .footer__main {
background: #000000;
padding-bottom: 1.25rem;
padding-top: 2.5rem;
}
.platnosci {
  margin: auto;
  display: -webkit-box;
}
.footer a,
.footer a:visited,
.footer a:hover,
.footer a:focus, 
.footer .email-subscription__content.row .btn {
  color: #fff !important;
  text-decoration: none !important;
}

.footer .email-subscription__content.row a,
.footer .email-subscription__content.row a:visited,
.footer .email-subscription__content.row a:hover,
.footer .email-subscription__content.row a:focus {
  color: #000 !important;
}

.footer__main--checkout-only {
  background: var(--color-bg-main);
  border-top: 1px solid var(--color-border);
}

.footer__main--checkout-only .copyright {
  margin: 0;
  padding: 0.85rem 0;
  text-align: center;
}

.footer__main--checkout-only .copyright a {
  color: var(--color-text-secondary);
  text-decoration: none;
}

.footer__main--checkout-only .copyright a:hover,
.footer__main--checkout-only .copyright a:focus {
  color: var(--color-accent-dark);
  text-decoration: underline;
}

.search-result__name, .search-result__price {
color: var(--color-text-main);
font-size: 0.825rem;
margin-bottom: 0;
margin-left: 0.825rem;
}

#notifications .cart-contains-notice {
  margin: 0 0 1rem;
  padding: 0;
  color: var(--color-text-main);
}

#notifications .cart-contains-notice .cart-contains-link {
  text-decoration: underline;
}

/* Sidebar categories + faceted filters: refined Europasaz look */
#left-column .block-categories,
#left-column #search_filters,
#left-column #search_filters_wrapper,
#left-column .search-filters,
#left-column .ps_categorytree.left-block,
#left-column .category-tree.left-block {
  background-color: #fff;
  border: 1px solid var(--color-border);
  border-radius: 0.75rem;
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.04);
  margin-bottom: 1rem;
  overflow: hidden;
}

.ps_categorytree.left-block,
.category-tree.left-block,
#search_filters_wrapper,
#search_filters {
  background-color: #fff;
}

#search_filters .accordion,
#search_filters .accordion-item,
#search_filters .facet,
#search_filters .accordion-button,
#search_filters .accordion-button:not(.collapsed),
#search_filters .accordion-body,
.search-filters .accordion,
.search-filters .accordion-item,
.search-filters .facet,
.search-filters .accordion-button,
.search-filters .accordion-button:not(.collapsed),
.search-filters .accordion-body {
  background-color: var(--color-surface) !important;
}

#search_filters .search-filters-title,
.search-filters .search-filters-title {
  display: block !important;
  width: 100%;
  margin: 0;
  padding: 0.9rem 1rem 0.8rem;
  border-bottom: 1px solid color-mix(in srgb, var(--color-border) 75%, #fff 25%) !important;
  background: #fff;
  color: var(--color-text-main);
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

#left-column .block-categories .h6,
#left-column .search-filters-title,
#left-column .search-filters > h4,
#left-column #search_filters > h4,
#left-column .ps_categorytree .left-block__title,
#left-column .category-tree .left-block__title {
  margin: 0;
  padding: 0.9rem 1rem 0.8rem;
  border-bottom: 1px solid color-mix(in srgb, var(--color-border) 75%, #fff 25%);
  background: #fff;
  color: var(--color-text-main);
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

#left-column .ps_categorytree .left-block__title__link,
#left-column .category-tree .left-block__title__link {
  color: var(--color-text-main);
}

#left-column .ps_categorytree .accordion--category,
#left-column .category-tree .accordion--category {
  margin: 0;
  padding: 0.2rem 1rem 0.85rem;
  background: var(--color-surface);
}

#left-column #search_filters .accordion,
#left-column .search-filters .accordion {
  padding: 0 0.75rem;
}

#left-column #search_filters .facet,
#left-column .search-filters .facet {
  margin: 0;
  padding: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--color-border) 68%, #fff 32%);
}

#left-column #search_filters .facet:last-child,
#left-column .search-filters .facet:last-child {
  border-bottom: 0;
}

#left-column .facet .facet-title {
  display: block;
  margin: 0;
}

#left-column .facet .accordion-button {
  padding: 0.88rem 0.25rem;
  background: var(--color-surface);
  box-shadow: none;
  color: var(--color-text-main);
  font-size: 1rem;
  font-weight: 400;
}

#left-column .facet .accordion-button:not(.collapsed) {
  color: var(--color-text-main);
  background: var(--color-surface);
}

#left-column .facet .accordion-button::after {
  opacity: 0.8;
}

#left-column .facet .accordion-body {
  padding: 0 0.25rem 0.75rem;
}

#left-column #search_filters .facet + hr,
#left-column .search-filters .facet + hr {
  display: none;
}

#left-column .facet .facet-label {
  margin: 0.15rem 0;
}

#left-column .facet .form-check {
  margin: 0;
}

#left-column .facet .form-check-input {
  border-color: color-mix(in srgb, var(--color-border) 85%, #000 15%);
}

#left-column .category-top-menu,
#left-column .block-categories .category-sub-menu {
  padding: 0.75rem 1rem 0.9rem;
}

#left-column .category-top-menu li,
#left-column .facet label,
#left-column .facet a {
  font-size: 0.875rem;
  line-height: 1.45;
}

#left-column .category-tree__mobile-toggle {
  padding: 0 1rem 0.9rem;
}

@media (max-width: 991.98px) {
  #left-column #category-tree-mobile-more {
    display: none;
  }

  #left-column #category-tree-mobile-more.show {
    display: block;
  }
}

#left-column .category-tree__toggle-btn[aria-expanded="true"] .category-tree__toggle-label-more {
  display: none;
}

#left-column .category-tree__toggle-btn[aria-expanded="true"] .category-tree__toggle-label-less {
  display: inline !important;
}

#left-column .category-tree__toggle-btn[aria-expanded="false"] .category-tree__toggle-label-less {
  display: none !important;
}

/* Unified typography for sidebar category/filter headings and lists */
#left-column .ps_categorytree .left-block__title,
#left-column .category-tree .left-block__title,
#left-column .search-filters-title,
#left-column #search_filters .facet .accordion-button,
#left-column .category-tree__item__link,
#left-column .facet label,
#left-column .facet a,
#left-column .facet .search-filters-link {
  font-family: var(--bs-body-font-family);
}
.breadcrumb a {
    color: var(--color-text-secondary);
    font-size: 0.825rem
}

body#cart .breadcrumb,
body#checkout .breadcrumb,
.page-cart .breadcrumb,
.page-order .breadcrumb,
.page-checkout .breadcrumb {
  display: none;
}

body#cart,
body#checkout,
body#order-confirmation {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

body#cart #header,
body#checkout #header,
body#order-confirmation #header,
body#cart #footer,
body#checkout #footer,
body#order-confirmation #footer {
  flex-shrink: 0;
}

body#cart #wrapper,
body#checkout #wrapper,
body#order-confirmation #wrapper {
  flex: 1 0 auto;
}

body#cart #footer,
body#checkout #footer,
body#order-confirmation #footer {
  margin-top: auto;
}

.eurobox-item__icon {
  width: 64px;
  height: 64px;
  line-height: 1;
}

.eurobox-item__icon img {
  max-width: 34px;
  max-height: 34px;
  width: auto;
  height: auto;
  display: block;
  margin: 0 auto;
}

.eurobox-item__icon .material-icons {
  font-size: 28px;
  line-height: 1;
  color: var(--color-text-secondary);
}

.eurobox-quickentries__heading {
  gap: 0;
}

.eurobox-quickentries__top {
  min-height: 16px;
  flex-shrink: 0;
}

.eurobox-quickentries__top .swiper-button-custom {
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
  color: var(--color-text-secondary);
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.eurobox-quickentries__top .swiper-button-custom::after {
  display: none;
}

.eurobox-quickentries__top .swiper-button-custom .material-icons {
  font-size: 16px;
  line-height: 1;
}

.eurobox-quickentries__top .swiper-button-custom.swiper-button-disabled {
  opacity: 0.35;
  pointer-events: none;
}
.eurobox-quickentries p {
    margin-bottom: 0;
}

.manufacturerContainer {
  padding: 0 0 25px;
  overflow: hidden;
  clear: both;
}

.manufacturerContainer__heading {
  gap: 0;
  justify-content: space-between;
}

.manufacturerContainer__heading .section-title {
  margin-bottom: 0;
}

.manufacturerContainer__nav {
  flex-shrink: 0;
}

.manufacturerContainer__nav .swiper-button-custom {
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
  color: var(--color-text-secondary, var(--bs-secondary-color));
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.manufacturerContainer__nav .swiper-button-custom::after {
  display: none;
}

.manufacturerContainer__nav .swiper-button-custom .material-icons {
  font-size: 16px;
  line-height: 1;
}

.manufacturerContainer__nav .swiper-button-custom.swiper-button-disabled {
  opacity: 0.35;
  pointer-events: none;
}

.manufacturerContainer p {
  margin-bottom: 0;
}

.manufacturerContainer .swiper {
  overflow: hidden;
}

.manufacturerContainer .swiper-slide {
  height: auto;
}

.manufacturerItem a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 80px;
  padding: 10px 12px;
  background: #fff;
  border: 1px solid var(--bs-border-color, #dee2e6);
  border-radius: var(--bs-border-radius, 8px);
  box-shadow: var(--bs-box-shadow-sm, 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075));
}

.manufacturerItem a img {
  max-width: 100%;
  max-height: 80px;
  width: auto;
  height: auto;
  display: block;
}

.brands-grid {
  list-style: none;
  margin-left: 0;
  margin-right: 0;
  padding-left: 0;
}

.brands-grid .brand.card {
  background: transparent;
  border: 0;
  box-shadow: none;
  margin-bottom: 1.5rem;
  padding: 0 0.5rem;
}

.brands-grid .brand .brand__img a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 80px;
  padding: 10px 12px;
  background: #fff;
  border: 1px solid var(--bs-border-color, #dee2e6);
  border-radius: var(--bs-border-radius, 8px);
  box-shadow: var(--bs-box-shadow-sm, 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075));
}

.brands-grid .brand .brand__img img {
  max-width: 100%;
  max-height: 80px;
  width: auto;
  height: auto;
  display: block;
  margin: 0;
}

.brands-grid .brand .brand__infos {
  margin-top: 0.75rem;
}
.has-discount {
  color: #f00;
}
#custom-text p {
  margin-bottom: 0.5rem;
}
#custom-text .card {
  border-radius: var(--bs-border-radius-lg);
background-color: #fff;
transition: 0.25s ease-out;
}
#custom-text .btn {
  margin-top: 1.5rem;
}
#gdpr_consent {
  font-size: 0.825rem;
}
.email-subscription .email-subscription__content {
margin: auto;
max-width: 100%;
}
.email-subscription .email-subscription__label {
color: var(--color-text-main, #101010);
font-size: 1rem;
line-height: 1.25rem;
}
.email-subscription .h2 {
    font-size: 1.5rem;
    color: var(--color-text-main, #101010);
}
.email-subscription .h3 {
font-size: 1.2rem;
  color: var(--color-text-main, #101010);
  margin: 1.5rem 0;
} 
.table-wrapper {
background: transparent;
border-radius: .5rem;
padding: 0 1rem;
}
.subcategory__name {
  margin: auto;
  font-size: 0.825rem;
  font-weight:600;
}
.sr-only {
clip: rect(0,0,0,0);
border: 0;
height: 1px;
margin: -1px;
overflow: hidden;
padding: 0;
position: absolute;
white-space: nowrap;
width: 1px;
}
#subcategories .subcategory {
min-height: 55px;
background-clip: border-box;
background-color: #fff;
border: 2px solid #F8F5EF;
}
.subcategories__navigation .swiper-button-custom {
  width: auto;
  height: auto;
  margin: 0;
  padding: 0;
  color: var(--color-text-secondary, var(--bs-secondary-color));
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  position: static;
  inset: auto;
  transform: none;
  min-width: 0;
  line-height: 1;
}

.subcategories__navigation .swiper-button-custom::after {
  display: none;
}

.subcategories__navigation .swiper-button-custom .material-icons {
  font-size: 14px;
  line-height: 1;
  width: auto;
  height: auto;
}

.subcategories__navigation {
  gap: 0.35rem;
}

.subcategories__navigation .swiper-button-custom.swiper-button-disabled {
  opacity: 0.35;
  pointer-events: none;
}

/* CLS fix: pre-style subcategory swiper slides przed inicjalizacją Swiper.js
   Dopasowane do konfiguracji: slidesPerView 2/3/4, spaceBetween: 12px
   Zapobiega przeskokowi layoutu gdy JS ustawia te same wartości */
.subcategories__slider.swiper-wrapper {
  flex-wrap: nowrap;
}
.subcategories__slider .swiper-slide {
  flex-shrink: 0;
  /* breakpoint 320: 2 slajdy, odstęp 12px → 6px na slajd */
  width: calc(50% - 6px);
}
@media (min-width: 992px) {
  .subcategories__slider .swiper-slide {
    /* breakpoint 992: 3 slajdy, odstęp 12px × 2 = 24px → 8px na slajd */
    width: calc(33.333% - 8px);
  }
}
@media (min-width: 1200px) {
  .subcategories__slider .swiper-slide {
    /* breakpoint 1200: 4 slajdy, odstęp 12px × 3 = 36px → 9px na slajd */
    width: calc(25% - 9px);
  }
}
.main-menu__tree>li .menu-container a[data-depth="1"] {
color: var(--color-text-main);
font-weight: 400;
}

.main-menu__tree .menu-container a,
.main-menu__tree .menu-container a:hover,
.main-menu__tree .menu-container a:focus {
  text-decoration: none;
}
#product .ocenyhead .material-icons {
font-size: 18px;
line-height: 22px;
}
.green {
color: var(--color-text-main);
}
.page-product .product__add-to-cart {
margin-bottom: 1rem;
}
.btn-primary .material-icons { 
  color: #fff;
}
.material-icons {
color: var(--color-text-main);
font-size: 1rem;
}
.btn-with-icon .material-icons {
  color: #fff;
}
.product-customization__item {
  background-color: #fff;
}
.product__details, .product__features{
background: #fff;
}
.product__details li:nth-child(odd) {
background: #f6f7f8;
}
.product__details li {
padding: 8px 20px;
width: 100%;
font-size: .825rem;
}
.product__details .detail__left {
width: 33%;
display: inline-block;
color: #070707;
text-align: right;
margin-right: 10px;
}
.page-product .product__name {
  margin-bottom: 1rem;
}
#zapytajoAccordion .accordion-header{
margin: 1rem auto;
}

#navbar-top {
  box-shadow: 0 2px 4px rgba(44, 44, 44, 0.05), 0 2px 8px rgba(44, 44, 44, 0.1);
  z-index: 999;
}

#navbar-top.shows {
  position: fixed;
  top: var(--product-sticky-top, 0px);
  left: 0;
  right: 0;
  width: 100%;
  background: var(--color-bg-soft);
  z-index: 99;
}

#navbar-product .nav-link {
  border: 1px solid transparent;
  border-radius: 0;
  transition: background-color .2s ease, border-color .2s ease, color .2s ease;
}

#navbar-product .nav-link.active,
#navbar-product .nav-link.active:hover,
#navbar-product .nav-link.active:focus {
  color: #fff;
  background-color: var(--bs-btn-bg, #222);
  border-color: var(--bs-btn-border-color, #222);
}

@media (max-width: 991.98px) {
  .page-product {
    padding-bottom: 6rem;
  }

  #product-mobile-bar {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1030;
    background: var(--color-surface, #fff);
    border-top: 1px solid var(--color-border, #e2dacf);
    box-shadow: 0 -2px 10px rgba(16, 16, 16, 0.08);
    transform: translateY(110%);
    opacity: 0;
    pointer-events: none;
    transition: transform .22s ease, opacity .22s ease;
  }

  #product-mobile-bar.is-visible {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }

  #product-mobile-bar .container {
    max-width: 100%;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: calc(.5rem + env(safe-area-inset-bottom, 0px));
  }

  .product-mobile-bar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    padding: .625rem .75rem .5rem;
  }

  .product-mobile-bar__price {
    font-weight: 700;
    font-size: 1.05rem;
    line-height: 1.2;
    color: var(--color-text-main);
    white-space: nowrap;
  }

  .product-mobile-bar__price .price {
    font-size: inherit;
    margin: 0;
  }

  .product-mobile-bar__button {
    flex: 0 0 auto;
    min-width: 9rem;
    white-space: nowrap;
  }
}

#home-slider .home-slider__img {
  width: 100%;
  height: auto;
  display: block;
}

body#index #home-slider .home-slider__swiper,
body#index #home-slider .home-slider__swiper .swiper-wrapper,
body#index #home-slider .home-slider__swiper .swiper-slide {
  height: auto !important;
}

body#index #home-slider .home-slider__swiper.swiper-autoheight,
body#index #home-slider .home-slider__swiper.swiper-autoheight .swiper-wrapper,
body#index #home-slider .home-slider__swiper.swiper-autoheight .swiper-slide {
  height: auto !important;
}

body#index #home-slider .home-slider__swiper .swiper-slide {
  display: block;
}

body#index #home-slider .home-slider__img {
  height: auto !important;
  aspect-ratio: auto !important;
}

body#index #home-slider .ratio {
  position: static;
}

body#index #home-slider .ratio::before {
  display: none;
}

body#index #home-slider .ratio > * {
  position: static;
  width: 100%;
  height: auto;
}

body#index #home-slider {
  margin-top: 0;
  padding-top: 0 !important;
}

#home-slider .home-slider__figure {
  margin: 0;
  padding: 0;
  line-height: 0;
}

#home-slider .home-slider__link {
  display: block;
  text-decoration: none;
}

#home-slider .home-slider__pagination {
  bottom: 0.5rem;
}

#home-slider .swiper-button-custom {
  width: 2.5rem;
  height: 2.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
  background: rgba(255, 255, 255, 0.85);
  border: 0;
  border-radius: 50%;
  box-shadow: 0 1px 4px rgba(0,0,0,0.15);
  color: #333;
  cursor: pointer;
  transition: background 0.2s ease;
}

#home-slider .swiper-button-custom:hover {
  background: rgba(255, 255, 255, 1);
}

#home-slider .swiper-button-custom::after {
  display: none;
}

#home-slider .swiper-button-custom .material-icons {
  font-size: 1.5rem;
  line-height: 1;
  width: auto;
  height: auto;
}

#home-slider .swiper-button-custom.swiper-button-disabled {
  opacity: 0.35;
  pointer-events: none;
}
#product  .custom-checkbox input[type=checkbox]+span.color.active,#product .custom-checkbox input[type=checkbox]+span.color:hover, #product .variant-links .color.active, #product .variant-links .color:hover, #product label .color.active, #product label .color:hover {
border: 2px solid #f00 !important;

}
#product .product__col .custom-checkbox input[type=checkbox]+span.color,#product .product__col .variant-links .color,#product .product__col label .color {
width: 3rem;
height: 3rem;
border: 2px solid #222;
}

/* CMS pages - adapted from style to current BS5 theme structure */
body#cms .page-header h1 {
  font-weight: 500;
  font-size: 1.45rem;
  padding-bottom: 0.8rem;
  margin-bottom: 0;
}

body#cms .page-content.page-cms {
  min-height: 170px;
  border: 1px solid #eee;
  padding: 1.5rem;
  color: #070707;
  position: relative;
  overflow: hidden;
  border-radius: 0.375rem;
  box-shadow: -1px 0 25px 1px rgba(0, 0, 0, 0.06);
  background: #fff;
}

@media (min-width: 768px) {
  body#cms .page-content.page-cms {
    min-height: 300px;
  }
}

/* FAQ target look (ported from Koala, adapted to BS5) */
body#cms.page-cms-16 .page-content.page-cms {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}

body#cms.page-cms-16 .cms-box {
  background: #fff;
  border: 1px solid #e6e6e6;
  border-radius: 0.25rem;
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.04);
  min-height: 250px;
  padding: 1.5rem 1rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

body#cms.page-cms-16 .virtual_cat_img {
  width: 40px;
  height: 35px;
  margin: 0 auto 0.75rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='35' viewBox='0 0 40 35'%3E%3Ctext x='20' y='25' text-anchor='middle' font-size='30' font-family='Arial' fill='%23101010'%3E%3F%3C/text%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 26px;
}

body#cms.page-cms-16 .image_title,
body#cms.page-cms-16 .image_title a {
  color: #475467;
  font-weight: 500;
}

body#cms.page-cms-16 .cms-box-wrap > a:hover .image_title,
body#cms.page-cms-16 .image_title a:hover {
  text-decoration: underline;
}

body#cms.page-cms-16 p a,
body#cms.page-cms-16 ul a {
  color: #dc0612;
}
.blockcart-modal .modal-content.small {
  font-size: 0.825rem;
}

.blockcart-modal .modal-content.small .modal-title,
.blockcart-modal .modal-content.small .h4 {
  font-size: 0.825rem;
  line-height: 1.35;
}

.blockcart-modal .modal-content.small .modal-title .material-icons {
  font-size: 1rem;
}
#cms .cms-content {
min-height: 170px;
border: 1px solid #eee;
padding: 26px;
color: #070707;
position: relative;
overflow: hidden;
border-radius: 3px;
box-shadow: -1px 0 25px 1px rgba(0,0,0,.06);
}

/* Contact page layout with Zapytaj module hook */
body#contact .contact-page-layout .card {
  border: 1px solid #e7e9ec;
  border-radius: 0.375rem;
  box-shadow: 0 6px 24px rgba(16, 24, 40, 0.06);
  background: #fff;
}

body#contact .card-welcome {
  border: 0;
  padding: 1rem 1.25rem;
}

body#contact .card-infos .h4 {
  border-bottom: 1px solid #dbdbdb;
  font-size: 1.15rem;
  padding-bottom: 0.75rem;
  font-weight: 700;
  gap: 0.75rem;
}

body#contact .card-infos .h4 .material-icons {
  background-color: #7f6868;
  color: #fff;
  border-radius: 4px;
  text-align: center;
  font-size: 22px;
  width: 40px;
  height: 41px;
  line-height: 40px;
  flex: 0 0 40px;
}

body#contact .contact-form .form-style {
  border: 1px solid #e7e9ec;
  border-radius: 0.375rem;
  box-shadow: 0 6px 24px rgba(16, 24, 40, 0.06);
  background: #fff;
  padding: 1.25rem;
}

body#contact .contact-form .form-style .row {
  --bs-gutter-y: 1rem;
}

body#contact .contact-form .form-style .form-label {
  font-size: 0.875rem;
  font-weight: 600;
  margin-bottom: 0.4rem;
}

body#contact .contact-form .form-style .form-control,
body#contact .contact-form .form-style .form-select {
  border-color: #d0d5dd;
  min-height: 2.5rem;
  font-size: 0.875rem;
}

body#contact .contact-form .form-style textarea.form-control {
  min-height: 7.5rem;
}

body#contact .contact-form .form-style .form-check {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  margin-top: 0.25rem;
}

body#contact .contact-form .form-style .form-check-input {
  margin-top: 0.2rem;
}

body#contact .contact-form .form-style .form-check-label {
  font-size: 0.8125rem;
  line-height: 1.45;
}

body#contact .contact-form .form-style #qsubmit_btn {
  min-width: 9.5rem;
}

body#contact .contact-form .form-style .required {
  color: #dc0612;
}

@media (max-width: 767.98px) {
  body#contact .card-welcome {
    padding: 0.75rem 1rem;
  }

  body#contact .contact-form .form-style {
    padding: 1rem;
  }

  body#contact .contact-form .form-style #qsubmit_btn {
    width: 100%;
    min-width: 0;
  }
}
.page-product .product__description-short, .page-product .product__description, 
#js-product-list-footer, #category-description, #index .opisy,
#manufacturer-description, #manufacturer-short_description {
margin-bottom: 0.5rem;
text-align: justify;  
}
.page-product .product__variants .variant .color-variants,
.page-product .product__variants .variant .radio-variants {
  list-style: none;
  padding-left: 0;
}
/* category-description read-more */
.category-description__inner.category-description--collapsed {
  max-height: calc(1.6em * 5);
  overflow: hidden;
  position: relative;
}
.category-description__inner.category-description--collapsed::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2.5em;
  background: linear-gradient(transparent, #fff);
}
.category-description__toggle {
  font-size: .875rem;
  text-decoration: underline;
}
.rich-text .h3, .rich-text h3, .rich-text .h2, .rich-text h2  {
  font-size: 1.25rem;
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}
.pavailable {
  color: green;
  margin-top: 0.5rem;
}
.custom-checkbox input[type=checkbox]+span.color.active, .custom-checkbox input[type=checkbox]+span.color:hover, .variant-links .color.active, .variant-links .color:hover, label .color.active, label .color:hover {
border: 2px solid #f00;
}
.product-actions__button .add-to-cart{
 background-color: #2E7D32;
  color: #ffffff;

}
.product-actions__button .add-to-cart:hover{
 background-color: #256E2A;
}
.product-actions__button .add-to-cart:focus{
   background-color: #2E7D32;
  outline: 2px solid #111111;
  outline-offset: 2px;
}