/* ═══════════════════════════════════════════
   FIDUS REALTY — Premium Design System v2
   Navy #1A2744 | Forest #1C3829 | Gold #C4973A | Ivory #F5F0E8
   Cormorant Garamond (display) | Jost (body)
═══════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;overflow-x:clip}
body{font-family:'Jost',sans-serif;color:#3a3632;background:#fff;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

:root{
  --navy:#1A2744; --navy2:#111c38; --navy3:#243566;
  --forest:#1C3829;
  --gold:#C4973A; --gold2:#d4ab5a; --gold3:#e8c97a; --gold-dim:rgba(196,151,58,.15);
  --ivory:#F5F0E8; --ivory2:#EDE7DB; --ivory3:#f9f6f1;
  --g50:#f9f9f7; --g100:#f0ede8; --g200:#e0dbd3;
  --g400:#9e9890; --g600:#6b6560; --g800:#3a3632;
  --radius:12px; --radius-lg:18px;
  --shadow:0 4px 24px rgba(0,0,0,.10);
  --shadow-lg:0 16px 48px rgba(0,0,0,.16);
  --shadow-gold:0 8px 32px rgba(196,151,58,.22);
  --nav-h:72px; --max:1280px;
  --px:clamp(1.25rem,4vw,2.5rem);
  --t:.28s cubic-bezier(.4,0,.2,1);
}

@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes goldPulse{0%,100%{box-shadow:0 6px 24px rgba(37,211,102,.45)}50%{box-shadow:0 6px 32px rgba(37,211,102,.7),0 0 0 8px rgba(37,211,102,.1)}}
@keyframes lineGrow{from{width:0}to{width:48px}}

.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}.reveal-d4{transition-delay:.4s}

/* Typography */
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;line-height:1.18;color:var(--navy)}
h1{font-size:clamp(2.2rem,5.5vw,3.8rem);font-weight:600;letter-spacing:-.01em}
h2{font-size:clamp(1.8rem,3.8vw,2.8rem);font-weight:600}
h3{font-size:clamp(1.2rem,2.5vw,1.7rem);font-weight:500}
h4{font-size:1.1rem;font-weight:500}
p{color:var(--g600);line-height:1.78}

.lbl{display:inline-flex;align-items:center;gap:.5rem;font-size:.62rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:.65rem}
.lbl::before{content:'';display:inline-block;width:20px;height:1px;background:var(--gold);opacity:.7}

.gold-text{background:linear-gradient(90deg,var(--gold),var(--gold3),var(--gold));background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 4s linear infinite}

/* Layout */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--px)}
.section{padding:clamp(4rem,8vw,7rem) 0}
.section-sm{padding:clamp(2.5rem,5vw,4rem) 0}
.bg-ivory{background:var(--ivory)}.bg-navy{background:var(--navy)}.bg-dark{background:var(--navy2)}
.text-center{text-align:center}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.flex{display:flex}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}
.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}
.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
body{padding-top:var(--nav-h)}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);background:#fff;border-bottom:1px solid rgba(0,0,0,.08);z-index:1000;transition:background var(--t),box-shadow var(--t),border-color var(--t)}
.nav.scrolled{background:#fff;box-shadow:0 2px 20px rgba(0,0,0,.09);border-bottom-color:rgba(196,151,58,.25)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--max);margin:0 auto;padding:0 var(--px);height:100%}
/* ── Nav logo image ── */
.site-logo{display:inline-flex;align-items:center;text-decoration:none;line-height:1}
.nav-logo-img{width:auto;height:64px;max-height:64px;display:block;filter:none;transition:opacity var(--t)}
.site-logo:hover .nav-logo-img{opacity:.82}
@media(max-width:768px){.nav-logo-img{height:54px;max-height:54px}}
@media(max-width:480px){.nav-logo-img{height:46px;max-height:46px}}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{font-size:.78rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);transition:color var(--t);position:relative;padding-bottom:4px}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transition:width .35s ease}
.nav-links a:hover,.nav-links a.active{color:var(--gold)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.btn-nav{background:linear-gradient(135deg,var(--gold),var(--gold2)) !important;color:var(--navy) !important;padding:.45rem 1.3rem;font-weight:700 !important;box-shadow:0 4px 16px rgba(196,151,58,.3);transition:all var(--t) !important}
.btn-nav:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(196,151,58,.5) !important;color:var(--navy) !important}
.btn-nav::after{display:none !important}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--navy);transition:var(--t)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:'Jost',sans-serif;font-weight:500;font-size:.78rem;letter-spacing:.09em;text-transform:uppercase;padding:.75rem 2rem;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:all var(--t);white-space:nowrap}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--navy);border-color:transparent;box-shadow:0 4px 18px rgba(196,151,58,.3)}
.btn-gold:hover{background:linear-gradient(135deg,var(--gold2),var(--gold3));transform:translateY(-2px);box-shadow:var(--shadow-gold)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy3);transform:translateY(-2px);box-shadow:0 6px 20px rgba(26,39,68,.35)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--gold);border-color:var(--gold)}
.btn-ghost:hover{background:var(--gold);color:var(--navy);transform:translateY(-1px)}
.btn-sm{padding:.45rem 1.25rem;font-size:.72rem}
.btn-lg{padding:.9rem 2.4rem;font-size:.85rem}

