*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Greens */
  --g0:#f0f8f1;   /* lightest tint */
  --g1:#d4edda;
  --g2:#3a8a48;   /* mid green (accents) */
  --g3:#2a6e37;   /* main green */
  --g4:#1c5228;   /* dark green */
  --g5:#102e16;   /* very dark */
  --g6:#081a0b;   /* near black green */
  /* Neutrals */
  --n0:#ffffff;
  --n1:#f6f4f0;
  --n2:#e8e4dd;
  --n3:#b8b2a8;
  --n4:#787068;
  --n5:#3a3630;
  --n6:#18150f;
  /* Typography */
  --f:'Montserrat',sans-serif;
  /* Transitions */
  --ease:.22s ease;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--f);color:var(--n5);background:var(--n0);overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* ── LAYOUT ── */
.wrap{max-width:1160px;margin:0 auto;padding:0 48px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:9px;padding:15px 30px;border-radius:4px;font-family:var(--f);font-size:15px;font-weight:700;cursor:pointer;border:2px solid transparent;transition:all var(--ease);text-decoration:none;white-space:nowrap;line-height:1;letter-spacing:.2px}
/* Primary solid green */
.btn-p{background:var(--g3);color:var(--n0);border-color:var(--g3)}
.btn-p:hover{background:var(--g4);transform:translateY(-2px);box-shadow:0 8px 24px rgba(26,82,40,.35)}
/* Primary solid white */
.btn-w{background:var(--n0);color:var(--g4);border-color:var(--n0)}
.btn-w:hover{background:var(--g0);transform:translateY(-2px)}
/* Outline white */
.btn-ow{background:transparent;color:var(--n0);border-color:rgba(255,255,255,.5)}
.btn-ow:hover{border-color:var(--n0);background:rgba(255,255,255,.1)}
/* Outline green */
.btn-og{background:transparent;color:var(--g3);border-color:var(--g3)}
.btn-og:hover{background:var(--g3);color:var(--n0)}
/* Light green fill */
.btn-lg{background:var(--g2);color:var(--n0);border-color:var(--g2)}
.btn-lg:hover{background:var(--g3);border-color:var(--g3);transform:translateY(-2px)}

/* ── SCROLL REVEAL ── */
.sr{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.sr.in{opacity:1;transform:none}

/* ═══════════════════════════════
   NAV
═══════════════════════════════ */
#nav{position:fixed;top:0;left:0;right:0;z-index:500}
.nav-bar{display:flex;align-items:center;height:72px;background:rgba(8,26,11,.96);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.07);transition:box-shadow .3s}
.nav-logo{display:flex;align-items:center;padding:0 20px 0 32px;text-decoration:none;border-right:1px solid rgba(255,255,255,.08);flex-shrink:0;height:100%}
.nav-logo img{height:50px;width:auto;display:block;object-fit:contain}
.nav-logo-t{display:none}
.nav-links{display:flex;flex:1;padding:0 8px;height:100%}
.nav-links a{display:flex;align-items:center;color:rgba(255,255,255,.58);text-decoration:none;font-size:11.5px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:0 14px;border-bottom:2px solid transparent;transition:all var(--ease)}
.nav-links a:hover{color:var(--n0);border-bottom-color:rgba(255,255,255,.5)}
.nav-r{display:flex;align-items:center;gap:12px;padding:0 28px;flex-shrink:0;margin-left:auto}
.nav-cta{background:var(--g3);color:var(--n0);padding:9px 20px;border-radius:4px;white-space:nowrap;font-size:12px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;text-decoration:none;transition:all var(--ease)}
.nav-cta:hover{background:var(--g2)}
/* Hamburger */
.nav-ham{display:none;background:none;border:none;cursor:pointer;padding:6px;flex-direction:column;gap:5px;align-items:center;justify-content:center;flex-shrink:0}
.nav-ham span{display:block;width:22px;height:2px;background:rgba(255,255,255,.8);border-radius:2px;transition:all .25s}
#nmob{display:none;position:fixed;top:72px;left:0;right:0;background:rgba(8,26,11,.98);backdrop-filter:blur(20px);z-index:490;padding:8px 0 16px}
#nmob.open{display:block}
#nmob a{display:block;color:rgba(255,255,255,.7);text-decoration:none;font-size:15px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:14px 28px;border-bottom:1px solid rgba(255,255,255,.05)}
#nmob a:last-child{border-bottom:none}
#nmob a:hover{color:var(--n0);background:rgba(255,255,255,.04)}
#nmob .nm-btn{background:var(--g3);color:var(--n0);margin:12px 28px 0;text-align:center;border-radius:4px;border-bottom:none;padding:13px 28px}

/* ═══════════════════════════════
   HERO — YouTube bg
═══════════════════════════════ */
#hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;
  padding-top:72px;overflow:hidden;
}
.hero-video{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;
  object-fit:cover;
  pointer-events:none;
}
.hero-ov{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    100deg,
    rgba(6,18,8,.78) 0%,
    rgba(10,28,12,.62) 40%,
    rgba(6,18,8,.45) 100%
  );
}
.hero-c{
  position:relative;z-index:2;
  padding:30px 0 80px;
  /* LEFT ALIGNED — no text-align override */
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(58,138,72,.2);
  border:1px solid rgba(58,138,72,.45);
  color:#7dcf8a;
  font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  padding:7px 15px;border-radius:3px;margin-bottom:28px;
}
.hero-dot{width:5px;height:5px;border-radius:50%;background:#7dcf8a;animation:blink 2.2s ease-in-out infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.hero-h1{
  font-size:clamp(34px,5vw,72px);
  font-weight:900;line-height:.92;
  color:var(--n0);letter-spacing:-1px;text-transform:uppercase;
  margin-bottom:26px;
  text-align:left;
}
.hero-h1 .accent{color:#7dcf8a}
.hero-h1 .soft{font-weight:500;opacity:.6;letter-spacing:0}
.hero-sub{
  font-size:clamp(16px,1.7vw,20px);font-weight:400;
  color:rgba(255,255,255,.65);line-height:1.75;
  max-width:520px;margin-bottom:40px;
  text-align:left;
}
.hero-ctas{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:48px;justify-content:flex-start}
.hero-chips{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding-top:22px;border-top:1px solid rgba(255,255,255,.1);
  justify-content:flex-start;
}
.hero-chips-lbl{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.28)}
.chip{
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.62);padding:5px 13px;border-radius:3px;
  font-size:11px;font-weight:600;letter-spacing:.8px;
}
/* Scroll hint */
.hero-scroll{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:5px}
.hs-ln{width:1px;height:32px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);animation:grow 1.8s ease-in-out infinite}
@keyframes grow{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}}
.hs-lb{font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.22)}

