/* =========================================================================
   GAURAV RAGHAV CORPORATION — 85 BIGHA GATED COMMUNITY PLOTS, JEWAR
   Design tokens: Emerald & Ivory with Black/Gold brand strip
   Display: 'Cormorant Garamond' | Body: 'Manrope' | Utility: 'Manrope' (caps)
   ========================================================================= */

:root{
  /* Color tokens */
  --gr-ink:            #0A0A0A;   /* black strip */
  --gr-emerald-900:     #072A20;
  --gr-emerald-800:     #0B3D2E;
  --gr-emerald-700:     #145C43;
  --gr-emerald-600:     #1C7A57;
  --gr-emerald-50:       #EAF3EE;
  --gr-ivory:           #FAF9F5;
  --gr-white:           #FFFFFF;
  --gr-gold:            #C9A227;
  --gr-gold-light:      #E8C874;
  --gr-gold-dim:        rgba(201,162,39,0.35);
  --gr-stone-600:       #5B655F;
  --gr-stone-300:       #D8DED9;
  --gr-line:            rgba(11,61,46,0.12);

  /* Elevation */
  --shadow-soft: 0 10px 30px -12px rgba(7,42,32,0.18);
  --shadow-lift: 0 20px 60px -20px rgba(7,42,32,0.35);
  --shadow-gold: 0 8px 24px -8px rgba(201,162,39,0.45);

  /* Type */
  --font-display: 'Cormorant Garamond', 'Georgia', serif;
  --font-body: 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Radii */
  --r-sm: 8px;
  --r-md: 16px;
  --r-lg: 28px;
  --r-pill: 999px;

  /* Motion */
  --ease-lux: cubic-bezier(.22,.9,.22,1);
  --dur-fast: .25s;
  --dur-med: .55s;
  --dur-slow: 1.1s;

  --container: 1240px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  font-family:var(--font-body);
  color:var(--gr-emerald-900);
  background:var(--gr-ivory);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
input{font-family:inherit;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.1;color:var(--gr-emerald-900);}
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px;}

/* Visually hidden (a11y) */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.skip-link{position:absolute;left:12px;top:-60px;background:var(--gr-emerald-800);color:#fff;padding:12px 18px;border-radius:var(--r-sm);z-index:9999;transition:top .2s var(--ease-lux);}
.skip-link:focus{top:12px;}

/* Focus visibility */
a:focus-visible,button:focus-visible,input:focus-visible{
  outline:2px solid var(--gr-gold);
  outline-offset:3px;
  border-radius:4px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}

/* ---------- Eyebrow / labels ---------- */
.eyebrow{
  font-family:var(--font-body);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--gr-gold);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:'';
  width:28px;height:1px;
  background:var(--gr-gold);
  display:inline-block;
}
.eyebrow.center{justify-content:center;}
.eyebrow.center::before{display:none;}

.section-head{max-width:720px;margin-bottom:52px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head h2{font-size:clamp(2rem,4vw,2.9rem);margin-top:14px;}
.section-head p{margin-top:16px;color:var(--gr-stone-600);font-size:1.05rem;max-width:60ch;}
.section-head.center p{margin-left:auto;margin-right:auto;}

.section-pad{padding:100px 0;}
@media(max-width:768px){.section-pad{padding:64px 0;}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 34px;
  border-radius:var(--r-pill);
  font-weight:700;font-size:.95rem;letter-spacing:.02em;
  transition:transform var(--dur-fast) var(--ease-lux), box-shadow var(--dur-fast) var(--ease-lux), background var(--dur-fast);
  white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg,var(--gr-emerald-700),var(--gr-emerald-800));
  color:#fff;
  box-shadow:var(--shadow-soft);
  border:1px solid var(--gr-emerald-700);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift);}
.btn-gold{
  background:linear-gradient(135deg,var(--gr-gold-light),var(--gr-gold));
  color:var(--gr-ink);
  box-shadow:var(--shadow-gold);
}
.btn-gold:hover{transform:translateY(-3px);filter:brightness(1.04);}
.btn-outline{
  background:transparent;
  border:1.5px solid var(--gr-emerald-800);
  color:var(--gr-emerald-800);
}
.btn-outline:hover{background:var(--gr-emerald-800);color:#fff;transform:translateY(-3px);}
.btn-ghost-white{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.35);
  color:#fff;
  backdrop-filter:blur(6px);
}
.btn-ghost-white:hover{background:rgba(255,255,255,0.18);transform:translateY(-3px);}
.btn-block{width:100%;}
.btn-sm{padding:11px 22px;font-size:.85rem;}

