/* ===== KKH Residency — static styles ===== */
:root{
  --bg-primary:#0C0F0A;
  --bg-surface:#141810;
  --bg-elevated:#1C2118;
  --accent-green:#2D6A4F;
  --accent-green-h:#3A8A65;
  --accent-gold:#C9A84C;
  --accent-gold-dim:#7A6230;
  --text-primary:#F2EDE4;
  --text-secondary:#9A9488;
  --border:rgba(242,237,228,0.08);
  --wa-green:#25D366;
  --fab-bottom:32px;
}
*,*::before,*::after{box-sizing:border-box;border-color:var(--border);}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--bg-primary);color:var(--text-primary);
  font-family:"Inter",sans-serif;font-weight:300;-webkit-font-smoothing:antialiased;
  line-height:1.5;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;background:none;border:0;color:inherit;cursor:pointer;}
ul{list-style:none;margin:0;padding:0;}
iframe{border:0;}

h1,h2,h3,h4{font-family:"Playfair Display",serif;margin:0;}

.container{max-width:1400px;margin:0 auto;width:100%;}
.container.narrow{max-width:800px;}

.italic{font-style:italic;font-weight:400;}
.gold{color:var(--accent-gold);}
.center{text-align:center;}
.mb-3{margin-bottom:12px;}
.mb-5{margin-bottom:20px;}
.max-w-620{max-width:620px;}
.max-w-700{max-width:700px;}

.eyebrow{
  font-size:11px;font-weight:700;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--accent-gold);
  margin-bottom:16px;
}
.h2{
  font-family:"Playfair Display",serif;font-weight:600;line-height:1.1;
  font-size:clamp(32px,4vw,54px);
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 24px;font-size:12px;font-weight:600;letter-spacing:0.08em;
  text-transform:uppercase;border-radius:2px;transition:all .25s ease;
  border:1px solid transparent;cursor:pointer;line-height:1;
}
.btn.sm{padding:12px 20px;font-size:12px;}
.btn.full{width:100%;}
.btn-green{background:var(--accent-green);color:var(--text-primary);}
.btn-green:hover{opacity:.9;}
.btn-outline{border-color:rgba(242,237,228,0.25);color:var(--text-primary);}
.btn-outline:hover{background:rgba(255,255,255,0.05);}
.btn-white{background:#fff;color:var(--accent-green);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,.25);}
.btn-ghost-white{border-color:rgba(255,255,255,.5);color:#fff;}
.btn-wa{background:var(--wa-green);color:#fff;}
.ico{flex:0 0 auto;}

/* ===== Nav ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(12,15,10,0.88);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  padding:20px 48px;transition:padding .3s ease;
}
.nav.scrolled{padding:14px 48px;}
.nav-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;}
.brand{font-family:"Playfair Display",serif;font-size:24px;font-weight:600;letter-spacing:-.01em;}
.brand-italic{color:var(--accent-gold);font-style:italic;font-weight:400;}
.nav-links{display:none;align-items:center;gap:36px;}
.nav-links a{font-size:13px;font-weight:500;color:var(--text-secondary);transition:color .2s;}
.nav-links a:hover{color:var(--text-primary);}
.nav-links .btn{margin-left:0;}
.menu-btn{display:inline-flex;padding:8px;color:var(--text-primary);}
@media(min-width:1024px){
  .nav-links{display:flex;}
  .menu-btn{display:none;}
}
@media(max-width:768px){
  .nav{padding:16px 20px;}
  .nav.scrolled{padding:12px 20px;}
}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:100;background:var(--bg-primary);
  display:none;flex-direction:column;
}
.mobile-menu.open{display:flex;animation:fadein .2s ease;}
@keyframes fadein{from{opacity:0;}to{opacity:1;}}
.mobile-menu-top{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border);}
.mobile-menu-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;}
.mm-link{font-family:"Playfair Display",serif;font-size:30px;}
.mm-ctas{display:flex;flex-direction:column;gap:12px;padding-top:24px;width:256px;}

/* ===== Hero ===== */
.hero{
  position:relative;width:100%;height:100vh;min-height:680px;
  overflow:hidden;background:#0c0f0a;
}
.hero-bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  object-position:center 30%;
  animation:heroZoom 8s ease-out both;
}
@keyframes heroZoom{from{transform:scale(1.08);}to{transform:scale(1);}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(12,15,10,.96) 0%,rgba(12,15,10,.55) 45%,rgba(12,15,10,.25) 75%,rgba(12,15,10,.55) 100%);
}
.hero-content{position:absolute;left:0;right:0;bottom:0;padding:0 48px 80px;z-index:10;}
@media(max-width:768px){.hero-content{padding:0 20px 64px;}}
.hero-title{
  font-family:"Playfair Display",serif;font-weight:600;line-height:1;letter-spacing:-.02em;
  font-size:clamp(40px,8vw,88px);
}
.hero-sub{
  margin-top:24px;font-size:16px;line-height:1.6;max-width:540px;
  color:var(--text-secondary);
}
.tag-row{margin-top:28px;display:flex;flex-wrap:wrap;gap:8px;}
.tag{
  padding:6px 12px;font-size:11px;font-weight:500;letter-spacing:.02em;
  border:1px solid rgba(242,237,228,.18);color:var(--text-secondary);border-radius:2px;
}
.cta-row{margin-top:36px;display:flex;flex-wrap:wrap;gap:12px;}

/* reveal animations */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease;}
.reveal.in{opacity:1;transform:none;}
.reveal-up{opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease;}
.reveal-up.in{opacity:1;transform:none;}

