:root {
  --bg:       #000000;
  --s1:       #0a1628;
  --s2:       #0e1c32;
  --s3:       #12223c;
  --border:   #1a2e48;
  --border2:  #243d5e;
  --blue:     #3d8ef5;
  --blue2:    #5aa3ff;
  --blue-g:   rgba(61,142,245,.18);
  --green:    #22c98a;
  --green2:   #30e09a;
  --green-g:  rgba(34,201,138,.15);
  --gold:     #e8b84b;
  --gold2:    #f5d080;
  --gold-g:   rgba(232,184,75,.14);
  --purple:   #a78bfa;
  --purple2:  #c4b5fd;
  --purple-g: rgba(167,139,250,.15);
  --cyan:     #00c8ff;
  --red:      #ff5e7a;
  --text:     #dde8f8;
  --text2:    #7a94b3;
  --text3:    #3d5570;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--text);font-family:"DM Sans",sans-serif;overflow-x:hidden;position:relative}

/* ── BG FX ── */
#bgc{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5}
.orb{position:fixed;border-radius:50%;filter: blur(100px);pointer-events:none;z-index:0}
.orb-a{width:700px;height:700px;top:-220px;right:-120px;background:radial-gradient(circle,rgba(61,142,245,.09) 0%,transparent 70%)}
.orb-b{width:580px;height:580px;bottom:40px;left:-130px;background:radial-gradient(circle,rgba(34,201,138,.07) 0%,transparent 70%)}
.orb-c{width:420px;height:420px;top:55%;left:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(167,139,250,.05) 0%,transparent 70%)}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 40px;
  background:rgba(4,7,15,.95);
  border-bottom:1px solid rgba(26,46,72,.5);
  transition:padding .3s ease;
}
.nav-brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.nav-logo{width:36px;height:36px}
.nav-name{font-family:"Syne",sans-serif;font-size:17px;font-weight:800;letter-spacing:.12em;color:var(--cyan);text-shadow:0 0 22px rgba(0,200,255,.35);text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  font-size:13px;color:var(--text2);text-decoration:none;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  padding:9px 16px;border-radius:10px;
  border:1px solid transparent;
  white-space:nowrap;
  transition:all .2s ease;
  position:relative;
}
.nav-links a:hover{
  color:var(--text);
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.07);
}
.nav-links a.active{
  color:var(--cyan);
  background:rgba(0,200,255,.07);
  border-color:rgba(0,200,255,.18);
  text-shadow:0 0 16px rgba(0,200,255,.4);
  box-shadow:0 0 16px rgba(0,200,255,.08);
}

/* hamburger */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;cursor:pointer;padding:4px;border-radius:8px;transition:background .2s}
.nav-burger:hover{background:rgba(255,255,255,.05)}
.nav-burger span{display:block;height:2px;border-radius:2px;background:var(--text);transition:all .3s cubic-bezier(.22,1,.36,1)}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile menu overlay */
.nav-mobile{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:490;
  background:rgba(4,7,15,.55);
  backdrop-filter:blur(28px) saturate(1.4);
  flex-direction:column;align-items:center;justify-content:flex-start;gap:0;
  padding:88px 20px 40px;overflow-y:auto;
  opacity:0;pointer-events:none;transition:opacity .35s ease;
}
.nav-mobile::before{
  content:'';position:absolute;top:-20%;left:-15%;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,200,255,.06) 0%,transparent 65%);
  pointer-events:none;
}
.nav-mobile::after{
  content:'';position:absolute;bottom:-15%;right:-10%;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(61,142,245,.07) 0%,transparent 65%);
  pointer-events:none;
}
.nav-mobile.open{opacity:1;pointer-events:all}
.nav-mobile.open .nm-item,
.nav-mobile.open .nav-mobile-cta{animation:nmSlide .4s cubic-bezier(.22,1,.36,1) both}
.nav-mobile.open .nm-menu-list .nm-item:nth-child(1){animation-delay:.06s}
.nav-mobile.open .nm-menu-list .nm-item:nth-child(2){animation-delay:.14s}
.nav-mobile.open .nm-menu-list .nm-item:nth-child(3){animation-delay:.22s}
.nav-mobile.open .nm-menu-list .nm-item:nth-child(4){animation-delay:.30s}
.nav-mobile.open .nav-mobile-cta{animation-delay:.38s}
@keyframes nmSlide{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:translateY(0)}
}
.nav-mobile a{
  font-family:"Syne",sans-serif;
  font-size:clamp(24px,6.5vw,36px);
  font-weight:800;letter-spacing:-.01em;
  color:rgba(221,232,248,.35);
  text-decoration:none;
  padding:11px 52px;
  border-radius:16px;
  transition:all .2s ease;
  text-align:center;width:100%;max-width:420px;
  border:1px solid transparent;
  position:relative;z-index:1;
}
.nav-mobile a:hover{
  color:var(--text);
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.07);
  letter-spacing:.01em;
}
.nav-mobile .nav-mobile-cta{
  margin-top:20px;
  background:linear-gradient(135deg,var(--blue),#2260d8) !important;
  color:#fff !important;
  border-color:transparent !important;
  box-shadow:0 0 48px rgba(61,142,245,.4) !important;
  font-size:clamp(13px,3vw,16px) !important;
  letter-spacing:.12em !important;
  text-transform:uppercase !important;
  padding:15px 52px !important;
  width:80% !important;
}

.nav-cta{
  background:linear-gradient(135deg,var(--blue),#2260d8);color:#fff;
  border:none;padding:11px 26px;border-radius:100px;
  font-family:"Syne",sans-serif;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;text-decoration:none;
  box-shadow:0 0 24px rgba(61,142,245,.25);
  transition:all .25s ease;
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 0 36px rgba(61,142,245,.4)}

/* ── SECTIONS ── */
section{position:relative;z-index:1}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}

/* ── HERO ── */
#hero{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:140px 40px 100px;text-align:center;
}
.hero-inner{max-width:820px;margin:0 auto}
.hero-pill{
  position:absolute;bottom:30px;right:30px;z-index:10;
  display:inline-flex;align-items:center;gap:10px;
  border:1px solid var(--border2);border-radius:100px;padding:8px 22px;
  background:linear-gradient(135deg,var(--s2),var(--s1));
  box-shadow:0 0 0 1px rgba(61,142,245,.07),inset 0 1px 0 rgba(255,255,255,.04);
  animation:up .8s ease both;
}
.dot-live{width:7px;height:7px;background:var(--green);border-radius:50%;flex-shrink:0;animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 6px var(--green),0 0 12px rgba(34,201,138,.3)}50%{box-shadow:0 0 14px var(--green),0 0 28px rgba(34,201,138,.6)}}
.pill-text{font-family:"Syne",sans-serif;font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--text3)}
h1{font-family:"Syne",sans-serif;font-size:80px;font-weight:700;line-height:.94;letter-spacing:-.03em;color:var(--text);margin-bottom:26px;animation:up .8s ease .1s both}
h1 em{font-style:normal;background:linear-gradient(135deg,var(--blue2),var(--green2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:17px;color:var(--text2);max-width:540px;margin:0 auto 44px;line-height:1.8;animation:up .8s ease .2s both}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;animation:up .8s ease .3s both}
.btn-primary{
  background:linear-gradient(135deg,var(--blue),#2260d8);color:#fff;
  border:none;padding:25px 36px;border-radius:100px;
  font-family:"Syne",sans-serif;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;box-shadow:0 0 36px rgba(61,142,245,.3),0 8px 24px rgba(0,0,0,.4);
  transition:all .3s ease;text-decoration:none;display:inline-block;text-align:center;
  position:relative;overflow:hidden;
}
.btn-primary::after{
  content:"";position:absolute;top:0;left:-150%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-20deg);pointer-events:none;
  animation:shine-flash 6s infinite cubic-bezier(0.4, 0.0, 0.2, 1);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 0 56px rgba(61,142,245,.5),0 16px 40px rgba(0,0,0,.5)}
.btn-secondary{
  background:rgba(10,22,40,.9);border:1px solid var(--border2);color:var(--text2);
  padding:25px 36px;border-radius:100px;
  font-family:"Syne",sans-serif;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;backdrop-filter:none;
  transition:all .25s ease;text-decoration:none;display:inline-block;text-align:center;
}
.btn-secondary:hover{background:var(--s2);color:var(--text);border-color:var(--blue)}

/* hero stats */
.hero-stats{
  display:flex;justify-content:center;  align-items: center; gap:60px; padding:60px 0; border-top:1px solid var(--border);flex-wrap:wrap;animation:up .8s ease .4s both}
.stat-num{font-family:"Syne",sans-serif;font-size:70px;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,var(--blue2),var(--green2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.stat-label{font-size:16px;color:var(--text2);margin-top:15px;text-align:center}

/* ── SECTION HEADERS ── */
.sec-header{text-align:center;margin-bottom:60px}
.sec-eyebrow{font-family:"Syne",sans-serif;font-size:10px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--text3);display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:18px}
.sec-eyebrow::before,.sec-eyebrow::after{content:"";width:36px;height:1px;background:var(--border)}
h2.sec-title{font-family:"Syne",sans-serif;font-size:clamp(40px,5vw,54px);font-weight:700;line-height:1.05;letter-spacing:-.025em;color:var(--text)}
h2.sec-title em{font-style:normal;background:linear-gradient(135deg,var(--blue2),var(--green2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sec-desc{font-size:15px;color:var(--text2);max-width:520px;margin:14px auto 0;line-height:1.8}

/* ══════════════════════════════
   QUIÉNES SOMOS
══════════════════════════════ */

#quienes-somos {
  padding: 120px 0;
  background: linear-gradient(180deg, transparent, rgba(10,22,40,.35), transparent);
  position: relative;
  overflow: hidden;
}

/* Glow ambiental de fondo */
#quienes-somos::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 900px;
  height: 600px;
  background: radial-gradient(ellipse at center,
    rgba(0,200,255,.04) 0%,
    rgba(61,142,245,.03) 40%,
    transparent 70%);
  pointer-events: none;
}

/* ── HEADER ── */
.qs-header {
  text-align: center;
  margin-bottom: 72px;
  position: relative;
}

/* Sobreescribe el tamaño global de sec-title solo en esta sección */
#quienes-somos h2.sec-title {
 font-size: clamp(50px, 7vw, 85px);
}

.qs-subtitle {
  font-size: 16px;
  color: var(--text2);
  max-width: 620px;
  margin: 20px auto 0;
  line-height: 1.85;
}
.qs-subtitle strong { color: var(--text); }

.qs-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 28px;
}
.qs-divider-line {
  height: 1px;
  width: 80px;
  background: linear-gradient(90deg, transparent, var(--border2));
}
.qs-divider-line:last-child {
  background: linear-gradient(90deg, var(--border2), transparent);
}

/* ── GRID PRINCIPAL ── */
.qs-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
  margin-bottom: 60px;
}

/* ── COLUMNA IZQUIERDA: texto ── */
.qs-text .tag {
  font-family: "Syne", sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: 16px;
  display: block;
}
.qs-text h2 {
  font-family: "Syne", sans-serif;
  font-size: clamp(26px, 3.5vw, 38px);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -.02em;
  margin-bottom: 22px;
  color: var(--text);
}
.qs-text h2 em {
  font-style: normal;
  background: linear-gradient(135deg, var(--cyan), var(--blue2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.qs-text p {
  font-size: 15px;
  color: var(--text2);
  line-height: 1.85;
  margin-bottom: 14px;
}

/* Enfoques */
.qs-enfoques {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 20px 0 28px;
}
.qs-enfoque {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(10,22,40,.5);
  transition: border-color .25s, background .25s;
}
.qs-enfoque:hover {
  border-color: rgba(0,200,255,.25);
  background: rgba(0,200,255,.04);
}
.qs-enfoque-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}
.qs-enfoque-icon.blue { background: rgba(61,142,245,.15); }
.qs-enfoque-icon.green { background: rgba(34,201,138,.15); }
.qs-enfoque-text strong {
  display: block;
  font-size: 13px;
  font-family: "Syne", sans-serif;
  font-weight: 700;
  color: var(--text);
  letter-spacing: .02em;
}
.qs-enfoque-text span {
  font-size: 12px;
  color: var(--text3);
}

.qs-promise-text-bottom {
  font-size: 14px;
  color: var(--text2);
  font-style: italic;
  line-height: 1.7;
  padding: 16px 20px;
  border-left: 2px solid var(--cyan);
  background: rgba(0,200,255,.04);
  border-radius: 0 10px 10px 0;
  margin-top: 4px;
}

/* ── COLUMNA DERECHA: diagrama ── */
.qs-diagram-card {
  background: linear-gradient(145deg, var(--s2), var(--s1));
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 32px 28px;
  position: relative;
  overflow: hidden;
}
.qs-diagram-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--cyan), var(--blue2), var(--green2), transparent);
  opacity: .7;
}
.qs-diagram-card::after {
  content: "";
  position: absolute;
  top: -60px; right: -60px;
  width: 200px; height: 200px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0,200,255,.07) 0%, transparent 70%);
  pointer-events: none;
}

