/*
Theme Name:   Movedo Child
Theme URI:    https://themeforest.net/user/greatives
Description:  Movedo Child Theme
Version:      3.5.7
Author:       Greatives Team
Author URI:   https://greatives.eu
Template:     movedo
*/

/*** Colores ***/
:root {
  --primary-color: #dd271d; /*rojo - primary 1*/
  --secondary-color: #151515; /*gris muy oscuro - primary 2*/
  --third-color: #faf9f9; /*gris fondo - primary 3*/
  --fourth-color: #cdcdcd; /*gris medio - primary 4*/
  --fifth-color: #595959; /* grid oscuro - blanco AAA */
  --white: #fff;
  --black: #000;
  --alto-contraste: #A8271D; /* Rojo oscuro - AAA */

  --family-title: "Poppins", sans-serif;
  --family-base: "Poppins", sans-serif;
}

/*** General ***/
h1,
h2,
h3,
h4,
h5,
h6,
#grve-feature-section.grve-fullscreen .grve-title {line-height: 1.5}
  h1,
  #grve-page-title .grve-title, 
  #grve-blog-title .grve-title, 
  #grve-search-page-title .grve-title,
  #grve-feature-section.grve-fullscreen .grve-title {font-size: 4.0625rem}
  h2 {font-size: 2.25rem}
  h3 {font-size: 1.5rem}
  h4 {font-size: 1.375rem}
  h5 {font-size: 1.25rem}
  h6 {font-size: 1.125rem}

body {
  font-size: 1rem;
  line-height: 1.5;
}

#grve-content .grve-main-content-wrapper {padding: 0}
  .home #grve-content .grve-main-content-wrapper {padding-top: 5rem}

h1,h2,h3,h4,h5,h6 {
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
}
  h1 {font-size: 4.0625rem}
  h2 {font-size: 2.25rem}
  h3 {font-size: 1.5rem}
  h4 {font-size: 1.375rem}
  h5 {font-size: 1.25rem}
  h6 {font-size: 1.125rem}

  .grve-btn, 
  a.grve-btn,
  #reply-title,
  .grve-link-text, 
  input[type="reset"], 
  input[type="submit"], 
  input[type="button"], 
  #cancel-comment-reply-link, 
  button:not(.mfp-arrow):not(.grve-search-btn), 
  .grve-anchor-menu .grve-anchor-wrapper .grve-container > ul > li > a, 
  .grve-anchor-menu .grve-anchor-wrapper .grve-container ul.sub-menu li a {
    font-size: .875rem !important;
    line-height: 1.4
  }

a.grve-btn, 
.woocommerce #grve-theme-wrapper a.button, 
.woocommerce #grve-theme-wrapper input.button,
.woocommerce #grve-theme-wrapper button.button, 
.woocommerce #grve-theme-wrapper #respond input#submit, 
#grve-theme-wrapper input[type="reset"]:not(.grve-custom-btn), 
#grve-theme-wrapper button[type="reset"]:not(.grve-custom-btn), 
#grve-theme-wrapper input[type="button"]:not(.grve-custom-btn), 
#grve-theme-wrapper input[type="submit"]:not(.grve-custom-btn), 
#grve-theme-wrapper button[type="button"]:not(.grve-custom-btn), 
#grve-theme-wrapper button[type="submit"]:not(.grve-custom-btn), 
#grve-theme-wrapper button:not(.grve-custom-btn):not(.vc_general):not(.tribe-events-c-subscribe-dropdown__button-text):not(.tribe-events-calendar-month__day-cell--mobile):not(.tribe-events-c-top-bar__datepicker-button):not(.tribe-events-c-nav__next):not(.tribe-events-c-nav__prev) {
  border-radius: .5rem !important;
  padding: 1.3125rem 5rem 1.3125rem 2rem;
}
  #grve-theme-wrapper input[type="submit"]:not(.grve-custom-btn) {
    background-image: url("/wp-content/uploads/2024/01/icoFlechaDerechaBlanca.png");
    background-position: right 1rem center;
    background-repeat: no-repeat;
    transition: .3s;
  }
    #grve-theme-wrapper input[type="submit"]:not(.grve-custom-btn):focus,
    #grve-theme-wrapper input[type="submit"]:not(.grve-custom-btn):hover {
      background-position: right 2rem center;
      transition: .3s;
    }
  a.grve-btn i, 
  .woocommerce #grve-theme-wrapper a.button i, 
  .woocommerce #grve-theme-wrapper input.button i,
  .woocommerce #grve-theme-wrapper button.button i, 
  .woocommerce #grve-theme-wrapper #respond input#submit i, 
  #grve-theme-wrapper input[type="reset"]:not(.grve-custom-btn) i, 
  #grve-theme-wrapper button[type="reset"]:not(.grve-custom-btn) i, 
  #grve-theme-wrapper input[type="button"]:not(.grve-custom-btn) i, 
    #grve-theme-wrapper button[type="button"]:not(.grve-custom-btn) i, 
  #grve-theme-wrapper button[type="submit"]:not(.grve-custom-btn) i, 
  #grve-theme-wrapper button:not(.grve-custom-btn):not(.vc_general):not(.tribe-events-c-subscribe-dropdown__button-text):not(.tribe-events-calendar-month__day-cell--mobile):not(.tribe-events-c-top-bar__datepicker-button):not(.tribe-events-c-nav__next):not(.tribe-events-c-nav__prev) i {
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    transition: .3s;
  }
    a.grve-btn:focus i, 
    a.grve-btn:hover i, 
    .woocommerce #grve-theme-wrapper a.button:focus i, 
    .woocommerce #grve-theme-wrapper a.button:hover i, 
    .woocommerce #grve-theme-wrapper input.button:focus i,
    .woocommerce #grve-theme-wrapper input.button:hover i,
    .woocommerce #grve-theme-wrapper button.button:focus i, 
    .woocommerce #grve-theme-wrapper button.button:hover i, 
    .woocommerce #grve-theme-wrapper #respond input#submit:focus i, 
    .woocommerce #grve-theme-wrapper #respond input#submit:hover i, 
    #grve-theme-wrapper input[type="reset"]:not(.grve-custom-btn):focus i, 
    #grve-theme-wrapper input[type="reset"]:not(.grve-custom-btn):hover i, 
    #grve-theme-wrapper button[type="reset"]:not(.grve-custom-btn):focus i, 
    #grve-theme-wrapper button[type="reset"]:not(.grve-custom-btn):hover i, 
    #grve-theme-wrapper input[type="button"]:not(.grve-custom-btn):focus i, 
    #grve-theme-wrapper input[type="button"]:not(.grve-custom-btn):hover i, 
    #grve-theme-wrapper button[type="button"]:not(.grve-custom-btn):focus i, 
    #grve-theme-wrapper button[type="button"]:not(.grve-custom-btn):hover i, 
    #grve-theme-wrapper button[type="submit"]:not(.grve-custom-btn):focus i, 
    #grve-theme-wrapper button[type="submit"]:not(.grve-custom-btn):hover i, 
    #grve-theme-wrapper button:not(.grve-custom-btn):not(.vc_general):not(.tribe-events-c-subscribe-dropdown__button-text):not(.tribe-events-calendar-month__day-cell--mobile):not(.tribe-events-c-top-bar__datepicker-button):not(.tribe-events-c-nav__next):not(.tribe-events-c-nav__prev):focus i,
    #grve-theme-wrapper button:not(.grve-custom-btn):not(.vc_general):not(.tribe-events-c-subscribe-dropdown__button-text):not(.tribe-events-calendar-month__day-cell--mobile):not(.tribe-events-c-top-bar__datepicker-button):not(.tribe-events-c-nav__next):not(.tribe-events-c-nav__prev):hover i {
      right: 2rem;
      transform: translateY(-50%);
      transition: .3s;
    }

/*** Header ***/
#grve-main-header {background-color: var(--third-color)}
.grve-sticky-header #grve-main-header {box-shadow: 0 5px 5px 0 rgba(0,0,0,.15)}

.grve-logo .grve-wrapper {transform: translateY(-50%)}
.grve-logo .grve-wrapper a img {top: 0}

.grve-logo-text a, 
.grve-header-element > a, 
.grve-header-text-element,
.grve-header-element .grve-purchased-items,
#grve-header .grve-main-menu .grve-wrapper > ul > li > a {color: var(--secondary-color)}
  .grve-logo-text a:focus, 
  .grve-logo-text a:hover, 
  .grve-header-element > a:hover,
  .grve-header-element > a:focus,
  #grve-header .grve-main-menu .grve-wrapper > ul > li:focus > a, 
  #grve-header .grve-main-menu .grve-wrapper > ul > li:hover > a {color: var(--primary-color)}

  #grve-header .grve-main-menu .grve-wrapper > ul > li.grve-current > a, 
  #grve-header .grve-main-menu .grve-wrapper > ul > li.current-menu-item > a, 
  #grve-header .grve-main-menu .grve-wrapper > ul > li.current-menu-ancestor > a {
    color: var(--secondary-color);
    font-weight: 700
  }

.grve-header-elements-wrapper.grve-position-right .grve-header-elements {margin-left: 1rem}
  .grve-header-elements-wrapper.grve-position-right:lang(fr) .grve-header-elements {margin-left: .875rem}
  .grve-header-elements-wrapper.grve-position-right .grve-header-elements a {padding-left: 1.25rem}
    .grve-header-elements-wrapper.grve-position-right:lang(fr) .grve-header-elements a {padding-left: 1rem}

.grve-header-elements,
#grve-main-header.grve-header-default {border: 0}

#grve-header #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: 1.5rem}
  #grve-header:lang(fr) #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: 1.125rem}

#grve-main-menu .grve-menu li.current_page_item a {
  color: var(--secondary-color);
  font-weight: 700
}

