@import url('https://fonts.googleapis.com/css2?family=Archivo+Black&family=Boldonse&display=swap');

:root{
  --bg:#0b1020;
  --bg2:#0f1733;
  --fg:#e9eefc;
  --muted:#b8c2e3;
  --card:#111a38cc;
  --stroke:#26315f;
  --accent:#c0b5eb;
  --accent2:#37abe9;
  --shadow: 0 20px 60px rgba(0,0,0,.35);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color:var(--fg);
  background: linear-gradient(180deg, var(--bg), #070a14);
  overflow-x:hidden;
}

.container{ width:min(1100px, calc(100% - 40px)); margin:0 auto; }

.topbar{
  position:sticky; top:0; z-index:50;
  background: rgba(5,8,18,.6);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar--v3{
  background: rgba(5,8,18,.72);
}
.brand__sub{ font-weight:500; opacity:.7; }
.topbar__inner{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 0; }
.brand{ font-weight:700; letter-spacing:.3px; }
.nav{ display:flex; gap:14px; flex-wrap:wrap; }
.nav a{ color:var(--muted); text-decoration:none; font-size:14px; padding:6px 10px; border-radius:999px; }
.nav a:hover{ background: rgba(255,255,255,.06); color: var(--fg); }

/* Hamburger button */
.nav__burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 38px;
  height: 38px;
  padding: 6px;
  background: none;
  border: none;
  cursor: pointer;
  border-radius: 8px;
}
.nav__burger span {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--muted);
  border-radius: 2px;
  transition: transform 0.25s, opacity 0.25s;
}
.nav__burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2) { opacity: 0; }
.nav__burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 700px) {
  .nav__burger { display: flex; }

  .nav {
    display: none;
    position: absolute;
    top: calc(100% - 20px);
    right: 0;
    flex-direction: column;
    gap: 2px;
    width: 50px;
    min-width: 140px;
    text-align: center;
    padding: 8px;
    border-radius: 14px;
    background:  var(--fg);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(207, 205, 205, 0.8);
    box-shadow: 0 8px 28px rgba(61,90,191,.14);
    z-index: 100;
  }
  .nav.is-open { display: flex;
  justify-content: center; align-items: center; }

  .nav a {
    font-size: 15px;
    padding: 10px 10px;
    border-radius: 10px;
    color: #1f2f57;
    white-space: nowrap;
  }
  .nav a:hover { background: rgba(139,124,255,.1); }

  .nav__cta {
    margin-top: 4px;
    text-align: center;
  }
}

.section{ position:relative; padding:44px 0; }

