/* public/css/rooms.css */
/* รวมสไตล์: rooms/index + rooms/zone + rooms/detail (อ่านง่าย + แฟนตาซี) */

.roomsPage{
  padding-top: 88px;
  min-height: 100vh;
  background:
    radial-gradient(1200px 600px at 15% 10%, rgba(255,47,179,.18), transparent 55%),
    radial-gradient(1100px 560px at 85% 0%, rgba(0,229,255,.16), transparent 55%),
    linear-gradient(180deg, rgba(8,6,18,1), rgba(5,4,12,1));
}

.rWrap{ padding: 24px 0 88px; }

/* =========================
   HERO (rooms/index.php)
========================= */
.rHero2{
  border-radius: 28px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(1100px 520px at 20% 10%, rgba(255,255,255,.14), transparent 60%),
    radial-gradient(900px 420px at 80% 0%, rgba(255,47,179,.10), transparent 60%),
    linear-gradient(180deg, rgba(16,12,36,.92), rgba(6,4,18,.96));
  box-shadow: 0 28px 80px rgba(0,0,0,.55);
  padding: 18px 18px 16px;
}

.rHero2Top h1{
  margin:0;
  font-family: Cinzel, serif;
  font-weight: 900;
  letter-spacing: .8px;
  font-size: 36px;
  color: rgba(255,255,255,.96);
  text-shadow: 0 8px 22px rgba(0,0,0,.55);
}
.rHero2Top p{
  margin: 10px 0 0;
  max-width: 920px;
  color: rgba(255,255,255,.86);
  line-height: 1.7;
}

/* GRID zone cards */
.zoneGrid2{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
  margin-top: 16px;
}

.zoneCard2{
  grid-column: span 6;
  border-radius: 28px;
  overflow:hidden;
  position:relative;
  text-decoration:none;
  color: #fff;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(12,10,26,.55);
  box-shadow: 0 22px 70px rgba(0,0,0,.55);
  transform: translateY(0);
}
.zoneCard2:hover{
  transform: translateY(-2px);
  transition: .18s ease;
  border-color: rgba(255,255,255,.24);
}
@media (max-width: 900px){
  .zoneCard2{ grid-column: span 12; }
}

/* slider header */
.zSlider{
  height: 180px;
  position:relative;
  background: #120c2c;
}
.zSlider img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  opacity:0;
  transform: scale(1.03);
  transition: opacity .9s ease, transform 1.2s ease;
  filter: saturate(1.12) contrast(1.05) brightness(1.02);
}
.zSlider img.show{
  opacity:1;
  transform: scale(1.00);
}
.zSliderShade{
  position:absolute; inset:0;
  background:
    radial-gradient(700px 220px at 25% 25%, rgba(255,255,255,.10), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 100%);
}
.zSparkles{
  position:absolute; inset:0;
  background-image:
    radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.9), transparent 60%),
    radial-gradient(2px 2px at 40% 20%, rgba(255,255,255,.8), transparent 60%),
    radial-gradient(1px 1px at 70% 25%, rgba(255,255,255,.75), transparent 60%),
    radial-gradient(1px 1px at 85% 40%, rgba(255,255,255,.7), transparent 60%),
    radial-gradient(2px 2px at 60% 55%, rgba(255,255,255,.65), transparent 60%);
  opacity:.45;
  animation: tw 4.5s ease-in-out infinite;
}
@keyframes tw{
  0%,100%{ opacity:.35; transform: translateY(0); }
  50%{ opacity:.55; transform: translateY(-1px); }
}

.zContent{
  padding: 14px 16px 16px;
  background:
    radial-gradient(900px 300px at 20% 10%, rgba(255,255,255,.08), transparent 60%),
    linear-gradient(180deg, rgba(18,14,40,.75), rgba(8,6,18,.85));
}

/* chip (รองรับทั้ง zChip และ zoneChip ที่คุณใช้ใน zone.php) */
.zChip, .zoneChip{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.18);
  backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  font-weight: 900;
  letter-spacing: .6px;
  color: rgba(255,255,255,.92);
}

