/* ============================================
   Botanic Belatuk Hotel — Main Stylesheet
   botanicbelatuk.id
   ============================================ */

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

:root {
  --primary:       #2C5F2E;
  --primary-light: #4a8c4e;
  --primary-dark:  #1a3d1c;
  --secondary:     #F5E6C8;
  --accent:        #8B7355;
  --text:          #1a1a1a;
  --text-light:    #666;
  --bg:            #fafaf8;
  --white:         #ffffff;
  --border:        #e0d5c5;
  --shadow:        0 4px 20px rgba(0,0,0,0.08);
  --shadow-hover:  0 8px 40px rgba(0,0,0,0.15);
  --radius:        12px;
  --transition:    all 0.3s ease;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Inter',sans-serif; color:var(--text); background:var(--bg); line-height:1.6; }
h1,h2,h3,h4,h5,h6 { font-family:'Playfair Display',serif; line-height:1.3; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; height:auto; display:block; }

.container { max-width:1200px; margin:0 auto; padding:0 24px; }

/* ── NAVBAR ─────────────────────────────────── */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  transition:var(--transition);
}
.navbar.scrolled { box-shadow:0 2px 20px rgba(0,0,0,0.1); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; height:72px; }

.nav-logo { display:flex; align-items:center; gap:10px; }
.nav-logo-icon {
  width:42px; height:42px; border-radius:10px; overflow:hidden; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.nav-logo-icon img {
  width:100%; height:100%; object-fit:contain;
}
.nav-logo-text .brand {
  font-family:'Playfair Display',serif; font-size:18px; font-weight:700;
  color:var(--primary); line-height:1; display:block;
}
.nav-logo-text .sub {
  font-size:10px; color:var(--text-light); letter-spacing:1.5px;
  text-transform:uppercase; display:block;
}

.nav-menu { display:flex; align-items:center; gap:4px; list-style:none; }
.nav-link {
  display:flex; align-items:center; gap:4px; padding:8px 14px;
  border-radius:8px; font-size:14px; font-weight:500; color:var(--text);
  transition:var(--transition); white-space:nowrap;
}
.nav-link:hover { background:var(--secondary); color:var(--primary); }
.nav-link.active { background:var(--primary); color:white; }

.nav-item { position:relative; }
.dropdown-menu {
  position:absolute; top:calc(100% + 8px); left:0; background:white;
  border-radius:var(--radius); box-shadow:var(--shadow-hover);
  border:1px solid var(--border); min-width:240px; padding:8px;
  opacity:0; visibility:hidden; transform:translateY(-8px);
  transition:var(--transition); z-index:200;
}
.nav-item:hover .dropdown-menu { opacity:1; visibility:visible; transform:translateY(0); }
.dropdown-item {
  display:flex; align-items:center; gap:12px; padding:10px 12px;
  border-radius:8px; font-size:13px; color:var(--text); transition:var(--transition);
}
.dropdown-item:hover { background:var(--secondary); color:var(--primary); }
.dropdown-item .di-icon {
  width:36px; height:36px; background:var(--secondary); border-radius:8px;
  display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0;
}
.dropdown-item .di-name { font-weight:600; font-size:13px; }
.dropdown-item .di-desc { font-size:11px; color:#999; }

.nav-cta {
  background:var(--primary)!important; color:white!important;
  padding:10px 20px!important; border-radius:8px!important;
  font-weight:600!important;
}
.nav-cta:hover { background:var(--primary-dark)!important; transform:translateY(-1px); }

.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:8px; border:none; background:none; }
.hamburger span { width:24px; height:2px; background:var(--text); border-radius:2px; transition:var(--transition); display:block; }

/* ── HERO ────────────────────────────────────── */
.hero {
  position:relative; height:100vh; min-height:620px;
  display:flex; align-items:center; overflow:hidden;
}
.hero-bg { position:absolute; inset:0; }
.hero-bg img { width:100%; height:100%; object-fit:cover; }
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(26,61,28,.78) 0%, rgba(26,61,28,.38) 100%);
}
.hero-content { position:relative; z-index:1; color:white; max-width:720px; }

