:root{
  --navy:#090b22;
  --navy-2:#111633;
  --ink:#101223;
  --muted:#666b7c;
  --light:#f6f6f6;
  --soft:#ecebeb;
  --white:#ffffff;
  --line:#dedee3;
  --grad-a:#f7931e;
  --grad-b:#e84d79;
  --grad-c:#b0009a;
  --radius:22px;
  --shadow:0 22px 60px rgba(9,11,34,.10);
  --max:1180px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.skip-link{position:absolute;left:-999px;top:0;background:#fff;color:#000;padding:.8rem 1rem;z-index:999}.skip-link:focus{left:1rem;top:1rem}.container{width:min(var(--max),calc(100% - 40px));margin:auto}.top-gradient{height:4px;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c))}.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);padding-top: 10px; padding-bottom: 10px;backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}.nav{height:78px;display:flex;align-items:center;justify-content:space-between;gap:22px}.logo img{width:188px;height:auto}.menu{display:flex;align-items:center;gap:24px;font-size:.92rem;font-weight:800}.menu a{color:#161829}.menu a[aria-current="page"]{color:var(--grad-c)}.nav-cta{padding:.76rem 1rem;border-radius:999px;background:var(--navy);color:#fff!important}.menu-toggle{display:none;border:0;background:var(--navy);color:#fff;border-radius:12px;padding:.7rem .85rem;font-weight:900}
h1,h2,h3{line-height:1.08;margin:0 0 18px}h1{font-size:clamp(2.5rem,5.4vw,5.1rem);letter-spacing:-.07em;color:var(--navy)}h2{font-size:clamp(2rem,4vw,3.55rem);letter-spacing:-.055em;color:var(--navy)}h3{font-size:1.24rem;color:var(--navy)}.lead{font-size:clamp(1.08rem,1.55vw,1.28rem);color:#45495b;max-width:700px}.muted,.card p{color:var(--muted)}
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#fff 0%,var(--light) 100%);color:var(--ink)}.hero:before{content:"";position:absolute;left:0;right:0;top:0;height:220px;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));opacity:.95}.hero .container{
  position:relative;
  z-index:2;
  display:block;
  min-height:690px;
  padding:126px 0 104px;
}.hero .container>div:first-child{background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.7);border-radius:34px;padding:44px;box-shadow:var(--shadow)}.kicker{display:inline-flex;align-items:center;gap:.55rem;padding:.42rem 2px;border-radius:999px;/*background:var(--soft)!important;*/ background-color: transparent !important; text-transform: uppercase; color:var(--navy)!important;border:0!important;font-size:.82rem;font-weight:900;letter-spacing:.02em}.btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:1rem 1.18rem;border-radius:999px;font-weight:900;border:1px solid transparent}.btn.primary,.btn.dark{background:var(--navy);color:#fff}.btn.ghost{background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));color:#fff;border:0}.hero-card{position:relative;min-height:540px;background:var(--navy);border-radius:42px;border:0;box-shadow:var(--shadow);overflow:visible}.hero-card:after{content:"";position:absolute;inset:8%;background:url('../img/simbolo-color.png') center/contain no-repeat;filter:drop-shadow(0 25px 45px rgba(9,11,34,.24))}.browser{display:none}.stats{position:absolute;z-index:3;right:calc(50% - 555px);bottom:120px;display:grid;grid-template-columns:1fr;gap:10px;margin:0}.stat{background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:18px;padding:14px 16px;box-shadow:var(--shadow);font-weight:900}.stat strong{display:block;font-size:1.35rem;color:var(--navy)}
.section{padding:92px 0}.section.soft{background:var(--soft)}.section.dark{background:var(--navy);color:#fff}.section.dark h2,.section.dark h3{color:#fff}.section.dark p,.section.dark .muted{color:rgba(255,255,255,.72)}.section-head{display:flex;justify-content:space-between;align-items:end;gap:34px;margin-bottom:36px}.section-head p{max-width:620px;color:var(--muted)}.grid{display:grid;gap:22px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:0 12px 42px rgba(9,11,34,.055)}.card:hover{transform:translateY(-3px);transition:.25s ease;box-shadow:var(--shadow)}.icon{width:48px;height:48px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,var(--grad-a),var(--grad-b),var(--grad-c));color:#fff;font-size:1.22rem;margin-bottom:18px;font-weight:900}.link{display:inline-flex;margin-top:12px;font-weight:900;color:var(--grad-c)}.split{display:grid;grid-template-columns:.92fr 1.08fr;gap:48px;align-items:center}.panel{border-radius:34px;background:#fff;padding:36px;border:1px solid var(--line);box-shadow:var(--shadow)}.checks{list-style:none;padding:0;margin:20px 0 0;display:grid;gap:12px}.checks li{padding-left:30px;position:relative}.checks li:before{content:"✓";position:absolute;left:0;top:0;color:var(--grad-c);font-weight:900}.process{counter-reset:step}.process .card:before{counter-increment:step;content:"0" counter(step);display:block;font-size:.82rem;color:var(--grad-c);font-weight:900;margin-bottom:12px}
.case{position:relative;min-height:350px;overflow:hidden;border-radius:30px;background:var(--navy);color:#fff;padding:28px;display:flex;flex-direction:column;justify-content:flex-end;box-shadow:0 18px 48px rgba(9,11,34,.15)}.case:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));opacity:.86}.case:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(9,11,34,.92),rgba(9,11,34,.18) 58%,rgba(255,255,255,.05))}.case>*{position:relative;z-index:2}.case h3{color:#fff;font-size:1.45rem}.tags{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 12px}.tag{font-size:.76rem;font-weight:900;padding:.28rem .55rem;border-radius:999px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22)}.cta{border-radius:34px;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));color:#fff;padding:54px;display:grid;grid-template-columns:1fr auto;gap:30px;align-items:center;overflow:hidden;position:relative}.cta:after{content:"";position:absolute;right:-70px;bottom:-90px;width:260px;height:260px;background:url('../img/simbolo-blanco.png') center/contain no-repeat;opacity:.14}.cta h2{color:#fff}.cta p{color:rgba(255,255,255,.84)}.cta>*{position:relative;z-index:2}.cta .btn.primary{background:#fff;color:var(--navy)}
.footer{background:var(--navy);color:#fff;padding:0}.footer-gradient{height:150px;background:url('../img/fondo-footer.jpg') center/cover no-repeat}.footer-main{padding:58px 0 30px}.footer-grid{display:grid;grid-template-columns:1.2fr repeat(3,1fr);gap:34px}.footer a{color:rgba(255,255,255,.78)}.footer small{color:rgba(255,255,255,.55)}.footer h3{color:#fff}.form{display:grid;gap:14px}label{font-weight:900;font-size:.92rem}input,textarea,select{width:100%;border:1px solid var(--line);border-radius:16px;padding:1rem;font:inherit;background:#fff;color:var(--ink)}input:focus,textarea:focus,select:focus,a:focus,button:focus{outline:3px solid rgba(176,0,154,.25);outline-offset:3px}textarea{min-height:150px}.page-hero{position:relative;padding:92px 0;background:linear-gradient(180deg,#fff,var(--light));overflow:hidden}/*.page-hero:before{content:"";position:absolute;left:0;right:0;top:0;height:10px;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c))}*/.page-hero h1{color:var(--navy);font-size:clamp(2.35rem,5vw,4.7rem)}.page-hero p{font-size:1.18rem;color:var(--muted);max-width:800px}.service-list .card{display:flex;flex-direction:column}.service-list .card .btn{margin-top:auto}.whatsapp{position:fixed;right:20px;bottom:20px;width:58px;height:58px;border-radius:50%;background:#25d366;color:#fff;display:grid;place-items:center;font-size:1.6rem;font-weight:900;box-shadow:0 15px 45px rgba(0,0,0,.22);z-index:40}.notice{font-size:.92rem;color:var(--muted)}
@media (max-width:900px){.menu{position:absolute;left:20px;right:20px;top:82px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px;display:none;flex-direction:column;align-items:flex-start;box-shadow:var(--shadow)}.menu.open{display:flex}.menu-toggle{display:block}.hero .container,.split,.cta{grid-template-columns:1fr}.hero .container{
  position:relative;
  z-index:2;
  display:block;
  min-height:690px;
  padding:126px 0 104px;
}.hero .container>div:first-child{padding:28px}.hero-card{min-height:390px}.stats{position:static;margin-top:20px}.grid-3,.grid-2,.footer-grid{grid-template-columns:1fr}.section-head{display:block}.cta{padding:34px}}

.hero{
  position:relative;
  overflow:hidden;
  min-height:690px;
  background:
    linear-gradient(90deg,rgba(9,11,34,.92) 0%,rgba(9,11,34,.82) 38%,rgba(9,11,34,.48) 68%,rgba(9,11,34,.24) 100%),
    url('../img/hero-luvistudio.jpg') center/cover no-repeat;
  color:#fff;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 78% 24%,rgba(232,77,121,.24),transparent 28%),
    linear-gradient(180deg,rgba(9,11,34,.08),rgba(9,11,34,.42));
  pointer-events:none;
}
.hero::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:10px;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
}
.hero .container{
  position:relative;
  z-index:2;
  display:block;
  min-height:690px;
  padding:126px 0 104px;
}
.hero-copy{
  background:transparent;
  border:0;
  border-radius:0;
  padding:0;
  box-shadow:none;
  max-width:760px;
}
.hero .kicker{
  background:rgba(255,255,255,.12);
  color:#fff;
  border:1px solid rgba(255,255,255,.22);
}
.hero h1{color:#fff;text-shadow:0 16px 50px rgba(0,0,0,.28)}
.hero .lead{color:rgba(255,255,255,.84)}
.hero-visual{display:none}
.hero-visual::before{display:none}
.hero-visual::after{display:none}
.hero-metrics{
  position:absolute;
  z-index:2;
  right:0;
  bottom:28px;
  display:grid;
  gap:10px;
  min-width:245px;
}
.metric{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);
  color:#fff;
  border-radius:18px;
  padding:14px 16px;
  box-shadow:0 22px 60px rgba(0,0,0,.18);
  font-weight:900;
  backdrop-filter:blur(10px);
}
.metric span{
  display:block;
  font-size:.82rem;
  color:rgba(255,255,255,.72);
  font-weight:700;
}
.metrics-band{
  background:#fff;
  border-bottom:1px solid var(--line);
}
.metrics-row{
  transform:translateY(-46px);
  margin-bottom:-46px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.metrics-row .metric{
  background:#fff;
  border:1px solid var(--line);
  color:var(--navy);
  border-radius:22px;
  padding:24px 26px;
  box-shadow:var(--shadow);
  font-weight:900;
  backdrop-filter:none;
}
.metrics-row .metric strong{
  display:block;
  font-size:clamp(2rem,4vw,3.1rem);
  line-height:1;
  letter-spacing:-.05em;
  color:var(--navy);
}
.metrics-row .metric span{
  display:block;
  margin-top:8px;
  color:var(--muted);
  font-weight:800;
  font-size:.95rem;
}
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .75s ease, transform .75s ease;
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
.card.reveal:nth-child(2), .case.reveal:nth-child(2){transition-delay:.08s}
.card.reveal:nth-child(3), .case.reveal:nth-child(3){transition-delay:.16s}
.card.reveal:nth-child(4), .case.reveal:nth-child(4){transition-delay:.24s}


/* HOME HERO FINAL */
.hero,
.metrics-band{display:none!important}

.home-hero{
  position:relative;
  min-height:calc(100vh - 78px);
  overflow:hidden;
  color:#fff;
  background:
    linear-gradient(90deg,rgba(9,11,34,.94) 0%,rgba(9,11,34,.88) 34%,rgba(9,11,34,.56) 63%,rgba(9,11,34,.34) 100%),
    url('../img/hero-luvistudio.jpg') center/cover no-repeat;
}
.home-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 72% 16%,rgba(232,77,121,.42),transparent 24%),
    radial-gradient(circle at 22% 86%,rgba(20,38,115,.56),transparent 34%),
    linear-gradient(180deg,rgba(9,11,34,.02),rgba(9,11,34,.48));
  pointer-events:none;
}
.home-hero::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:1px;
  background:rgba(255,255,255,.14);
}
.home-hero__inner{
  position:relative;
  z-index:2;
  min-height:calc(100vh - 78px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:92px 0 54px;
}
.home-hero__content{
  max-width:760px;
  padding-top:10px;
}
.home-hero__eyebrow{
  margin:0 0 28px;
  font-size:.88rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.055em;
  font-weight:900;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.home-hero h1{
  margin:0;
  color:#fff;
  font-size:clamp(3.1rem,4.9vw,6.65rem);
  line-height:.98;
  letter-spacing:-.075em;
  max-width:850px;
  text-shadow:0 20px 60px rgba(0,0,0,.32);
}
.home-hero h1 span{
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.home-hero__lead{
  margin:28px 0 0;
  max-width:650px;
  color:rgba(255,255,255,.82);
  font-size:clamp(1.05rem,1.45vw,1.28rem);
  line-height:1.75;
}
.home-hero__actions{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:18px;
  margin-top:34px;
}
.btn-outline-white{
  background:rgba(255,255,255,.03);
  color:#fff;
  border-color:rgba(255,255,255,.55);
  min-width:172px;
}
.btn-outline-white:hover{
  background:#fff;
  color:var(--navy);
}
.btn-gradient{
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  color:#fff;
  min-width:218px;
  border:0;
}
.home-hero__metrics{
  width:100%;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:34px;
  margin-top:74px;
}
.home-metric{
  position:relative;
  display:grid;
  grid-template-columns:78px 1fr;
  gap:22px;
  align-items:center;
  padding:0 34px 32px 0;
  border-right:1px solid rgba(255,255,255,.18);
}
.home-metric:last-child{
  border-right:0;
}
.home-metric::after{
  content:"";
  position:absolute;
  left:0;
  right:34px;
  bottom:0;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
}
.home-metric__icon{
  width:72px;
  height:72px;
  display:grid;
  place-items:center;
  border-radius:18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:inset 0 0 30px rgba(255,255,255,.05);
  color:#fff;
  font-size:1.65rem;
}
.home-metric strong{
  display:block;
  color:#fff;
  font-size:clamp(2.2rem,4vw,3.45rem);
  line-height:1;
  letter-spacing:-.06em;
}
/*
.home-metric .counter::after{
  content:"+";
  margin-left:.08em;
  color:var(--grad-c);
}
*/
.home-metric .counter{ font-size: 2rem !important; }
/*
.home-metric .counter[data-suffix="%"]::after{
  content:"%";
}
*/
.home-metric span:last-child{
  display:block;
  margin-top:9px;
  color:rgba(255,255,255,.72);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.84rem;
  font-weight:900;
}

/* make reveal visible on first fold with subtle entrance */
.home-hero .reveal{
  opacity:0;
  transform:translateY(24px);
  animation:heroFadeUp .85s ease forwards;
}
.home-hero__metrics.reveal{animation-delay:.25s}
@keyframes heroFadeUp{
  to{opacity:1;transform:translateY(0)}
}

@media (max-width:1020px){
  .home-hero__metrics{grid-template-columns:1fr;gap:20px;margin-top:48px}
  .home-metric{border-right:0;padding-right:0}
  .home-metric::after{right:0}
}
@media (max-width:700px){
  .home-hero{min-height:auto}
  .home-hero__inner{min-height:auto;padding:72px 0 46px}
  .home-hero h1{font-size:clamp(2.65rem,14vw,4.25rem)}
  .home-hero__lead{line-height:1.62}
  .home-hero__actions{align-items:stretch}
  .home-hero__actions .btn{width:100%}
  .home-metric{grid-template-columns:62px 1fr;gap:16px}
  .home-metric__icon{width:58px;height:58px;font-size:1.28rem}
}

.icon-img{width:58px;height:58px;display:grid;place-items:center;border-radius:18px;background:#f6f6f6;border:1px solid var(--line);margin-bottom:18px}
.icon-img img{width:42px;height:42px;object-fit:contain;opacity:.88}
.home-metric__icon img{width:42px;height:42px;object-fit:contain;filter:invert(32%) sepia(83%) saturate(1983%) hue-rotate(302deg) brightness(96%) contrast(96%)}
.custom-solutions-card{padding:38px}
.solution-label{display:inline-flex;margin-bottom:14px;font-size:.78rem;line-height:1;text-transform:uppercase;letter-spacing:.08em;font-weight:900;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));-webkit-background-clip:text;background-clip:text;color:transparent}
.solution-chips{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:26px 0 28px}
.solution-chips span{position:relative;display:flex;align-items:center;min-height:56px;padding:14px 14px 14px 42px;border:1px solid var(--line);border-radius:16px;background:linear-gradient(180deg,#fff,#f8f8f8);color:var(--navy);font-weight:900;font-size:.93rem}
/* .solution-chips span::before{content:"";position:absolute;left:14px;width:14px;height:14px;border-radius:50%;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));box-shadow:0 0 0 5px rgba(232,77,121,.10)} */
.solution-btn{margin-top:2px}
@media (max-width:700px){.solution-chips{grid-template-columns:1fr}}

/* AJUSTES V7 */
.home-metric__icon img{width:42px;height:42px;object-fit:contain;filter:brightness(0) invert(1);opacity:.95}
.icon-img{width:58px;height:58px;display:grid;place-items:center;border-radius:18px;background:#f6f6f6;border:1px solid var(--line);margin-bottom:18px}
.icon-img img{width:42px;height:42px;object-fit:contain;opacity:.9}
.custom-solutions-card{padding:38px}
.solution-label{display:inline-flex;margin-bottom:14px;font-size:.78rem;line-height:1;text-transform:uppercase;letter-spacing:.08em;font-weight:900;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));-webkit-background-clip:text;background-clip:text;color:transparent}
.solution-chips{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:24px 0 22px}
.solution-chips span{display:grid;grid-template-columns:34px 1fr;align-items:center;min-height:62px;padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:linear-gradient(180deg,#fff,#f8f8f8);color:var(--navy);font-weight:900;font-size:.92rem}
.solution-chips i{width:28px;height:28px;display:grid;place-items:center;border-radius:10px;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));color:#fff;font-style:normal;font-size:.85rem;box-shadow:0 8px 20px rgba(176,0,154,.16)}
.solution-microcopy{margin-top:0;margin-bottom:24px;font-weight:700}.solution-btn{margin-top:0}
@media (max-width:700px){.solution-chips{grid-template-columns:1fr}}


/* V8 - iconos personalizados grandes en bloque de Soluciones */
.service-custom-icon{
  width:82px;
  height:82px;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  margin-bottom:22px;
  display:grid;
  place-items:center;
}
.service-custom-icon img{
  width:68px;
  height:68px;
  object-fit:contain;
  display:block;
  opacity:.92;
}
.card:hover .service-custom-icon img{
  transform:translateY(-3px);
  transition:transform .25s ease;
}


/* V9 - bloque destacado de programación a medida */
.section.soft .split{
  align-items:center;
}

.custom-solutions-card{
  position:relative;
  overflow:hidden;
  padding:42px;
  border-radius:34px;
  background:
    radial-gradient(circle at 92% 10%, rgba(232,77,121,.12), transparent 28%),
    linear-gradient(180deg,#ffffff 0%,#fafafa 100%);
}

.custom-solutions-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:6px;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
}

.solution-label{
  display:inline-flex;
  margin-bottom:14px;
  font-size:.78rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:900;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.custom-solutions-card h3{
  max-width:620px;
  margin-bottom:24px;
}

.solution-chips{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin:24px 0 24px;
}

.solution-chips span{
  display:grid;
  grid-template-columns:38px 1fr;
  align-items:center;
  min-height:68px;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  color:var(--navy);
  box-shadow:0 10px 28px rgba(9,11,34,.045);
}

.solution-chips i{
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border-radius:11px;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  color:#fff;
  font-style:normal;
  font-size:.9rem;
  font-weight:900;
  box-shadow:0 8px 20px rgba(176,0,154,.16);
}

.solution-chips strong{
  display:block;
  font-size:.94rem;
  line-height:1.2;
}

.solution-microcopy{
  margin:2px 0 26px;
  font-weight:700;
  color:#5f6578;
}

.solution-btn{
  margin-top:0;
}

@media (max-width:700px){
  .custom-solutions-card{padding:30px}
  .solution-chips{grid-template-columns:1fr}
}

/* V10 SEO programación a medida */
.programming-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:28px 0 34px;
}
.programming-tags span{
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  font-size:.85rem;
  font-weight:800;
  color:var(--navy);
  box-shadow:0 8px 20px rgba(9,11,34,.05);
}

/* V11 - SEO sección Proyectos y casos de éxito */
.projects-intro{
  max-width:680px;
}
.projects-intro p{
  margin:0 0 14px;
  color:rgba(255,255,255,.72);
}
.project-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:20px;
}
.project-tags span{
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  font-size:.85rem;
  font-weight:800;
}

/* V12 - sección Proyectos y casos de éxito incorporada en .section.dark */
.section.dark .projects-intro,
.section.navy .projects-intro{
  max-width:700px;
}
.section.dark .projects-intro p,
.section.navy .projects-intro p{
  margin:0 0 14px;
  color:rgba(255,255,255,.74);
}
.project-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.project-tags span{
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
  font-size:.85rem;
  font-weight:800;
}


/* V13 WhatsApp */
.whatsapp{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:999;
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  background:#ffffff;
  color:#090b22;
  text-decoration:none;
  box-shadow:0 12px 35px rgba(9,11,34,.18);
  border:1px solid rgba(9,11,34,.08);
  font-weight:800;
  transition:.25s ease;
}
.whatsapp:hover{
  transform:translateY(-3px);
}
.whatsapp img{
  width:28px;
  height:28px;
  object-fit:contain;
}
@media(max-width:768px){
  .whatsapp span{
    display:none;
  }
  .whatsapp{
    padding:14px;
  }
}


/* V14 - WhatsApp verde con icono blanco y footer legal */
.whatsapp{
  position:fixed!important;
  right:20px!important;
  bottom:20px!important;
  width:58px!important;
  height:58px!important;
  padding:0!important;
  border-radius:50%!important;
  background:#25D366!important;
  color:#fff!important;
  display:grid!important;
  place-items:center!important;
  box-shadow:0 15px 45px rgba(0,0,0,.22)!important;
  border:0!important;
  z-index:999!important;
}
.whatsapp img{
  width:31px!important;
  height:31px!important;
  object-fit:contain!important;
  filter:brightness(0) invert(1)!important;
}
.whatsapp span{display:none!important}
.legal-content{
  max-width:900px;
}
.legal-content h2{
  margin-top:34px;
}
.footer .muted{
  color:rgba(255,255,255,.72);
}


/* V15 - Footer corregido sin logotipo y legales diferenciados */
.footer-main{
  padding:58px 0 26px;
}
.footer-grid{
  align-items:start;
}
.footer-grid h3{
  color:#fff;
  margin-bottom:16px;
}
.footer-legal{
  margin-top:36px;
  padding-top:22px;
  border-top:1px solid rgba(255,255,255,.14);
  display:flex;
  flex-wrap:wrap;
  gap:16px 26px;
  justify-content:center;
}
.footer-legal a{
  color:rgba(255,255,255,.74);
  font-size:.88rem;
  font-weight:800;
  text-decoration:none;
}
.footer-legal a:hover{
  color:#fff;
}
.whatsapp{
  position:fixed!important;
  right:20px!important;
  bottom:20px!important;
  width:58px!important;
  height:58px!important;
  padding:0!important;
  border-radius:50%!important;
  background:#25D366!important;
  color:#fff!important;
  display:grid!important;
  place-items:center!important;
  box-shadow:0 15px 45px rgba(0,0,0,.22)!important;
  border:0!important;
  z-index:999!important;
}
.whatsapp img{
  width:31px!important;
  height:31px!important;
  object-fit:contain!important;
  filter:brightness(0) invert(1)!important;
}
.whatsapp span{display:none!important}


/* V16 - Bloque confianza territorial */
.trust-area{
  background:#f6f6f6;
padding-top: 80px;
}
.trust-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:34px;
  padding:60px;
  box-shadow:0 20px 60px rgba(9,11,34,.06);
  text-align:center;
}
.trust-card h2{
  max-width:900px;
  margin-left:auto;
  margin-right:auto;
}
.trust-card p{
  max-width:900px;
  margin:20px auto 0;
}
.territory-tags{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
  margin-top:30px;
}
.territory-tags span{
  padding:10px 16px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  font-weight:800;
  color:var(--navy);
}
@media(max-width:768px){
  .trust-card{
    padding:34px 24px;
  }
}

/* V17 - Páginas web y Blog */
.pricing-grid{align-items:stretch}
.price-card{position:relative;display:flex;flex-direction:column}
.price-card .btn{margin-top:auto}
.price-icon{width:74px;height:74px;display:grid;place-items:center;margin-bottom:18px}
.price-icon img{width:66px;height:66px;object-fit:contain}
.price{margin:22px 0;color:var(--navy);font-size:2.55rem;line-height:1;font-weight:900;letter-spacing:-.06em}
.price span{font-size:.95rem;letter-spacing:0;color:var(--muted)}
.featured-price{border:2px solid transparent;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c)) border-box}
.recommended{position:absolute;right:22px;top:22px;padding:7px 11px;border-radius:999px;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));color:#fff;font-size:.75rem;font-weight:900} .btn.light,.btn.gradient{ background: linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c)); color: #fff; } 
.finance-note{margin-top:28px;padding:22px 26px;border-radius:20px;background:#fff;border:1px solid var(--line);box-shadow:0 10px 28px rgba(9,11,34,.045);color:var(--muted)}
.finance-note strong{color:var(--navy)}
.web-types{display:flex;flex-wrap:wrap;gap:12px}
.web-types span{padding:12px 16px;border-radius:999px;background:#f6f6f6;border:1px solid var(--line);color:var(--navy);font-weight:800}
.blog-category{display:inline-flex;margin-bottom:14px;font-size:.78rem;line-height:1;text-transform:uppercase;letter-spacing:.08em;font-weight:900;background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));-webkit-background-clip:text;background-clip:text;color:transparent}
.blog-card h3{min-height:76px}
@media(max-width:900px){.recommended{position:static;width:max-content;margin-bottom:12px}}