.zTitle{
  margin: 10px 0 0;
  font-family: Cinzel, serif;
  font-weight: 900;
  font-size: 28px;
  letter-spacing: .6px;
  color: rgba(255,255,255,.98);
  text-shadow: 0 10px 26px rgba(0,0,0,.45);
}
.zDesc{
  margin: 10px 0 0;
  color: rgba(255,255,255,.86);
  line-height: 1.7;
  max-width: 680px;
}
.zCta{
  margin-top: 14px;
  display:flex;
  align-items:center;
  gap: 10px;
  font-weight: 900;
  color: rgba(255,255,255,.92);
}

/* โซน accent */
.zoneCard2.resort{ box-shadow: 0 22px 80px rgba(0,229,255,.08), 0 22px 70px rgba(0,0,0,.55); }
.zoneCard2.fantasy{ box-shadow: 0 22px 80px rgba(255,47,179,.10), 0 22px 70px rgba(0,0,0,.55); }
.zoneCard2.vip{ box-shadow: 0 22px 80px rgba(247,211,107,.10), 0 22px 70px rgba(0,0,0,.55); }
.zoneCard2.standard{ box-shadow: 0 22px 80px rgba(167,139,250,.10), 0 22px 70px rgba(0,0,0,.55); }

.zoneCard2.resort .zContent{
  background:
    radial-gradient(900px 300px at 20% 10%, rgba(0,229,255,.12), transparent 60%),
    linear-gradient(180deg, rgba(12,40,44,.55), rgba(8,6,18,.85));
}
.zoneCard2.fantasy .zContent{
  background:
    radial-gradient(900px 300px at 20% 10%, rgba(255,47,179,.14), transparent 60%),
    radial-gradient(900px 300px at 85% 0%, rgba(255,154,60,.10), transparent 60%),
    linear-gradient(180deg, rgba(40,10,48,.62), rgba(8,6,18,.86));
}
.zoneCard2.vip .zContent{
  background:
    radial-gradient(900px 300px at 20% 10%, rgba(247,211,107,.14), transparent 60%),
    linear-gradient(180deg, rgba(42,30,10,.58), rgba(8,6,18,.86));
}
.zoneCard2.standard .zContent{
  background:
    radial-gradient(900px 300px at 20% 10%, rgba(167,139,250,.14), transparent 60%),
    linear-gradient(180deg, rgba(20,16,50,.58), rgba(8,6,18,.86));
}

/* =========================
   ZONE PAGE (rooms/zone.php)
========================= */
.zHeader{
  margin-top: 16px;
  border-radius: 28px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  padding: 18px;
  background:
    radial-gradient(1100px 520px at 20% 10%, rgba(255,255,255,.10), transparent 60%),
    linear-gradient(180deg, rgba(16,12,36,.90), rgba(6,4,18,.96));
  box-shadow: 0 28px 80px rgba(0,0,0,.55);
  color: rgba(255,255,255,.92);
}

/* ปุ่มใน zone.php / detail.php */
.rBtn{
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.92);
  padding: 10px 12px;
  border-radius: 16px;
  cursor:pointer;
  font-weight: 900;
  text-decoration: none;
  display:inline-flex;
  align-items:center;
  gap: 10px;
}
.rBtn:hover{ transform: translateY(-1px); transition:.15s ease; border-color: rgba(255,255,255,.24); }

/* grid rooms list */
.roomGrid2{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
  margin-top: 16px;
}
.roomCard2{
  grid-column: span 4;
  border-radius: 28px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(900px 300px at 20% 10%, rgba(255,255,255,.06), transparent 60%),
    linear-gradient(180deg, rgba(14,10,34,.72), rgba(6,4,18,.92));
  box-shadow: 0 22px 70px rgba(0,0,0,.55);
  text-decoration:none;
  color: rgba(255,255,255,.92);
}
.roomCard2:hover{
  transform: translateY(-2px);
  transition: .18s ease;
  border-color: rgba(255,255,255,.22);
}

@media (max-width: 980px){ .roomCard2{ grid-column: span 6; } }
@media (max-width: 680px){ .roomCard2{ grid-column: span 12; } }

