/* ============================================================
   ResortWealth — Complete Stylesheet (Final Build)
   Theme: White/Cream luxury, Cormorant Garamond + DM Sans
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&family=DM+Mono:wght@300;400&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

:root{
  --bg:#FAFAF7;--bg2:#F3F0EA;--white:#FFFFFF;
  --gold:#C9A84C;--gold-dk:#9A7B2C;--gold-lt:#F7F1E3;--gold-line:rgba(201,168,76,.3);
  --ink:#191510;--ink2:#3D3328;--ink3:#7A6E64;--ink4:#B5A898;
  --border:#E5DFD5;--border2:#CFC7BA;
  --green:#2C7A50;--green-lt:#EAF5EF;--red:#A83232;
  --shadow-xs:0 1px 3px rgba(25,21,16,.05);--shadow-sm:0 2px 10px rgba(25,21,16,.07);
  --shadow:0 6px 28px rgba(25,21,16,.10);--shadow-lg:0 16px 56px rgba(25,21,16,.14);
  --serif:'Cormorant Garamond',Georgia,serif;--sans:'DM Sans',system-ui,sans-serif;--mono:'DM Mono',monospace;
  --nav-h:76px;--max-w:1240px;
}

body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.65;font-size:15px;overflow-x:hidden}
img{display:block;max-width:100%}a{color:inherit;text-decoration:none}
button{font-family:var(--sans);cursor:pointer}ul,ol{list-style:none}
h1,h2,h3,h4,h5{font-family:var(--serif);line-height:1.1;color:var(--ink);font-weight:400}
section{padding:96px 5%}
.s-inner{max-width:var(--max-w);margin:0 auto}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 30px;font-size:13px;font-weight:500;letter-spacing:.06em;border:none;cursor:pointer;transition:all .22s;text-decoration:none;white-space:nowrap;font-family:var(--sans)}
.btn-gold{background:var(--gold);color:var(--ink)}.btn-gold:hover{background:#B8942A;transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.btn-outline{background:transparent;color:var(--gold-dk);border:1px solid var(--gold)}.btn-outline:hover{background:var(--gold-lt)}
.btn-dark{background:var(--ink);color:var(--white)}.btn-dark:hover{background:var(--ink2);transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.08);color:var(--white);border:1px solid rgba(255,255,255,.25)}.btn-ghost:hover{background:rgba(255,255,255,.18)}
.btn-sm{padding:10px 20px;font-size:12px}.btn-lg{padding:16px 36px;font-size:14px;letter-spacing:.08em}
.btn-full{width:100%;justify-content:center}

/* ── LABELS ── */
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.eyebrow::before{content:'';display:block;width:28px;height:1px;background:var(--gold)}
.eyebrow.center{justify-content:center}
.section-title{font-size:clamp(32px,4.5vw,52px);letter-spacing:-.3px;margin-bottom:14px}
.section-title em{font-style:italic;color:var(--gold-dk)}
.section-sub{font-size:16px;color:var(--ink3);max-width:520px;line-height:1.8}
.badge{display:inline-flex;align-items:center;gap:5px;font-size:9.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:4px 11px}
.badge-gold{background:var(--gold);color:var(--ink)}.badge-green{background:var(--green-lt);color:var(--green);border:1px solid rgba(44,122,80,.2)}
.badge-soft{background:var(--gold-lt);color:var(--gold-dk);border:1px solid var(--gold-line)}.badge-ink{background:var(--ink);color:var(--white)}
.fade-up{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:none}.fade-up.d1{transition-delay:.1s}.fade-up.d2{transition-delay:.2s}.fade-up.d3{transition-delay:.3s}.fade-up.d4{transition-delay:.4s}
.section-hd{margin-bottom:52px}.section-hd.center{text-align:center}.section-hd.center .eyebrow{justify-content:center}.section-hd.center .section-sub{margin:0 auto}
.section-hd.split{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px}.section-hd.split .section-title{margin-bottom:0}