#grve-header #grve-main-menu .grve-wrapper > ul > li > a {
  color: var(--secondary-color);
  margin: 0;
  padding: 0;
  position: relative
}
  #grve-header #grve-main-menu .grve-wrapper > ul > li > a:focus,
  #grve-header #grve-main-menu .grve-wrapper > ul > li > a:hover {color: var(--primary-color)}
  .grve-main-menu .grve-menu > li > a::before {
    background: var(--primary-color);
    content: '';
    height: 5px;
    left: 50%;
    position: absolute;
    top: calc(50% + 1rem);
    transform: translateX(-50%);
    transition: .3s;
    width: 0
  }
    .grve-main-menu .grve-menu > li > a:focus::before,
    .grve-main-menu .grve-menu > li > a:hover::before {
      transition: .4s;
      width: 100%
    }
    #grve-header .grve-main-menu .grve-wrapper > ul > li.grve-current > a::before, 
    #grve-header .grve-main-menu .grve-wrapper > ul > li.current-menu-item > a::before, 
    #grve-header .grve-main-menu .grve-wrapper > ul > li.current-menu-ancestor > a::before {width: 70%}
      #grve-header .grve-main-menu .grve-wrapper > ul > li.grve-current > a:focus::before, 
      #grve-header .grve-main-menu .grve-wrapper > ul > li.grve-current > a:hover::before, 
      #grve-header .grve-main-menu .grve-wrapper > ul > li.current-menu-item > a:focus::before, 
      #grve-header .grve-main-menu .grve-wrapper > ul > li.current-menu-item > a:hover::before, 
      #grve-header .grve-main-menu .grve-wrapper > ul > li.current-menu-ancestor > a:focus::before,
      #grve-header .grve-main-menu .grve-wrapper > ul > li.current-menu-ancestor > a:hover::before {width: 100%}

.grve-header-default .grve-header-elements-wrapper a:focus .fab,
.grve-header-default .grve-header-elements-wrapper a:hover .fab,
.grve-header-default .grve-header-elements-wrapper a:focus .grve-icon-globe,
.grve-header-default .grve-header-elements-wrapper a:hover .grve-icon-globe {transform: scale(1.2)}

#grve-main-menu #menu-menu-principal .menu-item-language .wpml-ls-flag + span {
  font-size: .9375rem;
  margin-left: .25rem
}
#grve-main-menu #menu-menu-principal .menu-item-language ul.sub-menu {
  left: 50%;
  transform: translateX(-50%);
  width: 10rem;
}
  #grve-main-menu #menu-menu-principal .menu-item-language ul.sub-menu a:focus,
  #grve-main-menu #menu-menu-principal .menu-item-language ul.sub-menu a:hover {
    color: var(--primary-color);
    text-decoration: underline;
  }

/* Sticky */
#grve-header.grve-sticky-header #grve-main-header #grve-bottom-header,
#grve-header.grve-sticky-header #grve-main-header:not(.grve-header-logo-top) {background-color: var(--third-color)}
  #grve-header.grve-sticky-header .grve-logo-text a, 
  #grve-header.grve-sticky-header .grve-header-text-element,
  #grve-header.grve-sticky-header #grve-main-header .grve-header-element > a, 
  #grve-header.grve-sticky-header .grve-header-element .grve-purchased-items, 
  #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li > a {color: var(--secondary-color)}
    #grve-header.grve-sticky-header .grve-logo-text a:focus, 
    #grve-header.grve-sticky-header .grve-logo-text a:hover, 
    #grve-header.grve-sticky-header #grve-main-header .grve-header-element > a:focus, 
    #grve-header.grve-sticky-header #grve-main-header .grve-header-element > a:hover, 
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li > a:focus,
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li > a:hover {color: var(--primary-color)}
  
  #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.active > a, 
  #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.grve-current > a, 
  #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.current-menu-item > a, 
  #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.current-menu-item > a, 
  #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.current-menu-ancestor > a {color: var(--secondary-color)}
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.active > a:focus, 
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.active > a:hover, 
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.grve-current > a:focus, 
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.grve-current > a:hover, 
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.current-menu-item > a:focus, 
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.current-menu-item > a:hover, 
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.current-menu-item > a:focus, 
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.current-menu-item > a:hover, 
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.current-menu-ancestor > a:focus,
    #grve-header.grve-sticky-header #grve-main-header #grve-main-menu .grve-wrapper > ul > li.current-menu-ancestor > a:hover {color: var(--primary-color)}
  
/*** Footer ***/
#grve-bottom-bar {color: var(--white)}
footer p,
footer ul,
footer p a,
footer ul a,
footer .grve-title {color: var(--white)}
  footer p a:focus,
  footer p a:hover,
  footer ul a:focus,
  footer ul a:hover {color: var(--primary-color)}
  footer ul {
    list-style-type: none;
    margin: 0
  }

  footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn {
    background-color: var(--white);
    border-color: var(--white);
    color: var(--secondary-color)
  }
    footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:focus,
    footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:hover {
      background-color: var(--secondary-color);
      border-color: var(--secondary-color);
      color: var(--white)
    }
    footer .c-banda-pie-superior .u-imagen-ajustada img {
      height: 13rem;
      width: auto;
    }

  footer #grve-bottom-bar .c-banda-pie-media ul {
    align-items: center;
    display: flex;
    justify-content: space-evenly;
  }

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-row {
    align-items: center;
    display: flex;
    justify-content: space-between;
  }
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-row::after,
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-row::before {content: unset}
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child {width: 49%}
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child {width: 49%}

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column ul {
    align-items: center;
    display: flex;
    justify-content: space-between
  }
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child ul {justify-content: right}
      footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child ul li:not(:first-child) {margin-left: 1rem}

    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child p {
      align-items: center;
      display: flex;
      text-transform: uppercase
    }
      footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child p img {margin: 0 0 0 1rem}

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child p a {
    margin: 0 .5rem;
    padding: 0 .25rem
  }
  
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:first-child a:focus .fab,
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:first-child a:hover .fab {transform: scale(1.2)}

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child p {
    align-items: center;
    display: flex;
    justify-content: flex-end
  }
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a {position: relative}
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a:not(:first-child)::before {
      border-left: 1px solid var(--white);
      content: '';
      height: 1rem;
      left: -0.5rem;
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 1px;
    }
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a:first-child {
      margin-left: 0;
      padding-left: 0
    }
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a:last-child {
      margin-right: 0;
      padding-right: 0
    }
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a:focus,
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a:hover {text-decoration: underline}

  #grve-footer .grve-footer-bar {
    background: var(--black);
    padding: 0 !important;
  }

/*** Home ***/

/** Featured section **/
#grve-feature-section .grve-background-wrapper .grve-bg-image::before {
  background-image: linear-gradient(rgba(0,0,0,.2) 10%, rgba(0,0,0,.3) 30%, rgba(0,0,0,.4) 60%, rgba(0,0,0,.5) 80%, rgba(0, 0, 0, 0.7));
  content: '';
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 9s
}
#grve-feature-section .grve-title-content-wrapper.grve-content-large {
  display: flex;
  flex-direction: column-reverse;
  margin: 0 auto
}
  #grve-feature-section .grve-title-content-wrapper.grve-content-large .grve-graphic {margin: 15vh auto 0}

/** Primer bloque **/
.home .grve-section:first-child .grve-column-wrapper {
  margin: 0 auto;
  max-width: 43.125rem;
  width: 100%
}
.home .grve-section:first-child .grve-btn {margin: 0 !important}

/** Listado de rutas **/
.c-listado-rutas .grve-box-icon {background: var(--third-color)}
  .c-listado-rutas .grve-box-icon:not(:last-child) {margin: 0 0 5rem}
  .c-listado-rutas .grve-box-icon a {
    align-items: center;
    display: flex;
    justify-content: space-between;
  }
  .c-listado-rutas .grve-box-icon .grve-image-icon img {width: 37.5rem}
  .c-listado-rutas .grve-box-icon .grve-box-content {
    color: var(--secondary-color);
    padding: 0 3.125rem 4rem 0;
    width: 34rem
  }
    .c-listado-rutas .grve-box-icon .grve-box-content a:focus,
    .c-listado-rutas .grve-box-icon .grve-box-content a:hover {transform: scale(1.2)}
    .c-listado-rutas .grve-box-icon .grve-box-content a:focus h3,
    .c-listado-rutas .grve-box-icon .grve-box-content a:hover h3 {color: var(--primary-color)}
    .c-listado-rutas .grve-box-icon .grve-box-content::after {
      bottom: 0;
      content: url("/wp-content/uploads/2023/12/icoVerMas.png");
      font-family: 'Font Awesome 6 Pro';
      height: 2.8125rem;
      position: absolute;
      right: 3.125rem;
      width: 2.8125rem;
    }
    .c-listado-rutas .grve-box-icon.grve-extra-large .grve-image-icon, 
    .c-listado-rutas .grve-box-icon.grve-extra-large .grve-wrapper-icon, 
    .c-listado-rutas .grve-box-icon.grve-extra-large .grve-box-title-wrapper {font-size: 1rem}
      .c-listado-rutas .grve-box-icon.grve-extra-large .grve-box-title-wrapper {margin: 0 0 2rem}
      .c-listado-rutas .grve-box-icon .grve-box-content h3 {text-transform: uppercase;}

/** Descargar App **/
.c-descargar-app::before {
  background: var(--primary-color);
  content: '';
  height: 4.4375rem;
  left: -61vw;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
}
.c-descargar-app .grve-column-1-2:last-child .grve-column-wrapper > .grve-element {
  margin-left: auto;
  margin-right: auto;
  max-width: 35.625rem;
  width: 100%
}
.c-descargar-app ul {
  align-items: center;
  display: flex;
  justify-content: space-between;
  list-style-type: none;
  margin: 0;
}

/*** Interiores ***/

/** Migas de pan **/
#grve-page-breadcrumbs,
#grve-post-breadcrumbs {
  border: 0;
  color: var(--primary-color);
  font-size: .9375rem;
  font-weight: 600;
  line-height: 3;
  padding: 2rem 0 0;
  text-transform: uppercase
}
  #grve-page-breadcrumbs a,
  #grve-post-breadcrumbs a {font-weight: 400}
    #grve-page-breadcrumbs a:focus, 
    #grve-page-breadcrumbs a:hover, 
    #grve-post-breadcrumbs a:focus, 
    #grve-post-breadcrumbs a:hover {
      color: var(--primary-color);
      text-decoration: underline
    }