/* ---------- Glassmorphism helper ---------- */
.glass{
  background:rgba(255,255,255,0.65);
  backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  border:1px solid rgba(255,255,255,0.5);
}
.glass-dark{
  background:rgba(10,20,16,0.55);
  backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  border:1px solid rgba(255,255,255,0.12);
}

/* =========================================================================
   TOP STRIP (Black + Gold)
   ========================================================================= */
.top-strip{
  background:linear-gradient(90deg,#000000 0%, var(--gr-ink) 55%, #111111 100%);
  color:#EDEAE0;
  border-bottom:1px solid var(--gr-gold-dim);
  font-size:.82rem;
  position:relative;
  z-index:60;
}
.top-strip::after{
  content:'';
  position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg,transparent, var(--gr-gold) 20%, var(--gr-gold-light) 50%, var(--gr-gold) 80%, transparent);
  opacity:.7;
}
.top-strip-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 24px;gap:20px;flex-wrap:wrap;
}
.top-strip-left{display:flex;align-items:center;gap:26px;flex-wrap:wrap;}
.top-strip a{display:inline-flex;align-items:center;gap:8px;color:#EDEAE0;transition:color var(--dur-fast);}
.top-strip a:hover{color:var(--gr-gold-light);}
.top-strip svg{width:15px;height:15px;stroke:var(--gr-gold);flex-shrink:0;}
.top-strip-right{display:flex;align-items:center;gap:16px;}
.top-strip-tag{
  letter-spacing:.14em;text-transform:uppercase;font-size:.68rem;color:var(--gr-gold-light);
  border:1px solid var(--gr-gold-dim);padding:5px 12px;border-radius:var(--r-pill);
}
.top-strip-socials{display:flex;gap:10px;}
.top-strip-socials a{
  width:28px;height:28px;border-radius:50%;
  align-items:center;justify-content:center;
  border:1px solid rgba(201,162,39,0.4);
}
.top-strip-socials svg{width:13px;height:13px;}

/* =========================================================================
   NAVIGATION (White + Green)
   ========================================================================= */
.navbar{
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  position:sticky;top:0;z-index:59;
  border-bottom:1px solid var(--gr-line);
  transition:box-shadow var(--dur-fast), padding var(--dur-fast);
}
.navbar.is-scrolled{box-shadow:0 8px 30px -12px rgba(7,42,32,0.18);}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;
}
.brand{display:flex;align-items:center;gap:14px;}
.brand-logo{
  /* ~40% larger than a standard 40px logo mark */
  width:56px;height:56px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--gr-emerald-800),var(--gr-emerald-700));
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;
  box-shadow:0 6px 18px -6px rgba(11,61,46,0.45), inset 0 0 0 1px rgba(201,162,39,0.5);
}
.brand-logo img{width:100%;height:100%;object-fit:contain;}
.brand-logo .logo-fallback{
  font-family:var(--font-display);color:var(--gr-gold-light);font-weight:700;font-size:1.5rem;
}
.brand-text{display:flex;flex-direction:column;line-height:1.2;}
.brand-text .brand-name{font-family:var(--font-display);font-weight:700;font-size:1.28rem;color:var(--gr-emerald-900);}
.brand-text .brand-sub{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gr-gold);font-weight:700;}

.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{
  font-size:.92rem;font-weight:600;color:var(--gr-emerald-900);
  position:relative;padding:6px 0;
}
.nav-links a::after{
  content:'';position:absolute;left:0;bottom:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--gr-gold),var(--gr-emerald-700));
  transition:width var(--dur-fast) var(--ease-lux);
}
.nav-links a:hover::after,.nav-links a:focus-visible::after{width:100%;}
.nav-cta{display:flex;align-items:center;gap:14px;}
.nav-toggle{
  display:none;width:44px;height:44px;border-radius:10px;align-items:center;justify-content:center;
  border:1px solid var(--gr-line);
}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--gr-emerald-900);position:relative;}
.nav-toggle span::before,.nav-toggle span::after{content:'';position:absolute;left:0;width:20px;height:2px;background:var(--gr-emerald-900);transition:transform var(--dur-fast);}
.nav-toggle span::before{top:-6px;}
.nav-toggle span::after{top:6px;}