.roomCover2{ height: 210px; position:relative; background:#120c2c; }
.roomCover2 img{ width:100%; height:100%; object-fit:cover; display:block; filter:saturate(1.08) contrast(1.02); }
.roomCover2:after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, transparent 35%, rgba(5,1,15,.88) 100%);
}
.roomBody2{ padding: 14px 14px 16px; }
.roomName2{ margin:0; font-weight: 900; font-size: 18px; }

.roomMeta2{
  margin-top: 8px;
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  opacity:.95;
  font-size: 13px;
}
.rPill{
  display:inline-flex;
  gap: 8px;
  align-items:center;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
}
.roomPrice2{
  margin-top: 10px;
  font-weight: 900;
  letter-spacing: .2px;
}

/* =========================
   DETAIL PAGE (rooms/detail.php)
========================= */
.detailGrid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  margin-top: 16px;
}
@media (max-width: 980px){ .detailGrid{ grid-template-columns: 1fr; } }

.panel2{
  border-radius: 28px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(12,9,30,.82), rgba(6,4,18,.96));
  box-shadow: 0 24px 70px rgba(0,0,0,.55);
}

.gMain{
  border-radius: 20px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  margin: 12px;
  position:relative;
}
.gMain img{ width:100%; height: 440px; object-fit:cover; display:block; }
@media (max-width:680px){ .gMain img{ height: 310px; } }

.gOverlay{
  position:absolute; left: 12px; right:12px; bottom: 12px;
  display:flex; justify-content:space-between; gap: 12px; align-items:flex-end;
}
.gTitleBox{
  padding: 10px 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  backdrop-filter: blur(10px);
}
.gTitleBox .t1{ margin:0; font-weight: 900; font-size: 18px; color: rgba(255,255,255,.96); }
.gTitleBox .t2{ margin:6px 0 0; opacity:.9; font-size: 13px; color: rgba(255,255,255,.88); }

.rBtns{ display:flex; gap: 10px; flex-wrap:wrap; justify-content:flex-end; }

.thumbsRow2{
  display:flex; gap: 10px;
  margin: 0 12px 12px;
  overflow:auto;
  padding-bottom: 8px;
}
.thumb2{
  width: 114px; height: 78px;
  border-radius: 16px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  cursor:pointer;
  flex: 0 0 auto;
  opacity: .95;
}
.thumb2:hover{ opacity: 1; }
.thumb2 img{ width:100%; height:100%; object-fit:cover; display:block; }

.info2{ padding: 16px; color: rgba(255,255,255,.92); }
.info2 h1{ margin:0; font-family: Cinzel, serif; font-weight: 900; font-size: 30px; }
.info2 .p{ margin-top: 10px; opacity:.92; line-height: 1.7; }
.hr2{ margin: 14px 0; border-top: 1px solid rgba(255,255,255,.12); }

