/* ══════════════════════════════════════════
   INJIDAB IMMO — style.css
   Premium Real Estate Agency · Kénitra
══════════════════════════════════════════ */

/* ── TOKENS ── */
:root{
  --navy:#080C14;
  --navy2:#0F1825;
  --navy3:#1C2333;
  --gold:#C4922A;
  --gold-l:#DBA94A;
  --gold-d:#9A7020;
  --ivory:#F9F6F0;
  --stone:#EDE8DF;
  --mid:#6B7280;
  --white:#FFFFFF;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --r:12px;
  --tr:.3s ease;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--ivory);color:var(--navy);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:var(--font-body);cursor:pointer;border:none;background:none}
ul{list-style:none}
address{font-style:normal}
select,input,textarea{font-family:var(--font-body)}

/* ── UTILITY ── */
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}

/* ── LOADER ── */
#loader{position:fixed;inset:0;background:var(--navy);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .5s,visibility .5s}
#loader.out{opacity:0;visibility:hidden}
.ld-inner{text-align:center}
.ld-logo{font-family:var(--font-display);font-size:2rem;font-weight:600;color:var(--white);letter-spacing:2px;margin-bottom:32px}
.ld-logo em{color:var(--gold);font-style:normal}
.ld-track{width:200px;height:2px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;margin:0 auto 12px}
.ld-fill{height:100%;width:0%;background:var(--gold);border-radius:2px;transition:width .05s}
.ld-pct{font-size:.75rem;color:rgba(255,255,255,.4);letter-spacing:1px}

/* ── HEADER ── */
#hdr{position:fixed;top:0;left:0;width:100%;z-index:100;background:transparent;transition:background .4s,box-shadow .4s,padding .3s}
#hdr.scrolled{background:rgba(8,12,20,.96);backdrop-filter:blur(12px);box-shadow:0 1px 0 rgba(196,146,42,.15)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:72px;padding:0 40px;max-width:1400px;margin:0 auto}
.nav-logo{font-family:var(--font-display);font-size:1.35rem;font-weight:600;color:var(--white);letter-spacing:2px;transition:opacity .2s}
.nav-logo em{color:var(--gold);font-style:normal}
.nav-links{display:flex;gap:36px}
.nl{font-size:.8rem;font-weight:400;letter-spacing:.8px;color:rgba(255,255,255,.7);position:relative;transition:color .2s}
.nl::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
.nl:hover{color:var(--white)}
.nl:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:20px}
.nav-tel{font-size:.8rem;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:6px;transition:color .2s}
.nav-tel:hover{color:var(--gold)}
.btn-nav-cta{background:var(--gold);color:var(--navy);font-size:.75rem;font-weight:600;padding:9px 20px;border-radius:4px;letter-spacing:.5px;transition:background .2s,transform .2s}
.btn-nav-cta:hover{background:var(--gold-l);transform:translateY(-1px)}
.burger{display:none;flex-direction:column;gap:5px;padding:4px}
.burger span{display:block;width:22px;height:1.5px;background:var(--white);transition:var(--tr)}
@media(max-width:900px){
  .nav-links{display:none;position:fixed;top:72px;left:0;right:0;background:rgba(8,12,20,.98);flex-direction:column;gap:0;padding:24px 0;backdrop-filter:blur(12px)}
  .nav-links.open{display:flex}
  .nl{padding:14px 40px;display:block;font-size:1rem}
  .burger{display:flex}
  .nav-tel{display:none}
}

