@media (max-width: 1100px) {
  .use-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .availability-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: none;
  }
}

@media (max-width: 980px) {
  .hero-card,
  .story-grid,
  .contact-grid,
  .feature-grid,
  .room-grid,
  .use-grid,
  .location-grid,
  .gallery-grid {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: 80vh;
  }

  .hero-inner {
    padding-top: 2.2rem;
    padding-bottom: 1.3rem;
    align-items: flex-end;
  }

  .hero-card {
    margin: 0 auto;
    max-width: 82%;
    padding: 0.9rem;
    background: rgba(253, 250, 247, 0.78);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    gap: 0.65rem;
    border-radius: 18px;
  }

  .hero-card h1 {
    font-size: clamp(2rem, 6vw, 2.8rem);
    line-height: 0.98;
    margin-bottom: 0.4rem;
  }

  .hero-card p {
    font-size: 0.95rem;
    line-height: 1.45;
    margin-bottom: 0.15rem;
  }

  .hero-card .lead,
  .hero-card .hero-text,
  .hero-card .intro-text {
    font-size: 0.94rem;
    line-height: 1.45;
    max-width: 32ch;
  }

  .hero-subtext {
    padding-left: 0.75rem;
    max-width: 30ch;
  }

  .hero-card .stats,
  .hero-card .hero-stats,
  .hero-card .facts,
  .hero-card .hero-facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem 0.8rem;
    margin-top: 0.3rem;
  }

  .stat {
    border: none;
    padding: 0;
  }

  .stat-value {
    font-size: 1.15rem;
    line-height: 1.05;
    margin-bottom: 0.1rem;
  }

  .small {
    font-size: 0.82rem;
    line-height: 1.3;
  }

  .gallery-grid {
    grid-auto-rows: 250px;
  }

  .gallery-grid img:first-child {
    grid-row: span 1;
  }

  .feature-card img,
  .room-card img,
  .location-card img,
  .story-grid img {
    height: 260px;
  }

  .availability-card {
    min-height: 135px;
    padding: 1.25rem;
  }

  .availability-card h3 {
    font-size: 1.55rem;
    margin-bottom: 0.7rem;
  }
}

@media (max-width: 720px) {
  .nav {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.7rem;
  }

  .hero {
    min-height: 72vh;
  }

  .hero-inner {
    padding-top: 1.6rem;
    padding-bottom: 1.2rem;
    align-items: flex-end;
  }

  .hero-card {
    max-width: 68%;
    padding: 0.8rem;
    gap: 0.55rem;
    border-radius: 16px;
    background: rgba(253, 250, 247, 0.72);
  }

  .hero-card h1 {
    font-size: clamp(1.7rem, 8vw, 2.3rem);
    line-height: 0.98;
    margin-bottom: 0.3rem;
  }

  .hero-card p {
    font-size: 0.9rem;
    line-height: 1.4;
  }

  .hero-card .lead,
  .hero-card .hero-text,
  .hero-card .intro-text {
    font-size: 0.88rem;
    line-height: 1.4;
    max-width: 28ch;
  }

  .hero-subtext {
    padding-left: 0.7rem;
    max-width: 26ch;
  }

  .hero-card .stats,
  .hero-card .hero-stats,
  .hero-card .facts,
  .hero-card .hero-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.5rem 0.7rem;
    margin-top: 0.2rem;
  }

  .stat-value {
    font-size: 1.05rem;
  }

  .small {
    font-size: 0.78rem;
    line-height: 1.25;
  }

  .section {
    padding: 3.8rem 0;
  }

  .hero video {
    display: none;
  }

  .hero .hero-fallback {
    display: block;
  }

  .feature-card img,
  .room-card img,
  .location-card img,
  .story-grid img {
    height: 230px;
  }

  .availability-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .availability-card {
    min-height: auto;
    padding: 1.15rem;
  }

  .availability-card h3 {
    font-size: 1.45rem;
    margin-bottom: 0.6rem;
  }

  .availability-badge {
    font-size: 0.8rem;
    padding: 0.35rem 0.7rem;
  }

  .wa-float {
    width: 50px;
    height: 50px;
    bottom: 18px;
    right: 18px;
  }

  .wa-float svg {
    width: 23px;
    height: 23px;
  }
}

@media (max-width: 560px) {
  .hero {
    min-height: 66vh;
  }

  .hero-inner {
    padding-top: 1.2rem;
    padding-bottom: 1rem;
  }

  .hero-card {
    max-width: 72%;
    padding: 0.7rem;
    gap: 0.5rem;
    border-radius: 14px;
  }

  .hero-card h1 {
    font-size: clamp(1.5rem, 9vw, 2rem);
  }

  .hero-card p,
  .hero-card .lead,
  .hero-card .hero-text,
  .hero-card .intro-text {
    font-size: 0.85rem;
    line-height: 1.35;
  }

  .hero-subtext {
    padding-left: 0.6rem;
    max-width: 24ch;
  }

  .hero-card .stats,
  .hero-card .hero-stats,
  .hero-card .facts,
  .hero-card .hero-facts {
    gap: 0.45rem 0.6rem;
  }

  .stat-value {
    font-size: 0.95rem;
  }

  .small {
    font-size: 0.74rem;
  }

  .gallery-grid {
    grid-auto-rows: 210px;
  }

  .feature-card img,
  .room-card img,
  .location-card img,
  .story-grid img {
    height: 200px;
  }

  .availability-card h3 {
    font-size: 1.3rem;
  }
}

/* Desktop / Mobile Text Switch */
@media (max-width: 720px) {
  .desktop-only {
    display: none;
  }

  .mobile-only {
    display: block;
  }
}

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

.footer-right {
  align-self: flex-end;
  margin-top: 0.5rem;
}