/* V18 - Bloques de planes y blog en Home */
.home-pricing .price-card{
  min-height:100%;
}
.home-pricing .checks{
  margin-bottom:28px;
}
.home-blog{
  background:#fff;
}
.blog-more{
  margin-top:30px;
  display:flex;
  justify-content:center;
}
.home-blog .blog-card h3{
  min-height:72px;
}


/* V19 - Imágenes en home, caso real destacado y blog */
.section.light,
.section.soft{
  position:relative;
  overflow:hidden;
}
.section.light::before{
  content:"";
  position:absolute;
  inset:0;
  /*background:url('../img/fondo-tecnologia-azul.jpg') right center/720px auto no-repeat;*/
  opacity:.035;
  pointer-events:none;
}
.section.light > *,
.section.soft > *{
  position:relative;
  z-index:1;
}

.real-case{
  background:#fff;
}
.real-case-card{
  display:grid;
  grid-template-columns:0.92fr 1.08fr;
  gap:38px;
  align-items:stretch;
  background:#090b22;
  border-radius:36px;
  overflow:hidden;
  box-shadow:0 24px 70px rgba(9,11,34,.18);
}
.real-case-content{
  padding:54px;
  color:#fff;
}
.real-case-content h2{
  color:#fff;
}
.real-case-content p{
  color:rgba(255,255,255,.78);
  font-size:1.08rem;
}
.real-case-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:26px 0 30px;
}
.real-case-tags span{
  padding:9px 13px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
  font-size:.84rem;
  font-weight:800;
}
.real-case-image{
  margin:0;
  min-height:430px;
}
.real-case-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.case-with-image{
  padding:0!important;
  overflow:hidden;
}
.case-with-image::before,
.case-with-image::after{
  display:none!important;
}
.case-with-image > img{
  width:100%;
  height:100%;
  min-height:360px;
  object-fit:cover;
  position:absolute;
  inset:0;
  z-index:0;
}
.case-with-image .case-content{
  position:relative;
  z-index:2;
  margin-top:auto;
  padding:28px;
  background:linear-gradient(to top,rgba(9,11,34,.94),rgba(9,11,34,.58),transparent);
}
.featured-project-card{
  min-height:460px;
}

