:root {
  --font-title: "Inter";
  --font-text: "Poppins";

  --color-primary: #e8b21c;
  --color-secondary: #111111;

  --color-white: #ffffff;
  --color-black: #111111;

  --color-red: #ec5523;
  --color-grey: #c9c9c9;
  --color-darkgrey: #888888;
  --color-grey-border: #dddddd;
  --color-orange: #a57e14;

  --font-xs: 11px;
  --font-sm: 13px;
  --font-md: 15px;

  --spaces-xs: 5px;
  --spaces-sm: 10px;
  --spaces-md: 20px;

  --separator-sections: 60px;
  --separator-sections-lg: 100px;

  --width-container: 1600px;
}

/* ---------------------- GENERAL ----------------------- */
main {
  position: relative;
}

#wrapper {
  padding: 0;
}

/* Buttons */
.btn {
  font-size: var(--font-md) !important;
  font-family: var(--font-text) !important;
  text-transform: uppercase !important;
  outline: none !important;
  transition: 0.3s !important;
  padding: 10px 20px;
}

.btn-primary {
  border: solid 1px var(--color-primary) !important;
  background-color: var(--color-primary) !important;
  color: var(--color-black) !important;
}

.btn-primary:hover {
  background-color: var(--color-secondary) !important;
  border-color: var(--color-secondary) !important;
  color: var(--color-white) !important;
}

.btn-secondary {
  border: solid 1px var(--color-secondary) !important;
  background-color: var(--color-secondary) !important;
  color: var(--color-white) !important;
}

.btn-secondary:hover {
  background-color: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
}

.btn-tertiary {
  border: solid 1px var(--color-black) !important;
  background-color: var(--color-white) !important;
  color: var(--color-black) !important;
}

.btn-tertiary:hover {
  background-color: var(--color-primary) !important;
  border-color: var(--color-secondary) !important;
  color: var(--color-white) !important;
}

/* Scroll */
::-webkit-scrollbar {
  width: 7px;
}

::-webkit-scrollbar-thumb {
  background-color: var(--color-primary);
}

/* Breadcrumb */
.breadcrumb {
  margin: var(--spaces-md) 0 !important;
}

#category .breadcrumb,
#contact .breadcrumb,
#cms:has(.block-cms) .breadcrumb {
  margin: 0 !important;
  padding: 0 var(--spaces-md) !important;
}

.breadcrumb *,
.breadcrumb *::after {
  font-size: var(--font-sm) !important;
  line-height: normal !important;
  color: #728282 !important;
}

#category .breadcrumb *,
#category .breadcrumb *::after,
#contact .breadcrumb *,
#contact .breadcrumb *::after,
#cms:has(.block-cms) .breadcrumb *,
#cms:has(.block-cms) .breadcrumb *::after {
  color: var(--color-white) !important;
}

.breadcrumb ol {
  overflow-x: auto;
}

.breadcrumb ol::-webkit-scrollbar {
  height: 2px;
}

.breadcrumb ol li > a span {
  transition: 0.3s;
}

.breadcrumb ol li > a:hover span {
  color: var(--color-primary) !important;
}

#category .breadcrumb ol li > a:hover span,
#contact .breadcrumb ol li > a:hover span,
#cms:has(.block-cms) .breadcrumb ol li > a:hover span {
  text-decoration: underline;
}

.breadcrumb ol li > span {
  color: var(--color-black) !important;
  text-transform: uppercase;
}

/* Carrusel Slick */
.slick-list .slick-track {
  margin-left: 0 !important;
}

/* Arrows */
.slick-arrow {
  width: fit-content;
  position: absolute;
  top: 50%;
  right: -15px;
  cursor: pointer;
  transform: translateY(-50%);
  z-index: 9;
}

.slick-arrow img {
  padding: 10px;
  border: solid 1px var(--color-black);
  background-color: var(--color-white);
  transition: 0.3s;
}

.slick-arrow img:hover {
  background-color: var(--color-primary);
}

.slick-arrow.slick-prev {
  left: -15px;
}

/* Dots */
.slick-dots {
  margin: 0;
  width: 100%;
  position: absolute;
  bottom: -25px;
  gap: 5px;
  display: none;
  justify-content: center;
}

.slick-dots:has(li:not(.slick-active)) {
  display: flex;
}

.slick-dots li {
  height: 20px;
  display: flex;
  align-items: center;
  border: solid 1px transparent;
}

.slick-dots li button {
  width: 30px !important;
  height: 4px !important;
  font-size: 0;
  border: none;
  background-color: #babbba;
  outline: none;
  cursor: pointer;
}

.slick-dots li.slick-active button {
  background-color: var(--color-primary);
}

/* Miniatura producto */
.product-miniature,
#product .product-miniature.accessory {
  margin: 0 3px 10px 3px !important;
  border: solid 1px var(--color-grey-border);
}

#index .product-miniature,
#product .product-miniature {
  margin-bottom: 0 !important;
}

.product-miniature > div {
  margin: 0 !important;
}

.product-miniature.accessory > div {
  display: flex;
}

.product-miniature.accessory > div > a {
  height: -webkit-fill-available !important;
}

.product-miniature img {
  padding: var(--spaces-sm);
  height: 100% !important;
  object-fit: contain;
  filter: brightness(0.93);
  background-color: var(--color-white);
}

.product-miniature .product-description {
  padding: 0 !important;
  align-items: center;
  display: flex;
  flex-direction: column;
}

.product-miniature.accessory .product-description {
  padding: 5px 0 !important;
  align-items: flex-start;
  justify-content: center;
}

.product-miniature .product-description .product-title {
  margin-bottom: 0 !important;
  padding: 0 var(--spaces-sm) !important;
  height: auto !important;
  text-align: center !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  font-size: var(--font-md) !important;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  text-overflow: ellipsis;
  overflow: hidden;
  transition: 0.3s;
}

.product-miniature.accessory .product-description .product-title {
  margin: 0;
  text-align: start !important;
}

.product-miniature .product-description .product-price-and-shipping {
  margin-top: var(--spaces-sm);
  padding: 0 var(--spaces-sm);
  line-height: normal !important;
  min-height: 19px !important;
  justify-content: center !important;
}

.product-miniature .product-description .product-price-and-shipping .range {
  display: flex;
}

.product-miniature .product-description .product-price-and-shipping .range span:not(.price) {
  margin: 0 var(--spaces-xs);
  font-family: var(--font-title);
  font-size: var(--font-md);
  color: var(--color-orange);
}

.product-miniature .product-description .product-price-and-shipping .range.discount > span {
  color: var(--color-red);
}

.product-miniature .product-description .product-price-and-shipping .price {
  color: var(--color-orange);
  font-size: var(--font-md);
  font-family: var(--font-title);
}

.product-miniature .product-description .product-price-and-shipping .prices_flex {
  flex-direction: row !important;
  align-items: center;
  gap: 10px;
}

.product-miniature .product-description .product-price-and-shipping .prices_flex .price {
  color: var(--color-red);
}

.product-miniature .product-description .product-price-and-shipping .prices_flex .regular-price {
  font-size: var(--font-md) !important;
  font-family: var(--font-title);
  text-decoration: line-through;
  color: var(--color-grey) !important;
  line-height: normal !important;
}

.product-miniature .product-description > form,
.product-miniature .product-description > .add {
  width: 100%;
}

.product-miniature.accessory .product-description > form,
.product-miniature.accessory .product-description > .add {
  margin-left: 10px;
  width: auto;
}

.product-miniature .product-description > form .block-product-attribute-custom {
  display: none;
}

.product-miniature.accessory .product-description .add button {
  padding: 0;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: solid 1px var(--color-primary) !important;
}

.product-miniature.accessory .product-description .add button:hover .fill {
  fill: var(--color-white);
}

.product-miniature.accessory .product-description .add button:hover .str {
  stroke: var(--color-white);
}

.product-miniature .wishlist-button-add {
  display: none;
}

/* Slick lightbox */
.slick-lightbox button {
  outline: none !important;
}

.slick-lightbox .slick-prev,
.slick-lightbox .slick-next {
  width: 60px;
  height: 60px;
}

.slick-lightbox .slick-next {
  right: 15px;
  left: unset;
}

.slick-lightbox .slick-prev {
  left: 15px;
}

.slick-lightbox .slick-lightbox-slick-img {
  background-color: var(--color-white);
  border-radius: var(--border-radius);
  filter: brightness(0.97);
}

.slick-lightbox .slick-prev:before {
  content: "arrow_back_ios";
}

.slick-lightbox .slick-next:before {
  content: "arrow_forward_ios";
}

.slick-lightbox .slick-prev:before,
.slick-lightbox .slick-next:before {
  font-family: "Material icons";
  font-size: 30px;
  color: var(--color-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-lightbox .slick-prev,
.slick-lightbox .slick-next {
  font-size: 0;
  top: 50%;
  padding: 0;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  border: none;
  background: transparent;
}

.slick-lightbox-close {
  height: 40px;
  width: 40px;
}

.slick-lightbox-close:hover {
  opacity: 0.6;
}

.slick-lightbox-close:before {
  font-family: "Material icons";
  font-size: 40px;
  opacity: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  content: "close";
}

/* Modal carrito */
#blockcart-modal .product-name .product-attributes .customized {
  font-weight: 500 !important;
}

/* ---------------------- HEADER ------------------------ */
#header,
#header > .headerCont {
  height: 180px;
}

#header.fixed > .headerCont {
  width: 100%;
  max-width: initial;
  position: fixed;
  top: 0;
  z-index: 999;
  animation: 1s ease 0s normal both 1 running fixedheader;
  background-color: var(--color-white);
}

@keyframes fixedheader {
  0% {
    top: -100%;
  }

  100% {
    top: 0;
  }
}

/* Topbar */
#header .topbar {
  background-color: var(--color-black);
}

#header .topbar .container {
  padding: var(--spaces-xs) 0;
  text-align: center;
}

#header .topbar .container span {
  color: var(--color-white);
  font-size: var(--font-md);
}

/* Menú móvil - Logo */
#header .header-top {
  padding: var(--spaces-sm) 0;
  border-bottom: solid 1px var(--color-grey-border);
}

#header .header-top .container > .header__flex {
  align-items: center;
  height: 60px;
}

#header .container .logoMenuCont {
  padding-left: 0;
  display: flex;
  align-items: center;
  gap: var(--spaces-md);
}

#header .container .logoMenuCont #menu-icon {
  cursor: pointer;
}

/* Buscador */
body > .searchbar-autocomplete {
  display: none !important;
}

#header .container #search_widget,
#header #search_widget_mobile {
  display: flex;
  justify-content: center;
}

#header .container #search_widget form {
  width: 70%;
}

#header .container #search_widget input[type="text"],
#header #search_widget_mobile input[type="text"] {
  height: 45px;
  padding-left: 50px !important;
  font-size: var(--font-md) !important;
  border: solid 2px var(--color-primary) !important;
  border-radius: unset !important;
  background-color: #f7f7f8 !important;
}

#header .container #search_widget svg,
#header #search_widget_mobile svg {
  width: 18px;
  height: auto;
  display: flex;
  position: absolute;
  left: 20px !important;
  right: auto !important;
  top: 50% !important;
  transform: translateY(-50%);
}

/* Buscador - Modal */
#content_search {
  padding: var(--spaces-md);
  height: 100dvh;
  margin-top: 0;
  top: 0;
  z-index: 9999;
  overflow: hidden;
}

#content_search .close_content_search {
  margin-bottom: var(--spaces-md);
  display: flex;
  justify-content: flex-end;
}

#content_search .close_content_search .close {
  outline: none;
  opacity: 1;
}

#content_search .close_content_search .close:hover {
  opacity: 0.5;
}

#content_search > form {
  margin-bottom: var(--spaces-md);
  position: relative;
}

#content_search > form > input[type="text"] {
  padding: var(--spaces-sm) var(--spaces-md);
  width: 100%;
  height: 45px;
  font-size: var(--font-md);
  outline: none;
  border: solid 2px var(--color-primary);
  background-color: #ebecec;
}

#content_search > form > button[type="submit"] {
  padding: 0;
  height: 44px;
  width: 60px;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  outline: none;
  border: none;
  background-color: var(--color-black);
  transition: 0.3s;
}

