
*{margin:0;padding:0;box-sizing:border-box}

[data-theme="dark"]{
  --bg:#07100e;--bg2:#0c1a16;--card:rgba(41,219,186,0.04);
  --border:rgba(41,219,186,0.18);--border-h:rgba(41,219,186,0.45);
  --text:#e8faf7;--muted:#7aada0;--accent:#29DBBA;
  --accent-dim:rgba(41,219,186,0.1);--accent-glow:rgba(41,219,186,0.28);
  --heading:#ffffff;--input-bg:rgba(255,255,255,0.05);--shadow:rgba(41,219,186,0.12);
  --nav-bg:rgba(7,16,14,0.78);
}
[data-theme="light"]{
  --bg:#f0faf8;--bg2:#ffffff;--card:rgba(255,255,255,0.92);
  --border:rgba(41,219,186,0.22);--border-h:rgba(41,219,186,0.55);
  --text:#1a3330;--muted:#5a8a80;--accent:#1ab89b;
  --accent-dim:rgba(26,184,155,0.1);--accent-glow:rgba(26,184,155,0.22);
  --heading:#0a1f1c;--input-bg:rgba(255,255,255,0.85);--shadow:rgba(41,219,186,0.1);
  --nav-bg:rgba(240,250,248,0.84);
}

html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;transition:background .5s,color .5s}

/* ─── THEME TOGGLE (bottom-right FAB) ─── */
#theme-toggle{
  position:fixed;bottom:1.8rem;right:1.8rem;z-index:200;
  width:50px;height:50px;border-radius:50%;
  background:var(--bg2);border:1.5px solid var(--border-h);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px var(--shadow);
  transition:background .4s,border-color .4s,box-shadow .3s,transform .2s;
  overflow:hidden;
}
#theme-toggle:hover{box-shadow:0 6px 28px var(--accent-glow);transform:scale(1.08)}
.icon-sun,.icon-moon{
  position:absolute;font-size:1.3rem;
  transition:transform .5s cubic-bezier(.34,1.56,.64,1),opacity .38s ease;
  line-height:1;
}
[data-theme="dark"] .icon-sun{transform:translateY(0) scale(1);opacity:1}
[data-theme="dark"] .icon-moon{transform:translateY(55px) scale(.6);opacity:0}
[data-theme="light"] .icon-sun{transform:translateY(-55px) scale(.6);opacity:0}
[data-theme="light"] .icon-moon{transform:translateY(0) scale(1);opacity:1}
.toggle-spin{animation:fabSpin .5s cubic-bezier(.34,1.56,.64,1)}
@keyframes fabSpin{from{transform:rotate(-200deg) scale(.4)}to{transform:rotate(0deg) scale(1)}}