.blog-card-image{
  padding:0!important;
  overflow:hidden;
}
.blog-card-image > img{
  width:100%;
  height:210px;
  object-fit:cover;
}
.blog-card-body{
  padding:26px;
}
.blog-card-image h3{
  min-height:auto;
}
@media(max-width:900px){
  .real-case-card{
    grid-template-columns:1fr;
  }
  .real-case-content{
    padding:34px;
  }
  .real-case-image{
    min-height:280px;
  }
}


/* V20 - Proyectos agrupados en la home con imágenes */
.real-case{display:none!important}
.home-projects-layout{
  display:grid;
  grid-template-columns:1.25fr .75fr;
  gap:24px;
  align-items:stretch;
}
.project-featured,
.project-mini{
  position:relative;
  overflow:hidden;
  border-radius:30px;
  background:#090b22;
  box-shadow:0 22px 60px rgba(0,0,0,.24);
}
.project-featured{min-height:560px}
.project-featured > img,
.project-mini > img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  opacity:.82;
  transition:transform .45s ease, opacity .45s ease;
}
.project-featured::after,
.project-mini::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(9,11,34,.96),rgba(9,11,34,.58),rgba(9,11,34,.12));
  z-index:1;
}
.project-featured:hover > img,
.project-mini:hover > img{transform:scale(1.045);opacity:1}
.project-featured-content,
.project-mini-content{position:relative;z-index:2;color:#fff}
.project-featured-content{
  min-height:560px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:42px;
}
.project-featured h3,
.project-mini h3{color:#fff}
.project-featured h3{font-size:clamp(2rem,3vw,3.2rem);max-width:760px}
.project-featured p{max-width:720px;color:rgba(255,255,255,.78);font-size:1.08rem}
.home-projects-side{display:grid;gap:24px}
.project-mini{min-height:268px}
.project-mini-content{
  min-height:268px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:26px;
}
.project-mini p{color:rgba(255,255,255,.74);margin-bottom:0}
.home-projects-more{display:flex;justify-content:center;margin-top:30px}
@media(max-width:980px){
  .home-projects-layout{grid-template-columns:1fr}
  .project-featured,
  .project-featured-content{min-height:460px}
}


/* V21 - corrección sección proyectos home */
.home-projects-section{
  overflow:hidden;
}
.home-projects-section .projects-heading{
  max-width:1040px;
  margin-bottom:46px;
}
.home-projects-section .projects-heading h2{
  max-width:940px;
}
.home-projects-section .projects-heading p{
  max-width:880px;
  color:rgba(255,255,255,.74);
  margin:0 0 14px;
}
.projects-showcase{
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);
  grid-template-rows:1fr 1fr;
  gap:24px;
}
.project-main-card,
.project-side-card{
  position:relative;
  overflow:hidden;
  border-radius:30px;
  background:#090b22;
  box-shadow:0 22px 60px rgba(0,0,0,.24);
  min-width:0;
}
.project-main-card{
  grid-row:1 / span 2;
  min-height:620px;
}
.project-side-card{
  min-height:298px;
}
.project-main-card > img,
.project-side-card > img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  opacity:.86;
  transition:transform .45s ease, opacity .45s ease;
}
.project-main-card::after,
.project-side-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(9,11,34,.96),rgba(9,11,34,.62),rgba(9,11,34,.12));
  z-index:1;
}
.project-main-card:hover > img,
.project-side-card:hover > img{
  transform:scale(1.045);
  opacity:1;
}
.project-card-overlay{
  position:relative;
  z-index:2;
  color:#fff;
  height:100%;
  min-height:inherit;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:32px;
}
.project-main-card .project-card-overlay{
  padding:44px;
}
.project-card-overlay h3{
  color:#fff;
  margin-bottom:14px;
}
.project-main-card h3{
  font-size:clamp(2.1rem,3.3vw,3.45rem);
  max-width:780px;
}
.project-card-overlay p{
  color:rgba(255,255,255,.78);
  margin-bottom:0;
}
.project-main-card p{
  max-width:720px;
  font-size:1.08rem;
  margin-bottom:26px;
}
.projects-cta{
  display:flex;
  justify-content:center;
  margin-top:32px;
}

