/*
MARK: VARS
*/

:root {
  --black: hsl(179deg 40% 3%);
  --black-5: hsl(from var(--black) h s l / 5%);
  --black-10: hsl(from var(--black) h s l / 10%);
  --black-20: hsl(from var(--black) h s l / 20%);
  --black-50: hsl(from var(--black) h s l / 50%);
  --brown: hsl(347deg 6% 23%);

  --sand: hsl(30deg 29% 66%);
  --sand-50: hsl(from var(--sand) h s l / 50%);
  --lightsand: hsl(27deg 20% 73%);
  --lightersand: hsl(27deg 30% 83%);
  --darksand: hsl(31deg 18% 53%);
  --darkersand: hsl(32deg 18% 45%);
  --richsand: hsl(44deg 75% 88%);
  --richsand-50: hsl(from var(--richsand) h s l / 50%);
  --richsand-80: hsl(from var(--richsand) h s l / 80%);
  --richdarksand: hsl(44deg 75% 78%);
  --richdarksand-50: hsl(from var(--richdarksand) h s l / 50%);
  --richdarksand-80: hsl(from var(--richdarksand) h s l / 80%);

  --beige: hsl(10deg 24% 91%);
  --lightbeige: hsl(359deg 21% 95%);
  --lightbeige-50: hsl(from var(--lightbeige) h s l / 50%);
  --lightbeige-80: hsl(from var(--lightbeige) h s l / 80%);
  --darkbeige: hsl(10deg 17% 85%);
  --darkbeige-50: hsl(from var(--darkbeige) h s l / 50%);

  --white: hsl(323deg 22% 97%);
  --white-5: hsl(from var(--white) h s l / 5%);
  --white-10: hsl(from var(--white) h s l / 10%);
  --white-20: hsl(from var(--white) h s l / 20%);
  --white-50: hsl(from var(--white) h s l / 50%);
  --white-80: hsl(from var(--white) h s l / 80%);
  --white-90: hsl(from var(--white) h s l / 90%);

  --purewhite: hsl(0deg 0% 99%);
  --purewhite-80: hsl(from var(--purewhite) h s l / 80%);
  --purewhite-50: hsl(from var(--purewhite) h s l / 50%);

  --pinegreen: hsl(183deg 54% 19%);
  --pinegreen-20: hsl(from var(--pinegreen) h s l / 20%);
  --pinegreen-40: hsl(from var(--pinegreen) h s l / 40%);
  --pinegreen-60: hsl(from var(--pinegreen) h s l / 60%);
  --pinegreen-80: hsl(from var(--pinegreen) h s l / 80%);
  --teal: hsl(187deg 44% 35%);
  --teal-20: hsl(from var(--teal) h s l / 20%);
  --teal-50: hsl(from var(--teal) h s l / 50%);
  --richteal: hsl(187deg 54% 48%);
  --richteal-20: hsl(from var(--richteal) h s l / 20%);
  --richteal-40: hsl(from var(--richteal) h s l / 40%);
  --richteal-60: hsl(from var(--richteal) h s l / 60%);
  --richteal-80: hsl(from var(--richteal) h s l / 80%);
  --lightteal: hsl(188deg 36% 62%);

  --sky: hsl(178deg 53% 94%);
  --richsky: hsl(38deg 66% 89%);
  --sun: hsl(28deg 71% 94%);
  --sunset: hsl(10deg, 98%, 65%);
  --sun1: hsl(41deg 99% 77%);
  --sun2: hsl(28deg 98% 61%);
  --roof: hsl(10deg 38% 53%);
  --roof-30: hsl(from var(--roof) h s l / 30%);
  --roof-50: hsl(from var(--roof) h s l / 50%);
  --roof-80: hsl(from var(--roof) h s l / 80%);
  --richroof: hsl(10deg 68% 53%);
  --richroof-50: hsl(from var(--richroof) h s l / 50%);
  --richroof-20: hsl(from var(--richroof) h s l / 20%);
  --darkroof: hsl(from var(--richroof) h 42% 39%);
  --darkerroof: hsl(from var(--richroof) h 32% 19%);
  --wood: hsl(31deg 59% 36%);

  --lightgreen: hsl(78deg 44% 95%);
  --richgreen: hsl(107deg 38% 85%);
  --richgreen-50: hsl(from var(--richgreen) h s l / 50%);

  --font: "Sora", Helvetica, sans-serif;
  --font-bold: "Sora", Helvetica, sans-serif;
  --font-serif: "Tenor Sans", Optima, serif;

  --normal: 1rem;
  --small: calc(var(--normal) * 0.8);
  --x-small: calc(var(--normal) * 0.6);
  --medium: calc(var(--normal) * 1.2);
  --mediumplus: calc(var(--normal) * 1.4);
  --large: calc(var(--normal) * 1.8);
  --x-large: calc(var(--normal) * 2.4);
}

@media (width < 1200px) {
  :root {
    --small: calc(var(--normal) * 0.8);
    --medium: calc(var(--normal) * 1.15);
    --large: calc(var(--normal) * 1.4);
    --x-large: calc(var(--normal) * 1.8);
  }
}

/*
MARK: FONTS
*/

@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 300;
  src: url('fonts/sora-v16-latin_latin-ext-300.woff2') format('woff2');
}

@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 700;
  src: url('fonts/sora-v16-latin_latin-ext-700.woff2') format('woff2');
}

@font-face {
  font-family: 'Tenor Sans';
  font-style: normal;
  font-weight: 400;
  src: url('fonts/tenor-sans-v20-latin_latin-ext-regular.woff2') format('woff2');
}

/* 
MARK: GENERAL
*/

* {
  box-sizing: border-box;
}

::selection {
  color: var(--white);
  background: var(--pinegreen);
}

body {
  font-family: var(--font);
  font-size: var(--normal);
  background-color: var(--white);
  color: var(--black);
  text-rendering: optimizeLegibility;
  font-variant-numeric: oldstyle-nums;
  font-variant-ligatures: common-ligatures;
  padding: 0;
  margin: 0;
}

a,
a:visited {
  color: var(--text);
}

a:hover {
  color: var(--text-60);
}

b,
strong {
  font-family: var(--font-bold);
  font-weight: 700;
}

em,
i {
  font-family: var(--font-bold);
  font-style: normal;
  font-weight: 700;
}

h2,
h3,
h4,
.title {
  font-family: var(--font-serif);
  font-size: var(--x-large);
  font-weight: 400;
  text-wrap: balance;
  color: var(--pinegreen);
  margin: 0 0 1rem 0;
  text-align: center;

  @media (width < 1024px) {
    margin: 0 0 .5rem 0;
  }

}

h3 {
  font-size: var(--large)
}

h4 {
  font-size: var(--medium)
}

p {
  hyphens: auto;
  hyphenate-limit-chars: auto 3 4;
  line-height: 130%;
}

.tight p {
  max-width: 80ch;
  margin: 0 auto 1rem;
  padding: 0 2rem;

  @media (width < 768px) {
    padding: 0 1rem;
  }
}

.center {
  text-align: center;
}

p.small {
  font-size: var(--small);
  opacity: .7;
}

#page {
  position: relative;
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  background-color: var(--beige);
  overflow: clip;

  @media (width > 1400px) {
    box-shadow: 0 0 4rem var(--black-20);
    outline: 1px solid var(--white);
  }
}

/*
MARK: BUTTON
*/

.btn,
.btn:visited {
  position: relative;
  display: inline-block;
  padding: 1rem 2rem;
  font-family: var(--font-serif);
  font-size: var(--medium);
  text-decoration: none;
  letter-spacing: 1px;
  color: var(--white);
  text-shadow: 1px 1px 3px var(--black-50),
    0 0 1rem var(--white-50);
  border-radius: 3rem;
  background-image: linear-gradient(var(--teal), var(--pinegreen));
  background-size: auto 100%;
  box-shadow: 0 0 0 var(--black-5),
    inset 0 0 0 var(--white),
    0 0 .5rem var(--teal-20),
    inset 1px 1px 1px var(--lightteal),
    inset -1px -1px 1px var(--black-20);
  transition: box-shadow 1s ease, scale 1s ease;
}

.btn:hover {
  color: var(--white);
  box-shadow: 0 0 .5rem var(--black-20),
    inset 0 0 4px var(--white),
    0 0 1rem var(--richteal-40),
    inset 1px 1px 1px var(--white),
    inset -1px -1px 1px var(--white);
  scale: .98;
}

.btn:active {
  scale: .94;
}

.btn::after {
  position: absolute;
  bottom: -10%;
  left: 10%;
  width: 80%;
  height: 50%;
  content: "";
  background: var(--white);
  mix-blend-mode: overlay;
  border-radius: 50%;
  z-index: -1;
  filter: blur(.5rem);
  opacity: 0;
  transition: opacity 1s ease;
}


.btn:hover::after {
  opacity: .8;
}

#hotel {
  text-align: left
}

.btn.sand {
  color: var(--brown);
  text-shadow: 1px 1px 3px var(--white-50), 0 0 1rem var(--white-50);
  background-image: linear-gradient(var(--white-20), var(--lightersand));
  box-shadow: 0 0 3rem 1rem var(--lightbeige-50), inset 1px 1px 1px var(--white), inset -1px -1px 1px var(--white);
  backdrop-filter: blur(1px) saturate(200%);
}

