/* ============================================================
   RIVER COVE RESIDENCES AT SOBHA CITY — Soprano Properties
   Version: 1.0  |  Project: River Cove Residences, Abu Dhabi
   ─────────────────────────────────────────────────────────────
   PALETTE:
   - Burgundy (#2e1111) as primary deep colour — Soprano Properties brand
   - Gold (#c0852b / #f2dfaa) as character accent
   - Gold pale (#f2dfaa) as text highlights
   - Cormorant Garamond (headings) + Jost (body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Jost:wght@300;400;500&display=swap');

/* ── CSS VARIABLES ── */
:root{
  --navy:#2e1111;
  --navy-deep:#160808;
  --navy-mid:#3d1616;
  --navy-light:#5a2020;
  --teal:#c0852b;
  --teal-light:#ddb96a;
  --teal-pale:#f2dfaa;
  --gold:#c0852b;
  --gold-light:#ddb96a;
  --gold-pale:#f2dfaa;
  --cream:#f3ede9;
  --warm:#f3ede9;
  --dark:#000000;
  --grey:#686868;
  --grey-lt:#a89a88;
  --wd:var(--navy-deep);
  --wm:var(--navy-mid);
  --wl:var(--gold);
  --wp:var(--gold-pale);
  --wcream:var(--cream);
  --wwarm:var(--warm);
  --wdark:var(--dark);
}

/* ── GLOBAL RESET ── */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Jost',sans-serif;
  background:var(--cream);
  color:var(--navy-deep);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--warm)}
::-webkit-scrollbar-thumb{background:var(--teal)}

/* ── ELEMENTOR RESETS ── */
.elementor-widget-html{padding:0!important;margin:0!important}
body.elementor-page{padding:0!important}
.e-con,.e-con-inner,.elementor-section,.elementor-column,.elementor-widget{
  padding:0!important;margin:0!important;max-width:100%!important;
}
#footer{display:none!important}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 40px;
  background:rgba(22,8,8,.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(192,133,43,.22);
  transition:padding .4s ease,background .4s ease;
}
nav.scrolled{padding:10px 40px;background:rgba(22,8,8,.97)}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:36px;width:auto;display:block;background:transparent}
.nav-links{display:flex;gap:24px;align-items:center;position:relative}
.nav-links a{
  font-size:9px;font-weight:400;letter-spacing:2.5px;
  text-transform:uppercase;color:rgba(242,223,170,.7);
  text-decoration:none;transition:color .3s;
}
.nav-links a:hover{color:var(--gold-pale)}

/* NAV DROPDOWN */
.nav-dropdown{position:relative}
.nav-dropdown > a{display:flex;align-items:center;gap:4px}
.nav-dropdown > a::after{content:'▾';font-size:7px;opacity:.6}
.nav-dropdown-menu{
  display:none;position:absolute;top:calc(100% + 14px);left:0;
  background:rgba(22,8,8,.97);border:1px solid rgba(192,133,43,.25);
  min-width:160px;z-index:300;padding:8px 0;
}
.nav-dropdown:hover .nav-dropdown-menu{display:block}
.nav-dropdown-menu a{
  display:block;padding:9px 18px;font-size:8.5px;letter-spacing:2px;
  text-transform:uppercase;color:rgba(242,223,170,.65);white-space:nowrap;
  text-decoration:none;transition:background .2s,color .2s;border-bottom:none;
}
.nav-dropdown-menu a:hover{background:rgba(192,133,43,.12);color:var(--gold-pale)}

.nav-btn{
  background:transparent;color:var(--gold-pale);
  padding:6px 14px;font-size:8px;font-weight:500;letter-spacing:2px;
  text-transform:uppercase;border:1px solid rgba(192,133,43,.5);
  cursor:pointer;font-family:'Jost',sans-serif;
  white-space:nowrap;transition:all .3s;min-height:0;
}
.nav-btn:hover{background:var(--gold);color:var(--dark);border-color:var(--gold)}

/* Hamburger */
.nav-ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.nav-ham span{display:block;width:22px;height:1.5px;background:var(--gold-pale);transition:all .3s}
.nav-mobile{
  display:none;flex-direction:column;
  position:fixed;top:61px;left:0;right:0;z-index:9990;
  background:rgba(22,8,8,.98);border-top:none;
  padding:12px 24px 20px;gap:0;
  box-shadow:0 16px 48px rgba(0,0,0,.6);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.nav-mobile.open{display:grid;grid-template-columns:1fr 1fr;align-items:start}
.nav-mobile-heading{grid-column:1/-1;font-size:8px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(192,133,43,.5);padding:14px 10px 10px;border-bottom:1px solid rgba(192,133,43,.15)}
.nav-mobile a{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(242,223,170,.7);text-decoration:none;padding:12px 10px;border-bottom:1px solid rgba(192,133,43,.1);display:block;transition:color .2s,transform .2s,letter-spacing .2s}
.nav-mobile a:hover{color:var(--gold-pale);transform:translateX(4px);letter-spacing:3px}
.nav-mobile-sub{padding-left:18px!important;font-size:8.5px!important;color:rgba(242,223,170,.5)!important}

/* ── HERO ── */
.hero{min-height:100svh;display:flex;align-items:flex-end;position:relative;overflow:hidden}
.hero-slides{position:absolute;inset:0}
.hero-slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.2s ease;
  animation:hzoom 14s ease-out forwards;
}
.hero-slide.active{opacity:1}
@keyframes hzoom{from{transform:scale(1.07)}to{transform:scale(1)}}
.hero-ov{
  position:absolute;inset:0;
  background:linear-gradient(180deg,
    rgba(22,8,8,.2) 0%,
    rgba(46,17,17,.1) 30%,
    rgba(46,17,17,.65) 65%,
    rgba(22,8,8,.93) 100%);
}
.hero-inner{position:relative;z-index:2;padding:100px 48px 68px;width:100%;max-width:1200px}

/* Hero dots */
.hero-dots{position:absolute;bottom:24px;right:48px;z-index:5;display:flex;gap:8px}
.hero-dot{width:6px;height:6px;border-radius:50%;background:rgba(242,223,170,.3);cursor:pointer;transition:background .3s,transform .3s}
.hero-dot.active{background:var(--teal-light);transform:scale(1.3)}

.eyebrow{
  font-size:8.5px;font-weight:400;letter-spacing:4px;text-transform:uppercase;
  color:var(--gold-pale);margin-bottom:24px;
  display:flex;align-items:center;gap:14px;
}
.eyebrow::before{content:'';width:32px;height:1px;background:var(--teal);flex-shrink:0;opacity:.7}

.h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(48px,10vw,88px);
  font-weight:300;line-height:.93;color:var(--cream);margin-bottom:8px;
}
.h1 .the{font-size:.42em;display:block;margin-bottom:.05em;font-style:italic;color:var(--teal-pale)}
.h1 .main{display:block;letter-spacing:-.02em}
.h1 .sub{font-size:.36em;font-style:italic;font-weight:300;color:var(--gold-light);display:block;margin-top:.1em;letter-spacing:.04em}

.hero-sub{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(13px,2.5vw,15px);font-weight:300;
  color:rgba(242,223,170,.75);
  margin-top:22px;margin-bottom:36px;
  letter-spacing:3.5px;text-transform:uppercase;
}
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;margin-bottom:36px;
  background:rgba(192,133,43,.15);
  border:1px solid rgba(192,133,43,.12);
  max-width:620px;
}
.stat{padding:16px 20px;background:rgba(46,17,17,.55);text-align:center}
.stat-v{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:var(--cream);line-height:1;text-align:center;width:100%;display:block}
.stat-l{font-size:7.5px;letter-spacing:1.8px;text-transform:uppercase;color:rgba(192,133,43,.75);margin-top:5px;text-align:center;width:100%;display:block}

/* ── GOLD STRIP ── */
.gstrip{height:3px;background:linear-gradient(90deg,var(--navy),var(--teal),var(--navy-mid),var(--gold),var(--navy))}

/* ── BUTTONS ── */
.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn-gold{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--gold);color:var(--dark);
  padding:15px 36px;font-size:9px;font-weight:600;letter-spacing:2.5px;
  text-transform:uppercase;border:none;cursor:pointer;
  font-family:'Jost',sans-serif;white-space:nowrap;
  transition:background .3s,transform .2s;
  -webkit-tap-highlight-color:transparent;min-height:48px;
}
.btn-gold:hover{background:var(--gold-light);transform:translateY(-1px)}
.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(192,133,43,.5);color:var(--cream);
  padding:15px 36px;font-size:9px;font-weight:300;letter-spacing:2.5px;
  text-transform:uppercase;cursor:pointer;background:transparent;
  transition:border-color .3s,color .3s;white-space:nowrap;
  font-family:'Jost',sans-serif;min-height:48px;
}
.btn-ghost:hover{border-color:var(--teal-pale);color:var(--teal-pale)}

