@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{
  --bg:#020713;
  --bg2:#050b18;
  --panel:#071020;
  --card:#0a1426;
  --card2:#101b33;
  --text:#ffffff;
  --muted:#b8c7dc;
  --muted2:#dce8f7;
  --cyan:#12d8ff;
  --blue:#087fc3;
  --blue2:#0ea5e9;
  --violet:#6d4dff;
  --purple:#2b145f;
  --pink:#9b5cff;
  --green:#20df75;
  --border:rgba(255,255,255,.12);
  --shadow:0 32px 90px rgba(0,0,0,.42);
  --radius:28px;
  --max:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
}

.site-bg{
  position:fixed;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(circle at 14% 8%, rgba(18,216,255,.18), transparent 32%),
    radial-gradient(circle at 86% 10%, rgba(8,127,195,.28), transparent 34%),
    radial-gradient(circle at 55% 78%, rgba(109,77,255,.12), transparent 38%),
    linear-gradient(180deg,#06101f 0%,#020713 58%,#01030a 100%);
}

a{color:inherit;text-decoration:none}
.container{width:min(var(--max),calc(100% - 48px));margin:0 auto}
.section{position:relative;padding:110px 0;overflow:hidden}

.caska-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(3,9,20,.82);
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
}
.nav-shell{
  width:min(1280px,calc(100% - 48px));
  margin:0 auto;
  height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:30px;
}
.brand{display:flex;align-items:center;gap:12px;min-width:max-content}
.brand-logo img{
  display:block;
  width:172px;
  max-height:58px;
  object-fit:contain;
  filter:drop-shadow(0 18px 32px rgba(36,225,255,.18));
}
.footer-brand img{
  width:190px;
  max-height:70px;
}
.brand-mark{
  width:46px;height:46px;border-radius:16px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  color:#06101f;font-weight:900;font-size:22px;
  box-shadow:0 18px 40px rgba(41,148,255,.28);
}
.brand-text{display:flex;flex-direction:column;line-height:.95}
.brand-text strong{font-size:22px;font-weight:900;letter-spacing:-.05em}
.brand-text small{font-size:20px;font-weight:800;color:#8ef3ff;letter-spacing:-.04em}

.main-nav{display:flex;align-items:center;gap:6px}
.main-nav a{
  padding:12px 15px;
  border-radius:999px;
  color:#ddd6ee;
  font-weight:700;
  font-size:15px;
  transition:.2s ease;
}
.main-nav a:hover,.main-nav a.active{background:rgba(8,127,195,.28);color:#fff}
.nav-cta{
  min-width:max-content;
  padding:15px 24px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--blue),var(--blue2),var(--cyan));
  font-weight:900;
  box-shadow:0 18px 52px rgba(41,148,255,.28);
}
.nav-toggle{display:none;background:transparent;border:0;cursor:pointer}
.nav-toggle span{display:block;width:26px;height:3px;background:#fff;border-radius:99px;margin:5px 0}

.hero{min-height:calc(100vh - 78px);display:flex;align-items:center;padding:72px 0 86px}
.hero-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:70px;align-items:center}
.hero-glow{position:absolute;border-radius:50%;filter:blur(10px);opacity:.8}
.hero-glow-one{width:380px;height:380px;left:-150px;top:90px;background:radial-gradient(circle,rgba(8,127,195,.38),transparent 70%)}
.hero-glow-two{width:520px;height:520px;right:-200px;top:110px;background:radial-gradient(circle,rgba(18,216,255,.24),transparent 70%)}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 17px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(8,127,195,.20);
  border-radius:999px;
  color:#fff;
  font-size:14px;
  font-weight:800;
  box-shadow:0 0 34px rgba(18,216,255,.12);
}
.hero h1{
  margin:20px 0 18px;
  font-size:clamp(42px,4.85vw,68px);
  line-height:1.02;
  letter-spacing:-.065em;
  font-weight:900;
  max-width:680px;
}
.hero p{
  margin:0;
  max-width:680px;
  color:var(--muted);
  font-size:17px;
  line-height:1.65;
}
.hero p strong{color:#fff}
.hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:26px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:54px;
  padding:16px 26px;
  border-radius:999px;
  font-weight:900;
  font-size:15px;
  transition:.22s ease;
}
.btn:hover{transform:translateY(-3px)}
.btn-primary{
  background:linear-gradient(135deg,var(--violet) 0%,var(--blue) 55%,var(--cyan) 100%);
  color:#fff;
  box-shadow:0 22px 55px rgba(41,148,255,.26);
}
.btn-ghost{
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  color:#fff;
}
.hero-proof{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:26px;
  max-width:650px;
}
.hero-proof div{
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
}
.hero-proof strong{display:block;font-size:18px}
.hero-proof span{display:block;color:var(--muted);font-size:13px;margin-top:4px}

.hero-visual{position:relative;min-height:455px}
.browser-card{
  position:relative;
  min-height:380px;
  border-radius:34px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:var(--shadow), inset 0 1px 0 rgba(255,255,255,.10);
  overflow:hidden;
}
.browser-card::before{
  content:'';
  position:absolute;
  inset:-1px;
  background:linear-gradient(135deg,rgba(123,82,255,.18),rgba(36,225,255,.08),rgba(255,82,170,.08));
  pointer-events:none;
}
.browser-top{
  height:58px;
  display:flex;
  align-items:center;
  gap:8px;
  padding:0 26px;
  position:relative;
  z-index:2;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.browser-top span{width:12px;height:12px;border-radius:50%;background:var(--violet)}
.browser-top span:nth-child(2){background:var(--cyan)}
.browser-top span:nth-child(3){background:var(--pink)}
.top-pill{
  margin-left:auto;width:42%;height:20px;border-radius:999px;background:rgba(255,255,255,.08);
}
.browser-content{
  position:relative;
  z-index:2;
  padding:26px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:26px;
}
.metric-card,.dash-right,.mini-grid div{
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.10);
  border-radius:24px;
}
.metric-card{padding:24px;min-height:148px}
.metric-card small{display:block;color:var(--muted);font-weight:700}
.metric-card strong{display:block;margin:13px 0 8px;font-size:38px;letter-spacing:-.06em}
.metric-card em{color:var(--cyan);font-style:normal;font-weight:800}
.mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}
.mini-grid div{height:62px}
.dash-right{padding:24px;min-height:270px}
.chart{height:160px;display:flex;align-items:flex-end;gap:12px;padding:10px 0}
.chart span{
  flex:1;border-radius:99px 99px 10px 10px;
  background:linear-gradient(180deg,var(--cyan),var(--violet));
  opacity:.85;
}
.status-list{display:grid;gap:10px;margin-top:18px}
.status-list i{height:16px;border-radius:999px;background:rgba(255,255,255,.12)}
.status-list i:nth-child(2){width:78%}
.status-list i:nth-child(3){width:55%}

.floating-card{
  position:absolute;
  z-index:5;
  padding:15px 17px;
  border-radius:20px;
  background:rgba(10,6,23,.76);
  border:1px solid rgba(255,255,255,.13);
  backdrop-filter:blur(16px);
  box-shadow:0 25px 50px rgba(0,0,0,.3);
}
.floating-card b{display:block;font-size:15px}
.floating-card span{display:block;margin-top:4px;color:var(--muted);font-size:12px}
.card-a{left:-34px;top:70px}
.card-b{right:-20px;top:245px}
.card-c{left:80px;bottom:20px}

.section-head{text-align:center;max-width:820px;margin:0 auto 58px}
.section-head h2{
  margin:18px 0 14px;
  font-size:clamp(36px,4.5vw,62px);
  line-height:1.04;
  letter-spacing:-.055em;
}
.section-head p{margin:0 auto;color:var(--muted);font-size:18px;line-height:1.7}

.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.service-card,.plan-card,.project-card,.step{
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius);
  padding:30px;
  box-shadow:0 24px 70px rgba(0,0,0,.20);
  transition:.22s ease;
}
.service-card:hover,.plan-card:hover,.project-card:hover,.step:hover{
  transform:translateY(-7px);
  border-color:rgba(36,225,255,.34);
  box-shadow:0 28px 90px rgba(20,40,120,.20);
}
.icon{
  width:58px;height:58px;border-radius:19px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  font-size:25px;
  margin-bottom:24px;
}
.service-card h3,.plan-card h3,.project-card h3,.step h3{margin:0 0 12px;font-size:23px;letter-spacing:-.03em}
.service-card p,.plan-card p,.project-card p,.step p{margin:0;color:var(--muted);line-height:1.68}
.service-card a{display:inline-flex;margin-top:24px;color:var(--cyan);font-weight:900}

.feature{background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,0))}
.feature-grid{display:grid;grid-template-columns:.88fr 1.12fr;gap:72px;align-items:center}
.feature-copy h2{
  margin:18px 0;
  font-size:clamp(36px,4.6vw,64px);
  line-height:1.02;
  letter-spacing:-.055em;
}
.feature-copy p{color:var(--muted);font-size:18px;line-height:1.75}
.feature-list{display:flex;flex-wrap:wrap;gap:10px;margin:28px 0 18px}
.feature-list span{
  padding:10px 14px;border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color:#fff;font-weight:700;font-size:14px;
}
.system-panel{
  border-radius:34px;
  background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(14,165,233,.035));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:var(--shadow);
  padding:28px;
}
.panel-header{display:flex;align-items:center;gap:8px;margin-bottom:24px}
.panel-header span{width:12px;height:12px;border-radius:50%;background:var(--violet)}
.panel-header span:nth-child(2){background:var(--cyan)}
.panel-header span:nth-child(3){background:var(--pink)}
.panel-header b{margin-left:auto;color:var(--muted2)}
.panel-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.panel-kpis div{
  padding:18px;
  border-radius:20px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.09);
}
.panel-kpis small{display:block;color:var(--muted)}
.panel-kpis strong{display:block;margin-top:8px;font-size:28px}
.panel-body{display:grid;grid-template-columns:1.25fr .75fr;gap:16px;margin-top:16px}
.line-chart,.tasks{
  height:220px;border-radius:22px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.09);
}
.line-chart{position:relative;overflow:hidden}
.line-chart i{
  position:absolute;left:10%;right:10%;bottom:30%;
  height:46%;
  border-radius:40px 40px 0 0;
  border:3px solid var(--cyan);
  border-left:0;border-bottom:0;
  transform:skewX(-14deg);
  opacity:.8;
}
.tasks{padding:20px;display:grid;gap:12px;align-content:start}
.tasks span{height:18px;border-radius:999px;background:rgba(255,255,255,.12)}
.tasks span:nth-child(2){width:80%}
.tasks span:nth-child(3){width:60%}
.tasks span:nth-child(4){width:90%}

