/* ── RESET & BASE ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',sans-serif;background:#000000;color:#111827;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}
p{text-align:justify}

/* ── TOKENS ── */
:root{
  --c-navy:   #2b54a4;
  --c-blue:   #147ac1;
  --c-sky:    #6094b4;
  --c-slate:  #3a3a3a;
  --c-white:  #ffffff;
  --c-off:    #f7f8fa;
  --c-border: #e5e8ef;
  --c-dark:   #0b0f1a;
  --c-muted:  #6b7280;
  --radius:   6px;
  --transition: .3s cubic-bezier(.4,0,.2,1);
}

/* ── NAVIGATION ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  height:70px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5%;
  transition:background var(--transition), box-shadow var(--transition);
}
.nav--scrolled{
  background:rgba(11,15,26,.96);
  backdrop-filter:blur(16px);
  box-shadow:0 1px 0 rgba(255,255,255,.06);
}
.nav__brand{display:flex;align-items:center;gap:12px}
.nav__logo{height:48px;width:auto;filter:brightness(0) invert(1);display:block}
.nav__links{display:flex;align-items:center;gap:36px}
.nav__links a{
  font-family:'Manrope',sans-serif;
  font-size:.8rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.85);
  position:relative;transition:color var(--transition);
}
.nav__links a::after{
  content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;
  background:var(--c-blue);transform:scaleX(0);transform-origin:left;
  transition:transform var(--transition);
}
.nav__links a:hover{color:#fff}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__cta{
  font-family:'Manrope',sans-serif;
  font-size:.78rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  color:#fff !important;
  background:var(--c-blue);
  padding:.55rem 1.4rem;border-radius:4px;
  transition:background var(--transition),transform var(--transition) !important;
}
.nav__cta::after{display:none !important}
.nav__links a.nav__active{color:#fff}
.nav__links a.nav__active::after{transform:scaleX(1)}
.mob-nav a.nav__active{color:var(--c-blue)}
.nav__cta:hover{background:var(--c-navy) !important;transform:translateY(-1px)}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.nav__burger span{display:block;width:22px;height:1.5px;background:#fff;transition:var(--transition)}
.nav__burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mob-nav{
  display:none;position:fixed;inset:0;z-index:499;
  background:var(--c-dark);
  flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;
}
.mob-nav.open{display:flex}
.mob-nav a{
  font-family:'Manrope',sans-serif;
  font-size:1.9rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.06em;
  color:#fff;transition:color var(--transition);
  opacity:0;transform:translateY(20px);
}
.mob-nav.open a{animation:mobLinkIn .45s cubic-bezier(.4,0,.2,1) forwards}
.mob-nav.open a:nth-child(1){animation-delay:.05s}
.mob-nav.open a:nth-child(2){animation-delay:.1s}
.mob-nav.open a:nth-child(3){animation-delay:.15s}
.mob-nav.open a:nth-child(4){animation-delay:.2s}
.mob-nav.open a:nth-child(5){animation-delay:.25s}
@keyframes mobLinkIn{to{opacity:1;transform:translateY(0)}}
.mob-nav a:hover{color:var(--c-blue)}

/* ── HERO ── */
.hero{
  position:relative;
  height:100vh;min-height:640px;
  display:flex;flex-direction:column;justify-content:flex-end;
  overflow:hidden;
}
.hero__bg{
  position:absolute;inset:0;
  background:url('/index/hero.jpeg') center/cover no-repeat;
  animation:heroZoom 18s ease-in-out infinite alternate;
}
@keyframes cvPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(20,122,193,.5)}
  50%{box-shadow:0 0 0 8px rgba(20,122,193,0)}
}
@keyframes heroZoom{
  from{transform:scale(1)}
  to{transform:scale(1.3)}
}
.hero__overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(to bottom, rgba(11,15,26,.5) 0%, rgba(11,15,26,.1) 30%, rgba(11,15,26,.55) 65%, var(--c-dark) 100%),
    linear-gradient(to right, rgba(11,15,26,.45) 0%, transparent 60%);
}
.hero__watermark{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  z-index:1;width:clamp(280px,38vw,560px);
  opacity:.18;pointer-events:none;
  animation:heroSlideUp .9s .4s cubic-bezier(.4,0,.2,1) both;
}
.hero__body{
  position:relative;z-index:2;
  padding:0 5% 9vh;
  display:grid;grid-template-columns:1fr 360px;
  gap:60px;align-items:flex-end;
}
.hero__left{animation:heroSlideUp .9s .3s cubic-bezier(.4,0,.2,1) both}
.hero__panel{animation:heroSlideUp .9s .55s cubic-bezier(.4,0,.2,1) both}
@keyframes heroSlideUp{
  from{opacity:0;transform:translateY(32px)}
  to{opacity:1;transform:translateY(0)}
}
.hero__scroll{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;
  animation:heroSlideUp .9s .9s cubic-bezier(.4,0,.2,1) both;
}
.hero__scroll span{
  font-family:'Manrope',sans-serif;
  font-size:.6rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:rgba(255,255,255,.28);
}
.scroll-line{
  width:1px;height:40px;
  background:linear-gradient(to bottom,rgba(255,255,255,.3),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{transform:scaleY(1);opacity:.4}
  50%{transform:scaleY(.6);opacity:1}
}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Manrope',sans-serif;
  font-size:.72rem;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;
  color:#fff;margin-bottom:20px;
  text-shadow:0 1px 8px rgba(0,0,0,.8);
}
.hero__eyebrow::before{content:'';width:32px;height:1px;background:#fff;opacity:.7}
.hero__h1{
  font-family:'Manrope',sans-serif;
  font-weight:800;font-size:clamp(2.8rem,5.5vw,5.2rem);
  line-height:1.05;color:#fff;letter-spacing:-.02em;
}
.hero__h1 .ghost{
  color:transparent;
  -webkit-text-stroke:1.5px rgba(255,255,255,.6);
}
.hero__panel{display:flex;flex-direction:column;gap:20px}
.hero__lead{font-size:.9rem;line-height:1.75;color:rgba(255,255,255,.8);text-align:justify}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Manrope',sans-serif;
  font-size:.78rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:.75rem 1.6rem;border-radius:4px;
  border:1px solid transparent;cursor:pointer;
  transition:background var(--transition),color var(--transition),border-color var(--transition),transform var(--transition),box-shadow var(--transition);
}
.btn--primary{background:var(--c-blue);color:#fff}
.btn--primary:hover{background:var(--c-navy);transform:translateY(-2px);box-shadow:0 8px 24px rgba(20,122,193,.4)}
.btn--ghost{background:transparent;color:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.25)}
.btn--ghost:hover{border-color:rgba(255,255,255,.65);color:#fff;transform:translateY(-2px)}
.btn svg{flex-shrink:0;transition:transform var(--transition)}
.btn:hover svg{transform:translateX(3px)}
.hero__stats{
  display:flex;gap:32px;
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:20px;margin-top:8px;
}
.hstat__num{font-family:'Manrope',sans-serif;font-weight:800;font-size:1.65rem;color:#fff;line-height:1}
.hstat__label{font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-top:4px}
.hero__progress{position:absolute;bottom:0;left:0;right:0;height:2px;background:rgba(255,255,255,.07);z-index:3}
.hero__progress-fill{height:100%;background:var(--c-blue);width:0;transition:width .1s linear}

/* ── STRIP ── */
.strip{background:var(--c-navy);overflow:hidden;padding:.75rem 0}
.strip__track{display:flex;width:max-content;animation:stripAnim 24s linear infinite}
.strip__item{
  flex-shrink:0;padding:0 2.8rem;
  display:flex;align-items:center;gap:2.8rem;
  font-family:'Manrope',sans-serif;
  font-size:.73rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.strip__dot{width:3px;height:3px;background:rgba(255,255,255,.3);border-radius:50%;flex-shrink:0}
@keyframes stripAnim{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── INTRO ── */
.intro{
  background:var(--c-dark);
  padding:7rem 5%;
  display:grid;grid-template-columns:1fr 1fr;
  gap:6rem;align-items:start;position:relative;
  overflow:hidden;
}
.intro::before{
  content:'';position:absolute;top:0;left:5%;right:5%;height:1px;
  background:linear-gradient(90deg,var(--c-blue),rgba(43,84,164,.1));
}

/* ── AURORA (intro section) ── */
.aurora{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  overflow:hidden;
}
.aurora__beam{
  position:absolute;
  border-radius:50%;
  filter:blur(72px);
  opacity:0;
  will-change:transform,opacity;
}
.aurora__beam--1{
  width:80%;height:320px;
  top:-80px;left:-20%;
  background:radial-gradient(ellipse at center,rgba(20,122,193,.5) 0%,rgba(43,84,164,.25) 45%,transparent 100%);
  animation:auroraSlide1 12s ease-in-out infinite;
}
.aurora__beam--2{
  width:65%;height:260px;
  top:28%;left:-30%;
  background:radial-gradient(ellipse at center,rgba(96,148,180,.42) 0%,rgba(20,122,193,.18) 50%,transparent 100%);
  animation:auroraSlide2 9s ease-in-out infinite;
  animation-delay:-2.5s;
}
.aurora__beam--3{
  width:70%;height:280px;
  bottom:-60px;left:-25%;
  background:radial-gradient(ellipse at center,rgba(43,84,164,.42) 0%,rgba(96,148,180,.16) 50%,transparent 100%);
  animation:auroraSlide3 14s ease-in-out infinite;
  animation-delay:-5s;
}
@keyframes auroraSlide1{
  0%  {transform:translateX(0);      opacity:.0}
  15% {opacity:1}
  50% {transform:translateX(160%);   opacity:1}
  85% {opacity:1}
  100%{transform:translateX(180%);   opacity:.0}
}
@keyframes auroraSlide2{
  0%  {transform:translateX(0) scaleY(.9);  opacity:.0}
  20% {opacity:1}
  50% {transform:translateX(175%) scaleY(1.1);opacity:.95}
  80% {opacity:1}
  100%{transform:translateX(200%) scaleY(.9);opacity:.0}
}
@keyframes auroraSlide3{
  0%  {transform:translateX(0) scaleX(.95); opacity:.0}
  18% {opacity:.95}
  50% {transform:translateX(155%) scaleX(1.05);opacity:.85}
  82% {opacity:.95}
  100%{transform:translateX(175%) scaleX(.95);opacity:.0}
}

/* Asegurar que el contenido esté sobre la aurora */
.intro__left,.intro__right{position:relative;z-index:1}
.section-tag{
  font-family:'Manrope',sans-serif;
  font-size:.7rem;font-weight:700;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--c-blue);
}
.section-tag--link{
  display:inline-flex;align-items:center;gap:.5rem;
  transition:color var(--transition),gap var(--transition);
}
.section-tag--link:hover{color:var(--c-sky);gap:.75rem}
.intro__left{display:flex;flex-direction:column;gap:28px}
.intro__headline{
  font-family:'Manrope',sans-serif;
  font-weight:300;font-size:clamp(1.5rem,2.6vw,2.1rem);
  line-height:1.55;color:rgba(255,255,255,.75);
  letter-spacing:-.01em;text-align:justify;
}
.intro__headline strong{color:#fff;font-weight:600}
.intro__divider{width:48px;height:1px;background:var(--c-blue)}
.intro__sub{font-size:1.08rem;line-height:1.9;color:rgba(255,255,255,.55);text-align:justify}

/* ── INTRO CERTS (columna derecha) ── */
.intro__right{display:flex;flex-direction:column;gap:0;padding-top:.4rem}
.intro__certs-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}
.intro__certs-header .section-tag{color:var(--c-sky)}
.intro__certs-header::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg,rgba(96,148,180,.3),transparent);
}
.intro__certs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.intro__certs-grid .cert::after{
  top:auto;bottom:0;left:10%;right:10%;width:auto;height:1px;background:rgba(255,255,255,.07);
}
.intro__certs-grid .cert:nth-child(3n)::after{display:none}
.intro__certs-grid .cert:nth-child(4)::after,
.intro__certs-grid .cert:nth-child(5)::after{display:block}
.intro__certs-grid .cert:nth-child(6)::after{display:none}
.intro__certs-grid .cert{border-right:1px solid rgba(255,255,255,.07)}
.intro__certs-grid .cert:nth-child(3n){border-right:none}
.intro__certs-grid .cert:last-child{border-right:none}

/* ── CERT items ── */
.cert{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;padding:1.6rem 1rem;
  position:relative;transition:background var(--transition);cursor:default;
}
.cert::after{
  content:'';position:absolute;right:0;top:20%;bottom:20%;
  width:1px;background:rgba(255,255,255,.07);
}
.cert:last-child::after{display:none}
.cert:hover{background:rgba(20,122,193,.07);transform:translateY(-2px);transition:background var(--transition),transform var(--transition)}
.cert__icon{
  width:42px;height:42px;
  border:1.5px solid rgba(20,122,193,.5);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1rem;
  transition:border-color var(--transition),background var(--transition);
}
.cert:hover .cert__icon{border-color:var(--c-blue);background:rgba(20,122,193,.15)}
.cert__icon svg{color:var(--c-blue);transition:color var(--transition)}
.cert:hover .cert__icon svg{color:var(--c-sky)}
.cert__iso{font-family:'Manrope',sans-serif;font-size:1rem;font-weight:800;letter-spacing:.06em;color:#fff;margin-bottom:.4rem;line-height:1.2}
.cert__name{font-size:.88rem;line-height:1.45;color:rgba(255,255,255,.45)}

/* ── SERVICES ── */
.services{background:#f7f8fa;padding:7rem 5%}
.section-header{
  display:flex;justify-content:space-between;
  align-items:flex-end;margin-bottom:3rem;
  flex-wrap:wrap;gap:1.5rem;
}
.section-title{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:clamp(1.9rem,3.8vw,3rem);
  color:#111827;line-height:1.1;letter-spacing:-.03em;margin-top:.6rem;
}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{
  border-radius:var(--radius);overflow:hidden;
  position:relative;min-height:400px;
  transition:box-shadow var(--transition),transform var(--transition);
}
.svc:hover{box-shadow:0 20px 56px rgba(20,122,193,.18);transform:translateY(-4px)}
.svc img{
  width:100%;height:100%;object-fit:cover;
  position:absolute;inset:0;
  transition:transform .7s cubic-bezier(.4,0,.2,1);
}
.svc:hover img{transform:scale(1.06)}
.svc__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(11,15,26,.95) 0%,rgba(11,15,26,.3) 55%,rgba(11,15,26,.05) 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:2rem;transition:background var(--transition);
}
.svc:hover .svc__overlay{background:linear-gradient(to top,rgba(11,15,26,.98) 0%,rgba(11,15,26,.45) 55%,rgba(11,15,26,.1) 100%)}
.svc__num{font-family:'Manrope',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:.5rem}
.svc__title{font-family:'Manrope',sans-serif;font-weight:800;font-size:1.4rem;text-transform:uppercase;letter-spacing:.02em;color:#fff;line-height:1.15;margin-bottom:.6rem}
.svc__desc{font-size:.88rem;line-height:1.7;color:rgba(255,255,255,.65);text-align:justify}
.svc__link{
  display:inline-flex;align-items:center;gap:6px;margin-top:1rem;
  font-family:'Manrope',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--c-sky);
  transition:color var(--transition),gap var(--transition);
}
.svc__link:hover{color:#fff;gap:10px}
.svc__link svg{transition:transform var(--transition)}
.svc__link:hover svg{transform:translateX(3px)}

/* ── NOSOTROS ── */
.about{display:grid;grid-template-columns:1fr 1fr;min-height:640px}
.about__visual{position:relative;overflow:hidden}
.about__visual img{width:100%;height:100%;object-fit:cover;filter:brightness(.85)}
.about__badge{
  position:absolute;bottom:2.5rem;right:2.5rem;
  background:rgba(11,15,26,.82);border:1px solid rgba(255,255,255,.12);
  padding:1.4rem 1.8rem;border-radius:var(--radius);
  text-align:center;backdrop-filter:blur(12px);
}
.about__badge-num{font-family:'Manrope',sans-serif;font-weight:800;font-size:2.5rem;color:#fff;line-height:1}
.about__badge-label{font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:.3rem}
.about__content{background:#f7f8fa;padding:5rem 5% 5rem 6%;display:flex;flex-direction:column;justify-content:center;gap:2rem}
.about__content .section-tag{
  display:inline-flex;align-items:center;gap:.75rem;
  color:var(--c-blue);font-size:.72rem;letter-spacing:.28em;
}
.about__content .section-tag::before{
  content:'';display:block;width:28px;height:1.5px;background:var(--c-blue);border-radius:2px;flex-shrink:0;
}
.about__title{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:clamp(2rem,3.2vw,2.9rem);
  color:#111827;line-height:1.12;letter-spacing:-.03em;
}
.about__title span{color:var(--c-blue)}
.about__text{font-size:.97rem;line-height:1.9;color:#5a6374}

/* Skill bars */
.skills-list__title{
  font-family:'Manrope',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--c-muted);
  padding-top:1.4rem;border-top:1px solid var(--c-border);
}
.skills-list{
  display:flex;flex-direction:column;gap:1.1rem;
  margin-top:0;
}
.skill{display:flex;align-items:center;gap:16px}
.skill__label{
  font-family:'Manrope',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.09em;text-transform:uppercase;color:#374151;
  width:140px;flex-shrink:0;
}
.skill__bar{flex:1;height:4px;background:rgba(0,0,0,.07);border-radius:4px;overflow:hidden}
.skill__fill{
  height:100%;
  background:linear-gradient(90deg,var(--c-blue) 0%,var(--c-sky) 100%);
  transform:scaleX(0);transform-origin:left;
  transition:transform 1.2s cubic-bezier(.4,0,.2,1);
}
.skill__fill.run{transform:scaleX(1)}
.skill__pct{
  font-family:'Manrope',sans-serif;font-size:.78rem;font-weight:800;
  color:var(--c-navy);width:38px;text-align:right;
}

/* MVV cards rediseño */
.mvv-cards{display:grid;grid-template-columns:1fr;gap:.7rem;margin-top:.4rem}
.mvv-card{
  display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;
  column-gap:1rem;row-gap:.25rem;
  padding:1.2rem 1.4rem;
  background:#fff;
  border:1px solid var(--c-border);
  border-radius:8px;
  box-shadow:0 1px 4px rgba(0,0,0,.05);
  transition:box-shadow var(--transition),border-color var(--transition),transform var(--transition);
}
.mvv-card:hover{
  box-shadow:0 4px 18px rgba(20,122,193,.1);
  border-color:rgba(20,122,193,.3);
  transform:translateY(-2px);
}
.mvv-card__icon{
  grid-column:1;grid-row:1/3;
  width:36px;height:36px;border-radius:8px;
  background:rgba(20,122,193,.08);
  display:flex;align-items:center;justify-content:center;
  color:var(--c-blue);flex-shrink:0;align-self:start;margin-top:1px;
}
.mvv-card__label{
  grid-column:2;grid-row:1;
  font-family:'Manrope',sans-serif;font-size:.68rem;font-weight:800;
  letter-spacing:.18em;text-transform:uppercase;color:var(--c-blue);
  align-self:end;
}
.mvv-card__text{
  grid-column:2;grid-row:2;
  font-size:.86rem;line-height:1.65;color:#6b7280;text-align:left;
}

/* ── STATS ROW ── */
.stats-row{background:var(--c-blue);display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.stats-row__header{
  position:absolute;top:0;left:0;right:0;
  display:flex;justify-content:center;
  padding:.6rem 1rem;
  background:rgba(0,0,0,.18);
  border-bottom:1px solid rgba(255,255,255,.1);
}
.stats-row__header span{
  font-family:'Manrope',sans-serif;font-size:.65rem;font-weight:700;
  letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.55);
}
.stat-cell{padding:4rem 2rem 3rem;text-align:center;border-right:1px solid rgba(255,255,255,.12);transition:background var(--transition)}
.stat-cell:hover{background:rgba(255,255,255,.04)}
.stat-cell:last-child{border-right:none}
.stat-cell__num{font-family:'Manrope',sans-serif;font-weight:800;font-size:clamp(2rem,3.5vw,3rem);color:#fff;line-height:1}
.stat-cell__suffix{color:rgba(255,255,255,.5);font-size:1.4rem}
.stat-cell__label{font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:.7rem}

/* ── PROJECTS ── */
.projects{background:#fff;padding:7rem 5%}
.projects__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.proj{border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:16/10;background:var(--c-slate)}
.proj img{width:100%;height:100%;object-fit:cover;transition:transform .55s cubic-bezier(.4,0,.2,1);filter:brightness(.75)}
.proj:hover img{transform:scale(1.05);filter:brightness(.9)}
.proj__info{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.6rem;background:linear-gradient(to top,rgba(11,15,26,.88) 0%,transparent 55%)}
.proj__year{font-family:'Manrope',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--c-sky);margin-bottom:.35rem}
.proj__name{font-family:'Manrope',sans-serif;font-weight:700;font-size:1.05rem;text-transform:uppercase;letter-spacing:.01em;color:#fff;line-height:1.3}

/* ── CONTACT ── */
.contact{display:grid;grid-template-columns:1fr 1fr;min-height:620px}
.contact__visual{position:relative;overflow:hidden}

.contact__visual-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,15,26,.15) 0%,rgba(11,15,26,.08) 60%,rgba(11,15,26,.35) 100%);
  pointer-events:none;z-index:1;
}
.contact__text{position:absolute;bottom:0;left:0;right:0;padding:2.5rem 3rem;z-index:2}
.contact__address{font-size:.82rem;line-height:1.75;color:rgba(255,255,255,.5)}
.contact__address strong{display:block;font-family:'Manrope',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--c-blue);margin-bottom:.5rem}
.contact__form-side{background:var(--c-dark);padding:5rem 4%;display:flex;flex-direction:column;justify-content:center}
.form__title{font-family:'Manrope',sans-serif;font-weight:800;font-size:clamp(1.6rem,2.8vw,2.2rem);color:#fff;letter-spacing:-.02em;line-height:1.15;margin-bottom:2rem}
.form__grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.field{display:flex;flex-direction:column;gap:.45rem}
.field--full{grid-column:span 2}
.field label{font-family:'Manrope',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.65)}
.field input,.field textarea{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:.8rem 1rem;font-family:'Inter',sans-serif;font-size:.9rem;color:#fff;outline:none;transition:border-color var(--transition),background var(--transition)}
.field input:focus,.field textarea:focus{border-color:var(--c-blue);background:rgba(20,122,193,.07)}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.18)}
.field textarea{resize:none;height:96px}
.btn--submit{width:100%;margin-top:.4rem;justify-content:center;background:var(--c-blue);color:#fff;font-size:.8rem;padding:.9rem}
.btn--submit:hover{background:var(--c-navy)}
.contact-info-list{display:flex;flex-direction:column;gap:.55rem;margin-top:2rem}
.cinfo{display:flex;align-items:center;gap:.7rem;font-size:.82rem;color:rgba(255,255,255,.65)}
.cinfo svg{color:var(--c-sky);flex-shrink:0}

/* ── BACK TO TOP ── */
.back-top{
  position:fixed;bottom:2rem;right:2rem;z-index:400;
  width:44px;height:44px;
  background:var(--c-blue);
  border:none;border-radius:50%;
  color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(20,122,193,.45);
  opacity:0;transform:translateY(12px);
  transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1),background var(--transition),box-shadow var(--transition);
  pointer-events:none;
}
.back-top.visible{opacity:1;transform:translateY(0);pointer-events:all}
.back-top:hover{background:var(--c-navy);box-shadow:0 8px 28px rgba(20,122,193,.55);transform:translateY(-2px)}

/* ── FOOTER WHATSAPP BAR ── */
.footer-wa{
  background:#0b1a10;
  border-top:1px solid rgba(37,211,102,.15);
  border-bottom:1px solid rgba(37,211,102,.08);
  padding:1.4rem 5%;
}
.footer-wa__inner{
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  max-width:1400px;margin:0 auto;
}
.footer-wa__left{display:flex;align-items:center;gap:1rem}
.footer-wa__dot{
  width:10px;height:10px;border-radius:50%;
  background:#25d366;flex-shrink:0;
  box-shadow:0 0 0 0 rgba(37,211,102,.5);
  animation:waPulse 2s ease-in-out infinite;
}
@keyframes waPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}
  50%{box-shadow:0 0 0 7px rgba(37,211,102,0)}
}
.footer-wa__title{
  font-family:'Manrope',sans-serif;font-size:.8rem;font-weight:700;
  letter-spacing:.06em;color:#fff;
}
.footer-wa__sub{font-size:.8rem;color:rgba(255,255,255,.45);margin-top:.15rem}
.footer-wa__btn{
  display:inline-flex;align-items:center;gap:.6rem;flex-shrink:0;
  font-family:'Manrope',sans-serif;font-size:.8rem;font-weight:700;
  letter-spacing:.04em;
  background:#25d366;color:#fff;
  padding:.65rem 1.4rem;border-radius:6px;
  transition:background var(--transition),transform var(--transition);
}
.footer-wa__btn:hover{background:#1ebe5d;transform:translateY(-1px)}
@media(max-width:720px){
  .footer-wa__inner{flex-direction:column;align-items:flex-start;gap:1rem}
  .footer-wa__sub{font-size:.75rem}
}

/* ── FOOTER ── */
footer{
  background:#07090f;padding:2.8rem 5%;
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:center;gap:1.5rem 2rem;
  border-top:1px solid rgba(255,255,255,.1);
}
.footer__brand{display:flex;align-items:center}
.footer__logo{height:72px;width:auto;filter:brightness(0) invert(1);opacity:.75;transition:opacity var(--transition)}
.footer__brand:hover .footer__logo{opacity:1}
.footer__links{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap}
.footer__links a{font-family:'Manrope',sans-serif;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);transition:color var(--transition)}
.footer__links a:hover{color:#fff}
.footer__right{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem}
.footer__copy{font-size:.72rem;color:rgba(255,255,255,.45)}
.footer__dev{font-size:.68rem;color:rgba(255,255,255,.45);font-style:italic}

/* ── REVEAL ── */
.r{opacity:0;transform:translateY(28px);transition:opacity .75s cubic-bezier(.4,0,.2,1),transform .75s cubic-bezier(.4,0,.2,1)}
.r.show{opacity:1;transform:translateY(0)}
.rl{opacity:0;transform:translateX(-32px);transition:opacity .75s cubic-bezier(.4,0,.2,1),transform .75s cubic-bezier(.4,0,.2,1)}
.rl.show{opacity:1;transform:translateX(0)}
.rr{opacity:0;transform:translateX(32px);transition:opacity .75s cubic-bezier(.4,0,.2,1),transform .75s cubic-bezier(.4,0,.2,1)}
.rr.show{opacity:1;transform:translateX(0)}
.rs{opacity:0;transform:scale(.94);transition:opacity .75s cubic-bezier(.4,0,.2,1),transform .75s cubic-bezier(.4,0,.2,1)}
.rs.show{opacity:1;transform:scale(1)}
.rd1{transition-delay:.1s}
.rd2{transition-delay:.2s}
.rd3{transition-delay:.3s}
.rd4{transition-delay:.4s}

/* ── PAGE HERO (páginas internas) ── */
.page-hero{
  position:relative;
  height:72vh;min-height:520px;
  display:flex;flex-direction:column;justify-content:flex-end;
  overflow:hidden;
}
.page-hero__bg{
  position:absolute;inset:0;
  background:url('/nosotros/hero.jpeg') center/cover no-repeat;
  animation:heroZoom 22s ease-in-out infinite alternate;
}
.page-hero__overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(to bottom, rgba(11,15,26,.6) 0%, rgba(11,15,26,.2) 30%, rgba(11,15,26,.7) 70%, var(--c-dark) 100%),
    linear-gradient(to right, rgba(11,15,26,.55) 0%, transparent 60%);
}
.page-hero__body{
  position:relative;z-index:2;
  padding:0 5% 8vh;
}
.page-hero__breadcrumb{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Manrope',sans-serif;
  font-size:.68rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.4);
  margin-bottom:1.5rem;
}
.page-hero__breadcrumb a{color:rgba(255,255,255,.4);transition:color var(--transition)}
.page-hero__breadcrumb a:hover{color:var(--c-sky)}
.page-hero__sep{
  width:18px;height:1px;
  background:rgba(255,255,255,.25);
  flex-shrink:0;
}
.page-hero__h1{
  font-family:'Manrope',sans-serif;
  font-weight:800;font-size:clamp(3rem,6vw,5.5rem);
  line-height:1.02;color:#fff;letter-spacing:-.03em;
  margin-bottom:1.2rem;
}
.page-hero__sub{
  font-family:'Manrope',sans-serif;
  font-size:clamp(.9rem,1.6vw,1.08rem);
  font-weight:400;line-height:1.7;
  color:rgba(255,255,255,.62);
}
.page-hero__progress{position:absolute;bottom:0;left:0;right:0;height:2px;background:rgba(255,255,255,.07);z-index:3}