.btn.sand::after {
  background: var(--white);
}

.btn.sand:hover {
  box-shadow: 0 0 4rem 1rem var(--lightbeige-50), inset 1px 1px 1px 1px var(--white), inset -1px -1px 1px 1px var(--white);
}

.btn.sand:hover::after {
  opacity: .3;
}

.btn-text {
  position: relative;
  z-index: 2;
  pointer-events: none;
}

.btn-shine {
  --shine: 2rem;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  z-index: 1;
  width: calc(100% + calc(var(--shine) / 2));
  height: calc(100% + calc(var(--shine) / 4));
  display: flex;
  overflow: visible;
  border-radius: 5rem;
  filter: blur(var(--shine));
}

.btn-shine i {
  display: block;
  width: 100%;
  height: 100%;
  background: var(--richteal);
  opacity: 0;
  transition: opacity 1s ease-in-out;

  &:hover {
    opacity: .6;
  }
}

.btn.sand .btn-shine i {
  background: var(--white);
}


.btn.sand .btn-shine i:hover {
  opacity: 1;
}

.btn-shine i:hover+i,
.btn-shine i:has(+i:hover) {
  opacity: .5;
}

.btn-shine i:hover+i+i,
.btn-shine i:has(+i+i:hover) {
  opacity: .25;
}

@media (width < 768px) {

  .btn,
  .btn:visited {
    font-size: var(--normal);
    padding: .75rem 1.5rem;
  }
}


/*
MARK: HEADER
*/

header {
  position: absolute;
  top: 0;
  z-index: 10;
  padding: 0 2rem;
  width: min(1400px, 100%);
  justify-content: space-between;
  align-items: center;
  display: grid;
  grid-template-columns: 1fr 3fr 1fr;
}

header::before {
  position: absolute;
  width: 100%;
  height: 200%;
  top: 0;
  left: 0;
  content: "";
  z-index: -1;
  background: var(--white-90);
  mask: linear-gradient(black, transparent);
}

#page:has(#hero.dark) header::before {
  @media (width > 767px) {
    height: 100%;
    background: var(--black-50);
  }
}

h1 {
  margin: 0;
  padding: 0;
}

h1 img {
  height: 6rem;
  translate: 0 2rem;
}

#page:has(#hero.dark) h1 img {
  @media (width > 767px) {
    filter: saturate(0%) brightness(500%);
  }
}

#nav-primary {
  display: flex;
  gap: 1rem;
  justify-content: center;
  align-items: center;
  text-align: center;
}

#mobile-nav-toggle {
  display: none;
}

#nav-secondary {
  display: flex;
  flex-direction: column;
  color: var(--teal);
  gap: 1rem;
  justify-content: center;
  align-items: flex-end;
  font-size: var(--small);
  text-align: right;
}

#page:has(#hero.dark) #nav-secondary {
  @media (width > 767px) {
    color: var(--white-90);
  }
}

#nav-secondary>div {
  display: flex;
  gap: .5rem;
  align-items: center;
  width: fit-content;
  white-space: nowrap;
}

#restrictions {
  background: url(images/no-animals.svg) center right no-repeat;
  background-size: 1.5rem;
  padding: 0.25rem 2rem 0.25rem 0.25rem;
  margin-right: 1rem;
}

#page:has(#hero.dark) #restrictions {
  @media (width > 767px) {
    background-image: url(images/no-animals-dark.svg);
  }
}

.icon {
  width: 1.5rem;
  height: 1.5rem;
}

#nav-secondary .btn {
  font-size: var(--normal);
  padding: 0.6rem 1.2rem 0.5rem 1.2rem;

  @media (width < 1200px) {
    font-size: var(--small);
  }
}

nav a {
  text-decoration: none;
}

nav a:active {
  scale: .96;
}


html[lang="en"] #lang-en,
html[lang="de"] #lang-de,
html[lang="fr"] #lang-fr,
html[lang="hu"] #lang-hu,
#nav-secondary>div:first-child a:hover {
  text-decoration: underline;
}

#nav-primary a {
  color: var(--text);
  border-radius: 2rem;
  padding: 0.25rem 0.75rem;
  transition: background .5s ease, box-shadow .5s ease, outline .5s ease, scale .25s ease;
  text-shadow: 0 0 2px var(--white), 0 0 8px var(--white);
  box-shadow: 0 0 0 transparent;
  outline: 1px solid transparent;
}

#page:has(#hero.dark) #nav-primary a {
  @media (width > 767px) {
    color: var(--purewhite);
    text-shadow: 0 0 2px var(--black-50), 0 0 8px var(--black-50);
  }
}

#nav-primary a:hover,
#nav-primary a.active {
  background: var(--white-20);
  box-shadow: 0 0 1rem var(--black-10);
  outline: 1px solid var(--white-50);
}

#mobile-booking {
  display: none;
}

@media (width < 1200px) {

  h1 img {
    height: 4rem;
  }

  #nav-primary {
    gap: .5rem;
    flex-wrap: wrap;
  }

  #nav-primary a {
    font-size: var(--small);
  }
}

/* nav anim */
@media (width > 767px) {
  @supports (animation-timeline: scroll()) {
    body:not(:has(#hero)) header {
      margin: 0 !important;
    }

    header {
      position: fixed;
      margin-bottom: -10rem;
      z-index: 100;
      border-bottom: 1px solid transparent;
    }

    header::before {
      height: 100%;
    }

    header,
    header::before,
    h1 img,
    #nav-secondary,
    #nav-secondary>div:first-child,
    #page:has(#hero.dark) #nav-primary a {
      animation-timeline: scroll(root);
      animation-range: 0 40dvh;
      animation-fill-mode: both;
    }

    header {
      animation-name: header-full;
      animation-range: 0 40dvh;
    }

    @keyframes header-full {
      60% {
        padding: .5rem 2rem;
        backdrop-filter: blur(0) saturate(1);
        background: transparent;
        border-bottom: 1px solid transparent;
      }

      100% {
        padding: .5rem 2rem;
        backdrop-filter: blur(4px) saturate(.5);
        background: var(--white-80);
        border-bottom: 1px solid var(--white);
      }
    }

    header::before {
      animation-name: header-before-full;
    }

    @keyframes header-before-full {
      to {
        background-color: var(--white-90);
        height: 100%;
      }
    }

    h1 img {
      animation-name: h1-img-full;
    }

    @keyframes h1-img-full {
      to {
        height: 3rem;
        translate: 0 4px;
        filter: saturate(100%) brightness(100%);
      }
    }

    #page:has(#hero.dark) #nav-primary a {
      animation-name: nav-primary-a-full;
    }

    @keyframes nav-primary-a-full {
      to {
        color: var(--text);
        text-shadow: 0 0 2px var(--white), 0 0 8px var(--white);
      }
    }

    #nav-secondary {
      gap: 0;
    }

    #nav-secondary>div:first-child {
      animation-name: nav-secondary-first-child-full;
      margin-bottom: 1rem;
      height: fit-content;
      interpolate-size: allow-keywords;
    }

    @keyframes nav-secondary-first-child-full {
      to {
        opacity: 0;
        height: 0;
        margin: 0;
        filter: blur(4px);
      }
    }
  }
}

/* nav mobile */
@media (width < 768px) {

  header {
    grid-template-columns: 1fr;
    height: 4.5rem;
    transition: height 0.25s ease;
    overflow: hidden;
    position: fixed;
    top: 0;
    padding: .5rem;
    backdrop-filter: blur(.5rem) saturate(.5);
    background: var(--white-50);
    border-bottom: 1px solid var(--white);
  }

  header::before {
    height: 150%;
    background: var(--white);
  }

  header.open {
    height: 100dvh;
    pointer-events: auto;
    background: var(--white-80);
  }

  body:has(header.open) {
    overflow: hidden;
    pointer-events: none;
  }


  h1 {
    text-align: center;
  }

  h1 img {
    transform-origin: top center;
    height: 3.5rem;
    translate: 0;
  }

  header.open h1 img {
    transition: height .5s ease;
    height: 6rem;
  }

  #mobile-nav-toggle {
    display: block;
    opacity: 1;
  }

  #mobile-booking {
    display: block;
    position: fixed;
    top: 1.3rem;
    right: .5rem;
    z-index: 100;
    font-size: var(--small);
    padding: .5rem 1rem;
    transition: opacity .5s ease;
  }

  header.open #mobile-booking {
    opacity: 0;
  }


  #mobile-nav-toggle input {
    display: none;
  }

  #mobile-nav-toggle label {
    position: absolute;
    top: 1.2rem;
    left: .5rem;
    z-index: 99;
    background: linear-gradient(var(--white-80), var(--white-50));
    border: 1px solid var(--white);
    padding: .5rem 1rem;
    border-radius: 2rem;
    font-size: var(--small);
    font-family: var(--font-serif);
    letter-spacing: 1px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .25rem;
  }

  #mobile-nav-toggle label div {
    position: relative;
    width: 1rem;
    height: .75rem;
    flex-basis: 1rem;
    translate: 0 -1px;
  }


  #mobile-nav-toggle label div span {
    display: block;
    position: absolute;
    width: 100%;
    height: 2px;
    background: var(--black);
    transition: all 250ms ease;
  }

  #mobile-nav-toggle label div span:nth-child(1) {
    top: 0;
  }

  #mobile-nav-toggle label div span:nth-child(2) {
    top: calc(50% - 1px);
  }

  #mobile-nav-toggle label div span:nth-child(3) {
    bottom: 0;
  }

  #mobile-nav-toggle:has(input:checked) label div span:nth-child(1) {
    rotate: 45deg;
    translate: 0 6px;
  }

  #mobile-nav-toggle:has(input:checked) label div span:nth-child(2) {
    opacity: 0;
  }

  #mobile-nav-toggle:has(input:checked) label div span:nth-child(3) {
    rotate: -45deg;
    translate: 0 -4px;
  }

  #nav-primary {
    flex-direction: row;
    flex-direction: column;
    gap: 1rem;
    margin: 2rem 0;
  }

  #nav-primary a {
    font-size: var(--normal);
  }

  #nav-secondary {
    justify-content: center;
    align-items: center;
  }


}