/* neutralizar layouts anteriores de proyectos que pudieran quedar en cascada */
.home-projects-layout,
.home-projects-side{
  display:contents;
}
@media(max-width:980px){
  .projects-showcase{
    grid-template-columns:1fr;
    grid-template-rows:auto;
  }
  .project-main-card{
    grid-row:auto;
    min-height:480px;
  }
  .project-side-card{
    min-height:320px;
  }
}
@media(max-width:640px){
  .project-main-card .project-card-overlay,
  .project-card-overlay{
    padding:26px;
  }
  .project-main-card{
    min-height:520px;
  }
}

/* V22 - Páginas web: CTA en section-head y financiación con icono */
.section-head-actions{margin-top:22px}
.finance-note{display:flex;align-items:center;gap:20px}
.finance-icon{width:64px;height:64px;flex:0 0 64px;display:grid;place-items:center;border-radius:20px;background:#f6f6f6;border:1px solid var(--line)}
.finance-icon img{width:44px;height:44px;object-fit:contain;opacity:.92}
@media(max-width:700px){
  .finance-note{align-items:flex-start}
  .finance-icon{width:54px;height:54px;flex-basis:54px}
  .finance-icon img{width:38px;height:38px}
}


/* V24 - CTA proyectos reales */
.section-head-actions{
  margin-top:28px;
  display:block;
}

.section-head-actions .btn{
  display:inline-flex;
  width:auto;
  min-width:260px;
  justify-content:center;
  padding:18px 42px;
  border-radius:999px;
  font-size:1.05rem;
}


/* V25 - ajuste CTA tipos de web y tarifas premium */
.web-types-head{
  align-items:start;
}
.web-types-copy{
  max-width:680px;
}
.web-types-copy p{
  margin:0;
}
.section-head-actions{
  margin-top:26px;
}
.section-head-actions .cta-inline-arrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  width:auto;
  min-width:0;
  padding:18px 38px;
  border-radius:999px;
  line-height:1;
  white-space:nowrap;
}
.section-head-actions .cta-inline-arrow span{
  display:inline-flex;
  align-items:center;
  line-height:1;
}