/* ── HERO ── */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;padding:120px 24px 80px}
.hero-bg{position:absolute;inset:0}
.hb-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;background:linear-gradient(135deg,#080C14 0%,#0f1e38 50%,#080C14 100%)}
.hb-slide:nth-child(2){background:linear-gradient(135deg,#0a0814 0%,#180d2c 50%,#080C14 100%)}
.hb-slide:nth-child(3){background:linear-gradient(135deg,#080C14 0%,#081c1e 50%,#080C14 100%)}
.hb-slide.active{opacity:1}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,12,20,.3) 0%,rgba(8,12,20,.1) 40%,rgba(8,12,20,.7) 100%)}

/* Cityscape */
.cityscape{position:absolute;bottom:0;left:0;right:0;height:55%;pointer-events:none;overflow:hidden}
.sky-glow{position:absolute;bottom:30%;left:50%;transform:translateX(-50%);width:80%;height:40%;background:radial-gradient(ellipse,rgba(196,146,42,.07) 0%,transparent 70%);border-radius:50%}
.building{position:absolute;bottom:0;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}
.bld-1{width:60px;height:45%;left:5%;background:rgba(196,146,42,.06);border-color:rgba(196,146,42,.1)}
.bld-2{width:90px;height:60%;left:12%}
.bld-3{width:50px;height:80%;left:20%;background:rgba(196,146,42,.05);border-color:rgba(196,146,42,.08)}
.bld-4{width:120px;height:40%;left:28%}
.bld-5{width:70px;height:65%;right:15%}
.bld-windows{position:absolute;inset:8px;display:grid;grid-template-columns:1fr 1fr;gap:4px;align-content:start;padding-top:8px}
.bld-windows span{height:6px;background:rgba(196,146,42,.3);border-radius:1px;animation:winBlink 4s infinite}
.bld-windows span:nth-child(odd){animation-delay:.5s}
.bld-windows span:nth-child(3n){animation-delay:1.2s}
@keyframes winBlink{0%,90%,100%{opacity:.3}95%{opacity:.9}}
.ground-line{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(196,146,42,.3),transparent)}

/* Hero content */
.hero-content{position:relative;text-align:center;max-width:780px;z-index:2}
.hero-eyebrow{font-size:.72rem;letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-bottom:28px;opacity:.9}
.hero-h1{font-family:var(--font-display);font-size:clamp(3rem,7vw,5.5rem);font-weight:600;line-height:1.05;color:var(--white);margin-bottom:24px;letter-spacing:-1px}
.hero-h1 em{color:var(--gold);font-style:italic}
.hero-sub{font-size:1.05rem;font-weight:300;color:rgba(255,255,255,.6);max-width:480px;margin:0 auto 40px;line-height:1.7}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:56px}
.hbtn-primary{background:var(--gold);color:var(--navy);font-size:.82rem;font-weight:600;padding:14px 32px;border-radius:4px;letter-spacing:.5px;transition:background .2s,transform .2s,box-shadow .2s}
.hbtn-primary:hover{background:var(--gold-l);transform:translateY(-2px);box-shadow:0 8px 24px rgba(196,146,42,.35)}
.hbtn-secondary{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.8);font-size:.82rem;font-weight:400;padding:14px 28px;border:1px solid rgba(255,255,255,.2);border-radius:4px;transition:all .2s;letter-spacing:.5px}
.hbtn-secondary:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.4);color:var(--white)}
.hero-kpis{display:flex;align-items:center;gap:0;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:hidden;backdrop-filter:blur(8px)}
.hkpi{padding:20px 32px;text-align:center}
.hkpi strong{display:block;font-family:var(--font-display);font-size:2rem;font-weight:600;color:var(--gold);line-height:1}
.hkpi span{font-size:.72rem;color:rgba(255,255,255,.5);letter-spacing:.5px;margin-top:4px;display:block}
.hkpi-sep{width:1px;height:48px;background:rgba(255,255,255,.08)}

/* Hero controls */
.hero-slider-ctrl{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:3}
.hsc-dot{width:24px;height:2px;background:rgba(255,255,255,.25);border-radius:2px;transition:all .3s;padding:0}
.hsc-dot.active{background:var(--gold);width:40px}
.hsa{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.06);color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.1);width:48px;height:48px;border-radius:50%;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:3}
.hsa:hover{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.hsa-prev{left:24px}
.hsa-next{right:24px}
.scroll-hint{position:absolute;right:32px;bottom:32px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:3}
.sh-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent);animation:shDrop 2s infinite}
@keyframes shDrop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
.scroll-hint span{font-size:.6rem;letter-spacing:2px;color:rgba(255,255,255,.3);writing-mode:vertical-rl;text-transform:uppercase}

