/*
 * Custom code goes here.
 * A template should always ship with an empty custom.css
 */

/* @import url('https://fonts.googleapis.com/css2?family=Comic+Neue:ital,wght@0,300;0,400;0,700;1,300;1,400;1,700&display=swap'); */

:root {
  --color-primary: #616907;
  --color-secondary: #bc2421;
  --color-accent: #ffcc18;
  --color-white: #e2e1cf;
  --color-black: #3a270f;

  --color-primary-light: #d8e061;
  --color-secondary-light: #bf413f;
  --color-accent-light: #f5da77;
  --color-white-light: #f5f4e5;
  --color-black-light: #645748;

  --color-primary-dark: #63690b;
  --color-secondary-dark: #5e1211;
  --color-accent-dark: #b39011;
  --color-white-dark: #a09f93;
  --color-black-dark: #120c05;

  --color-validation: var(--color-primary);
  --color-error: var(--color-secondary);
}

/* Fix horizontal overflow caused by Bootstrap row negative margins */
html,
body {
  overflow-x: clip;
  max-width: 100vw;
  background-color: var(--color-white);

  /* scroll to anchor */
  scroll-behavior: smooth;
  scroll-padding-top: 220px;
}

@media (max-width: 767px) {
  html,
body {
  scroll-padding-top: 110px;

}
}

.row {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* More specific selectors for rows */
section#wrapper>.container>.row,
#footer>.container>.row,
#footer .footer-container .container .row {
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding: 0;
}

/* Fix super long scroll for no reason */
main {
  overflow: clip;
}

/* 
* Navigation bar 
*/

/* Top bar */
#header {
  background: transparent;
  color: var(--color-black-light);
  -webkit-box-shadow: none;
  box-shadow: none;
  /* Sticky header */
  position: sticky;
  top: 0;
  z-index: 800;
  transition: all 0.3s ease;
}

#header .header-nav {
  background: var(--color-white);
}

#header .header-nav div:has(> #menu-icon) {
  display: flex;
  padding: 0;
  padding-right: 12px;
}

#header .header-nav div:has(> #menu-icon) #_mobile_logo {
  width: 100%;
  padding: 2px;
}

#header .header-nav div:has(> #menu-icon) #_mobile_logo a {
  display: flex;
}

#header .header-nav div:has(> #menu-icon) #_mobile_logo img {
  height: 100%;
  aspect-ratio: 1;
}

#header .header-nav div:has(> #menu-icon) #_mobile_logo,
#header .header-nav div:has(> #menu-icon) #menu-icon {
  height: 42px;
  min-height: 42px;
}

#header .header-nav #menu-icon .material-icons {
  line-height: 42px;
}

#header .header-nav div:has(> #menu-icon) #_mobile_cart,
#header .header-nav div:has(> #menu-icon) #_mobile_user_info {
  height: fit-content;
  width: fit-content;
  flex: 0;
}


/* Logo size */
#_desktop_logo img {
  max-height: 80px;
  width: auto;
}

#_desktop_logo,
#_desktop_logo h1 {
  width: fit-content;
}

/* Offres Pro */
.header-nav .offres-pro {
  display: flex;
  align-items: center;
  padding: 8px;
}


/* Search */
#search_widget {
  width: 100%;
  max-width: 100%;
  margin: 0;
}

#search_widget form input {
  border-radius: 32px;
  color: var(--color-black);
}

.searchbar-autocomplete {
  padding: 12px 8px;
  border-radius: 18px;
  background: var(--color-white-light);
  -webkit-box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.11);
  box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.11);
}

#search_widget form .icon {
  position: absolute;
  padding: .5rem;
  height: 24px;
  width: 24px;
}

#search_widget form .icon.search {
  left: .2rem;
}

#search_widget form .icon.clear {
  right: 0.2rem;
}

#search_widget form .icon.search svg,
#search_widget form .icon.clear svg {
  height: 24px;
  width: 24px;

  fill: var(--color-black);
}

/* .searchbar-autocomplete li.ui-menu-item {} */

.searchbar-autocomplete li.ui-menu-item a {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 32px;
  border: solid 1px transparent;
  color: var(--color-black);
}

.searchbar-autocomplete li.ui-menu-item a:hover,
.ui-autocomplete.searchbar-autocomplete li a.ui-state-focus {
  background: var(--color-white);
  border: solid 1px var(--color-primary);
  padding: 8px 12px;
  border-radius: 32px;
}

.searchbar-autocomplete li.ui-menu-item a img.autocomplete-thumbnail {
  width: 40px;
  height: 40px;
  object-fit: cover;
  margin: 0;
  border-radius: 50%;
}

.searchbar-autocomplete li.ui-menu-item a span.product {
  font-size: 17px;
  line-height: 18px;
  color: var(--color-black);
  text-transform: lowercase;
  width: 100%;
}

.searchbar-autocomplete li.ui-menu-item a span.product::first-letter {
  text-transform: capitalize;
}

/* Notifications */
#notifications .notifications-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12px;
  margin: 0;
  width: 100%;
}

/* Header */
#header .header-top {
  padding: 0.875rem 0;
  background-color: var(--color-white-light);
  -webkit-box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.11);
  box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.11);
  transition: all 0.3s ease;
}

#header .header-nav #_desktop_contact_link {
  height: 44px;
  display: flex;
  align-items: center;
}

#header .header-nav #_desktop_contact_link #contact-link {
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

#header .header-nav #_desktop_contact_link #contact-link button {
  padding: .2rem 1rem;
}

#mobile_top_menu_wrapper .js-top-menu-bottom #contact-link {
  display: flex;
  justify-content: center;
  align-items: center;

  gap: 8px;
}

/* Pure CSS sticky header - works without JavaScript */
/* The header is already sticky with position: sticky above */

#wrapper {
  padding-top: 0;
  background: var(--color-white);
}

/* Menu */
#_desktop_top_menu {
  flex-grow: 0;
  flex-shrink: 0;
}

/* Disable click on menu item A propos */

#_desktop_top_menu .cms-category>.dropdown-item {
  pointer-events: none;
}

#header .top-menu a[data-depth='0'],
.top-menu a[data-depth='0'] {
  color: var(--color-black-light);
  text-transform: capitalize;
  font-size: 1.25rem;
}

#header .top-menu a[data-depth='0']:hover,
#header a:hover {
  color: var(--color-secondary);
  background: transparent;
  text-decoration: none !important;
}

/* Header search+menu container */
#header .header-top-right {
  flex: 1;
  display: flex;
  align-items: center;
}

/* Header submenus next to search */
#top-menu {
  margin: 0;
}

#top-menu>li {
  position: relative;
}

#top-menu>li:has(.popover)>a::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 13px;
  margin-left: 4px;
  /* adjust spacing as needed */
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='13' viewBox='0 0 12 13' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5.64645 8.94852C5.84171 9.14379 6.15829 9.14379 6.35355 8.94852L9.53553 5.76654C9.7308 5.57128 9.7308 5.2547 9.53553 5.05944C9.34027 4.86417 9.02369 4.86417 8.82843 5.05944L6 7.88786L3.17157 5.05944C2.97631 4.86417 2.65973 4.86417 2.46447 5.05944C2.2692 5.2547 2.2692 5.57128 2.46447 5.76654L5.64645 8.94852ZM5.5 7.59497V8.59497H6.5V7.59497H5.5Z' fill='%23000'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  /* align with text if needed */
}

#top-menu li ul {
  display: flex;
  flex-direction: column;
}

/* Hide submenu for category menus ("Nos produits") on desktop */
#_desktop_top_menu .top-menu[data-depth="0"] li.category:hover .sub-menu {
  display: none;
}

#_desktop_top_menu ul.top-menu li.category a::after {
  display: none;
}


#top-menu .popover.sub-menu {
  width: fit-content;
  z-index: 502;
  right: 0;
  margin: 0;
  left: unset;
  top: calc(100% + 8px) !important;
  background-color: var(--color-white-light);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.11);
  border: 1px solid var(--color-primary);
  border-radius: 24px;
  padding: 12px 8px;
  min-width: 100px;
  max-width: 300px;
}

.top-menu[data-depth="1"] {
  margin: 0;
}

#top-menu .popover.sub-menu li {
  margin: 0;
  padding: 0;
}

#top-menu .popover.sub-menu li a::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 100%;
  background-color: var(--color-primary);
  margin: 0 8px;
}

#top-menu .popover.sub-menu li a {
  margin: 0;
  padding: 4px 12px 4px 8px;
  text-decoration: none;
  transition: background-color 0.2s ease;
  border-radius: 24px;
  min-height: 40px;
  border: 1px solid transparent;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 4px;
  text-transform: none;
  font-size: 17.5px;
  line-height: 17.5px;
}

#top-menu .popover.sub-menu li a:hover {
  background-color: var(--color-white) !important;
  text-decoration: none;
  color: var(--color-black);
  border: 1px solid var(--color-primary);
}

/* product modal */

#product-modal .modal-content .modal-body .product-cover-modal,
.product-cover img {
  object-fit: none;
}

button.wishlist-button-add {
  background-color: var(--color-white-light);
  box-shadow: none;
}

button.wishlist-button-add i {
  color: var(--color-secondary);
}

.btn-comment,
.btn-comment-inverse {
  background-color: var(--color-white-light);
  color: var(--color-black-light);
  border: 1px solid var(--color-black-light);
  border-radius: 32px;
  box-shadow: none;
}

.btn-comment:hover,
.btn-comment-inverse:hover {
  background-color: var(--color-black-light);
  color: var(--color-white-light);
}

#empty-product-comment {
  background-color: var(--color-white);
}

.product-flags {
  list-style: none;
}

.product-flags li.product-flag.out_of_stock {
  background: var(--color-secondary-light);
  width: unset;
  width: fit-content;
}

.product-flags li.product-flag.on-sale {
  border-radius: 0 0 32px 32px;
  background: var(--color-white-light);
  color: var(--color-secondary);
  width: 80%;
  align-self: center;
}

.product-flags li.product-flag:not(.on-sale) {
  margin-left: 12px;
}

.done {
  padding: 0 0.625rem;
  margin-right: 1.563rem;
}

/* Cart quantity update animation */
.cart-quantity-updating {
  animation: cart-quantity-pulse 1s ease-in-out infinite;
}

@keyframes cart-quantity-pulse {

  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.3;
  }
}

/* Manufacturer ("Producteurs" cards)  */
#manufacturer #main ul .brand {
  background: var(--color-white-light);
  border-radius: 32px;
  padding: 4px;
  margin: 0;
  width: 258px;
  min-width: unset;
}

@media (max-width: 767px) {
  #manufacturer #main ul .brand {
    width: 160px
  }
}

#manufacturer #main ul .brand:hover {
  -webkit-box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.2);
  box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.2);
}

#manufacturer #main ul .brand .brand-img {
  width: 100%;
  aspect-ratio: 1/1;
}

#manufacturer #main ul .brand .brand-img a,
#manufacturer #main ul .brand .brand-img a img {
  width: 100%;
  /* height: 200px; */
  object-fit: cover;
  border-radius: 32px 32px 0 0;
}

#manufacturer #main ul .brand .brand-infos {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 8px;
  gap: 8px;
  height: 100px;
}

#manufacturer #main ul .brand .brand-infos p {
  margin: 0;
  font-size: 11px;
  line-height: 14px;
  color: var(--color-black-light);
}

#manufacturer #main ul .brand .brand-infos p:last-child {
  height: 28px;
}

#manufacturer #main ul .brand .brand-infos a {
  font-size: 17px;
  line-height: 18px;
  color: var(--color-black);
}

/* Make the body full width */

section#wrapper>.container {
  width: 100% !important;
  max-width: 100%;
  padding: 8px 5% 8px 5%;
}

@media (max-width: 767px) {
  section#wrapper>.container {
    padding: 0;
  }
}


/* Modal */
.modal,
.modal-open {
  overflow: unset;
}

/* Add to cart modal */

.lpdy-modal-dialog .lpdy-modal-body {
  background: transparent;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.lpdy-modal-dialog {
  width: 100%;
  display: flex;
  justify-content: center;
  padding: 32px;
}

.lpdy-modal-dialog .row {
  display: flex;
  flex-direction: row;
  gap: 24px;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}

.lpdy-modal-dialog .column {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 180px;
}

.lpdy-modal-dialog .row::after {
  content: none;
}

.lpdy-modal-dialog .lpdy-modal-content {
  display: flex;
  flex-direction: column;
  width: fit-content;
  background: var(--color-white-light);
  border-radius: 32px;
  padding: 24px 32px;
  gap: 24px;
}

.lpdy-modal-dialog .lpdy-modal-header h2 {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: center;
}

.lpdy-modal-dialog .lpdy-modal-header i.material-icons {
  margin-right: 0;
  color: var(--color-validation);
}

.lpdy-cart-recap {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: 24px 32px;
  background: var(--color-white);
  border-radius: 32px;
}

.lpdy-cart-recap .column {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}

.lpdy-cart-recap .column p {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}

.lpdy-cart-recap .column p.product-total {
  border-top: 1px solid var(--color-white-light);
  padding-top: 12px;
}

.lpdy-modal-dialog .lpdy-modal-content .btn.link {
  background: transparent;
  color: var(--color-secondary);
  font-weight: 600;
}

.lpdy-modal-dialog .lpdy-modal-content .btn.link:hover {
  background: transparent;
  color: var(--color-primary);
}

#blockcart-modal .lpdy-product-name {
  color: var(--color-primary);
}

#blockcart-modal .product-image {
  border-radius: 32px;
  width: 120px;
  height: 120px;
  margin: 0;
}

@media (max-width: 767px) {
  .lpdy-modal-content {
    padding: 12px;
  }

  .lpdy-modal-dialog .row {
    gap: 12px;
  }

  #blockcart-modal .product-image {
    width: 80px;
    height: 80px;
  }

  .lpdy-modal-body>.row>.row {
    flex-direction: row;
    flex-wrap: nowrap;
  }
}

/* Page Produits : dropdown de tri */
.products-sort-order .btn-unstyle.select-title {
  border-radius: 32px;
  padding-left: 16px;
  border: 1px solid var(--color-primary);
}


/* 
* Hide Capcha 
*/
.grecaptcha-badge {
  display: none;
}


/* 
 * Cards
*/
.card-title {
  margin: 0;
}

@media screen and (max-width: 767px) {
  .card-block {
    padding: 1.25rem 1.25rem .5rem;
  }
}

/* 
* Footer 
*/

#footer {
  padding-top: 0;
}

#footer>.container>.row {
  padding: 0;
}

#footer .footer-container {
  padding: 32px 5%;
  background-color: var(--color-white);
}

#footer .footer-container .container {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

#footer .footer-container li {
  margin-bottom: 0;
}

#footer .footer-container p {
  margin-bottom: 0;
}

.footer-links {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: 100%;
}

@media (max-width: 767px) {
  .footer-links {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 8px;
  }
}

#footer .footer-container .container .row {
  display: flex;
  flex-direction: row;
  justify-content: space-around;
}

#footer .cms-banner-alcohol {
  width: 100%;
  max-width: 500px;
  height: auto;
  margin: 0 auto;
  display: block;

  padding-top: 12px;
}

/* 
 * Page My Account
*/
#my-account #content .links {
  gap: 32px;
  justify-content: center;
  align-items: center;
}

@media (max-width:480px) {
  #my-account #content .links {
    gap: 12px;
  }
}

#my-account #content .links a {
  margin: 0;
  padding: 0;
  min-width: 140px;
  max-width: 400px;
  flex: 1 0 22%;
}

#my-account #content .links a .link-item {
  border-radius: 32px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
  justify-content: center;
  text-transform: capitalize;
  font-size: 17px;
  line-height: 18px;
  font-weight: 600;
  min-height: 150px;
}

/* Hide payment methods */
#my-account #sogecommerce-wallet-link {
  display: none;
}