/* nav mobile anim */
@media (width < 768px) {
  @supports (animation-timeline: scroll()) {
    header {
      animation-name: header;
      animation-timeline: scroll(root);
      animation-range: 0 50dvh;
    }

    @keyframes header {
      from {
        border-bottom: 1px solid transparent;
        background: transparent;
        backdrop-filter: blur(0);
        height: 6rem;
      }
    }

    header::before,
    #mobile-nav-toggle label {
      animation-name: header-scroll-reveal;
      animation-timeline: scroll(root);
      animation-range: 0 50dvh;
    }

    @keyframes header-scroll-reveal {
      0% {
        opacity: 0;
        pointer-events: none;
      }

      60% {
        opacity: 0;
        pointer-events: none;
      }

      80% {
        opacity: 1;
        pointer-events: auto;
      }

      100% {
        opacity: 1;
        pointer-events: auto;
      }
    }

    h1 {
      animation-name: h1;
      animation-timeline: scroll(root);
      animation-range: 0 50dvh;
    }

    @keyframes h1 {
      from {
        translate: calc((50% - 3.5rem) * -1);
      }
    }

    h1 img {
      animation-name: h1-img;
      animation-timeline: scroll(root);
      animation-range: 0 50dvh;
    }

    @keyframes h1-img {
      from {
        height: 5rem;
      }
    }
  }
}

/*
MARK: HOME
*/

#awards-left {
  width: 6%;
  position: absolute;
  z-index: 10;
  top: 10rem;
  left: 2rem;

  @media (width < 768px) {
    width: 20%;
    top: 7rem;
    left: 1rem;
    z-index: 2;
  }

  img {
    width: 100%;
    margin-bottom: 1rem;
  }
}

#awards-right {
  width: 10%;
  position: absolute;
  z-index: 10;
  top: 10rem;
  right: 2rem;

  @media (width < 768px) {
    width: 25%;
    top: 7rem;
    right: 1rem;
    z-index: 2;
  }

  img {
    width: 100%;
    margin-bottom: 1rem;
  }
}

#home #page {
  background: var(--beige) url(images/page-bottom-20251124.webp) bottom center no-repeat;
  background-size: contain;
}

#hero {
  display: flex;
  justify-content: flex-end;
  flex-direction: column;
  align-items: center;
  position: relative;
  z-index: 1;
  padding: 1rem;
  color: var(--teal);
  aspect-ratio: 16 / 9;
}

#home #hero {
  padding: 0 1rem 10rem 1rem;

  @media (width > 767px) {
    aspect-ratio: 18 / 9;
    background: var(--brown);
    mask: linear-gradient(#fff 80%, transparent 98%);
  }
}

#bigpicture {
  position: absolute;
  overflow: hidden;
  width: 100%;
  top: 0;
  left: 0;
  z-index: -2;
  mask: linear-gradient(#fff 50%, #fff8 60%, #fff3 70%, #fff1 80%, transparent);
  background-size: cover;
  aspect-ratio: 16/9;
}

#home #bigpicture {
  @media (width > 767px) {
    aspect-ratio: 21/9;
    mask: linear-gradient(#fff 70%, transparent 98%);
  }
}

.first,
.second,
.third,
.himage {
  position: absolute;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center center;
  display: none;
}

.first {
  animation: firstanim 40s linear infinite;
}

@keyframes firstanim {
  0% {
    opacity: 1;
  }

  33% {
    opacity: 1;
  }

  34% {
    opacity: 0;
  }

  95% {
    opacity: 0;
  }

  96% {
    opacity: 1;
  }

  100% {
    opacity: 1;
  }
}

.second {
  animation: secondanim 40s linear infinite;
}

@keyframes secondanim {
  0% {
    opacity: 0;
  }

  30% {
    opacity: 0;
  }

  33% {
    opacity: 1;
  }

  66% {
    opacity: 1;
  }

  67% {
    opacity: 0;
  }

  100% {
    opacity: 0;
  }
}

.third {
  animation: thirdanim 40s linear infinite;
}

@keyframes thirdanim {
  0% {
    opacity: 0;
  }

  60% {
    opacity: 0;
  }

  66% {
    opacity: 1;
  }

  96% {
    opacity: 1;
  }

  99% {
    opacity: 0;
  }

  100% {
    opacity: 0;
  }
}

.first .himage {
  animation: firstanim2 40s linear infinite;
}

@keyframes firstanim2 {
  0% {
    transform: scale(1.0);
  }

  34% {
    transform: scale(1.04);
  }

  35% {
    transform: scale(1.0);
  }

  100% {
    transform: scale(1.0);
  }
}

.second .himage {
  animation: secondanim2 40s linear infinite;
}

@keyframes secondanim2 {
  0% {
    transform: scale(1.0);
  }

  30% {
    transform: scale(1.0);
  }

  67% {
    transform: scale(1.04);
  }

  68% {
    transform: scale(1.0);
  }

  100% {
    transform: scale(1.0);
  }
}

.third .himage {
  animation: thirdanim2 40s linear infinite;
}

@keyframes thirdanim2 {
  0% {
    transform: scale(1.0);
  }

  60% {
    transform: scale(1.0);
  }

  99% {
    transform: scale(1.04);
  }

  100% {
    transform: scale(1.0);
  }
}

/*
.first .himage {
  background-image: url(images/hero-1.webp);
}

.second .himage {
  background-image: url(images/hero-2.webp);
}

.third .himage {
  background-image: url(images/hero-3.webp);
}
*/

#hero-title {
  z-index: 1;
  position: relative;
  text-align: center;
}

#hero-title p {
  margin: 0;
  font-size: var(--medium);
  text-wrap: balance;
}

#home #hero-title p,
#home #hero-title h2 {
  @media (width > 767px) {
    color: var(--purewhite);
  }
}

#cta3 {
  margin-top: -10rem;
  z-index: 3;
  position: relative;
  padding: 2rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  background: linear-gradient(transparent, var(--black-50) 10%, transparent);
}

#cta3 a {
  border-radius: 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow: 0 0 1rem var(--white-10), 0 0 0 0 var(--white);
  text-decoration: none;
  font-size: var(--small);
  padding: .5rem;
  filter: saturate(100%);
  transition: scale 2s ease, box-shadow 2s ease, filter 2s ease;
  aspect-ratio: 5/4;
  height: clamp(300px, 400px, 100%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1rem;
}

#cta3 a:hover {
  box-shadow: 0 0 2rem var(--sand);
  scale: 1.01;
  filter: saturate(120%)
}

#cta3 a:active {
  transition: scale .5s ease;
  scale: .98;
}

#cta-hotel .bg {
  background-image: url(images/cta-hotel-20251124.webp);
}

#cta-bar .bg {
  background-image: url(images/cta-bar-20251126.webp);
}

#cta-spa .bg {
  background-image: url(images/cta-spa-20251124.webp);
}

.bg,
.title,
.desc,
.cta {
  position: relative;
  z-index: 1;
}

.bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 2rem;
  z-index: -2;
  background-position: center center;
  background-size: cover;
  transition: scale 10s ease;
}

#cta3 a:hover .bg {
  scale: 1.06;
}

.gradient {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background: linear-gradient(var(--white), var(--white-20) 20%, transparent 30%, var(--brown));
  border-radius: 2rem;
}

#cta-bar .gradient {
  background: linear-gradient(transparent 30%, var(--brown));
}

.title {
  font-size: var(--large);
  letter-spacing: 0.2px;
  text-shadow: 0 0 .5rem var(--white), 0 0 3rem var(--white-50);
  padding-top: 1rem;
}

.desc-text {
  color: var(--purewhite);
  text-shadow: 0 0 2px var(--black), 0 0 1rem var(--black), 0 0 1rem var(--black);
  letter-spacing: 0.4px;
  text-wrap: balance;
}

.cta,
.cta:visited {
  margin-top: 1rem;
  padding: 1rem 2rem;
  font-family: var(--font-serif);
  font-size: var(--medium);
  color: var(--white);
  text-shadow: 1px 1px 3px var(--black-50), 0 0 1rem var(--white-50);
  border-radius: 3rem;
  background-image: linear-gradient(var(--richteal-40), var(--pinegreen-60));
  background-size: auto 100%;
  backdrop-filter: blur(2px);
  box-shadow: 0 0 0 var(--black-5), inset 0 0 0 var(--white), 0 0 1rem var(--teal), inset 1px 1px 1px var(--lightteal), inset -1px -1px 1px var(--teal);
  transition: box-shadow 1s ease;
  overflow: clip;
  text-wrap: balance;

  @media (1023px < width < 1280px) {
    font-size: var(--normal);
  }
}