/* ═══════════════════════════════
   RIBBON
═══════════════════════════════ */
.ribbon{background:var(--g3);padding:14px 0}
.rib{display:flex;align-items:center;justify-content:center;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:0}
.rib::-webkit-scrollbar{display:none}
.ri{display:flex;align-items:center;gap:7px;color:rgba(255,255,255,.88);font-size:13px;font-weight:500;padding:3px 22px;flex-shrink:0;white-space:nowrap}
.ri svg{width:13px;height:13px;flex-shrink:0}
.rd{width:1px;height:14px;background:rgba(255,255,255,.2);flex-shrink:0}

/* ═══════════════════════════════
   STATS
═══════════════════════════════ */
.stats{background:var(--g5);padding:0}
.stats-g{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid rgba(255,255,255,.05)}
.st{padding:32px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.05)}
.st:last-child{border-right:none}
.st .n{font-size:clamp(36px,4.5vw,54px);font-weight:900;color:#7dcf8a;line-height:1;margin-bottom:7px;letter-spacing:-1px}
.st .l{font-size:14px;color:rgba(255,255,255,.42);font-weight:400}

/* ═══════════════════════════════
   SECTION BASE
═══════════════════════════════ */
.sec{padding:96px 0}
.lbl{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--g2);margin-bottom:12px}
.lbl-w{color:rgba(255,255,255,.45)}
.h2{font-size:clamp(30px,3.8vw,52px);font-weight:800;line-height:1.05;color:var(--n5);margin-bottom:20px;text-transform:uppercase;letter-spacing:-.5px}
.h2-w{color:var(--n0)}
.bod{font-size:clamp(16px,1.5vw,18px);font-weight:400;line-height:1.8;color:var(--n4);max-width:560px}
.bod-w{color:rgba(255,255,255,.6)}
.sec-hdr{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:44px;flex-wrap:wrap}