/* ─── NAV ─── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1.1rem 2.5rem;background:var(--nav-bg);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:background .5s,border-color .5s,padding .3s}
nav.scrolled{padding:.75rem 2.5rem}
.logo{font-size:1.25rem;font-weight:700;letter-spacing:-0.02em;color:var(--heading)}
.logo span{color:var(--accent)}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{text-decoration:none;color:var(--muted);font-size:.9rem;font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--accent)}
.nav-cta{background:var(--accent);color:#07100e;padding:.5rem 1.2rem;border-radius:8px;text-decoration:none;font-size:.875rem;font-weight:700;transition:opacity .2s,box-shadow .2s}
.nav-cta:hover{opacity:.88;box-shadow:0 0 18px var(--accent-glow)}

/* ─── HERO ─── */
#hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:6rem 2rem 4rem;position:relative;overflow:hidden}
.hero-glow{position:absolute;top:28%;left:50%;transform:translateX(-50%);width:700px;height:360px;background:radial-gradient(ellipse,var(--accent-glow) 0%,transparent 68%);pointer-events:none}
.badge{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent-dim);border:1px solid var(--border-h);border-radius:100px;padding:.35rem .9rem;font-size:.78rem;font-weight:600;color:var(--accent);letter-spacing:.06em;margin-bottom:1.8rem;text-transform:uppercase}
.badge::before{content:'';width:6px;height:6px;background:var(--accent);border-radius:50%;box-shadow:0 0 8px var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
h1{font-size:clamp(2.8rem,7vw,5.5rem);font-weight:900;line-height:1.05;letter-spacing:-0.04em;max-width:800px;margin:0 auto 1.5rem;color:var(--heading)}
h1 em{font-style:normal;color:var(--accent)}
.hero-sub{font-size:1.15rem;color:var(--muted);max-width:540px;margin:0 auto 2.8rem}
.hero-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-primary{background:var(--accent);color:#07100e;padding:.8rem 1.8rem;border-radius:10px;text-decoration:none;font-weight:700;font-size:.95rem;transition:box-shadow .25s,transform .2s}
.btn-primary:hover{box-shadow:0 0 28px var(--accent-glow);transform:translateY(-2px)}
.btn-outline{border:1px solid var(--border-h);color:var(--text);padding:.8rem 1.8rem;border-radius:10px;text-decoration:none;font-weight:500;font-size:.95rem;transition:border-color .2s,color .2s}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.hero-stats{display:flex;gap:3.5rem;justify-content:center;margin-top:4.5rem;flex-wrap:wrap}
.stat-num{font-size:2rem;font-weight:800;color:var(--accent)}
.stat-label{font-size:.78rem;color:var(--muted);font-weight:500;margin-top:.15rem}

/* ─── PARALLAX DIVIDER ─── */
.parallax-strip{height:120px;overflow:hidden;position:relative}
.parallax-strip svg{position:absolute;bottom:0;width:100%;will-change:transform}

/* ─── SECTIONS ─── */
section{padding:6rem 2rem}
.container{max-width:1100px;margin:0 auto}
.section-label{text-transform:uppercase;font-size:.72rem;font-weight:700;letter-spacing:.12em;color:var(--accent);margin-bottom:.8rem}
.section-title{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;letter-spacing:-0.03em;line-height:1.1;margin-bottom:1rem;color:var(--heading)}
.section-sub{color:var(--muted);max-width:520px;font-size:1rem}

/* ─── FEATURES ─── */
#features{background:var(--bg2)}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem;margin-top:3.5rem}
.feat-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:1.8rem;transition:border-color .25s,transform .3s,box-shadow .3s;will-change:transform}
.feat-card:hover{border-color:var(--border-h);transform:translateY(-4px);box-shadow:0 10px 36px var(--shadow)}
.feat-icon{width:44px;height:44px;background:var(--accent-dim);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;font-size:1.3rem;border:1px solid var(--border)}
.feat-card h3{font-size:1rem;font-weight:600;margin-bottom:.5rem;color:var(--heading)}
.feat-card p{font-size:.875rem;color:var(--muted);line-height:1.65}

/* ─── STEPS ─── */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:3.5rem;counter-reset:step}
.step{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:1.8rem;position:relative;counter-increment:step;transition:border-color .25s}
.step::before{content:counter(step,"0"counter(step));position:absolute;top:1.4rem;right:1.4rem;font-size:2.2rem;font-weight:900;color:var(--accent-dim);letter-spacing:-0.05em;line-height:1}
.step-num{font-size:.8rem;font-weight:700;color:var(--accent);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.08em}
.step h3{font-size:.95rem;font-weight:600;margin-bottom:.4rem;color:var(--heading)}
.step p{font-size:.85rem;color:var(--muted)}