#cta3 a:hover .cta {
  box-shadow: 0 0 1rem var(--black-50), inset 0 0 4px var(--white-80), 0 0 1rem var(--richteal-60), inset 1px 1px 1px var(--lightteal), inset -1px -1px 1px var(--black-20);
}

.cta::after {
  position: absolute;
  bottom: -80%;
  left: 10%;
  width: 80%;
  height: 100%;
  content: "";
  background: var(--richteal);
  opacity: 0;
  mix-blend-mode: overlay;
  border-radius: 50%;
  z-index: -1;
  filter: blur(10px);
  transition: opacity 1s ease;
}

#cta3 a:hover .cta::after {
  opacity: .8;
}

.cta .btn-shine i {
  background: var(--richteal);
}

#awards {
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  gap: 1rem;
  padding: 2rem;
  margin: 4rem auto 0;

  @media (width < 768px) {
    padding: 1rem;
    flex-wrap: wrap;
  }
}

#awards img {
  height: 10rem;

  @media (width < 768px) {
    height: 5rem;
  }
}

#cta1 {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  padding: 4rem 1rem;
  margin-bottom: 4rem;
  font-family: var(--font-serif);
  font-size: var(--large);
  color: var(--pinegreen);
  text-align: center;
  text-wrap: balance;

  @media (width < 768px) {
    padding: 1rem;
  }
}

#cta1 .btn {
  display: inline-block;
}

@media (width < 1200px) {
  #cta3 a {
    aspect-ratio: 1/1;
  }
}

@media (1023px < width < 1200px) {

  #hero {
    aspect-ratio: 14/9;
  }

}

@media (767px < width < 1024px) {

  #hero {
    aspect-ratio: 12/9;
  }

}

@media (width < 768px) {

  #hero,
  #bigpicture {
    aspect-ratio: 9/16;
  }

  body:not(#home) #hero,
  body:not(#home) #bigpicture {
    aspect-ratio: 2/3;
  }

  #hero {
    padding: .5rem;
    background: none;
  }

  #bigpicture {
    mask: linear-gradient(#fff 40%, #fffa 50%, #fff2 60%, transparent);
    display: block;
    background-size: cover;
  }

  #bigpicture video {
    display: none;
  }

  .first,
  .second,
  .third,
  .himage {
    display: block;
  }

  .first .himage {
    background-image: url(images/hero-1-mobile.webp);
  }

  .second .himage {
    background-image: url(images/hero-2-mobile.webp);
  }

  .third .himage {
    background-image: url(images/hero-3-mobile.webp);
  }

  #hero-title h2 {
    color: var(--pinegreen);
  }

  #hero-title p {
    font-size: var(--normal);
    color: var(--teal);
  }

  #cta3 a {
    height: auto;
    aspect-ratio: 5/4;
  }

  .cta {
    font-size: var(--normal);
    letter-spacing: 0;
  }

  #cta3 {
    margin-top: -9rem;
    grid-template-columns: 1fr;
    padding: .5rem;
    gap: 0.5rem;
  }
}

/* 
MARK: HOTEL
*/

#hotel #bigpicture {
  background-image: url(images/hero-hotel-20251124.webp);
  mask: linear-gradient(#fff 60%, #fffa 70%, #fff3 96%, transparent);
}

#hotel h2,
#hotel h3,
#hotel h4 {
  color: var(--brown);
  text-align: center;
}

#hotel #hero-title {
  color: var(--darkersand);
}

#hero-cta {
  z-index: 1;
  position: relative;
  text-align: center;
  font-size: var(--small);

  @media (width < 768px) {
    font-size: var(--x-small);
  }
}

#hotel #hero-cta {
  color: var(--sand)
}

#hero-cta .btn {
  margin: 1rem 0;
}

article {
  margin: 3rem 0;
}

article sup {
  display: inline-block;
  line-height: 0;
}

#rooms {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1rem;
  padding: 2rem;
}

#rooms>a {
  grid-column: span 3;
  background: var(--lightbeige);
  background-size: cover;
  border-radius: 2rem;
  position: relative;
  z-index: 1;
  overflow: hidden;
  box-shadow: 0 0 1rem var(--lightersand);
  border: 1px solid var(--white);
  outline: 1px solid transparent;
  text-decoration: none;
  display: flex;
  align-items: flex-end;
  transition: scale 2000ms cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 2400ms ease, outline 2000ms ease;
  aspect-ratio: 1/1;
}

#rooms>a:hover {
  box-shadow: 0 0 2rem var(--sand);
  scale: 1.01;
  outline: 1px solid var(--darksand);
}

#rooms>a.half:hover {
  scale: 1.005;
}

#rooms>a.full:hover {
  scale: 1.0025;
}

#rooms>a:active {
  scale: .98;
}

#rooms>a.half {
  aspect-ratio: 3/2;
  grid-column: span 6;
}

#rooms>a.full {
  aspect-ratio: 21/9;
  grid-column: span 12;
}

#rooms>a .photo {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: 100%;
  background-position: top center;
  transition: translate 10s ease, filter 10s ease, opacity 2s ease;
  box-shadow: inset 0 0 1rem var(--white);
  opacity: .9;
}

#rooms>a.full .photo {
  background-position: center;
  top: -1px;
  left: -1px;
  width: calc(100% + 2px);
  height: calc(100% + 2px);
}

#rooms>a:hover .photo {
  translate: 0 -5%;
  filter: saturate(120%);
  opacity: 1;
}



#rooms>a .text>div {
  background: linear-gradient(var(--white-80), var(--white) 40%);
  backdrop-filter: blur(2px) saturate(20%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 1rem;
  border-bottom-right-radius: 1.95rem;
  border-bottom-left-radius: 1.95rem;
  position: relative;
  border-top: 1px solid var(--white)
}

#rooms>a .text>div::after {
  position: absolute;
  bottom: -40%;
  left: 10%;
  width: 80%;
  height: 100%;
  content: "";
  background: var(--beige);
  border-radius: 50%;
  z-index: -2;
  filter: blur(20px);
  opacity: .7;
  transition: opacity 1s ease;
}

#rooms>a:hover .text>div::after {
  opacity: 0;
}

#rooms>a .text {
  display: flex;
  text-wrap: pretty;
  color: var(--darkersand);
  font-size: var(--small);
  position: relative;
  z-index: 1;
  justify-content: flex-end;
}

#rooms>a h4 {
  text-align: left;
  margin: 0;
}

#rooms>a p {
  margin: .25rem 0;
}

#rooms>a .bottom {
  display: grid;
  justify-content: space-between;
  align-items: center;
  grid-template-columns: 1fr auto 1fr;
}

.size {
  font-size: var(--small);
  color: var(--lightsand);
}

.size span {
  font-size: var(--normal);
  color: var(--darkersand);
}

.size span.green {
  font-size: var(--small);
  color: var(--teal);
}

.size span.green.mobile {
  display: none;
}

.size span.green::before {
  content: "+";
  margin-right: 2px;
  color: var(--lightsand);
}

#room .size span.green::before {
  display: block;
  text-align: center;
}

#rooms>a .person {
  display: flex;
  justify-content: center;
  align-items: center;
}

#rooms>a .person img {
  height: 1.1rem;
}

#rooms>a .person hr {
  display: inline-block;
  margin: 0 .25rem;
  width: 1px;
  height: 1.4rem;
  border: 0;
  background: var(--lightsand);
}

#rooms>a .details {
  text-align: right;
}

#rooms>a .details>div,
#rooms>a .details>div:visited {
  position: relative;
  z-index: -1;
  display: inline-block;
  padding: .25rem .5rem;
  border-radius: 3rem;
  font-size: var(--x-small);
  color: var(--brown);
  text-shadow: 1px 1px 3px var(--white-50), 0 0 1rem var(--white-50);
  background-image: linear-gradient(var(--white-20), var(--lightersand));
  box-shadow: 0 0 3rem 1rem var(--lightbeige-50), inset 1px 1px 1px var(--white), inset -1px -1px 1px var(--white);
  transition: box-shadow 1s ease;
  text-wrap: nowrap;
}

#rooms>a:hover .details>div {
  box-shadow: 0 0 6rem 4rem var(--lightbeige-50), inset 1px 1px 1px var(--lightsand), inset -1px -1px 1px 1px var(--lightsand);
}

#rooms>a .details>div::after {
  position: absolute;
  bottom: -80%;
  left: 10%;
  width: 80%;
  height: 100%;
  content: "";
  background: var(--white);
  mix-blend-mode: overlay;
  border-radius: 50%;
  z-index: -1;
  filter: blur(20px);
  opacity: 0;
  transition: opacity 1s ease;
}

#rooms>a:hover .details>div::after {
  opacity: .8;
}

#rooms>a .details>div img {
  width: 11px;
  margin-right: 2px;
  translate: 0 2px;
}

#services {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(20rem, 100%), 1fr));
  gap: 1rem;
  padding: 2rem;
}

#services div {
  color: var(--darkersand);
  text-align: center;
  font-size: var(--small);
}