/* ═══════════════════════════════
   FEATURES
═══════════════════════════════ */
#perf{background:var(--n0)}
.perf-2{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;margin-bottom:56px}
.feat-row{display:grid;grid-template-columns:repeat(5,1fr);border:1px solid var(--n2);border-radius:6px;overflow:hidden}
.fi{padding:34px 18px;text-align:center;border-right:1px solid var(--n2);cursor:default;transition:background var(--ease);position:relative;display:flex;flex-direction:column;align-items:center}
.fi::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--g3);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.fi:last-child{border-right:none}
.fi:hover{background:var(--g0)}
.fi:hover::after{transform:scaleX(1)}
.fi-ico{width:50px;height:50px;border-radius:50%;background:var(--g0);display:flex;align-items:center;justify-content:center;margin:0 auto 13px;transition:background var(--ease)}
.fi-ico svg{width:20px;height:20px;stroke:var(--g3);fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.fi:hover .fi-ico{background:rgba(42,110,55,.15)}
.fi strong{display:block;font-size:14px;font-weight:700;color:var(--n5);margin-bottom:8px;letter-spacing:.1px}
.fi span{font-size:12.5px;color:var(--n4);font-weight:400;line-height:1.55;display:block}

/* ═══════════════════════════════
   APPLICATIONS
═══════════════════════════════ */
#apps{padding:0}
.apps-2{display:grid;grid-template-columns:1fr 1fr}
.ap{padding:80px 64px;position:relative;overflow:hidden}
.ap-l{background:var(--g5)}
.ap-r{background:var(--n6)}
.ap-deco{position:absolute;right:-40px;bottom:-40px;opacity:.04;pointer-events:none}
.ap-deco svg{width:250px;height:250px}
.ap .h2{font-size:clamp(22px,2.6vw,38px);margin-bottom:14px}
.ap .bod{font-size:clamp(15px,1.4vw,17px);margin-bottom:26px;max-width:100%}
.ap-ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:30px}
.ap-ul li{display:flex;align-items:center;gap:9px;color:rgba(255,255,255,.75);font-size:clamp(14px,1.3vw,16px);font-weight:400}
.ap-ul li svg{width:13px;height:13px;stroke:#7dcf8a;fill:none;stroke-width:2.5;stroke-linecap:round;flex-shrink:0}

/* ═══════════════════════════════
   PRODUCTS
═══════════════════════════════ */
#prods{background:var(--n0)}
.prods-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--n2);border:1px solid var(--n2);border-radius:6px;overflow:hidden}
.prods-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--n2);border:1px solid var(--n2);border-radius:6px;overflow:hidden}
.pc{background:var(--n0);display:flex;flex-direction:column;transition:background var(--ease)}
.pc:hover{background:var(--g0)}
.pc-img{height:300px;display:flex;align-items:center;justify-content:center;position:relative;background-size:cover;background-position:center;background-repeat:no-repeat;background-color:#0e2114}
.pi-g{background-image:linear-gradient(145deg,var(--g5),var(--g3))}
.pi-dg{background-image:linear-gradient(145deg,#121512,var(--g4))}
.pi-dk{background-image:linear-gradient(145deg,#181614,#383028)}
.pc-img svg{width:58px;height:58px;stroke:rgba(255,255,255,.55);fill:none;stroke-width:1.2;stroke-linecap:round;stroke-linejoin:round}
.pc-tag{position:absolute;top:13px;left:13px;background:var(--g2);color:var(--n0);font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:3px}
.pc-body{padding:24px;flex:1;display:flex;flex-direction:column}
.pc-body h3{font-size:clamp(17px,1.8vw,20px);font-weight:800;color:var(--n5);margin-bottom:6px;text-transform:uppercase;letter-spacing:-.2px}
.pc-sub{display:block;font-size:13px;font-weight:600;color:var(--g3);margin-bottom:12px;letter-spacing:.1px;line-height:1.4}
.pc-body p{font-size:clamp(14px,1.3vw,15px);color:var(--n4);line-height:1.7;font-weight:400;flex:1;margin-bottom:18px}
.pc-lnk{display:inline-flex;align-items:center;gap:6px;color:var(--g3);font-size:14px;font-weight:600;text-decoration:none;border-top:1px solid var(--n2);padding-top:14px;transition:gap var(--ease)}
.pc-lnk svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;transition:transform var(--ease)}
.pc-lnk:hover{gap:10px}.pc-lnk:hover svg{transform:translateX(3px)}

/* ═══════════════════════════════
   BIENESTAR Y SALUD
═══════════════════════════════ */
#bienestar{background:var(--n1);position:relative}
.bs-head{text-align:center;max-width:780px;margin:0 auto 56px}
.bs-head .lbl{justify-content:center}
.bs-head h2{margin-bottom:20px}
.bs-head p{font-size:clamp(15px,1.4vw,17px);color:var(--n4);line-height:1.7;font-weight:400}
.bs-g{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:48px}
.bs-c{background:var(--n0);border:1px solid var(--n2);border-radius:8px;padding:36px 32px;display:flex;gap:22px;align-items:flex-start;transition:all var(--ease)}
.bs-c:hover{border-color:var(--g2);box-shadow:0 8px 28px rgba(26,82,40,.08);transform:translateY(-2px)}
.bs-ico{flex-shrink:0;width:52px;height:52px;border-radius:10px;background:var(--g0);display:flex;align-items:center;justify-content:center}
.bs-ico svg{width:24px;height:24px;stroke:var(--g3);fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.bs-c h3{font-size:17px;font-weight:800;color:var(--n5);margin-bottom:10px;letter-spacing:-.1px;line-height:1.3}
.bs-c p{font-size:14.5px;color:var(--n4);line-height:1.65;font-weight:400}
.bs-foot{text-align:center;padding:36px 24px;border-top:1px solid var(--n2)}
.bs-foot strong{display:block;font-size:clamp(20px,2.2vw,26px);font-weight:700;color:var(--g4);margin-bottom:10px;letter-spacing:-.3px}
.bs-foot span{display:block;font-size:15px;color:var(--n4);line-height:1.6;max-width:620px;margin:0 auto}

/* ═══════════════════════════════
   TESTIMONIAL
═══════════════════════════════ */
#testi{background:var(--g5)}
.testi-2{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.tq{font-size:clamp(18px,2.3vw,26px);font-weight:500;line-height:1.45;color:var(--n0);margin-bottom:24px;padding-left:22px;position:relative;font-style:italic}
.tq::before{content:'"';position:absolute;left:0;top:-8px;font-size:58px;color:rgba(125,207,138,.45);font-family:Georgia,serif;line-height:1;font-style:normal}
.ta{display:flex;align-items:center;gap:12px}
.tav{width:42px;height:42px;border-radius:50%;background:rgba(58,138,72,.3);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--n0);font-weight:700;flex-shrink:0}
.tai strong{display:block;color:var(--n0);font-size:14px;font-weight:700;margin-bottom:2px}
.tai span{color:rgba(255,255,255,.38);font-size:13px;font-weight:400}
.testi-r{display:flex;flex-direction:column;gap:13px}
.ts2{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.tsc{background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.09);border-radius:5px;padding:24px 22px}
.tsc .n{font-size:clamp(32px,4vw,46px);font-weight:900;color:#7dcf8a;line-height:1;margin-bottom:6px;letter-spacing:-1px}
.tsc .n small{font-size:clamp(20px,2.2vw,26px)}
.tsc .d{font-size:clamp(13px,1.2vw,14px);color:rgba(255,255,255,.4);line-height:1.55;font-weight:400}

/* ═══════════════════════════════
   PRESUPUESTO — PROMINENT
═══════════════════════════════ */
#presupuesto{
  background:var(--g4);
  padding:96px 0;
  position:relative;overflow:hidden;
}
/* Subtle texture */
#presupuesto::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(
    -55deg,transparent,transparent 30px,
    rgba(255,255,255,.018) 30px,rgba(255,255,255,.018) 31px
  );
}
.pres-head{text-align:center;margin-bottom:48px;position:relative;z-index:1}
.pres-head .lbl{color:rgba(255,255,255,.55)}
.pres-head .h2{color:var(--n0);font-size:clamp(28px,4vw,52px)}
.pres-head p{font-size:clamp(15px,1.5vw,18px);color:rgba(255,255,255,.6);font-weight:400;margin:0 auto;max-width:480px}
.pres-wrap{max-width:860px;margin:0 auto;position:relative;z-index:1}

/* Steps */
.step-bar{display:flex;align-items:flex-start;margin-bottom:36px;position:relative}
.step-bar::before{content:'';position:absolute;top:17px;left:calc(12.5%);right:calc(12.5%);height:1px;background:rgba(255,255,255,.15);z-index:0}
.step-bar::after{content:'';position:absolute;top:17px;left:calc(12.5%);height:1px;background:rgba(255,255,255,.7);z-index:1;transition:width .5s ease;width:var(--bw,0%)}
.si{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;position:relative;z-index:2}
.si-n{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:rgba(255,255,255,.4);transition:all .3s}
.si.done .si-n{background:rgba(255,255,255,.9);border-color:var(--n0);color:var(--g4)}
.si.active .si-n{background:var(--n0);border-color:var(--n0);color:var(--g4);box-shadow:0 0 0 5px rgba(255,255,255,.2)}
.si-l{font-size:11px;font-weight:600;color:rgba(255,255,255,.35);text-align:center;letter-spacing:.3px}
.si.done .si-l,.si.active .si-l{color:rgba(255,255,255,.85)}

/* Card */
.pcard{background:var(--n0);border-radius:10px;padding:clamp(24px,4vw,48px);box-shadow:0 20px 60px rgba(0,0,0,.25)}
.pstep{display:none}
.pstep.on{display:block;animation:fup .32s ease}
@keyframes fup{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.ps-lbl{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--n3);margin-bottom:6px}
.pstep h2{font-size:clamp(20px,2.5vw,26px);font-weight:800;color:var(--n5);margin-bottom:6px;text-transform:uppercase;letter-spacing:-.3px}
.pstep .pd{font-size:clamp(14px,1.3vw,15px);color:var(--n4);font-weight:400;margin-bottom:28px}

/* Category cards */
.cat-g{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
.cc{border:2px solid var(--n2);border-radius:6px;overflow:hidden;cursor:pointer;transition:all .2s;position:relative;background:var(--n0)}
.cc:hover,.cc.on{border-color:var(--g3);box-shadow:0 4px 18px rgba(42,110,55,.18)}
.cc.on .cc-ck{opacity:1;transform:scale(1)}
.cc-img{height:100px;display:flex;align-items:center;justify-content:center}
.c1{background:linear-gradient(145deg,#d8f2dd,#aadbb2)}
.c2{background:linear-gradient(145deg,#daeee0,#9ad0a8)}
.c3{background:linear-gradient(145deg,#d0ebd8,#88c898)}
.c4{background:linear-gradient(145deg,#c8e8d0,#70bc80)}
.cc-img svg{width:36px;height:36px;stroke-linecap:round;stroke-linejoin:round;fill:none;stroke-width:1.6}
.c1 svg,.c2 svg,.c3 svg,.c4 svg{stroke:var(--g4)}
.cc-body{padding:10px 12px}
.cc-body h4{font-size:13px;font-weight:700;color:var(--n5);margin-bottom:2px;text-transform:uppercase;letter-spacing:.1px}
.cc-body span{font-size:11px;color:var(--n4);font-weight:400;display:block;line-height:1.3}
.cc-ck{position:absolute;top:8px;right:8px;width:20px;height:20px;border-radius:50%;background:var(--g3);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.5);transition:all .22s}
.cc-ck svg{width:10px;height:10px;stroke:white;fill:none;stroke-width:3;stroke-linecap:round}

/* Fields */
.pf-g{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}
.pff{grid-column:1/-1}
.pf{display:flex;flex-direction:column;gap:7px}
.pf label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--n4)}
.pf input,.pf select,.pf textarea{
  background:var(--n1);border:1.5px solid var(--n2);border-radius:4px;
  color:var(--n5);font-family:var(--f);font-size:clamp(14px,1.3vw,15px);
  padding:12px 15px;outline:none;transition:all .2s;resize:none;-webkit-appearance:none;width:100%
}
.pf input:focus,.pf select:focus,.pf textarea:focus{border-color:var(--g3);background:var(--n0);box-shadow:0 0 0 3px rgba(42,110,55,.1)}
.pf input::placeholder,.pf textarea::placeholder{color:var(--n3)}
.pf textarea{height:82px}

/* Nav */
.pnav{display:flex;align-items:center;justify-content:space-between;padding-top:22px;border-top:1px solid var(--n2);gap:10px;flex-wrap:wrap}
.pbk{background:none;border:1.5px solid var(--n2);color:var(--n4);padding:10px 20px;border-radius:4px;font-family:var(--f);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}
.pbk svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round}
.pbk:hover{border-color:var(--n3);color:var(--n5)}
.pnxt{background:var(--g3);color:var(--n0);border:none;padding:13px 26px;border-radius:4px;font-family:var(--f);font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;letter-spacing:.2px}
.pnxt svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round}
.pnxt:hover{background:var(--g4);box-shadow:0 4px 14px rgba(42,110,55,.35)}
.perr{font-size:13px;color:#c0392b;margin-top:8px;display:none}
.p-ind{font-size:12px;color:var(--n3);font-weight:500}

/* Result */
.res-hd{display:flex;align-items:center;gap:14px;margin-bottom:22px;padding-bottom:20px;border-bottom:1px solid var(--n2)}
.res-ico{width:48px;height:48px;border-radius:50%;background:var(--g0);border:1.5px solid rgba(42,110,55,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.res-ico svg{width:22px;height:22px;stroke:var(--g3);fill:none;stroke-width:2;stroke-linecap:round}
.res-hd h2{font-size:clamp(18px,2.2vw,24px);font-weight:800;color:var(--n5);text-transform:uppercase;margin-bottom:2px}
.res-hd p{font-size:13px;color:var(--n4);font-weight:400}
.res-nums{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;margin-bottom:14px}
.rn{background:var(--n1);border:1px solid var(--n2);border-top:3px solid var(--g3);border-radius:4px;padding:18px 14px}
.rn.hi{border-top-color:var(--g2)}
.rn .rv{font-size:clamp(20px,2.5vw,28px);font-weight:900;color:var(--g3);line-height:1;margin-bottom:4px;letter-spacing:-.5px}
.rn.hi .rv{color:var(--g2)}
.rn .rl{font-size:11px;color:var(--n3);line-height:1.4;font-weight:500}
.res-nrg{background:rgba(42,110,55,.06);border:1px solid rgba(42,110,55,.15);border-radius:4px;padding:18px 20px;margin-bottom:20px}
.re-lbl{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g3);margin-bottom:10px}
.re-g{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.re-i .rv{font-size:clamp(18px,2.2vw,22px);font-weight:800;color:var(--g4);line-height:1;margin-bottom:2px}
.re-i .rl{font-size:11px;color:var(--n4);font-weight:400}
.res-acts{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* ═══════════════════════════════
   CASA INTERACTIVA
═══════════════════════════════ */
#casa{background:var(--n1);padding:96px 0}
.casa-intro{text-align:center;max-width:580px;margin:0 auto 52px}
.casa-lay{display:grid;grid-template-columns:1fr 340px;gap:30px;align-items:start}
.casa-svg-w{border-radius:10px;overflow:hidden;background:linear-gradient(175deg,#ddf0e2 0%,#c8e8d0 100%);border:1px solid rgba(42,110,55,.14)}
.casa-svg-w svg{display:block;width:100%}
/* hotspot */
.hs{cursor:pointer}
.hs .outer{transition:r .2s}
.hs:hover .outer,.hs.on .outer{r:17;opacity:.28}
.hs.on .inner{fill:var(--g2)}
/* panel */
.cp{position:sticky;top:74px}
.cp-in{background:var(--n0);border:1px solid var(--n2);border-radius:8px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.07)}
.cp-hd{background:var(--g5);padding:18px 22px}
.cp-hd h3{font-size:clamp(15px,1.8vw,18px);font-weight:800;color:var(--n0);text-transform:uppercase;margin-bottom:2px;letter-spacing:-.2px}
.cp-hd p{font-size:12px;color:rgba(255,255,255,.38);font-weight:400}
.cp-bd{padding:20px}
.cp-mt{text-align:center;padding:24px 12px;color:var(--n3)}
.cp-mt svg{width:40px;height:40px;stroke:var(--n2);fill:none;stroke-width:1.2;margin:0 auto 10px;display:block}
.cp-mt p{font-size:clamp(13px,1.2vw,14px);font-weight:400;line-height:1.6}
.zi{display:none}
.zi.on{display:block;animation:fup .3s ease}
.zi-title{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.zi-ico{width:36px;height:36px;border-radius:5px;background:var(--g0);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.zi-ico svg{width:17px;height:17px;stroke:var(--g3);fill:none;stroke-width:2;stroke-linecap:round}
.zi-title h4{font-size:clamp(14px,1.6vw,16px);font-weight:800;color:var(--n5);text-transform:uppercase;letter-spacing:-.2px}
.zi-desc{font-size:clamp(12px,1.2vw,13px);color:var(--n4);font-weight:400;line-height:1.7;margin-bottom:14px}
.zi-sp{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.zs{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:var(--n1);border:1px solid var(--n2);border-radius:3px;font-size:12px;gap:6px}
.zs strong{color:var(--n5);font-weight:600;flex-shrink:0}
.zs span{color:var(--g3);font-weight:700;font-size:11px;background:var(--g0);padding:2px 7px;border-radius:2px;text-align:right}
.zi-cta{width:100%;background:var(--g3);color:var(--n0);border:none;padding:11px;border-radius:4px;font-family:var(--f);font-size:13px;font-weight:700;cursor:pointer;transition:background var(--ease);display:flex;align-items:center;justify-content:center;gap:7px;letter-spacing:.2px}
.zi-cta svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round}
.zi-cta:hover{background:var(--g4)}

/* ═══════════════════════════════
   CTA FINAL
═══════════════════════════════ */
#ctaf{background:var(--g3);padding:80px 0;text-align:center;position:relative;overflow:hidden}
#ctaf::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 36px,rgba(255,255,255,.018) 36px,rgba(255,255,255,.018) 37px)}
#ctaf .h2{text-align:center;font-size:clamp(28px,4.5vw,58px);position:relative;z-index:1}
#ctaf p{color:rgba(255,255,255,.6);font-size:clamp(15px,1.5vw,18px);text-align:center;margin:0 auto 32px;max-width:460px;font-weight:400;position:relative;z-index:1}
.ctaf-acts{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;position:relative;z-index:1}

/* ═══════════════════════════════
   CONTACTO
═══════════════════════════════ */
#cont{background:var(--n0);padding:96px 0}
.cont-lay{display:grid;grid-template-columns:1fr 1.2fr;gap:80px}
.ci-items{display:flex;flex-direction:column;gap:10px;margin-top:24px}
.ci{display:flex;gap:13px;align-items:flex-start;padding:14px 16px;border:1.5px solid var(--n2);border-radius:4px;transition:border-color var(--ease)}
.ci:hover{border-color:var(--g3)}
.ci-ic{width:36px;height:36px;border-radius:4px;background:var(--g0);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-ic svg{width:15px;height:15px;stroke:var(--g3);fill:none;stroke-width:2.1;stroke-linecap:round}
.ci strong{display:block;font-size:14px;font-weight:700;color:var(--n5);margin-bottom:2px}
.ci span{font-size:14px;color:var(--n4);font-weight:400}
.cf{display:flex;flex-direction:column;gap:13px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.fg{display:flex;flex-direction:column;gap:7px}
.fg label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--n4)}
.fg input,.fg select,.fg textarea{background:var(--n1);border:1.5px solid var(--n2);border-radius:4px;color:var(--n5);font-family:var(--f);font-size:clamp(14px,1.3vw,15px);padding:12px 15px;outline:none;transition:all .2s;resize:none;-webkit-appearance:none;width:100%}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--g3);background:var(--n0);box-shadow:0 0 0 3px rgba(42,110,55,.1)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--n3)}
.fg textarea{height:100px}
.fsub{background:var(--g3);color:var(--n0);border:none;padding:13px 28px;border-radius:4px;font-family:var(--f);font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}
.fsub svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round}
.fsub:hover{background:var(--g4);box-shadow:0 4px 14px rgba(42,110,55,.3)}
.fok{display:none;padding:14px;border-radius:4px;background:var(--g0);border:1px solid rgba(42,110,55,.2);color:var(--g4);font-size:15px;font-weight:600}

/* ═══════════════════════════════
   FOOTER
═══════════════════════════════ */
footer{background:var(--n6);padding:64px 0 0}
.ft{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:52px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.06)}
.fb-logo{display:flex;align-items:center;margin-bottom:18px;text-decoration:none}
.fb-logo img{height:34px;width:auto;display:block;object-fit:contain}
.fb-logo-t{display:none}
.fb p{font-size:13px;color:rgba(255,255,255,.3);line-height:1.8;font-weight:400;max-width:240px}
.fb-chips{display:flex;gap:7px;margin-top:16px;flex-wrap:wrap}
.fcc{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.35);padding:4px 11px;border-radius:2px;font-size:10px;font-weight:700;letter-spacing:1.5px}
.fc h4{font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.22);margin-bottom:14px}
.fc ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.fc ul li a{color:rgba(255,255,255,.38);text-decoration:none;font-size:13px;font-weight:400;transition:color .2s}
.fc ul li a:hover{color:rgba(255,255,255,.82)}
.fb-bot{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;padding:16px 0;color:rgba(255,255,255,.16);font-size:11px}

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media(max-width:960px){
  .wrap{padding:0 28px}
  .nav-links{display:none}
  .nav-ham{display:flex}
  .nav-logo{padding:0 16px 0 20px}
  .nav-logo img{height:44px}
  .perf-2{grid-template-columns:1fr;gap:32px}
  .feat-row{grid-template-columns:repeat(3,1fr)}
  .apps-2{grid-template-columns:1fr}
  .prods-3,.prods-2{grid-template-columns:1fr;gap:0;border-radius:6px}
  .prods-3 .pc,.prods-2 .pc{border-bottom:1px solid var(--n2)}
  .prods-3 .pc:last-child,.prods-2 .pc:last-child{border-bottom:none}
  .testi-2{grid-template-columns:1fr;gap:36px}
  .cont-lay{grid-template-columns:1fr;gap:40px}
  .casa-lay{grid-template-columns:1fr}
  .cp{position:static}
  .ft{grid-template-columns:1fr 1fr;gap:36px}
  .stats-g{grid-template-columns:repeat(2,1fr)}
  .ap{padding:52px 36px}
}
@media(max-width:600px){
  .wrap{padding:0 20px}
  .sec{padding:56px 0}
  .bs-g{grid-template-columns:1fr;gap:16px}
  .bs-c{padding:26px 22px;gap:16px}
  /* Nav mobile */
  .nav-bar{height:62px}
  #nmob{top:62px}
  .nav-logo{padding:0 14px 0 16px}
  .nav-logo img{height:40px}
  .nav-r{padding:0 14px;gap:10px}
  .nav-cta{padding:8px 14px;font-size:11px;letter-spacing:.8px}
  /* Hero */
  #hero{padding-top:62px}
  .hero-c{padding:44px 0 60px}
  .hero-h1{font-size:clamp(32px,9vw,52px);letter-spacing:-.5px}
  .hero-sub{font-size:16px;max-width:100%}
  .hero-ctas{flex-direction:column;align-items:stretch}
  .hero-ctas .btn{width:100%;justify-content:center}
  .hero-chips{flex-wrap:wrap;gap:8px}
  /* Sections */
  .feat-row{grid-template-columns:1fr 1fr;border:1px solid var(--n2)}
  .feat-row .fi{border-bottom:1px solid var(--n2)}
  .feat-row .fi:nth-child(5){grid-column:1/-1;border-bottom:none}
  .ts2,.res-nums{grid-template-columns:1fr 1fr}
  .re-g{grid-template-columns:1fr}
  .fr,.pf-g{grid-template-columns:1fr}
  .pff{grid-column:1}
  .cat-g{grid-template-columns:1fr 1fr}
  .cc-img{height:88px}
  .cc-img svg{width:30px;height:30px}
  .sec-hdr{flex-direction:column;align-items:flex-start;gap:10px}
  .ft{grid-template-columns:1fr}
  .fb-logo img{height:26px}
  .testi-r .ts2{grid-template-columns:1fr 1fr}
  .ap{padding:44px 24px}
  .pcard{padding:22px 18px}
  .pres-head .h2{font-size:clamp(24px,7vw,36px)}
  }
@media(max-width:380px){
  .wrap{padding:0 14px}
  .cat-g{grid-template-columns:1fr 1fr}
  .hero-h1{font-size:clamp(28px,8vw,42px)}
  .nav-logo img{height:36px}
  .nav-cta{padding:7px 12px;font-size:11px}
  .stats-g{grid-template-columns:1fr 1fr}
}

/* ── WhatsApp Float Button ── */
.wa-float{
  position:fixed;
  bottom:28px;
  right:28px;
  z-index:9000;
  width:56px;
  height:56px;
  background:#25D366;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.45);
  cursor:pointer;
  transition:transform .2s, box-shadow .2s;
  text-decoration:none;
}
.wa-float:hover{
  transform:scale(1.1);
  box-shadow:0 6px 28px rgba(37,211,102,.6);
}
.wa-float svg{
  width:30px;
  height:30px;
  fill:#fff;
}

/* ── HERO DE SUBPÁGINAS ── */
.page-hero{position:relative;min-height:62vh;display:flex;align-items:center;padding:120px 0 60px;overflow:hidden;color:var(--n0)}
.page-hero-bg{position:absolute;inset:0;z-index:0;background:linear-gradient(135deg,var(--g6) 0%,var(--g5) 50%,#1a4822 100%)}
.page-hero .wrap{position:relative;z-index:2}
.page-hero-h1{font-size:clamp(36px,5vw,64px);line-height:1.05;letter-spacing:-1px;margin-bottom:18px}
@media(max-width:600px){.page-hero{min-height:auto;padding:100px 0 50px}}


/* ── REVIEWS CAROUSEL ── */
.rev-head{text-align:center;margin-bottom:48px}
.rev-head .lbl{justify-content:center}
.rev-carousel{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;max-width:920px;margin:0 auto 32px;position:relative}
.rev-stage{position:relative;min-height:340px;display:flex;align-items:center;justify-content:center}
.rev-card{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 24px;opacity:0;transform:translateY(12px);transition:opacity .5s ease, transform .5s ease;pointer-events:none}
.rev-card.active{opacity:1;transform:none;pointer-events:auto;position:relative}
.rev-avatar{width:84px;height:84px;border-radius:50%;background:linear-gradient(145deg,var(--g2),var(--g4));display:flex;align-items:center;justify-content:center;color:var(--n0);font-weight:800;font-size:28px;letter-spacing:.5px;margin-bottom:22px;box-shadow:0 8px 22px rgba(0,0,0,.25);overflow:hidden}
.rev-avatar img{width:100%;height:100%;object-fit:cover}
.rev-avatar span{display:block}
.rev-quote{font-size:clamp(17px,2vw,22px);line-height:1.55;font-weight:500;color:var(--n0);font-style:italic;max-width:680px;margin-bottom:24px;position:relative;padding:0 12px}
.rev-quote::before,.rev-quote::after{content:'"';color:var(--g2);font-size:1.6em;font-weight:800;opacity:.6}
.rev-author strong{display:block;color:var(--n0);font-size:15px;font-weight:700;margin-bottom:4px;letter-spacing:.2px}
.rev-author span{display:block;color:rgba(255,255,255,.55);font-size:13px}
.rev-arrow{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:var(--n0);width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--ease);flex-shrink:0}
.rev-arrow:hover{background:var(--g3);border-color:var(--g3);transform:scale(1.05)}
.rev-arrow svg{width:20px;height:20px}
.rev-dots{display:flex;justify-content:center;gap:10px;margin-bottom:48px}
.rev-dot{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.25);cursor:pointer;padding:0;transition:all var(--ease)}
.rev-dot.active{background:var(--g2);transform:scale(1.3)}
.rev-dot:hover{background:rgba(255,255,255,.5)}
.rev-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1);border-radius:6px;overflow:hidden;max-width:760px;margin:0 auto}
.rev-stat{padding:24px 16px;text-align:center;background:var(--g5)}
.rev-stat .n{font-size:clamp(28px,3.2vw,38px);font-weight:800;color:var(--g2);line-height:1;margin-bottom:6px}
.rev-stat .n small{font-size:.55em;font-weight:700}
.rev-stat .d{font-size:12.5px;color:rgba(255,255,255,.65);line-height:1.4}
@media(max-width:600px){
  .rev-carousel{grid-template-columns:1fr;gap:16px}
  .rev-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5}
  .rev-prev{left:-8px}
  .rev-next{right:-8px}
  .rev-stage{min-height:380px}
  .rev-stats{grid-template-columns:1fr}
}

/* ── FOOTER SOCIAL ── */
.fb-social{display:flex;gap:12px;margin:24px 0 18px;justify-content:flex-start}
.fb-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);transition:all var(--ease)}
.fb-social a:hover{background:var(--g3);border-color:var(--g3);color:var(--n0);transform:translateY(-2px)}
.fb-social svg{width:17px;height:17px}
@media(max-width:600px){.fb-social{justify-content:center}}


/* ── COMPACT REVIEWS GRID ── */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:0 auto 44px;max-width:1080px}
.rev-mini{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:22px 22px 24px;transition:all var(--ease)}
.rev-mini:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18);transform:translateY(-2px)}
.rev-mini-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.rev-mini-avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0;overflow:hidden;background:linear-gradient(145deg,var(--g2),var(--g4));display:flex;align-items:center;justify-content:center;color:var(--n0);font-weight:800;font-size:16px}
.rev-mini-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.rev-mini-author strong{display:block;color:var(--n0);font-size:13.5px;font-weight:700;letter-spacing:.1px;line-height:1.3;margin-bottom:2px}
.rev-mini-author span{display:block;color:rgba(255,255,255,.55);font-size:11.5px;line-height:1.3}
.rev-mini-quote{color:rgba(255,255,255,.85);font-size:13.5px;line-height:1.6;font-style:italic;font-weight:400}
@media(max-width:840px){.rev-grid{grid-template-columns:1fr;gap:14px;max-width:520px}}