/* Contact infos */
#block_contact_infos,
#block_contact_infos #contact-infos,
#block_contact_infos #contact-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0 !important;
}

#block_contact_infos #contact-logo img {
  width: 180px;
  height: 180px;
  min-width: 180px;
  min-height: 180px;
}

#block_contact_infos {
  flex-direction: row;
  justify-content: flex-start;
  width: 100%;
}

#block_contact_infos #contact-infos {
  flex-direction: column;
  align-items: flex-start;
  padding: 0 16px;
  gap: 4px;
}

#block_contact_infos #contact-infos .contact-item {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
}

#block_contact_infos #contact-infos .contact-item a,
#block_contact_infos #contact-infos .contact-item span {
  font-size: 16px;
  line-height: 17px;
}

#block_contact_infos #contact-infos .contact-item:hover a {
  color: var(--color-secondary);
}


#block_contact_infos #contact-infos .contact-item .contact-icon,
#block_contact_infos .contact-social .social-link {
  height: 32px;

  stroke: var(--color-primary);
  fill: transparent;
}

#block_contact_infos #contact-infos .contact-item:hover .contact-icon,
#block_contact_infos .contact-social .social-link:hover {
  stroke: var(--color-secondary);
  fill: transparent;
}

/* Block links */
#footer .footer-container .links:not(#block_contact_infos),
#block_myaccount_infos {
  display: flex;
  width: fit-content;
  min-width: 150px;
}

#footer .footer-container .links .h3 {
  font-size: 17px;
  line-height: 18px;
}

#footer .footer-container .links:not(#block_contact_infos) div,
#footer .footer-container .links:not(#block_contact_infos) ul {
  display: flex;
  width: 100%;
  text-align: center;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 0;
  margin: 0 !important;
}

#block_myaccount_infos {
  flex-direction: column;
  text-align: center;
  gap: 12px;
  justify-content: center;
}

#block_myaccount_infos ul {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  margin: 0;
}

#footer .footer-container .links:not(#block_contact_infos) div.wrapper {
  flex-direction: column;
  gap: 12px;
}

#footer .footer-container .links:not(#block_contact_infos) #footer_sub_menu_2,
#footer .footer-container .links:not(#block_contact_infos) #footer_account_list {
  flex-direction: column;
  gap: 2px;
}

@media (max-width: 767px) {
  /* Adjust footer */
  #footer .footer-container>.container>.row {
    flex-wrap: wrap;
  }

  #footer .footer-container .links#block_contact_infos {
    flex-direction: column;

    justify-content: center;
    align-items: center;
    gap: 32px;
    width: 100%;
  }

  #footer .footer-container>.container>.row:first-child>div#block_myaccount_infos,
  #footer .footer-container>.container>.row:first-child>div.links {
    width: 49%;
    padding-top: 16px;
    padding-bottom: 16px;
  }

  #block_contact_infos #contact-logo img {
    width: 100px;
    height: 100px;
    min-width: 100px;
    min-height: 100px;
  }

  #footer .links .float-xs-right {
    display: none;
  }

  #footer .container {
    width: 100%;
  }

  .footer-container .links ul>li {
    padding: 0;
    border-bottom: none;
    font-weight: 400;
  }


  .footer-container .links ul {
    background-color: var(--color-white);
  }

  .footer-container .links ul>li a {
    color: var(--color-black);
  }

  .footer-container .links ul>li a:hover {
    color: var(--color-secondary);
  }

  .footer-container .hidden-sm-down {
    display: block !important;
  }

  .footer-container .hidden-md-up {
    display: none !important;
  }

  .links .title {
    border-bottom: none;
  }

  .footer-container .links .h3 {
    /* Should be an h4 */
    font-size: 17px;
    line-height: 22px;
    margin-bottom: 0;
  }
}

/* 
* Subcategories section
*/
.block-category {
  width: 100%;
  margin: 0;
  min-height: 0;
  z-index: 50;
  position: relative;
  display: flex;
}

.block-category .block-category-inner {
  padding: 12px 8px;
  gap: 18px;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  width: 0;
  flex-grow: 1;
}

.block-category .block-category-inner .subcategory-item a {
  padding: 8px 12px 8px 8px;
  background: var(--color-white-light);
  display: flex;
  flex-direction: row;
  gap: 4px;
  align-items: center;
  justify-content: center;
  border-radius: 24px;
  font-size: 17px;
  line-height: 18px;
  color: var(--color-black);
  border: solid 1px transparent;
  flex-shrink: 0;
}

.block-category .block-category-inner .subcategory-item a:hover {
  border: solid 1px var(--color-primary);
  background: var(--color-white);
}

.block-category .block-category-inner .subcategory-item .category-icon-placeholder {
  margin: 4.5px;
}

/* Hide for category "Nos Produits" on desktop */
body.category-nos-produits .block-category {
  display: none;
}

@media (max-width: 767px) {
  body.category-nos-produits .block-category {
    display: flex;
  }
}


/* Category bar */
/* Category Bar Styles - Prepared for sticky header */
.category-bar {
  padding: 12px 0;
  position: relative;
  z-index: 500;

  background: linear-gradient(360deg, rgba(226, 225, 207, 0) 0%, rgba(226, 225, 207, 1) 60%, rgba(226, 225, 207, 1) 100%);
  /* Future: Add these when making header sticky
  position: sticky;
  top: 0;
  background-color: rgba(245, 245, 240, 0.95);
  backdrop-filter: blur(10px);
  */
}

#header .category-bar a:hover {
  border: 1px solid var(--color-primary);
  background-color: var(--color-white);
  color: var(--color-black);
}

.category-menu-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
}

.category-menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 4px;
  overflow: visible;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.category-menu-item {
  position: relative;
  flex-shrink: 0;
}

.category-menu-link {
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: var(--color-black);
  padding: 4px 12px 4px 8px;
  border-radius: 32px;
  transition: all 0.3s ease;
  white-space: nowrap;
  background-color: var(--color-white-light);
  gap: 4px;
  min-height: 40px;
  border: 1px solid transparent;
}

.category-menu-link:hover,
.category-menu-item:hover .category-menu-link {
  color: var(--color-black);
  text-decoration: none;
  background-color: var(--color-white);
  border: 1px solid var(--color-primary);
}

.category-icon-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.category-icon {
  width: 24px;
  height: 24px;
  object-fit: cover;
}

.category-icon-placeholder {
  width: 8px;
  height: 8px;
  background-color: var(--color-primary);
  border-radius: 50%;
  display: block;
}

/* Pure CSS Submenu - No JavaScript needed */
.submenu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--color-white-light);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.11);
  border: 1px solid var(--color-primary);
  border-radius: 24px;
  padding: 12px 8px;
  min-width: 200px;
  max-width: 300px;
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%) translateY(-10px);
  transition: all 0.3s ease;
  z-index: 501;
  /* Prevent overflow issues */
  white-space: nowrap;
}

/* Right-align submenu if it's one of the last items */
.category-menu-item:nth-last-child(-n+2) .submenu {
  left: auto;
  right: 0;
  transform: translateY(-10px);
}

.category-menu-item:nth-last-child(-n+2):hover .submenu {
  transform: translateY(0);
}

.category-menu-item:hover .submenu {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.submenu-level-1 {
  list-style: none;
  margin: 0;
  padding: 0;
}

.submenu-item {
  position: relative;
  white-space: nowrap;
}

.submenu-link {
  display: block;
  padding: 4px 12px 4px 8px;
  text-decoration: none;
  transition: background-color 0.2s ease;
  white-space: nowrap;
  border-radius: 24px;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 4px;
  border: 1px solid transparent;
}

a.submenu-link:hover {
  background-color: var(--color-white) !important;
  text-decoration: none;
  color: var(--color-black);
  border: 1px solid var(--color-primary);
}

/* Level 2 Submenu */
.submenu-level-2 a {
  padding-left: 24px;
}





/* Mobile-specific adjustments */
@media (max-width: 767px) {
  #header .header-top {
    padding: 0.5rem 0;
    /* Slightly smaller on mobile */
  }

  #_desktop_logo img {
    max-height: 60px;
    /* Smaller logo on mobile */
  }

  .category-bar {
    display: none !important;
  }

  /* Adjust custom dropdown styling to use classic style on mobile */
  #top-menu .popover.sub-menu {
    width: 100%;
    right: auto !important;
    left: auto !important;
    margin: 0 !important;
    max-width: none !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }

  #top-menu .popover.sub-menu ul.top-menu {
    width: 100%;
  }

  #top-menu .popover.sub-menu li a::before {}

  #top-menu .popover.sub-menu li a {
    padding: 8px 12px;
    margin: 0;
    background: none;
    border: none;
    position: relative;
    /* flex-direction: row-reverse;
    justify-content: flex-end; */
  }

  #top-menu>li:has(.popover)>a::after {
    display: none;
  }

  #top-menu .popover.sub-menu li a:has(span) {
    /* justify-content: space-between; */
  }

  #top-menu .popover.sub-menu li a span {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
  }

  #mobile_top_menu_wrapper .top-menu .sub-menu ul[data-depth="2"] li a {
    padding-left: 24px;
  }

  /* #top-menu .popover.sub-menu li a:hover {
    background-color: #f5f5f5 !important;
    border: none !important;
    color: #333 !important;
  } */

  /* Adjust "sort by" menu on product list on mobile */
  .row.sort-by-row {
    width: 100%;
  }
}





/* 
* Errors 
*/

#content.page-not-found {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 24px;
  width: 100%;
}

#content.page-not-found .row {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 24px;
  width: 100%;
}


#content.page-content.page-not-found {
  max-width: unset !important;
}

.page-header:has(.not-found-icon) h1 {
  text-align: center;
}

.not-found-icon {
  width: fit-content;
  margin: auto;
  display: flex;
}

.form-group.has-error .help-block {
  color: var(--color-error);
  margin: 0;
}

.form-group.has-error .help-block>ul {
  padding: 0;
  margin: 0;
}













/* 
* Alerts
*/

/* 
* Base Alert Styles
*/

.alert {
  border: none;
  margin: 0;
  font-size: 14px;
  line-height: 15px;
  font-weight: 600;
  border-radius: 32px;
  padding: 8px 20px;
}

.alert hr {
  margin: 10px 0;
  opacity: 0.3;
}


/* 
* Alert Variants
*/

/* Success Alert */
.alert-success {
  background: transparent;
  color: var(--color-validation);
}

.alert-success .alert-link {
  color: var(--color-validation);
  text-decoration: underline;
}

/* Info Alert */
.alert-info {
  background-color: var(--color-white-light);
  border-color: var(--color-white-light);
  color: var(--color-validation);
}

.alert-info hr {
  border-top-color: #a6d5ec;
}

.alert-info .alert-link {
  color: var(--color-error);
  text-decoration: underline;
}

/* Warning Alert */
.alert-warning {
  background-color: rgba(255, 154, 82, 0.3);
  border-color: #ff9a52;
  color: var(--color-black);
}

.alert-warning hr {
  border-top-color: #ff8b39;
}

.alert-warning .alert-link {
  color: var(--color-black);
  text-decoration: underline;
}

/* Danger Alert */
.alert-danger {
  background: transparent;
  color: var(--color-error);
}

.alert-danger hr {
  border-top-color: #e4b9b9;
}

.alert-danger .alert-link {
  color: var(--color-error);
  text-decoration: underline;
}


/* 
* PrestaShop Alert Components
*/

.ps-alert-error,
.ps-alert-success {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;

  border-radius: 32px;
  padding: 0;
  margin: 0;
}

/* Base PS Alert Item */
.ps-alert-error .item,
.ps-alert-success .item {
  border: 1px solid;
  border-radius: 32px;
  padding: 12px 8px;
  margin: 0;

  width: fit-content;

  gap: 12px;
}

/* PS Error Alert */
.ps-alert-error .item {
  background-color: var(--color-white-light);
  border-color: var(--color-error);
}

/* PS Success Alert */
.ps-alert-success .item {
  background-color: var(--color-white-light);
  border-color: var(--color-validation);
}

.ps-alert-success .item i {
  border: 0;
  background: var(--color-validation);
  border-radius: 32px;
  padding: 4px;
}

.ps-alert-error .item i {
  background: var(--color-error);
}

.ps-alert-success .item i svg,
.ps-alert-error .item i svg {
  background-color: transparent;
  fill: var(--color-validation)
}

.ps-alert-error .item i svg {
  background: var(--color-error);
}

/* PS Alert Content */
.ps-alert-error .item p,
.ps-alert-error .item ul,
.ps-alert-success .item p,
.ps-alert-success .item ul,
.page-content.page-cms .ps-alert-error .item ul,
.page-content.page-cms .ps-alert-success .item ul {
  padding: 0;
  margin: 0;
  border-radius: 32px;

  background-color: transparent;
}

.ps-alert-error .item ul,
.ps-alert-success .item ul {
  padding-left: 30px;
  list-style-type: disc;
}












/* 
* Forms
*/

/* Base Form Control Styles */
.form-control {
  display: block;
  width: 100%;
  font-size: 16px;
  line-height: 17px;
  padding: 8px 16px;
  border-radius: 32px;
  border: 1px solid var(--color-primary);
  background: var(--color-white);
  color: var(--color-black);
  background-clip: padding-box;
  appearance: none;
  -webkit-appearance: none;
  margin: 0;
}

.form-control:focus {
  outline: none;
  border-color: var(--color-primary);
  color: var(--color-black);
  background-color: var(--color-white-light);
}

.form-control:disabled,
.form-control[readonly] {
  background-color: var(--color-white);
  opacity: 1;
}

/* Input Group Styles */
.input-group .form-control:not(:last-child) {
  border-radius: 32px;
}

/* Textarea Specific */
textarea.form-control {
  background: var(--color-white);
  resize: vertical;
}

/* Select Specific */
select.form-control {
  height: unset;
}

select.form-control:focus::-ms-value {
  color: var(--color-black-light);
  background-color: var(--color-white-light);
}

/* Placeholder Styles */
.form-control::-webkit-input-placeholder,
.form-control::-moz-placeholder,
.form-control:-ms-input-placeholder,
.form-control::-ms-input-placeholder,
.form-control::placeholder {
  color: var(--color-black-light);
  opacity: 1;
}

/* Input & Textarea Base (for non-.form-control elements) */
input,
textarea {
  font-size: 16px;
  line-height: 17px;
}

input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder,
input::-moz-placeholder,
textarea::-moz-placeholder,
input:-ms-input-placeholder,
textarea:-ms-input-placeholder,
input:-moz-placeholder,
textarea:-moz-placeholder,
input::placeholder {
  color: var(--color-black-light);
}


.custom-checkbox label {
  font-weight: 400;
}

/* Form Group Layout - Base Styles */
.form-group.row {
  display: flex;
  flex-direction: column;
  margin: 0;
  width: 100%;
  gap: 4px;
  margin-bottom: 0;
  padding: 0;
}

.form-group.row>div {
  display: flex;
  flex-direction: column;
  width: 100%;
  padding: 0;
}

.form-group.row>.form-control-label {
  width: 100%;
  padding: 0 16px;
}


form .form-control-label {
  color: var(--color-black);
  margin: 0;
}

.form-group.row input,
input,
.block_newsletter form input[type='email'],
.form-group.row select,
select,
.form-group.row textarea,
textarea {
  padding: 8px 16px;
  border-radius: 32px;
  border: 1px solid var(--color-primary);
  background: var(--color-white);
  color: var(--color-black);
  font-size: 16px;
  line-height: 17px;
}

.form-group.row input:focus,
input:focus,
.form-group.row select:focus,
select:focus,
.block_newsletter form input[type='email']:focus,
.form-group.row textarea:focus,
textarea:focus {
  color: var(--color-black);
  background: var(--color-white-light);
  outline: 2px var(--color-primary) solid;
}

/* Clear default form-group after elements */
.form-group::after {
  display: none;
}

/* Input Group with Button */
.form-group .input-group {
  gap: 12px;
  align-items: center;
}

