:root{
  --m6-blue:#176bb2;
  --m6-blue-dark:#0a4e7b;
  --m6-gray:#f5f7fa;
  --m6-text:#333;
  --card-bg:#ffffff;
  --border:#e9eef3;
}

/* page wrapper */
.rooms-page{ color:var(--m6-text); }

/* constrain inner sections */
.rooms-page .container{
  width: min(1200px, 92%);
  margin-inline: auto;
}

/* Intro Paragraph Section */
.intro-text {
  background-color: rgba(249, 249, 249, 0.9);
  padding: 40px 20px;
  text-align: center;
}

.intro-text p {
  font-size: 1.1rem;
  color: #333;
  max-width: 800px;
  margin: 0 auto;
  line-height: 1.6;
}

/* hero - uses global styles from global-style.css */

/* list wrapper */
.rooms-page .room-list{ padding: 28px 0 40px; }

/* separation between room types (alternating backgrounds) */
.rooms-page .room-type{
  padding: 0;
  background: transparent;
}
.rooms-page .room-type:nth-child(even){
  background: transparent;
}

/* inner card */
.rooms-page .room-inner{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  box-shadow: 0 10px 22px rgba(0,0,0,.05);
  margin: 30px 12px;
}

/* title row */
.rooms-page .room-head{
  display:flex; align-items:center; justify-content:flex-start; gap:16px;
  margin-bottom: 16px;
}
.rooms-page .room-head h2{
  margin:0; font-size: clamp(1.3rem, 1.8vw, 1.6rem); color:var(--m6-blue);
}

/* two-column content */
.rooms-page .room-body{
  display:grid; grid-template-columns: 1.2fr 1fr; gap: 24px;
}
@media (max-width: 900px){
  .rooms-page .room-body{ grid-template-columns: 1fr; }
}

/* gallery */
.rooms-page .room-gallery{ width:100%; }
.rooms-page .room-gallery .main-frame{
  position:relative; border-radius:12px; overflow:hidden; background:#000;
}
.rooms-page .room-gallery .main-frame .main-image{
  display:block; width:100%; aspect-ratio: 16/10; object-fit:cover;
  cursor: zoom-in;
}
.rooms-page .room-gallery .main-frame .nav{
  position:absolute; top:50%; transform: translateY(-50%);
  width:44px; height:44px; border:0; border-radius:50%;
  display:grid; place-items:center;
  background: rgba(0,0,0,.45); color:#fff; cursor:pointer;
  transition: background .15s ease, transform .15s ease;
}
.rooms-page .room-gallery .main-frame .nav:hover{ background: rgba(0,0,0,.6); transform: translateY(-50%) scale(1.05); }
.rooms-page .room-gallery .main-frame .prev{ left:10px; }
.rooms-page .room-gallery .main-frame .next{ right:10px; }

.rooms-page .room-gallery .main-frame .zoom{
  position:absolute; right:10px; bottom:10px; border:0;
  background: rgba(0,0,0,.45); color:#fff; width:40px; height:40px; border-radius:8px;
  display:grid; place-items:center; cursor:pointer; transition:.15s ease;
}
.rooms-page .room-gallery .main-frame .zoom:hover{ background: rgba(0,0,0,.6); }

/* thumbnails */
.rooms-page .room-gallery .thumb-strip{
  display:flex; gap:10px; margin-top:10px; overflow-x:auto; padding-bottom:2px;
}
.rooms-page .room-gallery .thumb{
  width:100px; height:70px; object-fit:cover; border-radius:8px; cursor:pointer;
  opacity:.85; outline:2px solid transparent; transition:opacity .15s ease, outline-color .15s ease, transform .15s ease;
  flex:0 0 auto; background:#eee;
}
.rooms-page .room-gallery .thumb:hover{ opacity:1; transform: translateY(-1px); }
.rooms-page .room-gallery .thumb.active{ outline-color: var(--m6-blue); opacity:1; }

/* info */
.rooms-page .room-info p{
  margin:0 0 12px; line-height:1.6; font-size:1rem;
}
.rooms-page .features{
  list-style:none; padding:0; margin:0;
  display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:8px 18px;
}
.rooms-page .features li{
  position:relative; padding-left:20px;
}
.rooms-page .features li::before{
  content:""; position:absolute; left:0; top:.45em;
  width:10px; height:10px; border-radius:3px; transform: rotate(45deg);
  background: var(--m6-blue);
}
@media (max-width: 520px){
  .rooms-page .features{ grid-template-columns: 1fr; }
}

/* bottom CTA */
.rooms-page .room-cta{
  display:flex; justify-content:center; margin-top: 18px;
}
.rooms-page .room-cta .button-primary{
  appearance:none; border:0; cursor:pointer;
  background: var(--m6-blue);
  color:#fff; font-weight:700; text-decoration:none;
  padding:.75em 1.4em; border-radius:10px; transition:.2s ease;
  box-shadow: 0 6px 16px rgba(23,107,178,.25);
}
.rooms-page .room-cta .button-primary:hover{ background: var(--m6-blue-dark); transform: translateY(-1px); }