/* ── SEARCH ── */
.search-sec{padding:0 24px;margin-top:-40px;position:relative;z-index:10}
.search-card{max-width:1100px;margin:0 auto;background:var(--white);border-radius:var(--r);box-shadow:0 24px 80px rgba(0,0,0,.15),0 0 0 1px rgba(196,146,42,.12);overflow:hidden}
.sc-tabs{display:flex;border-bottom:1px solid var(--stone)}
.sct{flex:1;padding:14px;font-size:.8rem;font-weight:500;color:var(--mid);letter-spacing:.5px;border-bottom:2px solid transparent;transition:all .2s;text-transform:uppercase}
.sct.active,.sct:hover{color:var(--navy);border-bottom-color:var(--gold)}
.sc-fields{display:flex;align-items:center;padding:6px 10px;flex-wrap:wrap;gap:0}
.scf{display:flex;flex-direction:column;flex:1;min-width:130px;padding:10px 14px}
.scf label{font-size:.65rem;font-weight:600;color:var(--mid);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.scf select{border:none;outline:none;font-size:.88rem;font-weight:400;color:var(--navy);background:transparent;appearance:none;cursor:pointer}
.scf-div{width:1px;height:40px;background:var(--stone);margin:auto 0}
.sc-go{background:var(--gold);color:var(--navy);font-size:.8rem;font-weight:600;padding:12px 24px;border-radius:6px;display:flex;align-items:center;gap:8px;white-space:nowrap;margin:6px;transition:background .2s,transform .2s;letter-spacing:.3px}
.sc-go:hover{background:var(--gold-l);transform:translateY(-1px)}
@media(max-width:768px){.sc-fields{flex-direction:column}.scf-div{width:100%;height:1px;margin:0}.sc-go{width:100%;justify-content:center;margin:8px 0 0}}

/* ── STATS ── */
.stats-sec{padding:80px 24px;background:var(--navy)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid rgba(255,255,255,.06);border-radius:var(--r);overflow:hidden;max-width:900px;margin:0 auto}
.stat-item{padding:40px 24px;text-align:center;border-right:1px solid rgba(255,255,255,.06);transition:background .3s}
.stat-item:last-child{border-right:none}
.stat-item:hover{background:rgba(196,146,42,.05)}
.stat-ico{font-size:1.5rem;display:block;margin-bottom:12px}
.stat-n{display:block;font-family:var(--font-display);font-size:2.5rem;font-weight:600;color:var(--gold);line-height:1}
.stat-n small{font-size:1.2rem}
.stat-lbl{display:block;font-size:.72rem;color:rgba(255,255,255,.4);letter-spacing:.5px;margin-top:6px;text-transform:uppercase}
@media(max-width:700px){.stats-grid{grid-template-columns:1fr 1fr}.stat-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.06)}.stat-item:nth-child(odd){border-right:1px solid rgba(255,255,255,.06)}}

/* ── SECTION HEADER ── */
.sec-head{text-align:center;margin-bottom:48px}
.sec-head.light .sec-title{color:var(--white)}
.sec-head.light .sec-desc{color:rgba(255,255,255,.45)}
.sec-tag{font-size:.7rem;font-weight:600;letter-spacing:3px;color:var(--gold);text-transform:uppercase;margin-bottom:12px;display:block}
.sec-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);font-weight:600;color:var(--navy);line-height:1.15}
.sec-title em{color:var(--gold);font-style:italic}
.sec-desc{color:var(--mid);font-size:.95rem;margin-top:12px;font-weight:300;max-width:520px;margin-left:auto;margin-right:auto;line-height:1.7}

/* ── CATALOG ── */
.catalog-sec{padding:96px 0;background:var(--ivory)}