/* Planes más premium */
.pricing-grid{
  gap:26px;
}
.price-card{
  position:relative;
  overflow:hidden;
  padding:34px!important;
  border-radius:30px!important;
  border:1px solid rgba(9,11,34,.10)!important;
  box-shadow:0 22px 65px rgba(9,11,34,.08)!important;
}
.price-card::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:6px;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  opacity:.86;
}
.featured-price{
  transform:translateY(-10px);
  box-shadow:0 30px 90px rgba(9,11,34,.16)!important;
}
.plan-topline{
  display:inline-flex;
  align-items:center;
  width:max-content;
  margin-bottom:16px;
  padding:7px 12px;
  border-radius:999px;
  background:#f6f6f6;
  border:1px solid var(--line);
  color:var(--navy);
  font-size:.76rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.price-card h3{
  font-size:1.5rem;
}
.price-card .price{
  position:relative;
  display:flex;
  align-items:flex-end;
  gap:8px;
  margin:24px 0 24px;
}
.price-card .price::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-12px;
  width:72px;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
}
.price-card .checks{
  margin-top:34px;
}
.price-card .checks li{
  font-weight:700;
}
.price-card .btn{
  margin-top:auto;
  width:100%;
}
.featured-price .recommended{
  right:24px;
  top:24px;
}
@media(max-width:900px){
  .featured-price{
    transform:none;
  }
  .web-types-head{
    display:block;
  }
  .web-types-copy{
    margin-top:22px;
  }
}


/* V26 - Slider casos de uso en Programación a medida */
.custom-slider-panel{
  padding:0!important;
  overflow:hidden;
  border:0!important;
  background:#090b22!important;
}
.case-slider{
  position:relative;
  overflow:hidden;
}
.case-slider-track{
  position:relative;
  min-height:620px;
}
.case-slide{
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
  transform:translateX(36px);
  transition:opacity .45s ease, transform .45s ease;
  display:flex;
  flex-direction:column;
}
.case-slide.is-active{
  opacity:1;
  pointer-events:auto;
  transform:translateX(0);
}
.case-slide.is-exiting-left{
  transform:translateX(-36px);
}
.case-slide.is-exiting-right{
  transform:translateX(36px);
}
.case-slide img{
  width:100%;
  height:290px;
  object-fit:cover;
  display:block;
}
.case-slide-content{
  padding:34px 36px 92px;
  color:#fff;
}
.case-slide-label{
  display:inline-flex;
  margin-bottom:14px;
  font-size:.78rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:900;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.case-slide h3{
  color:#fff;
  margin-bottom:14px;
}
.case-slide p{
  color:rgba(255,255,255,.76);
}
.case-slide p strong{
  color:#fff;
}
.case-slider-controls{
  position:absolute;
  left:30px;
  right:30px;
  bottom:28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  z-index:5;
}
.case-slider-btn{
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.10);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:1.25rem;
  font-weight:900;
  cursor:pointer;
  transition:.25s ease;
}
.case-slider-btn:hover{
  background:#fff;
  color:#090b22;
  transform:translateY(-2px);
}
.case-slider-dots{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  flex:1;
}
.case-slider-dots span{
  width:9px;
  height:9px;
  border-radius:999px;
  background:rgba(255,255,255,.28);
  transition:.25s ease;
}
.case-slider-dots span.is-active{
  width:34px;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
}
@media(max-width:900px){
  .case-slider-track{
    min-height:590px;
  }
  .case-slide img{
    height:240px;
  }
  .case-slide-content{
    padding:28px 28px 86px;
  }
}


/* V27 - Slider real en Programación a medida */
.custom-slider-panel{
  padding:0!important;
  overflow:hidden!important;
  border:0!important;
  background:#090b22!important;
}
.case-slider{
  position:relative;
  overflow:hidden;
  border-radius:34px;
}
.case-slider-track{
  position:relative;
  min-height:620px;
}
.case-slide{
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
  transform:translateX(46px);
  transition:opacity .45s ease, transform .45s ease;
  display:flex;
  flex-direction:column;
  background:#090b22;
}
.case-slide.is-active{
  opacity:1;
  pointer-events:auto;
  transform:translateX(0);
}
.case-slide.is-exiting-left{
  opacity:0;
  transform:translateX(-46px);
}
.case-slide.is-exiting-right{
  opacity:0;
  transform:translateX(46px);
}
.case-slide img{
  width:100%;
  height:292px;
  object-fit:cover;
  display:block;
}
.case-slide-content{
  padding:34px 36px 94px;
  color:#fff;
}
.case-slide-label{
  display:inline-flex;
  margin-bottom:14px;
  font-size:.78rem;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:900;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.case-slide h3{
  color:#fff;
  margin-bottom:14px;
}
.case-slide p{
  color:rgba(255,255,255,.76);
}
.case-slide p strong{
  color:#fff;
}
.case-slider-controls{
  position:absolute;
  left:30px;
  right:30px;
  bottom:28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  z-index:5;
}
.case-slider-btn{
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.10);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:1.25rem;
  font-weight:900;
  cursor:pointer;
  transition:.25s ease;
}
.case-slider-btn:hover{
  background:#fff;
  color:#090b22;
  transform:translateY(-2px);
}
.case-slider-dots{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  flex:1;
}
.case-slider-dots span{
  width:9px;
  height:9px;
  border-radius:999px;
  background:rgba(255,255,255,.28);
  transition:.25s ease;
}
.case-slider-dots span.is-active{
  width:34px;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
}
@media(max-width:900px){
  .case-slider-track{min-height:590px}
  .case-slide img{height:240px}
  .case-slide-content{padding:28px 28px 86px}
}

/* V28 - Servicios: iconos sin caja de color y separación con CTA */
.service-list .card{display:flex;flex-direction:column;height:100%}
.service-list .card .checks{margin-bottom:34px}
.service-list .card .btn{margin-top:auto}
.service-list .service-custom-icon{width:86px;height:86px;background:transparent!important;border:0!important;box-shadow:none!important;margin-bottom:22px;display:grid;place-items:center}
.service-list .service-custom-icon img{width:70px;height:70px;object-fit:contain;display:block;opacity:.92}
.service-list .card:hover .service-custom-icon img{transform:translateY(-3px);transition:transform .25s ease}


/* V29 - Servicios: iconos personalizados sin cuadro de color */
.service-list .service-custom-icon{
  width:82px!important;
  height:82px!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  margin-bottom:22px!important;
  display:grid!important;
  place-items:center!important;
  padding:0!important;
  color:inherit!important;
}
.service-list .service-custom-icon img{
  width:68px!important;
  height:68px!important;
  object-fit:contain!important;
  display:block!important;
  opacity:.92!important;
  filter:none!important;
}
.service-list .card{
  display:flex!important;
  flex-direction:column!important;
}
.service-list .card .checks{
  margin-bottom:38px!important;
}
.service-list .card .btn{
  margin-top:auto!important;
}


/* V32 - Servicios reconstruidos y unificados */
.service-list .card{
  display:flex!important;
  flex-direction:column!important;
  height:100%!important;
}

.service-list .service-custom-icon{
  width:82px!important;
  height:82px!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  margin-bottom:22px!important;
  display:grid!important;
  place-items:center!important;
  padding:0!important;
}

.service-list .service-custom-icon img{
  width:68px!important;
  height:68px!important;
  object-fit:contain!important;
  display:block!important;
  opacity:.92!important;
  filter:none!important;
}

.service-list .card .checks{
  margin-bottom:38px!important;
}

.service-list .card .btn{
  margin-top:auto!important;
}

.service-list .card:hover .service-custom-icon img{
  transform:translateY(-3px);
  transition:transform .25s ease;
}