.modalX{
  position:fixed; inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background: rgba(0,0,0,.86);
  z-index:99999;
  padding: 18px;
}
.modalX.show{ display:flex; }
.modalBox{
  width: min(980px, 100%);
  border-radius: 20px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.16);
  background:#05010f;
  box-shadow: 0 28px 90px rgba(0,0,0,.8);
}
.modalBar{
  display:flex; justify-content:space-between; align-items:center;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.92);
}
.modalClose{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.24);
  color:#fff;
  padding: 8px 10px;
  border-radius: 14px;
  cursor:pointer;
}
.modalBody{ background:#000; }
.modalBody img{ width:100%; height:auto; display:block; }
.modalBody video, .modalBody iframe{ width:100%; height: 560px; display:block; }
@media (max-width:680px){ .modalBody video, .modalBody iframe{ height: 340px; } }


/* =========================
   LIGHT FANTASY THEME (ZONE PAGE)
   override: put at END of rooms.css
========================= */

/* พื้นหลังทั้งหน้าให้สว่างขึ้น + fantasy */
.roomsPage{
  background:
    radial-gradient(1400px 700px at 12% 10%, rgba(255,47,179,.18), transparent 55%),
    radial-gradient(1300px 680px at 88% 0%, rgba(0,229,255,.16), transparent 55%),
    radial-gradient(1200px 640px at 70% 95%, rgba(255,154,60,.12), transparent 60%),
    linear-gradient(180deg, rgba(250,252,255,1), rgba(245,248,255,1));
  color: #1b1b1f;
}

/* โทนโซน (ทั้งหน้า) */
.roomsPage[data-zone="resort"]{
  background:
    radial-gradient(1200px 640px at 10% 5%, rgba(0,229,255,.22), transparent 58%),
    radial-gradient(1100px 620px at 90% 0%, rgba(52,211,153,.18), transparent 55%),
    linear-gradient(180deg, rgba(250,252,255,1), rgba(244,252,250,1));
}
.roomsPage[data-zone="fantasy"]{
  background:
    radial-gradient(1200px 640px at 12% 5%, rgba(255,47,179,.22), transparent 58%),
    radial-gradient(1200px 640px at 88% 0%, rgba(139,92,246,.18), transparent 55%),
    linear-gradient(180deg, rgba(252,250,255,1), rgba(248,245,255,1));
}
.roomsPage[data-zone="vip"]{
  background:
    radial-gradient(1200px 640px at 10% 5%, rgba(247,211,107,.24), transparent 58%),
    radial-gradient(1200px 640px at 90% 0%, rgba(184,134,11,.14), transparent 55%),
    linear-gradient(180deg, rgba(255,253,248,1), rgba(252,248,240,1));
}
.roomsPage[data-zone="standard"]{
  background:
    radial-gradient(1200px 640px at 12% 5%, rgba(147,197,253,.24), transparent 58%),
    radial-gradient(1200px 640px at 88% 0%, rgba(167,139,250,.16), transparent 55%),
    linear-gradient(180deg, rgba(250,252,255,1), rgba(245,248,255,1));
}

/* Header box จากเดิมมืด -> glass ขาว */
.zHeader{
  background:
    radial-gradient(900px 340px at 15% 10%, rgba(255,255,255,.85), rgba(255,255,255,.55) 60%),
    linear-gradient(180deg, rgba(255,255,255,.68), rgba(255,255,255,.50));
  border: 1px solid rgba(0,0,0,.08);
  box-shadow:
    0 18px 60px rgba(17,24,39,.10),
    0 1px 0 rgba(255,255,255,.70) inset;
  color:#1b1b1f;
  position:relative;
}

/* เส้น accent บนหัว (แยกโซน) */
.zHeader:before{
  content:"";
  position:absolute; left:16px; right:16px; top:14px;
  height: 4px;
  border-radius: 999px;
  opacity:.9;
  filter: blur(.2px);
}
.roomsPage[data-zone="resort"] .zHeader:before{
  background: linear-gradient(90deg, rgba(0,229,255,1), rgba(52,211,153,1));
}
.roomsPage[data-zone="fantasy"] .zHeader:before{
  background: linear-gradient(90deg, rgba(255,47,179,1), rgba(139,92,246,1), rgba(255,154,60,1));
}
.roomsPage[data-zone="vip"] .zHeader:before{
  background: linear-gradient(90deg, rgba(247,211,107,1), rgba(184,134,11,1));
}
.roomsPage[data-zone="standard"] .zHeader:before{
  background: linear-gradient(90deg, rgba(147,197,253,1), rgba(167,139,250,1));
}

/* chip จากเดิมดำ -> ขาวอ่านง่าย */
.zoneChip{
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(0,0,0,.08);
  color:#111827;
  box-shadow: 0 10px 26px rgba(17,24,39,.10);
}

/* ปุ่มเป็นสไตล์สว่าง (ยังดูหรู) */
.rBtn{
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(0,0,0,.10);
  color:#111827;
  box-shadow: 0 12px 26px rgba(17,24,39,.10);
}
.rBtn:hover{
  border-color: rgba(0,0,0,.16);
  transform: translateY(-1px);
}

/* กริด: ให้เหมือนหน้าแรก สว่าง ๆ */
.roomGrid2{
  background: transparent;
}

/* การ์ดห้องจากเดิมมืด -> glass สว่าง */
.roomCard2{
  background:
    radial-gradient(900px 300px at 20% 10%, rgba(255,255,255,.85), rgba(255,255,255,.55) 60%),
    linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.55));
  border: 1px solid rgba(0,0,0,.08);
  box-shadow:
    0 18px 55px rgba(17,24,39,.12),
    0 1px 0 rgba(255,255,255,.75) inset;
  color:#111827;
}
.roomCard2:hover{
  border-color: rgba(0,0,0,.14);
  transform: translateY(-2px);
}

