@font-face {
  font-family: "PoppinsMed";
  src: local("PoppinsMed"),
    url("/assets/fonts/Poppins-Medium.ttf") format("truetype");
}

@font-face {
  font-family: "PoppinsReg";
  src: local("PoppinsReg"),
    url("/assets/fonts/Poppins-Regular.ttf") format("truetype");
}

@font-face {
  font-family: "PoppinsLig";
  src: local("PoppinsLig"),
    url("/assets/fonts/Poppins-Light.ttf") format("truetype");
}

@font-face {
  font-family: "Alicanrent";
  src: local("Alicanrent"),
    url("/assets/fonts/Alicanrent.ttf") format("truetype"),
    url("/assets/fonts/Alicanrent.woff") format("woff");
}

[class^="soyfont-"],
[class*=" soyfont-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "Alicanrent" !important;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.soyfont-check-rounded:before {
  content: "\e900";
  color: var(--principal);
}

.soyfont-close-rounded:before {
  content: "\e901";
  color: var(--rojo);
}

.soyfont-soy:before {
  content: "\e902";
}

.soyfont-check:before {
  content: "\e903";
}

.soyfont-close:before {
  content: "\e904";
  color: #ffffff;
  font-size: 1.8rem;
}

.soyfont-burguer:before {
  content: "\e905";
  color: #ffffff;
  font-size: 1.8rem;
}

:root {
  --negro: #212121;
  --gris1: #464646;
  --gris2: #a3a3a3;
  --gris3: #cbcbcb;
  --crudo: #f8f8f8;
  --blanco: #faf5de;
  --principal: #689c9c;
  --principal_osc: #4D7575;
  --amarillo: #ffe867;
  --melocoton: #ffb37b;
  --rojo: #F57B7B;

  /* Font/text values */
  --poppinsMed: "PoppinsMed", sans-serif;
  --poppinsReg: "PoppinsReg", sans-serif;
  --poppinsLig: "PoppinsLig", sans-serif;
}

body {
  top: 0px;
  left: 0px;
  background-color: #ffffff;
  background-repeat: no-repeat;
  background-origin: padding-box;
  opacity: 1;
  max-width: 1920px;
  min-width: 375px;
  width: 100%;
  margin: 0 auto;
}

.contenedor {
  width: 100%;
}

.bg {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background-color: rgba(104, 156, 156, 0.8);
  background-repeat: no-repeat;
  background-origin: padding-box;
  opacity: 1;
  z-index: 20;
  position: fixed;
  transition: top 0.3s;
  top: 0;
  padding: 9px 212px 7px;
}

.menu {
  display: flex;
  align-items: center;
  justify-content: space-evenly;
  opacity: 1;
}

.contacto {
  text-align: left;
  margin-right: 24px;
  font: normal normal bold 16px/25px var(--poppinsMed);
  letter-spacing: 0px;
  color: #ffffff;
  text-transform: capitalize;
  opacity: 1;
  text-decoration: none;
}

.contratar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 176px;
  height: 47px;
  border: 2px solid #ffffff;
  border-radius: 28px;
  opacity: 1;
  text-decoration: none;
  color: #ffffff;
  font: normal normal bold 16px/25px var(--poppinsMed);
  position: relative;
  overflow: hidden;
  z-index: 1;
}

.contratar::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40%;
  height: 110%;
  background-color: rgba(255, 255, 255, 0);
  border-radius: 28px;
  transform: translate(-50%, -50%);
  transition: width 0.2s linear, background-color 0.2s linear;
  z-index: -1;
  pointer-events: none;
}

.contratar:hover::before {
  width: 110%;
  background-color: rgba(255, 255, 255, 1);
}

.contratar:hover {
  color: var(--negro);
}


