/*
Theme Name: LA VISTA Developments - Landing Page
Theme URI: https://developments.lavista.com/
Description: High-converting bilingual (AR/EN) landing-page theme for LA VISTA Developments. Includes lead-tracking, WhatsApp & call tracking, SMTP, exit-intent, scarcity & full conversion suite.
Version: 1.0.0
Text Domain: lavista
Author: Bold Pixel
Author URI: https://bold-pixel.com/
*/

:root{
    /* La Vista identity — Mediterranean coastal: deep navy, sandy gold, terracotta accent, warm cream */
    --lavista-navy:#0E2A47;          /* primary deep brand navy (sea/sky) */
    --lavista-navy-dark:#081B2E;
    --lavista-navy-soft:#1B3D63;
    --lavista-teal:#1F6F7A;           /* coastal teal accent */
    --lavista-teal-light:#3A9CA8;
    --lavista-terracotta:#C36B3A;     /* warm sunset accent */
    --lavista-sand:#D9B679;           /* sandy gold (CTA gold) */
    --lavista-sand-light:#EAD0A0;
    --lavista-sand-dark:#A8854D;
    --lavista-cream:#F6EFE2;          /* warm cream sections */
    --lavista-bone:#FBF7EE;
    --lavista-stone:#7A7A7A;
    --lavista-mist:#B8B8B8;
    --lavista-cloud:#E8E6E1;
    --lavista-charcoal:#1B3D63;       /* re-mapped to navy-soft so legacy refs blend with brand */
    --lavista-ink:#0E2A47;            /* re-mapped to deep navy */
    --lavista-black:#081B2E;          /* re-mapped to navy-dark */
    --lavista-white:#FFFFFF;

    /* Legacy aliases retained so any leftover var() keeps working */
    --lavista-bronze:var(--lavista-sand-dark);
    --lavista-gold:var(--lavista-sand);
    --lavista-gold-light:var(--lavista-sand-light);
    --lavista-bronze-dark:#7E6238;
    --lavista-graphite:#4A4A4A;
    --lavista-green:#3C5A3C;
    --lavista-blush:#D4B5A0;

    --whatsapp:#25D366;
    --whatsapp-dark:#128C3E;

    --primary:var(--lavista-navy);
    --primary-dark:var(--lavista-navy-dark);
    --primary-light:var(--lavista-navy-soft);
    --secondary:var(--lavista-teal);
    --accent:var(--lavista-sand);
    --gold:var(--lavista-sand);

    --text:#1A1A1A;
    --text-light:#4A4A4A;
    --text-muted:#7A7A7A;
    --bg:#FFFFFF;
    --bg-light:var(--lavista-bone);
    --bg-dark:var(--lavista-navy);

    --radius:4px;
    --radius-lg:8px;
    --shadow:0 2px 16px rgba(10,10,10,0.06);
    --shadow-lg:0 12px 48px rgba(10,10,10,0.14);
    --shadow-xl:0 20px 80px rgba(10,10,10,0.18);
    --transition:all .35s cubic-bezier(.4,0,.2,1);

    --font-display:'Cormorant Garamond','Playfair Display',Georgia,serif;
    --font-body:'Inter','Helvetica Neue','Cairo','Tajawal',-apple-system,sans-serif;
    --font-arabic:'Cairo','Tajawal','Noto Kufi Arabic',sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden;max-width:100%}
body{
    font-family:var(--font-body);
    color:var(--text);
    line-height:1.7;
    background:var(--bg);
    overflow-x:hidden;
    max-width:100%;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
}
body.lang-ar,body.rtl{font-family:var(--font-arabic);direction:rtl}
body.lang-en,body.ltr{direction:ltr}

img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:var(--transition)}
ul,ol{list-style:none}

.container{max-width:1280px;margin:0 auto;padding:0 24px}
.container-narrow{max-width:980px;margin:0 auto;padding:0 24px}

h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:500;letter-spacing:-.01em;line-height:1.15}
body.lang-ar h1,body.lang-ar h2,body.lang-ar h3,body.lang-ar h4{font-family:var(--font-arabic);font-weight:800;letter-spacing:0;line-height:1.3}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    padding:18px 0;background:rgba(255,255,255,.0);
    transition:background .35s ease,padding .25s ease,box-shadow .25s ease,top .4s cubic-bezier(.34,1.56,.64,1);
}
body.has-scarcity .site-header{top:var(--scarcity-h, 46px)}
.site-header.scrolled{
    background:rgba(255,255,255,.97);
    backdrop-filter:saturate(150%) blur(14px);
    padding:12px 0;
    box-shadow:0 1px 0 rgba(0,0,0,.06);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:24px}
.site-logo{
    font-family:var(--font-display);
    font-size:1.6rem;font-weight:600;letter-spacing:.18em;
    color:#fff;text-transform:uppercase;
}
.site-header.scrolled .site-logo{color:var(--lavista-black)}
.site-logo img{height:34px;width:auto;display:block}