.form-group .input-group>.input-group-btn {
  padding: 4px 12px;
  font-size: 14px;
  line-height: 15px;
  border-radius: 32px;
  background: var(--color-primary);
  height: fit-content;
}

.form-group .input-group>.input-group-btn .btn {
  padding: 0;
  background-color: transparent;
}

/* Form Layout Containers */
.form-fields,
form {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  width: 100%;
}

.form-section {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}


form .form-fields,
form .form-section,
form .form-footer {
  max-width: 620px;
}

/* Hide form control comments by default */
form .form-group .form-control-comment {
  display: none;
}

/* Required Field Indicators */
.form-control-label.required::after {
  content: " *";
  color: var(--color-error);
}

/* 
* Validation States 
*/

/* Success State */
.has-success .custom-control,
.has-success .form-check-inline,
.has-success .form-check-label,
.has-success .form-control-feedback,
.has-success .form-control-label {
  color: var(--color-validation);
}

.has-success .form-control {
  border-color: var(--color-validation);
}

.has-success .form-control:focus {
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #96d7a9;
}

.has-success .input-group-addon {
  color: var(--color-validation);
  border-color: var(--color-validation);
  background-color: #e0f3e5;
}

.has-success .form-control-success {
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 8 8%27%3E%3Cpath fill=%27var(--color-validation)%27 d=%27M2.3 6.73L.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z%27/%3E%3C/svg%3E');
}

/* Warning State */
.has-warning .custom-control,
.has-warning .form-check-inline,
.has-warning .form-check-label,
.has-warning .form-control-feedback,
.has-warning .form-control-label {
  color: #ff9a52;
}

.has-warning .form-control {
  border-color: #ff9a52;
}

.has-warning .form-control:focus {
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ffd6b8;
}

.has-warning .input-group-addon {
  color: #ff9a52;
  border-color: #ff9a52;
  background-color: var(--color-white-light);
}

.has-warning .form-control-warning {
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 8 8%27%3E%3Cpath fill=%27%23ff9a52%27 d=%27M4.4 5.324h-.8v-2.46h.8zm0 1.42h-.8V5.89h.8zM3.76.63L.04 7.075c-.115.2.016.425.26.426h7.397c.242 0 .372-.226.258-.426C6.726 4.924 5.47 2.79 4.253.63c-.113-.174-.39-.174-.494 0z%27/%3E%3C/svg%3E');
}

/* Error/Danger State */
.has-danger .custom-control,
.has-danger .form-check-inline,
.has-danger .form-check-label,
.has-danger .form-control-feedback,
.has-danger .form-control-label {
  color: var(--color-error);
}

.has-danger .form-control {
  border-color: var(--color-error);
}

.has-danger .form-control:focus {
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ffb2b2;
}

.has-danger .input-group-addon {
  color: var(--color-error);
  border-color: var(--color-error);
  background-color: var(--color-white-light);
}

.has-danger .form-control-danger {
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 fill=%27var(--color-error)%27 viewBox=%27-2 -2 7 7%27%3E%3Cpath stroke=%27%23d9534f%27 d=%27M0 0l3 3m0-3L0 3%27/%3E%3Ccircle r=%27.5%27/%3E%3Ccircle cx=%273%27 r=%27.5%27/%3E%3Ccircle cy=%273%27 r=%27.5%27/%3E%3Ccircle cx=%273%27 cy=%273%27 r=%27.5%27/%3E%3C/svg%3E');
}

/* Disabled/Readonly Form Elements */
.form-check.disabled .form-check-label {
  color: var(--color-black-light);
  cursor: not-allowed;
}

.form-check-inline.disabled {
  color: var(--color-black-light);
  cursor: not-allowed;
}



/* Pages Legals */

#mentions-legales.flex-section>.flex-column,
#cgv.flex-section>.flex-column,
#cgu.flex-section>.flex-column {
  max-width: 1140px;
  align-items: flex-start;
  text-align: start;
}

@media (max-width: 767px) {
  #mentions-legales>.flex-column {
    width: 100%;
  }
}











/* ========================================
   TIMELINE SECTION
   ======================================== */

.timeline-section-full {
  width: 100%;
  max-width: 100%;

  padding: 0;
  margin: 0;
}

.timeline-section-full>h2:first-child {
  padding: 64px 0 0 0;
}

.timeline-section-full>p,
.timeline-section-full>h2 {
  text-align: center;

  padding: 0 24px;
}

/* Intro text */
.timeline-intro {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 20px 20px;
  text-align: center;
}

/* Visual timeline container */
.timeline-visual {
  position: relative;
  width: 100%;
  margin: 40px auto 0;
}

/* Visual timeline container */
.timeline-content {
  position: relative;
  width: 100%;
  padding: 0 18% 60px;
}

/* Bandeau phases avec proportions correctes */
.timeline-phases-bar {
  display: flex;
  width: 100%;
  margin-bottom: -5px;
  position: relative;
  z-index: 2;
}

.phase-zone {
  padding: 18px 40px;
  text-align: center;
  font-weight: 600;
  font-size: 1.05rem;
  letter-spacing: 0.3px;
  border-radius: 32px 32px 0 0;

}

/* 5 jours sur 8 = 62.5% */
.phase-commande {
  flex: 0 0 62.5%;
  background: var(--color-white-light);
  color: var(--color-black);
}

/* 3 jours sur 8 = 37.5% */
.phase-livraison {
  flex: 0 0 37.5%;
  background: var(--color-primary);
  color: var(--color-white-light);
}

/* Container SVG ligne ondulée */
.timeline-wave-svg {
  width: 100%;
  height: 148px;
  background-image: url('data:image/svg+xml;utf8,<svg width="1440" height="148" viewBox="0 0 1440 148" fill="none" xmlns="http://www.w3.org/2000/svg" preserveAspectRatio="none"><path d="M1630.2 36.7281C1630.2 36.7281 1457.69 35.3449 1315.12 35.2304C1280.4 35.2025 1229.83 106.623 1226.22 35.2304C1222.6 -36.1625 1196.48 35.2304 1177.42 35.2304C804.39 35.2304 259.313 36.7281 222.211 35.2304C185.109 33.7326 184.386 143.568 161.499 143.568C121.202 143.568 145.357 35.2304 72.1165 36.7281L-190.203 35.2304" stroke="%23A0AA10" stroke-width="7" stroke-linecap="round" stroke-linejoin="round"/></svg>');
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-position: center;
  position: absolute;
  margin-top: 28px;
}

/* Animation de la ligne */
.timeline-wave-svg::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: inherit;
  animation: drawLine 2.5s ease-in-out forwards;
  clip-path: inset(0 100% 0 0);
}

@keyframes drawLine {
  to {
    clip-path: inset(0 0 0 0);
  }
}

/* Markers container - 8 jours espacés uniformément */
.timeline-markers {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  position: relative;
  z-index: 3;
}

.timeline-marker {
  flex: 0 1 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  animation: markerFadeIn 0.6s ease-out forwards;
  opacity: 0;
  width: calc(100% / 7);
  /* 8 points = 7 espaces entre */
}

/* Premier et dernier marker collés aux bords */
.timeline-marker:first-child {
  margin-left: -30px;
}

.timeline-marker:last-child {
  margin-right: -30px;
}

/* Points */
.marker-dot {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--color-primary);
  border: 5px solid var(--color-white-light);
  display: block;
  margin-bottom: 20px;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.2);
  animation: dotPop 0.5s ease-out forwards;
  transform: scale(0);
  position: relative;
  z-index: 2;
}

.marker-dot-red {
  background: var(--color-secondary);
}

/* Labels - seulement pour certains jours */
.marker-label {
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--color-black);
  display: block;
  margin-bottom: 10px;
  min-height: 30px;
  /* Réserve l'espace même si pas de label */
}

.marker-label-red {
  color: var(--color-secondary);
  font-weight: 700;
  font-size: 1.25rem;
}

/* Note spéciale mardi */
.marker-special {
  position: relative;
}

.marker-note {
  display: block;
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--color-secondary);
  text-align: left;
  position: absolute;
  top: 110%;
  left: 65%;
  width: 300px;
}

.marker-note strong {
  color: var(--color-secondary);
  font-weight: 700;
}

/* Flèche de connexion */
.marker-note::before {
  content: url('data:image/svg+xml,<svg width="22" height="20" viewBox="0 0 22 20" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M0.873535 0.060791C0.873535 0.060791 -0.445631 10.7686 1.87354 16.5608C3.86652 21.5383 20.8735 16.5608 20.8735 16.5608" stroke="%23BC2421"/></svg>');
  position: absolute;
  top: -15%;
  left: -5%;
  transform: translateX(-50%);
  width: fit-content;
}

/* Animations */
@keyframes markerFadeIn {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes dotPop {
  0% {
    transform: scale(0);
  }

  60% {
    transform: scale(1.3);
  }

  100% {
    transform: scale(1);
  }
}

/* Délais d'animation pour les 8 jours */
.timeline-marker:nth-child(1) {
  animation-delay: 0.2s;
}

.timeline-marker:nth-child(1) .marker-dot {
  animation-delay: 0.4s;
}

.timeline-marker:nth-child(2) {
  animation-delay: 0.4s;
}

.timeline-marker:nth-child(2) .marker-dot {
  animation-delay: 0.6s;
}

.timeline-marker:nth-child(3) {
  animation-delay: 0.6s;
}

.timeline-marker:nth-child(3) .marker-dot {
  animation-delay: 0.8s;
}

.timeline-marker:nth-child(4) {
  animation-delay: 0.8s;
}

.timeline-marker:nth-child(4) .marker-dot {
  animation-delay: 1s;
}

.timeline-marker:nth-child(5) {
  animation-delay: 1s;
}

.timeline-marker:nth-child(5) .marker-dot {
  animation-delay: 1.2s;
}

.timeline-marker:nth-child(6) {
  animation-delay: 1.2s;
}

.timeline-marker:nth-child(6) .marker-dot {
  animation-delay: 1.4s;
}

.timeline-marker:nth-child(7) {
  animation-delay: 1.4s;
}

.timeline-marker:nth-child(7) .marker-dot {
  animation-delay: 1.6s;
}

.timeline-marker:nth-child(8) {
  animation-delay: 1.6s;
}

.timeline-marker:nth-child(8) .marker-dot {
  animation-delay: 1.8s;
}

/* ========================================
   RESPONSIVE
   ======================================== */

@media (max-width: 1200px) {
  .marker-dot {
    width: 18px;
    height: 18px;
    border: 4px solid var(--color-white-light);
  }
}

@media (max-width: 992px) {
  .timeline-wave-svg {
    height: 80px;
    margin-top: 58px;
  }

  .timeline-intro h2 {
    font-size: 1.75rem;
  }

  .timeline-intro p {
    font-size: 0.95rem;
  }

  .phase-zone {
    padding: 15px 30px;
    font-size: 0.95rem;
  }

  .marker-label {
    font-size: 1rem;
  }

  .marker-label-red {
    font-size: 1.1rem;
  }
}

@media (max-width: 768px) {

  .timeline-wave-svg {
    height: 80px;
    margin-top: 28px;
  }

  .timeline-intro {
    padding: 30px 15px 15px;
  }

  .timeline-intro h2 {
    font-size: 1.5rem;
  }

  .phase-commande,
  .phase-livraison {
    flex: 1 1 auto;
  }

  .phase-zone {
    padding: 12px 20px;
    font-size: 0.9rem;
  }

  .timeline-marker {
    width: 100%;
  }

  .timeline-marker:first-child,
  .timeline-marker:last-child {
    margin: 0;
  }

  .marker-dot {
    width: 18px;
    height: 18px;
    margin-bottom: 15px;
  }

  .marker-note {
    width: 300px;
  }
}

@media (max-width: 480px) {
  .timeline-content {
    padding: 0 16px 60px;
  }

  .marker-note {
    width: 200px;
    left: 0;
  }

  .marker-note::before {
    display: none;
  }

  .timeline-wave-svg {
    background-image: url('data:image/svg+xml,<svg width="963" height="8" viewBox="0 0 963 8" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M3.50006 3.5001C40.6021 4.99785 585.679 3.5001 958.714 3.5001" stroke="%23A0AA10" stroke-width="7" stroke-linecap="round" stroke-linejoin="round"/></svg>');
    height: 80px;
    margin-top: 30px;
  }

  .timeline-intro h2 {
    font-size: 1.3rem;
  }

  .timeline-intro p {
    font-size: 0.9rem;
  }

  .marker-label {
    font-size: 0.95rem;
  }
}









/**
 * ========================================
 * LPDY MODALS
 * ========================================
 */

/* Base modal structure */
.lpdy-modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.lpdy-modal.lpdy-modal-visible {
  display: flex;
  opacity: 1;
  pointer-events: all;
}

.lpdy-modal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5);
  transition: background 0.3s ease;
}

.lpdy-modal-content {
  position: relative;
  background: var(--color-white);
  border-radius: 12px;
  max-width: 90%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
  z-index: 1;
}

.lpdy-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--color-white);
  padding: 15px 20px;
}

.lpdy-modal-title {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-black);
  text-transform: none;
}

.lpdy-modal-close {
  background: none;
  border: none;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
  color: var(--color-black-light);
  padding: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  border-radius: 4px;
}

.lpdy-modal-close:hover {
  background: rgba(0, 0, 0, 0.1);
  color: var(--color-black);
}

.lpdy-modal-body {
  padding: 16px;
}

/* Cookie consent modal - bottom-left positioned, higher z-index */
.lpdy-modal-legal {
  z-index: 1001;
  align-items: flex-end;
  justify-content: flex-start;
}

.lpdy-modal-legal.lpdy-modal-visible {
  pointer-events: none;
}

.lpdy-modal-legal .lpdy-modal-overlay {
  background: transparent;
  pointer-events: none;
}

.lpdy-modal-legal .lpdy-modal-content {
  max-width: 450px;
  margin: 0 0 24px 24px;
  pointer-events: all;
}

.lpdy-modal-legal .lpdy-modal-title {
  font-size: 1.15rem;
}

.lpdy-modal-legal .lpdy-modal-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 8px 16px;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .lpdy-modal-content {
    max-width: 95%;
  }

  .lpdy-modal-legal {
    align-items: flex-end;
    justify-content: center;
  }

  .lpdy-modal-legal .lpdy-modal-content {
    max-width: 100%;
    width: 100%;
    margin: 0;
    border-radius: 12px 12px 0 0;
  }
}

/**
 * LPDY Cookie Consent Component Styles
 */

/* Cookie preferences section */
.lpdy-cookie-preferences {
  margin-top: 12px;
}

/* Cookie categories container */
.lpdy-cookie-categories {
  display: flex;
  flex-direction: column;
  gap: 12px;
  text-align: start;
}

/* Individual category */
.lpdy-cookie-category {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* Category header with checkbox */
.lpdy-cookie-category-header {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.lpdy-cookie-category-header.lpdy-required {
  cursor: default;
}

.lpdy-cookie-category-header input[type="checkbox"] {
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: var(--color-primary);
  flex-shrink: 0;
}

.lpdy-cookie-category-header.lpdy-required input[type="checkbox"] {
  cursor: not-allowed;
}

.lpdy-cookie-category-header strong {
  flex: 1;
}

/* "Always active" badge */
.lpdy-cookie-badge {
  font-size: 0.7rem;
  background: var(--color-primary);
  color: white;
  padding: 2px 8px;
  border-radius: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Category description */
.lpdy-cookie-category-body p {
  margin: 0;
  font-size: 0.85rem;
  color: #666;
  padding-left: 24px;
}

/* Action buttons */
.lpdy-cookie-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 16px;
}

/* Persistent floating cookie settings button */
.lpdy-cookie-floating-btn {
  position: fixed;
  bottom: 24px;
  left: 24px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--color-white);
  border: 2px solid var(--color-primary);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  cursor: pointer;
  z-index: 9997;
  font-size: 24px;
  display: none;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  padding: 0;
}

.lpdy-cookie-floating-btn.lpdy-visible {
  display: flex;
}

.lpdy-cookie-floating-btn:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
  background: var(--color-white-light);
}