/* lightbox */
.lightbox-overlay{
  position:fixed; inset:0; background: rgba(0,0,0,.85);
  display:grid; place-items:center; z-index: 9999;
}
.lightbox-overlay .lb-image{
  max-width: min(92vw, 1400px); max-height: 86vh; object-fit:contain; display:block;
}
.lightbox-overlay .lb-close,
.lightbox-overlay .lb-prev,
.lightbox-overlay .lb-next{
  position:fixed; border:0; cursor:pointer; color:#fff; background: rgba(0,0,0,.35);
  width:46px; height:46px; display:grid; place-items:center; border-radius:50%;
  transition: background .15s ease, transform .15s ease;
}
.lightbox-overlay .lb-close{ top:18px; right:18px; }
.lightbox-overlay .lb-prev{ left:20px; top:50%; transform: translateY(-50%); }
.lightbox-overlay .lb-next{ right:20px; top:50%; transform: translateY(-50%); }
.lightbox-overlay .lb-close:hover,
.lightbox-overlay .lb-prev:hover,
.lightbox-overlay .lb-next:hover{ background: rgba(255,255,255,.18); transform: scale(1.05); }

/* scroll-in animations */
.reveal{ opacity:0; transform: translateY(22px); transition: opacity .5s ease, transform .5s ease; }
.reveal.in-view{ opacity:1; transform: translateY(0); }

/* small helper if Font Awesome isn't globally sized */
.rooms-page .fa{ font-size: 16px; }

/* ========================================================= */
/* ===================  APPENDED FIXES  ==================== */
/* ========================================================= */

/* 1) Neutralize any global section padding on the rooms hero */
.rooms-page section.hero,
.rooms-page .hero{
  padding: 0 !important;
  margin: 0;
}

/* 2) Full-bleed alternating backgrounds per room-type without HTML changes */
.rooms-page .room-type{
  position: relative;
  z-index: 0;
  /* stop the in-container background so the pseudo-element can own it */
  background: transparent;
}
.rooms-page .room-type::before{
  content:"";
  position:absolute;
  top:0; bottom:0;
  left:50%; transform: translateX(-50%);
  width:100vw;                 /* stretch to full viewport width */
  background:#fff;             /* default background for odd rows */
  z-index: -1;                 /* sit behind the .room-inner card */
}
/* even rows get the gray band */
.rooms-page .room-type:nth-child(even)::before{
  background: var(--m6-gray);
}

/* Ensure the card sits above the band */
.rooms-page .room-inner{ position: relative; z-index: 1; }

/* 3) (Optional) Slightly larger spacing between blocks on large screens */
@media (min-width: 901px){
  .rooms-page .room-inner{ margin: 40px 16px; }
}

/* 4) (Optional) If any global section margins bleed above the hero */
.rooms-page .hero + .intro-text{ margin-top: 0; }

/* ========================================================= */
/* CTA Section - Responsive */
/* ========================================================= */

.rooms-cta {
  padding: 80px 0;
  background: #f4f7fb;
  text-align: center;
}

.rooms-cta h2 {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--m6-blue);
  margin: 0 0 15px;
}

.rooms-cta .cta-intro {
  font-size: 1.15rem;
  color: #666;
  margin: 0 0 50px;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

.rooms-cta .cta-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  max-width: 1200px;
  margin: 0 auto;
}

.rooms-cta .cta-box {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
}

.rooms-cta .cta-box:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(23, 107, 178, 0.2);
}

.rooms-cta .cta-image {
  width: 100%;
  height: 200px;
  overflow: hidden;
  position: relative;
}

.rooms-cta .cta-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.rooms-cta .cta-box:hover .cta-image img {
  transform: scale(1.1);
}

.rooms-cta .cta-content {
  padding: 25px 20px;
  text-align: center;
}

.rooms-cta .cta-content h3 {
  margin: 0 0 10px;
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--m6-text);
}

.rooms-cta .cta-content p {
  margin: 0 0 20px;
  font-size: 0.95rem;
  line-height: 1.6;
  color: #666;
  min-height: 45px;
}

.rooms-cta .cta-content .button-primary {
  display: inline-block;
  background: var(--m6-blue);
  color: #fff;
  padding: 12px 30px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 600;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(23, 107, 178, 0.3);
}

.rooms-cta .cta-content .button-primary:hover {
  background: var(--m6-blue-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(23, 107, 178, 0.4);
}

/* Tablet Responsive */
@media (max-width: 768px) {
  .rooms-cta {
    padding: 60px 0;
  }

  .rooms-cta h2 {
    font-size: 1.8rem;
  }

  .rooms-cta .cta-intro {
    font-size: 1.05rem;
    margin-bottom: 35px;
  }

  .rooms-cta .cta-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }

  .rooms-cta .cta-box:last-child {
    grid-column: 1 / -1;
  }
}

/* Mobile Responsive */
@media (max-width: 640px) {
  .rooms-cta {
    padding: 40px 0;
  }

  .rooms-cta h2 {
    font-size: 1.6rem;
  }

  .rooms-cta .cta-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .rooms-cta .cta-box:last-child {
    grid-column: 1;
  }

  .rooms-cta .cta-image {
    height: 180px;
  }

  .rooms-cta .cta-content {
    padding: 20px 15px;
  }

  .rooms-cta .cta-content h3 {
    font-size: 1.25rem;
  }

  .rooms-cta .cta-content p {
    min-height: auto;
    margin-bottom: 15px;
  }
}