/* ── GALERÍA DE OBRAS ── */
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,200px);gap:12px;margin-top:30px}
.gal-i{display:block;background-size:cover;background-position:center;border-radius:6px;position:relative;overflow:hidden;text-decoration:none;cursor:pointer;transition:transform var(--ease)}
.gal-i.gal-lg{grid-column:span 2;grid-row:span 2}
.gal-i::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 50%,rgba(0,0,0,.55));pointer-events:none;transition:opacity var(--ease)}
.gal-i:hover{transform:scale(1.02)}
.gal-i:hover::after{background:linear-gradient(180deg,rgba(26,82,40,.15) 0%,rgba(0,0,0,.7))}
.gal-cap{position:absolute;bottom:0;left:0;right:0;padding:14px 16px;color:var(--n0);font-size:12.5px;font-weight:600;letter-spacing:.2px;z-index:2;line-height:1.3}
@media(max-width:840px){.gal-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,170px)}.gal-i.gal-lg{grid-column:span 2;grid-row:span 1}}
@media(max-width:480px){.gal-grid{grid-template-columns:1fr;grid-template-rows:none}.gal-i,.gal-i.gal-lg{grid-column:auto;grid-row:auto;height:200px}}


/* ── LIGHTBOX (galería) ── */
.lb{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9500;display:none;align-items:center;justify-content:center;padding:24px}
.lb.open{display:flex}
.lb-header{position:absolute;top:0;left:0;right:0;padding:18px 28px;display:flex;justify-content:space-between;align-items:center;z-index:10;background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,0));pointer-events:none}
.lb-header .lb-close,.lb-header .lb-title{pointer-events:auto}