#services-bottom {
  text-align: center;
  color: var(--brown);
}

#hotel #cta1 {
  color: var(--brown);
}


@media (767px < width) {
  #rooms>a.full {
    grid-column: span 12;
    aspect-ratio: 21/9;
    align-items: stretch;
    justify-content: flex-end;
  }

  #rooms>a.full:hover .photo {
    translate: -3% 0;
  }

  #rooms>a.full .text>div {
    background: linear-gradient(90deg, var(--white-80), var(--white) 40%);
    border-bottom-left-radius: 0;
    border-top-right-radius: 1.95rem;
    border-top: 0;
    border-left: 1px solid var(--white);
  }

  #rooms>a.full .text>div>p {
    flex-basis: 100%;
  }

  #rooms>a.full .text>div::after {
    bottom: -10%;
    left: 10%;
    width: 80%;
    height: 20%;
  }

  #rooms>a.full .text {
    flex-basis: 22rem;
  }

  #rooms>a.full .bottom {
    grid-template-columns: 2fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 1rem;
  }

  #rooms>a.full .person {
    grid-column: span 2;
    grid-row: 1;
    justify-self: left;
  }

  #rooms>a.full .size {
    grid-column: 1;
    grid-row: 2;
  }

  #rooms>a.full .details {
    grid-column: 2;
    grid-row: 2;
  }
}

@media (1023px < width < 1400px) {

  #rooms>a {
    aspect-ratio: 1/1;
  }

  #rooms>a .size span {
    font-size: var(--small);
  }

  #rooms {
    gap: .5rem;
    padding: 1rem;
  }
}

@media (1023px < width < 1200px) {

  #rooms>a {
    aspect-ratio: 8/9;
  }
}

@media (767px < width < 1023px) {

  #rooms {
    gap: .5rem;
    padding: 1rem;
  }

  #rooms>a .size:has(.mobile) span.green:not(.mobile) {
    display: none;
  }

  #rooms>a .size span.green.mobile {
    display: inline-block;
  }
}

@media (width < 1025px) {
  .hide {
    display: none;
  }

  #rooms>a:not(.full) {
    aspect-ratio: 10/7 !important;
    grid-column: span 6 !important
  }
}

@media (width < 768px) {
  #hotel #bigpicture {
    background-image: url(images/hero-hotel-mobile-20251124.webp);
  }

  #hotel #oval {
    bottom: -8rem;
  }

  #rooms {
    padding: .5rem;
    gap: .5rem;
  }

  #rooms>a:not(.full),
  #rooms>a.full {
    aspect-ratio: 5/4 !important;
    grid-column: span 12 !important;
  }

  #rooms>a .photo {
    top: -10%;
  }

  #rooms>a.full .photo {
    background-position: left;
    background-size: 140%;
    top: -20%
  }

  #rooms>a .bottom {
    grid-template-columns: 2fr 1fr 2fr;
  }

  #rooms>a .size span {
    font-size: var(--small)
  }

  .size:has(.mobile) span.green:not(.mobile) {
    display: none;
  }

  .size span.green.mobile {
    display: inline-block;
  }

  #rooms>a .person img {
    height: .9rem;
  }

  #services {
    grid-template-columns: 1fr;
    padding: 1rem;
  }

  #services div,
  #services h4 {
    text-align: left;
  }
}

/* 
MARK: ROOM
*/

#room-cont {
  display: grid;
  grid-template-columns: 1fr 2.3fr;
  align-items: start;
  gap: 1rem;
  position: relative;
  margin: 2rem;
}

#room-cont article {
  position: sticky;
  top: 7rem;
  margin: 0;
}

.back-link {
  border-radius: 2rem;
  padding: 0.25rem 0.75rem;
  background: var(--purewhite-50);
  box-shadow: 0 0 1rem var(--black-10);
  outline: 1px solid var(--purewhite);
  text-decoration: none;
  font-size: var(--small);
}

#room-cont h2 {
  font-size: var(--large);
  text-align: left;
  margin-top: 1rem;
}

.room-info {
  display: grid;
  grid-template-columns: 4fr 1fr;
  grid-template-rows: 1fr 1fr;
  justify-items: center;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;

  @media (width < 768px) {
    gap: 0.5rem;
  }
}

.room-info div {
  width: 100%;
  height: 100%;
  border-radius: 1rem;
  background: var(--white-50);
  display: flex;
  justify-content: center;
  align-items: center;
}

.floor-plan {
  grid-row: span 2;
}

.floor-plan img {
  width: 100%;
}

.room-info .size {
  font-size: var(--medium);
  color: var(--darkersand);

  flex-direction: column;

  @media (width < 768px) {
    font-size: var(--x-small);
  }
}

.room-info .size span {
  font-size: var(--large);
  display: block;

  @media (width < 768px) {
    font-size: var(--medium);
  }
}

.room-info .size span.green {
  font-size: var(--medium);
  color: var(--teal);

  @media (width < 768px) {
    font-size: var(--small);
  }
}

.room-info .person {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  align-content: center;
}

.room-info .person img {
  height: 2rem;

  @media (width < 768px) {
    height: 1rem;
  }
}

.room-info .person hr {
  flex-basis: 100%;
  height: 0;
  border: 0;
}

#room-images {
  display: block;
  translate: none;
  width: auto;
}

#room-images a {
  display: block;
  width: 100%;
  margin-bottom: 1rem;
}

@media (width < 1024px) {
  #room-cont {
    grid-template-columns: 1fr;
    margin: 0.5rem;
  }

  #room-cont article {
    position: relative;
    top: auto;
  }

  #room-images a img {
    aspect-ratio: auto;
  }
}


/*
MARK: BAR
*/

#bar #page {
  background-color: var(--sun);
}

#bar #bigpicture {
  background-image: url(images/hero-bar-20251126.webp);
  mask: linear-gradient(#fff 70%, #fffc 85%, #fff1 98%, transparent);
}

#bar h2,
#bar h3,
#bar h4 {
  color: var(--roof);
  text-align: center;
}

#bar #hero-title #rooftop {
  width: 400px;
  width: min(100%, 20rem);
  margin-bottom: 2rem;
}

#bar #hero-title {
  color: var(--brown);
}

#bar #hero-cta {
  color: var(--sand)
}

#bar-article {
  aspect-ratio: 144/260;
  position: relative;
  padding: 10rem 2rem 2rem 2rem !important;
  display: grid;
  grid-template-rows: 2fr 1fr 2fr 1fr;
  align-items: center;
  margin: -6rem 0 0 0;
  background-image: linear-gradient(var(--sun), var(--darkroof));
  mask: linear-gradient(transparent, #fff 6rem);
}

#bar-article::before {
  content: "";
  position: absolute;
  offset: 0;
  width: 100%;
  height: 100%;
  background: url(images/bar-bg.webp);
  background-size: cover;

}



#bar-info,
#menu-info {
  position: relative;
  font-size: var(--medium);
  font-family: var(--font-serif);
}

.bar-text {
  background: var(--white);
  border-radius: 2rem;
  padding: 2rem;
  box-shadow: 0 0 1rem var(--black-20),
    inset 0 0 1px #fff;
  text-align: center;
}

.bar-text::after {
  position: absolute;
  content: "";
  bottom: 1.9rem;
  left: calc(50% - 62px);
  width: 130px;
  height: 30px;
  background-color: var(--white);
  background-image: url(images/rooftop.svg);
  background-size: cover;
}

.bar-text h3 {
  margin: 2rem 0 2rem 0;
}

#bar-info {
  width: 50%;
  justify-self: end;
}

#menu-info {
  width: 30%;
}

.opening {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.opening>div:nth-child(odd) {
  text-align: right;
}

.tnum {
  font-variant-numeric: tabular-nums;
  color: var(--roof);
  text-align: left;
}

.tnum span:nth-child(odd) {
  width: 5ch;
  text-align: right;
  display: inline-block;
}

.tnum span:nth-child(3) {
  translate: -1ch;
}

.tnum span:nth-child(even) {
  color: var(--black);
}

.bar-text hr {
  grid-column: span 2;
  height: 1px;
  background: var(--roof);
  border: 0;
  width: 70%;
  margin: 2rem auto;
}

.bar-text hr.large {
  margin: 3rem auto;
  width: 85%;
}

.bar-text>div {
  border: 1px solid var(--roof);
  padding: 1rem 1rem 3rem 1rem;
}

#menu-info h3,
#menu-info p.small {
  margin-bottom: 4rem;
}

.bar-text a,
.bar-text a:visited {
  color: var(--roof);
}

.bar-text .small {
  color: var(--sand);
  font-size: var(--small);
  font-family: var(--font);
}

.light-button,
.light-button:visited {
  display: inline-block;
  padding: 1rem 2rem;
  border-radius: 4rem;
  border: 1px solid var(--roof);
  text-decoration: none;
  color: var(--roof);
  background-color: transparent;
  transition: background-color 1s ease, color 1s ease;
}

.light-button:hover {
  background-color: var(--roof);
  color: var(--white) !important;
}

.images {
  display: flex;
  gap: 1rem;
  width: 100%;
}

.images a {
  display: inline-block;
  position: relative;
  box-shadow: 0 0 1rem var(--black-20);
  border: 1px solid var(--white);
  border-radius: 1rem;
  overflow: clip;
}