@media(max-width:960px){
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(320px,85vw);height:100vh;
    background:var(--gr-ivory);flex-direction:column;align-items:flex-start;
    padding:100px 32px 32px;gap:26px;
    transform:translateX(100%);transition:transform var(--dur-med) var(--ease-lux);
    box-shadow:-20px 0 60px rgba(0,0,0,0.15);
  }
  .nav-links.is-open{transform:translateX(0);}
  .nav-toggle{display:flex;}
  .nav-cta .btn{display:none;}
}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(28,122,87,0.35), transparent 55%),
    radial-gradient(ellipse at 90% 20%, rgba(201,162,39,0.18), transparent 45%),
    linear-gradient(180deg,var(--gr-emerald-900) 0%, var(--gr-emerald-800) 55%, #0d3327 100%);
  overflow:hidden;
  padding:140px 0 100px;
}
.hero-grid-svg{
  position:absolute;inset:0;width:100%;height:100%;opacity:.35;
  pointer-events:none;
}
.hero-grid-svg path{
  fill:none;stroke:var(--gr-gold-light);stroke-width:1;
  stroke-dasharray:2200;stroke-dashoffset:2200;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size:26px 26px;
  mask-image:radial-gradient(ellipse at 50% 30%, black, transparent 70%);
  opacity:.5;
}
.hero-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:start;
  width:100%;max-width:var(--container);margin:0 auto;padding:0 24px;
}
.hero-copy .eyebrow{color:var(--gr-gold-light);}
.hero-copy .eyebrow::before{background:var(--gr-gold-light);}
.hero-copy h1{
  color:#fff;font-size:clamp(2.6rem,5.2vw,4.4rem);margin-top:18px;
  letter-spacing:-.01em;
}
.hero-copy h1 em{color:var(--gr-gold-light);font-style:normal;}
.hero-copy p.lede{
  color:rgba(255,255,255,0.82);font-size:1.15rem;max-width:56ch;margin-top:22px;
}
.hero-badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px;}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:var(--r-pill);
  font-size:.82rem;font-weight:700;color:#fff;
}
.hero-badge svg{width:16px;height:16px;stroke:var(--gr-gold-light);}
.hero-actions{display:flex;gap:18px;margin-top:38px;flex-wrap:wrap;}

.hero-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  margin-top:56px;padding-top:34px;border-top:1px solid rgba(255,255,255,0.16);
  max-width:560px;
}
.hero-stats .stat h3{color:var(--gr-gold-light);font-size:clamp(1.8rem,3vw,2.5rem);}
.hero-stats .stat span{display:block;color:rgba(255,255,255,0.7);font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;margin-top:4px;}

