@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&family=Playfair+Display:wght@500;600&display=swap');

/* =========================================================
   DLG ROOMS PAGE — scoped, no conflict with other pages
========================================================= */

.dlg-rooms-page {
  --rooms-teal:#247d80;
  --rooms-teal-dark:#1d6f72;
  --rooms-bg:#f4f7f7;
  --rooms-card:#fbfdfc;
  --rooms-card-soft:#f7fbfa;
  --rooms-text:#333;
  --rooms-muted:#5e6767;
  --rooms-line:rgba(36,125,128,.18);
  --rooms-shadow:0 22px 54px rgba(33,64,72,.105);
  width:100%;
  overflow:hidden;
  background:var(--rooms-bg);
  color:var(--rooms-text);
  font-family:'Montserrat', Arial, sans-serif;
}

.dlg-rooms-page *,
.dlg-rooms-page *::before,
.dlg-rooms-page *::after {
  box-sizing:border-box;
}

.rooms-icon-sprite {
  position:absolute;
  width:0;
  height:0;
  overflow:hidden;
}

.rooms-container {
  width:min(1320px, calc(100% - 96px));
  margin:0 auto;
}

/* ================= HERO ================= */

.rooms-hero {
  position:relative;
  padding:90px 0 46px;
  background:linear-gradient(180deg, rgba(36,125,128,.13), rgba(244,247,247,0) 76%);
  text-align:center;
}

.rooms-hero__inner {
  width:min(760px, calc(100% - 44px));
  margin:0 auto;
  padding-top: 50px;
}

.rooms-hero span {
  display:block;
  margin-bottom:4px;
  color:#4f5b5b;
  font-size:12px;
  line-height:1;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.rooms-hero h1 {
  margin:0;
  color:var(--rooms-teal);
  font-family:'Playfair Display','Times New Roman',serif;
  font-size:40px;
  line-height:.95;
  font-weight:600;
  letter-spacing:.03em;
  text-transform:uppercase;
}

.rooms-hero i {
  display:block;
  width:46px;
  height:1px;
  margin:18px auto 0;
  background:var(--rooms-teal);
  opacity:.58;
}

.rooms-hero p {
  max-width:680px;
  margin:22px auto 0;
  color:#5d6262;
  font-size:14px;
  line-height:1.82;
  font-weight:400;
}

/* ================= GRID ================= */

.rooms-list {
  padding:34px 0 110px;
}

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

.rooms-card {
  min-width:0;
  display:flex;
  flex-direction:column;
  background:linear-gradient(180deg, #ffffff 0%, var(--rooms-card) 100%);
  border:1px solid rgba(36,125,128,.13);
  box-shadow:0 10px 28px rgba(33,64,72,.045);
  overflow:hidden;
  transform:translateY(0);
  transition:
    transform .48s cubic-bezier(.22,.72,.22,1),
    box-shadow .48s ease,
    border-color .48s ease,
    background .48s ease;
}

.rooms-card:hover {
  transform:translateY(-7px);
  border-color:rgba(36,125,128,.24);
  background:#fff;
  box-shadow:var(--rooms-shadow);
}

.rooms-card__media {
  position:relative;
  display:block;
  width:100%;
  aspect-ratio:1.45 / 1;
  overflow:hidden;
  background:#dbe4e2;
}

.rooms-card__media::after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.14));
  opacity:0;
  transition:opacity .55s ease;
  pointer-events:none;
}

.rooms-card:hover .rooms-card__media::after {
  opacity:1;
}

.rooms-card__media img {
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.01);
  transition:transform 1.05s cubic-bezier(.22,.72,.22,1), filter .65s ease;
}

.rooms-card:hover .rooms-card__media img {
  transform:scale(1.055);
}

.rooms-card__body {
  flex:1;
  display:flex;
  flex-direction:column;
  padding:26px 26px 24px;
  text-align:center;
}