.images a img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.images a::after,
.images a::before {
  content: "";
  width: 2rem;
  height: 2rem;
  background: var(--white);
  z-index: 1;
  right: 0;
  bottom: 0;
  position: absolute;
  filter: blur(4px);
  opacity: .6;

}

.images a::after {
  background: url(images/magnifying.svg) center no-repeat;
  background-size: cover;
  filter: none;
  opacity: 1;
  z-index: 2;
  width: 1rem;
  height: 1rem;
  right: .5rem;
  bottom: .5rem;
}

#bar .images a {
  border-color: var(--richdarksand);
}

#bar .images a::before {
  background: var(--richdarksand);
}

@media (width < 1200px) {
  #menu-info {
    width: 40%;
  }
}

@media (width < 768px) {
  #bar #bigpicture {
    background-image: url(images/hero-bar-mobile-20251124.webp);
    mask: linear-gradient(#fff 40%, #fff5 70%, transparent);
  }

  #bar #hero-title p {
    color: var(--brown);
  }

  #bar-article::before {
    display: none;
  }

  #bar-article {
    margin: 0;
    padding: 0.5rem !important;
    grid-template-rows: 1fr 1fr 1fr 1fr;
    background-image: linear-gradient(var(--sun), var(--darkroof));
    mask-image: none;
  }

  .opening {
    grid-template-columns: 1.2fr 1fr;
    gap: .5rem;
  }

  .bar-text {
    padding: 1rem;
  }

  .bar-text::after {
    bottom: .9rem;
  }

  .bar-text h3 {
    margin: 0 0 2rem 0;
  }

  #bar-info,
  #menu-info {
    width: 100%;
    text-shadow: none;
    border-radius: 1rem;
    margin: .5rem 0;
    font-size: var(--normal);
  }

  #gym-text {
    width: 100%;
    text-shadow: none;
    color: var(--richgreen);
  }

  #bar-images,
  #menu-images {
    width: 100%;
    translate: 0;
    gap: .5rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .images a img {
    object-fit: cover;
    height: 100%;
    aspect-ratio: 1 / 1;
  }
}


/*
MARK: SPA
*/

#spa #page {
  background-color: var(--teal);
}

#spa #bigpicture {
  background-image: url(images/hero-spa-20251126.webp);
  mask: linear-gradient(#fff 70%, #fffc 85%, #fff1 98%, transparent);
}

#spa h2,
#spa h3,
#spa h4,
#spa #hero-title {
  color: var(--white);
  text-align: center;
}

#spa h2 {
  background-image: linear-gradient(var(--white), var(--richgreen));
  -webkit-text-fill-color: transparent;
  background-clip: text;
  -webkit-background-clip: text;
}

#spa #hero-title #petit-bois-spa {
  width: 160px;
  width: min(100%, 10rem);
  margin-bottom: 2rem;
  filter: saturate(0%) brightness(500%);
}

#spa #hero-cta {
  color: var(--richgreen-50)
}

#spa-article {
  aspect-ratio: 144/220;
  position: relative;
  padding: 10rem 2rem 2rem 2rem !important;
  display: grid;
  grid-template-rows: 3fr 1fr 3fr 1fr;
  align-items: center;
  margin: -10rem 0 0 0;
  background-image: linear-gradient(var(--lightgreen), var(--pinegreen));
  mask: linear-gradient(transparent, #fff 6rem);
}

#spa-article::before {
  content: "";
  position: absolute;
  offset: 0;
  width: 100%;
  height: 100%;
  background: url(images/spa-bg-20251126.webp);
  background-size: cover;
}


#spa-text,
#gym-text {
  width: 49ch;
  color: var(--white);
  line-height: 150%;
  text-shadow: 0 0 2rem var(--black);
  position: relative;
}

#gym-text {
  justify-self: end;
  width: 48ch;
}

#spa-text h3,
#gym-text h3 {
  background-image: linear-gradient(var(--white), var(--richgreen));
  -webkit-text-fill-color: transparent;
  background-clip: text;
  -webkit-background-clip: text;
}

#spa .images a {
  border-color: var(--richgreen);
}

#spa .images a::before {
  background: var(--richgreen);
}

@media (1023px < width < 1200px) {
  #spa h3 {
    text-align: left;
  }

  #spa-text {
    width: 35ch;
  }

  #gym-text {
    width: 40ch;
  }
}

@media (767px < width < 1023px) {

  #spa-text,
  #gym-text {
    background: var(--black-50);
    backdrop-filter: blur(4px);
    padding: 1rem;
    border-radius: 2rem;
    width: 100%;
    align-self: end;
  }

  #gym-images {
    margin-top: 2rem
  }
}

@media (width < 768px) {

  #spa #hero-title p {
    color: var(--white);
  }

  #spa #bigpicture {
    background-image: url(images/hero-spa-mobile-20251126.webp);
  }

  #spa-article::before {
    display: none;
  }

  #spa-article {
    margin: 2rem 0 0 0;
    padding: 0.5rem !important;
    grid-template-rows: 1fr 1fr 1fr 1fr;
    background-image: linear-gradient(var(--teal), var(--pinegreen) 50%);
    mask-image: none;
  }

  #spa-text,
  #gym-text {
    width: 100%;
    text-shadow: none;
  }

  #spa-images,
  #gym-images {
    width: 100%;
    translate: 0;
    gap: .5rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  #spa-images {
    margin-top: 2rem;
    margin-bottom: 2rem;
  }

  #gym-images {
    margin-top: 2rem
  }
}

/*
MARK: HISTORY
*/

#history #bigpicture {
  background-image: url(images/hero-history-20251126.webp);
  mask: linear-gradient(#fff 80%, #fffa 90%, #fff3 98%, transparent);
}

@media (width < 768px) {
  #history #bigpicture {
    background-image: url(images/hero-history-mobile.webp);
    mask: linear-gradient(#fff 60%, #fffa 80%, #fff3 90%, transparent);
  }
}

.postcards {
  display: grid;
  grid-template-columns: 1fr 2fr 1fr;
  align-items: center;
  margin: 4rem 0;
}

.postcards img {
  box-shadow: 0 0 1rem var(--black-20);
  width: 100%;
  display: block;
  z-index: 1;
}

.postcards img:nth-child(1) {
  rotate: 2deg;
  transform: translateX(3rem);
}

.postcards img:nth-child(2) {
  rotate: -1deg;
  z-index: 2;
}

.postcards img:nth-child(3) {
  rotate: -3deg;
  transform: translateX(-3rem);
}

@media (width < 768px) {
  .postcards {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 2fr 1fr;
    justify-items: center;
    margin: 2rem 0;
  }

  .postcards img {
    width: 90%;
  }

  .postcards img:nth-child(1) {
    grid-column: 1;
    grid-row: 2;
    transform: translateX(1rem);
  }

  .postcards img:nth-child(2) {
    width: 90%;
    grid-column: span 2;
    grid-row: 1;
    transform: translateY(0.5rem);
  }

  .postcards img:nth-child(3) {
    grid-column: 2;
    grid-row: 2;
    transform: translateX(-1rem);
  }
}


@media (width > 767px) {
  @media (prefers-reduced-motion: no-preference) {
    @supports (animation-timeline: scroll()) {
      .postcards img {
        animation-name: postcard-parallax;
        animation-timeline: view();
      }

      .postcards img:nth-child(1) {
        --postcard-parallax-x: -2rem;
        --postcard-parallax-y: -2rem;
        --postcard-parallax-deg: -3deg;
      }

      .postcards img:nth-child(2) {
        --postcard-parallax-x: 0;
        --postcard-parallax-y: -0.5rem;
        --postcard-parallax-deg: 1deg;
      }

      .postcards img:nth-child(3) {
        --postcard-parallax-x: 1rem;
        --postcard-parallax-y: 1.5rem;
        --postcard-parallax-deg: 3.5deg;
      }

      .postcards:nth-of-type(2) img:nth-child(1) {
        --postcard-parallax-x: -2rem;
        --postcard-parallax-y: 4rem;
        --postcard-parallax-deg: -2deg;
      }

      .postcards:nth-of-type(2) img:nth-child(2) {
        --postcard-parallax-x: -0.5rem;
        --postcard-parallax-y: 0.5rem;
        --postcard-parallax-deg: -2deg;
      }

      .postcards:nth-of-type(2) img:nth-child(3) {
        --postcard-parallax-x: 2rem;
        --postcard-parallax-y: -2rem;
        --postcard-parallax-deg: 4deg;
      }

      @keyframes postcard-parallax {
        to {
          translate: var(--postcard-parallax-x) var(--postcard-parallax-y);
          rotate: var(--postcard-parallax-deg);
        }
      }
    }
  }
}

/*
MARK: DEFAULT
*/

body:not(:has(#hero)) #page {
  background: var(--beige) url(images/page-top.webp) top center no-repeat;
  background-size: 100%;

  @media (width < 767px) {
    padding-top: 8rem;
  }
}

body:not(:has(#hero)) main {
  @media (width > 767px) {
    padding-top: 14rem;
  }
}

/*
MARK: GALLERY
*/

#gallery-cont {
  overflow: clip;
}

.gallery {
  margin: 2rem;

  @media (width < 768px) {
    margin: 0.5rem;
  }
}

.gallery .images {
  width: auto;
  translate: 0;
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fill, minmax(min(16rem, 100%), 1fr));
}

