:root {
  --font: 'Montserrat', sans-serif;
  --font2: 'Montserrat', sans-serif;
  --font-size: 15px;
  --thin: 300;
  --bold: 600;
  /* sizes & spacings */
  --body: #271f15;
  --color: #444;
  --main: #fff;
  --container: 1440px;
  --narrow: 1000px;
  --flow: 1.2em;
  --x: 1.5rem;
  --x-lg: 3rem;
  --y: 3rem;
  --y-lg: 6rem;
  --space1: .6875rem;
  --space2: 2rem;
  --space3: 3rem;
  --space4: 4rem;
  --space5: 5rem;
  --radius: 0;
  /* navigation */
  --header: rgba(255, 255, 255, .95);
  --nav: 70px;
  --lang-y: 30px;
  --logo: url(../i/logo.webp);
  --logo-alt: url(../i/logo-alt.png?2);
  --logo-alt-y: 100px;
  --logo-alt-y-md: 130px;
  --logo-alt-y-lg: 150px;
  --noban-logo-alt: invert(21%) sepia(38%) saturate(856%) hue-rotate(350deg) brightness(98%) contrast(95%);
  /* menu burger */
  --burger: #000;
  --burger-alt: #fff;
  --burger-close: #fff;
  /* mobile menu */
  --menu-x: 100vw;
  --menu-bg: linear-gradient(20deg, #161719 30%, #2E3031 100%);
  --menu: #ccc;
  --menu-active: #fff;
  --submenu: #999;
  /* desktop menu */
  --nav-bg: rgba(255, 255, 255, 1);
  --menu-lg: #666;
  --menu-lg-active: #000;
  --menu-lg-alt: #fff;
  /* desktop submenu */
  --submenu-lg-bg: #111;
  --submenu-lg-bg-hover: #333;
  --submenu-lg: #ccc;
  --submenu-lg-active: #888;
  /* subnav mobile & desktop */
  --subnav-y: 44px;
  --subnav-bg: #eee;
  --subnav: #666;
  --subnav-active: #583619;
  /* colors */
  --link: #8f663d;
  --ac: #8f663d;
  --ac2: #583619;
  --ac3: #cf9963;
  --ac4: #EFEAE6;
  --c0: #000;
  --c1: #222;
  --c2: #333;
  --c3: #555;
  --c4: #666;
  --c5: #888;
  --c6: #aaa;
  --c7: #ccc;
  --c8: #eee;
  --c9: #f4f4f5;
  --fff: #fff;
  --gr1: #8f663d;
  --gr2: #836a49;
  /* buttons */
  --btn-pad: 1.125em 1.375em 1em 1.5625em;
  --wa: #31CA68;
  --wz: #3DC6F5;
  --cta: #31CA68;
  --social: invert(0%);
  --social-sm: invert(20%);
  --cta-url: url(../i/whatsapp.svg);
  /* misc */
  --cyc: 300px;
  --cyc-md: 70vh;
}

/* modal */
.modal {
  font-size: .813rem;
  padding: 2rem 2.875rem 2rem 2rem;
  position: fixed;
  cursor: pointer;
  z-index: 18;
  margin: 1rem;
  border-radius: var(--radius);
  max-height: calc(100vh - 2rem);
  overflow-y: auto;
  max-width: 450px;
  bottom: 0;
}

.modal h3 {
  font-size: 1.125rem;
}

.modal h4 {
  font-size: .75rem;
}

.modal::after {
  content: "×";
  position: absolute;
  right: .875rem;
  top: -.1875rem;
  font-size: 36px;
  font-family: Arial, sans-serif;
}

@media (min-width:1200px) and (min-height:700px) {
  .modal {
    bottom: 0;
    max-height: 600px;
    font-size: 100%
  }
}

/* Site custom styles */
footer {
  color: #796855;
  padding-bottom: var(--space5);
  padding-top: var(--space2);
}

footer .flow>*+* {
  margin-top: .25rem;
}

footer h4,
footer h4 a {
  font-size: .813rem;
  color: var(--c8) !important;
  letter-spacing: 4px;
}

footer p {
  font-size: .75rem;
}

footer ul {
  padding-left: 0 !important;
  list-style: none !important;
  font-size: .813rem;
  line-height: 1.2;
  margin-bottom: 1.5rem;
}

footer a {
  color: #8b7c6a !important;
}

footer li.active>a {
  color: #d3bca4 !important;
}

footer .social {
  filter: invert(80%) !important;
}

footer .social img {
  width: 25px;
}

.copyright p {
  color: #796855 !important;
  font-size: .5rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  border-top: 1px solid #352d24;
}

.copyright a {
  color: #796855 !important;
}

@media (min-width: 1200px) and (min-height: 870px) {
  main {
    margin-bottom: 800px;
  }

  footer {
    position: fixed;
    bottom: 0;
    width: 100vw;
    height: 800px;
    z-index: -1;
  }
}

main h1,
main h2,
main h3 {
  color: var(--ac)
}

h4,
[class*=btn-] {
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-size: .9375rem;
}

[class*=btn-] {
  font-size: .813rem !important;
}

p.note {
  font-style: normal;
  font-size: .6875rem;
  line-height: 1.4;
}

.sop img {
  margin: 0 auto;
  width: 44px
}

.sop {
  margin-bottom: 5rem;
  margin-top: 1rem
}

.sop [class*=col-] {
  margin-top: 1.5rem;
}

.sop .col-11 {
  padding-left: 1.5rem;
}

@media screen and (min-width: 1200px) {
  .sop {
    padding-right: 1rem;
    padding-left: 1rem;
  }
}

.hue img {
  filter: invert(100%) brightness(50%);
  width: 32px;
  padding-right: .375rem;
  margin-top: 1rem;
}

.lead,
big {
  opacity: .75;
}

@media screen and (min-width: 1200px) {
  li.m5>.submenu {
    left: auto;
    right: 0;
  }
}

/* Accordion */
.acco,
details {
  display: block;
  margin-bottom: 1.5rem;
  padding-bottom: .25rem;
  border-bottom: 1px dotted #ddd;
}

.acco:last-child,
details:last-child {
  border-bottom: none;
}

.acco>*:first-child,
details summary {
  position: relative;
  font-weight: var(--bold);
  line-height: 1.5;
  list-style-type: none;
  cursor: pointer;
  transition: color .4s ease-in-out;
  padding-right: 3rem;
}

details summary::-webkit-details-marker,
details summary::marker {
  display: none
}

details summary::-moz-list-bullet {
  list-style-type: none
}

.acco>*:first-child::after,
details summary::after {
  content: "";
  display: block;
  width: 1.5rem;
  height: 1.5rem;
  position: absolute;
  right: 0;
  top: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='rgba(0,0,0,.6)' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat center;
  background-size: 1.25rem auto;
  transition: transform .2s ease-in-out
}

.acco>*:first-child.is-open,
details summary:focus {
  outline: 0;
  color: var(--ac);
}

.acco>*:first-child~*,
details summary~* {
  margin-top: .813rem;
  padding-right: 3rem;
}

.acco>*:first-child~* {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.2s ease-in-out;
}

.acco>*:first-child~*~*,
details summary~*~* {
  margin-top: 0
}

.acco>*:first-child.is-open,
details[open]>summary {
  margin-bottom: var(--space)
}

.acco>*:first-child.is-open::after,
details[open]>summary::after {
  transform: rotate(-180deg);
}

.acco p {
  margin-bottom: 1.25rem
}

.acco ul {
  margin-top: 0;
  margin-bottom: 1.5rem
}

.acco ul+p {
  margin-bottom: 0
}

.bw-widget * {
  font-family: var(--font) !important;
}

/* EMbla */
.embla {
  max-width: 100%;
  margin: auto;
  --slide-spacing: 1rem;
}

.embla__viewport {
  overflow: hidden;
}

.embla .embla__container {
  display: flex;
  align-items: center;
  touch-action: pan-y pinch-zoom;
  margin-left: calc(var(--slide-spacing) * -1);
}

.embla .embla__slide {
  transform: translate3d(0, 0, 0);
  flex: 0 0 auto;
  width: min(90%, 350px);
  padding-left: var(--slide-spacing);
  padding-bottom: 3rem
}

@media screen and (min-width: 1200px) {
  .embla {
    position: relative;
    margin-top: -6rem;
    z-index: 5;
  }
}

.slide {
  padding: 1.5rem;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 50px 20px -50px rgba(71, 59, 48, 0.05), 0 8px 20px 0 rgba(71, 59, 48, 0.1);
  min-height: 280px;
}

.slide-top {
  border-bottom: 1px solid #EFEAE6;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-bottom: 1rem;
}

.slide-top h4 {
  width: 100%;
  font-size: .875rem;
  letter-spacing: 0;
  padding-bottom: 1rem;
  background: transparent url(../i/stars.svg) no-repeat left bottom;
  background-size: auto 13px;
}

.slide-bottom {
  padding-top: 1rem;
  font-size: .813rem
}

.splide-bottom p:last-child {
  margin-bottom: 0;
}

.avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: #E8E4D1;
  color: #fff;
  font-weight: 600;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-transform: uppercase;
  flex-shrink: 0;
}

.embla .t-date {
  margin-top: .5rem;
  font-size: .6875rem;
  opacity: .6
}

.caro {
  max-width: 100%;
  margin: auto;
  position: relative;
  background: #fff;
}

.caro .embla__container {
  display: flex;
}

.caro .embla__slide {
  flex: 0 0 100%;
}

.dots {
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 0.5rem;
  z-index: 8;
  padding: 0.3rem 0.8rem;
  border-radius: 20px;
}

.dot {
  border: none;
  padding: 0;
  margin: 0;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .6);
  cursor: pointer;
  display: inline-block;
  line-height: 0;
  box-sizing: content-box;
}

.dot.is-selected {
  background: #fff;
}

.shade {
  position: relative;
}

.shade::after {
  display: block;
  content: "";
  width: 100%;
  height: 100px;
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(to top, rgba(167, 160, 140, 0) 0%, rgba(167, 160, 140, .7) 100%);
  pointer-events: none;
}

@media screen and (max-width: 767px) {
  .caro img {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
  }
}

.soldout {
  filter: saturate(0);
  pointer-events: none;
  opacity: .5;
}