.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.15); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.3); padding:8px 18px;
  border-radius:50px; font-size:13px; font-weight:500; margin-bottom:24px;
}
.hero-badge .dot {
  width:8px; height:8px; background:#4ade80; border-radius:50%;
  animation:pulse 2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }

.hero h1 {
  font-size:clamp(36px,5.5vw,68px); font-weight:700; line-height:1.12;
  margin-bottom:20px; text-shadow:0 2px 20px rgba(0,0,0,.3);
}
.hero h1 span { color:var(--secondary); }
.hero p { font-size:18px; opacity:.88; margin-bottom:36px; max-width:520px; line-height:1.75; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; }

.hero-scroll {
  position:absolute; bottom:36px; left:50%; transform:translateX(-50%);
  z-index:1; display:flex; flex-direction:column; align-items:center; gap:6px;
  color:rgba(255,255,255,.65); font-size:11px; letter-spacing:2px; text-transform:uppercase;
}
.hero-scroll::after { content:''; width:1px; height:40px; background:rgba(255,255,255,.4); display:block; }
@keyframes bounceY { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(-8px)} }
.hero-scroll { animation:bounceY 2.2s infinite; }

/* ── BUTTONS ─────────────────────────────────── */
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--secondary); color:var(--primary-dark);
  padding:14px 28px; border-radius:50px; font-weight:700;
  font-size:15px; transition:var(--transition); border:2px solid transparent;
}
.btn-primary:hover { background:white; transform:translateY(-2px); box-shadow:0 8px 30px rgba(0,0,0,.2); }

.btn-secondary {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; color:white; padding:14px 28px;
  border-radius:50px; font-weight:600; font-size:15px;
  border:2px solid rgba(255,255,255,.55); transition:var(--transition);
}
.btn-secondary:hover { background:rgba(255,255,255,.15); border-color:white; }

.btn-green {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--primary); color:white; padding:13px 26px;
  border-radius:50px; font-weight:600; font-size:15px; transition:var(--transition);
}
.btn-green:hover { background:var(--primary-dark); transform:translateY(-2px); }