.lpdy-cookie-floating-btn:active {
  transform: scale(0.95);
}

.lpdy-cookie-links {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;

  gap: 32px;
  flex-wrap: wrap;
  padding: 8px 0;
}

/* =============================================================================
   MAP PLACEHOLDER (COOKIE CONSENT)
   ============================================================================= */

.lpdy-map-placeholder {
  width: 100%;
  min-height: 600px;
  background: var(--color-white);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  border: 2px solid var(--color-white-light);
}

.lpdy-map-placeholder-content {
  text-align: center;
  max-width: 500px;
}

.lpdy-map-icon {
  color: var(--color-primary);
  margin: 0 auto 1.5rem;
  opacity: 0.8;
}

.lpdy-map-placeholder h3 {
  font-size: 1.75rem;
  margin-bottom: 1rem;
  color: var(--color-black);
}

.lpdy-map-placeholder p {
  font-size: 1.125rem;
  color: var(--color-black);
  line-height: 1.6;
  margin-bottom: 2rem;
}

.lpdy-map-placeholder .btn {
  margin-top: 0.5rem;
  font-size: 1.125rem;
  padding: 0.75rem 2rem;
}

/* Responsive */
@media (max-width: 768px) {
  .lpdy-cookie-checkboxes {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 12px;
  }

  .lpdy-cookie-actions {
    flex-direction: column;
    gap: 8px;
  }

  .lpdy-cookie-actions button {
    width: 100%;
  }

  .lpdy-cookie-categories {
    gap: 12px;
  }

  .lpdy-cookie-category {
    padding: 12px;
  }

  /* Floating button smaller on mobile */
  .lpdy-cookie-floating-btn {
    width: 44px;
    height: 44px;
    bottom: 16px;
    left: 16px;
    font-size: 20px;
  }
}

@media (max-width: 480px) {
  .lpdy-cookie-checkboxes {
    grid-template-columns: 1fr;
  }
}



/* Breadcrumbs */

#wrapper .breadcrumb {
  background-color: transparent;
  border-radius: 0;

  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;

  text-align: center;

  padding: 12px 32px;
  margin-bottom: 32px;
}

.breadcrumb-item+.breadcrumb-item::before {
  color: var(--color-white);
}

.breadcrumb-item.active {
  color: var(--color-white);
}


#wrapper .breadcrumb li:last-child {
  color: var(--color-black);
}

#wrapper .breadcrumb li a,
/* separator */
#wrapper .breadcrumb li::after {
  color: var(--color-black-light);
}






























/* Default style : 
 */

/*!
 * Bootstrap v4.0.0-alpha.5 (https://getbootstrap.com)
 * Copyright 2011-2016 The Bootstrap Authors
 * Copyright 2011-2016 Twitter, Inc.
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
 */
/*! normalize.css v4.2.0 | MIT License | github.com/necolas/normalize.css */

html {
  -webkit-tap-highlight-color: transparent;
}

mark {
  color: #000;
}

[type='button']:-moz-focusring,
[type='reset']:-moz-focusring,
[type='submit']:-moz-focusring,
button:-moz-focusring {
  outline: 1px dotted var(--color-white);
}

button:focus {
  outline: 1px solid var(--color-primary);
}

abbr[data-original-title],
abbr[title] {
  border-bottom: 1px dotted var(--color-white);
}

caption {
  color: var(--color-black-light);
}

.mark,
mark {
  background-color: #fcf8e3;
}

.blockquote {
  border-left: 0.25rem solid var(--color-white);
}

.blockquote-footer {
  color: var(--color-white);
}

.blockquote-reverse {
  border-right: 0.25rem solid var(--color-white);
  border-left: 0;
}

.img-thumbnail {
  background-color: var(--color-white-light);
  border: 1px solid var(--color-white-light);
  border-radius: 0;
}

.figure-caption {
  color: var(--color-white);
}

code {
  color: #bd4147;
  background-color: #f7f7f9;
}

kbd {
  color: var(--color-white-light);
  background-color: #333;
  border-radius: 0.2rem;
}

pre {
  color: #363a42;
}

.table td,
.table th {
  border-top: 1px solid var(--color-white);
}

.table thead th {
  border-bottom: 2px solid var(--color-white);
}

.table tbody+tbody {
  border-top: 2px solid var(--color-white);
}

.table .table {
  background-color: var(--color-white-light);
}

.table-bordered,
.table-bordered td,
.table-bordered th {
  border: 1px solid var(--color-white);
}

.table-striped tbody tr:nth-of-type(odd) {
  background-color: rgba(0, 0, 0, 0.05);
}

.table-active,
.table-active>td,
.table-active>th,
.table-hover .table-active:hover,
.table-hover .table-active:hover>td,
.table-hover .table-active:hover>th,
.table-hover tbody tr:hover {
  background-color: rgba(0, 0, 0, 0.075);
}

.table-success,
.table-success>td,
.table-success>th {
  background-color: #dff0d8;
}

.table-hover .table-success:hover,
.table-hover .table-success:hover>td,
.table-hover .table-success:hover>th {
  background-color: #d0e9c6;
}

.table-info,
.table-info>td,
.table-info>th {
  background-color: #d9edf7;
}

.table-hover .table-info:hover,
.table-hover .table-info:hover>td,
.table-hover .table-info:hover>th {
  background-color: #c4e3f3;
}

.table-warning,
.table-warning>td,
.table-warning>th {
  background-color: #fcf8e3;
}

.table-hover .table-warning:hover,
.table-hover .table-warning:hover>td,
.table-hover .table-warning:hover>th {
  background-color: #faf2cc;
}

.table-danger,
.table-danger>td,
.table-danger>th {
  background-color: #f2dede;
}

.table-hover .table-danger:hover,
.table-hover .table-danger:hover>td,
.table-hover .table-danger:hover>th {
  background-color: #ebcccc;
}

.table-inverse,
.thead-inverse th {
  color: var(--color-white-light);
  background-color: var(--color-primary);
}

.thead-default th {
  color: var(--color-black-light);
  background-color: var(--color-white);
}

.table-inverse {
  color: var(--color-white);
}

.table-inverse td,
.table-inverse th,
.table-inverse thead th {
  border-color: var(--color-black-light);
}

.table-reflow td,
.table-reflow th {
  border-top: 1px solid var(--color-white);
  border-left: 1px solid var(--color-white);
}

.table-reflow td:last-child,
.table-reflow th:last-child {
  border-right: 1px solid var(--color-white);
}

.table-reflow tbody:last-child tr:last-child td,
.table-reflow tbody:last-child tr:last-child th,
.table-reflow tfoot:last-child tr:last-child td,
.table-reflow tfoot:last-child tr:last-child th,
.table-reflow thead:last-child tr:last-child td,
.table-reflow thead:last-child tr:last-child th {
  border-bottom: 1px solid var(--color-white);
}

.table-reflow tr td,
.table-reflow tr th {
  display: block !important;
  border: 1px solid var(--color-white);
}

.has-danger .form-control-danger {
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 fill=%27var(--color-error)%27 viewBox=%27-2 -2 7 7%27%3E%3Cpath stroke=%27%23d9534f%27 d=%27M0 0l3 3m0-3L0 3%27/%3E%3Ccircle r=%27.5%27/%3E%3Ccircle cx=%273%27 r=%27.5%27/%3E%3Ccircle cy=%273%27 r=%27.5%27/%3E%3Ccircle cx=%273%27 cy=%273%27 r=%27.5%27/%3E%3C/svg%3E');
}

.btn-primary,
.btn-primary:hover {
  color: var(--color-white-light);
  background-color: var(--color-primary);
  border-color: transparent;
  border-radius: 32px;
  text-transform: none;
}

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

.btn-primary.focus,
.btn-primary:focus {
  color: var(--color-white-light);
  background-color: var(--color-secondary);
  border-color: transparent;
}

.btn-primary.active,
.btn-primary:active,
.open>.btn-primary.dropdown-toggle {
  color: var(--color-white-light);
  background-color: var(--color-secondary);
  border-color: transparent;
  background-image: none;
}

.btn-primary.active.focus,
.btn-primary.active:focus,
.btn-primary.active:hover,
.btn-primary:active.focus,
.btn-primary:active:focus,
.btn-primary:active:hover,
.open>.btn-primary.dropdown-toggle.focus,
.open>.btn-primary.dropdown-toggle:focus,
.open>.btn-primary.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: var(--color-secondary);
  border-color: transparent;
}

.btn-primary.disabled.focus,
.btn-primary.disabled:focus,
.btn-primary:disabled.focus,
.btn-primary:disabled:focus {
  background-color: var(--color-primary);
  border-color: transparent;
}

.btn-primary.disabled:hover,
.btn-primary:disabled:hover {
  background-color: var(--color-primary);
  border-color: transparent;
}

.btn-secondary {
  color: var(--color-black);
  background-color: var(--color-white);
  border-color: transparent;
  border-radius: 32px;
  text-transform: none;
}

.btn-secondary:hover {
  color: var(--color-black);
  background-color: var(--color-white-light);
  border-color: transparent;
}

.btn-tertiary {
  border-color: transparent;
  border-radius: 32px;
  text-transform: lowercase;
  font-weight: 400;
  color: var(--color-black-light);
  background-color: #f7f7f7;
}

.btn-tertiary:hover {
  color: var(--color-black);
  background-color: var(--color-white-light);
  border: 1px solid rgba(35, 35, 35, 0.2);
}

.btn-secondary.focus,
.btn-secondary:focus,
.btn-tertiary:focus,
.focus.btn-tertiary {
  color: var(--color-black);
  background-color: var(--color-white-light);
  border-color: transparent;
}

.active.btn-tertiary,
.btn-secondary.active,
.btn-secondary:active,
.btn-tertiary:active,
.open>.btn-secondary.dropdown-toggle,
.open>.dropdown-toggle.btn-tertiary {
  color: var(--color-black);
  background-color: var(--color-white-light);
  border-color: transparent;
  background-image: none;
}

.active.btn-tertiary:focus,
.active.btn-tertiary:hover,
.active.focus.btn-tertiary,
.btn-secondary.active.focus,
.btn-secondary.active:focus,
.btn-secondary.active:hover,
.btn-secondary:active.focus,
.btn-secondary:active:focus,
.btn-secondary:active:hover,
.btn-tertiary:active.focus,
.btn-tertiary:active:focus,
.btn-tertiary:active:hover,
.open>.btn-secondary.dropdown-toggle.focus,
.open>.btn-secondary.dropdown-toggle:focus,
.open>.btn-secondary.dropdown-toggle:hover,
.open>.dropdown-toggle.btn-tertiary:focus,
.open>.dropdown-toggle.btn-tertiary:hover,
.open>.dropdown-toggle.focus.btn-tertiary {
  color: var(--color-black);
  background-color: #cbcbcb;
  border-color: transparent;
}

.btn-secondary.disabled.focus,
.btn-secondary.disabled:focus,
.btn-secondary:disabled.focus,
.btn-secondary:disabled:focus,
.btn-tertiary:disabled.focus,
.btn-tertiary:disabled:focus,
.disabled.btn-tertiary:focus,
.disabled.focus.btn-tertiary {
  background-color: var(--color-white);
  border-color: transparent;
}

.btn-secondary.disabled:hover,
.btn-secondary:disabled:hover,
.btn-tertiary:disabled:hover,
.disabled.btn-tertiary:hover {
  background-color: var(--color-white);
  border-color: transparent;
}

.btn-info {
  color: var(--color-white-light);
  background-color: #5bc0de;
  border-color: #5bc0de;
}

.btn-info:hover {
  color: var(--color-white-light);
  background-color: #31b0d5;
  border-color: #2aabd2;
}

.btn-info.focus,
.btn-info:focus {
  color: var(--color-white-light);
  background-color: #31b0d5;
  border-color: #2aabd2;
}

.btn-info.active,
.btn-info:active,
.open>.btn-info.dropdown-toggle {
  color: var(--color-white-light);
  background-color: #31b0d5;
  border-color: #2aabd2;
  background-image: none;
}

.btn-info.active.focus,
.btn-info.active:focus,
.btn-info.active:hover,
.btn-info:active.focus,
.btn-info:active:focus,
.btn-info:active:hover,
.open>.btn-info.dropdown-toggle.focus,
.open>.btn-info.dropdown-toggle:focus,
.open>.btn-info.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: #269abc;
  border-color: #1f7e9a;
}

.btn-info.disabled.focus,
.btn-info.disabled:focus,
.btn-info:disabled.focus,
.btn-info:disabled:focus {
  background-color: #5bc0de;
  border-color: #5bc0de;
}

.btn-info.disabled:hover,
.btn-info:disabled:hover {
  background-color: #5bc0de;
  border-color: #5bc0de;
}

.btn-success {
  color: var(--color-white-light);
  background-color: var(--color-validation);
  border-color: var(--color-validation);
}

.btn-success:hover {
  color: var(--color-white-light);
  background-color: #3a9a56;
  border-color: #389252;
}

.btn-success.focus,
.btn-success:focus {
  color: var(--color-white-light);
  background-color: #3a9a56;
  border-color: #389252;
}

.btn-success.active,
.btn-success:active,
.open>.btn-success.dropdown-toggle {
  color: var(--color-white-light);
  background-color: #3a9a56;
  border-color: #389252;
  background-image: none;
}

.btn-success.active.focus,
.btn-success.active:focus,
.btn-success.active:hover,
.btn-success:active.focus,
.btn-success:active:focus,
.btn-success:active:hover,
.open>.btn-success.dropdown-toggle.focus,
.open>.btn-success.dropdown-toggle:focus,
.open>.btn-success.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: #318047;
  border-color: #256237;
}

.btn-success.disabled.focus,
.btn-success.disabled:focus,
.btn-success:disabled.focus,
.btn-success:disabled:focus {
  background-color: var(--color-validation);
  border-color: var(--color-validation);
}

.btn-success.disabled:hover,
.btn-success:disabled:hover {
  background-color: var(--color-validation);
  border-color: var(--color-validation);
}

.btn-warning {
  color: var(--color-white-light);
  background-color: #ff9a52;
  border-color: #ff9a52;
}

.btn-warning:hover {
  color: var(--color-white-light);
  background-color: #ff7c1f;
  border-color: #ff7615;
}

.btn-warning.focus,
.btn-warning:focus {
  color: var(--color-white-light);
  background-color: #ff7c1f;
  border-color: #ff7615;
}

.btn-warning.active,
.btn-warning:active,
.open>.btn-warning.dropdown-toggle {
  color: var(--color-white-light);
  background-color: #ff7c1f;
  border-color: #ff7615;
  background-image: none;
}

.btn-warning.active.focus,
.btn-warning.active:focus,
.btn-warning.active:hover,
.btn-warning:active.focus,
.btn-warning:active:focus,
.btn-warning:active:hover,
.open>.btn-warning.dropdown-toggle.focus,
.open>.btn-warning.dropdown-toggle:focus,
.open>.btn-warning.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: #fa6800;
  border-color: #d25700;
}

.btn-warning.disabled.focus,
.btn-warning.disabled:focus,
.btn-warning:disabled.focus,
.btn-warning:disabled:focus {
  background-color: #ff9a52;
  border-color: #ff9a52;
}

.btn-warning.disabled:hover,
.btn-warning:disabled:hover {
  background-color: #ff9a52;
  border-color: #ff9a52;
}

.btn-danger {
  color: var(--color-white-light);
  background-color: var(--color-error);
  border-color: var(--color-error);
}

.btn-danger:hover {
  color: var(--color-white-light);
  background-color: #ff1919;
  border-color: #ff0f0f;
}

.btn-danger.focus,
.btn-danger:focus {
  color: var(--color-white-light);
  background-color: #ff1919;
  border-color: #ff0f0f;
}