/* ── NOS-INTRO ── */
.nos-intro{background:var(--c-dark);padding:7rem 5%;position:relative;overflow:hidden}
.nos-intro::before{
  content:'';position:absolute;top:0;left:5%;right:5%;height:1px;
  background:linear-gradient(90deg,var(--c-blue),rgba(43,84,164,.1));
}
.nos-intro__inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:6rem;align-items:center;
  position:relative;z-index:1;
}
.nos-intro__left{display:flex;flex-direction:column;gap:1.6rem}
.nos-intro__h2{
  font-family:'Manrope',sans-serif;
  font-weight:300;font-size:clamp(1.6rem,2.8vw,2.3rem);
  line-height:1.45;color:rgba(255,255,255,.75);
  letter-spacing:-.01em;
}
.nos-intro__h2 strong{color:#fff;font-weight:700}
.nos-intro__divider{width:48px;height:1px;background:var(--c-blue)}
.nos-intro__p{font-size:.95rem;line-height:1.9;color:rgba(255,255,255,.6);text-align:justify}
.nos-intro__cta{margin-top:0}
.nos-intro__right{}
.nos-intro__visual{
  position:relative;border-radius:var(--radius);
  aspect-ratio:4/3;
  overflow:hidden;
}
.nos-intro__badge{
  position:absolute;bottom:2.5rem;right:2rem;
  background:rgba(11,15,26,.85);border:1px solid rgba(255,255,255,.12);
  padding:1.4rem 1.8rem;border-radius:var(--radius);
  text-align:center;backdrop-filter:blur(12px);
  z-index:20;
}
.nos-intro__badge-num{font-family:'Manrope',sans-serif;font-weight:800;font-size:2.5rem;color:#fff;line-height:1}
.nos-intro__badge-label{font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:.3rem}
.nos-intro__founded{
  position:absolute;top:2rem;left:2rem;
  background:rgba(20,122,193,.18);border:1px solid rgba(20,122,194,.35);
  padding:1.1rem 1.5rem;border-radius:var(--radius);
  text-align:center;backdrop-filter:blur(12px);
  z-index:20;
}
.nos-intro__founded-year{font-family:'Manrope',sans-serif;font-weight:800;font-size:1.9rem;color:var(--c-sky);line-height:1}
.nos-intro__founded-label{font-size:.65rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:.3rem}
/* fila de stats debajo del carrusel en móvil */
.nos-intro__badges-row{
  display:none;
  gap:1px;
  background:rgba(255,255,255,.07);
  border-radius:0 0 var(--radius) var(--radius);
  overflow:hidden;
}
.nos-intro__stat{
  flex:1;
  background:rgba(255,255,255,.03);
  padding:1.2rem 1rem;
  text-align:center;
  display:flex;flex-direction:column;gap:.3rem;
}
.nos-intro__stat-num{font-family:'Manrope',sans-serif;font-weight:800;font-size:1.8rem;color:#fff;line-height:1}
.nos-intro__stat-num span{color:var(--c-sky)}
.nos-intro__stat-label{font-size:.62rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35)}

/* ── ESPECIALIDADES ── */
.especialidades{background:#f7f8fa;padding:7rem 5%}
.especialidades__inner{}
.especialidades__header{text-align:center;max-width:640px;margin:0 auto 4rem}
.especialidades__sub{font-size:.95rem;line-height:1.8;color:var(--c-muted);margin-top:1rem;text-align:justify}
.especialidades__grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:2rem;
}
.espec-item{
  background:#fff;
  border:1px solid var(--c-border);
  border-radius:var(--radius);
  padding:2rem 2.2rem;
  transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition);
}
.espec-item:hover{
  box-shadow:0 16px 48px rgba(20,122,193,.16);
  transform:translateY(-4px);
  border-color:rgba(20,122,193,.3);
}
.espec-item__head{
  display:flex;align-items:center;gap:1rem;
  margin-bottom:1rem;
}
.espec-item__icon{
  width:40px;height:40px;flex-shrink:0;
  border:1.5px solid rgba(20,122,193,.4);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--c-blue);
  transition:background var(--transition),border-color var(--transition);
}
.espec-item:hover .espec-item__icon{background:rgba(20,122,193,.1);border-color:var(--c-blue)}
.espec-item__label{
  font-family:'Manrope',sans-serif;font-weight:700;
  font-size:.9rem;letter-spacing:.04em;text-transform:uppercase;
  color:#111827;flex:1;
}
.espec-item__pct{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:1.1rem;color:var(--c-blue);
}
.espec-item__bar{margin-bottom:1.2rem;height:4px}
.espec-item__desc{font-size:.88rem;line-height:1.75;color:var(--c-muted);text-align:justify}