/** Rutas de compras **/
.c-rutas-compras {
  display: flex;
  justify-content: space-between
}
  .c-rutas-compras .u-lista-rutas {width: 32.5%}
    .u-lista-rutas h2 {
      margin-bottom: 2.8125rem;
      max-width: 22rem;
      width: 100%
    }
    .u-lista-rutas ul {
      list-style-type: none;
      margin: 0
    }
      .u-lista-rutas ul li {
        align-items: center;
        box-shadow: 0 10px 18px 0 rgba(188,188,188,.57);
        display: flex;
        font-size: 1.375rem;
        font-weight: 600;
        margin: 0 0 2.8125rem;
        min-height: 7.625rem;
        position: relative
      }
        .u-lista-rutas ul li.destacar,
        .u-lista-rutas ul li.active.destacar {background: var(--primary-color) !important}
        .u-lista-rutas img {
          margin: 0 1rem 0 2rem;
          position: relative;
          z-index: 7
        }
          .u-lista-rutas ul li.active img,
          .u-lista-rutas ul li.destacar img {filter: brightness(0) invert(1)}
        .u-lista-rutas span {
          position: relative;
          z-index: 7
        }
          .u-lista-rutas ul li.active span,
          .u-lista-rutas ul li.destacar span {color: var(--white) !important}
        .u-lista-rutas a {
          height: 100%;
          left: 0;
          padding: 1.5rem 2rem;
          position: absolute;
          top: 0;
          width: 100%;
          z-index: 9;
        }
          .u-lista-rutas a.u-enlace-oculto {
            display: none;
            font-weight: 400;
            height: 100%;
            left: 0;
            padding: 0;
            position: absolute;
            top: 0;
            width: 100%
          }
            .u-lista-rutas li.active a.u-enlace-oculto {display: block}
            .u-lista-rutas ul li.active a.u-enlace-oculto span {
              font-size: .875rem;
              bottom: .375rem;
              padding: 0 1.25rem 0 0;
              position: absolute;
              right: 1rem;
              text-transform: uppercase
            }
              .u-lista-rutas ul li.active a.u-enlace-oculto span::after {
                content: '\f055';
                font-family: 'Font Awesome 6 Pro';
                font-size: .875rem;
                font-weight: 400;
                height: .875rem;
                position: absolute;
                right: .125rem;
                top: 0;
                width: .875rem
              }
          .u-lista-rutas li.active a.ruta-link {display: none}
          .u-lista-rutas a.ruta-link span {
            display: block;
            text-indent: -10000rem
          }
          .u-lista-rutas ul li.todas-rutas a {
            align-items: center;
            color: var(--primary-color);
            display: flex;
            justify-content: center
          }
            .u-lista-rutas ul li.todas-rutas a:focus,
            .u-lista-rutas ul li.todas-rutas a:hover {
              background: var(--primary-color);
              color: var(--white)
            }
            .u-lista-rutas ul li.todas-rutas.active a.ruta-link.active {
              background: var(--secondary-color);
              color: var(--white);
              display: flex;
            }


  .c-rutas-compras .u-mapa-rutas {width: 63.5%}

/** Listado de comercios en una ruta **/
.ruta-header-info {
  align-items: flex-end;
  display: flex;
  justify-content: space-between;
  margin: 1rem 0 6.125rem
}
  .ruta-header-info .subtitle {width: 69%}
  .ruta-header-info .ruta-selector {width: 29%}

  #grve-theme-wrapper .ruta-header-info select {
    background-image: url(/wp-content/uploads/2024/02/icoSelect2.png);
    background-position: center right 1rem;
    border-color: var(--secondary-color);
    border-radius: .375rem;
    color: var(--secondary-color);
    font-family: 'Poppins', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    text-transform: uppercase
  }
    #grve-theme-wrapper .ruta-header-info select option {background: var(--white)}

.tax-ruta_comercio .grve-two-column-layout {
  align-items: stretch;
  display: flex;
  margin: 0 0 1rem;
  max-height: 80vw
}
  .tax-ruta_comercio .grve-two-column-layout .grve-column-map {
    overflow: hidden;
    width: 51%
  }
  .tax-ruta_comercio .grve-two-column-layout .grve-column-content {
    background: var(--third-color);
    padding: 1.5rem 1rem 3rem 1rem;
    width: 49%;
  }
    .tax-ruta_comercio .grve-two-column-layout .grve-column-content .u-contenedora {
      height: 100%;
      overflow-y: auto;
      padding: 1.5rem 1.25rem 0 4.625rem
    }
      .tax-ruta_comercio .grve-two-column-layout .grve-column-content .u-contenedora .grve-row.grve-columns-gap-30 {margin: 0 !important}
    .tax-ruta_comercio .grve-column-content h3 {
      margin:0;
      position: relative
    }
      .tax-ruta_comercio .grve-column-content h3::before {
        background: var(--primary-color);
        border-radius: .375rem;
        content: '';
        height: .6875rem;
        left: -2.5rem;
        position: absolute;
        top: .75rem;
        width: .6875rem;
        z-index: 2;
      }
    .tax-ruta_comercio #grve-main-content .grve-column-content h3 + .grve-section {
      background: transparent !important;
      color: var(--secondary-color) !important;
      padding: .5rem 0 1rem !important
    }
      .tax-ruta_comercio #grve-main-content .grve-column-content h3 + .grve-section .grve-column {padding: 0 !important}
      .tax-ruta_comercio .grve-column-content p.u-mas-info::before,
      .tax-ruta_comercio .grve-column-content h3 + .grve-section::before {
        border-left: 1px solid var(--primary-color);
        content: '';
        height: calc(100% + 1.5rem);
        left: -2.18755rem;
        position: absolute;
        top: -0.75rem;
        width: .125rem;
        z-index: 1;
      }
    .tax-ruta_comercio .grve-column-content p {margin: 0}
      .tax-ruta_comercio .grve-column-content p.u-mas-info {padding: .5rem 0 2rem}
        .tax-ruta_comercio .grve-column-content p.u-mas-info::before {top:-0.8125rem}
    .tax-ruta_comercio p.u-mas-info a {color: var(--primary-color)}
      .tax-ruta_comercio p.u-mas-info a:focus,
      .tax-ruta_comercio p.u-mas-info a:hover {text-decoration: underline}
  .tax-ruta_comercio .grve-main-content-wrapper .grve-container + .grve-container > p {margin: 0 0 5rem}

/** Comercio individual **/
.single-comercio .grve-two-column-layout {
  display: flex;
  justify-content: space-between;
  padding: 0 0 2rem
}
  .single-comercio #grve-main-content .grve-section {
    background: transparent !important;
    color: var(--secondary-color) !important
  }
  .single-comercio .grve-two-column-layout .grve-column-map,
  .single-comercio .grve-two-column-layout .grve-column-content {width: 49%}

  .single-comercio .grve-two-column-layout .grve-column-map img {margin: 1.5rem 0 0 auto}
  
  .single-comercio #grve-theme-wrapper h1 {margin: 0}
  .single-comercio #grve-theme-wrapper h1 + .grve-padding-bottom-1x {padding-top: 1rem}

  .single-comercio .grve-datos-interes-social {
    align-items: center;
    border-bottom: 1px solid var(--primary-color);
    display: flex;
    justify-content: space-between;
    margin: 0 0 1.625rem
  }
    .grve-datos-interes-social h3 {
      color: var(--primary-color);
      font-size: 1rem;
      font-weight: 700;
      padding: .25rem 0;
      text-transform: uppercase;
    }
    .grve-datos-interes-social ul {
      align-items: center;
      display: flex;
      line-height: 1.5;
      list-style-type: none;
      margin: 0
    }
      .grve-datos-interes-social ul li:not(:first-child) {margin-left: .875rem}
      .grve-datos-interes-social ul li a {
        color: var(--primary-color);
        display: block;
        height: 1.5rem;
        position: relative;
        transition: .2s;
        width: 1.5rem
      }
        .grve-datos-interes-social ul li a:focus,
        .grve-datos-interes-social ul li a:hover {
          color: var(--secondary-color);
          font-size: 1.375rem;
          transition: .3s;
        }
        .grve-datos-interes-social ul li a i::before {
          left: 50%;
          position: absolute;
          top: 50%;
          transform: translate(-50%,-50%)
        }

  .single-comercio .grve-mas-info {
    display: flex;
    flex-wrap: wrap;
    max-width: 40rem;
    width: 100%;
  }
    .single-comercio .grve-mas-info .acf-field {
      color: var(--secondary-color);
      margin: 1rem 0 0;
      padding: 0 0 0 2rem;
      position: relative;
      width: 100%
    }
      .single-comercio .grve-mas-info .acf-field:first-child {margin-top: 0}
      .single-comercio .grve-mas-info .u-web {padding-left: 0}
        .single-comercio .grve-mas-info .u-web a {color: var(--primary-color)}
          .single-comercio .grve-mas-info .u-web a:focus,
          .single-comercio .grve-mas-info .u-web a:hover {
            color: var(--secondary-color);
            text-decoration: underline
          }
      .single-comercio .grve-mas-info .u-telefono,
      .single-comercio .grve-mas-info .u-whatsapp {
        margin-right: 2%;
        width: 30%
      }
        .single-comercio .grve-mas-info .u-dirccion a:focus,
        .single-comercio .grve-mas-info .u-direccion a:hover,
        .single-comercio .grve-mas-info .u-telefono a:focus,
        .single-comercio .grve-mas-info .u-telefono a:hover,
        .single-comercio .grve-mas-info .u-whatsapp a:focus,
        .single-comercio .grve-mas-info .u-whatsapp a:hover {
          color: var(--primary-color);
          text-decoration: underline
        }
        .single-comercio .grve-mas-info .acf-field a::after,
        .single-comercio .grve-mas-info .acf-field::before {
          font-family: 'Font Awesome 6 Pro';
          font-size: 1rem;
          font-weight: 400;
          height: 1rem;
          left: .25rem;
          line-height: 1;
          position: absolute;
          top: .25rem;
          width: 1rem;
          z-index: 3
        }
          .single-comercio .grve-mas-info .acf-field.u-horario::before {content: '\f017'}
          .single-comercio .grve-mas-info .acf-field.u-telefono::before {content: '\f095'}
          .single-comercio .grve-mas-info .acf-field.u-whatsapp::before {
            content: '\f232';
            font-family: 'Font Awesome 6 Brands';
          }
          .single-comercio .grve-mas-info .acf-field.u-direccion::before {content: '\f3c5'}
          .single-comercio .grve-mas-info .u-direccion a {
            padding-right: 2rem;
            position: relative;
          }
              .single-comercio .grve-mas-info .acf-field.u-direccion a::after {
                content: '\f08e';
                left: auto;
                right: .25rem
              }
      .single-comercio .u-web {
        color: var(--primary-color);
        font-size: 1.125rem;
        font-weight: 700;
      }