@media (max-width: 600px) {
  .section { padding: 24px 0; }
}
.section--dark{ background: linear-gradient(180deg, #070a14, #060818); }

.hero {
  position: relative;
  overflow: hidden;
  min-height: calc(100vh - 70px);
}

.hero__content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;  /* kicker arriba, kpi abajo */
  width: 100%;
  min-height: 76vh;
  padding: 24px 0 36px;
}
.hero h1{ font-size: clamp(24px, 5vw, 58px); line-height:1.1; margin:0 0 12px; }

@media (max-width: 600px) {
  .hero h1 { font-size: clamp(22px, 7vw, 34px); margin-bottom: 8px; }
}
.hero p{ max-width:60ch; margin:0 0 18px; }

.kicker{
   display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;

  font-size: 15.8px;
  font-weight: 500;
  letter-spacing: 0.4px;

  color: #ffffff;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(6px);

  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;

  padding: 8px 16px;
  /* margin-bottom: 598px; */
  width: max-content;
  max-width: 100%;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
}

.mt-p{
  margin-top: 136px;
}

@media (max-width: 600px) {
  .kicker {
    font-size: 14px;
    padding: 6px 12px;
    border-radius: 12px;
    width: 100%;
    text-align: center;
    justify-content: center;
  }

  .mt-p{
    margin-top: 0px;
  }
}



.hero__buttons_{
display: flex;
  gap: 12px;
  z-index: 800;
  margin-top: -340px;
}

.wsp-float{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:1000;
  transition:.2s;
}

.wsp-float img{
  width:50px;
  height:50px;
}

.wsp-float:hover{
  transform:scale(1.08);
}

/* footer */
.footer{
  margin-top:40px;
  padding:10px 0;
  /* border:1px solid rgb(0, 0, 0); */
  font-size:1.2rem;
  background:  rgba(255, 255, 255, 0.62);
}

.footer__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.footer__left{
  display:flex;
  align-items:center;
  gap:8px;
  color:#080808;
}

.footer__sep{
  opacity:.5;
}

.footer__right{
  display:flex;
  align-items:center;
}

.footer__icon{
  width:26px;
  height:26px;
  opacity:.7;
  transition:.2s;
}

.footer__icon:hover{
  opacity:1;
  transform:scale(1.1);
}

@media (max-width: 600px) {
  .footer {
    font-size: 0.85rem;
    padding: 16px 0 24px;
  }
  .footer__inner {
    flex-direction: column;
    align-items: center;
    gap: 12px;
    text-align: center;
  }
  .footer__left {
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
  }
  .footer__left .brand__logo {
    width: 28px !important;
    height: auto !important;
  }
  .footer__sep {
    display: none;
  }
}

/* Form feedback + spinner */
.btn__spinner[hidden] { display: none !important; }
.btn__spinner {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  vertical-align: middle;
  margin-left: 6px;
}
@keyframes spin { to { transform: rotate(360deg); } }

#formFeedback {
  margin-top: .8rem;
  padding: .75rem 1rem;
  border-radius: 12px;
  font-weight: 600;
  font-size: .95rem;
}
#formFeedback.success {
  background: #e7fbf2;
  color: #0e7f4f;
  border: 1px solid #a3e9c8;
}
#formFeedback.error {
  background: #fff0f0;
  color: #c0392b;
  border: 1px solid #f5b7b1;
}
.lead{ 
  /* max-width: 70ch; */

  font-size: 17px;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0.3px;

  color: #111;
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(6px);

  padding: 14px 20px;
  border-radius: 20px;

  border: 1px solid rgba(255, 255, 255, 0.4);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);}
.hero__proof{ display:flex; gap:10px; flex-wrap:wrap; margin-top: 18px; }
.proof{
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: 10px 12px;
  min-width: 150px;
}
.proof__n{ font-weight: 800; letter-spacing:.2px; }
.proof__t{ color: rgba(233,238,252,.68); font-size: 13px; margin-top: 4px; }

.split{ display:grid; grid-template-columns: 1.2fr .8fr; gap: 16px; align-items:start; }
@media (max-width: 1000px){ .split{ grid-template-columns: 1fr; } }

.panel{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  padding: 16px;
}

.bullets{ display:grid; grid-template-columns: 1fr; gap: 12px; margin-top: 14px; }
.bullet{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  padding: 14px;
}
.bullet h3{ margin:0 0 6px; }

.icon{
  width: 18px;
  height: 18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  vertical-align: -3px;
  margin-right: 8px;
  opacity: .95;
}
.icon svg{ width:100%; height:100%; }

.icon--lg{ width:42px; height:42px; margin-right:0; }

.card__media{
  width:56px;
  height:56px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background: radial-gradient(120% 120% at 20% 20%, rgba(124,58,237,.22), rgba(34,211,238,.10) 55%, rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.08);
  margin-bottom: .8rem;
}

.ancor-card-solution{
  text-decoration: none;
  color: inherit;
}

.btn--sm{ padding: 8px 12px; border-radius: 10px; font-size: 13px; }
.hero__buttons{ display:flex; 
  gap:12px; flex-wrap:wrap; 
  margin:20px 0 0; 
  position: absolute;
  bottom: 20px;
}

.hero__buttons2{ display:flex;
  gap:12px; flex-wrap:wrap;
  margin-top: auto;
  padding-top: 16px;
}

.hint{ margin-top:16px; font-size:13px; opacity:.85; }