.btn-wa {
  display:inline-flex; align-items:center; gap:10px;
  background:#25D366; color:white; padding:15px 32px;
  border-radius:50px; font-weight:700; font-size:16px; transition:var(--transition);
}
.btn-wa:hover { background:#1da851; transform:translateY(-2px); box-shadow:0 8px 30px rgba(37,211,102,.4); }

.btn-outline-white {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; color:white; padding:15px 30px;
  border-radius:50px; font-weight:600; font-size:15px;
  border:2px solid rgba(255,255,255,.5); transition:var(--transition);
}
.btn-outline-white:hover { background:rgba(255,255,255,.1); border-color:white; }

/* ── SECTIONS ─────────────────────────────────── */
section { padding:80px 0; }
.section-label {
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; font-weight:700; letter-spacing:2.5px;
  text-transform:uppercase; color:var(--primary); margin-bottom:14px;
}
.section-label::before { content:''; width:22px; height:2px; background:var(--primary); flex-shrink:0; }
.section-title { font-size:clamp(26px,4vw,44px); font-weight:700; margin-bottom:14px; }
.section-desc { font-size:17px; color:var(--text-light); max-width:600px; line-height:1.75; }
.text-center { text-align:center; }
.text-center .section-label { justify-content:center; }
.text-center .section-desc { margin:0 auto; }

/* ── STATS BAR ───────────────────────────────── */
.stats-bar { background:var(--primary); padding:44px 0; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:32px; }
.stat-item { text-align:center; color:white; }
.stat-number { font-family:'Playfair Display',serif; font-size:42px; font-weight:700; color:var(--secondary); line-height:1; margin-bottom:8px; }
.stat-label { font-size:14px; opacity:.8; }

/* ── ABOUT ───────────────────────────────────── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-img-wrap { position:relative; }
.about-img-main { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-hover); }
.about-img-main img { width:100%; height:460px; object-fit:cover; }
.about-badge {
  position:absolute; bottom:-24px; right:-24px;
  background:var(--secondary); border-radius:var(--radius); padding:22px 26px;
  box-shadow:var(--shadow); text-align:center; border:4px solid white;
}
.about-badge .number { font-family:'Playfair Display',serif; font-size:38px; font-weight:700; color:var(--primary); line-height:1; }
.about-badge .label { font-size:12px; color:var(--accent); font-weight:600; letter-spacing:1px; text-transform:uppercase; }
.features-list { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:28px; }
.feature-item { display:flex; align-items:center; gap:10px; font-size:14px; color:var(--text-light); }
.feature-item::before {
  content:'✓'; width:24px; height:24px; background:var(--primary); color:white;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; flex-shrink:0;
}

/* ── ROOM CARDS ──────────────────────────────── */
.rooms-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-top:48px; }
.room-card {
  background:white; border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow); transition:var(--transition); border:1px solid var(--border);
}
.room-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-hover); }
.room-card-img { position:relative; overflow:hidden; height:220px; }
.room-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.room-card:hover .room-card-img img { transform:scale(1.06); }
.room-tag {
  position:absolute; top:12px; left:12px;
  background:var(--primary); color:white;
  padding:4px 12px; border-radius:50px; font-size:11px; font-weight:600;
}
.room-tag.tag-vip { background:#7c3aed; }
.room-tag.tag-fomo { background:#dc2626; }
.room-card-body { padding:22px; }
.room-card-body h3 { font-size:19px; font-weight:700; margin-bottom:8px; }
.room-card-body p { font-size:14px; color:var(--text-light); margin-bottom:14px; line-height:1.65; }
.room-amenities { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:18px; }
.amenity-tag {
  display:flex; align-items:center; gap:4px;
  background:var(--secondary); color:var(--accent);
  padding:4px 10px; border-radius:50px; font-size:11px; font-weight:500;
}
.room-card-footer { display:flex; align-items:center; justify-content:space-between; padding-top:14px; border-top:1px solid var(--border); }
.room-price .from { font-size:10px; color:var(--text-light); text-transform:uppercase; letter-spacing:1px; }
.room-price .price { font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:var(--primary); line-height:1; }
.room-price .per { font-size:11px; color:var(--text-light); }
.btn-room {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--primary); color:white; padding:10px 18px;
  border-radius:8px; font-size:13px; font-weight:600; transition:var(--transition);
}
.btn-room:hover { background:var(--primary-dark); }

/* ── WHY US ──────────────────────────────────── */
.why-section { background:var(--primary); color:white; }
.why-section .section-label { color:var(--secondary); }
.why-section .section-label::before { background:var(--secondary); }
.why-section .section-title { color:white; }
.why-section .section-desc { color:rgba(255,255,255,.8); }
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.why-card {
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius); padding:32px; transition:var(--transition);
}
.why-card:hover { background:rgba(255,255,255,.15); transform:translateY(-4px); }
.why-icon { font-size:42px; margin-bottom:20px; display:block; }
.why-card h3 { font-size:20px; margin-bottom:12px; color:var(--secondary); }
.why-card p { font-size:14px; line-height:1.75; opacity:.8; }