/* Hero */
.hero{position:relative;height:calc(100vh - var(--nav-h));min-height:520px;max-height:860px;overflow:hidden;background:var(--navy2)}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover}
.hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(17,28,56,.88) 0%,rgba(17,28,56,.55) 55%,rgba(17,28,56,.2) 100%),linear-gradient(to top,rgba(17,28,56,.6) 0%,transparent 50%)}
.hero::before{content:'';position:absolute;bottom:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--forest),var(--gold),var(--navy3),var(--gold),var(--forest));z-index:5}
.hero-accent{position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:140px;background:linear-gradient(to bottom,transparent,var(--gold),transparent);z-index:4}
.hero-body{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;justify-content:center;padding:0 var(--px);max-width:calc(var(--max) + var(--px)*2);margin:0 auto;left:50%;transform:translateX(-50%);width:100%}
.hero-body .lbl{color:var(--gold);font-size:.65rem;letter-spacing:.25em;animation:fadeUp .8s ease both}
.hero-body h1{color:#fff;max-width:700px;text-shadow:0 2px 20px rgba(0,0,0,.3);margin-bottom:1rem;animation:fadeUp .9s .1s ease both}
.hero-body p{color:rgba(255,255,255,.75);max-width:480px;font-size:1.05rem;margin-bottom:2.25rem;animation:fadeUp .9s .2s ease both}
.hero-btns{animation:fadeUp .9s .3s ease both}
.hero-dots{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;gap:.6rem;z-index:5}
.hero-dot{width:28px;height:3px;background:rgba(255,255,255,.3);border:none;cursor:pointer;transition:all .4s ease;border-radius:2px}
.hero-dot.active{background:var(--gold);width:44px}
.hero-scroll{position:absolute;bottom:2.25rem;right:var(--px);z-index:5;display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.hero-scroll::after{content:'';width:1px;height:40px;background:linear-gradient(to bottom,rgba(196,151,58,.6),transparent)}

/* Stats */
.stats{background:linear-gradient(135deg,#1a2e20 0%,#162518 100%);padding:1.4rem 0;position:relative;overflow:hidden;border-top:1px solid rgba(196,151,58,.1);border-bottom:1px solid rgba(196,151,58,.1)}
.stats::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(90deg,rgba(196,151,58,.025) 0,rgba(196,151,58,.025) 1px,transparent 1px,transparent 80px)}
.stats-inner{display:flex;justify-content:space-around;flex-wrap:wrap;gap:1.25rem;position:relative;z-index:1}
.stat{text-align:center;position:relative;padding:0 1.25rem}
.stat:not(:last-child)::after{content:'';position:absolute;right:0;top:50%;transform:translateY(-50%);height:22px;width:1px;background:rgba(196,151,58,.15)}
.stat .num{font-family:'Cormorant Garamond',serif;font-size:1.75rem;font-weight:600;color:rgba(196,151,58,.82);line-height:1;display:block;letter-spacing:.01em}
.stat .lbl{color:rgba(255,255,255,.38);margin-top:.3rem;font-size:.56rem;letter-spacing:.2em}
.stat .lbl::before{display:none}

/* Section head */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:2.5rem}
.sec-head h2{margin-top:.25rem}
.heading-line{position:relative;display:inline-block}
.heading-line::after{content:'';position:absolute;bottom:-10px;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--gold),transparent);animation:lineGrow .7s .5s ease forwards}