/* ===== Strip ===== */
.strip{overflow:hidden;background:var(--accent-green);}
.strip-track{display:flex;white-space:nowrap;width:max-content;animation:marquee 30s linear infinite;padding:14px 0;}
.strip-track span{padding:0 24px;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;display:inline-flex;align-items:center;gap:12px;}
.strip-track .dot{opacity:.5;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ===== Sections ===== */
.section{padding:60px 20px;}
@media(min-width:768px){.section{padding:100px 48px;}}
.surface{background:var(--bg-surface);}
.grid-2{display:grid;grid-template-columns:1fr;gap:48px;align-items:center;}
@media(min-width:768px){.grid-2{grid-template-columns:1fr 1fr;gap:80px;}}

/* ===== About ===== */
.about-images{position:relative;height:420px;}
@media(min-width:768px){.about-images{height:520px;}}
.about-img-a{position:absolute;top:0;left:0;width:80%;height:80%;object-fit:cover;border-radius:2px;}
.about-img-b{position:absolute;bottom:0;right:0;width:55%;height:50%;object-fit:cover;border-radius:2px;border:4px solid var(--bg-primary);}
.rating-badge{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;
  text-align:center;padding:20px 24px;background:var(--accent-gold);color:var(--bg-primary);
  border-radius:2px;box-shadow:0 8px 32px rgba(0,0,0,.5);
}
.rating-num{font-family:"Playfair Display",serif;font-size:30px;font-weight:600;line-height:1;}
.rating-label{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-top:6px;}
.about-grid > div:last-child .h2{margin-bottom:28px;}
.lead{display:flex;flex-direction:column;gap:20px;max-width:520px;font-size:17px;line-height:1.8;font-weight:300;color:var(--text-secondary);}
.lead p{margin:0;}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px 24px;margin-top:48px;}
.stat{padding-left:18px;border-left:2px solid var(--accent-gold);}
.stat-n{font-family:"Playfair Display",serif;font-size:32px;line-height:1;}
.stat-l{margin-top:8px;font-size:12px;font-weight:500;color:var(--text-secondary);}

/* ===== Rooms ===== */
.rooms-head{display:flex;flex-direction:column;gap:24px;margin-bottom:48px;}
@media(min-width:768px){.rooms-head{flex-direction:row;align-items:flex-end;justify-content:space-between;}}
.rooms-sub{max-width:300px;font-size:14px;color:var(--text-secondary);}
@media(min-width:768px){.rooms-sub{text-align:right;}}
.rooms-grid{display:grid;grid-template-columns:1fr;gap:2px;}
@media(min-width:768px){.rooms-grid{grid-template-columns:1fr 1fr;}}
.rooms-stack{display:grid;grid-template-rows:1fr 1fr;gap:2px;}
.room-card{
  position:relative;overflow:hidden;display:block;min-height:320px;
}
.room-card.room-tall{min-height:640px;}
.room-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s ease;}
.room-card:hover img{transform:scale(1.04);}
.room-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(12,15,10,.95) 0%,rgba(12,15,10,.3) 55%,transparent 100%);}
.room-content{position:absolute;left:0;right:0;bottom:0;padding:32px;}
@media(max-width:768px){.room-content{padding:28px;}}
.badge{display:inline-block;margin-bottom:16px;padding:4px 12px;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-gold);border:1px solid var(--accent-gold);border-radius:2px;}
.room-title{font-family:"Playfair Display",serif;font-size:32px;margin-bottom:8px;}
@media(max-width:768px){.room-title{font-size:24px;}}
.room-desc{font-size:13px;line-height:1.6;margin:0 0 12px;color:var(--text-secondary);transition:all .5s ease;}
.room-features{font-size:11px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:20px;color:var(--accent-gold-dim);}
.room-cta{
  display:inline-flex;align-items:center;gap:8px;padding:10px 16px;
  font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  background:var(--accent-green);border-radius:2px;color:#fff;
  transition:all .5s ease;
}
@media(min-width:768px){
  .room-desc{opacity:0;transform:translateY(8px);}
  .room-card:hover .room-desc{opacity:1;transform:none;}
  .room-cta{opacity:0;transform:translateY(8px);}
  .room-card:hover .room-cta{opacity:1;transform:none;}
}