.main-nav{display:flex;align-items:center;gap:34px}
.main-nav a{
    color:#fff;font-size:.86rem;letter-spacing:.18em;text-transform:uppercase;
    font-weight:500;position:relative;padding:6px 0;
}
.site-header.scrolled .main-nav a{color:var(--lavista-ink)}
.main-nav a::after{
    content:'';position:absolute;left:0;right:0;bottom:0;height:1px;
    background:currentColor;transform:scaleX(0);transform-origin:right;
    transition:transform .35s ease;
}
.main-nav a:hover::after{transform:scaleX(1);transform-origin:left}

.nav-lang{
    display:inline-flex;align-items:center;gap:6px;
    border:1px solid rgba(255,255,255,.4);
    padding:7px 14px;border-radius:30px;font-size:.78rem;letter-spacing:.12em;
    color:#fff;
}
.site-header.scrolled .nav-lang{border-color:rgba(0,0,0,.18);color:var(--lavista-ink)}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:36px;height:36px;color:#fff;padding:0}
.site-header.scrolled .nav-toggle{color:var(--lavista-ink)}

/* ============================================================
   HERO — Full screen cinematic
   ============================================================ */
.hero{
    position:relative;min-height:100vh;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;color:#fff;text-align:center;
    background:#0a0a0a;
}
.hero-bg{
    position:absolute;inset:0;z-index:1;
    background-size:cover;background-position:center;
    transform:scale(1.05);
    transition:transform 8s ease-out;
}
.hero.in-view .hero-bg{transform:scale(1)}
.hero-bg::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.35) 40%,rgba(0,0,0,.75) 100%);
}
.hero .container{position:relative;z-index:3;padding-top:90px;padding-bottom:60px}

.hero-eyebrow{
    display:inline-block;font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
    color:var(--lavista-gold-light);margin-bottom:24px;font-weight:500;
}
.hero-title{
    font-family:var(--font-display);
    font-size:clamp(2.4rem,6.2vw,5.4rem);
    font-weight:400;line-height:1.05;letter-spacing:-.015em;
    margin:0 0 22px;color:#fff;
}
body.lang-ar .hero-title{font-family:var(--font-arabic);font-weight:800;line-height:1.2}
.hero-title em{font-style:italic;color:var(--lavista-gold-light);font-weight:400}
.hero-subtitle{
    font-size:1.1rem;line-height:1.7;color:rgba(255,255,255,.86);
    max-width:640px;margin:0 auto 38px;font-weight:300;
}
.hero-cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:50px}