.single-comercio .gallery ul {
  align-items: stretch;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  list-style-type: none;
  margin: 0;
  padding: 4rem 1rem
}
  .single-comercio .gallery ul li {
    height: auto;
    margin: 0;
    padding: 0;
    width: 28.125rem;
  }
    .single-comercio .gallery li:nth-child(n+4) {margin: 2rem 0 0}
  .single-comercio .gallery img {
    display: block;
    height: auto;
    object-fit: cover;
    width: 100%;
  }


/** LOADER DE MAPA **/
.u-mapa-rutas {position: relative}

#map-overlay {
  align-items: center; /* Centra verticalmente */
  background: rgba(255, 255, 255, 0.8);
  display: flex; /* Usa Flexbox */
  justify-content: center; /* Centra horizontalmente */
  left: 0;
  height: 31.25rem;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1000
}

.loader {
  animation: spin 2s linear infinite;
  border: 5px solid var(--fourth-color);
  border-top: 5px solid var(--primary-color);
  border-radius: 50%;
  height: 2.5rem;
  width: 2.5rem
}

@keyframes spin {
  0% {transform: rotate(0deg)}
  100% {transform: rotate(360deg)}
}

.leaflet-popup-content .popup-content {font-family: Arial, sans-serif}

.leaflet-popup-content .popup-thumbnail {
  height: auto;
  margin-bottom: .5rem;
  width: 100%
}

.leaflet-popup-content .popup-content h3 {
  color: var(--secondary-color);
  font-size: 1rem;
  margin: 0 0 .375rem 0
}

.leaflet-popup-content .popup-content p {
  color: var(--secondary-color);
  font-size: .875rem;
  margin: 0 0 1.25rem
}

.leaflet-popup-content .btn-primary {
  background-color: var(--primary-color);
  background-image: url("/wp-content/uploads/2024/01/icoFlechaDerechaBlanca.png");
  background-position: right .75rem center;
  background-repeat: no-repeat;
  border-radius: 5px;
  color: white;
  font-size: .875rem;
  padding: .5rem 3rem .5rem .75rem;
  text-decoration: none;
  transition: .3s;
}
  .leaflet-popup-content .btn-primary:focus,  
  .leaflet-popup-content .btn-primary:hover {
    background-color: var(--secondary-color);
    background-position: right 1.5rem center;
    transition: .3s;
  }

/*** Interiores ***/

/** Planificador de rutas */
.page-template-template-listado-comercios .page {
  align-items: stretch;
  display: flex;
  justify-content: space-between;
  padding-bottom: 3rem;
}
  .page-template-template-listado-comercios .page .listado-comercios {width: calc(40% - 2rem)}
  .page-template-template-listado-comercios .page #contenedor-mapa {width: 60%}
    .page-template-template-listado-comercios .page .comercios-listado-completo {height: 58rem}
.listado-comercios form {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin: 0 0 2rem;
}
  #grve-theme-wrapper #grve-theme-content .listado-comercios form input {
    margin: 0 .5rem 0 0;
    width: 23rem
  }

#grve-theme-wrapper #grve-theme-content .listado-comercios button {
  display: block;
  margin: 0 1rem 0 auto;
  padding: .5625rem 3.75rem .5625rem 1rem;
  width: 16rem
}
  #grve-theme-wrapper #grve-theme-content .u-favorito {background: var(--fifth-color)}
  #grve-theme-wrapper #grve-theme-content .u-favorito:focus,
  #grve-theme-wrapper #grve-theme-content .u-favorito:hover {background: var(--secondary-color)}
  #grve-theme-wrapper #grve-theme-content .listado-comercios form button {
    margin: 0;
    width: 9.5rem
  }

  .listado-comercios h2 {
    font-size: 2rem;
    margin-top: 2rem
  }
    .listado-comercios h2:first-child {margin-top: 0}

.listado-comercios ul {
  color: var(--secondary-color);
  list-style-type: none;
  margin: 0;
  padding: 0
}
  .listado-comercios ul li:not(:first-child) {margin-top: 2rem}
  .listado-comercios ul li p,
  .listado-comercios ul li h3 {margin: 0 1rem 1rem 0}
    .listado-comercios ul li h3 {
      font-size: 1.25rem;
      margin-bottom: .5rem
    }
    .listado-comercios ul li img {
      border-radius: 4px;
      height: 10rem;
      object-fit: cover;
      width: calc(100% - 1rem)
    }

.listado-comercios .comercios-listado-completo{
	height: 700px;
	overflow-y: scroll;
}

#mensaje-favoritos {
  top: 20px;
  padding: 10px 20px;
  border-radius: 4px;
  margin-bottom: 10px;
  color: #fff;
  z-index: 1000;
}
  #mensaje-favoritos.confirmacion {background-color: #1F8037}
  #mensaje-favoritos.advertencia {background-color: #dc3545}

#contenedor-btn-ruta {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
}

#ver-favoritos {
  padding: 10px 20px;
  border: none;
  border-radius: 4px;
  background-color: #007bff;
  color: #ffffff;
  cursor: pointer;
}

button[type="submit"] {
  border: none;
  background: transparent;
  cursor: pointer;
}

.formulario-busqueda {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}

.formulario-busqueda .filtro-rutas {
    flex-grow: 1;
    margin: 10px 0 10px 20px;
}

.formulario-busqueda input[type="text"] {
    flex-grow: 1;
    margin-right: 20px;
}

.formulario-busqueda button {
    white-space: nowrap;
}

.ruta-badge {
    background-color: #ccc;
    color: #000;
    padding: 5px 10px;
    border-radius: 15px;
    display: inline-block;
    margin: 5px;
    cursor: pointer;
}

.ruta-badge.selected {
    background-color: #dd271d;
    color: #fff;
}


.ruta-badge input[type="checkbox"] {
    display: none;
}

.ruta-badge input[type="checkbox"]:checked + span {
    color: #fff;
    background-color: #007bff; /* Estilo para cuando el checkbox está seleccionado */
}

.ruta-badge span {
    display: block;
}


.ruta-badge input[type="checkbox"] {
    margin-right: 5px;
}

/** Quienes somos **/
.c-carrusel-comercios .owl-stage {
  align-items: center;
  display: flex
}
.c-carrusel-comercios .grve-media img {
  margin: 0 auto;
  width: auto
}

.c-carrusel-comercios .owl-controls .owl-dot span {
  background-color: var(--fourth-color);
  border: 0;
  height: 1.3125rem;
  opacity: 1;
  width: 1.3125rem
}
  .c-carrusel-comercios .owl-controls .owl-dot.active span {background-color: var(--primary-color) !important}

/** Contacto **/
.gravity-theme .gform_required_legend {text-align: right}

#grve-theme-wrapper select, 
#grve-theme-wrapper textarea, 
#grve-theme-wrapper .select2-choice, 
#grve-theme-wrapper input[type="url"], 
#grve-theme-wrapper input[type="tel"], 
#grve-theme-wrapper input[type="date"], 
#grve-theme-wrapper input[type="text"], 
#grve-theme-wrapper input[type="input"], 
#grve-theme-wrapper input[type="email"], 
#grve-theme-wrapper input[type="number"], 
#grve-theme-wrapper input[type="number"], 
#grve-theme-wrapper input[type="search"], 
#grve-theme-wrapper input[type="password"] {
  font-size: .875rem;
  margin: 0;
  min-height: auto;
  padding: .5rem .75rem
}

#grve-main-content .gravity-theme .ginput_counter {padding: 0}

.gravity-theme .gfield--type-consent a {text-decoration: underline}
  .gravity-theme .gfield--type-consent a:focus,
  .gravity-theme .gfield--type-consent a:hover {text-decoration: none}

#grve-main-content .gravity-theme .gform_footer {padding: 2rem 0 0}

/*** Accesibilidad ***/

.skip-link {color: var(--primary-color) !important}
body.contrast .skip-link {
  background: var(--white) !important;
  background-color: var(--white) !important;
  color: var(--primary-color)
}

body.contrast p,
body.contrast ul,
body.contrast li,
body.contrast h2,
body.contrast h3,
body.contrast nav,
body.contrast div,
body.contrast div a,
body.contrast div span,
body.contrast div a span {
  background: var(--white) !important;
  background-color: var(--white) !important
}
  body.contrast #grve-main-header i {
    background: transparent !important;
    background-color: transparent !important;
    text-decoration: none !important
  }

body.contrast i,
body.contrast img {
  background: transparent !important;
  background-color: transparent !important
}

body.contrast .leaflet-bar a,
body.contrast #grve-main-header div a,
body.contrast #grve-main-header div a span,
body.contrast #grve-main-header div a:visited {
  color: var(--black) !important;
  text-decoration: none !important
}
  body.contrast #grve-main-header div li:not(.current-menu-item) a {font-weight: 500}

body.contrast a:focus,
body.contrast a:hover,
body.contrast a:focus span,
body.contrast a:hover span,
body.contrast a:visited:focus,
body.contrast a:visited:hover {
  background: transparent !important;
  background-color: transparent !important
}


body.contrast #grve-main-header div a:focus,
body.contrast #grve-main-header div a:hover,
body.contrast #grve-main-header div a:focus span,
body.contrast #grve-main-header div a:hover span,
body.contrast #grve-theme-content .grve-breadcrumbs a {color: var(--alto-contraste) !important}