.apartment-block{display:grid;grid-template-columns:1fr;gap:2px;margin-top:2px;background:var(--bg-elevated);}
@media(min-width:768px){.apartment-block{grid-template-columns:1.1fr 1fr;}}
.apt-img{position:relative;min-height:360px;overflow:hidden;}
.apt-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.apt-body{padding:32px;}
@media(min-width:768px){.apt-body{padding:48px;}}
.apt-title{font-family:"Playfair Display",serif;font-size:36px;margin-bottom:20px;}
.apt-desc{font-size:15px;line-height:1.7;font-weight:300;margin:0 0 24px;color:var(--text-secondary);}
.apt-list{display:flex;flex-direction:column;gap:8px;font-size:14px;margin-bottom:28px;color:var(--text-secondary);}

/* ===== Amenities ===== */
.amen-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-top:56px;}
@media(min-width:768px){.amen-grid{grid-template-columns:repeat(3,1fr);}}
@media(min-width:1024px){.amen-grid{grid-template-columns:repeat(4,1fr);}}
.amen{padding:36px 28px;background:var(--bg-surface);transition:background .3s ease;cursor:default;}
.amen:hover{background:var(--bg-elevated);}
.amen-ico{font-size:28px;line-height:1;margin-bottom:14px;color:var(--accent-gold);}
.amen-name{font-size:14px;font-weight:600;margin-bottom:6px;}
.amen-detail{font-size:12px;font-weight:300;color:var(--text-secondary);}

/* ===== Why ===== */
.why-grid{display:grid;grid-template-columns:1fr;gap:40px;margin-top:56px;}
@media(min-width:640px){.why-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:1024px){.why-grid{grid-template-columns:repeat(4,1fr);}}
.why-n{font-family:"Playfair Display",serif;font-size:64px;line-height:1;color:var(--bg-elevated);}
.why-bar{width:32px;height:2px;margin:20px 0;background:var(--accent-gold);}
.why-t{font-size:17px;font-weight:600;margin-bottom:12px;}
.why-b{font-size:14px;line-height:1.7;font-weight:300;margin:0;color:var(--text-secondary);}

/* ===== Gallery ===== */
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;margin-top:56px;}
@media(min-width:768px){.gallery-grid{grid-template-columns:repeat(3,1fr);}}
.g-item{position:relative;overflow:hidden;cursor:pointer;display:block;padding:0;border:0;background:transparent;}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.g-item:hover img{transform:scale(1.05);}
.g-item-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;background:rgba(0,0,0,.35);transition:opacity .25s;}
.g-item:hover .g-item-overlay{opacity:1;}
.g-zoom{display:grid;place-items:center;width:52px;height:52px;border-radius:50%;background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:20px;}

.lightbox{
  position:fixed;inset:0;z-index:200;display:none;
  align-items:center;justify-content:center;padding:24px;
  background:rgba(0,0,0,.96);
}
.lightbox.open{display:flex;animation:fadein .2s ease;}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;}
.lb-close{position:absolute;top:24px;right:24px;color:#fff;font-size:30px;width:48px;height:48px;display:grid;place-items:center;}

/* ===== Reviews ===== */
.reviews-grid{display:grid;grid-template-columns:1fr;gap:2px;margin-top:56px;}
@media(min-width:768px){.reviews-grid{grid-template-columns:repeat(3,1fr);}}
.review{padding:36px;background:var(--bg-elevated);border-top:2px solid transparent;transition:border-color .3s;}
.review:hover{border-top-color:var(--accent-gold);}
.stars{letter-spacing:2px;margin-bottom:20px;color:var(--accent-gold);}
.review-q{font-family:"Playfair Display",serif;font-style:italic;font-size:15px;line-height:1.7;margin:0 0 24px;}
.review-a{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);}
.review-t{font-size:11px;margin-top:4px;color:var(--accent-gold-dim);}