/* ══════════════════════════════════════════════
   NAV
══════════════════════════════════════════════ */
#nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-h);background:transparent;border-bottom:1px solid transparent;transition:background .35s,border-color .35s,box-shadow .35s}
#nav.scrolled{background:rgba(250,250,247,.97);border-color:var(--border);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 1px 12px rgba(25,21,16,.06)}
.nav-inner{max-width:var(--max-w);margin:0 auto;padding:0 5%;height:100%;display:flex;align-items:center}
.nav-logo{font-family:var(--serif);font-size:22px;color:var(--white);text-decoration:none;letter-spacing:-.2px;margin-right:auto;transition:color .3s;flex-shrink:0}
#nav.scrolled .nav-logo{color:var(--ink)}.nav-logo-dot{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none;margin:0;padding:0}
.nav-links li a{font-size:12.5px;font-weight:500;letter-spacing:.03em;color:rgba(255,255,255,.75);text-decoration:none;padding:6px 0;position:relative;transition:color .2s}
#nav.scrolled .nav-links li a{color:var(--ink3)}.nav-links li a:hover{color:var(--gold)}#nav.scrolled .nav-links li a:hover{color:var(--gold-dk)}
.nav-links li a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transition:transform .25s}.nav-links li a:hover::after{transform:scaleX(1)}
.nav-phone{display:flex;align-items:center;gap:7px;font-size:12.5px;color:rgba(255,255,255,.6);text-decoration:none;margin-left:24px;transition:color .2s;white-space:nowrap}
#nav.scrolled .nav-phone{color:var(--ink3)}.nav-phone:hover{color:var(--gold)}
.nav-phone-dot{width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0;animation:dotpulse 2.5s infinite}
@keyframes dotpulse{0%,100%{box-shadow:0 0 0 0 rgba(44,122,80,.35)}50%{box-shadow:0 0 0 4px rgba(44,122,80,.0)}}
.nav-cta{display:inline-flex;align-items:center;margin-left:16px;padding:9px 20px;background:var(--gold);color:var(--ink);font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.04em;text-decoration:none;transition:background .2s,transform .15s;white-space:nowrap}
.nav-cta:hover{background:#B8942A;transform:translateY(-1px)}
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;background:none;border:none;padding:8px;margin-left:10px;cursor:pointer}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--white);border-radius:1px;transition:transform .3s,opacity .2s,background .3s}
#nav.scrolled .nav-burger span{background:var(--ink)}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}.nav-burger.open span:nth-child(2){opacity:0}.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mob-menu{position:fixed;top:0;right:0;bottom:0;width:min(320px,85vw);background:var(--white);z-index:1100;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:-6px 0 24px rgba(25,21,16,.1)}
.mob-menu.open{transform:translateX(0)}
.mob-menu-top{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}
.mob-close{width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink3);transition:all .2s}
.mob-close:hover{background:var(--bg2);color:var(--ink)}
.mob-links{list-style:none;margin:0;padding:8px 0;flex:1;overflow-y:auto}
.mob-links li a{display:block;padding:15px 24px;font-family:var(--serif);font-size:20px;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--border);transition:background .15s}
.mob-links li:last-child a{border-bottom:none}.mob-links li a:hover{background:var(--bg2);color:var(--gold-dk)}
.mob-bottom{padding:16px 20px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}
.mob-phone{display:flex;align-items:center;justify-content:center;gap:7px;font-size:13px;color:var(--ink3);text-decoration:none;padding:6px 0}.mob-phone:hover{color:var(--gold-dk)}
.mob-overlay{position:fixed;inset:0;z-index:1050;background:rgba(25,21,16,.45);opacity:0;pointer-events:none;transition:opacity .3s}.mob-overlay.show{opacity:1;pointer-events:all}

/* ══════════════════════════════════════════════
   HERO — Image Slider (Homepage)
══════════════════════════════════════════════ */
.hero{position:relative;height:100vh;min-height:700px;display:flex;align-items:flex-end;padding:0 5% 80px;overflow:hidden}
.hero-slider{position:absolute;inset:0}.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease}.hero-slide.active{opacity:1}
.hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(12,8,3,.88) 0%,rgba(12,8,3,.45) 40%,rgba(12,8,3,.15) 100%)}
.slider-dots{position:absolute;bottom:28px;right:5%;z-index:5;display:flex;gap:8px}
.slider-dot{width:24px;height:2px;background:rgba(255,255,255,.3);cursor:pointer;transition:all .25s}.slider-dot.active{background:var(--gold);width:42px}
.slider-counter{position:absolute;top:calc(var(--nav-h) + 24px);right:5%;z-index:5;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.4);letter-spacing:.1em}
.hero-content{position:relative;z-index:4;max-width:760px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.hero-eyebrow::before{content:'';width:32px;height:1px;background:var(--gold)}
.hero h1{font-family:var(--serif);font-size:clamp(44px,6.5vw,82px);font-weight:300;letter-spacing:-.5px;color:var(--white);margin-bottom:22px;line-height:1.05}
.hero h1 em{font-style:italic;color:var(--gold);font-weight:400}
.hero-sub{font-size:16px;color:rgba(255,255,255,.68);line-height:1.8;max-width:520px;margin-bottom:36px}
.hero-stats{display:flex;align-items:stretch;margin-bottom:36px}
.hero-stat{padding:14px 24px;border:1px solid rgba(255,255,255,.15)}.hero-stat+.hero-stat{border-left:none}
.hero-stat .val{font-family:var(--serif);font-size:28px;color:var(--gold);line-height:1}
.hero-stat .lbl{font-size:9.5px;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.1em;margin-top:5px}
.hero-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.hero-trust{font-size:11px;color:rgba(255,255,255,.4);margin-top:18px;display:flex;gap:18px;flex-wrap:wrap}
.hero-trust-item{display:flex;align-items:center;gap:5px}.hero-trust-item::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--green)}

