@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&display=swap');

:root {

  --color-brand-1: #f9bb9a;
  --color-brand-2: #DF220F; /*--- pri button ---*/
  --color-brand-3: #DF220F; /*--- headline ---*/
  --color-brand-4: #01012d; /*--- text ---*/
  --color-brand-5: #F4F0DB; /*--- background ---*/
  --color-brand-6: #fde3da; /*--- text (hover) ---*/
  --color-brand-7: #ffffff; /*--- button (hover) ---*/
  --color-brand-8: #FDE3DA; /*--- background-2 ---*/
  --brand-color-text: #DF220F; /*--- text ---*/

  --color-black: #000000;
  --color-white: #ffffff;
  --color-white-opacity: rgba(255,255,255,0.1);

  --branding-default: var(--color-brand-1);
  --branding-hovered: var(--color-brand-2);
  --branding-pressed: var(--color-brand-4);

  --border-hovered: var(--color-brand-2);
  --background-hovered: var(--color-brand-2);
  --base-featured: var(--color-brand-4);
  
  --border-radius-default: 0;
  --border-radius-1x: 0;
  --border-radius-2x: 0;
  --border-radius-3x: 0;
  --border-radius-05x: 0;
  --border-radius-button: 100px;
  --border-default: 1px solid var(--color-brand-1);
  --border-brand-2: 1px solid var(--color-brand-2);
  --border-brand-3: 1px solid var(--color-brand-3);
  --border-white: 1px solid var(--color-white);
  --border-white-opacity: 1px solid var(--color-white-opacity);
  --border-black: 1px solid var(--color-black);
  --border-black-opacity: 1px solid var(--color-black-opacity);

  --font-family-1: "Outfit", sans-serif;
  --font-family-2: "Lusitana", serif;

  --font-size-body: 16px;
  --font-size-20: 20px;
  --font-size-22: 22px;

  --container-max-width: 1200px;

  --box-shadow-btn: 0 6px 12px rgba(0, 0, 0, .1);
  --box-shadow-btn-2: 0 0 10px rgba(0, 0, 0, 0.15);
  --box-shadow-header: 0 7px 24px rgba(0, 0, 0, .06);

  --box-shadow-default: 0px 1px 20px -12px var(--color-brand-1);

  --box-shadow-pre-hover-brand-2: inset 0px 0px 0 0 var(--color-brand-2);
  --box-shadow-hover-brand-2-top: inset 0px 200px 0 0 var(--color-brand-2);

  /*--background-arrow-brand-1: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40 33.28"><path class="cls-1" d="M39.36,15.08L24.92.64c-.41-.41-.96-.64-1.55-.64s-1.14.23-1.55.64l-1.31,1.31c-.41.41-.64.96-.64,1.55s.23,1.15.64,1.57l8.43,8.45H2.16c-1.21,0-2.16.95-2.16,2.15v1.85c0,1.21.95,2.25,2.16,2.25h26.87l-8.52,8.49c-.41.41-.64.95-.64,1.53s.23,1.13.64,1.54l1.31,1.31c.41.41.96.64,1.55.64s1.14-.23,1.55-.64l14.45-14.45c.41-.41.64-.97.64-1.55,0-.59-.23-1.14-.64-1.55Z" fill="teal"/></svg>');
  --background-arrow-brand-2: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40 33.28"><path class="cls-1" d="M39.36,15.08L24.92.64c-.41-.41-.96-.64-1.55-.64s-1.14.23-1.55.64l-1.31,1.31c-.41.41-.64.96-.64,1.55s.23,1.15.64,1.57l8.43,8.45H2.16c-1.21,0-2.16.95-2.16,2.15v1.85c0,1.21.95,2.25,2.16,2.25h26.87l-8.52,8.49c-.41.41-.64.95-.64,1.53s.23,1.13.64,1.54l1.31,1.31c.41.41.96.64,1.55.64s1.14-.23,1.55-.64l14.45-14.45c.41-.41.64-.97.64-1.55,0-.59-.23-1.14-.64-1.55Z" fill="burlywood"/></svg>');
  --background-arrow-white: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40 33.28"><path class="cls-1" d="M39.36,15.08L24.92.64c-.41-.41-.96-.64-1.55-.64s-1.14.23-1.55.64l-1.31,1.31c-.41.41-.64.96-.64,1.55s.23,1.15.64,1.57l8.43,8.45H2.16c-1.21,0-2.16.95-2.16,2.15v1.85c0,1.21.95,2.25,2.16,2.25h26.87l-8.52,8.49c-.41.41-.64.95-.64,1.53s.23,1.13.64,1.54l1.31,1.31c.41.41.96.64,1.55.64s1.14-.23,1.55-.64l14.45-14.45c.41-.41.64-.97.64-1.55,0-.59-.23-1.14-.64-1.55Z" fill="white"/></svg>');
  */

  --transition-default: all 0.5s ease; 
  
  --img-ratio-rate-primary: 4 / 3;
  --img-ratio-rate-primary-mobile: 4 / 3;
  --img-ratio-rate-secondary: 4 / 3;
  --img-ratio-rate-secondary-mobile: 4 / 3;
  --img-ratio-mda-secondary-rate: 4 / 3;
  --img-ratio-mda-secondary-rate-mobile: 4 / 3;
}