/* V33 - Proyectos con imágenes y popup iframe */
.projects-page-section{
  overflow:hidden;
}
.projects-gallery{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}
.project-card-modal{
  position:relative;
  min-height:390px;
  border:0;
  border-radius:30px;
  overflow:hidden;
  padding:0;
 /* background:#090b22; */
  text-align:left;
  cursor:pointer;
  box-shadow:0 22px 60px rgba(0,0,0,.22);
  color:#fff;
}
.project-card-modal img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .45s ease, opacity .45s ease;
  opacity:.82;
}
.project-card-modal:hover img{
  transform:scale(1.05);
  opacity:1;
}
.project-card-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(9,11,34,.96),rgba(9,11,34,.56),rgba(9,11,34,.14));
}
.project-card-content{
  position:relative;
  z-index:2;
  min-height:390px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:28px;
}
.tituloProyecto{
  display:block;
  color:#fff;
  font-size:1.45rem;
  line-height:1.1;
  margin:12px 0 12px;
}
.project-card-content > span:last-child{
  color:rgba(255,255,255,.78);
  font-size:.98rem;
}
.project-modal{
  position:fixed;
  inset:0;
  z-index:2000;
  display:none;
}
.project-modal.is-open{
  display:block;
}
.project-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(9,11,34,.78);
  backdrop-filter:blur(10px);
}
.project-modal-dialog{
  position:absolute;
  inset:4vh 4vw;
  background:#fff;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 30px 100px rgba(0,0,0,.38);
  display:flex;
  flex-direction:column;
}
.project-modal-header{
  min-height:72px;
  padding:18px 24px;
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.project-modal-header h2{
  margin:0;
  font-size:1.35rem;
}
.project-modal-close{
  width:44px;
  height:44px;
  border-radius:50%;
  border:0;
  background:#090b22;
  color:#fff;
  font-size:1.7rem;
  line-height:1;
  cursor:pointer;
}
.project-modal-body{
  position:relative;
  flex:1;
  background:#f6f6f6;
}
.project-modal-body iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
  background:#fff;
}
.project-modal-empty{
  position:absolute;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  padding:36px;
  text-align:center;
  color:var(--navy);
}
.project-modal-empty p{
  max-width:560px;
  color:var(--muted);
}
.project-modal-empty.is-visible{
  display:flex;
}
body.modal-open{
  overflow:hidden;
}
@media(max-width:980px){
  .projects-gallery{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:680px){
  .projects-gallery{
    grid-template-columns:1fr;
  }
  .project-modal-dialog{
    inset:2vh 3vw;
    border-radius:20px;
  }
}


/* V34 - Nosotros: infografía ligera del colibrí */
.hummingbird-brand{
  position:relative;
  min-height:760px;
  padding:0;
}
.hummingbird-title{
  text-align:center;
  max-width:720px;
  margin:0 auto 18px;
}
.hummingbird-title h3{
  font-size:clamp(1.7rem,2.6vw,2.5rem);
  margin-bottom:10px;
}
.hummingbird-title p{
  color:var(--muted);
  margin:0 auto;
  max-width:640px;
}
.hummingbird-map{
  position:relative;
  min-height:640px;
}
.hummingbird-img{
  position:absolute;
  left:50%;
  top:50%;
  width:min(410px,44vw);
  transform:translate(-50%,-42%);
  filter:drop-shadow(0 22px 44px rgba(9,11,34,.12));
  z-index:3;
}
.hb-callout{
  position:absolute;
  z-index:4;
  width:210px;
  color:var(--navy);
}
.hb-callout strong{
  display:block;
  font-size:1.05rem;
  margin-bottom:6px;
}
.hb-callout span{
  display:block;
  color:#3f4558;
  font-size:.9rem;
  line-height:1.45;
}
.hb-line{
  position:absolute;
  z-index:2;
  height:1px;
  background:#d4d6de;
  transform-origin:left center;
}
.hb-line::after{
  content:"";
  position:absolute;
  right:-1px;
  top:-1px;
  width:1px;
  height:1px;
}
.hb-dot{
  position:absolute;
  z-index:5;
  width:10px;
  height:10px;
  border-radius:50%;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  box-shadow:0 0 0 6px rgba(176,0,154,.09);
}

/* Posiciones desktop */
.hb-callout-1{left:50%;top:42px;transform:translateX(-34%);}
.hb-line-1{left:55%;top:255px;width:118px;transform:rotate(-90deg);}
.hb-dot-1{left:55%;top:178px;}

.hb-callout-2{left:0;top:220px;}
.hb-line-2{left:250px;top:306px;width:142px;transform:rotate(8deg);}
.hb-dot-2{left:238px;top:302px;}

.hb-callout-3{right:0;top:220px;}
.hb-line-3{right:246px;top:307px;width:150px;transform:rotate(174deg);}
.hb-dot-3{right:238px;top:303px;}

.hb-callout-4{right:24px;top:430px;}
.hb-line-4{right:250px;top:500px;width:134px;transform:rotate(180deg);}
.hb-dot-4{right:244px;top:496px;}

.hb-callout-5{left:10px;top:430px;}
.hb-line-5{left:250px;top:500px;width:140px;transform:rotate(0deg);}
.hb-dot-5{left:242px;top:496px;}

.hb-callout-6{right:96px;bottom:0;}
.hb-line-6{right:292px;bottom:122px;width:118px;transform:rotate(160deg);}
.hb-dot-6{right:284px;bottom:118px;}

.hb-callout-7{left:118px;bottom:0;}
.hb-line-7{left:330px;bottom:122px;width:118px;transform:rotate(20deg);}
.hb-dot-7{left:320px;bottom:118px;}

@media(max-width:1100px){
  .hummingbird-brand{
    min-height:auto;
  }
  .hummingbird-map{
    min-height:auto;
    display:grid;
    grid-template-columns:1fr;
    gap:18px;
    padding-top:24px;
  }
  .hummingbird-img{
    position:relative;
    left:auto;
    top:auto;
    transform:none;
    width:min(360px,78vw);
    margin:0 auto 20px;
  }
  .hb-line,.hb-dot{
    display:none;
  }
  .hb-callout{
    position:relative;
    left:auto!important;
    right:auto!important;
    top:auto!important;
    bottom:auto!important;
    transform:none!important;
    width:auto;
    padding:0 0 14px;
    border-bottom:1px solid var(--line);
  }
  .hb-callout:last-child{
    border-bottom:0;
  }
}


/* V35 - Sección Nosotros rediseñada */
.about-section{
  background:#fff;
}
.about-copy h2{
  max-width:650px;
}
.about-values{
  margin-top:32px;
}
.about-image{
  margin:0;
  min-height:520px;
  border-radius:34px;
  overflow:hidden;
  box-shadow:0 30px 80px rgba(9,11,34,.12);
}
.about-image img{
  width:100%;
  height:100%;
  min-height:520px;
  object-fit:cover;
  display:block;
}

.hummingbird-section{
  background:#fff;
  overflow:hidden;
}
.section-head.center{
  text-align:center;
  max-width:940px;
  margin:0 auto 64px;
  display:block;
}
.section-head.center p{
  max-width:760px;
  margin:18px auto 0;
}

.hummingbird-wrapper{
  position:relative;
  min-height:760px;
  max-width:1180px;
  margin:0 auto;
}
.hummingbird-center{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-46%);
  z-index:2;
}
.hummingbird-center img{
  width:min(430px,42vw);
  filter:drop-shadow(0 24px 54px rgba(9,11,34,.13));
  transition:transform .35s ease;
}
.hummingbird-wrapper:hover .hummingbird-center img{
  transform:scale(1.025);
}
.trait{
  position:absolute;
  z-index:4;
  max-width:245px;
}
.trait h3{
  font-size:1.22rem;
  margin:0 0 8px;
}
.trait p{
  color:#4d5366;
  line-height:1.55;
  margin:0;
}
.trait::after{
  content:"";
  position:absolute;
  width:10px;
  height:10px;
  border-radius:50%;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  box-shadow:0 0 0 6px rgba(176,0,154,.08);
}
.trait::before{
  content:"";
  position:absolute;
  height:1px;
  background:#d7d9e1;
}
.trait-inteligencia{
  top:20px;
  left:50%;
  transform:translateX(-50%);
  text-align:center;
}
.trait-inteligencia::before{
  left:50%;
  top:120px;
  width:125px;
  transform:rotate(90deg);
  transform-origin:left center;
}
.trait-inteligencia::after{
  left:50%;
  top:178px;
  transform:translateX(-50%);
}

.trait-adaptabilidad{
  top:210px;
  left:0;
}
.trait-adaptabilidad::before{
  right:-150px;
  top:74px;
  width:140px;
  transform:rotate(8deg);
}
.trait-adaptabilidad::after{
  right:-160px;
  top:78px;
}