.gallery .images .wide {
  @media (1140px < width < 1200px) {
    grid-column: span 4;
  }
}

.gallery .images .wide {
  @media (870px < width < 1139px) {
    grid-column: span 3;
  }
}

.gallery .images .wide {
  @media (767px < width < 869px) {
    grid-column: span 2;
  }
}

.gallery .images a img {
  @media (width < 768px) {
    aspect-ratio: 3 / 2;
  }
}

.gallery .images .large {
  @media (width > 767px) {
    grid-column: span 2;
    grid-row: span 2;
  }
}

.gallery .images .medium {
  @media (767px < width < 1200px) {
    grid-column: span 1;
    grid-row: span 1;
  }
}

.gallery .images .large.wide {
  @media (width=1024px) {
    display: none;
  }
}

.gallery-images {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
}

.gallery-images a {
  display: block;
  aspect-ratio: 3/2;
  background: red;
}

/*
MARK: CONTACT
*/
#contact-cont {
  text-align: center !important;
}

#contact-cont hr {
  margin: 2rem;
  border: 0;
}

.contact-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding: 4rem;

  @media (width < 768px) {
    grid-template-columns: 1fr;
  }
}

.contact-cards>div {
  position: relative;
  overflow: hidden;
  padding: 1rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;

}

.contact-cards>div h3,
.contact-cards>div p {
  margin: 0;
}

.contact-cards>div h3 {
  font-size: var(--medium);
}

#contact-hotel {
  border-right: 1px solid var(--sand);

  @media (width < 768px) {
    border-right: 0;
    border-top: 1px solid var(--sand);
    padding-top: 3rem;
    margin-top: 3rem;
  }
}

#contact-hotel .contact-logo {
  height: 6rem;
  margin-bottom: 1rem;
}

#contact-hotel h3 {
  color: var(--pinegreen);
}

#contact-bar h3 {
  color: var(--roof);
}

#contact-bar .contact-logo {
  margin-top: 3rem;
  height: 3rem;
  margin-bottom: 1rem;
}

#contact-bar {
  @media (width < 768px) {
    grid-row: 1;
  }
}

.icon img {
  margin: 1rem;
  width: 2rem;
  opacity: .8;
}

#guest-information-cont article {
  max-width: 80ch;
  margin: 3rem auto;
}

#guest-information-cont .tight p {
  padding: 0;
}

#guest-information-cont h3 {
  text-align: left;
  margin-top: 3rem;
}

@media (width < 1024px) {
  #guest-information-cont article {
    padding: 1rem;
  }
}

/*
MARK: FOOTER
*/
footer {
  font-size: var(--small);
  color: var(--darksand);
  display: grid;
  grid-template-columns: 5rem 2fr 1fr;
  padding: 2rem;
  gap: 1rem;
  justify-content: space-between;
  align-items: end;
  position: relative;
}

footer section {
  position: relative;
  z-index: 1;
}

#footer-left a img {
  width: 5rem;
  filter: sepia(1) brightness(200%);
}

#footer-center {
  flex-basis: fit-content;
  display: flex;
  gap: 3rem;
  padding: 0 2rem;
}

#footer-right {
  text-align: right;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  font-size: var(--small);
}

#footer-right div {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .5rem;
}

#footer-right>div:first-child {
  font-family: var(--font-serif);
  font-size: var(--normal);
}

#footer-right div hr {
  background-color: var(--sand);
  height: 1rem;
}

footer nav {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: .5rem;
}

footer hr {
  display: inline-block;
  width: 1px;
  height: 1.5rem;
  background: var(--teal-50);
  margin: 0 .5rem;
  border: 0;
}

footer a {
  display: inline;
  text-decoration: none;
}

footer a:hover {
  text-decoration: underline;
}

/* footer a[href*="facebook.com"],
footer a[href*="instagram.com"] {
  background: url(images/fb.svg) top left no-repeat;
  background-size: 1rem;
  background-blend-mode: darken;
  padding-left: 1.25rem;
}

footer a[href*="instagram.com"] {
  background-image: url(images/ig.svg);
} */

#bar footer {
  color: var(--roof);
  background: linear-gradient(var(--darkroof), var(--black) 80%, var(--darkerroof));
}

#bar #footer-left a img {
  filter: invert(1) brightness(70%) saturate(300%);
  opacity: 1;
}

#sun {
  position: absolute;
  top: 0;
  left: 0;
  width: 300px;
  height: 300px;
  background: radial-gradient(farthest-side at 30% 30%, var(--sun1), var(--sun2));
  border-radius: 50%;
  z-index: 0;
  box-shadow: inset 0 0 1rem var(--sun1),
    0 0 3rem 2rem var(--richroof-50);

  offset-path: ellipse(70% 80% at bottom left);
  offset-rotate: 0deg;
  animation: sunset 40s infinite ease-out;
}

@keyframes sunset {
  0% {
    offset-distance: 71%;
  }

  100% {
    offset-distance: 104%;
  }
}

#footer-cta {
  grid-column: span 3;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-evenly;
  text-align: center;
  margin-bottom: 5rem;
}

#footer-cta-video {
  z-index: 2;
  width: min(100%, 400px);
}

#footer-cta-video div {
  aspect-ratio: 9/16;
  width: min(100%, 400px);
  border-radius: 1rem;
  background: var(--black);
  box-shadow: 0 0 1rem var(--richroof-50);
  overflow: clip;
}

#footer-cta-video div video {
  width: 100%;
  position: relative;
  display: block;
}

#footer-cta-video-text {
  font-family: var(--font-serif);
  font-size: var(--large);
  color: var(--sun);
  text-shadow: 0 0 1rem var(--richroof-50);
}

#footer-cta-video-text>div {
  background: linear-gradient(var(--white), var(--sun1));
  -webkit-text-fill-color: transparent;
  background-clip: text;
  -webkit-background-clip: text;
  position: relative;
  z-index: 1;
}

#footer-cta-video-text .btn {
  text-decoration: none;
  margin: 1rem auto;
  padding: 1rem 2rem;
  color: var(--sun);
  text-shadow: 1px 1px 3px var(--black-50), 0 0 1rem var(--white-50);
  border-radius: 3rem;
  background-image: linear-gradient(var(--richroof-50), var(--black-5));
  background-size: auto 100%;
  backdrop-filter: blur(4px) saturate(125%);
  box-shadow: 0 0 0 var(--black-5), inset 0 0 0 var(--white), 0 0 3rem var(--richroof-50), inset 1px 1px 1px var(--richroof), inset -1px -1px 1px var(--sunset);
  overflow: clip;
  text-wrap: balance;
  overflow: visible;
}

#footer-cta-video-text .btn:hover {
  box-shadow: 0 0 0 var(--black-5), inset 0 0 0 var(--white), 0 0 6rem var(--sunset), inset 1px 1px 1px var(--sun2), inset -1px -1px 1px var(--sun2);
}

#footer-cta-video-text .btn::after,
#footer-cta-video-text .btn-shine i {
  background: var(--richroof);
  filter: blur(1rem);
}

#footer-cta-video-text .btn-shine i:hover {
  opacity: 1;
}

#footer-cta-video-text>div:last-child {
  font-size: var(--small);
  font-family: var(--font);
  opacity: .3;
}

#spa footer {
  color: var(--lightteal);
  background: linear-gradient(var(--pinegreen), var(--black) 80%, var(--pinegreen));
}

#spa #footer-left a img {
  filter: brightness(300%);
  opacity: 1;
}

#spa #footer-right div hr {
  background-color: var(--darkroof);
}

#spa #footer-cta-video div {
  background: var(--black);
  box-shadow: 0 0 1rem var(--teal);
}

#spa #footer-cta-video-text {
  color: var(--sun);
  text-shadow: 0 0 1rem var(--teal);
}

#footer-cta-video-text>div {
  background: linear-gradient(var(--white), var(--lightgreen));
  -webkit-text-fill-color: transparent;
  background-clip: text;
  -webkit-background-clip: text;
}

#spa #footer-cta-video-text .btn {
  color: var(--lightgreen);
  text-shadow: 1px 1px 3px var(--black-50), 0 0 1rem var(--white-50);
  background-image: linear-gradient(var(--teal), var(--black-5));
  box-shadow: 0 0 0 var(--black-5), inset 0 0 0 var(--white), 0 0 3rem var(--richteal-40), inset 1px 1px 1px var(--lightteal), inset -1px -1px 1px var(--lightteal);
}

#spa #footer-cta-video-text .btn:hover {
  box-shadow: 0 0 0 var(--black-5), inset 0 0 0 var(--white), 0 0 6rem var(--richteal-80), inset 1px 1px 1px var(--richteal), inset -1px -1px 1px var(--richteal);
}

#spa #footer-cta-video-text .btn::after,
#spa #footer-cta-video-text .btn-shine i {
  background: var(--richteal);
}

#waves {
  position: absolute;
  offset: 0;
  width: 100%;
  height: 100%;
  filter: blur(.5rem);
  opacity: .5;
  transition: scale 6s ease, translate 8s ease, opacity 10s ease;
}