/* ── SHARED TYPOGRAPHY ── */
.st{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(30px,6vw,52px);font-weight:400;
  line-height:1.08;color:var(--navy-deep);margin-bottom:16px;
}
.st em{font-style:italic;color:var(--teal)}
.st.li{color:var(--cream)}.st.li em{color:var(--gold)}

.sl{
  font-size:8.5px;letter-spacing:4px;text-transform:uppercase;
  color:var(--teal);margin-bottom:12px;
  display:flex;align-items:center;gap:12px;
}
.sl::before{content:'';width:24px;height:1px;background:var(--teal);flex-shrink:0}
.sl.li{color:var(--gold)}.sl.li::before{background:var(--gold)}
.sl.gn{color:var(--gold-pale)}.sl.gn::before{background:var(--gold-pale)}

.sb{font-size:14px;font-weight:300;line-height:1.9;color:var(--grey)}
.sb.li{color:rgba(242,223,170,.65)}

/* Scroll reveal */
.fu{opacity:1;transform:none}
.fu.animate{opacity:0;transform:translateY(20px);transition:opacity .65s ease,transform .65s ease}
.fu.animate.on{opacity:1;transform:none}

/* ── SECTIONS ── */
.sec{padding:96px 48px}
.sec-inner{max-width:1200px;margin:0 auto}
.sec-cream{background:var(--cream)}
.sec-warm{background:var(--warm)}
.sec-navy{background:var(--navy)}
.sec-navy-mid{background:var(--navy-mid)}
.sec-deep{background:var(--navy-deep)}
.sec-wd{background:var(--navy-deep)}
.sec-wm{background:var(--navy-mid)}
.sec-burg{background:var(--navy)}
.sec-burg-mid{background:var(--navy-mid)}
.sec-teal{background:var(--teal)}

/* ── FACTS BAR ── */
.facts-bar{background:var(--navy);padding:32px 48px}
.facts-inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:rgba(192,133,43,.2);
}
.fact-item{padding:24px 28px;background:var(--navy);text-align:center;transition:background .3s}
.fact-item:hover{background:var(--navy-mid)}
.fact-v{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:400;color:var(--gold-pale);line-height:1}
.fact-l{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:rgba(192,133,43,.75);margin-top:6px}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-img-wrap{position:relative}
.about-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.about-accent-frame{
  position:absolute;top:-14px;right:-14px;
  width:70%;height:85%;
  border:1px solid rgba(192,133,43,.35);
  pointer-events:none;
}
.dev-badge{
  display:flex;align-items:center;gap:14px;
  margin:28px auto 0;padding:12px 16px;
  border:1px solid rgba(192,133,43,.25);background:rgba(192,133,43,.06);
  max-width:320px;
}
.dev-badge-lbl{font-size:8px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(192,133,43,.7);margin-bottom:4px;white-space:nowrap}
.dev-badge-logo{height:36px!important;max-width:120px!important;width:auto;object-fit:contain;display:block}
.dev-badge-divider{width:1px;height:36px;background:rgba(192,133,43,.25);flex-shrink:0}

/* ── MASTERPLAN ── */
.masterplan-wrap{position:relative;display:inline-block;width:100%;cursor:crosshair}
.masterplan-img{width:100%;display:block;border:1px solid rgba(192,133,43,.18)}
.mp-popup{position:absolute;z-index:50;background:rgba(22,8,8,.96);border:1px solid rgba(192,133,43,.3);width:260px;padding:0;pointer-events:none;opacity:0;transform:scale(.92) translateY(-8px);transition:opacity .25s ease,transform .25s ease;box-shadow:0 12px 40px rgba(0,0,0,.5)}
.mp-popup.show{opacity:1;transform:scale(1) translateY(0);pointer-events:auto}
.mp-popup-img{width:100%;height:150px;object-fit:cover;display:block}
.mp-popup-body{padding:14px 16px}
.mp-popup-name{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:400;color:var(--teal-pale);margin-bottom:6px}
.mp-popup-meta{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(192,133,43,.8);margin-bottom:8px}
.mp-popup-specs{display:flex;gap:14px}
.mp-popup-spec span{display:block;font-size:12px;font-weight:300;color:rgba(242,223,170,.6)}
.mp-popup-spec strong{display:block;font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--teal-pale)}
.mp-hotspot{position:absolute;transform:translate(-50%,-50%);width:44px;height:44px;cursor:pointer;z-index:10}
.mp-hotspot-dot{width:16px;height:16px;background:var(--gold);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 4px rgba(242,223,170,.3),0 0 14px rgba(242,223,170,.5);z-index:2;transition:transform .3s}
.mp-hotspot:hover .mp-hotspot-dot{transform:translate(-50%,-50%) scale(1.5)}
.mp-hotspot::before,.mp-hotspot::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;border:2px solid rgba(242,223,170,.9);animation:hotpulse 2.2s ease-out infinite;pointer-events:none}
.mp-hotspot::after{animation-delay:1.1s;border-color:rgba(242,223,170,.5)}
@keyframes hotpulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1}100%{transform:translate(-50%,-50%) scale(5.5);opacity:0}}
/* ── COMMUNITIES ── */
.comm-tabs{display:flex;gap:0;margin-bottom:40px;border-bottom:1px solid rgba(242,223,170,.2)}
.comm-tab{font-family:'Jost',sans-serif;font-size:9px;font-weight:500;letter-spacing:2px;text-transform:uppercase;padding:12px 24px;cursor:pointer;color:var(--grey);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .3s;background:none;border-top:none;border-left:none;border-right:none}
.comm-tab.active,.comm-tab:hover{color:var(--navy);border-bottom-color:var(--gold)}
.comm-panel{display:none}
.comm-panel.active{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.comm-map-img{width:100%;border:1px solid rgba(242,223,170,.15);display:block}
.comm-house-img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;margin-bottom:20px}
.comm-specs-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(242,223,170,.12);margin-bottom:20px}
.comm-spec{padding:16px 18px;background:var(--navy-deep)}
.comm-spec-v{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:var(--teal-pale)}
.comm-spec-l{font-size:8px;letter-spacing:1.8px;text-transform:uppercase;color:rgba(242,223,170,.5);margin-top:4px}

/* ── THREE PILLARS ── */
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(192,133,43,.12);margin:48px 0}
.pillar{padding:36px 28px;background:var(--navy-deep);transition:background .3s}
.pillar:hover{background:var(--navy-mid)}
.pillar-label{font-size:8.5px;letter-spacing:3.5px;text-transform:uppercase;color:var(--teal-pale);margin-bottom:6px}
.pillar-title{font-family:'Cormorant Garamond',serif;font-size:clamp(24px,3.5vw,36px);font-weight:400;color:var(--cream);margin-bottom:14px;line-height:1.1}
.pillar-title em{font-style:italic;color:var(--teal-pale)}
.pillar-body{font-size:13px;font-weight:300;color:rgba(242,223,170,.55);line-height:1.75}

/* ── MASTERPLAN STATS ── */
.mp-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(192,133,43,.15);margin-top:48px}
.mp-stat{padding:24px 22px;background:var(--navy);text-align:center;transition:background .3s}
.mp-stat:hover{background:var(--navy-mid)}
.mp-stat-icon{font-size:20px;margin-bottom:8px}
.mp-stat-v{font-family:'Cormorant Garamond',serif;font-size:15px;font-weight:400;color:var(--teal-pale);line-height:1.3;margin-bottom:4px}
.mp-stat-l{font-size:7.5px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(192,133,43,.5);margin-top:4px}