/* ── MVV SECTION ── */
.mvv-section{background:var(--c-dark);padding:7rem 5%;position:relative}
.mvv-section::before{
  content:'';position:absolute;top:0;left:5%;right:5%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(20,122,193,.3),transparent);
}
.mvv-section__inner{position:relative;z-index:1}
.mvv-section__header{margin-bottom:3.5rem}
.mvv-section__header-top{
  display:flex;align-items:flex-end;
  justify-content:space-between;gap:2rem;flex-wrap:wrap;
}
.btn--cv{
  background:var(--c-blue);
  color:#fff;
  border:1px solid var(--c-blue);
  padding:.75rem 1.6rem;
  flex-shrink:0;
  box-shadow:0 0 0 0 rgba(20,122,193,.5);
  animation:cvPulse 2.5s ease-in-out infinite;
  transition:background var(--transition),border-color var(--transition),transform var(--transition),box-shadow var(--transition);
}
.btn--cv:hover{
  background:var(--c-navy);
  border-color:var(--c-navy);
  color:#fff;
  animation:none;
  box-shadow:0 6px 20px rgba(20,122,193,.4);
  transform:translateY(-2px);
}
.mvv-section__grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5px;
  background:rgba(255,255,255,.07);
  border-radius:var(--radius);
  overflow:hidden;
}
.mvv-full-card{
  background:rgba(255,255,255,.025);
  padding:2.8rem 2.5rem;
  display:flex;flex-direction:column;gap:1.2rem;
  position:relative;
  transition:background var(--transition);
}
.mvv-full-card:hover{background:rgba(20,122,193,.07)}
.mvv-full-card__num{
  font-family:'Manrope',sans-serif;
  font-weight:800;font-size:.7rem;
  letter-spacing:.25em;
  color:rgba(255,255,255,.15);
  position:absolute;top:2rem;right:2.2rem;
}
.mvv-full-card__icon{
  width:48px;height:48px;
  border:1.5px solid rgba(20,122,193,.4);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--c-blue);
  transition:background var(--transition),border-color var(--transition);
}
.mvv-full-card:hover .mvv-full-card__icon{background:rgba(20,122,193,.15);border-color:var(--c-sky)}
.mvv-full-card__title{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:1.25rem;letter-spacing:-.01em;
  color:#fff;
}
.mvv-full-card__text{font-size:.88rem;line-height:1.85;color:rgba(255,255,255,.62);text-align:justify}
.mvv-full-card__text strong{color:rgba(255,255,255,.7)}

/* ── CERTS FULL ── */
.certs-full{background:#f7f8fa;padding:7rem 5%}
.certs-full__inner{}
.certs-full__header{text-align:center;max-width:640px;margin:0 auto 4rem}
.certs-full__sub{font-size:.95rem;line-height:1.8;color:var(--c-muted);margin-top:1rem;text-align:justify}
.certs-full__grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
/* ── CERT CARDS (texto) ── */
.cert-card{
  background:#fff;
  border:1px solid var(--c-border);
  border-radius:var(--radius);
  padding:2.2rem 2rem;
  display:flex;flex-direction:column;gap:.9rem;
  transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition);
  position:relative;overflow:hidden;
}
.cert-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--c-blue),var(--c-sky));
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--transition);
}
.cert-card:hover::before{transform:scaleX(1)}
.cert-card:hover{
  box-shadow:0 12px 40px rgba(20,122,193,.12);
  transform:translateY(-4px);
  border-color:rgba(20,122,193,.2);
}
.cert-card__badge{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;
  background:rgba(20,122,193,.1);color:var(--c-blue);
  padding:.3rem .8rem;border-radius:3px;width:fit-content;
}
.cert-card__badge--esr{background:rgba(43,84,164,.1);color:var(--c-navy)}
.cert-card__code{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:1.6rem;letter-spacing:-.02em;color:#111827;line-height:1;
}
.cert-card__title{font-family:'Manrope',sans-serif;font-weight:700;font-size:.9rem;color:#374151;letter-spacing:.01em}
.cert-card__desc{font-size:.83rem;line-height:1.75;color:var(--c-muted);flex:1;text-align:justify}
.cert-card__footer{margin-top:auto;padding-top:.8rem;border-top:1px solid var(--c-border)}
.cert-card__tag{font-family:'Manrope',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--c-blue)}
.cert-card__tag--esr{color:var(--c-navy)}
.cert-card--esr{border-color:rgba(43,84,164,.2)}

/* cert-img: certificados con imagen real + marca de agua */
.cert-img{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  aspect-ratio:3/4;
  background:#e5e8ef;
  box-shadow:0 4px 20px rgba(0,0,0,.1);
  transition:transform var(--transition),box-shadow var(--transition);
  user-select:none;
}
.cert-img:hover{
  transform:translateY(-5px);
  box-shadow:0 16px 48px rgba(20,122,193,.18);
}
/* foto del certificado */
.cert-img > img:first-child{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  pointer-events:none;
  -webkit-user-drag:none;
}
/* marca de agua — patrón repetido en diagonal */
.cert-img__wm{
  position:absolute;inset:0;
  pointer-events:none;
  z-index:2;
  overflow:hidden;
}
.cert-img__wm-inner{
  position:absolute;inset:-60%;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.2rem;
  transform:rotate(-25deg);
  pointer-events:none;
}
.cert-img__wm-inner img{
  width:100%;
  opacity:.7;
  -webkit-user-drag:none;
  pointer-events:none;
  display:block;
}
/* overlay sutil en hover */
.cert-img::before{
  content:'';
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top, rgba(11,15,26,.7) 0%, transparent 45%);
}
/* etiqueta inferior */
.cert-img__info{
  position:absolute;bottom:0;left:0;right:0;
  z-index:3;
  padding:1.2rem 1.4rem;
  display:flex;flex-direction:column;gap:.3rem;
}
.cert-img__code{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:.95rem;letter-spacing:.03em;
  color:#fff;line-height:1;
}
.cert-img__name{
  font-size:.75rem;line-height:1.4;
  color:rgba(255,255,255,.6);
}

/* ── CLIENTES ── */
.clientes{padding:7rem 5%;position:relative;overflow:hidden}
.clientes::before{
  content:'';position:absolute;inset:0;
  background:url('/general/mapa.jpeg') center/cover no-repeat;
  filter:brightness(.35);
  z-index:0;
}
.clientes::after{
  content:'';position:absolute;inset:0;
  background:rgba(8,18,50,.3);
  z-index:1;
}
.clientes__inner,.clientes__header,.logos-car{position:relative;z-index:2}
.clientes__inner{}
.clientes__header{text-align:center;max-width:580px;margin:0 auto 4rem}
.clientes__sub{font-size:.95rem;line-height:1.8;color:rgba(255,255,255,.35);margin-top:1rem;text-align:justify}
/* ── LOGOS CARRUSEL ── */
.logos-car{
  position:relative;
  display:flex;align-items:center;gap:1.2rem;
}
.logos-car__viewport{
  flex:1;overflow:hidden;
  border-radius:var(--radius);
}
.logos-car__track{
  display:flex;
  transition:transform .45s cubic-bezier(.4,0,.2,1);
}
.logos-car__item{
  flex:0 0 calc(100% / 5);
  display:flex;align-items:center;justify-content:center;
  padding:2rem 1.5rem;
  background:rgba(255,255,255,.04);
  border-right:1px solid rgba(255,255,255,.07);
  overflow:hidden;
  transition:background var(--transition);
}
.logos-car__item:last-child{border-right:none}
.logos-car__item:hover{background:rgba(255,255,255,.09)}
.logos-car__item img{
  width:100%;max-width:300px;height:160px;
  object-fit:contain;
  display:block;
  transition:transform .4s cubic-bezier(.4,0,.2,1);
}
.logos-car__item:hover img{transform:scale(1.12)}
.logos-car__btn{
  flex-shrink:0;
  width:46px;height:46px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:50%;
  color:rgba(255,255,255,.7);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition);
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}
.logos-car__btn:hover{
  background:rgba(20,122,193,.5);
  border-color:var(--c-blue);
  color:#fff;
  transform:scale(1.08);
}