/* Cards */
.card{background:#fff;border-radius:var(--radius);box-shadow:0 2px 12px rgba(0,0,0,.07);overflow:hidden;transition:box-shadow var(--t),transform var(--t)}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}

/* Property card */
.prop-card{position:relative}
.prop-card .thumb{position:relative;aspect-ratio:4/3;overflow:hidden}
.prop-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .65s cubic-bezier(.4,0,.2,1)}
.prop-card:hover .thumb img{transform:scale(1.07)}
.prop-card .thumb::after{content:'';position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,rgba(26,39,68,.4),transparent);pointer-events:none}
.prop-card::before{content:'';position:absolute;inset:0;border-radius:var(--radius);border:1.5px solid transparent;background:linear-gradient(var(--g50),var(--g50)) padding-box,linear-gradient(135deg,transparent 0%,var(--gold) 50%,transparent 100%) border-box;opacity:0;transition:opacity var(--t);z-index:1;pointer-events:none}
.prop-card:hover::before{opacity:1}
.badge{position:absolute;top:.75rem;left:.75rem;z-index:2;background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--navy);font-size:.58rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.22rem .65rem;border-radius:3px;box-shadow:0 2px 8px rgba(196,151,58,.4)}
.badge-focus{background:linear-gradient(135deg,var(--navy),var(--navy3));color:var(--gold)}
.badge-him{background:linear-gradient(135deg,#1B4332,#2d6a4f);color:#95d5b2;left:auto;right:.75rem}
.prop-body{padding:1.35rem}
.prop-loc{font-size:.7rem;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.3rem}
.prop-body h3{font-size:1.1rem;margin-bottom:.5rem;transition:color var(--t)}
.prop-card:hover .prop-body h3{color:var(--gold)}
.prop-price{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;color:var(--navy);margin-bottom:.75rem}
.prop-meta{display:flex;gap:.9rem;font-size:.75rem;color:var(--g600);padding-top:.75rem;border-top:1px solid var(--g100)}
.prop-foot{padding:0 1.35rem 1.35rem;display:flex;gap:.6rem}

/* Project card */
.proj-card .thumb{aspect-ratio:16/9;overflow:hidden;position:relative}
.proj-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .65s ease}
.proj-card:hover .thumb img{transform:scale(1.05)}
.proj-card .thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(26,39,68,.65) 0%,transparent 60%)}
.proj-body{padding:1.5rem}
.proj-dev{font-size:.7rem;color:var(--gold);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.3rem}
.proj-body h3{font-size:1.15rem;margin-bottom:.5rem}
.proj-meta{display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;font-size:.76rem;color:var(--g600);margin-top:.8rem}
.status{display:inline-block;font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.22rem .7rem;border-radius:20px}
.s-ongoing{background:#e8f5e9;color:#2e7d32}.s-upcoming{background:#fff3e0;color:#e65100}.s-ready{background:#e3f2fd;color:#1565c0}

/* Spotlights */
.spotlight-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.sp-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;display:block}
.sp-card img{width:100%;height:100%;object-fit:cover;transition:transform .65s ease}
.sp-card:hover img{transform:scale(1.07)}
.sp-over{position:absolute;inset:0;background:linear-gradient(to top,rgba(17,28,56,.92) 0%,rgba(17,28,56,.2) 65%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;transition:background var(--t)}
.sp-card:hover .sp-over{background:linear-gradient(to top,rgba(17,28,56,.96) 0%,rgba(17,28,56,.45) 65%,transparent 100%)}
.sp-tag{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--gold);margin-bottom:.3rem}
.sp-over h3{color:#fff;font-size:1.15rem;margin-bottom:.75rem}
.sp-arrow{display:inline-flex;align-items:center;gap:.4rem;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);transform:translateY(8px);opacity:0;transition:all var(--t)}
.sp-card:hover .sp-arrow{transform:translateY(0);opacity:1}

/* Trust cards */
.trust-card{padding:2rem;border-radius:var(--radius);background:#fff;border:1px solid var(--g100);transition:all var(--t);position:relative;overflow:hidden}
.trust-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transition:transform .45s ease}
.trust-card:hover{border-color:var(--gold-dim);box-shadow:var(--shadow-gold);transform:translateY(-5px)}
.trust-card:hover::before{transform:scaleX(1)}
.trust-icon{width:52px;height:52px;border-radius:12px;margin-bottom:1.25rem;background:var(--gold-dim);display:flex;align-items:center;justify-content:center;font-size:1.4rem;transition:all var(--t)}
.trust-card:hover .trust-icon{background:var(--gold);transform:scale(1.1)}