.btn{
  display:inline-block;
  padding: 11px 16px;
  border-radius: 12px;
  text-decoration:none;
  color: #fff;
  background: linear-gradient(90deg, #60a5fa, #0284c7);
  /* box-shadow: var(--shadow); */
  border: 1px solid rgba(255,255,255,.15);
}


.btn-vertical{
  position: absolute;
  display:inline-block;
  padding: 11px 16px;
  border-radius: 12px;
  text-decoration:none;
  width: 140px;
  box-shadow: 0 4px 12px rgba(80, 110, 210, 0.25);
  top: 430px;
  background: rgba(255, 255, 255, .80);
  color: #203056;
  border: 1px solid rgba(95, 120, 200, .18);
  transition: transform .16s ease, box-shadow .16s ease;
}

.cases{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
  align-items: stretch; /* 👈 clave */
}

.cases > * {
  height: 100%;
}
@media (max-width: 1000px){
  .cases{ grid-template-columns: 1fr; }
}

.ccard__body{ 
  padding: 16px;
  display: flex;
  flex-direction: column;
  height: 350px; /* 👈 importante */
}

.btn-vertical2{
  margin-top: auto; /* 👈 esto lo empuja al fondo */

  display: inline-block;
  padding: 11px 16px;
  border-radius: 12px;
  text-decoration: none;
  align-self: flex-start; 
  box-shadow: 0 4px 12px rgba(80, 110, 210, 0.25);
  background: rgba(255, 255, 255, .80);
  color: #203056;
  border: 1px solid rgba(95, 120, 200, .18);
  transition: transform .16s ease, box-shadow .16s ease;
}
.btn-vertical:hover, .btn-vertical2:hover{ 
  display:inline-block;
  padding: 11px 16px;
  border-radius: 12px;
  text-decoration:none;
  color: #fff;
  background: linear-gradient(90deg, #60a5fa, #6fc9f7);
  box-shadow: var(--shadow);
  border: 1px solid rgb(255, 255, 255);
  transform: translateY(-1px); box-shadow: 0 14px 24px rgba(80,110,210,.3);
}

.mini-model-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap:.9rem; 
}

@media (max-width: 1024px) {
  .mini-model-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .mini-model-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .mini-model-grid {
    grid-template-columns: 1fr;
  }
}

#scrollUpBtn {
  position: fixed;
  bottom: 30px;
  left: 30px;
  z-index: 1000;

  padding: 8px 14px;
  font-size: 23px;
  border: none;
  border-radius: 8px;
  cursor: pointer;

  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  background: linear-gradient(90deg, #60a5fa, #0284c7);
  color: white;
}

#scrollUpBtn:active {
  background: #fff;
  color: #0284c7;
  border: 2px solid #0284c7;
}

#scrollUpBtn.show {
  opacity: 1;
  pointer-events: auto;
}

.photo-comment-home{
  height: 550px;
  width: 650px;
  margin-bottom: 20px;
  border-radius: 8px;
}

.photo-comment-home-2 {
    height: 550px;
    /* width: 650px; */
    margin-bottom: 20px;
    border-radius: 8px;
    background-color: #050715;
}

.mini-model {
  height: auto; 
  padding: .9rem;
  border-radius: 14px;
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(255,255,255,.8);
  box-shadow: 0 10px 24px rgba(61,90,191,.12);
  display: flex;
  flex-direction: column; 
}


.btn-pdf-download{  
  padding: 11px 16px;
  border-radius: 12px;
  text-decoration:none;
  box-shadow: 0 3px 30px rgba(0, 0, 0, 0.13);
  background: rgba(255, 255, 255, .80);
  color: #203056;
  border: 2px solid rgba(95, 120, 200, .18);
  margin-top: auto;
}