.trait-rapidez{
  top:210px;
  right:0;
}
.trait-rapidez::before{
  left:-156px;
  top:74px;
  width:145px;
  transform:rotate(-7deg);
}
.trait-rapidez::after{
  left:-166px;
  top:78px;
}

.trait-precision{
  bottom:205px;
  left:42px;
}
.trait-precision::before{
  right:-150px;
  top:62px;
  width:142px;
  transform:rotate(-2deg);
}
.trait-precision::after{
  right:-160px;
  top:58px;
}

.trait-agilidad{
  bottom:205px;
  right:42px;
}
.trait-agilidad::before{
  left:-150px;
  top:62px;
  width:142px;
  transform:rotate(2deg);
}
.trait-agilidad::after{
  left:-160px;
  top:58px;
}

.trait-cercania{
  bottom:20px;
  left:26%;
}
.trait-cercania::before{
  right:-76px;
  top:54px;
  width:78px;
  transform:rotate(-22deg);
}
.trait-cercania::after{
  right:-86px;
  top:38px;
}

.trait-energia{
  bottom:20px;
  right:24%;
}
.trait-energia::before{
  left:-88px;
  top:54px;
  width:86px;
  transform:rotate(22deg);
}
.trait-energia::after{
  left:-96px;
  top:38px;
}

@media(max-width:1050px){
  .about-image,
  .about-image img{
    min-height:360px;
  }
  .hummingbird-wrapper{
    min-height:auto;
    display:grid;
    gap:22px;
    padding-top:10px;
  }
  .hummingbird-center{
    position:relative;
    left:auto;
    top:auto;
    transform:none;
    order:-1;
    display:flex;
    justify-content:center;
    margin-bottom:20px;
  }
  .hummingbird-center img{
    width:min(360px,80vw);
  }
  .trait{
    position:relative;
    inset:auto!important;
    left:auto!important;
    right:auto!important;
    top:auto!important;
    bottom:auto!important;
    transform:none!important;
    max-width:none;
    padding-bottom:16px;
    border-bottom:1px solid var(--line);
  }
  .trait::before,
  .trait::after{
    display:none;
  }
}


/* V36 - Nosotros final con colibrí limpio y estable */
.about-hero{
  padding-bottom:50px;
}

.about-section{
  background:#fff;
  padding-top:42px;
}

.about-split{
  align-items:center;
  gap:72px;
  padding-bottom:66px;
  border-bottom:1px solid var(--line);
}

.about-copy h2{
  max-width:650px;
}

.about-values{
  margin-top:32px;
}

.about-image{
  margin:0;
  min-height:520px;
  border-radius:34px;
  overflow:hidden;
  box-shadow:0 30px 80px rgba(9,11,34,.12);
  background:#090b22;
}

.about-image img{
  width:100%;
  height:100%;
  min-height:520px;
  object-fit:cover;
  display:block;
}

.hummingbird-section{
  background:#fff;
  overflow:hidden;
  padding-top:66px;
}

.hummingbird-head{
  text-align:center!important;
  max-width:920px!important;
  margin:0 auto 28px!important;
  display:block!important;
}

.hummingbird-head p{
  max-width:760px;
  margin:16px auto 0!important;
}

.hummingbird-infographic{
  position:relative;
  max-width:1160px;
  height:690px;
  margin:0 auto;
}

.hummingbird-center{
  position:absolute!important;
  left:50%!important;
  top:51%!important;
  transform:translate(-50%,-50%)!important;
  z-index:3;
  display:block!important;
}

.hummingbird-center img{
  width:500px!important;
  max-width:46vw;
  filter:drop-shadow(0 28px 60px rgba(9,11,34,.14));
  transition:transform .35s ease;
}

.hummingbird-infographic:hover .hummingbird-center img{
  transform:scale(1.025);
}

.hummingbird-infographic .trait{
  position:absolute!important;
  z-index:4;
  max-width:230px;
  color:var(--navy);
  border:0!important;
  padding:0!important;
  transform:none!important;
}

.hummingbird-infographic .trait h3{
  font-size:1.15rem;
  line-height:1.15;
  margin:0 0 7px;
  color:var(--navy);
}

.hummingbird-infographic .trait p{
  font-size:.92rem;
  line-height:1.45;
  margin:0;
  color:#4d5366;
}

.trait-line{
  position:absolute;
  display:block;
  height:1px;
  background:#d8dbe4;
  z-index:1;
}

.trait-dot{
  position:absolute;
  display:block;
  width:10px;
  height:10px;
  border-radius:50%;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  box-shadow:0 0 0 7px rgba(176,0,154,.08);
  z-index:2;
}

/* Posicionamiento final, más compacto y ordenado */
.trait-inteligencia{
  left:50%!important;
  top:22px!important;
  width:220px;
  text-align:center;
  transform:translateX(-50%)!important;
}
.trait-inteligencia .trait-line{
  left:50%;
  top:92px;
  width:112px;
  transform:rotate(90deg);
  transform-origin:left center;
}
.trait-inteligencia .trait-dot{
  left:50%;
  top:156px;
  transform:translateX(-50%);
}

.trait-adaptabilidad{
  left:88px!important;
  top:206px!important;
  text-align:right;
}
.trait-adaptabilidad .trait-line{
  right:-168px;
  top:47px;
  width:150px;
  transform:rotate(0deg);
}
.trait-adaptabilidad .trait-dot{
  right:-178px;
  top:42px;
}

.trait-rapidez{
  right:84px!important;
  top:206px!important;
  text-align:left;
}
.trait-rapidez .trait-line{
  left:-168px;
  top:47px;
  width:150px;
  transform:rotate(0deg);
}
.trait-rapidez .trait-dot{
  left:-178px;
  top:42px;
}

.trait-precision{
  left:122px!important;
  top:428px!important;
  text-align:right;
}
.trait-precision .trait-line{
  right:-158px;
  top:43px;
  width:140px;
}
.trait-precision .trait-dot{
  right:-168px;
  top:38px;
}

.trait-agilidad{
  right:122px!important;
  top:428px!important;
  text-align:left;
}
.trait-agilidad .trait-line{
  left:-158px;
  top:43px;
  width:140px;
}
.trait-agilidad .trait-dot{
  left:-168px;
  top:38px;
}

.trait-cercania{
  left:266px!important;
  bottom:28px!important;
  text-align:right;
}
.trait-cercania .trait-line{
  right:-126px;
  top:34px;
  width:116px;
  transform:rotate(-18deg);
}
.trait-cercania .trait-dot{
  right:-136px;
  top:15px;
}

.trait-energia{
  right:258px!important;
  bottom:28px!important;
  text-align:left;
}
.trait-energia .trait-line{
  left:-126px;
  top:34px;
  width:116px;
  transform:rotate(18deg);
}
.trait-energia .trait-dot{
  left:-136px;
  top:15px;
}

/* Anular restos de versiones anteriores del colibrí */
.hummingbird-map,
.hummingbird-brand,
.hb-callout,
.hb-line,
.hb-dot{
  display:none!important;
}

@media(max-width:1050px){
  .about-split{
    gap:34px;
    padding-bottom:48px;
  }
  .about-image,
  .about-image img{
    min-height:360px;
  }

  .hummingbird-infographic{
    height:auto;
    display:grid;
    grid-template-columns:1fr;
    gap:18px;
    padding-top:10px;
  }

  .hummingbird-center{
    position:relative!important;
    left:auto!important;
    top:auto!important;
    transform:none!important;
    display:flex!important;
    justify-content:center;
    order:-1;
    margin:6px auto 22px;
  }

  .hummingbird-center img{
    width:min(400px,82vw)!important;
    max-width:none;
  }

  .hummingbird-infographic .trait{
    position:relative!important;
    inset:auto!important;
    left:auto!important;
    right:auto!important;
    top:auto!important;
    bottom:auto!important;
    width:auto!important;
    max-width:none!important;
    text-align:left!important;
    padding:0 0 16px!important;
    border-bottom:1px solid var(--line)!important;
  }

  .trait-line,
  .trait-dot{
    display:none!important;
  }
}


/* V37 - Nosotros: colibrí limpio sin líneas ni puntos desordenados */
.hummingbird-infographic{
  height:620px!important;
  max-width:1120px!important;
  margin:0 auto!important;
}

.hummingbird-center{
  left:50%!important;
  top:50%!important;
  transform:translate(-50%,-50%)!important;
}

.hummingbird-center img{
  width:560px!important;
  max-width:48vw!important;
}

/* Quitamos líneas y puntos para dejar la composición limpia y estable */
.trait-line,
.trait-dot,
.hummingbird-infographic .trait::before,
.hummingbird-infographic .trait::after{
  display:none!important;
}