/* Price filter */
.price-filter{background:var(--white);border:1px solid var(--stone);border-radius:var(--r);padding:28px 32px;margin-bottom:32px;box-shadow:0 4px 24px rgba(0,0,0,.04)}
.pf-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.pf-top h3{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--navy)}
.price-disp{font-size:.82rem;font-weight:500;color:var(--gold);background:rgba(196,146,42,.08);padding:4px 12px;border-radius:20px}
.range-wrap{position:relative;height:20px;margin-bottom:20px}
.range-track{position:absolute;top:50%;transform:translateY(-50%);left:0;right:0;height:3px;background:var(--stone);border-radius:2px}
.range-fill{position:absolute;height:100%;background:var(--gold);border-radius:2px;transition:left .05s,width .05s}
.r-input{position:absolute;width:100%;top:50%;transform:translateY(-50%);appearance:none;background:transparent;pointer-events:none;height:20px}
.r-input::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:var(--gold);border:3px solid var(--white);box-shadow:0 2px 8px rgba(196,146,42,.4);pointer-events:all;cursor:pointer;transition:transform .2s}
.r-input::-webkit-slider-thumb:hover{transform:scale(1.2)}
.r-input::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--gold);border:3px solid var(--white);box-shadow:0 2px 8px rgba(196,146,42,.4);pointer-events:all;cursor:pointer}
.pf-presets{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.pfp{padding:6px 16px;border:1.5px solid var(--stone);border-radius:20px;font-size:.75rem;font-weight:500;color:var(--mid);transition:all .2s}
.pfp.active,.pfp:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}

/* Category bar */
.cat-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px}
.cat{padding:8px 20px;border:1.5px solid var(--stone);border-radius:4px;font-size:.78rem;font-weight:500;color:var(--mid);transition:all .2s;letter-spacing:.3px}
.cat.active,.cat:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}

/* Property grid */
.props-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:28px}
.prop-card{background:var(--white);border-radius:var(--r);overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:transform .3s,box-shadow .3s;cursor:pointer}
.prop-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.12)}
.prop-img{position:relative;height:230px;overflow:hidden;background:linear-gradient(135deg,var(--navy2) 0%,var(--navy3) 100%);display:flex;align-items:center;justify-content:center}
.prop-emoji{font-size:4rem;opacity:.35;transition:transform .4s}
.prop-card:hover .prop-emoji{transform:scale(1.1);opacity:.45}
.prop-badge{position:absolute;top:16px;left:16px;padding:5px 12px;border-radius:3px;font-size:.65rem;font-weight:700;letter-spacing:1px;text-transform:uppercase}
.pb-vente{background:var(--gold);color:var(--navy)}
.pb-location{background:var(--navy);color:var(--white);border:1px solid rgba(255,255,255,.15)}
.pb-nouveau{position:absolute;top:16px;right:52px;background:#10B981;color:var(--white);padding:5px 10px;border-radius:3px;font-size:.6rem;font-weight:700;letter-spacing:1px;text-transform:uppercase}
.prop-fav{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:transform .2s,background .2s;backdrop-filter:blur(4px)}
.prop-fav:hover{transform:scale(1.1)}
.prop-fav.liked{background:var(--white)}
.prop-body{padding:20px 22px}
.prop-price{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--navy);margin-bottom:4px}
.prop-price span{font-size:.8rem;font-weight:300;color:var(--mid);font-family:var(--font-body)}
.prop-title{font-size:.92rem;font-weight:500;color:var(--navy);margin-bottom:6px;line-height:1.3}
.prop-loc{font-size:.78rem;color:var(--mid);display:flex;align-items:center;gap:4px;margin-bottom:16px}
.prop-feats{display:flex;gap:14px;padding-top:14px;border-top:1px solid var(--stone);flex-wrap:wrap}
.pf-feat{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--mid)}
.pf-feat strong{color:var(--navy);font-weight:600}
.prop-cta{display:block;text-align:center;margin-top:14px;padding:10px;border:1.5px solid var(--stone);border-radius:5px;font-size:.78rem;font-weight:600;color:var(--navy);letter-spacing:.3px;transition:all .2s}
.prop-cta:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}

.props-empty{text-align:center;padding:80px 24px;color:var(--mid)}
.props-empty h3{font-family:var(--font-display);font-size:1.5rem;color:var(--navy);margin-bottom:8px}