.qs-diagram-label {
  font-family: "Syne", sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.qs-diagram-label::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--border);
}

/* ── DIAGRAMA DE FLUJO ── */
.flow-diagram {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  position: relative;
  z-index: 1;
}

.flow-node {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 13px 16px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: rgba(10,22,40,.7);
  cursor: default;
  transition: all .3s ease;
  position: relative;
}
.flow-node:hover {
  transform: translateX(4px);
  border-color: var(--node-color, var(--cyan));
  background: rgba(10,22,40,.9);
  box-shadow: 0 0 20px rgba(0,0,0,.3), -3px 0 0 var(--node-color, var(--cyan));
}
.flow-node-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  flex-shrink: 0;
  background: var(--node-bg, rgba(0,200,255,.12));
  border: 1px solid var(--node-border, rgba(0,200,255,.2));
}
.flow-node-content strong {
  display: block;
  font-family: "Syne", sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: .01em;
}
.flow-node-content span {
  font-size: 11px;
  color: var(--text3);
  line-height: 1.4;
}
.flow-node-badge {
  margin-left: auto;
  font-family: "Syne", sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .1em;
  color: var(--node-color, var(--cyan));
  border: 1px solid var(--node-color, var(--cyan));
  border-radius: 100px;
  padding: 3px 9px;
  opacity: .7;
  white-space: nowrap;
}

/* Conector entre nodos */
.flow-connector {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 3px 0;
}
.flow-connector-line {
  width: 2px;
  height: 18px;
  background: linear-gradient(180deg, var(--connector-top, var(--border2)), var(--connector-bottom, var(--border2)));
  border-radius: 2px;
}
.flow-connector-arrow {
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid var(--connector-bottom, var(--border2));
  margin-top: -1px;
}

/* ── CTA ── */
.qs-cta-row {
  margin-top: 44px;
  text-align: center;
}

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .qs-grid { grid-template-columns: 1fr; gap: 40px; }
  #quienes-somos h2.sec-title { font-size: clamp(48px, 12vw, 80px); }
}

/* ── ABOUT / QUÉ ES ── */
#about{padding:100px 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.about-text .tag{font-family:"Syne",sans-serif;font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);margin-bottom:14px;display:block}
.about-text h2{font-family:"Syne",sans-serif;font-size:clamp(30px,4vw,46px);font-weight:700;line-height:1.1;letter-spacing:-.02em;margin-bottom:20px}
.about-text h2 em{font-style:normal;color:var(--cyan)}
.about-text p{font-size:15px;color:var(--text2);line-height:1.85;margin-bottom:16px}
.about-promise{background:linear-gradient(135deg,var(--s2),var(--s1));border:1px solid var(--border);border-radius:18px;padding:24px;margin-top:28px;position:relative;overflow:hidden}
.about-promise::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.3}
.promise-label{font-family:"Syne",sans-serif;font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--text3);margin-bottom:10px}
.promise-text{font-size:15px;color:var(--text);font-style:italic;line-height:1.7}
.about-visual{display:flex;flex-direction:column;gap:14px}
.av-card{background:var(--s1);border:1px solid var(--border);border-radius:16px;padding:22px 24px;display:flex;align-items:center;gap:18px;transition:all .3s ease}
.av-card:hover{border-color:var(--border2);transform:translateX(6px)}
.av-icon{font-size:26px;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--s2);border-radius:12px;flex-shrink:0}
.av-label{font-family:"Syne",sans-serif;font-size:13px;font-weight:700;color:var(--text);margin-bottom:3px}
.av-desc{font-size:12.5px;color:var(--text2);line-height:1.5}

/* ── QUÉ MEJORA ── */
#mejoras{padding:80px 0;background:linear-gradient(180deg,transparent,rgba(10,22,40,.4),transparent)}
.mejoras-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.mcard{background:var(--s1);border:1px solid var(--border);border-radius:20px;padding:28px 24px;position:relative;overflow:hidden;transition:all .35s ease}
.mcard::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(61,142,245,.04),transparent 60%);pointer-events:none}
.mcard:hover{transform:translateY(-5px);border-color:var(--border2);box-shadow:0 20px 50px rgba(0,0,0,.5)}
.mcard-icon{font-size:28px;margin-bottom:16px}
.mcard-title{font-family:"Syne",sans-serif;font-size:15px;font-weight:700;color:var(--text);margin-bottom:8px}
.mcard-desc{font-size:13px;color:var(--text2);line-height:1.7}

/* ── WORKERS ── */
#workers{padding:100px 0}
#workers .wrap{width:90%}
.workers-section-title{font-family:"Syne",sans-serif;font-size:10px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:var(--text3);display:flex;align-items:center;gap:14px;margin-bottom:20px;margin-top:56px}
.workers-section-title::before,.workers-section-title::after{content:"";flex:1;height:1px;background:var(--border)}
.workers-section-title:first-of-type{margin-top:0}