@media screen and (max-width: 499px) {

  :root {
    --font-size-body: 14px;
    --font-size-20: 18px;
    --font-size-22: 20px;
    --container-max-width: 100vw;
  }

}

@media screen {
  
  .header a i,
  .backtotop a i,
  .footer a i {
    margin-right: 0px;
  }
  
  body {
    background-color: var(--color-brand-5);
    font-family: var(--font-family-2);
    font-size: var(--font-size-body);
    margin: 0;
    padding: 0;
  }

  .avvio-calendar-container,
  .avvio-calendar__month {
    border-radius: var(--border-default)!important;
  }

  .input-container {
    font-family: var(--font-family-2);
  }

  .input {
    border-radius: var(--border-radius-button);
    padding-left: 20px;
  }

  .placeholder {
    left: 20px;
  }

  .avvioCalendarFragment .label {
    min-width: 50%;
    color: var(--color-brand-3);
  }

  button.date.avvio-calendar__date.today.available,
  button.date.avvio-calendar__date.available {
    border-radius: 10px;
  }

  button.date.avvio-calendar__date.available.check-in {
    background: var(--color-brand-2);
  }

  button.date.avvio-calendar__date.available.check-out {
    background: var(--color-brand-7);
    color: var(--color-black);
  }

  button.date.avvio-calendar__date.available.range,
  .avvio-calendar .hovered {
    border-radius: 10px;
    color: var(--color-black);
    background: var(--color-brand-5);
  }

  .avvio-calendar .hovered:hover::before, .avvio-calendar .check-out::before {
    background: var(--color-brand-1);
  }

  /* ------- button ------- */

  .button--primary {
    color: var(--color-brand-2);
    border-color: var(--color-brand-2);
  }
  
  .button--primary:hover {
    color: var(--color-white);
  }

  .button-card-horizontal.selected, 
  .button-card-horizontal:focus, 
  .slect.selected {
    border-color: var(--color-brand-2);
  }

  .navigation .button--primary:hover {
    color: var(--color-brand-2);
  }

  .avvio-calendar__date,
  .button, 
  .button--secondary,
  .button--branded {
    transition: var(--transition-default);
    border-radius: var(--border-radius-button);
  }

  .avvioCalendarFragment .prev-btn {
    left: -72px;
  }

  .avvioCalendarFragment .next-btn {
    right: -72px;
  }

  .button--branded {
    margin-top: 20px;
    background-color: var(--color-brand-3);
    color: var(--color-white);
    border: 1px solid var(--color-brand-2);
    padding: 15px 30px;
    border-radius: 300px;
    cursor: pointer;
    font-weight: 600;
    transition: var(--transition-default);
  }

  .button--branded:hover {
    background-color: var(--color-white);
    color: var(--color-brand-2)!important;
    border: 1px solid var(--color-brand-2);
  }

  .mda-table__total-cta.padding-top-1x.padding-bottom-1x.flex.flex-col.justify-end.items-end.flex-wrap {
    margin-right: 10px; 
  }

  .button--branded.calendarConfirmBtn .button__text,
  .button--branded.button--medium.book-now-button .button__text {
    font-size: 16px;
    text-transform: uppercase;
  }

  .mda-table tr td {
    border: 1px solid #cbcbcb;
  }

  #control-area-links .button.button--plain.button--primary {
    position: relative;
  }

  #control-area-links .button.button--plain.button--primary:hover {
    color: var(--color-brand-1);
  }

  #control-area-links .button.button--plain.button--primary::before {
    position: absolute;
    content: '';
    left: 0;
    bottom: 10px;
    width: 0;
    height: 1px;
    background-color: var(--color-brand-2);
    transition: var(--transition-default);
  }

  #control-area-links .button.button--plain.button--primary:hover::before {
    width: 100%;
  }

  .button-icon {
    padding: 8px!important;
  }

  .button-icon .button-icon__icon {
    width: 100%!important;
    height: 100%!important;
    background-color: transparent!important;
    color: var(--color-brand-2)!important;
    border: solid 1px var(--color-brand-2)!important;
    border-radius: var(--border-radius-button)!important;
    transition: var(--transition-default);
  }

  .button-icon:hover .button-icon__icon {
    color: var(--color-white)!important;
    background-color: var(--color-brand-2)!important;
    border: solid 1px var(--color-brand-2)!important;
  }

  .button-icon.inactive .button-icon__icon,
  .button-icon:disabled .button-icon__icon {
    background-color: transparent!important;
    color: var(--color-grey-5, #9e9e9e)!important;
    border: solid 1px var(--color-grey-3, #bdbdbd)!important;
    cursor: not-allowed;
    pointer-events: none;
    opacity: 0.7;
  }

  .avvio-modal__bottom .button--secondary:hover,
  button.button--medium.book-now-button:hover,
  button.addRoomButton:hover,
  .sendBasketTrigger:hover {
    color: var(--color-white);
  }

  .APPButtonDiv {
    border-radius: var(--border-radius-button);
  }

}
  
/*-------------- Header ----------------*/

.header {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 80px;
  padding: 30px 0;
  background-color: var(--color-white);
  box-shadow: var(--box-shadow-default);
  padding-block: 0px;
  z-index: 999;
}

.main-be-area {
  background: none;
}

.full-ribbon-one {
  box-shadow: var(--box-shadow-default);
  z-index: 1;
}

.avvio-incentives__item {
  border-radius: 5px;
}

.policy-link-container a {
  color: var(--color-brand-2);
}

button.button--secondary.modal-promo-code__skip {
  color: #585862;
  border-color: #8c9196;
  background-color: transparent;
}

button.button--secondary.modal-promo-code__skip:hover {
  color: var(--color-white);
  border-color: var(--color-brand-2);
  background-color: var(--color-brand-2);
}

.header .logo {
  display: flex;
  justify-content: center;
  align-items: center;
}

.header .logo a {
  width: auto;
  height: 29px;
}

.header .logo a img {
  display: inline-block;
  width: 100%;
  height: 100%;
  transition: var(--transition-default);
  object-fit: contain;
}

.header .logo a img:hover {
  opacity: 60%;
}

.header .backtosite {
  position: absolute;
  right: 35px;
}

.header .backtosite a,
.footer-newsletter a,
.sendBasketTrigger,
button.button--secondary.white-space-nowrap {
  font-family: var(--font-family-1);
  text-transform: uppercase;
  background-color: var(--color-brand-3);
  color: var(--color-white);
  border: 1px solid var(--color-brand-2);
  padding: 15px 30px;
  border-radius: 300px;
  cursor: pointer;
  font-weight: 600;
  transition: var(--transition-default);
}

.header .backtosite:hover a,
.footer-newsletter a:hover,
.sendBasketTrigger:hover,
button.button--secondary.white-space-nowrap:hover {
  background-color: var(--color-white);
  color: var(--color-brand-2);
}

h1, h2, h3, h4, h5, h6,
.header1, .header2, .header3, .header4, .header5, .header6,
.heading-1, .heading-2, .heading-3, .heading-4, .heading-5, .heading-6 {
  font-family: var(--font-family-1);
}

#details button:hover,
#ipulse .privacy-policy-container a:hover {
  color: var(--color-brand-1);
}

