@media (min-width: 1200px) {}

@media (max-width: 1920px) {}

@media (min-width: 1920px) {}

@media (max-width: 1536px) {}

@media (max-width: 1440px) {}

@media (max-width: 1366px) {}

@media (max-width: 1280px) {}

@media (max-width: 1199px) {}

@media (max-width: 1099px) {}

@media (max-width: 1024px) {
  .rooms-head.uk-margin-medium-top.activity-detail-head p {
    width: 100%;
  }

  .footer-leaf {
    display: none;
  }

  .contact-simple__grid {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .contact-simple__title {
    font-size: 30px;
  }

  .contact-simple__card {
    max-width: 420px;
  }

  .contact-simple__submit {
    width: 100%;
  }

  .gallery-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
  }

  .room-detail-slider.room-detail-slider--hero.uk-margin-medium-top.slick-initialized.slick-slider {
    margin-top: 10px !important;
  }

  section.room-spec-section.uk-margin-medium-top {
    margin: 0px !important;
  }

  .rooms-head p {
    width: 100%;

  }

  .page-head-text {
    width: 100%;
    font-size: 18px;
  }

  .rooms-head {
    padding: 30px 50px;
  }

  .rooms-head::after {
    display: none !important;
  }

  .full-menu {
    height: 100%;
    min-height: 100vh;
    min-height: 100svh;
    min-height: 100dvh;
    min-height: -webkit-fill-available;
  }

  .full-menu__panel {
    flex-direction: column;
    align-items: stretch;
    align-content: stretch;
    width: 100%;
    height: 100%;
    min-height: 100%;
    min-height: 100vh;
    min-height: 100svh;
    min-height: 100dvh;
    min-height: -webkit-fill-available;
    max-height: 100%;
    overflow: hidden;
    overflow-x: hidden;
    box-sizing: border-box;
  }

  .full-menu__link {
    font-size: clamp(22px, 5.2vw, 26px);
  }

  .full-menu__left {
    flex: 1 1 auto;
    width: 100%;
    max-width: 100%;
    min-height: 100%;
    align-self: stretch;
    box-sizing: border-box;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 84px 20px 20px;
  }

  .full-menu__preview {
    display: block !important;
    flex: 0 0 auto;
    flex-shrink: 0;
    width: 100%;
    max-width: 100%;
    min-height: min(36vh, 280px);
    height: min(36vh, 280px);
    align-self: stretch;
  }

  .full-menu__columns {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .hotels-section::after {
    display: none;
  }

  .about-section::after {
    display: none;
  }

  .campaigns-cta.uk-flex.uk-flex-center.uk-margin-medium-top {
    margin-top: 65px !important;
  }

  .hotels-button {
    display: none;
  }

  /* Header layout */
  .top-header-section {
    height: auto;
    padding: 14px 0;
  }

  .header-top-section {
    width: 94%;
  }

  .header-top {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
  }

  .top-center {
    flex: 1;
    justify-content: center;
  }

  .top-right {
    gap: 10px;
  }

  .menuHeader {
    gap: 12px;
    align-items: center;
  }

  .hotel-select__toggle {
    height: 50px;
    padding: 0 14px;
    font-size: 12px;
  }

  .lang-button__toggle,
  .menu-button a {
    width: 50px;
    height: 50px;
  }

  /* Banner typography */
  .banner-text span {
    font-size: 54px;
    line-height: 1.06;
  }

  .banner-text p {
    font-size: 16px;
  }

  .vertical-line {
    height: 80px;
  }

  .play a {
    width: 86px;
    height: 86px;
  }

  /* About */
  .about-inner {
    grid-template-columns: 1fr;
    gap: 26px;
  }

  .about-top span {
    font-size: 44px;
  }

  .text-left {
    width: 100%;
    text-align: left;
    border-right: 0;
    padding-right: 0;
    margin-right: 0;
    font-size: 22px;
  }

  .about-bottom .uk-flex-right {
    justify-content: flex-start;
  }

  .about-section::after {
    display: none;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 28px;
  }

  .footer-bottom-inner {
    flex-direction: column;
    align-items: center;
  }

  .hotels-section {
    padding: 50px 0 60px;
  }

  .hotels-head h2 {
    font-size: 30px;
  }

  .hotels-slider .slick-arrow {
    top: -58px;
    width: 40px;
    height: 40px;
  }

  .hotels-slider .slick-prev {
    right: 48px;
  }

  .activities-section {
    padding: 60px 0 70px;
  }

  .activities-head h2 {
    font-size: 28px;
  }

  .activities-slider .slick-arrow {
    top: -58px;
    width: 40px;
    height: 40px;
  }

  .activities-slider .slick-prev {
    right: 48px;
  }

  .campaigns-section {
    padding: 60px 0 70px;
  }

  /* Slick mode on mobile */
  .campaigns-slider {
    display: block;
    margin: 18px -10px 0;
  }

  .campaigns-slider .slick-slide {
    padding: 0 10px;
  }

  .campaigns-slider .slick-dots {
    bottom: -14px;
  }

  .discover-section {
    padding: 90px 0;
    min-height: 520px;
  }

  .discover-box {
    padding: 34px 22px;
  }

  .discover-box h2 {
    font-size: 30px;
  }

  .room-split {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .room-split--reverse .room-split__media,
  .room-split--reverse .room-split__content {
    order: initial;
  }

  .room-split__content h3 {
    font-size: 36px;
  }

  .rooms-section--other .hotels-head h2 {
    font-size: 36px;
  }

  .rooms-section--other .rooms-slider {
    width: 94% !important;
  }

  .room-spec-card {
    padding: 42px 34px 44px;
  }

  .room-spec-title,
  .room-spec-features h3 {
    font-size: 28px;
  }

  .room-spec-description {
    font-size: 14px;
  }

  .room-spec-features {
    padding: 34px 30px;
  }

  .room-spec-features__grid {
    grid-template-columns: 1fr 1fr;
    gap: 16px 30px;
  }

  .room-spec-features__grid li {
    font-size: 14px;
    line-height: 1.75;
  }

  .site-footer {
    padding-top: 56px;
  }

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

@media (max-width: 991px) {}

@media (max-width: 768px) {}

@media (max-width: 768px) {

  /* Header tighten */
  .top-header-section {
    padding: 10px 0;
  }

  .logo img {
    max-height: 80px;
  }

  .reservation-button.mobile-none,
  .call-button.mobile-none {
    display: none;
  }

  /* Banner */
  .banner-text span {
    font-size: 38px;
  }

  .banner-text p {
    font-size: 14px;
  }

  .vertical-line {
    height: 60px;
  }

  .play a {
    width: 76px;
    height: 76px;
  }

  /* Section headings reuse */
  .hotels-head h2 {
    font-size: 26px;
  }

  /* Hotels arrows less intrusive */
  .hotels-slider .slick-arrow {
    top: -54px;
  }

  /* Activities arrows */
  .activities-slider .slick-arrow {
    top: -54px;
  }

  /* Experiences dots */
  .experiences-slider .slick-dots {
    bottom: -34px;
  }

  /* Discover */
  .discover-section {
    min-height: 460px;
    padding: 70px 0;
  }

  .discover-box {
    padding: 28px 18px;
  }

  .discover-box h2 {
    font-size: 26px;
  }

  .room-card__title {
    font-size: 18px;
  }

  .room-split__content h3 {
    font-size: 30px;
    width: 100%;
  }

  .rooms-section--other {
    padding: 44px 0 60px;
  }

  .rooms-section--other .hotels-head h2 {
    font-size: 28px;
  }

  .rooms-section--other .room-card__title {
    width: 100%;
  }

  .room-detail-hero-section {
    padding: 20px 0 22px;
  }

  .room-detail-slider--hero .room-detail-slide img {
    aspect-ratio: 16 / 10;
  }

  .room-spec-section {
    padding: 18px 0 54px;
  }

  .room-spec-card {
    width: 100%;
    padding: 30px 18px 34px;
  }

  .room-spec-title,
  .room-spec-features h3 {
    font-size: 22px;
  }

  .room-spec-description {
    margin-top: 14px;
    font-size: 12.5px;
    line-height: 1.65;
  }

  .room-spec-features {
    margin-top: 22px;
    padding: 24px 16px;
  }

  .room-spec-features__grid {
    margin-top: 16px;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .room-spec-features__grid li {
    font-size: 12.5px;
    line-height: 1.65;
  }

  .experience-card__title {
    font-size: 16px;
  }

  .experience-card__link {
    font-size: 13px;
  }

  .instagram-head h2,
  .instagram-head span {
    font-size: 38px;
  }

  .activities-page-section {
    padding: 34px 0 60px;
  }

  .activities-page-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  /* activity-detail legacy removed */

  /* Mobile-only elements */
  .mobile-only {
    display: flex !important;
  }

}


@media (max-width: 480px) {
  .activities-section {
    padding: 50px 0 60px;
  }

  /* Header */
  .header-top-section {
    width: 92%;
  }

  .lang-button {
    margin-right: 6px;
  }

  .hotel-select__toggle {
    padding: 0 10px;
    font-size: 11px;
  }

  .lang-button__toggle,
  .menu-button a {
    width: 46px;
    height: 46px;
  }

  /* Banner */
  .banner-text span {
    font-size: 30px;
  }

  .banner-text p {
    font-size: 13px;
  }

  .play a {
    width: 68px;
    height: 68px;
  }

  /* Hotels */
  .hotel-card__logo img {
    max-width: 120px;
  }

  /* Footer */
  .footer-grid {
    gap: 22px;
  }

  .footer-concept img {
    width: 120px;
  }

  .room-card__title {
    font-size: 16px;
  }

  .room-split__content h3 {
    font-size: 24px;
    margin-bottom: 0px;
  }

  .experience-card__title {
    font-size: 15px;
  }

  .experience-card__link {
    font-size: 12px;
  }

  .instagram-head {
    gap: 8px;
    margin-bottom: 18px;
  }

  .instagram-head h2,
  .instagram-head span {
    font-size: 28px;
  }

  .activities-page-grid {
    grid-template-columns: 1fr;
  }

  .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .gallery-tabs .uk-tab {
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    /* Firefox */
    padding-bottom: 6px;
  }

  .gallery-tabs .uk-tab::-webkit-scrollbar {
    display: none;
    /* Safari/Chrome */
  }

  .gallery-tabs .uk-tab>* {
    flex: 0 0 auto;
  }

  .gallery-tabs .uk-tab>*>a {
    white-space: nowrap;
  }

  .page-head-text br {
    display: none;
  }

  .full-menu__left {
    padding: 76px 16px 14px;
  }

  .full-menu__close {
    top: 14px;
    left: 14px;
    width: 40px;
    height: 40px;
  }

  .full-menu__close::before,
  .full-menu__close::after {
    width: 13px;
    height: 1px;
  }

  .full-menu__top {
    top: 14px;
    right: 10px;
    gap: 8px;
  }

  .full-menu__label {
    margin-bottom: 22px;
  }

  .full-menu__preview {
    min-height: min(30vh, 200px);
    height: min(30vh, 200px);
  }

  .full-menu__sublist a,
  .full-menu__contact p,
  .full-menu__contact a {
    font-size: 13px;
  }
}

@media (max-width: 576px) {}

@media (max-width: 414px) {}

@media (max-width: 390px) {}

@media (max-width: 320px) {}