/* =====================================================
   Zuri Estates — Public Website CSS
   ===================================================== */
:root{
  --gold:#C9A84C; --gold-l:#E8C97A; --gold-d:#9B7A2E;
  --deep:#0D1117; --charcoal:#1A1F2E; --slate:#2C3347;
  --cream:#FAF8F3; --warm:#F5F0E8;
  --text:#1A1A2E; --mid:#4A4A6A; --light:#8A8AA0;
  --success:#10B981; --danger:#EF4444; --info:#3B82F6;
  --r:16px; --rs:8px;
  --heading:'Cormorant Garamond',serif;
  --body:'DM Sans',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--cream);color:var(--text);overflow-x:hidden}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--deep)}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:3px}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* ── NAV ── */
#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 60px;display:flex;align-items:center;justify-content:space-between;transition:all .4s ease}
#navbar.scrolled{background:rgba(13,17,23,.96);backdrop-filter:blur(20px);padding:14px 60px;box-shadow:0 4px 30px rgba(0,0,0,.4)}
.nav-logo{display:flex;align-items:center;gap:12px}
.nav-logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--gold),var(--gold-d));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}
.nav-logo-text{font-family:var(--heading);font-size:22px;font-weight:600;color:white;letter-spacing:1px}
.nav-logo-text span{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none}
.nav-links a{color:rgba(255,255,255,.82);font-size:12px;font-weight:500;letter-spacing:.5px;transition:color .3s;text-transform:uppercase}
.nav-links a:hover{color:var(--gold)}
.nav-cta{background:linear-gradient(135deg,var(--gold),var(--gold-d));color:white!important;padding:10px 22px;border-radius:6px;font-weight:700!important;transition:transform .2s,box-shadow .2s!important}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,.4)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:4px}
.nav-toggle span{display:block;width:22px;height:2px;background:white;border-radius:2px;transition:all .3s}

/* ── HERO ── */
#hero{min-height:100vh;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--deep)}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;animation:hzoom 22s ease-in-out infinite alternate}
@keyframes hzoom{from{transform:scale(1)}to{transform:scale(1.06)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(13,17,23,.88) 0%,rgba(13,17,23,.38) 50%,rgba(13,17,23,.82) 100%)}
.hero-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.particle{position:absolute;width:2px;height:2px;background:var(--gold);border-radius:50%;animation:pfloat linear infinite;opacity:0}
@keyframes pfloat{0%{transform:translateY(100vh);opacity:0}10%{opacity:.7}90%{opacity:.7}100%{transform:translateY(-100px) translateX(40px);opacity:0}}
.hero-content{position:relative;z-index:2;text-align:center;max-width:920px;padding:0 30px;padding-top:80px;animation:hreveal 1.2s ease forwards}
@keyframes hreveal{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.3);padding:7px 18px;border-radius:30px;color:var(--gold-l);font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;margin-bottom:24px}
.hero-title{font-family:var(--heading);font-size:clamp(44px,7vw,86px);color:white;font-weight:300;line-height:1.02;margin-bottom:20px;letter-spacing:-1px}
.hero-title em{font-style:italic;color:var(--gold)}
.hero-subtitle{color:rgba(255,255,255,.62);font-size:clamp(15px,2vw,19px);font-weight:300;line-height:1.7;max-width:640px;margin:0 auto 40px}

/* ── HERO SEARCH ── */
.hero-search{background:rgba(255,255,255,.96);backdrop-filter:blur(20px);border-radius:12px;padding:18px 20px;display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;max-width:880px;margin:0 auto 44px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.hero-search-group{flex:1;min-width:140px}
.hero-search-group label{display:block;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--mid);margin-bottom:6px}
.hero-search-group select,.hero-search-group input{width:100%;padding:10px 12px;border:1px solid #e8ebf2;border-radius:8px;font-family:var(--body);font-size:13px;color:var(--text);outline:none;background:white;transition:border-color .2s}
.hero-search-group select:focus,.hero-search-group input:focus{border-color:var(--gold)}
.hero-search-btn{padding:12px 28px;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:white;border:none;border-radius:8px;font-family:var(--body);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:8px;white-space:nowrap;transition:transform .2s,box-shadow .2s}
.hero-search-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,.4)}