/* ── SERVICES ── */
.services-sec{padding:96px 0;background:var(--navy)}
.srv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;max-width:1100px;margin:0 auto}
.srv-card{border:1px solid rgba(255,255,255,.07);border-radius:var(--r);padding:36px 28px;transition:all .3s;position:relative;overflow:hidden}
.srv-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(196,146,42,.06),transparent);opacity:0;transition:opacity .3s}
.srv-card:hover{border-color:rgba(196,146,42,.3);transform:translateY(-4px)}
.srv-card:hover::before{opacity:1}
.srv-ico{font-size:2rem;margin-bottom:20px;display:block}
.srv-card h3{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--white);margin-bottom:12px}
.srv-card p{font-size:.85rem;color:rgba(255,255,255,.45);line-height:1.7}
.srv-lnk{display:inline-block;margin-top:20px;font-size:.78rem;color:var(--gold);letter-spacing:.3px;transition:gap .2s}
.srv-lnk:hover{gap:8px}

/* ── TESTIMONIALS ── */
.testi-sec{padding:96px 0;background:var(--ivory)}
.testi-wrap{overflow:hidden;border-radius:var(--r)}
.testi-track{display:flex;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.testi-card{min-width:100%;padding:48px;background:var(--white);border:1px solid var(--stone);border-radius:var(--r);box-shadow:0 4px 24px rgba(0,0,0,.05)}
.tc-stars{color:var(--gold);font-size:1rem;margin-bottom:20px;letter-spacing:2px}
.tc-text{font-family:var(--font-display);font-size:1.3rem;font-weight:400;line-height:1.6;color:var(--navy);margin-bottom:28px;font-style:italic}
.tc-author{display:flex;align-items:center;gap:16px}
.tc-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--navy));display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--white);font-weight:600;flex-shrink:0}
.tc-name{font-weight:600;font-size:.88rem;color:var(--navy)}
.tc-role{font-size:.75rem;color:var(--mid);margin-top:2px}
.testi-ctrl{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:32px}
.tca{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--stone);font-size:1.2rem;color:var(--navy);display:flex;align-items:center;justify-content:center;transition:all .2s}
.tca:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}
.testi-dots{display:flex;gap:8px}
.td-dot{width:8px;height:8px;border-radius:50%;background:var(--stone);transition:all .3s;border:none;padding:0}
.td-dot.active{background:var(--gold);width:24px;border-radius:4px}