/* ─── PRICING ─── */
#precios{background:var(--bg2)}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:1.5rem;margin-top:3.5rem}
.price-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:2rem;display:flex;flex-direction:column;transition:border-color .25s,box-shadow .25s}
.price-card.featured{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 12px 40px var(--shadow)}
.popular{display:none}
.price-card.featured .popular{display:inline-block;background:var(--accent);color:#07100e;font-size:.72rem;font-weight:700;padding:.25rem .75rem;border-radius:100px;margin-bottom:1rem;letter-spacing:.05em;text-transform:uppercase}
.price-name{font-size:.85rem;font-weight:700;color:var(--muted);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.06em}
.price-amount{font-size:3rem;font-weight:900;letter-spacing:-0.05em;line-height:1;margin-bottom:.3rem;color:var(--heading)}
.price-amount span{font-size:1rem;font-weight:500;color:var(--muted)}
.price-desc{font-size:.8rem;color:var(--muted);margin-bottom:1.8rem}
.price-features{list-style:none;margin-bottom:2rem;flex:1}
.price-features li{font-size:.875rem;padding:.5rem 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.7rem;color:var(--muted)}
.price-features li::before{content:'✓';color:var(--accent);font-weight:700;flex-shrink:0}
.price-btn{display:block;text-align:center;background:var(--accent);color:#07100e;padding:.85rem;border-radius:10px;text-decoration:none;font-weight:700;font-size:.9rem;transition:opacity .2s,box-shadow .2s}
.price-card:not(.featured) .price-btn{background:transparent;border:1px solid var(--border-h);color:var(--text)}
.price-card:not(.featured) .price-btn:hover{border-color:var(--accent);color:var(--accent)}
.price-btn:hover{opacity:.88;box-shadow:0 0 20px var(--accent-glow)}

/* ─── HOSTING ─── */
.hosting-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:3rem}
.hosting-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:1.5rem;text-align:center;transition:border-color .25s,box-shadow .25s}
.hosting-card:hover{border-color:var(--border-h);box-shadow:0 4px 24px var(--shadow)}
.hosting-card h3{font-size:.9rem;font-weight:600;margin-bottom:.4rem;color:var(--heading)}
.h-price{font-size:2rem;font-weight:800;color:var(--accent);margin-bottom:.1rem}
.h-sub{font-size:.75rem;color:var(--muted)}
.hosting-perks{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1.8rem}
.perk{display:flex;align-items:flex-start;gap:.8rem;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1rem 1.2rem;transition:border-color .2s}
.perk:hover{border-color:var(--border-h)}
.perk-icon{font-size:1.2rem;flex-shrink:0;margin-top:.1rem}
.perk h4{font-size:.85rem;font-weight:600;margin-bottom:.2rem;color:var(--heading)}
.perk p{font-size:.78rem;color:var(--muted)}

/* ─── MANT ─── */
.mant-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3rem}
.mant-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:2rem;transition:border-color .25s}
.mant-card:hover{border-color:var(--border-h)}
.mant-card h3{font-size:1rem;font-weight:700;margin-bottom:.6rem;color:var(--heading)}
.mant-card p{font-size:.875rem;color:var(--muted)}