#ipulse .privacy-policy-container a {
  transition: var(--transition-default);
}

/*-------------- Footer ----------------*/

.footer {
  font-family: "Outfit", sans-serif;
  background-color: var(--color-brand-1);
}

.footer-container {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.footer-container-1 {
  display: flex;
  justify-content: space-between;
}

.footer-container-2 {
  background-color: var(--color-brand-2);
  display: flex;
  justify-content: center;
  color: var(--color-white);
}

.footer-credit {
  color: var(--color-white);
}

.footer-credit a {
  color: var(--color-white);
  position: relative;
}

.footer-credit a::before {
  position: absolute;
  content: '';
  left: 0;
  bottom: -2px;
  width: 0;
  height: 1px;
  background-color: var(--color-white);
  transition: var(--transition-default);
}

.footer-credit a:hover::before {
  width: 100%;
}

/* LEFT SECTION */
.footer-left {
  background-color: var(--color-brand-1);
  min-width: 250px;
  padding: 70px 30px;
}

.footer-logo {
  color: var(--color-brand-3);
  font-size: 32px;
  margin-bottom: 20px;
}

.footer-left .logo a {
  display: inline-block;
  width: 180px;
  height: auto;
}

.footer-left .logo a img {
  width: 100%;
  height: auto;
  transition: var(--transition-default);
}

.footer-left .logo a img:hover {
  opacity: 60%;
}

.footer-illustration {
  width: 100%;
  margin-top: 30px;
}

.footer-socials {
  display: flex;
  margin-top: 30px;
}

.footer-socials a {
  color: var(--color-black);
  margin-right: 15px;
  font-size: 20px;
  text-decoration: none;
  transition: var(--transition-default);
}

.footer-socials a:hover {
  color: var(--color-brand-3);
}

.fa-brands, .fab {
  font-size: 24px;
}

.footer-copy {
  font-size: 14px;
  color: var(--color-black);
  margin-top: 30px;
}

/* MIDDLE LINKS */
.footer-links {
  background-color: var(--color-brand-1);
  display: flex;
  padding: 70px 30px;
  gap: 40px;
  color: var(--color-black);
}

.footer-column {
  min-width: 150px;
  text-align: left;
}

.footer-column h4 {
  font-weight: 600;
  margin: 0;
  margin-bottom: 10px;
}

.footer-column p,
.footer-column a {
  font-size: 14px;
  color: var(--color-black);
  text-decoration: none;
  margin-bottom: 8px;
  display: block;
}

.footer-column ul {
  list-style: none;
  padding: 0;
}

.footer-column ul li {
  margin-bottom: 5px;
}

.footer-column ul li a:hover {
  color: var(--color-brand-3);
}

.footer-address {
  margin-bottom: 50px;
}

.footer-contact a {
  transition: var(--transition-default);
}

.footer-contact a:hover {
  text-decoration: underline;
  color: var(--color-brand-3);
}

/* NEWSLETTER */
.footer-newsletter {
  background-color: var(--color-brand-8);
  padding: 70px 50px;
  text-align: left;
}

.footer-newsletter h3 {
  color: var(--color-brand-3);
  font-size: 28px;
  font-weight: 400;
  margin: 0;
}

.footer-newsletter p {
  color: var(--color-black);
  font-size: 14px;
  margin-top: 10px;
  padding-bottom: 30px;
  font-weight: 300;
}

.footer-design {
  font-size: 14px;
  margin-top: 40px;
}

/* ---------------- Responsive ---------------- */

/* Tablet: up to 900px */
@media (max-width: 900px) {

  .footer-container-1 {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .footer-left {
    padding: 50px 20px;
  }

  .footer-links {
    flex-wrap: wrap;
    justify-content: center;
    padding: 50px 20px;
    gap: 30px;
  }

  .footer-column {
    min-width: 200px;
    text-align: center;
  }

  .footer-newsletter {
    padding: 50px 30px;
    text-align: center;
  }

  .footer-newsletter h3 {
    font-size: 24px;
  }

  .footer-newsletter p {
    font-size: 13px;
  }

  .footer-illustration {
    margin: 20px auto;
  }

  .footer-socials {
    justify-content: center;
  }
  
}

/* Tablet portrait: up to 767px */
@media (max-width: 767px) {
  
}

/* Small tablets / big phones: up to 745px */
@media (max-width: 745px) {

}

/* Mobile: up to 499px */
@media (max-width: 499px) {

}

/* Small Mobile: up to 450px */
@media (max-width: 450px) {
  
  .footer-left {
    padding: 40px 15px;
  }

  .footer-logo {
    font-size: 24px;
  }

  .footer-links {
    flex-direction: column;
    align-items: center;
    padding: 40px 15px;
    gap: 20px;
  }

  .footer-column {
    min-width: unset;
    width: 100%;
    text-align: center;
  }

  .footer-column h4 {
    font-size: 16px;
  }

  .footer-column a,
  .footer-column p {
    font-size: 13px;
  }

  .footer-newsletter {
    padding: 40px 20px;
  }

  .footer-newsletter h3 {
    font-size: 20px;
  }

  .footer-newsletter p {
    font-size: 12px;
  }

  .footer-socials a {
    font-size: 18px;
    margin-right: 10px;
  }

  .footer-credit {
    font-size: 12px;
    text-align: center;
    padding: 10px 0;
  }

  .footer-copy {
    font-size: 12px;
    margin-top: 20px;
  }

}