.workers-explainer{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;background:var(--s1);border:1px solid var(--border);border-radius:24px;padding:40px;margin-bottom:48px;position:relative;overflow:hidden}
.workers-explainer::before{content:"";position:absolute;top:0;left:15%;right:15%;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.15}
.we-tag{font-family:"Syne",sans-serif;font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.we-tag::before{content:"";width:20px;height:1px;background:var(--cyan);opacity:.5}
.we-title{font-family:"Syne",sans-serif;font-size:40px;font-weight:700;line-height:1.1;letter-spacing:-.02em;color:var(--text);margin-bottom:16px}
.we-title em{font-style:normal;background:linear-gradient(135deg,var(--blue2),var(--green2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.we-body{font-size:13.5px;color:var(--text2);line-height:1.75}
.we-list-label{font-family:"Syne",sans-serif;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text3);margin-bottom:14px}
.we-list{list-style:none;display:flex;flex-direction:column}
.we-list li{display:flex;align-items:flex-start;gap:14px;padding:11px 0;border-bottom:1px solid rgba(26,46,72,.6);font-size:13px;color:var(--text2)}
.we-list li:last-child{border-bottom:none}
.we-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:5px}
.we-worker-name{font-family:"Syne",sans-serif;font-size:12px;font-weight:700;color:var(--text);min-width:54px}
.we-worker-role{color:var(--text2);font-size:12.5px}
.we-footer{margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}
.we-steps{display:flex;flex-direction:column;gap:4px}
.we-steps span{font-family:"Syne",sans-serif;font-size:15px;font-weight:800;line-height:1.3;letter-spacing:-.015em;background:linear-gradient(135deg,var(--blue2),var(--green2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.we-steps span:first-child{font-size:18px}
.we-steps span:last-child{font-size:13px;font-weight:700;color:var(--text2);-webkit-text-fill-color:var(--text2);background:none}

/* worker card */
.wcard{
  background: transparent;
  perspective: 1500px;
  padding: 0;
  border: none;
  box-shadow: none;
  transition:transform .35s cubic-bezier(.22,.68,0,1.2);
  cursor:pointer;
  display: block;
  text-decoration: none;
  color: inherit;
  user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}
.wcard.flipped{transform:translateY(-6px);}

.wcard-inner { position: relative; width: 100%; height: 100%; text-align: left; transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1); transform-style: preserve-3d; display: grid; grid-template-columns: 1fr; grid-template-rows: 1fr; will-change: transform; }
.wcard.flipped .wcard-inner { transform: rotateY(180deg); transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1); }

.wcard-front, .wcard-back { grid-area: 1 / 1; backface-visibility: hidden; background: var(--bg-card, var(--s1)); border: 1px solid var(--border); border-radius: 24px; padding: 16px 18px; position: relative; overflow: hidden; display: flex; flex-direction: column; transition: box-shadow .35s ease, border-color .35s ease; }
.wcard-back { transform: rotateY(180deg); align-items: center; justify-content: flex-start; }

.wcard-front::before, .wcard-back::before {content:"";position:absolute;top:0;left:15%;right:15%;height:1px;background:linear-gradient(90deg,transparent,var(--ac,var(--blue)),transparent);opacity:.2;transition:opacity .35s,left .35s,right .35s}
.wcard-front::after, .wcard-back::after {content:"";position:absolute;top:-2px;right:-2px;width:70px;height:70px;background:radial-gradient(circle at top right,var(--ac-g,transparent),transparent 70%);border-radius:0 24px 0 0;opacity:0;transition:opacity .35s}

.wcard.flipped .wcard-front, .wcard.flipped .wcard-back { border-color:var(--ac,var(--blue));box-shadow:0 0 0 1px var(--ac,var(--blue)),0 30px 60px rgba(0,0,0,.6),0 0 40px var(--ac-g,transparent) }
.wcard.flipped .wcard-front::before, .wcard.flipped .wcard-back::before {opacity:1;left:0;right:0}
.wcard.flipped .wcard-front::after, .wcard.flipped .wcard-back::after {opacity:1}

.wcard-back { padding: 0; }

.wcard.flipped .wibox{border-color:var(--ac,var(--blue));box-shadow:0 0 16px var(--ac-g,transparent)}

.wblue  {--ac:var(--blue); --ac-g:var(--blue-g); --bg-card: linear-gradient(145deg, #0a1628, #0e1c32, #091520); }
.wgreen {--ac:var(--green);--ac-g:var(--green-g); --bg-card: linear-gradient(145deg, #0a0f1d, #0d1428, #080c1a); }
.wmax   {--ac:#22c55e; --ac-g:rgba(34,197,94,.14); --bg-card: linear-gradient(145deg, #061a0e, #0a2e14, #051508); }
.wgold  {--ac:var(--gold); --ac-g:var(--gold-g); --bg-card: linear-gradient(145deg, #1a1200, #2a1e00, #1a1500); border-color:rgba(232,184,75,.2)}
.wpurple{--ac:var(--purple);--ac-g:var(--purple-g); --bg-card: linear-gradient(145deg, #100d28, #140f30, #0a0820); border-color:rgba(167,139,250,.2)}
.wred   {--ac:var(--red);   --ac-g:rgba(255,94,122,.14); --bg-card: linear-gradient(145deg, #1a0a10, #240e12, #15090d); }

/* shimmer on special cards */
.shimmer{position:absolute;inset:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.022) 50%,transparent 70%);background-size:200% 100%;animation:shim 5s ease-in-out infinite;pointer-events:none}
@keyframes shim{0%{background-position:-200% 0}100%{background-position:200% 0}}

.best-badge{
  position:absolute;top:18px;right:18px;
  background:linear-gradient(135deg,var(--gold),#b87a10);color:#000;
  font-family:"Syne",sans-serif;font-size:9px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;
  padding:5px 12px;border-radius:100px;
}

.wtop{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:12px}
.wnum{font-family:"Syne",sans-serif;font-size:9px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--text3);margin-bottom:5px}
.wname{font-family:"Syne",sans-serif;font-size:28px;font-weight:800;line-height:1;letter-spacing:-.025em;color:var(--text)}
.wgold  .wname{background:linear-gradient(135deg,var(--gold2),var(--gold),#c8963a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.wpurple .wname{background:linear-gradient(135deg,var(--purple2),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.wrole{font-size:12px;color:var(--text2);margin-bottom:10px;font-style:italic}

.wibox{
  width:48px;height:48px;border-radius:12px;border:1px solid var(--border2);
  background:linear-gradient(145deg,var(--s2),var(--s3));
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:border-color .3s,box-shadow .3s;
  box-shadow:0 4px 16px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.06);
}
.wibox svg{width:26px;height:26px}

.wdesc{font-size:12px;color:var(--text2);line-height:1.5;margin-bottom:6px}
.wlabel{font-family:"Syne",sans-serif;font-size:8px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text3);margin-bottom:4px;width:100%}
.wtasks{list-style:none;margin-bottom:6px}
.wtasks li{display:flex;align-items:flex-start;gap:8px;font-size:11px;color:var(--text2);padding:3px 0;border-bottom:1px solid rgba(26,46,72,.5)}
.wtasks li:last-child{border-bottom:none}
.tdot{width:5px;height:5px;border-radius:50%;margin-top:6px;flex-shrink:0}
.wblue  .tdot{background:var(--blue);box-shadow:0 0 5px var(--blue-g)}
.wgreen .tdot{background:var(--green);box-shadow:0 0 5px var(--green-g)}
.wgold  .tdot{background:var(--gold);box-shadow:0 0 5px var(--gold-g)}
.wpurple .tdot{background:var(--purple);box-shadow:0 0 5px var(--purple-g)}
.wred   .tdot{background:var(--red);box-shadow:0 0 5px rgba(255,94,122,.2)}

.wcard-back .wtasks { width: 100%; }
.wcard-back .back-img { width: 90%; height: 93%; object-fit: cover; border-radius: 20px; margin: auto; border: none; box-shadow: none; }

.wexample{background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:12px}
.wex-label{font-family:"Syne",sans-serif;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text3);margin-bottom:6px}
.wex-text{font-size:12px;color:var(--text2);line-height:1.65;font-style:italic}

.wch{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.ch{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;padding:5px 12px;font-size:11.5px;color:var(--text2)}

.wdivider{height:1px;background:var(--border);margin:12px 0}
.wfooter{display:flex;align-items:center;justify-content:space-between}
.wplan-name{font-family:"Syne",sans-serif;font-size:12px;font-weight:700;color:var(--text)}
.wplan-sub{font-size:11px;color:var(--text3);margin-top:2px}
.wbadge{font-family:"Syne",sans-serif;font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:5px 13px;border-radius:100px;border:1px solid;transition:all .3s}
.wblue   .wbadge{color:var(--blue);border-color:rgba(61,142,245,.35);background:rgba(61,142,245,.08)}
.wgreen  .wbadge{color:var(--green);border-color:rgba(34,201,138,.35);background:rgba(34,201,138,.08)}
.wgold   .wbadge{color:var(--gold);border-color:rgba(232,184,75,.35);background:rgba(232,184,75,.08)}
.wpurple .wbadge{color:var(--purple);border-color:rgba(167,139,250,.35);background:rgba(167,139,250,.08)}
.wred    .wbadge{color:var(--red);border-color:rgba(255,94,122,.35);background:rgba(255,94,122,.08)}

.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:20px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px}

#precios{padding:100px 0;background:linear-gradient(180deg,transparent,rgba(10,22,40,.3),transparent)}
.price-table{width:100%;border-collapse:collapse;margin-top:16px}
.price-table th{font-family:"Syne",sans-serif;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text3);padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}
.price-table td{padding:16px 16px;border-bottom:1px solid rgba(26,46,72,.4);font-size:13.5px;color:var(--text2);vertical-align:middle}
.price-table tr:hover td{background:rgba(255,255,255,.02)}
.price-table tr:last-child td{border-bottom:none}
.pt-name{display:flex;align-items:center;gap:12px}
.pt-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.pt-worker{font-family:"Syne",sans-serif;font-size:14px;font-weight:700;color:var(--text)}
.pt-desc{font-size:11.5px;color:var(--text3);margin-top:2px}
.price-num{font-family:"Syne",sans-serif;font-size:15px;font-weight:700;color:var(--text)}
.price-sub{font-size:11px;color:var(--text3)}
.price-wrap{background:var(--s1);border:1px solid var(--border);border-radius:20px;overflow:hidden}
.price-cards{width:100%}
.pc-header{display:grid;grid-template-columns:2fr 1.2fr 1fr 1fr;padding:12px 20px;border-bottom:1px solid var(--border)}
.pc-header div{font-family:"Syne",sans-serif;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text3)}
.pc-row{display:grid;grid-template-columns:2fr 1.2fr 1fr 1fr;padding:16px 20px;border-bottom:1px solid rgba(26,46,72,.4);align-items:center;transition:background .2s}
.pc-row:hover{background:rgba(255,255,255,.02)}
.pc-col-worker{}
.pc-col-canal{font-size:13px;color:var(--text2)}
.pc-col-price{}
.pc-tag{font-size:12px;color:var(--text2)}
.pc-tag-call{color:var(--text2)}

/* Nota pequeña en Max */
.pc-note{
  display:block;
  font-size:10px;
  color:var(--green);
  margin-top:2px;
  font-style:italic;
}

.price-note{background:linear-gradient(135deg,var(--s2),var(--s1));border:1px solid var(--border);border-radius:16px;padding:24px 28px;margin-top:16px;display:grid;grid-template-columns:1fr 1fr;gap:20px}

.price-promo-hint{display:flex;align-items:center;gap:14px;background:rgba(255,94,122,.06);border:1px solid rgba(255,94,122,.25);border-radius:12px;padding:14px 20px;margin-top:12px}
.pph-fire{font-size:20px;flex-shrink:0}
.pph-label{font-family:"Syne",sans-serif;font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:4px}
.pph-text{font-size:13px;color:var(--text2)}
.pph-text strong{color:var(--text);font-family:"Syne",sans-serif}
.pph-old{font-size:11px;color:var(--text3);text-decoration:line-through;margin-left:2px}
.pn-item{}
.pn-label{font-family:"Syne",sans-serif;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text3);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.pn-label span{font-size:14px}
.pn-text{font-size:13px;color:var(--text2);line-height:1.7}



/* ── SOCIAL DOCK ── */
.social-dock{
  position:fixed;bottom:40px;left:40px;z-index:400;
  display:flex;flex-direction:column;gap:12px;
}
.social-item{
  display:flex;align-items:center;text-decoration:none;
  color:var(--text3);transition:all .3s ease;position:relative;
}
.si-icon{
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  border-radius:12px;border:1px solid var(--border);
  background:rgba(10,22,40,.6);backdrop-filter:none;
  transition:all .3s ease;
}
.si-icon svg{width:20px;height:20px;fill:currentColor;}
.si-label{
  position:absolute;left:52px;
  font-family:"Syne",sans-serif;font-size:11px;font-weight:700;
  letter-spacing:.05em;color:var(--text);
  background:var(--s2);padding:8px 14px;border-radius:8px;
  border:1px solid var(--border);
  opacity:0;transform:translateX(-10px);pointer-events:none;
  transition:all .3s cubic-bezier(.22,1,.36,1);
  white-space:nowrap;box-shadow:0 8px 24px rgba(0,0,0,.4);
}
.social-item:hover .si-icon{
  color:var(--cyan);border-color:rgba(0,200,255,.4);
  background:rgba(0,200,255,.1);
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(0,0,0,.3);
}
.social-item:hover .si-label{
  opacity:1;transform:translateX(0);
}

/* ── RESPONSIVE MÓVIL ── */
@media(max-width:820px){
  .price-note{grid-template-columns:1fr}
  .workers-explainer{grid-template-columns:1fr;gap:28px;padding:28px 22px}
  .we-title{font-size:22px}
  .social-dock{display:none}
}

@media(max-width:600px){
  .pc-header{display:none}
  .pc-row{display:flex;flex-direction:column;gap:8px;padding:20px 18px;border-bottom:1px solid rgba(26,46,72,.5)}
  .pc-col-canal::before{content:"Canal: ";font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-right:4px}
  .pc-col-price{display:flex;align-items:baseline;gap:6px}
  .pc-col-price .price-num{font-size:14px}
  .pc-col-price:nth-child(3)::before{content:"Instalación · ";font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}
  .pc-col-price:nth-child(4)::before{content:"Mensualidad · ";font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}
  .pc-col-price .price-sub{display:none}
  .pc-note{display:inline;margin-left:4px}
  .price-note{padding:20px 18px;gap:16px}
  .pn-text{font-size:12.5px}
}
/* ── PROCESO ── */
#proceso{padding:100px 0}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;margin-top:16px}
.steps::before{content:"";position:absolute;top:28px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--border2),var(--border2),transparent)}
.step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 12px;position:relative}
.step-num{width:56px;height:56px;border-radius:50%;background:var(--s2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-family:"Syne",sans-serif;font-size:16px;font-weight:800;color:var(--text2);margin-bottom:20px;position:relative;z-index:2;transition:all .3s ease}
.step:hover .step-num{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 0 24px var(--blue-g)}
.step-title{font-family:"Syne",sans-serif;font-size:12px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:.04em}
.step-desc{font-size:11.5px;color:var(--text2);line-height:1.65}

/* ── CTA FINAL ── */
#cta{padding:120px 0;text-align:center}
.cta-box{
  max-width:680px;margin:0 auto;
  background:linear-gradient(145deg,var(--s2),var(--s1));
  border:1px solid var(--border);border-radius:28px;padding:64px 56px;
  position:relative;overflow:hidden;
}
.cta-box::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.35}
.cta-box::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at top,rgba(0,200,255,.04) 0%,transparent 70%);pointer-events:none}
.cta-glow{position:absolute;width:400px;height:400px;top:-200px;left:50%;transform:translateX(-50%);background:radial-gradient(circle,rgba(61,142,245,.1),transparent 70%);pointer-events:none}
.cta-box h2{font-family:"Syne",sans-serif;font-size:clamp(32px,5vw,52px);font-weight:700;line-height:1.05;letter-spacing:-.025em;margin-bottom:18px;position:relative;z-index:1}
.cta-box h2 em{font-style:normal;background:linear-gradient(135deg,var(--cyan),var(--blue2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cta-box p{font-size:15px;color:var(--text2);line-height:1.8;max-width:460px;margin:0 auto 36px;position:relative;z-index:1}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.wa-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(135deg,#22c93a,#1a9e2e);color:#fff;
  border:none;padding:14px 32px;border-radius:100px;
  font-family:"Syne",sans-serif;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;text-decoration:none;
  box-shadow:0 0 32px rgba(34,201,58,.3),0 8px 24px rgba(0,0,0,.4);
  transition:all .3s ease;
}
.wa-btn:hover{transform:translateY(-3px);box-shadow:0 0 50px rgba(34,201,58,.5),0 16px 40px rgba(0,0,0,.5)}
.wa-num{font-size:13px;color:var(--text2);margin-top:16px;position:relative;z-index:1}
.wa-num a{color:var(--cyan);text-decoration:none}
.wa-num a:hover{text-decoration:underline}

/* ── FOOTER ── */
footer{border-top:1px solid var(--border);padding:40px;text-align:center;position:relative;z-index:1}
.foot-brand{font-family:"Syne",sans-serif;font-size:15px;font-weight:800;letter-spacing:.12em;color:var(--cyan);text-transform:uppercase;margin-bottom:8px}
.foot-tagline{font-size:12.5px;color:var(--text3)}

/* ── DIFFERENTIATOR BANNER ── */
#differentiator{
  position:relative;z-index:2;
  padding:80px 0 0;margin:0;
  background:linear-gradient(135deg,#020915 0%,#050e20 40%,#030c1a 100%);
  border-top:1px solid rgba(0,200,255,.12);
  border-bottom:1px solid rgba(0,200,255,.12);
  overflow:hidden;
}
#differentiator::before{
  content:"";position:absolute;inset:0;
  background: radial-gradient(ellipse at 20% 50%,rgba(61,142,245,.08) 0%,transparent 70%),
             radial-gradient(ellipse at 80% 50%,rgba(0,200,255,.06) 0%,transparent 60%);
  pointer-events:none;
}
.diff-combo {
  text-align: left;
  max-width: 500px;
  margin: 0;
  padding: 40px 20px 100px;
}
.diff-solution {
  margin-top: 40px;
  margin-bottom: 48px;
}
.diff-solution .tag {
  font-family: "Syne", sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--cyan);
  display: inline-block;
  margin-bottom: 24px;
  border: 1px solid rgba(0, 200, 255, 0.2);
  padding: 8px 16px;
  border-radius: 8px;
  background: rgba(0, 200, 255, 0.05);
  text-align: center;
}
.diff-text {
  font-size: 15px;
  color: var(--text2);
  line-height: 1.8;
  max-width: 600px;
  margin: 0;
}

.diff-right-image {
  position: absolute;
  top: 50%;
  right: -7%;
  width: 60%;
  /* max-width: 520px; */
  height: auto;
  z-index: 3;
  pointer-events: none;
  filter: drop-shadow(0 20px 50px rgba(0,0,0,0.5));
  transform: translateY(-50%) rotate(3deg);
  -webkit-mask-image: linear-gradient(to bottom, black 70%, transparent 98%);
  mask-image: linear-gradient(to bottom, black 70%, transparent 98%);
}

/* ── CASOS REALES ── */
#casos{padding:100px 0;background:linear-gradient(180deg,transparent,rgba(10,22,40,.4),transparent)}
.casos-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:40px}
.caso-card{
  background:var(--s1);border:1px solid var(--border);border-radius:20px;
  padding:28px;position:relative;overflow:hidden;transition:all .35s ease;
}
.caso-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),var(--green));opacity:.4;transition:opacity .3s}
.caso-card:hover{transform:translateY(-4px);border-color:var(--border2);box-shadow:0 20px 50px rgba(0,0,0,.5)}
.caso-card:hover::before{opacity:1}
.caso-eyebrow{font-family:"Syne",sans-serif;font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px;display:flex;align-items:center;gap:8px;background:rgba(0,200,255,.08);border:1px solid rgba(0,200,255,.2);padding:8px 14px;border-radius:8px;width:fit-content}
.caso-eyebrow span{font-size:16px}
.caso-phase{margin-bottom:14px}
.caso-phase-label{font-family:"Syne",sans-serif;font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text3);margin-bottom:6px;display:flex;align-items:center;gap:8px}
.caso-phase-label .ph-dot{width:6px;height:6px;border-radius:50%}
.ph-before{background:var(--red)}
.ph-after{background:var(--green)}
.caso-phase p{font-size:13px;color:var(--text2);line-height:1.7;margin:0}
.caso-divider{height:1px;background:var(--border);margin:14px 0}
.caso-results{display:flex;flex-direction:column;gap:5px}
.caso-result-item{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text)}
.caso-result-item::before{content:"✔";color:var(--green);font-weight:700;flex-shrink:0;font-size:11px}
.casos-summary{
  background:linear-gradient(135deg,var(--s2),var(--s1));
  border:1px solid var(--border2);border-radius:20px;padding:32px 40px;
  display:flex;align-items:flex-start;gap:48px;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.casos-summary::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);opacity:.35}