#content_search > form > button[type="submit"]:hover {
  background-color: var(--color-primary);
  cursor: pointer;
}

#content_search .allresult_searchbar .btn {
  margin-bottom: var(--spaces-md);
}

#content_search .result_searchbar {
  height: calc(100% - 180px);
  overflow-y: auto;
}

#content_search .result_searchbar #js-product-list .products {
  margin: 0;
  padding-right: var(--spaces-sm);
  gap: var(--spaces-sm);
}

#content_search .result_searchbar #js-product-list .products > div {
  margin: 0;
  width: calc(20% - 8px);
}

/* Iconos */
#header .container #iconosHeader {
  display: flex;
  justify-content: flex-end;
  padding-right: 0;
  gap: calc(var(--spaces-md) + var(--spaces-sm));
}

#header .container #iconosHeader a,
#header .container #iconosHeader .user {
  display: flex;
  align-items: center;
}

#header .container #iconosHeader a:hover *,
#header .container #iconosHeader svg:hover * {
  stroke: var(--color-primary);
  cursor: pointer;
}

#header .container #iconosHeader a:hover *.fill {
  fill: var(--color-primary);
  stroke: none;
}

#header .container #_desktop_cart {
  position: relative;
}

#header .container .hayProducts {
  width: 15px;
  height: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: -6px;
  right: -5px;
  font-size: 9px;
  border-radius: 50%;
  color: var(--color-white);
  background-color: var(--color-black);
}

/* Menú */
#header .header-bottom {
  border-bottom: solid 1px var(--color-grey-border);
}

#header .header-bottom .header__flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spaces-md) 0;
}

#header .header-bottom .header__flex #menu-horizontal {
  width: 100%;
}

#_desktop_megamenu .pos-menu-horizontal {
  max-width: none;
}

#_desktop_megamenu .menu-content {
  display: flex !important;
  margin: 0;
}

#_desktop_megamenu .menu-content .menu-item {
  padding: 0 !important;
  margin: 0 !important;
}

#_desktop_megamenu .menu-content .menu-item:nth-child(4) {
  margin-left: auto !important;
}

#_desktop_megamenu .menu-content .menu-item a {
  height: auto !important;
  line-height: normal !important;
  border: none !important;
}

#_desktop_megamenu .menu-content .menu-item a span {
  color: var(--color-black);
  text-transform: uppercase;
  font-size: var(--font-md);
  font-weight: 600;
  transition: 0.3s;
}

#_desktop_megamenu .menu-content .menu-item.open-modal {
  position: relative;
}

#_desktop_megamenu .menu-content .menu-item.open-modal:hover .menu-dropdown {
  opacity: 0;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > a {
  display: flex;
  align-items: center;
  gap: var(--spaces-xs);
  cursor: pointer;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > a span {
  color: var(--color-primary);
}

#_desktop_megamenu .menu-content .menu-item.open-modal > a img {
  width: 22px !important;
}

#_desktop_megamenu .menu-content .menu-item:not(.open-modal) {
  display: flex;
  align-items: center;
  justify-content: center;
}

#_desktop_megamenu .menu-content .menu-item:not(.open-modal) a {
  margin-left: var(--spaces-md);
}

#_desktop_megamenu .menu-content .menu-item.ofertas a span {
  color: var(--color-red);
  transition: 0.3s !important;
}

#_desktop_megamenu .menu-content .menu-item.ofertas a:hover span {
  text-decoration: underline;
}

#_desktop_megamenu .menu-content .menu-item:not(.open-modal, .ofertas) a:hover span {
  color: var(--color-primary);
}

/* Menú modal */
#menu_bg {
  width: 100%;
  height: calc(100% - 180px);
  display: none;
  position: absolute;
  background-color: #02154021;
  z-index: 99;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown {
  padding: var(--spaces-md) 0 0 0;
  width: calc(var(--width-container) / 3);
  max-width: calc(var(--width-container) / 3 - calc(40px / 3));
  transform: none !important;
  z-index: 99999;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .pos-sub-inner {
  padding: 0 !important;
  box-shadow: none;
  border-top: solid 1px var(--color-grey-border);
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .pos-sub-inner > .row {
  margin: 0;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .pos-sub-inner > .row > .pos-menu-col {
  padding: 0;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .pos-sub-inner > .row > .pos-menu-col > ul {
  padding: 0 var(--spaces-md);
  min-height: 600px;
  max-height: calc(100dvh - 400px);
  overflow-y: auto;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item {
  display: flex;
  align-items: center;
  margin: var(--spaces-md) 0 !important;
  cursor: pointer;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item:hover > div > *:not(div),
#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item:has(ul.visible) > div > span,
#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > li:hover > *:not(ul),
#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > li:has(ul.visible) > span {
  color: var(--color-primary);
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item:hover > svg *,
#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item:has(ul.visible) > svg *,
#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > li:hover > svg *,
#_desktop_megamenu.menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > li:has(ul.visible) > svg * {
  stroke: var(--color-primary);
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item a,
#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item span {
  font-size: var(--font-md);
  color: var(--color-black);
  transition: 0.3s;
  transform: none !important;
  text-transform: none;
  line-height: 26px !important;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item > svg *,
#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > li > svg * {
  transition: 0.3s;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item > div {
  width: 100%;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item > div,
#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > .header > div {
  display: flex;
  align-items: center;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item > div > a {
  width: 100%;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item > svg,
#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > li > svg {
  height: 15px;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu {
  margin: 0;
  width: calc(var(--width-container) / 3);
  max-width: calc(var(--width-container) / 3 - calc(40px / 3));
  height: calc(100% + 1px);
  position: absolute;
  left: 100%;
  top: -1px;
  display: none;
  flex-direction: column;
  background-color: var(--color-white);
  border-top: solid 1px var(--color-grey-border);
  border-left: solid 1px var(--color-grey-border);
  cursor: default;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu.submenu2 {
  height: calc(100% + 1px);
  top: -1px;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div {
  padding: var(--spaces-md) calc(var(--spaces-sm) + var(--spaces-xs));
  overflow-y: scroll;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > .header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--spaces-sm);
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > .header > div {
  gap: var(--spaces-sm);
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > .header > div > div {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 0.3s;
  cursor: pointer;
  border: none;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > .header > div > div svg * {
  transition: 0.3s;
}

#_desktop_megamenu
  .menu-content
  .menu-item.open-modal
  > .menu-dropdown
  .submenu-item
  .category-sub-menu
  > div
  > .header
  > div
  > div:hover
  svg
  * {
  stroke: var(--color-primary);
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > .header span {
  font-weight: 600;
  line-height: normal;
  cursor: default;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > .header a {
  color: var(--color-primary);
  font-size: var(--font-sm);
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > .header a:hover {
  color: var(--color-black);
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > li {
  margin: var(--spaces-md) 0 !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spaces-sm);
  cursor: pointer;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > li:last-child {
  margin-bottom: 0 !important;
}

#_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div > li > a {
  width: 100%;
  line-height: 26px !important;
}

/* Menú modal (móvil) */
body:has(#menu-modal.in) #menu_bg,
body:has(#menu-modal.in) #menu-icon .cross {
  display: flex !important;
}

body:has(#menu-modal.in) #menu-icon .hamburguer,
#header .container .logoMenuCont #menu-icon .cross {
  display: none;
}

#menu-modal {
  padding: 0 !important;
  overflow-y: hidden;
  display: none;
  z-index: 9999;
}

#menu-modal .modal-dialog {
  height: 100dvh;
  width: 420px;
  max-width: none;
  margin: 82px auto 0 0 !important;
}

#menu-modal .modal-content {
  height: calc(100dvh - 82px);
  border: none;
}

#menu-modal .modal-body {
  padding: 0;
}

#menu-modal .custom-modal-body {
  overflow-y: auto;
}

#menu-modal #modal-menu {
  height: calc(100dvh - 82px);
}

#menu-modal #modal-menu:has(.category-sub-menu.visible) {
  overflow: hidden;
}

#menu-modal #_desktop_megamenu .menu-content {
  height: calc(100dvh - 82px);
  flex-direction: column;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal {
  height: calc(100dvh - 338px); /* 338px -> Altura header + bottom menú */
  overflow-y: auto;
  overflow-x: clip;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal:has(.category-sub-menu.visible) {
  height: 100dvh;
  overflow-y: visible;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal > a {
  display: none;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown {
  padding: 0;
  height: fit-content;
  left: 0 !important;
  max-width: 100% !important;
  opacity: 1 !important;
  visibility: visible !important;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .pos-sub-inner {
  border: none;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .pos-menu-col {
  padding: var(--spaces-md) 0 0 0;
  height: auto;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .submenu-item:first-child {
  margin-top: 0 !important;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .submenu-item .category-sub-menu {
  height: calc(100dvh - 81px) !important;
  border: none;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .submenu-item .category-sub-menu.submenu2 {
  height: calc(100dvh - 80px) !important;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .submenu-item .category-sub-menu > div {
  padding: var(--spaces-md) var(--spaces-md) var(--spaces-sm) var(--spaces-md);
  height: auto !important;
}

#menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .submenu-item .category-sub-menu > div > .header > div {
  gap: var(--spaces-sm);
}

#menu-modal #_desktop_megamenu .menu-content li.ofertas {
  padding: var(--spaces-md) !important;
  justify-content: flex-start;
  background-color: var(--color-red);
  transition: 0.3s;
}

#menu-modal #_desktop_megamenu .menu-content li.ofertas a span {
  color: var(--color-white);
}

#menu-modal #_desktop_megamenu .menu-content li.menu-item:not(.open-modal) {
  height: auto;
  margin: 0 !important;
  padding: var(--spaces-md) !important;
  justify-content: flex-start;
  border-top: solid 1px var(--color-grey-border) !important;
}

#menu-modal #_desktop_megamenu .menu-content li.menu-item:not(.open-modal) a {
  width: 100%;
}

#menu-modal #_desktop_megamenu .menu-content li.menu-item:not(.open-modal) a span {
  text-transform: none;
  font-weight: 400;
}

#menu-modal #_desktop_megamenu .menu-content li a {
  margin: 0;
  padding: 0;
}

/* ---------------------- FOOTER ------------------------ */
.page-footer {
  margin: 0 !important;
}

#footer {
  margin-top: var(--separator-sections-lg);
}

#footer a:hover,
#footer a:hover > span {
  text-decoration: underline;
}

#footer .footer-container {
  padding: 60px 0 40px 0;
}

/* Logo - SEO */
#footer .footer-container .center .links:has(.logo_seo) {
  padding-right: 0;
  margin-right: 45px;
  width: calc(50% - 45px);
}

#footer .footer-container .center .logo_seo {
  display: flex;
  flex-direction: column;
  gap: var(--spaces-md);
  border-right: solid 1px var(--color-grey-border);
  padding-right: 60px;
  padding-bottom: 60px;
}

#footer .footer-container .center .logo_seo span {
  font-size: var(--font-md);
}

/* Links */
#footer .footer-container .center .links > .title,
#footer .footer-container .bottom .links > .title,
#footer .footer-container .center .links .title > span,
#footer .footer-container .bottom .links .title > span {
  font-weight: 600;
  text-transform: uppercase;
  color: var(--color-black);
  line-height: normal;
  display: flex;
  margin-bottom: var(--spaces-sm);
}

#footer .footer-container .center .links ul {
  margin: 0 !important;
}

#footer .footer-container .center .links ul li:not(:last-child) {
  margin-bottom: 10px;
}

/* Contacto - Métodos de pago */
#footer .footer-container .bottom .links:first-child {
  border-right: solid 1px var(--color-grey-border);
  padding-right: 60px;
  margin-right: 45px;
  width: calc(50% - 45px);
}

#footer .footer-container .bottom .links .contact {
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: var(--font-md);
}

#footer .footer-container .bottom .links .contact > a {
  display: flex;
  flex-direction: column;
  width: fit-content;
}

#footer .footer-container .bottom .links .payment {
  display: flex;
  gap: 10px;
}

/* Copyright - RRSS */
#footer .copyright .copyright_content {
  padding: 20px 0;
  flex-direction: row;
  border-top: solid 1px var(--color-grey-border);
}

#footer .copyright .text_copyright {
  margin: 0;
  width: auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  font-size: var(--font-md) !important;
  line-height: normal;
}