/* ── TESTIMONIALS ────────────────────────────── */
.testimonials { background:var(--secondary); }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:48px; }
.testimonial-card { background:white; border-radius:var(--radius); padding:28px; box-shadow:var(--shadow); }
.stars { color:#f59e0b; font-size:18px; margin-bottom:14px; }
.testimonial-text { font-size:15px; color:var(--text-light); line-height:1.75; font-style:italic; margin-bottom:20px; }
.testimonial-author { display:flex; align-items:center; gap:12px; }
.author-avatar {
  width:44px; height:44px; background:var(--primary); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:white; font-weight:700; font-size:16px; flex-shrink:0;
}
.author-info .name { font-weight:700; font-size:15px; }
.author-info .from { font-size:12px; color:var(--text-light); }

/* ── CTA SECTION ─────────────────────────────── */
.cta-section {
  background:linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
  text-align:center; padding:80px 0;
}
.cta-section h2 { font-size:clamp(26px,4vw,44px); color:white; margin-bottom:14px; }
.cta-section p { font-size:18px; color:rgba(255,255,255,.8); margin-bottom:36px; }
.cta-actions { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; }

/* ── FOOTER ──────────────────────────────────── */
.footer { background:#111; color:white; padding:64px 0 0; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer-brand .logo { font-family:'Playfair Display',serif; font-size:22px; font-weight:700; color:var(--secondary); display:block; margin-bottom:14px; }
.footer-brand p { font-size:14px; color:rgba(255,255,255,.6); line-height:1.75; margin-bottom:22px; }
.social-links { display:flex; gap:10px; }
.social-link {
  width:40px; height:40px; background:rgba(255,255,255,.08); border-radius:8px;
  display:flex; align-items:center; justify-content:center; font-size:18px;
  color:rgba(255,255,255,.7); transition:var(--transition);
}
.social-link:hover { background:var(--primary); color:white; }
.footer-col h4 { font-family:'Playfair Display',serif; font-size:16px; margin-bottom:20px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:14px; color:rgba(255,255,255,.6); transition:var(--transition); display:flex; align-items:center; gap:6px; }
.footer-links a:hover { color:var(--secondary); padding-left:4px; }
.contact-item { display:flex; gap:12px; margin-bottom:14px; }
.contact-item .ci-icon { font-size:17px; margin-top:2px; flex-shrink:0; }
.contact-item .ci-text { font-size:14px; color:rgba(255,255,255,.6); line-height:1.55; }
.footer-bottom {
  padding:22px 0; display:flex; justify-content:space-between;
  align-items:center; flex-wrap:wrap; gap:12px;
}
.footer-bottom p { font-size:13px; color:rgba(255,255,255,.4); }
.footer-bottom a { color:var(--secondary); }

/* ── PAGE HERO (inner pages) ─────────────────── */
.page-hero {
  position:relative; height:58vh; min-height:400px;
  display:flex; align-items:flex-end; padding-bottom:60px;
  overflow:hidden; margin-top:72px;
}
.page-hero-bg { position:absolute; inset:0; }
.page-hero-bg img { width:100%; height:100%; object-fit:cover; }
.page-hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(26,61,28,.9) 0%, rgba(26,61,28,.28) 100%);
}
.page-hero-content { position:relative; z-index:1; color:white; }
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:13px; color:rgba(255,255,255,.7); margin-bottom:14px; }
.breadcrumb a { color:var(--secondary); }
.breadcrumb a:hover { color:white; }
.page-hero-content h1 { font-size:clamp(30px,5vw,56px); font-weight:700; margin-bottom:10px; }
.page-hero-content p { font-size:17px; opacity:.85; max-width:520px; }

/* ── ROOM DETAIL PAGE ────────────────────────── */
.room-detail { padding:72px 0; }
.room-detail-grid { display:grid; grid-template-columns:1fr 380px; gap:48px; align-items:start; }
.gallery-main { border-radius:var(--radius); overflow:hidden; height:420px; margin-bottom:14px; }
.gallery-main img { width:100%; height:100%; object-fit:cover; }
.gallery-thumbs { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; }
.gallery-thumbs img { width:100%; height:78px; object-fit:cover; border-radius:8px; cursor:pointer; opacity:.65; transition:var(--transition); }
.gallery-thumbs img:hover,.gallery-thumbs img.active { opacity:1; box-shadow:0 0 0 2px var(--primary); }
.room-info h2 { font-size:30px; margin-bottom:14px; }
.room-info > p { font-size:15px; color:var(--text-light); line-height:1.8; margin-bottom:24px; }
.room-specs { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:30px; }
.spec-item { display:flex; align-items:center; gap:12px; padding:14px; background:var(--bg); border-radius:10px; border:1px solid var(--border); }
.spec-icon { font-size:22px; }
.spec-label { font-size:11px; color:var(--text-light); text-transform:uppercase; letter-spacing:1px; }
.spec-value { font-weight:600; font-size:15px; }
.room-detail-amenities { margin-bottom:28px; }
.room-detail-amenities h4 { font-size:16px; margin-bottom:14px; }
.amenity-list { display:flex; flex-direction:column; gap:10px; }
.amenity-row { display:flex; align-items:center; gap:10px; font-size:14px; color:var(--text-light); }
.amenity-row::before {
  content:'✓'; width:22px; height:22px; background:#dcfce7; color:#16a34a;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700; flex-shrink:0;
}