/* ── BRAND BAR ── */
.brand-bar{background:var(--white);border-bottom:1px solid var(--border);padding:14px 5%}
.brand-bar-inner{max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;gap:24px;overflow-x:auto}
.brand-bar-label{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink4);white-space:nowrap;flex-shrink:0}
.brand-sep{width:1px;height:18px;background:var(--border);flex-shrink:0}
.brand-pills{display:flex;align-items:center;gap:8px}.brand-pill{font-size:11px;font-weight:500;color:var(--ink3);border:1px solid var(--border);padding:5px 13px;white-space:nowrap}
.media-names{display:flex;align-items:center;gap:18px;margin-left:auto;flex-shrink:0}.media-name{font-size:11px;font-style:italic;color:var(--ink4);white-space:nowrap}

/* ── WHY INVEST ── */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.why-list{display:flex;flex-direction:column}
.why-item{padding:28px 0;border-bottom:1px solid var(--border);display:flex;gap:24px;align-items:flex-start}.why-item:first-child{padding-top:0}.why-item:last-child{border-bottom:none}
.why-num{font-family:var(--mono);font-size:11px;color:var(--gold-dk);width:28px;flex-shrink:0;padding-top:3px}
.why-body h3{font-family:var(--serif);font-size:21px;margin-bottom:8px}.why-body p{font-size:14px;color:var(--ink3);line-height:1.75}.why-body strong{color:var(--ink);font-weight:500}
.why-visual-panel{position:sticky;top:calc(var(--nav-h) + 20px);background:var(--white);border:1px solid var(--border);box-shadow:var(--shadow)}
.wvp-header{padding:22px 26px;border-bottom:1px solid var(--border)}.wvp-header h3{font-family:var(--serif);font-size:20px;margin-bottom:3px}.wvp-header p{font-size:12px;color:var(--ink3)}
.compare-table{width:100%;border-collapse:collapse}
.compare-table th{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink4);padding:11px 16px;font-weight:600;border-bottom:1px solid var(--border);text-align:left;background:var(--bg2)}.compare-table th:not(:first-child){text-align:center}
.compare-table td{padding:13px 16px;border-bottom:1px solid var(--border);font-size:13px;color:var(--ink3)}.compare-table td:not(:first-child){text-align:center;font-weight:600}.compare-table tr:last-child td{border-bottom:none}
.cmp-good{color:var(--green)}.cmp-bad{color:var(--red)}.col-resort{color:var(--gold-dk)!important}
.wvp-footer{padding:16px 26px;background:var(--gold-lt);border-top:1px solid var(--gold-line)}.wvp-footer p{font-size:11px;color:var(--ink3);line-height:1.7}

/* ── PROPERTY CARDS ── */
.props-section{background:var(--bg2)}
.prop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.prop-card{background:var(--white);display:block;text-decoration:none;color:inherit;overflow:hidden;box-shadow:var(--shadow-xs);transition:box-shadow .3s,transform .3s;position:relative}
.prop-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px)}
.prop-img{height:240px;position:relative;overflow:hidden;background:var(--bg2)}
.prop-img img{width:100%;height:100%;object-fit:cover;transition:transform .65s ease}.prop-card:hover .prop-img img{transform:scale(1.07)}
.prop-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(12,8,3,.6) 0%,transparent 55%)}
.prop-img-badges{position:absolute;top:14px;left:14px;display:flex;flex-direction:column;gap:5px}
.prop-img-brand{position:absolute;top:14px;right:14px}.prop-img-brand span{display:block;background:rgba(255,255,255,.94);font-size:9.5px;font-weight:600;letter-spacing:.06em;color:var(--ink2);padding:4px 10px}
.prop-img-loc{position:absolute;bottom:14px;left:14px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.75);display:flex;align-items:center;gap:5px}
.prop-loc-dot{width:4px;height:4px;border-radius:50%;background:var(--gold)}
.prop-body{padding:20px 20px 0}.prop-name{font-family:var(--serif);font-size:20px;font-weight:400;line-height:1.2;margin-bottom:6px;color:var(--ink)}
.prop-tagline{font-size:12px;color:var(--ink3);font-style:italic}
.prop-stats-row{display:flex;align-items:stretch;border-top:1px solid var(--border);margin-top:16px}
.prop-stat-item{flex:1;text-align:center;padding:14px 8px}.prop-stat-item+.prop-stat-item{border-left:1px solid var(--border)}
.psi-val{font-family:var(--serif);font-size:20px;color:var(--gold-dk)}.psi-key{font-size:9.5px;color:var(--ink4);text-transform:uppercase;letter-spacing:.1em;margin-top:2px}
.prop-link{display:flex;align-items:center;justify-content:space-between;padding:13px 20px;border-top:1px solid var(--border);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-dk);transition:background .2s}
.prop-link:hover{background:var(--gold-lt)}.prop-link-arrow{transition:transform .25s}.prop-card:hover .prop-link-arrow{transform:translateX(4px)}