#footer .copyright .rrss {
  width: auto;
  display: flex;
  justify-content: flex-end;
  gap: var(--spaces-sm);
}

#footer .copyright .rrss a {
  display: flex;
}

#footer .copyright .rrss svg * {
  transition: 0.3s;
}

#footer .copyright .rrss svg rect {
  stroke: var(--color-black);
}

#footer .copyright .rrss svg:hover rect {
  fill: var(--color-white);
}

#footer .copyright .rrss svg:hover path {
  fill: var(--color-black);
}

/* ----------------------- HOME ------------------------- */
#index #wrapper > .container {
  width: 100%;
  padding: 0 !important;
}

#index #content > .block {
  margin-top: var(--separator-sections-lg);
}

#index .header .pretitle {
  margin-bottom: 0;
  color: var(--color-primary);
  text-transform: uppercase;
  text-align: center;
  font-size: var(--font-sm);
  font-weight: 500;
}

#index .header .title {
  margin: 0;
  color: var(--color-black);
  text-transform: uppercase;
  text-align: center;
  font-size: 45px;
  font-weight: 600;
  line-height: 1;
}

/* Carrusel */
#index #carousel {
  margin: 0;
}

#index #carousel .carousel-inner {
  margin: 0;
  min-height: 700px;
}

#index #carousel .carousel-inner img {
  height: 700px;
  object-fit: cover;
}

/* Reassurance */
#blockreassurancehome {
  padding: 0;
}

#blockreassurancehome > .container {
  display: flex;
  flex-wrap: wrap;
}

#blockreassurancehome .item {
  padding: 20px 40px 40px 40px;
  width: calc(100% / 3);
  display: flex;
  gap: var(--spaces-md);
  background-color: var(--color-black);
  border-right: solid 1px var(--color-white);
}

#blockreassurancehome .item:last-child {
  border: none;
}

#blockreassurancehome .item .icon svg {
  width: 40px;
  height: 40px;
}

#blockreassurancehome .item .text {
  text-align: left;
}

#blockreassurancehome .item .text span {
  font-weight: 600;
  font-size: var(--font-md);
  text-transform: uppercase;
}

#blockreassurancehome .item .text p {
  margin: 0;
  font-size: var(--font-md);
}

/* Texto SEO */
#custom-text {
  margin: -20px 0 0 0;
  position: relative;
}

#custom-text .cont {
  margin: 0 auto;
  padding: var(--spaces-sm) var(--spaces-md);
  max-width: 70%;
  background-color: var(--color-primary);
}

#custom-text .cont .title {
  margin: 0;
  font-weight: 600;
  font-size: var(--font-md);
  text-align: center;
  text-transform: uppercase;
  color: var(--color-black);
}

/* Categorías destacadas */
#index .homecategories .categories {
  margin: 40px -5px 0 -5px;
  display: flex;
  flex-wrap: wrap;
}

#index .homecategories .categories .category {
  padding: 0 5px;
}

#index .homecategories .categories .category a {
  display: flex;
  position: relative;
  overflow: hidden;
}

#index .homecategories .categories .category a:hover img {
  transform: scale(1.05);
}

#index .homecategories .categories .category a img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  transition: 0.3s;
}

#index .homecategories .categories .category a .shadow {
  width: 100%;
  height: 500px;
  position: absolute;
  background: linear-gradient(to bottom, transparent, rgba(0, 0, 0, 0.3));
}

#index .homecategories .categories .category a .info {
  padding: 30px;
  position: absolute;
  left: 0;
  bottom: 0;
}

#index .homecategories .categories .category a .info .cat-title {
  margin: 0 !important;
  font-size: 14px;
  text-transform: uppercase;
  color: var(--color-primary);
  font-weight: 600;
}

#index .homecategories .categories .category a .info .cat-subtitle {
  margin: 0 !important;
  font-size: 20px;
  color: var(--color-white);
  text-transform: uppercase;
  font-weight: 600;
  font-family: var(--font-title);
}

/* Carrusel productos de la categoría */
#index #categories-products .products {
  margin-top: 40px;
}

#index #categories-products .slide {
  width: 25%;
}

#index #categories-products .slick-not-init .slide:nth-child(n + 2) {
  display: none;
}

/* Categorías interactivas */
#index #interactive-categories .category .category-info .name {
  text-transform: uppercase;
  font-size: var(--font-md);
  font-weight: 600;
  line-height: normal;
}

#index #interactive-categories .category .category-info .description {
  font-size: var(--font-sm);
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

#index #interactive-categories .category .category-info > a {
  padding: 8px var(--spaces-sm);
}

/* Carrusel featured products */
#index #carrusel_featuredproducts {
  margin-top: 40px;
}

#index #carrusel_featuredproducts .slide {
  width: 25%;
}

#index #carrusel_featuredproducts.slick-not-init .slide:nth-child(n + 2) {
  display: none;
}

/* Sobre nosotros */
#seo-home .container {
  display: flex;
  flex-wrap: wrap;
}

#seo-home .container > div {
  padding: 0;
}

#seo-home .top {
  background-color: var(--color-black);
}

#seo-home .top .content {
  padding: 40px 40px 40px 0;
}

#seo-home .top .content .header .pretitle {
  text-align: left;
}

#seo-home .top .content .header .title {
  width: min-content;
  display: flex;
  align-items: flex-end;
  gap: 10px;
  line-height: 1;
  color: var(--color-white);
}

#seo-home .top .content .header .title .dot {
  margin-bottom: 7px;
  min-width: 18px;
  min-height: 18px;
  border-radius: 50%;
  background-color: var(--color-primary);
}

#seo-home .top .content .text {
  margin-top: 20px;
  color: var(--color-white);
}

#seo-home .top .content a {
  margin-top: 20px;
  background-color: transparent !important;
  border-color: var(--color-white) !important;
  color: var(--color-white) !important;
}

#seo-home .top .content a:hover {
  background-color: var(--color-white) !important;
  color: var(--color-black) !important;
}

#seo-home .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#seo-home .bottom .content {
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

#seo-home .bottom .content .title {
  margin: 0;
  text-transform: uppercase;
  font-weight: 600 !important;
  font-size: 20px;
  font-family: var(--font-title);
}

#seo-home .bottom .content span {
  margin-top: 30px;
  display: flex;
}

#seo-home .bottom .content span:last-child {
  font-weight: 500;
}

/* Banners home - categoría */
#banners-home .banners,
#banners-category .banners {
  display: flex;
  gap: 20px;
}

#banners-home .banners::after,
#banners-category .banners::after {
  display: none;
}

#banners-home .banners .banner,
#banners-category .banners .banner {
  width: calc(50% - 10px);
  margin: 0;
  position: relative;
}

#banners-home .banners .banner img,
#banners-category .banners .banner img {
  width: 100%;
  height: 400px;
  object-fit: cover;
}

#banners-home .banners .banner .shadow,
#banners-category .banners .banner .shadow {
  width: 100%;
  height: 400px;
  position: absolute;
  top: 0;
  background: radial-gradient(circle, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.2) 70%, rgba(0, 0, 0, 0) 100%);
}

#banners-home .banners .banner .info,
#banners-category .banners .banner .info {
  position: absolute;
  bottom: 50%;
  left: 50%;
  transform: translate(-50%, 50%);
  text-align: center;
  width: 80%;
}

#banners-home .banners .banner .info .title,
#banners-category .banners .banner .info .title {
  margin-bottom: var(--spaces-sm);
  color: var(--color-primary);
  text-transform: uppercase;
  font-size: var(--font-sm);
  font-weight: 500;
  line-height: 1;
}

#banners-home .banners .banner .info .text,
#banners-category .banners .banner .info .text {
  color: var(--color-white);
  text-transform: uppercase;
  font-size: 45px;
  font-weight: 600;
  line-height: 1;
  font-family: var(--font-title);
}

/* Blog */
#index #blog #carrusel_blog .post {
  margin: 0 3px 0 3px !important;
  border: solid 1px var(--color-grey-border);
  width: calc(100% / 3);
}

#index #blog #carrusel_blog.slick-not-init .post:nth-child(n + 2) {
  display: none;
}

#index #blog #carrusel_blog .post > a {
  min-height: 300px;
  display: flex;
  background-position: center;
  background-size: cover;
}

#index #blog #carrusel_blog .post .info {
  padding: 20px;
}

#index #blog #carrusel_blog .post .info .post-date {
  font-size: var(--font-md);
  color: var(--color-darkgrey);
}

#index #blog #carrusel_blog .post .info .post-title p {
  margin: 10px 0;
  height: 52px;
  font-size: 20px;
  font-weight: 600;
  text-overflow: ellipsis;
  text-transform: uppercase;
  font-family: var(--font-title);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: 0.3s;
}

#index #blog #carrusel_blog .post .info .post-title p:hover {
  color: var(--color-primary);
}

#index #blog #carrusel_blog .post .info .post-description {
  height: 100px;
  line-height: 25px;
  font-size: var(--font-md);
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  text-overflow: ellipsis;
  overflow: hidden;
}

/* --------------------- CATEGORÍA ---------------------- */
#category #wrapper > .container {
  width: 100%;
  padding: 0 !important;
}

/* Top categoria (Imagen - Nombre - Breadcrumb) */
#category .block-category {
  margin: 0;
  position: relative;
  background-image: url("/themes/dfd-miliarlaboral/assets/img/category-default.jpg");
  background-size: cover;
  background-position: center;
}

#category .block-category::before {
  content: "";
  position: absolute;
  background-color: #00000052;
  inset: 0;
  z-index: 1;
}

#category .block-category .category-text,
#contact .block-contact .contact-text,
#cms .block-cms .cms-text {
  padding: var(--separator-sections) 0;
  color: var(--color-white);
  width: 100%;
  position: relative;
  z-index: 9;
}

#category .block-category .category-text h1,
#contact .block-contact .contact-text h1,
#cms .block-cms .cms-text h1 {
  margin: 0;
  padding: var(--spaces-md);
  text-transform: uppercase;
  text-align: center;
  font-size: 70px;
  font-family: var(--font-title);
  font-weight: 600;
  line-height: 1;
  word-break: break-word;
}

#category .block-category .category-text .breadcrumb,
#contact .block-contact .contact-text .breadcrumb,
#cms .block-cms .cms-text .breadcrumb {
  text-align: center;
}

/* Descripción */
#category #js-product-list-header .description {
  margin-top: var(--separator-sections);
  text-align: center;
}

#category #js-product-list-header .description > p:last-child,
#category #js-product-list-footer .additional_description > p:last-child {
  margin: 0;
}

/* Subcategorías */
#category #left-column {
  width: 100%;
  padding: 0;
}

#category #left-column .block-categories {
  margin-top: var(--separator-sections);
  padding: 0;
}

#category #left-column .block-categories .category-sub-menu {
  margin: 0 -1.5px;
}

#category #left-column .block-categories .category-sub-menu .slide {
  margin: 0 3px;
  height: 250px;
  width: 25%;
}

#category #left-column .block-categories .category-sub-menu.slick-not-init .slide:nth-child(n + 2) {
  display: none;
}

#category #left-column .block-categories .category-sub-menu .slide a {
  margin: 0;
  padding: 0;
  position: relative;
}

#category #left-column .block-categories .category-sub-menu .slide a img {
  width: 100%;
  object-fit: cover;
}

#category #left-column .block-categories .category-sub-menu .slide a .shadow {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #00000052;
}

#category #left-column .block-categories .category-sub-menu .slide a .title {
  padding: 0 40px;
  position: absolute;
  bottom: 20px;
  left: 0;
  font-weight: 600;
  font-family: var(--font-title);
  text-transform: uppercase;
  color: var(--color-white);
}

/* Apartado productos */
#category #content-wrapper {
  padding: 0;
  width: 100%;
  display: block !important;
}

/* Filtros */
#js-product-list-top {
  margin-top: calc(var(--spaces-md) * 2);
  padding: 0;
  align-items: flex-start;
  border: none;
}

#category #js-product-list-top {
  margin-top: var(--separator-sections);
}

#js-product-list-top .filtros {
  display: flex;
  gap: 20px;
}

#category #search_filter_toggler {
  height: 45px;
  width: auto;
  display: flex;
  align-items: center;
  gap: 10px;
  border: solid 1px var(--color-black) !important;
}

