/*
  1. Use a more-intuitive box-sizing model.
*/
*,
*::before,
*::after {
  box-sizing: border-box;
}

/*
    2. Remove default margin
  */
* {
  margin: 0;
}

/*
    3. Allow percentage-based heights in the application
  */
html,
body {
  height: 100%;
}

/*
    Typographic tweaks!
    4. Add accessible line-height
    5. Improve text rendering
  */
body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/*
    6. Improve media defaults
  */
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

/*
    7. Remove built-in form typography styles
  */
input,
button,
textarea,
select {
  font: inherit;
}

/*
    8. Avoid text overflows
  */
p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

/*
    9. Create a root stacking context
  */
#root,
#__next {
  isolation: isolate;
}

body {
  font-family: "League Spartan", sans-serif;
  font-size: 1rem;
}

.fade-out {
  opacity: 0;
  transition: opacity 1s cubic-bezier(0.075, 0.82, 0.165, 1);
}

.fade-in {
  opacity: 1;
}

.text-normal {
  font-size: 1rem;
  font-weight: 400;
  color: hsla(0deg, 0%, 30%, 0.5);
}

.text-pop {
  font-size: 1.25rem;
  font-weight: 700;
  color: hsl(0deg, 0%, 30%);
}

.displayNone {
  display: none;
}

.hero {
  position: relative;
  overflow-x: hidden;
}

.hero__img {
  max-width: 90em;
  min-width: 23.4375em;
}
.hero__img img {
  width: 100%;
  object-fit: cover;
}

.hero__content {
  position: absolute;
  color: hsl(0deg, 0%, 100%);
  top: 30.6%;
  height: min-content;
  display: flex;
  flex-direction: column;
  gap: 2.375em;
  width: 87.2%;
  left: 6.68%;
}

.hero__content__logo {
  display: flex;
  justify-content: center;
}
.hero__content__logo img {
  width: 5.15em;
  height: 2em;
}

.hero__content__description {
  display: flex;
  flex-direction: column;
  text-align: center;
  align-items: center;
  justify-content: center;
}

.hero__content__description__title {
  font-size: 2rem;
  font-weight: 300;
  line-height: 1;
}

.hero__content__description__para {
  font-size: 1rem;
  font-weight: 400;
  margin-top: 1.3125em;
  margin-bottom: 3.3125em;
  line-height: 26px;
}

.hero__content__description__button {
  text-transform: uppercase;
  background-color: transparent;
  color: hsl(0deg, 0%, 100%);
  border-style: none;
  border: 1px solid hsl(0deg, 0%, 100%);
  font-size: 1.063rem;
  font-weight: 600;
  width: 14.4117647059em;
  height: 3.7647058824em;
  padding: 1.4705882353em 3.1764705882em;
  cursor: pointer;
}
.hero__content__description__button:hover {
  background-color: hsl(0deg, 0%, 100%);
  color: hsl(0deg, 0%, 7%);
}