/* ── CALCULATOR ── */
.calc-section{background:var(--white);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.calc-field{margin-bottom:30px}.calc-field label{display:block;font-size:10px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--ink3);margin-bottom:10px}
.range-val{font-family:var(--serif);font-size:34px;color:var(--gold-dk);margin-bottom:10px}
input[type=range]{width:100%;-webkit-appearance:none;height:2px;background:var(--border);outline:none;cursor:pointer}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--white);border:2px solid var(--gold);cursor:pointer;box-shadow:0 0 0 3px rgba(201,168,76,.15)}
.range-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:11px;color:var(--ink4)}
.calc-selects{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.calc-select{width:100%;padding:11px 14px;border:1px solid var(--border);background:var(--bg2);color:var(--ink);font-family:var(--sans);font-size:13px;outline:none;cursor:pointer;appearance:none}.calc-select:focus{border-color:var(--gold)}
.calc-output{background:var(--bg2);border:1px solid var(--border);padding:36px;position:sticky;top:calc(var(--nav-h) + 20px)}
.calc-output-title{font-family:var(--serif);font-size:13px;color:var(--ink3);font-style:italic;margin-bottom:22px}
.year-tabs{display:flex;gap:0;margin-bottom:24px}
.year-tab{flex:1;padding:9px 0;text-align:center;border:1px solid var(--border);background:var(--white);color:var(--ink3);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.year-tab+.year-tab{border-left:none}.year-tab.active{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.calc-result-rows{display:flex;flex-direction:column;margin-bottom:22px}
.crr{display:flex;justify-content:space-between;align-items:center;padding:13px 0;border-bottom:1px solid var(--border)}.crr:last-child{border-bottom:none}
.crr-label{font-size:13px;color:var(--ink3)}.crr-val{font-family:var(--serif);font-size:19px;color:var(--ink)}
.crr.hl{background:var(--gold-lt);margin:0 -36px;padding:16px 36px;border:none;border-top:1px solid var(--gold-line);border-bottom:1px solid var(--gold-line)}.crr.hl .crr-val{font-size:26px;color:var(--gold-dk)}
.calc-note{font-size:11px;color:var(--ink4);line-height:1.7;border-top:1px solid var(--border);padding-top:14px}

/* ── HOW IT WORKS ── */
.steps-row{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.steps-row::before{content:'';position:absolute;top:22px;left:calc(12.5% + 10px);right:calc(12.5% + 10px);height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 18px}
.step-num{width:44px;height:44px;border-radius:50%;background:var(--white);border:1px solid var(--gold-line);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:18px;color:var(--gold-dk);margin-bottom:20px;position:relative;z-index:1;box-shadow:var(--shadow-xs)}
.step-svg{width:30px;height:30px;margin-bottom:10px;opacity:.55}.step-svg svg{width:100%;height:100%;stroke:var(--gold-dk);fill:none;stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round}
.step h4{font-family:var(--serif);font-size:18px;margin-bottom:8px}.step p{font-size:13px;color:var(--ink3);line-height:1.7}

/* ── TESTIMONIALS ── */
.testi-bg{background:var(--bg2)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.testi-card{background:var(--white);padding:32px;border-top:2px solid var(--gold);box-shadow:var(--shadow-xs)}
.testi-mark{font-family:var(--serif);font-size:52px;color:var(--gold);line-height:.8;margin-bottom:12px;opacity:.3}
.testi-text{font-family:var(--serif);font-size:16px;color:var(--ink2);line-height:1.75;margin-bottom:22px;font-style:italic}
.testi-rule{width:32px;height:1px;background:var(--gold);margin-bottom:18px}
.testi-author{display:flex;align-items:center;gap:13px}
.testi-avatar{width:42px;height:42px;border-radius:50%;background:var(--gold-lt);border:1px solid var(--gold-line);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:16px;color:var(--gold-dk);flex-shrink:0}
.testi-name{font-size:14px;font-weight:600;color:var(--ink)}.testi-detail{font-size:11px;color:var(--ink3);margin-top:2px}
.testi-income{display:inline-block;background:var(--green-lt);color:var(--green);border:1px solid rgba(44,122,80,.2);padding:4px 10px;font-size:11px;font-weight:700;margin-top:11px;letter-spacing:.04em}

/* ── FAQ ── */
.faq-list{max-width:740px;margin:0 auto}.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;background:transparent;border:none;padding:20px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;cursor:pointer;text-align:left;font-family:var(--serif);font-size:18px;color:var(--ink)}
.faq-icon{width:22px;height:22px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px;color:var(--gold-dk);transition:transform .25s,background .25s}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--gold-lt);border-color:var(--gold-line)}
.faq-a{font-size:14px;color:var(--ink3);line-height:1.8;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .25s}.faq-item.open .faq-a{max-height:300px;padding-bottom:20px}

/* ── CTA SECTION ── */
.cta-section{background:var(--ink);position:relative;overflow:hidden}
.cta-pattern{position:absolute;inset:0;opacity:.04;background-image:linear-gradient(rgba(201,168,76,1) 1px,transparent 1px),linear-gradient(90deg,rgba(201,168,76,1) 1px,transparent 1px);background-size:60px 60px}
.cta-inner{position:relative;z-index:2;text-align:center;max-width:640px;margin:0 auto}
.cta-inner h2{font-size:clamp(32px,4vw,52px);color:var(--white);margin-bottom:14px}.cta-inner h2 em{color:var(--gold)}
.cta-inner p{font-size:16px;color:rgba(255,255,255,.55);line-height:1.8;margin-bottom:36px}
.lead-row{display:flex;gap:10px;max-width:520px;margin:0 auto 16px;flex-wrap:wrap}
.lead-input{flex:1;min-width:180px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);padding:13px 18px;font-family:var(--sans);font-size:14px;color:var(--white);outline:none;transition:border-color .2s}
.lead-input::placeholder{color:rgba(255,255,255,.3)}.lead-input:focus{border-color:var(--gold)}
.lead-trust-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.lead-trust-item{font-size:11px;color:rgba(255,255,255,.35);display:flex;align-items:center;gap:5px}.lead-trust-item::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--green)}