.header {
  width: 236px;
  height: 75px;
  background: transparent;
  background-image: url("/assets/img/DEFINITIVOS_HEADER.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-position: center top;
  background-size: cover;
  opacity: 1;
  cursor: pointer;
}

.foto-cabecera {
  width: 100%;
  height: 700px;
  background: transparent;
  background-image: url("/assets/img/foto-cabecera.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-position: center top;
  background-size: cover;
  opacity: 1;
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 1;
}

.foto-cabecera p {
  font-family: var(--poppinsReg);
  font-size: 40px;
  letter-spacing: 0px;
  color: var(--crudo);
  text-transform: uppercase;
  opacity: 1;
  margin: 0;
  padding-top: 351px;
}

.heroe {
  text-align: center;
  max-width: 740px;
  height: auto;
  font-family: var(--poppinsReg);
  opacity: 1;
  color: var(--negro);
  letter-spacing: 0px;
  margin: 94px auto 120px;
}

.heroe h2 {
  font-size: 25px;
  line-height: 1.24;

  margin-bottom: 24px;
}

.heroe p {
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 24px;
}

.heroe>img {
  width: 194px;
  height: auto;
}

.acordeon-bg {
  background-color: var(--crudo);
  display: flex;
  justify-content: space-between;
  padding: 46px 212px 46px 338px;
}

.acordeon-img {
  width: 488px;
  height: 598px;
  background-image: url("/assets/img/alicante-vertical.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-position: center top;
  background-size: cover;
}

.accordion {
  width: 740px;
  opacity: 1;
  background-color: inherit;
  background-color: transparent;
}

.accordion-item,
.accordion-header button,
.accordion-body,
.accordion-collapse {
  background-color: var(--crudo);
  color: var(--gris2);
}

.accordion {
  --bs-accordion-inner-border-radius: 0;
  --bs-accordion-active-bg: var(--crudo);
  --bs-accordion-active-color: var(--negro);
  --bs-accordion-btn-focus-border-color: var(--crudo);
}


.accordion-button::after {
  content: none;
}

.accordion-button {
  font-family: var(--poppinsReg);
  font-size: 20px;
  line-height: 1.55;
  outline: none;
}

.accordion-button:focus {
  border: none;
  box-shadow: none;
}

.accordion-button:not(.collapsed) {
  background-color: var(--crudo);
}

.accordion-button:focus {
  border: none;
  box-shadow: none;
}

.accordion-body {
  color: var(--negro);
  font-family: var(--poppinsReg);
  font-size: 16px;
  line-height: 1.5;
}

.horizontal {
  display: flex;
  justify-content: center;
}

.rectangulo {
  display: flex;
  justify-content: space-between;
  background-color: var(--principal);
  width: 100%;
  max-width: 960px;
  opacity: 1;
  padding-right: 134px;
  padding-left: 212px;
}

.anfitriones {
  padding-top: 117.5px;
  color: #ffffff;
  text-align: left;
  letter-spacing: 0px;
  opacity: 1;
  box-sizing: content-box;
}

.anfitriones h2 {
  font-family: var(--poppinsReg);
  font-size: 25px;
  line-height: 1.24;
  margin-bottom: 24px;
}

.anfitriones p {
  font-family: var(--poppinsLig);
  font-size: 16px;
  line-height: 1.5;
}

.anfitriones div {
  display: flex;
  justify-content: flex-end;
  margin-top: 200px;
}

.playa {
  width: 100%;
  max-width: 960px;
  height: 672px;
  background-image: url("/assets/img/alicante-horizontal.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-position: center top;
  background-size: cover;
  opacity: 1;
}

.cajas {
  margin: 74px auto 53px;
}

.caja {
  width: 362px;
  height: 477px;
  background-color: var(--principal);
  border-radius: 20px;
  opacity: 1;
  color: #ffffff;
  text-align: center;
}

.caja h2 {
  font-family: var(--poppinsMed);
  font-size: 18px;
  line-height: 1.55;
  margin: 24px 25px 16px;
}

.caja p {
  font-family: var(--poppinsReg);
  font-size: 14px;
  line-height: 1.42;
  margin: 16px 25px;
}

.caja img {
  height: 60px;
  max-width: 60px;
  margin: 42px auto 0;
}

.owl-item {
  display: flex;
}

.owl-carousel {
  margin: 0 auto;
  max-width: 1496px;
}

.owl-dots {
  display: flex;
  justify-content: center;
  margin-top: 61px;
}

.owl-carousel button.owl-dot {
  margin: 5px;
  width: 10px;
  height: 10px;
  background-color: var(--gris3);
  border-radius: 50px;
}

.owl-carousel button.owl-dot.active {
  background-color: var(--negro);
}

.cuadrado {
  width: 100%;
  background-color: var(--crudo);
  opacity: 1;
  display: flex;
}

.izquierda {
  width: 960px;
  height: 630px;
  padding-left: 212px;
  padding-top: 81.5px;
}

.izquierda h2 {
  margin-bottom: 24px;
  font-family: var(--poppinsReg);
  font-size: 25px;
  color: var(--gris1);
  letter-spacing: 0px;
  opacity: 1;
}

.izquierda p {
  width: 614px;
  margin-bottom: 24px;
  text-align: left;
  font-size: 16px;
  line-height: 1.5;
  font-family: var(--poppinsLig);
  letter-spacing: 0px;
  color: var(--negro);
  opacity: 1;
}

.derecha {
  width: 960px;
  height: 630px;
  padding-top: 98px;
}

.derecha-grupo {
  display: flex;
  border-bottom: 1px solid var(--gris2);
  width: 740px;
  margin-bottom: 24px;
}

.derecha-grupo:last-child {
  border-bottom: 0;
}

.derecha-grupo h2 {
  width: 236px;
  margin-bottom: 24px;
  font-family: var(--poppinsReg);
  font-size: 20px;
  letter-spacing: 0px;
  color: var(--negro);
  text-align: left;
  letter-spacing: 0px;
  opacity: 1;
}

.derecha-grupo p {
  width: 488px;
  font-family: var(--poppinsLig);
  font-size: 16px;
  line-height: 1.5;
  color: var(--negro);
  text-align: left;
  letter-spacing: 0px;
  opacity: 1;
  margin-bottom: 24px;
  padding-left: 16px;
}

.fondo-cards {
  width: 100%;
  height: 800px;
  background-image: url("/assets/img/fondo-cards.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-position: center top;
  background-size: cover;
  opacity: 1;
  display: flex;
  justify-content: center;
  padding-top: 81px;
}

.carta-izq {
  width: 362px;
  height: 546px;
  background: rgba(255, 255, 255, 0.5) 0% 0% no-repeat padding-box;
  border-radius: 28px;
  opacity: 1;
  margin: 0 8px;
}

.tarifa {
  text-align: center;
  color: var(--negro);
  margin-bottom: 35px;
}

.tarifa-basic {
  margin-top: 65px;
  font-size: 20px;
  line-height: 1.55;
  font-family: var(--poppinsMed);
  opacity: 1;
}

.tarifa p {
  position: relative;
  z-index: 2;
  top: -20px;
  font-size: 40px;
  font-family: var(--poppinsReg);
  text-align: center;
  margin-bottom: -5px;
}

.borde {
  background-color: var(--principal);
  height: 25px;
  width: 118px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  top: -40px;
}

.borde-golden {
  background: transparent linear-gradient(90deg, #ffe867 0%, #ffb37b 100%) 0% 0% no-repeat padding-box;
  height: 25px;
  width: 158px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  top: -40px;
}

.precio {
  font-family: var(--poppinsReg);
  margin-top: -23px;
}

.precio span:first-child {
  font-size: 40px;
}

.precio span:nth-child(2) {
  font-size: 30px;
  margin-left: 5px;
}

.precio span:last-child {
  font-size: 20px;
  margin-left: 15px;
}

.incluye {
  margin-left: 28px;
  margin-bottom: 27px;
  color: var(--negro);
}

.incluye>div {
  display: flex;
  align-items: baseline;
}

.incluye>div p {
  font-size: 16px;
  line-height: 1.5;
  font-family: var(--poppinsReg);
  margin-left: 15px;
  margin-bottom: 12px;
}

.incluye h3 {
  font-size: 16px;
  line-height: 1.5;
  font-family: var(--poppinsMed);
}

.contratar-basic {
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 176px;
  height: 47px;
  border: 2px solid var(--negro);
  border-radius: 28px;
  opacity: 1;
  text-decoration: none;
  color: var(--negro);
  font: normal normal bold 16px/25px var(--poppinsMed);
  position: relative;
  overflow: hidden;
  z-index: 1;
}

.contratar-basic::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40%;
  height: 110%;
  background-color: rgba(0, 0, 0, 0);
  border-radius: 28px;
  transform: translate(-50%, -50%);
  transition: width 0.2s linear, background-color 0.2s linear;
  z-index: -1;
  pointer-events: none;
}

.contratar-basic:hover::before {
  width: 110%;
  background-color: rgba(0, 0, 0, 1);
}

.contratar-basic:hover {
  color: #ffffff;
}

.coste {
  text-align: left;
  font-family: var(--poppinsMed);
  font-size: 14px;
  line-height: 1.71;
  letter-spacing: 0px;
  color: #212121;
  opacity: 1;
  margin-top: 25px;
  margin-left: 19px;
}

.contratar-golden {
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 176px;
  height: 47px;
  border-radius: 28px;
  opacity: 1;
  text-decoration: none;
  background-color: var(--negro);
  color: #ffffff;
  font: normal normal bold 16px/25px var(--poppinsMed);
  position: relative;
  overflow: hidden;
  z-index: 1;
}

.contratar-golden::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 40%;
  height: 110%;
  background: transparent linear-gradient(90deg, #ffe867 0%, #ffb37b 100%);
  opacity: 0;
  border-radius: 28px;
  transform: translate(-50%, -50%);
  transition: width 0.2s linear, opacity 0.2s linear;
  z-index: -1;
  pointer-events: none;
}

.contratar-golden:hover::before {
  width: 110%;
  opacity: 1;
}

.contratar-golden:hover {
  color: var(--negro);
}

.carta-dcha {
  width: 362px;
  height: 630px;
  background: rgba(255, 255, 255, 0.5) 0% 0% no-repeat padding-box;
  border-radius: 28px;
  opacity: 1;
  margin: 0 8px;
}

.carta-dcha-degradado {
  width: 362px;
  height: 34px;
  background: linear-gradient(90deg,
      rgba(255, 232, 103, 1) 0%,
      rgba(255, 179, 123, 1) 100%) 0% 0% no-repeat padding-box;
  border-radius: 28px 28px 0px 0px;
  opacity: 1;
}

.carta-dcha-degradado p {
  text-align: center;
  padding: 7px 0 4px;
  font-size: 16px;
  font-family: var(--poppinsMed);
  color: #ffffff;
}

.carta-dcha .incluye {
  margin-bottom: 40px;
}

.tarifa-golden {
  margin-top: 31px;
  font-size: 20px;
  line-height: 1.55;
  font-family: var(--poppinsMed);
  opacity: 1;
}

footer {
  width: 100%;
  height: auto;
  background: #ebebeb 0% 0% no-repeat padding-box;
  opacity: 1;
  padding-top: 80px;
  padding-bottom: 39px;
}

.footer.accordion {
  display: flex;
  justify-content: space-between;
  margin-left: 212px;
  left: 0;
  width: calc(100% - 212px);
}

.enlace h3 {
  font-size: 20px;
  font-family: var(--poppinsMed);
  text-align: left;
  letter-spacing: 0px;
  color: var(--principal_osc);
  opacity: 1;
}

.enlace p {
  font-size: 14px;
  line-height: 1.71;
  font-family: var(--poppinsLig);
  letter-spacing: 0px;
  color: var(--principal_osc);
  opacity: 1;
  margin-bottom: 8px;
}

.footer-img {
  position: relative;
  top: -23px;
  margin-right: 192px;
  width: 394px;
  height: 128px;
  background-image: url("/assets/img/DEFINITIVOS_FOOTER.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-position: center top;
  background-size: contain;
}

.footer-linea {
  width: 1496px;
  height: 0px;
  border: 1px solid var(--principal_osc);
  opacity: 0.58;
  margin-left: 212px;
  margin-bottom: 8px;
  margin-top: 77px;
}

footer>p {
  margin-left: 212px;
  font-family: var(--poppinsReg);
  font-size: 13px;
  text-align: left;
  letter-spacing: 0px;
  color: var(--negro);
  opacity: 0.75;
}

/************** CONTACTO **************/

.contenedor-contacto {
  width: auto;
  height: auto;
}

.contacta {
  max-width: 614px;
  text-align: left;
  letter-spacing: 0px;
  opacity: 1;
  margin: 0 auto;
}

.contacta h1 {
  width: 100%;
  margin-top: 86px;
  margin-bottom: 24px;
  font-family: var(--poppinsMed);
  font-size: 40px;
  line-height: 1.2;
  letter-spacing: 0px;
  color: var(--negro);
}

.contacta h1>span {
  color: #7ba8a7;
}

.contacta>p {
  width: 100%;
  color: var(--negro);
  font-size: 16px;
  line-height: 1.5;
  font-family: var(--poppinsLig);
}

.rellena {
  grid-area: rellena;
  position: relative;
}

.ballena {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  width: 614px;
  background: var(--principal) 0% 0% no-repeat padding-box;
  border-radius: 60px 60px 0px 60px;
  opacity: 1;
}

.ballena p {
  width: 85%;
  margin: 40px 0 26px 34px;
  color: #ffffff;
  font-family: var(--poppinsLig);
  font-size: 16px;
  line-height: 1.5;
}

.tlf p {
  font-family: var(--poppinsMed);
  width: 100%;
  margin: 0 0 42px 34px;
}

.tlf a {
  text-decoration: none;
  color: #ffffff;
}

.tlf a:hover {
    color: var(--blanco);
}

.tlf span {
  padding-left: 20px;
}

.principal-img {
  width: 614px;
  background-image: url("/assets/img/will-myers-BCSnor8oUt0-unsplash.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-position: center top;
  background-size: cover;
}

.secundario {
  display: flex;
  margin-top: 93px;
  margin-left: 212px;
}

.mapa {
  width: 630px;
}

#map-canvas {
  width: 488px;
  height: 488px;
}

.ver-mapa {
  position: relative;
  top: -85px;
  width: 488px;
  height: 85px;
  background-color: rgba(33, 33, 33, 0.8);
  opacity: 1;
}

.ver-mapa p {
  color: #ffffff;
  font-family: var(--poppinsReg);
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  padding-top: 31px;
  cursor: pointer;
}

.mapa>p {
  position: relative;
  top: -61px;
  font-family: var(--poppinsReg);
  font-size: 16px;
  margin-bottom: 8px;
}

.mapa>p:last-child {
  margin-bottom: 107px;
}

.formulario {
  width: 866px;
}

.formulario h2 {
  font-family: var(--poppinsMed);
  font-size: 25px;
  line-height: 1.24;
  margin-bottom: 0px;
  color: var(--negro);
}

.formulario form {
  height: 630px;
}

.nombre label,
.pais label,
.interesa,
.mensaje label {
  background-color: #ffffff;
  font-family: var(--poppinsReg);
  color: #7ba8a7;
  font-size: 14px;
  line-height: 1.71;
  letter-spacing: 0px;
  padding: 5px;
  position: relative;
  z-index: 2;
  left: 18px;
}

.nombre input {
  width: 100%;
  height: 52px;
  border: 1px solid #7ba8a7;
  border-radius: 10px;
  position: relative;
  z-index: 1;
  top: -20px;
  padding-left: 23px;
}

.nombre input[type="text"]::placeholder,
.nombre input[type="email"]::placeholder {
  font-family: var(--poppinsReg);
  color: var(--gris2);
  font-size: 14px;
  line-height: 1.71;
  letter-spacing: 0px;
}

.pais-provincia {
  display: flex;
  justify-content: space-between;
}

.pais {
  width: 100%;
  position: relative;
}

.pais.izq {
  padding-right: 9px;
}

.pais.dcha {
  padding-left: 9px;
}

.pais select {
  width: 100%;
  height: 52px;
  border: 1px solid #7ba8a7;
  border-radius: 10px;
  position: relative;
  z-index: 1;
  top: -20px;
  padding-left: 23px;
  appearance: none;
  font-family: var(--poppinsReg);
  color: var(--negro);
  font-size: 14px;
  line-height: 1.71;
  letter-spacing: 0px;
  background-color: #ffffff;
}

.soyfont-check {
  position: absolute;
  right: 25px;
  z-index: 5;
  top: 50%;
  transform: translateY(-50%);
  color: var(--negro);
}

.interesa {
  width: 170px;
  padding: 0 5px;
  top: -4px;
}

.interesa-radio {
  display: flex;
  height: 52px;
  border: 1px solid #7ba8a7;
  border-radius: 10px;
  position: relative;
  z-index: 1;
  top: -34px;
  padding-left: 23px;
  padding-top: 14px;
  font-family: var(--poppinsReg);
  color: var(--negro);
  font-size: 14px;
  line-height: 1.71;
  letter-spacing: 0px;
}

.interesa-div input {
  margin-right: 10px;
}

.interesa-div label {
  margin-right: 50px;
}

.form-check-input {
  border: 1px solid #707070;
}

.form-check-input:hover {
  border: 1px solid #707070;
  background-color: #7ba8a7;
}

.form-check-input:checked {
  border: 3px solid #7ba8a7;
  background-color: #ffffff;
}

.mensaje {
  margin: -23px 0 -7px;
}

.mensaje textarea {
  width: 866px;
  height: 157px;
  border: 1px solid #7ba8a7;
  border-radius: 10px;
  position: relative;
  z-index: 1;
  top: -20px;
  padding-left: 23px;
  padding-top: 16px;
  color: var(--gris2);
}

.campos {
  font-family: var(--poppinsReg);
  color: var(--negro);
  font-size: 13px;
  line-height: 1.46;
  letter-spacing: 0px;
}

.lorem {
  display: flex;
}

.lorem-input {
  margin-right: 22px;
  width: 32px;
  height: 20px;
  border: 1px solid #707070;
  border-radius: 2px;
}

.enviar {
  display: flex;
  justify-content: flex-end;
}

.enviar .contratar-basic {
  margin: 0;
  color: #7ba8a7;
  border: 2px solid #7ba8a7;
}

.enviar .contratar-basic:hover {
  background-color: var(--negro);
  color: #ffffff;
  border: 2px solid #ffffff;
  cursor: pointer;
}

.hamburguesa,
.oculto {
  display: none;
}

.principal {
  margin: 135px auto 0;
  width: 90%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  grid-auto-columns: 1fr;
  gap: 0px 0px;
  grid-auto-flow: row;
  grid-template-areas:
    "contacta principal-img"
    "rellena principal-img";
}

.contacta {
  grid-area: contacta;
}

.rellena {
  grid-area: rellena;
}

.principal-img {
  grid-area: principal-img;
}

/* CIUDAD DE LA LUZ */
.foto-cabecera-luz {
  width: 100%;
  height: 753px;
  background: transparent;
  background-image: url("/assets/img/fotoheroe-desk.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-position: center top;
  background-size: cover;
  opacity: 1;
  position: relative;
  z-index: 1;
}

.cabecera-texto {
  max-width: 641px;
  margin-left: 212px
}

.foto-cabecera-luz h2 {
  font-family: var(--poppinsMed);
  font-size: 40px;
  color: var(--principal_osc);
  padding-top: 160px;
}

.foto-cabecera-luz p {
  margin-top: 24px;
  font-family: var(--poppinsReg);
  font-size: 16px;
  color: var(--negro);
}

body#ciudad .heroe {
  max-width: 662px;
}

.heroe-iconos {
  display: flex;
  justify-content: center;
  gap: 34px;
  padding: 22px 0 45px;
}

.calidad {
  display: flex;
  align-items: center;
  margin: 43px 0 108px 212px;
  background-color: var(--crudo);
}

.puerta {
  width: 630px;
  height: 419px;
  background-image: url("/assets/img/Imagen 6.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-size: cover;
}

.calidad-texto {
  max-width: 542px;
  margin-left: 126px;
}

.calidad-texto h2,
.viviendas-texto h2 {
  font-family: var(--poppinsMed);
  font-size: 25px;
}

.calidad-texto p,
.viviendas-texto p {
  margin-top: 24px;
  font-family: var(--poppinsReg);
  font-size: 16px;
}

.viviendas {
  display: flex;
  align-items: center;
}

.viviendas-texto {
  max-width: 542px;
}

.viviendas-img {
  display: flex;
  align-items: center;
  gap: 51px;
}

.cojines {
  width: 132px;
  height: 132px;
  background-image: url("/assets/img/Enmascarar grupo 9.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-size: cover;
}

.cama {
  width: 309px;
  height: 309px;
  background-image: url("/assets/img/Enmascarar grupo 5.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-size: cover;
}

.cuadro {
  width: 132px;
  height: 132px;
  background-image: url("/assets/img/Enmascarar grupo 6.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-size: cover;
}

/* MEDIA QUERIES */
@media screen and (max-width: 1750px) {
  .acordeon-bg {
    justify-content: center;
    padding: 39px 0;
    flex-wrap: wrap;
  }

  .caja:first-child {
    margin-left: 15px;
  }

  .cuadrado {
    flex-wrap: wrap;
    width: 100%;
    height: auto;
    justify-content: center;
  }

  .izquierda,
  .derecha {
    text-align: center;
    padding: 0 16px;
    width: 100%;
    max-width: 640px;
    height: auto;
  }

  .izquierda h2 {
    text-align: center;
    font-size: 18px;
    line-height: 1.33;
    margin-bottom: 22px;
    margin-top: 42px;
    width: auto;
    height: auto;
  }

  .derecha-grupo h2 {
    text-align: center;
    font-size: 18px;
    line-height: 1.33;
    margin-bottom: 12px;
    margin-top: 42px;
    width: auto;
    height: auto;
  }

  .izquierda p,
  .derecha-grupo p {
    width: auto;
    text-align: center;
    font-size: 14px;
    line-height: 1.42;
    margin-bottom: 22px;
    padding: 0;
  }

  .derecha-grupo {
    display: block;
    border: 0;
    width: auto;
    height: auto;
  }

  #ver {
    text-transform: uppercase;
    text-decoration: none;
    font-family: var(--poppinsMed);
    font-size: 14px;
    color: var(--negro);
    margin: 0 auto 28px;
    display: flex;
    align-items: center;
  }

  #ver::after {
    content: "";
    display: flex;
    width: 1rem;
    height: 1rem;
    margin-left: 10px;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23212529'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
  }


  .secundario {
    flex-wrap: wrap-reverse;
    margin: 0 auto;
    max-width: 640px;
  }

  .formulario,
  .mapa {
    width: 100%;
    margin: 0 16px;
  }

  .formulario form {
    height: auto;
  }

  .formulario h2 {
    text-align: center;
    margin-top: 17px;
    font-size: 18px;
  }

  .pais-provincia {
    display: block;
    width: 100%;
    position: relative;
  }

  .pais select {
    width: 100%;
  }

  .pais.izq,
  .pais.dcha {
    padding: 0;
  }

  .interesa-radio {
    height: 100%;
    display: block;
  }

  .interesa-div:last-child {
    margin-bottom: 15px;
  }

  .mensaje textarea {
    width: 100%;
  }

  #map-canvas {
    width: 100%;
  }

  .ver-mapa {
    width: auto;
  }

  .mapa {
    height: 630px;
  }

  .mapa>p {
    text-align: center;
    font-size: 14px;
    line-height: 0.9;
  }

  .obligatorio {
    display: none;
  }
}


@media screen and (max-width: 1444px) {
  .rectangulo {
    padding: 0 30px;
    max-width: unset;
  }

  .horizontal {
    flex-wrap: wrap-reverse;
  }

  .anfitriones div {
    justify-content: center;
    margin-top: 60px;
  }

  .anfitriones {
    text-align: center;
    padding: 20px;
  }

  .footer.accordion {
    flex-wrap: wrap;
    justify-content: space-evenly;
    margin: 0 auto;
  }

  .footer-linea {
    margin: 53px auto 0;
    width: 80%;
  }

  footer>p {
    margin: 11px auto 70px;
    text-align: center;
    font-size: 12px;
  }

  .principal {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    gap: 0px;
    grid-auto-flow: row;
    grid-template-areas:
      "contacta"
      "principal-img"
      "rellena";
  }

  .ballena {
    position: static;
    transform: none;
    width: 100%;
    margin: 0 auto;
    text-align: center;
  }

  .ballena p {
    font-size: 14px;
    line-height: 1.42;
    margin: 47px 28px 23px 30px;
  }

  .tlf p {
    margin: 0;
    margin-bottom: 54px;
  }

  .contacta {
    width: 100%;
    text-align: center;
  }

  .contacta h1,
  .contacta p {
    width: auto;
    margin: 0;
  }

  .contacta h1 {
    font-size: 22px;
    line-height: 1.27;
    margin-bottom: 20.5px;
  }

  .contacta p {
    font-size: 14px;
    line-height: 1.42;
    margin-bottom: 37px;
  }

  .principal-img {
    width: auto;
    height: 432px;
  }

  .rellena {
    width: 100%;
    height: auto;
    margin: 17px auto;
  }
}

@media screen and (max-width: 1227px) {

  .accordion,
  .accordion-item,
  .accordion-button,
  .accordion-header,
  .accordion-body,
  .accordion-collapse,
  .accordion-body {
    text-align: center;
    display: block;
  }

  .enlace p {
    text-align: left;
  }
}



@media screen and (max-width: 950px) {
  .menu {
    display: none;
  }

  .bg {
    padding: 9px 0 7px;
    justify-content: center;
  }

  .header {
    background-size: contain;
  }

  .heroe {
    padding: 0 16px;
    margin-bottom: 90px;
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .footer.accordion {
    flex-direction: column;
    margin-left: 0px;
    width: 100%;
  }

  .footer.accordion h3 {
    padding: 0;
    display: flex;
    justify-content: center;
    margin-bottom: 5px;
  }

  .footer .accordion-button::after {
    --bs-accordion-btn-icon-width: 1rem;
    margin-left: 10px;
    content: "";
  }

  footer {
    padding: 0 15.5px 39px;
  }

  .footer {
    display: grid;
    grid-template-columns: 1fr;
    margin: 0;
  }

  .footer-img {
    margin: 0 auto;
    top: 0;
    height: 100px;
    width: 100%;
    order: -1;
  }

  .accordion-button {
    background-color: transparent !important;
  }

  .enlace p {
    text-align: center;
  }
}

@media screen and (max-width: 750px) {
  .fondo-cards {
    width: auto;
    height: auto;
    flex-wrap: wrap-reverse;
    padding: 25px 0;
  }

  .carta-dcha {
    margin-bottom: 25px;
  }
}

@media screen and (max-width: 480px) {

  .bg {
    position: static;
  }

  .foto-cabecera {
    background-image: url("/assets/img/cabecera-movil.png");
    height: 500px;
    top: 0;
  }

  .foto-cabecera p {
    font-size: 22px;
    padding-top: 246px;
    letter-spacing: 2px;
  }

  .heroe h2 {
    margin-top: 58px;
    font-size: 18px;
    line-height: 1.33;
  }

  .heroe p {
    font-size: 14px;
    line-height: 1.42;
  }

  .acordeon-bg {
    padding-bottom: 0;
  }

  .acordeon-img {
    height: 420px;
    width: 343px;
    margin: 0 auto;
  }

  .accordion {
    left: 0;
    width: 100%;
  }

  .accordion-button {
    font-size: 16px;
    line-height: 1.5;
  }

  .accordion-body {
    font-size: 14px;
    line-height: 1.42;
  }

  .playa {
    background-image: url("/assets/img/horizontal-movil.png");
    height: 263px;
    top: 0;
  }

  .anfitriones {
    padding: 20px;
    text-align: center;
  }

  .anfitriones h2 {
    font-family: var(--poppinsReg);
    font-size: 18px;
    line-height: 1.33;
    margin-bottom: 22px;
    margin-top: 31px;
  }

  .anfitriones p {
    font-size: 14px;
    line-height: 1.42;
  }

  .rectangulo {
    height: 465px;
    padding: 0;
  }

  .cajas {
    margin: 32px auto 16px;
  }

  .owl-dots {
    margin-top: 27px;
  }

  .caja {
    width: 263px;
    height: 416px;
  }

  .caja h2 {
    font-size: 16px;
    line-height: 1.37;
    margin: 22px 19px 16px;
  }

  .caja p {
    margin: 16px 19px;
  }

  .caja img {
    margin-top: 19px;
  }

  #acordeonContenido .derecha-grupo h2:first-child {
    margin-top: 0;
  }

  #acordeonContenido .derecha-grupo p:last-child {
    padding: 6px;
  }

  .carta-dcha,
  .carta-dcha-degradado,
  .carta-izq {
    width: 344px;
    height: auto;
    margin: 0;
    justify-content: center;
  }

  .carta-dcha {
    margin-bottom: 25px;
  }

  .tarifa-golden {
    font-size: 16px;
    line-height: 1.93;
    margin-top: 20px;
  }

  .tarifa p {
    font-size: 22px;
    line-height: 1.41;
  }

  .borde-golden,
  .borde {
    width: 108px;
    height: 27px;
    top: -32px;
  }

  .precio span:first-child {
    font-size: 30px;
  }

  .precio span:nth-child(2) {
    font-size: 22px;
    margin-left: 2px;
  }

  .precio span:last-child {
    font-size: 16px;
    margin-left: 12px;
  }

  .incluye h3,
  .incluye>div p {
    font-size: 14px;
  }

  .coste {
    font-family: var(--poppinsReg);
    font-size: 13px;
    margin-bottom: 42px;
  }

  .tarifa-basic {
    margin-top: 32px;
    font-size: 16px;
    line-height: 1.93;
  }

  /************** CONTACTO **************/

  .principal {
    margin-top: 44px;
  }

  .rellena>p {
    font-size: 14px;
    line-height: 1.42;
  }

  .hamburguesa {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 74px;
    height: 50px;
    background: var(--principal) 0% 0% no-repeat padding-box;
    border: 2px solid #FFFFFF;
    border-radius: 25px;
    opacity: 1;
    margin: 0 auto;
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 25;
    cursor: pointer;
  }
  
  .hamburguesa > i {
  	position: absolute;
  }

  .oculto {
    width: 75%;
    display: flex;
    visibility: hidden;
    flex-direction: column;
    align-items: center;
    background: var(--principal) 0% 0% no-repeat padding-box;
    border: 2px solid #FFFFFF;
    border-radius: 20px;
    margin: 0 auto;
    position: fixed;
    bottom: 100px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 25;
    padding: 35px 75px;
    gap: 10px;
	opacity: 0;
	transition: opacity 0.1s linear, visibility 0.1s linear;
  }

  .oculto a {
    color: var(--blanco);
    text-align: center;
    font-size: 14px;
    line-height: 2;
    font-family: var(--poppinsMed);
    text-decoration: none;
  }

  .oculto a:hover {
  	color: #ffffff;
  }
  
  .invisible {
	  visibility: hidden;
	  opacity: 1;
  }
  
  .visible {
	  visibility: visible;
	  opacity: 1;
  }
}

body#cms .contenedor {
  max-width: 1440px;
  margin: 0 auto;
}

body#cms .contenedor>h1 {
  color: #FF4E00;
  text-transform: uppercase;
  font-size: 20px;
}

body#cms .designers {
  display: flex;
  justify-content: space-between;
  margin-bottom: 19px;
}

body#cms .designs {
  display: flex;
  overflow: hidden;
  white-space: pre;
  position: relative;
}

body#cms .bio {
  text-align: center;
}

body#cms .bio {
  position: relative;
  max-width: 758px;
}