/* Booking card */
.booking-card {
  background:white; border-radius:var(--radius); box-shadow:var(--shadow-hover);
  border:1px solid var(--border); padding:28px; position:sticky; top:90px;
}
.price-display { text-align:center; padding:20px; background:var(--secondary); border-radius:10px; margin-bottom:22px; }
.price-from { font-size:12px; color:var(--accent); text-transform:uppercase; letter-spacing:1px; }
.price-amount { font-family:'Playfair Display',serif; font-size:36px; font-weight:700; color:var(--primary); line-height:1; margin:4px 0; }
.price-note { font-size:13px; color:var(--accent); }
.booking-amenities { display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }
.book-btn {
  display:flex; align-items:center; justify-content:center; gap:10px; width:100%;
  background:#25D366; color:white; padding:15px; border-radius:10px;
  font-weight:700; font-size:16px; transition:var(--transition);
  margin-bottom:10px; text-decoration:none;
}
.book-btn:hover { background:#1da851; transform:translateY(-2px); box-shadow:0 8px 20px rgba(37,211,102,.35); }
.book-btn-alt {
  display:flex; align-items:center; justify-content:center; gap:8px; width:100%;
  background:var(--primary); color:white; padding:13px; border-radius:10px;
  font-weight:600; font-size:15px; transition:var(--transition); text-decoration:none;
}
.book-btn-alt:hover { background:var(--primary-dark); }

/* ── GALLERY PAGE ────────────────────────────── */
.gallery-section { padding:72px 0; }
.gallery-filters { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:32px; }
.filter-btn {
  padding:8px 22px; border-radius:50px; font-size:14px; font-weight:500;
  border:2px solid var(--border); background:white; color:var(--text-light);
  cursor:pointer; transition:var(--transition);
}
.filter-btn.active,.filter-btn:hover { background:var(--primary); color:white; border-color:var(--primary); }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.gallery-item { border-radius:10px; overflow:hidden; cursor:pointer; position:relative; }
.gallery-item img { width:100%; height:240px; object-fit:cover; transition:transform .5s ease; }
.gallery-item:hover img { transform:scale(1.06); }
.gallery-item-label {
  position:absolute; bottom:0; left:0; right:0; padding:12px;
  background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 100%);
  color:white; font-size:13px; font-weight:500;
  transform:translateY(100%); transition:var(--transition);
}
.gallery-item:hover .gallery-item-label { transform:translateY(0); }

/* Lightbox */
.lightbox {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,.92);
  z-index:9000; align-items:center; justify-content:center;
}
.lightbox.open { display:flex; }
.lightbox-img { max-width:90vw; max-height:88vh; object-fit:contain; border-radius:8px; }
.lightbox-close {
  position:absolute; top:20px; right:20px; background:rgba(255,255,255,.15);
  border:none; color:white; font-size:28px; width:48px; height:48px;
  border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center;
  transition:var(--transition);
}
.lightbox-close:hover { background:rgba(255,255,255,.3); }