.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.plan-card{padding:34px}
.plan-card.featured{
  background:
    radial-gradient(circle at 50% 0%,rgba(18,216,255,.18),transparent 40%),
    linear-gradient(180deg,rgba(8,127,195,.24),rgba(109,77,255,.07));
  border-color:rgba(36,225,255,.28);
}
.plan-label{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(8,127,195,.20);border:1px solid rgba(255,255,255,.10);color:#fff;font-size:12px;font-weight:900}
.plan-card h3{font-size:30px;margin-top:22px}
.plan-card ul{list-style:none;margin:24px 0 30px;padding:0;display:grid;gap:12px}
.plan-card li{color:var(--muted2);position:relative;padding-left:25px}
.plan-card li::before{content:'✓';position:absolute;left:0;color:var(--cyan);font-weight:900}

.project-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.project-thumb{
  height:175px;border-radius:24px;margin-bottom:22px;
  border:1px solid rgba(255,255,255,.11);
  position:relative;overflow:hidden;
}
.project-thumb::before{
  content:'';position:absolute;inset:24px;border-radius:18px;background:rgba(255,255,255,.14);
  box-shadow:0 54px 0 rgba(255,255,255,.09);
}
.project-thumb.web{background:linear-gradient(135deg,rgba(123,82,255,.55),rgba(36,225,255,.18))}
.project-thumb.ecommerce{background:linear-gradient(135deg,rgba(36,225,255,.34),rgba(255,82,170,.18))}
.project-thumb.system{background:linear-gradient(135deg,rgba(255,82,170,.26),rgba(123,82,255,.46))}
.project-card span{color:var(--cyan);font-weight:900;font-size:13px;text-transform:uppercase;letter-spacing:.08em}

.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step b{
  width:52px;height:52px;border-radius:50%;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  margin-bottom:22px;
}

.cta-section{
  padding:120px 0;
  text-align:center;
  background:
    radial-gradient(circle at 15% 0%,rgba(18,216,255,.18),transparent 30%),
    radial-gradient(circle at 85% 0%,rgba(109,77,255,.18),transparent 28%),
    linear-gradient(135deg,#061a33 0%,#06101f 54%,#020713 100%);
}
.cta-section h2{
  max-width:920px;margin:20px auto 18px;
  font-size:clamp(40px,5vw,72px);
  line-height:1.02;
  letter-spacing:-.06em;
}
.cta-section p{max-width:760px;margin:0 auto;color:var(--muted);font-size:18px;line-height:1.75}
.centered{justify-content:center}

.footer{
  padding:70px 0 90px;
  border-top:1px solid rgba(255,255,255,.08);
  background:#01040b;
}
.footer-grid{display:grid;grid-template-columns:1.4fr .8fr .8fr;gap:60px}
.footer p{color:var(--muted);line-height:1.7;max-width:390px}
.footer h4{margin:0 0 18px;font-size:18px}
.footer a,.footer span{display:block;color:var(--muted);margin:11px 0}
.footer a:hover{color:var(--cyan)}
.footer-brand{margin-bottom:20px}

.whatsapp-float{
  position:fixed;
  right:26px;
  bottom:26px;
  z-index:60;
  padding:16px 22px;
  border-radius:999px;
  background:var(--green);
  color:#031108;
  font-weight:900;
  box-shadow:0 20px 60px rgba(32,223,117,.28);
}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.delay-1{transition-delay:.09s}.delay-2{transition-delay:.18s}.delay-3{transition-delay:.27s}

@media(max-width:1050px){
  .nav-cta{display:none}
  .main-nav{gap:2px}
  .main-nav a{font-size:14px;padding:10px}
  .hero-grid,.feature-grid{grid-template-columns:1fr;gap:54px}
  .service-grid,.process-grid{grid-template-columns:repeat(2,1fr)}
  .plans-grid,.project-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .brand-logo img{width:142px;max-height:48px}

  .container,.nav-shell{width:min(100% - 34px,var(--max))}
  .nav-shell{height:62px}
  .nav-toggle{display:block}
  .main-nav{
    position:absolute;left:17px;right:17px;top:86px;
    display:none;flex-direction:column;align-items:stretch;
    padding:16px;border-radius:24px;
    background:rgba(12,8,24,.96);
    border:1px solid var(--border);
    box-shadow:var(--shadow);
  }
  .main-nav.open{display:flex}
  .main-nav a{padding:14px 16px}
  .hero{padding:80px 0}
  .hero h1{font-size:43px}
  .hero p{font-size:16px}
  .hero-proof{grid-template-columns:1fr}
  .hero-visual{min-height:430px}
  .browser-content{grid-template-columns:1fr;padding:22px}
  .dash-right{display:none}
  .floating-card{display:none}
  .section{padding:78px 0}
  .service-grid,.panel-kpis,.panel-body,.process-grid,.footer-grid{grid-template-columns:1fr}
  .footer{padding-bottom:120px}
}


/* CASKA palette refinement: blue + black + white with premium purple accents */
.hero h1,
.section-head h2,
.feature-copy h2,
.cta-section h2{
  color:#fff;
}

.hero h1::after{
  content:'';
  display:block;
  width:110px;
  height:5px;
  margin-top:24px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--cyan),var(--blue),var(--violet));
  box-shadow:0 0 35px rgba(18,216,255,.24);
}

.service-card,
.plan-card,
.project-card,
.step,
.system-panel,
.hero-proof div{
  background:
    linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.028)),
    linear-gradient(135deg,rgba(18,216,255,.035),rgba(109,77,255,.025));
}

.service-card::before,
.plan-card::before,
.project-card::before{
  content:'';
  display:block;
  height:3px;
  width:54px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--cyan),var(--violet));
  margin-bottom:22px;
  opacity:.9;
}

.brand-logo img{
  filter:drop-shadow(0 18px 35px rgba(18,216,255,.16));
}


/* V4 HERO FIT FIX: mantener el hero completo dentro de la primera pantalla */
.hero{
  min-height:calc(100vh - 78px);
  padding-top:64px;
  padding-bottom:70px;
}
.hero-grid{
  grid-template-columns:.9fr 1.1fr;
  gap:64px;
}
.hero h1{
  font-size:clamp(40px,4.6vw,66px);
  line-height:1.02;
  letter-spacing:-.055em;
  max-width:660px;
}
.hero p{
  max-width:620px;
  font-size:17px;
  line-height:1.62;
}
.hero-actions{
  margin-top:24px;
}
.btn{
  min-height:50px;
  padding:14px 24px;
}
.hero-proof{
  margin-top:24px;
}
.hero-proof div{
  padding:13px 14px;
}
.hero-visual{
  min-height:430px;
}
.browser-card{
  min-height:372px;
}
.browser-content{
  padding:24px;
}
.metric-card{
  min-height:142px;
}
.metric-card strong{
  font-size:36px;
}
.dash-right{
  min-height:260px;
}
.chart{
  height:150px;
}
.floating-card{
  padding:13px 15px;
}
.card-a{left:-20px;top:66px}
.card-b{right:-8px;top:218px}
.card-c{left:110px;bottom:26px}

@media(max-width:1280px){
  .hero h1{
    font-size:clamp(38px,4.35vw,60px);
    max-width:610px;
  }
  .hero-grid{
    gap:48px;
  }
}
@media(max-width:1050px){
  .hero{
    min-height:auto;
    padding-top:78px;
    padding-bottom:78px;
  }
  .hero h1{
    font-size:48px;
    max-width:760px;
  }
}
@media(max-width:760px){
  .hero{
    padding-top:64px;
    padding-bottom:72px;
  }
  .hero h1{
    font-size:38px;
    line-height:1.03;
  }
}


/* V5 HERO COMPACTO: entra mejor en pantalla principal */
.hero{
  min-height:calc(100vh - 78px);
  padding-top:44px !important;
  padding-bottom:46px !important;
}

.hero-grid{
  grid-template-columns:.86fr 1.14fr;
  gap:56px;
  align-items:center;
}

.hero h1{
  font-size:clamp(34px,3.85vw,54px) !important;
  line-height:1.03 !important;
  letter-spacing:-.052em !important;
  max-width:560px !important;
  margin:16px 0 14px !important;
}

.hero h1::after{
  width:92px;
  height:4px;
  margin-top:18px;
}

.eyebrow{
  padding:8px 15px;
  font-size:13px;
}

.hero p{
  max-width:560px !important;
  font-size:15.5px !important;
  line-height:1.58 !important;
}

.hero-actions{
  margin-top:20px !important;
}

.btn{
  min-height:46px !important;
  padding:13px 22px !important;
  font-size:14px !important;
}

.hero-proof{
  margin-top:20px !important;
  gap:10px !important;
  max-width:560px !important;
}

.hero-proof div{
  padding:11px 12px !important;
  border-radius:17px !important;
}

.hero-proof strong{
  font-size:16px !important;
}

.hero-proof span{
  font-size:12px !important;
}

.hero-visual{
  min-height:390px !important;
}

.browser-card{
  min-height:330px !important;
  border-radius:30px !important;
}

.browser-top{
  height:50px !important;
  padding:0 22px !important;
}

.browser-top span{
  width:10px !important;
  height:10px !important;
}

.top-pill{
  height:17px !important;
}

.browser-content{
  padding:22px !important;
  gap:18px !important;
}

.metric-card{
  min-height:120px !important;
  padding:20px !important;
}

.metric-card strong{
  font-size:32px !important;
}

.metric-card em{
  font-size:14px !important;
}

.mini-grid{
  gap:10px !important;
  margin-top:12px !important;
}

.mini-grid div{
  height:52px !important;
  border-radius:18px !important;
}

.dash-right{
  min-height:228px !important;
  padding:20px !important;
  border-radius:22px !important;
}

.chart{
  height:128px !important;
}

.status-list{
  gap:8px !important;
  margin-top:14px !important;
}

.status-list i{
  height:14px !important;
}

.floating-card{
  padding:11px 13px !important;
  border-radius:17px !important;
}