.line-wave {
  position: absolute;
  width: 200%;
  height: 75%;
  left: 0;
  top: 0;
  overflow: visible;
  pointer-events: none;
  z-index: -1;
  --move-period: 42s;
  --scale-period: 17s;
  --color-one: var(--teal);
  --color-two: var(--richteal);
  --color-three: var(--lightteal);
}

footer:has(#footer-cta .btn:hover) #waves {
  scale: 1 0.4;
  translate: 0 -2rem;
  opacity: 1;
}

.line-wave path {
  transform-origin: center;
  stroke-width: 2;
  fill: transparent;

}

.line-wave g:nth-child(1) {
  animation: move-across var(--move-period) infinite linear;
}

.line-wave g:nth-child(2) {
  animation: move-across calc(var(--move-period) * 1.6) calc(var(--move-period) * -0.6) infinite linear;
}

.line-wave g:nth-child(3) {
  animation: move-across calc(var(--move-period) * 2.2) calc(var(--move-period) * -1.4) infinite linear;
}

.line-wave g:nth-child(1) path {
  animation: scale-y calc(var(--scale-period)) calc(var(--scale-period) * -0.9) infinite ease;
  stroke: var(--color-one);
}

.line-wave g:nth-child(2) path {
  animation: scale-y calc(var(--scale-period) * 1.4) calc(var(--scale-period) * -0.6) infinite ease;
  stroke: var(--color-two);
}

.line-wave g:nth-child(3) path {
  animation: scale-y calc(var(--scale-period) * 2.8) calc(var(--scale-period) * -0.2) infinite ease;
  stroke: var(--color-three);
}

@keyframes scale-y {
  0% {
    transform: scaleY(30%);
  }

  50% {
    transform: scaleY(-30%);
  }

  100% {
    transform: scaleY(30%);
  }
}

@keyframes move-across {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-40%);
  }
}

#hotel footer {
  color: var(--darksand);
  background: linear-gradient(var(--beige), var(--lightbeige));
}

#hotel #footer-right div hr {
  background-color: var(--sand);
}

#hotel #footer-cta-video div {
  background: var(--black);
  box-shadow: 0 0 1rem var(--richsand);
}

#hotel #footer-cta-video-text {
  color: var(--black);
  text-shadow: 0 0 3rem var(--lightersand);
}

#hotel #footer-cta-video-text>div {
  background: linear-gradient(var(--brown), var(--black));
  -webkit-text-fill-color: transparent;
  background-clip: text;
  -webkit-background-clip: text;
}

#hotel #footer-cta-video-text .btn {
  color: var(--brown);
  text-shadow: 1px 1px 3px var(--white-50), 0 0 1rem var(--white-50);
  background-image: linear-gradient(var(--white-20), var(--lightersand));
  box-shadow: 0 0 8rem 2rem var(--lightersand), inset 1px 1px 1px var(--white), inset -1px -1px 1px var(--white);
  backdrop-filter: blur(1px) saturate(200%);
}

#hotel #footer-cta-video-text .btn:hover {
  box-shadow: 0 0 12rem 4rem var(--lightersand), inset 1px 1px 1px 1px var(--white), inset -1px -1px 1px 1px var(--white);
}

#hotel #footer-cta-video-text .btn::after,
#hotel #footer-cta-video-text .btn-shine i {
  background: var(--white);
}

.circles {
  position: absolute;
  offset: 0;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: -2;
  pointer-events: none;
  opacity: .3;
  transition: opacity 3s ease-in-out;
}

.btn:hover .circles {
  opacity: .6;
}

.circles i {
  --size: 800px;
  display: block;
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  box-shadow: 3rem 3rem 4rem var(--darkbeige),
    -3rem -3rem 4rem var(--lightbeige),
    inset 2rem 2rem 4rem 1rem var(--darkbeige),
    inset -2rem -2rem 4rem 1rem var(--lightbeige);
  outline: 2px solid var(--white);
  position: absolute;
  top: calc(50% - (var(--size) / 2));
  left: calc(50% - (var(--size) / 2));
  opacity: 0;
  animation: circle 20s infinite ease;
  filter: blur(1px);
}

.circles i:nth-child(2) {
  animation-delay: 4s;
}

.circles i:nth-child(3) {
  animation-delay: 8s;
}

.circles i:nth-child(4) {
  animation-delay: 12s;
}

.circles i:nth-child(5) {
  animation-delay: 16s;
}

@keyframes circle {
  0% {
    scale: 1%;
    opacity: 0;
  }

  60% {
    opacity: 1;
  }

  100% {
    scale: 100%;
    opacity: 0;
  }
}

@media (width < 1200px) {
  #footer-center {
    gap: 2rem;
  }
}

@media (width < 1025px) {

  #sun,
  .circles,
  #waves {
    display: none;
  }

  footer {
    grid-template-columns: 1fr;
    padding: 0rem .5rem 2rem;
    justify-content: center;
    align-items: center;
    align-content: center;
    background-image: linear-gradient(transparent, var(--white-80));
  }

  footer>section {
    text-align: center;
  }

  footer nav {
    align-items: center;
  }

  #footer-cta {
    flex-wrap: wrap;
  }

  #footer-cta,
  #footer-right {
    grid-column: span 2;
  }

  #footer-cta-video {
    margin-bottom: 5rem;
  }

  #footer-cta-video,
  #footer-cta-video div {
    width: 100%;
  }

  #footer-cta-video-text>div:last-child {
    font-size: var(--x-small)
  }

  #footer-left {
    display: none;
  }

  #footer-center {
    display: grid;
    grid-template-columns: 1fr 1fr;
    text-align: center;
    padding: 2rem 0;
    gap: 2rem;
  }

  #footer-center nav:first-child {
    grid-column: span 2;
    flex-direction: row;
    justify-content: center
  }

  #footer-right div {
    justify-content: center;
  }

  #footer-right div:last-child {
    flex-direction: column;

    hr {
      display: none;
    }
  }
}

/* 
MARK: ANIMS
*/

@media (prefers-reduced-motion: no-preference) {

  /* VIEW TRANSITIONS */
  html {
    scroll-behavior: smooth;
  }

  /* @view-transition {
    navigation: auto;
  } */


  /* SCROLL ANIMATIONS */
  @supports (animation-timeline: scroll()) {


    body:not(#home) #bigpicture {
      animation-name: bigpicture;
      animation-timeline: scroll(root);
      animation-range: 0 40rem;
      animation-fill-mode: both;

      @media (orientation: portrait) {
        animation-range: 0 20rem;
      }
    }

    @keyframes bigpicture {
      from {
        scale: 1.025;
      }

      to {
        translate: 0 15%;
        opacity: 0.1;
        filter: saturate(10%);
        scale: 1;
      }
    }

    /* REVEAL ANIMATIONS */

    /* #awards-left a,
    #awards-right a {
      animation: awards-reveal 1000ms ease both;
      position: relative;
      display: block;
      overflow: clip;
    }

    #awards-right a:nth-child(1) {
      animation-delay: 200ms;
    }

    #awards-right a:nth-child(2) {
      animation-delay: 400ms;
    } */

    @keyframes awards-reveal {
      from {
        opacity: 0;
        filter: blur(4px);
        translate: 0 -1rem;
      }

      to {
        opacity: 1;
        filter: blur(0);
        translate: 0;
      }
    }

    #hero-title h2,
    #hero-title p,
    #hero-cta {
      animation: title-reveal 500ms ease both;
    }

    #hero-title p {
      animation-delay: 200ms;
    }

    @keyframes title-reveal {
      from {
        opacity: 0;
        translate: 0 -0.5rem;
      }

      to {
        opacity: 1;
        translate: 0;
      }
    }

    #home #cta3 a,
    #home #cta1 {
      animation: cta-reveal 1000ms ease both;
    }

    #home #cta-hotel {
      animation-delay: 200ms !important;
    }

    #home #cta-bar,
    #hero-cta {
      animation-delay: 400ms !important;
    }

    #home #cta-spa {
      animation-delay: 600ms !important;
    }

    #home #cta1 {
      animation-delay: 800ms;
    }

    @keyframes cta-reveal {
      from {
        opacity: 0;
        translate: 0 1rem;
      }

      to {
        opacity: 1;
        translate: 0;
      }
    }

    /* #bar-article::before {
      animation-name: bar-bg;
      animation-timeline: scroll(root);
      animation-fill-mode: both;
      animation-timing-function: ease-in-out;
    }

    @keyframes bar-bg {
      from {
        translate: 0 5rem;
        scale: 1.025;
      }

      to {
        translate: 0 0;
        scale: 1;
      }
    }

    #spa-article::before {
      animation-name: spa-bg;
      animation-timeline: scroll(root);
      animation-fill-mode: both;
      animation-timing-function: ease-in-out;
    }

    @keyframes spa-bg {
      from {
        scale: 1.025;
      }

      to {
        translate: 0 -5rem;
        scale: 1;
      }
    } */

    @media (width > 767px) {
      .images {
        width: calc(110% + 4rem);
        translate: -5%;
      }

      #spa-images,
      #gym-images,
      #bar-images,
      #menu-images {
        animation-name: scroll;
        animation-timeline: scroll(root);
        animation-timing-function: linear;
      }

      #gym-images,
      #menu-images {
        animation-direction: reverse
      }

      @keyframes scroll {
        from {
          translate: -5%;
        }

        to {
          translate: -10%;
        }
      }
    }
  }
}