body#cms .bio img {
  border: 3px solid #FF4E00;
}

body#cms .bio .recuadro {
  width: 242px;
  height: 242px;
  background: #FF4E00 0% 0% no-repeat padding-box;
  opacity: 1;
  position: absolute;
  left: 0;
  right: 20px;
  top: 10px;
  margin: auto;
  z-index: -1;
}

body#cms .bio .recuadro.izq {
  left: 20px;
  right: 0;
}

body#cms .bio h2 {
  margin: 35px 0 42px;
  color: #FF4E00;
  text-transform: uppercase;
  font-size: 20px;
}

body#cms .bio p {
  font-size: 18px;
}

body#cms .bio a {
  text-decoration: none;
}

body#cms .mas {
  width: 42px;
  height: 42px;
  background: #FF4E00 0% 0% no-repeat padding-box;
  color: white;
  border-radius: 50px;
  font-size: 36px;
  line-height: 36px;
  margin: 0 auto;
}

body#cms .owl-dots {
  display: none;
}

body#cms .designs .owl-nav {
  position: absolute;
  width: 100%;
  display: flex;
  justify-content: space-between;
  top: 50%;
  padding: 0 20px;
}

body#cms .designs .owl-nav button {
  color: #FF4E00;
}

body#cms .designs .owl-nav button span {
  font-size: 100px;
  line-height: 0;
}