body.contrast #grve-main-header a i::before {
  background: var(--white) !important;
  background-color: var(--white) !important;
  color: var(--black) !important
}
  body.contrast #grve-main-header a:focus i::before,
  body.contrast #grve-main-header a:hover i::before {color: var(--alto-contraste) !important}

body.contrast #grve-footer div {
  background: transparent !important;
  background-color: transparent !important
}
body.contrast #grve-footer .grve-section:first-child,
body.contrast #grve-theme-wrapper #grve-theme-content .listado-comercios form button {
  background: var(--alto-contraste) !important;
  background-color: var(--alto-contraste) !important;
  color: var(--white) !important
}
body.contrast #grve-footer .grve-section:nth-child(2) {
  background: var(--white) !important;
  background-color: var(--white) !important;
}
body.contrast #grve-footer .grve-section:nth-child(3) {
  background: var(--black) !important;
  background-color: var(--black) !important;
}
body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn {
  background: var(--white) !important;
  background-color: var(--white) !important;
}
  body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn,
  body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn i,
  body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn span,
  body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:visited {
    color: var(--black) !important;
    text-decoration: none !important;
  }
  body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:focus,
  body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:hover,
  body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:focus span,
  body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:hover span {
    background: var(--black) !important;
    background-color: var(--black) !important;
    color: var(--white) !important;
    }
    body.contrast p,
    body.contrast ul,
    body.contrast li,
    body.contrast em,
    body.contrast strong,
    body.contrast .listado-comercios form,
    body.contrast div.leaflet-top.leaflet-left,
    body.contrast footer #grve-bottom-bar a i::before,
    body.contrast #grve-main-content .u-lista-rutas li a,
    body.contrast .single-comercio #grve-theme-wrapper h1,
    body.contrast #grve-main-content .u-lista-rutas li span,
    body.contrast #grve-footer .grve-section:nth-child(3) p,
    body.contrast #grve-footer .grve-section:nth-child(3) ul,
    body.contrast #grve-footer .grve-section:nth-child(3) li,
    body.contrast .listado-comercios form input[type="text"],
    body.contrast #grve-footer .grve-section:nth-child(3) p a,
    body.contrast #grve-footer .grve-section:nth-child(3) li a,
    body.contrast #grve-footer .grve-section:nth-child(3) li i,
    body.contrast .listado-comercios form button[type="submit"],
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior p,
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior h2,
    body.contrast #grve-footer .grve-section:nth-child(3) li a span,
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior h2 span,
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn span,
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:focus i,
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:hover i,
    body.contrast #grve-main-content .u-lista-rutas ul li a.u-enlace-oculto span::after,
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:focus i::before,
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:hover i::before {
      background: transparent !important;
      background-color: transparent !important
    }
    
    body.contrast #grve-footer .grve-section:nth-child(3) p a,
    body.contrast #grve-footer .grve-section:nth-child(3) li a,
    body.contrast #grve-footer .grve-section:nth-child(3) p a:focus,
    body.contrast #grve-footer .grve-section:nth-child(3) p a:hover,
    body.contrast #grve-footer .grve-section:nth-child(3) li a:focus,
    body.contrast #grve-footer .grve-section:nth-child(3) li a:hover,
    body.contrast #grve-footer .grve-section:nth-child(3) li i::before,
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior h2 span,
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:focus i::before,
    body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn:hover i::before {color: var(--white) !important}
    body.contrast #grve-footer .grve-section:nth-child(3) li i {text-decoration: none !important}

    body.contrast #grve-footer .grve-section:nth-child(3) .grve-text:nth-child(2) p a:focus,
    body.contrast #grve-footer .grve-section:nth-child(3) .grve-text:nth-child(2) p a:hover {text-decoration: none !important}

body.contrast #grve-page-title .grve-container,
body.contrast #grve-feature-section div.grve-content,
body.contrast #grve-theme-content .grve-page-title .grve-content {
  background: var(--black) !important;
  background-color: var(--black) !important
}
  body.contrast #grve-feature-section div.grve-content div,  
  body.contrast #grve-theme-content .grve-page-title .grve-content p,
  body.contrast #grve-theme-content .grve-page-title .grve-content div,
  body.contrast #grve-feature-section div.grve-content .grve-title span {
    background-color: transparent !important;
    color: var(--white) !important
  }

body.contrast #grve-content p,
body.contrast #grve-content h2,
body.contrast #grve-content h3,
body.contrast #grve-content h2 span,
body.contrast #grve-page-breadcrumbs,
body.contrast .single-comercio #grve-theme-wrapper h1,
body.contrast #grve-theme-content .grve-breadcrumbs span,
body.contrast #grve-theme-content .grve-breadcrumbs .breadcrumb_last,
body.contrast footer #grve-bottom-bar .c-banda-pie-superior a.grve-btn i::before {color: var(--black) !important}

body.contrast #grve-theme-wrapper .grve-bg-primary-1 {
  background-color: var(--alto-contraste) !important;
  border-color: var(--alto-contraste) !important
}
  body.contrast #grve-theme-wrapper .grve-bg-primary-1:focus,
  body.contrast #grve-theme-wrapper .grve-bg-primary-1:hover {background-color: var(--black) !important}

  body.contrast #grve-theme-wrapper a p,
  body.contrast #grve-theme-wrapper a h2,
  body.contrast #grve-theme-wrapper a h3,
  body.contrast #grve-theme-wrapper a h4,
  body.contrast #grve-theme-wrapper a div,
  body.contrast #grve-theme-wrapper a:visited,
  body.contrast #grve-theme-wrapper a:visited p,
  body.contrast #grve-theme-wrapper a:visited h2,
  body.contrast #grve-theme-wrapper a:visited h3,
  body.contrast #grve-theme-wrapper a:visited h4,
  body.contrast #grve-theme-wrapper a:visited div,
  body.contrast #grve-theme-wrapper .grve-bg-primary-1 i,
  body.contrast #grve-theme-wrapper .grve-bg-primary-1 span,
  body.contrast #grve-theme-wrapper .grve-bg-primary-1 i::before,
  body.contrast .c-listado-rutas .grve-box-icon .grve-box-content::after {
    background-color: transparent !important;
    text-decoration: none !important;
  }
  body.contrast #grve-theme-wrapper .grve-bg-primary-1 span,
  body.contrast #grve-theme-wrapper .grve-bg-primary-1:visited {
    color: var(--white) !important;
    text-decoration: none !important;
  }

  body.contrast .u-lista-rutas ul li {
    background: var(--fifth-color) !important;
    background-color: var(--fifth-color) !important
  }
    body.contrast .u-lista-rutas ul li.active {
      background: var(--black) !important;
      background-color: var(--black) !important
    }

  body.home.contrast #grve-content .c-listado-rutas a,
  body.home.contrast #grve-content .c-listado-rutas a:visited {
    background: var(--third-color) !important;
    background-color: var(--third-color) !important;
    color: var(--white) !important;
    transition: .3s
  }
    body.home.contrast #grve-content .c-listado-rutas a:focus,
    body.home.contrast #grve-content .c-listado-rutas a:hover {
      border: 2px solid lime;
      background: var(--black) !important;
      background-color: var(--black) !important;
      color: var(--black) !important;
      transition: .3s
    }
    body.home.contrast #grve-content .c-listado-rutas a:focus p,
    body.home.contrast #grve-content .c-listado-rutas a:hover p,
    body.home.contrast #grve-content .c-listado-rutas a:focus h3,
    body.home.contrast #grve-content .c-listado-rutas a:hover h3 {
      color: var(--white) !important;
      transition: .3s;
    }

body.contrast #grve-main-content .u-lista-rutas li img {filter: brightness(0) invert(1)}

body.contrast #grve-main-content .u-lista-rutas ul li.destacar,
body.contrast #grve-main-content .u-lista-rutas ul li.active.destacar {
  background: var(--alto-contraste) !important;
  transform: scale(1.05);
}

body.contrast #grve-main-content .u-lista-rutas ul li.todas-rutas a {
  color: var(--white) !important;
  text-decoration: none !important
}
  body.contrast #grve-main-content .u-lista-rutas ul li.todas-rutas a:focus,
  body.contrast #grve-main-content .u-lista-rutas ul li.todas-rutas a:hover {
    background: var(--primary-color);
    color: var(--white)
  }

body.contrast.tax-ruta_comercio .grve-column-content p strong {
  background: transparent !important;
  background-color: transparent !important;
  color: var(--black) !important
}

body.contrast.tax-ruta_comercio .grve-column-content h3::before {background: var(--alto-contraste) !important}
body.contrast.tax-ruta_comercio .grve-column-content p.u-mas-info::before, 
body.contrast.tax-ruta_comercio .grve-column-content h3 + .grve-section::before {
  background: transparent !important;
  border-color: var(--alto-contraste);
  width: 0
}

body.contrast.tax-ruta_comercio .grve-column-content p.u-mas-info a {color: var(--alto-contraste) !important}
  body.contrast.tax-ruta_comercio .grve-column-content p.u-mas-info a:focus,
  body.contrast.tax-ruta_comercio .grve-column-content p.u-mas-info a:hover {font-weight: 600}