/* ── PHASE 1 RESIDENCES ── */
.phase1-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 1fr;
  gap:16px;
  margin-top:40px;
}
.phase1-card{
  background:#fff;overflow:hidden;
  border:1px solid rgba(192,133,43,.12);
  transition:transform .3s,box-shadow .3s;
  position:relative;display:flex;flex-direction:column;
}
.phase1-card:hover{transform:translateY(-4px);box-shadow:0 20px 60px rgba(46,17,17,.14)}
.phase1-card--featured{
  background:var(--navy-deep);
  border:1.5px solid rgba(192,133,43,.55);
  box-shadow:0 8px 40px rgba(192,133,43,.2);
}
.phase1-card--featured:hover{box-shadow:0 20px 60px rgba(192,133,43,.18)}
.phase1-card-img{position:relative;overflow:hidden}
.phase1-card-img img{
  width:100%;height:200px;object-fit:cover;display:block;
  transition:transform .5s ease;
}
.phase1-card--featured .phase1-card-img img{height:240px}
.phase1-card:hover .phase1-card-img img{transform:scale(1.04)}
.new-launch-badge{
  position:absolute;top:12px;left:12px;z-index:5;
  background:var(--gold);color:var(--dark);
  font-size:7px;font-weight:700;letter-spacing:2.5px;
  text-transform:uppercase;font-variant:small-caps;
  padding:5px 12px;pointer-events:none;line-height:1.4;
  box-shadow:0 2px 12px rgba(192,133,43,.4);
}
.phase1-card-body{padding:22px 20px 24px;flex:1;display:flex;flex-direction:column}
.phase1-card--featured .phase1-card-body{padding:24px 22px 26px}
.phase1-type{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--teal);margin-bottom:4px}
.phase1-card--featured .phase1-type{color:var(--teal-pale)}
.phase1-name{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:var(--navy-deep);margin-bottom:6px;line-height:1.1}
.phase1-card--featured .phase1-name{color:var(--cream);font-size:24px}
.phase1-sub{font-size:11px;font-weight:300;color:var(--grey);line-height:1.6;margin-bottom:14px}
.phase1-card--featured .phase1-sub{color:rgba(242,223,170,.6)}
.phase1-table{width:100%;border-collapse:collapse;margin-bottom:16px;font-size:11px}
.phase1-table th{text-align:left;font-size:7.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey-lt);padding:4px 0 8px;border-bottom:1px solid rgba(192,133,43,.12);font-weight:400}
.phase1-card--featured .phase1-table th{color:rgba(192,133,43,.5);border-bottom-color:rgba(192,133,43,.2)}
.phase1-table td{padding:7px 0;border-bottom:1px solid rgba(192,133,43,.06);font-weight:300;color:var(--navy-deep);vertical-align:top}
.phase1-card--featured .phase1-table td{color:rgba(242,223,170,.8);border-bottom-color:rgba(192,133,43,.1)}
.phase1-table td:last-child{text-align:right;font-family:'Cormorant Garamond',serif;font-size:13px;color:var(--teal);font-weight:400}
.phase1-card--featured .phase1-table td:last-child{color:var(--gold-light)}
.phase1-status{font-size:8.5px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(192,133,43,.6);margin-bottom:12px}
.phase1-cta{
  margin-top:auto;
  display:inline-flex;align-items:center;gap:8px;
  font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:var(--navy-deep);border:none;background:none;cursor:pointer;
  transition:gap .3s,color .3s;padding:8px 0;
  font-family:'Jost',sans-serif;
  -webkit-tap-highlight-color:transparent;min-height:44px;
  text-decoration:none;
}
.phase1-cta:hover{gap:14px;color:var(--teal)}
.phase1-cta-arrow{color:var(--gold);font-size:14px;line-height:1}
.phase1-card--featured .phase1-cta{
  background:var(--gold);color:var(--dark);
  padding:12px 20px;justify-content:center;gap:6px;
  transition:background .3s,gap .2s;
}
.phase1-card--featured .phase1-cta:hover{background:var(--gold-light);gap:10px}
.phase1-card--featured .phase1-cta-arrow{color:var(--dark)}

/* ── UNIT CARDS ── */
.units-tabs{display:flex;gap:0;margin-bottom:40px;border-bottom:1px solid rgba(192,133,43,.2);flex-wrap:wrap}
.unit-tab{
  font-family:'Jost',sans-serif;font-size:9px;font-weight:500;
  letter-spacing:2px;text-transform:uppercase;
  padding:12px 20px;cursor:pointer;color:var(--grey);
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:all .3s;background:none;
  border-top:none;border-left:none;border-right:none;
  -webkit-tap-highlight-color:transparent;
}
.unit-tab.active,.unit-tab:hover{color:var(--navy-deep);border-bottom-color:var(--teal)}

.units-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.unit-card{background:#fff;overflow:hidden;border:1px solid rgba(192,133,43,.1);transition:transform .3s,box-shadow .3s}
.unit-card:hover{transform:translateY(-4px);box-shadow:0 20px 60px rgba(46,17,17,.1)}

.unit-img-wrap{
  height:240px;position:relative;overflow:hidden;
  background:var(--warm);
  display:flex;align-items:center;justify-content:center;
}
.unit-img{width:100%;height:100%!important;object-fit:cover;object-position:center top;padding:0;display:block;vertical-align:top;transition:transform .4s ease}
.unit-card:hover .unit-img{transform:scale(1.03)}

.unit-badge{
  position:absolute;top:10px;left:10px;z-index:3;
  background:var(--navy);color:var(--gold-pale);
  font-size:7.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  padding:4px 10px;pointer-events:none;line-height:1.4;
}
.unit-badge.apt1br{background:var(--teal)}
.unit-badge.apt2br{background:var(--navy-mid)}

.unit-body{padding:22px 24px 24px}
.unit-type{font-size:8.5px;letter-spacing:3px;text-transform:uppercase;color:var(--teal);margin-bottom:6px}
.unit-name{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:400;color:var(--navy-deep);margin-bottom:4px;line-height:1.1}
.unit-price{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:300;color:var(--teal);margin-bottom:14px}
.unit-specs{display:flex;gap:16px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid rgba(192,133,43,.1)}
.us-v{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:400;color:var(--navy-deep)}
.us-l{font-size:8px;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey-lt);margin-top:2px}
.unit-view{font-size:11px;font-weight:300;color:var(--grey);margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(192,133,43,.07)}
.unit-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:var(--navy-deep);border:none;background:none;cursor:pointer;
  transition:gap .3s,color .3s;padding:8px 0;
  font-family:'Jost',sans-serif;
  -webkit-tap-highlight-color:transparent;min-height:44px;
}
.unit-cta:hover{gap:14px;color:var(--teal)}
.unit-cta-arrow{color:var(--teal);font-size:14px;line-height:1}

/* Floor plan thumbs */
.fp-row{display:flex;gap:8px;margin-bottom:16px}
.fp-thumb{flex:1;cursor:pointer;position:relative;overflow:hidden;background:var(--warm);border:1px solid rgba(192,133,43,.1)}
.fp-thumb img{width:100%;height:80px;object-fit:cover;display:block;transition:transform .4s}
.fp-thumb:hover img{transform:scale(1.06)}
.fp-thumb-label{font-size:7.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey);text-align:center;padding:4px 6px;background:rgba(243,237,233,.9)}
.fp-thumb-zoom{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--cream);background:rgba(46,17,17,.0);opacity:0;transition:background .3s,opacity .3s}
.fp-thumb:hover .fp-thumb-zoom{background:rgba(46,17,17,.58);opacity:1}
.fp-thumb-zoom svg{filter:drop-shadow(0 1px 4px rgba(0,0,0,.4))}

/* ── GALLERY TABS ── */
.gallery-tabs{display:flex;gap:0;margin-bottom:32px;border-bottom:1px solid rgba(192,133,43,.2);flex-wrap:wrap}
.gallery-tab{font-size:9px;font-weight:500;letter-spacing:2px;text-transform:uppercase;padding:10px 20px;cursor:pointer;color:rgba(242,223,170,.5);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .3s;background:none;font-family:'Jost',sans-serif;border-top:none;border-left:none;border-right:none}
.gallery-tab.active,.gallery-tab:hover{color:var(--teal-pale);border-bottom-color:var(--gold)}
.gallery-panel{display:none}
.gallery-panel.active{display:block}

/* ── LIFESTYLE GALLERY GRID ── */
.gallery-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;grid-template-rows:220px 220px 180px;gap:8px}
.g-item{overflow:hidden!important;position:relative!important;cursor:pointer!important;display:block!important;padding:0!important;margin:0!important}
.g-item.tall{grid-column:1!important;grid-row:1/4!important;height:636px!important;max-height:636px!important}
.g-item:not(.tall):not(.wide){height:220px!important;max-height:220px!important}
.g-item.wide{grid-column:2/4!important;grid-row:3!important;height:180px!important;max-height:180px!important}
.g-img{width:100%!important;height:100%!important;object-fit:cover!important;display:block!important;transition:transform .8s ease;pointer-events:none!important;margin:0!important;padding:0!important}
.g-item:hover .g-img{transform:scale(1.04)}
.g-cap{position:absolute!important;bottom:0!important;left:0!important;right:0!important;top:auto!important;padding:10px 16px!important;font-size:8px!important;letter-spacing:2px;text-transform:uppercase;color:rgba(242,223,170,.95)!important;background:linear-gradient(transparent,rgba(22,8,8,.85) 40%)!important;opacity:0!important;transform:translateY(8px)!important;transition:opacity .3s ease,transform .3s ease!important;pointer-events:none!important;z-index:2!important}
.g-item:hover .g-cap{opacity:1!important;transform:translateY(0)!important}