/* ภาพ cover: เพิ่มความคมชัดแบบสว่าง + fantasy */
.roomCover2 img{
  filter: saturate(1.12) contrast(1.06) brightness(1.04);
}
.roomCover2:after{
  background: linear-gradient(180deg, transparent 90%, rgba(255,255,255,.55) 100%);
}

/* ชื่อห้อง + meta อ่านง่าย */
.roomName2{
  color:#111827;
  text-shadow: none;
}
.roomMeta2{
  opacity: 1;
}
.rPill{
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(0,0,0,.08);
  color:#111827;
}

/* ป้ายราคาให้เด่นขึ้นแบบหรู */
.roomPrice2{
  color:#111827;
}
.roomPrice2:before{
  content:"✨ ";
  opacity:.9;
}

/* ทำให้แต่ละโซน “มี aura” ที่ขอบการ์ด */
.roomsPage[data-zone="resort"] .roomCard2{
  box-shadow: 0 20px 60px rgba(0,229,255,.12), 0 18px 55px rgba(17,24,39,.10);
}
.roomsPage[data-zone="fantasy"] .roomCard2{
  box-shadow: 0 20px 60px rgba(255,47,179,.12), 0 18px 55px rgba(17,24,39,.10);
}
.roomsPage[data-zone="vip"] .roomCard2{
  box-shadow: 0 20px 60px rgba(247,211,107,.16), 0 18px 55px rgba(17,24,39,.10);
}
.roomsPage[data-zone="standard"] .roomCard2{
  box-shadow: 0 20px 60px rgba(167,139,250,.12), 0 18px 55px rgba(17,24,39,.10);
}

/* =========================
   FANTASY BRIGHT 2.0 (append to END)
========================= */

.roomsPage{
  background:
    radial-gradient(1400px 700px at 12% 10%, rgba(255,47,179,.22), transparent 55%),
    radial-gradient(1200px 650px at 88% 0%, rgba(0,229,255,.20), transparent 55%),
    radial-gradient(1100px 620px at 65% 95%, rgba(255,154,60,.14), transparent 60%),
    linear-gradient(180deg, rgba(252,253,255,1), rgba(246,249,255,1));
  color:#0f172a;
}

