/* Hotel Mahalok Palace — Luxury Landing Page */
:root{
  --bg:#0d0f1a;
  --bg-2:#141729;
  --card:#171a2e;
  --card-2:#1d2138;
  --border:#2a2f4a;
  --text:#f5efe1;
  --muted:#a8a698;
  --gold:#caa15a;
  --gold-light:#e8c98a;
  --gold-dark:#8a6a35;
  --gradient-gold:linear-gradient(135deg,var(--gold-dark),var(--gold),var(--gold-light));
  --shadow-luxe:0 30px 80px -20px rgba(202,161,90,.25);
  --radius:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -10%,rgba(202,161,90,.12),transparent 60%),
    radial-gradient(ellipse 60% 40% at 100% 100%,rgba(138,106,53,.08),transparent 60%);
  background-attachment:fixed;
}
h1,h2,h3,.font-display{font-family:'Playfair Display',Georgia,serif;letter-spacing:-.01em;font-weight:600}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1152px;margin:0 auto;padding:0 1rem}
.text-gold{
  background:var(--gradient-gold);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.muted{color:var(--muted)}
.btn{
  display:inline-block;padding:.85rem 1.75rem;border-radius:999px;
  font-weight:600;font-size:.95rem;cursor:pointer;border:none;
  transition:transform .25s,box-shadow .25s,background .25s,color .25s;
}
.btn-gold{background:var(--gradient-gold);color:#1a1525;box-shadow:var(--shadow-luxe)}
.btn-gold:hover{transform:scale(1.05)}
.btn-outline{border:1px solid rgba(202,161,90,.4);color:var(--gold);background:transparent}
.btn-outline:hover{background:var(--gold);color:#1a1525}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  border-bottom:1px solid rgba(42,47,74,.6);
  background:rgba(13,15,26,.7);backdrop-filter:blur(20px);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding-block:1rem}
.brand{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:600}
.nav{display:none;gap:1.75rem;font-size:.9rem;font-weight:500}
.nav a:hover{color:var(--gold)}
@media(min-width:768px){.nav{display:flex}}

/* Breadcrumb */
.breadcrumb{padding-top:1.5rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;color:var(--muted)}
.breadcrumb ol{display:flex;gap:.5rem;list-style:none}
.breadcrumb [aria-current]{color:var(--gold)}

/* Hero */
.hero{padding:3.5rem 0}
.hero-grid{display:grid;gap:3rem}
@media(min-width:768px){.hero{padding:6rem 0}.hero-grid{grid-template-columns:1fr 1fr;align-items:center}}
.eyebrow{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.3em;color:var(--gold);margin-bottom:1rem}
.hero h1{font-size:clamp(2.5rem,6vw,4.5rem);line-height:1.05}
.hero h1 .italic{font-style:italic;font-weight:500}
.hero p.lead{margin-top:1.5rem;max-width:28rem;font-size:1.125rem;color:var(--muted)}
.hero-actions{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.75rem}
.stats{margin-top:2.5rem;display:flex;align-items:center;gap:1.5rem;font-size:.875rem;color:var(--muted)}
.stat-num{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--gold)}
.stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em}
.divider-v{width:1px;height:2.5rem;background:var(--border)}
.hero-img-wrap{position:relative}
.hero-img-wrap::before{
  content:'';position:absolute;inset:-1rem;border-radius:24px;
  background:var(--gradient-gold);opacity:.3;filter:blur(40px);
}
.hero-img{position:relative;overflow:hidden;border-radius:24px;border:1px solid rgba(202,161,90,.2);box-shadow:var(--shadow-luxe)}
.hero-img img{width:100%;height:100%;object-fit:cover}

/* Section */
section{padding-block:5rem}
.section-head{text-align:center;margin-bottom:3.5rem}
.section-head h2{font-size:clamp(2rem,4vw,3rem);margin-top:1rem}
.ornament{display:flex;align-items:center;justify-content:center;gap:.75rem;color:rgba(202,161,90,.7)}
.ornament span{height:1px;width:3rem;background:linear-gradient(to right,transparent,rgba(202,161,90,.6))}
.ornament span+span{background:linear-gradient(to left,transparent,rgba(202,161,90,.6))}
.ornament svg{width:1rem;height:1rem;fill:currentColor}

/* Rooms */
.rooms-grid{display:grid;gap:2rem}
@media(min-width:768px){.rooms-grid{grid-template-columns:repeat(3,1fr)}}
.room-card{
  position:relative;overflow:hidden;border-radius:16px;
  border:1px solid var(--border);background:var(--card);
  transition:transform .3s,border-color .3s,box-shadow .3s;
}
.room-card:hover{transform:translateY(-8px);border-color:rgba(202,161,90,.5);box-shadow:var(--shadow-luxe)}
.room-card img{aspect-ratio:4/5;width:100%;object-fit:cover;transition:transform .7s}
.room-card:hover img{transform:scale(1.1)}
.room-overlay{
  position:absolute;inset:auto 0 0 0;padding:4rem 1.5rem 1.5rem;
  background:linear-gradient(to top,var(--card),rgba(23,26,46,.95),transparent);
}
.room-overlay h3{font-size:1.5rem}
.room-overlay p{margin-top:.5rem;font-size:.875rem;color:var(--muted)}

/* Amenities */
.amenities{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:768px){.amenities{grid-template-columns:repeat(4,1fr)}}
.amenity{
  border:1px solid var(--border);background:rgba(23,26,46,.6);
  padding:1.25rem;border-radius:12px;text-align:center;font-size:.875rem;font-weight:500;
  backdrop-filter:blur(8px);transition:border-color .25s,color .25s,background .25s;
}
.amenity:hover{border-color:rgba(202,161,90,.6);background:var(--card);color:var(--gold)}

