/* =========================================================
   NS Comfort Premium — Mobile-first responsive system
   Load last. Base = phones; min-width = larger devices.
   ========================================================= */

:root {
  --bp-xs: 360px;
  --bp-sm: 480px;
  --bp-md: 768px;
  --bp-lg: 980px;
  --bp-xl: 1200px;
  --bp-2xl: 1440px;
  --page-gutter: clamp(14px, 4vw, 28px);
  --touch-target: 44px;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-padding-top: calc(72px + var(--safe-top));
}

body {
  min-width: 320px;
  padding-left: var(--safe-left);
  padding-right: var(--safe-right);
}

img,
video,
iframe,
svg {
  max-width: 100%;
  height: auto;
}

.container,
.header-inner {
  width: min(100% - (var(--page-gutter) * 2), 1120px);
  margin-inline: auto;
}

.site-header {
  padding-top: var(--safe-top);
}

.site-header .nav-wrap {
  min-height: calc(64px + var(--safe-top));
  padding-inline: 0;
  gap: clamp(8px, 2vw, 14px);
}

.header-start {
  flex: 1 1 auto;
  min-width: 0;
  max-width: calc(100% - 108px);
}

.site-header .brand {
  min-width: 0;
}

.site-header .brand-text {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-size: clamp(0.72rem, 3.2vw, 1rem);
  line-height: 1.2;
  max-width: min(11rem, 46vw);
}

.site-header .brand-logo {
  height: 40px !important;
  width: auto !important;
  flex-shrink: 0;
}

.business-toggle__option {
  min-width: 2.75rem;
  min-height: var(--touch-target);
  padding: 8px 10px;
  font-size: 0.68rem;
}

.header-end {
  gap: 8px;
  margin-left: auto;
  flex-shrink: 0;
}

.header-login-btn,
.site-header .nav-toggle {
  min-width: var(--touch-target);
  min-height: var(--touch-target);
}

.header-login-btn {
  padding: 8px 12px;
  font-size: 12px;
}

.site-header .nav-toggle {
  width: var(--touch-target);
  height: var(--touch-target);
  padding: 10px;
}

.site-header .nav a {
  min-height: var(--touch-target);
}

.hero {
  min-height: calc((var(--vh, 1vh) * 100) - var(--announcement-height, 0px) - var(--safe-top));
}

.hero-actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  width: 100%;
}

.hero-actions .btn {
  width: 100%;
  min-height: var(--touch-target);
  justify-content: center;
}

.section {
  padding-block: clamp(48px, 10vw, 88px);
}

.section-title {
  font-size: clamp(1.45rem, 5vw, 2.2rem);
}

.card-grid,
.reviews-grid,
.availability-floors {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(14px, 3vw, 20px);
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

.contact-map iframe {
  width: 100%;
  min-height: 260px;
  aspect-ratio: 4 / 3;
}

.floating-cta-stack {
  --chatbot-gutter: max(12px, var(--safe-right));
  right: var(--chatbot-gutter);
  bottom: calc(max(12px, var(--safe-bottom)) + var(--safe-bottom));
}

.floating-cta-btn {
  min-width: 0;
  width: min(148px, 42vw);
  min-height: var(--touch-target);
}

.faq-question {
  min-height: var(--touch-target);
}

.btn,
button,
input,
select,
textarea {
  font-size: max(16px, 1rem);
}

input,
select,
textarea {
  width: 100%;
}

.availability-toolbar {
  flex-direction: column;
  align-items: stretch;
}

.availability-filters {
  width: 100%;
}

.availability-filter select {
  width: 100%;
  min-width: 0;
}

.room-tariff-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.site-header--hotel .header-inner {
  width: min(100% - (var(--page-gutter) * 2), 1280px);
}

.hotel-ix-card__top,
.hotel-contact-grid,
.hotel-booking-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(16px, 3vw, 24px);
}

.hotel-facilities-group__grid {
  grid-template-columns: 1fr;
}

.ix-sticky-bar {
  padding-left: max(16px, var(--safe-left));
  padding-right: max(16px, var(--safe-right));
  padding-bottom: calc(12px + var(--safe-bottom));
}

.ix-sticky-bar__inner {
  width: 100%;
  flex-wrap: wrap;
}

.ix-sticky-bar__meta {
  flex: 1 1 140px;
}

.ix-sticky-bar .ix-booking-btn {
  width: 100%;
  min-height: var(--touch-target);
}

body.hotel-has-sticky {
  padding-bottom: calc(112px + var(--safe-bottom));
}

@media (max-width: 479px) {
  .business-toggle__option {
    min-width: 2.5rem;
    padding-inline: 8px;
  }

  .header-login-btn {
    padding-inline: 10px;
  }

  .floating-cta-buttons {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-end;
    max-width: min(100vw - 24px, 320px);
  }

  .floating-cta-btn {
    width: auto;
    flex: 1 1 calc(50% - 6px);
  }

  .hotel-facilities-group__grid {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 480px) {
  .hero-actions {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
  }

  .hero-actions .btn {
    width: auto;
    flex: 1 1 calc(50% - 8px);
  }

  .card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .reviews-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hotel-facilities-group__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 768px) {
  .site-header .brand-logo {
    height: 46px !important;
  }

  .site-header .brand-text {
    max-width: 14rem;
    -webkit-line-clamp: 1;
  }

  .hero-actions .btn {
    flex: 0 1 auto;
    width: auto;
  }

  .card-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .reviews-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

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

  .hotel-ix-gallery__stack {
    grid-template-columns: 1fr 1fr;
  }

  .hotel-facilities-group__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .ix-sticky-bar__inner {
    flex-wrap: nowrap;
  }

  .ix-sticky-bar .ix-booking-btn {
    width: auto;
  }
}

@media (min-width: 980px) {
  .site-header .nav-wrap {
    justify-content: flex-start !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
  }

  .site-header .brand-logo {
    height: 52px !important;
  }

  .site-header .brand-text {
    font-size: clamp(0.85rem, 1.2vw, 1.05rem);
    max-width: min(16rem, 22vw);
  }

  .header-start {
    max-width: none;
    flex: 0 1 auto;
  }

  .header-end {
    margin-left: 0;
  }

  .card-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .hotel-ix-card__top {
    grid-template-columns: 1.2fr 0.8fr;
  }

  .hotel-contact-grid {
    grid-template-columns: 1fr 1.1fr;
  }

  .hotel-booking-layout {
    grid-template-columns: minmax(0, 1fr) 320px;
  }
}

@media (min-width: 1200px) {
  .container {
    width: min(100% - 48px, 1120px);
  }

  .site-header--hotel .header-inner {
    width: min(100% - 48px, 1280px);
  }
}

@media (min-width: 1440px) {
  .container,
  .header-inner {
    width: min(100% - 64px, 1200px);
  }
}

@media (max-height: 500px) and (orientation: landscape) {
  .site-header .nav-wrap {
    min-height: 56px;
  }

  .hero {
    min-height: auto;
    padding-block: 24px !important;
  }

  .site-header .nav {
    padding-top: calc(56px + var(--safe-top)) !important;
  }
}

@media (hover: none) and (pointer: coarse) {
  .btn:hover,
  .floating-cta-btn:hover,
  .site-header .nav a:hover {
    transform: none;
  }

  .btn:active,
  .floating-cta-btn:active {
    transform: scale(0.98);
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

@media (prefers-color-scheme: dark) {
  :root {
    color-scheme: light;
  }
}