.floating-card b{
  font-size:13px !important;
}

.floating-card span{
  font-size:11px !important;
}

.card-a{left:-8px !important;top:54px !important;}
.card-b{right:-4px !important;top:190px !important;}
.card-c{left:105px !important;bottom:18px !important;}

@media(max-width:1366px){
  .hero h1{
    font-size:clamp(33px,3.55vw,50px) !important;
    max-width:530px !important;
  }
  .hero p{
    font-size:15px !important;
    max-width:530px !important;
  }
  .hero-grid{
    gap:50px;
  }
  .hero-visual{
    min-height:365px !important;
  }
  .browser-card{
    min-height:310px !important;
  }
}

@media(max-width:1050px){
  .hero{
    min-height:auto !important;
    padding-top:64px !important;
    padding-bottom:70px !important;
  }
  .hero-grid{
    grid-template-columns:1fr;
  }
  .hero h1{
    font-size:44px !important;
    max-width:760px !important;
  }
  .hero p{
    max-width:720px !important;
  }
}

@media(max-width:760px){
  .hero h1{
    font-size:35px !important;
  }
  .hero p{
    font-size:15px !important;
  }
}


/* V6 MOCKUPS: hero y sistema más premium */
.browser-card{
  background:
    linear-gradient(180deg, rgba(255,255,255,.11), rgba(255,255,255,.03)),
    radial-gradient(circle at 100% 0%, rgba(18,216,255,.08), transparent 30%),
    radial-gradient(circle at 0% 100%, rgba(109,77,255,.10), transparent 34%);
}

.premium-browser{
  display:grid !important;
  grid-template-columns:74px 1fr;
  gap:18px;
  align-items:stretch;
}
.browser-sidebar{
  border-radius:22px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.10);
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:16px 10px;
  gap:12px;
}
.side-avatar{
  width:38px;
  height:38px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--blue2),var(--cyan));
  box-shadow:0 10px 24px rgba(18,216,255,.22);
  margin-bottom:6px;
}
.browser-sidebar span{
  width:100%;
  height:12px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
}
.browser-sidebar span:nth-child(3){width:86%}
.browser-sidebar span:nth-child(4){width:72%}
.browser-sidebar span:nth-child(5){width:90%}

.browser-main{
  display:grid;
  gap:16px;
}
.browser-main-top{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:16px;
}
.browser-main-bottom{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.metric-card.main{
  background:
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04)),
    linear-gradient(135deg, rgba(18,216,255,.08), rgba(109,77,255,.08));
}

.kpi-stack{
  display:grid;
  gap:12px;
}
.kpi-chip{
  border-radius:20px;
  padding:18px 18px 16px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.10);
}
.kpi-chip small{
  display:block;
  color:var(--muted);
}
.kpi-chip b{
  display:block;
  margin-top:8px;
  font-size:24px;
  color:#fff;
}

.mini-grid div{
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035)),
    linear-gradient(135deg, rgba(18,216,255,.04), rgba(109,77,255,.05));
  position:relative;
  overflow:hidden;
}
.mini-grid div::before{
  content:'';
  position:absolute;
  left:14px;
  right:14px;
  top:14px;
  height:10px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
}
.mini-grid div::after{
  content:'';
  position:absolute;
  left:14px;
  right:30%;
  bottom:14px;
  height:24px;
  border-radius:12px;
  background:rgba(255,255,255,.08);
}

.dash-right{
  background:
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03)),
    linear-gradient(135deg, rgba(109,77,255,.06), rgba(18,216,255,.04));
}

.chart{
  align-items:flex-end;
}
.chart span{
  box-shadow:0 10px 24px rgba(18,216,255,.12);
}

.system-panel{
  background:
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.035)),
    radial-gradient(circle at 100% 0%, rgba(18,216,255,.08), transparent 30%);
}
.panel-table{
  margin-top:16px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  overflow:hidden;
}
.table-head,
.table-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:14px 18px;
}
.table-head{
  background:rgba(255,255,255,.06);
  color:#fff;
}
.table-head small{
  color:var(--muted);
}
.table-row{
  border-top:1px solid rgba(255,255,255,.08);
}
.table-row span{
  color:#fff;
  font-weight:700;
}
.table-row em{
  font-style:normal;
  color:var(--muted);
  font-size:14px;
}

.floating-card{
  background:rgba(9,10,25,.82);
  box-shadow:0 22px 48px rgba(0,0,0,.35);
}

@media(max-width:1050px){
  .premium-browser,
  .browser-main-top,
  .browser-main-bottom{
    grid-template-columns:1fr;
  }
  .browser-sidebar{
    display:none;
  }
}


/* V7 SERVICES + ICONS: iconografía profesional y cards más premium */
.svg-icon{
  position:relative;
  overflow:hidden;
}
.svg-icon svg{
  width:28px;
  height:28px;
  fill:#fff;
  position:relative;
  z-index:2;
}
.svg-icon::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:radial-gradient(circle at 35% 20%,rgba(255,255,255,.28),transparent 34%);
  opacity:.9;
}
.service-card{
  position:relative;
  min-height:355px;
  display:flex;
  flex-direction:column;
}
.service-card .icon{
  margin-bottom:22px;
}
.service-card h3{
  font-size:24px;
}
.service-card p{
  min-height:82px;
}
.mini-bullets{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  list-style:none;
  padding:0;
  margin:22px 0 0;
}
.mini-bullets li{
  padding:8px 10px;
  border-radius:999px;
  background:rgba(18,216,255,.075);
  border:1px solid rgba(18,216,255,.14);
  color:#dff8ff;
  font-size:12px;
  font-weight:800;
}
.service-card a{
  margin-top:auto;
  padding-top:24px;
}
.service-card::after{
  content:'';
  position:absolute;
  inset:auto 24px 0 24px;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  opacity:.35;
}
.service-card:hover .svg-icon{
  box-shadow:0 22px 48px rgba(18,216,255,.22);
}
.service-card:hover .svg-icon svg{
  transform:scale(1.04);
}
.svg-icon svg{
  transition:transform .22s ease;
}

@media(max-width:1050px){
  .service-card{
    min-height:auto;
  }
  .service-card p{
    min-height:auto;
  }
}


/* V8 SAAS + PLANES: secciones más comerciales y premium */
.feature{
  position:relative;
}
.feature::before{
  content:'';
  position:absolute;
  inset:40px auto auto 6%;
  width:160px;
  height:160px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(18,216,255,.12), transparent 70%);
  pointer-events:none;
}
.feature-modules{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
  margin:30px 0 22px;
}
.feature-list.feature-modules span{
  display:block;
  padding:15px 16px;
  border-radius:18px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.03)),
    linear-gradient(135deg,rgba(18,216,255,.055),rgba(109,77,255,.035));
  border:1px solid rgba(255,255,255,.10);
}
.feature-modules b{
  display:block;
  color:#fff;
  font-size:15px;
  margin-bottom:4px;
}
.feature-modules small{
  display:block;
  color:var(--muted);
  font-size:12px;
  font-weight:700;
}
.feature-secondary{
  margin-left:10px;
}
.panel-table{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04);
}
.table-row:hover{
  background:rgba(18,216,255,.035);
}
.plans{
  background:
    radial-gradient(circle at 50% 0%,rgba(18,216,255,.08),transparent 32%),
    linear-gradient(180deg,rgba(255,255,255,.012),rgba(255,255,255,0));
}
.plan-card{
  position:relative;
  overflow:hidden;
}
.plan-card::after{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(18,216,255,.10),transparent 42%);
  opacity:0;
  transition:.22s ease;
  pointer-events:none;
}
.plan-card:hover::after,
.plan-card.featured::after{
  opacity:1;
}
.plan-card.featured{
  transform:translateY(-12px);
  box-shadow:0 34px 110px rgba(18,216,255,.12), 0 28px 90px rgba(0,0,0,.32);
}
.plan-card.featured:hover{
  transform:translateY(-18px);
}
.plan-label{
  background:rgba(18,216,255,.08);
  border-color:rgba(18,216,255,.18);
  color:#dffaff;
}
.plan-card.featured .plan-label{
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  color:#03101f;
}
.plan-card .btn{
  width:100%;
}
.plan-card .btn.btn-ghost{
  border-color:rgba(18,216,255,.18);
}
.plans-note{
  margin:32px auto 0;
  max-width:880px;
  padding:18px 22px;
  border-radius:22px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.10);
  color:var(--muted);
  text-align:center;
  line-height:1.65;
}
.plans-note strong{
  color:#fff;
}

@media(max-width:1050px){
  .feature-modules{
    grid-template-columns:repeat(2,1fr);
  }
  .feature-secondary{
    margin-left:0;
  }
  .plan-card.featured{
    transform:none;
  }
  .plan-card.featured:hover{
    transform:translateY(-7px);
  }
}
@media(max-width:760px){
  .feature-modules{
    grid-template-columns:1fr;
  }
}