/* ── FOOTER ── */
footer{background:#0F0C09;color:rgba(255,255,255,.5);padding:64px 5% 32px}
.footer-inner{max-width:var(--max-w);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:52px;margin-bottom:52px}
.footer-logo{font-family:var(--serif);font-size:24px;color:var(--gold);margin-bottom:14px}
.footer-desc{font-size:13px;line-height:1.8;color:rgba(255,255,255,.38);max-width:260px;margin-bottom:22px}
.footer-socials{display:flex;gap:8px}
.social-btn{width:32px;height:32px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:12px;color:rgba(255,255,255,.38);cursor:pointer;transition:all .2s;text-decoration:none}.social-btn:hover{border-color:var(--gold);color:var(--gold)}
.footer-col h5{font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:18px}
.footer-col li{margin-bottom:10px}.footer-col a{font-size:13px;color:rgba(255,255,255,.38);text-decoration:none;transition:color .2s}.footer-col a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:11px}.footer-rera{font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.22)}

/* ── FLOAT WA / STICKY ── */
/* ── FLOAT WA (WhatsApp Button Desktop) ── */
.float-wa {
  position: fixed;
  bottom: 30px;
  right: 30px;
  z-index: 9999;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  border: none;
  background: #25D366;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(37, 211, 102, 0.4);
  transition: all 0.3s ease;
  text-decoration: none;
}

.float-wa svg {
  width: 32px;
  height: 32px;
  fill: white;
}

.float-wa-tip {
  position: absolute;
  right: 75px; 
  top: 50%;
  transform: translateY(-50%) translateX(10px);
  background: var(--ink);
  color: var(--white);
  font-size: 13px;
  font-weight: 500;
  padding: 8px 16px;
  border-radius: 6px;
  white-space: nowrap; /* Ye line text ko tootne se rokegi */
  opacity: 0;
  pointer-events: none;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(25, 21, 16, 0.15);
}

/* Tooltip ke aage chhota sa arrow */
.float-wa-tip::after {
  content: '';
  position: absolute;
  right: -5px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 6px solid var(--ink);
}

.float-wa:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 24px rgba(37, 211, 102, 0.5);
}

.float-wa:hover .float-wa-tip {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}

/* Sticky Bottom Bar */
.sticky-bottom{position:fixed;bottom:0;left:0;right:0;z-index:800;background:rgba(250,250,247,.98);backdrop-filter:blur(14px);border-top:1px solid var(--border);padding:12px 5%;display:flex;align-items:center;justify-content:space-between;gap:12px;transform:translateY(100%);transition:transform .3s}
.sticky-bottom.show{transform:translateY(0)}.sb-text{font-size:13px;color:var(--ink2)}.sb-text strong{color:var(--gold-dk)}
body.has-sticky{padding-bottom:56px}