/* Floating lead form card in hero */
.lead-card{
  position:relative;z-index:3;
  border-radius:var(--r-lg);
  padding:32px 30px 30px;
  box-shadow:var(--shadow-lift);
  align-self:start;
  animation:floatCard 6s ease-in-out infinite;
}
@keyframes floatCard{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}
.lead-card .lead-tag{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--gr-emerald-800);color:var(--gr-gold-light);
  font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:7px 14px;border-radius:var(--r-pill);margin-bottom:16px;
}
.lead-card h3{font-size:1.5rem;color:var(--gr-emerald-900);}
.lead-card p{color:var(--gr-stone-600);font-size:.9rem;margin-top:8px;margin-bottom:22px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:.78rem;font-weight:700;color:var(--gr-emerald-900);margin-bottom:7px;letter-spacing:.02em;}
.field input{
  width:100%;padding:14px 16px;border-radius:12px;
  border:1.5px solid var(--gr-stone-300);background:#fff;
  font-size:.98rem;color:var(--gr-emerald-900);
  transition:border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.field input::placeholder{color:#A7B3AC;}
.field input:focus{border-color:var(--gr-emerald-700);box-shadow:0 0 0 4px rgba(20,92,67,0.12);outline:none;}
.field .field-error{color:#B4232A;font-size:.76rem;margin-top:6px;display:none;}
.field.has-error input{border-color:#B4232A;}
.field.has-error .field-error{display:block;}
.lead-card .form-note{font-size:.72rem;color:var(--gr-stone-600);margin-top:14px;text-align:center;line-height:1.5;}
.lead-card .form-note svg{width:12px;height:12px;vertical-align:-1px;}
.form-success{
  display:none;text-align:center;padding:18px 6px;
}
.form-success.is-visible{display:block;}
.form-success svg{width:52px;height:52px;stroke:var(--gr-emerald-700);margin:0 auto 14px;}
.form-success h4{font-size:1.2rem;color:var(--gr-emerald-900);}
.form-success p{font-size:.88rem;color:var(--gr-stone-600);margin-top:8px;}

@media(max-width:1080px){
  .hero-inner{grid-template-columns:1fr;}
  .lead-card{justify-self:stretch;max-width:480px;}
}

/* =========================================================================
   MARQUEE / TRUST STRIP
   ========================================================================= */
.trust-strip{background:var(--gr-emerald-900);padding:16px 0;overflow:hidden;border-bottom:1px solid rgba(201,162,39,0.25);}
.marquee{display:flex;white-space:nowrap;animation:marquee 32s linear infinite;}
.marquee span{
  color:rgba(255,255,255,0.75);font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;
  padding:0 34px;display:inline-flex;align-items:center;gap:34px;font-weight:600;
}
.marquee span::after{content:'◆';color:var(--gr-gold);font-size:.6rem;margin-left:34px;}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* =========================================================================
   CARDS (generic)
   ========================================================================= */
.card{
  background:#fff;border-radius:var(--r-md);
  border:1px solid var(--gr-line);
  padding:34px 28px;
  transition:transform var(--dur-med) var(--ease-lux), box-shadow var(--dur-med) var(--ease-lux), border-color var(--dur-med);
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lift);border-color:var(--gr-gold-dim);}
.card-icon{
  width:58px;height:58px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--gr-emerald-50),#fff);
  border:1px solid var(--gr-line);
  margin-bottom:20px;
}
.card-icon svg{width:26px;height:26px;stroke:var(--gr-emerald-700);}
.card h3{font-size:1.3rem;margin-bottom:10px;}
.card p{color:var(--gr-stone-600);font-size:.95rem;}

/* =========================================================================
   HIGHLIGHTS
   ========================================================================= */
.highlights-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
@media(max-width:1080px){.highlights-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.highlights-grid{grid-template-columns:1fr;}}

/* =========================================================================
   WHY INVEST (split layout)
   ========================================================================= */
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:70px;align-items:center;}
@media(max-width:960px){.split{grid-template-columns:1fr;gap:40px;}}
.split-media{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lift);aspect-ratio:4/5;}
.split-media img{width:100%;height:100%;object-fit:cover;}
.split-media .media-badge{
  position:absolute;left:20px;bottom:20px;
  padding:14px 20px;border-radius:var(--r-md);
  display:flex;align-items:center;gap:12px;
}
.split-media .media-badge h4{font-size:1.4rem;color:var(--gr-emerald-900);}
.split-media .media-badge span{font-size:.72rem;color:var(--gr-stone-600);text-transform:uppercase;letter-spacing:.08em;}