/* Testimonials */
.testi-card{padding:2rem;border-radius:var(--radius-lg);background:var(--navy);position:relative;overflow:hidden}
.testi-card::before{content:'\201C';position:absolute;top:.25rem;right:1.25rem;font-family:'Cormorant Garamond',serif;font-size:6rem;color:rgba(196,151,58,.1);line-height:1}
.testi-text{color:rgba(255,255,255,.8);font-size:.92rem;line-height:1.78;margin-bottom:1.5rem;font-style:italic}
.testi-name{color:#fff;font-family:'Cormorant Garamond',serif;font-size:1.1rem}
.testi-role{color:var(--gold);font-size:.7rem;letter-spacing:.09em;text-transform:uppercase;margin-top:.15rem}
.testi-stars{color:var(--gold);font-size:.85rem;margin-bottom:.75rem;letter-spacing:.1em}

/* Developers */
.dev-logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem}
.dev-logo{background:#fff;border:1px solid var(--g100);border-radius:10px;padding:1rem 1.75rem;transition:all var(--t);filter:grayscale(1);opacity:.55}
.dev-logo:hover{filter:grayscale(0);opacity:1;border-color:var(--gold-dim);box-shadow:var(--shadow-gold);transform:translateY(-3px)}
.dev-logo img{height:30px;width:auto;object-fit:contain}

/* CTA Band */
.cta-band{background:linear-gradient(135deg,var(--navy2) 0%,var(--navy3) 50%,var(--forest) 100%);padding:clamp(3.5rem,8vw,6rem) 0;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-45deg,transparent,transparent 30px,rgba(196,151,58,.03) 30px,rgba(196,151,58,.03) 31px)}
.cta-band::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--forest),var(--gold),var(--forest))}

/* Regions */
.region-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:3/2;display:block}
.region-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.region-card:hover img{transform:scale(1.06)}
.region-over{position:absolute;inset:0;background:linear-gradient(to top,rgba(17,28,56,.92) 0%,rgba(17,28,56,.2) 70%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.75rem}
.region-name{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;color:#fff;margin-bottom:.25rem}
.region-count{font-size:.7rem;color:var(--gold);letter-spacing:.1em;text-transform:uppercase}

/* Detail */
.detail-wrap{display:grid;grid-template-columns:1fr 380px;gap:2.5rem;align-items:start}
.detail-hero{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/7}
.detail-hero img{width:100%;height:100%;object-fit:cover}
.thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;margin-top:.75rem}
.thumbs img{border-radius:8px;aspect-ratio:4/3;object-fit:cover;cursor:pointer;opacity:.65;transition:all var(--t);border:2px solid transparent}
.thumbs img:hover,.thumbs img.active{opacity:1;border-color:var(--gold)}
.specs{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;margin:1.75rem 0}
.spec{background:var(--ivory3);border-radius:10px;padding:1rem;text-align:center;border:1px solid var(--ivory2);transition:all var(--t)}
.spec:hover{border-color:var(--gold-dim);background:#fff;box-shadow:0 4px 16px rgba(196,151,58,.1)}
.spec .val{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:700;color:var(--navy)}
.spec .key{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--g600);margin-top:.2rem}
.amenity-list{display:flex;flex-wrap:wrap;gap:.5rem}
.amenity{background:var(--ivory3);border:1px solid var(--ivory2);border-radius:20px;padding:.35rem 1rem;font-size:.78rem;color:var(--g800);transition:all var(--t)}
.amenity:hover{background:var(--gold-dim);border-color:rgba(196,151,58,.3);color:var(--navy)}

/* Lead card */
.lead-card{background:linear-gradient(160deg,var(--navy) 0%,var(--navy2) 100%);border-radius:var(--radius-lg);padding:2rem;position:sticky;top:calc(var(--nav-h) + 1.25rem);border:1px solid rgba(196,151,58,.2);box-shadow:0 20px 60px rgba(17,28,56,.3)}
.lead-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.lead-card h3{color:#fff;font-size:1.4rem;margin-bottom:.3rem}
.lead-card>p{color:rgba(255,255,255,.52);font-size:.82rem;margin-bottom:1.5rem}

/* Forms */
.fg{margin-bottom:1rem}
.fg label{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.5);margin-bottom:.4rem}
.fg input,.fg select,.fg textarea{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:.75rem 1rem;color:#fff;font-size:.88rem;font-family:'Jost',sans-serif;transition:all var(--t)}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(255,255,255,.28)}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--gold);background:rgba(255,255,255,.1)}
.fg select option{background:var(--navy)}
.fg textarea{height:72px;resize:vertical}
.form-light .fg label{color:var(--g600)}
.form-light .fg input,.form-light .fg select,.form-light .fg textarea{background:#fff;border-color:var(--g200);color:var(--g800)}
.form-light .fg input::placeholder,.form-light .fg textarea::placeholder{color:var(--g400)}
.form-light .fg input:focus,.form-light .fg select:focus,.form-light .fg textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,151,58,.12)}

/* Filters */
.filters{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;margin-bottom:2rem;display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end;border:1px solid var(--g100)}
.fgrp{display:flex;flex-direction:column;gap:.35rem;flex:1 1 160px}
.fgrp label{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--g600);font-weight:500}
.fgrp select,.fgrp input{height:42px;border:1px solid var(--g200);border-radius:8px;padding:0 .8rem;font-size:.87rem;color:var(--g800);background:var(--g50);transition:all var(--t);font-family:'Jost',sans-serif}
.fgrp select:focus,.fgrp input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,151,58,.1)}