.rooms-card__body h3 {
  min-height:52px;
  margin:0 auto 13px;
  color:var(--rooms-teal);
  font-family:'Playfair Display','Times New Roman',serif;
  font-size:22px;
  line-height:1.18;
  font-weight:500;
  letter-spacing:1px;
}

.rooms-card__body p {
  max-width:390px;
  min-height:45px;
  margin:0 auto 17px;
  color:#4f5656;
  font-size:13px;
  line-height:1.7;
  font-weight:400;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* ================= ROOM META ================= */

.rooms-card__meta {
  width:100%;
  margin:0 auto 22px;
  padding-top:16px;
  border-top:1px solid var(--rooms-line);
  color:var(--rooms-teal);
  font-size:11px;
  line-height:1.45;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  text-align:center;
}

/* ================= BUTTONS ================= */

.rooms-card__actions {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:auto;
}

.rooms-card__btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:0 16px;
  border:1px solid var(--rooms-teal);
  border-radius:999px;
  font-size:10px;
  line-height:1;
  font-weight:700;
  letter-spacing:.13em;
  text-transform:uppercase;
  text-decoration:none;
  white-space:nowrap;
  transition:
    background .35s ease,
    border-color .35s ease,
    color .35s ease,
    transform .35s cubic-bezier(.22,.72,.22,1);
}

.rooms-card__btn--book {
  background:var(--rooms-teal);
  color:#fff;
}

.rooms-card__btn--detail {
  background:transparent;
  color:var(--rooms-teal);
}

.rooms-card__btn:hover {
  background:var(--rooms-teal-dark);
  border-color:var(--rooms-teal-dark);
  color:#fff;
  transform:translateY(-2px);
}

/* ================= FADE IN UP ================= */

.rooms-reveal {
  opacity:0;
  transform:translate3d(0, 38px, 0);
  filter:blur(5px);
  transition:
    opacity .95s cubic-bezier(.22,.72,.22,1) var(--delay,0ms),
    transform .95s cubic-bezier(.22,.72,.22,1) var(--delay,0ms),
    filter .95s cubic-bezier(.22,.72,.22,1) var(--delay,0ms);
  will-change:opacity, transform, filter;
}

.rooms-reveal.is-visible {
  opacity:1;
  transform:translate3d(0, 0, 0);
  filter:blur(0);
}

/* ================= RESPONSIVE ================= */

@media (max-width:1180px) {
  .rooms-container {
    width:min(980px, calc(100% - 64px));
  }

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

@media (max-width:760px) {
  .rooms-container {
    width:calc(100% - 40px);
  }

  .rooms-hero {
    padding:74px 0 34px;
  }

  .rooms-hero h1 {
    font-size:34px;
  }

  .rooms-hero p {
    font-size:14px;
    line-height:1.78;
  }

  .rooms-list {
    padding:26px 0 78px;
  }

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

  .rooms-card__media {
    aspect-ratio:1.32 / 1;
  }

  .rooms-card__body {
    padding:24px 22px 24px;
  }

  .rooms-card__body h3 {
    min-height:auto;
    font-size:21px;
  }

  .rooms-card__body p {
    min-height:auto;
    font-size:13px;
  }
}

@media (max-width:500px) {
  .rooms-card__meta {
    margin-bottom:18px;
    padding-top:14px;
    font-size:10px;
    line-height:1.55;
    letter-spacing:.105em;
  }

  .rooms-card__actions {
    gap:8px;
  }

  .rooms-card__btn {
    min-height:40px;
    padding:0 10px;
    font-size:9px;
    letter-spacing:.09em;
  }
}

@media (max-width:430px) {
  .rooms-container {
    width:calc(100% - 32px);
  }

  .rooms-hero__inner {
    width:calc(100% - 32px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .rooms-reveal,
  .rooms-card,
  .rooms-card__media img,
  .rooms-card__btn,
  .rooms-reveal {
    opacity:1;
    transform:none;
    filter:none;
  }
}