@media screen and (min-width: 42.37em) {
  .hero__content__logo img {
    width: 6.4375em;
    height: 2.5em;
  }
  .hero__content {
    top: 37.8%;
  }
  .hero__content__description__title {
    font-size: 3rem;
  }
  .hero__content__description__para {
    font-size: 1.25rem;
    line-height: 1.5;
  }
}
@media screen and (min-width: 64em) {
  .hero__content {
    max-width: 507px;
    gap: 10vw;
    left: 11.45%;
    top: 8%;
  }
  .hero__content__logo {
    justify-content: start;
  }
  .hero__content__description {
    align-items: flex-start;
    text-align: left;
  }
  .hero__content__description__title {
    font-size: 5rem;
    line-height: 1;
  }
  .hero__content__description__para {
    line-height: 1.5;
    margin-top: 0.5em;
    margin-bottom: 2em;
  }
}
.main {
  position: relative;
  height: 90.875em;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (min-width: 42.37em) {
  .main {
    height: 93.125em;
  }
}
@media screen and (min-width: 64em) {
  .main {
    height: 88.1875em;
  }
}
.main .main__pattern {
  position: absolute;
  display: none;
}
.main .main__pattern--curve-top-right {
  bottom: 0;
  left: 30%;
}
@media screen and (min-width: 64em) {
  .main .main__pattern--curve-top-right {
    left: 38%;
  }
}
.main .main__pattern--curve-bottom-left {
  right: 30%;
  top: 10%;
}
@media screen and (min-width: 64em) {
  .main .main__pattern--curve-bottom-left {
    left: 0;
  }
}
@media screen and (min-width: 42.37em) {
  .main .main__pattern {
    display: block;
  }
}
.main .main__block {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 87.2%;
  text-align: center;
  gap: 3em;
}
.main .main__block--top__img, .main .main__block--bottom__img {
  -webkit-box-shadow: 10px 10px 43px 0px rgba(0, 0, 0, 0.31);
  -moz-box-shadow: 10px 10px 43px 0px rgba(0, 0, 0, 0.31);
  box-shadow: 10px 10px 43px 0px rgba(0, 0, 0, 0.31);
}
@media screen and (min-width: 42.37em) {
  .main .main__block {
    width: 35.8125em;
  }
}
@media screen and (min-width: 64em) {
  .main .main__block {
    flex-direction: row;
    width: 80%;
    height: 45em;
    gap: 7.8125em;
  }
}
.main .main__block--top {
  position: absolute;
  top: -5.15%;
  left: 0;
  right: 0;
  margin-inline: auto;
}
@media screen and (min-width: 64em) {
  .main .main__block--top__description {
    width: 454px;
    height: 275px;
    text-align: left;
  }
}
.main .main__block--top__description__pattern {
  display: flex;
  justify-content: center;
}
@media screen and (min-width: 64em) {
  .main .main__block--top__description__pattern {
    justify-content: flex-start;
  }
}
.main .main__block--top__description__title {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  margin-top: 1.125em;
  margin-bottom: 0.40625em;
}
@media screen and (min-width: 42.37em) {
  .main .main__block--top__description__title {
    font-size: 3rem;
  }
}
.main .main__block--top__description__para {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.625;
}
@media screen and (min-width: 42.37em) {
  .main .main__block--top__description__para {
    font-size: 1.25rem;
  }
}
.main .main__block--bottom {
  padding-top: 43.1875em;
}
@media screen and (min-width: 64em) {
  .main .main__block--bottom__description {
    width: 454px;
    height: 275px;
    text-align: left;
  }
}
.main .main__block--bottom__description__pattern {
  display: flex;
  justify-content: center;
}
@media screen and (min-width: 64em) {
  .main .main__block--bottom__description__pattern {
    justify-content: flex-start;
  }
}
.main .main__block--bottom__description__title {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  margin-top: 1.125em;
  margin-bottom: 0.40625em;
}
@media screen and (min-width: 42.37em) {
  .main .main__block--bottom__description__title {
    font-size: 3rem;
  }
}
.main .main__block--bottom__description__para {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.625;
}
@media screen and (min-width: 42.37em) {
  .main .main__block--bottom__description__para {
    font-size: 1.25rem;
  }
}
@media screen and (min-width: 42.37em) {
  .main .main__block--bottom {
    padding-top: 43.5625em;
  }
}
@media screen and (min-width: 64em) {
  .main .main__block--bottom {
    flex-direction: row-reverse;
    position: absolute;
    padding: 0;
    bottom: -71px;
  }
}

.highlights {
  background-color: hsl(0deg, 0%, 7%);
  color: hsl(0deg, 0%, 100%);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5.3125em;
  padding-inline: 1.5em;
  padding-block: 4.5em;
}
@media screen and (min-width: 64em) {
  .highlights {
    flex-direction: row;
    padding-inline: 10.3125em;
    padding-block: 12.5em;
    align-items: flex-start;
  }
}
.highlights__main {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2.25em;
  text-align: center;
}
.highlights__main__pattern {
  display: flex;
  justify-content: flex-start;
}
.highlights__main__title {
  font-weight: 700;
  font-size: clamp(2rem, 1.6479rem + 1.5023vw, 3rem);
}
.highlights__main__para {
  font-size: clamp(1rem, 0.912rem + 0.3756vw, 1.25rem);
  font-weight: 400;
}
@media screen and (min-width: 64em) {
  .highlights__main {
    text-align: left;
    align-items: flex-start;
    width: 445px;
  }
}
.highlights__item__block {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2.25em;
  text-align: center;
  border-bottom: 0.5px solid hsla(0deg, 0%, 30%, 0.5);
}
.highlights__item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2.25em;
  text-align: center;
  border-bottom: 0.5px solid hsla(0deg, 0%, 30%, 0.5);
}
@media screen and (min-width: 42.37em) {
  .highlights__item {
    flex-direction: row;
    padding-bottom: 1.5em;
  }
}
.highlights__item__img {
  max-width: 126px;
}
.highlights__item__img picture {
  width: 128px;
}
@media screen and (min-width: 42.37em) {
  .highlights__item__description {
    text-align: left;
  }
}
.highlights__item__description > :not(:last-child) {
  margin-bottom: 0.375em;
}
@media screen and (min-width: 42.37em) {
  .highlights__item__description > :not(:last-child) {
    margin-bottom: 0;
  }
}
.highlights__item__description__title {
  font-size: 1.25rem;
  font-weight: 700;
}
.highlights__item__description__para {
  font-size: clamp(1rem, 0.912rem + 0.3756vw, 1.25rem);
  font-weight: 400;
  margin-bottom: 3.5em;
}
@media screen and (min-width: 42.37em) {
  .highlights__item__description__para {
    margin-bottom: 0;
  }
}