/* Page header */
.page-hd{background:linear-gradient(135deg,var(--navy2) 0%,var(--navy) 60%,var(--forest) 100%);padding:3rem 0 2.5rem;position:relative;overflow:hidden}
.page-hd::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--forest),var(--gold),var(--forest))}
.page-hd::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-45deg,transparent,transparent 40px,rgba(196,151,58,.025) 40px,rgba(196,151,58,.025) 41px)}
.page-hd .container{position:relative;z-index:1}
.page-hd h1{color:#fff;margin-bottom:.4rem}
.page-hd p{color:rgba(255,255,255,.52)}
.crumb{display:flex;flex-wrap:wrap;gap:.35rem;font-size:.76rem;color:rgba(255,255,255,.38);margin-bottom:.75rem}
.crumb a{color:rgba(255,255,255,.52);transition:color var(--t)}.crumb a:hover{color:var(--gold)}

/* Footer */
.footer{background:var(--navy2);color:rgba(255,255,255,.52);padding:5rem 0 2rem;position:relative}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--forest),var(--gold),var(--forest))}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.footer-brand p{font-size:.84rem;line-height:1.82;margin:1rem 0 1.5rem}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:1.75rem;font-weight:700;color:#fff;letter-spacing:.06em;display:inline-block;margin-bottom:.25rem}
.footer-logo em{color:var(--gold);font-style:normal}
.footer h4{color:#fff;font-family:'Jost',sans-serif;font-size:.62rem;text-transform:uppercase;letter-spacing:.18em;margin-bottom:1.1rem;padding-bottom:.65rem;border-bottom:1px solid rgba(196,151,58,.2)}
.footer ul li{margin-bottom:.55rem}
.footer a{font-size:.82rem;transition:color var(--t)}.footer a:hover{color:var(--gold)}
.footer-contact-item{display:flex;align-items:flex-start;gap:.65rem;font-size:.82rem;margin-bottom:.75rem}
.footer-contact-icon{color:var(--gold);flex-shrink:0;margin-top:2px;font-size:1rem}
.rera-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(196,151,58,.1);border:1px solid rgba(196,151,58,.22);border-radius:6px;padding:.45rem .9rem;font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}
.social-links{display:flex;gap:.65rem}
.social-link{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;transition:all var(--t);color:rgba(255,255,255,.55);font-size:.85rem}
.social-link:hover{background:var(--gold);border-color:var(--gold);color:var(--navy);transform:translateY(-3px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.75rem;font-size:.76rem}

/* Breadcrumb */
.breadcrumb{display:flex;flex-wrap:wrap;gap:.35rem;font-size:.76rem;color:var(--g600);margin-bottom:1.75rem}
.breadcrumb a:hover{color:var(--gold)}

/* Pagination */
.pagination{display:flex;gap:.4rem;justify-content:center;margin-top:3rem;flex-wrap:wrap}
.pagination a,.pagination span{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:.83rem;border:1px solid var(--g200);color:var(--g800);transition:all var(--t)}
.pagination a:hover{background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-2px)}
.pagination .current{background:var(--gold);color:var(--navy);border-color:var(--gold);font-weight:700}