body.contrast.tax-ruta_comercio #grve-theme-wrapper .ruta-selector select {
  appearance: none !important;
  background: var(--white) url('/wp-content/uploads/2023/12/icoSelect.png') no-repeat right 1rem center !important;
  border-width: 2px;
  color: var(--black) !important;
  content: '';
}
  body.contrast.tax-ruta_comercio #grve-theme-wrapper .ruta-selector select option {
    background: var(--white) !important;
    background-color: var(--white) !important;
    color: var(--black) !important;
  }

  body.contrast.single-comercio #grve-main-content h1 {
    background: transparent !important;
    background-color: transparent !important;
    color: var(--black) !important
  }
  body.contrast.single-comercio .grve-datos-interes-social {border-bottom: 2px solid var(--alto-contraste)}
  body.contrast.single-comercio .grve-datos-interes-social h3 {color: var(--alto-contraste) !important}
  body.contrast.single-comercio .grve-mas-info a,
  body.contrast.single-comercio .grve-mas-info .acf-field {color: var(--black) !important}
    body.contrast.single-comercio .grve-mas-info .acf-field a::after, 
    body.contrast.single-comercio .grve-mas-info .acf-field::before {
      background: transparent !important;
      background-color: transparent !important;
      color: var(--black) !important
    }
    body.contrast.single-comercio .grve-mas-info .acf-field a:focus::after, 
    body.contrast.single-comercio .grve-mas-info .acf-field a:hover::after {color: var(--alto-contraste) !important}
    body.contrast.single-comercio .grve-mas-info a:focus,
    body.contrast.single-comercio .grve-mas-info a:hover {
      color: var(--alto-contraste) !important;
      font-weight: 600 !important
    }
    body.contrast.single-comercio .grve-mas-info .u-web a {
      color: var(--alto-contraste) !important;
      font-weight: 600 !important
    }
      body.contrast.single-comercio .grve-mas-info .u-web a:focus,
      body.contrast.single-comercio .grve-mas-info .u-web a:hover {font-weight: 900 !important}


body.contrast.page-template-template-listado-comercios .listado-comercios form input[type="text"]::placeholder {color: var(--fifth-color);}
body.contrast.page-template-template-listado-comercios .listado-comercios h3 a {
  color: var(--black) !important;
  font-weight: 600 !important
}
  body.contrast.page-template-template-listado-comercios .listado-comercios h3 a:focus,
  body.contrast.page-template-template-listado-comercios .listado-comercios h3 a:hover {
    color: var(--alto-contraste) !important;
    font-weight: 900 !important
  }
body.contrast.page-template-template-listado-comercios .listado-comercios button.btn-favorito {
  background: var(--alto-contraste) !important;
  background-color: var(--alto-contraste) !important
}
  body.contrast.page-template-template-listado-comercios .listado-comercios button.btn-favorito.u-favorito {
    background: var(--black) !important;
    background-color: var(--black) !important
  }
body.contrast.page-template-template-listado-comercios .listado-comercios button.btn-favorito i::before,
body.contrast.page-template-template-listado-comercios .listado-comercios button[type="submit"] i::before {
  background: transparent !important;
  background-color: transparent !important
}

/*** media queries ***/

/** min-width **/

/** max-width **/

@media screen and (max-width: 1920px) {
  .c-descargar-app::before {left: -65vw}
}

@media screen and (max-width: 1470px) {
  #grve-header #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: 1.25rem}
  #grve-header:lang(fr) #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: 1rem}

  #disqus_thread,
  .grve-container,
  #grve-content.grve-left-sidebar .grve-content-wrapper,
  #grve-content.grve-right-sidebar .grve-content-wrapper {
    padding: 0 1rem;
    width: 100%
  }

  .single-comercio .grve-column-content .grve-section .grve-container {padding: 0}
  .single-comercio .gallery ul {padding: 3rem 1rem}
}

@media screen and (max-width: 1400px) {
  #grve-main-header .grve-logo {max-width: 18rem}
  #grve-main-header:lang(fr) .grve-logo {max-width: 16rem}
  #grve-main-header .grve-logo img {
    height: auto;
    top: 50%;
    transform: translateY(-50%);
    width: 100% !important
  }

  #grve-main-menu .grve-wrapper > ul > li > a {font-size: .9375rem}
  #grve-main-header .grve-header-elements-wrapper.grve-position-right .grve-item {
    font-size: 1.125rem;
    height: 1.125rem;
    width: 1.125rem
  }
  #grve-main-menu #menu-menu-principal .menu-item-language .wpml-ls-flag + span {font-size: .875rem}
  

  .grve-header-elements-wrapper.grve-position-right:lang(fr) .grve-header-elements {margin-left: .75rem}

  #grve-header #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: 1.125rem}
  #grve-header:lang(fr) #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: 1rem}

  .tax-ruta_comercio .grve-two-column-layout {max-height: 85vw}
  .tax-ruta_comercio .grve-two-column-layout .grve-column-content .u-contenedora {padding: 1.5rem 1.25rem 0 4rem}

  .single-comercio .gallery ul {
    margin: 0 auto;
    max-width: 60rem;
    width: 100%
  }
  .single-comercio .gallery ul li {width: 48%}
  .single-comercio .gallery li:nth-child(n+3) {margin: 2rem 0 0}
}

@media screen and (max-width: 1280px) {
  .grve-header-elements-wrapper.grve-position-right .grve-header-elements .grve-header-element:first-child > a {padding-left: 0}


  .c-listado-rutas .grve-box-icon .grve-image-icon,
  .c-listado-rutas .grve-box-icon .grve-box-content {
    float: none;
    width: 45%
  }
  .c-listado-rutas .grve-box-icon .grve-box-content {padding: 1rem 2rem 4.5rem 0}
  .c-listado-rutas .grve-box-icon .grve-box-content::after {
    bottom: 1rem;
    right: 2rem
  }

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child {width: 46%}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child {width: 52%}

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul {
    flex-wrap: wrap;
    justify-content: space-evenly;
    margin: 0 auto;
    max-width: 25rem;
    width: 100%
  }
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul li:nth-child(n+3) {margin: 1rem 0 0}

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child p a {font-size: .9375rem}
}

@media screen and (max-width: 1250px) {
  #grve-main-header .grve-logo {max-width: 17rem}
  #grve-main-header:lang(fr) .grve-logo {max-width: 15rem}

  .grve-main-menu .grve-wrapper > ul > li > a, 
  #grve-main-menu .grve-wrapper > ul > li > a,
  .grve-main-menu .grve-wrapper > ul > li.megamenu > ul > li > a, 
  .grve-main-menu .grve-wrapper > ul > li .grve-toggle-menu-item-wrapper a, 
  .grve-toggle-hiddenarea .grve-label, .grve-main-menu .grve-wrapper > ul > li ul li.grve-goback a {font-size: .875rem}

  #grve-header #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: 1rem}
  #grve-header:lang(fr) #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: .875rem}

  #grve-main-menu #menu-menu-principal .menu-item-language .wpml-ls-flag + span {font-size: .8125rem}

  .grve-header-elements-wrapper.grve-position-right:lang(fr) .grve-header-elements a {padding-left: .875rem}
  #grve-main-header .grve-header-elements-wrapper.grve-position-right .grve-item {
    font-size: 1rem;
    height: 1rem;
    width: 1rem
  }
}

@media only screen and (max-width: 1200px) {
  html {font-size: 16px}
  h1,
  #grve-page-title .grve-title, 
  #grve-blog-title .grve-title, 
  #grve-search-page-title .grve-title,
  #grve-feature-section.grve-fullscreen .grve-title {font-size: 3.5rem}
  h2 {font-size: 2rem}
  h3 {font-size: 1.375rem}
  h4 {font-size: 1.25rem}
  h5 {font-size: 1.125rem}
  h6 {font-size: 1rem}

  .grve-btn, 
  a.grve-btn,
  #reply-title,
  .grve-link-text, 
  input[type="reset"], 
  input[type="submit"], 
  input[type="button"], 
  #cancel-comment-reply-link, 
  #grve-theme-wrapper a.grve-btn,
  button:not(.mfp-arrow):not(.grve-search-btn), 
  .grve-anchor-menu .grve-anchor-wrapper .grve-container > ul > li > a, 
  .grve-anchor-menu .grve-anchor-wrapper .grve-container ul.sub-menu li a {
    font-size: .875rem !important;
    line-height: 1.4
  }

  .grve-logo .grve-wrapper {
    align-items: center;
    display: flex;
    height: 100%;
  }
  .grve-logo .grve-wrapper a {height: auto}

  #grve-main-header .grve-logo {max-width: 14rem}
  #grve-main-header:lang(fr) .grve-logo {max-width: 12rem}
  #grve-main-header .grve-logo img {transform: unset}

  #grve-header #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: .875rem}
  #grve-header:lang(fr) #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: .75rem}

  .grve-main-menu .grve-wrapper > ul > li > a, 
  #grve-main-menu .grve-wrapper > ul > li > a,
  .grve-main-menu .grve-wrapper > ul > li.megamenu > ul > li > a, 
  .grve-main-menu .grve-wrapper > ul > li .grve-toggle-menu-item-wrapper a, 
  .grve-toggle-hiddenarea .grve-label, .grve-main-menu .grve-wrapper > ul > li ul li.grve-goback a {font-size: .8125rem}

  #grve-main-header .grve-header-elements-wrapper.grve-position-right .grve-item {
    font-size: .9375rem;
    height: .9375rem;
    width: .9375rem
  }

  #grve-main-menu #menu-menu-principal .menu-item-language .wpml-ls-flag + span {font-size: .75rem}

  .grve-header-elements-wrapper.grve-position-right:lang(fr) .grve-header-elements a {padding-left: .75rem}

  .grve-page-title .grve-title-content-wrapper.grve-content-large, 
  #grve-feature-section .grve-title-content-wrapper.grve-content-large {max-width: 62rem}

  .c-listado-rutas .grve-box-icon .grve-image-icon,
  .c-listado-rutas .grve-box-icon .grve-box-content {width: 47%}

  .c-descargar-app ul li {width: 48%}
  .c-descargar-app ul li img {width: 100%}

  .u-lista-rutas ul li {font-size: 1.25rem}
  .u-lista-rutas img {margin: 0 .875rem 0 1.875rem}

  .tax-ruta_comercio .grve-two-column-layout .grve-column-content .u-contenedora {padding: 1.5rem 1.25rem 0 3.5rem}

  #grve-theme-wrapper #grve-theme-content .listado-comercios form input {width: calc(100% - 9.5rem)}
  #grve-theme-wrapper #grve-theme-content .listado-comercios form button {width: 9rem}
}