.hero-scroll{
    position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
    color:rgba(255,255,255,.6);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
    display:flex;flex-direction:column;align-items:center;gap:10px;
}
.hero-scroll-line{width:1px;height:46px;background:rgba(255,255,255,.4);position:relative;overflow:hidden}
.hero-scroll-line::after{
    content:'';position:absolute;top:-46px;left:0;right:0;height:46px;
    background:#fff;animation:scrollLine 2.4s ease-in-out infinite;
}
@keyframes scrollLine{0%{top:-46px}50%{top:0}100%{top:46px}}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:10px;
    padding:16px 38px;border:1px solid currentColor;
    font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;
    font-weight:500;cursor:pointer;font-family:var(--font-body);
    background:transparent;color:#fff;
    transition:var(--transition);position:relative;overflow:hidden;
    text-decoration:none;border-radius:0;
}
body.lang-ar .btn{letter-spacing:.05em;font-family:var(--font-arabic);font-weight:700;font-size:.95rem}
.btn:hover{background:#fff;color:var(--lavista-black);transform:translateY(-1px)}
.btn-primary{background:#fff;color:var(--lavista-black);border-color:#fff}
.btn-primary:hover{background:transparent;color:#fff}
.btn-dark{background:var(--lavista-black);color:#fff;border-color:var(--lavista-black)}
.btn-dark:hover{background:transparent;color:var(--lavista-black)}
.btn-gold{background:var(--lavista-gold);color:#fff;border-color:var(--lavista-gold)}
.btn-gold:hover{background:var(--lavista-bronze-dark);border-color:var(--lavista-bronze-dark);color:#fff}
.btn-whatsapp{
    background:var(--whatsapp-dark);border-color:var(--whatsapp-dark);color:#fff;
    box-shadow:0 4px 18px rgba(37,211,102,.3);
}
.btn-whatsapp:hover{background:#0d6e30;border-color:#0d6e30;color:#fff;transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.45)}

.btn-sm{padding:11px 24px;font-size:.74rem}
.btn-lg{padding:20px 50px;font-size:.88rem}

/* ============================================================
   SECTION TITLES
   ============================================================ */
.section{padding:110px 0;position:relative}
.section-light{background:var(--lavista-bone)}
.section-dark{background:var(--lavista-black);color:#fff}
.section-cream{background:var(--lavista-cream)}

.section-eyebrow{
    display:block;font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;
    color:var(--lavista-bronze);margin-bottom:18px;font-weight:600;text-align:center;
}
.section-dark .section-eyebrow{color:var(--lavista-gold-light)}
.section-title{
    font-family:var(--font-display);
    font-size:clamp(2rem,4.4vw,3.6rem);font-weight:400;line-height:1.1;
    text-align:center;margin:0 auto 22px;max-width:820px;color:var(--lavista-black);
}
body.lang-ar .section-title{font-family:var(--font-arabic);font-weight:800;line-height:1.3}
.section-dark .section-title{color:#fff}
.section-title em{font-style:italic;color:var(--lavista-bronze)}
.section-dark .section-title em{color:var(--lavista-gold-light)}
.section-intro{
    text-align:center;max-width:680px;margin:0 auto 60px;color:var(--text-light);
    font-size:1.05rem;line-height:1.8;font-weight:300;
}
.section-dark .section-intro{color:rgba(255,255,255,.7)}

/* ============================================================
   ABOUT BLOCK
   ============================================================ */
.about{padding:110px 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-image{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius)}
.about-image img{width:100%;height:100%;object-fit:cover;transition:transform 1s ease}
.about-image:hover img{transform:scale(1.04)}
.about-image::before{
    content:'';position:absolute;top:24px;left:24px;right:-24px;bottom:-24px;
    border:1px solid var(--lavista-gold);z-index:-1;
}
body.rtl .about-image::before{left:-24px;right:24px}

.about-text .section-eyebrow{text-align:left}
body.rtl .about-text .section-eyebrow{text-align:right}
.about-text .section-title{text-align:left;margin-left:0}
body.rtl .about-text .section-title{text-align:right;margin-right:0}
.about-lede{
    font-family:var(--font-display);font-size:1.45rem;line-height:1.55;
    color:var(--lavista-charcoal);margin-bottom:24px;font-weight:400;
}
body.lang-ar .about-lede{font-family:var(--font-arabic);font-weight:600;font-size:1.25rem}
.about-text p{color:var(--text-light);font-size:1rem;line-height:1.85;margin-bottom:18px}

.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:34px;padding-top:34px;border-top:1px solid var(--lavista-cloud)}
.about-stat .num{font-family:var(--font-display);font-size:2.6rem;font-weight:500;color:var(--lavista-black);line-height:1;display:block}
.about-stat .lbl{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin-top:8px;display:block}

/* ============================================================
   PILLARS — Six values (Sustainability / Luxury / Design / Innovation / Life / You)
   ============================================================ */
.pillars{padding:120px 0;background:var(--lavista-bone)}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--lavista-cloud);border:1px solid var(--lavista-cloud)}
.pillar{
    background:#fff;padding:54px 36px;text-align:center;
    transition:var(--transition);position:relative;cursor:default;
}
.pillar:hover{background:var(--lavista-black);color:#fff}
.pillar-icon{
    width:54px;height:54px;margin:0 auto 22px;color:var(--lavista-bronze);
    transition:var(--transition);
}
.pillar:hover .pillar-icon{color:var(--lavista-gold-light)}
.pillar h3{
    font-family:var(--font-display);font-size:1.7rem;font-weight:500;
    margin-bottom:12px;color:inherit;
}
body.lang-ar .pillar h3{font-family:var(--font-arabic);font-weight:700;font-size:1.4rem}
.pillar p{color:var(--text-light);font-size:.95rem;line-height:1.7;font-weight:300}
.pillar:hover p{color:rgba(255,255,255,.75)}
.pillar-more{
    display:inline-block;margin-top:18px;font-size:.74rem;letter-spacing:.24em;
    text-transform:uppercase;color:var(--lavista-bronze);font-weight:600;
}
.pillar:hover .pillar-more{color:var(--lavista-gold-light)}

/* ============================================================
   DEVELOPMENTS — Project Grid
   ============================================================ */
.developments{padding:120px 0;background:#fff}
.dev-filters{display:flex;justify-content:center;gap:6px;margin-bottom:54px;flex-wrap:wrap}
.dev-filter{
    background:transparent;border:1px solid var(--lavista-cloud);
    padding:11px 26px;font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--text-light);cursor:pointer;font-family:inherit;font-weight:500;
    transition:var(--transition);border-radius:30px;
}
body.lang-ar .dev-filter{letter-spacing:.04em;font-size:.92rem;font-weight:700}
.dev-filter:hover{color:var(--lavista-black);border-color:var(--lavista-black)}
.dev-filter.active{background:var(--lavista-black);color:#fff;border-color:var(--lavista-black)}

.dev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.dev-card{
    position:relative;overflow:hidden;cursor:pointer;
    aspect-ratio:4/5;background:#000;border-radius:var(--radius);
    transition:var(--transition);
}
.dev-card-img{
    position:absolute;inset:0;background-size:cover;background-position:center;
    transition:transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.dev-card:hover .dev-card-img{transform:scale(1.08)}
.dev-card-overlay{
    position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(0,0,0,.0) 30%,rgba(0,0,0,.85) 100%);
    display:flex;flex-direction:column;justify-content:flex-end;
    padding:32px 28px;color:#fff;
}
.dev-card-region{
    font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
    color:var(--lavista-gold-light);margin-bottom:8px;font-weight:600;
}
.dev-card h3{
    font-family:var(--font-display);font-size:2rem;font-weight:500;
    margin-bottom:6px;letter-spacing:.02em;
}
body.lang-ar .dev-card h3{font-family:var(--font-arabic);font-weight:800;font-size:1.7rem}
.dev-card-loc{font-size:.86rem;color:rgba(255,255,255,.85);font-weight:300;margin-bottom:18px}
.dev-card-meta{
    display:flex;gap:16px;font-size:.78rem;color:rgba(255,255,255,.75);
    padding-top:14px;border-top:1px solid rgba(255,255,255,.18);
}
.dev-card-meta span{flex:1}
.dev-card-meta b{display:block;color:#fff;font-weight:600;margin-top:2px;font-size:.95rem}
.dev-card-cta{
    position:absolute;top:24px;right:24px;
    width:42px;height:42px;border-radius:50%;
    background:rgba(255,255,255,.92);color:var(--lavista-black);
    display:flex;align-items:center;justify-content:center;
    opacity:0;transform:translateY(-6px);transition:var(--transition);
}
body.rtl .dev-card-cta{right:auto;left:24px}
.dev-card:hover .dev-card-cta{opacity:1;transform:translateY(0)}

/* ============================================================
   FEATURED PROJECT — Editorial Split
   ============================================================ */
.featured{padding:0;background:#fff}
.featured-row{display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:680px}
.featured-row.reverse{grid-template-columns:1fr 1fr}
.featured-row.reverse .featured-img{order:2}
body.rtl .featured-row.reverse .featured-img{order:initial}
.featured-img{background-size:cover;background-position:center;min-height:520px}
.featured-content{padding:90px 80px;display:flex;flex-direction:column;justify-content:center;background:var(--lavista-bone)}
.featured-row:nth-child(even) .featured-content{background:#fff}
.featured-tag{
    font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
    color:var(--lavista-bronze);font-weight:600;margin-bottom:18px;
}
.featured-content h3{
    font-family:var(--font-display);font-size:clamp(2rem,3.6vw,3.2rem);
    font-weight:400;line-height:1.1;margin-bottom:14px;color:var(--lavista-black);
}
body.lang-ar .featured-content h3{font-family:var(--font-arabic);font-weight:800;line-height:1.3}
.featured-loc{color:var(--text-muted);font-size:.95rem;margin-bottom:28px;font-weight:300}
.featured-content > p{color:var(--text-light);line-height:1.9;font-size:1rem;margin-bottom:30px;font-weight:300}
.featured-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:36px;padding:30px 0;border-top:1px solid var(--lavista-cloud);border-bottom:1px solid var(--lavista-cloud)}
.featured-fact .v{font-family:var(--font-display);font-size:1.7rem;color:var(--lavista-black);line-height:1;display:block;font-weight:500}
.featured-fact .l{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);margin-top:8px;display:block}

/* ============================================================
   ENQUIRE FORM — Sticky Side
   ============================================================ */
.enquire{padding:120px 0;background:var(--lavista-black);color:#fff;position:relative;overflow:hidden}
.enquire::before{
    content:'';position:absolute;top:-30%;right:-15%;width:780px;height:780px;
    background:radial-gradient(circle,rgba(201,169,110,.08) 0%,transparent 70%);
    border-radius:50%;
}
.enquire .container{position:relative;z-index:2}
.enquire-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.enquire-text .section-eyebrow{text-align:left}
body.rtl .enquire-text .section-eyebrow{text-align:right}
.enquire-text .section-title{text-align:left;margin-left:0;color:#fff}
body.rtl .enquire-text .section-title{text-align:right;margin-right:0}
.enquire-text > p{color:rgba(255,255,255,.72);font-size:1.05rem;line-height:1.8;margin-bottom:28px;font-weight:300}
.enquire-perks{margin-top:24px;display:grid;gap:14px}
.enquire-perk{display:flex;gap:14px;align-items:flex-start;color:rgba(255,255,255,.85);font-size:.96rem}
.enquire-perk-icon{width:34px;height:34px;border-radius:50%;background:rgba(201,169,110,.15);color:var(--lavista-gold-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}

.enquire-form-wrap{
    background:#fff;color:var(--lavista-ink);padding:50px 44px;border-radius:var(--radius-lg);
    box-shadow:0 30px 90px rgba(0,0,0,.4);
}
.enquire-form-wrap h3{
    font-family:var(--font-display);font-size:1.8rem;font-weight:500;margin-bottom:8px;text-align:center;color:var(--lavista-black);
}
body.lang-ar .enquire-form-wrap h3{font-family:var(--font-arabic);font-weight:700}
.enquire-form-wrap > p{text-align:center;color:var(--text-muted);font-size:.92rem;margin-bottom:30px}

.lead-form .form-field{margin-bottom:14px}
.lead-form input,.lead-form select{
    width:100%;padding:14px 16px;border:1px solid var(--lavista-cloud);
    background:#fff;color:var(--lavista-ink);font-size:.96rem;font-family:inherit;
    border-radius:var(--radius);transition:var(--transition);
}
.lead-form input::placeholder{color:var(--lavista-mist)}
.lead-form input:focus,.lead-form select:focus{outline:none;border-color:var(--lavista-bronze);box-shadow:0 0 0 3px rgba(164,134,82,.12)}
.lead-form .form-field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.lead-form .btn-submit{
    width:100%;padding:16px;background:var(--lavista-black);color:#fff;border:1px solid var(--lavista-black);
    font-size:.84rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;cursor:pointer;
    font-family:inherit;border-radius:var(--radius);margin-top:6px;transition:var(--transition);
}
body.lang-ar .lead-form .btn-submit{letter-spacing:.04em;font-size:1rem;font-weight:700}
.lead-form .btn-submit:hover{background:var(--lavista-bronze);border-color:var(--lavista-bronze)}
.lead-form .btn-submit:disabled{opacity:.7;cursor:not-allowed}
.lead-form .spinner{display:none;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}
.lead-form .btn-submit.loading .btn-text{display:none}
.lead-form .btn-submit.loading .spinner{display:block}
@keyframes spin{to{transform:rotate(360deg)}}

.form-message{text-align:center;padding:12px;border-radius:var(--radius);margin-top:14px;font-weight:600;font-size:.92rem;display:none}
.form-message.success{background:rgba(60,90,60,.1);color:var(--lavista-green);display:block}
.form-message.error{background:rgba(220,60,60,.1);color:#c53030;display:block}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{padding:120px 0;background:var(--lavista-bone)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery-item{position:relative;overflow:hidden;aspect-ratio:1;cursor:pointer;border-radius:var(--radius)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.8,.2,1)}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item::after{
    content:'';position:absolute;inset:0;
    background:rgba(10,10,10,.4) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3Cline x1='11' y1='8' x2='11' y2='14'/%3E%3Cline x1='8' y1='11' x2='14' y2='11'/%3E%3C/svg%3E") center/28px no-repeat;
    opacity:0;transition:var(--transition);
}
.gallery-item:hover::after{opacity:1}
.gallery-item.tall{grid-row:span 2;aspect-ratio:1/2}
.gallery-item.wide{grid-column:span 2;aspect-ratio:2/1}

/* Lightbox */
.lightbox{display:none;position:fixed;inset:0;background:rgba(10,10,10,.96);z-index:9999;align-items:center;justify-content:center;padding:40px}
.lightbox.active{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:var(--radius);object-fit:contain}
.lightbox-close{position:absolute;top:24px;right:24px;width:48px;height:48px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10000}
.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:50%;cursor:pointer;font-size:1.6rem;display:flex;align-items:center;justify-content:center}
.lightbox-prev{left:24px}.lightbox-next{right:24px}

/* ============================================================
   TESTIMONIALS — Editorial style
   ============================================================ */
.testimonials{padding:120px 0;background:#fff}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.testi{
    background:var(--lavista-bone);padding:44px 36px;border-radius:var(--radius-lg);
    position:relative;border:1px solid var(--lavista-cloud);
}
.testi::before{
    content:'"';position:absolute;top:-10px;left:24px;font-family:var(--font-display);
    font-size:6rem;color:var(--lavista-gold);line-height:1;font-weight:700;
}
body.rtl .testi::before{left:auto;right:24px;content:'”'}
.testi-quote{font-style:italic;color:var(--lavista-charcoal);font-size:1.02rem;line-height:1.85;margin:30px 0 24px;font-weight:300}
.testi-author{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--lavista-cloud)}
.testi-avatar{width:48px;height:48px;border-radius:50%;background:var(--lavista-cloud);display:flex;align-items:center;justify-content:center;color:var(--lavista-bronze);font-weight:700}
.testi-name{font-weight:600;color:var(--lavista-ink);font-size:.96rem}
.testi-role{font-size:.82rem;color:var(--text-muted);margin-top:2px}

/* ============================================================
   FAQ
   ============================================================ */
.faq{padding:120px 0;background:var(--lavista-bone)}
.faq-list{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{
    background:#fff;border:1px solid var(--lavista-cloud);border-radius:var(--radius);
    padding:22px 26px;transition:var(--transition);
}
.faq-item[open]{border-color:var(--lavista-bronze);box-shadow:0 6px 22px rgba(164,134,82,.1)}
.faq-item summary{
    cursor:pointer;font-weight:600;color:var(--lavista-ink);font-size:1.02rem;
    list-style:none;display:flex;justify-content:space-between;align-items:center;gap:18px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
    content:'+';color:var(--lavista-bronze);font-size:1.7rem;font-weight:300;line-height:1;
    flex-shrink:0;transition:transform .3s;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-answer{
    color:var(--text-light);line-height:1.85;margin-top:14px;padding-top:14px;
    border-top:1px solid var(--lavista-cloud);font-size:.96rem;font-weight:300;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
    background:var(--lavista-black);color:rgba(255,255,255,.7);
    padding:90px 0 0;font-size:.92rem;
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;padding-bottom:60px}
.footer-brand h2{
    font-family:var(--font-display);font-size:2rem;letter-spacing:.18em;color:#fff;
    margin-bottom:18px;font-weight:500;text-transform:uppercase;
}
.footer-brand p{color:rgba(255,255,255,.65);line-height:1.85;font-weight:300;max-width:380px;font-size:.94rem}
.footer-col h4{
    font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:#fff;
    margin-bottom:22px;font-weight:600;font-family:var(--font-body);
}
body.lang-ar .footer-col h4{font-family:var(--font-arabic);letter-spacing:.04em;font-size:1rem}
.footer-col ul{display:flex;flex-direction:column;gap:11px}
.footer-col a{color:rgba(255,255,255,.7);font-size:.93rem;transition:var(--transition)}
.footer-col a:hover{color:var(--lavista-gold-light)}
.footer-social{display:flex;gap:12px;margin-top:24px}
.footer-social a{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;color:#fff}
.footer-social a:hover{background:var(--lavista-gold);border-color:var(--lavista-gold);color:#fff}
.footer-bottom{
    border-top:1px solid rgba(255,255,255,.1);padding:24px 0;
    display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
    color:rgba(255,255,255,.55);font-size:.84rem;
}
.footer-bottom a{color:rgba(255,255,255,.7)}
.footer-bottom a:hover{color:var(--lavista-gold-light)}
.footer-credit{color:rgba(255,255,255,.55)}
.footer-credit a{color:var(--lavista-gold-light);font-weight:600}

/* ============================================================
   MOBILE STICKY BAR
   ============================================================ */
.mobile-sticky-bar{
    position:fixed;bottom:0;left:0;right:0;z-index:9000;
    display:none;background:#fff;border-top:1px solid var(--lavista-cloud);
    box-shadow:0 -4px 24px rgba(0,0,0,.1);
}
.mobile-sticky-bar .sticky-btn{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:5px;padding:12px 6px;color:#fff;text-decoration:none;
    font-size:.7rem;font-weight:700;font-family:inherit;border:none;background:transparent;cursor:pointer;
    min-height:62px;letter-spacing:.04em;
}
.mobile-sticky-bar .sticky-btn-whatsapp{background:var(--whatsapp-dark);color:#fff}
.mobile-sticky-bar .sticky-btn-call{background:var(--lavista-black);color:#fff}
.mobile-sticky-bar .sticky-btn-form{background:var(--lavista-bronze);color:#fff}
.mobile-sticky-bar .sticky-btn:active{filter:brightness(.85)}

@media(max-width:768px){
    .mobile-sticky-bar{display:flex;padding-bottom:env(safe-area-inset-bottom,0)}
    .site-footer{padding-bottom:calc(74px + env(safe-area-inset-bottom,0))}
}

/* ============================================================
   POPUP / EXIT INTENT
   ============================================================ */
.popup-overlay,.lavista-exit-overlay{
    display:none;position:fixed;inset:0;background:rgba(10,10,10,.78);
    backdrop-filter:blur(8px);z-index:99998;align-items:center;justify-content:center;padding:20px;
}
.popup-overlay.active,.lavista-exit-overlay.active{display:flex;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.popup-content,.lavista-exit-box{
    background:#fff;border-radius:var(--radius-lg);max-width:480px;width:100%;
    padding:44px 36px 32px;position:relative;text-align:center;
    box-shadow:0 30px 90px rgba(0,0,0,.45);
    border-top:4px solid var(--lavista-bronze);
    animation:popIn .4s cubic-bezier(.34,1.56,.64,1);
}
@keyframes popIn{from{transform:scale(.92) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.popup-close,.lavista-exit-close{
    position:absolute;top:14px;right:14px;width:38px;height:38px;
    background:var(--lavista-bone);border:none;border-radius:50%;font-size:1.3rem;
    cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;
}
.popup-close:hover,.lavista-exit-close:hover{background:var(--lavista-cloud)}
.lavista-exit-badge{
    display:inline-block;background:var(--lavista-bronze);color:#fff;
    padding:6px 18px;border-radius:30px;font-size:.74rem;font-weight:700;
    letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;
}
.popup-content h3,.lavista-exit-box h3{
    font-family:var(--font-display);font-size:1.7rem;color:var(--lavista-black);
    margin:0 0 10px;font-weight:500;line-height:1.25;
}
body.lang-ar .popup-content h3,body.lang-ar .lavista-exit-box h3{font-family:var(--font-arabic);font-weight:700;font-size:1.4rem}
.popup-desc,.lavista-exit-sub{color:var(--text-light);margin-bottom:22px;font-size:.96rem;line-height:1.7;font-weight:300}

.lavista-countdown{display:flex;justify-content:center;gap:8px;margin:18px 0;direction:ltr}
.lavista-countdown-cell{background:var(--lavista-black);color:#fff;border-radius:var(--radius);padding:10px 4px;min-width:62px;text-align:center}
.lavista-countdown-cell .num{display:block;font-size:1.5rem;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;font-family:var(--font-display)}
.lavista-countdown-cell .lbl{display:block;font-size:.66rem;color:var(--lavista-gold-light);margin-top:5px;letter-spacing:.12em;text-transform:uppercase}
.lavista-live-viewers{
    display:inline-flex;align-items:center;gap:8px;
    background:rgba(60,90,60,.08);color:var(--lavista-green);
    padding:6px 14px;border-radius:30px;font-size:.84rem;font-weight:600;margin-bottom:14px;
}
.lavista-live-viewers .dot{width:8px;height:8px;border-radius:50%;background:var(--whatsapp);animation:pulseDot 1.5s infinite}
@keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}

/* ============================================================
   SCROLL PROGRESS + SCARCITY BANNER + SOCIAL PROOF TOAST
   ============================================================ */
#lavistaScrollProgress{
    position:fixed;top:0;left:0;height:2px;width:0;
    background:linear-gradient(90deg,var(--lavista-bronze),var(--lavista-gold));
    z-index:100000;transition:width .1s linear;pointer-events:none;
}
#lavistaScarcityBanner{
    position:fixed;top:-100px;left:0;right:0;z-index:9500;
    background:var(--lavista-black);color:#fff;padding:13px 16px;
    text-align:center;font-weight:600;font-size:.92rem;
    box-shadow:0 4px 20px rgba(0,0,0,.3);transition:top .4s cubic-bezier(.34,1.56,.64,1);
    display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;
}
#lavistaScarcityBanner.visible{top:0}
#lavistaScarcityBanner .pulse{width:9px;height:9px;border-radius:50%;background:var(--lavista-gold);animation:pulseDot 1.5s infinite}
#lavistaScarcityBanner .cta{background:var(--lavista-gold);color:var(--lavista-black);padding:5px 14px;border-radius:30px;font-weight:700;text-decoration:none;font-size:.82rem;letter-spacing:.06em}

#lavistaSocialToast{
    position:fixed;bottom:24px;left:24px;z-index:9400;
    background:#fff;color:var(--lavista-ink);padding:14px 18px;border-radius:var(--radius-lg);
    box-shadow:0 12px 40px rgba(0,0,0,.18);
    display:flex;align-items:center;gap:14px;
    transform:translateY(140%);opacity:0;transition:transform .5s ease,opacity .5s ease;
    max-width:340px;font-size:.88rem;border:1px solid var(--lavista-cloud);
}
#lavistaSocialToast.visible{transform:translateY(0);opacity:1}
body.rtl #lavistaSocialToast{left:auto;right:24px}
#lavistaSocialToast .ic{width:38px;height:38px;border-radius:50%;background:var(--lavista-bone);display:flex;align-items:center;justify-content:center;color:var(--lavista-bronze);flex-shrink:0}
#lavistaSocialToast .nm{font-weight:600;color:var(--lavista-ink);display:block}
#lavistaSocialToast .ms{color:var(--text-muted);font-size:.82rem}

/* ============================================================
   CONTACT GATE — captures phone before WhatsApp / Call
   ============================================================ */
.lavista-gate-overlay{
    display:none;position:fixed;inset:0;background:rgba(10,10,10,.82);
    backdrop-filter:blur(10px);z-index:99999;align-items:center;justify-content:center;padding:20px;
}
.lavista-gate-overlay.active{display:flex;animation:fadeIn .25s ease}
.lavista-gate-box{
    background:#fff;border-radius:var(--radius-lg);max-width:440px;width:100%;
    padding:42px 34px 30px;position:relative;text-align:center;
    box-shadow:0 30px 90px rgba(0,0,0,.5);border-top:4px solid var(--lavista-bronze);
    animation:popIn .4s cubic-bezier(.34,1.56,.64,1);
}
.lavista-gate-close{
    position:absolute;top:14px;right:14px;width:36px;height:36px;
    background:var(--lavista-bone);border:none;border-radius:50%;font-size:1.3rem;
    cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;
    transition:var(--transition);
}
.lavista-gate-close:hover{background:var(--lavista-cloud)}
.lavista-gate-icon{
    width:64px;height:64px;margin:0 auto 18px;border-radius:50%;
    background:var(--lavista-bone);color:var(--lavista-bronze);
    display:flex;align-items:center;justify-content:center;
}
.lavista-gate-icon.whatsapp{background:rgba(37,211,102,.12);color:var(--whatsapp-dark)}
.lavista-gate-icon.call{background:rgba(10,10,10,.06);color:var(--lavista-black)}
.lavista-gate-box h3{
    font-family:var(--font-display);font-size:1.55rem;color:var(--lavista-black);
    margin:0 0 8px;font-weight:500;line-height:1.3;
}
body.lang-ar .lavista-gate-box h3{font-family:var(--font-arabic);font-weight:700;font-size:1.35rem}
.lavista-gate-sub{color:var(--text-light);font-size:.95rem;margin-bottom:22px;line-height:1.65;font-weight:300}
.lavista-gate-form .form-field{margin-bottom:12px}
.lavista-gate-form input{
    width:100%;padding:14px 16px;border:1px solid var(--lavista-cloud);border-radius:var(--radius);
    font-size:1rem;font-family:inherit;direction:ltr;text-align:center;letter-spacing:.04em;
    transition:var(--transition);
}
.lavista-gate-form input:focus{outline:none;border-color:var(--lavista-bronze);box-shadow:0 0 0 3px rgba(164,134,82,.12)}
.lavista-gate-submit{
    width:100%;padding:15px;border:none;border-radius:var(--radius);
    font-size:.84rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;
    cursor:pointer;font-family:inherit;color:#fff;transition:var(--transition);margin-top:6px;
    display:inline-flex;align-items:center;justify-content:center;gap:10px;
}
body.lang-ar .lavista-gate-submit{letter-spacing:.04em;font-size:1rem;font-weight:700}
.lavista-gate-submit.whatsapp{background:var(--whatsapp-dark)}
.lavista-gate-submit.whatsapp:hover{background:#0d6e30}
.lavista-gate-submit.call{background:var(--lavista-black)}
.lavista-gate-submit.call:hover{background:var(--lavista-bronze)}
.lavista-gate-submit:disabled{opacity:.7;cursor:not-allowed}
.lavista-gate-submit .spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;display:none}
.lavista-gate-submit.loading .gate-text{display:none}
.lavista-gate-submit.loading .spinner{display:block}
.lavista-gate-trust{
    display:flex;justify-content:center;gap:18px;margin-top:18px;padding-top:16px;
    border-top:1px solid var(--lavista-cloud);font-size:.78rem;color:var(--text-muted);
}
.lavista-gate-trust span{display:inline-flex;align-items:center;gap:6px}
.lavista-gate-trust svg{color:var(--lavista-green);flex-shrink:0}
/* ============================================================
   PAGE BANNERS (Inner pages)
   ============================================================ */
.page-banner{
    position:relative;height:62vh;min-height:440px;
    display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;
    background:#0a0a0a;overflow:hidden;
}
.page-banner-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-banner-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.75))}
.page-banner .container{position:relative;z-index:2;padding-top:80px}
.page-banner .eyebrow{font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;color:var(--lavista-gold-light);margin-bottom:18px;font-weight:600}
.page-banner h1{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,4.4rem);font-weight:400;color:#fff;line-height:1.1;margin-bottom:14px}
body.lang-ar .page-banner h1{font-family:var(--font-arabic);font-weight:800;line-height:1.3}
.page-banner p{color:rgba(255,255,255,.82);font-size:1.05rem;font-weight:300;max-width:640px;margin:0 auto}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
    .dev-grid,.testi-grid{grid-template-columns:repeat(2,1fr)}
    .pillars-grid{grid-template-columns:repeat(2,1fr)}
    .featured-content{padding:60px 50px}
    .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
    .gallery-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:880px){
    .about-grid,.enquire-grid{grid-template-columns:1fr;gap:50px}
    .featured-row,.featured-row.reverse{grid-template-columns:1fr}
    .featured-img{min-height:340px}
    .featured-content{padding:50px 32px}
    .nav-toggle{display:flex;align-items:center;justify-content:center}
    .main-nav{
        position:fixed;top:0;right:-100%;height:100vh;width:80%;max-width:340px;
        background:var(--lavista-black);flex-direction:column;align-items:flex-start;
        padding:90px 36px 36px;gap:28px;transition:right .4s ease;z-index:999;
    }
    body.rtl .main-nav{right:auto;left:-100%;transition:left .4s ease}
    .main-nav.open{right:0}
    body.rtl .main-nav.open{left:0}
    .main-nav a,.site-header.scrolled .main-nav a{color:#fff;font-size:1rem}
    .nav-lang,.site-header.scrolled .nav-lang{color:#fff;border-color:rgba(255,255,255,.3)}
    .section{padding:80px 0}
    .about,.pillars,.developments,.testimonials,.faq,.gallery,.enquire{padding:80px 0}
}
@media(max-width:680px){
    .container{padding:0 18px}
    .dev-grid,.testi-grid,.pillars-grid{grid-template-columns:1fr}
    .gallery-grid{grid-template-columns:repeat(2,1fr);gap:10px}
    .gallery-item.tall,.gallery-item.wide{grid-column:span 1;grid-row:span 1;aspect-ratio:1}
    .footer-grid{grid-template-columns:1fr;gap:36px;padding-bottom:40px}
    .footer-bottom{flex-direction:column;text-align:center}
    .about-stats{grid-template-columns:1fr;gap:18px}
    .featured-facts{grid-template-columns:1fr;gap:14px}
    .enquire-form-wrap{padding:34px 24px}
    .lead-form .form-field-row{grid-template-columns:1fr}
    .hero{min-height:100vh}
    .hero .container{padding-top:110px}
    .hero-cta-row{flex-direction:column;width:100%;padding:0 14px}
    .hero-cta-row .btn{width:100%}
    .btn{padding:14px 26px;font-size:.78rem}
    .page-banner{height:50vh;min-height:340px}
    .testi{padding:34px 26px}
    .pillar{padding:42px 26px}
    body{padding-bottom:calc(70px + env(safe-area-inset-bottom,0))}
}
@media(max-width:380px){
    body{font-size:15px}
    .hero-title{font-size:2rem}
    .section-title{font-size:1.6rem}
}

/* ── Animation Utility ── */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.fade-up.in{opacity:1;transform:translateY(0)}