.lb-stage{position:relative;max-width:1200px;max-height:90vh;width:100%;display:flex;align-items:center;justify-content:center}
.lb-img{max-width:100%;max-height:90vh;border-radius:6px;box-shadow:0 20px 80px rgba(0,0,0,.6);object-fit:contain}
.lb-close{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:#fff;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--ease);flex-shrink:0}
.lb-close:hover{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.5);transform:scale(1.05)}
.lb-close svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);color:#fff;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--ease)}
.lb-nav:hover{background:rgba(255,255,255,.18)}
.lb-prev{left:-60px}
.lb-next{right:-60px}
.lb-nav svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round}
.lb-counter{position:absolute;bottom:-36px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:13px;font-weight:600;letter-spacing:.5px}
@media(max-width:600px){
  .lb-prev{left:0;background:rgba(0,0,0,.5)}
  .lb-next{right:0;background:rgba(0,0,0,.5)}
}


/* ── REVIEW STARS ── */
.rev-stars{display:flex;gap:3px;margin-bottom:10px}
.rev-stars svg{width:14px;height:14px;fill:#f5c518;stroke:none}


/* ── PROJECT CARDS (galería) ── */
.proj-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px}
.proj-card{background:var(--n0);border:1px solid var(--n2);border-radius:8px;overflow:hidden;cursor:pointer;transition:all var(--ease);display:flex;flex-direction:column}
.proj-card:hover{border-color:var(--g3);box-shadow:0 10px 30px rgba(26,82,40,.12);transform:translateY(-3px)}
.proj-img{height:180px;background-size:cover;background-position:center;background-color:var(--g5);position:relative}
.proj-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;padding:14px;background:linear-gradient(180deg,rgba(0,0,0,0) 50%,rgba(0,0,0,.65))}
.proj-count{color:var(--n0);font-size:11.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);padding:5px 10px;border-radius:3px}
.proj-body{padding:18px 20px;flex:1;display:flex;flex-direction:column}
.proj-body h3{font-size:15px;font-weight:800;color:var(--n5);text-transform:uppercase;letter-spacing:-.1px;margin-bottom:6px}
.proj-body p{font-size:12.5px;color:var(--n4);line-height:1.5;margin:0}
@media(max-width:960px){.proj-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.proj-grid{grid-template-columns:1fr}}