/* ══════════════════════════════════════════════
   PROPERTY HERO (Single Page)
══════════════════════════════════════════════ */
.prop-hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;margin-top:var(--nav-h);overflow:hidden;background:#0A0705}
.prop-hero-img{position:absolute;inset:0;z-index:1}.prop-hero-img img{width:100%;height:100%;object-fit:cover;object-position:center}
.prop-hero-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(to top,rgba(8,5,2,.92) 0%,rgba(8,5,2,.65) 35%,rgba(8,5,2,.25) 65%,rgba(8,5,2,.10) 100%),linear-gradient(to right,rgba(8,5,2,.3) 0%,transparent 60%)}
.prop-hero-content{position:relative;z-index:3;width:100%;max-width:var(--max-w);margin:0 auto;padding:0 5% 56px}
.prop-breadcrumb{display:flex;align-items:center;gap:8px;font-size:11px;color:rgba(255,255,255,.45);margin-bottom:24px}
.prop-breadcrumb a{color:rgba(255,255,255,.45);text-decoration:none;transition:color .2s}.prop-breadcrumb a:hover{color:var(--gold)}.prop-breadcrumb span{opacity:.35}
.prop-hero-badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.prop-hero h1{font-family:var(--serif);font-size:clamp(32px,5vw,56px);font-weight:300;letter-spacing:-.3px;color:var(--white);margin-bottom:12px;line-height:1.1;max-width:700px}
.prop-hero h1 em{color:var(--gold);font-style:italic;font-weight:400}
.prop-hero-tagline{font-size:15px;color:rgba(255,255,255,.6);max-width:520px;line-height:1.75;margin-bottom:32px;font-style:italic}
.ph-stats{display:inline-flex;align-items:stretch;margin-bottom:32px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.04);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.ph-stat{padding:14px 22px;text-align:center;border-right:1px solid rgba(255,255,255,.12)}.ph-stat:last-child{border-right:none}
.ph-val{font-family:var(--serif);font-size:22px;color:var(--gold);line-height:1.15}
.ph-key{font-size:9px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.1em;margin-top:4px}
.prop-hero-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}

/* ── PROPERTY STICKY ── */
.prop-sticky{position:sticky;top:var(--nav-h);z-index:850;background:rgba(250,250,247,.98);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:12px 5%;display:flex;align-items:center;justify-content:space-between;gap:20px;transform:translateY(-120%);transition:transform .3s;flex-wrap:wrap}
.prop-sticky.visible{transform:translateY(0)}
.ps-info{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.ps-name{font-family:var(--serif);font-size:17px;color:var(--ink)}
.ps-meta{font-size:12px;color:var(--ink3)}.ps-meta strong{color:var(--gold-dk)}

/* ── PROPERTY TABS ── */
.prop-section-block{border-bottom:1px solid var(--border);padding-bottom:40px;margin-bottom:40px}
.prop-section-block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}

/* ── PROPERTY LAYOUT ── */
.prop-layout{display:grid;grid-template-columns:1fr 360px;gap:0;max-width:var(--max-w);margin:0 auto;padding:0 5%}
.prop-main{padding:48px 48px 48px 0;border-right:1px solid var(--border)}
.prop-sidebar{padding:32px 0 32px 40px;position:sticky;top:calc(var(--nav-h) + 56px);align-self:start}
.prop-section{margin-bottom:48px;padding-bottom:48px;border-bottom:1px solid var(--border)}.prop-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.prop-section h2{font-family:var(--serif);font-size:28px;margin-bottom:20px}.prop-section p{font-size:14px;color:var(--ink3);line-height:1.85;margin-bottom:14px}

/* Highlights */
.highlights-list{display:flex;flex-direction:column}
.highlight-item{padding:20px 0;border-bottom:1px solid var(--border);display:flex;gap:20px;align-items:flex-start}.highlight-item:first-child{padding-top:0}.highlight-item:last-child{border-bottom:none}
.hi-num{font-family:var(--mono);font-size:11px;color:var(--gold-dk);width:24px;flex-shrink:0;padding-top:2px}
.hi-title{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:5px}.hi-desc{font-size:13px;color:var(--ink3);line-height:1.7}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:200px 200px;gap:6px}
.gallery-img{overflow:hidden;background:var(--bg2)}.gallery-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}.gallery-img:hover img{transform:scale(1.05)}.gallery-img:first-child{grid-row:1/3}

/* Amenities */
.amenities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.amenity-tile{background:var(--white);padding:16px 14px;font-size:13px;color:var(--ink2);display:flex;align-items:center;gap:10px}

/* Units */
.unit-list{display:flex;flex-direction:column;border:1px solid var(--border)}
.unit-item{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:12px}.unit-item:last-child{border-bottom:none}
.unit-name{font-family:var(--serif);font-size:18px}.unit-size{font-size:12px;color:var(--ink3);margin-top:3px}
.unit-price{font-family:var(--serif);font-size:22px;color:var(--gold-dk)}.unit-income{font-size:11px;color:var(--green);margin-top:2px}