@media only screen and (max-width: 1100px) {
  #grve-main-header .grve-logo {max-width: 13rem}
  #grve-main-header:lang(fr) .grve-logo {max-width: 11rem}

  #grve-main-header .grve-header-elements-wrapper.grve-position-right .grve-item {
    font-size: .875rem;
    height: .875rem;
    width: .875rem
  }

  #grve-header #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: .625rem}
  #grve-header:lang(fr) #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: .5rem}

  #grve-header .grve-main-menu .grve-wrapper > ul > li.grve-current > a, 
  #grve-header .grve-main-menu .grve-wrapper > ul > li.current-menu-item > a, 
  #grve-header .grve-main-menu .grve-wrapper > ul > li.current-menu-ancestor > a {font-weight: 600}
}

@media only screen and (max-width: 1024px) {
  h1,
  #grve-page-title .grve-title, 
  #grve-blog-title .grve-title, 
  #grve-search-page-title .grve-title,
  #grve-feature-section.grve-fullscreen .grve-title {font-size: 3rem}
  h2 {font-size: 1.875rem}
  h3 {font-size: 1.25rem}
  h4 {font-size: 1.125rem}
  h5 {font-size: 1.0625rem}
  h6 {font-size: 1rem}

  #grve-main-header .grve-logo {max-width: 11.875rem}
  #grve-main-header:lang(fr) .grve-logo {max-width: 10rem}

  #grve-main-header .grve-header-elements-wrapper.grve-position-right .grve-item {
    font-size: .8125rem;
    height: .8125rem;
    width: .8125rem
  }

  #grve-header #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: .75rem}
  #grve-header:lang(fr) #grve-main-menu .grve-wrapper > ul > li:not(:first-child) {margin-left: .625rem}

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child {width: 44%}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child {width: 54%}

  .grve-main-menu .grve-wrapper > ul > li > a, 
  #grve-main-menu .grve-wrapper > ul > li > a,
  .grve-main-menu .grve-wrapper > ul > li.megamenu > ul > li > a, 
  .grve-main-menu .grve-wrapper > ul > li .grve-toggle-menu-item-wrapper a, 
  .grve-toggle-hiddenarea .grve-label, .grve-main-menu .grve-wrapper > ul > li ul li.grve-goback a {font-size: .75rem}

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child p a {font-size: .875rem}

  .grve-page-title .grve-title-content-wrapper.grve-content-large, 
  #grve-feature-section .grve-title-content-wrapper.grve-content-large {max-width: 58rem}

  .c-listado-rutas .grve-box-icon a {align-items: stretch}
  .c-listado-rutas .grve-box-icon .grve-image-icon,
  .c-listado-rutas .grve-box-icon .grve-box-content {width: 48%}
  .c-listado-rutas .grve-box-icon .grve-image-icon img {
    height: 100%;
    object-fit: cover;
    width: auto
  }

  .u-lista-rutas ul li {
    font-size: 1.125rem;
    padding: 0 1rem 0 0
  }
  .u-lista-rutas img {margin: 0 .75rem 0 1.75rem}

  .tax-ruta_comercio .grve-two-column-layout .grve-column-content .u-contenedora {padding: 1.5rem 1.25rem 0 3rem}
  .tax-ruta_comercio .grve-column-content h3::before {
    border: 2px solid var(--third-color);
    border-radius: .5rem;
    left: -2.4375rem;
    top: .5rem
  }
  .tax-ruta_comercio .grve-column-content p.u-mas-info::before, 
  .tax-ruta_comercio .grve-column-content h3 + .grve-section::before {left: -2rem}

  .single-comercio .grve-mas-info .u-telefono, 
  .single-comercio .grve-mas-info .u-whatsapp {width: 40%}

  .gform_wrapper.gravity-theme .gfield.gfield--width-half {grid-column: span 12}

  #grve-theme-wrapper #grve-theme-content .listado-comercios form input {width: calc(100% - 8.5rem)}
  #grve-theme-wrapper #grve-theme-content .listado-comercios form button {width: 8rem}
}

@media only screen and (max-width: 959px) {
  .grve-container {max-width: 100% !important}

  .grve-btn, 
  #reply-title,
  .grve-link-text, 
  input[type="reset"], 
  input[type="submit"], 
  input[type="button"], 
  #cancel-comment-reply-link, 
  button:not(.mfp-arrow):not(.grve-search-btn), 
  .grve-anchor-menu .grve-anchor-wrapper .grve-container > ul > li > a, 
  .grve-anchor-menu .grve-anchor-wrapper .grve-container ul.sub-menu li a {font-size: .875rem !important}

  #grve-theme-wrapper #grve-theme-content .listado-comercios button {width: 13rem}
}

@media only screen and (max-width: 950px) {
  h1,
  #grve-page-title .grve-title, 
  #grve-blog-title .grve-title, 
  #grve-search-page-title .grve-title,
  #grve-feature-section.grve-fullscreen .grve-title {font-size: 2.6875rem}
  h2 {font-size: 1.75rem}

  .grve-page-title .grve-title-content-wrapper.grve-content-large, 
  #grve-feature-section .grve-title-content-wrapper.grve-content-large {max-width: 47rem}

  #grve-responsive-header #grve-main-responsive-header {background-color: unset}
  #grve-hidden-menu .grve-close-btn {color: var(--secondary-color)}
  #grve-responsive-header a.grve-toggle-hiddenarea {
    color: var(--secondary-color);
    padding: 0 1rem
  }

  #grve-theme-content #grve-feature-section {
    height: calc(100vh - 5rem) !important;
    max-height: 40rem
  }
  #grve-feature-section .grve-wrapper,
  #grve-feature-section .grve-content {height: 100% !important}

  #grve-hidden-menu .grve-close-btn:focus,
  #grve-hidden-menu .grve-close-btn:hover,
  #grve-responsive-header a.grve-toggle-hiddenarea:focus,
  #grve-responsive-header a.grve-toggle-hiddenarea:hover {
    color: var(--primary-color);
    transform: scale(1.12);
  }
  .grve-header-element .grve-item {
    height: 1.8125rem;
    width: 1.8125rem
  }
  #grve-hidden-menu a {color: var(--secondary-color)}
  #grve-hidden-menu a:focus,
  #grve-hidden-menu a:hover {
    color: var(--primary-color);
    text-decoration: underline
  }
  #grve-hidden-menu ul.grve-menu li.open > a,
  #grve-hidden-menu ul.grve-menu li.current-menu-item > a, 
  #grve-hidden-menu ul.grve-menu > li.current-menu-item > a, 
  #grve-hidden-menu ul.grve-menu > li.current-menu-ancestor > a {
    color: var(--primary-color);
    font-weight: 600
  }
  #grve-responsive-header .grve-icon-menu {line-height: 1}
  #grve-responsive-header .grve-icon-menu::before {
    content: '\f0c9';
    display: inline-block;
    font-family: 'Font Awesome 6 Pro';
    font-size: 1.8125rem;
    font-weight: 400;
    height: 1.8125rem;
    width: 1.8125rem
  }
  .grve-hiddenarea-wrapper {padding-bottom: 5rem}
  .grve-close-btn-wrapper {margin: 2rem auto 3rem}
  .grve-hiddenarea-content {margin: 0 auto}
  .grve-close-btn-wrapper,
  .grve-hiddenarea-content {
    padding: 0 2rem;
    max-width: 25rem;
    width: 100% !important
  }
  .grve-hiddenarea-content .grve-menu-wrapper {margin: 0 0 5rem}
  .grve-hiddenarea-content .grve-header-responsive-elements ul {
    align-items: center;
    display: flex;
  }
  .grve-hiddenarea-content .grve-header-responsive-elements ul li {float: none}
  #grve-hidden-menu .grve-header-responsive-elements a {color: var(--secondary-color) !important}
  #grve-hidden-menu .grve-header-responsive-elements a:focus,
  #grve-hidden-menu .grve-header-responsive-elements a:hover {
    color: var(--primary-color) !important;
    transform: scale(1.12)
  }

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-row {
    display: flex;
    flex-direction: column;
  }
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child,
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child {width: 100%}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul {
    flex-wrap: nowrap;
    justify-content: space-between
  }
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul li {padding: 0 .5rem}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul li:first-child {padding-left: 0}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul li:last-child {padding-right: 0}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul li:first-child {
    margin: 0;
    width: auto
  }
  
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-column-wrapper,
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child .grve-column-wrapper {height: auto !important}
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-column-wrapper {padding: 2rem 0 0}

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child p,
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child ul,
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child p {justify-content: center}


  .c-rutas-compras .u-lista-rutas {width: 36%}
  .c-rutas-compras .u-mapa-rutas {width: 60%}
  .u-lista-rutas ul li {font-size: 1rem}
  .u-lista-rutas img {margin: 0 .625rem 0 1.625rem}

  .tax-ruta_comercio .grve-two-column-layout .grve-column-map,
  .tax-ruta_comercio .grve-two-column-layout .grve-column-content {width: 50%}

  .tax-ruta_comercio .grve-two-column-layout .grve-column-content .u-contenedora {padding: 1.5rem 1.25rem 0 2.5rem}
  .tax-ruta_comercio .grve-column-content h3::before {left: -2.1875rem}
  .tax-ruta_comercio .grve-column-content p.u-mas-info::before, 
  .tax-ruta_comercio .grve-column-content h3 + .grve-section::before {left: -1.75rem}

  .single-comercio .gallery ul {padding: 2rem 1rem}

  .gravity-theme .gform_required_legend {margin: 0 0 .5rem}

  .page-template-template-listado-comercios .page #contenedor-mapa,
  .page-template-template-listado-comercios .page .listado-comercios {width: 49%}
}

@media only screen and (max-width: 820px) {
  .u-lista-rutas img {margin: 0 .5rem 0 1rem}

  .tax-ruta_comercio .grve-two-column-layout .grve-column-content .u-contenedora {padding: 1.5rem 1.25rem 0 2rem}
  .tax-ruta_comercio .grve-column-content h3::before {left: -1.9375rem}
  .tax-ruta_comercio .grve-column-content p.u-mas-info::before, 
  .tax-ruta_comercio .grve-column-content h3 + .grve-section::before {left: -1.5rem}
}