/* V9 PROYECTOS: catálogo de soluciones comprables */
.projects{
  background:
    radial-gradient(circle at 10% 8%,rgba(18,216,255,.06),transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.012),rgba(255,255,255,0));
}
.project-grid-six{
  grid-template-columns:repeat(3,1fr);
}
.project-card{
  position:relative;
  overflow:hidden;
  min-height:430px;
  display:flex;
  flex-direction:column;
}
.project-card .project-thumb{
  flex:0 0 auto;
}
.project-thumb{
  background-size:cover;
}
.project-thumb.landing{
  background:
    radial-gradient(circle at 20% 20%,rgba(18,216,255,.26),transparent 34%),
    linear-gradient(135deg,rgba(8,127,195,.52),rgba(109,77,255,.22));
}
.project-thumb.membership{
  background:
    radial-gradient(circle at 82% 18%,rgba(18,216,255,.26),transparent 34%),
    linear-gradient(135deg,rgba(109,77,255,.48),rgba(8,127,195,.22));
}
.project-thumb.workshop{
  background:
    radial-gradient(circle at 20% 80%,rgba(18,216,255,.22),transparent 34%),
    linear-gradient(135deg,rgba(8,127,195,.38),rgba(255,255,255,.055));
}
.project-thumb.finance{
  background:
    radial-gradient(circle at 80% 20%,rgba(32,223,117,.14),transparent 34%),
    linear-gradient(135deg,rgba(18,216,255,.28),rgba(109,77,255,.24));
}
.project-thumb::before{
  inset:18px;
}
.project-thumb::after{
  top:32px;
  height:20px;
  box-shadow:0 38px 0 rgba(255,255,255,.10), 0 76px 0 rgba(255,255,255,.07);
}
.project-card h3{
  font-size:24px;
}
.project-card p{
  min-height:76px;
}
.project-points{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  list-style:none;
  padding:0;
  margin:20px 0 0;
}
.project-points li{
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.10);
  color:#e8f7ff;
  font-size:12px;
  font-weight:800;
}
.project-card a{
  margin-top:auto;
  padding-top:24px;
  color:var(--cyan);
  font-weight:900;
}
.projects-cta{
  margin-top:34px;
  padding:28px;
  border-radius:30px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.032)),
    linear-gradient(135deg,rgba(18,216,255,.045),rgba(109,77,255,.045));
  border:1px solid rgba(255,255,255,.11);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
}
.projects-cta span{
  display:inline-flex;
  color:var(--cyan);
  font-weight:900;
  margin-bottom:8px;
}
.projects-cta h3{
  margin:0;
  max-width:760px;
  font-size:25px;
  line-height:1.25;
  letter-spacing:-.035em;
}
.projects-cta .btn{
  min-width:max-content;
}
@media(max-width:1050px){
  .project-grid-six{
    grid-template-columns:1fr 1fr;
  }
  .projects-cta{
    align-items:flex-start;
    flex-direction:column;
  }
}
@media(max-width:760px){
  .project-grid-six{
    grid-template-columns:1fr;
  }
  .project-card{
    min-height:auto;
  }
  .project-card p{
    min-height:auto;
  }
}


/* V10 CIERRE: proceso, CTA y footer más profesionales */
.process{
  background:
    radial-gradient(circle at 8% 8%,rgba(109,77,255,.08),transparent 32%),
    radial-gradient(circle at 92% 12%,rgba(18,216,255,.07),transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.012),rgba(255,255,255,0));
}
.process-timeline{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.process-timeline::before{
  content:'';
  position:absolute;
  left:7%;
  right:7%;
  top:26px;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(18,216,255,.35),rgba(109,77,255,.25),transparent);
  pointer-events:none;
}
.step{
  position:relative;
  min-height:245px;
}
.step b{
  position:relative;
  z-index:2;
}
.step h3{
  margin-top:18px;
}
.cta-section{
  text-align:left;
  padding:110px 0;
}
.cta-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:52px;
  align-items:center;
}
.cta-copy h2{
  max-width:820px;
  margin:20px 0 18px;
}
.cta-copy p{
  margin:0;
  max-width:720px;
}
.contact-card{
  padding:30px;
  border-radius:32px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.035)),
    radial-gradient(circle at 100% 0%,rgba(18,216,255,.12),transparent 36%);
  border:1px solid rgba(255,255,255,.13);
  box-shadow:0 32px 90px rgba(0,0,0,.28);
}
.contact-row{
  padding:18px 0;
  border-bottom:1px solid rgba(255,255,255,.10);
}
.contact-row:last-child{
  border-bottom:0;
}
.contact-row span{
  display:block;
  color:var(--cyan);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:900;
  margin-bottom:6px;
}
.contact-row strong{
  display:block;
  color:#fff;
  font-size:19px;
  line-height:1.35;
}
.footer{
  padding:78px 0 34px;
}
.footer-grid{
  grid-template-columns:1.25fr .75fr .9fr .9fr;
  gap:46px;
}
.footer-about p{
  max-width:430px;
}
.footer h4{
  color:#fff;
  position:relative;
  padding-bottom:12px;
}
.footer h4::after{
  content:'';
  position:absolute;
  left:0;
  bottom:0;
  width:42px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--cyan),var(--violet));
}
.footer-bottom{
  margin-top:56px;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  justify-content:space-between;
  gap:20px;
  color:var(--muted);
  font-size:14px;
}
.whatsapp-float{
  transition:.22s ease;
}
.whatsapp-float:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 70px rgba(32,223,117,.36);
}
@media(max-width:1050px){
  .process-timeline{
    grid-template-columns:1fr 1fr;
  }
  .process-timeline::before{
    display:none;
  }
  .cta-grid,
  .footer-grid{
    grid-template-columns:1fr;
  }
}
@media(max-width:760px){
  .process-timeline{
    grid-template-columns:1fr;
  }
  .step{
    min-height:auto;
  }
  .cta-section{
    padding:82px 0;
  }
  .contact-card{
    padding:24px;
  }
  .contact-row strong{
    font-size:16px;
    word-break:break-word;
  }
  .footer-bottom{
    flex-direction:column;
  }
}


/* V11 RESPONSIVE FINAL: ajustes para tablet y móvil */
@media(max-width:1180px){
  .nav-shell{
    width:min(100% - 34px, var(--max));
    gap:18px;
  }
  .main-nav a{
    padding:10px 10px;
    font-size:13.5px;
  }
  .brand-logo img{
    width:148px;
  }
  .hero-grid{
    grid-template-columns:.92fr 1.08fr;
    gap:38px;
  }
  .hero h1{
    font-size:clamp(34px,4vw,50px) !important;
  }
  .browser-card{
    min-height:300px !important;
  }
  .premium-browser{
    grid-template-columns:60px 1fr;
    gap:14px;
  }
}

@media(max-width:980px){
  .nav-cta{
    display:inline-flex;
    padding:13px 18px;
    font-size:13px;
  }
  .main-nav{
    display:none;
  }
  .nav-toggle{
    display:block;
  }
  .main-nav{
    position:absolute;
    left:17px;
    right:17px;
    top:84px;
    flex-direction:column;
    align-items:stretch;
    padding:16px;
    border-radius:24px;
    background:rgba(3,9,20,.96);
    border:1px solid var(--border);
    box-shadow:var(--shadow);
  }
  .main-nav.open{
    display:flex;
  }
  .main-nav a{
    padding:14px 16px;
    font-size:15px;
  }
  .hero-grid,
  .feature-grid,
  .cta-grid{
    grid-template-columns:1fr;
  }
  .hero{
    min-height:auto !important;
    padding-top:68px !important;
    padding-bottom:74px !important;
  }
  .hero-copy{
    text-align:left;
  }
  .hero h1{
    font-size:46px !important;
    max-width:760px !important;
  }
  .hero p{
    max-width:720px !important;
    font-size:16.5px !important;
  }
  .hero-proof{
    grid-template-columns:repeat(3,1fr);
    max-width:720px !important;
  }
  .hero-visual{
    min-height:auto !important;
  }
  .browser-card{
    min-height:360px !important;
  }
  .card-a,.card-b,.card-c{
    display:flex;
  }
  .service-grid,
  .plans-grid,
  .project-grid-six,
  .process-timeline{
    grid-template-columns:1fr 1fr;
  }
  .plan-card.featured{
    transform:none;
  }
  .footer-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media(max-width:720px){
  .container,
  .nav-shell{
    width:min(100% - 30px, var(--max));
  }
  .nav-shell{
    height:72px;
  }
  .brand-logo img{
    width:132px;
    max-height:45px;
  }
  .nav-cta{
    display:none;
  }
  .main-nav{
    top:78px;
  }
  .section{
    padding:72px 0;
  }
  .hero{
    padding-top:52px !important;
    padding-bottom:62px !important;
  }
  .eyebrow{
    font-size:12px;
    padding:8px 13px;
  }
  .hero h1{
    font-size:34px !important;
    line-height:1.04 !important;
    letter-spacing:-.045em !important;
    max-width:100% !important;
  }
  .hero h1::after{
    width:78px;
    height:4px;
    margin-top:16px;
  }
  .hero p{
    font-size:15px !important;
    line-height:1.58 !important;
  }
  .hero-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:10px;
    margin-top:22px !important;
  }
  .btn{
    width:100%;
    min-height:48px !important;
  }
  .hero-proof{
    grid-template-columns:1fr;
    gap:10px !important;
  }
  .hero-proof div{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
  }
  .hero-proof span{
    text-align:right;
  }
  .browser-card{
    min-height:auto !important;
    border-radius:26px;
  }
  .browser-top{
    height:46px !important;
    padding:0 18px !important;
  }
  .premium-browser{
    display:block !important;
    padding:18px !important;
  }
  .browser-sidebar{
    display:none !important;
  }
  .browser-main,
  .browser-main-top,
  .browser-main-bottom{
    display:grid;
    grid-template-columns:1fr !important;
    gap:12px;
  }
  .dash-right{
    display:block;
    min-height:190px !important;
  }
  .chart{
    height:104px !important;
  }
  .mini-grid{
    grid-template-columns:1fr 1fr;
  }
  .floating-card{
    display:none !important;
  }
  .section-head{
    margin-bottom:38px;
  }
  .section-head h2,
  .feature-copy h2,
  .cta-section h2{
    font-size:34px;
    line-height:1.06;
    letter-spacing:-.045em;
  }
  .section-head p,
  .feature-copy p,
  .cta-section p{
    font-size:15.5px;
  }
  .service-grid,
  .plans-grid,
  .project-grid-six,
  .process-timeline,
  .footer-grid{
    grid-template-columns:1fr;
  }
  .service-card,
  .plan-card,
  .project-card,
  .step{
    min-height:auto;
    padding:24px;
  }
  .service-card p,
  .project-card p{
    min-height:auto;
  }
  .feature-modules{
    grid-template-columns:1fr;
  }
  .feature-secondary{
    margin-left:0;
  }
  .system-panel{
    padding:22px;
    border-radius:28px;
  }
  .panel-kpis{
    grid-template-columns:1fr;
  }
  .panel-body{
    grid-template-columns:1fr;
  }
  .line-chart,
  .tasks{
    height:170px;
  }
  .table-head,
  .table-row{
    align-items:flex-start;
    flex-direction:column;
    gap:6px;
  }
  .projects-cta{
    padding:24px;
    border-radius:26px;
  }
  .projects-cta h3{
    font-size:22px;
  }
  .cta-section{
    padding:78px 0;
  }
  .contact-card{
    padding:22px;
    border-radius:26px;
  }
  .contact-row strong{
    font-size:16px;
    word-break:break-word;
  }
  .footer{
    padding:62px 0 110px;
  }
  .footer-bottom{
    flex-direction:column;
    margin-top:36px;
  }
  .whatsapp-float{
    left:15px;
    right:15px;
    bottom:15px;
    text-align:center;
    display:flex;
    justify-content:center;
  }
}