.casos-summary::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at top left,rgba(34,201,138,.04) 0%,transparent 60%);pointer-events:none}
.cs-label{font-family:"Syne",sans-serif;font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--text3);margin-bottom:16px;flex-basis:100%}
.cs-stat{display:flex;align-items:center;gap:14px;flex:1;min-width:160px}
.cs-icon{font-size:24px;width:48px;height:48px;background:var(--s3);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cs-text .cs-num{font-family:"Syne",sans-serif;font-size:13px;font-weight:700;color:var(--text);line-height:1.3}
.cs-text .cs-sub{font-size:12px;color:var(--text2)}

/* ── CÓMO TRABAJAN JUNTOS ── */
#juntos{padding:80px 0;background:linear-gradient(180deg,transparent,rgba(10,22,40,.3),transparent)}
.juntos-inner{max-width:860px;margin:0 auto;text-align:center}
.juntos-flow{
  display:flex;align-items:center;justify-content:center;gap:0;
  margin:44px 0;flex-wrap:wrap;
}
.jf-step{
  background:var(--s1);border:1px solid var(--border);border-radius:14px;
  padding:14px 20px;text-align:center;min-width:100px;
  transition:all .3s ease;cursor:default;
}
.jf-step:hover{border-color:var(--cyan);transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,0,0,.4)}
.jf-icon{font-size:22px;margin-bottom:6px}
.jf-label{font-family:"Syne",sans-serif;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text2)}
.jf-arrow{color:var(--text3);font-size:18px;margin:0 8px;flex-shrink:0;align-self:center}
.juntos-desc{font-size:15px;color:var(--text2);line-height:1.85;max-width:540px;margin:0 auto 28px}
.juntos-note{
  display:inline-flex;align-items:center;gap:12px;
  background:rgba(0,200,255,.06);border:1px solid rgba(0,200,255,.15);
  border-radius:14px;padding:16px 24px;
  font-size:14px;color:var(--text);
}
.juntos-note span{font-size:20px}

/* ── ANIMATIONS ── */
@keyframes up{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.on{opacity:1;transform:translateY(0)}

/* ── BUTTON SHINE ANIMATION ── */
@keyframes shine-flash {
  0%, 90% { left: -150%; }
  100% { left: 150%; }
}

/* ── RESPONSIVE ── */
@media(max-width:820px){

  .diff-right-image{display:none}

  nav{padding:12px 20px}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav-mobile{display:flex}
  .wrap{padding:0 20px}
  .about-grid{grid-template-columns:1fr}
  .mejoras-grid{grid-template-columns:1fr 1fr}
  .grid3,.grid2{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr;row-gap:32px}
  .steps::before{display:none}
  .cta-box{padding:44px 24px}
  .price-note{grid-template-columns:1fr}
  h1{font-size:42px}
  #hero{padding:110px 20px 70px}
  .hero-inner{padding:0}
  .hero-btns{flex-direction:column;align-items:center}
  .btn-primary,.btn-secondary{width:100%;max-width:300px;text-align:center;padding:13px 28px}
  #about{padding:70px 0}
  #mejoras{padding:60px 0}
  #workers{padding:70px 0}
  .wname{font-size:26px}
  h2, .sec-title, .about-text h2, .diff-headline h2, .cta-box h2 {font-size:40px}
  .qs-text h2{font-size:35px}
  #quienes-somos{padding:70px 16px}
  .qs-grid{grid-template-columns:1fr}
  .diff-inner{grid-template-columns:1fr;gap:40px;padding:60px 20px}
  .casos-grid{grid-template-columns:1fr}
  .casos-summary{gap:24px;padding:24px}
  .juntos-flow{gap:6px}
  .jf-arrow{font-size:14px;margin:0 4px}

  .mpromo-header, .vpromo-header {
    font-size:10px;
    font-weight: bold;
    padding:4px 4px;
  }
}
@media(max-width:540px){

  .diff-combo {text-align: center;}
  /* h2 {font-size:40px} */
  .mejoras-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  nav{padding:10px 16px}
  .wrap{padding:0 16px}
  .nav-cta{padding:8px 6px;font-size:8px;letter-spacing:.06em;  text-align: center;}
  /* .nav-name{font-size:14px} */
  .nav-logo{width:30px;height:30px}
  h1{font-size:42px}
  .hero-sub{font-size:15px}
  .hero-pill{padding:7px 16px}
  .pill-text{font-size:10px}
  .qs-stat-card{padding:18px 20px;gap:14px}
  .qs-stat-num{font-size:30px;min-width:64px}
  .workers-explainer{padding:22px 18px;gap:22px}
  .we-steps span:first-child{font-size:15px}

  /* ── Mobile Worker Cards Optimization ── */
  .wcard-front, .wcard-back { padding: 16px 14px; }
  .wtop { margin-bottom: 8px; }
  .wname { font-size: 26px; margin-bottom: 2px; }
  .wrole { font-size: 11.5px; margin-bottom: 10px; }
  .wibox { width: 42px; height: 42px; }
  .wibox svg { width: 22px; height: 22px; }
  
  .wavatar { margin-bottom: 8px; margin-top: 0; }
  .wavatar img { width: 130px; height: 130px; border-radius: 16px; }
  .wavatar::after { width: 130px; }
  
  .wdesc { font-size: 12px; line-height: 1.5; margin-bottom: 8px; }
  .wlabel { margin-bottom: 4px; }
  .wtasks { margin-bottom: 8px; }
  .wtasks li { padding: 2px 0; }
  
  /* Ocultar ejemplo para ahorrar espacio vertical crítico */
  .wexample { display: none; }
  
  .wch { margin-bottom: 10px; }
  .wdivider { margin: 10px 0; }

  /* Ajuste etiquetas promo para que no tapen el nombre */
  .vpromo-box, .mpromo-box {
    border-radius: 0 12px 0 8px;
    box-shadow: -1px 2px 4px rgba(0,0,0,0.2);
  }
  .vpromo-header, .mpromo-header {
    padding: 4px 4px !important;
    font-size: 10px !important;
    font-weight: bold !important;
  }
  .vpromo-body, .mpromo-body {
    padding: 4px 4px !important;
  }
  .vpromo-price, .mpromo-price {
    font-size: 11px !important;
    font-weight: bold !important;
  }
  .mpromo-old {
    font-size: 7px;
    line-height: 1;
  }
}

/* ── WORKERS CAROUSEL CLEAN (NO BLUR/SCALE) ── */
.workers-slider-container {
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
}
.workers-slider-wrapper {
  width: 100%;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 20px 0 40px;
  cursor: grab;
}
.workers-slider-wrapper::-webkit-scrollbar { display: none; }

.workers-slider-track {
  display: flex;
  flex-direction: row !important;
  gap: 24px;
  padding: 0 10%;
  width: max-content;
}

.workers-slider-track .wcard {
  scroll-snap-align: center;
  flex: 0 0 380px;
  min-width: 380px;
  height: auto;
  user-select: none;
  /* Eliminamos escala y opacidad reducida para maxima nitidez */
  opacity: 1 !important;
  transform: translateZ(0) scale(1) !important;
  filter: none !important;
  transition: transform 0.3s ease;
}

/* Flechas de Navegación */
.slider-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 45px;
  height: 45px;
  background: rgba(10, 22, 40, 0.8);
  border: 1px solid var(--border2);
  border-radius: 50%;
  color: white;
  cursor: pointer;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}
.slider-arrow:hover {
  background: var(--blue);
  box-shadow: 0 0 15px var(--blue-g);
}
.slider-arrow svg { width: 24px; height: 24px; }
.slider-arrow.prev { left: 20px; }
.slider-arrow.next { right: 20px; }

.slider-dots {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 10px;
}
.dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border2);
  cursor: pointer;
}
.dot.active {
  background: var(--cyan);
  transform: scale(1.2);
}

@media (max-width: 820px) {
  .slider-arrow { display: none; }
  .workers-slider-track .wcard { 
    flex: 0 0 300px; 
    min-width: 300px; 
    opacity: 1 !important; /* Brillo máximo en móvil para legibilidad total */
  }
  /* Quitamos los degradados laterales en movil para evitar que se vea oscuro */
  .workers-slider-container::before,
  .workers-slider-container::after {
    display: none;
  }
  .banner-img {
    object-position: 15% center;
  }
}
 

/* ── WORKER AVATAR ── */
.wavatar {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-bottom: 8px;
  margin-top: 0;
  position: relative;
}
.wavatar::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 180px;
  height: 20px;
  background: radial-gradient(ellipse, rgba(0,0,0,0.35) 0%, transparent 70%);
  border-radius: 50%;
  z-index: 0;
}
.wavatar img {
  width: 150px;
  height: 150px;
  object-fit: cover;
  object-position: top center;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.07);
  background: transparent;
  filter: drop-shadow(0 12px 32px rgba(0,0,0,0.6));
  transition: transform 0.35s cubic-bezier(.22,.68,0,1.2), filter 0.35s ease;
  position: relative;
  z-index: 1;
}
.wcard.flipped .wavatar img {
  transform: translateY(-5px) scale(1.04);
  filter: drop-shadow(0 20px 40px rgba(0,0,0,0.7));
}
.wblue .wavatar img   { filter: drop-shadow(0 12px 32px rgba(61,142,245,0.25)); }
.wgreen .wavatar img  { filter: drop-shadow(0 12px 32px rgba(34,201,138,0.22)); }
.wgold .wavatar img   { filter: drop-shadow(0 12px 32px rgba(232,184,75,0.28)); }
.wpurple .wavatar img { filter: drop-shadow(0 12px 32px rgba(167,139,250,0.28)); }
.wred .wavatar img    { filter: drop-shadow(0 12px 32px rgba(255,94,122,0.28)); }
.wcard:hover .wblue .wavatar img   { filter: drop-shadow(0 20px 48px rgba(61,142,245,0.4)); }
.wcard:hover .wgreen .wavatar img  { filter: drop-shadow(0 20px 48px rgba(34,201,138,0.4)); }
.wcard:hover .wgold .wavatar img   { filter: drop-shadow(0 20px 48px rgba(232,184,75,0.45)); }
.wcard:hover .wpurple .wavatar img { filter: drop-shadow(0 20px 48px rgba(167,139,250,0.45)); }
.wcard:hover .wred .wavatar img    { filter: drop-shadow(0 20px 48px rgba(255,94,122,0.45)); }


/* ── HERO BANNER ── */
#hero-banner {
  position: relative;
  width: 100%;
  overflow: hidden;
  z-index: 1;
  line-height: 0;
  margin-top: 70px;
  height: 100vh;
}
.banner-img {
  width: 100%;
  height: 100%;
  display: block;
  max-width: 100%;
  opacity: 0.2;
  object-fit: cover;
}
/* Top fade overlay - keeps nav readable */
.banner-fade-top {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 120px;
  background: linear-gradient(to bottom, rgba(4,7,15,0.55), transparent);
  z-index: 2;
  pointer-events: none;
}
/* Bottom fade - difumina hacia el fondo de la página */
.banner-fade-bottom {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 40%;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(4,7,15,0.2) 25%,
    rgba(4,7,15,0.6) 55%,
    rgba(4,7,15,0.9) 80%,
    #04070f 100%
  );
  z-index: 2;
  pointer-events: none;
}
/* Side fades for polish */
.banner-fade-left {
  position: absolute;
  top: 0; bottom: 0; left: 0;
  width: 80px;
  background: linear-gradient(to right, rgba(4,7,15,0.35), transparent);
  z-index: 2;
  pointer-events: none;
}
.banner-fade-right {
  position: absolute;
  top: 0; bottom: 0; right: 0;
  width: 80px;
  background: linear-gradient(to left, rgba(4,7,15,0.35), transparent);
  z-index: 2;
  pointer-events: none;
}

/* Scroll indicator */
.banner-scroll {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  opacity: 0.5;
  animation: scrollbob 2.2s ease-in-out infinite;
  pointer-events: none;
}
.banner-scroll span {
  font-family: "Syne", sans-serif;
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--text2);
}
.banner-scroll svg { width: 18px; height: 18px; }
@keyframes scrollbob {
  0%,100% { transform: translateX(-50%) translateY(0); opacity:0.5; }
  50%      { transform: translateX(-50%) translateY(6px); opacity:0.8; }
}

#hero-banner .hero-inner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
  width: 100%;
  text-align: center;
}

.banner-text {
  position: absolute;
  top: 50%;
  left: 6%;
  transform: translateY(-50%);
  z-index: 3;
  max-width: 700px;
  text-align: left;
}
.banner-text h1 {
  color: #fff;
  text-shadow: 0 4px 24px rgba(0,0,0,0.7);
  font-size: 60px;
  font-weight: 700;
  line-height: 1.1;
  margin: 0;
}
.banner-btns {
  margin-top: 32px;
  display: flex;
  gap: 16px;
}
/* Estilos para la nueva imagen en el lado derecho */
.hero-right-image {
  position: absolute;
  bottom: 0; /* Ajusta según sea necesario para la posición vertical */
  right: 0;
  width: 45%; /* Ajusta el tamaño de la imagen */
  max-width: 500px; /* Tamaño máximo para la imagen */
  height: auto;
  z-index: 3; /* Asegurar que esté por encima de los degradados */
  pointer-events: none; /* Para que no interfiera con clics en el texto/botones */
  opacity: 0.8; /* Ajusta la opacidad si quieres que sea más sutil */
  transform: translateX(10%); /* Empuja un poco hacia afuera para un efecto de "asomarse" */
  transition: transform 0.5s ease-out, opacity 0.5s ease-out;
}