/* ── HERO STATS ── */
.hero-stats{display:flex;justify-content:center;gap:48px;flex-wrap:wrap}
.hero-stat-num{font-family:var(--heading);font-size:38px;font-weight:600;color:var(--gold-l);line-height:1}
.hero-stat-label{font-size:11px;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:1px;margin-top:4px}

/* ── LOCATIONS STRIP ── */
.locations-strip{background:var(--deep);padding:16px 60px;display:flex;align-items:center;gap:12px;overflow-x:auto;border-bottom:1px solid rgba(255,255,255,.07)}
.locations-label{color:rgba(255,255,255,.3);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;white-space:nowrap}
.location-chip{display:flex;align-items:center;gap:6px;padding:7px 16px;border-radius:20px;border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.55);font-size:12px;font-weight:500;white-space:nowrap;transition:all .2s;cursor:pointer}
.location-chip:hover,.location-chip.active{background:rgba(201,168,76,.15);border-color:rgba(201,168,76,.35);color:var(--gold-l)}

/* ── SECTIONS ── */
section{padding:80px 60px}
.section-tag{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--gold-d);margin-bottom:12px}
.section-title{font-family:var(--heading);font-size:clamp(32px,4vw,48px);font-weight:300;line-height:1.1;color:var(--text);margin-bottom:16px}
.section-subtitle{color:var(--mid);font-size:15px;line-height:1.7;max-width:540px}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:16px}
.view-all-btn{display:inline-flex;align-items:center;gap:7px;color:var(--gold-d);font-size:13px;font-weight:600;border:1px solid var(--gold-d);padding:9px 18px;border-radius:7px;transition:all .2s}
.view-all-btn:hover{background:var(--gold-d);color:white}

/* ── PROPERTY CARDS ── */
.properties-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.property-card{border-radius:var(--r);overflow:hidden;background:white;box-shadow:0 4px 20px rgba(0,0,0,.08);transition:transform .3s,box-shadow .3s;cursor:pointer}
.property-card:hover{transform:translateY(-6px);box-shadow:0 16px 50px rgba(0,0,0,.16)}
.property-card.featured{grid-column:span 2}
.property-img{position:relative;height:240px;overflow:hidden}
.property-card.featured .property-img{height:340px}
.property-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.property-card:hover .property-img img{transform:scale(1.04)}
.property-badges{position:absolute;top:14px;left:14px;display:flex;gap:6px;flex-wrap:wrap}
.badge{padding:4px 10px;border-radius:5px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.badge-sale{background:var(--gold);color:white}
.badge-rent{background:var(--info);color:white}
.badge-premium{background:var(--deep);color:var(--gold-l)}
.badge-new{background:var(--success);color:white}
.property-like{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.property-like i{color:#ccc;font-size:14px;transition:color .2s}
.property-like.liked i,.property-like:hover i{color:#e74c3c}
.property-price-overlay{position:absolute;bottom:14px;left:14px}
.property-price{font-family:var(--heading);font-size:22px;font-weight:600;color:white;text-shadow:0 2px 8px rgba(0,0,0,.6)}
.property-price-sub{font-size:11px;color:rgba(255,255,255,.7)}
.property-body{padding:18px}
.property-name{font-family:var(--heading);font-size:18px;font-weight:600;margin-bottom:5px}
.property-location{font-size:12px;color:var(--light);display:flex;align-items:center;gap:5px;margin-bottom:12px}
.property-location i{color:var(--gold);font-size:11px}
.property-specs{display:flex;gap:14px;flex-wrap:wrap}
.spec{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--mid)}
.spec i{color:var(--gold-d);font-size:12px}

/* ── ALL PROPERTIES LIST ── */
.properties-list{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.property-card-sm{border-radius:14px;overflow:hidden;background:white;box-shadow:0 2px 14px rgba(0,0,0,.07);transition:transform .25s,box-shadow .25s;cursor:pointer}
.property-card-sm:hover{transform:translateY(-4px);box-shadow:0 10px 35px rgba(0,0,0,.13)}

/* ── SEARCH SECTION ── */
#search-section{background:linear-gradient(135deg,var(--deep),var(--charcoal));text-align:center}
.search-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}
.search-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
.search-field{text-align:left}
.search-field label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.5);margin-bottom:7px}
.search-field select,.search-field input{width:100%;padding:12px 14px;border:1px solid rgba(255,255,255,.15);border-radius:8px;font-family:var(--body);font-size:13px;color:white;background:rgba(255,255,255,.08);outline:none;transition:.2s}
.search-field select:focus,.search-field input:focus{border-color:var(--gold)}
.search-field select option{background:var(--charcoal);color:white}
.search-actions{display:flex;justify-content:center;gap:12px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:white;border:none;border-radius:8px;font-family:var(--body);font-size:14px;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,.4)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.7);border-radius:8px;font-family:var(--body);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;background:none}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}