/* ── CAROUSEL ── */
.carousel{
  position:absolute;inset:0;
}
.carousel__track{
  width:100%;height:100%;
  position:relative;
}
.carousel__slide{
  position:absolute;inset:0;
  opacity:0;
  transition:opacity .7s cubic-bezier(.4,0,.2,1);
  z-index:0;
}
.carousel__slide.active{opacity:1;z-index:1}
.carousel__slide img{
  width:100%;height:100%;
  object-fit:cover;
  filter:brightness(.82);
}
.carousel__btn{
  position:absolute;top:50%;transform:translateY(-50%);
  z-index:15;
  width:44px;height:44px;
  background:rgba(11,15,26,.65);
  border:1px solid rgba(255,255,255,.18);
  border-radius:50%;
  color:#fff;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--transition),border-color var(--transition),transform var(--transition);
  backdrop-filter:blur(8px);
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
}
.carousel__btn:hover{
  background:rgba(20,122,193,.75);
  border-color:rgba(20,122,193,.7);
  transform:translateY(-50%) scale(1.08);
}
.carousel__btn--prev{left:1rem}
.carousel__btn--next{right:1rem}
.carousel__dots{
  position:absolute;bottom:4.5rem;left:50%;transform:translateX(-50%);
  z-index:15;
  display:flex;gap:.6rem;align-items:center;
}
.carousel__dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.35);
  border:none;cursor:pointer;padding:0;
  transition:background var(--transition),width var(--transition);
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
  min-width:8px;
}
.carousel__dot.active{
  background:#fff;
  width:22px;border-radius:4px;
}

/* ── LIGHTBOX ── */
.lb{
  position:fixed;inset:0;z-index:900;
  display:flex;align-items:center;justify-content:center;
  padding:1.5rem;
  opacity:0;pointer-events:none;
  transition:opacity .3s cubic-bezier(.4,0,.2,1);
}
.lb.open{opacity:1;pointer-events:all}
.lb__backdrop{
  position:absolute;inset:0;
  background:rgba(5,8,18,.92);
  backdrop-filter:blur(10px);
  cursor:pointer;
}
.lb__box{
  position:relative;z-index:1;
  max-width:min(520px, 92vw);
  width:100%;
  transform:scale(.93) translateY(12px);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.lb.open .lb__box{transform:scale(1) translateY(0)}
.lb__close{
  position:absolute;top:-14px;right:-14px;z-index:10;
  width:38px;height:38px;
  background:var(--c-dark);border:1px solid rgba(255,255,255,.18);
  border-radius:50%;color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--transition),transform var(--transition);
}
.lb__close:hover{background:var(--c-blue);transform:scale(1.1)}
.lb__img-wrap{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  line-height:0;
  box-shadow:0 32px 80px rgba(0,0,0,.6);
}
.lb__img-wrap img:first-child{
  width:100%;height:auto;display:block;
  pointer-events:none;
  -webkit-user-drag:none;
}
.lb__wm{
  position:absolute;inset:0;
  overflow:hidden;
  pointer-events:none;
}
.lb__wm-inner{
  position:absolute;inset:-60%;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.4rem;
  transform:rotate(-25deg);
  pointer-events:none;
}
.lb__wm-inner img{
  width:100%;
  opacity:.7;
  pointer-events:none;
  -webkit-user-drag:none;
  display:block;
}
.lb__caption{
  font-family:'Manrope',sans-serif;
  font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.45);
  text-align:center;
  padding:.9rem 0 0;
}

/* cursor pointer en las cards de cert */
.cert-img{cursor:zoom-in}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .services__grid{grid-template-columns:1fr 1fr}
  .hero__body{grid-template-columns:1fr 300px;gap:40px}
  .intro__certs-grid{grid-template-columns:repeat(3,1fr)}
  .nos-intro__inner{gap:4rem}
  .certs-full__grid{grid-template-columns:repeat(3,1fr)}
  .logos-car__item{flex:0 0 calc(100% / 3)}
}
@media(max-width:900px){
  .hero__body{grid-template-columns:1fr;gap:0;padding:0 6% 8vh}
  .hero__panel{display:flex;margin-top:1.5rem}
  .hero__h1{font-size:clamp(2.4rem,8vw,4rem)}
  .hero__stats{gap:24px}
  .hero__scroll{display:none}
  .about{grid-template-columns:1fr}
  .about__visual{min-height:400px}
  .about__badge{bottom:1.5rem;right:1.5rem}
  .contact{grid-template-columns:1fr}
  .contact__visual{min-height:320px}
  .intro{grid-template-columns:1fr;gap:3rem;padding:5rem 5%}
  .stats-row{grid-template-columns:1fr 1fr}
  .stat-cell{border-bottom:1px solid rgba(255,255,255,.1)}
  .stat-cell:nth-child(2n){border-right:none}
  .projects__grid{grid-template-columns:1fr 1fr}
  .services{padding:5rem 5%}
  /* nosotros */
  .page-hero{height:auto;min-height:520px;padding-bottom:5vh}
  .nos-intro__inner{grid-template-columns:1fr;gap:3rem}
  .nos-intro__visual{aspect-ratio:16/9}
  .especialidades__grid{grid-template-columns:1fr}
  .mvv-section__grid{grid-template-columns:1fr;gap:1px}
  .certs-full__grid{grid-template-columns:repeat(2,1fr)}
  .logos-car__item{flex:0 0 calc(100% / 3)}
}
@media(max-width:720px){
  .hero__bg{background:url('/index/hero_movil.jpeg') center/cover no-repeat;animation:heroZoom 18s ease-in-out infinite alternate}
  .eyebrow__break{display:block;margin-top:4px}
  .nav{padding:0 4%}
  .nav__links{display:none}
  .nav__burger{display:flex}
  .hero__body{padding:0 4% 10vh}
  .hero__h1{font-size:clamp(2.2rem,9vw,3.2rem)}
  .hero__stats{flex-wrap:wrap;gap:16px 28px}
  .hero__lead{font-size:.85rem}
  .services__grid{grid-template-columns:1fr}
  .svc{min-height:300px}
  .projects__grid{grid-template-columns:1fr}
  .form__grid{grid-template-columns:1fr}
  .field--full{grid-column:span 1}
  footer{grid-template-columns:1fr;text-align:center}
  .footer__brand{justify-self:center}
  .footer__right{align-items:center}
  .footer__links{flex-wrap:wrap;justify-content:center;gap:1.2rem}
  .intro{padding:4rem 4%}
  .intro__certs-grid{grid-template-columns:repeat(2,1fr)}
  .intro__certs-grid .cert:nth-child(3n){border-right:1px solid rgba(255,255,255,.07)}
  .intro__certs-grid .cert:nth-child(2n){border-right:none}
  .about__content{padding:3.5rem 4%}
  .contact__form-side{padding:3.5rem 4%}
  .services{padding:4rem 4%}
  .projects{padding:4rem 4%}
  .about__badge{bottom:1rem;right:1rem;padding:1rem 1.4rem}
  .about__badge-num{font-size:2rem}
  .hero__watermark{display:none}
  /* fix franja negra: desactiva translateX en móvil */
  .rr{transform:translateY(28px)}
  .rr.show{transform:translateY(0)}
  .rl{transform:translateY(28px)}
  .rl.show{transform:translateY(0)}
  /* nosotros */
  .page-hero__h1{font-size:clamp(2.5rem,9vw,4rem)}
  .page-hero__sub br{display:none}
  .page-hero{height:auto;min-height:600px}
  .page-hero__body{padding-bottom:6vh}
  .nos-intro{padding:5rem 4%}
  .especialidades{padding:5rem 4%}
  .mvv-section{padding:5rem 4%}
  .certs-full{padding:5rem 4%}
  .certs-full__grid{grid-template-columns:1fr 1fr}
  .clientes{padding:5rem 4%}
  .logos-car__item{flex:0 0 100%}
  /* carrusel móvil: imagen más alta, badges salen de encima */
  .nos-intro__visual{aspect-ratio:3/4;border-radius:var(--radius) var(--radius) 0 0}
  .carousel{border-radius:var(--radius) var(--radius) 0 0}
  .nos-intro__badge{display:none}
  .nos-intro__founded{display:none}
  .nos-intro__badges-row{display:flex}
  /* flechas más grandes y fáciles de tocar */
  .carousel__btn{width:50px;height:50px}
  .carousel__btn--prev{left:.5rem}
  .carousel__btn--next{right:.5rem}
  .carousel__dots{bottom:1rem;gap:.8rem}
  .carousel__dot{width:10px;height:10px;min-width:10px}
  .carousel__dot.active{width:26px}
}
@media(max-width:480px){
  .hero__h1{font-size:clamp(2rem,10vw,2.8rem)}
  .hero__eyebrow{font-size:.65rem}
  .hero__stats{gap:12px 20px}
  .hstat__num{font-size:1.35rem}
  .btn{font-size:.72rem;padding:.65rem 1.2rem}
  .section-header{flex-direction:column;align-items:flex-start}
  .stats-row{grid-template-columns:1fr 1fr}
  .stat-cell{padding:2rem 1rem}
  .contact__text{padding:1.5rem 2rem}
  .about__badge{display:none}
  .skill__label{width:100px;font-size:.65rem}
  /* nosotros */
  .page-hero__h1{font-size:clamp(2.2rem,11vw,3rem)}
  .certs-full__grid{grid-template-columns:1fr}
  .logos-car__item{flex:0 0 100%}
  .mvv-full-card{padding:2rem 1.6rem}
  .espec-item{padding:1.6rem}
}

/* ══════════════════════════════════════
   MEJORAS INDEX — NUEVOS ESTILOS
══════════════════════════════════════ */

/* ── About: badge "Fundada 2013" ── */
.about__founded{
  position:absolute;top:2rem;left:2rem;
  background:rgba(20,122,193,.18);
  border:1px solid rgba(20,122,193,.35);
  padding:1rem 1.4rem;border-radius:var(--radius);
  text-align:center;backdrop-filter:blur(12px);
}
.about__founded-year{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:1.8rem;color:var(--c-sky);line-height:1;
}
.about__founded-label{
  font-size:.62rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.45);margin-top:.3rem;
}

/* ── About: mvv-cards con ícono ── */
.mvv-card__icon{
  flex-shrink:0;
  width:32px;height:32px;
  border:1.5px solid rgba(20,122,193,.4);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--c-blue);margin-bottom:.3rem;
  transition:background var(--transition),border-color var(--transition);
}
.mvv-card:hover .mvv-card__icon{background:rgba(20,122,193,.12);border-color:var(--c-blue)}
/* redispone la card para que el ícono vaya arriba */
.mvv-card{flex-direction:column;gap:.5rem}
.mvv-card__label{margin-top:0}

/* ── Stats Row: ícono ── */
.stat-cell__icon{
  width:44px;height:44px;
  border:1.5px solid rgba(255,255,255,.18);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.6);
  margin:0 auto 1rem;
  transition:border-color var(--transition),color var(--transition);
}
.stat-cell:hover .stat-cell__icon{border-color:rgba(255,255,255,.5);color:#fff}
/* patrón de puntos decorativo en stats-row */
.stats-row{
  background-image:radial-gradient(rgba(255,255,255,.06) 1px, transparent 1px);
  background-size:24px 24px;
}

/* ── Servicios: tag de categoría ── */
.svc__tag{
  position:absolute;top:1.2rem;left:1.2rem;z-index:5;
  font-family:'Manrope',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  background:rgba(20,122,193,.75);color:#fff;
  padding:.3rem .8rem;border-radius:3px;
  backdrop-filter:blur(6px);
  transition:background var(--transition);
}
.svc:hover .svc__tag{background:rgba(20,122,193,.95)}

/* ── Servicios: número grande decorativo ── */
.svc__bg-num{
  position:absolute;top:.8rem;right:1.2rem;z-index:5;
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:5rem;line-height:1;letter-spacing:-.04em;
  color:rgba(255,255,255,.0);
  transition:color .5s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
}
.svc:hover .svc__bg-num{color:rgba(255,255,255,.07)}

/* ── Servicios: bullets de sub-servicios ── */
.svc__bullets{
  list-style:none;margin-top:.6rem;
  display:flex;flex-direction:column;gap:.35rem;
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .4s;
  opacity:0;
}
.svc:hover .svc__bullets{max-height:120px;opacity:1}
.svc__bullets li{
  font-size:.78rem;line-height:1.5;color:rgba(255,255,255,.5);
  padding-left:1rem;position:relative;
}
.svc__bullets li::before{
  content:'·';position:absolute;left:0;
  color:var(--c-sky);font-weight:700;
}

/* ── Servicios: link mejorado ── */
.svc__link{
  margin-top:1.2rem;
  background:rgba(20,122,193,.2);
  border:1px solid rgba(20,122,193,.35);
  padding:.45rem 1rem;border-radius:4px;
  align-self:flex-start;
  transition:background var(--transition),border-color var(--transition),color var(--transition),gap var(--transition);
}
.svc__link:hover{
  background:rgba(20,122,193,.55);
  border-color:var(--c-blue);
  color:#fff;gap:10px;
}

/* ── Proceso de Trabajo ── */
.process{
  background:var(--c-dark);
  padding:7rem 5%;
  position:relative;overflow:hidden;
}
.process::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(20,122,193,.4),transparent);
}
.process::after{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(20,122,193,.04) 1px,transparent 1px);
  background-size:32px 32px;pointer-events:none;
}
.process__inner{position:relative;z-index:1}
.process__header{text-align:center;max-width:640px;margin:0 auto 4.5rem}
.process__sub{
  font-size:.95rem;line-height:1.8;
  color:rgba(255,255,255,.4);
  margin-top:1rem;text-align:justify;
}
.process__steps{
  display:grid;
  grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;
  align-items:start;gap:0;
}
.process__connector{
  align-self:center;margin-top:-2.5rem;
  width:100%;height:1px;
  background:linear-gradient(90deg,rgba(20,122,193,.4),rgba(20,122,193,.15));
  min-width:20px;
}
.process__step{
  display:flex;flex-direction:column;
  align-items:center;text-align:center;
  padding:0 1.5rem;
}
.process__step-num{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:2.8rem;line-height:1;letter-spacing:-.04em;
  color:rgba(20,122,193,.6);margin-bottom:1.2rem;
  transition:color var(--transition);
}
.process__step:hover .process__step-num{color:rgba(20,122,193,.9)}
.process__step-icon{
  width:56px;height:56px;
  border:1.5px solid rgba(20,122,193,.35);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--c-blue);margin-bottom:1.3rem;
  background:rgba(20,122,193,.05);
  transition:background var(--transition),border-color var(--transition),transform var(--transition);
}
.process__step:hover .process__step-icon{
  background:rgba(20,122,193,.18);
  border-color:var(--c-blue);
  transform:translateY(-4px);
}
.process__step-title{
  font-family:'Manrope',sans-serif;font-weight:700;
  font-size:1rem;letter-spacing:.01em;
  color:#fff;margin-bottom:.7rem;line-height:1.2;
}
.process__step-desc{
  font-size:.83rem;line-height:1.75;
  color:rgba(255,255,255,.4);
}