.slider {
  padding-inline: 1.5em;
  padding-block: 5em;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 3.0625em;
}
@media screen and (min-width: 64em) {
  .slider {
    flex-direction: row;
    padding-block: 10em;
    gap: 7.8125em;
    max-height: 920px;
  }
}
.slider__img {
  position: relative;
  -webkit-box-shadow: 10px 10px 43px 0px rgba(0, 0, 0, 0.31);
  -moz-box-shadow: 10px 10px 43px 0px rgba(0, 0, 0, 0.31);
  box-shadow: 10px 10px 43px 0px rgba(0, 0, 0, 0.31);
}
.slider__img__pattern {
  position: absolute;
  display: none;
}
@media screen and (min-width: 42.37em) {
  .slider__img__pattern {
    display: block;
    top: -10%;
    left: -10%;
  }
}
.slider__content {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 1.6875em;
}
@media screen and (min-width: 64em) {
  .slider__content {
    flex-direction: column-reverse;
    max-width: 445px;
    gap: 4.9375em;
  }
}
.slider__content__headline {
  color: hsla(0deg, 0%, 30%, 0.5);
}
@media screen and (min-width: 42.37em) {
  .slider__content__headline {
    display: flex;
    justify-content: space-around;
  }
}
@media screen and (min-width: 64em) {
  .slider__content__headline {
    flex-direction: column;
    align-items: flex-start;
  }
}
.slider__content__description {
  display: flex;
  flex-direction: column;
  gap: 0.8125em;
  align-items: center;
}
@media screen and (min-width: 64em) {
  .slider__content__description {
    text-align: left;
    align-items: flex-start;
  }
}
.slider__content__description__title {
  font-size: clamp(2rem, 1.6479rem + 1.5023vw, 3rem);
  font-weight: 700;
}
.slider__content__description__para {
  font-size: clamp(1rem, 0.912rem + 0.3756vw, 1.25rem);
  font-weight: 400;
}
@media screen and (min-width: 64em) {
  .slider__content__description__para {
    margin-bottom: 3.75em;
  }
}
.slider__content__description__button {
  width: 15.875em;
  height: 4em;
  font-weight: 700;
  text-transform: uppercase;
  background-color: hsl(0deg, 0%, 7%);
  color: hsl(0deg, 0%, 100%);
}
.slider__content__description__button:hover {
  background-color: hsl(0deg, 0%, 100%);
  color: hsl(0deg, 0%, 7%);
  cursor: pointer;
}

.footer {
  max-height: 768px;
}
.footer__booking {
  position: relative;
}
.footer__booking__img img {
  width: 100%;
  max-height: 328px;
  object-fit: cover;
}
.footer__booking__content {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1.25em;
  text-align: center;
  margin-inline: auto;
}
@media screen and (min-width: 64em) {
  .footer__booking__content {
    flex-direction: row;
    justify-content: space-around;
  }
}
.footer__booking__content__title {
  color: hsl(0deg, 0%, 100%);
  font-weight: 700;
  font-size: clamp(2rem, 1.6479rem + 1.5023vw, 3rem);
}
.footer__booking__content__button {
  width: 15.875em;
  height: 4em;
  font-weight: 700;
  text-transform: uppercase;
  background-color: hsl(0deg, 0%, 7%);
  color: hsl(0deg, 0%, 100%);
  background-color: transparent;
  border-color: hsl(0deg, 0%, 100%);
}
.footer__booking__content__button:hover {
  background-color: hsl(0deg, 0%, 100%);
  color: hsl(0deg, 0%, 7%);
  cursor: pointer;
}
.footer__about {
  background-color: hsl(0deg, 0%, 7%);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2.625em;
  padding-block: 5em;
  padding-inline: 1.5em;
}
@media screen and (min-width: 42.37em) {
  .footer__about {
    flex-direction: row;
    justify-content: space-between;
    padding-inline: 2.5em;
    gap: 8.0625em;
  }
}
.footer__about__content {
  display: flex;
  flex-direction: column;
  text-align: center;
  gap: 2.625em;
  color: hsl(0deg, 0%, 100%);
  font-size: 0.875rem;
  font-weight: 400;
  flex-grow: 1;
}
@media screen and (min-width: 42.37em) {
  .footer__about__content {
    text-align: left;
  }
}
@media screen and (min-width: 64em) {
  .footer__about__content {
    flex-direction: row;
    justify-content: space-between;
  }
}

/*# sourceMappingURL=styles.css.map */