.reason-list{display:flex;flex-direction:column;gap:22px;margin-top:30px;}
.reason-item{display:flex;gap:18px;align-items:flex-start;}
.reason-num{
  font-family:var(--font-display);font-weight:700;color:var(--gr-gold);
  font-size:1.1rem;width:46px;height:46px;border-radius:50%;
  border:1.5px solid var(--gr-gold-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.reason-item h4{font-size:1.15rem;margin-bottom:4px;}
.reason-item p{color:var(--gr-stone-600);font-size:.93rem;}

/* =========================================================================
   LOCATION ADVANTAGES
   ========================================================================= */
.location-band{
  background:linear-gradient(180deg,var(--gr-emerald-900),var(--gr-emerald-800));
  color:#fff;position:relative;overflow:hidden;
}
.location-band .section-head h2, .location-band .section-head p{color:#fff;}
.location-band .section-head p{color:rgba(255,255,255,0.75);}
.location-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
@media(max-width:860px){.location-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.location-grid{grid-template-columns:1fr;}}
.loc-card{
  padding:28px 24px;border-radius:var(--r-md);
  transition:transform var(--dur-med) var(--ease-lux);
}
.loc-card:hover{transform:translateY(-6px);}
.loc-card svg{width:28px;height:28px;stroke:var(--gr-gold-light);margin-bottom:14px;}
.loc-card h4{color:#fff;font-size:1.1rem;margin-bottom:6px;font-family:var(--font-display);}
.loc-card p{color:rgba(255,255,255,0.68);font-size:.88rem;}
.loc-card .distance{
  display:inline-block;margin-top:10px;font-size:.72rem;font-weight:700;
  color:var(--gr-gold-light);letter-spacing:.06em;
}

/* =========================================================================
   CONNECTIVITY (timeline)
   ========================================================================= */
.connectivity-timeline{position:relative;max-width:880px;margin:0 auto;}
.connectivity-timeline::before{
  content:'';position:absolute;left:29px;top:8px;bottom:8px;width:2px;
  background:linear-gradient(180deg,var(--gr-gold),var(--gr-emerald-700));
}
@media(max-width:640px){.connectivity-timeline::before{left:21px;}}
.timeline-item{display:flex;gap:26px;padding-bottom:44px;position:relative;}
.timeline-item:last-child{padding-bottom:0;}
.timeline-dot{
  width:60px;height:60px;border-radius:50%;flex-shrink:0;
  background:#fff;border:2px solid var(--gr-gold);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;color:var(--gr-emerald-800);
  box-shadow:var(--shadow-soft);position:relative;z-index:2;
}
@media(max-width:640px){.timeline-dot{width:44px;height:44px;font-size:.85rem;}}
.timeline-content{padding-top:8px;}
.timeline-content h4{font-size:1.2rem;margin-bottom:4px;}
.timeline-content p{color:var(--gr-stone-600);font-size:.92rem;}

/* =========================================================================
   MASTER PLAN
   ========================================================================= */
.masterplan-frame{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-lift);border:1px solid var(--gr-line);
  aspect-ratio:16/9;background:linear-gradient(135deg,var(--gr-emerald-50),#fff);
}
.masterplan-frame img{width:100%;height:100%;object-fit:cover;}
.masterplan-legend{
  display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:30px;
}
.legend-chip{
  display:flex;align-items:center;gap:9px;font-size:.85rem;font-weight:600;color:var(--gr-emerald-900);
  background:#fff;padding:9px 16px;border-radius:var(--r-pill);border:1px solid var(--gr-line);
}
.legend-dot{width:11px;height:11px;border-radius:3px;}

/* =========================================================================
   PLOT SIZES
   ========================================================================= */
.plot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
@media(max-width:960px){.plot-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.plot-grid{grid-template-columns:1fr;}}
.plot-card{
  background:#fff;border-radius:var(--r-md);border:1px solid var(--gr-line);
  padding:30px 26px;text-align:center;position:relative;overflow:hidden;
  transition:transform var(--dur-med) var(--ease-lux), box-shadow var(--dur-med) var(--ease-lux);
}
.plot-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lift);}
.plot-card.featured{border:1.5px solid var(--gr-gold);}
.plot-card .ribbon{
  position:absolute;top:16px;right:-34px;transform:rotate(35deg);
  background:var(--gr-gold);color:var(--gr-ink);font-size:.65rem;font-weight:800;
  padding:5px 40px;letter-spacing:.08em;
}
.plot-size{font-family:var(--font-display);font-size:2.6rem;color:var(--gr-emerald-800);font-weight:700;}
.plot-size span{font-size:1rem;font-weight:600;color:var(--gr-stone-600);}
.plot-card .plot-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gr-gold);font-weight:700;margin-top:6px;}
.plot-card .plot-desc{color:var(--gr-stone-600);font-size:.87rem;margin-top:14px;}

/* =========================================================================
   PRICING
   ========================================================================= */