/* Enquiry card */
.enquiry-card{background:var(--white);border:1px solid var(--border);box-shadow:var(--shadow)}
.eq-header{padding:24px;border-bottom:1px solid var(--border)}.eq-header h3{font-family:var(--serif);font-size:22px;margin-bottom:4px}.eq-header p{font-size:13px;color:var(--ink3)}
.eq-body{padding:22px}
.eq-income-strip{background:var(--green-lt);border:1px solid rgba(44,122,80,.2);padding:14px;margin-bottom:18px}
.eq-income-label{font-size:10px;color:var(--green);text-transform:uppercase;letter-spacing:.12em;font-weight:600;margin-bottom:4px}
.eq-income-val{font-family:var(--serif);font-size:28px;color:var(--green)}.eq-income-sub{font-size:11px;color:var(--ink3);margin-top:2px}
.eq-field{margin-bottom:13px}.eq-field label{display:block;font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:6px}
.eq-input{width:100%;padding:11px 14px;border:1px solid var(--border);background:var(--bg2);color:var(--ink);font-family:var(--sans);font-size:13px;outline:none;transition:border-color .2s}.eq-input:focus{border-color:var(--gold);background:var(--white)}
.eq-footer{padding:14px;border-top:1px solid var(--border);background:var(--bg2)}.eq-footer p{font-size:11px;color:var(--ink4);line-height:1.75}
.quick-facts{background:var(--white);border:1px solid var(--border);margin-top:14px}
.qf-header{padding:13px 18px;border-bottom:1px solid var(--border);background:var(--bg2);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3)}
.qf-item{display:flex;justify-content:space-between;padding:11px 18px;border-bottom:1px solid var(--border);font-size:13px}.qf-item:last-child{border-bottom:none}
.qf-label{color:var(--ink3)}.qf-val{font-weight:600;color:var(--ink)}.qf-val.gold{color:var(--gold-dk)}

/* ── LISTING PAGE ── */
.listing-hero{padding:calc(var(--nav-h) + 52px) 5% 44px;background:var(--white);border-bottom:1px solid var(--border)}
.listing-filters{display:flex;gap:8px;margin-top:22px;flex-wrap:wrap}
.filter-btn{padding:8px 18px;border:1px solid var(--border);background:transparent;color:var(--ink3);font-size:12px;font-weight:500;letter-spacing:.04em;cursor:pointer;transition:all .2s}
.filter-btn.active{border-color:var(--gold);background:var(--gold-lt);color:var(--gold-dk)}.filter-btn:hover{border-color:var(--gold-dk)}