.btn-danger.active,
.btn-danger:active,
.open>.btn-danger.dropdown-toggle {
  color: var(--color-white-light);
  background-color: #ff1919;
  border-color: #ff0f0f;
  background-image: none;
}

.btn-danger.active.focus,
.btn-danger.active:focus,
.btn-danger.active:hover,
.btn-danger:active.focus,
.btn-danger:active:focus,
.btn-danger:active:hover,
.open>.btn-danger.dropdown-toggle.focus,
.open>.btn-danger.dropdown-toggle:focus,
.open>.btn-danger.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: #f40000;
  border-color: #c00;
}

.btn-danger.disabled.focus,
.btn-danger.disabled:focus,
.btn-danger:disabled.focus,
.btn-danger:disabled:focus {
  background-color: var(--color-error);
  border-color: var(--color-error);
}

.btn-danger.disabled:hover,
.btn-danger:disabled:hover {
  background-color: var(--color-error);
  border-color: var(--color-error);
}

.btn-outline-primary {
  color: var(--color-primary);
  background-image: none;
  background-color: transparent;
  border-color: var(--color-primary);
}

.btn-outline-primary:hover {
  color: var(--color-white-light);
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

.btn-outline-primary.focus,
.btn-outline-primary:focus {
  color: var(--color-white-light);
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

.btn-outline-primary.active,
.btn-outline-primary:active,
.open>.btn-outline-primary.dropdown-toggle {
  color: var(--color-white-light);
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

.btn-outline-primary.active.focus,
.btn-outline-primary.active:focus,
.btn-outline-primary.active:hover,
.btn-outline-primary:active.focus,
.btn-outline-primary:active:focus,
.btn-outline-primary:active:hover,
.open>.btn-outline-primary.dropdown-toggle.focus,
.open>.btn-outline-primary.dropdown-toggle:focus,
.open>.btn-outline-primary.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: var(--color-secondary);
  border-color: darken(var(--color-secondary), 10%);
}

.btn-outline-primary.disabled.focus,
.btn-outline-primary.disabled:focus,
.btn-outline-primary:disabled.focus,
.btn-outline-primary:disabled:focus {
  border-color: #79d6e8;
}

.btn-outline-primary.disabled:hover,
.btn-outline-primary:disabled:hover {
  border-color: #79d6e8;
}

.btn-outline-secondary,
.btn-outline-secondary:hover {
  background-color: transparent;
  border-color: transparent;
}

.btn-outline-secondary {
  color: transparent;
  background-image: none;
}

.btn-outline-secondary:hover {
  color: var(--color-white-light);
}

.btn-outline-secondary.focus,
.btn-outline-secondary:focus {
  color: var(--color-white-light);
  background-color: transparent;
  border-color: transparent;
}

.btn-outline-secondary.active,
.btn-outline-secondary:active,
.open>.btn-outline-secondary.dropdown-toggle {
  color: var(--color-white-light);
  background-color: transparent;
  border-color: transparent;
}

.btn-outline-secondary.active.focus,
.btn-outline-secondary.active:focus,
.btn-outline-secondary.active:hover,
.btn-outline-secondary:active.focus,
.btn-outline-secondary:active:focus,
.btn-outline-secondary:active:hover,
.open>.btn-outline-secondary.dropdown-toggle.focus,
.open>.btn-outline-secondary.dropdown-toggle:focus,
.open>.btn-outline-secondary.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: transparent;
  border-color: transparent;
}

.btn-outline-secondary.disabled.focus,
.btn-outline-secondary.disabled:focus,
.btn-outline-secondary:disabled.focus,
.btn-outline-secondary:disabled:focus {
  border-color: transparent;
}

.btn-outline-secondary.disabled:hover,
.btn-outline-secondary:disabled:hover {
  border-color: transparent;
}

.btn-outline-info {
  color: #5bc0de;
  background-image: none;
  background-color: transparent;
  border-color: #5bc0de;
}

.btn-outline-info:hover {
  color: var(--color-white-light);
  background-color: #5bc0de;
  border-color: #5bc0de;
}

.btn-outline-info.focus,
.btn-outline-info:focus {
  color: var(--color-white-light);
  background-color: #5bc0de;
  border-color: #5bc0de;
}

.btn-outline-info.active,
.btn-outline-info:active,
.open>.btn-outline-info.dropdown-toggle {
  color: var(--color-white-light);
  background-color: #5bc0de;
  border-color: #5bc0de;
}

.btn-outline-info.active.focus,
.btn-outline-info.active:focus,
.btn-outline-info.active:hover,
.btn-outline-info:active.focus,
.btn-outline-info:active:focus,
.btn-outline-info:active:hover,
.open>.btn-outline-info.dropdown-toggle.focus,
.open>.btn-outline-info.dropdown-toggle:focus,
.open>.btn-outline-info.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: #269abc;
  border-color: #1f7e9a;
}

.btn-outline-info.disabled.focus,
.btn-outline-info.disabled:focus,
.btn-outline-info:disabled.focus,
.btn-outline-info:disabled:focus {
  border-color: #b0e1ef;
}

.btn-outline-info.disabled:hover,
.btn-outline-info:disabled:hover {
  border-color: #b0e1ef;
}

.btn-outline-success {
  color: var(--color-validation);
  background-image: none;
  background-color: transparent;
  border-color: var(--color-validation);
}

.btn-outline-success:hover {
  color: var(--color-white-light);
  background-color: var(--color-validation);
  border-color: var(--color-validation);
}

.btn-outline-success.focus,
.btn-outline-success:focus {
  color: var(--color-white-light);
  background-color: var(--color-validation);
  border-color: var(--color-validation);
}

.btn-outline-success.active,
.btn-outline-success:active,
.open>.btn-outline-success.dropdown-toggle {
  color: var(--color-white-light);
  background-color: var(--color-validation);
  border-color: var(--color-validation);
}

.btn-outline-success.active.focus,
.btn-outline-success.active:focus,
.btn-outline-success.active:hover,
.btn-outline-success:active.focus,
.btn-outline-success:active:focus,
.btn-outline-success:active:hover,
.open>.btn-outline-success.dropdown-toggle.focus,
.open>.btn-outline-success.dropdown-toggle:focus,
.open>.btn-outline-success.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: #318047;
  border-color: #256237;
}

.btn-outline-success.disabled.focus,
.btn-outline-success.disabled:focus,
.btn-outline-success:disabled.focus,
.btn-outline-success:disabled:focus {
  border-color: #96d7a9;
}

.btn-outline-success.disabled:hover,
.btn-outline-success:disabled:hover {
  border-color: #96d7a9;
}

.btn-outline-warning {
  color: #ff9a52;
  background-image: none;
  background-color: transparent;
  border-color: #ff9a52;
}

.btn-outline-warning:hover {
  color: var(--color-white-light);
  background-color: #ff9a52;
  border-color: #ff9a52;
}

.btn-outline-warning.focus,
.btn-outline-warning:focus {
  color: var(--color-white-light);
  background-color: #ff9a52;
  border-color: #ff9a52;
}

.btn-outline-warning.active,
.btn-outline-warning:active,
.open>.btn-outline-warning.dropdown-toggle {
  color: var(--color-white-light);
  background-color: #ff9a52;
  border-color: #ff9a52;
}

.btn-outline-warning.active.focus,
.btn-outline-warning.active:focus,
.btn-outline-warning.active:hover,
.btn-outline-warning:active.focus,
.btn-outline-warning:active:focus,
.btn-outline-warning:active:hover,
.open>.btn-outline-warning.dropdown-toggle.focus,
.open>.btn-outline-warning.dropdown-toggle:focus,
.open>.btn-outline-warning.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: #fa6800;
  border-color: #d25700;
}

.btn-outline-warning.disabled.focus,
.btn-outline-warning.disabled:focus,
.btn-outline-warning:disabled.focus,
.btn-outline-warning:disabled:focus {
  border-color: #ffd6b8;
}

.btn-outline-warning.disabled:hover,
.btn-outline-warning:disabled:hover {
  border-color: #ffd6b8;
}

.btn-outline-danger {
  color: var(--color-error);
  background-image: none;
  background-color: transparent;
  border-color: var(--color-error);
}

.btn-outline-danger:hover {
  color: var(--color-white-light);
  background-color: var(--color-error);
  border-color: var(--color-error);
}

.btn-outline-danger.focus,
.btn-outline-danger:focus {
  color: var(--color-white-light);
  background-color: var(--color-error);
  border-color: var(--color-error);
}

.btn-outline-danger.active,
.btn-outline-danger:active,
.open>.btn-outline-danger.dropdown-toggle {
  color: var(--color-white-light);
  background-color: var(--color-error);
  border-color: var(--color-error);
}

.btn-outline-danger.active.focus,
.btn-outline-danger.active:focus,
.btn-outline-danger.active:hover,
.btn-outline-danger:active.focus,
.btn-outline-danger:active:focus,
.btn-outline-danger:active:hover,
.open>.btn-outline-danger.dropdown-toggle.focus,
.open>.btn-outline-danger.dropdown-toggle:focus,
.open>.btn-outline-danger.dropdown-toggle:hover {
  color: var(--color-white-light);
  background-color: #f40000;
  border-color: #c00;
}

.btn-outline-danger.disabled.focus,
.btn-outline-danger.disabled:focus,
.btn-outline-danger:disabled.focus,
.btn-outline-danger:disabled:focus {
  border-color: #ffb2b2;
}

.btn-outline-danger.disabled:hover,
.btn-outline-danger:disabled:hover {
  border-color: #ffb2b2;
}

.btn-link {
  font-weight: 400;
  color: var(--color-primary);
  border-radius: 0;
}

.btn-link,
.btn-link.active,
.btn-link:active,
.btn-link:disabled {
  background-color: transparent;
}

.btn-link,
.btn-link:active,
.btn-link:focus {
  border-color: transparent;
}

.btn-link:hover {
  border-color: transparent;
}

.btn-link:focus,
.btn-link:hover {
  color: #198195;
  text-decoration: underline;
  background-color: transparent;
}

.btn-link:disabled:focus,
.btn-link:disabled:hover {
  color: var(--color-white);
  text-decoration: none;
}

.dropdown-toggle::after {
  border-top: 0.3em solid;
  border-right: 0.3em solid transparent;
  border-left: 0.3em solid transparent;
}

.dropdown-menu {
  color: #363a42;
  background-color: var(--color-white-light);
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 0;
}

.dropdown-divider {
  background-color: #e5e5e5;
}

.dropdown-item {
  font-weight: 400;
  color: #363a42;
  background: 0 0;
  border: 0;
}

.dropdown-item:focus,
.dropdown-item:hover {
  background-color: transparent;
}

.dropdown-item.active,
.dropdown-item.active:focus,
.dropdown-item.active:hover {
  color: var(--color-white-light);
  background-color: var(--color-primary);
}

.dropdown-item.disabled,
.dropdown-item.disabled:focus,
.dropdown-item.disabled:hover {
  color: var(--color-white);
}

.dropdown-header {
  color: var(--color-white);
}

.input-group-addon {
  color: var(--color-black-light);
  background-color: var(--color-white);
  border: 1px solid rgba(0, 0, 0, 0.25);
  border-radius: 0;
}

.custom-control-input:checked~.custom-control-indicator {
  color: var(--color-white-light);
  background-color: #0074d9;
}

.custom-control-input:focus~.custom-control-indicator {
  -webkit-box-shadow: 0 0 0 0.075rem var(--color-white-light),
    0 0 0 0.2rem #0074d9;
  box-shadow: 0 0 0 0.075rem var(--color-white-light), 0 0 0 0.2rem #0074d9;
}

.custom-control-input:active~.custom-control-indicator {
  color: var(--color-white-light);
  background-color: #84c6ff;
}

.custom-control-input:disabled~.custom-control-indicator {
  background-color: #eee;
}

.custom-control-input:disabled~.custom-control-description {
  color: #767676;
}

.custom-control-indicator {
  background-color: var(--color-white-light);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 50% 50%;
}

.custom-checkbox .custom-control-input:checked~.custom-control-indicator {
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 8 8%27%3E%3Cpath fill=%27var(--color-white-light)%27 d=%27M6.564.75l-3.59 3.612-1.538-1.55L0 4.26 2.974 7.25 8 2.193z%27/%3E%3C/svg%3E');
}

.custom-checkbox .custom-control-input:indeterminate~.custom-control-indicator {
  background-color: #0074d9;
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 4 4%27%3E%3Cpath stroke=%27var(--color-white-light)%27 d=%27M0 2h4%27/%3E%3C/svg%3E');
}

.custom-radio .custom-control-input:checked~.custom-control-indicator {
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%27-4 -4 8 8%27%3E%3Ccircle r=%273%27 fill=%27var(--color-white-light)%27/%3E%3C/svg%3E');
}

.custom-select {
  color: var(--color-black-light);
  background: var(--color-white-light) url('data:image/svg+xml;charset=utf8,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 4 5%27%3E%3Cpath fill=%27#333%27 d=%27M2 0L0 2h4zm0 5L0 3h4z%27/%3E%3C/svg%3E') no-repeat right 0.75rem center;
  background-size: 8px 10px;
  border: 1px solid rgba(0, 0, 0, 0.25);
  border-radius: 0;
}

.custom-select:focus {
  border-color: var(--color-primary);
  outline: 2px var(--color-primary) solid;
}

.custom-select:focus::-ms-value {
  color: var(--color-black-light);
  background-color: var(--color-white-light);
}

.custom-select:disabled {
  color: var(--color-white);
  cursor: not-allowed;
  background-color: var(--color-white);
}

.custom-file-control {
  background-color: var(--color-white-light);
  border: 1px solid var(--color-white-light);
  border-radius: 0;
}

.custom-file-control::before {
  color: #555;
  background-color: #eee;
  border: 1px solid var(--color-white-light);
  border-radius: 0 0 0 0;
}

.nav-link.disabled {
  color: var(--color-white);
}

.nav-link.disabled,
.nav-link.disabled:focus,
.nav-link.disabled:hover {
  color: var(--color-white);
  background-color: transparent;
}

.nav-tabs {
  border-bottom: 1px solid var(--color-white-light);
}

.nav-tabs .nav-link {
  border: 1px solid transparent;
}

.nav-tabs .nav-link:focus,
.nav-tabs .nav-link:hover {
  border-color: var(--color-white) var(--color-white) var(--color-white-light);
}

.nav-tabs .nav-link.disabled,
.nav-tabs .nav-link.disabled:focus,
.nav-tabs .nav-link.disabled:hover {
  color: var(--color-white);
  background-color: transparent;
  border-color: transparent;
}

.nav-tabs .nav-item.open .nav-link,
.nav-tabs .nav-item.open .nav-link:focus,
.nav-tabs .nav-item.open .nav-link:hover,
.nav-tabs .nav-link.active,
.nav-tabs .nav-link.active:focus,
.nav-tabs .nav-link.active:hover {
  color: var(--color-black-light);
  background-color: var(--color-white-light);
  border-color: var(--color-white-light) var(--color-white-light) transparent;
}

.nav-pills .nav-item.open .nav-link,
.nav-pills .nav-item.open .nav-link:focus,
.nav-pills .nav-item.open .nav-link:hover,
.nav-pills .nav-link.active,
.nav-pills .nav-link.active:focus,
.nav-pills .nav-link.active:hover {
  color: var(--color-white-light);
  background-color: var(--color-primary);
}

.navbar-toggler {
  background: no-repeat center center;
  background-size: 24px 24px;
  border: 1px solid transparent;
  border-radius: 0;
}

.navbar-light .navbar-brand,
.navbar-light .navbar-toggler {
  color: rgba(0, 0, 0, 0.9);
}

.navbar-light .navbar-brand:focus,
.navbar-light .navbar-brand:hover,
.navbar-light .navbar-toggler:focus,
.navbar-light .navbar-toggler:hover {
  color: rgba(0, 0, 0, 0.9);
}