/* extra images row — masonry */
.gallery-extra{columns:3;column-gap:8px;margin-top:8px}
.gallery-extra .g-item{break-inside:avoid;margin-bottom:8px;height:auto!important;max-height:none!important;grid-column:unset!important;grid-row:unset!important;display:block!important}
.gallery-extra .g-item img{width:100%;height:auto;display:block}

/* ── AMENITIES MASONRY ── */
.masonry-grid{
  columns:3;column-gap:8px;
}
.masonry-item{
  break-inside:avoid;margin-bottom:8px;position:relative;overflow:hidden;cursor:pointer;
}
.masonry-item img{width:100%;display:block;transition:transform .5s ease}
.masonry-item:hover img{transform:scale(1.04)}

/* ── INTERIOR GALLERY ROW ── */
.interior-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:48px}
.int-item{position:relative;overflow:hidden;cursor:pointer}
.int-item img{width:100%;height:200px;object-fit:cover;display:block;transition:transform .5s ease}
.int-item:hover img{transform:scale(1.05)}
.int-cap{
  position:absolute;bottom:0;left:0;right:0;
  padding:10px 14px;font-size:8px;letter-spacing:2px;text-transform:uppercase;
  color:rgba(242,223,170,.9);background:linear-gradient(transparent,rgba(22,8,8,.82));
  opacity:0;transition:opacity .3s;
}
.int-item:hover .int-cap{opacity:1}

/* ── AMENITIES ── */
.am-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.am-excl{background:rgba(192,133,43,.08);border:1px solid rgba(192,133,43,.2);padding:28px;margin-bottom:24px}
.am-excl-lbl{font-size:8px;letter-spacing:2.5px;text-transform:uppercase;color:var(--teal);margin-bottom:8px}
.am-excl-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:var(--teal-pale);margin-bottom:4px}
.am-excl-sub{font-size:12px;font-weight:300;color:rgba(242,223,170,.5);line-height:1.6}
.am-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:0}
.am-list li{font-size:12.5px;font-weight:300;color:rgba(242,223,170,.7);padding:9px 0;border-bottom:1px solid rgba(192,133,43,.08);display:flex;align-items:center;gap:8px}
.am-list li::before{content:'—';color:var(--teal);font-size:9px;flex-shrink:0}
.am-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;margin-top:24px}
#amenities{padding-bottom:0}
.am-strip{display:flex;gap:0;height:320px;margin-top:40px;width:100vw;margin-left:50%;transform:translateX(-50%)}
.am-strip-item{position:relative;overflow:hidden;flex:1;cursor:pointer;min-width:0}
.am-strip-item img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block;transition:transform .6s ease}
.am-strip-item:hover img{transform:scale(1.06)}
.am-strip-cap{position:absolute;bottom:0;left:0;right:0;padding:10px 12px;font-size:8px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(242,223,170,.9);background:linear-gradient(transparent,rgba(22,8,8,.85));opacity:0;transition:opacity .3s}
.am-strip-item:hover .am-strip-cap{opacity:1}

/* ── INVESTMENT ── */
.inv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(192,133,43,.1);margin-top:8px}
.inv-item{padding:28px 24px;background:var(--navy-deep)}
.inv-item:hover{background:var(--navy-mid)}
.inv-num{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:300;color:rgba(192,133,43,.25);line-height:1;margin-bottom:12px}
.inv-title{font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--teal-pale);margin-bottom:10px}
.inv-body{font-size:13px;font-weight:300;color:rgba(242,223,170,.45);line-height:1.75}

/* ── PAYMENT PLAN 60/40 ── */
.pp6040-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}

/* Table */
.pp6040-table-wrap{overflow-x:auto}
.pp6040-table{width:100%;border-collapse:collapse}
.pp6040-table thead tr{background:var(--navy);color:var(--gold-pale)}
.pp6040-table thead th{padding:14px 20px;font-size:8px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;text-align:left}
.pp6040-table thead th:last-child{text-align:right}
.pp6040-table tbody tr{border-bottom:1px solid rgba(192,133,43,.1)}
.pp6040-table tbody td{padding:13px 20px;font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:400;color:var(--navy);background:#fff}
.pp6040-table tbody td:last-child{text-align:right;font-weight:500}
.pp6040-table tr.pp-highlight td{background:rgba(192,133,43,.06)}
.pp6040-table tr.pp-highlight .pp-pct-cell{color:var(--gold);font-weight:700;font-size:19px}

/* Right panel */
.pp6040-split{display:grid;grid-template-columns:1fr 1px 1fr;align-items:center;border:1px solid rgba(192,133,43,.2);margin-bottom:32px}
.pp6040-half{padding:24px 20px;text-align:center}
.pp6040-num{font-family:'Cormorant Garamond',serif;font-size:48px;font-weight:300;color:var(--gold);line-height:1}
.pp6040-num span{font-size:22px;vertical-align:super}
.pp6040-lbl{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--grey);margin-top:4px}
.pp6040-divider{background:rgba(192,133,43,.2);height:100%}

/* Benefits */
.pp6040-benefits{display:flex;flex-direction:column;gap:18px;margin-bottom:28px}
.pp6040-benefit{display:flex;gap:14px;align-items:flex-start}
.pp6040-num-badge{min-width:28px;height:28px;background:rgba(192,133,43,.12);color:var(--gold);font-size:9px;font-weight:700;letter-spacing:1px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pp6040-benefit-title{font-family:'Cormorant Garamond',serif;font-size:18px;font-weight:400;color:var(--navy);margin-bottom:3px}
.pp6040-benefit-desc{font-size:12px;font-weight:300;color:var(--grey);line-height:1.6}

/* Example scenario */
.pp6040-example{background:var(--navy);padding:22px 24px}
.pp6040-example-lbl{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.pp6040-example-title{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:var(--gold-pale);margin-bottom:16px}
.pp6040-example-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid rgba(192,133,43,.12);font-size:12px;font-weight:300;color:rgba(242,223,170,.65)}
.pp6040-example-row:last-child{border-bottom:none}
.pp6040-example-val{color:var(--gold);font-weight:500;font-family:'Cormorant Garamond',serif;font-size:16px}

.pp-ho{border:1px solid rgba(192,133,43,.2);background:rgba(192,133,43,.04)}
.pp-ho-lbl{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:rgba(192,133,43,.7);margin-bottom:4px}
.pp-ho-val{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400;color:var(--navy)}
.pp-crypto-note{
  padding:12px 18px;
  background:rgba(192,133,43,.06);border-left:2px solid rgba(192,133,43,.35);
  font-size:12px;font-weight:300;color:var(--grey);line-height:1.6;letter-spacing:.3px;
}
.pp-note{margin-top:28px;padding:18px 24px;background:rgba(192,133,43,.06);border-left:2px solid rgba(192,133,43,.3)}
.pp-note p{font-size:12px;font-weight:300;color:var(--grey);line-height:1.7}

/* Payment methods */
.pay-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:28px}
.pay-method{
  padding:10px 14px;border:1px solid rgba(192,133,43,.3);
  font-size:9px;letter-spacing:2px;text-transform:uppercase;
  color:var(--navy);background:rgba(192,133,43,.06);
  display:flex;align-items:center;justify-content:center;gap:8px;cursor:default;text-align:center;
  transition:background .2s,border-color .2s;
}
.pay-method:hover{background:rgba(192,133,43,.12);border-color:var(--gold)}
.pay-method-icon{font-size:14px}

/* ── LOCATION ── */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.dist-table{width:100%;border-collapse:collapse}
.dist-table tr{border-bottom:1px solid rgba(192,133,43,.12)}
.dist-table td{padding:13px 0;font-size:12px;font-weight:300}
.dist-table .dest{color:var(--grey)}
.dist-table .time{text-align:right;color:var(--teal);font-weight:500;font-family:'Cormorant Garamond',serif;font-size:18px}