/* Ajustes responsivos para la imagen */
@media (max-width: 1200px) {
  .hero-right-image {
    width: 40%;
    transform: translateX(5%);
  }
}

  .orb-a {
    width: 300px !important;
    height: 300px !important;
    top: -100px !important;
  }

  .orb-b {
    width: 220px !important;
    height: 220px !important;
  }

  .orb-c {
    width: 160px !important;
    height: 160px !important;
  }
.hero,
.banner,
header {
  min-height: auto !important;
  padding: 20px 20px !important;
}

.hero h1 {
  font-size: 28px !important;
  line-height: 1.2 !important;
  margin-top: 0 !important;
}
.hero-inner {
  width: 100% !important; /* En móviles, el texto puede ocupar todo el ancho */
  transform: translate(-50%, -50%) !important; /* Asegura que el texto siga centrado horizontalmente */
}

.hero p {
  font-size: 16px !important;
}.hero {
  display: block !important;
  text-align: center !important;
  margin-top: -35px !important; 
}

.hero .content,
.hero .container {
  width: 100% !important;
}

nav {
  padding: 12px 20px !important;
}
  #hero-banner {
  height: 100vh;
  overflow: hidden;
}

.banner-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.banner-text {
  left: 20px;
  right: 20px;
  max-width: none;
}


 /* VALERY — bloque promo */
.vpromo-box {
  position: absolute;
  top: -1px;
  right: -1px;
  z-index: 20;
  margin: 0;
  border-radius: 0 24px 0 16px;
  overflow: hidden;
  border: 1px solid rgba(245, 208, 106, 0.5);
  box-shadow: -2px 4px 10px rgba(0,0,0,0.25);
}

.vpromo-header {
  background: linear-gradient(90deg, #c8810a, #f5d06a, #c8810a);
  border-bottom: 1px solid rgba(245, 208, 106, 0.3);
  padding: 4px 10px;
  text-align: center;
  font-size: 10px;
  font-weight: 900;
  color: #0d1b2a;
  letter-spacing: -0.2px;
  font-family: "Syne", sans-serif;
  text-transform: uppercase;
}

.vpromo-body {
  background: #f5d06a;
  padding: 6px 10px;
  text-align: center;
}

.vpromo-sub {
  display: none;
}

.vpromo-price {
  font-size: 11px;
  font-weight: 800;
  color: #0d1b2a;
  letter-spacing: -0.5px;
  line-height: 1.1;
  margin: 0;
  font-family: "Syne", sans-serif;
}

.vpromo-old {
  font-size: 9px;
  color: rgba(0, 0, 0, 0.5);
  text-decoration: line-through;
  margin: 0;
}

.vpromo-note {
  display: none;
}



/* ===== TIM — Worker 02 CSS ===== */

.tw2-card {
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 32px 28px 26px;
  position: relative;
  overflow: hidden;
  transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s ease, border-color .35s ease;
  cursor: default;
  --ac: var(--green);
  --ac-g: var(--green-g);
}

.tw2-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 15%;
  right: 15%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--ac), transparent);
  opacity: .2;
  transition: opacity .35s, left .35s, right .35s;
}

.tw2-card::after {
  content: "";
  position: absolute;
  top: -2px;
  right: -2px;
  width: 70px;
  height: 70px;
  background: radial-gradient(circle at top right, var(--ac-g), transparent 70%);
  border-radius: 0 24px 0 0;
  opacity: 0;
  transition: opacity .35s;
}

.tw2-card:hover {
  transform: translateY(-6px);
  border-color: var(--ac);
  box-shadow: 0 0 0 1px var(--ac), 0 30px 60px rgba(0,0,0,.6), 0 0 40px var(--ac-g);
}

.tw2-card:hover::before { opacity: 1; left: 0; right: 0; }
.tw2-card:hover::after  { opacity: 1; }
.tw2-card:hover .tw2-ibox {
  border-color: var(--ac);
  box-shadow: 0 0 16px var(--ac-g);
}

.tw2-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 24px;
}

.tw2-num {
  font-family: "Syne", sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--text3);
  margin-bottom: 4px;
}

.tw2-name {
  font-family: "Syne", sans-serif;
  font-size: 42px;
  font-weight: 800;
  font-style: italic;
  color: var(--text);
  line-height: 1;
  letter-spacing: -1px;
  margin-bottom: 4px;
}

.tw2-role {
  font-family: "DM Sans", sans-serif;
  font-size: 13px;
  font-style: italic;
  color: var(--text2);
}

.tw2-ibox {
  width: 48px;
  height: 48px;
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: border-color .35s, box-shadow .35s;
}

.tw2-ibox svg {
  width: 26px;
  height: 26px;
}

.tw2-avatar {
  display: flex;
  justify-content: center;
  margin-bottom: 24px;
}

.tw2-avatar img {
  width: 190px;
  height: 190px;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid var(--border);
}

.tw2-desc {
  font-family: "DM Sans", sans-serif;
  font-size: 13px;
  line-height: 1.7;
  color: var(--text2);
  margin: 0 0 18px 0;
}

.tw2-label {
  font-family: "Syne", sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 10px;
}

.tw2-tasks {
  list-style: none;
  padding: 0;
  margin: 0 0 20px 0;
}

.tw2-card .tw2-tasks li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: "DM Sans", sans-serif;
  font-size: 13px;
  color: var(--text2);
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}

.tw2-card .tw2-tasks li:last-child {
  border-bottom: none;
}

.tw2-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
}

.tw2-example {
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
  margin-bottom: 20px;
}

.tw2-ex-label {
  font-family: "Syne", sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: 8px;
}

.tw2-ex-text {
  font-family: "DM Sans", sans-serif;
  font-size: 13px;
  font-style: italic;
  color: var(--text2);
  line-height: 1.65;
}

.tw2-ch {
  margin-bottom: 20px;
}

.tw2-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 5px 14px;
  font-family: "DM Sans", sans-serif;
  font-size: 12.5px;
  color: var(--text2);
}

.tw2-divider {
  height: 1px;
  background: var(--border);
  margin-bottom: 18px;
}

.tw2-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.tw2-plan-name {
  font-family: "Syne", sans-serif;
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
}

.tw2-plan-sub {
  font-family: "DM Sans", sans-serif;
  font-size: 12px;
  color: var(--text2);
  margin-top: 2px;
}

.tw2-badge {
  background: linear-gradient(135deg, rgba(34,201,138,.15), rgba(34,201,138,.05));
  border: 1px solid rgba(34,201,138,.3);
  color: var(--green);
  font-family: "Syne", sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 20px;
}
  /* MAX — bloque promo plan completo */
.mpromo-box, .vpromo-box{
  position: absolute;
  top: -1px;
  right: -1px;
  z-index: 20;
  margin: 0;
  border-radius: 0 24px 0 16px;
  overflow: hidden;
  border: 1px solid rgba(34, 201, 138, 0.5);
  box-shadow: -2px 4px 10px rgba(0,0,0,0.25);
}

.mpromo-header {
  background: linear-gradient(90deg, #0b5c38, #22c98a, #0b5c38);
  border-bottom: 1px solid rgba(34, 201, 138, 0.3);
  padding: 4px 10px;
  text-align: center;
  font-family: "Syne", sans-serif;
  font-size: 10px;
  font-weight: 900;
  color: #04100a;
  letter-spacing: -0.2px;
  text-transform: uppercase;
}

.mpromo-body {
  background: #22c98a;
  padding: 6px 10px;
  text-align: center;
}

.mpromo-sub {
  display: none;
}

.mpromo-price {
  font-family: "Syne", sans-serif;
  font-size: 11px;
  font-weight: 800;
  color: #04100a;
  letter-spacing: -0.5px;
  line-height: 1.1;
  margin: 0;
}

.mpromo-old {
  font-size: 9px;
  color: rgba(0, 0, 0, 0.5);
  text-decoration: line-through;
  margin: 0;
}

.mpromo-note {
  display: none;
}
  /* ===== PLANES Y ESCALERA ===== */
#planes {
  padding: 80px 0;
}

.planes-box {
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 40px 36px;
  max-width: 560px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
}

.planes-box::before {
  content: "";
  position: absolute;
  top: 0;
  left: 15%;
  right: 15%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--blue), transparent);
  opacity: .15;
}

.sec-sub {
  font-family: "DM Sans", sans-serif;
  font-size: 15px;
  color: var(--text2);
  text-align: center;
  margin-top: 12px;
}

/* Tabla de niveles */
.planes-table {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 20px;
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
}

.planes-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  transition: background .2s;
}

.planes-row:last-child {
  border-bottom: none;
}

.planes-row:hover {
  background: var(--s2);
}

.planes-nivel {
  font-family: "Syne", sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text3);
  min-width: 52px;
}

.planes-nombre {
  font-family: "DM Sans", sans-serif;
  font-size: 13px;
  color: var(--text2);
  flex: 1;
}

.planes-precio {
  font-family: "Syne", sans-serif;
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
}

.planes-precio span {
  font-size: 11px;
  font-weight: 400;
  color: var(--text3);
}

/* Extras */
.planes-extras {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}

.planes-extra-item {
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 5px 12px;
  font-family: "DM Sans", sans-serif;
  font-size: 12px;
  color: var(--text2);
}

/* Promos activas — rojo Luke */
.ppromo-box {
  border-radius: 14px;
  overflow: hidden;
  border: 1.5px solid rgba(255, 94, 122, 0.45);
}

.ppromo-header {
  background: linear-gradient(90deg, #7a0a1a, #ff5e7a, #7a0a1a);
  padding: 13px 16px;
  text-align: center;
  font-family: "Syne", sans-serif;
  font-size: 14px;
  font-weight: 900;
  color: #fff;
  letter-spacing: -0.2px;
}

.ppromo-body {
  background: #ff5e7a;
  padding: 16px 20px;
}

.ppromo-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
}

.ppromo-label {
  font-family: "DM Sans", sans-serif;
  font-size: 13px;
  color: rgba(0,0,0,0.7);
}

.ppromo-price {
  font-family: "Syne", sans-serif;
  font-size: 16px;
  font-weight: 800;
  color: #04070f;
  display: flex;
  align-items: center;
  gap: 8px;
}

.ppromo-old {
  font-size: 11px;
  font-weight: 400;
  color: rgba(0,0,0,0.4);
  text-decoration: line-through;
}

.ppromo-divider {
  height: 1px;
  background: rgba(0,0,0,0.15);
}

/* ===== RESPONSIVE MÓVIL ===== */
@media (max-width: 540px) {
  .planes-box {
    padding: 28px 20px;
    border-radius: 18px;
  }

  .planes-title {
    font-size: 16px;
  }

  .planes-row {
    padding: 12px 14px;
    flex-wrap: wrap;
    gap: 6px;
  }

  .planes-nivel {
    min-width: 100%;
    margin-bottom: 2px;
  }

  .planes-nombre {
    font-size: 13px;
    flex: 1;
  }

  .planes-precio {
    font-size: 14px;
  }

  .planes-extras {
    gap: 8px;
  }

  .planes-extra-item {
    font-size: 11.5px;
    padding: 5px 10px;
  }

  .ppromo-header {
    font-size: 13px;
    padding: 12px 14px;
  }

  .ppromo-body {
    padding: 14px 16px;
  }

  .ppromo-label {
    font-size: 12.5px;
  }

  .ppromo-price {
    font-size: 15px;
  }
}

/* ------------FORMULARIO----------------------- */

/* ── FORMULARIO NISSI TECH ── */
.form-container {
  max-width: 800px;
  margin: 0 auto;
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: 28px;
  padding: 48px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 40px 80px rgba(0,0,0,0.5);
}

.form-container::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, var(--cyan), transparent);
  opacity: 0.4;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 24px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.form-group.full-width {
  grid-column: span 2;
}

.form-group label {
  font-family: "Syne", sans-serif;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text3);
}

.form-group input, 
.form-group textarea,
.form-group select {
  background: var(--s2);
  border: 1px solid var(--border2);
  border-radius: 12px;
  padding: 14px 18px;
  color: var(--text);
  font-family: inherit;
  font-size: 14px;
  transition: all 0.3s ease;
}

.form-group input:focus, 
.form-group textarea:focus,
.form-group select:focus {
  outline: none;
  border-color: var(--cyan);
  background: var(--s3);
  box-shadow: 0 0 15px rgba(0, 200, 255, 0.1);
}