body#cms .occult {
  display: none !important;
}

@media screen and (max-width: 1450px) {
  body#cms .designers {
    flex-wrap: wrap-reverse;
  }

  body#cms .designers.izq {
    flex-wrap: wrap;
  }

  body#cms .designers .bio {
    margin: 0 auto;
  }

}

@media screen and (max-width: 768px) {
  body#cms .contenedor>h1 {
    padding: 20px;
  }

  body#cms .designers .bio {
    padding: 0 16px;
  }

  body#cms .bio h2 {
    font-size: 18px;
    margin: 33px 0 23px;
  }

  body#cms .bio p {
    font-size: 16px;
  }

  body#cms .designs .owl-nav button span {
    font-size: 60px;
  }

  body#cms .designs .owl-nav {
    padding: 0 25px;
  }
}

/* DEVOLUCIONES */

body#cms.cms-id-13 .head h1{
  font-size: 22px;
  font-weight: bold;
}
body#cms.cms-id-13 .head p{
  font-size: 15px;
}

body#cms.cms-id-13 .imagen {
  width: 558px;
  height: 603px;
  background-image: url("/assets/img/devol.png");
  background-repeat: no-repeat;
  background-origin: padding-box;
  background-position: center top;
  background-size: cover;
}

body#cms.cms-id-13 .guia {
  display: flex;
  justify-content: center;
}