/* ── CONTACT / FORM SECTION ── */
.contact-sec{position:relative;overflow:hidden;background:var(--navy-deep)}
.contact-sec::before{
  content:'';position:absolute;inset:0;
  background-image:url('references/River Cove Residences/Images/River Cove Residences at Sobha City - Brochure (1)_Page_020.jpg');
  background-size:cover;background-position:center;opacity:.05;
}
.contact-ov{position:absolute;inset:0;background:rgba(22,8,8,.82)}
.contact-inner{
  position:relative;z-index:2;
  max-width:1200px;margin:0 auto;
  padding:96px 48px;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;
}
.c-item{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.c-icon{font-size:16px;min-width:24px;margin-top:2px}
.c-text{font-size:13px;font-weight:300;color:rgba(242,223,170,.55);line-height:1.6}
.c-text a{color:rgba(242,223,170,.7);text-decoration:none;transition:color .3s}
.c-text a:hover{color:var(--teal-pale)}

/* ── FORM ── */
.form-title{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:400;color:var(--cream);margin-bottom:6px}
.form-sub{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(192,133,43,.6);margin-bottom:28px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:6px}
.fg.full{grid-column:1/-1}
.fg label{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(192,133,43,.65);font-weight:400}
.fg input,.fg select,.fg textarea{
  background:rgba(255,255,255,.04);border:1px solid rgba(192,133,43,.2);
  color:var(--cream);padding:13px 14px;
  font-family:'Jost',sans-serif;
  font-size:13px;font-weight:300;outline:none;transition:border-color .3s;
  -webkit-appearance:none;appearance:none;border-radius:0;width:100%;
}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(242,223,170,.2)}
.fg input:focus,.fg select:focus{border-color:rgba(192,133,43,.55)}
.fg select{
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(192,133,43,.55)'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
}
.fg select option{background:var(--navy-deep);color:var(--cream)}

/* Validation states */
.fg input.valid,.fg select.valid{border-color:rgba(37,211,102,.4)}
.fg input.invalid,.fg select.invalid{border-color:rgba(255,100,100,.4)}
.field-hint{font-size:10px;color:rgba(255,138,138,.7);margin-top:3px;display:none}
.field-hint.show{display:block}
.field-hint.ok{color:rgba(37,211,102,.7)}

.f-btn{
  grid-column:1/-1;width:100%;
  background:var(--gold);color:var(--dark);
  padding:16px;font-size:9.5px;font-weight:600;letter-spacing:2.5px;
  text-transform:uppercase;border:none;cursor:pointer;
  font-family:'Jost',sans-serif;
  transition:background .3s;min-height:52px;
}
.f-btn:hover:not(:disabled){background:var(--gold-light)}
.f-btn:disabled{opacity:.55;cursor:wait}
.f-err{color:#ff8a8a;font-size:11px;margin-top:4px;display:none;grid-column:1/-1;padding:10px 12px;background:rgba(255,100,100,.08);border:1px solid rgba(255,100,100,.2)}
.f-priv{font-size:10px;color:rgba(242,223,170,.28);margin-top:4px;grid-column:1/-1;line-height:1.6}
.f-priv a{color:rgba(192,133,43,.5);text-decoration:none}
.f-ok{display:none;text-align:center;padding:40px 10px}
.f-ok-i{font-size:36px;margin-bottom:12px;color:var(--teal-light)}
.f-ok-t{font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--cream);margin-bottom:8px}
.f-ok-m{font-size:13px;font-weight:300;color:rgba(242,223,170,.5);line-height:1.7}

/* Retry counter */
.f-retry{font-size:10px;color:rgba(192,133,43,.4);text-align:center;grid-column:1/-1;margin-top:-4px;display:none}

/* ── DISCLAIMER ── */
.disc{background:var(--navy);padding:20px 48px}
.disc p{font-size:10px;font-weight:300;color:rgba(242,223,170,.35);line-height:1.75;max-width:1200px;margin:0 auto}

/* ── FOOTER ── */
footer{background:var(--navy-deep);padding:56px 48px 32px;border-top:1px solid rgba(192,133,43,.1)}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1fr 1fr 1fr;gap:48px;margin-bottom:40px;align-items:start}
.footer-col-mid{display:flex;flex-direction:column;align-items:center;text-align:center}
.footer-col-mid .f-col-title{text-align:center}
.footer-col-mid .fci{justify-content:flex-start;width:180px}
.f-logo img{height:44px;width:auto;display:block;background:transparent;margin-bottom:12px}
.f-tag{font-size:12px;font-weight:300;color:rgba(242,223,170,.4);max-width:280px;line-height:1.8}
.f-col-title{font-size:8.5px;letter-spacing:3px;text-transform:uppercase;color:rgba(192,133,43,.55);margin-bottom:16px}
.fci{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}
.fci-i{font-size:13px;min-width:20px;color:var(--teal);opacity:.7;margin-top:2px}
.fci-t{font-size:12px;font-weight:300;color:rgba(242,223,170,.55);text-decoration:none;line-height:1.5}
.fci-t:hover{color:var(--teal-pale)}
.dld-block{margin-top:20px;padding:16px;background:rgba(255,255,255,.02);border:1px solid rgba(192,133,43,.12)}
.dld-lbl{font-size:8px;letter-spacing:2px;text-transform:uppercase;color:rgba(192,133,43,.5);margin-bottom:8px}
.perm-r{font-size:11px;font-weight:300;color:rgba(242,223,170,.5);margin-bottom:4px}
.perm-r strong{color:rgba(242,223,170,.7);font-weight:500}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid rgba(192,133,43,.1);flex-wrap:wrap;gap:10px}
.f-leg{font-size:10px;font-weight:300;color:rgba(242,223,170,.3)}
.f-lnks{display:flex;gap:18px}
.f-lnks a{font-size:10px;font-weight:300;color:rgba(192,133,43,.5);text-decoration:none}
.f-lnks a:hover{color:var(--teal-pale)}

/* Developer + project logos in footer */
.footer-dev-logos{display:flex;align-items:center;gap:20px;margin-top:28px;flex-wrap:wrap;justify-content:flex-start}
.footer-dev-logos img{height:44px!important;width:auto;object-fit:contain;display:block;filter:brightness(0) invert(1);opacity:.9}
.footer-dev-sep{width:1px;height:44px;background:rgba(192,133,43,.25);flex-shrink:0}