.btn-pdf-download:hover{ 
  display:inline-block;
  padding: 11px 16px;
  border-radius: 12px;
  text-decoration:none;
  color: #fff;
  background: linear-gradient(90deg, #60a5fa, #6fc9f7);
  box-shadow: var(--shadow);
  border: 1px solid rgb(255, 255, 255);
}

.btn--ghost{
  background: rgba(255,255,255,.04);
  box-shadow:none;
  color: #000;
  border: 1px solid #000;
}

.btn--ghost:hover{
color: #ffffff;
background: linear-gradient(90deg, #60a5fa, #0284c7);
}

.grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 28px;
}
@media (max-width: 900px){
  .grid{ grid-template-columns:1fr; }
}

.card{
  /* background: var(--card); */
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  padding: 18px;
    box-shadow: 0 12px 32px rgba(61, 90, 191, 0.14);
}
.card h3{ margin: 0 0 8px; }
.card p{ margin:0; color:var(--muted); }

.card2{
  background: var(--card);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  box-shadow: 0 12px 32px rgba(61, 90, 191, 0.14);

}

.card-testemol{
  background: rgba(255, 255, 255, .58);
  padding: 20px;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 18px;
  box-shadow: 0 4px 12px rgba(61, 90, 191, 0.14);
}

.card-testemol2{
  background: rgba(255, 255, 255, .58);
  padding: 10px;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 18px;
  box-shadow: 0 4px 12px rgba(61, 90, 191, 0.14);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}


.p-comment{
  margin-top: -10px;
  font-size: 16px;
  margin-left: 65px;
}

.name-user-comment{
  color: #0284c7;
  font-size: 18px;
}

.p-rol{
  color: #526e7c;
  font-size: 13px;
}

.bullets {
  margin-top: 16px;
  /* padding-left: 20px; */
}

.bullets li {
  margin-bottom: 10px;
  line-height: 1.5;
}

.parallax{
  /* position:absolute; */
  inset:0;
  pointer-events:none;
  overflow:hidden;
}


.parallax__layer{
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  position:absolute;
  /* inset:-20% -15% -20% -15%; */
  transform: translate3d(0,0,0);
  will-change: transform;
  background:
    radial-gradient(1200px 600px at 20% 30%, rgba(124,92,255,.35), transparent 60%),
    radial-gradient(900px 500px at 80% 40%, rgba(39,224,255,.22), transparent 65%),
    radial-gradient(700px 420px at 60% 80%, rgba(255,255,255,.10), transparent 70%);
}
.parallax__layer--glow{
  opacity:.7;
  filter: blur(20px) saturate(120%);
  overflow:hidden;
}
.parallax--image{
  /* position:relative; */
  /* height: 200px; */
  margin: 18px 0 0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}
.parallax--image .parallax__layer{
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), transparent),
    radial-gradient(900px 420px at 30% 40%, rgba(124,92,255,.28), transparent 65%),
    radial-gradient(800px 420px at 70% 55%, rgba(39,224,255,.20), transparent 65%),
    repeating-linear-gradient(45deg, rgba(255,255,255,.05), rgba(255,255,255,.05) 2px, transparent 2px, transparent 12px);
}

.parallax--hero .parallax__layer {
    /* position: absolute; */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; 
background-repeat: no-repeat;
     background-size: cover !important; 
  background-position: center 27%!important;
  overflow:hidden;
}

.parallax--hero {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 10;
  display: flex;
  align-items: flex-end;
  padding-bottom: 32px;
  pointer-events: none;
}

.hero__overlay-inner {
  pointer-events: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
}

.section-op {
    margin-top: 30px;
  }

/* Mobile */
@media (max-width: 768px) {
  .parallax--hero {
    aspect-ratio: 16 / 9;

  }
}

/* Desktop grande */
/* @media (min-width: 1000px) {
  .parallax--hero {
    height: 76.5vh;
  }

  .section-op {
    margin-top: 95px;
  }
}

@media (min-width: 1700px) {
  .parallax--hero {
    height: 88.4vh;
  }

  .section-op {
    margin-top: 45px;
  }
}

@media (min-width: 2000px) {
  .parallax--hero {
    height: 72.3vh;
  }

  .section-op {
    margin-top: 30px;
  }
} */