/* ─── CONTACT ─── */
#contacto{background:var(--bg2)}
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-info h2{font-size:2rem;font-weight:800;line-height:1.15;margin-bottom:1rem;color:var(--heading)}
.contact-info p{color:var(--muted);font-size:.95rem;margin-bottom:2rem}
.contact-detail{display:flex;align-items:center;gap:.75rem;margin-bottom:.8rem;color:var(--muted);font-size:.9rem}
.contact-form{display:flex;flex-direction:column;gap:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.contact-form input,.contact-form textarea{background:var(--input-bg);border:1px solid var(--border);border-radius:10px;padding:.85rem 1rem;color:var(--text);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:.9rem;outline:none;width:100%;transition:border-color .2s}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent)}
.contact-form textarea{resize:vertical;min-height:130px}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--muted)}
.send-btn{background:var(--accent);color:#07100e;border:none;padding:.9rem 1.8rem;border-radius:10px;font-weight:700;font-size:.95rem;cursor:pointer;transition:box-shadow .25s,transform .2s;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif}
.send-btn:hover{box-shadow:0 0 28px var(--accent-glow);transform:translateY(-1px)}
.form-safe-note{color:var(--muted);font-size:.72rem;line-height:1.4}

/* ─── FOOTER ─── */
footer{background:var(--bg);border-top:1px solid var(--border);padding:2.5rem 2rem;text-align:center;transition:background .5s,border-color .5s}
footer p{color:var(--muted);font-size:.82rem}
footer a{color:var(--accent);text-decoration:none}

/* ─── SCROLL ANIMATIONS ─── */
/* fade up (default) */
.sa{opacity:0;transform:translateY(36px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.sa.visible{opacity:1;transform:none}

/* fade in left */
.sa-left{opacity:0;transform:translateX(-40px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.sa-left.visible{opacity:1;transform:none}

/* fade in right */
.sa-right{opacity:0;transform:translateX(40px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.sa-right.visible{opacity:1;transform:none}

/* scale in */
.sa-scale{opacity:0;transform:scale(.88);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1)}
.sa-scale.visible{opacity:1;transform:scale(1)}

/* stagger delay classes */
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.40s}.d6{transition-delay:.48s}


.brand-wordmark{height:42px;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.15rem;font-weight:900;letter-spacing:-.03em;filter:drop-shadow(0 0 12px var(--accent-glow))}
.imunify-mark{color:#58e070}.litespeed-mark{color:#e8faf7}.cpanel-mark{color:#ff7a2f;font-size:1.45rem}.jetbackup-mark{color:#e8faf7;font-style:italic}

@media(max-width:768px){
  nav{padding:.9rem 1.2rem}
  .nav-links{display:none}
  .contact-wrap,.mant-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}


/* ─── ICONOS ANIMADOS / BRAND ─── */
.feat-icon{position:relative;width:76px;height:76px;background:linear-gradient(145deg,rgba(41,219,186,.12),rgba(41,219,186,.02));border-radius:18px;box-shadow:inset 0 0 18px rgba(41,219,186,.08),0 0 24px rgba(41,219,186,.08);overflow:hidden}
.feat-icon svg,.mant-icon svg{width:46px;height:46px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 8px var(--accent-glow));animation:iconFloat 3.8s ease-in-out infinite}
.feat-icon::after{content:'';position:absolute;inset:-45%;background:conic-gradient(from 0deg,transparent,rgba(41,219,186,.22),transparent 38%);animation:iconOrbit 5s linear infinite}
.feat-icon svg{position:relative;z-index:1}
@keyframes iconFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-5px) scale(1.04)}}
@keyframes iconOrbit{to{transform:rotate(360deg)}}
.feat-card:nth-child(2) .feat-icon svg{animation:iconDash 2.8s ease-in-out infinite}
@keyframes iconDash{0%,100%{transform:translateX(0)}50%{transform:translateX(5px)}}
.feat-card:nth-child(4) .feat-icon svg{animation:iconPulse 2.2s ease-in-out infinite}
@keyframes iconPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.82}}