#category #search_filter_toggler svg * {
  transition: 0.3s;
}

#category #search_filter_toggler:hover svg * {
  stroke: var(--color-white);
}

#category #search_filter_toggler > #count-filters {
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px !important;
  background-color: var(--color-black);
  color: var(--color-white);
  border-radius: 50%;
  cursor: pointer;
}

#category #search_filter_toggler > #count-filters.hidden {
  display: none;
}

/* Filtros activos */
#category #js-active-search-filters:not(.hide) {
  margin: 0;
  padding: 0;
  background-color: transparent;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--spaces-sm);
}

#category #js-active-search-filters *:not(i) {
  font-size: var(--font-md);
  font-weight: 400;
}

#category #js-active-search-filters ul {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--spaces-sm);
}

#category #js-active-search-filters ul li {
  margin: 0;
  padding: 0;
  border: solid 1px var(--color-black);
}

#category #js-active-search-filters ul li a {
  padding: var(--spaces-sm);
  display: flex;
  align-items: center;
  gap: var(--spaces-xs);
  line-height: normal;
  color: var(--color-black);
  transition: 0.3s;
}

#category #js-active-search-filters ul li a:hover {
  background-color: var(--color-grey-border);
}

#category #js-active-search-filters ul li a i {
  font-size: var(--font-md);
}

#category #js-active-search-filters .js-search-filters-clear-all {
  height: 45px;
  display: flex;
  align-items: center;
  gap: var(--spaces-xs);
  text-transform: none !important;
  background-color: var(--color-black);
  border: solid 1px var(--color-black);
  color: var(--color-white);
}

#category #js-active-search-filters .js-search-filters-clear-all:hover {
  background-color: var(--color-grey-border);
  color: var(--color-black);
}

#category #js-active-search-filters .js-search-filters-clear-all i {
  margin: 0;
  font-size: var(--font-md);
}

/* Modal filtros */
#filters_category .modal-dialog {
  margin: 0;
  width: 100%;
  max-width: 380px;
  height: 100dvh;
  float: left;
}

#filters_category .modal-body {
  height: 100dvh !important;
  padding: var(--spaces-md) !important;
  overflow-y: auto;
}

#filters_category .modal-body > button {
  position: absolute;
  right: 20px;
  top: 19px;
  opacity: 1;
  outline: none;
  font-weight: 400;
}

#filters_category .modal-body > button span {
  font-size: 30px !important;
}

#filters_category .modal-body .modal-title {
  padding-bottom: var(--spaces-md);
  border-bottom: 1px solid var(--color-grey-border);
}

#filters_category .modal-body .modal-title > div {
  display: flex;
  align-items: center;
  gap: var(--spaces-sm);
}

#filters_category .modal-body .modal-title > div svg {
  width: 25px;
  height: 25px;
}

#filters_category .modal-body .modal-title > div span {
  text-transform: uppercase;
  font-weight: 600;
  font-family: var(--font-title);
}

#filters_category .modal-body #js-active-search-filters:not(.hide) {
  margin-top: var(--spaces-md);
  padding-bottom: 20px;
  border-bottom: solid 1px var(--color-grey-border);
}

#filters_category .modal-body #search_filters {
  margin: var(--spaces-md) 0 0 0 !important;
  padding: 0;
  display: block;
  max-height: none;
  overflow: auto;
  border: none !important;
}

#filters_category .modal-body #search_filters .facet {
  border: none !important;
}

#filters_category .modal-body #search_filters .facet:last-child {
  margin: 0 !important;
  padding: 0 !important;
}

#filters_category .modal-body #search_filters .facet .facet-title {
  margin-bottom: var(--spaces-sm) !important;
  color: var(--color-black);
  font-size: var(--font-md);
  line-height: normal;
  font-weight: 600;
}

#filters_category .modal-body #search_filters .facet .title > span {
  padding: 0 !important;
}

#filters_category .modal-body #search_filters .facet ul:not(.faceted-slider) {
  max-height: 250px;
  overflow-y: auto;
}

#filters_category .modal-body #search_filters .facet ul li {
  padding: 0 var(--spaces-sm) !important;
  margin-bottom: var(--spaces-xs);
}

#filters_category .modal-body #search_filters .facet ul li:last-child {
  margin: 0;
}

#filters_category .modal-body #search_filters .facet ul li .facet-label {
  align-items: center;
  gap: var(--spaces-xs);
}

#filters_category .modal-body #search_filters .facet ul li .facet-label a {
  margin: 0;
}

#filters_category .modal-body #search_filters .facet ul li .facet-label a .search-link {
  white-space: normal;
}

#filters_category .modal-body #search_filters .facet .faceted-slider .ui-slider {
  max-width: 95%;
}

#filters_category .modal-body #search_filters .facet ul li .facet-label .custom-checkbox > input:checked + span {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

#filters_category .modal-body #search_filters .facet ul li .facet-label .custom-checkbox > span {
  margin: 0;
  width: 15px;
  height: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #f0f0f0;
  border-color: var(--color-grey);
}

#filters_category .modal-body #search_filters .facet ul li .facet-label .custom-checkbox > span i {
  font-size: 9px;
}

/* Ordenar por */
#js-product-list-top .sort-by-row .products-sort-order {
  width: 100%;
}

#js-product-list-top .sort-by-row .products-sort-order #selectProductSort {
  padding-right: 30px !important;
  max-width: fit-content !important;
  height: 45px !important;
  border: solid 1px var(--color-black);
  font-family: var(--font-text);
  font-size: var(--font-md) !important;
  z-index: 9 !important;
}

/* Apartado productos */
#products #js-product-list .products {
  margin: 0 -3px;
  justify-content: flex-start;
}

/* Paginación */
.pagination {
  width: 100% !important;
  position: relative;
  left: 0;
}

.pagination .page-list {
  margin: 40px 0 0 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spaces-xs);
}

.pagination .page-list li:not(:has(.spacer)) {
  display: flex;
  align-items: center;
  justify-content: center;
  border: solid 1px var(--color-black);
  transition: 0.3s;
}

.pagination .page-list li.arrow {
  height: 32px;
  width: 32px;
  position: relative;
  top: 0;
  left: 0;
  transform: none;
}

.pagination .page-list li.current {
  border-color: var(--color-primary);
  background-color: var(--color-primary);
}

.pagination .page-list li:not(.current, :has(.spacer)):hover {
  background-color: var(--color-black);
}

.pagination .page-list li:not(.current, :has(.spacer)):hover a {
  color: var(--color-white);
}

.pagination .page-list li:not(.current, :has(.spacer)):hover svg * {
  stroke: var(--color-white);
}

.pagination .page-list li > * {
  min-width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: normal;
  font-weight: 400;
  font-size: var(--font-sm) !important;
  letter-spacing: 0 !important;
  color: var(--color-black);
}

.pagination .page-list li.current a {
  color: var(--color-white);
}

.pagination .page-list li a svg {
  height: 10px !important;
}

/* Descripción */
#category #js-product-list-footer,
#category #banners-category {
  margin-top: var(--separator-sections);
}

/* Banners */
#category #banners-category .banners {
  padding: 0 !important;
}

/* ---------------------- PRODUCTO ---------------------- */
#product .product_topview {
  margin-top: var(--separator-sections);
  padding: 0 !important;
}

/* Left - Imágenes */
#product .block_left #content .product-view_content #product-cover-slider {
  margin-bottom: 6px;
}

#product .block_left #content .product-view_content #product-cover-slider .slick-list {
  margin: 0;
  width: 100%;
}

#product .block_left #content .product-view_content > .product-images-container ul {
  margin: 0;
}

#product .block_left #content .product-view_content .product-cover .thumb-item {
  width: 100%;
}

#product .block_left #content .product-view_content .product-cover.slick-not-init .thumb-item:nth-child(n + 2),
#product .block_left #content .product-view_content .product-images.slick-not-init .thumb-container:nth-child(n + 2) {
  display: none;
}

#product .block_left #content .product-view_content .product-cover img {
  filter: brightness(0.93);
}

#product .block_left #content .product-view_content > .product-images-container .slick-list {
  width: calc(100% + 3px);
}

#product .block_left #content .product-view_content > .product-images-container .slick-track {
  display: flex;
}

#product .block_left #content .product-view_content > .product-images-container .slick-track > .slick-slide {
  margin: 0 3px;
}

#product .block_left #content .product-view_content .product-images .thumb-container {
  width: 25%;
}

#product .block_left #content .product-view_content > .product-images-container img.thumb {
  height: auto;
  cursor: pointer;
  filter: brightness(0.93);
}

/* Right - Info prod. */
#product .block_right {
  padding-left: 60px;
}

/* Nombre - Manufacturer */
#product .block_right .name_manufacturer {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

#product .block_right .name_manufacturer .product_name {
  margin: 0;
  font-size: 30px;
  font-family: var(--font-title);
  text-transform: uppercase;
  line-height: 1;
}

#product .block_right .name_manufacturer .manufacturer img {
  height: auto;
}

/* Precio */
#product .block_right > .content {
  margin-top: 75px;
  position: relative;
}

#product .block_right > .content:has(.block-product-attribute-custom) {
  margin-top: 125px;
}

#product .block_right .product-actions {
  margin-top: 20px;
  padding: 0;
}

#product .block_right .product-actions .product-prices > .product-price {
  position: absolute;
  top: -50px;
}

#product .block_right .product-actions:has(.block-product-attribute-custom) .product-prices > .product-price {
  top: -100px;
}

#product .block_right .product-actions .product_prices .current-price {
  align-items: center;
  gap: var(--spaces-md);
}

#product .block_right .product-actions .product_prices .price_pvp {
  color: var(--color-orange);
  font-size: 25px;
  font-family: var(--font-title);
  font-weight: 600;
  line-height: normal;
}

#product .block_right .product-actions .product_prices .has-discount .price_pvp {
  color: var(--color-red);
  margin: 0;
}

#product .block_right .product-actions .product_prices .current-price .show_pvp span {
  color: #babbba;
  font-size: 18px;
  font-family: var(--font-title);
  font-weight: 500;
  line-height: normal;
}

/* Disponibilidad */
#product .block_right .product-actions .product_prices .tax-shipping-delivery-label {
  padding: 0;
  margin: 0;
  border: none;
}

/* Personalización - Checkbox */
#product .block-product-attribute-custom {
  margin: 0;
  position: absolute;
  top: -40px;
}

#product .block-product-attribute-custom .control-label {
  margin: 0;
  padding: 0;
  width: fit-content;
  display: flex !important;
  align-items: center;
  gap: var(--spaces-xs);
  font-weight: 400;
}

#product .block-product-attribute-custom .control-label .ets_input_group {
  margin: 0 var(--spaces-xs) 0 0;
  height: auto;
}

#product .block-product-attribute-custom .control-label .ets_input_group input {
  width: 14px;
  height: 14px;
  min-width: auto;
  min-height: auto;
}

#product .block-product-attribute-custom .control-label .ets_input_group .ets_input_check {
  width: 14px;
  height: 14px;
  border-radius: unset;
  border: solid 1px var(--color-black);
}

#product .block-product-attribute-custom .control-label .ets_input_group input:checked + .ets_input_check {
  border-color: var(--color-primary);
}

#product .block-product-attribute-custom .control-label .ets_input_group .ets_input_check i {
  font-size: 10px;
}

#product .block-product-attribute-custom .control-label > span {
  line-height: 1;
}

#product .block-product-attribute-custom .control-label .product-discount {
  font-size: 13px;
  color: var(--color-black);
}

/* Personalización - Contenido */
#product .block_right .product_customization {
  border: solid 1px var(--color-black);
  margin-bottom: 40px;
  padding: var(--spaces-md);
}

#product .block_right .product_customization .title {
  margin-bottom: 5px;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--color-primary);
}

#product .block_right .product_customization .subtitle {
  font-size: var(--font-sm);
}

#product .block_right .product_customization form {
  margin-top: 20px;
}

#product .block_right .product_customization form li {
  margin: 15px 0;
  padding-bottom: 15px;
  border-bottom: solid 1px var(--color-grey-border);
}

#product .block_right .product_customization form li:last-child,
#product .block_right .product_customization form li.file {
  padding: 0;
  margin-bottom: 0;
  border: none;
}