.video-wrap{
  position:relative;
  height: 380px;
  margin: 22px 0 0;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.video-wrap__media{
  position:absolute; inset:0;
  display:grid; place-items:center;
  background: linear-gradient(180deg, #0a0f22, #050715);
}
.video-placeholder{
  width:min(720px, calc(100% - 40px));
  height:min(240px, calc(100% - 90px));
  border-radius: 18px;
  border: 1px dashed rgba(255,255,255,.22);
  display:grid; place-items:center;
  color: rgba(233,238,252,.65);
  letter-spacing: .32em;
  font-weight: 700;
}
.parallax--video .parallax__layer{ opacity:.55; }
.parallax__layer--noise{
  opacity:.18;
  background:
    radial-gradient(900px 450px at 35% 35%, rgba(124,92,255,.30), transparent 62%),
    radial-gradient(900px 450px at 70% 55%, rgba(39,224,255,.22), transparent 62%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  background-size: auto, auto, 160px 160px;
  mix-blend-mode: overlay;
}

.cta{ text-align:center; }
.small{ color: var(--muted); font-size: 13px; }

.footer{
  padding: 24px 0 40px;
  color: rgba(0,0,0,.60);
}

/* Reduce motion: disable parallax */
@media (prefers-reduced-motion: reduce){
  .parallax__layer{ transform:none !important; }
}

/* -----------------------------
   Lightbox
   ----------------------------- */

.lb-lock{ overflow: hidden; }

.lightbox{
  position: fixed;
  inset: 0;
  z-index: 200;
  display: none;
}
.lightbox.is-open{ display:block; }
.lightbox__backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(6px);
}
.lightbox__dialog{
  position:absolute;
  inset: 0;
  display:grid;
  place-items:center;
  padding: 24px;
}
.lightbox__close{
  position: absolute;
  top: 18px;
  right: 18px;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--fg);
  font-size: 26px;
  cursor:pointer;
}
.lightbox__img {
  width: min(1100px, calc(100vw - 60px));
  aspect-ratio: 16 / 9;

  object-fit: cover;

  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
}
.lightbox__caption{
  margin-top: 12px;
  color: rgba(233,238,252,.75);
  font-size: 13px;
  max-width: min(1100px, calc(100vw - 60px));
}


.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(233,238,252,.78);
  font-size: 13px;
  margin-bottom: 14px;
}

.muted{ color: var(--muted); }
.nav__cta{ border:1px solid rgba(255,255,255,.12); }