/* ── CTA ── */
.cta-sec{padding:0;background:var(--ivory)}
.cta-box{background:linear-gradient(135deg,var(--gold) 0%,#9A7020 100%);padding:80px 60px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.cta-tag{font-size:.68rem;font-weight:700;letter-spacing:2px;color:rgba(8,12,20,.5);text-transform:uppercase;margin-bottom:12px;display:block}
.cta-txt h2{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:600;color:var(--navy);line-height:1.2;margin-bottom:10px}
.cta-txt h2 em{font-style:italic}
.cta-txt p{font-size:.9rem;color:rgba(8,12,20,.65);max-width:400px;line-height:1.6}
.cta-acts{display:flex;gap:12px;flex-wrap:wrap}
.cta-btn-p{background:var(--navy);color:var(--white);font-size:.82rem;font-weight:600;padding:14px 28px;border-radius:4px;letter-spacing:.3px;transition:all .2s}
.cta-btn-p:hover{background:#1C2333;transform:translateY(-2px)}
.cta-btn-w{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.15);color:var(--navy);font-size:.82rem;font-weight:600;padding:14px 24px;border-radius:4px;border:1px solid rgba(8,12,20,.15);transition:all .2s}
.cta-btn-w:hover{background:rgba(255,255,255,.25)}

/* ── CONTACT ── */
.contact-sec{padding:96px 0;background:var(--ivory)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;max-width:1100px;margin:0 auto}

/* Form */
.cform-wrap{background:var(--white);border-radius:var(--r);padding:40px;box-shadow:0 4px 24px rgba(0,0,0,.06)}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.fg label{font-size:.7rem;font-weight:600;color:var(--navy);text-transform:uppercase;letter-spacing:.5px}
.fg input,.fg select,.fg textarea{padding:12px 14px;border:1.5px solid var(--stone);border-radius:6px;font-size:.88rem;color:var(--navy);outline:none;transition:border-color .2s,background .2s;background:var(--ivory)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold);background:var(--white)}
.fg textarea{resize:vertical;min-height:100px}
.ferr{font-size:.72rem;color:#EF4444;margin-top:2px;min-height:16px}
.form-sub{width:100%;padding:14px;background:var(--navy);color:var(--white);border-radius:6px;font-size:.82rem;font-weight:600;letter-spacing:.5px;transition:background .2s,transform .2s;margin-top:4px}
.form-sub:hover{background:var(--navy3);transform:translateY(-1px)}
.form-ok{text-align:center;padding:32px}
.form-ok h3{font-family:var(--font-display);font-size:1.5rem;color:var(--navy);margin-bottom:8px}
.form-ok p{color:var(--mid);font-size:.9rem}

/* Info card */
.cinfo-card{background:var(--navy);border-radius:var(--r);padding:36px;margin-bottom:20px;color:var(--white)}
.cinfo-card h3{font-family:var(--font-display);font-size:1.6rem;font-weight:600;margin-bottom:6px}
.cinfo-sub{font-size:.82rem;color:rgba(255,255,255,.45);margin-bottom:28px;line-height:1.5}
.cii{display:flex;align-items:center;gap:14px;margin-bottom:18px;text-decoration:none;transition:opacity .2s}
.cii:hover{opacity:.8}
.cii-ico{width:40px;height:40px;background:rgba(196,146,42,.12);border:1px solid rgba(196,146,42,.2);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.cii strong{display:block;font-size:.72rem;font-weight:600;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}
.cii span{font-size:.85rem;color:rgba(255,255,255,.85)}
.cinfo-socials{display:flex;gap:10px;margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08)}
.csoc{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:5px;font-size:.75rem;font-weight:500;transition:all .2s}
.csoc.wa{background:#25D366;color:var(--white)}
.csoc.wa:hover{background:#1ebe5d}
.csoc.fb{background:#1877F2;color:var(--white)}
.csoc.fb:hover{background:#1464d8}
.csoc.ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:var(--white)}

/* Map */
.map-box{border-radius:var(--r);overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.08)}

/* ── FOOTER ── */
.site-footer{background:var(--navy)}
.ft-top{padding:72px 24px 56px}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:48px;max-width:1200px;margin:0 auto}
.ft-logo{font-family:var(--font-display);font-size:1.2rem;font-weight:600;color:var(--white);letter-spacing:2px;display:block;margin-bottom:16px}
.ft-logo em{color:var(--gold);font-style:normal}
.ft-brand p{font-size:.82rem;color:rgba(255,255,255,.35);line-height:1.7;margin-bottom:24px}
.ft-socials{display:flex;gap:10px}
.ft-socials a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);transition:all .2s}
.ft-socials a:hover{background:var(--gold);color:var(--navy)}
.ft-nav h4,.ft-contact h4{font-size:.68rem;font-weight:600;letter-spacing:2px;color:rgba(255,255,255,.25);text-transform:uppercase;margin-bottom:20px}
.ft-nav ul{display:flex;flex-direction:column;gap:10px}
.ft-nav a{font-size:.82rem;color:rgba(255,255,255,.4);transition:color .2s}
.ft-nav a:hover{color:var(--gold)}
.ft-contact p{font-size:.82rem;color:rgba(255,255,255,.4);line-height:1.8}
.ft-contact a{color:rgba(255,255,255,.5);transition:color .2s}
.ft-contact a:hover{color:var(--gold)}
.ft-bottom{border-top:1px solid rgba(255,255,255,.06);padding:20px 24px}
.ft-bottom .wrap{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.ft-bottom p{font-size:.75rem;color:rgba(255,255,255,.2)}
.ft-legal{display:flex;gap:20px}
.ft-legal a{font-size:.72rem;color:rgba(255,255,255,.2);transition:color .2s}
.ft-legal a:hover{color:var(--gold)}

/* ── MODAL ── */
.modal-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1000;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(6px)}
.modal-ov.open{display:flex}
.modal-box{background:var(--white);border-radius:16px;max-width:580px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:mdIn .35s cubic-bezier(.34,1.56,.64,1)}
@keyframes mdIn{from{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:none}}
.modal-cls{position:sticky;top:12px;left:calc(100% - 48px);width:36px;height:36px;border-radius:50%;background:var(--stone);font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .2s;margin:12px 12px 0 auto;z-index:1}
.modal-cls:hover{background:var(--navy);color:var(--white)}
.modal-gal{height:220px;background:linear-gradient(135deg,var(--navy2),var(--navy3));display:flex;align-items:center;justify-content:center;font-size:4rem;border-radius:0}
.modal-info{padding:28px 32px 32px}
.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}
.modal-badge{display:inline-block;padding:4px 10px;border-radius:3px;font-size:.62rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.mb-vente{background:var(--gold);color:var(--navy)}
.mb-location{background:var(--navy);color:var(--white)}
.modal-title{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--navy)}
.modal-loc{font-size:.78rem;color:var(--mid);margin-top:4px}
.modal-price{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--gold);white-space:nowrap}
.modal-feats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}
.mf-item{background:var(--ivory);border-radius:6px;padding:10px;text-align:center}
.mf-item strong{display:block;font-size:1.1rem;color:var(--navy);font-weight:600}
.mf-item span{font-size:.65rem;color:var(--mid);text-transform:uppercase;letter-spacing:.5px}
.modal-desc{font-size:.88rem;color:var(--mid);line-height:1.7;margin-bottom:24px}
.modal-acts{display:flex;gap:10px}
.ma-wa{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;background:#25D366;color:var(--white);border-radius:6px;font-size:.82rem;font-weight:600;transition:background .2s}
.ma-wa:hover{background:#1ebe5d}
.ma-call{flex:1;display:flex;align-items:center;justify-content:center;padding:12px;background:var(--ivory);border:1.5px solid var(--stone);color:var(--navy);border-radius:6px;font-size:.82rem;font-weight:600;transition:all .2s}
.ma-call:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}
.ma-form{flex:1;padding:12px;background:var(--navy);color:var(--white);border-radius:6px;font-size:.82rem;font-weight:600;transition:background .2s}
.ma-form:hover{background:var(--navy3)}

/* ── TOAST ── */
#toast{position:fixed;bottom:28px;right:28px;background:var(--navy);color:var(--white);padding:12px 22px;border-radius:6px;font-size:.82rem;box-shadow:0 8px 32px rgba(0,0,0,.2);z-index:2000;transform:translateY(80px);opacity:0;transition:all .3s;border-left:3px solid var(--gold);pointer-events:none}
#toast.show{transform:translateY(0);opacity:1}

/* ── BACK TO TOP ── */
#btt{position:fixed;bottom:28px;left:28px;width:44px;height:44px;border-radius:50%;background:var(--gold);color:var(--navy);font-size:1rem;font-weight:700;box-shadow:0 4px 16px rgba(196,146,42,.4);transition:all .3s;opacity:0;pointer-events:none;z-index:500}
#btt.show{opacity:1;pointer-events:all}
#btt:hover{background:var(--gold-l);transform:translateY(-3px)}

/* ── REVEAL ANIMATIONS ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}
.reveal-d4{transition-delay:.4s}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .ft-grid{grid-template-columns:1fr 1fr;gap:36px}
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .hero{padding:100px 20px 60px}
  .hero-kpis{flex-direction:column;gap:0}
  .hkpi-sep{width:100%;height:1px;margin:0}
  .hsa{display:none}
  .scroll-hint{display:none}
  .stats-grid{grid-template-columns:1fr 1fr}
  .catalog-sec,.services-sec,.testi-sec,.contact-sec{padding:64px 0}
  .cta-box{padding:48px 28px;flex-direction:column}
  .contact-grid{grid-template-columns:1fr;gap:28px}
  .fg-row{grid-template-columns:1fr}
  .modal-feats{grid-template-columns:1fr 1fr}
  .modal-acts{flex-direction:column}
  .ft-grid{grid-template-columns:1fr}
  .ft-brand{grid-column:1}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}