.price-panel{
  border-radius:var(--r-lg);
  background:linear-gradient(135deg,var(--gr-emerald-800),var(--gr-emerald-900));
  color:#fff;padding:64px 50px;position:relative;overflow:hidden;
  display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;
}
@media(max-width:860px){.price-panel{grid-template-columns:1fr;padding:44px 26px;text-align:center;}}
.price-panel::before{
  content:'';position:absolute;top:-40%;right:-10%;width:60%;height:160%;
  background:radial-gradient(circle,rgba(201,162,39,0.25),transparent 65%);
}
.price-tag{position:relative;z-index:1;}
.price-tag .amount{font-family:var(--font-display);font-size:clamp(3rem,6vw,4.6rem);color:var(--gr-gold-light);}
.price-tag .amount sub{font-size:1.1rem;color:rgba(255,255,255,0.75);}
.price-panel ul{display:flex;flex-direction:column;gap:14px;position:relative;z-index:1;}
.price-panel ul li{display:flex;align-items:center;gap:12px;font-size:.96rem;color:rgba(255,255,255,0.9);}
.price-panel ul svg{width:20px;height:20px;stroke:var(--gr-gold-light);flex-shrink:0;}

/* =========================================================================
   AMENITIES
   ========================================================================= */
.amenity-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
@media(max-width:960px){.amenity-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.amenity-grid{grid-template-columns:1fr 1fr;}}
.amenity-card{
  text-align:center;padding:30px 16px;border-radius:var(--r-md);
  background:#fff;border:1px solid var(--gr-line);
  transition:transform var(--dur-med) var(--ease-lux), background var(--dur-med);
}
.amenity-card:hover{transform:translateY(-6px);background:var(--gr-emerald-50);}
.amenity-card svg{width:30px;height:30px;stroke:var(--gr-emerald-700);margin:0 auto 14px;}
.amenity-card h4{font-size:.98rem;}

/* =========================================================================
   INVESTMENT BENEFITS (counters)
   ========================================================================= */
.counters-band{
  background:var(--gr-emerald-50);border-radius:var(--r-lg);
  padding:50px 30px;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
@media(max-width:860px){.counters-band{grid-template-columns:1fr 1fr;}}
.counter-item{text-align:center;}
.counter-item .num{
  font-family:var(--font-display);font-size:clamp(2.2rem,4vw,3.2rem);color:var(--gr-emerald-800);font-weight:700;
}
.counter-item .num .plus{color:var(--gr-gold);}
.counter-item .lbl{font-size:.8rem;color:var(--gr-stone-600);text-transform:uppercase;letter-spacing:.06em;margin-top:6px;}

/* =========================================================================
   ABOUT COMPANY
   ========================================================================= */
.about-stats{display:flex;gap:30px;margin-top:30px;flex-wrap:wrap;}
.about-stats .stat h4{font-family:var(--font-display);color:var(--gr-emerald-800);font-size:2rem;}
.about-stats .stat span{font-size:.78rem;color:var(--gr-stone-600);text-transform:uppercase;letter-spacing:.06em;}
.cin-tag{
  display:inline-flex;align-items:center;gap:8px;margin-top:24px;
  font-size:.8rem;color:var(--gr-stone-600);background:#fff;border:1px solid var(--gr-line);
  padding:9px 16px;border-radius:var(--r-pill);
}
.cin-tag b{color:var(--gr-emerald-900);}

/* =========================================================================
   TESTIMONIALS (slider)
   ========================================================================= */
.testi-track-wrap{overflow:hidden;position:relative;}
.testi-track{display:flex;gap:24px;transition:transform var(--dur-slow) var(--ease-lux);}
.testi-card{
  min-width:100%;background:#fff;border-radius:var(--r-lg);border:1px solid var(--gr-line);
  padding:44px 40px;position:relative;
}
@media(min-width:820px){.testi-card{min-width:calc(50% - 12px);}}
.testi-card .quote-mark{font-family:var(--font-display);font-size:3.4rem;color:var(--gr-gold);line-height:1;opacity:.5;}
.testi-card p{font-size:1.05rem;color:var(--gr-emerald-900);margin-top:6px;font-style:italic;}
.testi-person{display:flex;align-items:center;gap:14px;margin-top:24px;}
.testi-avatar{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--gr-emerald-700),var(--gr-emerald-900));
  display:flex;align-items:center;justify-content:center;color:var(--gr-gold-light);font-family:var(--font-display);font-weight:700;font-size:1.2rem;
}
.testi-person h5{font-size:.98rem;}
.testi-person span{font-size:.8rem;color:var(--gr-stone-600);}
.testi-controls{display:flex;justify-content:center;gap:14px;margin-top:34px;}
.testi-dot{width:9px;height:9px;border-radius:50%;background:var(--gr-stone-300);transition:background var(--dur-fast), width var(--dur-fast);}
.testi-dot.is-active{background:var(--gr-gold);width:26px;border-radius:6px;}
.testi-arrow{
  width:46px;height:46px;border-radius:50%;border:1px solid var(--gr-line);
  display:flex;align-items:center;justify-content:center;transition:background var(--dur-fast);
}
.testi-arrow:hover{background:var(--gr-emerald-50);}
.testi-arrow svg{width:18px;height:18px;stroke:var(--gr-emerald-800);}
.testi-nav{display:flex;justify-content:center;gap:16px;margin-top:26px;}