/* ── WHATSAPP FLOAT ── */
.wa-wrap{position:fixed;bottom:28px;right:28px;z-index:300;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.wa-chat{background:var(--navy-deep);border:1px solid rgba(192,133,43,.25);width:300px;padding:20px;display:none;box-shadow:0 8px 32px rgba(0,0,0,.4);border-radius:2px}
.wa-chat.open{display:block}
.wa-chat-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.wa-chat-title{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:400;color:var(--cream)}
.wa-chat-close{background:none;border:none;color:rgba(242,223,170,.4);cursor:pointer;font-size:18px;line-height:1;transition:color .3s;padding:0}
.wa-chat-close:hover{color:var(--teal-pale)}
.wa-chat-msg{background:rgba(255,255,255,.04);border:1px solid rgba(192,133,43,.15);padding:12px 14px;font-size:12px;font-weight:300;color:rgba(242,223,170,.65);line-height:1.6;margin-bottom:12px}
.wa-chat-sub{font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(192,133,43,.5);margin-bottom:8px}
.wa-chat-input{background:rgba(255,255,255,.05);border:1px solid rgba(192,133,43,.2);color:var(--cream);padding:10px 12px;font-family:'Jost',sans-serif;font-size:12px;font-weight:300;outline:none;width:100%;transition:border-color .3s;margin-bottom:10px;resize:vertical;-webkit-appearance:none;border-radius:0}
.wa-chat-input::placeholder{color:rgba(242,223,170,.2)}
.wa-chat-input:focus{border-color:rgba(192,133,43,.5)}
.wa-chat-btn{width:100%;background:#25D366;color:#fff;padding:11px;font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;border:none;cursor:pointer;font-family:'Jost',sans-serif;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;transition:background .3s}
.wa-chat-btn:hover{background:#1aab54}
.wa-chat-btn svg{width:16px;height:16px;fill:#fff;flex-shrink:0}
.wa-btn{position:relative;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.3);cursor:pointer;border:none;transition:transform .3s,box-shadow .3s}
.wa-btn:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(37,211,102,.4)}
.wa-btn svg{width:28px;height:28px;fill:#fff;position:relative;z-index:1}
.wa-btn::before,.wa-btn::after{content:'';position:absolute;width:56px;height:56px;border-radius:50%;border:2px solid rgba(37,211,102,.5);animation:wapulse 3s ease-out infinite;pointer-events:none}
.wa-btn::after{animation-delay:1.5s;border-color:rgba(37,211,102,.3)}
@keyframes wapulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.9);opacity:0}100%{transform:scale(1.9);opacity:0}}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.82);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal-box{
  background:var(--navy-deep);border:1px solid rgba(192,133,43,.28);
  max-width:520px;width:100%;max-height:92vh;overflow-y:auto;
  padding:44px 40px;position:relative;
  scrollbar-width:thin;scrollbar-color:var(--teal) transparent;
}
.modal-box::-webkit-scrollbar{width:3px}
.modal-box::-webkit-scrollbar-thumb{background:var(--teal)}
.modal-close{position:absolute;top:18px;right:22px;background:none;border:none;color:rgba(242,223,170,.4);font-size:22px;cursor:pointer;transition:color .3s;line-height:1}
.modal-close:hover{color:var(--teal-pale)}
.modal-brand{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:rgba(192,133,43,.55);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.modal-brand::before{content:'';width:20px;height:1px;background:rgba(192,133,43,.4);flex-shrink:0}
.modal-title{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:400;color:var(--cream);margin-bottom:4px}
.modal-sub{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(192,133,43,.55);margin-bottom:28px}
.mfg-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:0}
.mfg-row .mfg{margin-bottom:0}
.mfg{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.mfg label{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(192,133,43,.6)}
.mfg input,.mfg select{background:rgba(255,255,255,.04);border:1px solid rgba(192,133,43,.2);color:var(--cream);padding:13px 14px;font-family:'Jost',sans-serif;font-size:13px;font-weight:300;outline:none;transition:border-color .3s;-webkit-appearance:none;appearance:none;border-radius:0;width:100%}
.mfg input::placeholder{color:rgba(242,223,170,.2)}
.mfg input:focus,.mfg select:focus{border-color:rgba(192,133,43,.55)}
.mfg select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(192,133,43,.55)'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.mfg select option{background:var(--navy-deep);color:var(--cream)}
.mfg input.valid,.mfg select.valid{border-color:rgba(37,211,102,.4)}
.mfg input.invalid,.mfg select.invalid{border-color:rgba(255,100,100,.4)}
.mfg-hint{font-size:10px;color:rgba(255,138,138,.7);margin-top:3px;display:none}
.mfg-hint.show{display:block}
.mfg-hint.ok{color:rgba(37,211,102,.7)}
.m-btn{width:100%;background:var(--gold);color:var(--dark);padding:16px;font-size:9.5px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;border:none;cursor:pointer;font-family:'Jost',sans-serif;margin-top:6px;transition:background .3s;min-height:52px}
.m-btn:hover:not(:disabled){background:var(--gold-light)}
.m-btn:disabled{opacity:.55;cursor:wait}
.m-err{color:#ff8a8a;font-size:11px;margin-top:8px;display:none;padding:10px 12px;background:rgba(255,100,100,.08);border:1px solid rgba(255,100,100,.2)}
.m-priv{font-size:10px;color:rgba(242,223,170,.25);margin-top:12px;line-height:1.6}
.m-priv a{color:rgba(192,133,43,.5);text-decoration:none}
.m-ok{display:none;text-align:center;padding:40px 10px}
.m-ok-i{font-size:36px;margin-bottom:12px;color:var(--teal-light)}
.m-ok-t{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--cream);margin-bottom:8px}
.m-ok-m{font-size:12px;font-weight:300;color:rgba(242,223,170,.5);line-height:1.7}
.m-retry{font-size:10px;color:rgba(192,133,43,.4);text-align:center;margin-top:8px;display:none}

/* ── LIGHTBOX ── */
.lb-overlay{display:none;position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.92);align-items:center;justify-content:center;cursor:zoom-out}
.lb-overlay.open{display:flex}
.lb-inner{position:relative;max-width:92vw;max-height:88vh;display:flex;align-items:center;justify-content:center}
.lb-img{max-width:92vw;max-height:88vh;object-fit:contain;display:block;box-shadow:0 20px 80px rgba(0,0,0,.6);cursor:default}
.lb-cap{position:absolute;bottom:-31px;left:0;right:0;text-align:center;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(242,223,170,.95)}
.lb-close{position:fixed;top:20px;right:24px;z-index:10;background:none;border:none;color:rgba(242,223,170,.6);font-size:28px;cursor:pointer;line-height:1;transition:color .3s;padding:4px 8px}
.lb-close:hover{color:var(--teal-pale)}
.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(46,17,17,.55);border:1px solid rgba(192,133,43,.25);color:var(--teal-pale);font-size:20px;cursor:pointer;padding:14px 18px;z-index:10;transition:background .3s;line-height:1}
.lb-prev{left:16px}
.lb-next{right:16px}
.lb-prev:hover,.lb-next:hover{background:rgba(46,17,17,.85)}

/* ── PRICE TBA ── */
.price-tba{font-size:10px;letter-spacing:1.5px;color:rgba(192,133,43,.55);text-transform:uppercase}

/* ── LOAD MORE BUTTON ── */
.load-more-wrap{display:flex;justify-content:center;margin-top:40px}
.load-more-btn{
  padding:7px 40px;background:transparent;
  border:1px solid rgba(192,133,43,.4);color:var(--teal-pale);
  font-size:9px;letter-spacing:2.5px;text-transform:uppercase;
  cursor:pointer;font-family:'Jost',sans-serif;transition:all .3s;
}
.load-more-btn:hover{background:var(--teal);color:var(--cream);border-color:var(--teal)}

/* ── MULTI-STEP FORM ── */
.ms-progress{height:3px;background:rgba(192,133,43,.15);border-radius:2px;margin-bottom:10px;overflow:hidden}
.ms-bar{height:100%;background:var(--teal);border-radius:2px;transition:width .4s ease}
.ms-step-lbl{font-size:9px;letter-spacing:2px;color:rgba(192,133,43,.55);text-transform:uppercase;margin-bottom:24px}
.ms-step{display:none}
.ms-step.active{display:block;animation:msIn .32s ease both}
.ms-step.active.ms-back{animation:msInBack .32s ease both}
.ms-q{font-family:'Cormorant Garamond',serif;font-size:clamp(20px,3vw,24px);color:var(--cream);font-weight:400;line-height:1.3;margin-bottom:6px}
.ms-hint{font-size:11px;color:rgba(192,133,43,.6);letter-spacing:.8px;margin-bottom:20px}
.ms-nxt{width:100%;padding:15px 24px;background:var(--gold);color:#1a0a0a;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;font-weight:700;border:none;cursor:pointer;margin-top:14px;transition:opacity .2s}
.ms-nxt:hover{opacity:.85}
.ms-nxt:disabled{opacity:.5;cursor:not-allowed}
.ms-row{display:flex;gap:10px;align-items:center;margin-top:14px}
.ms-row .ms-nxt{flex:1;margin-top:0}
.ms-bck{padding:15px 14px;background:transparent;border:1px solid rgba(192,133,43,.3);color:rgba(192,133,43,.65);font-size:9px;letter-spacing:1.5px;cursor:pointer;transition:border-color .2s;white-space:nowrap;text-transform:uppercase}
.ms-bck:hover{border-color:var(--teal);color:var(--teal)}
.ms-err{font-size:11px;color:#e07070;margin-top:8px;min-height:14px}
@keyframes msIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:translateX(0)}}
@keyframes msInBack{from{opacity:0;transform:translateX(-18px)}to{opacity:1;transform:translateX(0)}}

/* ══════════════════════════════════════
   RESPONSIVE — TABLET (max 900px)
══════════════════════════════════════ */
@media(max-width:900px){
  nav{padding:12px 20px}
  .nav-links{display:none}
  .nav-ham{display:flex}
  .hero-inner{padding:80px 24px 56px}
  .stats{grid-template-columns:1fr 1fr;max-width:100%}
  .sec{padding:64px 24px}
  .about-grid,.loc-grid,.am-layout,.contact-inner{grid-template-columns:1fr;gap:40px}
  .about-img-wrap{order:-1}
  .facts-bar{padding:24px}
  .facts-inner{grid-template-columns:1fr 1fr}
  .inv-grid{grid-template-columns:1fr 1fr}
  .pp-grid{grid-template-columns:1fr}
  .units-grid{grid-template-columns:1fr 1fr}
  .contact-inner{padding:64px 24px}
  .form-grid{grid-template-columns:1fr}
  .fg.full,.f-btn,.f-err,.f-priv,.f-retry{grid-column:1}
  .disc{padding:16px 24px}
  footer{padding:40px 24px 24px}
  .footer-top{grid-template-columns:1fr;gap:36px}
  .footer-top>div{display:flex;flex-direction:column;align-items:center;text-align:center}
  .footer-dev-logos{justify-content:center}
  .footer-dev-logos img{height:52px!important}
  .footer-dev-sep{height:52px}
  .footer-top>div .fci{justify-content:flex-start}
  .footer-col-mid{display:block}
  .footer-col-mid .f-col-title{display:block;grid-column:1/-1;margin-bottom:12px}
  .footer-col-mid .fci{width:auto;display:inline-flex;vertical-align:top}
  .footer-col-mid-links{display:grid;grid-template-columns:1fr 1fr;gap:0 12px}
  .footer-col-mid-links .fci{justify-content:flex-start;margin-bottom:8px}
  .footer-top>div .f-tag{text-align:center;max-width:100%}
  .footer-top>div .dld-block{width:100%;max-width:320px;text-align:left}
  .footer-bottom{justify-content:center;text-align:center}
  .wa-chat{width:260px}
  .pillars-grid{grid-template-columns:1fr}
  .mp-stats-grid{grid-template-columns:1fr 1fr}
  .phase1-grid{grid-template-columns:1fr 1fr;gap:12px}
  .interior-gallery{grid-template-columns:1fr 1fr}
  .am-cats{gap:20px}
  /* Floor plans tablet */
  .fp-cards-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .fp-search-wrap{padding:10px 14px}
  /* Sub communities */
  .comm-panel.active{grid-template-columns:1fr;gap:32px}
  /* Masterplan */
  .mp-popup{width:220px}
  /* Amenities */
  .am-layout{grid-template-columns:1fr;gap:40px}
  .am-list{grid-template-columns:1fr 1fr}
  .am-strip{height:260px}
}