@media(max-width:420px){
  .hero h1{
    font-size:31px !important;
  }
  .section-head h2,
  .feature-copy h2,
  .cta-section h2{
    font-size:30px;
  }
  .brand-logo img{
    width:118px;
  }
}


/* V12 MOBILE UX: menos técnico, más claro y más atractivo en celular */
.mobile-guide{
  display:none;
}

@media(max-width:720px){
  /* En móvil reducimos complejidad visual y palabras técnicas */
  .hero{
    padding-top:44px !important;
    padding-bottom:46px !important;
  }

  .hero h1{
    font-size:32px !important;
    line-height:1.06 !important;
    letter-spacing:-.04em !important;
    margin-bottom:14px !important;
  }

  .hero p{
    font-size:14.8px !important;
    line-height:1.56 !important;
  }

  .hero-actions{
    margin-top:18px !important;
  }

  .hero-proof{
    margin-top:18px !important;
    display:grid !important;
    grid-template-columns:1fr;
  }

  .hero-proof div{
    padding:12px 14px !important;
    border-radius:18px !important;
    background:rgba(255,255,255,.055);
  }

  .hero-proof strong{
    font-size:15px !important;
  }

  .hero-proof span{
    font-size:12px !important;
    color:#d7e9f8;
  }

  /* El mockup en móvil no debe competir con el mensaje */
  .hero-visual{
    margin-top:6px;
  }

  .browser-card{
    min-height:auto !important;
    opacity:.92;
  }

  .browser-content.premium-browser{
    padding:15px !important;
  }

  .metric-card{
    min-height:auto !important;
    padding:16px !important;
  }

  .metric-card strong{
    font-size:28px !important;
  }

  .kpi-stack,
  .mini-grid,
  .dash-right{
    display:none !important;
  }

  .mobile-guide{
    display:block;
    padding:52px 0 34px;
    background:
      radial-gradient(circle at 10% 0%, rgba(18,216,255,.10), transparent 32%),
      linear-gradient(180deg, rgba(255,255,255,.015), rgba(255,255,255,0));
  }

  .mobile-guide h2{
    margin:16px 0 22px;
    font-size:28px;
    line-height:1.08;
    letter-spacing:-.04em;
  }

  .mobile-guide-grid{
    display:grid;
    gap:12px;
  }

  .mobile-guide-grid a{
    display:block;
    padding:18px;
    border-radius:22px;
    background:
      linear-gradient(180deg,rgba(255,255,255,.078),rgba(255,255,255,.034)),
      linear-gradient(135deg,rgba(18,216,255,.05),rgba(109,77,255,.04));
    border:1px solid rgba(255,255,255,.11);
    box-shadow:0 18px 50px rgba(0,0,0,.18);
  }

  .mobile-guide-grid strong{
    display:block;
    color:#fff;
    font-size:17px;
    margin-bottom:5px;
  }

  .mobile-guide-grid span{
    display:block;
    color:var(--muted);
    font-size:13px;
    line-height:1.45;
  }

  /* Servicios: más simples en móvil */
  .services{
    padding-top:54px !important;
  }

  .services .section-head h2{
    font-size:30px;
  }

  .service-card{
    padding:22px !important;
  }

  .service-card h3{
    font-size:21px;
  }

  .service-card p{
    font-size:14.5px;
    line-height:1.55;
  }

  .mini-bullets{
    display:none;
  }

  .service-card a{
    padding-top:18px;
  }
}

@media(max-width:420px){
  .hero h1{
    font-size:30px !important;
  }
  .mobile-guide h2{
    font-size:26px;
  }
}


/* V13 MOBILE DIAGRAMACIÓN: menos chorro, más ritmo visual */
.mobile-section-hint{
  display:none;
}

@media(max-width:720px){
  /* estructura general más aireada y fácil de escanear */
  .section{
    padding:58px 0;
  }

  .section-head{
    text-align:left;
    margin:0 0 26px;
    max-width:100%;
  }

  .section-head h2,
  .feature-copy h2,
  .cta-copy h2,
  .mobile-guide h2{
    font-size:28px !important;
    line-height:1.08 !important;
    letter-spacing:-.04em !important;
    margin:14px 0 12px !important;
  }

  .section-head p,
  .feature-copy p,
  .cta-copy p,
  .mobile-guide-grid span{
    font-size:14.5px !important;
    line-height:1.55 !important;
  }

  .mobile-guide{
    padding:32px 0 20px;
  }

  .mobile-guide-grid{
    gap:10px;
  }

  .mobile-guide-grid a{
    padding:16px;
    border-radius:18px;
  }

  .mobile-guide-grid strong{
    font-size:16px;
  }

  .mobile-section-hint{
    display:flex;
    margin:0 0 12px;
  }

  .mobile-section-hint span{
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:8px 12px;
    border-radius:999px;
    background:rgba(255,255,255,.055);
    border:1px solid rgba(255,255,255,.10);
    color:#d8ecff;
    font-size:12px;
    font-weight:800;
  }

  .mobile-section-hint span::before{
    content:'↔';
    color:var(--cyan);
    font-size:13px;
  }

  /* grids a modo slider horizontal */
  .service-grid,
  .plans-grid,
  .project-grid-six{
    display:grid !important;
    grid-auto-flow:column;
    grid-auto-columns:84%;
    gap:14px;
    overflow-x:auto;
    overscroll-behavior-x:contain;
    scroll-snap-type:x mandatory;
    padding:2px 2px 12px;
    margin-right:-15px;
    scrollbar-width:none;
  }

  .service-grid::-webkit-scrollbar,
  .plans-grid::-webkit-scrollbar,
  .project-grid-six::-webkit-scrollbar{
    display:none;
  }

  .service-grid > *,
  .plans-grid > *,
  .project-grid-six > *{
    scroll-snap-align:start;
  }

  .service-card,
  .plan-card,
  .project-card{
    min-height:auto !important;
    padding:22px !important;
    border-radius:24px;
  }

  .service-card p,
  .plan-card p,
  .project-card p{
    min-height:auto !important;
  }

  .service-card::after{
    inset:auto 20px 0 20px;
  }

  .service-card h3,
  .plan-card h3,
  .project-card h3{
    font-size:22px !important;
    line-height:1.16;
  }

  .feature{
    padding-top:44px !important;
  }

  .feature-grid{
    gap:24px;
  }

  .feature-list.feature-modules{
    display:grid !important;
    grid-auto-flow:column;
    grid-auto-columns:68%;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    gap:10px;
    padding-bottom:8px;
    scrollbar-width:none;
  }

  .feature-list.feature-modules::-webkit-scrollbar{
    display:none;
  }

  .feature-list.feature-modules span{
    scroll-snap-align:start;
    min-height:72px;
  }

  .feature-copy .btn{
    width:100%;
  }

  .feature-secondary{
    margin-top:10px;
  }

  .plans{
    padding-top:44px !important;
  }

  .plan-card.featured{
    transform:none !important;
  }

  .plans-note{
    margin-top:18px;
    padding:15px 16px;
    border-radius:18px;
    font-size:13px;
    text-align:left;
  }

  .projects{
    padding-top:46px !important;
  }

  .project-thumb{
    height:150px;
    margin-bottom:18px;
  }

  .project-points{
    margin-top:16px;
  }

  .project-card a{
    padding-top:18px;
  }

  .projects-cta{
    margin-top:20px;
    padding:20px;
    border-radius:22px;
  }

  .projects-cta h3{
    font-size:20px;
    line-height:1.3;
  }

  .process{
    padding-top:48px !important;
  }

  .process-timeline{
    gap:14px;
  }

  .step{
    padding:20px !important;
    border-radius:22px;
  }

  .step b{
    width:44px;
    height:44px;
    font-size:16px;
    margin-bottom:16px;
  }

  .step h3{
    font-size:20px;
    margin-bottom:10px;
  }

  .cta-section{
    padding:58px 0 72px !important;
    text-align:left;
  }

  .cta-grid{
    gap:18px;
  }

  .contact-card{
    padding:20px;
  }

  .contact-row{
    padding:14px 0;
  }

  .footer{
    padding-top:52px;
  }

  .footer-grid{
    gap:24px;
  }

  .footer h4{
    margin-bottom:10px;
  }
}


/* V14 MOBILE FIXES: anchos consistentes, mejor márgenes y WhatsApp tipo ícono */
.whatsapp-float{
  width:58px;
  height:58px;
  padding:0;
  border-radius:50%;
  display:grid;
  place-items:center;
  right:18px;
  left:auto;
  bottom:18px;
  background:#20df75;
  color:#031108;
}
.whatsapp-float svg{
  width:28px;
  height:28px;
  fill:currentColor;
}
.whatsapp-float:hover{
  transform:translateY(-4px) scale(1.03);
}

