:root{
  --navy:   #07111f;
  --navy2:  #0c1c30;
  --navy3:  #112240;
  --blue:   #0ea5e9;
  --blue2:  #0284c7;
  --blue3:  #0369a1;
  --muted:  #64748b;
  --border: #e2e8f0;
  --light:  #f8fafc;
  --white:  #ffffff;
  --fn-h:   'Outfit', sans-serif;
  --fn-b:   'Mulish', sans-serif;
  --fn-nav: 'Inter', sans-serif;
  --r: 16px;
}
html{ scroll-behavior:smooth; overflow-x:hidden; }
body{ font-family:var(--fn-b); overflow-x:hidden; color:#1e293b; }

/* Offset para navbar fijo al navegar con anclas — sin JS */
section[id], div[id='contacto'] { scroll-margin-top: 78px; }
h1,h2,h3,h4,h5,h6{ font-family:var(--fn-h); }

/* ── NAVBAR ── */
#mainNav{
  background:rgba(7,17,31,.97);
  backdrop-filter:blur(18px);
  padding:0;
  transition:box-shadow .3s;
}
#mainNav.scrolled{ box-shadow:0 4px 28px rgba(0,0,0,.5); }
.navbar-brand img{ height:52px; filter:brightness(0) invert(1); }

.navbar-nav .nav-link{
  font-family:var(--fn-nav);
  font-size:.88rem; font-weight:300;
  letter-spacing:.07em;
  color:rgba(255,255,255,.7) !important;
  padding:22px 16px !important;
  position:relative;
  transition:color .2s;
}
.navbar-nav .nav-link::after{
  content:'';
  position:absolute; bottom:14px; left:16px; right:16px;
  height:2px; background:var(--blue);
  transform:scaleX(0); transform-origin:left;
  transition:transform .25s;
}
.navbar-nav .nav-link:hover{ color:#fff !important; }
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after{ transform:scaleX(1); }
.navbar-nav .nav-link.active{ color:#fff !important; }

.nav-contact-btn{
  font-family:var(--fn-nav) !important;
  font-size:.85rem !important; font-weight:400 !important;
  letter-spacing:.07em;
  color:#fff !important;
  background:transparent;
  border:1.5px solid rgba(255,255,255,.25);
  border-radius:8px; padding:9px 22px !important;
  margin:12px 0 12px 10px;
  transition:border-color .2s, background .2s !important;
}
.nav-contact-btn::after{ display:none !important; }
.nav-contact-btn:hover{
  border-color:var(--blue) !important;
  background:var(--blue) !important;
}

.navbar-toggler{ border:1px solid rgba(255,255,255,.2); padding:7px 11px; }
.navbar-toggler-icon{
  background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,.85)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* ── HERO ── */
.hero-slide{
  min-height:96vh; display:flex; align-items:center;
  position:relative; overflow:hidden;
}
.hero-slide .bg-pan{
  position:absolute; inset:-8%;
  background-size:cover; background-position:center;
  animation:kenburns 9s ease-out forwards;
  will-change:transform;
}
@keyframes kenburns{ from{ transform:scale(1.12); } to{ transform:scale(1.0); } }
.carousel-item:not(.active) .bg-pan{ animation:none; }
.hero-slide .bg-overlay{
  position:absolute; inset:0;
  background:linear-gradient(110deg,rgba(7,17,31,.82) 0%,rgba(7,17,31,.55) 50%,rgba(7,17,31,.22) 100%);
}
.hero-content{ position:relative; z-index:2; }

.hero-badge{
  display:inline-flex; align-items:center; gap:9px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  color:#fff; font-family:var(--fn-nav);
  font-size:.74rem; font-weight:300; letter-spacing:.18em; text-transform:uppercase;
  padding:6px 18px; border-radius:50px; margin-bottom:26px;
}
.hero-badge .dot{
  width:8px; height:8px; border-radius:50%; background:var(--blue);
  animation:blink 2s infinite;
}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(1.6)}}

.hero-title{
  font-size:clamp(1.9rem,5.5vw,4.6rem);
  font-weight:900; color:#fff;
  line-height:1.08; letter-spacing:-.025em; margin-bottom:22px;
}
.hero-title span{ color:var(--blue); }
.hero-sub{
  font-size:clamp(.95rem,1.5vw,1.18rem);
  color:rgba(255,255,255,.8); max-width:540px;
  line-height:1.76; margin-bottom:32px; font-weight:400;
}