@media only screen and (max-width: 768px) {
  h1,
  #grve-page-title .grve-title, 
  #grve-blog-title .grve-title, 
  #grve-search-page-title .grve-title,
  #grve-feature-section.grve-fullscreen .grve-title {font-size: 2rem}
  h2 {font-size: 1.6875rem}

  .grve-page-title .grve-title-content-wrapper.grve-content-large, 
  #grve-feature-section .grve-title-content-wrapper.grve-content-large {max-width: 34rem}

  #grve-theme-content #grve-feature-section {max-height: 30rem}
}

@media only screen and (max-width: 767px) {
  footer #grve-bottom-bar .c-banda-pie-media ul {
    flex-wrap: wrap;
    margin: 0 auto;
    max-width: 25rem;
    width: 100%
  }
  footer #grve-bottom-bar .c-banda-pie-media ul li:nth-child(n+3) {margin: 1rem 0 0}

  .c-descargar-app::before {top: 33%}
  .c-descargar-app .grve-column:last-child .grve-column-wrapper {height: auto !important}
  .c-descargar-app .grve-column:last-child .grve-column-wrapper h2 {margin: 2rem auto !important}
  .c-descargar-app .grve-column:last-child .grve-column-wrapper .grve-text {margin-bottom: 2rem !important}

  #grve-bottom-bar .c-banda-pie-superior .grve-column:first-child .grve-text {margin-bottom: 2rem !important}
  #grve-bottom-bar .c-banda-pie-superior .grve-column:last-child {margin-top: 2rem}

  .c-rutas-compras {
    flex-direction: column
  }
  .c-rutas-compras .u-mapa-rutas,
  .c-rutas-compras .u-lista-rutas {width: 100%}
  .c-rutas-compras .u-mapa-rutas {
    margin: 2rem auto 0;
    width: calc(100% - 2rem)
  }
  .u-lista-rutas h2 {max-width: none}
  .u-lista-rutas ul {
    align-items: stretch;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between
  }
  .u-lista-rutas ul li {
    margin: 0;
    width: 48%
  }
  .u-lista-rutas ul li:nth-child(n+3) {margin-top: 2rem}

  .ruta-header-info {
    flex-direction: column;
    margin: 0 0 2rem;
  }
  .ruta-header-info > div {width: 100%}
  #grve-content .ruta-header-info > div select {margin: 1rem 0 0}
  .single-comercio .grve-two-column-layout,
  .tax-ruta_comercio .grve-two-column-layout {
    flex-direction: column;
    max-height: none
  }
  .single-comercio .grve-two-column-layout .grve-column-map, 
  .single-comercio .grve-two-column-layout .grve-column-content,
  .tax-ruta_comercio .grve-two-column-layout .grve-column-map, 
  .tax-ruta_comercio .grve-two-column-layout .grve-column-content {width: 100%}
  .single-comercio .grve-two-column-layout .grve-column-map {margin: 3rem 0 0}
  .tax-ruta_comercio .grve-two-column-layout .grve-column-content {
    height: 45rem;
    padding-bottom: 2rem
  }
  .tax-ruta_comercio .grve-two-column-layout .grve-column-content .u-contenedora {
    height: 42rem;
    overflow-y: auto;
    padding: 0 1.25rem 0 2rem
  }
  .single-comercio .grve-two-column-layout .grve-column-map img {margin: 0 auto}
  .single-comercio .gallery ul {padding: 1rem}

  .listado-comercios form {flex-direction: column}
  #grve-theme-wrapper #grve-theme-content .listado-comercios form input {
    margin: 0 0 1rem;
    width: 100%
  }
  #grve-theme-wrapper #grve-theme-content .listado-comercios form button {margin: 0 0 0 auto}
  .page-template-template-listado-comercios .page .comercios-listado-completo {height: 55rem}
}

@media only screen and (max-width: 640px) {
  .c-listado-rutas .grve-box-icon a {flex-direction: column}
  .c-listado-rutas .grve-box-icon .grve-image-icon,
  .c-listado-rutas .grve-box-icon .grve-box-content {width: 100%}
  .c-listado-rutas .grve-box-icon .grve-box-content {padding: 2rem 2rem 4.5rem}
  .c-listado-rutas .grve-box-icon .grve-image-icon img {
    height: auto;
    object-fit: none;
    margin: 0 auto;
    width: 100%
  }

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul {
    flex-wrap: wrap;
    justify-content: space-evenly;
  }
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul li:first-child {
    margin: 0 0 2rem;
    width: 100%
  }

  .single-comercio .gallery ul {
    flex-direction: column;
    max-width: 30.125rem
  }
  .single-comercio .gallery ul li {width: 100%}
  .single-comercio .gallery li:nth-child(n+2) {margin: 2rem 0 0}
}

@media only screen and (max-width: 580px) {
  h1,
  #grve-page-title .grve-title, 
  #grve-blog-title .grve-title, 
  #grve-search-page-title .grve-title,
  #grve-feature-section.grve-fullscreen .grve-title {font-size: 1.625rem}
  h2 {font-size: 1.5rem}

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child p {
    flex-wrap: wrap;
    margin: 0 auto;
    max-width: 20rem;
    width: 100%
  }
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a:nth-child(3) {
      margin-right: 0;
      padding-right: 0;
    }
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a:nth-child(4) {
      margin-left: 0;
      padding-left: 0;
    }
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a:nth-child(4)::before {content: unset}
    footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a:nth-child(n+4) {margin-top: 1.5rem}
  .grve-page-title .grve-title-content-wrapper.grve-content-large, 
  #grve-feature-section .grve-title-content-wrapper.grve-content-large {max-width: 28rem}

  #grve-theme-content #grve-feature-section {max-height: 20rem}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a {font-size: .875rem}

  .u-lista-rutas h2 {text-align: center}
  .u-lista-rutas ul {
    flex-direction: column;
    justify-content: space-evenly
  }
  .u-lista-rutas ul li {
    margin: 0 auto;
    max-width: 20rem;
    width: 100%

  }
  .u-mapa-rutas {width: 100%}
  .u-lista-rutas ul li:nth-child(n+2) {margin-top: 2rem}

  .tax-ruta_comercio .grve-two-column-layout .grve-column-content {padding: 1rem 1rem 2rem 0.5rem}
  .tax-ruta_comercio .grve-two-column-layout .grve-column-content .u-contenedora {padding: 0 1.25rem 0 1.5rem}
  .tax-ruta_comercio .grve-column-content h3::before {left: -1.4375rem}
  .tax-ruta_comercio .grve-column-content p.u-mas-info::before, 
  .tax-ruta_comercio .grve-column-content h3 + .grve-section::before {left: -1rem}

  .single-comercio .gallery ul li {width: 100%}
  .single-comercio .gallery ul li:nth-child(n+2) {margin: 2rem 0 0}

  .page-template-template-listado-comercios .page {flex-direction: column}
  .page-template-template-listado-comercios .page #contenedor-mapa, 
  .page-template-template-listado-comercios .page .listado-comercios {
    margin: 0 auto;
    width: 86%
  }
  .listado-comercios form {flex-direction: row}
  #grve-theme-wrapper #grve-theme-content .listado-comercios form input {
    margin: 0;
    width: calc(100% - 8.5rem)
  }
  #grve-theme-wrapper #grve-theme-content .listado-comercios form button {width: 8rem}
  .page-template-template-listado-comercios .page .comercios-listado-completo {height: 28rem}
  .page-template-template-listado-comercios .page #contenedor-mapa {margin-top: 2rem} 
  .page-template-template-listado-comercios .page #contenedor-mapa .leaflet-container {height: 90vh !important} 
}

@media only screen and (max-width: 480px) {
  .c-descargar-app::before {top: 25%}
  .c-descargar-app .grve-column:last-child .grve-text:last-child ul {flex-direction: column}
  .c-descargar-app .grve-column:last-child .grve-text:last-child ul li {
    text-align: center;
    width: 100%
  }
  .c-descargar-app .grve-column:last-child .grve-text:last-child ul li:not(:first-child) {margin-top: 2rem}
  .c-descargar-app .grve-column:last-child .grve-text:last-child img {
    display: inline-block;
    max-width: 100%;
    width: auto
  }
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a {font-size: .75rem}

  .listado-comercios h2 {font-size: 1.5rem}
  .listado-comercios ul li h3 {font-size: 1.125rem}
  .listado-comercios ul li p {font-size: .875rem}
}

@media only screen and (max-width: 420px) {
  .c-descargar-app::before {top: 23%}

  #grve-bottom-bar .grve-column:first-child a.grve-btn {
    font-size: .8125rem !important;
    padding: 1rem 3.5rem 1rem 1rem
  }
  footer #grve-bottom-bar .c-banda-pie-media ul {flex-direction: column}
  footer #grve-bottom-bar .c-banda-pie-media ul li:nth-child(n+2) {margin: 1rem 0 0}
  #grve-bottom-bar .grve-column:first-child a.grve-btn i {margin: 0}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child .grve-text:last-child p {flex-direction: column}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child .grve-text:last-child p img {margin-top: 1rem}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child .grve-text:last-child a:nth-child(n+2) {margin-top: 1.5rem}

  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column + .grve-column p {
    flex-direction: column !important;
    justify-content: center !important;
  }
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column + .grve-column p a {
    font-size: 1rem !important;
    margin: .5rem 0;
    padding: 0
  }
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:last-child p a::before {content: unset !important}

  .single-comercio .grve-two-column-layout .grve-column-map {margin: 2rem 0 0}
  .single-comercio .grve-datos-interes-social {margin: 0}
  .single-comercio .grve-two-column-layout {padding: 0 0 1rem}

  .single-comercio .grve-mas-info .u-telefono, 
  .single-comercio .grve-mas-info .u-whatsapp {
    margin-right: 0;
    width: 1000%
  }

  .listado-comercios form {flex-direction: column}
  #grve-theme-wrapper #grve-theme-content .listado-comercios form input {
    margin: 0 0 1rem;
    width: 100%
  }
}

@media only screen and (max-width: 350px) {
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul li {width: 100%}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul li:not(:last-child) {margin-bottom: 1rem}
  footer #grve-bottom-bar .c-banda-pie-inferior .grve-column:first-child ul li img {margin: 0 auto}
}