@media(max-width:720px){
  /* más margen lateral general */
  .container,
  .nav-shell{
    width:min(100% - 38px, var(--max)) !important;
  }

  .section,
  .mobile-guide,
  .cta-section{
    overflow:hidden;
  }

  .section{
    padding:56px 0 !important;
  }

  .hero{
    padding-top:40px !important;
    padding-bottom:42px !important;
  }

  .hero h1{
    font-size:30px !important;
    max-width:100% !important;
  }

  .hero p{
    font-size:14.5px !important;
    max-width:100% !important;
  }

  .mobile-guide{
    padding:28px 0 16px !important;
  }

  .services,
  .feature,
  .plans,
  .projects,
  .process{
    padding-top:42px !important;
  }

  .section-head{
    margin-bottom:20px !important;
  }

  .section-head h2,
  .feature-copy h2,
  .cta-copy h2{
    font-size:26px !important;
    margin:12px 0 10px !important;
  }

  .feature-copy p,
  .section-head p,
  .cta-copy p{
    font-size:14.5px !important;
    line-height:1.56 !important;
  }

  /* sliders horizontales con ancho consistente */
  .service-grid,
  .plans-grid,
  .project-grid-six{
    display:flex !important;
    flex-wrap:nowrap !important;
    gap:14px !important;
    overflow-x:auto !important;
    overflow-y:hidden !important;
    scroll-snap-type:x mandatory;
    padding:2px 0 10px !important;
    margin:0 !important;
    scrollbar-width:none;
  }

  .service-grid::-webkit-scrollbar,
  .plans-grid::-webkit-scrollbar,
  .project-grid-six::-webkit-scrollbar,
  .feature-list.feature-modules::-webkit-scrollbar{
    display:none;
  }

  .service-grid > .service-card,
  .plans-grid > .plan-card,
  .project-grid-six > .project-card{
    flex:0 0 86% !important;
    width:86% !important;
    max-width:86% !important;
    min-width:86% !important;
    scroll-snap-align:start;
    align-self:stretch;
  }

  .service-card,
  .plan-card,
  .project-card{
    min-height:auto !important;
    height:auto !important;
    padding:22px !important;
  }

  .service-card h3,
  .plan-card h3,
  .project-card h3{
    font-size:21px !important;
    line-height:1.16 !important;
  }

  .service-card p,
  .plan-card p,
  .project-card p{
    font-size:14.2px !important;
    line-height:1.55 !important;
    min-height:auto !important;
  }

  .service-card a,
  .plan-card .btn,
  .project-card a{
    margin-top:18px !important;
  }

  .plan-card .btn{
    width:100%;
  }

  /* sección SaaS más responsive */
  .feature-grid{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:18px !important;
  }

  .feature-list.feature-modules{
    display:flex !important;
    flex-wrap:nowrap !important;
    gap:10px !important;
    overflow-x:auto !important;
    overflow-y:hidden !important;
    scroll-snap-type:x mandatory;
    padding:2px 0 8px !important;
    margin:18px 0 14px !important;
    scrollbar-width:none;
  }

  .feature-list.feature-modules span{
    flex:0 0 74% !important;
    width:74% !important;
    max-width:74% !important;
    min-width:74% !important;
    scroll-snap-align:start;
    min-height:72px;
    padding:14px 14px !important;
    border-radius:18px !important;
  }

  .feature-copy .btn,
  .feature-copy .feature-secondary{
    width:100%;
    margin:0 !important;
  }

  .feature-copy .feature-secondary{
    margin-top:10px !important;
  }

  .system-panel{
    margin-top:2px;
    padding:20px !important;
    border-radius:24px !important;
  }

  .panel-header{
    margin-bottom:18px !important;
  }

  .panel-kpis{
    grid-template-columns:1fr !important;
    gap:10px !important;
  }

  .panel-kpis div{
    padding:14px !important;
    border-radius:16px !important;
  }

  .panel-body{
    grid-template-columns:1fr !important;
    gap:10px !important;
    margin-top:10px !important;
  }

  .line-chart,
  .tasks{
    height:150px !important;
    border-radius:18px !important;
  }

  .panel-table{
    margin-top:10px !important;
    border-radius:18px !important;
  }

  .table-head,
  .table-row{
    padding:12px 14px !important;
  }

  /* notas y CTA internos más compactos */
  .plans-note{
    margin-top:16px !important;
    padding:14px !important;
    border-radius:16px !important;
    font-size:13px !important;
  }

  .projects-cta{
    margin-top:16px !important;
    padding:18px !important;
    border-radius:20px !important;
  }

  .projects-cta h3{
    font-size:19px !important;
  }

  .process-timeline{
    grid-template-columns:1fr !important;
    gap:12px !important;
  }

  .step{
    padding:18px !important;
    border-radius:20px !important;
  }

  .step h3{
    font-size:19px !important;
  }

  .cta-grid{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }

  .contact-card{
    padding:18px !important;
    border-radius:22px !important;
  }

  .contact-row{
    padding:12px 0 !important;
  }

  .footer{
    padding:48px 0 94px !important;
  }

  .footer-grid{
    grid-template-columns:1fr !important;
    gap:20px !important;
  }

  .footer-bottom{
    margin-top:26px !important;
    padding-top:18px !important;
    flex-direction:column !important;
    gap:8px !important;
  }

  .whatsapp-float{
    width:54px;
    height:54px;
    right:14px;
    bottom:14px;
  }

  .whatsapp-float svg{
    width:26px;
    height:26px;
  }
}

@media(max-width:420px){
  .service-grid > .service-card,
  .plans-grid > .plan-card,
  .project-grid-six > .project-card{
    flex-basis:88% !important;
    width:88% !important;
    max-width:88% !important;
    min-width:88% !important;
  }

  .feature-list.feature-modules span{
    flex-basis:78% !important;
    width:78% !important;
    max-width:78% !important;
    min-width:78% !important;
  }

  .hero h1{
    font-size:28px !important;
  }
}


/* V15 MOBILE SISTEMAS FIX: corregir corte, anchos y jerarquía de la sección SaaS */
.feature-grid > *,
.service-grid > *,
.plans-grid > *,
.project-grid-six > *{
  min-width:0;
}

@media(max-width:720px){
  html, body{
    overflow-x:hidden;
  }

  .feature{
    padding-top:38px !important;
  }

  .feature-grid{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }

  .feature-copy,
  .system-panel{
    width:100%;
    max-width:100%;
    min-width:0;
  }

  .feature-copy .eyebrow{
    margin-bottom:8px;
  }

  .feature-copy h2{
    font-size:24px !important;
    line-height:1.10 !important;
    letter-spacing:-.035em !important;
    margin:10px 0 10px !important;
    max-width:100% !important;
    text-wrap:balance;
    overflow-wrap:anywhere;
  }

  .feature-copy p{
    font-size:14px !important;
    line-height:1.55 !important;
    max-width:100% !important;
    margin-bottom:14px !important;
  }

  .feature-list.feature-modules{
    margin:14px 0 12px !important;
  }

  .feature-list.feature-modules span{
    flex:0 0 72% !important;
    width:72% !important;
    max-width:72% !important;
    min-width:72% !important;
    min-height:68px !important;
    padding:13px 14px !important;
  }

  .feature-copy .btn,
  .feature-copy .feature-secondary{
    display:flex !important;
    width:100% !important;
    max-width:100% !important;
    justify-content:center;
    align-items:center;
    white-space:normal !important;
    text-align:center !important;
    line-height:1.22 !important;
    padding:14px 18px !important;
    min-height:50px !important;
  }

  .feature-copy .feature-secondary{
    margin-top:10px !important;
  }

  .system-panel{
    padding:18px !important;
    border-radius:22px !important;
    margin-top:2px !important;
  }

  .panel-header{
    margin-bottom:14px !important;
  }

  .panel-header b{
    font-size:14px;
  }

  .panel-kpis{
    gap:8px !important;
  }

  .panel-kpis div{
    padding:13px !important;
    border-radius:14px !important;
  }

  .panel-kpis strong{
    font-size:18px !important;
  }

  .panel-body{
    gap:8px !important;
    margin-top:8px !important;
  }

  .line-chart,
  .tasks{
    height:132px !important;
    border-radius:16px !important;
  }

  .panel-table{
    margin-top:8px !important;
  }

  .table-head,
  .table-row{
    padding:11px 12px !important;
  }

  .table-row span,
  .table-head b{
    font-size:14px;
  }

  .table-row em,
  .table-head small{
    font-size:12px;
  }
}

@media(max-width:420px){
  .feature-copy h2{
    font-size:22px !important;
  }

  .feature-list.feature-modules span{
    flex-basis:78% !important;
    width:78% !important;
    max-width:78% !important;
    min-width:78% !important;
  }
}


/* V16 VISUAL BOOST: más vida, profundidad y dinamismo visual */
.site-bg{
  background:
    radial-gradient(circle at 8% 10%, rgba(18,216,255,.12), transparent 22%),
    radial-gradient(circle at 88% 6%, rgba(109,77,255,.14), transparent 22%),
    radial-gradient(circle at 52% 48%, rgba(8,127,195,.07), transparent 28%),
    linear-gradient(180deg,#06101f 0%,#020713 58%,#01030a 100%);
}

.site-bg::after{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.08;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 120px 120px;
  mask-image: radial-gradient(circle at center, black, transparent 78%);
}

.hero{
  position:relative;
  overflow:hidden;
}

.hero-copy{
  position:relative;
}

.hero-copy::before{
  content:'';
  position:absolute;
  left:-26px;
  top:92px;
  width:2px;
  height:170px;
  border-radius:999px;
  background:linear-gradient(180deg, transparent, var(--cyan), var(--violet), transparent);
  opacity:.55;
}

.hero-copy::after{
  content:'';
  position:absolute;
  right:18px;
  bottom:14px;
  width:110px;
  height:110px;
  border-radius:28px;
  border:1px solid rgba(18,216,255,.12);
  transform:rotate(18deg);
  opacity:.34;
}

.hero-visual{
  position:relative;
  isolation:isolate;
}

.hero-visual::before{
  content:'';
  position:absolute;
  inset:12% 10% 12% 12%;
  border-radius:42px;
  background:
    radial-gradient(circle at 20% 20%, rgba(18,216,255,.20), transparent 32%),
    radial-gradient(circle at 80% 30%, rgba(109,77,255,.20), transparent 28%),
    radial-gradient(circle at 40% 80%, rgba(18,216,255,.10), transparent 32%);
  filter:blur(22px);
  z-index:-2;
  opacity:.95;
}

.hero-visual::after{
  content:'';
  position:absolute;
  right:6%;
  top:3%;
  width:160px;
  height:160px;
  border-radius:50%;
  border:1px dashed rgba(18,216,255,.18);
  opacity:.32;
  z-index:-1;
}

.hero-shape{
  position:absolute;
  pointer-events:none;
  z-index:0;
}
.hero-shape-a{
  right:10px;
  top:38px;
  width:64px;
  height:64px;
  border-radius:20px;
  border:1px solid rgba(18,216,255,.22);
  background:linear-gradient(135deg, rgba(18,216,255,.08), rgba(109,77,255,.06));
  box-shadow:0 16px 44px rgba(18,216,255,.14);
  transform:rotate(18deg);
}
.hero-shape-b{
  left:26px;
  bottom:44px;
  width:90px;
  height:90px;
  border-radius:50%;
  border:1px solid rgba(109,77,255,.20);
  box-shadow:inset 0 0 0 14px rgba(255,255,255,.025);
  opacity:.48;
}
.hero-shape-c{
  right:72px;
  bottom:28px;
  width:120px;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--cyan), transparent);
  box-shadow:0 0 24px rgba(18,216,255,.30);
  opacity:.72;
}