.navbar-light .navbar-nav .nav-link {
  color: rgba(0, 0, 0, 0.5);
}

.navbar-light .navbar-nav .nav-link:focus,
.navbar-light .navbar-nav .nav-link:hover {
  color: rgba(0, 0, 0, 0.7);
}

.navbar-light .navbar-nav .active>.nav-link,
.navbar-light .navbar-nav .active>.nav-link:focus,
.navbar-light .navbar-nav .active>.nav-link:hover,
.navbar-light .navbar-nav .nav-link.active,
.navbar-light .navbar-nav .nav-link.active:focus,
.navbar-light .navbar-nav .nav-link.active:hover,
.navbar-light .navbar-nav .nav-link.open,
.navbar-light .navbar-nav .nav-link.open:focus,
.navbar-light .navbar-nav .nav-link.open:hover,
.navbar-light .navbar-nav .open>.nav-link,
.navbar-light .navbar-nav .open>.nav-link:focus,
.navbar-light .navbar-nav .open>.nav-link:hover {
  color: rgba(0, 0, 0, 0.9);
}

.navbar-light .navbar-toggler {
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg viewBox=%270 0 32 32%27 xmlns=%27http://www.w3.org/2000/svg%27%3E%3Cpath stroke=%27rgba%280,0,0,0.5%29%27 stroke-width=%272%27 stroke-linecap=%27round%27 stroke-miterlimit=%2710%27 d=%27M4 8h24M4 16h24M4 24h24%27/%3E%3C/svg%3E');
  border-color: rgba(0, 0, 0, 0.1);
}

.navbar-light .navbar-divider {
  background-color: rgba(0, 0, 0, 0.075);
}

.navbar-dark .navbar-brand,
.navbar-dark .navbar-toggler {
  color: var(--color-white-light);
}

.navbar-dark .navbar-brand:focus,
.navbar-dark .navbar-brand:hover,
.navbar-dark .navbar-toggler:focus,
.navbar-dark .navbar-toggler:hover {
  color: var(--color-white-light);
}

.navbar-dark .navbar-nav .nav-link {
  color: rgba(255, 255, 255, 0.5);
}

.navbar-dark .navbar-nav .nav-link:focus,
.navbar-dark .navbar-nav .nav-link:hover {
  color: rgba(255, 255, 255, 0.75);
}

.navbar-dark .navbar-nav .active>.nav-link,
.navbar-dark .navbar-nav .active>.nav-link:focus,
.navbar-dark .navbar-nav .active>.nav-link:hover,
.navbar-dark .navbar-nav .nav-link.active,
.navbar-dark .navbar-nav .nav-link.active:focus,
.navbar-dark .navbar-nav .nav-link.active:hover,
.navbar-dark .navbar-nav .nav-link.open,
.navbar-dark .navbar-nav .nav-link.open:focus,
.navbar-dark .navbar-nav .nav-link.open:hover,
.navbar-dark .navbar-nav .open>.nav-link,
.navbar-dark .navbar-nav .open>.nav-link:focus,
.navbar-dark .navbar-nav .open>.nav-link:hover {
  color: var(--color-white-light);
}

.navbar-dark .navbar-toggler {
  background-image: url('data:image/svg+xml;charset=utf8,%3Csvg viewBox=%270 0 32 32%27 xmlns=%27http://www.w3.org/2000/svg%27%3E%3Cpath stroke=%27rgba%28255,255,255,0.5%29%27 stroke-width=%272%27 stroke-linecap=%27round%27 stroke-miterlimit=%2710%27 d=%27M4 8h24M4 16h24M4 24h24%27/%3E%3C/svg%3E');
  border-color: rgba(255, 255, 255, 0.1);
}

.navbar-dark .navbar-divider {
  background-color: rgba(255, 255, 255, 0.075);
}

.card {
  background-color: var(--color-white-light);
  border-radius: 0;
  border: 1px solid rgba(0, 0, 0, 0.125);
}

.card-header {
  background-color: #f5f5f5;
  border-bottom: 1px solid rgba(0, 0, 0, 0.125);
}

.card-footer {
  background-color: #f5f5f5;
  border-top: 1px solid rgba(0, 0, 0, 0.125);
}

.card-primary {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

.card-danger .card-footer,
.card-danger .card-header,
.card-info .card-footer,
.card-info .card-header,
.card-primary .card-footer,
.card-primary .card-header,
.card-success .card-footer,
.card-success .card-header,
.card-warning .card-footer,
.card-warning .card-header {
  background-color: transparent;
}

.card-success {
  background-color: var(--color-validation);
  border-color: var(--color-validation);
}

.card-info {
  background-color: #5bc0de;
  border-color: #5bc0de;
}

.card-warning {
  background-color: #ff9a52;
  border-color: #ff9a52;
}

.card-danger {
  background-color: var(--color-error);
  border-color: var(--color-error);
}

.card-outline-primary,
.card-outline-secondary {
  background-color: transparent;
  border-color: var(--color-primary);
}

.card-outline-secondary {
  border-color: transparent;
}

.card-outline-info,
.card-outline-success {
  background-color: transparent;
  border-color: #5bc0de;
}

.card-outline-success {
  border-color: var(--color-validation);
}

.card-outline-danger,
.card-outline-warning {
  background-color: transparent;
  border-color: #ff9a52;
}

.card-outline-danger {
  border-color: var(--color-error);
}

.card-inverse .card-footer,
.card-inverse .card-header {
  border-color: rgba(255, 255, 255, 0.2);
}

.card-inverse .card-blockquote,
.card-inverse .card-footer,
.card-inverse .card-header,
.card-inverse .card-title {
  color: var(--color-white-light);
}

.card-inverse .card-blockquote .blockquote-footer,
.card-inverse .card-link,
.card-inverse .card-subtitle,
.card-inverse .card-text {
  color: rgba(255, 255, 255, 0.65);
}

.card-inverse .card-link:focus,
.card-inverse .card-link:hover {
  color: var(--color-white-light);
}



.page-item.active .page-link,
.page-item.active .page-link:focus,
.page-item.active .page-link:hover {
  color: var(--color-white-light);
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

.page-item.disabled .page-link,
.page-item.disabled .page-link:focus,
.page-item.disabled .page-link:hover {
  color: var(--color-white);
  background-color: var(--color-white-light);
  border-color: var(--color-white-light);
}

.page-link {
  color: var(--color-primary);
  text-decoration: none;
  background-color: var(--color-white-light);
  border: 1px solid var(--color-white-light);
}

.page-link:focus,
.page-link:hover {
  color: #198195;
  background-color: var(--color-white);
  border-color: var(--color-white-light);
}

.tag {
  color: var(--color-white-light);
  border-radius: 0;
}

a.tag:focus,
a.tag:hover {
  color: var(--color-white-light);
}

.tag-default {
  background-color: var(--color-white);
}

.tag-default[href]:focus,
.tag-default[href]:hover {
  background-color: var(--color-white-light);
}

.tag-primary {
  background-color: var(--color-primary);
}

.tag-primary[href]:focus,
.tag-primary[href]:hover {
  background-color: #1d93ab;
}

.tag-success {
  background-color: var(--color-validation);
}

.tag-success[href]:focus,
.tag-success[href]:hover {
  background-color: #3a9a56;
}

.tag-info {
  background-color: #5bc0de;
}

.tag-info[href]:focus,
.tag-info[href]:hover {
  background-color: #31b0d5;
}

.tag-warning {
  background-color: #ff9a52;
}

.tag-warning[href]:focus,
.tag-warning[href]:hover {
  background-color: #ff7c1f;
}

.tag-danger {
  background-color: var(--color-error);
}

.tag-danger[href]:focus,
.tag-danger[href]:hover {
  background-color: #ff1919;
}

.jumbotron {
  background-color: var(--color-white);
  border-radius: 0.3rem;
}

.jumbotron-hr {
  border-top-color: var(--color-white-light);
}

.progress[value] {
  background-color: #eee;
  border-radius: 0;
}

.progress[value]::-ms-fill {
  background-color: #0074d9;
}

.progress[value]::-moz-progress-bar {
  background-color: #0074d9;
}

.progress[value]::-webkit-progress-value {
  background-color: #0074d9;
}

.progress[value]::-webkit-progress-bar {
  background-color: #eee;
  border-radius: 0;
}

.progress[value],
base::-moz-progress-bar {
  background-color: #eee;
  border-radius: 0;
}

.progress-striped[value]::-webkit-progress-value {
  background-image: linear-gradient(45deg,
      rgba(255, 255, 255, 0.15) 25%,
      transparent 25%,
      transparent 50%,
      rgba(255, 255, 255, 0.15) 50%,
      rgba(255, 255, 255, 0.15) 75%,
      transparent 75%,
      transparent);
  background-size: 1rem 1rem;
}

.progress-striped[value]::-moz-progress-bar {
  background-image: linear-gradient(45deg,
      rgba(255, 255, 255, 0.15) 25%,
      transparent 25%,
      transparent 50%,
      rgba(255, 255, 255, 0.15) 50%,
      rgba(255, 255, 255, 0.15) 75%,
      transparent 75%,
      transparent);
  background-size: 1rem 1rem;
}

.progress-striped[value]::-ms-fill {
  background-image: linear-gradient(45deg,
      rgba(255, 255, 255, 0.15) 25%,
      transparent 25%,
      transparent 50%,
      rgba(255, 255, 255, 0.15) 50%,
      rgba(255, 255, 255, 0.15) 75%,
      transparent 75%,
      transparent);
  background-size: 1rem 1rem;
}

.progress-success[value]::-webkit-progress-value {
  background-color: var(--color-validation);
}

.progress-success[value]::-moz-progress-bar {
  background-color: var(--color-validation);
}

.progress-success[value]::-ms-fill {
  background-color: var(--color-validation);
}

.progress-info[value]::-webkit-progress-value {
  background-color: #5bc0de;
}

.progress-info[value]::-moz-progress-bar {
  background-color: #5bc0de;
}

.progress-info[value]::-ms-fill {
  background-color: #5bc0de;
}

.progress-warning[value]::-webkit-progress-value {
  background-color: #ff9a52;
}

.progress-warning[value]::-moz-progress-bar {
  background-color: #ff9a52;
}

.progress-warning[value]::-ms-fill {
  background-color: #ff9a52;
}

.progress-danger[value]::-webkit-progress-value {
  background-color: var(--color-error);
}

.progress-danger[value]::-moz-progress-bar {
  background-color: var(--color-error);
}

.progress-danger[value]::-ms-fill {
  background-color: var(--color-error);
}

.list-group-item {
  background-color: var(--color-white-light);
  border: 1px solid var(--color-white-light);
}

.list-group-item.disabled,
.list-group-item.disabled:focus,
.list-group-item.disabled:hover {
  color: var(--color-white);
  background-color: var(--color-white);
}

.list-group-item.disabled .list-group-item-heading,
.list-group-item.disabled:focus .list-group-item-heading,
.list-group-item.disabled:hover .list-group-item-heading {
  color: inherit;
}

.list-group-item.disabled .list-group-item-text,
.list-group-item.disabled:focus .list-group-item-text,
.list-group-item.disabled:hover .list-group-item-text {
  color: var(--color-white);
}

.list-group-item.active,
.list-group-item.active:focus,
.list-group-item.active:hover {
  color: var(--color-white-light);
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

.list-group-item.active .list-group-item-heading,
.list-group-item.active .list-group-item-heading>.small,
.list-group-item.active .list-group-item-heading>small,
.list-group-item.active:focus .list-group-item-heading,
.list-group-item.active:focus .list-group-item-heading>.small,
.list-group-item.active:focus .list-group-item-heading>small,
.list-group-item.active:hover .list-group-item-heading,
.list-group-item.active:hover .list-group-item-heading>.small,
.list-group-item.active:hover .list-group-item-heading>small {
  color: inherit;
}

.list-group-item.active .list-group-item-text,
.list-group-item.active:focus .list-group-item-text,
.list-group-item.active:hover .list-group-item-text {
  color: #d0f1f7;
}

.list-group-flush .list-group-item {
  border-right: 0;
  border-left: 0;
  border-radius: 0;
}

.list-group-item-action {
  width: 100%;
  color: #555;
  text-align: inherit;
}

.list-group-item-action .list-group-item-heading {
  color: #333;
}

.list-group-item-action:focus,
.list-group-item-action:hover {
  color: #555;
  text-decoration: none;
  background-color: #f5f5f5;
}

.list-group-item-success {
  color: #3c763d;
  background-color: #dff0d8;
}

a.list-group-item-success,
button.list-group-item-success {
  color: #3c763d;
}

a.list-group-item-danger .list-group-item-heading,
a.list-group-item-info .list-group-item-heading,
a.list-group-item-success .list-group-item-heading,
a.list-group-item-warning .list-group-item-heading,
button.list-group-item-danger .list-group-item-heading,
button.list-group-item-info .list-group-item-heading,
button.list-group-item-success .list-group-item-heading,
button.list-group-item-warning .list-group-item-heading {
  color: inherit;
}

a.list-group-item-success:focus,
a.list-group-item-success:hover,
button.list-group-item-success:focus,
button.list-group-item-success:hover {
  color: #3c763d;
  background-color: #d0e9c6;
}

a.list-group-item-success.active,
a.list-group-item-success.active:focus,
a.list-group-item-success.active:hover,
button.list-group-item-success.active,
button.list-group-item-success.active:focus,
button.list-group-item-success.active:hover {
  color: var(--color-white-light);
  background-color: #3c763d;
  border-color: #3c763d;
}

.list-group-item-info {
  color: #31708f;
  background-color: #d9edf7;
}

a.list-group-item-info,
button.list-group-item-info {
  color: #31708f;
}

a.list-group-item-info:focus,
a.list-group-item-info:hover,
button.list-group-item-info:focus,
button.list-group-item-info:hover {
  color: #31708f;
  background-color: #c4e3f3;
}

a.list-group-item-info.active,
a.list-group-item-info.active:focus,
a.list-group-item-info.active:hover,
button.list-group-item-info.active,
button.list-group-item-info.active:focus,
button.list-group-item-info.active:hover {
  color: var(--color-white-light);
  background-color: #31708f;
  border-color: #31708f;
}

.list-group-item-warning {
  color: #8a6d3b;
  background-color: #fcf8e3;
}

a.list-group-item-warning,
button.list-group-item-warning {
  color: #8a6d3b;
}

a.list-group-item-warning:focus,
a.list-group-item-warning:hover,
button.list-group-item-warning:focus,
button.list-group-item-warning:hover {
  color: #8a6d3b;
  background-color: #faf2cc;
}

a.list-group-item-warning.active,
a.list-group-item-warning.active:focus,
a.list-group-item-warning.active:hover,
button.list-group-item-warning.active,
button.list-group-item-warning.active:focus,
button.list-group-item-warning.active:hover {
  color: var(--color-white-light);
  background-color: #8a6d3b;
  border-color: #8a6d3b;
}

.list-group-item-danger {
  color: #a94442;
  background-color: #f2dede;
}

a.list-group-item-danger,
button.list-group-item-danger {
  color: #a94442;
}

a.list-group-item-danger:focus,
a.list-group-item-danger:hover,
button.list-group-item-danger:focus,
button.list-group-item-danger:hover {
  color: #a94442;
  background-color: #ebcccc;
}

a.list-group-item-danger.active,
a.list-group-item-danger.active:focus,
a.list-group-item-danger.active:hover,
button.list-group-item-danger.active,
button.list-group-item-danger.active:focus,
button.list-group-item-danger.active:hover {
  color: var(--color-white-light);
  background-color: #a94442;
  border-color: #a94442;
}

.close {
  text-shadow: 0 1px 0 var(--color-white-light);
}

.close:focus,
.close:hover {
  color: #000;
}

.modal-content {
  background-color: var(--color-white-light);
  background-clip: padding-box;
  border: none;
  border-radius: 32px;
  overflow: hidden;
}

.modal-backdrop {
  background-color: #000;
}

.modal-header {
  border-bottom: none;
}


.modal-footer {
  border-top: 1px solid #e5e5e5;
}

.tooltip.bs-tether-element-attached-bottom .tooltip-inner::before,
.tooltip.tooltip-top .tooltip-inner::before {
  border-width: 5px 5px 0;
  border-top-color: var(--color-error);
}

.tooltip.bs-tether-element-attached-left .tooltip-inner::before,
.tooltip.tooltip-right .tooltip-inner::before {
  border-right-color: var(--color-error);
}

.tooltip.bs-tether-element-attached-top .tooltip-inner::before,
.tooltip.tooltip-bottom .tooltip-inner::before {
  border-width: 0 5px 5px;
  border-bottom-color: var(--color-error);
}

.tooltip.bs-tether-element-attached-right .tooltip-inner::before,
.tooltip.tooltip-left .tooltip-inner::before {
  border-width: 5px 0 5px 5px;
  border-left-color: var(--color-error);
}

.tooltip-inner {
  color: var(--color-white-light);
  background-color: var(--color-error);
  border-radius: 0;
}

.popover.bs-tether-element-attached-bottom::before,
.popover.popover-top::before {
  border-top-color: rgba(0, 0, 0, 0.25);
}

.popover.bs-tether-element-attached-bottom::after,
.popover.popover-top::after {
  border-top-color: var(--color-white-light);
}

.popover.bs-tether-element-attached-left::before,
.popover.popover-right::before {
  border-right-color: rgba(0, 0, 0, 0.25);
}

.popover.bs-tether-element-attached-top::before,
.popover.popover-bottom::before {
  border-bottom-color: rgba(0, 0, 0, 0.25);
}

.popover.bs-tether-element-attached-top::after,
.popover.popover-bottom::after {
  border-bottom-color: #f7f7f7;
}

.popover.bs-tether-element-attached-top .popover-title::before,
.popover.popover-bottom .popover-title::before {
  border-bottom: 1px solid #f7f7f7;
}

.popover.bs-tether-element-attached-right::after,
.popover.popover-left::after {
  border-left-color: var(--color-white-light);
}

.popover-title {
  background-color: #f7f7f7;
  border-bottom: 1px solid #ebebeb;
  border-radius: 0.2375rem 0.2375rem 0 0;
}

.carousel-control {
  color: var(--color-white-light);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
}

.carousel-control.left {
  background-image: -webkit-gradient(linear,
      left top,
      right top,
      from(rgba(0, 0, 0, 0.5)),
      to(rgba(0, 0, 0, 0.0001)));
  background-image: linear-gradient(to right,
      rgba(0, 0, 0, 0.5) 0,
      rgba(0, 0, 0, 0.0001) 100%);
  background-repeat: repeat-x;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1);
}

.carousel-control.right {
  right: 0;
  left: auto;
  background-image: -webkit-gradient(linear,
      left top,
      right top,
      from(rgba(0, 0, 0, 0.0001)),
      to(rgba(0, 0, 0, 0.5)));
  background-image: linear-gradient(to right,
      rgba(0, 0, 0, 0.0001) 0,
      rgba(0, 0, 0, 0.5) 100%);
  background-repeat: repeat-x;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1);
}

.carousel-control:focus,
.carousel-control:hover {
  color: var(--color-white-light);
}

.carousel-indicators li {
  background-color: transparent;
  border: 1px solid var(--color-white-light);
  border-color: var(--color-black-light);
}

.carousel-caption {
  color: var(--color-white-light);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
}

.bg-faded {
  background-color: #f7f7f9;
}

.bg-primary {
  background-color: var(--color-primary) !important;
}

a.bg-primary:focus,
a.bg-primary:hover {
  background-color: #1d93ab !important;
}

.bg-success {
  background-color: var(--color-validation) !important;
}

a.bg-success:focus,
a.bg-success:hover {
  background-color: #3a9a56 !important;
}

.bg-info {
  background-color: #5bc0de !important;
}

a.bg-info:focus,
a.bg-info:hover {
  background-color: #31b0d5 !important;
}

.bg-warning {
  background-color: #ff9a52 !important;
}

a.bg-warning:focus,
a.bg-warning:hover {
  background-color: #ff7c1f !important;
}

.bg-danger {
  background-color: var(--color-error) !important;
}

a.bg-danger:focus,
a.bg-danger:hover {
  background-color: #ff1919 !important;
}

.bg-inverse {
  background-color: #363a42 !important;
}

a.bg-inverse:focus,
a.bg-inverse:hover {
  background-color: #1f2126 !important;
}

.text-white {
  color: var(--color-white-light) !important;
}

.text-muted {
  color: var(--color-black-light) !important;
}

a.text-muted:focus,
a.text-muted:hover {
  color: #616161 !important;
}

.text-primary {
  color: var(--color-secondary) !important;
}

a.text-primary:focus,
a.text-primary:hover {
  color: var(--color-primary) !important;
}

.text-success {
  color: var(--color-validation) !important;
}

a.text-success:focus,
a.text-success:hover {
  color: #3a9a56 !important;
}

.text-info {
  color: #5bc0de !important;
}

a.text-info:focus,
a.text-info:hover {
  color: #31b0d5 !important;
}

.text-warning {
  color: #ff9a52 !important;
}

a.text-warning:focus,
a.text-warning:hover {
  color: #ff7c1f !important;
}

.text-danger {
  color: var(--color-error) !important;
}

a.text-danger:focus,
a.text-danger:hover {
  color: #ff1919 !important;
}

.text-gray-dark {
  color: #363a42 !important;
}

a.text-gray-dark:focus,
a.text-gray-dark:hover {
  color: #1f2126 !important;
}

.page-content.page-cms ul,
p {
  font-weight: 400;
  color: var(--color-black);
}

.custom-checkbox input[type='checkbox']+span.color,
.variant-links .color,
label .color {
  background-size: contain;
  border: 1px solid #979797;
}

.custom-checkbox input[type='checkbox']+span.color.active,
.custom-checkbox input[type='checkbox']+span.color:hover,
.variant-links .color.active,
.variant-links .color:hover,
label .color.active,
label .color:hover {
  border: 2px solid var(--color-black);
}

.facet-label.active .custom-checkbox span.color,
.facet-label:hover .custom-checkbox span.color {
  border: 1px solid #979797;
}

.block_newsletter form input[type='text']:focus+button .search,
.btn-unstyle:focus .expand-more,
.search-widget form input[type='text']:focus+button .search {
  color: var(--color-primary);
}


.input-group.focus,
.input-group.focus:has(input[type="password"]) input {
  outline: 2px var(--color-primary) solid;
}

.input-group.focus:has(input[type="password"]) {
  outline: none;
}

.input-group .input-group-btn>.btn {
  color: var(--color-white-light);
  text-transform: none;
  border-radius: 32px;
}


input:active::-webkit-input-placeholder,
textarea:active::-webkit-input-placeholder {
  color: var(--color-black);
}

input:active::-moz-placeholder,
textarea:active::-moz-placeholder {
  color: var(--color-black);
}

input:active:-ms-input-placeholder,
textarea:active:-ms-input-placeholder {
  color: var(--color-black);
}

input:active:-moz-placeholder,
textarea:active:-moz-placeholder {
  color: var(--color-black);
}

.form-control-select {
  height: 2.625rem;
  padding: 0 0.5rem;
  background: var(--color-white) url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAQAAAD9CzEMAAAAPklEQVR4Ae3TwREAEBQD0V/6do4SXPZg7EsBhsQ8IEmSMOsiuEfg3gL3oXC7wK0bd1G4o8X9F4yIkyQfSrIByQBjp7QuND8AAAAASUVORK5CYII=) no-repeat right 0.5rem center/1.25rem 1.25rem;
  -moz-appearance: none;
  -webkit-appearance: none;
}