/* Botón con efecto Nissi */
.form-submit-btn {
  width: fit-content;      /* El botón solo ocupa lo que mide el texto */
  min-width: 280px;        /* Pero le damos un mínimo para que tenga presencia */
  margin: 20px auto 0;
  background: linear-gradient(135deg, var(--blue), #2260d8);
  color: #fff;
  border: none;
  padding: 18px;
  border-radius: 100px;
  font-family: "Syne", sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  transition: all 0.3s ease;
  box-shadow: 0 10px 30px rgba(61, 142, 245, 0.3);
}

.form-submit-btn svg {
  width: 18px;
  transition: transform 0.3s ease;
}

.form-submit-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 15px 40px rgba(61, 142, 245, 0.5);
}

.form-submit-btn:hover svg {
  transform: translateX(5px);
}

.field-note {
  display: block;
  font-size: 11px;
  color: var(--text3); /* El azul grisáceo que ya usas */
  margin-top: 6px;
  line-height: 1.4;
  font-style: italic;
  opacity: 0.8;
  padding-left: 4px;
}

/* Efecto opcional: Que la nota resalte un poco cuando el usuario hace clic en el input */
.form-group input:focus + .field-note,
.form-group select:focus + .field-note,
.form-group textarea:focus + .field-note {
  color: var(--cyan);
  opacity: 1;
  transition: all 0.3s ease;
}

/* Responsive */
@media (max-width: 600px) {
  .form-grid { grid-template-columns: 1fr; }
  .form-group.full-width { grid-column: span 1; }
  .form-container { padding: 30px 20px; }
}

/* ── WORKERS CAROUSEL ── */
.workers-slider-container {
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  background: transparent;
}

/* Degradados en los extremos para el efecto de desvanecimiento */
.workers-slider-container::before,
.workers-slider-container::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 250px;
  z-index: 12;
  pointer-events: none;
}
.workers-slider-container::before {
  left: 0;
  background: linear-gradient(to right, var(--bg) 0%, var(--bg) 15%, rgba(0, 0, 0, 0) 100%);
}
.workers-slider-container::after {
  right: 0;
  background: linear-gradient(to left, var(--bg) 0%, var(--bg) 15%, rgba(0, 0, 0, 0) 100%);
}
.workers-slider-wrapper {
  width: 100%;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none; /* Firefox */
  padding: 20px 0 60px; /* Aumentamos padding inferior para que el scroll no tape los puntos */
  cursor: grab;
  background: transparent;
} 
.workers-slider-wrapper::-webkit-scrollbar {
  display: none; /* Chrome/Safari */
}
.workers-slider-wrapper:active {
  cursor: grabbing;
}
.workers-slider-track {
  display: flex;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  gap: 24px;
  padding: 0 10%; /* Espacio para que la primera/última tarjeta se centren */
  width: max-content;
  align-items: stretch;
  background: transparent;
}
.workers-slider-track .wcard {
  scroll-snap-align: center;
  flex: 0 0 380px;
  min-width: 380px;
  height: auto;
  user-select: none;
  transition: transform 0.3s ease, opacity 0.3s ease;
  filter: none !important;
  opacity: 1 !important;
  transform: translate3d(0,0,0) scale(1) !important;
  backface-visibility: hidden;
  -webkit-font-smoothing: antialiased;
  will-change: transform, opacity;
}
.workers-slider-track .wcard img {
  pointer-events: none;
  -webkit-user-drag: none;
}

/* Efecto Focus para la tarjeta central */
.workers-slider-track .wcard.focused {
  filter: none !important;
  opacity: 1 !important;
  transform: translateZ(0) scale(1) !important;
  z-index: 10;
  box-shadow: 0 0 40px rgba(61, 142, 245, 0.1); /* Sutil brillo para resaltar sobre negro */
}

/* Flechas de Navegación */
.slider-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 45px;
  height: 45px;
  background: rgba(10, 22, 40, 0.7);
  border: 1px solid var(--border2);
  border-radius: 50%;
  color: white;
  cursor: pointer;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  backdrop-filter: none;
}
.slider-arrow.disabled {
  opacity: 0.15;
  pointer-events: none;
  filter: grayscale(1);
}
.slider-arrow:hover {
  background: var(--blue);
  border-color: var(--blue2);
  box-shadow: 0 0 15px var(--blue-g);
}
.slider-arrow svg { width: 24px; height: 24px; }
.slider-arrow.prev { left: 20px; }
.slider-arrow.next { right: 20px; }

@media (max-width: 820px) {
  .slider-arrow.next { right: -30px; }
  .slider-arrow.prev { left: -30px; }

}

@media (max-width: 820px) {

.diff-right-image {
    display: block;
    position: relative;
    top: auto;
    right: 85px;
    width: 150%;
    /* max-width: 400px; */
    margin: 0 auto;
    transform: none;
    order: -1;
    -webkit-mask-image: none;
    mask-image: none;
  }

  .workers-slider-track .wcard {
    flex: 0 0 300px;
    min-width: 300px;
  }
  .workers-slider-track { padding: 0 20px; }
}

.slider-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  position: absolute; /* Sacar del flujo para que no ocupe espacio físico */
  bottom: 15px; /* Ubicar al final del contenedor relativo */
  left: 0;
  right: 0;
  z-index: 10;
  margin-top: 0;
}
.dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border2);
  cursor: pointer;
  transition: all 0.3s ease;
}
.dot.active {
  background: var(--cyan);
  transform: scale(1.5);
  box-shadow: 0 0 15px rgba(0, 200, 255, 0.4);
}

/* WhatsApp Button on Cards */
.w-wa-btn {
  position: absolute;
  bottom: 15px;
  right: 15px;
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, #25d366, #128c3e);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  z-index: 10;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  text-decoration: none;
}
.w-wa-btn:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 16px rgba(37, 211, 102, 0.4);
}
.w-wa-btn svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}





/* ═══ SERVICIOS DE CRECIMIENTO ═══ */
#servicios { padding: 80px 0; }
#servicios .sg-header { text-align: center; max-width: 680px; margin: 0 auto 48px; }
#servicios .servicios-sub { color: var(--text2); font-size: 1.05rem; line-height: 1.75; margin-top: 16px; }
#servicios .serv-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-bottom: 48px; }
#servicios .sg-cta { text-align: center; margin-top: 48px; }
#servicios .serv-card { background: #0e1c32; border: 1px solid #243d5e; border-radius: 20px; padding: 28px 24px; position: relative; overflow: hidden; transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s ease, border-color .35s ease; }
#servicios .serv-card::before { content: ""; position: absolute; top: 0; left: 15%; right: 15%; height: 1px; background: linear-gradient(90deg,transparent,#3d8ef5,transparent); opacity: .2; transition: opacity .35s, left .35s, right .35s; }
#servicios .serv-card::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at top left,rgba(61,142,245,.04),transparent 60%); pointer-events: none; }
#servicios .serv-card:hover { transform: translateY(-6px); border-color: var(--blue); box-shadow: 0 0 0 1px var(--blue), 0 30px 60px rgba(0,0,0,.6), 0 0 60px rgba(61,142,245,.2); }
#servicios .serv-card { background: linear-gradient(145deg, #0a1628, #0e1c32, #091520); border: 1px solid rgba(61,142,245,.25); border-radius: 20px; padding: 28px 24px; position: relative; overflow: hidden; transition: transform .35s cubic-bezier(.22,.68,0,1.2), box-shadow .35s ease, border-color .35s ease; }
#servicios .serv-icons { display: flex; gap: 14px; align-items: center; margin-bottom: 18px; flex-wrap: wrap; }
#servicios .serv-num { font-family: "Syne",sans-serif; font-size: 9px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--text3); margin-bottom: 10px; }
#servicios .serv-title { font-family: "Syne",sans-serif; font-size: 18px; font-weight: 800; letter-spacing: -.02em; line-height: 1.2; background: linear-gradient(135deg, #ffffff 0%, #7dd3fc 50%, #00c8ff 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
#servicios .serv-desc { font-size: 13px; color: var(--text2); line-height: 1.7; }
#servicios .serv-top { display: flex; align-items: center; justify-content: space-between; gap: 0; margin-bottom: 12px; }
@media (max-width: 900px) { #servicios .serv-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { #servicios .serv-grid { grid-template-columns: 1fr; } }

.wavatar { text-align: center; }
.wavatar img { display: block; margin: 0 auto; }

.steps-label { text-align: center; font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--text3); margin-bottom: 32px; }

@media (max-width: 768px) {
  #hero-banner .hero-inner {
    width: 90%;
  }
  #hero-banner .hero-inner h1 {
    line-height: 35px;
  }
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }
}
  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

  
 
  #hero-banner .hero-sub {
    margin-bottom: 35px;
  }
  .btn-primary, .btn-secondary {
    padding: 20px 28px !important;
  }
  #hero-banner .hero-pill {
    display: none;
  }
  #quienes-somos .wrap {
    width: 90%;
    padding-left: 0;
    padding-right: 0;
  }
  .qs-promise-list {
    align-items: flex-start;
  }
  #servicios .wrap,
  #about .wrap,
  #mejoras .wrap,
  #juntos .wrap,
  #proceso .wrap,
  #casos .wrap,
  #planes .wrap,
  #contacto .wrap,
  #precios .wrap,
  #cta .wrap {
    width: 90%;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }

/* ── LUKE ANIMATED CARD ── */
@keyframes lk-pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.15)} }
@keyframes lk-ring { 0%{transform:scale(1);opacity:.8} 100%{transform:scale(2.8);opacity:0} }
@keyframes lk-wave { 0%,100%{height:5px} 50%{height:28px} }
@keyframes lk-vib { 0%,100%{transform:rotate(0)} 25%{transform:rotate(-9deg)} 75%{transform:rotate(9deg)} }
.luke-animated { background:linear-gradient(160deg,#1a0a0a,#2d0f0f,#1a0505); display:flex; align-items:center; justify-content:center; border-radius:20px; }
.lk-c { display:flex; flex-direction:column; align-items:center; gap:14px; padding:1.5rem; }
.lk-tag { font-size:10px; color:rgba(255,255,255,0.35); letter-spacing:.18em; text-transform:uppercase; }
.lk-name { font-size:28px; font-weight:700; color:#fff; margin:0; }
.lk-smart { font-size:12px; color:rgba(255,150,150,0.6); margin:-8px 0 0; }
.lk-aw { position:relative; width:80px; height:80px; display:flex; align-items:center; justify-content:center; }
.lk-r { position:absolute; width:80px; height:80px; border-radius:50%; border:2px solid rgba(220,80,80,0.6); animation:lk-ring 2.2s ease-out infinite; }
.lk-r:nth-child(2){ animation-delay:.7s; }
.lk-r:nth-child(3){ animation-delay:1.4s; }
.lk-av { width:80px; height:80px; border-radius:50%; background:#3d0f0f; border:2px solid rgba(220,80,80,0.6); display:flex; align-items:center; justify-content:center; z-index:2; animation:lk-vib .5s ease-in-out infinite; }
.lk-ws { display:flex; align-items:center; gap:4px; height:32px; }
.lk-b { width:4px; border-radius:4px; background:rgba(220,80,80,0.8); height:5px; animation:lk-wave 1s ease-in-out infinite; }
.lk-b:nth-child(1){animation-delay:0s} .lk-b:nth-child(2){animation-delay:.1s} .lk-b:nth-child(3){animation-delay:.2s} .lk-b:nth-child(4){animation-delay:.3s} .lk-b:nth-child(5){animation-delay:.4s} .lk-b:nth-child(6){animation-delay:.3s} .lk-b:nth-child(7){animation-delay:.2s} .lk-b:nth-child(8){animation-delay:.1s} .lk-b:nth-child(9){animation-delay:0s}
.lk-btns { display:flex; gap:36px; align-items:center; }
.lk-bw { display:flex; flex-direction:column; align-items:center; gap:6px; }
.lk-rej { width:54px; height:54px; border-radius:50%; background:#c0392b; display:flex; align-items:center; justify-content:center; border:none; cursor:pointer; }
.lk-ans { width:62px; height:62px; border-radius:50%; background:#27ae60; display:flex; align-items:center; justify-content:center; border:none; cursor:pointer; animation:lk-pulse 1.2s ease-in-out infinite; }
.lk-bl { font-size:11px; color:rgba(255,255,255,0.4); }
/* ── NISSI BLOG ── */
.blog-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 24px;
  margin-top: 2.5rem;
}
.blog-card {
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: 20px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: border-color .3s, transform .3s;
  display: flex;
  flex-direction: column;
}
.blog-card:hover {
  border-color: var(--cyan);
  transform: translateY(-4px);
}
.blog-card-soon {
  opacity: .5;
  cursor: default;
  pointer-events: none;
}
.blog-card-img {
  width: 100%;
  height: 180px;
  overflow: hidden;
}
.blog-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.blog-card-img-soon {
  background: var(--s1);
  height: 180px;
}
.blog-card-body {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.blog-card-tag {
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--cyan);
}
.blog-card-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.5;
}
.blog-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.blog-card-date { font-size: 12px; color: var(--muted); }
.blog-card-read { font-size: 12px; color: var(--cyan); font-weight: 500; }
@media (max-width: 768px) {
  .blog-cards-grid { grid-template-columns: 1fr; }
}
  #blog .sec-title {
  text-align: center;
}
 /* ════════════════════════════════════════
   SECCIÓN: CORPORATIVO / INDUSTRIA
════════════════════════════════════════ */

/* ════════════════════════════════════════
   SECCIÓN: CORPORATIVO / INDUSTRIA
   Pegar al final de styles.css
════════════════════════════════════════ */

/* ── HERO GRID ── */
.cp-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  margin-bottom: 40px;
}

@media (max-width: 860px) {
  .cp-hero-grid { grid-template-columns: 1fr; gap: 36px; }
  .cp-right { display: none; }
}

.cp-left h2 {
  font-family: "Syne", sans-serif;
  font-size: clamp(24px, 3.2vw, 34px);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -.02em;
  color: var(--text);
  margin-bottom: 14px;
}

.cp-left h2 em {
  font-style: normal;
  background: linear-gradient(135deg, var(--blue2), var(--green2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cp-desc {
  font-size: 14px;
  color: var(--text2);
  line-height: 1.8;
  margin-bottom: 22px;
}

.cp-quote {
  border-left: 2px solid var(--blue);
  padding: 10px 16px;
  background: var(--blue-g);
  border-radius: 0 8px 8px 0;
}

.cp-quote p {
  font-size: 13px;
  color: var(--text2);
  line-height: 1.65;
  font-style: italic;
}

.cp-quote p strong {
  color: var(--text);
  font-style: normal;
}

/* ── TAG ── */
#corporativo-preview .tag {
  font-family: "Syne", sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: var(--blue2);
  background: var(--blue-g);
  border: 1px solid rgba(61,142,245,.25);
  border-radius: 6px;
  padding: 4px 12px;
  letter-spacing: .06em;
  display: inline-block;
  margin-bottom: 14px;
}

/* ── DIAGRAMA ── */
.cp-diagram {
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 28px 24px;
  position: relative;
  overflow: hidden;
}

.cp-diagram::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--blue), var(--cyan), transparent);
}

.cp-diag-label {
  font-family: "Syne", sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--text3);
  text-align: center;
  margin-bottom: 24px;
}