body#cms.cms-id-13 .contenido {
  display: flex;
  max-width: 1100px;
  flex-wrap: wrap;
  column-gap: 85px;
  row-gap: 50px;
}

body#cms.cms-id-13 .bloque {
  display: flex;
  gap: 25px;
  max-width: 428px;
}

body#cms.cms-id-13 .numero {
  font-size: 69px;
  line-height: 0.7;
  position: relative;
  color: #3A8EFF;
}

body#cms.cms-id-13 .numero.uno::before {
  content: "1";
  color: #B7EAB9;
  position: absolute;
  z-index: -1;
  top: 4px;
  left: 4px;
}

body#cms.cms-id-13 .numero.dos::before {
  content: "2";
  color: #F4C6FF;
  position: absolute;
  z-index: -1;
  top: 4px;
  left: 4px;
}

body#cms.cms-id-13 .numero.tres::before {
  content: "3";
  color: #FFD5C6;
  position: absolute;
  z-index: -1;
  top: 4px;
  left: 4px;
}

body#cms.cms-id-13 .numero.cuatro::before {
  content: "4";
  color: #FCEFC6;
  position: absolute;
  z-index: -1;
  top: 4px;
  left: 4px;
}

body#cms.cms-id-13 .texto {
  max-width: 370px;
}