.form-control-comment {
  color: var(--color-black-light);
}

.form-control-submit.disabled {
  color: var(--color-white-light);
  background: #5bc0de;
}

.form-group.has-error input,
.form-group.has-error select {
  outline: 2px var(--color-error) solid;
}

.bootstrap-touchspin .group-span-filestyle .btn-touchspin,
.group-span-filestyle .bootstrap-touchspin .btn-touchspin,
.group-span-filestyle .btn-default {
  color: var(--color-white-light);
  text-transform: uppercase;
  background: var(--color-primary);
  border-radius: 0;
}

.bootstrap-touchspin input.form-control,
.bootstrap-touchspin input.input-group {
  color: var(--color-black);
  background-color: var(--color-white-light);
  border: 1px solid transparent;
}

.bootstrap-touchspin .btn-touchspin {
  background-color: var(--color-white-light);
}

#order-items table tr.total-value,
.bootstrap-touchspin .btn-touchspin:hover {
  background-color: var(--color-white);
}

.bootstrap-touchspin .input-group-btn-vertical {
  color: var(--color-black);
}

form section .form-informations {
  color: var(--color-black);
}

.custom-radio {
  background: var(--color-white-light);
  border: #979797 1px solid;
  border-radius: 50%;
}

.custom-radio input[type='radio']:checked+span {
  background-color: var(--color-primary);
  border-radius: 50%;
}

.custom-checkbox input[type='checkbox']:focus+span,
.custom-radio input[type='radio']:focus+span {
  border-color: var(--color-black-light);
}

.custom-checkbox input[type='checkbox']+span {
  border: 1px #979797 solid;
}

.custom-checkbox input[type='checkbox']+span .checkbox-checked {
  color: var(--color-black);
}

.done {
  color: var(--color-validation);
}

.thumb-mask>.mask {
  border: var(--color-white) 1px solid;
}

.definition-list dl dd,
.definition-list dl dt {
  background: var(--color-white);
}

.definition-list dl dd:nth-of-type(even),
.definition-list dl dt:nth-of-type(even),
.product-features>dl.data-sheet dd.value:nth-of-type(even),
.product-features>dl.data-sheet dt.name:nth-of-type(even) {
  background: var(--color-white);
}

.btn.disabled,
.btn.disabled:hover {
  color: var(--color-white-light);
  background: var(--color-white);
}

.alert-warning .material-icons {
  color: #ff9a52;
}

.alert-warning .alert-link {
  color: #6c868e;
  border-radius: 2px;
}

.alert-warning ul li:last-child .alert-link {
  color: var(--color-white-light);
}

.btn-tertiary-outline {
  color: #6c868e;
  background-color: transparent;
  background-image: none;
  border: 0.15rem solid #6c868e;
  border-color: #6c868e;
}

.btn-tertiary-outline:hover {
  color: #bbcdd2;
  border-color: #bbcdd2;
}

.nav-item .nav-link,
.nav-item .nav-separtor {
  font-weight: 600;
  color: var(--color-black-light);
}

#mobile_top_menu_wrapper .top-menu,
.nav-item .nav-link.active,
.nav-item .nav-separtor.active {
  color: var(--color-secondary);
}

.separator {
  margin: 0;
  border-color: rgba(0, 0, 0, 0.25);
}


#mobile_top_menu_wrapper .js-top-menu-bottom a,
.dropdown {
  color: var(--color-black-light);
}

.carousel .carousel-control .icon-next:hover i,
.carousel .carousel-control .icon-prev:hover i,
.dropdown:hover .expand-more,
.page-my-account #content .links a:hover i,
.search-widget form button[type='submit'] .search:hover,
.top-menu .sub-menu a:hover {
  color: var(--color-secondary);
}

.dropdown .expand-more {
  color: var(--color-black);
}

.dropdown select {
  color: var(--color-black);
  background: var(--color-white-light);
}

.dropdown-item:focus,
.dropdown-item:hover {
  color: var(--color-primary);
}

.block_newsletter form input[type='text'],
.search-widget form input[type='text'] {
  color: var(--color-black-light);
  border: 0;
  border: 1px solid rgba(0, 0, 0, 0.25);
}

.search-widget form input[type='text']:focus {
  color: var(--color-black);
  background: var(--color-white-light);
  outline: 2px var(--color-primary) solid;
}

.block_newsletter form button[type='submit'],
.search-widget form button[type='submit'] {
  color: var(--color-black-light);
}

.header-top .search-widgets form input[type='text'] {
  color: #9b9b9b;
  background: var(--color-white);
}

.header-top .search-widgets form input[type='text']:focus {
  background: var(--color-white-light);
}

.header-top #search_widget input {
  background-color: var(--color-white);
  border: 1px solid var(--color-black-light);
}

.top-menu a:not([data-depth='0']) {
  color: var(--color-black-light);
}

.top-menu a.dropdown-submenu {
  color: var(--color-black);
}

#mobile_top_menu_wrapper {
  background: var(--color-white-light);
}

#mobile_top_menu_wrapper .top-menu a[data-depth='0'] {
  padding: 0.625rem;
  /* border-bottom: 1px solid var(--color-white); */
  border: none;
}

#mobile_top_menu_wrapper .top-menu .sub-menu {
  background: var(--color-white-light);
}

#mobile_top_menu_wrapper .top-menu .sub-menu ul[data-depth='0']>li {
  border-bottom: 1px solid var(--color-black-light);
}

#mobile_top_menu_wrapper .top-menu .sub-menu li>a {
  border-bottom: 1px solid var(--color-white-light);
}

body#checkout .cart-grid-right .card .cart-summary-subtotals-container {
  padding: 1rem 0;
  border-top: 1px solid var(--color-white-light);
  border-bottom: 1px solid var(--color-white-light);
}

body#checkout #cart-summary-product-list img {
  width: 3.125rem;
  border: var(--color-white) 1px solid;
}


body#checkout #order-summary-content #order-items h3.h3 {
  margin-top: 1.25rem;
  color: var(--color-black);
}



body#checkout #order-summary-content .step-edit {
  display: inline;
  color: var(--color-black-light);
  text-transform: none;
}

#history .orders .order a h3,
body#checkout #order-summary-content a .step-edit {
  color: var(--color-black-light);
}

body#checkout #delivery,
body#checkout #gift_message {
  max-width: 100%;
  border-color: var(--color-black);
}


#order-items {
  border-right: var(--color-white) 1px solid;
}

#order-items hr {
  border-top-color: var(--color-black);
}

#order-items .image img {
  width: 100%;
  margin-bottom: 1rem;
  border: 1px solid gray-lighter;
}

.table-labeled .label {
  font-weight: 400;
  color: var(--color-white-light);
  border-radius: 3px;
}


.page-authentication #content,
.page-registration #content {
  background: var(--color-white-light);
}


.page-my-account #content .links a {
  font-weight: 700;
  color: var(--color-black-light);
  text-transform: uppercase;
}

.page-my-account #content .links a span.link-item {
  background: var(--color-white-light);
}

.page-my-account #content .links a i {
  color: var(--color-black);
}

#history .orders .order {
  border-bottom: 1px solid var(--color-white);
}

.carousel .carousel-item .caption {
  color: var(--color-white-light);
}

.carousel .carousel-item .caption .caption-description .page-content.page-cms ul,
.carousel .carousel-item .caption .caption-description p,
.page-content.page-cms .carousel .carousel-item .caption .caption-description ul {
  color: var(--color-white-light);
}

.carousel .carousel-control .icon-next i,
.carousel .carousel-control .icon-prev i {
  font-size: 3.125rem;
  color: var(--color-white-light);
}

.carousel-indicators .active {
  background-color: var(--color-black-light);
}


#custom-text {
  background: var(--color-white-light);
  border-radius: 2px;
}

#custom-text h2 {
  font-weight: 500;
  color: var(--color-black);
  text-transform: uppercase;
}

#custom-text .page-content.page-cms ul,
#custom-text p,
.page-content.page-cms #custom-text ul {
  font-weight: 400;
  color: var(--color-black);
}

#custom-text .page-content.page-cms ul .dark,
#custom-text p .dark,
.page-content.page-cms #custom-text ul .dark {
  font-weight: 600;
  color: var(--color-black);
}

.page-content.page-cms {
  background: var(--color-white-light);
}