/* Lightbox extras for video + project name */
.lb-video{max-width:100%;max-height:90vh;border-radius:6px;box-shadow:0 20px 80px rgba(0,0,0,.6);background:#000}
.lb-title{color:#fff;font-size:18px;font-weight:700;letter-spacing:.3px;text-shadow:0 2px 8px rgba(0,0,0,.6);text-transform:uppercase;line-height:1.2}


/* ── REVIEW AVATAR (person icon) ── */
.rev-mini-avatar svg{width:26px;height:26px;stroke:rgba(255,255,255,.85);fill:none}


/* ── MAPA ARGENTINA — cobertura nacional ── */
#alcance{padding:96px 0}
.map-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}
.map-text .lbl{margin-bottom:14px}
.map-text .h2{margin-bottom:22px}
.map-text .bod{margin-bottom:24px;max-width:520px}
.map-list{list-style:none;padding:0;margin:0}
.map-list li{position:relative;padding:14px 0 14px 32px;border-bottom:1px solid var(--n2);font-size:14px;color:var(--n5)}
.map-list li:last-child{border-bottom:none}
.map-list li strong{display:block;color:var(--g4);font-weight:800;font-size:14px;letter-spacing:.1px}
.map-list li .ml-tag{display:block;color:var(--n4);font-size:12px;font-weight:500;margin-top:2px}
.map-list li::before{content:'';position:absolute;left:0;top:18px;width:18px;height:18px;border-radius:50%;background:var(--g0);border:1.5px solid var(--g3)}
.map-list li::after{content:'';position:absolute;left:6px;top:24px;width:6px;height:6px;border-radius:50%;background:var(--g3)}
.map-list li:first-child::before{background:var(--g3);border-color:var(--g4)}
.map-list li:first-child::after{background:#7dcf8a}
.map-svg-wrap{display:flex;justify-content:center;position:relative}
.map-stage{position:relative;width:100%;max-width:280px;aspect-ratio:428/925;margin:0 auto}
.map-bg{width:100%;height:100%;display:block;filter:drop-shadow(0 14px 30px rgba(26,82,40,.18))}
.map-lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:visible}
.map-lines .route{stroke:var(--g4);stroke-width:.45;stroke-dasharray:1.8,1.4;fill:none;opacity:.9;stroke-linecap:round;animation:ar-flow 6s linear infinite}
@keyframes ar-flow{to{stroke-dashoffset:-20}}
.map-marker{position:absolute;transform:translate(-50%,-50%);z-index:3}
.mm-dot{width:13px;height:13px;border-radius:50%;background:var(--g3);border:2px solid var(--n0);box-shadow:0 2px 6px rgba(0,0,0,.25)}
.map-marker.origin .mm-dot{background:#3a8a48;width:18px;height:18px;border:3px solid var(--n0);box-shadow:0 0 0 1px var(--g4),0 4px 14px rgba(26,82,40,.4)}
.mm-pulse{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:18px;height:18px;border-radius:50%;border:2px solid #3a8a48;animation:mm-pulse 2.4s ease-out infinite;pointer-events:none}
.mm-pulse-d{animation-delay:1.2s}
@keyframes mm-pulse{0%{width:18px;height:18px;opacity:.9}100%{width:80px;height:80px;opacity:0}}
.mm-label{position:absolute;font-size:10.5px;font-weight:800;color:var(--g4);letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;background:rgba(255,255,255,.92);padding:3px 9px;border-radius:3px;box-shadow:0 2px 8px rgba(0,0,0,.10)}
.mm-label-r{left:calc(100% + 8px);top:50%;transform:translateY(-50%)}
.mm-label-l{right:calc(100% + 8px);top:50%;transform:translateY(-50%)}
.map-marker.origin .mm-label{font-size:12px;color:#fff;background:var(--g3);font-weight:800;box-shadow:0 4px 12px rgba(26,82,40,.35)}
@media(max-width:840px){
  .map-grid{grid-template-columns:1fr;gap:40px;text-align:center}
  .map-text .bod{margin-left:auto;margin-right:auto}
  .map-list li{text-align:left}
  .ar-map{max-width:260px}
}


/* ── MAPA: sucursales (replaza city/city-label) ── */
.ar-map .branch-dot{fill:var(--g3);stroke:var(--g0);stroke-width:1.2}
.ar-map .branch-label{font-family:var(--f);font-size:9px;font-weight:700;fill:var(--g4);letter-spacing:.3px;text-transform:uppercase}
.ar-map .branch{transition:transform .25s}
.ar-map .branch:hover .branch-dot{fill:#7dcf8a;r:5}


/* ── Galería técnica en Arquitectos ── */
.arq-gal{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:0}
.arq-gal-i{height:200px;background-size:cover;background-position:center;border-radius:6px;transition:transform var(--ease)}
.arq-gal-i:hover{transform:scale(1.02)}
@media(max-width:900px){.arq-gal{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.arq-gal{grid-template-columns:1fr}.arq-gal-i{height:180px}}


/* ── QUIÉNES SOMOS — imagen + cierre ── */
.nosotros-img{margin:60px auto 0;max-width:1280px;padding:0 24px}
.nosotros-img img{width:100%;height:auto;border-radius:8px;display:block;box-shadow:0 16px 48px rgba(0,0,0,.12)}
.qs-cierre{max-width:780px;margin:56px auto 16px;padding:32px 28px;text-align:center;border-top:1px solid var(--n2);border-bottom:1px solid var(--n2)}
.qs-cierre p{font-size:clamp(18px,2.2vw,24px);line-height:1.5;color:var(--g4);font-weight:500;letter-spacing:-.2px}
.qs-cierre p strong{color:var(--g3);font-weight:800}
@media(max-width:600px){
  .nosotros-img{margin-top:42px;padding:0 16px}
  .qs-cierre{margin:40px auto 10px;padding:24px 16px}
}


/* ── EQUIPO (Quiénes somos) ── */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:48px}
.team-c{display:flex;flex-direction:column;align-items:center;text-align:center;padding:8px}
.team-photo{width:100%;aspect-ratio:1/1;border-radius:50%;overflow:hidden;background:var(--g5);margin-bottom:16px;box-shadow:0 8px 24px rgba(0,0,0,.10)}
.team-photo img{width:100%;height:100%;object-fit:cover;display:block}
.team-c strong{font-size:15px;font-weight:800;color:var(--g4);letter-spacing:-.1px;line-height:1.3;margin-bottom:4px}
.team-c span{font-size:12.5px;color:var(--n4);font-weight:500;line-height:1.4}
@media(max-width:840px){.team-grid{grid-template-columns:repeat(2,1fr);gap:28px}}
@media(max-width:480px){.team-grid{grid-template-columns:1fr;gap:24px;max-width:280px;margin-left:auto;margin-right:auto}}