/* ── NEIGHBOURHOODS ── */
#neighborhoods{background:var(--warm)}
.neighborhoods-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.neighborhood-card{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3;cursor:pointer;display:block}
.neighborhood-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.neighborhood-card:hover img{transform:scale(1.06)}
.neighborhood-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,17,23,.8) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:18px}
.neighborhood-name{font-family:var(--heading);font-size:22px;font-weight:600;color:white}
.neighborhood-count{font-size:12px;color:rgba(255,255,255,.65);margin-top:3px}
.neighborhood-city{position:absolute;top:12px;right:12px;background:rgba(201,168,76,.85);color:white;font-size:10px;font-weight:700;padding:3px 10px;border-radius:4px;text-transform:uppercase}

/* ── CURRENCY CONVERTER ── */
#currency{background:var(--deep)}
#currency .section-title{color:white}
.converter-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:40px;max-width:680px;margin:0 auto}
.converter-title{font-family:var(--heading);font-size:28px;color:white;font-weight:400;margin-bottom:6px}
.converter-sub{color:rgba(255,255,255,.4);font-size:13px;margin-bottom:28px}
.converter-row{display:flex;gap:14px;align-items:flex-end;margin-bottom:20px;flex-wrap:wrap}
.conv-field{flex:1;min-width:160px}
.conv-field label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.4);margin-bottom:7px}
.conv-field input,.conv-field select{width:100%;padding:12px 14px;border:1px solid rgba(255,255,255,.15);border-radius:8px;font-family:var(--body);font-size:14px;color:white;background:rgba(255,255,255,.08);outline:none;transition:.2s}
.conv-field input:focus,.conv-field select:focus{border-color:var(--gold)}
.conv-field select option{background:var(--charcoal)}
.conv-swap{width:42px;height:42px;border-radius:50%;background:rgba(201,168,76,.15);border:1px solid rgba(201,168,76,.3);color:var(--gold);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .2s;flex-shrink:0}
.conv-swap:hover{background:rgba(201,168,76,.3);transform:rotate(180deg)}
.conv-result{text-align:center;margin-bottom:22px}
.conv-result-label{font-size:13px;color:rgba(255,255,255,.4);margin-bottom:6px}
.conv-result-value{font-family:var(--heading);font-size:44px;font-weight:600;color:var(--gold-l);line-height:1}
.conv-rate{font-size:12px;color:rgba(255,255,255,.3);margin-top:7px}
.common-amounts{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:center}
.amount-chip{padding:6px 14px;border-radius:20px;border:1px solid rgba(201,168,76,.25);color:var(--gold-l);font-size:11px;font-weight:600;background:none;cursor:pointer;transition:all .2s;font-family:var(--body)}
.amount-chip:hover{background:rgba(201,168,76,.15)}