#heroCarousel .carousel-control-prev,
#heroCarousel .carousel-control-next{
  width:54px; height:54px;
  background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.16);
  border-radius:50%; top:50%; transform:translateY(-50%);
  margin:0 22px; opacity:1; transition:background .2s,border-color .2s;
}
#heroCarousel .carousel-control-prev:hover,
#heroCarousel .carousel-control-next:hover{ background:var(--blue); border-color:var(--blue); }
#heroCarousel .carousel-control-prev-icon,
#heroCarousel .carousel-control-next-icon{ width:20px; height:20px; }
.carousel-indicators [data-bs-target]{
  width:10px; height:10px; border-radius:50%;
  background:rgba(255,255,255,.38); border:none; margin:0 5px;
  transition:background .3s,transform .3s;
}
.carousel-indicators .active{ background:var(--blue); transform:scale(1.3); }

/* ── STATS ── */
.stats-strip{ background:var(--navy2); }
.stat-item{
  padding:26px 16px; text-align:center;
  border-right:1px solid rgba(255,255,255,.07);
}
.stat-item:last-child{ border-right:none; }
.stat-n{ font-family:var(--fn-h); font-size:1.9rem; font-weight:800; color:var(--blue); line-height:1; }
.stat-l{ font-size:.84rem; color:rgba(255,255,255,.5); margin-top:5px; font-weight:500; }

/* ── WAVE ── */
.wave svg{ display:block; }

/* ── SECTIONS ── */
.sec-hd{ margin-bottom:54px; }
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--fn-h); font-size:.74rem; font-weight:800;
  letter-spacing:.18em; text-transform:uppercase; color:var(--blue2); margin-bottom:12px;
}
.eyebrow::before{ content:''; width:8px; height:8px; border-radius:50%; background:var(--blue); flex-shrink:0; }
.eyebrow.inv{ color:var(--blue); }
.eyebrow.inv::before{ background:var(--blue); }
.sec-title{
  font-size:clamp(1.85rem,3vw,2.55rem);
  font-weight:800; letter-spacing:-.025em; line-height:1.15; margin-bottom:14px;
}
.sec-sub{ color:var(--muted); font-size:1.02rem; max-width:600px; line-height:1.78; }

