@font-face {
  font-family: S;
  src: url('../fonts/s_italic.ttf') format("truetype");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: S;
  src: url('../fonts/s_regular.ttf') format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --beige: #f4eae0;
  --cafe: #4b351d;
  --transparent: #fff0;
  --cajeta: #a4784c;
}

body {
  color: #333;
  font-family: S, Times New Roman, sans-serif;
  font-size: 14px;
  line-height: 20px;
  transition: opacity .8s;
}

.body-home {
  background-color: #d1aeae;
  background-image: url('../images/Home.jpg');
  background-position: 50% 0;
  background-repeat: no-repeat;
  background-size: auto;
  height: 5000px;
}

.section-hero {
  height: 100vh;
}

.header {
  z-index: 4;
  padding: 2rem;
  position: absolute;
  inset: 0% 0% auto;
}

.container-header {
  justify-content: space-between;
  align-items: center;
  max-width: 112rem;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.img-logo {
  width: 11rem;
}

.menu-group {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  display: flex;
}

.link-menu {
  color: var(--beige);
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1em;
  text-decoration: none;
}

.slider-hero {
  background-color: var(--transparent);
  height: 100%;
}

.nav-hero {
  display: none;
}

.img-slider {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.slider-group {
  width: 100%;
  height: 100%;
  position: relative;
}

.card-hero {
  z-index: 1;
  padding-left: 2rem;
  padding-right: 2rem;
  position: absolute;
  inset: auto 0% 0%;
}

.container-card-hero {
  max-width: 112rem;
  margin-left: auto;
  margin-right: auto;
}

.card-graphic {
  background-image: linear-gradient(180deg, #f4eae000 21%, var(--beige)), url('../images/textura_papel.jpg');
  background-position: 0 0, 0 0;
  background-size: auto, auto;
  width: 35rem;
  padding: 4rem;
  box-shadow: 6px -6px 7px #0003;
}

.hero-title {
  color: var(--cafe);
  margin-top: 0;
  margin-bottom: 3rem;
  font-family: S, Times New Roman, sans-serif;
  font-size: 4rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1em;
}

.btn-link {
  color: var(--cajeta);
  padding-bottom: .8rem;
  font-family: Times New Roman, TimesNewRoman, Times, Baskerville, Georgia, serif;
  font-size: 1.4rem;
  line-height: 1em;
  text-decoration: none;
  display: inline-block;
  position: relative;
}

.linea-abajo {
  border-bottom: 1px solid var(--cafe);
  color: var(--transparent);
  width: 20%;
  height: 0;
  position: absolute;
  bottom: 0;
  left: 0;
}

.degradado-hero {
  z-index: 1;
  background-image: linear-gradient(#221609a3 16%, #0000);
  height: 40%;
  position: absolute;
  inset: 0% 0% auto;
}

.section-espacios-privados {
  background-color: var(--beige);
  padding: 4.1rem 2rem 2.8rem;
}

.container-espacios {
  flex-flow: column;
  justify-content: space-between;
  align-items: stretch;
  max-width: 112rem;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.nav-espacios {
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 4rem;
  display: flex;
}

.btn-lugar {
  color: var(--cafe);
  text-transform: uppercase;
  cursor: pointer;
  margin-bottom: 0;
  font-size: 1.8rem;
  line-height: 1em;
}

.btn-lugar.on {
  color: var(--cajeta);
}

.tab-location {
  justify-content: space-between;
  align-items: flex-end;
  display: none;
}

.tab-location.on {
  display: flex;
}

.dato-cuando {
  color: var(--cafe);
  text-align: right;
  margin-top: 1.8rem;
  margin-bottom: 0;
  font-family: S, Times New Roman, sans-serif;
  font-size: 2.6rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1em;
}

.col-a-tabs {
  width: 24.7rem;
  padding-bottom: 4.7rem;
}

.p-location {
  color: var(--cafe);
  margin-bottom: 0;
  font-size: 1.5rem;
  line-height: 1.3em;
}

.col-b-tabs {
  width: 70.7rem;
}

.imagen-tabs {
  aspect-ratio: 3 / 1.95;
  object-fit: cover;
  width: 100%;
}

.slider-galeria {
  border: 1px solid var(--cafe);
  background-color: var(--transparent);
  height: auto;
  padding: 1.5rem;
}

.nav-galeria {
  display: none;
}

.row-bottom-galeria {
  justify-content: space-between;
  align-items: center;
  margin-top: 1.2rem;
  display: flex;
}

.btn-link-instagram {
  color: var(--cafe);
  background-image: url('../images/instagram_icon.svg');
  background-position: 0%;
  background-repeat: no-repeat;
  background-size: auto 100%;
  padding-bottom: 0;
  padding-left: 2rem;
  font-family: Times New Roman, TimesNewRoman, Times, Baskerville, Georgia, serif;
  font-size: 1.4rem;
  line-height: 1em;
  text-decoration: none;
  display: inline-block;
  position: relative;
}

.link-espacios {
  color: var(--cafe);
}

.section-favoritos {
  background-image: url('../images/textura_2.jpg');
  background-position: 0 0;
  background-repeat: repeat;
  background-size: auto;
  padding: 7.3rem 2rem 15.6rem;
  overflow: hidden;
}

.container-favoritos {
  max-width: 112rem;
  margin-left: auto;
  margin-right: auto;
}

.fila-top-favoritos {
  justify-content: flex-start;
  align-items: flex-end;
  margin-bottom: 7.6rem;
  display: flex;
}

.titulo-favoritos {
  color: var(--cafe);
  margin-top: 0;
  margin-bottom: 0;
  font-size: 4rem;
  font-weight: 400;
  line-height: 1em;
}

.de-la-casa {
  margin-left: 9.2rem;
}

.p-top-favoritos {
  color: var(--cafe);
  width: 30.1rem;
  margin-bottom: 0;
  margin-left: 4.9rem;
  font-size: 1.8rem;
  line-height: 1.3em;
}

.slider-favoritos {
  background-color: var(--transparent);
  height: auto;
  margin-left: -.6rem;
  margin-right: -.6rem;
}

.nav-favoritos {
  display: none;
}

.slide-favorito {
  width: 20%;
}

.inside-favorito {
  float: left;
  width: 20%;
  padding-left: .6rem;
  padding-right: .6rem;
}

.inside-favorito.hide {
  display: none;
}

.imagen-favorito {
  aspect-ratio: 2 / 2.46;
  object-fit: cover;
  width: 100%;
  margin-bottom: .8rem;
}

.titulo-favorito {
  color: var(--cafe);
  margin-bottom: 0;
  font-size: 1.7rem;
  line-height: 1.3em;
}

.section-hablemos {
  background-color: #503317;
  padding-bottom: 3.3rem;
  position: relative;
}

.container-hablemos {
  max-width: 112rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: 2rem;
  padding-right: 2rem;
}

.logo-cafe {
  width: 39rem;
  margin-bottom: .4rem;
  margin-left: auto;
  margin-right: auto;
  display: block;
  position: relative;
  top: -8.5rem;
}

.p-nosotros {
  color: var(--beige);
  text-align: center;
  width: 48rem;
  margin: -6.9rem auto 3.8rem;
  font-size: 1.8rem;
  line-height: 1.3em;
}

.slider-hablemos {
  background-color: var(--transparent);
  max-width: 130rem;
  height: auto;
  margin-left: auto;
  margin-right: auto;
  display: none;
}

.slider-hablemos.on {
  display: block;
}

.icono {
  border-bottom: 1px solid var(--beige);
  border-left: 1px solid var(--beige);
  color: var(--transparent);
  width: 3rem;
  height: 3rem;
  left: auto;
  right: 11%;
  transform: rotate(45deg);
}

.icono.next {
  left: 11%;
  right: auto;
  transform: rotate(-135deg);
}

.arrow {
  width: 6.3rem;
}

.hide-hablemos {
  display: none;
}

.slide-inside {
  border: 1px solid var(--beige);
  background-color: #503317;
  margin-left: auto;
  margin-right: auto;
  padding: 3.9rem 3.9rem 3.8rem;
  position: relative;
}

.mask {
  margin-left: 6.3rem;
  margin-right: 6.3rem;
}

.titulo-lugar {
  z-index: 1;
  color: var(--beige);
  text-transform: uppercase;
  width: 26rem;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 3.07rem;
  line-height: 1.2em;
  position: absolute;
  top: 6rem;
  left: 4rem;
}

.imagen-salas {
  aspect-ratio: 3 / 2;
  object-fit: cover;
  width: 54.9rem;
  margin-left: auto;
  margin-right: auto;
  display: block;
  position: relative;
  right: 1.2rem;
}

.p-lugar {
  color: var(--beige);
  width: 20.9rem;
  margin-bottom: 0;
  font-size: 1.8rem;
  line-height: 1.3em;
  position: absolute;
  inset: auto 4.7rem 4.4rem auto;
}

.top-lugar {
  font-style: italic;
}

.section-gallery {
  z-index: 5;
  display: none;
  position: fixed;
  inset: 0%;
}

.gallery-flex {
  justify-content: center;
  align-items: center;
  height: 100%;
  display: flex;
}

.slider-gallery {
  aspect-ratio: 3.5 / 2;
  background-color: var(--transparent);
  width: 100%;
  height: auto;
}

.puntos-slider {
  color: var(--beige);
  height: 1.8rem;
  padding-top: .8rem;
  font-size: .3rem;
  line-height: 1em;
}

.nav-gallery {
  width: 5rem;
  margin-bottom: 1.8rem;
}

.icon-galleria {
  border-bottom: 1px solid var(--beige);
  border-left: 1px solid var(--beige);
  color: var(--transparent);
  width: 1rem;
  height: 1rem;
  transform: rotate(45deg);
}

.icon-galleria.right {
  transform: rotate(-135deg);
}

.mask-gallery {
  margin-left: 5rem;
  margin-right: 5rem;
  padding-bottom: 1.8rem;
}

.close-gallery {
  z-index: 0;
  background-color: #0c0804e0;
  position: absolute;
  inset: 0%;
}

.img-galeria {
  border: 1px solid var(--beige);
  object-fit: cover;
  width: 100%;
  height: 100%;
  padding: 1.5rem;
}

.gallery-group {
  z-index: 1;
  width: 100%;
  max-width: 69rem;
  display: none;
  position: relative;
}

.gallery-group.on {
  display: block;
}

.titulo-galeria {
  color: var(--beige);
  text-transform: uppercase;
  cursor: pointer;
  margin-bottom: 2rem;
  margin-left: 5rem;
  margin-right: 5rem;
  font-size: 1.8rem;
  line-height: 1em;
}

.titulo-galeria.on {
  color: var(--cajeta);
}

.btn-galeria {
  color: var(--cajeta);
  padding-bottom: .8rem;
  font-family: Times New Roman, TimesNewRoman, Times, Baskerville, Georgia, serif;
  font-size: 1.4rem;
  line-height: 1em;
  text-decoration: none;
  display: inline-block;
  position: relative;
}

.btn-privado {
  color: var(--cajeta);
  cursor: pointer;
  margin-bottom: 0;
  font-size: 1.4rem;
  line-height: 1em;
}

.btn-privado.on {
  color: var(--beige);
}

.section-footer {
  background-color: var(--beige);
  padding: 5rem 2rem;
}

.container-footer {
  max-width: 112rem;
  margin-left: auto;
  margin-right: auto;
}

.row-footer-top {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 7rem;
  display: flex;
}

.menu-group-footer {
  grid-column-gap: 4rem;
  grid-row-gap: 4rem;
  display: flex;
}

.link-footer {
  color: var(--cafe);
  text-transform: uppercase;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1em;
  text-decoration: none;
}

.socials-links {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  display: flex;
}

.link-social {
  color: var(--cajeta);
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1em;
  text-decoration: none;
}

.row-footer-bottom {
  justify-content: space-between;
  align-items: flex-end;
  display: flex;
}

.img-logo-footer {
  width: 7rem;
}

.legal-links {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-end;
  display: flex;
}

.legal-link {
  color: var(--cafe);
  margin-bottom: 0;
  font-size: .9rem;
  font-weight: 400;
  line-height: 1em;
  text-decoration: none;
}

.r-footer {
  margin-left: .2rem;
  font-size: .8em;
  position: relative;
  top: -.3rem;
}

.body-nosotros {
  background-image: url('../images/Nosotros.jpg');
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: auto;
  height: 4000px;
}

.section-hero-nosotros {
  justify-content: space-between;
  align-items: stretch;
  height: 67.1rem;
  padding: 2rem 2rem 4.6rem;
  display: flex;
  position: relative;
}

.container-hero-nosotros {
  z-index: 2;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  max-width: 108rem;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: relative;
}

.icono-bottom-nosotros {
  width: 3.3rem;
  position: absolute;
  bottom: 0;
  left: 0;
}

.imagen-side-hero-nosotros {
  z-index: 0;
  object-fit: cover;
  width: 39.2rem;
  height: 91%;
  position: absolute;
  bottom: 0%;
  left: auto;
  right: 9.6rem;
}

.titulo-nosotros {
  z-index: 1;
  color: var(--beige);
  margin: 0 auto 14rem;
  font-size: 2.6rem;
  font-weight: 400;
  line-height: 1.2em;
  position: relative;
}

.script {
  font-style: italic;
}

.imagen-fondo {
  z-index: -1;
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: fixed;
  inset: 0%;
}

.section-nosotros-dos {
  justify-content: space-between;
  align-items: stretch;
  height: 67.6rem;
  padding: 2rem;
  display: flex;
  position: relative;
  overflow: hidden;
}

.container-hero-nosotros-dos {
  z-index: 3;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  max-width: 108rem;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: relative;
}

.mexico-fondo {
  z-index: 2;
  opacity: .3;
  width: 55.6rem;
  position: absolute;
  inset: auto auto -7.2rem -3.1rem;
}

.p-nosotros-dos {
  color: var(--beige);
  margin-bottom: 0;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.35em;
}

.btn-disponibilidad {
  color: var(--cajeta);
  padding-bottom: .8rem;
  font-family: Times New Roman, TimesNewRoman, Times, Baskerville, Georgia, serif;
  font-size: 1.4rem;
  line-height: 1em;
  text-decoration: none;
  display: inline-block;
  position: relative;
}

.linea-disponibilidad {
  border-bottom: 1px solid var(--beige);
  color: var(--transparent);
  width: 20%;
  height: 0;
  position: absolute;
  bottom: 0;
  left: 0;
}

.intro-hero-nosotros {
  z-index: 1;
  width: 50%;
  margin-right: auto;
  position: relative;
}

.p-texto-nosotros {
  color: var(--beige);
  max-width: 57.8rem;
  margin-bottom: 0;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.35em;
}

.section-pilares {
  background-image: url('../images/textura_2.jpg');
  background-position: 0 0;
  background-repeat: repeat;
  background-size: auto;
  padding: 8rem 2rem;
  overflow: hidden;
}

.container-pilares {
  max-width: 112rem;
  margin-left: auto;
  margin-right: auto;
}

.titulo-pilares {
  color: var(--cafe);
  margin-top: 0;
  margin-bottom: 6rem;
  font-size: 4rem;
  font-weight: 400;
  line-height: 1em;
}

.lista-pilares {
  grid-row-gap: 9rem;
  background-color: var(--transparent);
  flex-flow: wrap;
  justify-content: space-between;
  align-items: stretch;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.col-pilares.hide {
  display: none;
}

.col-pilares.final {
  width: 29%;
}

.titulo-elem-pilares {
  color: var(--cafe);
  margin-bottom: 0;
  font-size: 1.7rem;
  line-height: 1.3em;
}

.titulo-menor-pilares {
  color: var(--cafe);
  margin-bottom: 0;
  font-size: 1.2rem;
  font-style: italic;
  line-height: 1.3em;
}

.p-desc-pilares {
  color: var(--cafe);
  max-width: 57.8rem;
  margin-top: 3rem;
  margin-bottom: 0;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.35em;
}

.section-hero-experiencia {
  justify-content: space-between;
  align-items: stretch;
  height: 60rem;
  padding: 8rem 2rem 2rem;
  display: flex;
  position: relative;
}

.container-hero-experiencia {
  z-index: 2;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  max-width: 103rem;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: relative;
}

.imagen-side-hero-experiencia {
  z-index: 0;
  aspect-ratio: 1;
  opacity: .68;
  object-fit: cover;
  width: 43rem;
  position: absolute;
}

.intro-hero-experiencia {
  z-index: 1;
  text-align: center;
  width: 100%;
  max-width: 60rem;
  margin-left: auto;
  position: relative;
}

.titulo-experiencia {
  z-index: 1;
  color: var(--beige);
  margin: 0 auto 14rem;
  font-size: 2.6rem;
  font-weight: 400;
  line-height: 1.2em;
  position: relative;
}

.p-experiencia {
  color: var(--beige);
  max-width: 48rem;
  margin-bottom: 0;
  margin-left: auto;
  margin-right: auto;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.35em;
}

.icono-bottom-experiencia {
  width: 3.3rem;
  margin-top: 3rem;
}

.section-quote {
  padding: 2rem;
}

.quote-experiencia {
  color: var(--beige);
  text-align: center;
  max-width: 62rem;
  margin: 0 auto;
  font-size: 2.8rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1.35em;
}

.section-experiencia {
  justify-content: space-between;
  align-items: stretch;
  height: 41rem;
  padding: 2rem;
  display: flex;
  position: relative;
}

.container-hero-experiencia-bis {
  z-index: 3;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  max-width: 108rem;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: relative;
}

.p-texto-experiencia {
  color: var(--beige);
  max-width: 49rem;
  margin-bottom: 0;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.35em;
}

.section-recomendaciones {
  background-image: url('../images/textura_papel.jpg');
  background-position: 0 0;
  background-repeat: repeat;
  background-size: auto;
  padding: 8rem 2rem;
  overflow: hidden;
}

.container-recomendaciones {
  max-width: 112rem;
  margin-left: auto;
  margin-right: auto;
}

.titulo-recomendaciones {
  color: var(--cafe);
  max-width: 40rem;
  margin-top: 0;
  margin-bottom: 1rem;
  font-size: 4rem;
  font-weight: 400;
  line-height: 1em;
}

.sub-titulo-recomendaciones {
  color: var(--cafe);
  margin-bottom: 4rem;
  font-size: 1.7rem;
  line-height: 1.3em;
}

.section-degustacion {
  background-image: url('../images/textura.png'), url('../images/textura_2.jpg');
  background-position: 0 0, 0 0;
  background-repeat: repeat-x, repeat;
  background-size: auto, auto;
  padding: 8rem 2rem;
  overflow: hidden;
}

.col-brindis {
  float: left;
  width: 33.33%;
  padding-left: 1rem;
  padding-right: 1rem;
}

.col-brindis.hide {
  display: none;
}

.container-brindis {
  max-width: 112rem;
  margin-left: auto;
  margin-right: auto;
}

.titulo-brindis {
  color: var(--cafe);
  width: 27rem;
  margin-top: 0;
  margin-bottom: 6rem;
  font-size: 4rem;
  font-weight: 400;
  line-height: 1em;
}

.titulo-elem-brindis {
  color: var(--cafe);
  margin-bottom: 0;
  font-size: 1.7rem;
  font-style: italic;
  line-height: 1.3em;
}

.p-desc-brindis {
  color: var(--cafe);
  max-width: 57.8rem;
  margin-top: 3rem;
  margin-bottom: 0;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.35em;
}

.section-unete {
  background-color: var(--cafe);
  justify-content: space-between;
  align-items: stretch;
  min-height: 100vh;
  padding: 2rem;
  display: flex;
  position: relative;
}

.container-unete {
  z-index: 2;
  background-color: var(--cafe);
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  max-width: 103rem;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: relative;
}

.imagen-side-hero-unete {
  z-index: 0;
  aspect-ratio: 1;
  mix-blend-mode: screen;
  object-fit: cover;
  width: 43rem;
  position: absolute;
}

.intro-hero-unete {
  z-index: 1;
  text-align: center;
  width: 100%;
  max-width: 60rem;
  margin-left: auto;
  position: relative;
}

.titulo-unete {
  z-index: 1;
  color: var(--beige);
  margin: 0 auto 5rem;
  font-size: 2.6rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1.2em;
  position: relative;
}

.p-unete {
  color: var(--beige);
  max-width: 48rem;
  margin-bottom: 0;
  margin-left: auto;
  margin-right: auto;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.35em;
}

.mail-jobs {
  color: var(--cajeta);
  font-style: italic;
}

.btn-hamb, .close-menu {
  display: none;
}

.row-pilares {
  grid-row-gap: 5rem;
  flex-flow: column;
  justify-content: space-between;
  align-items: center;
  width: 29%;
  display: flex;
}

.row-pilares.invert {
  flex-flow: column-reverse;
}

.row-pilares.final {
  flex-flow: row;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.imagen-pilar {
  width: 100%;
}

.imagen-pilar.final {
  aspect-ratio: 16 / 9;
  object-fit: cover;
  width: 64.5%;
}

.anchor-espacios {
  position: absolute;
  inset: -12rem 0% auto;
}

@media screen and (max-width: 991px) {
  .section-hero {
    height: 37rem;
  }

  .menu-group {
    background-color: var(--beige);
    flex-flow: column;
    justify-content: flex-start;
    align-items: center;
    width: 23rem;
    padding: 4rem 2rem;
    transition: all .2s;
    position: fixed;
    top: 0;
    right: -23rem;
  }

  .menu-group.on {
    z-index: 1;
    right: 0;
  }

  .link-menu {
    color: var(--cafe);
    font-size: 1rem;
  }

  .card-graphic {
    width: 28rem;
    padding: 2rem 2rem 4rem;
  }

  .hero-title {
    margin-bottom: 2rem;
    font-size: 3rem;
  }

  .btn-link, .btn-lugar {
    font-size: 1rem;
  }

  .dato-cuando {
    font-size: 2rem;
  }

  .col-a-tabs {
    width: 16rem;
    padding-bottom: 3.4rem;
  }

  .p-location {
    font-size: 1rem;
  }

  .col-b-tabs {
    width: 37rem;
  }

  .slider-galeria {
    padding: 1rem;
  }

  .btn-link-instagram {
    padding-left: 1.5rem;
    font-size: 1rem;
  }

  .section-favoritos {
    padding-bottom: 13rem;
  }

  .titulo-favoritos {
    font-size: 3rem;
  }

  .de-la-casa {
    margin-left: 3rem;
  }

  .p-top-favoritos {
    width: 24rem;
    font-size: 1.5rem;
  }

  .inside-favorito {
    width: 25%;
  }

  .inside-favorito.hide-resp-1 {
    display: none;
  }

  .titulo-favorito {
    font-size: 1rem;
  }

  .logo-cafe {
    width: 25rem;
  }

  .p-nosotros {
    width: 39.1rem;
    font-size: 1.5rem;
  }

  .slider-hablemos {
    z-index: 0;
  }

  .icono {
    width: 2rem;
    height: 2rem;
    right: 22%;
  }

  .icono.next {
    left: 22%;
  }

  .slide-inside {
    padding: 2.5rem;
  }

  .titulo-lugar {
    width: 16rem;
    font-size: 2rem;
    top: 4rem;
  }

  .imagen-salas {
    width: 100%;
    position: static;
  }

  .p-lugar {
    text-align: right;
    font-size: 1.5rem;
    bottom: 4rem;
    right: 4rem;
  }

  .btn-galeria, .btn-privado {
    font-size: 1rem;
  }

  .row-footer-top {
    flex-flow: column;
    margin-bottom: 5rem;
  }

  .link-footer {
    font-size: 1rem;
  }

  .socials-links {
    margin-top: 2rem;
  }

  .link-social {
    font-size: 1rem;
  }

  .row-footer-bottom {
    flex-flow: column;
    justify-content: space-between;
    align-items: center;
  }

  .legal-links {
    justify-content: flex-start;
    align-items: center;
    margin-top: 3rem;
  }

  .section-hero-nosotros {
    overflow: hidden;
  }

  .imagen-side-hero-nosotros {
    width: 33rem;
    height: auto;
    right: -11.1rem;
  }

  .titulo-nosotros {
    font-size: 2rem;
  }

  .section-nosotros-dos {
    height: 48rem;
  }

  .mexico-fondo {
    bottom: -24.2rem;
  }

  .p-nosotros-dos {
    max-width: 44rem;
    font-size: 1.5rem;
  }

  .btn-disponibilidad {
    font-size: 1rem;
    position: absolute;
    bottom: 4rem;
    left: 4rem;
  }

  .p-texto-nosotros {
    text-align: center;
    max-width: 35rem;
    margin-left: auto;
    margin-right: auto;
    font-size: 1.5rem;
  }

  .section-pilares {
    padding-bottom: 5rem;
  }

  .titulo-pilares {
    font-size: 3rem;
  }

  .col-pilares.final {
    width: 100%;
  }

  .titulo-elem-pilares {
    font-size: 1.5rem;
  }

  .p-desc-pilares {
    font-size: 1rem;
  }

  .section-hero-experiencia {
    overflow: hidden;
  }

  .container-hero-experiencia {
    justify-content: center;
    align-items: flex-start;
  }

  .imagen-side-hero-experiencia {
    opacity: 30;
    width: 31rem;
    left: -14rem;
  }

  .titulo-experiencia {
    font-size: 2rem;
  }

  .p-experiencia {
    font-size: 1.5rem;
  }

  .quote-experiencia {
    max-width: 49rem;
    font-size: 2rem;
  }

  .p-texto-experiencia {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    font-size: 1.5rem;
  }

  .titulo-recomendaciones {
    max-width: 37rem;
    margin-bottom: .3rem;
    font-size: 3rem;
  }

  .sub-titulo-recomendaciones {
    font-size: 1.5rem;
  }

  .titulo-brindis {
    font-size: 3rem;
  }

  .p-desc-brindis {
    margin-top: 2rem;
    font-size: 1rem;
  }

  .section-unete {
    min-height: 0;
    padding: 0;
  }

  .imagen-side-hero-unete {
    opacity: .3;
    width: 100%;
    height: 100%;
    inset: 0%;
  }

  .intro-hero-unete {
    max-width: none;
    margin-left: 0;
    padding: 6rem 2rem;
  }

  .btn-hamb {
    border-top: 1px solid var(--beige);
    border-bottom: 1px solid var(--beige);
    cursor: pointer;
    width: 3rem;
    height: 1rem;
    display: block;
  }

  .close-menu {
    z-index: 0;
    display: none;
    position: fixed;
    inset: 0%;
  }

  .row-pilares {
    width: 47%;
  }

  .row-pilares.final {
    flex-flow: column-reverse;
    width: 47%;
    margin-left: 0;
    margin-right: 0;
  }

  .imagen-pilar.final {
    aspect-ratio: 683 / 850;
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .dato-cuando {
    font-size: 1.5rem;
  }

  .col-a-tabs {
    width: 13rem;
    padding-bottom: 3rem;
  }

  .col-b-tabs {
    width: 30rem;
  }

  .titulo-favoritos {
    font-size: 2rem;
  }

  .p-top-favoritos {
    width: 16rem;
    font-size: 1rem;
  }

  .slide-inside {
    padding: 2rem;
  }

  .titulo-lugar {
    width: 15rem;
    font-size: 1.5rem;
  }

  .p-lugar {
    font-size: 1rem;
  }

  .titulo-galeria {
    margin-bottom: 1rem;
    font-size: 1.5rem;
  }

  .menu-group-footer {
    flex-flow: column;
    justify-content: center;
    align-items: center;
  }

  .socials-links {
    margin-top: 5rem;
  }

  .section-hero-nosotros {
    height: 61rem;
  }

  .imagen-side-hero-nosotros {
    right: -23.4rem;
  }

  .titulo-nosotros {
    margin-bottom: 7rem;
  }

  .intro-hero-nosotros {
    width: 72%;
  }

  .titulo-pilares {
    margin-bottom: 3rem;
    font-size: 2rem;
  }

  .lista-pilares {
    grid-row-gap: 6rem;
  }

  .section-hero-experiencia {
    height: 49rem;
  }

  .quote-experiencia {
    max-width: 34rem;
    font-size: 1.5rem;
  }

  .titulo-recomendaciones {
    max-width: 30rem;
    font-size: 2.5rem;
  }

  .titulo-brindis {
    width: 23rem;
    margin-bottom: 3rem;
    font-size: 2.5rem;
  }

  .titulo-elem-brindis {
    font-size: 1.3rem;
  }

  .titulo-unete {
    font-size: 2rem;
  }

  .p-unete {
    max-width: 31rem;
    font-size: 1rem;
  }
}

@media screen and (max-width: 479px) {
  .section-hero {
    height: 38rem;
  }

  .img-logo {
    width: 7rem;
  }

  .menu-group {
    width: 18rem;
    right: -18rem;
  }

  .card-graphic {
    width: 16rem;
    padding: 1rem 1rem 3rem;
  }

  .hero-title {
    font-size: 2rem;
  }

  .section-espacios-privados {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .nav-espacios {
    grid-row-gap: .7rem;
    flex-flow: wrap;
  }

  .btn-lugar {
    width: 50%;
  }

  .tab-location.on {
    flex-flow: column-reverse;
  }

  .dato-cuando {
    text-align: left;
  }

  .col-a-tabs {
    width: 100%;
    padding-top: 3rem;
    padding-bottom: 0;
  }

  .p-location {
    width: 60%;
  }

  .col-b-tabs {
    width: 100%;
  }

  .section-favoritos {
    padding-top: 4rem;
    padding-bottom: 8rem;
  }

  .fila-top-favoritos {
    flex-flow: column;
    justify-content: flex-start;
    align-items: flex-start;
    margin-bottom: 3rem;
  }

  .p-top-favoritos {
    margin-top: 1rem;
    margin-left: 0;
  }

  .slider-favoritos {
    width: 280%;
  }

  .section-hablemos {
    padding-bottom: 4rem;
  }

  .container-hablemos {
    padding-left: 3rem;
    padding-right: 3rem;
  }

  .logo-cafe {
    width: 17rem;
    top: -5.8rem;
  }

  .p-nosotros {
    width: auto;
    margin-top: -5rem;
    font-size: 1rem;
  }

  .icono {
    width: 1rem;
    height: 1rem;
  }

  .arrow {
    width: 3rem;
  }

  .slide-inside {
    padding: 1rem;
  }

  .mask {
    margin-left: 3rem;
    margin-right: 3rem;
  }

  .titulo-lugar {
    margin-bottom: 1rem;
    position: static;
    top: 2rem;
    left: 2rem;
  }

  .p-lugar {
    width: auto;
    margin-top: 1rem;
    position: static;
    bottom: 2rem;
    right: 2rem;
  }

  .img-galeria {
    border-style: none;
    padding: 0;
  }

  .btn-privado {
    width: 50%;
  }

  .section-hero-nosotros {
    height: auto;
    padding-top: 8rem;
    padding-bottom: 4rem;
  }

  .icono-bottom-nosotros {
    margin-bottom: 2rem;
    position: static;
  }

  .imagen-side-hero-nosotros {
    margin-bottom: 3rem;
    position: static;
  }

  .titulo-nosotros {
    margin-bottom: 3rem;
    font-size: 1.5rem;
  }

  .section-nosotros-dos {
    height: auto;
    padding-top: 4rem;
    padding-bottom: 13rem;
  }

  .p-nosotros-dos {
    font-size: 1rem;
  }

  .btn-disponibilidad {
    bottom: 1rem;
    left: 1rem;
  }

  .intro-hero-nosotros {
    width: 100%;
  }

  .p-texto-nosotros {
    max-width: 21rem;
    font-size: 1rem;
  }

  .section-pilares {
    padding-top: 4rem;
  }

  .lista-pilares {
    flex-flow: column;
    display: flex;
  }

  .col-pilares {
    width: 100%;
  }

  .section-hero-experiencia {
    height: auto;
  }

  .imagen-side-hero-experiencia {
    left: -17.5rem;
  }

  .p-experiencia {
    font-size: 1rem;
  }

  .section-experiencia {
    height: auto;
    padding-top: 4rem;
    padding-bottom: 13rem;
  }

  .p-texto-experiencia {
    max-width: 20rem;
    font-size: 1rem;
  }

  .section-recomendaciones {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .titulo-recomendaciones {
    max-width: 21rem;
    font-size: 2rem;
  }

  .sub-titulo-recomendaciones {
    font-size: 1rem;
  }

  .section-degustacion {
    padding-top: 4rem;
    padding-bottom: 1rem;
  }

  .col-brindis {
    float: none;
    width: 100%;
    margin-bottom: 3rem;
  }

  .row-pilares {
    width: 100%;
  }

  .row-pilares.invert {
    flex-flow: column;
  }

  .row-pilares.final {
    flex-flow: column;
    width: 100%;
  }

  .anchor-espacios {
    top: -8rem;
  }
}


@font-face {
  font-family: 'S';
  src: url('../fonts/s_italic.ttf') format('truetype');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'S';
  src: url('../fonts/s_regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}