/* =========================================================================
   CTA BAND
   ========================================================================= */
.cta-band{
  position:relative;overflow:hidden;border-radius:var(--r-lg);
  background:linear-gradient(135deg,var(--gr-emerald-900),var(--gr-emerald-700));
  padding:70px 40px;text-align:center;color:#fff;
}
.cta-band::before,.cta-band::after{
  content:'';position:absolute;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,162,39,0.25),transparent 65%);
}
.cta-band::before{top:-180px;left:-140px;}
.cta-band::after{bottom:-200px;right:-140px;}
.cta-band h2{color:#fff;font-size:clamp(1.9rem,4vw,2.8rem);position:relative;z-index:1;}
.cta-band p{color:rgba(255,255,255,0.8);max-width:56ch;margin:16px auto 30px;position:relative;z-index:1;}
.cta-band .hero-actions{justify-content:center;position:relative;z-index:1;}

/* =========================================================================
   CONTACT
   ========================================================================= */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;}
@media(max-width:960px){.contact-grid{grid-template-columns:1fr;}}
.contact-info-card{
  background:var(--gr-emerald-900);color:#fff;border-radius:var(--r-lg);padding:44px 36px;
}
.contact-info-card h3{color:#fff;font-size:1.6rem;margin-bottom:18px;}
.contact-line{display:flex;gap:16px;align-items:flex-start;margin-top:22px;}
.contact-line svg{width:22px;height:22px;stroke:var(--gr-gold-light);flex-shrink:0;margin-top:2px;}
.contact-line h5{font-size:.95rem;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px;}
.contact-line a,.contact-line span{font-size:1rem;color:#fff;}
.contact-form-card{background:#fff;border-radius:var(--r-lg);border:1px solid var(--gr-line);padding:40px 34px;}
.contact-form-card .field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:560px){.contact-form-card .field-row{grid-template-columns:1fr;}}
.contact-form-card textarea{
  width:100%;padding:14px 16px;border-radius:12px;border:1.5px solid var(--gr-stone-300);
  min-height:120px;resize:vertical;font-family:inherit;font-size:.98rem;
}
.contact-form-card textarea:focus{border-color:var(--gr-emerald-700);outline:none;box-shadow:0 0 0 4px rgba(20,92,67,0.12);}

/* Map placeholder */
.map-wrap{
  border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--gr-line);
  position:relative;aspect-ratio:21/8;box-shadow:var(--shadow-soft);
}
.map-placeholder{
  width:100%;height:100%;
  background:
    linear-gradient(135deg, rgba(11,61,46,0.9), rgba(20,92,67,0.85)),
    repeating-linear-gradient(45deg, rgba(255,255,255,0.04) 0 2px, transparent 2px 30px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:10px;
}
.map-placeholder svg{width:40px;height:40px;stroke:var(--gr-gold-light);}
.map-placeholder span{font-size:.85rem;color:rgba(255,255,255,0.75);}

/* =========================================================================
   FAQ
   ========================================================================= */
.faq-list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:14px;}
.faq-item{background:#fff;border:1px solid var(--gr-line);border-radius:var(--r-md);overflow:hidden;}
.faq-question{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 24px;text-align:left;font-weight:700;font-size:1rem;color:var(--gr-emerald-900);
}
.faq-question .plus{
  width:26px;height:26px;border-radius:50%;border:1.5px solid var(--gr-gold);
  flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;
}
.faq-question .plus::before,.faq-question .plus::after{content:'';position:absolute;background:var(--gr-gold);transition:transform var(--dur-fast) var(--ease-lux);}
.faq-question .plus::before{width:11px;height:1.6px;}
.faq-question .plus::after{width:1.6px;height:11px;}
.faq-item.is-open .plus::after{transform:rotate(90deg) scaleY(0);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height var(--dur-med) var(--ease-lux);}
.faq-answer-inner{padding:0 24px 22px;color:var(--gr-stone-600);font-size:.93rem;}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{background:var(--gr-ink);color:rgba(255,255,255,0.7);position:relative;}
.site-footer::before{
  content:'';display:block;height:2px;
  background:linear-gradient(90deg,transparent,var(--gr-gold),transparent);
}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:44px;padding:70px 0 46px;}
@media(max-width:860px){.footer-top{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.footer-top{grid-template-columns:1fr;}}
.footer-brand{display:flex;align-items:center;gap:14px;margin-bottom:18px;}
.footer-brand .brand-logo{width:56px;height:56px;}
.footer-brand .brand-text .brand-name{color:#fff;}
.footer-col h5{color:#fff;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px;font-family:var(--font-body);font-weight:700;}
.footer-col ul{display:flex;flex-direction:column;gap:12px;}
.footer-col a{font-size:.9rem;transition:color var(--dur-fast);}
.footer-col a:hover{color:var(--gr-gold-light);}
.footer-col p{font-size:.9rem;line-height:1.7;}
.footer-socials{display:flex;gap:12px;margin-top:18px;}
.footer-socials a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;}
.footer-socials a:hover{border-color:var(--gr-gold);background:rgba(201,162,39,0.12);}
.footer-socials svg{width:16px;height:16px;stroke:currentColor;}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.1);padding:26px 0;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
  font-size:.82rem;
}
.footer-bottom a{color:rgba(255,255,255,0.6);}
.footer-bottom a:hover{color:var(--gr-gold-light);}
.footer-legal{display:flex;gap:22px;flex-wrap:wrap;}

/* =========================================================================
   FLOATING STICKY BUTTONS
   ========================================================================= */
.floating-actions{
  position:fixed;right:22px;bottom:22px;z-index:80;
  display:flex;flex-direction:column;gap:14px;align-items:center;
}
.fab{
  width:58px;height:58px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-lift);
  transition:transform var(--dur-fast) var(--ease-lux);
  position:relative;
}
.fab:hover{transform:scale(1.08);}
.fab svg{width:26px;height:26px;}
.fab-whatsapp{background:#25D366;}
.fab-whatsapp svg{stroke:#fff;fill:#fff;}
.fab-call{background:linear-gradient(135deg,var(--gr-gold-light),var(--gr-gold));}
.fab-call svg{stroke:var(--gr-ink);}
.fab-ping{
  position:absolute;inset:0;border-radius:50%;background:inherit;
  animation:ping 2.2s cubic-bezier(0,0,.2,1) infinite;
  opacity:.55;
}
@keyframes ping{0%{transform:scale(1);opacity:.5;}100%{transform:scale(1.9);opacity:0;}}

.back-to-top{
  position:fixed;left:22px;bottom:22px;z-index:80;
  width:46px;height:46px;border-radius:50%;
  background:var(--gr-emerald-800);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-soft);opacity:0;pointer-events:none;
  transition:opacity var(--dur-fast), transform var(--dur-fast);
}
.back-to-top.is-visible{opacity:1;pointer-events:auto;}
.back-to-top svg{width:18px;height:18px;stroke:#fff;}

/* =========================================================================
   UTILS
   ========================================================================= */
.text-gold{color:var(--gr-gold);}
.text-white{color:#fff;}
.mt-0{margin-top:0;}
.divider-gold{width:60px;height:3px;background:linear-gradient(90deg,var(--gr-gold),var(--gr-gold-light));border-radius:2px;}

/* Lazy image fade-in */
img.lazy{opacity:0;transition:opacity .6s var(--ease-lux);}
img.lazy.is-loaded{opacity:1;}

/* AOS-safe defaults (fallback if AOS CSS not loaded) */
[data-aos]{opacity:0;transition-property:opacity, transform;}
[data-aos].aos-animate{opacity:1;}

/* Skeleton placeholder for image assets not yet uploaded */
.img-frame{position:relative;background:linear-gradient(135deg,var(--gr-emerald-50),#eef4f0);}
.img-frame::before{
  content:attr(data-caption);
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:var(--gr-stone-600);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;text-align:center;padding:20px;
}
.img-frame img{position:relative;z-index:1;}