#product .block_right .product_customization form li:has(.radio-group) ~ li {
  display: none;
}

#product .block_right .product_customization form li > label {
  margin-bottom: 5px;
  font-size: var(--font-md);
  font-weight: 600;
  text-transform: uppercase;
}

#product .block_right .product_customization form li .radio-group {
  display: flex;
  gap: 60px;
}

#product .block_right .product_customization form li .radio-group .radio label {
  margin: 0;
  display: flex;
  align-items: center;
  gap: var(--spaces-xs);
  font-size: 14px;
}

#product .block_right .product_customization form li small {
  margin-top: 2px;
}

#product .block_right .product_customization form li .customization-message {
  margin: 5px 0 0 0;
  display: flex;
  gap: 5px;
  font-size: 13px;
}

#product .block_right .product_customization form li .customization-message span {
  font-weight: 500;
}

#product .block_right .product_customization form li img {
  margin-bottom: 10px;
}

#product .block_right .product_customization form li .custom-file input {
  top: 0;
}

#product .block_right .product_customization form li .custom-file span.btn {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 0;
  height: 40px;
  display: flex;
  align-items: center;
}

#product .block_right .product_customization form li .custom-file:hover span.btn {
  background-color: var(--color-black) !important;
  border-color: var(--color-black) !important;
}

#product .block_right .product_customization form li .custom-file span.btn i {
  transition: 0.3s;
}

#product .block_right .product_customization form li .custom-file:hover span.btn i {
  color: var(--color-white);
}

/* Atributos */
#product .block_right .product-actions .product-variants {
  margin-top: 20px;
}

#product .block_right .product-actions .product-variants > div {
  margin-bottom: 30px;
  display: flex;
  align-items: center;
}

#product .block_right .product-actions .product-variants > div .control-label {
  margin: 0;
  width: auto;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 15px;
  min-width: 150px;
}

/* Descripción */
#product .block_right .product-actions .product-description {
  padding-top: var(--spaces-sm);
}

/* Referencia */
#product .block_right .product-actions #product-reference > .cont {
  font-size: var(--font-sm);
  text-transform: uppercase;
  line-height: normal;
  color: var(--color-darkgrey);
}

/* Cantidad - Add to cart - Wishlist */
#product .block_right .add_cart_wishlist {
  position: relative;
}

#product .block_right .product_add_to_cart {
  margin-top: 40px;
}

#product .block_right .product_add_to_cart .product-add-to-cart .product-quantity {
  width: calc(100% - 70px);
  gap: var(--spaces-md);
}

#product .block_right .product_add_to_cart .product-add-to-cart .product-quantity::after {
  display: none;
}

#product .block_right .product_add_to_cart .product-add-to-cart .product-quantity .qty {
  margin: 0;
  min-width: auto;
}

#product .block_right .product_add_to_cart .product-add-to-cart .product-quantity .qty #quantity_wanted {
  width: 40px;
  height: 50px !important;
  left: 35px;
  color: var(--color-primary);
  border-color: var(--color-primary);
}

#product .block_right .product_add_to_cart .product-add-to-cart .product-quantity .qty .btn {
  width: 35px !important;
  height: 50px !important;
  border-color: var(--color-primary);
}

#product .block_right .product_add_to_cart .product-add-to-cart .product-quantity .qty .btn i {
  color: var(--color-primary);
}

#product .block_right .product_add_to_cart .product-add-to-cart .product-quantity .qty .btn.bootstrap-touchspin-down {
  left: -73px;
}

#product .block_right .product_add_to_cart .product-add-to-cart .product-quantity .qty .btn.bootstrap-touchspin-up {
  left: 36px;
}

#product .block_right .product_add_to_cart .product-add-to-cart .product-quantity .add {
  width: calc(100% - 129px) !important;
  min-width: auto !important;
}

#product .block_right .wishlist-button-add {
  margin: 0;
  padding: 0;
  width: 50px;
  height: 50px;
  position: absolute;
  top: 0;
  right: 0;
  box-shadow: none !important;
  border: solid 1px var(--color-primary);
  border-radius: unset;
  opacity: 1 !important;
}

#product .block_right .wishlist-button-add i {
  background-repeat: no-repeat;
  background-size: contain;
  width: 22px;
  height: 22px;
}

#product .block_right .wishlist-button-add:hover i.heart,
#product .block_right .wishlist-button-add i.heart-full {
  background-image: url("/themes/dfd-miliarlaboral/assets/img/icons/heart-full.svg");
}

#product .block_right .wishlist-button-add i.heart {
  background-image: url("/themes/dfd-miliarlaboral/assets/img/icons/heart.svg");
  transition: 0.3s;
}

/* Reassurance */
#product .blockreassurance_product {
  padding: 0;
  margin: 40px 0 0 0 !important;
  flex-direction: column;
  gap: 10px;
  border: none;
}

#product .blockreassurance_product .item {
  width: 100%;
  height: 30px;
  margin: 0;
  justify-content: flex-start;
  display: flex;
  gap: 20px;
}

#product .blockreassurance_product .item .icon {
  display: flex;
}

#product .blockreassurance_product .item .icon svg {
  width: 30px;
  height: 30px;
}

#product .blockreassurance_product .item .icon svg * {
  stroke: var(--color-black);
}

#product .blockreassurance_product .item .text p {
  margin: 0;
  font-size: var(--font-md);
}

/* Productos relacionados */
#product .product-accessories {
  margin: var(--separator-sections) -3px 0 -3px;
  display: flex;
  flex-wrap: wrap;
}

#product .product-accessories:has(.slick-arrow) {
  margin-bottom: 50px;
}

#product .product-accessories .slick-list {
  margin: 0;
}

#product .product-accessories .slide {
  width: 50%;
}

#product .product-accessories .slick-list .slide .product-miniature {
  margin-bottom: 0 !important;
}

#product .product-accessories.slick-not-init .slide:nth-child(n + 2) {
  display: none;
}

#product .product-accessories .slick-arrow {
  left: 3px;
  bottom: -50px;
  top: unset;
  transform: none;
}

#product .product-accessories .slick-arrow.slick-next {
  left: 53px;
}

/* Tabs información */
#product .product-tabs {
  margin-top: var(--separator-sections-lg);
}

#product .product-tabs .tabs {
  margin: 0;
  padding: 0;
}

#product .product-tabs .tabs > .container {
  padding: 0 !important;
}

#product .product-tabs .tabs .nav-tabs {
  padding-bottom: 5px;
  display: flex;
  overflow-x: scroll;
  overflow-y: clip;
  border: none;
}

#product .product-tabs .tabs .nav-tabs::-webkit-scrollbar {
  height: 2px;
}

#product .product-tabs .tabs .nav-tabs .nav-item {
  margin: 0;
  padding: 10px 30px;
  border-bottom: solid 3px transparent;
  transition: 0.3s;
}

#product .product-tabs .tabs .nav-tabs .nav-item:has(.active) {
  border-color: var(--color-primary);
}

#product .product-tabs .tabs .nav-tabs .nav-item:has(.nav-link:not(.active):hover) {
  border-color: var(--color-darkgrey);
}

#product .product-tabs .tabs .nav-tabs .nav-item .nav-link {
  padding: 0;
  height: 100%;
  display: flex;
  align-items: center;
  text-align: center;
  text-transform: uppercase;
  color: var(--color-black);
  font-weight: 600;
  transition: 0.3s;
  border: none;
}

#product .product-tabs .tabs .nav-tabs .nav-item .nav-link:hover {
  color: var(--color-darkgrey);
}

#product .product-tabs .tabs .nav-tabs .nav-item .nav-link.active {
  color: var(--color-primary);
}

#product .product-tabs .tabs .contentCont {
  margin-top: var(--spaces-md);
}

#product .product-tabs .tabs .contentCont .tab-content,
#product .product-tabs .tabs .contentCont .tab-content .tab-pane {
  padding: 0 !important;
}

#product .product-tabs .tabs .contentCont .tab-content .tab-pane .manufacturer img {
  width: auto;
}

#product .product-tabs .tabs .contentCont #description .product-description p:last-child {
  margin: 0;
}

/* Category products */
#product .featured-products.block {
  margin-top: var(--separator-sections-lg);
}

#product .featured-products .header .pretitle {
  margin-bottom: 0;
  color: var(--color-primary);
  text-transform: uppercase;
  text-align: center;
  font-size: var(--font-sm);
  font-weight: 500;
}

#product .featured-products .header .title {
  color: var(--color-black);
  text-transform: uppercase;
  text-align: center;
  font-size: 45px;
  font-weight: 600;
  line-height: 1;
}

#product .featured-products #carrusel_categoryproducts {
  margin-top: 40px;
}

#product .featured-products #carrusel_categoryproducts .slide {
  width: 25%;
}

#product .featured-products #carrusel_categoryproducts.slick-not-init .slide:nth-child(n + 2) {
  display: none;
}

/* ---------------------- CARRITO ----------------------- */
#cart #wrapper > .container,
#checkout #wrapper {
  margin-top: 30px;
}

#cart .cart-grid {
  margin-bottom: 0;
}

/* Bloque izquierda */
#cart .cart-grid > .left {
  margin: 0;
}

#cart .cart-grid > .left .card-block,
#cart .cart-grid > .left .cart-items {
  padding: 0;
}

#cart .cart-grid > .left .card-block > h1 {
  line-height: unset;
  font-family: var(--font-title);
  font-weight: 500;
}

#cart .cart-grid > .left .no-items {
  margin-top: var(--spaces-sm);
  display: flex;
}

#cart .cart-grid > .left .cart-items {
  margin-top: var(--spaces-md);
}

#cart .cart-grid > .left .cart-item {
  margin: 0;
  padding: 15px 0;
  border-bottom: solid 1px var(--color-grey-border);
}

#cart .cart-grid > .left .cart-item:last-child {
  padding-bottom: 0;
  border: none;
}

#cart .cart-grid > .left .cart-item .cart__product-name {
  padding-right: var(--spaces-md);
}

#cart .cart-grid > .left .cart-item .cart__product-name .product-name > a {
  font-size: var(--font-md);
  line-height: normal;
}

#cart .cart-grid > .left .cart-item .cart__product-name .product-name > a:hover {
  color: var(--color-black);
  text-decoration: underline;
}

#cart .cart-grid > .left .cart-item .cart__product-name .product-attributes span,
#cart .cart-grid > .left .cart-item .cart__product-name > a {
  font-size: var(--font-sm);
}

#cart .cart-grid > .left .cart-item .cart__product-qty {
  z-index: 9;
}

#cart .cart-grid > .left .cart-item input,
#cart .cart-grid > .left .cart-item .cart__product-qty button {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

#cart .cart-item .cart__product-price {
  align-items: flex-end;
}

#cart .cart-item .cart__product-price .product-totalprice {
  font-family: var(--font-title);
  font-size: 20px;
  font-weight: 600;
  line-height: normal;
  color: var(--color-orange);
}

#cart .cart-item .cart__product-price .product-totalprice:has(.old_price) {
  color: var(--color-red);
}

#cart .cart-item .cart__product-price .product-totalprice .old_price {
  font-size: var(--font-sm);
  margin-right: var(--spaces-xs);
}

/* Bloque derecha */
#cart .cart-grid > .right > .card {
  margin: 0;
}

#cart .cart-grid > .right > .card span {
  line-height: normal;
}

#cart .cart-grid > .right .cart-summary_header {
  padding: 1rem;
  padding-top: 0;
  font-family: var(--font-title);
  font-size: 24px !important;
  font-weight: 500;
  line-height: unset !important;
}

#cart .cart-grid > .right .block-promo .promo-code-button > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--color-black);
}

#cart .cart-grid > .right .block-promo:has(#promo-code.collapsing) .collapse_up,
#cart .cart-grid > .right .block-promo:has(#promo-code.collapse.in) .collapse_up,
#cart .cart-grid > .right .block-promo:has(#promo-code.collapsing[aria-expanded="false"]) .collapse_down {
  display: block;
}