.browser-card{
  box-shadow:
    0 38px 100px rgba(0,0,0,.34),
    0 0 0 1px rgba(255,255,255,.05),
    0 0 90px rgba(18,216,255,.08);
}

.browser-card::before{
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.05),
    0 0 0 1px rgba(255,255,255,.03);
}

.metric-card.main,
.kpi-chip,
.dash-right,
.system-panel,
.plan-card,
.service-card,
.project-card,
.projects-cta,
.contact-card{
  box-shadow:
    0 24px 80px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.04);
}

.floating-card{
  backdrop-filter: blur(10px);
  border-color: rgba(255,255,255,.10);
}

.section{
  position:relative;
}

.section-head{
  position:relative;
}

.section-spark{
  position:absolute;
  right:0;
  top:4px;
  width:92px;
  height:92px;
  pointer-events:none;
  opacity:.65;
}
.section-spark::before,
.section-spark::after{
  content:'';
  position:absolute;
  inset:0;
}
.section-spark::before{
  width:92px;
  height:2px;
  top:44px;
  left:0;
  background:linear-gradient(90deg, transparent, var(--cyan), var(--violet), transparent);
  box-shadow:0 0 16px rgba(18,216,255,.22);
}
.section-spark::after{
  width:2px;
  height:92px;
  left:44px;
  top:0;
  background:linear-gradient(180deg, transparent, var(--cyan), var(--violet), transparent);
  box-shadow:0 0 16px rgba(18,216,255,.22);
}

.services::before,
.projects::before,
.plans::before,
.feature::before,
.process::before{
  content:'';
  position:absolute;
  pointer-events:none;
  inset:auto auto 16% 6%;
  width:180px;
  height:180px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(18,216,255,.08), transparent 70%);
  filter:blur(12px);
  opacity:.8;
}

.services::after,
.projects::after,
.plans::after{
  content:'';
  position:absolute;
  right:4%;
  top:12%;
  width:140px;
  height:140px;
  border-radius:32px;
  border:1px solid rgba(255,255,255,.05);
  transform:rotate(18deg);
  background:linear-gradient(135deg, rgba(18,216,255,.03), rgba(109,77,255,.04));
  opacity:.45;
  pointer-events:none;
}

.service-card,
.plan-card,
.project-card{
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  border-color:rgba(255,255,255,.11);
}

.service-card:hover,
.plan-card:hover,
.project-card:hover{
  transform:translateY(-6px);
  box-shadow:
    0 34px 90px rgba(0,0,0,.28),
    0 0 0 1px rgba(18,216,255,.08),
    0 0 46px rgba(18,216,255,.10);
}

.service-card .icon{
  box-shadow:0 18px 42px rgba(18,216,255,.16);
}

.service-card::before,
.plan-card::before,
.project-card::before{
  box-shadow:0 0 20px rgba(18,216,255,.16);
}

.project-thumb{
  position:relative;
  overflow:hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 20px 60px rgba(0,0,0,.16);
}

.project-thumb::before{
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.07),
    0 10px 30px rgba(0,0,0,.16);
}

.project-thumb::after{
  left:24px;
  right:24px;
  top:28px;
  border-radius:999px;
}

.project-thumb .mock-badge{
  display:none;
}

.project-card:nth-child(1) .project-thumb{
  background:
    radial-gradient(circle at 22% 20%, rgba(18,216,255,.28), transparent 32%),
    linear-gradient(135deg, rgba(8,127,195,.54), rgba(109,77,255,.18));
}
.project-card:nth-child(2) .project-thumb{
  background:
    radial-gradient(circle at 78% 16%, rgba(255,255,255,.10), transparent 28%),
    linear-gradient(135deg, rgba(109,77,255,.48), rgba(18,216,255,.18));
}
.project-card:nth-child(3) .project-thumb{
  background:
    radial-gradient(circle at 22% 78%, rgba(18,216,255,.22), transparent 32%),
    linear-gradient(135deg, rgba(8,127,195,.36), rgba(255,255,255,.04));
}
.project-card:nth-child(4) .project-thumb{
  background:
    radial-gradient(circle at 80% 20%, rgba(109,77,255,.28), transparent 32%),
    linear-gradient(135deg, rgba(53,32,116,.58), rgba(8,127,195,.18));
}
.project-card:nth-child(5) .project-thumb{
  background:
    radial-gradient(circle at 16% 20%, rgba(18,216,255,.26), transparent 32%),
    linear-gradient(135deg, rgba(8,127,195,.40), rgba(255,255,255,.05));
}
.project-card:nth-child(6) .project-thumb{
  background:
    radial-gradient(circle at 84% 28%, rgba(32,223,117,.16), transparent 32%),
    linear-gradient(135deg, rgba(18,216,255,.26), rgba(109,77,255,.20));
}

.system-panel{
  position:relative;
  overflow:hidden;
}
.system-panel::before{
  content:'';
  position:absolute;
  top:-36px;
  right:-36px;
  width:160px;
  height:160px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(18,216,255,.12), transparent 70%);
  filter:blur(10px);
  opacity:.85;
}
.system-panel::after{
  content:'';
  position:absolute;
  left:24px;
  right:24px;
  bottom:22px;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(18,216,255,.28), transparent);
}

.panel-kpis div{
  background:
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03)),
    linear-gradient(135deg, rgba(18,216,255,.04), rgba(109,77,255,.03));
  border:1px solid rgba(255,255,255,.08);
}

.feature-list.feature-modules span{
  box-shadow:0 14px 34px rgba(0,0,0,.12);
}

.plan-card.featured{
  background:
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.035)),
    radial-gradient(circle at 50% 0%, rgba(18,216,255,.12), transparent 44%),
    linear-gradient(135deg, rgba(18,216,255,.04), rgba(109,77,255,.04));
}

.projects-cta,
.cta-section{
  position:relative;
  overflow:hidden;
}

.projects-cta::before{
  content:'';
  position:absolute;
  left:-30px;
  top:-30px;
  width:120px;
  height:120px;
  border-radius:28px;
  background:linear-gradient(135deg, rgba(18,216,255,.08), rgba(109,77,255,.06));
  border:1px solid rgba(255,255,255,.05);
  transform:rotate(20deg);
  opacity:.55;
}

.cta-section::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 12% 30%, rgba(18,216,255,.10), transparent 24%),
    radial-gradient(circle at 88% 18%, rgba(109,77,255,.12), transparent 22%);
}

.cta-orb{
  position:absolute;
  pointer-events:none;
  border-radius:50%;
  filter:blur(8px);
  opacity:.8;
}
.cta-orb-a{
  width:180px;
  height:180px;
  left:6%;
  top:18%;
  background:radial-gradient(circle, rgba(18,216,255,.14), transparent 70%);
}
.cta-orb-b{
  width:220px;
  height:220px;
  right:4%;
  bottom:12%;
  background:radial-gradient(circle, rgba(109,77,255,.16), transparent 70%);
}

.contact-card{
  position:relative;
}
.contact-card::after{
  content:'';
  position:absolute;
  right:18px;
  top:18px;
  width:42px;
  height:42px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(135deg, rgba(18,216,255,.08), rgba(109,77,255,.06));
  transform:rotate(18deg);
  opacity:.65;
}

.footer{
  position:relative;
  overflow:hidden;
}
.footer::before{
  content:'';
  position:absolute;
  left:-60px;
  bottom:-40px;
  width:220px;
  height:220px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(18,216,255,.08), transparent 70%);
}
.footer::after{
  content:'';
  position:absolute;
  right:8%;
  top:14%;
  width:120px;
  height:120px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.05);
  transform:rotate(22deg);
  background:linear-gradient(135deg, rgba(18,216,255,.03), rgba(109,77,255,.05));
  opacity:.45;
}

@media(max-width:720px){
  .site-bg::after,
  .hero-copy::before,
  .hero-copy::after,
  .hero-visual::after,
  .hero-shape-a,
  .hero-shape-b,
  .section-spark,
  .services::after,
  .projects::after,
  .plans::after,
  .projects-cta::before,
  .contact-card::after,
  .footer::after{
    display:none;
  }

  .hero-visual::before{
    inset:10% 10% 12% 10%;
    opacity:.7;
  }

  .hero-shape-c{
    right:24px;
    bottom:18px;
    width:84px;
    opacity:.58;
  }

  .service-card,
  .plan-card,
  .project-card,
  .system-panel,
  .projects-cta,
  .contact-card{
    box-shadow:
      0 18px 48px rgba(0,0,0,.20),
      inset 0 1px 0 rgba(255,255,255,.04);
  }

  .service-card:hover,
  .plan-card:hover,
  .project-card:hover{
    transform:none;
  }

  .cta-orb-a{
    width:120px;
    height:120px;
  }

  .cta-orb-b{
    width:150px;
    height:150px;
  }
}


/* V17 HERO MOTION LIGHT: movimiento sutil y liviano */
.hero-motion{
  position:relative;
  overflow:hidden;
}

.hero-particles{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:0;
  opacity:.85;
}

.hero-wave{
  position:absolute;
  left:0;
  right:0;
  bottom:-8px;
  height:180px;
  pointer-events:none;
  z-index:0;
  opacity:.72;
  mix-blend-mode:screen;
  filter:blur(.2px);
  animation:heroWaveFloat 11s ease-in-out infinite alternate;
}

.hero-wave svg{
  width:100%;
  height:100%;
  display:block;
}

.hero .container,
.hero-copy,
.hero-visual{
  position:relative;
  z-index:1;
}

.hero::before{
  content:'';
  position:absolute;
  width:300px;
  height:300px;
  left:-70px;
  top:52px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(18,216,255,.16), transparent 68%);
  filter:blur(8px);
  animation:heroOrbFloatA 13s ease-in-out infinite;
  pointer-events:none;
}

.hero::after{
  content:'';
  position:absolute;
  width:360px;
  height:360px;
  right:-80px;
  top:18px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(109,77,255,.18), transparent 70%);
  filter:blur(10px);
  animation:heroOrbFloatB 16s ease-in-out infinite;
  pointer-events:none;
}

.hero-shape-a{
  animation:shapeDriftA 8s ease-in-out infinite;
}
.hero-shape-b{
  animation:shapeDriftB 10s ease-in-out infinite;
}
.hero-shape-c{
  animation:shapePulse 6s ease-in-out infinite;
}