/* ===== Location ===== */
.loc-grid{align-items:flex-start;}
.loc-p{font-size:16px;line-height:1.8;font-weight:300;max-width:520px;color:var(--text-secondary);margin:0 0 32px;}
.loc-info{padding-top:28px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:20px;}
.loc-row{display:flex;gap:16px;font-size:15px;line-height:1.6;font-weight:300;color:var(--text-secondary);}
.loc-row strong{display:block;color:var(--text-primary);}
.loc-ico{flex-shrink:0;margin-top:4px;color:var(--accent-gold);}
.loc-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px;}
.map-wrap{height:420px;border:1px solid var(--border);border-radius:2px;overflow:hidden;}
.map-wrap iframe{width:100%;height:100%;filter:grayscale(.4) invert(.92) hue-rotate(180deg);}
.distance-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:2px;}
.dist{text-align:center;padding:20px 12px;background:var(--bg-elevated);}
.dist-n{font-family:"Playfair Display",serif;font-size:28px;color:var(--accent-gold);}
@media(max-width:768px){.dist-n{font-size:22px;}}
.dist-l{font-size:11px;margin-top:4px;color:var(--text-secondary);}

/* ===== FAQ ===== */
.faq{margin-top:0;}
.faq-item{border-bottom:1px solid var(--border);}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:24px 0;text-align:left;font-size:16px;font-weight:500;
  transition:color .25s;
}
.faq-q:hover{color:var(--accent-gold);}
.faq-toggle{
  flex-shrink:0;width:28px;height:28px;display:grid;place-items:center;border-radius:50%;
  border:1px solid var(--border);color:var(--accent-gold);
  transition:transform .3s;
}
.faq-item.open .faq-toggle{transform:rotate(45deg);}
.faq-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s ease;}
.faq-item.open .faq-body{grid-template-rows:1fr;}
.faq-body > div{overflow:hidden;}
.faq-a{padding-bottom:24px;font-size:14px;line-height:1.8;font-weight:300;max-width:680px;color:var(--text-secondary);margin:0;}

/* ===== CTA Banner ===== */
.cta-banner{padding:64px 20px;background:var(--accent-green);}
@media(min-width:768px){.cta-banner{padding:80px 48px;}}
.grid-cta{display:grid;grid-template-columns:1fr;gap:40px;align-items:center;color:#fff;}
@media(min-width:768px){.grid-cta{grid-template-columns:1fr auto;gap:64px;}}
.cta-eyebrow{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-bottom:12px;color:rgba(255,255,255,.6);}
.cta-h{font-family:"Playfair Display",serif;font-weight:600;line-height:1.1;font-size:clamp(30px,4vw,48px);}
.cta-p{margin:20px 0 0;max-width:480px;font-size:16px;line-height:1.7;font-weight:300;color:rgba(255,255,255,.78);}
.cta-actions{display:flex;flex-direction:column;gap:12px;}

/* ===== Footer ===== */
.footer{padding:64px 20px 32px;background:#080A07;}
@media(min-width:768px){.footer{padding:64px 48px 32px;}}
.footer-grid{display:grid;grid-template-columns:1fr;gap:40px;}
@media(min-width:640px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:1024px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;}}
.footer-brand{font-family:"Playfair Display",serif;font-size:22px;margin-bottom:16px;}
.footer-p{font-size:13px;font-weight:300;max-width:260px;margin:0 0 24px;color:var(--text-secondary);}
.footer-contact{display:flex;flex-direction:column;gap:10px;font-size:13px;color:var(--text-secondary);}
.fc-link{display:flex;align-items:center;gap:10px;transition:color .25s;}
.fc-link.static{align-items:flex-start;}
.fc-link:hover{color:var(--accent-gold);}
.footer-list{display:flex;flex-direction:column;gap:10px;}
.footer-list a{font-size:13px;font-weight:300;color:var(--text-secondary);transition:color .2s;}
.footer-list a:hover{color:var(--accent-gold);}
.footer-tag{margin-top:16px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-gold-dim);}
.footer-bottom{margin-top:56px;padding-top:28px;display:flex;flex-direction:column;gap:12px;justify-content:space-between;font-size:12px;border-top:1px solid var(--border);color:var(--text-secondary);}
@media(min-width:768px){.footer-bottom{flex-direction:row;}}

/* ===== Floating ===== */
.fab{
  position:fixed;bottom:var(--fab-bottom);right:24px;z-index:90;
  display:grid;place-items:center;width:56px;height:56px;border-radius:50%;
  color:#fff;background:#25D366;box-shadow:0 4px 24px rgba(37,211,102,.45);
  transition:transform .25s,bottom .5s;
}
.fab:hover{transform:scale(1.1);}

.sticky-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:80;
  background:rgba(12,15,10,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--border);padding:12px 16px;
  transform:translateY(100%);transition:transform .5s ease;
}
.sticky-bar.show{transform:translateY(0);}
.sticky-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.sticky-text{font-size:13px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
@media(max-width:640px){.sticky-text{font-size:12px;}}
.sticky-text .muted{color:var(--text-secondary);}
.sticky-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.hide-sm{display:inline;}
.show-sm{display:none;}
@media(max-width:640px){
  .hide-sm{display:none;}
  .show-sm{display:inline;}
}