body#cms.cms-id-13 .texto h2 {
  font-size: 24px;
  color: #2BAAFF;
}

body#cms.cms-id-13 .texto p {
  font-size: 15px;
}

body#cms.cms-id-13 .texto.cuatro {
  position: relative;
}

body#cms.cms-id-13 p.listo {
  position: absolute;
  bottom: 0;
  font-size: 24px;
  color: #2BAAFF;
}

body#cms.cms-id-13 .nota {
  background: #F7F7F7 0% 0% no-repeat padding-box;
  border-radius: 8px;
  padding: 24px;
  ;
  color: #808080;
  margin: 0;
}

body#cms.cms-id-13 .faqs {
  background: #FAFAFA 0% 0% no-repeat padding-box;
  padding-top: 45px;
  margin-top: 103px;
}

body#cms.cms-id-13 .faqs>h1 {
  font-size: 22px;
  text-decoration: underline;
  font-weight: bold;
  /* margin-bottom: 40px; */
}

body#cms.cms-id-13 .faqs>h2 {
  font-size: 18px;
  text-transform: capitalize;
  display: inline-block;
  padding: 10px 7px 5px 7px;
  margin-top: 48px;
}

body#cms.cms-id-13 .faqs .uno {
  margin-top: 40px;
  background-color: #B7EAB9;
}