.browser-card{
  animation:browserLift 7s ease-in-out infinite;
}

.floating-card.card-a{
  animation:floatCardA 7s ease-in-out infinite;
}
.floating-card.card-b{
  animation:floatCardB 8s ease-in-out infinite;
}
.floating-card.card-c{
  animation:floatCardC 9s ease-in-out infinite;
}

@keyframes heroWaveFloat{
  0%{transform:translateY(0) translateX(0) scaleX(1)}
  50%{transform:translateY(-6px) translateX(-8px) scaleX(1.01)}
  100%{transform:translateY(8px) translateX(6px) scaleX(.995)}
}
@keyframes heroOrbFloatA{
  0%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(12px,14px,0) scale(1.04)}
  100%{transform:translate3d(-6px,22px,0) scale(.98)}
}
@keyframes heroOrbFloatB{
  0%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(-18px,16px,0) scale(1.03)}
  100%{transform:translate3d(8px,26px,0) scale(.98)}
}
@keyframes shapeDriftA{
  0%{transform:rotate(18deg) translateY(0)}
  50%{transform:rotate(24deg) translateY(-8px)}
  100%{transform:rotate(16deg) translateY(6px)}
}
@keyframes shapeDriftB{
  0%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-10px) scale(1.03)}
  100%{transform:translateY(6px) scale(.98)}
}
@keyframes shapePulse{
  0%{opacity:.58; transform:scaleX(1)}
  50%{opacity:.9; transform:scaleX(1.08)}
  100%{opacity:.6; transform:scaleX(.98)}
}
@keyframes browserLift{
  0%{transform:translateY(0)}
  50%{transform:translateY(-4px)}
  100%{transform:translateY(0)}
}
@keyframes floatCardA{
  0%{transform:translateY(0)}
  50%{transform:translateY(-7px)}
  100%{transform:translateY(0)}
}
@keyframes floatCardB{
  0%{transform:translateY(0)}
  50%{transform:translateY(8px)}
  100%{transform:translateY(0)}
}
@keyframes floatCardC{
  0%{transform:translateY(0)}
  50%{transform:translateY(-5px)}
  100%{transform:translateY(0)}
}

@media(max-width:720px){
  .hero-wave{
    height:120px;
    opacity:.48;
  }

  .hero::before{
    width:170px;
    height:170px;
    top:40px;
    left:-50px;
  }

  .hero::after{
    width:220px;
    height:220px;
    right:-70px;
    top:10px;
  }

  .browser-card,
  .floating-card.card-a,
  .floating-card.card-b,
  .floating-card.card-c,
  .hero-shape-a,
  .hero-shape-b,
  .hero-shape-c{
    animation-duration:0s !important;
  }
}

@media (prefers-reduced-motion: reduce){
  .hero-wave,
  .hero::before,
  .hero::after,
  .hero-shape-a,
  .hero-shape-b,
  .hero-shape-c,
  .browser-card,
  .floating-card.card-a,
  .floating-card.card-b,
  .floating-card.card-c{
    animation:none !important;
  }
}


/* V18 VIDEO HERO: fondo de video liviano para el primer contenedor */
.hero-bg-video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  z-index:-3;
  opacity:.75;
  
  pointer-events:none;
}

.hero-video-overlay{
  position:absolute;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background:
    radial-gradient(circle at 12% 18%, rgba(18,216,255,.18), transparent 30%),
    radial-gradient(circle at 85% 12%, rgba(109,77,255,.18), transparent 28%),
    linear-gradient(90deg, rgba(2,7,19,.92) 0%, rgba(2,7,19,.70) 46%, rgba(2,7,19,.84) 100%),
    linear-gradient(180deg, rgba(2,7,19,.74), rgba(2,7,19,.92));
}

.hero-motion{
  isolation:isolate;
}

@media(max-width:720px){
  .hero-bg-video{
    opacity:.20;
    filter:saturate(1.02) contrast(1.05) brightness(.72);
  }

  .hero-video-overlay{
    background:
      radial-gradient(circle at 20% 12%, rgba(18,216,255,.12), transparent 32%),
      linear-gradient(180deg, rgba(2,7,19,.88), rgba(2,7,19,.94));
  }
}

@media (prefers-reduced-motion: reduce){
  .hero-bg-video{
    display:none;
  }
}


/* WordPress / WooCommerce compatibility */
.caska-page-content{
  padding:90px 0;
  color:var(--text);
  background:var(--bg);
}
.caska-page-content .entry-title{
  font-size:clamp(36px,4vw,62px);
  line-height:1.05;
  letter-spacing:-.05em;
  margin:0 0 24px;
}
.caska-page-content .entry-content{
  color:var(--muted2);
  line-height:1.75;
}
.woocommerce .products ul,
.woocommerce ul.products{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product{
  width:auto !important;
  float:none !important;
  padding:22px;
  border-radius:24px;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.10);
}
.woocommerce div.product,
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce,
.woocommerce-account .woocommerce{
  color:var(--text);
}
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit{
  border-radius:999px !important;
  background:linear-gradient(135deg,var(--blue),var(--blue2),var(--cyan)) !important;
  color:#fff !important;
  font-weight:900 !important;
}
@media(max-width:980px){
  .woocommerce .products ul,
  .woocommerce ul.products{
    grid-template-columns:repeat(2,1fr);
  }
}
@media(max-width:720px){
  .woocommerce .products ul,
  .woocommerce ul.products{
    grid-template-columns:1fr;
  }
}


/* =========================
   SEO + TYPOGRAPHY FIXES v1.2
   ========================= */
.text-gradient{
  display:inline-block;
  background:linear-gradient(135deg, #5de2ff 0%, #20c8ff 34%, #0ea5e9 66%, #0a5bca 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  text-shadow:none !important;
}

.hero-copy h1,
.section-head h2,
.mobile-guide h2,
.feature-copy h2,
.projects-cta h3,
.cta-box h2,
.plan-card h3,
.project-card h3,
.service-card h3,
.step h3{
  color:var(--text) !important;
}

.plan-card h3 .text-gradient,
.project-card h3 .text-gradient,
.service-card h3 .text-gradient,
.step h3 .text-gradient,
.hero-copy h1 .text-gradient,
.section-head h2 .text-gradient,
.mobile-guide h2 .text-gradient,
.feature-copy h2 .text-gradient,
.projects-cta h3 .text-gradient,
.cta-box h2 .text-gradient{
  color:transparent !important;
}

.plan-card p,
.project-card p,
.service-card p,
.step p,
.feature-copy p,
.section-head p,
.hero-copy p,
.mobile-guide-grid span,
.projects-cta p,
.cta-box p,
.note,
.note p{
  color:var(--muted2) !important;
}

.plan-card ul,
.plan-card li,
.project-card ul,
.project-card li,
.service-card ul,
.service-card li{
  color:#f4f8ff !important;
}

.plan-card li::marker,
.project-card li::marker,
.service-card li::marker{
  color:var(--cyan);
}

.plan-card a,
.project-card a,
.service-card a,
.projects-cta a,
.cta-box a{
  color:var(--cyan) !important;
  font-weight:900;
}

.plan-card .plan-label,
.project-card .project-tag,
.service-card .service-kicker,
.projects-cta span,
.feature-kicker,
.section-head .eyebrow,
.eyebrow{
  color:var(--cyan) !important;
}

.plan-card strong,
.project-card strong,
.service-card strong,
.step strong,
.note strong,
.projects-cta strong{
  color:#ffffff !important;
}

.step b{
  color:#031221;
  box-shadow:0 8px 30px rgba(18,216,255,.18);
}

button,
.button,
.btn,
.btn-secondary,
.btn-ghost,
input[type="submit"],
input[type="button"],
input[type="reset"]{
  color:#ffffff !important;
}

.process .step,
.projects-grid .project-card,
.plans-grid .plan-card,
.service-grid .service-card{
  backdrop-filter: blur(10px);
}

.project-card h3,
.plan-card h3,
.step h3{
  font-size:clamp(26px, 2vw, 34px);
  line-height:1.15;
}

@media (max-width: 980px){
  .project-card h3,
  .plan-card h3,
  .step h3{
    font-size:clamp(23px, 5vw, 30px);
  }
}

@media (max-width: 720px){
  .hero-copy h1 .text-gradient,
  .section-head h2 .text-gradient{
    display:inline;
  }
}


/* =========================
   ELEMENTOR EDITABLE HOME v1.3
   Mantiene el diseño exacto dentro de Elementor.
   ========================= */
.caska-elementor-home{
  background:var(--bg);
  color:var(--text);
  overflow:hidden;
}

.caska-elementor-home .elementor-section.caska-import-section{
  padding:0 !important;
  margin:0 !important;
  background:transparent !important;
}

.caska-elementor-home .elementor-section.caska-import-section > .elementor-container{
  max-width:none !important;
  width:100% !important;
  min-height:0 !important;
}

.caska-elementor-home .elementor-section.caska-import-section .elementor-column,
.caska-elementor-home .elementor-section.caska-import-section .elementor-widget-wrap{
  padding:0 !important;
  margin:0 !important;
  display:block !important;
  width:100% !important;
}

.caska-elementor-home .elementor-widget-html,
.caska-elementor-home .elementor-widget-html .elementor-widget-container{
  margin:0 !important;
  padding:0 !important;
  width:100% !important;
}

.caska-elementor-home section{
  margin:0;
}

/* Evita que Elementor agregue espacios visuales no deseados */
.caska-elementor-home .elementor-section-wrap,
.caska-elementor-home .elementor{
  background:transparent !important;
}

/* En el editor, las secciones HTML siguen visibles sin romper márgenes */
.elementor-editor-active .caska-elementor-home .caska-import-section{
  outline:1px dashed rgba(18,216,255,.18);
}

/* Textos seguros dentro de Elementor */
.caska-elementor-home h1,
.caska-elementor-home h2,
.caska-elementor-home h3,
.caska-elementor-home h4,
.caska-elementor-home h5,
.caska-elementor-home h6{
  color:#fff;
}

.caska-elementor-home p,
.caska-elementor-home li,
.caska-elementor-home span{
  color:inherit;
}

/* Elementor full width template */
.caska-elementor-content{
  background:var(--bg);
  color:var(--text);
  min-height:60vh;
}