.cp-diag-body {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 16px;
  align-items: center;
  min-height: 160px;
}

.cp-d-col {
  display: flex;
  flex-direction: column;
  gap: 10px;
  justify-content: center;
}

.cp-d-col.right { align-items: flex-start; }

.cp-d-node {
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 8px 12px;
  font-size: 11px;
  font-weight: 500;
  color: var(--text2);
  display: flex;
  align-items: center;
  gap: 7px;
  transition: border-color .2s, color .2s;
  white-space: nowrap;
  width: 130px;
}

.cp-d-node:hover { border-color: var(--blue2); color: var(--text); }

.cp-d-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }

.cp-d-center {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 12px;
}

.cp-d-ring {
  width: 72px; height: 72px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cp-d-ring::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1px solid rgba(61,142,245,.35);
  background: conic-gradient(from 0deg, transparent 60%, rgba(61,142,245,.5) 100%);
  animation: cpSpin 10s linear infinite;
}

.cp-d-core {
  width: 50px; height: 50px;
  border-radius: 50%;
  background: linear-gradient(135deg, #091526, #0e2040);
  border: 2px solid var(--blue);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 20px rgba(61,142,245,.3);
  position: relative;
  z-index: 1;
  gap: 1px;
}

.cp-d-core span:first-child {
  font-family: "Syne", sans-serif;
  font-size: 7px; font-weight: 800;
  letter-spacing: .1em; color: var(--blue2);
}

.cp-d-core span:last-child {
  font-family: "Syne", sans-serif;
  font-size: 10px; font-weight: 700; color: var(--text);
}

.cp-d-caption {
  font-family: "Syne", sans-serif;
  font-size: 8px; color: var(--text3);
  letter-spacing: .14em; text-transform: uppercase; font-weight: 700;
}

/* ── PILARES ACORDEÓN — DESKTOP Y MÓVIL ── */
.cp-pillars {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
}

.cp-pillar {
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px 20px;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: border-color .3s;
}

.cp-pillar:hover { border-color: var(--border2); }

.cp-pillar::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
}

.cp-pillar.p1::before { background: linear-gradient(90deg, var(--blue), var(--cyan)); }
.cp-pillar.p2::before { background: linear-gradient(90deg, var(--gold), var(--green)); }
.cp-pillar.p3::before { background: linear-gradient(90deg, var(--green), var(--blue2)); }

.cp-pillar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.cp-pillar-header-left {
  display: flex;
  align-items: center;
  gap: 10px;
}

.cp-pillar-ico { font-size: 18px; margin-bottom: 0; }

.cp-pillar-title {
  font-family: "Syne", sans-serif;
  font-size: 13px; font-weight: 700;
  color: var(--text);
}

.cp-pillar-chevron {
  width: 16px; height: 16px;
  color: var(--text3);
  flex-shrink: 0;
  transition: transform .3s ease;
}

.cp-pillar.open .cp-pillar-chevron {
  transform: rotate(180deg);
}

.cp-pillar-desc {
  font-size: 12px;
  color: var(--text2);
  line-height: 1.6;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height .35s ease, opacity .3s ease, margin .3s ease;
  margin-top: 0;
}

.cp-pillar.open .cp-pillar-desc {
  max-height: 120px;
  opacity: 1;
  margin-top: 12px;
}

/* ── MODELO DE INVERSIÓN ── */
.cp-model {
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 24px 28px;
  margin-top: 14px;
  margin-bottom: 40px;
}

.cp-model-tag {
  font-family: "Syne", sans-serif;
  font-size: 9px; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 8px;
}

.cp-model-title {
  font-family: "Syne", sans-serif;
  font-size: 15px; font-weight: 700;
  color: var(--text); margin-bottom: 6px;
}

.cp-model-desc { font-size: 13px; color: var(--text2); line-height: 1.65; }

/* ── CTA FINAL ── */
.cp-cta-block {
  text-align: center;
  padding: 48px 24px;
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: 16px;
  position: relative;
  overflow: hidden;
}

.cp-cta-block::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--blue), var(--cyan), var(--blue));
}

.cp-cta-block p {
  font-size: 15px;
  color: var(--text2);
  line-height: 1.75;
  max-width: 480px;
  margin: 0 auto 28px;
}

.cp-cta-block p strong { color: var(--text); font-weight: 500; }

.cp-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(135deg, var(--blue), #1a6fd4);
  border: none;
  border-radius: 50px;
  padding: 14px 32px;
  font-family: "Syne", sans-serif;
  font-size: 12px; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  color: #fff; cursor: pointer; text-decoration: none;
  transition: opacity .2s, transform .2s, box-shadow .2s;
  box-shadow: 0 4px 20px rgba(61,142,245,.3);
}

.cp-btn:hover {
  opacity: .9;
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(61,142,245,.4);
}

.cp-btn svg { width: 13px; height: 13px; transition: transform .2s; }
.cp-btn:hover svg { transform: translateX(3px); }

/* ── MODAL ── */
.cp-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 900;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}

.cp-modal-overlay.open {
  opacity: 1;
  pointer-events: all;
}

.cp-modal {
  background: var(--s1);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 40px 36px;
  width: 100%;
  max-width: 520px;
  position: relative;
  overflow: hidden;
  transform: translateY(20px) scale(.97);
  transition: transform .35s cubic-bezier(.22,1,.36,1);
}

@media (max-width: 540px) { .cp-modal { padding: 28px 20px; } }

.cp-modal-overlay.open .cp-modal {
  transform: translateY(0) scale(1);
}

.cp-modal::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--blue), var(--cyan), var(--blue));
}

.cp-modal-close {
  position: absolute;
  top: 16px; right: 16px;
  width: 32px; height: 32px;
  border-radius: 8px;
  background: var(--s2);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--text2);
  transition: background .2s, color .2s;
}

.cp-modal-close:hover { background: var(--s3); color: var(--text); }
.cp-modal-close svg { width: 14px; height: 14px; }

.cp-modal-eyebrow {
  font-family: "Syne", sans-serif;
  font-size: 9px; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--text3); margin-bottom: 10px;
}

.cp-modal h3 {
  font-family: "Syne", sans-serif;
  font-size: clamp(20px, 3vw, 26px);
  font-weight: 700;
  line-height: 1.15;
  color: var(--text);
  margin-bottom: 8px;
}

.cp-modal h3 em {
  font-style: normal;
  background: linear-gradient(135deg, var(--blue2), var(--green2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cp-modal-sub {
  font-size: 13px;
  color: var(--text2);
  line-height: 1.65;
  margin-bottom: 28px;
}

.cp-modal-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

@media (max-width: 480px) { .cp-modal-row { grid-template-columns: 1fr; } }

.cp-field { display: flex; flex-direction: column; gap: 6px; }

.cp-field label {
  font-family: "Syne", sans-serif;
  font-size: 9px; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--text3);
}

.cp-field input,
.cp-field textarea {
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 11px 14px;
  font-size: 13px;
  color: var(--text);
  font-family: "DM Sans", sans-serif;
  outline: none;
  width: 100%;
  transition: border-color .2s, box-shadow .2s;
  -webkit-appearance: none;
}

.cp-field input::placeholder,
.cp-field textarea::placeholder { color: var(--text3); }

.cp-field input:focus,
.cp-field textarea:focus {
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(61,142,245,.12);
}

.cp-field textarea {
  resize: vertical;
  min-height: 90px;
  line-height: 1.6;
  margin-bottom: 12px;
}

.cp-modal-note {
  font-size: 11px;
  color: var(--text3);
  margin-bottom: 20px;
  line-height: 1.5;
}

.cp-modal-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 14px 28px;
  background: linear-gradient(135deg, var(--blue), #1a6fd4);
  border: none;
  border-radius: 50px;
  font-family: "Syne", sans-serif;
  font-size: 12px; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  color: #fff; cursor: pointer;
  transition: opacity .2s, transform .2s, box-shadow .2s;
  box-shadow: 0 4px 20px rgba(61,142,245,.3);
}

.cp-modal-submit:hover {
  opacity: .9;
  transform: translateY(-1px);
  box-shadow: 0 8px 32px rgba(61,142,245,.4);
}

.cp-modal-submit svg { width: 14px; height: 14px; transition: transform .2s; }
.cp-modal-submit:hover svg { transform: translateX(3px); }

.cp-modal-success { display: none; text-align: center; padding: 16px 0 8px; }
.cp-modal-success-ico { font-size: 40px; margin-bottom: 12px; }

.cp-modal-success h4 {
  font-family: "Syne", sans-serif;
  font-size: 18px; font-weight: 700;
  color: var(--green); margin-bottom: 8px;
}

.cp-modal-success p { font-size: 13px; color: var(--text2); line-height: 1.65; }

/* ── PADDING BOTTOM SECCIÓN ── */
#corporativo-preview { padding-bottom: 96px; }

/* ── DROPDOWN NAV ── */
.nav-dropdown { position: relative; }

.nav-dropdown-toggle {
  font-size: 11px; color: var(--text2); text-decoration: none; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
  padding: 6px 10px; border-radius: 8px;
  border: 1px solid transparent;
  display: flex; align-items: center; gap: 5px;
  cursor: pointer; background: none;
  transition: all .2s ease;
  font-family: "DM Sans", sans-serif;
}

.nav-dropdown-toggle:hover {
  color: var(--text);
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.07);
}

.nav-dropdown-toggle svg {
  width: 10px; height: 10px;
  transition: transform .2s;
  flex-shrink: 0;
}

.nav-dropdown.open .nav-dropdown-toggle svg { transform: rotate(180deg); }

.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  background: rgba(4,7,15,.98);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 8px;
  min-width: 220px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity .2s ease, transform .2s ease;
  z-index: 600;
  backdrop-filter: blur(12px);
}

.nav-dropdown.open .nav-dropdown-menu {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0);
}

.nav-dropdown-menu a {
  display: block;
  font-size: 11px; font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
  color: var(--text2); text-decoration: none;
  padding: 8px 12px; border-radius: 8px;
  transition: all .2s ease;
  border: 1px solid transparent;
}

.nav-dropdown-menu a:hover {
  color: var(--text);
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.07);
}

.nav-dropdown-menu .nav-dropdown-divider {
  height: 1px;
  background: var(--border);
  margin: 6px 4px;
}

.nav-dropdown-menu .nav-dropdown-highlight { color: var(--cyan); }

.nav-dropdown-menu .nav-dropdown-highlight:hover {
  background: rgba(0,200,255,.07);
  border-color: rgba(0,200,255,.18);
}

/* ── ANIMACIÓN DIAGRAMA ── */
@keyframes cpSpin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* ── NAV DROPDOWNS DOS CATEGORÍAS ── */
.nav-dropdown-group-label {
  font-size: 9px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: var(--text3); padding: 4px 12px 8px;
}
.nav-dropdown-menu a { display: flex; align-items: center; gap: 9px; }

.nav-dd-dot {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
}
.nav-dd-dot--blue  { background: var(--blue);  box-shadow: 0 0 6px rgba(61,142,245,.5); }
.nav-dd-dot--green { background: var(--green); box-shadow: 0 0 6px rgba(34,201,138,.4); }