/* ── Proyectos: layout asimétrico ── */
.projects__grid--asym{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:1.5rem;
  margin-top:3rem;
  align-items:stretch;
}
.projects__stack{
  display:flex;flex-direction:column;
  gap:1.5rem;
}
/* tarjeta grande */
.proj--featured{
  min-height:560px;
  aspect-ratio:auto;
}
.proj--featured .proj__name{
  font-size:1.3rem;
}
/* número de proyecto decorativo */
.proj__bg-num{
  position:absolute;top:.8rem;right:1.2rem;z-index:5;
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:5rem;line-height:1;letter-spacing:-.04em;
  color:rgba(255,255,255,.0);
  transition:color .5s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
}
.proj:hover .proj__bg-num{color:rgba(255,255,255,.06)}
/* categoría tag */
.proj__category{
  font-family:'Manrope',sans-serif;
  font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--c-blue);margin-bottom:.3rem;
  display:inline-block;
  padding:.2rem .6rem;
  background:rgba(20,122,193,.25);
  border-radius:3px;
  width:fit-content;
}
/* línea azul decorativa izquierda */
.proj::after{
  content:'';
  position:absolute;left:0;bottom:0;top:0;width:3px;
  background:linear-gradient(to top,var(--c-blue),transparent);
  opacity:0;
  transition:opacity var(--transition);
}
.proj:hover::after{opacity:1}
/* cliente */
.proj__client{
  font-size:.75rem;color:rgba(255,255,255,.35);
  margin-top:.25rem;
}
/* botón ver detalle */
.proj__cta{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:.9rem;
  font-family:'Manrope',sans-serif;font-size:.7rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:#fff;
  background:rgba(20,122,193,.3);
  border:1px solid rgba(20,122,193,.4);
  padding:.4rem .9rem;border-radius:3px;
  width:fit-content;
  opacity:0;transform:translateY(8px);
  transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s,background var(--transition),gap var(--transition);
}
.proj:hover .proj__cta{opacity:1;transform:translateY(0)}
.proj__cta:hover{background:rgba(20,122,193,.6);gap:10px}
.proj__cta svg{transition:transform var(--transition)}
.proj__cta:hover svg{transform:translateX(3px)}

/* mejora overlay proyectos */
.proj__info{
  background:linear-gradient(to top,rgba(11,15,26,.98) 0%,rgba(11,15,26,.55) 40%,transparent 72%);
  padding:2.2rem 1.8rem;
}

/* ── Responsive nuevos estilos ── */
@media(max-width:1100px){
  .process__steps{
    grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;
  }
  .process__step-desc{font-size:.8rem}
}
@media(max-width:900px){
  .projects__grid--asym{grid-template-columns:1fr 1fr}
  .projects__stack{flex-direction:column}
  .proj--featured{min-height:340px}
  /* proceso: 2x2 sin conectores */
  .process__steps{grid-template-columns:1fr 1fr;gap:2rem}
  .process__connector{display:none}
  .process{padding:5rem 5%}
  .process__header{margin-bottom:3rem}
  .about__founded{top:1.5rem;left:1.5rem}
}
@media(max-width:720px){
  .projects__grid--asym{grid-template-columns:1fr}
  .projects__stack{flex-direction:column}
  .proj--featured{min-height:280px}
  .process{padding:5rem 4%}
  .process__steps{grid-template-columns:1fr 1fr;gap:1.5rem}
  .about__founded{top:1rem;left:1rem;padding:.8rem 1.1rem}
  .about__founded-year{font-size:1.5rem}
  .stat-cell__icon{width:36px;height:36px;margin-bottom:.75rem}
  .svc__bullets{display:none}
  .proj__cta{opacity:1;transform:translateY(0)}
}
@media(max-width:480px){
  .process__steps{grid-template-columns:1fr}
  .process__step{padding:0}
  .proj__cta{opacity:1;transform:translateY(0)}
  .about__founded{display:none}
}

/* ══════════════════════════════════════
   MEJORAS NOSOTROS.PHP
══════════════════════════════════════ */

/* ── Page Hero stats flotantes ── */
.page-hero__stats{
  display:flex;align-items:center;gap:0;
  margin-top:2.5rem;
  background:rgba(11,15,26,.5);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);
  overflow:hidden;
  backdrop-filter:blur(12px);
  width:fit-content;
}
.page-hero__stat{
  padding:1rem 1.8rem;
  display:flex;flex-direction:column;gap:.3rem;
}
.page-hero__stat-num{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:1.4rem;color:#fff;line-height:1;
  letter-spacing:-.02em;
}
.page-hero__stat-label{
  font-size:.6rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.4);
}
.page-hero__stat-sep{
  width:1px;height:40px;
  background:rgba(255,255,255,.1);
  flex-shrink:0;
}

/* ── Quiénes Somos: lista de valores ── */
.nos-intro__values{
  list-style:none;
  display:flex;flex-direction:column;gap:.75rem;
  margin-top:.4rem;
}
.nos-intro__values li{
  display:flex;align-items:flex-start;gap:.75rem;
  font-size:.9rem;line-height:1.6;
  color:rgba(255,255,255,.5);
}
.nos-intro__values li svg{
  flex-shrink:0;margin-top:2px;
  color:var(--c-blue);
}

/* ── Quiénes Somos: botones alineados ── */
.nos-intro__actions{
  display:flex;align-items:center;gap:1rem;
  flex-wrap:wrap;margin-top:.8rem;
}

/* ── Clientes: strip de confianza ── */
.clientes__trust{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:0;
  margin-top:3rem;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:2rem;
}
.clientes__trust-item{
  display:flex;align-items:center;gap:.6rem;
  font-family:'Manrope',sans-serif;
  font-size:.72rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.4);
  padding:0 2rem;
}
.clientes__trust-item svg{color:var(--c-sky);flex-shrink:0}
.clientes__trust-sep{
  width:1px;height:20px;
  background:rgba(255,255,255,.1);
  flex-shrink:0;
}

/* ── Responsive nosotros ── */
@media(max-width:900px){
  .page-hero__stats{gap:0}
  .page-hero__stat{padding:.8rem 1.2rem}
  .page-hero__stat-num{font-size:1.2rem}
  .clientes__trust-sep{display:none}
  .clientes__trust-item{padding:.4rem 1rem}
  .clientes__trust{gap:.5rem}
}
@media(max-width:720px){
  .page-hero__stats{width:100%;justify-content:space-between;border-radius:0}
  .page-hero__stat{padding:.7rem .8rem;flex:1;align-items:center;text-align:center}
  .page-hero__stat-sep{height:28px}
  .nos-intro__actions{flex-direction:column;align-items:flex-start}
  .clientes__trust{flex-direction:column;align-items:flex-start;padding-top:1.5rem;gap:.75rem}
  .clientes__trust-sep{display:none}
  .clientes__trust-item{padding:0}
}
@media(max-width:480px){
  .page-hero__stats{flex-wrap:wrap}
  .page-hero__stat-sep{display:none}
  .page-hero__stat{flex:0 0 50%;border-bottom:1px solid rgba(255,255,255,.07)}
}

/* ══════════════════════════════════════
   SERVICIOS.PHP
══════════════════════════════════════ */

/* ── Page Hero variante Servicios ── */
.page-hero__bg--svc{
  background:url('/servicios/hero.jpg') center 0%/cover no-repeat;
}
@media(max-width:720px){
  .page-hero__bg--svc{
    background:url('/servicios/hero_movil.jpeg') center center/cover no-repeat;
  }
}

/* ── Intro Servicios ── */
.svc-intro{
  background:var(--c-dark);
  padding:7rem 5%;
  position:relative;overflow:hidden;
}
.svc-intro::before{
  content:'';position:absolute;top:0;left:5%;right:5%;height:1px;
  background:linear-gradient(90deg,var(--c-blue),rgba(43,84,164,.1));
}
.svc-intro__inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:6rem;align-items:center;
  position:relative;z-index:1;
}
.svc-intro__left{display:flex;flex-direction:column;gap:1.6rem}
.svc-intro__h2{
  font-family:'Manrope',sans-serif;
  font-weight:300;font-size:clamp(1.6rem,2.8vw,2.3rem);
  line-height:1.45;color:rgba(255,255,255,.75);
  letter-spacing:-.01em;
}
.svc-intro__h2 strong{color:#fff;font-weight:700}
.svc-intro__divider{width:48px;height:1px;background:var(--c-blue)}
.svc-intro__p{font-size:.95rem;line-height:1.9;color:rgba(255,255,255,.45);text-align:justify}
.svc-intro__values{
  list-style:none;display:flex;flex-direction:column;gap:.75rem;margin-top:.4rem;
}
.svc-intro__values li{
  display:flex;align-items:flex-start;gap:.75rem;
  font-size:.9rem;line-height:1.6;color:rgba(255,255,255,.5);
}
.svc-intro__values li svg{flex-shrink:0;margin-top:2px;color:var(--c-blue)}
.svc-intro__actions{
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:.8rem;
}

/* Grid de mini-cards 3×2 (derecha) */
.svc-intro__card-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;
  gap:1px;
  background:rgba(255,255,255,.07);
  border-radius:var(--radius);
  overflow:hidden;
}
.svc-intro__mini{
  background:rgba(255,255,255,.025);
  padding:1.8rem 1.5rem;
  display:flex;flex-direction:column;gap:.55rem;
  position:relative;
  transition:background var(--transition);
}
.svc-intro__mini:hover{background:rgba(20,122,193,.07)}
.svc-intro__mini-icon{
  width:36px;height:36px;flex-shrink:0;
  border:1.5px solid rgba(20,122,193,.4);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--c-blue);margin-bottom:.2rem;
  transition:background var(--transition),border-color var(--transition);
}
.svc-intro__mini:hover .svc-intro__mini-icon{
  background:rgba(20,122,193,.15);border-color:var(--c-blue);
}
.svc-intro__mini-num{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:.6rem;letter-spacing:.25em;
  color:rgba(255,255,255,.15);
  position:absolute;top:1.2rem;right:1.3rem;
}
.svc-intro__mini-title{
  font-family:'Manrope',sans-serif;font-weight:700;
  font-size:.88rem;letter-spacing:.02em;
  color:#fff;
}
.svc-intro__mini-desc{
  font-size:.78rem;line-height:1.6;
  color:rgba(255,255,255,.4);
}

/* ── Servicios Detallados ── */
.svc-detail{background:#f7f8fa;padding:7rem 5%;position:relative}
.svc-detail::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--c-blue),transparent);
}
.svc-detail__inner{}

/* Header centrado */
.svc-detail__header{
  text-align:center;max-width:700px;margin:0 auto 4rem;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
}
.svc-detail__sub{
  font-size:.95rem;line-height:1.8;color:var(--c-muted);
  max-width:540px;
}

/* Grid mosaico asimétrico */
.svc-grid{
  display:grid;
  grid-template-columns:2fr 1fr;
  grid-template-rows:auto auto auto;
  grid-template-areas:
    "civil    procura"
    "inst     mec"
    "elec     mant";
  gap:1.5px;
  background:var(--c-border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:0 4px 32px rgba(0,0,0,.08);
}

/* ── Item base ── */
.svc-item{
  background:#fff;
  display:flex;flex-direction:column;
  position:relative;
  transition:background var(--transition);
  overflow:hidden;
}
.svc-item:hover{background:#f4f8fd}

/* línea azul top en hover */
.svc-item::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--c-blue),var(--c-sky));
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--transition);z-index:5;
}
.svc-item:hover::before{transform:scaleX(1)}

/* imagen en cards compactas */
.svc-item__img{
  position:relative;overflow:hidden;height:210px;flex-shrink:0;
}
.svc-item__img img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.8);
  transition:transform .7s cubic-bezier(.4,0,.2,1),filter .5s;
}
.svc-item:hover .svc-item__img img{transform:scale(1.05);filter:brightness(.85)}
.svc-item__img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 45%,rgba(11,15,26,.75) 100%);
  pointer-events:none;
}
.svc-item__num{
  position:absolute;top:.8rem;right:1rem;z-index:2;
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:3.2rem;line-height:1;letter-spacing:-.05em;
  color:rgba(255,255,255,.14);pointer-events:none;
  transition:color .5s;
}
.svc-item:hover .svc-item__num{color:rgba(255,255,255,.28)}
.svc-item__tag{
  position:absolute;bottom:.85rem;left:.85rem;z-index:2;
  font-family:'Manrope',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  background:rgba(20,122,193,.8);color:#fff;
  padding:.25rem .65rem;border-radius:3px;
  backdrop-filter:blur(6px);
}