.block-category .block-category-inner #category-description .page-content.page-cms ul,
.block-category .block-category-inner #category-description p,
.page-content.page-cms .block-category .block-category-inner #category-description ul {
  color: var(--color-black);
}

.block-category .block-category-inner #category-description strong {
  font-weight: 400;
  color: var(--color-black-light);
}

.brands-sort,
.products-sort-order,
.suppliers-sort {
  color: var(--color-black-light);
}

.brands-sort .select-title,
.products-sort-order .select-title,
.suppliers-sort .select-title {
  color: var(--color-black);
  background: var(--color-white-light);
  border: 1px solid rgba(0, 0, 0, 0.25);
}

.brands-sort .select-list,
.products-sort-order .select-list,
.suppliers-sort .select-list {
  color: var(--color-black);
}

.brands-sort .select-list:hover,
.products-sort-order .select-list:hover,
.suppliers-sort .select-list:hover {
  color: var(--color-white-light);
  text-decoration: none;
  background: var(--color-primary);
}

.brands-sort .dropdown-menu,
.products-sort-order .dropdown-menu,
.suppliers-sort .dropdown-menu {
  background: var(--color-white);
  border: 0;
  border-radius: 0;
  -webkit-box-shadow: 2px 2px 4px 0 rgba(0, 0, 0, 0.1);
  box-shadow: 2px 2px 4px 0 rgba(0, 0, 0, 0.1);
}

.facet-dropdown {
  color: var(--color-black-light);
  background: var(--color-white);
  border: 3px solid transparent;
  -webkit-box-shadow: 1px 1px 1px 1px var(--color-white);
  box-shadow: 1px 1px 1px 1px var(--color-white);
}

.facet-dropdown.open>.select-title {
  background: var(--color-white);
  border: 3px solid var(--color-primary);
}

.facet-dropdown .select-title {
  color: var(--color-black);
  cursor: pointer;
  background: var(--color-white);
}

.facet-dropdown .select-list {
  color: var(--color-black);
  background: var(--color-white);
}

.facet-dropdown .select-list:hover {
  color: var(--color-white-light);
  text-decoration: none;
  background: var(--color-primary);
}

.facet-dropdown .dropdown-menu {
  background: var(--color-white);
  border: 0;
  -webkit-box-shadow: 1px 1px 1px 1px var(--color-white);
  box-shadow: 1px 1px 1px 1px var(--color-white);
}

#search_filters,
#search_filters_brands,
#search_filters_suppliers {
  background: var(--color-white-light);
}

#search_filters .facet .facet-title,
#search_filters_brands .facet .facet-title,
#search_filters_suppliers .facet .facet-title {
  color: var(--color-black);
}

#search_filters .facet .facet-label a,
#search_filters_brands .facet .facet-label a,
#search_filters_suppliers .facet .facet-label a {
  color: var(--color-black);
}

.pagination .page-list {
  background: transparent;
}

.pagination a {
  font-weight: 600;
  color: #000;
}

.pagination .disabled {
  color: var(--color-black-light);
}

.pagination .current a {
  color: var(--color-primary);
  text-decoration: none;
}

.active_filters {
  background: #dededd;
}

.active_filters .active-filter-title {
  font-weight: 600;
}

.active_filters .filter-block {
  color: var(--color-black);
  background: var(--color-white-light);
}

.active_filters .filter-block .close {
  color: var(--color-black);
}

.block-categories {
  background: var(--color-white-light);
}

.block-categories a,
.facets-title {
  color: var(--color-black);
}

#subcategories ul li .subcategory-name:hover,
.block-categories .arrows .arrow-down:hover,
.block-categories .arrows .arrow-right:hover,
.block-categories .collapse-icons .add:hover,
.block-categories .collapse-icons .remove:hover,
.cart-grid-body a.label:hover {
  color: var(--color-primary);
}

#subcategories {
  border-top: 1px solid var(--color-white);
}

#subcategories ul li .subcategory-image a {
  border: 1px solid var(--color-white);
}

#subcategories ul li .subcategory-name {
  text-transform: uppercase;
}

#subcategories ul li:hover .subcategory-image a {
  padding: 5px;
  border: 5px solid var(--color-primary);
}

#blockcart-modal,
#product-description-short {
  color: var(--color-black);
}

#product-description-short ol li,
#product-description-short ul li,
.product-information .product-description ol li,
.product-information .product-description ul li {
  color: var(--color-black-light);
}

.product-information {
  color: var(--color-black);
}

.product-information .manufacturer-logo {
  border: 2px solid var(--color-white);
}

.input-color:checked+span,
.input-color:hover+span,
.input-radio:checked+span,
.input-radio:hover+span {
  border: 2px solid var(--color-black);
}

.radio-label {
  background: var(--color-white-light);
  border: 2px solid var(--color-white-light);
}

.block-social ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.product-discounts>.table-product-discounts thead tr th {
  text-align: center;
  background: var(--color-white-light);
  border: 0.3125rem var(--color-white) solid;
}

.product-discounts>.table-product-discounts tbody tr {
  background: var(--color-white);
}

.product-discounts>.table-product-discounts tbody tr:nth-of-type(even) {
  background: var(--color-white-light);
}

.product-discounts>.table-product-discounts tbody tr td {
  border: 0.3125rem var(--color-white) solid;
}

.product-prices .tax-shipping-delivery-label {
  color: var(--color-black-light);
}

.product-customization small,
.product-discount {
  color: var(--color-black-light);
}

.has-discount .page-content.page-cms ul,
.has-discount p,
.has-discount.product-price,
.page-content.page-cms .has-discount ul {
  color: var(--color-secondary-light);
}

.has-discount .discount {
  font-weight: 600;
  color: var(--color-white-light);
  text-transform: uppercase;
  background: var(--color-secondary-light);
}



.tabs {
  background: var(--color-white-light);
}

.tabs .nav-tabs {
  border-bottom: var(--color-white) 2px solid;
}

.tabs .nav-tabs .nav-link {
  color: var(--color-black-light);
  border: 0 solid transparent;
}

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

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

#product-modal .modal-content .modal-body .product-cover-modal,
.product-cover img {
  background: var(--color-white-light);
}

.product-cover .layer {
  background: #000;
  background: rgba(0, 0, 0, 0.6);
}

.product-cover .layer .zoom-in {
  font-size: 3.125rem;
  color: var(--color-white-light);
}

#product-modal .modal-content .modal-body .image-caption {
  background: var(--color-white-light);
  border-top: var(--color-white) 1px solid;
}

#product-modal .modal-content .modal-body .product-images img {
  background: var(--color-white-light);
}

#product-modal .modal-content .modal-body .product-images img:hover {
  border: var(--color-primary) 3px solid;
}

#product-modal .modal-content .modal-body .arrows {
  color: var(--color-white-light);
}

#product #block-reassurance {
  background: var(--color-white-light);
}


.product-images>li.thumb-container .thumb.selected,
.product-images>li.thumb-container .thumb:hover {
  border: var(--color-primary) 3px solid;
}

#product-availability .product-available {
  color: var(--color-validation);
}

#product-availability .product-last-items,
#product-availability .product-unavailable {
  color: #ff9a52;
}

#product-details .label {
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-black);
}

.product-features>dl.data-sheet dd.value,
.product-features>dl.data-sheet dt.name {
  font-weight: 500;
  text-transform: capitalize;
  word-break: normal;
  background: var(--color-white);
}

.product-variants>.product-variants-item select {
  background-color: var(--color-white-light);
}

.product-flags {
  left: 0;
}

.product-flags li.product-flag {
  color: var(--color-white-light);
  text-transform: none;
  background: var(--color-primary);
  border-radius: 32px;
}

.product-flags li.product-flag.discount,
.product-flags li.product-flag.discount-amount,
.product-flags li.product-flag.discount-percentage {
  background-color: var(--color-secondary-light);
}

.product-customization .product-message {
  background: var(--color-white);
}

.product-customization .product-message:focus {
  background-color: var(--color-white-light);
  outline: 2px var(--color-primary) solid;
}

.product-customization .custom-file {
  color: var(--color-black-light);
  text-indent: 0.625rem;
  background: var(--color-white);
}

.product-pack .pack-product-container .pack-product-name {
  color: var(--color-black-light);
}

.product-pack .pack-product-container .pack-product-quantity {
  border-left: var(--color-white) 2px solid;
}

.social-sharing li {
  background-color: var(--color-white-light);
  background-repeat: no-repeat;
  background-position: 0.25rem 0.25rem;
  background-size: 2rem 2rem;
  border-radius: 50%;
}

.block-social ul li a:hover,
.social-sharing li a:hover {
  color: transparent;
}

#header .header-nav .blockcart a,
.account-list a,
.products-selection .title {
  color: var(--color-black-light);
}

.card-block.cart-detailed-subtotals+.cart-summary-totals .cart-total {
  border-top: 1px solid var(--color-white-light);
}

.cart-summary-line .label {
  font-weight: 400;
  color: #363a42;
}

.cart-summary-line .value {
  font-weight: 600;
  color: var(--color-black);
}

.cart-grid-right .promo-discounts .cart-summary-line .label {
  font-size: 1rem;
  color: var(--color-black-light);
}

.cart-grid-right .promo-discounts .cart-summary-line .label .code {
  color: #f49d6e;
}

.block-promo .promo-code .alert-danger {
  position: relative;
  display: none;
  margin-top: 1.25rem;
  color: var(--color-white-light);
  background: var(--color-error);
}

.block-promo .promo-code .alert-danger::after {
  border: solid transparent;
  border-width: 10px;
  border-bottom-color: var(--color-error);
}

.block-promo .promo-input {
  color: var(--color-black);
  text-indent: 0.625rem;
  border: var(--color-black-light) 1px solid;
}

.block-promo .promo-input+button {
  text-transform: capitalize;
  border: 2px solid var(--color-primary);
}

.block-promo .cart-summary-line .label,
.block-promo .promo-name {
  font-weight: 600;
  color: #ff9a52;
}

.block-promo .cart-summary-line .label a,
.block-promo .promo-name a {
  font-weight: 500;
  color: var(--color-black);
}

.block-promo .promo-name .cart-summary-line .label {
  font-weight: 500;
  color: #363a42;
}

.block-promo .promo-name .cart-summary-line span {
  color: #f49d6e;
}

.block-promo .promo-code-button.cancel-promo {
  color: var(--color-primary);
}

.product-line-grid-body>.product-line-info>.out-of-stock {
  color: red;
}

.product-line-grid-body>.product-line-info>.available {
  color: var(--color-validation);
}

.product-line-grid-body>.product-line-info .unit-price-cart {
  font-weight: 500;
  color: var(--color-black-light);
}

.product-line-grid-right .cart-line-product-actions {
  color: var(--color-black);
}

.product-line-grid-right .cart-line-product-actions .remove-from-cart,
.product-line-grid-right .product-price .remove-from-cart {
  color: var(--color-black);
}

#block-reassurance li {
  border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}

.quickview .modal-content {
  background: var(--color-white);
}

.quickview .modal-footer {
  border-top: 1px solid rgba(122, 122, 122, 0.3);
}

.quickview .images-container .product-images>li.thumb-container .thumb {
  background: var(--color-white-light);
}

#stores .page-stores .store-item-container .divide-left {
  border-left: var(--color-white) 1px solid;
}

#stores .page-stores .store-item-footer.divide-top {
  border-top: var(--color-white) 1px solid;
}

#stores .page-stores .store-item-footer i.material-icons {
  color: var(--color-black-light);
}

.block-contact,
.footer-container li a {
  color: var(--color-black-light);
}

#block_myaccount_infos .myaccount-title a,
#header a,
.block-contact .block-contact-title,
.block-contact .navbar-toggler .material-icons,
.linklist .blockcms-title a {
  color: var(--color-black);
}

.account-list a:hover,
.block_newsletter form button[type='submit'] .search:hover,
.footer-container li a:hover {
  color: var(--color-secondary);
}

.block-social ul li {
  background-color: var(--color-white);
}

.block-social ul li:hover {
  background-color: var(--color-primary);
}

.contact-rich .block .data {
  color: var(--color-black);
}

.contact-form {
  color: var(--color-black-light);
  background: var(--color-white-light);
}

.contact-form h3,
.contact-rich h4 {
  color: var(--color-black);
  text-transform: uppercase;
}

#pagenotfound .page-not-found,
#products .page-not-found {
  color: var(--color-black-light);
  background: transparent;
}

.customization-modal .modal-content {
  border: 1px solid var(--color-white);
  border-radius: 0;
}

.customization-modal .modal-content .modal-body .product-customization-line {
  border-bottom: 1px solid var(--color-white);
}

.sitemap h2 {
  font-weight: 600;
  color: var(--color-black);
  text-transform: uppercase;
  border-bottom: 1px solid var(--color-black-light);
}

.block_newsletter {
  background: var(--color-white-light);
}

.block_newsletter form input[type='text']:focus {
  color: var(--color-black);
  background: var(--color-white-light);
  outline: 2px var(--color-primary) solid;
}

.block_newsletter #block-newsletter-label {
  color: var(--color-black);
}

.block_newsletter form .row .col-xs-12:last-of-type .page-content.page-cms ul,
.block_newsletter form .row .col-xs-12:last-of-type p,
.page-content.page-cms .block_newsletter form .row .col-xs-12:last-of-type ul {
  color: var(--color-black-light);
}

#header .header-nav {
  border-bottom: none;
}

.progress {
  background: #dbdbdb;
}

@media print {

  blockquote,
  pre {
    border: 1px solid #999;
  }

  .btn>.caret,
  .dropup>.btn>.caret {
    border-top-color: #000 !important;
  }

  .tag {
    border: 1px solid #000;
  }

  .table td,
  .table th {
    background-color: var(--color-white-light) !important;
  }

  .table-bordered td,
  .table-bordered th {
    border: 1px solid var(--color-white-light) !important;
  }
}

@media (max-width: 575px) {
  .cart-item {
    border-bottom: 1px solid var(--color-white);
  }

  #stores .page-stores .store-item-footer.divide-top {
    border-top: var(--color-white) 1px solid;
  }
}

@media (max-width: 767px) {
  .header-top .search-widget form input[type='text'] {
    background: var(--color-white-light);
  }

  #order-details .card-title,
  #order-items .card-title {
    border: none;
  }

  #order-items hr {
    border-top-color: var(--color-white);
  }

  #category #left-column #search_filters .facet .facet-title {
    color: var(--color-black);
    text-transform: uppercase;
  }

  #category #left-column #search_filters .facet ul li {
    border-top: 1px solid var(--color-white);
  }
}

@media (max-width: 991px) {
  .carousel {
    background-color: var(--color-white);
  }

  .carousel .carousel-item .caption .display-1 {
    font-weight: 500;
    color: var(--color-black);
  }

  .carousel .carousel-item .caption .caption-description .page-content.page-cms ul,
  .carousel .carousel-item .caption .caption-description h3,
  .carousel .carousel-item .caption .caption-description p,
  .page-content.page-cms .carousel .carousel-item .caption .caption-description ul {
    color: var(--color-black-light);
  }

  .carousel .direction .carousel-control i {
    background: rgba(122, 122, 122, 0.5);
  }
}

@media screen and (min-width: 0\0) {
  .progress-bar {
    background-color: #0074d9;
  }

  .progress-bar-striped {
    background-image: linear-gradient(45deg,
        rgba(255, 255, 255, 0.15) 25%,
        transparent 25%,
        transparent 50%,
        rgba(255, 255, 255, 0.15) 50%,
        rgba(255, 255, 255, 0.15) 75%,
        transparent 75%,
        transparent);
    background-size: 1rem 1rem;
  }

  .progress-success .progress-bar {
    background-color: var(--color-validation);
  }

  .progress-info .progress-bar {
    background-color: #5bc0de;
  }

  .progress-warning .progress-bar {
    background-color: #ff9a52;
  }

  .progress-danger .progress-bar {
    background-color: var(--color-error);
  }
}