/* Alerts */
.alert{padding:1rem 1.25rem;border-radius:10px;font-size:.88rem;margin-bottom:1rem}
.alert-ok{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}
.alert-err{background:#fce4ec;color:#b71c1c;border:1px solid #ef9a9a}

/* Tags */
.tag{display:inline-block;font-size:.62rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;padding:.22rem .75rem;border-radius:20px;background:var(--ivory2);color:var(--navy)}
.tag-gold{background:rgba(196,151,58,.15);color:#a07820;border:1px solid rgba(196,151,58,.2)}

/* FAQ */
.faq-item{border-bottom:1px solid var(--g100);overflow:hidden}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:1.25rem 0;cursor:pointer;font-family:'Jost',sans-serif;font-size:.92rem;font-weight:500;color:var(--navy);display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:color var(--t)}
.faq-q:hover{color:var(--gold)}
.faq-icon{width:22px;height:22px;border-radius:50%;background:var(--ivory2);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.9rem;transition:all var(--t);line-height:1}
.faq-q.open .faq-icon{background:var(--gold);color:var(--navy);transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease}
.faq-a.open{max-height:300px;padding-bottom:1.25rem}
.faq-a p{font-size:.88rem;color:var(--g600);line-height:1.78}

/* Related tags */
.related-tag{display:inline-block;border:1px solid var(--g200);border-radius:20px;padding:.4rem 1rem;font-size:.75rem;color:var(--g800);transition:all var(--t);margin:.25rem}
.related-tag:hover{background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-2px)}

/* WhatsApp FAB */
.wa-fab{position:fixed;bottom:1.75rem;right:1.75rem;z-index:900;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#25D366,#128C7E);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(37,211,102,.45);transition:all var(--t);animation:goldPulse 3s infinite}
.wa-fab:hover{transform:scale(1.1) translateY(-3px);box-shadow:0 10px 30px rgba(37,211,102,.6)}
.wa-fab svg{width:28px;height:28px;fill:#fff}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}
.lightbox img{max-width:92vw;max-height:90vh;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.6)}
#lb-close{position:absolute;top:1.25rem;right:1.75rem;font-size:2.2rem;color:rgba(255,255,255,.7);background:none;border:none;cursor:pointer;line-height:1;transition:color var(--t)}

/* Responsive */
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr}.detail-wrap{grid-template-columns:1fr}.lead-card{position:static}}
@media(max-width:768px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .nav-links{display:none;flex-direction:column;position:absolute;top:var(--nav-h);left:0;right:0;background:rgba(17,28,56,.98);backdrop-filter:blur(16px);padding:2rem var(--px);gap:1.5rem;border-bottom:1px solid rgba(196,151,58,.2)}
  .nav-links.open{display:flex}
  .hamburger{display:flex}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .specs{grid-template-columns:1fr 1fr}
  .sec-head{flex-direction:column;align-items:flex-start}
  .thumbs{grid-template-columns:repeat(3,1fr)}
  .stats-inner{gap:1rem}
  .stat:not(:last-child)::after{display:none}
}
@media(max-width:480px){.hero{min-height:460px}.btn-lg{padding:.8rem 1.75rem;font-size:.82rem}}

/* ════════════════════════════════════════════════════
   GLOBAL SHARP CORNERS + GOLD GLOW — v2 override
════════════════════════════════════════════════════ */

/* Sharp corners universally */
.card,.prop-card,.proj-card,.sp-card,
.region-card,.trust-card,.testi-card,
.detail-hero,.thumbs img,
.filters,.lead-card{border-radius:0 !important}

/* Cards — gold border glow on hover */
.card:hover,.prop-card:hover,.proj-card:hover{
  box-shadow:
    0 0 0 1px rgba(196,151,58,.22),
    0 12px 40px rgba(0,0,0,.15),
    0 0 60px -12px rgba(196,151,58,.2) !important;
}

/* Image frames — sharp + glow */
.prop-card .thumb,
.proj-card .thumb,
.sp-card{
  border:1px solid rgba(196,151,58,.12);
  box-shadow:0 0 30px -8px rgba(196,151,58,.12);
  transition:box-shadow var(--t),border-color var(--t);
}
.prop-card:hover .thumb,
.proj-card:hover .thumb,
.sp-card:hover{
  border-color:rgba(196,151,58,.3);
  box-shadow:0 0 50px -6px rgba(196,151,58,.22);
}

/* Trust cards — sharp */
.trust-card{border-radius:0 !important}

/* Buttons — sharp */
.btn,.btn-nav,.btn-gold,.btn-navy,.btn-outline,.btn-ghost{border-radius:0 !important}