/* ── SERVICE CARDS ── */
.svc-card{
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r); padding:32px 24px 28px;
  height:100%; position:relative; overflow:hidden;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.svc-card::before{
  content:''; position:absolute; top:0;left:0;right:0; height:3px;
  background:linear-gradient(90deg,var(--blue3),var(--blue));
  transform:scaleX(0); transform-origin:left; transition:transform .3s;
}
.svc-card:hover{ transform:translateY(-6px); box-shadow:0 16px 48px rgba(14,165,233,.13); border-color:#bae6fd; }
.svc-card:hover::before{ transform:scaleX(1); }
.svc-ico{
  width:54px; height:54px; border-radius:14px;
  background:linear-gradient(135deg,#f0f9ff,#e0f2fe);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:var(--blue2); margin-bottom:18px;
}
.svc-card h5{ font-family:var(--fn-h); font-weight:700; font-size:1.05rem; margin-bottom:10px; }
.svc-card p{ font-size:.88rem; color:var(--muted); line-height:1.65; margin:0; }
.svc-badge{
  display:inline-block; margin-top:14px;
  font-family:var(--fn-h); font-size:.67rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; padding:4px 12px; border-radius:50px;
}
.b-blue  { background:#f0f9ff; color:var(--blue3); }
.b-sky   { background:#e0f2fe; color:#0369a1; }
.b-indigo{ background:#eef2ff; color:#4338ca; }
.b-green { background:#f0fdf4; color:#166534; border:1px solid #bbf7d0; }

/* ── INFRA ── */
.infra-wrap{
  background:linear-gradient(160deg,var(--navy) 0%,var(--navy2) 50%,#0c2440 100%);
}
.infra-card{
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r); padding:32px 24px; height:100%;
  transition:background .25s,transform .25s,box-shadow .25s;
}
.infra-card:hover{ background:rgba(255,255,255,.09); transform:translateY(-5px); box-shadow:0 14px 44px rgba(0,0,0,.35); }
.infra-card.feat{ background:rgba(14,165,233,.1); border-color:rgba(14,165,233,.3); }
.infra-ico{
  width:54px; height:54px; border-radius:13px;
  background:rgba(14,165,233,.15);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:var(--blue); margin-bottom:18px;
}
.infra-card h5{ font-family:var(--fn-h); font-weight:700; color:#fff; font-size:1.05rem; margin-bottom:10px; }
.infra-card p{ font-size:.88rem; color:rgba(255,255,255,.58); line-height:1.65; margin:0; }
.infra-card ul{ margin:14px 0 0; padding:0; list-style:none; }
.infra-card ul li{
  font-size:.82rem; color:rgba(255,255,255,.52);
  padding:3px 0; display:flex; align-items:center; gap:8px;
}
.infra-card ul li::before{ content:'✓'; color:var(--blue); font-weight:800; flex-shrink:0; }

/* ── PORTFOLIO ── */
.pf-card{
  border-radius:var(--r); overflow:hidden; position:relative;
  box-shadow:0 4px 20px rgba(0,0,0,.1);
  transition:transform .3s,box-shadow .3s;
}
.pf-card:hover{ transform:translateY(-5px); box-shadow:0 16px 48px rgba(0,0,0,.18); }
.pf-card img{ width:100%; aspect-ratio:4/3; object-fit:cover; display:block; transition:transform .55s; }
.pf-card:hover img{ transform:scale(1.05); }
.pf-overlay{
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(7,17,31,.9) 0%,rgba(7,17,31,.2) 55%,transparent 100%);
  display:flex; flex-direction:column; justify-content:flex-end; padding:24px;
}
.pf-cat{
  display:inline-block; align-self:flex-start;
  font-family:var(--fn-h); font-size:.65rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  background:var(--blue); color:#fff;
  padding:4px 12px; border-radius:50px; margin-bottom:9px;
}
.pf-overlay h5{ font-family:var(--fn-h); font-weight:700; color:#fff; font-size:1.05rem; margin:0 0 12px; }
.pf-overlay a{
  display:inline-flex; align-items:center; gap:7px; align-self:flex-start;
  background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.28);
  color:#fff; font-family:var(--fn-h); font-size:.82rem; font-weight:600;
  padding:7px 16px; border-radius:9px; backdrop-filter:blur(8px);
  transition:background .2s;
}
.pf-overlay a:hover{ background:rgba(14,165,233,.5); border-color:var(--blue); }
/* ── PORTFOLIO SLIDER ── */
.pf-track-wrap{
  overflow:hidden;
  -webkit-mask-image: linear-gradient(to right, black 85%, transparent 100%);
  mask-image: linear-gradient(to right, black 85%, transparent 100%);
  transition: mask-image .3s, -webkit-mask-image .3s;
}
/* Última tarjeta: mostrarla completa, sin fade */
.pf-track-wrap.at-end{
  -webkit-mask-image: none;
  mask-image: none;
}
.pf-track{
  display:flex;
  gap:24px;
  transition:transform .45s cubic-bezier(.25,.8,.25,1);
  will-change:transform;
  cursor:grab;
}
.pf-track.dragging{ cursor:grabbing; transition:none; }
.pf-slide{
  /* 2 cards + ~35% of 3rd visible = each card ~44% of wrapper */
  flex: 0 0 calc(44% - 12px);
  min-width: 0;
}
@media(max-width:991px){ .pf-slide{ flex: 0 0 calc(70% - 12px); } }
@media(max-width:600px) { .pf-slide{ flex: 0 0 calc(90% - 12px); } }

/* Arrow buttons */
.pf-arrows{ display:flex; gap:10px; }
.pf-arr{
  width:48px; height:48px; border-radius:50%;
  border:1.5px solid var(--border);
  background:var(--white);
  color:var(--navy2);
  font-size:1.1rem;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .2s, border-color .2s, color .2s;
}
.pf-arr:hover{ background:var(--blue2); border-color:var(--blue2); color:#fff; }
.pf-arr:disabled{ opacity:.35; cursor:default; }
.pf-arr:disabled:hover{ background:var(--white); border-color:var(--border); color:var(--navy2); }

/* ── SUPPORT ── */
.support-wrap{
  background:linear-gradient(135deg,var(--light) 0%,#f0f9ff 100%);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
/* Steps */
.support-steps{ display:flex; gap:0; flex-wrap:wrap; margin-top:36px; }
.support-step{
  display:flex; align-items:flex-start; gap:16px;
  flex:1; min-width:180px; padding:0 24px 0 0; position:relative;
}
.support-step:not(:last-child)::after{
  content:''; position:absolute; right:0; top:24px;
  width:1px; height:32px; background:var(--border);
}
.step-num{
  width:44px; height:44px; border-radius:50%; flex-shrink:0;
  background:var(--blue2); color:#fff;
  font-family:var(--fn-h); font-weight:800; font-size:1rem;
  display:flex; align-items:center; justify-content:center;
}
.step-text h6{ font-family:var(--fn-h); font-weight:700; font-size:.95rem; margin-bottom:3px; }
.step-text p{ font-size:.82rem; color:var(--muted); margin:0; line-height:1.55; }

/* Download bar */
.rdsk-bar{
  display:flex; align-items:center; flex-wrap:wrap; gap:16px;
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r); padding:22px 28px;
  box-shadow:0 4px 24px rgba(14,165,233,.07);
  margin-top:36px;
}
.rdsk-bar-label{
  display:flex; align-items:center; gap:10px;
  font-family:var(--fn-h); font-weight:700; font-size:.95rem; color:#1e293b;
  flex:1; min-width:160px;
}
.rdsk-bar-label i{ font-size:1.25rem; color:var(--blue2); }
.rdsk-bar-label small{ display:block; font-family:var(--fn-b); font-size:.78rem; font-weight:400; color:var(--muted); }
.rdsk-btns{ display:flex; gap:10px; flex-wrap:wrap; }
.rdsk-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:11px 20px; border-radius:10px; text-decoration:none;
  font-family:var(--fn-h); transition:transform .2s,box-shadow .2s;
}
.rdsk-btn:hover{ transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.15); }
.rdsk-btn i{ font-size:1.5rem; }
.rdsk-btn small{ display:block; font-size:.64rem; font-weight:300; opacity:.75; letter-spacing:.04em; text-transform:uppercase; }
.rdsk-btn strong{ display:block; font-size:.9rem; font-weight:700; line-height:1.1; }
.rdsk-btn.win{ background:#0078d4; color:#fff; }
.rdsk-btn.mac{ background:#1d1d1f; color:#fff; }
.rdsk-link{
  font-family:var(--fn-h); font-size:.8rem; font-weight:500;
  color:var(--blue2); text-decoration:none;
  display:flex; align-items:center; gap:5px; white-space:nowrap;
  margin-left:auto;
}
.rdsk-link:hover{ color:var(--blue3); }
@media(max-width:767px){
  .rdsk-bar{ flex-direction:column; align-items:flex-start; padding:18px; }
  .rdsk-btns{ width:100%; }
  .rdsk-btn{ flex:1; justify-content:center; }
  .rdsk-link{ margin-left:0; }
  .support-step:not(:last-child)::after{ display:none; }
  .support-steps{ gap:20px; }
}

/* ── CONTACT ── */
.contact-wrap{ background:linear-gradient(160deg,var(--navy) 0%,var(--navy2) 100%); }
.contact-card{
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r); padding:40px 24px;
  height:100%; min-height:220px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; transition:background .25s,transform .25s;
}
.contact-card:hover{ background:rgba(255,255,255,.12); transform:translateY(-4px); }
.contact-ico{ font-size:2.2rem; margin-bottom:16px; display:block; color:var(--blue); }
.contact-ico.wa{ color:#25d366; }
.contact-card h6{ font-family:var(--fn-h); font-weight:700; color:#fff; font-size:1.05rem; margin-bottom:10px; }
.contact-card a,
.contact-card p{ color:rgba(255,255,255,.62); font-size:.92rem; text-decoration:none; margin:0; line-height:1.75; }
.contact-card a:hover{ color:#fff; }

/* ── BUTTONS ── */
.btn-az{
  background:var(--blue2); color:#fff;
  font-family:var(--fn-h); font-weight:700; font-size:.9rem;
  padding:13px 28px; border-radius:11px; border:none;
  transition:background .2s,transform .2s;
}
.btn-az:hover{ background:var(--blue3); transform:translateY(-2px); color:#fff; }
.btn-sky{
  background:var(--blue); color:#fff;
  font-family:var(--fn-h); font-weight:700; font-size:.9rem;
  padding:13px 28px; border-radius:11px; border:none;
  transition:background .2s,transform .2s;
}
.btn-sky:hover{ background:var(--blue2); transform:translateY(-2px); color:#fff; }
.btn-ghost{
  background:transparent; color:#fff;
  font-family:var(--fn-h); font-weight:600; font-size:.9rem;
  padding:12px 26px; border-radius:11px;
  border:2px solid rgba(255,255,255,.3);
  transition:border-color .2s,background .2s;
}
.btn-ghost:hover{ border-color:#fff; background:rgba(255,255,255,.1); color:#fff; }

/* ── FOOTER ── */
footer{ background:#040d18; padding:52px 0 0; color:#5e7a90; }
.ft-logo{ height:36px; filter:brightness(0) invert(1); opacity:.8; margin-bottom:16px; }
footer p{ font-size:.86rem; line-height:1.8; }
.ft-fb{
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09);
  color:#fff; font-family:var(--fn-h); font-size:.8rem; font-weight:600;
  padding:8px 16px; border-radius:9px; transition:background .2s; text-decoration:none;
}
.ft-fb:hover{ background:rgba(24,119,242,.22); border-color:#1877f2; color:#fff; }
footer h6{ font-family:var(--fn-h); font-size:.72rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:#fff; margin-bottom:16px; }
footer ul{ list-style:none; padding:0; margin:0; }
footer ul li{ padding:3px 0; }
footer a{ color:#5e7a90; font-size:.85rem; text-decoration:none; transition:color .2s; }
footer a:hover{ color:#fff; }
.ft-bottom{ border-top:1px solid rgba(255,255,255,.05); padding:18px 0; margin-top:44px; font-size:.78rem; color:#253545; }

/* ── RESPONSIVE ── */
.hero-row{
  min-height:92vh;
  padding-top:100px;  /* clear fixed navbar */
  padding-bottom:48px;
}
@media(max-width:991px){
  /* Touch target mínimo 48px para links del menú */
  .navbar-nav .nav-link{ padding:14px 20px !important; min-height:48px; display:flex; align-items:center; }
  .navbar-nav .nav-link::after{ display:none; }
  .nav-contact-btn{ margin:6px 20px 14px; min-height:44px; display:flex; align-items:center; justify-content:center; }
  .hero-row{ min-height:88vh; padding-top:90px; }
}
@media(max-width:767px){
  .hero-slide{ min-height:unset; }
  .hero-row{ min-height:100svh; padding-top:80px; padding-bottom:40px; }
  .hero-badge{ font-size:.68rem; padding:5px 14px; }
  .btn-ghost{ padding:10px 18px; font-size:.85rem; }
  .btn-sky{ padding:12px 22px; font-size:.88rem; }
  .stats-strip .col-6:nth-child(odd){ border-right:1px solid rgba(255,255,255,.07); }
  .stats-strip .col-6{ border-bottom:1px solid rgba(255,255,255,.07); }
  .stats-strip .col-6:nth-last-child(-n+2){ border-bottom:none; }
  #heroCarousel .carousel-control-prev,
  #heroCarousel .carousel-control-next{ display:none; }
  .d-flex.flex-wrap.gap-3{ gap:.75rem !important; }
}

/* ── CHAT WIDGET ─────────────────────────────────────────────────────────── */
#chatWidget{
  position:fixed;
  bottom:24px;
  right:24px;
  z-index:9000;
  /* pointer-events:none evita que el contenedor (invisible) bloquee
     el menú hamburguesa y otros elementos de la página.
     Los hijos que necesitan interacción tienen su propio pointer-events:auto */
  pointer-events:none;
}
#chatToggle{
  width:auto; height:52px; border-radius:50px;
  background:linear-gradient(135deg,var(--blue2) 0%,var(--blue3) 100%);
  border:none; color:#fff; font-size:1.3rem;
  box-shadow:0 8px 28px rgba(14,165,233,.5);
  display:flex; align-items:center; justify-content:center;
  gap:10px; padding:0 20px;
  cursor:pointer; transition:transform .22s,box-shadow .22s;
  position:relative;
  pointer-events:auto;
}
#chatToggle:hover{ transform:scale(1.1); box-shadow:0 14px 36px rgba(14,165,233,.6); }
#chatToggle .chat-notif{
  position:absolute; top:-3px; right:-3px;
  width:16px; height:16px; border-radius:50%;
  background:#22c55e; border:2px solid #fff;
  animation:pulseGreen 2.4s infinite;
}
@keyframes pulseGreen{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}

#chatBox{
  /* position:absolute saca el chatBox del flujo — el #chatWidget queda del
     tamaño exacto del botón (62px) y no crea overlay invisible sobre la página */
  position:absolute;
  bottom:calc(52px + 14px); /* encima del botón toggle + gap */
  right:0;
  width:370px;
  background:#fff; border-radius:22px;
  box-shadow:0 24px 64px rgba(0,0,0,.18);
  display:flex; flex-direction:column; overflow:hidden;
  transform:scale(.9) translateY(20px); opacity:0; pointer-events:none;
  transform-origin:bottom right;
  transition:transform .28s cubic-bezier(.34,1.56,.64,1), opacity .2s;
}
#chatBox.open{ transform:scale(1) translateY(0); opacity:1; pointer-events:auto; }

.chat-header{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);
  padding:16px 20px; display:flex; align-items:center; gap:13px; flex-shrink:0;
}
.chat-header-avatar{
  width:42px; height:42px; border-radius:50%; flex-shrink:0;
  background:rgba(14,165,233,.18); border:2px solid rgba(14,165,233,.5);
  display:flex; align-items:center; justify-content:center;
  font-size:1.25rem; color:var(--blue);
}
.chat-header-name{ font-family:var(--fn-h); font-weight:700; color:#fff; font-size:.95rem; }
.chat-header-status{ display:flex; align-items:center; gap:6px; font-size:.72rem; color:rgba(255,255,255,.5); margin-top:2px; }
.chat-status-dot{ width:7px; height:7px; border-radius:50%; background:#22c55e; flex-shrink:0; }
.chat-header-close{
  margin-left:auto; background:none; border:none; color:rgba(255,255,255,.4);
  font-size:1rem; cursor:pointer; padding:4px; border-radius:6px; line-height:1;
  transition:color .2s;
}
.chat-header-close:hover{ color:#fff; }

#chatMessages{
  flex:1; overflow-y:auto; padding:18px 14px; display:flex; flex-direction:column; gap:10px;
  min-height:260px; max-height:320px;
  scroll-behavior:smooth;
}
#chatMessages::-webkit-scrollbar{ width:4px; }
#chatMessages::-webkit-scrollbar-thumb{ background:#e2e8f0; border-radius:4px; }

.chat-bubble{
  max-width:84%; padding:10px 14px; border-radius:18px;
  font-size:.875rem; line-height:1.65; word-break:break-word;
}
.chat-bubble.bot{
  background:var(--light); color:#1e293b; border:1px solid var(--border);
  border-bottom-left-radius:5px; align-self:flex-start;
}
.chat-bubble.user{
  background:linear-gradient(135deg,var(--blue2),var(--blue3));
  color:#fff; border-bottom-right-radius:5px; align-self:flex-end;
}
.chat-bubble.bot a{ color:var(--blue2); }

/* Typing indicator */
#chatTyping{ align-self:flex-start; }
.typing-dots{
  background:var(--light); border:1px solid var(--border);
  border-radius:18px; border-bottom-left-radius:5px;
  padding:12px 18px; display:flex; gap:5px; align-items:center;
}
.typing-dots span{
  width:7px; height:7px; border-radius:50%; background:#94a3b8;
  animation:typBounce 1.3s ease-in-out infinite;
}
.typing-dots span:nth-child(2){ animation-delay:.2s; }
.typing-dots span:nth-child(3){ animation-delay:.4s; }
@keyframes typBounce{ 0%,60%,100%{transform:translateY(0);opacity:.45} 30%{transform:translateY(-7px);opacity:1} }

.chat-input-wrap{
  border-top:1px solid var(--border); padding:12px 12px;
  display:flex; gap:8px; align-items:center; flex-shrink:0;
}
#chatInput{
  flex:1; border:1px solid var(--border); border-radius:12px;
  padding:9px 13px; font-size:.875rem; outline:none;
  font-family:var(--fn-b); background:var(--light); color:#1e293b;
  transition:border-color .2s,background .2s;
}
#chatInput:focus{ border-color:var(--blue); background:#fff; }
#chatInput:disabled{ opacity:.5; }
#chatSend{
  width:40px; height:40px; border-radius:12px; flex-shrink:0;
  background:var(--blue2); border:none; color:#fff;
  font-size:1rem; display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .2s,transform .15s;
}
#chatSend:hover{ background:var(--blue3); transform:scale(1.06); }
#chatSend:disabled{ opacity:.5; cursor:default; transform:none; }

@media(max-width:500px){
  #chatWidget{ bottom:20px; right:20px; }
  /* chatBox ocupa el ancho disponible menos los márgenes laterales */
  #chatBox{ width:calc(100vw - 40px); right:0; }
}

/* ── CLIENTES ── */
.clientes-strip{
  background:var(--light);
  padding:44px 0;
}
.clientes-label{
  font-family:var(--fn-h); font-size:.7rem; font-weight:800;
  letter-spacing:.22em; text-transform:uppercase;
  color:#94a3b8; text-align:center; margin-bottom:32px;
}
.clientes-row{
  display:flex; flex-wrap:wrap;
  align-items:center; justify-content:center;
  gap:28px 52px;
}
/* caja fija igual para todos — elimina diferencia de área visual */
.cl-item{
  display:flex; align-items:center; justify-content:center;
  width:130px; height:52px; flex-shrink:0;
  text-decoration:none;
  transition:transform .25s;
}
.cl-item:hover{ transform:scale(1.08); }
.cl-item img{
  width:100%; height:100%;
  object-fit:contain;
  filter:grayscale(1) opacity(.55) contrast(1.1);
  transition:filter .3s;
}
.cl-item:hover img{ filter:grayscale(0) opacity(1); }

/* ── PRICING CARDS ── */
.pkg-card{
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--r); padding:36px 28px 32px;
  height:100%; display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.pkg-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 56px rgba(14,165,233,.12);
  border-color:#bae6fd;
}
.pkg-card.featured{
  border-color:var(--blue2);
  box-shadow:0 12px 48px rgba(14,165,233,.18);
}
.pkg-card.featured:hover{ box-shadow:0 24px 64px rgba(14,165,233,.25); }
.pkg-popular{
  display:block; text-align:center;
  background:var(--blue2); color:#fff;
  font-family:var(--fn-h); font-size:.68rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  padding:8px 18px;
  /* jalar hasta los bordes superiores del card (padding-top:36px, left/right:28px) */
  margin:-36px -28px 26px;
  border-radius:calc(var(--r) - 1.5px) calc(var(--r) - 1.5px) 0 0;
}
.pkg-badge{
  display:inline-block; margin-bottom:14px;
  font-family:var(--fn-h); font-size:.67rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  background:#f0f9ff; color:var(--blue3);
  padding:4px 12px; border-radius:50px;
}
.pkg-badge.premium{ background:#fdf4ff; color:#7c3aed; }
.pkg-name{
  font-family:var(--fn-h); font-weight:800; font-size:1.45rem;
  color:var(--navy); margin-bottom:10px; letter-spacing:-.02em;
}
.pkg-price{
  font-family:var(--fn-b); font-size:1rem; color:var(--muted);
  margin-bottom:22px; padding-bottom:18px; border-bottom:1px solid var(--border);
}
.pkg-price strong{
  font-family:var(--fn-h); font-size:2rem; font-weight:800;
  color:var(--navy); line-height:1; display:inline;
}
.pkg-price small{ font-size:.8rem; font-weight:400; color:var(--muted); }
.pkg-list{
  list-style:none; padding:0; margin:0 0 28px; flex:1;
}
.pkg-list li{
  font-size:.88rem; color:#334155;
  padding:6px 0; display:flex; align-items:flex-start; gap:9px;
  border-bottom:1px solid #f1f5f9;
}
.pkg-list li:last-child{ border-bottom:none; }
.pkg-list li::before{ content:'✓'; color:var(--blue2); font-weight:800; flex-shrink:0; margin-top:1px; }
.pkg-note{
  font-size:.85rem; color:var(--muted);
  max-width:640px; margin-left:auto; margin-right:auto; line-height:1.75;
}

/* ── PORTAFOLIO DESCRIPCIÓN ── */
.pf-overlay h5{ margin:0 0 4px; }
.pf-desc{
  font-size:.76rem; color:rgba(255,255,255,.65);
  margin:0 0 12px; line-height:1.5;
}

/* ── BLOQUE ASESOR IA ── */
.ai-cta-wrap{
  background:linear-gradient(135deg,var(--blue3) 0%,var(--blue2) 60%,#0699db 100%);
  padding:72px 0;
}
.ai-cta-inner{
  display:flex; align-items:center; gap:40px; flex-wrap:wrap;
}
.ai-cta-icon{
  width:80px; height:80px; border-radius:50%; flex-shrink:0;
  background:rgba(255,255,255,.18); border:2px solid rgba(255,255,255,.35);
  display:flex; align-items:center; justify-content:center;
  font-size:2.2rem; color:#fff;
}
.ai-cta-body{ flex:1; min-width:240px; }
.ai-cta-body h3{
  font-family:var(--fn-h); font-weight:800; color:#fff;
  font-size:clamp(1.3rem,2.5vw,1.9rem); margin-bottom:10px;
}
.ai-cta-body p{
  color:rgba(255,255,255,.85); font-size:.97rem;
  line-height:1.78; margin:0;
}
.ai-cta-btn{
  white-space:nowrap; padding:14px 30px;
  font-size:1rem; flex-shrink:0;
}
@media(max-width:767px){
  .ai-cta-inner{ flex-direction:column; text-align:center; }
  .ai-cta-icon{ margin:0 auto; }
  .ai-cta-btn{ width:100%; }
}

/* ── LANGUAGE SWITCHER ── */
.lang-switch{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--fn-nav); font-size:.72rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.5);
  border:1px solid rgba(255,255,255,.2);
  border-radius:6px; padding:4px 10px;
  text-decoration:none;
  transition:color .2s, border-color .2s;
  margin-left:10px; line-height:1;
}
.lang-switch:hover{ color:#fff; border-color:rgba(255,255,255,.5); }

/* ── CHAT QUICK REPLY ── */
.chat-options{
  display:flex; flex-wrap:wrap; gap:7px;
  padding:4px 14px 12px; align-self:flex-start;
}
.chat-opt-btn{
  background:transparent; border:1.5px solid var(--blue2);
  color:var(--blue2); font-family:var(--fn-h); font-size:.77rem; font-weight:600;
  padding:6px 14px; border-radius:20px; cursor:pointer;
  transition:background .2s, color .2s, border-color .2s;
  white-space:nowrap; line-height:1.3;
}
.chat-opt-btn:hover,
.chat-opt-btn:active{ background:var(--blue2); color:#fff; }

/* ── BACK TO TOP ── */
#backToTop{
  position:fixed; bottom:24px; left:24px;
  width:46px; height:46px; border-radius:50%;
  background:var(--navy3); border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.65); font-size:1.1rem;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; z-index:8999;
  opacity:0; pointer-events:none;
  transform:translateY(12px);
  transition:opacity .25s, transform .25s, background .2s, color .2s;
}
#backToTop.visible{ opacity:1; pointer-events:auto; transform:translateY(0); }
#backToTop:hover{ background:var(--blue2); color:#fff; border-color:var(--blue2); }
@media(max-width:480px){ #backToTop{ bottom:20px; left:20px; width:42px; height:42px; font-size:1rem; } }

/* ── CHAT TOGGLE LABEL ── */
.chat-toggle-label{
  font-family:var(--fn-h); font-weight:700; font-size:.85rem;
  white-space:nowrap; line-height:1;
}
@media(max-width:480px){
  .chat-toggle-label{ display:none; }
  #chatToggle{ width:56px; height:56px; padding:0; border-radius:50%; }
  #chatBox{ bottom:calc(56px + 14px); }
}

/* ── HERO TRUST ── */
.hero-trust{
  display:flex; flex-wrap:wrap; gap:10px 28px;
  margin-bottom:28px;
}
.hero-trust span{
  display:inline-flex; align-items:center; gap:7px;
  color:rgba(255,255,255,.88);
  font-family:var(--fn-h); font-size:.9rem; font-weight:600;
}
.hero-trust .bi{ color:var(--blue); font-size:1rem; flex-shrink:0; }

/* ── PROPUESTA DE VALOR ── */
.valor-card{
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r); padding:40px 28px;
  height:100%; text-align:center;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.valor-card:hover{ transform:translateY(-5px); box-shadow:0 14px 44px rgba(14,165,233,.1); border-color:#bae6fd; }
.valor-ico{
  width:72px; height:72px; border-radius:50%; margin:0 auto 22px;
  background:linear-gradient(135deg,var(--blue3),var(--blue));
  display:flex; align-items:center; justify-content:center;
  font-size:1.75rem; color:#fff;
}
.valor-card h5{ font-family:var(--fn-h); font-weight:700; font-size:1.1rem; margin-bottom:12px; color:var(--navy); }
.valor-card p{ font-size:.9rem; color:var(--muted); line-height:1.75; margin:0; }

/* ── PLAN DESCRIPCIÓN ── */
.pkg-desc{ font-size:.88rem; color:var(--muted); line-height:1.65; margin-bottom:16px; }

/* ── ASESOR IA — BENEFICIOS ── */
.ai-benefits{
  list-style:none; padding:0; margin:14px 0 0;
}
.ai-benefits li{
  display:flex; align-items:flex-start; gap:8px;
  font-size:.9rem; color:rgba(255,255,255,.88);
  padding:4px 0;
}
.ai-benefits li::before{ content:'✔'; color:#fff; font-weight:800; flex-shrink:0; margin-top:1px; }

/* ── RESULTADOS ── */
.results-wrap{
  background:var(--navy);
  padding:72px 0;
}
.result-block{
  text-align:center; padding:40px 24px;
}
@media(min-width:768px){
  .results-wrap .col-md-4:not(:last-child) .result-block{
    border-right:1px solid rgba(255,255,255,.08);
  }
}
@media(max-width:767px){
  .results-wrap .col-md-4:not(:last-child) .result-block{
    border-bottom:1px solid rgba(255,255,255,.08);
  }
}
.result-n{
  font-family:var(--fn-h); font-size:clamp(2.2rem,5vw,3.4rem);
  font-weight:900; color:var(--blue); line-height:1; margin-bottom:10px;
}
.result-l{
  font-family:var(--fn-h); font-size:.98rem; font-weight:700; color:#fff; margin-bottom:8px;
}
.result-desc{ font-size:.82rem; color:rgba(255,255,255,.46); line-height:1.6; margin:0; }

/* ── OFERTA ── */
.oferta-wrap{
  background:linear-gradient(135deg,var(--light) 0%,#e0f2fe 100%);
  padding:88px 0; text-align:center;
}
.oferta-sub{
  color:var(--muted); font-size:1.02rem; max-width:520px;
  margin:0 auto 36px; line-height:1.82;
}

/* ── FAQ ── */
.faq-wrap{ background:#fff; }
.faq-item{
  padding:24px 0; border-bottom:1px solid var(--border);
}
.faq-item:first-child{ border-top:1px solid var(--border); }
.faq-q{
  font-family:var(--fn-h); font-weight:700; font-size:1rem;
  color:var(--navy); margin-bottom:10px;
  display:flex; align-items:flex-start; gap:12px;
}
.faq-q::before{
  content:''; width:8px; height:8px; border-radius:50%;
  background:var(--blue); flex-shrink:0; margin-top:5px;
}
.faq-a{ font-size:.93rem; color:var(--muted); line-height:1.78; margin:0; padding-left:20px; }

/* ── CTA FINAL ── */
.cta-final-wrap{
  background:var(--navy2);
  border-top:1px solid rgba(255,255,255,.06);
  padding:80px 0; text-align:center;
}
.cta-final-title{
  font-family:var(--fn-h); font-weight:800; color:#fff;
  font-size:clamp(1.5rem,3vw,2.1rem);
  letter-spacing:-.02em; line-height:1.22; margin-bottom:32px;
  max-width:640px; margin-left:auto; margin-right:auto;
}