.hero--v2 .parallax__layer{
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.vertical-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
@media (max-width: 1000px){
  .vertical-grid{ grid-template-columns: 1fr; }
}


.vcard{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}
.vcard__img{ height: 160px; background-size: cover; background-position:center; filter: saturate(110%); }
.vcard__img--illu{
  filter:none;
  background:
    radial-gradient(900px 240px at 20% 30%, rgba(124,92,255,.30), transparent 60%),
    radial-gradient(700px 220px at 75% 55%, rgba(39,224,255,.22), transparent 65%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}

/* vertical variants */
.vcard--food .vcard__img--illu{ background:
  radial-gradient(900px 240px at 22% 35%, rgba(255,196,61,.18), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(39,224,255,.18), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
}
.vcard--hotel .vcard__img--illu{ background:
  radial-gradient(900px 240px at 25% 40%, rgba(39,224,255,.26), transparent 62%),
  radial-gradient(900px 260px at 75% 60%, rgba(124,92,255,.26), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
}
.vcard--stations .vcard__img--illu{ background:
  radial-gradient(900px 240px at 25% 40%, rgba(34,211,238,.18), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(16,185,129,.14), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
}
.vcard--health .vcard__img--illu{ background:
  radial-gradient(900px 240px at 30% 40%, rgba(124,92,255,.30), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(0,255,198,.16), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
}
.vcard--industry .vcard__img--illu{ background:
  radial-gradient(900px 240px at 25% 40%, rgba(124,92,255,.26), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(255,255,255,.14), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
}
.vcard__body{
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  /* gap: 6px; */
  height: 326px;
}
.vcard__body h3{ margin:0 0 8px; 
  font-size: 17px;
}

.products{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
@media (max-width: 1000px){
  .products{ grid-template-columns: 1fr; }
}

.pcard{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}
.pcard__img{
  height: 220px;
  background: rgba(0,0,0,.18);
  display:block;
}
.pcard__imgEl{
  width:100%;
  height:100%;
  display:block;
  object-fit: cover;
  object-position: center;
}
.pcard__body{
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: 445px;
  background-color: #fff;
}

.pcard__body2{
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: 536px;
  background-color: #fff;
}


.limpieza-layout {
display: flex;
  align-items: flex-start;
  gap: 40px;
}


.limpieza-media {
  flex: 1;
}

.limpieza-text {
  flex: 1;
  justify-content: flex-start;
  margin-top: 20px;
font-family: "Archivo Black", sans-serif;
  font-weight: 500;
  letter-spacing: 0.3px;
  font-size: 25px;
  text-transform: uppercase;
}

.limpieza-media img,
.limpieza-media video {
  width: 100%;
  height: 100%;
  max-height: 620px;
  object-fit: cover;
  border-radius: 16px;
  
}

/* responsive */
@media (max-width: 768px) {
  .limpieza-layout {
    flex-direction: column;
  }
}

.partners-div{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: 20px;
  background: #fff;
  padding: 10px;
  margin-bottom: 15px;
}

.p-1er-partner{
  font-weight: bolder;
  color: #080808;
  font-size: 17px;
  margin-bottom: -4px;
}

.p-2do-partner{
  font-weight: bolder;
  background: linear-gradient(to right, #6d6b6b 76%, #4289f3 21%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-size: 17px;
  margin-top: -4px;
}

.img-logo-paartner{
  width: auto;
  height: 220px;
}

.img-keenon-paartner{
  width: 420px;
  height: auto;
}

@media (max-width: 600px) {
  .partners-div {
    flex-direction: column;
    text-align: center;
    gap: 6px;
    padding: 16px 12px;
  }
  .img-logo-paartner {
    height: 100px;
    margin-bottom: -14px;
  }
  .img-keenon-paartner {
    width: 100%;
    max-width: 230px;
  }
  .p-1er-partner,
  .p-2do-partner {
    font-size: 14px;
  }
}

.list__item--small {
  font-size: 14px;
  padding: 1px 0;
}

.pcard__body p{
  margin-top: 0;
}

.pcard__top{ display:flex; align-items:center; justify-content:space-between; gap:10px; }

.pgallery{
  margin-top: 10px;
  margin-bottom: 10px;
}
.pgallery__thumbs{ display:flex; gap:10px; }
.pgallery__thumb{
  width: 64px;
  height: 50px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  padding:0;
  overflow:hidden;
  cursor:pointer;
  opacity:.85;
}
.pgallery__thumb:hover{ opacity:1; }
.pgallery__thumb.is-active{
  outline: 2px solid #0284c7;
  opacity:1;
}
.pgallery__thumb img,
.pgallery__thumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;   /* clave para que no se deformen */
  display: block;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.pgallery__thumb video {
  pointer-events: none;
}

.pgallery__thumb video::-webkit-media-controls {
  display: none !important;
}

.lb-lock{
  position: fixed;
  width: 100%;
  overflow: hidden;
}

.pill{
  display:inline-flex;
  padding: 4px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  font-size: 12px;
  color: rgba(35, 36, 36, 0.78);
  white-space: nowrap;
}

.list{ margin: 10px 0 14px; padding-left: 18px; color: rgba(56, 84, 126, 0.82); }

.plans{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
@media (max-width: 1000px){
  .plans{ grid-template-columns: 1fr; }
}
.plan{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  overflow:hidden;
  padding: 0;
}
.plan__media{
  height: 140px;
  background-size: cover;
  background-position: center;
  filter: saturate(110%);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
/* v4 illustrated plan media */
.plan__media--pilot{
  filter:none;
  background:
    radial-gradient(900px 240px at 30% 30%, rgba(39,224,255,.24), transparent 62%),
    radial-gradient(900px 260px at 75% 70%, rgba(124,92,255,.24), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
}
.plan__media--scale{
  filter:none;
  background:
    radial-gradient(900px 240px at 30% 30%, rgba(124,92,255,.30), transparent 62%),
    radial-gradient(900px 260px at 75% 70%, rgba(39,224,255,.22), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
}
.plan__media--buy{
  filter:none;
  background:
    radial-gradient(900px 240px at 30% 30%, rgba(255,196,61,.18), transparent 62%),
    radial-gradient(900px 260px at 75% 70%, rgba(39,224,255,.20), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
}
.plan > *:not(.plan__media){
  padding-left: 30px;
  padding-right: 16px;
}
.plan__head{ padding-top: 16px; }
.plan ul{ padding-bottom: 10px; }
.plan a.btn{ margin: 0 16px 16px; }
.plan--featured{
  background: linear-gradient(180deg, rgba(124,92,255,.18), rgba(255,255,255,.03));
  box-shadow: var(--shadow);
}
.plan__head{ display:flex; align-items:center; justify-content:space-between; gap:10px; }

.faq{ margin-top: 16px; }
.faq__item{
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  border-radius: 14px;
  padding: 10px 12px;
  margin-bottom: 10px;
}
.faq__item summary{ cursor:pointer; font-weight: 600; }

.cases{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}
@media (max-width: 1000px){
  .cases{ grid-template-columns: 1fr; }
}
.ccard{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}
.ccard__img{ height: 160px; background-size: cover; background-position:center; }
.ccard__img--illu{
  background:
    radial-gradient(900px 240px at 20% 35%, rgba(124,92,255,.30), transparent 62%),
    radial-gradient(900px 260px at 80% 60%, rgba(39,224,255,.22), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.ccard--case-food .ccard__img--illu{ background:
  radial-gradient(900px 240px at 22% 35%, rgba(255,196,61,.18), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(39,224,255,.20), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.ccard--case-stations .ccard__img--illu{ background:
  radial-gradient(900px 240px at 22% 35%, rgba(34,211,238,.18), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(16,185,129,.14), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.ccard--case-clean .ccard__img--illu{ background:
  radial-gradient(900px 240px at 22% 35%, rgba(124,92,255,.30), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(39,224,255,.20), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.ccard--case-hotel .ccard__img--illu{ background:
  radial-gradient(900px 240px at 22% 35%, rgba(39,224,255,.26), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(124,92,255,.24), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}

.blog{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}
@media (max-width: 1000px){
  .blog{ grid-template-columns: 1fr; }
}
.bcard{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}
.bcard__img{ height: 228px; background-size: cover; background-position:center; border-radius: 10px;}
.bcard__img--illu{
  background:
    radial-gradient(900px 240px at 25% 35%, rgba(124,92,255,.30), transparent 62%),
    radial-gradient(900px 260px at 80% 60%, rgba(39,224,255,.22), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.bcard--blog-roi .bcard__img--illu{ background:
  radial-gradient(900px 240px at 25% 35%, rgba(16,185,129,.14), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(124,92,255,.26), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.bcard--blog-marketing .bcard__img--illu{ background:
  radial-gradient(900px 240px at 25% 35%, rgba(34,211,238,.18), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(255,196,61,.16), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.bcard--blog-delivery .bcard__img--illu{ background:
  radial-gradient(900px 240px at 25% 35%, rgba(39,224,255,.22), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(124,92,255,.22), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.bcard--blog-pilot .bcard__img--illu{ background:
  radial-gradient(900px 240px at 25% 35%, rgba(124,92,255,.30), transparent 62%),
  radial-gradient(900px 260px at 80% 60%, rgba(39,224,255,.20), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.bcard__body{ padding: 16px; 
  }

.contact{
  /* display:grid;
  grid-template-columns: 1.2fr .8fr; */
  gap: 14px;
  margin-top: 16px;
  position: relative;
}

.robot-helper{
  position: absolute;
  top: -120px;
  right: 0;
  width: 120px;
  opacity: 0;
  transform: translateY(40px);
  transition: all .4s ease;
  pointer-events: none;
}

@media (max-width: 600px) {
  .robot-helper {
    width: 70px;
    top: -69px;
    right: 8px;
  }
}

.robot-helper.show{
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 1000px){
  .contact{ grid-template-columns: 1fr; }
}
.form{
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255,255,255);
  padding: 16px;
  display: flex;
  flex-direction: column;
}
.form label{ display:block; font-size: 13px; color: rgba(49, 49, 49, 0.8); margin-bottom: 10px; }
.form input, .form textarea{
  width:100%;
  max-width:100%;
  box-sizing: border-box;
  margin-top: 6px;
  border-radius: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(193, 194, 195, 0.22);
  color: rgb(0, 0, 0);
  /* color: var(--fg); */
  resize: none;
}
.contact__side{ display:flex; flex-direction:column; gap: 14px; }

.footer__sep{ margin: 0 10px; opacity:.5; }

.trust{ margin-top: 16px; }
.trust__logos{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom: 14px; }
.logo-pill{
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: rgba(233,238,252,.78);
  font-size: 13px;
}
.trust__grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 1000px){
  .trust__grid{ grid-template-columns: 1fr; }
}
.trust__cta{ display:flex; gap:12px; flex-wrap:wrap; margin-top: 14px; }