/* Forms — sharp inputs */
.fg input,.fg select,.fg textarea,
.fgrp select,.fgrp input{border-radius:0 !important}
.fgrp select:focus,.fgrp input:focus{
  box-shadow:0 0 0 2px rgba(196,151,58,.15),inset 0 0 0 1px rgba(196,151,58,.2);
}

/* Stats bar glow line */
.stats{
  box-shadow:0 4px 24px rgba(0,0,0,.2),0 0 0 1px rgba(196,151,58,.1);
}

/* Lead card — sharp + stronger glow */
.lead-card{
  box-shadow:
    0 0 0 1px rgba(196,151,58,.18),
    0 24px 64px rgba(17,28,56,.4),
    0 0 80px -15px rgba(196,151,58,.18) !important;
}

/* Page header — sharper bottom accent */
.page-hd::after{height:2px}

/* Pagination — sharp */
.pagination a,.pagination span{border-radius:0 !important}

/* Status tags — sharp */
.status,.tag,.badge{border-radius:0 !important}

/* Spec items — sharp */
.spec{border-radius:0 !important}
.spec:hover{box-shadow:inset 0 -2px 0 var(--gold)}

/* Amenity pills — sharp */
.amenity{border-radius:0 !important}

/* Related tags — sharp */
.related-tag{border-radius:0 !important}

/* Spotlight card — corner gold accents */
.sp-card::before,.sp-card::after{
  content:'';position:absolute;z-index:4;pointer-events:none;
  width:22px;height:22px;
  border-color:rgba(196,151,58,.5);border-style:solid;
  transition:opacity .3s ease;opacity:0;
}
.sp-card::before{top:10px;left:10px;border-width:2px 0 0 2px}
.sp-card::after{bottom:10px;right:10px;border-width:0 2px 2px 0}
.sp-card:hover::before,.sp-card:hover::after{opacity:1}

/* Testimonial cards — sharp with gold left accent */
.testi-card{
  border-left:3px solid rgba(196,151,58,.4) !important;
  border-radius:0 !important;
}

/* WhatsApp FAB — sharp */
.wa-fab{border-radius:0 !important}

/* Highlight the active thumbnail everywhere */
.thumbs img.active,.thumbs img:hover{
  box-shadow:0 0 0 2px var(--gold),0 0 16px rgba(196,151,58,.3);
}


/* ═══════════════════════════════════════════════════════════════
   FIDUS REALTY — LUXURY EXPERIENCE LAYER v1
   "The Reception Feeling" — refined, deliberate, premium
═══════════════════════════════════════════════════════════════ */

/* ── 1. Grain texture overlay — like premium paper ── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: .028;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 180px 180px;
}

/* ── 2. Scroll progress bar — gold line at very top ── */
/* ── Prevent horizontal scroll — set on html, not body (body overflow-x breaks position:fixed) ── */

#scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  width: 0%;
  height: 2px;
  background: linear-gradient(90deg, var(--forest), var(--gold), var(--gold3));
  z-index: 9998;
  transition: width .1s linear;
  box-shadow: 0 0 8px rgba(196,151,58,.5);
}

/* ── 3. Custom cursor ── */
#cursor-dot {
  width: 6px;
  height: 6px;
  background: var(--gold);
  border-radius: 50%;
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 99999;
  transform: translate(-50%, -50%);
  transition: transform .08s ease, opacity .3s, background .3s, width .25s, height .25s;
  mix-blend-mode: multiply;
}
#cursor-ring {
  width: 32px;
  height: 32px;
  border: 1px solid rgba(196,151,58,.45);
  border-radius: 50%;
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 99998;
  transform: translate(-50%, -50%);
  transition: transform .18s cubic-bezier(.25,.46,.45,.94), width .3s, height .3s, border-color .3s, opacity .3s;
}
body:has(a:hover) #cursor-ring,
body:has(button:hover) #cursor-ring {
  width: 48px;
  height: 48px;
  border-color: rgba(196,151,58,.7);
}
@media (hover: none) {
  #cursor-dot, #cursor-ring { display: none; }
}

/* ── 5. Magnetic CTA effect ── */
.btn-nav, .btn-gold, .btn-cta-magnetic {
  transform-origin: center center;
  will-change: transform;
}

/* ── 6. Refined hover transitions — everything settles, not bounces ── */
.card, .prop-card, .proj-card, .trust-card, .sp-card, .region-card {
  transition:
    box-shadow .4s cubic-bezier(.25,.46,.45,.94),
    transform .4s cubic-bezier(.25,.46,.45,.94),
    border-color .3s ease !important;
}