#cart .cart-grid > .right .block-promo:has(#promo-code.collapse) .collapse_up,
#cart .cart-grid > .right .block-promo:has(#promo-code.collapsing[aria-expanded="false"]) .collapse_up,
#cart .cart-grid > .right .block-promo:has(#promo-code.collapsing) .collapse_down,
#cart .cart-grid > .right .block-promo:has(#promo-code.collapse.in) .collapse_down {
  display: none;
}

#cart .cart-grid > .right .block-promo .promo-code form .promo-input {
  border-color: var(--color-primary);
  border-right: none;
  height: 40px;
}

#cart .cart-grid > .right .block-promo .promo-code form button {
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}

#cart .cart-grid > .right .block-promo .promo-code .alert {
  margin-bottom: 0;
}

#cart .cart-grid > .right .block-promo .promo-code .alert > span {
  padding: 0;
  font-size: var(--font-sm) !important;
}

#cart .cart-grid > .right .block-promo .promo-discounts li {
  padding: var(--spaces-sm) var(--spaces-md);
}

#cart .cart-grid > .right .block-promo .promo-discounts li .code {
  color: var(--color-primary);
}

#cart .cart-grid > .right .cart-detailed-totals {
  padding: 0;
}

#cart .cart-grid > .right .cart-detailed-totals hr {
  display: none;
}

#cart .cart-grid > .right .card-block {
  margin: 0;
  padding: 1rem;
  padding-top: 0;
}

#cart .cart-grid > .right .card-block:not(:last-child) > .cart-summary-line:first-child {
  padding-top: 1rem;
  border-top: solid 1px #e0e0e0;
}

#cart .cart-grid > .right .card-block:not(:last-child) > .cart-summary-line:last-child,
#cart .cart-grid > .right .card-block .promo-name li {
  margin: 0;
}

#cart .cart-grid > .right .card-block:last-child .cart-total {
  padding: 1rem 0 0 0;
  margin: 0;
}

#cart .cart-grid > .right .card-block:last-child .cart-total > span {
  font-size: var(--font-md) !important;
}

#cart .cart-grid > .right .card-block.checkout {
  padding-bottom: 0;
}

/* Modal personalización */
.customization-modal .modal-content {
  padding: 0 !important;
}

.customization-modal .modal-content .modal-header {
  display: block;
}

.customization-modal .modal-content .modal-header button {
  margin-top: var(--spaces-xs);
  outline: none;
}

.customization-modal .modal-content .modal-body .product-customization-line {
  margin: 0;
  display: flex;
}

.customization-modal .modal-content .modal-body .product-customization-line > div {
  margin-bottom: var(--spaces-sm);
  padding: 0 0 var(--spaces-sm) 0;
  width: 50%;
  display: flex;
  align-items: center;
  text-align: left;
  border-bottom: solid 1px var(--color-grey-border);
}

.customization-modal .modal-content .modal-body .product-customization-line:last-child > div {
  margin: 0;
  padding: 0;
  border: none;
}

/* --------------------- CHECKOUT ----------------------- */
#checkout #content,
#checkout #opc_main,
#checkout #opc_main .opc-step {
  margin-bottom: 0 !important;
}

#checkout #opc_main * {
  border-radius: 0 !important;
}

/* OPC - Información personal */
#opc_step_my_account .tabs-view .nav-link {
  padding: 0 !important;
}

#opc_personal_information #field_custom_autogenerate_password *,
#opc_personal_information #field_custom_psgdpr *,
#opc_personal_information #field_custom_customer_privacy *,
#opc_personal_information .opc-form__required-fields * {
  font-size: 14px !important;
}

#opc_login_customer form > .row:has(#txt-login_password) {
  margin-top: 10px;
}

/* OPC - Direcciones - Envío */
#opc_addresses .address-selector {
  padding-right: 5px;
}

#checkout #opc_main #opc_addresses .address-selector > .address-item:first-child {
  margin-top: 0 !important;
}

#checkout #opc_main #opc_addresses .address-selector > .address-item:last-child,
#opc_step_shipping .delivery-options .delivery_option_title {
  margin-bottom: 0 !important;
}

/* OPC - Pago */
#opc_step_payment #payment-confirmation button > i {
  display: none;
}

/* OPC - Carrito */
#opc_main #opc_step_cart .cart-summary-products .media-list,
#opc_main #opc_step_cart .cart-summary-totals {
  padding: 0 !important;
}

#opc_main #opc_step_cart .cart-summary-totals .cart-summary-line {
  margin: 0 !important;
}

#opc_main #opc_step_cart #opc_step_cart_footer {
  padding: 0 !important;
  border: none;
}

/* Modal términos del servicio */
#checkout #cms_modal .modal-dialog {
  max-width: 60%;
}

#checkout #cms_modal .modal-dialog .modal-header {
  padding-top: 0;
}

#checkout .modal-dialog .modal-header .btn-close {
  box-shadow: none;
  height: 22px;
}

#checkout .modal-dialog .modal-body #content > h2 {
  margin-top: 30px;
  font-size: 20px;
  font-weight: 500;
  text-transform: uppercase;
}

#checkout .modal-dialog .modal-body #content h3 {
  margin-top: var(--spaces-sm);
  font-size: 18px;
}

/* --------------- CONFIRMACIÓN DE PEDIDO --------------- */
#order-confirmation #main > section {
  border: solid 1px var(--color-primary) !important;
}

#order-confirmation #wrapper #content-wrapper a:hover,
#order-confirmation #wrapper #content-wrapper a:hover span {
  text-decoration: underline;
}

#order-confirmation #wrapper #content-hook_order_confirmation {
  margin-top: 30px;
}

#order-confirmation #wrapper #content-hook_order_confirmation .title_confirmation {
  gap: var(--spaces-md);
}

#order-confirmation #wrapper #content-hook_order_confirmation .title_confirmation > div {
  display: flex;
  flex-direction: column;
  gap: var(--spaces-xs);
}

#order-confirmation #wrapper #content-hook_order_confirmation .title_confirmation > div .card-title {
  margin: 0;
  display: flex;
  align-items: center;
  line-height: normal;
  font-size: 26px !important;
}

#order-confirmation #wrapper #content-hook_order_confirmation .title_confirmation > div .card-title i {
  padding: 0 var(--spaces-sm) 0 0;
}

#order-confirmation #wrapper #content {
  margin: 0;
}

#order-confirmation #wrapper #content #order-details {
  margin: 0;
  padding-left: 0;
}

#order-confirmation #wrapper #content #order-details ul li:last-child {
  font-weight: 600;
}

#order-confirmation #wrapper #content #order-details + div {
  padding-right: 0;
}

/* --------------------- MI CUENTA ---------------------- */
#tabs-account > .nav-tabs {
  margin-top: var(--spaces-md);
  display: flex;
  justify-content: center;
  border-bottom: solid 1px var(--color-grey-border);
}

#tabs-account > .nav-tabs .nav-link {
  height: 100%;
  display: flex;
  align-items: center;
  text-align: center;
  border: none;
  border-bottom: 3px solid transparent;
}

#tabs-account > .nav-tabs .nav-link:hover,
#tabs-account > .nav-tabs .nav-link.active {
  border-bottom: 3px solid var(--color-primary);
}

#tabs-account > .nav-tabs .nav-link.active {
  color: var(--color-primary);
}

#tabs-account > .tab-content .tab-pane.active {
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
  gap: var(--spaces-md);
}

#tabs-account > .tab-content .tab-pane a {
  padding: 0;
  width: calc(50% - var(--spaces-sm));
}

#tabs-account > .tab-content .tab-pane a .link-item {
  margin: 0;
  height: 100%;
  min-height: auto;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  border: 1px solid var(--color-primary);
  transition: 0.3s;
}

#tabs-account > .tab-content .tab-pane a:hover .link-item {
  background-color: var(--color-grey-border);
}

#tabs-account > .tab-content .tab-pane a .link-item i {
  margin: 0 var(--spaces-sm) 0 0 !important;
  min-width: 55px !important;
  font-size: 30px;
}

#tabs-account > .tab-content .tab-pane a .link-item .content .title {
  margin-bottom: 0;
  font-family: var(--font-title);
  font-weight: 600;
}

#tabs-account > .tab-content .tab-pane a .link-item .content .desc {
  margin: var(--spaces-sm) 0 0 0;
  font-size: var(--font-sm);
  line-height: normal;
}

/* ---------------- SUBAPARTADOS MI CUENTA -------------- */
#content-wrapper.account {
  padding: 0;
}

#content-wrapper.account > #content > .card_account {
  margin: 20px 0 0 0;
  padding: 0;
}

#content-wrapper.account #notifications > .container {
  padding: 0 !important;
}

/* Direcciones */
#addresses .card_account > .addresses {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

#addresses .card_account > .addresses .card_address {
  padding: 0 10px;
  width: calc(33.3% - 3px);
  border: solid 1px var(--color-primary);
}

#addresses .card_account > .addresses .card_address .address {
  margin: 0;
}

#addresses .card_account > .addresses-footer {
  margin: 20px 0 0 0;
}

/* Cupones descuento */
#discount #content table {
  margin-top: var(--spaces-md);
  border: solid 1px var(--color-primary);
}

#discount #content table > thead th {
  background-color: var(--color-primary);
  color: var(--color-white);
}

#discount #content table th,
#discount #content table td {
  text-align: center !important;
}

#discount .cart-rules {
  margin-top: var(--spaces-md);
}

#discount .cart-rules .cart-rule > ul {
  padding: var(--spaces-sm) var(--spaces-md);
  border: solid 1px var(--color-primary);
}

/* Mis pedidos */
#history .order_history {
  border: 1px solid var(--color-primary);
}

#history .order_history .history_info .title {
  font-size: var(--font-md);
}

#history .order_history .history_info .value {
  font-weight: 500;
}

/* Detalles del pedido */
#order-detail #content-wrapper span {
  font-size: var(--font-md) !important;
}

#order-detail .order_info > span:first-child {
  margin-right: var(--spaces-md);
}

#order-detail .order_resume .box {
  margin-top: calc(var(--spaces-md) * 2);
  padding: 0;
}

#order-detail .order-items .order-item .desc {
  margin: 0;
}

#order-detail .order-items .order-item,
#order-detail .messages,
#order-detail .order-message-form {
  margin: calc(var(--spaces-md) * 2) 0 0 0 !important;
  padding: calc(var(--spaces-md) * 2) 0 0 0 !important;
  border-top: solid 1px var(--color-grey-border);
}

#order-detail .order-items .order-item a:hover {
  color: var(--color-black);
}

/* Mis datos personales */
#module-psgdpr-gdpr #content > .items {
  margin-top: var(--spaces-md);
}

#module-psgdpr-gdpr #content > .items .item {
  border: solid 1px var(--color-primary);
}

#module-psgdpr-gdpr #content > .items .item:last-child {
  margin: 0;
}

/* Lista de deseos */
#module-blockwishlist-lists .wishlist-container-header {
  margin-top: var(--spaces-md);
}

#module-blockwishlist-lists .wishlist-container-header .wishlist-add-to-new {
  display: flex;
  align-items: center;
  opacity: 1;
  color: var(--color-black) !important;
}

#module-blockwishlist-lists .wishlist-container-header .wishlist-add-to-new:hover {
  color: var(--color-primary) !important;
}

#module-blockwishlist-lists #content-wrapper #content {
  padding: 0;
  margin: 0;
  box-shadow: none;
}

#module-blockwishlist-lists #content-wrapper #content li {
  border: solid 1px var(--color-primary);
}

#module-blockwishlist-lists #content-wrapper #content li:not(:first-child) {
  margin-top: var(--spaces-sm);
}

#module-blockwishlist-lists #content-wrapper #content a {
  padding: var(--spaces-md);
  transition: 0.3s;
}

#module-blockwishlist-lists #content-wrapper #content a:hover {
  background-color: var(--color-grey-border);
}

#module-blockwishlist-lists #content-wrapper #content a p {
  color: var(--color-black) !important;
}

#module-blockwishlist-lists #content-wrapper #content a div button:hover {
  opacity: 1;
}

#module-blockwishlist-lists #content-wrapper #content a div button i {
  transition: 0.3s;
}

#module-blockwishlist-lists #content-wrapper #content a div button:hover i {
  color: var(--color-primary);
}

#module-blockwishlist-lists #content-wrapper #content .dropdown-menu {
  position: absolute;
  right: 40px;
  top: 35px;
  z-index: 9;
}