/* Redistribución limpia de los textos alrededor del colibrí */
.hummingbird-infographic .trait{
  max-width:230px!important;
  padding:0!important;
  border:0!important;
}

.trait-inteligencia{
  left:50%!important;
  top:0!important;
  transform:translateX(-50%)!important;
  text-align:center!important;
}

.trait-adaptabilidad{
  left:40px!important;
  top:190px!important;
  text-align:right!important;
}

.trait-rapidez{
  right:40px!important;
  top:190px!important;
  text-align:left!important;
}

.trait-precision{
  left:92px!important;
  top:405px!important;
  text-align:right!important;
}

.trait-agilidad{
  right:92px!important;
  top:405px!important;
  text-align:left!important;
}

.trait-cercania{
  left:290px!important;
  bottom:0!important;
  text-align:center!important;
}

.trait-energia{
  right:290px!important;
  bottom:0!important;
  text-align:center!important;
}

@media(max-width:1050px){
  .hummingbird-infographic{
    height:auto!important;
    display:grid!important;
    gap:18px!important;
  }

  .hummingbird-center{
    position:relative!important;
    left:auto!important;
    top:auto!important;
    transform:none!important;
    order:-1!important;
    margin:0 auto 20px!important;
  }

  .hummingbird-center img{
    width:min(420px,82vw)!important;
    max-width:none!important;
  }

  .hummingbird-infographic .trait{
    position:relative!important;
    left:auto!important;
    right:auto!important;
    top:auto!important;
    bottom:auto!important;
    transform:none!important;
    text-align:left!important;
    max-width:none!important;
    padding-bottom:16px!important;
    border-bottom:1px solid var(--line)!important;
  }
}


/* V38 - Nosotros: colibrí limpio con textos a la izquierda e imagen a la derecha */
.hummingbird-clean-section{
  background:#fff!important;
  overflow:hidden;
  padding-top:70px;
  padding-bottom:86px;
}

.hummingbird-clean{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);
  gap:72px;
  align-items:center;
}

.hummingbird-clean-copy h2{
  max-width:620px;
}

.hummingbird-clean-copy > p{
  max-width:720px;
  margin-bottom:34px;
}

.hummingbird-values-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px 34px;
}

.hummingbird-values-grid article{
  position:relative;
  padding-left:20px;
}

.hummingbird-values-grid article::before{
  content:"";
  position:absolute;
  left:0;
  top:.58em;
  width:8px;
  height:8px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--grad-a),var(--grad-b),var(--grad-c));
  box-shadow:0 0 0 6px rgba(176,0,154,.08);
}

.hummingbird-values-grid h3{
  font-size:1.08rem;
  margin:0 0 6px;
  color:var(--navy);
}

.hummingbird-values-grid p{
  margin:0;
  color:#4d5366;
  line-height:1.45;
  font-size:.94rem;
}

.hummingbird-clean-image{
  min-height:560px;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}

.hummingbird-clean-image::before{
  content:"";
  position:absolute;
  width:560px;
  height:560px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(176,0,154,.08),rgba(255,255,255,0) 62%);
  z-index:0;
}

.hummingbird-clean-image img{
  position:relative;
  z-index:1;
  width:min(560px,42vw);
  filter:drop-shadow(0 30px 70px rgba(9,11,34,.14));
  animation:hummingbirdFloat 6s ease-in-out infinite;
}

@keyframes hummingbirdFloat{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-10px) rotate(.6deg)}
}

/* Anular definitivamente restos de la infografía anterior */
.hummingbird-infographic,
.hummingbird-wrapper,
.hummingbird-map,
.hummingbird-brand,
.trait-line,
.trait-dot,
.hb-line,
.hb-dot,
.hb-callout{
  display:none!important;
}

@media(max-width:1050px){
  .hummingbird-clean{
    grid-template-columns:1fr;
    gap:38px;
  }

  .hummingbird-clean-image{
    order:-1;
    min-height:auto;
  }

  .hummingbird-clean-image img{
    width:min(430px,82vw);
  }

  .hummingbird-clean-image::before{
    width:420px;
    height:420px;
  }
}

@media(max-width:680px){
  .hummingbird-values-grid{
    grid-template-columns:1fr;
  }
}


/* V39 - Nosotros: frame "Cómo trabajamos" con fondo blanco uniforme */
.process-clean-section{
  background:#fff!important;
  position:relative;
  overflow:hidden;
}

.process-clean-section::before,
.process-clean-section::after{
  display:none!important;
  content:none!important;
  background:none!important;
}

.process-clean-section .section-head,
.process-clean-section .grid,
.process-clean-section .card{
  position:relative;
  z-index:1;
}

.process-clean-section .card{
  background:#fff;
}


/* V40 - Contacto: datos directos y legal formulario */
.contact-quick-section{
  background:#fff;
  padding-bottom:42px;
}

.contact-cards{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}

.contact-card{
  display:block;
  text-decoration:none;
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:30px;
  box-shadow:0 18px 54px rgba(9,11,34,.06);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.contact-card:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 70px rgba(9,11,34,.11);
  border-color:rgba(176,0,154,.22);
}

.contact-card span{
  display:block;
  color:var(--muted);
  font-weight:800;
  font-size:.9rem;
  margin-bottom:10px;
}

.contact-card strong{
  display:block;
  color:var(--navy);
  font-size:1.28rem;
  line-height:1.2;
}

.form-check{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin:20px 0 18px;
  color:var(--muted);
  font-size:.94rem;
  line-height:1.45;
}

.form-check input{
  margin-top:4px;
  width:18px;
  height:18px;
  accent-color:#c4009f;
  flex:0 0 auto;
}

.form-check a{
  color:var(--navy);
  font-weight:900;
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:3px;
}

.form-legal{
  margin:14px 0 0;
  color:var(--muted);
  font-size:.86rem;
  line-height:1.55;
}

@media(max-width:820px){
  .contact-cards{
    grid-template-columns:1fr;
  }
}


/* V41 - Contacto: datos junto al formulario */
.contact-quick-section{
  display:none!important;
}

.contact-inline-details{
  margin-top:34px;
  display:grid;
  gap:16px;
}

.contact-inline-details h3{
  font-size:1.25rem;
  margin:0 0 4px;
  color:var(--navy);
}

.contact-inline-item{
  display:flex;
  align-items:center;
  gap:16px;
  padding:18px 20px;
  border:1px solid var(--line);
  border-radius:22px;
  background:#fff;
  text-decoration:none;
  box-shadow:0 14px 40px rgba(9,11,34,.045);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.contact-inline-item:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 55px rgba(9,11,34,.09);
  border-color:rgba(176,0,154,.22);
}

.contact-inline-item img{
  width:38px;
  height:38px;
  object-fit:contain;
  flex:0 0 38px;
}

.contact-inline-item span{
  display:grid;
  gap:2px;
}

.contact-inline-item small{
  color:var(--muted);
  font-weight:800;
  font-size:.82rem;
}

.contact-inline-item strong{
  color:var(--navy);
  font-size:1.08rem;
  line-height:1.2;
}


/* V42 - Validación y resultado formulario */
.contact-form .is-invalid{
  border-color:#c4009f!important;
  box-shadow:0 0 0 4px rgba(196,0,159,.10)!important;
}

.field-error{
  margin:8px 0 0;
  color:#b0007f;
  font-size:.84rem;
  line-height:1.4;
  font-weight:700;
}

.form-result{
  margin-top:22px;
  padding:24px;
  border-radius:24px;
  border:1px solid var(--line);
  background:#fff;
}

.form-result strong{
  display:block;
  color:var(--navy);
  font-size:1.25rem;
  margin-bottom:8px;
}

.form-result p{
  margin:0;
  color:var(--muted);
  line-height:1.55;
}

.form-result.success{
  border-color:rgba(0,160,110,.22);
  background:linear-gradient(180deg,#ffffff,#f2fff9);
}

.form-result.error{
  border-color:rgba(196,0,159,.22);
  background:linear-gradient(180deg,#ffffff,#fff5fc);
}

.contact-form button[disabled]{
  opacity:.72;
  cursor:not-allowed;
}

  .form-row--hp {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
  }

  .form-feedback {
    padding: 1rem;
    border-left: 4px solid var(--pm-blue);
    background: var(--pm-blue-soft);
    color: var(--pm-navy);
    font-weight: 700;
  }

  .form-feedback.is-error {
    border-left-color: #b42318;
    background: #fff1f0;
    color: #8a1f15;
  }

  .form-feedback.is-success {
    border-left-color: #2f7d32;
    background: #eef8ef;
    color: #1e5b22;
  }