/* Reviews */
.rating-line{margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:.75rem}
.stars{display:flex;gap:.125rem;color:var(--gold)}
.stars svg{width:1rem;height:1rem}
.reviews-grid{display:grid;gap:1.5rem}
@media(min-width:768px){.reviews-grid{grid-template-columns:1fr 1fr}}
.review{
  position:relative;border-radius:16px;border:1px solid var(--border);
  background:rgba(23,26,46,.8);padding:2rem;backdrop-filter:blur(8px);
  transition:border-color .3s,box-shadow .3s;
}
.review:hover{border-color:rgba(202,161,90,.4);box-shadow:var(--shadow-luxe)}
.review .quote-mark{
  position:absolute;top:-1rem;left:1.5rem;
  font-family:'Playfair Display',serif;font-size:3.75rem;line-height:1;
  color:rgba(202,161,90,.4);user-select:none;
}
.review h3{margin-top:.75rem;font-size:1.25rem;color:var(--gold)}
.review blockquote{margin-top:.75rem;color:rgba(245,239,225,.9)}
.review figcaption{
  margin-top:1.5rem;display:flex;align-items:center;gap:.75rem;
  border-top:1px solid rgba(42,47,74,.6);padding-top:1rem;
}
.avatar{
  width:2.75rem;height:2.75rem;border-radius:999px;display:flex;align-items:center;justify-content:center;
  background:var(--gradient-gold);color:#1a1525;font-family:'Playfair Display',serif;font-weight:600;
}
.review-name{font-weight:600}
.review-loc{font-size:.7rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted)}

/* About */
.about{max-width:48rem;margin:0 auto;text-align:center}
.about p{margin-top:1.5rem;font-size:1.125rem;color:var(--muted)}

/* Contact */
.contact-grid{display:grid;gap:2.5rem}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-card,.map-wrap{border-radius:16px;border:1px solid rgba(202,161,90,.2);overflow:hidden}
.contact-card{background:rgba(23,26,46,.6);padding:2rem;backdrop-filter:blur(8px)}
.contact-card h2{margin-top:1rem;font-size:2rem}
.contact-card address,.contact-card p{margin-top:1rem;font-size:1.05rem;font-style:normal}
.contact-card strong{color:var(--gold)}
.contact-card a:hover{text-decoration:underline}
.map-wrap{box-shadow:var(--shadow-luxe)}
.map-wrap iframe{width:100%;min-height:20rem;height:100%;border:0;display:block}

/* FAQ */
.faq{max-width:48rem;margin:0 auto}
.faq details{
  border:1px solid var(--border);background:rgba(23,26,46,.6);
  border-radius:12px;padding:1.25rem;margin-bottom:.75rem;backdrop-filter:blur(8px);
}
.faq details[open]{border-color:rgba(202,161,90,.5);box-shadow:var(--shadow-luxe)}
.faq summary{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary span:last-child{color:var(--gold);transition:transform .25s}
.faq details[open] summary span:last-child{transform:rotate(45deg)}
.faq details p{margin-top:.75rem;color:var(--muted)}

/* Footer */
.site-footer{border-top:1px solid rgba(42,47,74,.6);background:rgba(23,26,46,.5);padding-block:2.5rem;text-align:center;font-size:.875rem;color:var(--muted);backdrop-filter:blur(8px)}
.site-footer .brand-foot{font-family:'Playfair Display',serif;font-size:1.125rem}

/* Popup */
.popup{
  position:fixed;inset:0;z-index:100;display:none;
  align-items:center;justify-content:center;padding:1rem;
  animation:fadeIn .3s ease;
}
.popup.open{display:flex}
.popup-bg{position:absolute;inset:0;background:rgba(13,15,26,.8);backdrop-filter:blur(5px)}
.popup-box{
  position:relative;width:100%;max-width:28rem;overflow:hidden;
  border-radius:24px;border:1px solid rgba(202,161,90,.3);
  background:var(--card);box-shadow:var(--shadow-luxe);
  animation:scaleIn .35s cubic-bezier(.2,.9,.3,1.2);
}
.popup-close{
  position:absolute;top:1rem;right:1rem;z-index:20;
  width:2.25rem;height:2.25rem;border-radius:999px;
  border:1px solid rgba(42,47,74,.6);background:rgba(13,15,26,.6);
  color:rgba(245,239,225,.7);backdrop-filter:blur(8px);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.popup-close:hover{border-color:var(--gold);color:var(--gold)}
.popup-gallery{position:relative;height:14rem;overflow:hidden}
.popup-gallery img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity 1s ease,transform 4s ease-out;
}
.popup-gallery img.active{opacity:1;transform:scale(1.05)}
.popup-gallery .overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--card),rgba(23,26,46,.4),transparent)}
.popup-caption{
  position:absolute;bottom:.75rem;left:0;right:0;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
}
.popup-caption p{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.25em;color:var(--gold)}
.popup-dots{display:flex;gap:.375rem}
.popup-dots button{
  height:.375rem;width:.375rem;border-radius:999px;border:none;cursor:pointer;
  background:rgba(202,161,90,.4);transition:all .3s;
}
.popup-dots button.active{width:1.5rem;background:var(--gold)}
.popup-body{padding:1.75rem 2rem;text-align:center}
.popup-body h2{margin-top:.5rem;font-size:1.75rem}
.popup-body p{margin-top:.75rem;font-size:.875rem;color:var(--muted)}
.popup-actions{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}
@media(min-width:480px){.popup-actions{flex-direction:row;justify-content:center}}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