/* ── WHY US ── */
#why-us{background:white}
.why-us-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.why-us-img{position:relative;border-radius:20px;overflow:hidden}
.why-us-img img{width:100%;height:460px;object-fit:cover}
.why-us-img-badge{position:absolute;bottom:24px;left:24px;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:white;padding:16px 20px;border-radius:12px}
.why-us-img-badge .num{font-family:var(--heading);font-size:40px;font-weight:700;line-height:1}
.why-us-img-badge .lbl{font-size:12px;opacity:.8;margin-top:2px}
.features-list{display:flex;flex-direction:column;gap:22px;margin-top:28px}
.feature-item{display:flex;gap:16px;align-items:flex-start}
.feature-icon{width:46px;height:46px;border-radius:12px;background:rgba(201,168,76,.1);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--gold-d);flex-shrink:0}
.feature-body h4{font-size:14px;font-weight:700;margin-bottom:4px}
.feature-body p{font-size:13px;color:var(--mid);line-height:1.6}

/* ── TESTIMONIALS ── */
#testimonials{background:var(--deep)}
#testimonials .section-tag{color:var(--gold-l)}
#testimonials .section-title{color:white}
.testimonials-track{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.testimonial-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:28px;position:relative}
.testimonial-quote{font-family:var(--heading);font-size:64px;color:var(--gold);line-height:.8;margin-bottom:10px;opacity:.4}
.stars{color:var(--gold);font-size:14px;letter-spacing:2px;margin-bottom:12px}
.testimonial-text{font-size:14px;color:rgba(255,255,255,.7);line-height:1.75;font-style:italic;margin-bottom:20px}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid rgba(201,168,76,.4)}
.testimonial-name{font-size:13px;font-weight:700;color:white}
.testimonial-role{font-size:11px;color:rgba(255,255,255,.4);margin-top:2px}

/* ── AGENT CTA ── */
.agent-cta{background:linear-gradient(135deg,var(--gold-d),var(--gold));padding:48px 60px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px}
.agent-cta h2{font-family:var(--heading);font-size:36px;font-weight:400;color:white;margin-bottom:8px}
.agent-cta p{color:rgba(255,255,255,.75);font-size:15px}
.agent-cta-btn{display:inline-flex;align-items:center;gap:9px;padding:15px 32px;background:white;color:var(--gold-d);border-radius:8px;font-weight:700;font-size:14px;white-space:nowrap;transition:transform .2s,box-shadow .2s}
.agent-cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}

/* ── CONTACT ── */
#contact{background:white}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-info .section-subtitle{margin-bottom:28px}
.contact-details{display:flex;flex-direction:column;gap:16px}
.contact-item{display:flex;align-items:flex-start;gap:14px}
.contact-icon{width:42px;height:42px;border-radius:10px;background:rgba(201,168,76,.1);display:flex;align-items:center;justify-content:center;color:var(--gold-d);font-size:16px;flex-shrink:0}
.contact-item-text small{display:block;font-size:10px;color:var(--light);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}
.contact-item-text span{font-size:14px;font-weight:500}
.contact-form{background:var(--warm);border-radius:20px;padding:32px}
.form-title{font-family:var(--heading);font-size:28px;font-weight:600;margin-bottom:22px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--mid);margin-bottom:7px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;border:1px solid #e8ebf2;border-radius:8px;font-family:var(--body);font-size:13px;color:var(--text);outline:none;background:white;transition:.2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.1)}
.form-group textarea{resize:vertical;min-height:100px}
.form-submit{width:100%;padding:14px;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:white;border:none;border-radius:8px;font-family:var(--body);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;transition:transform .2s,box-shadow .2s}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(201,168,76,.4)}