/* ── 7. Button ripple base ── */
.btn, .btn-nav, .btn-gold, .btn-navy {
  position: relative;
  overflow: hidden;
}
.btn::before, .btn-gold::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at var(--rx, 50%) var(--ry, 50%), rgba(255,255,255,.22) 0%, transparent 65%);
  opacity: 0;
  transition: opacity .4s;
  pointer-events: none;
}
.btn:hover::before, .btn-gold:hover::before { opacity: 1; }

/* ── 8. Gold shimmer on section headings ── */
.gold-shimmer {
  background: linear-gradient(90deg, var(--gold) 0%, var(--gold3) 40%, var(--gold) 60%, var(--gold3) 100%);
  background-size: 300% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer 5s linear infinite;
}

/* ── 9. Page entrance — content fades in on load ── */
.page-enter {
  animation: pageEnter .6s cubic-bezier(.25,.46,.45,.94) both;
}
@keyframes pageEnter {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── 10. Refined reveal — curtain parting, not popping ── */
.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .9s cubic-bezier(.25,.46,.45,.94), transform .9s cubic-bezier(.25,.46,.45,.94);
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay: .08s; }
.reveal-d2 { transition-delay: .18s; }
.reveal-d3 { transition-delay: .28s; }
.reveal-d4 { transition-delay: .38s; }

/* ── 11. Nav phone number (desktop) ── */
.nav-phone {
  font-size: .72rem;
  font-weight: 500;
  color: var(--navy);
  letter-spacing: .04em;
  display: flex;
  align-items: center;
  gap: .4rem;
  opacity: .7;
  transition: opacity .25s, color .25s;
  text-decoration: none;
}
.nav-phone::before {
  content: '';
  display: inline-block;
  width: 1px;
  height: 14px;
  background: rgba(0,0,0,.15);
  margin-right: .4rem;
}
.nav-phone:hover { opacity: 1; color: var(--gold); }
@media(max-width:900px) { .nav-phone { display: none; } }

/* ── 12. Hero parallax wrapper ── */
.hero-slide img {
  transform-origin: center center;
  will-change: transform;
}

/* ── 13. Exit intent — bottom slide, not intrusive popup ── */
#exit-nudge {
  position: fixed;
  bottom: 0;
  left: 0; right: 0;
  background: linear-gradient(135deg, var(--forest), #0d2018);
  border-top: 1px solid rgba(196,151,58,.3);
  z-index: 7999;
  padding: 1.5rem var(--px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  transition: bottom .5s cubic-bezier(.34,1.56,.64,1);
  box-shadow: 0 -8px 40px rgba(0,0,0,.3);
}
#exit-nudge { transform: translateY(110%); transition: transform .5s cubic-bezier(.34,1.56,.64,1); }
#exit-nudge.show { transform: translateY(0); }
#exit-nudge p {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  color: rgba(255,255,255,.88);
  line-height: 1.4;
  margin: 0;
  max-width: 500px;
}
#exit-nudge p span { color: var(--gold); }
#exit-nudge .en-actions { display: flex; align-items: center; gap: 1rem; flex-shrink: 0; }
#exit-nudge .en-close {
  background: none; border: none; color: rgba(255,255,255,.35);
  cursor: pointer; font-size: 1.25rem; line-height: 1; transition: color .2s;
}
#exit-nudge .en-close:hover { color: rgba(255,255,255,.7); }
@media(max-width:600px) {
  #exit-nudge { flex-direction: column; align-items: flex-start; }
  #exit-nudge .en-actions { width: 100%; }
}

/* ── 14. Property card — gold corner accents on hover ── */
.prop-card::after {
  content: '';
  position: absolute;
  top: 10px; right: 10px;
  width: 20px; height: 20px;
  border-top: 2px solid rgba(196,151,58,.0);
  border-right: 2px solid rgba(196,151,58,.0);
  z-index: 3;
  pointer-events: none;
  transition: border-color .4s, width .4s, height .4s;
}
.prop-card:hover::after {
  border-color: rgba(196,151,58,.6);
  width: 28px; height: 28px;
}

/* ── 15. Lead card — glowing phone number ── */
.lead-phone {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--gold);
  display: block;
  margin: 1rem 0 .25rem;
  letter-spacing: .03em;
  transition: text-shadow .3s;
}
.lead-phone:hover {
  text-shadow: 0 0 20px rgba(196,151,58,.5);
  color: var(--gold3);
}