/* ══════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════ */
/* TABLET & MOBILE HEADER FIX */
@media(max-width:1024px){
  /* Force solid background & dark text on mobile/tablet to fix transparency issues */
  #nav { 
    background: var(--white) !important; 
    border-bottom: 1px solid var(--border);
    box-shadow: 0 1px 12px rgba(25,21,16,.04);
  }
  .nav-logo { color: var(--ink) !important; }
  .nav-burger span { background: var(--ink) !important; }

  /* Hide desktop elements */
  .nav-links, .nav-phone, .nav-cta { display:none!important; }
  .nav-burger { display:flex!important; margin-left:auto; }
  
  .why-grid{grid-template-columns:1fr}.why-visual-panel{position:static}
  .prop-grid{grid-template-columns:repeat(2,1fr)}
  .calc-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:repeat(2,1fr)}
  .prop-layout{grid-template-columns:1fr}.prop-main{border-right:none;padding-right:0}.prop-sidebar{position:static;padding-left:0; margin-top: 30px;}
  .footer-grid{grid-template-columns:1fr 1fr}
  .ph-stat{padding:12px 16px}.ph-val{font-size:19px}
  .prop-hero{min-height:85vh}
}
@media(max-width:768px){
  :root{--nav-h:62px}
  section{padding:64px 5%}
  .nav-links{display:none!important}.nav-phone{display:none!important}.nav-cta{display:none!important}.nav-burger{display:flex!important}
  .hero h1{font-size:40px}.hero-stats{display:none}
  .prop-grid{grid-template-columns:1fr}
  .steps-row{grid-template-columns:1fr 1fr}.steps-row::before{display:none}
  .testi-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .amenities-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}.gallery-img:first-child{grid-row:auto}
  /* PROPERTY HERO MOBILE */
  .prop-hero{min-height:auto;padding:0}
  .prop-hero-img{position:relative;height:45vh;min-height:260px}
  .prop-hero-overlay{background:linear-gradient(to top,rgba(8,5,2,.7) 0%,rgba(8,5,2,.1) 60%,transparent 100%)}
  .prop-hero-content{background:var(--bg);padding:28px 5% 36px}
  .prop-hero h1{color:var(--ink);font-size:28px}.prop-hero h1 em{color:var(--gold-dk)}
  .prop-hero-tagline{color:var(--ink3);font-size:14px;margin-bottom:22px}
  .prop-breadcrumb{color:var(--ink4);margin-bottom:16px}.prop-breadcrumb a{color:var(--ink4)}
  .ph-stats{display:grid;grid-template-columns:repeat(2,1fr);background:var(--white);border:1px solid var(--border);width:100%;backdrop-filter:none}
  .ph-stat{padding:14px 12px;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
  .ph-stat:nth-child(2n){border-right:none}.ph-stat:nth-last-child(-n+2){border-bottom:none}
  .ph-stats>.ph-stat:last-child:nth-child(odd){grid-column:1/-1;border-right:none}
  .ph-val{font-size:20px;color:var(--gold-dk)}.ph-key{color:var(--ink4)}
  .prop-hero-actions{flex-direction:column;align-items:stretch}
  .prop-hero-actions .btn{justify-content:center}
  .prop-hero-actions .btn-ghost{background:var(--white);color:var(--gold-dk);border:1px solid var(--gold)}
  .brand-bar-inner{gap:16px}.media-names{display:none}
}
@media(max-width:480px){
  .steps-row{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .lead-row{flex-direction:column}
  .calc-selects{grid-template-columns:1fr}
}

/* =======================================================
   HORIZONTAL SCROLL & MOBILE OVERFLOW FIXES
======================================================= */

/* 1. Strictly lock the viewport width for all devices */
html, body {
  overflow-x: hidden !important;
  width: 100%;
  max-width: 100vw;
  position: relative;
}

/* 2. Fix the Comparison Table breaking out on mobile */
.why-visual-panel {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch; /* Smooth swipe inside table if needed */
}

.compare-table {
  min-width: 480px; /* Force table to keep format, allows internal scrolling */
}

/* 3. Fix negative margins on Calculator Box on mobile screens */
@media (max-width: 768px) {
  .calc-output {
    padding: 24px 20px !important;
  }
  .crr.hl {
    margin: 0 -20px !important;
    padding: 16px 20px !important;
  }
}

/* =======================================================
   SINGLE PROPERTY PAGE: MOBILE UI FIXES
======================================================= */

@media(max-width: 768px) {
    /* 1. Force the Hero Section to stack vertically (Top to Bottom) */
    .prop-hero {
        display: flex !important;
        flex-direction: column !important; /* Fixes the split screen bug */
        min-height: auto !important;
        padding: 0 !important;
        background: var(--bg) !important;
    }

    /* 2. Set Image at the top with proper height */
    .prop-hero-img {
        position: relative !important;
        width: 100% !important;
        height: 40vh !important;
        min-height: 280px !important;
        order: 1 !important; /* Keep image on top */
    }

    /* 3. Confine the dark overlay ONLY to the image area */
    .prop-hero-overlay {
        height: 40vh !important;
        min-height: 280px !important;
        bottom: auto !important;
        background: linear-gradient(to top, rgba(8,5,2,0.6) 0%, transparent 60%) !important;
    }

    /* 4. Make content sit cleanly below the image */
    .prop-hero-content {
        position: relative !important;
        order: 2 !important; /* Keep text below image */
        width: 100% !important;
        background: var(--bg) !important;
        padding: 32px 5% 40px !important;
    }

    /* 5. Update Text Colors to be readable on the cream background */
    .prop-hero h1 { color: var(--ink) !important; font-size: 28px !important; margin-top: 12px !important; line-height: 1.2 !important; }
    .prop-hero h1 em { color: var(--gold-dk) !important; }
    .prop-hero-tagline { color: var(--ink3) !important; font-size: 14px !important; }
    .prop-breadcrumb, .prop-breadcrumb a { color: var(--ink4) !important; }

    /* 6. Fix Stats Grid Box layout */
    .ph-stats {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 1px !important;
        background: var(--border) !important;
        border: 1px solid var(--border) !important;
        width: 100% !important;
        backdrop-filter: none !important;
    }
    .ph-stat {
        background: var(--white) !important;
        border: none !important;
        padding: 16px 12px !important;
    }
    .ph-stat:last-child:nth-child(odd) {
        grid-column: 1 / -1 !important; /* Centers the odd box (like Land Area) perfectly */
    }
    .ph-val { color: var(--gold-dk) !important; font-size: 22px !important; }
    .ph-key { color: var(--ink4) !important; font-weight: 600 !important; }

    /* 7. Button Stacking & Design */
    .prop-hero-actions {
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        margin-top: 24px !important;
    }
    .prop-hero-actions .btn {
        width: 100% !important;
        justify-content: center !important;
    }
    .prop-hero-actions .btn-ghost {
        background: transparent !important;
        color: var(--gold-dk) !important;
        border: 1px solid var(--gold) !important;
    }

    /* 8. Fix Sticky Property Bar (so it doesn't look messy) */
    .prop-sticky {
        padding: 12px 5% !important;
        gap: 10px !important;
        flex-wrap: nowrap !important;
    }
    .ps-info { display: flex; flex-direction: column; gap: 2px !important; }
    .ps-name { font-size: 13px !important; font-weight: 600 !important; }
    .ps-meta:nth-child(3), .ps-meta:nth-child(4) { display: none !important; } /* Hide extra text to save space */

}