/* ─── CAMINO / PROCESO: ROAD JOURNEY RESPONSIVE ─── */
#proceso{
  position:relative;
  background:
    radial-gradient(circle at 22% 24%,rgba(41,219,186,.16),transparent 28%),
    radial-gradient(circle at 78% 68%,rgba(41,219,186,.12),transparent 30%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  overflow:hidden;
  padding-bottom:7rem;
}
#proceso::before{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:.34;
  background-image:linear-gradient(rgba(41,219,186,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(41,219,186,.05) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:linear-gradient(180deg,transparent,#000 12%,#000 86%,transparent);
}
.process-intro{
  position:relative;
  display:grid;
  grid-template-columns:250px minmax(0,1fr);
  gap:2.4rem;
  align-items:start;
  margin-top:3.6rem;
}
.process-intro>div:first-child{
  position:sticky;
  top:105px;
  z-index:5;
}
.process-intro>div:first-child::after{
  content:'';display:block;width:86px;height:86px;margin-top:1.8rem;border-radius:50%;
  background:radial-gradient(circle,var(--accent) 0 8%,transparent 9% 32%,rgba(41,219,186,.16) 33% 52%,transparent 53%),conic-gradient(from 180deg,var(--accent),transparent 32%,transparent 68%,var(--accent));
  filter:drop-shadow(0 0 24px var(--accent-glow));
  animation:compassSpin 6s linear infinite;
}
@keyframes compassSpin{to{transform:rotate(360deg)}}
.road-steps{
  --line-x:84px;
  position:relative;
  display:grid;
  gap:1.25rem;
  padding-left:34px;
}
.road-steps::before{
  content:'';position:absolute;left:var(--line-x);top:40px;bottom:46px;width:3px;border-radius:999px;
  background:linear-gradient(180deg,rgba(41,219,186,.95),rgba(41,219,186,.25),rgba(41,219,186,.95));
  box-shadow:0 0 28px var(--accent-glow);
  opacity:.8;
}
.road-step{
  position:relative;
  min-height:260px;
  display:grid;
  grid-template-columns:minmax(230px,.9fr) minmax(0,1.1fr);
  align-items:stretch;
  gap:0;
  margin:0 0 1.15rem;
  border:1px solid rgba(41,219,186,.24);
  border-radius:24px;
  overflow:visible;
  background:linear-gradient(135deg,rgba(8,29,25,.94),rgba(4,14,12,.88));
  box-shadow:0 20px 70px rgba(0,0,0,.36),inset 0 0 0 1px rgba(255,255,255,.025);
  transform:translateX(18px) scale(.985);
  opacity:.88;
  transition:transform .65s cubic-bezier(.22,1,.36,1),opacity .65s,border-color .65s,box-shadow .65s;
  isolation:isolate;
}
.road-step.visible,
.road-step.active{
  transform:translateX(0) scale(1);
  opacity:1;
  border-color:rgba(41,219,186,.72);
  box-shadow:0 0 0 1px rgba(41,219,186,.16),0 28px 90px rgba(0,0,0,.44),0 0 44px rgba(41,219,186,.11);
}
.road-step::before{
  content:'';position:absolute;left:calc(var(--line-x) * -1 + 34px);top:50%;width:72px;height:3px;
  background:linear-gradient(90deg,var(--accent),rgba(41,219,186,.15));
  box-shadow:0 0 18px var(--accent-glow);
  transform:translateY(-50%);
  z-index:0;
}
.road-step::after{
  content:'';position:absolute;inset:-1px;border-radius:24px;pointer-events:none;opacity:.55;
  background:linear-gradient(115deg,transparent 0 36%,rgba(41,219,186,.16) 48%,transparent 60%);
  transform:translateX(-36%);
  transition:transform .9s cubic-bezier(.22,1,.36,1);
  mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
  padding:1px;-webkit-mask-composite:xor;mask-composite:exclude;
}
.road-step.active::after{transform:translateX(0)}
.road-copy,.road-visual{position:relative;z-index:2}
.road-copy{padding:clamp(1.2rem,2.5vw,2.15rem);display:flex;flex-direction:column;justify-content:center}
.road-copy h3{font-size:clamp(1.35rem,2.4vw,2rem);line-height:1.08;color:var(--heading);margin:.75rem 0 .8rem;letter-spacing:-.035em}
.road-copy p{color:var(--muted);font-size:clamp(.9rem,1.1vw,.98rem);max-width:470px;line-height:1.65}
.road-list{list-style:none;margin-top:1.05rem;display:grid;gap:.48rem}
.road-list li{font-size:.84rem;color:var(--text);display:flex;gap:.62rem;align-items:center;opacity:.92}
.road-list li::before{content:'✓';display:inline-grid;place-items:center;width:19px;height:19px;border:1px solid var(--border-h);border-radius:50%;color:#07100e;background:var(--accent);font-size:.68rem;font-weight:900;flex:0 0 auto;box-shadow:0 0 14px var(--accent-glow)}
.road-badge{display:inline-flex;align-items:center;gap:.75rem;color:var(--accent);font-weight:900;font-size:.75rem;letter-spacing:.1em;text-transform:uppercase}
.road-num{position:absolute;left:calc(var(--line-x) * -1 - 5px);top:50%;transform:translateY(-50%);display:inline-grid;place-items:center;width:60px;height:60px;border:1px solid var(--border-h);border-radius:50%;box-shadow:0 0 34px var(--accent-glow),inset 0 0 16px rgba(41,219,186,.1);background:#07100e;font-size:1.1rem;color:var(--heading);z-index:4}
.road-step.active .road-num{animation:nodePulse 1.8s ease-in-out infinite}
@keyframes nodePulse{50%{box-shadow:0 0 46px rgba(41,219,186,.45),inset 0 0 22px rgba(41,219,186,.18);transform:translateY(-50%) scale(1.04)}}
.road-visual{
  min-height:260px;
  border-left:1px solid rgba(41,219,186,.18);
  border-radius:22px 0 0 22px;
  background:
    radial-gradient(circle at 58% 70%,rgba(41,219,186,.34),transparent 28%),
    linear-gradient(180deg,rgba(255,255,255,.04),rgba(0,0,0,.14));
  display:grid;place-items:center;overflow:hidden;
}
.road-visual::before{
  content:'';position:absolute;inset:0;opacity:.36;
  background:repeating-linear-gradient(90deg,transparent 0 38px,rgba(41,219,186,.08) 39px 40px);
  animation:scanMove 4s linear infinite;
}
.road-visual::after{
  content:'';position:absolute;left:-8%;right:-8%;bottom:12%;height:56px;
  background:radial-gradient(ellipse,var(--accent-glow),transparent 68%);
  filter:blur(8px);opacity:.5;
}
@keyframes scanMove{to{transform:translateX(80px)}}
.road-visual svg{width:min(86%,390px);height:auto;stroke:var(--accent);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 12px var(--accent-glow));animation:roadFloat 4s ease-in-out infinite}
.road-path{stroke-dasharray:10 12;animation:pathMove .9s linear infinite}.spark{animation:sparkBlink 1.4s ease-in-out infinite}.launch{animation:rocket 2.2s ease-in-out infinite}.road-step.active .road-visual svg{animation-duration:3s}@keyframes roadFloat{50%{transform:translateY(-10px) scale(1.015)}}@keyframes pathMove{to{stroke-dashoffset:-44}}@keyframes sparkBlink{50%{opacity:.22;transform:scale(.78)}}@keyframes rocket{50%{transform:translateY(-15px)}}

@media(max-width:900px){
  #proceso{padding-top:4.5rem;padding-bottom:5rem}
  .process-intro{display:block;margin-top:2.2rem}
  .process-intro>div:first-child{position:relative;top:auto}
  .process-intro>div:first-child::after{display:none}
  .road-steps{--line-x:24px;margin-top:2rem;padding-left:3.15rem;gap:1rem}
  .road-steps::before{left:24px;top:38px;bottom:44px;width:3px}
  .road-step{grid-template-columns:1fr;min-height:0;margin:0 0 .9rem;border-radius:22px;transform:translateX(10px) scale(.99);overflow:visible}
  .road-step::before{left:-28px;width:28px}
  .road-num{left:-4.9rem;width:52px;height:52px;font-size:1rem}
  .road-visual{order:-1;min-height:210px;border-left:0;border-bottom:1px solid rgba(41,219,186,.18);border-radius:22px 22px 0 0}
  .road-visual svg{width:min(82%,320px)}
  .road-copy{padding:1.15rem 1.1rem 1.25rem}
  .road-copy h3{font-size:1.25rem;margin:.55rem 0 .55rem}.road-copy p{font-size:.88rem;line-height:1.55}.road-list{gap:.4rem;margin-top:.85rem}.road-list li{font-size:.8rem}.road-badge{font-size:.68rem;gap:.55rem}
}
@media(max-width:480px){
  #proceso{padding-left:0;padding-right:0}
  .process-intro{margin-top:1.5rem}
  .road-steps{padding-left:2.55rem;margin-right:.1rem}
  .road-step{border-radius:18px}
  .road-visual{min-height:170px;border-radius:18px 18px 0 0}
  .road-visual svg{width:min(86%,260px)}
  .road-num{left:-4.05rem;width:44px;height:44px;font-size:.9rem}
  .road-step::before{left:-22px;width:22px}
  .road-copy{padding:1rem}.road-list{display:none}
}
/* ─── LOGOS OFICIALES TECNOLOGÍAS ─── */
.brand-logo{height:42px;max-width:165px;object-fit:contain;margin-bottom:1rem;filter:drop-shadow(0 0 8px rgba(41,219,186,.2))}.hosting-card{text-align:left}.hosting-card .h-price,.hosting-card .h-sub{display:none}.hosting-card p{font-size:.82rem;color:var(--muted);margin-top:.6rem}.hosting-link{display:inline-block;margin-top:1rem;color:var(--accent);text-decoration:none;font-size:.78rem;font-weight:700}

/* ─── SOPORTE / MANTENIMIENTO ─── */
.mant-card{display:grid;grid-template-columns:82px 1fr;align-items:center;gap:1.4rem}.mant-icon{width:82px;height:82px;border-radius:20px;background:var(--accent-dim);border:1px solid var(--border-h);display:grid;place-items:center;box-shadow:0 0 24px var(--accent-glow)}.mant-card h3{margin-bottom:.35rem}.mant-card p{line-height:1.65}


.brand-wordmark{height:42px;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.15rem;font-weight:900;letter-spacing:-.03em;filter:drop-shadow(0 0 12px var(--accent-glow))}
.imunify-mark{color:#58e070}.litespeed-mark{color:#e8faf7}.cpanel-mark{color:#ff7a2f;font-size:1.45rem}.jetbackup-mark{color:#e8faf7;font-style:italic}

@media(max-width:768px){
  #proceso::before{left:2rem;top:11rem}.process-intro{display:block}.road-steps{margin-top:2rem}.road-step{grid-template-columns:1fr;min-height:auto;padding:1.4rem;margin-left:1.4rem}.road-visual{min-height:190px;order:-1}.road-copy h3{font-size:1.25rem}.mant-card{grid-template-columns:1fr;text-align:left}.feat-icon{width:64px;height:64px}.feat-icon svg{width:38px;height:38px}}



/* ─── PROCESO V5: SCROLL UNO A UNO, MOBILE FIRST ─── */
#proceso.scroll-process{
  position:relative;
  min-height:430vh;
  padding:6rem 2rem 0;
  background:
    radial-gradient(circle at 50% 16%,rgba(41,219,186,.18),transparent 28%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  overflow:clip;
}
#proceso.scroll-process::before{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:.4;
  background-image:linear-gradient(rgba(41,219,186,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(41,219,186,.045) 1px,transparent 1px);
  background-size:46px 46px;
  mask-image:linear-gradient(180deg,transparent,#000 9%,#000 92%,transparent);
}
.process-head{position:relative;z-index:2;text-align:center;margin-bottom:2rem}.process-head .section-sub{margin:0 auto}.process-head em{font-style:normal;color:var(--accent)}
.process-sticky{
  position:sticky;top:82px;z-index:3;height:calc(100vh - 82px);max-width:1120px;margin:0 auto;
  display:grid;place-items:center;padding:1.25rem 0 2rem;
}
.step-screen{
  position:absolute;inset:1.2rem 0 2rem 0;
  display:grid;grid-template-columns:minmax(280px,.82fr) minmax(0,1.18fr);align-items:center;gap:1.4rem;
  border:1px solid rgba(41,219,186,.2);border-radius:30px;overflow:hidden;
  background:linear-gradient(135deg,rgba(8,29,25,.97),rgba(3,12,10,.92));
  box-shadow:0 26px 90px rgba(0,0,0,.42),inset 0 0 0 1px rgba(255,255,255,.025);
  opacity:0;transform:translateY(42px) scale(.96);filter:blur(8px);pointer-events:none;
  transition:opacity .55s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1),filter .55s;
}
.step-screen.active{opacity:1;transform:translateY(0) scale(1);filter:blur(0);pointer-events:auto;border-color:rgba(41,219,186,.72);box-shadow:0 0 0 1px rgba(41,219,186,.18),0 34px 110px rgba(0,0,0,.52),0 0 60px rgba(41,219,186,.16)}
.step-screen.leaving-up{transform:translateY(-42px) scale(.96);opacity:0;filter:blur(8px)}
.step-copy{padding:clamp(1.3rem,4vw,3.4rem);position:relative;z-index:2}.step-kicker{display:inline-flex;color:var(--accent);font-weight:900;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.75rem}.step-copy h3{font-size:clamp(1.8rem,4vw,3.25rem);line-height:1;letter-spacing:-.045em;color:var(--heading);margin-bottom:1rem}.step-copy p{color:var(--muted);font-size:clamp(.94rem,1.25vw,1.08rem);max-width:520px;line-height:1.65}.step-copy ul{list-style:none;margin-top:1.3rem;display:grid;gap:.62rem}.step-copy li{color:var(--text);font-size:.92rem;display:flex;gap:.7rem;align-items:center}.step-copy li::before{content:'✓';width:21px;height:21px;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:#07100e;font-weight:900;font-size:.72rem;box-shadow:0 0 18px var(--accent-glow);flex:0 0 auto}
.step-art{min-height:100%;display:grid;place-items:center;position:relative;overflow:hidden;background:radial-gradient(circle at 50% 60%,rgba(41,219,186,.28),transparent 32%),linear-gradient(90deg,rgba(41,219,186,.04),rgba(255,255,255,.02))}.step-art::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 0 55%,rgba(41,219,186,.1)),repeating-linear-gradient(90deg,transparent 0 40px,rgba(41,219,186,.07) 41px 42px);animation:processScan 5s linear infinite;opacity:.52}.step-art::after{content:'';position:absolute;left:8%;right:8%;bottom:16%;height:70px;border-radius:50%;background:radial-gradient(ellipse,var(--accent-glow),transparent 68%);filter:blur(10px);opacity:.65}.step-art svg{position:relative;z-index:2;width:min(84%,520px);height:auto;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 18px var(--accent-glow));animation:stepFloat 4s ease-in-out infinite}.glow-road{stroke-width:5;stroke-dasharray:12 14;animation:roadFlow 1s linear infinite;filter:drop-shadow(0 0 12px var(--accent))}.rocket{animation:rocketLift 2.4s ease-in-out infinite}@keyframes processScan{to{transform:translateX(84px)}}@keyframes stepFloat{50%{transform:translateY(-12px) scale(1.015)}}@keyframes roadFlow{to{stroke-dashoffset:-52}}@keyframes rocketLift{50%{transform:translateY(-16px)}}
.process-progress{position:absolute;left:0;top:50%;transform:translate(-42%, -50%);z-index:6;display:grid;gap:1.1rem;place-items:center}.progress-line{position:absolute;width:2px;top:28px;bottom:28px;background:linear-gradient(var(--accent),rgba(41,219,186,.2));box-shadow:0 0 16px var(--accent-glow);z-index:-1}.progress-dot{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:#07100e;border:1px solid rgba(41,219,186,.34);color:var(--muted);font-weight:900;font-size:1rem;transition:.35s}.progress-dot.active{color:#fff;border-color:var(--accent);box-shadow:0 0 30px var(--accent-glow),inset 0 0 18px rgba(41,219,186,.12);transform:scale(1.08)}
@media(max-width:900px){#proceso.scroll-process{min-height:420vh;padding:4.5rem 1rem 0}.process-sticky{top:70px;height:calc(100vh - 70px);padding:.8rem 0 1rem}.step-screen{inset:.7rem 0 1rem;grid-template-columns:1fr;grid-template-rows:auto 1fr;border-radius:24px}.step-art{order:-1;min-height:42vh;border-bottom:1px solid rgba(41,219,186,.16)}.step-copy{padding:1.25rem}.step-copy h3{font-size:clamp(1.55rem,8vw,2.35rem)}.step-copy p{font-size:.92rem}.step-copy ul{gap:.42rem;margin-top:.9rem}.step-copy li{font-size:.82rem}.process-progress{left:50%;top:auto;bottom:.2rem;transform:translateX(-50%);display:flex;gap:.55rem}.progress-line{display:none}.progress-dot{width:38px;height:38px;font-size:.78rem;background:rgba(7,16,14,.92)}}
@media(max-width:520px){#proceso.scroll-process{padding-left:.75rem;padding-right:.75rem}.process-head{text-align:left;margin-bottom:1rem}.process-head .section-sub{margin:0}.step-screen{border-radius:20px}.step-art{min-height:36vh}.step-art svg{width:min(88%,330px)}.step-copy{padding:1.05rem}.step-copy ul{display:none}.process-progress{bottom:.45rem}.progress-dot{width:34px;height:34px;font-size:.72rem}.step-screen{inset:.55rem 0 1.15rem}}
@media(max-height:680px){.step-art{min-height:34vh}.step-copy{padding:1rem}.step-copy h3{font-size:1.55rem}.step-copy p{font-size:.86rem}.step-copy ul{display:none}.process-sticky{top:62px;height:calc(100vh - 62px)}}
@media(prefers-reduced-motion:reduce){.step-screen,.step-art svg,.glow-road,.rocket,.step-art::before{animation:none!important;transition:none!important}}


/* ─── Anti-spam honeypot ─── */
.hp-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important}

.grecaptcha-badge {
  visibility: hidden !important;
}

/* Ocultar badge reCAPTCHA v3 */
.grecaptcha-badge {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Links legales del formulario */
.form-safe-note a {
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.form-safe-note a:hover {
  color: var(--heading);
}