/* ── FOOTER ── */
footer{background:var(--deep);padding:60px 60px 28px;border-top:1px solid rgba(255,255,255,.06)}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand p{color:rgba(255,255,255,.4);font-size:13px;line-height:1.7;margin:14px 0 20px}
.footer-socials{display:flex;gap:10px}
.social-btn{width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);font-size:14px;transition:all .2s}
.social-btn:hover{background:rgba(201,168,76,.15);border-color:rgba(201,168,76,.3);color:var(--gold-l)}
.footer-col h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:rgba(255,255,255,.3);margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-col ul a{font-size:13px;color:rgba(255,255,255,.45);transition:color .2s}
.footer-col ul a:hover{color:var(--gold-l)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,.25)}

/* ── CHAT WIDGET ── */
.chat-fab{position:fixed;bottom:28px;right:28px;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-d));border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:22px;color:white;z-index:900;box-shadow:0 8px 30px rgba(201,168,76,.5);transition:transform .2s,box-shadow .2s}
.chat-fab:hover{transform:scale(1.08);box-shadow:0 12px 40px rgba(201,168,76,.6)}
.badge-dot{position:absolute;top:6px;right:6px;width:10px;height:10px;background:var(--success);border-radius:50%;border:2px solid white}
.chat-panel{position:fixed;bottom:100px;right:28px;width:340px;background:white;border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.2);z-index:900;overflow:hidden;display:none;animation:chatPop .3s ease;flex-direction:column}
.chat-panel.open{display:flex}
@keyframes chatPop{from{opacity:0;transform:scale(.92) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}
.chat-header{background:linear-gradient(135deg,var(--deep),var(--charcoal));padding:16px 18px;display:flex;align-items:center;gap:12px}
.chat-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-d));display:flex;align-items:center;justify-content:center;font-size:16px}
.chat-header-info h4{color:white;font-size:14px;font-weight:700}
.chat-header-info p{color:rgba(255,255,255,.5);font-size:11px}
.chat-online{width:8px;height:8px;background:var(--success);border-radius:50%;margin-left:auto;flex-shrink:0}
.chat-messages{height:240px;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:8px;background:#f8f9fc}
.chat-msg{max-width:80%;padding:10px 13px;border-radius:12px;font-size:13px;line-height:1.5}
.chat-msg.bot{background:white;color:var(--text);align-self:flex-start;border-radius:3px 12px 12px 12px;box-shadow:0 1px 4px rgba(0,0,0,.08)}
.chat-msg.user{background:linear-gradient(135deg,var(--gold),var(--gold-d));color:white;align-self:flex-end;border-radius:12px 3px 12px 12px}
.chat-input-row{display:flex;gap:8px;padding:12px;border-top:1px solid #f0f0f0}
.chat-input{flex:1;padding:10px 12px;border:1px solid #e8ebf2;border-radius:8px;font-family:var(--body);font-size:13px;outline:none;transition:.2s}
.chat-input:focus{border-color:var(--gold)}
.chat-send{width:38px;height:38px;border-radius:8px;background:linear-gradient(135deg,var(--gold),var(--gold-d));border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:white;font-size:14px;transition:.2s}
.chat-send:hover{transform:scale(1.05)}

/* ── WHATSAPP FLOAT ── */
.wa-fab{position:fixed;bottom:98px;right:28px;width:50px;height:50px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;color:white;font-size:22px;z-index:900;box-shadow:0 6px 20px rgba(37,211,102,.45);transition:transform .2s}
.wa-fab:hover{transform:scale(1.1)}

/* ── PROPERTY MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);z-index:1100;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:white;border-radius:20px;max-width:760px;width:100%;max-height:88vh;overflow-y:auto;animation:mPop .3s ease}
@keyframes mPop{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
.modal-img-gallery{position:relative}
.modal-img-gallery img#modalMainImg{width:100%;height:340px;object-fit:cover}
.modal-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.5);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:white;font-size:16px;z-index:10;transition:.2s}
.modal-close:hover{background:rgba(0,0,0,.8)}
.modal-thumbnails{display:flex;gap:7px;padding:10px 14px;background:#f9f9f9;overflow-x:auto}
.modal-thumb{width:64px;height:46px;border-radius:6px;overflow:hidden;cursor:pointer;opacity:.6;border:2px solid transparent;transition:.2s;flex-shrink:0}
.modal-thumb.active,.modal-thumb:hover{opacity:1;border-color:var(--gold)}
.modal-thumb img{width:100%;height:100%;object-fit:cover}
.modal-body{padding:26px}
.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.modal-title{font-family:var(--heading);font-size:26px;font-weight:600}
.modal-price{font-family:var(--heading);font-size:24px;font-weight:600;color:var(--gold-d);white-space:nowrap}
.modal-specs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px;padding:14px;background:var(--warm);border-radius:10px}
.modal-spec{text-align:center;flex:1;min-width:70px}
.modal-spec-num{font-family:var(--heading);font-size:22px;font-weight:600;color:var(--text)}
.modal-spec-lbl{font-size:10px;color:var(--light);text-transform:uppercase;letter-spacing:1px;margin-top:2px}
.modal-desc{font-size:14px;color:var(--mid);line-height:1.75;margin-bottom:18px}
.modal-amenities{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.amenity{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;background:rgba(201,168,76,.08);font-size:12px;color:var(--gold-d);border:1px solid rgba(201,168,76,.2)}
.amenity i{font-size:11px}
.modal-actions{display:flex;gap:10px;flex-wrap:wrap}
.modal-btn-book{flex:1;padding:13px;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:white;border:none;border-radius:9px;font-family:var(--body);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:.2s}
.modal-btn-book:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(201,168,76,.4)}
.modal-btn-chat{padding:13px 20px;border:1px solid var(--gold-d);color:var(--gold-d);border-radius:9px;font-family:var(--body);font-size:14px;font-weight:600;cursor:pointer;background:none;display:flex;align-items:center;gap:7px;transition:.2s}
.modal-btn-chat:hover{background:rgba(201,168,76,.07)}

/* ── BOOKING MODAL ── */
#bookingModal .modal{max-width:520px}

/* ── TOAST ── */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(30px);background:var(--text);color:white;padding:12px 22px;border-radius:10px;font-size:13px;display:flex;align-items:center;gap:9px;z-index:2000;opacity:0;transition:all .35s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast i{color:var(--gold)}

/* ── BOOKING MODAL FORM ── */
#bookingModal .modal-body{padding:28px}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  section{padding:64px 40px}
  .properties-grid{grid-template-columns:1fr 1fr}
  .property-card.featured{grid-column:span 1}
  .footer-grid{grid-template-columns:1fr 1fr}
  .testimonials-track{grid-template-columns:1fr}
  .why-us-grid{grid-template-columns:1fr}
  .why-us-img{display:none}
}
@media(max-width:768px){
  section{padding:52px 20px}
  #navbar{padding:16px 20px}
  #navbar.scrolled{padding:12px 20px}
  .nav-links{display:none;flex-direction:column;position:fixed;top:64px;left:0;right:0;background:rgba(13,17,23,.98);padding:20px;gap:16px;border-top:1px solid rgba(255,255,255,.07)}
  .nav-links.open{display:flex}
  .nav-toggle{display:flex}
  .hero-search{flex-direction:column;margin:0 0 32px}
  .properties-grid,.properties-list,.neighborhoods-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .search-grid,.search-row{grid-template-columns:1fr}
  .hero-stats{gap:24px}
  .agent-cta{flex-direction:column;text-align:center}
  .locations-strip{padding:14px 20px}
  .chat-panel{width:calc(100vw - 40px);right:20px}
}