#module-blockwishlist-lists #content-wrapper #content .dropdown-menu > * {
  padding: var(--spaces-xs) 15px;
}

/* Modal lista de deseos */
.wishlist-modal .modal-header button {
  outline: none;
}

.wishlist-modal .modal-body .wishlist-list-item {
  margin-bottom: 0 !important;
}

/* Detalles lista de deseos */
#view .wishlist-products-container {
  margin-bottom: var(--spaces-md);
}

#view .wishlist-products-container > div h1,
#view .wishlist-products-container > #content {
  margin: 0 !important;
  box-shadow: none;
}

#view .wishlist-products-container > div .sort-by-row,
#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-image p,
#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-combinations > a,
#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-availability {
  display: none;
}

#view .wishlist-products-container .wishlist-list-empty {
  padding: var(--spaces-md) 0;
  text-align: start;
  font-weight: 500;
}

#view .wishlist-products-container ul {
  padding: 0;
  margin: 0;
  justify-content: flex-start;
  gap: 6px;
}

#view .wishlist-products-container ul li {
  margin: 0;
  width: calc(25% - calc(18px / 4));
}

#view .wishlist-products-container ul li > .wishlist-product {
  max-width: none;
  border: solid 1px var(--color-grey-border);
}

#view .wishlist-products-container ul li > .wishlist-product > a:hover .wishlist-product-image img {
  transform: translate(-50%, -50%);
}

#view .wishlist-products-container ul li > .wishlist-product > a:hover .wishlist-product-title {
  color: var(--color-primary);
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-image {
  width: auto;
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-image img {
  opacity: 1;
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-title {
  margin-top: var(--spaces-sm);
  padding: 0 var(--spaces-sm) !important;
  height: auto !important;
  text-align: center !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  font-size: var(--font-md) !important;
  color: var(--color-black);
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  text-overflow: ellipsis;
  overflow: hidden;
  transition: 0.3s;
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-price {
  margin: var(--spaces-sm) 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-price:has(span) {
  color: var(--color-red);
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-price > span {
  margin: 0;
  font-weight: 400;
  font-size: var(--font-md) !important;
  color: var(--color-grey) !important;
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-combinations {
  padding: 0 var(--spaces-sm);
  justify-content: center;
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-combinations > p {
  min-height: auto;
  text-align: center;
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-bottom .wishlist-product-addtocart {
  background-color: var(--color-primary);
  color: var(--color-white);
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-bottom {
  margin-top: var(--spaces-sm);
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-bottom .wishlist-product-addtocart:hover {
  background-color: var(--color-black);
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-bottom .wishlist-button-add {
  padding: 0 !important;
  width: auto !important;
  height: auto !important;
  min-width: auto !important;
  top: 20px;
  right: 20px;
  box-shadow: none !important;
  background-color: transparent !important;
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-bottom .wishlist-button-add:hover {
  opacity: 1;
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-bottom .wishlist-button-add i {
  transition: 0.3s;
}

#view .wishlist-products-container ul li > .wishlist-product .wishlist-product-bottom .wishlist-button-add:hover i {
  color: var(--color-primary);
}

#view .wishlist-footer-links,
#view .wishlist-footer-links > a i {
  margin: 0;
}

#view .wishlist-footer-links > a:last-child {
  display: none;
}

/* ---------------------- CONTACTO ---------------------- */
#contact #wrapper > .container,
#cms:has(.block-cms) #wrapper > .container {
  width: 100%;
  padding: 0 !important;
}

#contact #wrapper > .container #content {
  padding: 0 !important;
  margin: 0;
}

#contact .block-contact,
#cms .block-cms {
  padding: 0;
  position: relative;
}

#contact .block-contact .contact-cover img,
#cms .block-cms .cms-cover img {
  width: 100%;
  height: 300px;
  object-fit: cover;
}

#contact .block-contact .shadow,
#cms .block-cms .shadow {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #00000052;
}

#contact .block-contact .contact-text,
#cms .block-cms .cms-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

#contact .contact-form {
  padding: 0;
}

#contact .contact-form form {
  padding: 40px;
  margin-top: -200px;
  position: relative;
  background-color: var(--color-white);
  box-shadow: 0px 10px 50px 0px #22222212;
}

#contact .contact-form form .form-fields > .title {
  color: var(--color-black);
  font-size: 45px;
  font-weight: 600;
  font-family: var(--font-title);
  text-transform: uppercase;
  word-break: break-word;
  line-height: normal;
}

#contact .contact-form form .form-fields > .subtitle {
  font-size: var(--font-md);
}

#contact .contact-form form .form-fields > .form-group .form-control-label {
  margin-bottom: var(--spaces-xs);
}

#contact .contact-form form .form-fields > .form-group.file label:hover {
  background-color: var(--color-black);
  color: var(--color-white);
}

/* -------------------- INICIAR SESIÓN ------------------ */
#authentication #content,
#registration #content,
#password #content {
  margin: 0 auto !important;
  padding: 40px 20px 0 20px;
  max-width: 640px;
}

body.page-customer-account .auth-title {
  margin-bottom: 30px;
  font-family: var(--font-title);
  font-weight: 600;
  text-transform: uppercase;
  text-align: center;
}

#authentication #content-wrapper #content .no-account a {
  font-size: var(--font-sm) !important;
}

#authentication #content-wrapper #content > hr {
  margin: 30px 0 var(--spaces-md) 0;
}

/* ---------------------- REGISTRO ---------------------- */
#registration #content-wrapper #content .register-form .custom-checkbox span:not(.form_required),
#identity #content-wrapper #content form .custom-checkbox span:not(.form_required) {
  height: 14px;
  width: 14px;
  position: relative;
  margin-right: 2px;
  vertical-align: sub;
}

#registration #content-wrapper #content .register-form .custom-checkbox span i,
#identity #content-wrapper #content form .custom-checkbox span i {
  font-size: 8px !important;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
}

#registration #content-wrapper #content .register-form .custom-checkbox *,
#identity #content-wrapper #content form .custom-checkbox * {
  font-size: var(--font-xs) !important;
}

/* ----------------- PASSWORD RECOVERY ------------------ */
#password #content > form .form-group .form-footer > button {
  width: 100%;
  height: auto;
  margin: 15px 0 0 0;
}

body.page-customer-account .back-login {
  margin-top: var(--spaces-md);
  width: fit-content;
  display: flex;
  align-items: center;
  gap: var(--spaces-xs);
}

body.page-customer-account .back-login * {
  font-size: var(--font-sm) !important;
  line-height: 1;
}

#password .ps-alert-success {
  padding: 0;
}

/* ------------------ PASSWORD RESET -------------------- */
#password #content > form .renew-password > .email {
  margin-bottom: var(--spaces-md);
  text-align: center;
}

#password #content > form .renew-password > .container-fluid > .form-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

#password #content > form .renew-password > .container-fluid > .form-group label {
  margin: 0;
  padding-left: 0;
}

#password #content > form .renew-password > .container-fluid > .form-group > div {
  padding-right: 0;
}

#password #content > form .renew-password > .container-fluid > .form-group:last-child > div {
  margin-top: var(--spaces-md);
  width: 100%;
}

#password #content > form .renew-password > .container-fluid > .form-group button {
  width: 100%;
}

/* ----------------------- MARCAS ----------------------- */
#manufacturer #main > ul {
  margin: var(--spaces-md) -3px 0 -3px;
  justify-content: flex-start;
}

#manufacturer #main > ul .brand {
  height: -webkit-fill-available;
  margin: 3px;
  width: calc(20% - 6px);
  min-width: auto;
  border-color: var(--color-primary);
}

#manufacturer #main > ul .brand .brand-img {
  width: auto;
  max-width: 200px;
}

#manufacturer #main > ul .brand span {
  color: var(--color-black);
  transition: 0.3s;
}

#manufacturer #main > ul .brand:hover span {
  color: var(--color-primary);
}

#manufacturer #main > ul .brand .brand-img span img {
  width: 100%;
}

#manufacturer #main #js-product-list-top {
  margin: 0 0 32px 0;
}

#manufacturer #main #js-product-list-top .sort-by-row {
  width: 100%;
}

/* ------------------------ CMS ------------------------- */
#cms .block-cms {
  margin-bottom: 40px;
}

#cms #content {
  margin: 0 auto !important;
  max-width: var(--width-container);
}

#cms:has(.block-cms) #content {
  padding: 0 var(--spaces-md);
}

#cms:has(.block-cms) #content * {
  text-align: center;
}

#cms #content > h2 {
  margin-top: 30px;
  font-size: 20px;
  font-weight: 500;
  text-transform: uppercase;
}

#cms #content > h2:has(+ ul.list) {
  margin: var(--separator-sections) 0 var(--spaces-md) 0;
}

#cms #content > h2:first-child {
  margin-top: 0;
}

#cms #content > h3 {
  font-size: 18px;
}

#cms:has(.block-cms) #content ul.list {
  margin-bottom: var(--separator-sections);
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--spaces-md);
}

#cms:has(.block-cms) #content ul.list li {
  width: calc(25% - 15px);
  list-style: none;
  display: flex;
  flex-direction: column;
}

#cms:has(.block-cms) #content ul.list li b {
  margin-bottom: var(--spaces-sm);
  padding: var(--spaces-xs) var(--spaces-sm);
  background-color: var(--color-primary);
  color: var(--color-white);
}

#cms:has(.block-cms) #content .imgs {
  margin-bottom: var(--separator-sections);
  display: flex;
  flex-wrap: wrap;
  gap: var(--spaces-sm);
}

#cms:has(.block-cms) #content .imgs > img {
  width: calc(50% - var(--spaces-xs));
  object-fit: cover;
}

/* ------------------ 404 NOT FOUND --------------------- */
#pagenotfound #content,
#js-product-list.not-found #content {
  margin: 0 auto 0 0 !important;
  padding-left: 0;
}

#pagenotfound #content h4,
#js-product-list.not-found #content h4 {
  color: var(--color-black);
}

/* -------------------- RESPONSIVE ---------------------- */
@media (max-width: 1600px) {
  /* ---------------------- HEADER ---------------------- */
  /* Menú modal */
  #_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown,
  #_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu {
    max-width: calc(100dvw / 3 - calc(40px / 3));
  }

  /* ---------------------- HOME ------------------------ */
  /* Sobre nosotros */
  #seo-home .container {
    padding: 0 !important;
  }

  #seo-home .top .content {
    padding: 40px;
  }
}

@media (max-width: 1199px) {
  /* ---------------------- HEADER ---------------------- */
  /* Buscador */
  #header .container #search_widget form,
  #header #search_widget_mobile form {
    width: 100%;
  }

  /* Buscador - Modal */
  #content_search .result_searchbar #js-product-list .products > div {
    width: calc(25% - 7.5px);
  }

  /* Menú modal */
  #_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown {
    left: -20px;
    height: calc(100dvh + 40px);
    max-width: 420px !important;
  }

  #_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .pos-sub-inner {
    height: 100%;
  }

  #_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .pos-sub-inner > .row > .pos-menu-col:not(:has(ul.visible)) {
    height: calc(100dvh - 180px);
    overflow-y: auto;
  }

  #_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .pos-sub-inner > .row > .pos-menu-col > ul {
    height: auto;
    min-height: auto;
    max-height: unset;
    overflow: clip;
  }

  #_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu {
    max-width: 420px !important;
    left: 0;
    z-index: 9;
  }

  header:not(.fixed) #_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu {
    height: calc(100% + 73px) !important;
  }

  header:not(.fixed) #_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu,
  #_desktop_megamenu .menu-content .menu-item.open-modal > .menu-dropdown .submenu-item .category-sub-menu > div {
    height: calc(100dvh - 180px);
  }

  /* --------------------- FOOTER ----------------------- */
  /* Logo - SEO */
  #footer .footer-container .center .links:has(.logo_seo) {
    margin-right: 30px;
  }

  #footer .footer-container .center .logo_seo {
    padding-right: 45px;
  }

  /* ---------------------- HOME ------------------------ */
  /* Categorías interactivas */
  #interactive-categories .categories-container .category .category-info {
    width: 220px;
  }

  #interactive-categories .categories-container .category .category-info img {
    max-height: 130px;
  }

  /* ---------------------- MARCAS ---------------------- */
  #manufacturer #main > ul .brand {
    width: calc(25% - 6px);
  }
}