/* ── FACILITIES ──────────────────────────────── */
.facility-block { margin-bottom:56px; }
.facility-block:last-child { margin-bottom:0; }
.facility-inner { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
.facility-inner.reverse { direction:rtl; }
.facility-inner.reverse > * { direction:ltr; }
.facility-img-wrap { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-hover); }
.facility-img-wrap img { width:100%; height:380px; object-fit:cover; }
.facility-text h3 { font-size:28px; margin-bottom:14px; }
.facility-text p { font-size:15px; color:var(--text-light); line-height:1.8; margin-bottom:22px; }
.facility-features { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.ff-item { display:flex; align-items:center; gap:8px; font-size:14px; color:var(--text-light); padding:10px 12px; background:var(--bg); border-radius:8px; border:1px solid var(--border); }
.ff-item .ff-icon { font-size:18px; }

/* ── CONTACT PAGE ────────────────────────────── */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.contact-intro h3 { font-size:28px; margin-bottom:14px; }
.contact-intro p { font-size:15px; color:var(--text-light); line-height:1.8; margin-bottom:28px; }
.contact-cards { display:flex; flex-direction:column; gap:16px; margin-bottom:28px; }
.contact-card { display:flex; gap:16px; padding:20px; background:white; border-radius:var(--radius); box-shadow:var(--shadow); border:1px solid var(--border); }
.cc-icon { width:48px; height:48px; background:var(--secondary); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:22px; flex-shrink:0; }
.cc-content h4 { font-size:15px; margin-bottom:4px; }
.cc-content p { font-size:14px; color:var(--text-light); line-height:1.5; }
.contact-form-card { background:white; border-radius:var(--radius); padding:36px; box-shadow:var(--shadow); border:1px solid var(--border); }
.contact-form-card h3 { font-size:22px; margin-bottom:24px; }
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-size:13px; font-weight:600; margin-bottom:7px; color:var(--text); }
.form-group input,.form-group select,.form-group textarea {
  width:100%; padding:12px 15px; border:2px solid var(--border); border-radius:9px;
  font-size:14px; font-family:'Inter',sans-serif; color:var(--text);
  background:var(--bg); transition:var(--transition); outline:none;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:var(--primary); background:white; }
.form-group textarea { resize:vertical; min-height:110px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.submit-btn {
  width:100%; padding:15px; background:var(--primary); color:white;
  border:none; border-radius:10px; font-size:15px; font-weight:700;
  cursor:pointer; transition:var(--transition); font-family:'Inter',sans-serif;
}
.submit-btn:hover { background:var(--primary-dark); transform:translateY(-2px); }
.map-wrap { border-radius:var(--radius); overflow:hidden; height:420px; margin-top:56px; }
.map-wrap iframe { width:100%; height:100%; border:none; }

/* ── FLOATING WA ─────────────────────────────── */
.wa-float {
  position:fixed; bottom:28px; right:28px; z-index:999;
  width:60px; height:60px; background:#25D366; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.5); transition:var(--transition);
  animation:waPulse 2.5s infinite;
}
@keyframes waPulse {
  0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}
  70%{box-shadow:0 0 0 14px rgba(37,211,102,0)}
  100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}
}
.wa-float:hover { transform:scale(1.12); }
.wa-float svg { width:32px; height:32px; fill:white; }

/* ── RELATED ROOMS ───────────────────────────── */
.related-section { background:var(--secondary); }

/* ── RESPONSIVE ──────────────────────────────── */
@media(max-width:1024px){
  .rooms-grid { grid-template-columns:repeat(2,1fr); }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .about-grid { gap:48px; }
}
@media(max-width:768px){
  section { padding:56px 0; }
  .nav-menu {
    display:none; position:fixed; top:72px; left:0; right:0;
    background:white; flex-direction:column; padding:16px;
    border-bottom:1px solid var(--border); box-shadow:0 4px 20px rgba(0,0,0,.1); gap:4px;
  }
  .nav-menu.open { display:flex; }
  .nav-item { width:100%; }
  .nav-link { width:100%; }
  .dropdown-menu { position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:none; background:var(--bg); display:none; min-width:unset; }
  .nav-item.open .dropdown-menu { display:block; }
  .hamburger { display:flex; }
  .about-grid { grid-template-columns:1fr; gap:40px; }
  .about-badge { right:0; }
  .rooms-grid { grid-template-columns:1fr; }
  .why-grid { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .room-detail-grid { grid-template-columns:1fr; }
  .booking-card { position:static; }
  .contact-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .footer-grid { grid-template-columns:1fr; gap:28px; }
  .features-list { grid-template-columns:1fr; }
  .room-specs { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .facility-inner,.facility-inner.reverse { grid-template-columns:1fr; direction:ltr; }
  .facility-features { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .stats-grid { grid-template-columns:repeat(2,1fr); gap:20px; }
  .gallery-thumbs { grid-template-columns:repeat(4,1fr); }
}
@media(max-width:480px){
  .gallery-grid { grid-template-columns:1fr; }
  .hero-actions,.cta-actions { flex-direction:column; align-items:flex-start; }
  .cta-actions { align-items:center; }
  .stats-grid { grid-template-columns:1fr 1fr; }
}