.nav-dd--empresas { color: var(--blue2) !important; }
.nav-dd--negocios { color: var(--green2) !important; }

.nav-dropdown-menu--empresas { border-top: 2px solid rgba(61,142,245,.25); }
.nav-dropdown-menu--negocios { border-top: 2px solid rgba(34,201,138,.25); }

.nav-dd-item--empresas { color: var(--cyan) !important; }
.nav-dd-item--empresas:hover { background: rgba(0,200,255,.07) !important; border-color: rgba(0,200,255,.18) !important; }

.nav-dd-item--negocios { color: var(--text2); }
.nav-dd-item--negocios:hover { color: var(--green2) !important; background: rgba(34,201,138,.07) !important; border-color: rgba(34,201,138,.18) !important; }

/* ── MOBILE MENU ACORDEÓN ── */

/* Contenedor de items */
.nm-menu-list {
  display: flex; flex-direction: column; gap: 6px;
  width: 100%; max-width: 420px; margin-bottom: 16px;
}

/* Base de cada item (link directo o acordeón) */
.nm-item {
  width: 100%; border-radius: 14px; overflow: hidden;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(10,22,40,.55);
  backdrop-filter: blur(8px);
  position: relative; z-index: 1;
}

/* Item link directo (¿Quiénes somos?, Blog) */
a.nm-item.nm-item--link {
  display: flex !important; align-items: center !important; justify-content: space-between !important;
  padding: 15px 18px !important;
  font-family: "Syne", sans-serif !important; font-size: 13px !important;
  font-weight: 700 !important; letter-spacing: .06em !important; text-transform: uppercase !important;
  color: rgba(221,232,248,.6) !important; text-decoration: none !important;
  transition: all .2s ease !important;
}
a.nm-item.nm-item--link svg { opacity: .4; transition: opacity .2s, transform .2s; flex-shrink: 0; }
a.nm-item.nm-item--link:hover {
  color: var(--text) !important; background: rgba(255,255,255,.05) !important;
  border-color: rgba(255,255,255,.12) !important; letter-spacing: .06em !important;
}
a.nm-item.nm-item--link:hover svg { opacity: .9; transform: translateX(3px); }

/* Item acordeón — borde de color */
.nm-item--empresas { border-color: rgba(61,142,245,.2); }
.nm-item--negocios { border-color: rgba(34,201,138,.2); }
.nm-item--empresas.open { border-color: rgba(61,142,245,.35); box-shadow: 0 0 20px rgba(61,142,245,.06); }
.nm-item--negocios.open { border-color: rgba(34,201,138,.35); box-shadow: 0 0 20px rgba(34,201,138,.06); }

/* Header clickeable del acordeón */
.nm-item-header {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 15px 18px; cursor: pointer;
  font-family: "Syne", sans-serif; font-size: 13px; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  color: rgba(221,232,248,.6);
  transition: color .2s, background .2s;
  user-select: none;
}
.nm-item-header:hover { color: var(--text); background: rgba(255,255,255,.04); }
.nm-item--empresas .nm-item-header:hover { color: var(--blue2); }
.nm-item--negocios .nm-item-header:hover { color: var(--green2); }
.nm-item--empresas.open .nm-item-header { color: var(--blue2); border-bottom: 1px solid rgba(61,142,245,.15); }
.nm-item--negocios.open .nm-item-header { color: var(--green2); border-bottom: 1px solid rgba(34,201,138,.15); }

.nm-item-label { flex: 1; text-align: center; }

/* Dot de color en acordeón */
.nm-item-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.nm-item-dot--blue  { background: var(--blue);  box-shadow: 0 0 6px rgba(61,142,245,.6); }
.nm-item-dot--green { background: var(--green); box-shadow: 0 0 6px rgba(34,201,138,.5); }
.nm-item-dot--gold  { background: var(--gold);  box-shadow: 0 0 6px rgba(232,184,75,.5); }
.nm-item-dot--red { background: var(--red); box-shadow: 0 0 6px rgba(255,94,122,.5); }

/* Chevron rotación */
.nm-chevron { flex-shrink: 0; opacity: .5; transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .2s; }
.nm-item.open .nm-chevron { transform: rotate(180deg); opacity: 1; }

/* Cuerpo colapsable */
.nm-item-body {
  max-height: 0; overflow: hidden;
  transition: max-height .12s cubic-bezier(0.2,0,0,1);
}
.nm-item.open .nm-item-body { max-height: 260px; }

/* Links dentro del acordeón */
.nm-item-body { padding: 0 8px; }
.nm-item.open .nm-item-body { padding: 8px; }
.nm-item-body a {
  animation: none !important;
  display: flex !important; align-items: center !important; gap: 10px !important;
  font-family: "DM Sans", sans-serif !important; font-size: 14px !important;
  font-weight: 500 !important; letter-spacing: 0 !important;
  color: var(--text2) !important; padding: 10px 12px !important;
  border-radius: 10px !important; border: 1px solid transparent !important;
  text-align: left !important; width: 100% !important; max-width: 100% !important;
  transition: all .15s ease !important;
}
.nm-item-body a:hover {
  color: var(--text) !important; background: rgba(255,255,255,.05) !important;
  border-color: rgba(255,255,255,.07) !important; letter-spacing: 0 !important;
}

/* Dots en links internos */
.nm-link-dot { display: inline-block; width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; }
.nm-link-dot--blue  { background: var(--blue);  box-shadow: 0 0 5px rgba(61,142,245,.5); }
.nm-link-dot--green { background: var(--green); box-shadow: 0 0 5px rgba(34,201,138,.4); }

/* ── SECTION ENTRY MARKER ── */
.section-entry {
  display: flex; align-items: center; gap: 18px;
  margin-bottom: 48px;
}
.section-entry-rule { flex: 1; height: 1.5px; background-size: 200% 100%; animation: rgbRuleShift 4s ease infinite; }
.section-entry--blue .section-entry-rule {
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(236,72,153,.5)  8%,
    rgba(167,139,250,.8) 22%,
    rgba(61,142,245,1)   40%,
    rgba(0,200,255,.9)   58%,
    rgba(34,201,138,.6)  76%,
    rgba(0,200,255,.3)   90%,
    transparent 100%
  );
}
.section-entry--green .section-entry-rule {
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(61,142,245,.4)  8%,
    rgba(0,200,255,.8)   24%,
    rgba(34,201,138,1)   42%,
    rgba(0,200,255,.9)   60%,
    rgba(167,139,250,.7) 78%,
    rgba(236,72,153,.3)  92%,
    transparent 100%
  );
}

@keyframes rgbRuleShift {
  0%,100% { opacity: .7; filter: brightness(1); }
  50%     { opacity: 1;  filter: brightness(1.4); }
}

.section-entry-label {
  font-family: "Syne", sans-serif; font-size: 10px; font-weight: 700;
  letter-spacing: .26em; text-transform: uppercase; white-space: nowrap;
  padding: 6px 18px; border-radius: 100px;
  position: relative; isolation: isolate; border: none;
}
/* Borde RGB */
.section-entry-label::before {
  content: '';
  position: absolute; inset: -1.5px; border-radius: 100px; z-index: -1;
  background: linear-gradient(90deg, #ec4899, #a78bfa, #3d8ef5, #00c8ff, #22c98a, #a78bfa, #ec4899);
  background-size: 200% 100%;
  animation: rgbBorderFlow 4s linear infinite;
}
/* Máscara interior oscura */
.section-entry-label::after {
  content: '';
  position: absolute; inset: 1.5px; border-radius: 100px; z-index: -1;
  background: rgba(4,7,15,.92);
}
@keyframes rgbBorderFlow {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

.section-entry-label--blue  { color: var(--blue2);  background: transparent; }
.section-entry-label--green { color: var(--green2); background: transparent; }

/* ── PERSONAS Y NEGOCIOS ENTRY ── */
.pyn-entry-wrap {
  padding: 70px 0 30px;
  position: relative; z-index: 1;
}
.pyn-intro {
  text-align: center; margin-bottom: 0;
}
.pyn-intro .sec-title { margin-bottom: 14px; }
.pyn-entry-wrap + #workers { padding-top: 40px; }

/* ── DIVISION BAND ── */
#differentiator {
  position: relative; padding: 90px 0; overflow: hidden; z-index: 1;
}

/* ── AURORA LAYERS ── */
#differentiator::before {
  content: '';
  position: absolute; inset: -30%;
  pointer-events: none; z-index: 0;
  background:
    radial-gradient(ellipse 85% 55% at 12% 55%, rgba(167,139,250,.32) 0%, transparent 58%),
    radial-gradient(ellipse 70% 65% at 85% 35%, rgba(0,200,255,.28) 0%, transparent 55%),
    radial-gradient(ellipse 75% 50% at 50% 82%, rgba(34,201,138,.25) 0%, transparent 52%),
    radial-gradient(ellipse 60% 58% at 65% 12%, rgba(236,72,153,.22) 0%, transparent 48%);
  filter: blur(28px);
  animation: auroraDrift 11s ease-in-out infinite alternate;
}
#differentiator::after {
  content: '';
  position: absolute; inset: -30%;
  pointer-events: none; z-index: 0;
  background:
    radial-gradient(ellipse 78% 45% at 38% 22%, rgba(61,142,245,.26) 0%, transparent 55%),
    radial-gradient(ellipse 65% 58% at 75% 72%, rgba(167,139,250,.24) 0%, transparent 52%),
    radial-gradient(ellipse 85% 40% at 18% 78%, rgba(0,200,255,.22) 0%, transparent 50%);
  filter: blur(35px);
  animation: auroraDrift2 15s ease-in-out infinite alternate;
}

@keyframes auroraDrift {
  0%   { transform: translate(0,   0)   scale(1);    }
  30%  { transform: translate(4%,  -6%) scale(1.06); }
  65%  { transform: translate(-5%, 4%)  scale(.97);  }
  100% { transform: translate(6%,  -3%) scale(1.04); }
}
@keyframes auroraDrift2 {
  0%   { transform: translate(0,   0)   scale(1);    }
  40%  { transform: translate(-6%, 5%)  scale(1.07); }
  100% { transform: translate(5%,  -7%) scale(.96);  }
}

.divband-top-rule {
  position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg,
    transparent 0%, rgba(236,72,153,.5) 15%,
    rgba(167,139,250,.7) 30%, rgba(61,142,245,.9) 50%,
    rgba(0,200,255,.7) 70%, rgba(34,201,138,.4) 88%, transparent 100%);
  opacity: .6;
}
.divband-bottom-rule {
  position: absolute; bottom: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg,
    transparent 0%, rgba(34,201,138,.4) 12%,
    rgba(0,200,255,.7) 30%, rgba(167,139,250,.7) 50%,
    rgba(61,142,245,.8) 70%, rgba(236,72,153,.4) 88%, transparent 100%);
  opacity: .6;
}
.divband-glow { display: none; }

/* Asegurar que el contenido quede sobre la aurora */
.divband-content { position: relative; z-index: 1; }

.divband-content {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 0;
}
.divband-from-row {
  display: flex; align-items: center; gap: 16px;
  width: 100%; max-width: 600px; margin-bottom: 36px;
}
.divband-to-row {
  display: flex; align-items: center; justify-content: flex-end; gap: 16px;
  width: 100%; max-width: 600px; margin-top: 36px;
}
.divband-from-line { flex: 1; height: 1px; background: linear-gradient(90deg, transparent, rgba(61,142,245,.3)); }
.divband-to-line   { flex: 1; height: 1px; background: linear-gradient(90deg, rgba(34,201,138,.3), transparent); }

.divband-segment-tag {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: "Syne", sans-serif; font-size: 10px; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  padding: 6px 14px; border-radius: 100px; white-space: nowrap;
}
.divband-segment-tag--blue  { color: var(--blue2);  background: rgba(61,142,245,.08);  border: 1px solid rgba(61,142,245,.2); }
.divband-segment-tag--green { color: var(--green2); background: rgba(34,201,138,.08); border: 1px solid rgba(34,201,138,.2); }

.divband-center { display: flex; flex-direction: column; align-items: center; gap: 18px; }

.divband-arrow-wrap { display: flex; justify-content: center; }
.divband-arrow { width: 18px; height: 30px; opacity: .65; }

.divband-question {
  font-family: "Syne", sans-serif; font-size: 11px; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase; color: var(--text3); margin: 0;
}
.divband-title {
  font-family: "Syne", sans-serif; font-size: clamp(30px, 4.2vw, 48px); font-weight: 700;
  line-height: 1.1; letter-spacing: -.025em; color: var(--text); margin: 0;
}
.divband-title em {
  font-style: normal;
  background: linear-gradient(135deg, var(--blue2), var(--green2));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.divband-sub {
  font-size: 15px; color: var(--text2); line-height: 1.8; max-width: 480px; margin: 0;
}
.divband-cta { margin-top: 6px; }

@media(max-width: 600px) {
  .divband-from-row, .divband-to-row { max-width: 100%; }
  .divband-title { font-size: 28px; }
  .divband-sub br { display: none; }
}