body#cms.cms-id-13 .faqs .dos {
  background-color: #F4C6FF;
}

body#cms.cms-id-13 .faqs .tres {
  background-color: #FFD5C6;
}

body#cms.cms-id-13 .faqs .cuatro {
  background-color: #FCEFC6;
}

body#cms.cms-id-13 .faqs .cinco {
  background-color: #C8C6FC;
}

body#cms.cms-id-13 .faqs p,
body#cms.cms-id-13 .faqs li{
  font-size: 15px;
  color: #808080;
  max-width: 1070px;
  margin-bottom: 10px;
}

.footer a {
	text-decoration: none;
}

.footer a:hover {
	text-shadow: 0px 0px 1px black;
}


@media screen and (max-width: 1670px) {
  body#cms.cms-id-13 .guia{
    flex-wrap: wrap-reverse;
  }
  body#cms.cms-id-13 .contenido{
    padding-top: 40px;
    justify-content: center;
    margin: 0 32px;
  }
}

@media screen and (max-width: 1004px) {
  body#cms.cms-id-13 p.listo{
    position: unset;
    font-size: 20px;
  }
}

@media screen and (max-width: 768px) {
  body#cms.cms-id-13 .bloque {
    display: block;
  }

  body#cms.cms-id-13 .texto {
    margin-top: 20px;
  }

  body#cms.cms-id-13 .texto h2{
    font-size: 20px;
  }

  body#cms.cms-id-13 .texto p{
    font-size: 14px;
  }
  body#cms.cms-id-13 p.listo{
    font-size: 20px;
    margin: 56px 0;
  }

  body#cms.cms-id-13 .head {
    margin: 38px 32px 50px;
  }

  body#cms.cms-id-13 .faqs{
    padding: 32px 32px 75px;
    margin: 0;
  }

  body#cms.cms-id-13 .faqs>h2 {
    /* display: inline; */
    font-size: 16px;
  }

  body#cms.cms-id-13 .faqs p,
  body#cms.cms-id-13 .faqs li{
    font-size: 14px;
  }

  body#cms.cms-id-13 .faqs ol {
    list-style-position: inside;
    padding: 0;
  }
}