/* ══════════════════════════════════════
   RESPONSIVE — MOBILE (max 640px)
══════════════════════════════════════ */
@media(max-width:640px){
  nav{padding:10px 16px}
  .nav-logo img{height:30px}
  .nav-btn{padding:8px 14px;font-size:8px;letter-spacing:2px}
  .hero-inner{padding:90px 20px 52px;text-align:center}
  .hero-ov{background:linear-gradient(180deg,rgba(22,8,8,.45) 0%,rgba(22,8,8,.3) 25%,rgba(22,8,8,.7) 60%,rgba(22,8,8,.97) 100%)}
  .eyebrow{justify-content:center;font-size:8px}
  .eyebrow::before{display:none}
  .stats{grid-template-columns:1fr 1fr;max-width:100%;margin-bottom:32px}
  .cta-row{flex-direction:column;align-items:stretch;gap:10px}
  .btn-gold,.btn-ghost{width:100%;padding:16px 20px;font-size:9px}
  .sec{padding:52px 20px}
  .st{font-size:clamp(26px,8vw,38px)}
  .sl{justify-content:center;text-align:center}
  .sl::before{display:none}
  .sb{font-size:13px}
  /* About */
  .about-grid{gap:32px}
  /* Investment */
  .inv-grid{grid-template-columns:1fr}
  /* Payment */
  .pp-grid{grid-template-columns:1fr}
  .pp-dot{display:none}
  /* Units */
  .units-grid{grid-template-columns:1fr}
  /* Floor plans */
  .fp-cards-grid{grid-template-columns:1fr;gap:16px}
  .fp-card{border-radius:12px}
  .fp-card-specs{grid-template-columns:repeat(2,1fr)}
  .fp-spec:nth-child(2){border-right:none}
  .fp-spec:nth-child(3){border-right:1px solid #f0f0f0;border-top:1px solid #f0f0f0}
  .fp-spec:nth-child(4){border-top:1px solid #f0f0f0}
  .fp-search-wrap{padding:10px 12px}
  .fp-show-all-btn{width:100%;justify-content:center;padding:14px 20px}
  /* Modal */
  .modal-box{padding:28px 16px;margin:16px}
  .modal-title{font-size:22px}
  .modal-close{top:12px;right:12px}
  /* Facts bar */
  .facts-inner{grid-template-columns:1fr 1fr}
  .fact-item{padding:16px 12px}
  .fact-v{font-size:22px}
  /* Gallery — masonry on mobile */
  .gallery-tabs{gap:0}
  .gallery-tab{padding:8px 14px;font-size:8px}
  .gallery-grid{display:block;columns:2;column-gap:8px;grid-template-columns:unset;grid-template-rows:unset}
  .g-item,.g-item.tall,.g-item.wide{display:block!important;height:auto!important;max-height:none!important;grid-column:unset!important;grid-row:unset!important;break-inside:avoid;margin-bottom:8px}
  .g-item img{width:100%;height:auto;display:block}
  .gallery-extra{columns:2}
  .masonry-grid{columns:2}
  /* Amenities */
  .am-layout{grid-template-columns:1fr;gap:32px}
  .am-list{grid-template-columns:1fr 1fr}
  .am-strip{height:220px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .am-strip-item{flex:0 0 60vw;min-width:160px}
  /* Masterplan */
  .mp-stats-grid{grid-template-columns:1fr 1fr}
  .mp-popup{width:200px;font-size:11px}
  .mp-popup-img{height:110px}
  /* Sub communities — hide map, show only banner */
  .comm-tabs{gap:0;flex-wrap:wrap}
  .comm-tab{padding:10px 14px;font-size:8px;flex:1 1 auto;text-align:center}
  .comm-panel.active{grid-template-columns:1fr;gap:28px}
  .comm-panel .comm-map-img{display:none}
  .comm-specs-grid{grid-template-columns:1fr 1fr}
  /* Phase 1 */
  .phase1-grid{grid-template-columns:1fr;gap:14px}
  /* Pillars */
  .pillars-grid{grid-template-columns:1fr}
  .pillar{padding:24px 20px}
  /* Location */
  .loc-grid{grid-template-columns:1fr;gap:32px}
  .loc-map{height:240px}
  /* Interior gallery */
  .interior-gallery{grid-template-columns:1fr 1fr}
  /* Footer */
  footer{padding:36px 20px 24px}
  .footer-bottom{flex-direction:column;align-items:center;gap:12px;text-align:center}
  .disc{padding:16px 20px}
  /* WhatsApp */
  .wa-wrap{bottom:20px;right:16px}
  .wa-chat{width:calc(100vw - 32px)}
  /* Lightbox */
  .lb-prev{left:4px;padding:10px 12px}
  .lb-next{right:4px;padding:10px 12px}
  .hero-dots{right:16px;bottom:16px}
  /* Mfg */
  .mfg-row{grid-template-columns:1fr}
}

@media(max-width:380px){
  .gallery-grid{grid-template-columns:1fr}
  .g-item,.g-item.tall,.g-item.wide{grid-column:span 1!important;height:180px!important;max-height:180px!important}
  .gallery-extra{columns:1}
  .masonry-grid{columns:1}
  .am-strip-item{flex:0 0 55vw;min-width:140px}
  .stats{grid-template-columns:1fr 1fr}
  .fp-card-specs{grid-template-columns:1fr 1fr}
}

/* ── MOBILE NAV — logo left, register center, burger right ── */
@media(max-width:768px){
  nav{padding:12px 16px!important;position:fixed!important;justify-content:space-between}
  nav.scrolled{padding:9px 16px!important}
  .nav-links{display:none!important}
  .nav-logo{order:1;position:static!important;transform:none!important;flex:0 0 auto}
  .nav-btn{
    order:2;
    position:absolute;left:50%;transform:translateX(-50%);
    font-size:8px;padding:7px 14px;letter-spacing:1.5px;
    white-space:nowrap;
  }
  .nav-ham{display:flex!important;order:3}
}

/* ── MOBILE — center headings & body text ── */
@media(max-width:768px){
  .st{text-align:center}
  .sb{text-align:center}
  .sl{justify-content:center!important;text-align:center!important}
  .sl::before{display:none}
  .fu .sl,.fu .st,.fu .sb{text-align:center}
}

/* ── UNITS FILTER — mobile scrollable tabs ── */
@media(max-width:768px){
  .units-tabs{
    display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;
    gap:8px;padding-bottom:8px;flex-wrap:nowrap;justify-content:flex-start;
  }
  .units-tabs::-webkit-scrollbar{height:2px}
  .units-tabs::-webkit-scrollbar-thumb{background:rgba(192,133,43,.3)}
  .unit-tab{white-space:nowrap;flex-shrink:0;font-size:8px;padding:8px 14px}
}

/* ── PAYMENT SECTION — mobile centering ── */
@media(max-width:768px){
  .pp-ho{display:flex;width:100%;justify-content:center;box-sizing:border-box}
  .pay-methods{grid-template-columns:repeat(2,1fr)}
  .pay-method{justify-content:center}
  .pp-note{text-align:center}
  .pp-note p{text-align:center}
  /* 60/40 grid stacks on mobile */
  .pp6040-grid{grid-template-columns:1fr;gap:36px}
  .pp6040-table-wrap{overflow-x:auto}
  .pp6040-table tbody td{font-size:14px;padding:11px 14px}
  .pp6040-table thead th{padding:12px 14px}
  .pp6040-split{margin-bottom:24px}
  .pp6040-num{font-size:38px}
}

/* ════════════════════════════════════════════
   FLOOR PLAN SEARCH BAR
════════════════════════════════════════════ */
.fp-search-wrap{
  display:flex;align-items:center;gap:12px;
  background:#fff;border:1.5px solid rgba(192,133,43,.25);
  padding:12px 16px;margin-bottom:12px;
  border-radius: 24px;
}
.fp-search-wrap:focus-within{border-color:#1a6a78;box-shadow:0 0 0 3px rgba(192,133,43,.08)}
.fp-search-icon{color:#1a6a78;flex-shrink:0;display:flex}
.fp-search-input{
  flex:1;border:none;outline:none;font-size:14px;font-family:'Jost',sans-serif;
  color:#0a1628;background:transparent;
}
.fp-search-input::placeholder{color:#9ca3af;font-weight:300}
.fp-search-clear{
  background:none;border:none;cursor:pointer;color:#9ca3af;
  font-size:14px;line-height:1;padding:2px 4px;transition:color .2s;flex-shrink:0;
}
.fp-search-clear:hover{color:#374151}

/* ════════════════════════════════════════════
   FLOOR PLAN DROPDOWN FILTER BAR
════════════════════════════════════════════ */
.fp-dd-bar{
  display:grid;grid-template-columns:repeat(4,1fr);align-items:end;gap:12px;
  background:#f8f8f6;border:1px solid rgba(192,133,43,.12);
  padding:16px 20px;margin-bottom:24px;border-radius:4px;
}
.fp-dd-group{display:flex;flex-direction:column;gap:5px}
.fp-dd-label{
  font-size:8px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  color:var(--gold);
}
.fp-dd{
  padding:9px 28px 9px 10px;border:1.5px solid rgba(192,133,43,.3);
  background:#fff;color:var(--navy);font-size:13px;font-weight:500;
  cursor:pointer;outline:none;transition:border-color .2s;
  -webkit-appearance:none;appearance:none;border-radius:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(192,133,43,.6)'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;
}
.fp-dd:focus{border-color:var(--gold)}
.fp-dd-reset{
  align-self:flex-end;padding:9px 18px;
  background:var(--gold);color:#fff;border:none;cursor:pointer;
  font-size:12px;font-weight:600;letter-spacing:.05em;white-space:nowrap;
  transition:background .2s;border-radius:0;
}
.fp-dd-reset:hover{background:var(--navy)}
@media(max-width:768px){
  .fp-dd-bar{grid-template-columns:repeat(2,1fr);gap:10px;padding:14px 16px}
  .fp-dd-reset{grid-column:span 2}
}
@media(max-width:480px){
  .fp-dd-bar{grid-template-columns:repeat(2,1fr);gap:8px;padding:12px}
  .fp-dd-label{font-size:7px;letter-spacing:.1em}
  .fp-dd{font-size:11px;padding:7px 24px 7px 8px}
  .fp-dd-reset{grid-column:span 2;padding:8px;font-size:11px}
}

/* ════════════════════════════════════════════
   FLOOR PLAN FILTER BAR (legacy — unused)
════════════════════════════════════════════ */
.fp-filters{
  display:flex;flex-direction:column;gap:14px;margin-bottom:24px;
}
.fp-filter-row{
  display:flex;align-items:center;flex-wrap:wrap;gap:10px;
}
.fp-filter-label{
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--teal);min-width:90px;flex-shrink:0;
}
.fp-filter-btns{
  display:flex;flex-wrap:wrap;gap:8px;
}
.fp-btn{
  padding:7px 16px;border-radius:100px;border:1.5px solid rgba(192,133,43,.3);
  background:#fff;color:#1a6a78;font-size:12px;font-weight:600;cursor:pointer;
  transition:background .18s,color .18s,border-color .18s;white-space:nowrap;
}
.fp-btn:hover{background:rgba(192,133,43,.08);border-color:#1a6a78}
.fp-btn.active{background:#1a6a78;color:#fff;border-color:#1a6a78}

/* results meta row */
.fp-results-meta{
  display:flex;align-items:center;gap:16px;margin-bottom:24px;
}
.fp-count-label{
  font-size:13px;color:#6b7280;
}
.fp-reset-btn{
  padding:5px 14px;border-radius:100px;border:1.5px solid rgba(192,133,43,.3);
  background:transparent;color:#1a6a78;font-size:12px;font-weight:600;cursor:pointer;
  transition:background .18s,color .18s;
}
.fp-reset-btn:hover{background:#1a6a78;color:#fff;border-color:#1a6a78}

/* ════════════════════════════════════════════
   FLOOR PLAN CARDS GRID
════════════════════════════════════════════ */
.fp-cards-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:24px;
}
.fp-cards-grid.collapsed .fp-card:nth-child(n+9){display:none}
@media(max-width:640px){
  .fp-cards-grid.collapsed .fp-card:nth-child(n+4){display:none}
}

/* Show All button */
.fp-show-all-wrap{display:flex;justify-content:center;margin-top:32px}
.fp-show-all-btn{
  background:transparent;border:1px solid var(--gold);
  color:var(--navy);padding:14px 40px;
  font-family:'Jost',sans-serif;font-size:9px;font-weight:500;
  letter-spacing:2.5px;text-transform:uppercase;cursor:pointer;
  transition:all .3s;display:flex;align-items:center;gap:8px;
}
.fp-show-all-btn:hover{background:var(--gold);color:#fff}
.fp-show-all-arrow{font-size:14px;transition:transform .3s}

.fp-card{
  background:#fff;border-radius:16px;overflow:hidden;
  box-shadow:0 2px 12px rgba(0,0,0,.07);
  display:flex;flex-direction:column;
  transition:box-shadow .22s,transform .22s;
}
.fp-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.13);transform:translateY(-3px)}

/* card header row: tower badge + type label */
.fp-card-top{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 0;
}
.fp-tower-badge{
  font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;
}
.fp-badge-a{background:#e8f4f7;color:#0f5361}
.fp-badge-b{background:#f0ece8;color:#7a4f2e}
.fp-type-label{
  font-size:11px;font-weight:600;color:#6b7280;
}

/* floor plan image */
.fp-img-wrap{
  position:relative;cursor:zoom-in;overflow:hidden;margin:12px 16px 0;
  border-radius:10px;background:#f3f4f6;aspect-ratio:4/3;
}
.fp-img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .3s;
}
.fp-img-wrap:hover .fp-img{transform:scale(1.04)}
.fp-zoom-icon{
  position:absolute;top:8px;right:8px;background:rgba(0,0,0,.45);color:#fff;
  width:30px;height:30px;border-radius:6px;display:flex;align-items:center;
  justify-content:center;opacity:0;transition:opacity .2s;pointer-events:none;
}
.fp-img-wrap:hover .fp-zoom-icon{opacity:1}

/* specs row */
.fp-card-specs{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;padding:14px 16px 0;border-top:1px solid #f0f0f0;margin-top:14px;
}
.fp-spec{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:8px 4px;border-right:1px solid #f0f0f0;
}
.fp-spec:last-child{border-right:none}
.fp-sv{
  font-size:13px;font-weight:700;color:#111;line-height:1.1;white-space:nowrap;
}
.fp-sl{
  font-size:9px;color:#9ca3af;margin-top:3px;white-space:nowrap;
}

/* view tag */
.fp-view-tag{
  font-size:11px;font-weight:600;padding:6px 16px;margin:10px 16px 0;
  border-radius:6px;display:inline-block;align-self:flex-start;
}
.fp-view-amenity{background:#e8f4f7;color:#0f5361}
.fp-view-green{background:#e8f5ee;color:#1a5c35}
.fp-view-canal{background:#e8eef7;color:#1a3c78}

/* sample units — hidden per design */
.fp-units{display:none}

/* CTA button */
.fp-card .unit-cta{
  margin:14px 16px 16px;width:calc(100% - 32px);
}

/* no results message */
.fp-no-results{
  text-align:center;padding:48px 24px;color:#6b7280;font-size:15px;
}
.fp-reset-inline{
  background:none;border:none;color:#1a6a78;font-weight:600;cursor:pointer;
  text-decoration:underline;font-size:inherit;
}

/* ════════════════════════════════════════════
   FLOOR PLAN — MOBILE
════════════════════════════════════════════ */
@media(max-width:768px){
  .fp-filter-row{flex-direction:column;align-items:flex-start}
  .fp-filter-label{min-width:auto}
  .fp-filter-btns{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:4px;width:100%}
  .fp-filter-btns::-webkit-scrollbar{height:2px}
  .fp-filter-btns::-webkit-scrollbar-thumb{background:rgba(192,133,43,.3)}
  .fp-btn{flex-shrink:0}
  .fp-cards-grid{grid-template-columns:1fr}
  .fp-card-specs{grid-template-columns:repeat(2,1fr)}
  .fp-spec:nth-child(2){border-right:none}
  .fp-spec:nth-child(3){border-right:1px solid #f0f0f0;border-top:1px solid #f0f0f0}
  .fp-spec:nth-child(4){border-top:1px solid #f0f0f0}
}