.roomsPage[data-zone="resort"]{ --accent1:#00e5ff; --accent2:#34d399; --accent3:#60a5fa; }
.roomsPage[data-zone="fantasy"]{ --accent1:#ff2fb3; --accent2:#8b5cf6; --accent3:#ff9a3c; }
.roomsPage[data-zone="vip"]{ --accent1:#f7d36b; --accent2:#b8860b; --accent3:#ffb703; }
.roomsPage[data-zone="standard"]{ --accent1:#93c5fd; --accent2:#a78bfa; --accent3:#22d3ee; }

/* HERO */
.zoneHero{
  border-radius: 30px;
  overflow:hidden;
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 24px 70px rgba(17,24,39,.12);
  position:relative;
  margin-top: 10px;
  background: #fff;
}

.zoneHeroBg{
  position:absolute; inset:0;
  background-image: var(--zoneHero);
  background-size: cover;
  background-position: center;
  filter: saturate(1.08) contrast(1.02) brightness(1.05);
  transform: scale(1.02);
}

.zoneHero:before{
  content:"";
  position:absolute; inset:-2px;
  background: linear-gradient(135deg, var(--accent1), var(--accent2), var(--accent3));
  opacity:.35;
  filter: blur(18px);
}

.zoneHeroSpark{
  position:absolute; inset:0;
  background-image:
    radial-gradient(2px 2px at 12% 25%, rgba(255,255,255,.95), transparent 60%),
    radial-gradient(2px 2px at 35% 12%, rgba(255,255,255,.9), transparent 60%),
    radial-gradient(1px 1px at 70% 18%, rgba(255,255,255,.9), transparent 60%),
    radial-gradient(1px 1px at 88% 30%, rgba(255,255,255,.85), transparent 60%),
    radial-gradient(2px 2px at 58% 55%, rgba(255,255,255,.75), transparent 60%);
  opacity:.55;
  pointer-events:none;
}

.zoneHeroInner{
  position:relative;
  padding: 20px 22px 22px;
  background:
    radial-gradient(900px 360px at 12% 10%, rgba(255,255,255,.82), rgba(255,255,255,.62) 58%),
    linear-gradient(180deg, rgba(255,255,255,.70), rgba(255,255,255,.56));
  backdrop-filter: blur(10px);
}

.zoneHeroChip{
  display:inline-flex;
  gap:10px;
  align-items:center;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 14px 34px rgba(17,24,39,.10);
  font-weight: 900;
}
.zoneHeroChip .dot{ opacity:.55; }
.zoneHeroChip .ico{ filter: drop-shadow(0 8px 18px rgba(0,0,0,.20)); }

.zoneHeroTitle{
  margin: 14px 0 0;
  font-family: Cinzel, serif;
  font-weight: 900;
  font-size: 44px;
  letter-spacing: .9px;
  color:#0f172a;
  text-shadow: 0 18px 40px rgba(17,24,39,.14);
}
.zoneHeroSub{
  margin: 10px 0 0;
  max-width: 920px;
  color: rgba(15,23,42,.80);
  line-height: 1.75;
  font-size: 16px;
}

.zoneHeroBtns{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.zBtn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 14px;
  border-radius: 16px;
  text-decoration:none;
  font-weight: 900;
  color:#0f172a;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.78);
  box-shadow: 0 14px 32px rgba(17,24,39,.10);
}
.zBtn:hover{ transform: translateY(-1px); transition:.18s ease; }
.zBtn.ghost{
  background: rgba(255,255,255,.60);
}

/* GRID room posters */
.roomGrid2{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}

.roomPoster{
  grid-column: span 4;
  border-radius: 28px;
  overflow:hidden;
  text-decoration:none;
  position:relative;
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 22px 70px rgba(17,24,39,.12);
  background: #fff;
  transform: translateY(0);
}
.roomPoster:hover{
  transform: translateY(-3px);
  transition: .18s ease;
  box-shadow:
    0 26px 80px rgba(17,24,39,.14),
    0 16px 50px color-mix(in srgb, var(--accent1) 18%, transparent);
}

@media (max-width: 980px){ .roomPoster{ grid-column: span 6; } }
@media (max-width: 680px){ .roomPoster{ grid-column: span 12; } }

.roomPosterMedia{
  height: 300px;
  position:relative;
  background: #eef2ff;
}
.roomPosterMedia img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  filter: saturate(1.12) contrast(1.06) brightness(1.05);
  transform: scale(1.02);
}
.roomPosterShade{
  position:absolute; inset:0;
  background:
    radial-gradient(700px 240px at 20% 10%, rgba(255,255,255,.18), transparent 10%),
    linear-gradient(180deg, rgba(255,255,255,0) 85%, rgba(255,255,255,.95) 100%);
}

/* info overlay (glass) */
.roomPosterInfo{
  padding: 14px 14px 16px;
  background:
    radial-gradient(700px 240px at 20% 10%, rgba(255,255,255,.95), rgba(255,255,255,.70) 60%),
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.62));
  position:relative;
}

.roomPosterInfo:before{
  content:"";
  position:absolute; left: 14px; right: 14px; top: 10px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent1), var(--accent2), var(--accent3));
  opacity:.95;
}

.roomPosterTitle{
  margin: 10px 0 0;
  font-weight: 900;
  font-size: 18px;
  color:#0f172a;
}

.roomPosterMeta{
  margin-top: 10px;
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}
.roomPosterMeta .pill{
  padding: 7px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.78);
  color:#0f172a;
}