@media (max-width: 991px) {
  /* ---------------------- HEADER ---------------------- */
  #header {
    position: sticky;
    top: 0;
    z-index: 999;
  }

  #header,
  #header > .headerCont {
    height: 82px;
  }

  /* Topbar */
  #header .topbar {
    display: none;
  }

  /* Buscador - Modal */
  #content_search .result_searchbar #js-product-list .products > div {
    width: calc(calc(100% / 3) - calc(var(--spaces-md) / 3));
  }

  /* --------------------- FOOTER ----------------------- */
  /* Logo - SEO */
  #footer .footer-container .center .links:has(.logo_seo) {
    margin: 0 !important;
    padding: 0;
    width: 100%;
  }

  #footer .footer-container .center .logo_seo {
    padding-right: 0;
    align-items: center;
    gap: 40px;
    border: none;
  }

  /* Links */
  #footer .footer-container .center .links {
    width: calc(100% / 3);
    text-align: center;
    float: left;
  }

  #footer .footer-container .links .title {
    justify-content: center;
  }

  /* Contacto - Métodos de pago*/
  #footer .footer-container .bottom {
    margin-top: var(--separator-sections);
  }

  #footer .footer-container .bottom .links {
    width: 50% !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    float: left;
  }

  #footer .footer-container .bottom .links .contact {
    align-items: center;
  }

  #footer .footer-container .bottom .links .payment {
    justify-content: center;
  }

  /* ---------------------- HOME ------------------------ */
  /* Carrusel imágenes */
  #index #carousel {
    left: 0;
    width: auto;
    background-color: transparent;
  }

  /* Reassurance */
  #blockreassurancehome .item {
    padding: 20px 40px;
    width: 100%;
    justify-content: center;
    border-right: none;
    border-bottom: solid 1px var(--color-white);
  }

  #blockreassurancehome .item:last-child {
    padding: 20px 40px 40px 40px;
  }

  /* Texto SEO */
  #custom-text .cont {
    max-width: 100%;
    margin: 0 40px;
  }

  /* Categorías interactivas */
  #interactive-categories .categories-container .category .category-info {
    width: 200px;
  }

  #interactive-categories .categories-container .category .category-info img {
    max-height: 120px;
  }

  #interactive-categories .categories-container .category .category-info > a {
    padding: var(--spaces-xs) var(--spaces-sm);
  }

  /* --------------------- PRODUCTO --------------------- */
  #product .product_topview {
    margin-top: 40px;
  }

  /* Left - Imágenes */
  #product .block_left #content .product-view_content > .product-images-container {
    display: none;
  }

  /* Right - Info prod. */
  #product .block_right {
    margin-top: 60px;
    padding: 0;
  }

  /* --------------------- CARRITO ---------------------- */
  /* Bloque derecha */
  #cart .cart-grid > .right {
    margin-top: calc(var(--spaces-md) * 2);
    padding: 0;
  }

  /* -------------------- CHECKOUT ---------------------- */
  #opc_step_cart {
    display: none;
  }

  /* --------------- SUBAPARTADOS MI CUENTA ------------- */
  /* Direcciones */
  #addresses .card_account > .addresses .card_address {
    width: calc(50% - 3px);
  }

  /* Detalles lista de deseos */
  #view .wishlist-products-container ul li {
    width: calc(33.33% - 4px);
  }

  /* ---------------------- MARCAS ---------------------- */
  #manufacturer #main #products .products > div {
    width: 50%;
  }

  /* ----------------------- CMS ------------------------ */
  #cms:has(.block-cms) #content ul.list li {
    width: calc(50% - 10px);
  }
}

@media (max-width: 767px) {
  /* ---------------------- HEADER ---------------------- */
  #header,
  #header > .headerCont {
    height: 142px;
  }

  /* Buscador - Modal */
  #content_search .result_searchbar #js-product-list .products > div {
    width: calc(50% - var(--spaces-xs));
  }

  /* Buscador móvil */
  #header #search_widget_mobile {
    padding: var(--spaces-sm) var(--spaces-md);
    border-bottom: solid 1px var(--color-grey-border);
  }

  #header #search_widget_mobile input[type="text"] {
    height: 40px;
    border: solid 1px var(--color-primary) !important;
  }

  /* Menú modal (móvil) */
  #menu-modal .modal-dialog {
    margin-top: 142px !important;
  }

  #menu-modal .modal-content {
    height: calc(100% - 142px);
  }

  #menu-modal #modal-menu,
  #menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .submenu-item .category-sub-menu {
    height: calc(100dvh - 142px) !important;
    top: 0;
    z-index: 9;
  }

  #menu-modal #_desktop_megamenu .menu-content {
    height: calc(100dvh - 142px);
  }

  #menu-modal #_desktop_megamenu .menu-content li.open-modal {
    height: calc(100dvh - 398px); /* 398px -> Altura header + bottom menú */
  }

  #menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .submenu-item .category-sub-menu > div {
    height: calc(100dvh - 141px) !important;
  }

  /* --------------------- FOOTER ----------------------- */
  /* Links */
  #footer .footer-container .links > .title.hidden-sm-down {
    display: flex !important;
  }

  #footer .footer-container .links > .title.hidden-md-up {
    display: none;
  }

  #footer .footer-container .links .collapse {
    display: block;
  }

  /* ---------------------- HOME ------------------------ */
  /* Categorías destacadas */
  #index .homecategories .categories .category {
    padding: 5px;
  }

  #index .homecategories .categories .category a img,
  #index .homecategories .categories .category a .shadow {
    height: 300px;
  }

  /* Sobre nosotros */
  #seo-home .image img {
    max-height: 300px;
  }

  #seo-home .bottom .container {
    flex-direction: column-reverse;
  }

  /* Banners home - categoría */
  #banners-home .banners,
  #banners-category .banners {
    flex-direction: column;
  }

  #banners-home .banners .banner,
  #banners-category .banners .banner {
    width: 100%;
  }

  #banners-home .banners .banner img,
  #banners-category .banners .banner img,
  #banners-home .banners .banner .shadow,
  #banners-category .banners .banner .shadow {
    height: 300px;
  }

  #banners-home .banners .banner .info,
  #banners-category .banners .banner .info {
    padding: 0 var(--spaces-md);
    width: 100%;
  }

  /* -------------------- CATEGORÍA --------------------- */
  /* Top categoria (Imagen - Nombre - Breadcrumb) */
  #category .block-category .category-text h1,
  #contact .block-contact .contact-text h1 {
    font-size: 75px;
  }

  /* Filtros */
  #js-product-list-top > div {
    width: 50%;
  }

  /* Modal filtros */
  #filters_category .modal-body #search_filters .facet .facet-title {
    padding: 0 0 10px 0 !important;
    font-weight: 500;
  }

  /* -------------- CONFIRMACIÓN DE PEDIDO -------------- */
  #order-confirmation #wrapper #content #order-details + div {
    padding: 0;
  }

  /* -------------------- MI CUENTA --------------------- */
  #tabs-account > .tab-content .tab-pane a .link-item i {
    min-width: 45px !important;
    width: auto;
  }

  /* --------------- SUBAPARTADOS MI CUENTA ------------- */
  /* Direcciones */
  #addresses .card_account > .addresses .card_address {
    width: 100%;
  }

  /* Detalles lista de deseos */
  #view .wishlist-products-container ul li {
    width: calc(50% - 3px);
  }

  #view .wishlist-products-container ul li > .wishlist-product a {
    flex-direction: column;
  }

  #view .wishlist-products-container ul li > .wishlist-product a > div {
    width: 100% !important;
    text-align: center;
  }

  #view .wishlist-products-container ul li > .wishlist-product .wishlist-product-bottom .wishlist-button-add {
    position: absolute;
  }

  /* ---------------------- MARCAS ---------------------- */
  #manufacturer #main > ul .brand {
    width: calc(33.33% - 6px);
  }

  /* ----------------------- CMS ------------------------ */
  #cms:has(.block-cms) #content .imgs > img {
    width: 100%;
  }
}

@media (max-width: 543px) {
  /* --------------------- GENERAL ---------------------- */
  .product-miniature .product-description .add button {
    padding: var(--spaces-sm);
  }

  /* ---------------------- HEADER ---------------------- */
  /* Menú móvil - Logo */
  #header .container .logoMenuCont a img {
    max-width: 120px;
  }

  /* Menú modal (móvil) */
  #menu-modal .modal-dialog {
    margin-top: 142px !important;
    width: 100%;
  }

  #menu-modal .modal-content,
  #menu-modal #modal-menu,
  #menu-modal #_desktop_megamenu .menu-content,
  #menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .submenu-item .category-sub-menu,
  #menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .submenu-item .category-sub-menu > div {
    height: calc(100dvh - 65px) !important;
  }

  #menu-modal #_desktop_megamenu .menu-content li.open-modal .menu-dropdown .submenu-item .category-sub-menu {
    max-width: 100% !important;
  }

  /* Buscador - Modal */
  #content_search .result_searchbar #js-product-list .products > div .product-miniature .product-flags {
    display: none;
  }

  /* Iconos */
  #header .container #iconosHeader {
    gap: calc(var(--spaces-md));
  }

  #header .container #iconosHeader > a {
    display: none;
  }

  /* --------------------- FOOTER ----------------------- */
  /* Logo - SEO */
  #footer .footer-container .center .logo_seo {
    padding-bottom: 0;
  }

  /* Links */
  #footer .footer-container .bottom {
    margin: 0 !important;
  }

  #footer .footer-container .center .links,
  #footer .footer-container .bottom .links {
    margin-top: 40px !important;
    width: 100% !important;
  }

  /* Copyright - RRSS */
  #footer .copyright .copyright_content {
    flex-direction: column-reverse;
    align-items: center;
    gap: var(--spaces-md);
  }

  /* ---------------------- HOME ------------------------ */
  /* Categorías interactivas */
  #interactive-categories .categories-container .category .category-info {
    width: 150px;
  }

  #interactive-categories .categories-container .category .category-info img {
    max-height: 100px;
  }

  #interactive-categories .categories-container .category .category-info > a {
    font-size: var(--font-sm) !important;
  }

  /* -------------------- CATEGORÍA --------------------- */
  /* Filtros */
  #category #js-product-list-top {
    gap: 20px;
  }

  #category #js-product-list-top::after {
    display: none;
  }

  #js-product-list-top > div {
    width: 100%;
  }

  #js-product-list-top .filtros,
  #js-product-list-top .products-sort-order {
    display: flex;
    justify-content: center;
  }

  /* --------------------- PRODUCTO --------------------- */
  /* Atributos */
  #product .block_right .product-actions .product-variants > div .control-label {
    min-width: 100px;
  }

  /* Cantidad - Add to cart - Wishlist */
  #product .block_right .product_add_to_cart {
    margin-bottom: 110px;
  }

  #product .block_right .product_add_to_cart .product-add-to-cart .product-quantity {
    width: 100%;
  }

  #product .block_right .wishlist-button-add {
    left: 0;
    top: unset;
    bottom: -70px;
  }

  /* -------------------- MI CUENTA --------------------- */
  #tabs-account > .tab-content .tab-pane a {
    width: 100%;
  }

  /* --------------- SUBAPARTADOS MI CUENTA ------------- */
  /* Detalles del pedido */
  #order-detail .order_actions .oactions {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spaces-sm);
  }

  /* Detalles lista de deseos */
  #view .wishlist-products-container ul li {
    width: 100%;
  }

  /* Mis datos personales */
  #module-psgdpr-gdpr #content > .items .item a {
    margin-right: 0;
    margin-left: 0;
    width: 100%;
  }

  /* ----------------- PASSWORD RESET ------------------- */
  #password #content > form .renew-password > .container-fluid > .form-group > div {
    padding: var(--spaces-xs) 0 0 0;
  }

  /* ---------------------- MARCAS ---------------------- */
  #manufacturer #main > ul .brand {
    width: calc(50% - 6px);
  }

  #manufacturer #main #js-product-list-top {
    margin: 32px 0;
  }

  /* ----------------------- CMS ------------------------ */
  #cms:has(.block-cms) #content ul.list li {
    width: 100%;
  }
}