/* cuerpo texto compacto */
.svc-item__body{
  padding:1.6rem 1.8rem;
  display:flex;flex-direction:column;gap:.85rem;
  flex:1;
}
.svc-item__icon{
  width:38px;height:38px;flex-shrink:0;
  border:1.5px solid rgba(20,122,193,.3);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--c-blue);
  transition:background var(--transition),border-color var(--transition);
}
.svc-item:hover .svc-item__icon{background:rgba(20,122,193,.1);border-color:var(--c-blue)}
.svc-item__title{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:1.1rem;letter-spacing:-.02em;color:#111827;line-height:1.2;
}
.svc-item__desc{font-size:.84rem;line-height:1.75;color:var(--c-muted)}
.svc-item__list{
  list-style:none;display:flex;flex-direction:column;gap:.4rem;
}
.svc-item__list li{
  font-size:.8rem;line-height:1.5;color:#374151;
  padding-left:1rem;position:relative;
}
.svc-item__list li::before{
  content:'·';position:absolute;left:0;
  color:var(--c-blue);font-weight:700;font-size:1.1rem;line-height:1.2;
}
.svc-item__cta{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:auto;padding-top:.8rem;
  border-top:1px solid var(--c-border);
  font-family:'Manrope',sans-serif;font-size:.7rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--c-blue);
  transition:color var(--transition),gap var(--transition);
  width:fit-content;
}
.svc-item:hover .svc-item__cta{color:var(--c-navy);gap:10px}
.svc-item__cta svg{transition:transform var(--transition)}
.svc-item:hover .svc-item__cta svg{transform:translateX(3px)}

/* ── Cards HERO (Obra Civil y Mecánica) — imagen full + texto sobre foto ── */
.svc-item--hero{
  min-height:420px;
  position:relative;
}
.svc-item--hero .svc-item__bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;filter:brightness(.9);
  transition:transform .8s cubic-bezier(.4,0,.2,1),filter .6s;
}
.svc-item--hero:hover .svc-item__bg{transform:scale(1.04);filter:brightness(.65)}
.svc-item--hero .svc-item__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(11,15,26,.95) 0%,rgba(11,15,26,.4) 55%,transparent 100%);
  transition:background var(--transition);
}
.svc-item--hero:hover .svc-item__overlay{
  background:linear-gradient(to top,rgba(11,15,26,.98) 0%,rgba(11,15,26,.55) 55%,transparent 100%);
}
.svc-item--hero .svc-item__over-body{
  position:absolute;bottom:0;left:0;right:0;
  padding:2.2rem 2.4rem;
  display:flex;flex-direction:column;gap:.9rem;
  z-index:2;
}
/* tag y número en hero */
.svc-item--hero .svc-item__tag{
  position:static;backdrop-filter:none;
  align-self:flex-start;
}
.svc-item--hero .svc-item__num{
  position:absolute;top:1.2rem;right:1.4rem;
  font-size:5rem;color:rgba(255,255,255,.1);
}
.svc-item--hero:hover .svc-item__num{color:rgba(20,122,193,.25)}
/* textos sobre foto */
.svc-item--hero .svc-item__title{color:#fff;font-size:1.5rem}
.svc-item--hero .svc-item__desc{color:rgba(255,255,255,.6);font-size:.88rem}
.svc-item--hero .svc-item__list li{color:rgba(255,255,255,.55)}
.svc-item--hero .svc-item__list li::before{color:var(--c-sky)}
.svc-item--hero .svc-item__cta{
  color:var(--c-sky);border-top-color:rgba(255,255,255,.15);
}
.svc-item--hero:hover .svc-item__cta{color:#fff;gap:10px}

/* ── CTA Band ── */
.svc-cta-band{
  background:var(--c-dark);
  padding:7rem 5%;
  position:relative;overflow:hidden;
}
.svc-cta-band::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--c-blue),var(--c-sky),transparent);
}
/* glow radial de fondo */
.svc-cta-band::after{
  content:'';position:absolute;
  width:700px;height:700px;
  top:50%;left:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(20,122,193,.12) 0%,transparent 70%);
  pointer-events:none;
}
/* patrón de puntos decorativo */
.svc-cta-band__dots{
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(20,122,193,.07) 1px,transparent 1px);
  background-size:24px 24px;pointer-events:none;
}
.svc-cta-band__inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:4rem;flex-wrap:wrap;
  position:relative;z-index:1;
}
.svc-cta-band__left{display:flex;flex-direction:column;gap:1rem}
.svc-cta-band__tag{
  font-family:'Manrope',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--c-sky);
  display:flex;align-items:center;gap:.6rem;
}
.svc-cta-band__tag::before{
  content:'';display:block;width:28px;height:1px;background:var(--c-blue);
}
.svc-cta-band__title{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:clamp(2.2rem,3.8vw,3.2rem);
  color:#fff;letter-spacing:-.03em;line-height:1.15;
}
.svc-cta-band__ghost{
  color:transparent;
  -webkit-text-stroke:1.5px rgba(255,255,255,.3);
}
.svc-cta-band__sub{
  font-size:.92rem;line-height:1.75;color:rgba(255,255,255,.35);
  max-width:440px;
}
.svc-cta-band__actions{
  display:flex;flex-direction:column;align-items:stretch;gap:1rem;flex-shrink:0;min-width:220px;
}

/* ── Responsive Servicios ── */
@media(max-width:1100px){
  .svc-intro__inner{gap:4rem}
  .svc-intro__card-grid{grid-template-columns:1fr 1fr}
  .svc-item--hero{min-height:360px}
}
@media(max-width:900px){
  .svc-intro__inner{grid-template-columns:1fr;gap:3rem}
  .svc-intro__card-grid{grid-template-columns:repeat(3,1fr)}
  .svc-cta-band__inner{flex-direction:column;align-items:flex-start;gap:3rem}
  .svc-intro{padding:5rem 5%}
  .svc-detail{padding:5rem 5%}
  .svc-cta-band{padding:5rem 5%}
  .svc-grid{grid-template-columns:1fr 1fr;grid-template-areas:"civil civil""procura inst""mec mec""elec mant"}
  .svc-item--hero{min-height:320px}
}
@media(max-width:720px){
  .svc-intro{padding:5rem 4%}
  .svc-detail{padding:4rem 4%}
  .svc-cta-band{padding:4rem 4%}
  .svc-intro__card-grid{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr;grid-template-areas:"civil""procura""inst""mec""elec""mant"}
  /* cards hero se comportan igual que las normales en móvil */
  .svc-item--hero{min-height:0;position:relative;flex-direction:column}
  .svc-item--hero .svc-item__bg{
    position:relative;inset:auto;width:100%;height:210px;
    object-fit:cover;filter:brightness(.7);flex-shrink:0;
  }
  .svc-item--hero .svc-item__overlay{display:none}
  .svc-item--hero .svc-item__over-body{
    position:relative;inset:auto;
    padding:1.6rem 1.8rem;
    background:#fff;
  }
  .svc-item--hero .svc-item__title{color:#111827;font-size:1.1rem}
  .svc-item--hero .svc-item__desc{color:var(--c-muted)}
  .svc-item--hero .svc-item__list li{color:#374151}
  .svc-item--hero .svc-item__list li::before{color:var(--c-blue)}
  .svc-item--hero .svc-item__cta{color:var(--c-blue);border-top-color:var(--c-border)}
  .svc-item--hero .svc-item__num{top:.8rem;right:1rem;font-size:3.2rem;color:rgba(255,255,255,.14)}
  .svc-item--hero .svc-item__tag{position:absolute;bottom:.85rem;left:.85rem}
  .svc-cta-band__actions{flex-direction:column;align-items:stretch;width:100%}
  .svc-cta-band__actions .btn{width:100%;justify-content:center}
}
@media(max-width:480px){
  .svc-intro__card-grid{grid-template-columns:1fr}
  .svc-item__body{padding:1.4rem 1.3rem}
  .svc-item--hero .svc-item__over-body{padding:1.4rem 1.3rem}
}

/* ══════════════════════════════════════
   ALIANZAS.PHP
══════════════════════════════════════ */

.page-hero__bg--alianzas{
  background:url('/alianzas/proyectos/PROY-PEP-CAMINOS-PUENTES/7.jpeg') center 20%/cover no-repeat;
}
@media(max-width:720px){
  .page-hero__bg--alianzas{background-position:center center}
}

/* ── Portafolio ── */
.ali-port{background:#f7f8fa;padding:7rem 5%;position:relative}
.ali-port::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--c-blue),transparent);
}
.ali-port__inner{}
.ali-port__header{
  text-align:center;max-width:640px;margin:0 auto 2.5rem;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
}
.ali-port__sub{font-size:.95rem;line-height:1.8;color:var(--c-muted)}

/* filtros */
.ali-filters{
  display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;
  justify-content:center;margin-bottom:3rem;
}
.ali-filter{
  font-family:'Manrope',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.45rem 1.1rem;border-radius:3px;
  border:1.5px solid var(--c-border);
  background:#fff;color:var(--c-muted);
  cursor:pointer;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  transition:background var(--transition),color var(--transition),border-color var(--transition);
}
.ali-filter:hover{border-color:var(--c-blue);color:var(--c-blue)}
.ali-filter.active{background:var(--c-blue);border-color:var(--c-blue);color:#fff}

/* grid proyectos */
.ali-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.5rem;
}
.ali-item{
  border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--c-border);
  background:#fff;
  display:flex;flex-direction:column;
  cursor:pointer;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition);
  position:relative;
}
.ali-item:hover{
  box-shadow:0 16px 40px rgba(20,122,193,.12);
  transform:translateY(-4px);
  border-color:rgba(20,122,193,.2);
}
.ali-item::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--c-blue),var(--c-sky));
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--transition);z-index:5;
}
.ali-item:hover::before{transform:scaleX(1)}
/* imagen */
.ali-item__img{position:relative;overflow:hidden;aspect-ratio:16/9;flex-shrink:0}
.ali-item__img img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.75);
  transition:transform .7s cubic-bezier(.4,0,.2,1),filter .5s;
}
.ali-item:hover .ali-item__img img{transform:scale(1.06);filter:brightness(.9)}
.ali-item__img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 45%,rgba(11,15,26,.7) 100%);
  pointer-events:none;
}
.ali-item__img::before{
  content:'';position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:190px;height:190px;
  background-image:url('/general/logo.svg');
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
  opacity:0.7;
  pointer-events:none;
  z-index:3;
  filter:brightness(0) invert(1);
}
.ali-item__year{
  position:absolute;top:.7rem;left:.7rem;z-index:2;
  font-family:'Manrope',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.12em;
  background:rgba(11,15,26,.6);color:rgba(255,255,255,.85);
  padding:.2rem .6rem;border-radius:3px;
  backdrop-filter:blur(6px);
}
.ali-item__cat{
  position:absolute;bottom:.7rem;left:.7rem;z-index:2;
  font-family:'Manrope',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  background:rgba(20,122,193,.8);color:#fff;
  padding:.2rem .6rem;border-radius:3px;
  backdrop-filter:blur(6px);
}
/* cuerpo */
.ali-item__body{
  padding:1.2rem 1.3rem;
  display:flex;flex-direction:column;gap:.5rem;
  flex:1;
}
.ali-item__client{
  font-family:'Manrope',sans-serif;font-size:.68rem;font-weight:600;
  color:var(--c-blue);letter-spacing:.03em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ali-item__title{
  font-family:'Manrope',sans-serif;font-weight:700;
  font-size:.9rem;line-height:1.35;color:#111827;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.ali-item__more{
  display:inline-flex;align-items:center;gap:.4rem;
  margin-top:auto;padding-top:.6rem;
  font-family:'Manrope',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--c-blue);border-top:1px solid var(--c-border);
  transition:gap var(--transition),color var(--transition);
}
.ali-item:hover .ali-item__more{gap:.65rem;color:var(--c-navy)}
/* oculto por filtro */
.ali-item.hidden{display:none}