.roomPosterDesc{
  margin-top: 10px;
  color: rgba(15,23,42,.78);
  line-height: 1.6;
  min-height: 44px;
}

.roomPosterPrice{
  margin-top: 10px;
  font-weight: 900;
  color:#0f172a;
}
.roomPosterPrice:before{
  content:"✨ ";
  opacity:.9;
}

/* FIX: background continuity */
html, body{
  min-height: 100%;
}

body{
  background-attachment: fixed; /* ให้ไล่สีติดกับ viewport ต่อเนื่อง */
}

/* ทำพื้นหลังเป็น layer ยาวทั้งหน้า */
.roomsPage{
  min-height: 100vh;
  position: relative;
  background: none !important; /* กันพื้นหลังไปติด container แล้วตัด */
}

.roomsPage::before{
  content:"";
  position: fixed; /* เกาะ viewport ตลอด ไม่ตัดตามความสูงคอนเทนต์ */
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(1400px 700px at 12% 10%, rgba(255,47,179,.22), transparent 55%),
    radial-gradient(1200px 650px at 88% 0%, rgba(0,229,255,.20), transparent 55%),
    radial-gradient(1100px 620px at 65% 95%, rgba(255,154,60,.14), transparent 60%),
    linear-gradient(180deg, rgba(252,253,255,1), rgba(246,249,255,1));
}

.roomsPage[data-zone="resort"]::before{
  background:
    radial-gradient(1200px 640px at 10% 5%, rgba(0,229,255,.22), transparent 58%),
    radial-gradient(1100px 620px at 90% 0%, rgba(52,211,153,.18), transparent 55%),
    linear-gradient(180deg, rgba(250,252,255,1), rgba(244,252,250,1));
}
.roomsPage[data-zone="fantasy"]::before{
  background:
    radial-gradient(1200px 640px at 12% 5%, rgba(255,47,179,.22), transparent 58%),
    radial-gradient(1200px 640px at 88% 0%, rgba(139,92,246,.18), transparent 55%),
    linear-gradient(180deg, rgba(252,250,255,1), rgba(248,245,255,1));
}
.roomsPage[data-zone="vip"]::before{
  background:
    radial-gradient(1200px 640px at 10% 5%, rgba(247,211,107,.24), transparent 58%),
    radial-gradient(1200px 640px at 90% 0%, rgba(184,134,11,.14), transparent 55%),
    linear-gradient(180deg, rgba(255,253,248,1), rgba(252,248,240,1));
}
.roomsPage[data-zone="standard"]::before{
  background:
    radial-gradient(1200px 640px at 12% 5%, rgba(147,197,253,.24), transparent 58%),
    radial-gradient(1200px 640px at 88% 0%, rgba(167,139,250,.16), transparent 55%),
    linear-gradient(180deg, rgba(250,252,255,1), rgba(245,248,255,1));
}

main, section, .container, .roomGrid2{
  background: transparent !important;
}














/* ==========================================
   PREMIUM ZONE PATTERNS (SVG data-uri)
   Append at END of rooms.css
========================================== */

.zoneCard2{
  position: relative;
  overflow: hidden;
}

/* layer ลาย */
.zoneCard2::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.22;                 /* ปรับความเข้มลาย */
  background-repeat: repeat;
  background-size: 320px 320px; /* ปรับขนาดลาย */
  mix-blend-mode: overlay;     /* ทำให้ดูหรู ไม่ทึบ */
  filter: contrast(1.05);
}

/* เพิ่ม layer glow เบาๆ ให้หรู */
.zoneCard2::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(900px 360px at 20% 10%, rgba(255,255,255,.25), transparent 60%),
    radial-gradient(900px 360px at 90% 0%, rgba(255,255,255,.20), transparent 60%);
  opacity:.6;
}

.zoneCard2.resort::after{
  opacity:1;
  background-size: 80px 80px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cg fill='none' stroke='%2300899a' stroke-width='2.5'%3E%3Cpath d='M50 250 V140 Q50 70 110 70 Q140 40 150 40 Q160 40 190 70 Q250 70 250 140 V250'/%3E%3Cpath d='M80 250 V150 Q80 100 120 100 Q150 70 150 70 Q150 70 180 100 Q220 100 220 150 V250'/%3E%3Cpath d='M50 250 H250'/%3E%3C/g%3E%3C/svg%3E");
}

.zoneCard2.vip::after{
  opacity:1;
  background-size: 80px 80px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cg fill='none' stroke='%23caa400' stroke-width='2.2'%3E%3Cpath d='M130 30 Q150 60 130 90 Q110 60 130 30 Z'/%3E%3Cpath d='M130 90 Q180 120 130 160 Q80 120 130 90 Z'/%3E%3Cpath d='M130 160 Q190 190 130 230 Q70 190 130 160 Z'/%3E%3Cpath d='M30 130 Q60 150 90 130 Q60 110 30 130 Z'/%3E%3Cpath d='M230 130 Q200 150 170 130 Q200 110 230 130 Z'/%3E%3C/g%3E%3C/svg%3E");
}

.zoneCard2.fantasy::after{
  opacity:1;
  background-size: 80px 80px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='320' height='320'%3E%3Cg fill='none' stroke='%238b3dff' stroke-width='2'%3E%3Ccircle cx='160' cy='160' r='100'/%3E%3Ccircle cx='160' cy='160' r='70'/%3E%3Cpath d='M160 60 L190 130 L260 140 L200 180 L220 250 L160 210 L100 250 L120 180 L60 140 L130 130 Z'/%3E%3C/g%3E%3C/svg%3E");
}

.zoneCard2.standard::after{
  opacity:1;
  background-size: 80px 80px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='280' height='280'%3E%3Cg fill='none' stroke='%2300988a' stroke-width='2.2'%3E%3Cpath d='M60 260 Q80 200 60 150 Q40 100 90 50'/%3E%3Cpath d='M140 270 Q160 210 140 150 Q120 90 170 40'/%3E%3Cpath d='M220 260 Q200 200 220 150 Q240 100 190 50'/%3E%3C/g%3E%3C/svg%3E");
}

/* เพิ่มความแพง: ขอบ gradient บางๆ */
.zoneCard2{
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 30px;
  box-shadow: 0 22px 80px rgba(17,24,39,.12);
}
.zoneCard2:hover{
  transform: translateY(-2px);
  transition: .18s ease;
}

/* กัน layer ลายไปทับ content */
.zoneCard2 .zSlider,
.zoneCard2 .zSliderShade{ position: relative; z-index: 1; }
.zoneCard2 .zContent{ position: relative; z-index: 2; }


.zPriceTag{
  position:absolute;
  right:14px;
  bottom:14px;
  z-index:5;
  padding:10px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(10px);
  font-weight:900;
  font-size:14px;
  color:#111;
  box-shadow:0 15px 40px rgba(0,0,0,.25);
  border:1px solid rgba(0,0,0,.1);
}

/* ===== Rate box (เหมือนรูปที่ 2) ===== */
.roomCardBright{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.08);
  box-shadow: 0 24px 70px rgba(17,24,39,.10);
}

.rateBox{
  margin-top: 12px;
  background: rgba(245,246,250,.9);
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 18px;
  padding: 10px;
}

.rateRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.75);
}

.rateRow + .rateRow{ margin-top: 8px; }

.rateLabel{
  font-size: 14px;
  font-weight: 700;
  color: rgba(15,23,42,.86);
  line-height: 1.2;
}

.ratePrice{
  font-size: 20px;
  font-weight: 900;
  letter-spacing: .2px;
  color: rgba(15,23,42,.92);
}

/* ปรับให้ดูเป็นของแต่ละโซน (ขอบสี/เส้นไล่สีบางๆ) */
.roomCard2.resort .rateBox{ border-color: rgba(0,160,180,.25); }
.roomCard2.fantasy .rateBox{ border-color: rgba(255,47,179,.25); }
.roomCard2.vip .rateBox{ border-color: rgba(202,164,0,.25); }
.roomCard2.standard .rateBox{ border-color: rgba(80,120,255,.22); }