/* ── Modal ── */
.ali-modal{
  position:fixed;inset:0;z-index:900;
  display:flex;align-items:center;justify-content:center;
  padding:1.5rem;
  opacity:0;pointer-events:none;
  transition:opacity .3s;
}
.ali-modal.open{opacity:1;pointer-events:all}
.ali-modal__backdrop{
  position:absolute;inset:0;
  background:rgba(11,15,26,.75);
  backdrop-filter:blur(6px);
}
.ali-modal__box{
  position:relative;z-index:1;
  background:#fff;border-radius:8px;
  width:100%;max-width:860px;max-height:90vh;
  overflow-y:auto;
  box-shadow:0 32px 80px rgba(0,0,0,.3);
  transform:translateY(16px);
  transition:transform .3s;
}
.ali-modal.open .ali-modal__box{transform:translateY(0)}
.ali-modal__close{
  position:sticky;top:1rem;float:right;margin:1rem 1rem 0 0;
  width:36px;height:36px;border-radius:50%;
  border:1.5px solid var(--c-border);background:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--c-muted);z-index:10;
  transition:background var(--transition),color var(--transition),border-color var(--transition);
}
.ali-modal__close:hover{background:var(--c-dark);color:#fff;border-color:var(--c-dark)}
.ali-modal__inner{padding:2rem 2.4rem 2.4rem;clear:both}

/* contenido del modal (generado por JS) */
.ali-modal__cover{
  width:100%;height:320px;object-fit:cover;
  border-radius:6px;margin-bottom:1.8rem;
  filter:brightness(.85);
}
.ali-modal__meta{
  display:flex;align-items:center;gap:.75rem;
  flex-wrap:wrap;margin-bottom:1.2rem;
}
.ali-modal__year{
  font-family:'Manrope',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.15em;background:rgba(20,122,193,.1);
  color:var(--c-blue);padding:.25rem .7rem;border-radius:3px;
}
.ali-modal__cat{
  font-family:'Manrope',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  background:var(--c-blue);color:#fff;
  padding:.25rem .7rem;border-radius:3px;
}
.ali-modal__client{
  font-family:'Manrope',sans-serif;font-size:.8rem;font-weight:600;
  color:var(--c-muted);margin-left:auto;
}
.ali-modal__title{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:clamp(1.2rem,2vw,1.6rem);
  color:#111827;letter-spacing:-.02em;line-height:1.25;
  margin-bottom:1rem;
}
.ali-modal__desc{
  font-size:.93rem;line-height:1.85;color:var(--c-muted);
  margin-bottom:1.5rem;
}
.ali-modal__specs{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:.75rem;margin-bottom:2rem;
  padding:1.2rem;background:#f7f8fa;border-radius:6px;
}
.ali-modal__spec{display:flex;flex-direction:column;gap:.2rem}
.ali-modal__spec-k{
  font-family:'Manrope',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--c-blue);
}
.ali-modal__spec-v{font-size:.85rem;color:#111827;font-weight:500}
/* galería */
.ali-modal__gallery-title{
  font-family:'Manrope',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--c-muted);margin-bottom:1rem;
}
.ali-modal__gallery{
  display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;
}
.ali-modal__gallery img{
  width:100%;height:160px;object-fit:cover;
  border-radius:4px;filter:brightness(.85);
  cursor:pointer;
  transition:filter var(--transition),transform var(--transition);
}
.ali-modal__gallery img:hover{filter:brightness(1);transform:scale(1.02)}

/* ── Modal carrusel ── */
.ali-mcar{
  position:relative;width:100%;background:#000;
  border-radius:8px 8px 0 0;overflow:hidden;
  aspect-ratio:16/9;
}
.ali-mcar::after{
  content:'';
  position:absolute;inset:0;
  background-image:url('/general/logo.svg');
  background-size:60% auto;
  background-repeat:no-repeat;
  background-position:center;
  opacity:0.5;
  pointer-events:none;
  z-index:10;
  filter:brightness(0) invert(1);
}
.ali-mcar__track{
  position:relative;width:100%;height:100%;
}
.ali-mcar__track img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;filter:brightness(.9);
  opacity:0;transition:opacity .45s ease;
}
.ali-mcar__track img.active{opacity:1}
.ali-mcar__btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:38px;height:38px;border-radius:50%;
  background:rgba(11,15,26,.55);border:1.5px solid rgba(255,255,255,.2);
  color:#fff;cursor:pointer;z-index:10;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--transition);
}
.ali-mcar__btn:hover{background:rgba(20,122,193,.8)}
.ali-mcar__btn--prev{left:.8rem}
.ali-mcar__btn--next{right:.8rem}
.ali-mcar__dots{
  position:absolute;bottom:.8rem;left:50%;transform:translateX(-50%);
  display:flex;gap:.45rem;z-index:10;
}
.ali-mcar__dot{
  width:7px;height:7px;border-radius:50%;
  background:rgba(255,255,255,.35);border:none;cursor:pointer;
  transition:background var(--transition),transform var(--transition);
}
.ali-mcar__dot.active{background:#fff;transform:scale(1.25)}
.ali-mcar__expand{
  position:absolute;bottom:.8rem;right:.8rem;z-index:10;
  width:30px;height:30px;border-radius:4px;
  background:rgba(11,15,26,.55);border:1.5px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.8);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--transition);
}
.ali-mcar__expand:hover{background:rgba(20,122,193,.8)}

/* modal más ancho */
.ali-modal__box{max-width:1020px}
.ali-modal__inner{padding:0 0 2.4rem}
.ali-modal__meta{padding:1.6rem 2rem .6rem;margin:0}
.ali-modal__title{padding:0 2rem;margin-bottom:.75rem}
.ali-modal__desc{padding:0 2rem;margin-bottom:1.2rem}
.ali-modal__specs{margin:0 2rem 0;max-width:none}
/* quita la imagen cover (ya no se usa) */
.ali-modal__cover{display:none}
.ali-modal__gallery{display:none}
.ali-modal__gallery-title{display:none}

/* ── Lightbox galería ── */
.ali-glb{
  position:fixed;inset:0;z-index:1100;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .25s;
}
.ali-glb.open{opacity:1;pointer-events:all}
.ali-glb__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.92)}
/* wrapper para marca de agua en lightbox */
.ali-glb__wrap{
  position:relative;z-index:1;
  display:inline-block;line-height:0;
}
.ali-glb__wrap::after{
  content:'';
  position:absolute;inset:0;
  background-image:url('/general/logo.svg');
  background-size:60% auto;
  background-repeat:no-repeat;
  background-position:center;
  opacity:.5;
  pointer-events:none;
  border-radius:4px;
  filter:brightness(0) invert(1);
}
.ali-glb__img{
  position:relative;
  max-width:90vw;max-height:85vh;
  object-fit:contain;border-radius:4px;
  box-shadow:0 24px 60px rgba(0,0,0,.5);
}
.ali-glb__close{
  position:fixed;top:1.2rem;right:1.4rem;z-index:2;
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.2);
  color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--transition);
}
.ali-glb__close:hover{background:rgba(255,255,255,.25)}
.ali-glb__prev,.ali-glb__next{
  position:fixed;top:50%;transform:translateY(-50%);z-index:2;
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.2);
  color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--transition);
}
.ali-glb__prev:hover,.ali-glb__next:hover{background:rgba(20,122,193,.7)}
.ali-glb__prev{left:1.2rem}
.ali-glb__next{right:1.2rem}
.ali-glb__count{
  position:fixed;bottom:1.4rem;left:50%;transform:translateX(-50%);z-index:2;
  font-family:'Manrope',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.12em;color:rgba(255,255,255,.6);
}

/* ── Portafolio: botón cargar más ── */
.ali-port__more{display:flex;justify-content:center;margin-top:2.5rem}
.ali-port__more.hidden{display:none}

/* ── CTA + Clientes híbrido ── */
.ali-cta-clientes{
  background:var(--c-dark);padding:5rem 5%;
  position:relative;overflow:hidden;
}
.ali-cta-clientes__dots{
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(20,122,193,.07) 1px,transparent 1px);
  background-size:24px 24px;pointer-events:none;
}
.ali-cta-clientes__inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;gap:0;
  min-width:0;
}
.ali-cta-clientes__cta,
.ali-cta-clientes__clientes{min-width:0}
.ali-cta-clientes__cta{
  display:flex;flex-direction:column;gap:1.3rem;
  padding-right:3.5rem;
}
.ali-cta-clientes__sep{
  width:1px;background:rgba(255,255,255,.1);
  align-self:stretch;margin:0 .5rem;
}
.ali-cta-clientes__clientes{
  padding-left:3.5rem;
  display:flex;flex-direction:column;gap:1rem;
}
.ali-cta-clientes__clientes-tag{
  font-family:'Manrope',sans-serif;font-size:.68rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--c-sky);
  display:flex;align-items:center;gap:.6rem;
}
.ali-cta-clientes__clientes-tag::before{
  content:'';display:block;width:22px;height:1px;background:var(--c-blue);
}
.ali-cta-clientes__clientes-title{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:clamp(1.3rem,2.2vw,1.9rem);
  color:#fff;letter-spacing:-.02em;line-height:1.2;margin:0;
}
.ali-cta-clientes__clientes-sub{
  font-size:.85rem;line-height:1.7;color:rgba(255,255,255,.55);
  margin:0;
}
/* carrusel de logos en sección híbrida */
.ali-logos-car{overflow:hidden;width:100%;position:relative}
.ali-logos-car__track{
  display:flex;
  transition:transform .5s cubic-bezier(.4,0,.2,1);
}
.ali-logos-car__item{
  flex:0 0 calc(100% / 3); /* 3 visibles a la vez */
  display:flex;align-items:center;justify-content:center;
  padding:1.25rem 1.5rem;
}
.ali-logos-car__item img{
  max-height:140px;width:auto;max-width:100%;
  opacity:.7;
  transition:opacity var(--transition);
  object-fit:contain;display:block;
}
.ali-logos-car__item img:hover{opacity:1}
/* trust strip */
.ali-cta-clientes__trust{
  display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;
  padding-top:.5rem;border-top:1px solid rgba(255,255,255,.08);
}
.ali-cta-clientes__trust span{
  display:flex;align-items:center;gap:.4rem;
  font-family:'Manrope',sans-serif;font-size:.7rem;font-weight:600;
  letter-spacing:.04em;color:rgba(255,255,255,.55);
}
.ali-cta-clientes__trust svg{color:var(--c-sky);flex-shrink:0}

/* ── Timeline Interactivo — fondo claro ── */
.ali-tl{background:var(--c-off);padding:7rem 5%;position:relative;overflow:hidden}
.ali-tl::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--c-blue),transparent);
}
.ali-tl::after{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(20,122,193,.06) 1px,transparent 1px);
  background-size:28px 28px;pointer-events:none;
}
.ali-tl__inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;}
.ali-tl__header{
  text-align:center;max-width:680px;margin:0 auto 4rem;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
}
.ali-tl__sub{font-size:.95rem;line-height:1.8;color:var(--c-muted)}
/* pista */
.ali-tl__track{
  display:flex;flex-direction:column;gap:0;
  position:relative;padding-left:120px;
}
/* eje vertical */
.ali-tl__axis{
  position:absolute;left:60px;top:24px;bottom:24px;width:1px;
  background:linear-gradient(to bottom,transparent,rgba(20,122,193,.35) 10%,rgba(20,122,193,.35) 90%,transparent);
}
/* nodo */
.ali-tl__node{position:relative;margin-bottom:0}
/* punto en el eje */
.ali-tl__dot{
  position:absolute;left:-68px;top:18px;
  width:16px;height:16px;border-radius:50%;
  background:var(--c-off);border:2px solid rgba(20,122,193,.35);
  cursor:pointer;padding:0;
  display:flex;align-items:center;justify-content:center;
  transition:border-color var(--transition),background var(--transition),transform var(--transition);
  z-index:2;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;
}
.ali-tl__dot-ring{
  width:6px;height:6px;border-radius:50%;
  background:rgba(20,122,193,.4);
  transition:background var(--transition),transform var(--transition);
}
.ali-tl__node.active .ali-tl__dot{
  border-color:var(--c-blue);background:var(--c-off);
  transform:scale(1.2);
}
.ali-tl__node.active .ali-tl__dot-ring{background:var(--c-blue);transform:scale(1.3)}
.ali-tl__node:hover .ali-tl__dot{border-color:var(--c-blue)}
/* etiqueta de año (legacy — no se usa en el layout actual) */
.ali-tl__year-label{
  position:absolute;left:-120px;top:14px;width:48px;
  font-family:'Manrope',sans-serif;font-weight:800;font-size:.78rem;
  letter-spacing:.05em;color:rgba(0,0,0,.2);
  text-align:right;
  transition:color var(--transition);
  cursor:pointer;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;
  user-select:none;
}
.ali-tl__node.active .ali-tl__year-label{color:var(--c-blue)}
.ali-tl__node:hover .ali-tl__year-label{color:var(--c-muted)}
/* panel colapsable */
.ali-tl__panel{
  overflow:hidden;
  max-height:0;
  transition:max-height .45s cubic-bezier(.4,0,.2,1),opacity .35s ease;
  opacity:0;
}
.ali-tl__node.active .ali-tl__panel{max-height:3000px;opacity:1}
.ali-tl__panel-inner{
  padding:.6rem 0 1.8rem;
  display:flex;flex-direction:column;gap:.85rem;
  border-left:1px solid rgba(20,122,193,.2);
  padding-left:1.8rem;margin-left:.1rem;
}
.ali-tl__node:not(.active){cursor:pointer}
.ali-tl__node-btn{
  display:flex;align-items:center;gap:1rem;
  padding:.7rem 0;
  cursor:pointer;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;
  background:none;border:none;width:100%;text-align:left;
}
/* entrada individual del panel */
.ali-tl__entry{
  display:flex;flex-direction:column;gap:.35rem;
  padding:.9rem 1.1rem;
  background:#fff;
  border:1px solid var(--c-border);
  border-radius:6px;
  transition:background var(--transition),border-color var(--transition),box-shadow var(--transition);
}
.ali-tl__entry:hover{
  background:#fff;
  border-color:rgba(20,122,193,.3);
  box-shadow:0 2px 12px rgba(20,122,193,.08);
}
.ali-tl__entry-tag{
  font-family:'Manrope',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  background:rgba(20,122,193,.12);color:var(--c-blue);
  padding:.18rem .55rem;border-radius:3px;
  align-self:flex-start;
}
.ali-tl__entry-tag--origin{background:rgba(43,84,164,.1);color:var(--c-navy)}
.ali-tl__entry strong{
  font-family:'Manrope',sans-serif;font-weight:700;font-size:.88rem;
  color:var(--c-slate);
}
.ali-tl__entry p{
  font-size:.82rem;line-height:1.7;color:var(--c-muted);
  margin:0;
}
/* cabecera de año (clic abre/cierra) */
.ali-tl__year-row{
  display:flex;align-items:center;gap:.8rem;
  padding:.5rem 0;cursor:pointer;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;
  user-select:none;
}
.ali-tl__year-row-num{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:1.5rem;color:rgba(0,0,0,.1);
  letter-spacing:-.04em;line-height:1;
  transition:color var(--transition);
  min-width:60px;
}
.ali-tl__node.active .ali-tl__year-row-num{color:rgba(20,122,193,.5)}
.ali-tl__year-row-info{
  display:flex;flex-direction:column;gap:.15rem;
}
.ali-tl__year-row-count{
  font-family:'Manrope',sans-serif;font-size:.65rem;font-weight:600;
  letter-spacing:.1em;color:var(--c-muted);
  text-transform:uppercase;
}
.ali-tl__node.active .ali-tl__year-row-count{color:var(--c-blue)}
.ali-tl__year-row-arrow{
  margin-left:auto;
  color:rgba(0,0,0,.2);
  transition:transform var(--transition),color var(--transition);
  flex-shrink:0;
}
.ali-tl__node.active .ali-tl__year-row-arrow{
  transform:rotate(90deg);color:var(--c-blue);
}

/* ── Responsive Alianzas ── */
@media(max-width:1100px){
  .ali-grid{grid-template-columns:repeat(3,1fr)}
  .ali-cta-clientes__inner{grid-template-columns:1fr auto 1fr}
  .ali-cta-clientes__cta{padding-right:2.5rem}
  .ali-cta-clientes__clientes{padding-left:2.5rem}
}
@media(max-width:900px){
  .ali-grid{grid-template-columns:repeat(2,1fr)}
  .ali-port{padding:5rem 5%}
  .ali-mcar{aspect-ratio:16/9}
  .ali-modal__inner{padding:0 0 2rem}
  .ali-modal__meta,.ali-modal__title,.ali-modal__desc,.ali-modal__specs{padding-left:1.4rem;padding-right:1.4rem}
  .ali-cta-clientes__inner{grid-template-columns:1fr;grid-template-rows:auto auto auto}
  .ali-cta-clientes__sep{width:100%;height:1px;margin:2rem 0;align-self:auto}
  .ali-cta-clientes__cta{padding-right:0}
  .ali-cta-clientes__clientes{padding-left:0}
}
@media(max-width:720px){
  .ali-grid{grid-template-columns:repeat(2,1fr)}
  .ali-port{padding:4rem 4%}
  .ali-item__img{aspect-ratio:16/9}
  .ali-modal__box{max-width:100%;margin:.5rem}
  .ali-modal__inner{padding:0 0 1.5rem}
  .ali-modal__meta,.ali-modal__title,.ali-modal__desc,.ali-modal__specs{padding-left:1.2rem;padding-right:1.2rem}
  .ali-modal__client{margin-left:0;width:100%}
  .ali-modal{padding:.5rem}
  .ali-mcar{aspect-ratio:16/9}
  .ali-cta-clientes{padding:3.5rem 4%;overflow-x:hidden}
  .ali-cta-clientes__inner{gap:0;width:100%}
  .ali-cta-clientes__cta,.ali-cta-clientes__clientes{width:100%;box-sizing:border-box}
  .ali-cta-clientes__sep{margin:1.5rem 0}
  .ali-logos-car__item img{max-height:70px}
  .svc-cta-band__title{font-size:clamp(1.4rem,6vw,2rem);word-break:break-word}
  .svc-cta-band__sub{font-size:.85rem;max-width:100%}
  .ali-cta-clientes__cta .svc-cta-band__title br{display:none}
  .ali-cta-clientes__clientes-title{font-size:1.3rem}
  .ali-cta-clientes__clientes-sub{font-size:.82rem}
  .ali-logos-car__item{flex:0 0 50%;padding:.75rem 1rem}
  .ali-logos-car__item img{max-height:90px;width:100%;max-width:160px;margin:0 auto}
  .ali-cta-clientes__trust{gap:.6rem 1rem}
  .ali-cta-clientes__trust span{font-size:.68rem}
  .ali-glb__prev{left:.4rem}
  .ali-glb__next{right:.4rem}
  .ali-glb__img{max-width:95vw}
  /* timeline móvil */
  .ali-tl{padding:4rem 4%}
  .ali-tl__track{padding-left:80px}
  .ali-tl__axis{left:40px}
  .ali-tl__dot{left:-48px;background:var(--c-off)}
  .ali-tl__node.active .ali-tl__dot{background:var(--c-off)}
  .ali-tl__year-row-num{font-size:1.1rem;min-width:44px}
  .ali-logos-car__item{flex:0 0 50%} /* 2 logos visibles en móvil */
}
@media(max-width:480px){
  .ali-grid{grid-template-columns:1fr}
  .ali-logos-car__item{flex:0 0 100%}
  .ali-logos-car__item img{max-height:60px;width:100%;max-width:160px;margin:0 auto}
}

/* ═══════════════════════════════════════════
   PÁGINA CONTACTO
═══════════════════════════════════════════ */

/* Hero */
.page-hero__bg--contacto{
  background-image:url('/servicios/mecanica.jpeg');
  background-size:cover;background-position:center;
}

/* ── Header compacto contacto ── */
.cto-header{
  background:var(--c-dark);
  padding:calc(70px + 4rem) 5% 4rem;
  position:relative;overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.cto-header__inner{
  position:relative;z-index:1;
  display:flex;justify-content:space-between;align-items:center;gap:3rem;
}
.cto-header__left{display:flex;flex-direction:column;gap:.9rem}
.cto-header__h1{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:clamp(2rem,4vw,3.2rem);
  color:#fff;letter-spacing:-.03em;line-height:1.1;margin:0;
}
.cto-header__h1 .ghost{
  color:transparent;
  -webkit-text-stroke:1px rgba(255,255,255,.35);
}
.cto-header__sub{
  font-size:.95rem;line-height:1.75;
  color:rgba(255,255,255,.6);
  max-width:480px;margin:0;
}
.cto-header__stats{
  display:flex;align-items:center;
  flex-shrink:0;gap:0;
}
.cto-header__stat{
  display:flex;flex-direction:column;align-items:center;gap:.3rem;
  padding:0 .5rem;
}
.cto-header__stat-num{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:clamp(1.4rem,2.5vw,2rem);color:#fff;
  letter-spacing:-.02em;line-height:1;
}
.cto-header__stat-label{
  font-family:'Manrope',sans-serif;font-size:.65rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.45);text-align:center;
}
.cto-header__stat-sep{
  width:1px;height:40px;
  background:rgba(255,255,255,.12);
  margin:0 1.5rem;flex-shrink:0;
}
@media(max-width:900px){
  .cto-header__inner{flex-direction:column;align-items:flex-start;gap:2rem}
  .cto-header__stats{gap:0}
}
@media(max-width:720px){
  .cto-header{padding:calc(70px + 2.5rem) 4% 2.5rem}
  .cto-header__stats{display:grid;grid-template-columns:1fr 1px 1fr 1px 1fr;align-items:center;width:100%}
  .cto-header__stat-sep{height:32px;margin:0}
}

/* ── Layout split: lado oscuro izq + lado claro der ── */
.cto-main{
  display:grid;grid-template-columns:1fr 1.3fr;
  min-height:700px;
}
.cto-dark-side{
  background:var(--c-dark);
  display:flex;flex-direction:column;
}
.cto-light-side{
  background:var(--c-off);
  display:flex;align-items:stretch;
}

/* ── Columna info (lado oscuro) ── */
.cto-info{
  padding:5rem 4rem 3rem;
  display:flex;flex-direction:column;gap:2rem;
  flex:1;
}
.cto-info__tag{
  font-family:'Manrope',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--c-sky);display:flex;align-items:center;gap:.6rem;
}
.cto-info__tag::before{content:'';display:block;width:22px;height:1px;background:var(--c-blue)}
.cto-info__title{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:clamp(1.6rem,2.5vw,2.2rem);
  color:#fff;letter-spacing:-.02em;line-height:1.15;margin:0;
}
.cto-info__sub{font-size:.88rem;line-height:1.7;color:rgba(255,255,255,.4);margin:0}

/* Datos de contacto */
.cto-datos{display:flex;flex-direction:column;gap:1.1rem}
.cto-dato{display:flex;align-items:flex-start;gap:.9rem}
.cto-dato__icon{
  width:32px;height:32px;border-radius:50%;
  background:rgba(20,122,193,.15);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  color:var(--c-sky);
}
.cto-dato__label{
  font-family:'Manrope',sans-serif;font-size:.58rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.3);margin-bottom:.2rem;
}
.cto-dato__val{font-size:.83rem;line-height:1.6;color:rgba(255,255,255,.65)}
.cto-dato__val a{color:var(--c-sky);text-decoration:none}
.cto-dato__val a:hover{color:#fff}

/* WhatsApp inline (dentro del lado oscuro) */
.cto-wa{
  border:1px solid rgba(37,211,102,.2);
  border-radius:8px;padding:1.4rem 1.5rem;
  background:rgba(37,211,102,.04);
  display:flex;flex-direction:column;gap:.85rem;
}
.cto-wa__header{display:flex;align-items:center;gap:.6rem}
.cto-wa__dot{
  width:7px;height:7px;border-radius:50%;
  background:#25d366;flex-shrink:0;
  box-shadow:0 0 0 3px rgba(37,211,102,.2);
  animation:waPulse 2s ease-in-out infinite;
}
@keyframes waPulse{
  0%,100%{box-shadow:0 0 0 3px rgba(37,211,102,.2)}
  50%{box-shadow:0 0 0 6px rgba(37,211,102,.05)}
}
.cto-wa__badge{
  font-family:'Manrope',sans-serif;font-size:.62rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:#25d366;
}
.cto-wa__desc{
  font-size:.82rem;line-height:1.65;color:rgba(255,255,255,.4);margin:0;
}
.cto-wa__btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  background:#25d366;color:#fff;
  font-family:'Manrope',sans-serif;font-weight:700;font-size:.8rem;
  padding:.75rem 1.2rem;border-radius:5px;
  text-decoration:none;border:none;cursor:pointer;
  transition:background var(--transition),transform var(--transition);
  align-self:flex-start;
}
.cto-wa__btn:hover{background:#1ebe5d;transform:translateY(-1px)}

/* Mapa — fila 2, ancho completo */
.cto-map-embed{
  grid-column:1 / -1;
  height:340px;
  border-top:1px solid rgba(255,255,255,.06);
  position:relative;overflow:hidden;
}
.cto-map-embed iframe{
  width:100%;height:100%;border:0;display:block;
  filter:grayscale(100%) invert(92%) hue-rotate(180deg) brightness(0.8);
}

/* ── Columna formulario (lado claro) ── */
.cto-form-wrap{
  padding:5rem 3.5rem;
  display:flex;flex-direction:column;gap:0;
  width:100%;
}
.cto-form__head{display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem}
.cto-form__title{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:clamp(1.4rem,2.2vw,1.9rem);
  color:var(--c-dark);letter-spacing:-.02em;line-height:1.15;margin:0;
}
.cto-form__sub{font-size:.83rem;color:var(--c-muted);line-height:1.6;margin:0}

.cto-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.2rem}
.cto-field{display:flex;flex-direction:column;gap:.38rem}
.cto-field--full{grid-column:span 2}
.cto-field label{
  font-family:'Manrope',sans-serif;font-size:.6rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted);
}
.cto-field label span{color:var(--c-blue)}
.cto-field input,
.cto-field select,
.cto-field textarea{
  background:#fff;border:1px solid var(--c-border);
  border-radius:5px;padding:.72rem .9rem;
  font-family:'Inter',sans-serif;font-size:.87rem;
  color:var(--c-slate);outline:none;
  transition:border-color var(--transition),box-shadow var(--transition);
  appearance:none;-webkit-appearance:none;
}
.cto-field select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .9rem center;
  padding-right:2.5rem;cursor:pointer;
}
.cto-field input:focus,
.cto-field select:focus,
.cto-field textarea:focus{
  border-color:var(--c-blue);
  box-shadow:0 0 0 3px rgba(20,122,193,.1);
}
.cto-field input::placeholder,
.cto-field textarea::placeholder{color:#b0b8c4}
.cto-field textarea{resize:vertical;min-height:100px}

.cto-form__actions{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.cto-btn-send{justify-content:center;padding:.82rem}
.cto-btn-wa{
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  background:#25d366;color:#fff;border:1px solid transparent;
  font-family:'Manrope',sans-serif;font-weight:700;font-size:.78rem;
  padding:.82rem;border-radius:6px;cursor:pointer;
  transition:background var(--transition),transform var(--transition);
}
.cto-btn-wa:hover{background:#1ebe5d;transform:translateY(-1px)}
.cto-form__note{
  font-size:.7rem;color:var(--c-muted);margin:.75rem 0 0;text-align:center;
}
.cto-form__note span{color:var(--c-blue)}

/* ── Responsive Contacto ── */
@media(max-width:1000px){
  .cto-info{padding:4rem 3rem 2.5rem}
  .cto-form-wrap{padding:4rem 3rem}
}
@media(max-width:800px){
  .cto-main{grid-template-columns:1fr}
  .cto-map-embed{height:260px;grid-column:1}
  .cto-info{padding:3.5rem 4%}
  .cto-form-wrap{padding:3.5rem 4%}
}
@media(max-width:720px){
  .cto-form__grid{grid-template-columns:1fr}
  .cto-field--full{grid-column:span 1}
  .cto-form__actions{grid-template-columns:1fr}
  .cto-map-embed{height:220px}
}

/* =====================================================
   PROTECCIÓN DE CONTENIDO
   ===================================================== */

/* Deshabilitar selección de texto globalmente */
* {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* Permitir selección en campos de formulario */
input, textarea, select {
  -webkit-user-select: text;
  -moz-user-select: text;
  -ms-user-select: text;
  user-select: text;
}

/* Solo las imágenes pierden pointer-events y drag */
img {
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -moz-user-drag: none;
  -o-user-drag: none;
  user-drag: none;
  pointer-events: none;
  -webkit-touch-callout: none;
}

/* iframes — sin drag */
iframe {
  -webkit-user-drag: none;
  user-drag: none;
}
