: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;
  }
}


/* V19 HERO VIDEO OPTIMIZADO: partículas canvas eliminadas para mejorar rendimiento */
.hero-motion{
  position:relative;
  overflow:hidden;
  contain:paint;
}


.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:.34;
  filter:saturate(1.08) contrast(1.08) brightness(.82);
  pointer-events:none;
  transform:translateZ(0);
  backface-visibility:hidden;
}

.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;
}


/* CASKA v1.3.2: identidad oficial, video externo y optimización visual */
.hero-proof-caska{
  grid-template-columns:repeat(5,minmax(0,1fr)) !important;
  max-width:760px !important;
}
.hero-proof-caska div{
  min-height:94px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-proof-caska strong{
  display:inline-grid !important;
  place-items:center;
  width:34px;
  height:34px;
  border-radius:12px;
  margin-bottom:8px;
  color:#06101f;
  background:linear-gradient(135deg,var(--cyan),#fff,var(--violet));
  box-shadow:0 14px 28px rgba(18,216,255,.18);
}
.hero-proof-caska span{
  text-align:left;
  line-height:1.25;
}
.hero-bg-video{
  opacity:.42;
  filter:saturate(1.08) contrast(1.06) brightness(.76);
}
.hero-video-overlay{
  background:
    radial-gradient(circle at 12% 18%, rgba(18,216,255,.16), transparent 30%),
    radial-gradient(circle at 85% 12%, rgba(109,77,255,.16), transparent 28%),
    linear-gradient(90deg, rgba(2,7,19,.94) 0%, rgba(2,7,19,.74) 46%, rgba(2,7,19,.88) 100%),
    linear-gradient(180deg, rgba(2,7,19,.72), rgba(2,7,19,.94));
}
.feature-list.feature-modules span b{
  font-size:22px;
}
@media(max-width:1050px){
  .hero-proof-caska{grid-template-columns:repeat(3,minmax(0,1fr)) !important;}
}
@media(max-width:720px){
  .hero-proof-caska{grid-template-columns:1fr !important;}
  .hero-proof-caska div{
    min-height:auto;
    flex-direction:row;
    justify-content:space-between;
  }
  .hero-proof-caska strong{margin-bottom:0;flex:0 0 auto;}
  .hero-proof-caska span{text-align:right;}
  .hero-bg-video{opacity:.26;}
}


/* ==========================================================
   CASKA v1.3.3 — SISTEMA VISUAL MADRE
   Base oficial para web, portal, cotizadores, dashboards y SaaS.
   Mantiene la estética dark premium y deja lista una versión light.
   ========================================================== */
:root{
  /* Marca oficial */
  --caska-bg-dark:#020713;
  --caska-bg-deep:#01040b;
  --caska-bg-navy:#06101f;
  --caska-panel-dark:#071020;
  --caska-card-dark:#0a1426;
  --caska-card-dark-2:#101b33;

  --caska-bg-light:#f4f7fb;
  --caska-surface:#ffffff;
  --caska-surface-soft:#eef5ff;

  --caska-text-dark:#ffffff;
  --caska-text-light:#101828;
  --caska-muted-dark:#b8c7dc;
  --caska-muted-light:#667085;

  --caska-cyan:#12d8ff;
  --caska-blue:#087fc3;
  --caska-blue-strong:#1d7bf2;
  --caska-violet:#6d4dff;
  --caska-green:#20df75;
  --caska-warning:#f59e0b;
  --caska-danger:#ef4444;

  --caska-border-dark:rgba(255,255,255,.12);
  --caska-border-light:rgba(16,24,40,.10);
  --caska-radius-sm:14px;
  --caska-radius-md:20px;
  --caska-radius-lg:28px;
  --caska-radius-xl:34px;
  --caska-shadow-dark:0 32px 90px rgba(0,0,0,.36);
  --caska-shadow-light:0 18px 50px rgba(16,24,40,.10);
  --caska-gradient-main:linear-gradient(135deg,var(--caska-violet) 0%,var(--caska-blue) 52%,var(--caska-cyan) 100%);
  --caska-gradient-soft:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.035));

  /* Aliases para que los sistemas actuales hereden la nueva línea */
  --bg:var(--caska-bg-dark);
  --bg2:var(--caska-bg-navy);
  --panel:var(--caska-panel-dark);
  --card:var(--caska-card-dark);
  --card2:var(--caska-card-dark-2);
  --text:var(--caska-text-dark);
  --muted:var(--caska-muted-dark);
  --muted2:#e8f2ff;
  --cyan:var(--caska-cyan);
  --blue:var(--caska-blue);
  --blue2:var(--caska-blue-strong);
  --violet:var(--caska-violet);
  --green:var(--caska-green);
  --border:var(--caska-border-dark);
  --shadow:var(--caska-shadow-dark);
  --radius:var(--caska-radius-lg);
}

body{
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* Fondos y secciones más consistentes */
.site-bg{
  background:
    radial-gradient(circle at 12% 8%, rgba(18,216,255,.16), transparent 30%),
    radial-gradient(circle at 88% 8%, rgba(109,77,255,.18), transparent 34%),
    linear-gradient(180deg,var(--caska-bg-navy) 0%,var(--caska-bg-dark) 58%,var(--caska-bg-deep) 100%) !important;
}
.section{
  isolation:isolate;
}
.section::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.015),transparent 55%,rgba(18,216,255,.018));
  z-index:-1;
}

/* Componentes reutilizables para futuras páginas y apps */
.caska-shell,
.caska-dashboard-shell{
  background:var(--caska-bg-light);
  color:var(--caska-text-light);
  border-radius:var(--caska-radius-xl);
  box-shadow:var(--caska-shadow-light);
}
.caska-panel-light,
.caska-card-light,
.caska-dashboard-card{
  background:var(--caska-surface);
  color:var(--caska-text-light);
  border:1px solid var(--caska-border-light);
  border-radius:var(--caska-radius-lg);
  box-shadow:var(--caska-shadow-light);
}
.caska-panel-dark,
.caska-card-dark{
  background:var(--caska-gradient-soft);
  color:var(--caska-text-dark);
  border:1px solid var(--caska-border-dark);
  border-radius:var(--caska-radius-lg);
  box-shadow:var(--caska-shadow-dark);
}
.caska-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 14px;
  border-radius:999px;
  background:rgba(18,216,255,.10);
  border:1px solid rgba(18,216,255,.22);
  color:var(--caska-cyan);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.caska-btn,
.btn-primary,
.nav-cta,
.whatsapp-float{
  background:var(--caska-gradient-main) !important;
  border:0;
  color:#fff !important;
  box-shadow:0 18px 50px rgba(29,123,242,.24) !important;
}
.caska-btn-outline,
.btn-ghost{
  background:rgba(255,255,255,.065) !important;
  border:1px solid rgba(255,255,255,.16) !important;
  color:#fff !important;
}
.caska-btn-light{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:14px 22px;
  border-radius:999px;
  background:var(--caska-gradient-main);
  color:#fff;
  font-weight:900;
  box-shadow:0 16px 38px rgba(29,123,242,.22);
}

/* Tarjetas principales más parejas */
.service-card,
.plan-card,
.project-card,
.step,
.system-panel,
.browser-card,
.hero-proof div,
.mobile-guide-grid a{
  border-color:rgba(255,255,255,.12) !important;
  box-shadow:0 22px 64px rgba(0,0,0,.20) !important;
}
.service-card,
.plan-card,
.project-card,
.step{
  min-height:100%;
  display:flex;
  flex-direction:column;
}
.service-card a,
.plan-card .btn,
.project-card a{
  margin-top:auto;
}
.icon,
.step b,
.hero-proof-caska strong{
  background:var(--caska-gradient-main) !important;
}
.text-gradient{
  background:linear-gradient(90deg,#ffffff 0%,var(--caska-cyan) 38%,#9ccfff 70%,var(--caska-violet) 100%) !important;
  -webkit-background-clip:text !important;
  background-clip:text !important;
  color:transparent !important;
}

/* Estándar de formularios/tablas para páginas futuras */
.caska-form input,
.caska-form select,
.caska-form textarea,
.caska-input{
  width:100%;
  border:1px solid var(--caska-border-light);
  border-radius:var(--caska-radius-sm);
  background:#fff;
  color:var(--caska-text-light);
  padding:13px 15px;
  outline:none;
  transition:border-color .18s ease, box-shadow .18s ease;
}
.caska-form input:focus,
.caska-form select:focus,
.caska-form textarea:focus,
.caska-input:focus{
  border-color:rgba(18,216,255,.68);
  box-shadow:0 0 0 4px rgba(18,216,255,.13);
}
.caska-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  border-radius:var(--caska-radius-md);
  border:1px solid var(--caska-border-light);
  background:#fff;
  color:var(--caska-text-light);
}
.caska-table th,
.caska-table td{
  padding:14px 16px;
  border-bottom:1px solid rgba(16,24,40,.08);
  text-align:left;
}
.caska-table th{
  background:#f8fbff;
  color:var(--caska-muted-light);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.caska-status{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(29,123,242,.10);
  color:var(--caska-blue-strong);
  font-size:12px;
  font-weight:900;
}

/* Performance: eliminar costos visuales innecesarios en móvil y accesibilidad */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.001ms !important;
  }
  .hero-bg-video{display:none !important;}
}

@media(max-width:760px){
  .caska-header{backdrop-filter:none;}
  .service-card,
  .plan-card,
  .project-card,
  .step,
  .system-panel,
  .browser-card,
  .hero-proof div,
  .mobile-guide-grid a{
    backdrop-filter:none !important;
    box-shadow:0 14px 34px rgba(0,0,0,.18) !important;
  }
  .hero-video-overlay{
    background:
      linear-gradient(180deg,rgba(2,7,19,.86),rgba(2,7,19,.96)),
      radial-gradient(circle at 50% 0%,rgba(18,216,255,.11),transparent 35%) !important;
  }
  .btn,
  .caska-btn,
  .caska-btn-light{
    width:100%;
    min-height:52px;
  }
}


/* =========================
   CASKA v1.3.4 — Ajustes finos: texto destacado + WhatsApp
   ========================= */
.text-gradient{
  background:linear-gradient(90deg,var(--caska-cyan) 0%,#24a7ff 46%,var(--caska-violet) 100%) !important;
  -webkit-background-clip:text !important;
  background-clip:text !important;
  -webkit-text-fill-color:transparent !important;
  color:transparent !important;
  text-shadow:none !important;
}

.whatsapp-float{
  width:58px !important;
  height:58px !important;
  padding:0 !important;
  border-radius:50% !important;
  display:grid !important;
  place-items:center !important;
  right:18px !important;
  left:auto !important;
  bottom:18px !important;
  background:#25D366 !important;
  background-color:#25D366 !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.18) !important;
  box-shadow:0 18px 46px rgba(37,211,102,.32) !important;
  overflow:hidden !important;
}
.whatsapp-float img,
.whatsapp-float svg{
  width:31px !important;
  height:31px !important;
  display:block !important;
  object-fit:contain !important;
  fill:#fff !important;
}
.whatsapp-float:hover{
  transform:translateY(-4px) scale(1.04) !important;
  box-shadow:0 22px 58px rgba(37,211,102,.42) !important;
}

@media(max-width:720px){
  .whatsapp-float{
    width:54px !important;
    height:54px !important;
    right:14px !important;
    bottom:14px !important;
  }
  .whatsapp-float img,
  .whatsapp-float svg{
    width:29px !important;
    height:29px !important;
  }
}


/* =========================
   CASKA v1.3.5 — Performance boost desktop + móvil
   ========================= */
html{scroll-behavior:auto;}
body{font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;}
img,svg,video{max-width:100%;}
.hero-bg-video{content-visibility:auto;contain:layout paint;}
.section.services,
.section.systems,
.section.pricing,
.section.projects,
.section.process,
.cta-section,
.mobile-guide,
.footer{
  content-visibility:auto;
  contain-intrinsic-size:1px 760px;
}
.service-card,
.plan-card,
.project-card,
.step,
.system-panel,
.contact-card,
.browser-card{
  contain:layout paint style;
}
.reveal{will-change:auto;}
.reveal.visible{will-change:auto;}
.hero-wave,
.hero-glow,
.hero-shape,
.floating-card,
.browser-card{
  will-change:auto;
}
@media(max-width:767px){
  .hero-bg-video{display:none !important;}
  .hero-wave,
  .hero-glow,
  .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;
  }
  .caska-header,
  .eyebrow,
  .hero-proof div,
  .service-card,
  .plan-card,
  .project-card,
  .step,
  .system-panel,
  .browser-card,
  .contact-card{
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }
  .service-card:hover,
  .plan-card:hover,
  .project-card:hover,
  .btn:hover,
  .whatsapp-float:hover{
    transform:none !important;
  }
  .reveal,
  .reveal.visible{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
  }
}
@media (prefers-reduced-motion: reduce){
  .hero-bg-video{display:none !important;}
}


/* =========================================================
 * CASKA v1.3.6 PERFORMANCE EXTRA
 * Objetivo: evitar pegones por animaciones infinitas, blur,
 * filtros y sombras pesadas, especialmente en móvil.
 * ========================================================= */
:root{
  --shadow: 0 14px 34px rgba(0,0,0,.18);
}
html{scroll-behavior:auto;}

/* Las animaciones infinitas del hero se dejan quietas para reducir uso de GPU/CPU */
.hero-wave,
.hero-orb,
.hero-shape,
.browser-card,
.floating-card{
  animation:none !important;
}

/* Evita que el navegador calcule/pinte secciones fuera de pantalla */
.section,
.mobile-guide,
.feature,
.plans,
.projects,
.process,
.cta-section,
.site-footer{
  content-visibility:auto;
  contain-intrinsic-size: 1px 900px;
}

/* Reduce costos de filtros/backdrop sin cambiar el diseño base */
.site-header,
.mobile-guide a,
.browser-card,
.system-panel,
.service-card,
.plan-card,
.project-card,
.contact-card,
.cta-section,
.footer-card{
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}

.hero-bg-video{
  will-change:auto !important;
  transform:none !important;
  filter:brightness(.78) contrast(1.03) !important;
}

/* Menos sombras costosas en tarjetas grandes */
.service-card,
.plan-card,
.project-card,
.system-panel,
.browser-card,
.contact-card,
.footer-card{
  box-shadow:0 14px 34px rgba(0,0,0,.18) !important;
}

@media (max-width: 767px){
  html, body{
    scroll-behavior:auto !important;
    overscroll-behavior-y:auto;
  }

  /* En móvil el video del hero no aporta al rendimiento: se oculta por completo */
  .hero-bg-video,
  .hero-video-overlay{
    display:none !important;
  }

  /* Se eliminan decoraciones que más pegan el scroll en celular */
  .hero-glow,
  .hero-wave,
  .hero-orb,
  .hero-shape,
  .section-spark,
  .cta-orb,
  .floating-card{
    display:none !important;
  }

  .reveal,
  .reveal.visible,
  .delay-1,
  .delay-2,
  .delay-3{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
    transition-delay:0s !important;
  }

  .btn:hover,
  .service-card:hover,
  .plan-card:hover,
  .project-card:hover,
  .whatsapp-float:hover{
    transform:none !important;
  }

  .site-header,
  .service-card,
  .plan-card,
  .project-card,
  .system-panel,
  .browser-card,
  .contact-card,
  .mobile-guide a{
    box-shadow:0 8px 22px rgba(0,0,0,.14) !important;
    filter:none !important;
  }
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation:none !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }
}

/* =========================================================
   CASKA v1.3.7 - Visual System + Image Ready
   Imágenes WebP optimizadas, interfaz tipo dashboard premium.
   ========================================================= */
.visual-frame{
  position:relative;
  margin:0;
  border-radius:30px;
  overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.025));
  border:1px solid rgba(55,205,255,.18);
  box-shadow:0 26px 70px rgba(0,0,0,.34),0 0 0 1px rgba(255,255,255,.04) inset;
  transform:translateZ(0);
  isolation:isolate;
}
.visual-frame::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(18,216,255,.18),transparent 35%,rgba(109,77,255,.14));
  pointer-events:none;
  opacity:.62;
}
.visual-frame img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  transform:translateZ(0);
}
.hero-image-card{
  min-height:420px;
  aspect-ratio:16/9;
}
.hero-visual{display:flex;align-items:center;justify-content:center;min-height:430px}
.hero .floating-card{backdrop-filter:none;background:rgba(5,12,28,.88);border-color:rgba(18,216,255,.20)}
.service-card{overflow:hidden}
.service-visual-thumb{
  margin:-4px -4px 20px;
  aspect-ratio:16/10;
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(18,216,255,.16);
  background:#071020;
}
.service-visual-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.ux-premium{background:radial-gradient(circle at 15% 20%,rgba(18,216,255,.10),transparent 36%),radial-gradient(circle at 85% 50%,rgba(109,77,255,.12),transparent 38%)}
.ux-premium-grid{display:grid;grid-template-columns:.86fr 1.14fr;gap:46px;align-items:center}
.ux-copy p{color:var(--muted2);font-size:18px;line-height:1.72;max-width:620px}
.ux-pills{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:26px 0 28px;max-width:650px}
.ux-pills span{
  padding:15px 12px;
  text-align:center;
  border-radius:18px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(18,216,255,.18);
  color:#fff;
  font-weight:800;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.ux-image{aspect-ratio:3/2;min-height:430px}
.visual-system-panel{padding:0;background:transparent;border:0;box-shadow:none;min-height:auto}
.system-image{aspect-ratio:3/2;min-height:430px}
.project-thumb{position:relative;overflow:hidden;background:#071020}
.project-thumb img{width:100%;height:100%;object-fit:cover;display:block;opacity:.88;filter:saturate(1.05) contrast(1.03)}
.project-card:hover .project-thumb img{opacity:1;transform:scale(1.04)}
.project-thumb img{transition:transform .35s ease,opacity .35s ease}
.cta-grid{align-items:center}
.contact-visual{aspect-ratio:3/2;min-height:330px}
.contact-card{position:relative;z-index:2}

/* Reducir costo visual en móvil sin perder look premium */
@media (max-width: 960px){
  .ux-premium-grid{grid-template-columns:1fr;gap:28px}
  .ux-image,.system-image,.hero-image-card{min-height:auto}
  .ux-pills{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero-visual{min-height:auto}
}
@media (max-width: 768px){
  html{scroll-behavior:auto}
  .visual-frame{border-radius:24px;box-shadow:0 18px 42px rgba(0,0,0,.28)}
  .hero-image-card{aspect-ratio:4/3}
  .service-visual-thumb{aspect-ratio:16/11;margin-bottom:16px}
  .ux-copy p{font-size:16px}
  .ux-pills span{padding:13px 10px;font-size:13px}
  .contact-visual{min-height:auto}
  .cta-grid{gap:24px}
}

/* =========================================================
   CASKA v1.3.8 - VISUAL SYSTEM PERFORMANCE MOUNT
   Objetivo: montar la página con imágenes WebP y eliminar consumo alto.
   ========================================================= */

.hero-static-bg{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(5,10,24,.96) 0%, rgba(5,10,24,.82) 46%, rgba(5,10,24,.58) 100%),
    url('../img/visuals/01-ecosistema-digital.webp') right center/cover no-repeat;
  opacity:.72;
  pointer-events:none;
}

.hero-bg-video{display:none!important;visibility:hidden!important}
.hero-motion .hero-wave,
.hero-motion .hero-glow,
.hero-motion .hero-shape,
.cta-orb,
.section-spark{
  animation:none!important;
  filter:none!important;
}

.hero-wave{opacity:.32!important}
.hero-glow{opacity:.28!important;filter:none!important}
.hero-shape{opacity:.18!important;filter:none!important}
.floating-card{animation:none!important;transform:none!important}
.hero-image-card,
.visual-frame,
.service-card,
.project-card,
.plan-card,
.step,
.contact-card,
.system-panel{
  will-change:auto!important;
}

.hero-image-card img,
.service-visual-thumb img,
.project-thumb img,
.ux-image img,
.system-image img,
.contact-visual img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

.service-visual-thumb img,
.project-thumb img{
  object-position:72% center;
}
.image-focus-right img{object-position:78% center!important}
.image-focus-center img{object-position:center center!important}

.service-visual-thumb,
.project-thumb,
.visual-frame{
  background:linear-gradient(135deg, rgba(12,20,45,.96), rgba(5,10,22,.96));
}

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

.service-card,
.project-card,
.plan-card,
.contact-card,
.system-panel,
.visual-frame{
  box-shadow:0 12px 32px rgba(0,0,0,.24)!important;
  backdrop-filter:none!important;
}

.reveal{
  transition:opacity .38s ease, transform .38s ease!important;
}

@media (max-width: 767px){
  html{scroll-behavior:auto!important}
  .hero-static-bg{
    background:
      linear-gradient(180deg, rgba(5,10,24,.98) 0%, rgba(5,10,24,.9) 50%, rgba(5,10,24,.98) 100%),
      url('../img/visuals/01-ecosistema-digital.webp') center top/cover no-repeat;
    opacity:.45;
  }
  .hero-motion .hero-wave,
  .hero-motion .hero-glow,
  .hero-motion .hero-shape,
  .floating-card,
  .cta-orb,
  .section-spark{
    display:none!important;
  }
  .reveal{
    opacity:1!important;
    transform:none!important;
    transition:none!important;
  }
  .service-card,
  .project-card,
  .plan-card,
  .contact-card,
  .system-panel,
  .visual-frame{
    box-shadow:0 8px 22px rgba(0,0,0,.2)!important;
  }
  .service-visual-thumb img,
  .project-thumb img,
  .image-focus-right img{
    object-position:72% center!important;
  }
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation:none!important;
    transition:none!important;
    scroll-behavior:auto!important;
  }
}

/* =========================================================
 * CASKA v1.3.9 - Dashboard UI System
 * Rediseño visual inspirado en arquitectura dashboard.
 * Animaciones decorativas pesadas eliminadas/reducidas.
 * ========================================================= */
:root{
  --caska-bg:#050B16;
  --caska-bg-soft:#07111F;
  --caska-panel:rgba(255,255,255,.045);
  --caska-panel-strong:rgba(255,255,255,.075);
  --caska-border:rgba(0,212,255,.18);
  --caska-border-soft:rgba(255,255,255,.10);
  --caska-text:#F5F8FF;
  --caska-muted:#A8B5C8;
  --caska-blue:#2F7BFF;
  --caska-cyan:#00D4FF;
  --caska-purple:#7C5CFF;
  --caska-green:#18E6A7;
}
html{scroll-behavior:auto;}
body.caska-home{background:var(--caska-bg);}
.site-bg{
  background:
    radial-gradient(circle at 12% 8%, rgba(0,212,255,.13), transparent 30%),
    radial-gradient(circle at 88% 10%, rgba(124,92,255,.13), transparent 34%),
    linear-gradient(180deg,#050B16 0%,#06101F 46%,#020713 100%);
}
.caska-v139{background:transparent;color:var(--caska-text);overflow:hidden;}
.caska-v139 .section{padding:104px 0;content-visibility:auto;contain-intrinsic-size:900px;}
.caska-v139 .text-gradient{
  background:linear-gradient(90deg,var(--caska-cyan),var(--caska-blue),var(--caska-purple));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.caska-v139 img{max-width:100%;height:auto;display:block;}
.caska-header{background:rgba(5,11,22,.84);backdrop-filter:blur(12px);}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:linear-gradient(135deg,var(--caska-purple),var(--caska-blue) 55%,var(--caska-cyan));box-shadow:0 18px 44px rgba(47,123,255,.22);}
.btn-ghost{background:rgba(255,255,255,.055);border:1px solid var(--caska-border-soft);}
.eyebrow{background:rgba(0,212,255,.08);border-color:var(--caska-border);box-shadow:none;}

.v139-hero{min-height:calc(100vh - 78px);display:flex;align-items:center;padding:84px 0 86px!important;position:relative;overflow:hidden;content-visibility:visible!important;}
.v139-hero:before{content:'';position:absolute;inset:-20%;background:radial-gradient(circle at 75% 35%,rgba(0,212,255,.16),transparent 28%),radial-gradient(circle at 35% 70%,rgba(124,92,255,.11),transparent 32%);pointer-events:none;}
.v139-noise{position:absolute;inset:0;opacity:.06;background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:48px 48px;mask-image:linear-gradient(180deg,#000,transparent 85%);}
.v139-hero-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:68px;align-items:center;position:relative;z-index:2;}
.v139-hero-copy h1{font-size:clamp(44px,5vw,76px);line-height:1.01;letter-spacing:-.065em;margin:20px 0 18px;max-width:780px;}
.v139-hero-copy p{font-size:18px;line-height:1.7;color:var(--caska-muted);max-width:690px;margin:0;}
.v139-hero-widgets{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:28px;}
.v139-hero-widgets article,.v139-widget,.v139-core-card,.v139-module,.v139-service-card,.v139-mini-grid article,.v139-flow-grid article,.v139-kpi-grid article,.v139-process-grid article,.v139-portfolio-grid article,.v139-contact-panel article{
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.032));
  border:1px solid var(--caska-border-soft);
  border-radius:24px;
  box-shadow:0 18px 50px rgba(0,0,0,.20);
}
.v139-hero-widgets article{padding:15px 14px;}
.v139-hero-widgets b{display:grid;place-items:center;width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,var(--caska-blue),var(--caska-cyan));font-weight:950;color:#fff;margin-bottom:10px;}
.v139-hero-widgets span{display:block;color:var(--caska-muted);font-size:12px;font-weight:700;}
.v139-hero-visual{position:relative;min-height:520px;display:grid;place-items:center;}
.v139-main-visual{margin:0;border-radius:34px;overflow:hidden;border:1px solid var(--caska-border);background:rgba(255,255,255,.05);box-shadow:0 36px 90px rgba(0,0,0,.35),0 0 70px rgba(0,212,255,.08);}
.v139-main-visual img{width:100%;aspect-ratio:16/9;object-fit:cover;}
.v139-float{position:absolute;z-index:4;padding:14px 16px;border-radius:18px;background:rgba(7,17,31,.88);border:1px solid var(--caska-border);box-shadow:0 22px 48px rgba(0,0,0,.3);}
.v139-float strong{display:block;font-size:17px;}
.v139-float span{display:block;color:var(--caska-muted);font-size:12px;margin-top:3px;}
.v139-float-a{left:-16px;top:110px}.v139-float-b{right:8px;top:70px}.v139-float-c{left:90px;bottom:34px}

.v139-trust{padding:18px 0 68px;}
.v139-trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.v139-widget{padding:22px;}
.v139-icon{display:grid;place-items:center;width:46px;height:46px;border-radius:15px;background:rgba(0,212,255,.08);border:1px solid var(--caska-border);color:var(--caska-cyan);font-size:22px;margin-bottom:15px;}
.v139-widget h3{margin:0 0 8px;font-size:18px;}.v139-widget p{margin:0;color:var(--caska-muted);font-size:14px;line-height:1.55;}

.v139-ecosystem-grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:1120px;margin:0 auto;}
.v139-ecosystem-grid:before{content:'';position:absolute;inset:12%;border:1px solid rgba(0,212,255,.08);border-radius:38px;pointer-events:none;}
.v139-core-card{grid-column:2 / span 2;grid-row:1 / span 2;min-height:220px;padding:34px;display:flex;flex-direction:column;justify-content:center;text-align:center;border-color:var(--caska-border);background:radial-gradient(circle at 50% 0%,rgba(0,212,255,.16),transparent 48%),linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.035));}
.v139-core-card span{color:var(--caska-cyan);text-transform:uppercase;letter-spacing:.12em;font-weight:900;font-size:12px;}.v139-core-card strong{display:block;font-size:28px;letter-spacing:-.035em;line-height:1.15;margin:10px 0;}.v139-core-card p{margin:0;color:var(--caska-muted);}
.v139-module{min-height:92px;display:grid;place-items:center;text-align:center;padding:18px;font-weight:900;color:#fff;border-color:rgba(0,212,255,.14);}

.v139-service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.v139-service-card{overflow:hidden;padding:0;transition:transform .22s ease,border-color .22s ease;background:linear-gradient(180deg,rgba(255,255,255,.065),rgba(255,255,255,.028));}
.v139-service-card:hover{transform:translateY(-3px);border-color:rgba(0,212,255,.34);}
.v139-service-card figure{margin:0;height:170px;overflow:hidden;background:#07111f;}
.v139-service-card img{width:100%;height:100%;object-fit:cover;object-position:center right;opacity:.82;filter:saturate(1.04) contrast(1.02);}
.v139-card-body{padding:24px;}
.v139-card-icon{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:15px;background:linear-gradient(135deg,var(--caska-blue),var(--caska-purple));font-weight:950;color:#fff;margin-bottom:16px;}
.v139-service-card h3{margin:0 0 10px;font-size:21px;letter-spacing:-.025em;}
.v139-service-card p{margin:0;color:var(--caska-muted);font-size:14px;line-height:1.62;}
.v139-service-card a{display:inline-flex;margin-top:18px;color:var(--caska-cyan);font-weight:900;}

.v139-feature{background:linear-gradient(180deg,rgba(255,255,255,.015),rgba(255,255,255,0));}
.v139-feature-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center;}.v139-feature-grid-alt{grid-template-columns:1.05fr .95fr;}
.v139-feature-copy h2{font-size:clamp(36px,4.3vw,64px);line-height:1.02;letter-spacing:-.055em;margin:18px 0;}
.v139-feature-copy p{color:var(--caska-muted);font-size:18px;line-height:1.75;margin:0 0 24px;}
.v139-side-visual{margin:0;border-radius:34px;overflow:hidden;border:1px solid var(--caska-border);box-shadow:0 30px 80px rgba(0,0,0,.28);background:rgba(255,255,255,.04);}
.v139-side-visual img{width:100%;aspect-ratio:3/2;object-fit:cover;object-position:center right;}
.v139-mini-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:26px 0;}
.v139-mini-grid article{padding:18px;text-align:center;}.v139-mini-grid b{display:block;color:var(--caska-cyan);font-size:13px;margin-bottom:6px;}.v139-mini-grid span{font-weight:900;font-size:14px;}
.v139-tag-cloud{display:flex;flex-wrap:wrap;gap:10px;margin:26px 0;}.v139-tag-cloud span{padding:11px 14px;border:1px solid var(--caska-border-soft);border-radius:999px;background:rgba(255,255,255,.055);color:#fff;font-weight:750;font-size:14px;}

.v139-flow-grid{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:18px;align-items:center;}.v139-flow-grid article{padding:28px;min-height:168px;}.v139-flow-grid b{display:block;font-size:22px;margin-bottom:10px;}.v139-flow-grid p{margin:0;color:var(--caska-muted);line-height:1.65;}.v139-arrow{display:grid;place-items:center;color:var(--caska-cyan);font-size:30px;font-weight:900;}

.v139-dashboard-grid{display:grid;grid-template-columns:.78fr 1.22fr;gap:48px;align-items:center;}.v139-kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;}.v139-kpi-grid article{padding:24px;}.v139-kpi-grid span{display:block;color:var(--caska-muted);font-size:13px;font-weight:800;}.v139-kpi-grid strong{display:block;font-size:34px;letter-spacing:-.04em;margin-top:10px;color:#fff;}

.v139-process-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;}.v139-process-grid article{padding:26px;}.v139-process-grid b{display:grid;place-items:center;width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,var(--caska-blue),var(--caska-cyan));margin-bottom:16px;}.v139-process-grid h3{margin:0 0 10px;font-size:20px;}.v139-process-grid p{margin:0;color:var(--caska-muted);line-height:1.6;font-size:14px;}

.v139-portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}.v139-portfolio-grid article{padding:0;overflow:hidden;}.v139-portfolio-grid img{width:100%;height:210px;object-fit:cover;object-position:center right;opacity:.86;}.v139-portfolio-grid span,.v139-portfolio-grid h3,.v139-portfolio-grid p{display:block;margin-left:24px;margin-right:24px;}.v139-portfolio-grid span{margin-top:22px;color:var(--caska-cyan);font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.12em;}.v139-portfolio-grid h3{margin-top:8px;margin-bottom:8px;font-size:23px;}.v139-portfolio-grid p{margin-bottom:24px;color:var(--caska-muted);line-height:1.6;}

.v139-cta{background:radial-gradient(circle at 80% 20%,rgba(0,212,255,.12),transparent 30%),radial-gradient(circle at 20% 20%,rgba(124,92,255,.14),transparent 28%),linear-gradient(135deg,#06101F,#050B16);content-visibility:visible!important;}.v139-cta-grid{display:grid;grid-template-columns:1fr .72fr;gap:48px;align-items:center;}.v139-contact-panel{display:grid;gap:14px;}.v139-contact-panel article{padding:24px;}.v139-contact-panel span{display:block;color:var(--caska-muted);font-size:13px;font-weight:800;}.v139-contact-panel strong{display:block;margin-top:8px;font-size:19px;}

/* Reduce old decorative animations/effects from previous versions */
.hero-motion .hero-shape,.hero-wave,.hero-glow,.cta-orb,.section-spark{display:none!important;animation:none!important;}
.reveal{transition:opacity .45s ease, transform .45s ease;}

@media(max-width:1100px){
  .v139-hero-grid,.v139-feature-grid,.v139-feature-grid-alt,.v139-dashboard-grid,.v139-cta-grid{grid-template-columns:1fr;gap:42px;}
  .v139-service-grid{grid-template-columns:repeat(2,1fr);}
  .v139-trust-grid{grid-template-columns:repeat(2,1fr);}
  .v139-process-grid{grid-template-columns:repeat(2,1fr);}
  .v139-kpi-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:760px){
  html{scroll-behavior:auto!important;}
  .caska-v139 .section{padding:68px 0;content-visibility:visible;contain-intrinsic-size:auto;}
  .v139-hero{padding:66px 0 58px!important;min-height:auto;}
  .v139-hero-copy h1{font-size:42px;letter-spacing:-.045em;}
  .v139-hero-copy p,.v139-feature-copy p{font-size:16px;line-height:1.65;}
  .v139-hero-widgets,.v139-service-grid,.v139-trust-grid,.v139-ecosystem-grid,.v139-mini-grid,.v139-flow-grid,.v139-kpi-grid,.v139-process-grid,.v139-portfolio-grid{grid-template-columns:1fr;}
  .v139-hero-widgets{gap:10px;}
  .v139-hero-visual{min-height:auto;}
  .v139-float{display:none;}
  .v139-main-visual,.v139-side-visual{border-radius:24px;}
  .v139-main-visual img{aspect-ratio:1.18/1;object-position:center right;}
  .v139-trust{padding:0 0 38px;}
  .v139-core-card{grid-column:auto;grid-row:auto;min-height:auto;padding:26px;}
  .v139-ecosystem-grid:before{display:none;}
  .v139-service-card:hover,.btn:hover{transform:none;}
  .v139-service-card figure{height:190px;}
  .v139-flow-grid{gap:12px;}.v139-arrow{transform:rotate(90deg);}
  .v139-kpi-grid article,.v139-process-grid article,.v139-widget{padding:20px;}
  .v139-portfolio-grid img{height:190px;}
  .v139-contact-panel strong{font-size:16px;word-break:break-word;}
  .caska-header{backdrop-filter:none;}
  .reveal,.reveal.visible{opacity:1!important;transform:none!important;transition:none!important;}
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;}
}

/* =========================================================
   CASKA v1.4.0 — DASHBOARD ARCHITECTURE REBUILD
   Rediseño real: sistema visual tipo dashboard, iconos SVG,
   menos animaciones, más arquitectura y cards modulares.
   ========================================================= */
:root{
  --v140-bg:#030814;
  --v140-bg2:#071324;
  --v140-panel:rgba(10,24,45,.78);
  --v140-panel2:rgba(255,255,255,.052);
  --v140-border:rgba(0,216,255,.18);
  --v140-border2:rgba(124,92,255,.22);
  --v140-cyan:#00d8ff;
  --v140-blue:#2f7bff;
  --v140-purple:#7c5cff;
  --v140-text:#f7fbff;
  --v140-muted:#aab8cc;
}
body.caska-home{background:var(--v140-bg)!important;color:var(--v140-text)!important;}
.caska-v140{background:var(--v140-bg);color:var(--v140-text);overflow:hidden;}
.caska-v140 *{box-sizing:border-box;}
.caska-v140 img{max-width:100%;display:block;height:auto;}
.caska-v140 svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.caska-v140 .btn{border-radius:999px;min-height:52px;padding:14px 22px;font-weight:900;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:transform .18s ease,border-color .18s ease,background .18s ease;}
.caska-v140 .btn:hover{transform:translateY(-2px);}
.caska-v140 .btn-primary{background:linear-gradient(135deg,var(--v140-purple),var(--v140-blue) 55%,var(--v140-cyan));color:white!important;border:0;box-shadow:0 18px 42px rgba(47,123,255,.24);}
.caska-v140 .btn-ghost{background:rgba(255,255,255,.055);color:white!important;border:1px solid rgba(255,255,255,.12);}
.caska-v140 .container{width:min(1180px,calc(100% - 32px));margin-inline:auto;}
.v140-kicker{display:inline-flex;align-items:center;gap:8px;color:var(--v140-cyan);font-size:13px;font-weight:950;letter-spacing:.08em;text-transform:uppercase;background:rgba(0,216,255,.08);border:1px solid rgba(0,216,255,.18);border-radius:999px;padding:10px 14px;}
.v140-kicker:before{content:'';width:7px;height:7px;border-radius:50%;background:var(--v140-cyan);box-shadow:0 0 16px var(--v140-cyan);}
.v140-hero{position:relative;min-height:calc(100vh - 76px);padding:96px 0 82px;display:flex;align-items:center;background:radial-gradient(circle at 88% 18%,rgba(124,92,255,.2),transparent 32%),radial-gradient(circle at 70% 62%,rgba(0,216,255,.16),transparent 30%),linear-gradient(180deg,#030814,#06101f 70%,#030814);content-visibility:visible!important;}
.v140-grid-bg{position:absolute;inset:0;opacity:.12;background-image:linear-gradient(rgba(0,216,255,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(0,216,255,.12) 1px,transparent 1px);background-size:64px 64px;mask-image:linear-gradient(180deg,#000,transparent 78%);pointer-events:none;}
.v140-hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:.86fr 1.14fr;gap:58px;align-items:center;}
.v140-hero-copy h1{font-size:clamp(46px,5.7vw,86px);line-height:.96;letter-spacing:-.07em;margin:18px 0 22px;max-width:760px;}
.v140-hero-copy h1 span{display:block;background:linear-gradient(90deg,var(--v140-cyan),var(--v140-blue),var(--v140-purple));-webkit-background-clip:text;background-clip:text;color:transparent;}
.v140-hero-copy p{font-size:19px;line-height:1.72;color:var(--v140-muted);max-width:690px;margin:0;}
.v140-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px;}
.v140-chip-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px;}
.v140-chip-row span,.v140-pill-grid span{display:inline-flex;align-items:center;gap:9px;color:#fff;font-weight:900;border:1px solid rgba(0,216,255,.16);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.032));border-radius:999px;padding:11px 14px;}
.v140-chip-row svg,.v140-pill-grid svg{color:var(--v140-cyan);width:19px;height:19px;}
.v140-system-visual{position:relative;min-height:590px;display:grid;place-items:center;}
.v140-device{position:relative;margin:0;width:100%;border:1px solid rgba(0,216,255,.22);border-radius:34px;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));box-shadow:0 35px 90px rgba(0,0,0,.46),0 0 90px rgba(0,216,255,.10);}
.v140-device:before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(3,8,20,.76) 0%,rgba(3,8,20,.18) 38%,rgba(3,8,20,.1) 100%);z-index:1;pointer-events:none;}
.v140-device img{width:100%;aspect-ratio:16/10;object-fit:cover;object-position:center right;filter:saturate(1.08) contrast(1.03);}
.v140-side-panel{position:absolute;z-index:5;width:210px;padding:16px;border:1px solid rgba(0,216,255,.22);border-radius:20px;background:rgba(5,13,27,.86);box-shadow:0 22px 48px rgba(0,0,0,.34);}
.v140-side-panel span{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,rgba(47,123,255,.28),rgba(0,216,255,.1));color:var(--v140-cyan);border:1px solid rgba(0,216,255,.18);margin-bottom:12px;}
.v140-side-panel b{display:block;font-size:15px;}.v140-side-panel small{display:block;color:var(--v140-muted);margin-top:4px;}
.v140-panel-a{left:-28px;top:92px;}.v140-panel-b{right:-18px;top:52px;}.v140-panel-c{right:28px;bottom:38px;}
.v140-strip{padding:20px 0 76px;background:linear-gradient(180deg,#030814,#040b18);}
.v140-strip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.v140-strip-grid article,.v140-node,.v140-core,.v140-service,.v140-process-line article,.v140-kpis article,.v140-contact-card article{background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.028));border:1px solid rgba(255,255,255,.10);border-radius:26px;box-shadow:0 20px 56px rgba(0,0,0,.22);}
.v140-strip-grid article{padding:23px;}.v140-strip-grid span,.v140-service-icon{display:grid;place-items:center;width:48px;height:48px;border-radius:16px;color:var(--v140-cyan);background:rgba(0,216,255,.08);border:1px solid rgba(0,216,255,.18);margin-bottom:15px;}.v140-strip-grid b{display:block;font-size:18px;}.v140-strip-grid p{margin:8px 0 0;color:var(--v140-muted);line-height:1.55;font-size:14px;}
.v140-section{padding:108px 0;background:linear-gradient(180deg,#030814,#050d1c);content-visibility:auto;contain-intrinsic-size:920px;}
.v140-head{text-align:center;max-width:820px;margin:0 auto 42px;}.v140-head h2,.v140-feature-copy h2,.v140-cta h2{font-size:clamp(34px,4.3vw,64px);line-height:1.02;letter-spacing:-.055em;margin:16px 0;}.v140-head p,.v140-feature-copy p,.v140-cta p{color:var(--v140-muted);font-size:18px;line-height:1.72;margin:0;}.v140-head-split{max-width:none;display:grid;grid-template-columns:.9fr .7fr;gap:36px;align-items:end;text-align:left;}
.v140-architecture{background:radial-gradient(circle at 50% 40%,rgba(0,216,255,.12),transparent 34%),linear-gradient(180deg,#040b18,#030814);}
.v140-map{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:16px;align-items:stretch;}.v140-map:before{content:'';position:absolute;inset:12%;border:1px solid rgba(0,216,255,.09);border-radius:40px;pointer-events:none;}.v140-core{grid-column:2 / span 3;grid-row:1 / span 2;display:grid;place-items:center;text-align:center;min-height:250px;padding:34px;border-color:rgba(0,216,255,.28);background:radial-gradient(circle at top,rgba(0,216,255,.16),transparent 52%),linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.032));}.v140-core span{display:grid;place-items:center;width:64px;height:64px;border-radius:22px;color:var(--v140-cyan);background:rgba(0,216,255,.10);border:1px solid rgba(0,216,255,.22);}.v140-core b{font-size:32px;letter-spacing:-.04em;}.v140-core p{color:var(--v140-muted);margin:0;}.v140-node{min-height:132px;padding:18px;display:flex;flex-direction:column;justify-content:center;gap:8px;position:relative;}.v140-node span{color:var(--v140-cyan);}.v140-node b{font-size:16px;}.v140-node small{color:var(--v140-muted);line-height:1.35;}
.v140-services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}.v140-service{position:relative;overflow:hidden;transition:transform .18s ease,border-color .18s ease;}.v140-service:hover{transform:translateY(-4px);border-color:rgba(0,216,255,.30);}.v140-service-icon{position:absolute;z-index:3;top:18px;left:18px;background:rgba(5,13,27,.86);}.v140-service figure{margin:0;height:180px;overflow:hidden;background:#06101f;}.v140-service figure:after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(3,8,20,.82));}.v140-service img{width:100%;height:100%;object-fit:cover;object-position:center right;opacity:.78;}.v140-service-body{padding:24px;}.v140-service-body small{display:block;color:var(--v140-cyan);font-weight:950;letter-spacing:.12em;margin-bottom:10px;}.v140-service h3{font-size:21px;line-height:1.15;letter-spacing:-.025em;margin:0 0 10px;}.v140-service p{color:var(--v140-muted);font-size:14px;line-height:1.62;margin:0;}
.v140-uiux{background:radial-gradient(circle at 78% 35%,rgba(124,92,255,.16),transparent 32%),linear-gradient(180deg,#030814,#071224);}.v140-feature-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:62px;align-items:center;}.v140-feature-alt{grid-template-columns:1.05fr .95fr;}.v140-feature-img{margin:0;border-radius:34px;overflow:hidden;border:1px solid rgba(0,216,255,.22);background:rgba(255,255,255,.045);box-shadow:0 30px 85px rgba(0,0,0,.35);}.v140-feature-img img{width:100%;aspect-ratio:3/2;object-fit:cover;object-position:center right;}.v140-pill-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;}
.v140-flow-section{background:linear-gradient(180deg,#050d1c,#030814);}.v140-process-line{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;position:relative;}.v140-process-line:before{content:'';position:absolute;left:5%;right:5%;top:42px;height:1px;background:linear-gradient(90deg,transparent,var(--v140-cyan),transparent);opacity:.35;}.v140-process-line article{position:relative;z-index:2;padding:26px;}.v140-process-line b{display:grid;place-items:center;width:52px;height:52px;border-radius:18px;background:linear-gradient(135deg,var(--v140-blue),var(--v140-cyan));box-shadow:0 0 34px rgba(0,216,255,.16);}.v140-process-line h3{font-size:20px;margin:18px 0 8px;}.v140-process-line p{color:var(--v140-muted);font-size:14px;line-height:1.6;margin:0;}
.v140-data{background:radial-gradient(circle at 20% 40%,rgba(0,216,255,.12),transparent 30%),linear-gradient(180deg,#030814,#06101f);}.v140-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:26px;}.v140-kpis article{padding:22px;}.v140-kpis small{display:block;color:var(--v140-muted);font-weight:800;}.v140-kpis b{display:block;font-size:34px;margin-top:8px;letter-spacing:-.04em;color:white;}
.v140-cta{background:radial-gradient(circle at 85% 20%,rgba(0,216,255,.16),transparent 32%),radial-gradient(circle at 20% 40%,rgba(124,92,255,.16),transparent 30%),linear-gradient(180deg,#071224,#030814);content-visibility:visible!important;}.v140-cta-grid{display:grid;grid-template-columns:1fr .78fr;gap:54px;align-items:center;}.v140-contact-card{display:grid;gap:14px;}.v140-contact-card article{padding:22px;display:grid;grid-template-columns:auto 1fr;column-gap:14px;align-items:center;}.v140-contact-card span{grid-row:1 / span 2;display:grid;place-items:center;width:48px;height:48px;border-radius:16px;color:var(--v140-cyan);background:rgba(0,216,255,.08);border:1px solid rgba(0,216,255,.18);}.v140-contact-card b{font-size:18px;}.v140-contact-card small{color:var(--v140-muted);}
/* Forzar que no se vea la home Elementor previa en front-page */
.caska-elementor-home{display:none!important;}
/* Menos consumo: apagar decorativos previos */
.hero-shape,.hero-wave,.hero-glow,.cta-orb,.section-spark,.v139-float{display:none!important;animation:none!important;}
.reveal,.reveal.visible{opacity:1!important;transform:none!important;transition:none!important;}
@media(max-width:1100px){.v140-hero-grid,.v140-feature-grid,.v140-feature-alt,.v140-cta-grid,.v140-head-split{grid-template-columns:1fr;}.v140-services-grid{grid-template-columns:repeat(2,1fr);}.v140-strip-grid{grid-template-columns:repeat(2,1fr);}.v140-map{grid-template-columns:repeat(2,1fr);}.v140-core{grid-column:1 / -1;grid-row:auto;}.v140-process-line{grid-template-columns:repeat(2,1fr);}.v140-process-line:before{display:none;}.v140-system-visual{min-height:auto;}.v140-panel-a,.v140-panel-b,.v140-panel-c{position:static;width:auto;margin-top:12px;}}
@media(max-width:760px){html{scroll-behavior:auto!important;}.v140-hero{min-height:auto;padding:66px 0 58px;}.v140-hero-copy h1{font-size:42px;letter-spacing:-.045em;}.v140-hero-copy p,.v140-head p,.v140-feature-copy p,.v140-cta p{font-size:16px;line-height:1.65;}.v140-section{padding:68px 0;content-visibility:visible;contain-intrinsic-size:auto;}.v140-services-grid,.v140-strip-grid,.v140-map,.v140-process-line,.v140-kpis{grid-template-columns:1fr;}.v140-device,.v140-feature-img{border-radius:24px;}.v140-device:before{background:linear-gradient(180deg,rgba(3,8,20,.25),rgba(3,8,20,.72));}.v140-device img{aspect-ratio:1.08/1;}.v140-service:hover,.caska-v140 .btn:hover{transform:none;}.v140-service figure{height:190px;}.v140-head{text-align:left;}.v140-actions{flex-direction:column;}.v140-actions .btn{width:100%;}.v140-contact-card article{grid-template-columns:auto 1fr;}*{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;}.caska-header{backdrop-filter:none!important;}}

/* =========================================================
   V1.4.2 — Proporción Visual + Typography Scale
   Ajuste general para que los títulos no dominen la pantalla,
   mejorar equilibrio hero/imagen y limpiar proporciones por sección.
   ========================================================= */
:root{
  --v142-max:1240px;
}
.caska-v140 .container{
  width:min(var(--v142-max),calc(100% - 48px))!important;
}
.caska-header{
  background:rgba(3,9,20,.88)!important;
  border-bottom:1px solid rgba(0,216,255,.10)!important;
}
body.admin-bar .caska-header{
  top:32px;
}
.nav-shell{
  width:min(1280px,calc(100% - 48px))!important;
  height:72px!important;
  gap:22px!important;
}
.brand-logo img{
  width:128px!important;
  max-height:44px!important;
}
.main-nav{
  gap:4px!important;
}
.main-nav a{
  padding:10px 14px!important;
  font-size:14px!important;
  line-height:1!important;
}
.nav-cta{
  padding:13px 22px!important;
  font-size:14px!important;
  box-shadow:0 14px 36px rgba(41,148,255,.22)!important;
}
.v140-hero{
  min-height:auto!important;
  padding:78px 0 70px!important;
}
.v140-hero-grid{
  grid-template-columns:.90fr 1.10fr!important;
  gap:44px!important;
  align-items:center!important;
}
.v140-kicker{
  font-size:11px!important;
  padding:8px 12px!important;
  letter-spacing:.11em!important;
}
.v140-hero-copy h1{
  font-size:clamp(40px,4.15vw,62px)!important;
  line-height:1.03!important;
  letter-spacing:-.055em!important;
  margin:16px 0 18px!important;
  max-width:620px!important;
}
.v140-hero-copy p{
  font-size:16.5px!important;
  line-height:1.62!important;
  max-width:610px!important;
}
.v140-actions{
  margin-top:24px!important;
  gap:12px!important;
}
.caska-v140 .btn{
  min-height:48px!important;
  padding:12px 20px!important;
  font-size:14px!important;
}
.v140-chip-row{
  margin-top:22px!important;
  gap:9px!important;
}
.v140-chip-row span,
.v140-pill-grid span{
  padding:9px 12px!important;
  font-size:13px!important;
  border-radius:18px!important;
}
.v140-chip-row svg,
.v140-pill-grid svg{
  width:17px!important;
  height:17px!important;
}
.v140-system-visual{
  min-height:470px!important;
}
.v140-device{
  border-radius:28px!important;
  width:96%!important;
  margin-left:auto!important;
}
.v140-device img{
  aspect-ratio:16/9.6!important;
}
.v140-side-panel{
  width:178px!important;
  padding:13px!important;
  border-radius:18px!important;
}
.v140-side-panel span{
  width:36px!important;
  height:36px!important;
  border-radius:12px!important;
  margin-bottom:9px!important;
}
.v140-side-panel b{
  font-size:13.5px!important;
}
.v140-side-panel small{
  font-size:12px!important;
  line-height:1.35!important;
}
.v140-panel-a{left:-6px!important;top:86px!important;}
.v140-panel-b{right:10px!important;top:44px!important;}
.v140-panel-c{right:52px!important;bottom:24px!important;}
.v140-strip{
  padding:20px 0 62px!important;
}
.v140-strip-grid{
  gap:14px!important;
}
.v140-strip-grid article{
  padding:20px!important;
  border-radius:22px!important;
}
.v140-strip-grid span,
.v140-service-icon,
.v140-core span,
.v140-contact-card span{
  width:42px!important;
  height:42px!important;
  border-radius:14px!important;
}
.v140-strip-grid b{
  font-size:16px!important;
}
.v140-strip-grid p{
  font-size:13.5px!important;
  line-height:1.5!important;
}
.v140-section{
  padding:86px 0!important;
  contain-intrinsic-size:760px!important;
}
.v140-head{
  max-width:760px!important;
  margin-bottom:36px!important;
}
.v140-head h2,
.v140-feature-copy h2,
.v140-cta h2{
  font-size:clamp(30px,3.25vw,48px)!important;
  line-height:1.08!important;
  letter-spacing:-.045em!important;
  margin:14px 0!important;
}
.v140-head p,
.v140-feature-copy p,
.v140-cta p{
  font-size:16.5px!important;
  line-height:1.64!important;
}
.v140-head-split{
  grid-template-columns:.95fr .75fr!important;
  gap:30px!important;
  align-items:center!important;
}
.v140-map{
  gap:14px!important;
}
.v140-core{
  min-height:220px!important;
  padding:28px!important;
  border-radius:24px!important;
}
.v140-core b{
  font-size:28px!important;
}
.v140-core p{
  font-size:15px!important;
  line-height:1.55!important;
  max-width:430px!important;
}
.v140-node{
  min-height:116px!important;
  padding:16px!important;
  border-radius:22px!important;
}
.v140-node b{
  font-size:15px!important;
}
.v140-node small{
  font-size:12.5px!important;
}
.v140-services-grid{
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:18px!important;
}
.v140-service{
  border-radius:24px!important;
}
.v140-service figure{
  height:158px!important;
}
.v140-service-icon{
  top:14px!important;
  left:14px!important;
}
.v140-service-body{
  padding:20px!important;
}
.v140-service h3{
  font-size:18.5px!important;
  line-height:1.18!important;
  letter-spacing:-.02em!important;
}
.v140-service p{
  font-size:13.3px!important;
  line-height:1.55!important;
}
.v140-feature-grid{
  gap:46px!important;
}
.v140-feature-img{
  border-radius:28px!important;
}
.v140-pill-grid{
  margin-top:22px!important;
}
.v140-process-line{
  gap:14px!important;
}
.v140-process-line article{
  padding:22px!important;
  border-radius:22px!important;
}
.v140-process-line b{
  width:46px!important;
  height:46px!important;
  border-radius:15px!important;
  font-size:14px!important;
}
.v140-process-line h3{
  font-size:18px!important;
  margin:16px 0 7px!important;
}
.v140-process-line p{
  font-size:13.5px!important;
}
.v140-kpis{
  gap:12px!important;
}
.v140-kpis article{
  padding:18px!important;
  border-radius:22px!important;
}
.v140-kpis b{
  font-size:28px!important;
}
.v140-cta-grid{
  gap:44px!important;
}
.v140-contact-card article{
  padding:18px!important;
  border-radius:22px!important;
}
.v140-contact-card b{
  font-size:16.5px!important;
}
.v140-contact-card small{
  font-size:13px!important;
}
.caska-v140 h1,
.caska-v140 h2,
.caska-v140 h3,
.caska-v140 p,
.caska-v140 b,
.caska-v140 small,
.caska-v140 span,
.caska-v140 a{
  overflow-wrap:anywhere;
}

@media(max-width:1366px){
  .caska-v140 .container{width:min(1160px,calc(100% - 42px))!important;}
  .v140-hero{padding:64px 0 58px!important;}
  .v140-hero-grid{gap:36px!important;grid-template-columns:.92fr 1.08fr!important;}
  .v140-hero-copy h1{font-size:clamp(38px,4vw,56px)!important;max-width:570px!important;}
  .v140-hero-copy p{font-size:15.5px!important;max-width:560px!important;}
  .v140-system-visual{min-height:420px!important;}
  .v140-side-panel{width:166px!important;}
  .v140-section{padding:78px 0!important;}
  .v140-head h2,.v140-feature-copy h2,.v140-cta h2{font-size:clamp(29px,3vw,44px)!important;}
  .v140-service figure{height:146px!important;}
  .v140-service h3{font-size:17.5px!important;}
}
@media(max-width:1180px){
  .nav-shell{height:68px!important;}
  .brand-logo img{width:118px!important;}
  .main-nav a{font-size:13px!important;padding:9px 10px!important;}
  .nav-cta{padding:12px 18px!important;font-size:13px!important;}
  .v140-hero-grid{grid-template-columns:1fr!important;gap:34px!important;}
  .v140-hero-copy h1{max-width:760px!important;}
  .v140-hero-copy p{max-width:720px!important;}
  .v140-system-visual{min-height:auto!important;}
  .v140-device{width:100%!important;margin:0!important;}
  .v140-panel-a,.v140-panel-b,.v140-panel-c{position:static!important;width:auto!important;margin-top:10px!important;}
  .v140-services-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
  .v140-head-split{grid-template-columns:1fr!important;text-align:left!important;}
}
@media(max-width:782px){
  body.admin-bar .caska-header{top:46px;}
}
@media(max-width:760px){
  .caska-v140 .container,.nav-shell{width:min(100% - 30px, var(--v142-max))!important;}
  .nav-shell{height:64px!important;}
  .brand-logo img{width:108px!important;max-height:38px!important;}
  .v140-hero{padding:52px 0 48px!important;}
  .v140-hero-copy h1{font-size:clamp(32px,9.6vw,40px)!important;line-height:1.06!important;letter-spacing:-.04em!important;margin:14px 0!important;}
  .v140-hero-copy p,.v140-head p,.v140-feature-copy p,.v140-cta p{font-size:15px!important;line-height:1.58!important;}
  .v140-actions{display:grid!important;grid-template-columns:1fr!important;}
  .v140-chip-row{display:grid!important;grid-template-columns:1fr 1fr!important;gap:8px!important;}
  .v140-chip-row span{justify-content:center!important;text-align:center!important;font-size:12px!important;}
  .v140-device{border-radius:22px!important;}
  .v140-device img{aspect-ratio:1.2/1!important;}
  .v140-section{padding:60px 0!important;content-visibility:visible!important;contain-intrinsic-size:auto!important;}
  .v140-head{margin-bottom:28px!important;}
  .v140-head h2,.v140-feature-copy h2,.v140-cta h2{font-size:clamp(27px,8.2vw,34px)!important;line-height:1.1!important;letter-spacing:-.035em!important;}
  .v140-strip{padding:14px 0 50px!important;}
  .v140-strip-grid,.v140-map,.v140-services-grid,.v140-process-line,.v140-kpis{grid-template-columns:1fr!important;}
  .v140-core{min-height:auto!important;padding:24px!important;}
  .v140-core b{font-size:24px!important;}
  .v140-node{min-height:auto!important;}
  .v140-service figure{height:170px!important;}
  .v140-feature-grid,.v140-feature-alt,.v140-cta-grid{grid-template-columns:1fr!important;gap:28px!important;}
  .v140-feature-img{border-radius:22px!important;}
  .v140-pill-grid{display:grid!important;grid-template-columns:1fr 1fr!important;}
  .v140-process-line:before{display:none!important;}
  .v140-contact-card article{grid-template-columns:auto 1fr!important;}
}
@media(max-width:420px){
  .v140-chip-row,.v140-pill-grid{grid-template-columns:1fr!important;}
  .v140-hero-copy h1{font-size:31px!important;}
  .v140-head h2,.v140-feature-copy h2,.v140-cta h2{font-size:27px!important;}
}


/* =========================================================
   CASKA v1.4.3 — Ecosystem Futuristic Upgrade
   Rediseño visual del bloque Ecosistema: núcleo digital, nodos,
   conexiones luminosas y profundidad futurista sin consumo pesado.
   ========================================================= */
.v140-architecture{
  position:relative!important;
  overflow:hidden!important;
  background:
    radial-gradient(circle at 50% 36%, rgba(0,216,255,.18), transparent 28%),
    radial-gradient(circle at 73% 56%, rgba(124,92,255,.14), transparent 30%),
    linear-gradient(180deg,#030814 0%,#05101f 50%,#030814 100%)!important;
}
.v140-architecture:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.22;
  background-image:
    linear-gradient(rgba(0,216,255,.13) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,216,255,.13) 1px, transparent 1px),
    radial-gradient(circle at 50% 48%, rgba(0,216,255,.16), transparent 32%);
  background-size:74px 74px,74px 74px,100% 100%;
  mask-image:linear-gradient(180deg, transparent 0%, #000 20%, #000 78%, transparent 100%);
}
.v140-architecture .container{position:relative;z-index:2;}
.v140-architecture .v140-head{max-width:880px!important;margin-bottom:48px!important;}
.v140-architecture .v140-head h2{
  max-width:900px!important;
  margin-left:auto!important;
  margin-right:auto!important;
  background:linear-gradient(90deg,#fff 0%,#d9f7ff 40%,#7c9cff 72%,#b9a7ff 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent!important;
}
.v140-architecture .v140-head p{max-width:740px!important;margin-left:auto!important;margin-right:auto!important;}
.v140-map{
  position:relative!important;
  display:grid!important;
  grid-template-columns:1fr 1fr 1fr 1fr 1fr 1fr!important;
  grid-template-rows:auto auto auto!important;
  gap:16px!important;
  padding:34px!important;
  border:1px solid rgba(0,216,255,.12)!important;
  border-radius:46px!important;
  background:
    radial-gradient(circle at 50% 45%,rgba(0,216,255,.10),transparent 38%),
    linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.012))!important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.025),0 28px 92px rgba(0,0,0,.24)!important;
  overflow:hidden!important;
}
.v140-map:before{
  content:""!important;
  position:absolute!important;
  inset:58px 76px 70px!important;
  border:1px solid rgba(0,216,255,.12)!important;
  border-radius:72px!important;
  box-shadow:0 0 42px rgba(0,216,255,.07), inset 0 0 42px rgba(0,216,255,.035)!important;
  pointer-events:none!important;
}
.v140-map:after{
  content:"";
  position:absolute;
  left:8%;right:8%;top:50%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,216,255,.32),rgba(124,92,255,.26),rgba(0,216,255,.32),transparent);
  box-shadow:0 0 28px rgba(0,216,255,.16);
  pointer-events:none;
}
.v140-core{
  position:relative!important;
  grid-column:2 / span 4!important;
  grid-row:1 / span 2!important;
  min-height:290px!important;
  padding:38px!important;
  border-radius:34px!important;
  border-color:rgba(0,216,255,.34)!important;
  background:
    radial-gradient(circle at 50% 18%,rgba(0,216,255,.18),transparent 36%),
    radial-gradient(circle at 50% 100%,rgba(124,92,255,.14),transparent 42%),
    linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.025))!important;
  box-shadow:0 28px 92px rgba(0,0,0,.34),0 0 84px rgba(0,216,255,.12),inset 0 0 34px rgba(0,216,255,.04)!important;
  isolation:isolate!important;
}
.v140-core:before{
  content:"";
  position:absolute;
  inset:22px;
  border-radius:28px;
  border:1px solid rgba(0,216,255,.10);
  pointer-events:none;
}
.v140-core:after{
  content:"";
  position:absolute;
  width:148px;height:148px;
  left:50%;top:50%;transform:translate(-50%,-50%);
  border-radius:999px;
  background:radial-gradient(circle,rgba(0,216,255,.16),transparent 68%);
  filter:blur(2px);
  z-index:-1;
  pointer-events:none;
}
.v140-core span{
  width:74px!important;
  height:74px!important;
  border-radius:26px!important;
  background:linear-gradient(135deg,rgba(0,216,255,.20),rgba(124,92,255,.13))!important;
  border:1px solid rgba(0,216,255,.30)!important;
  box-shadow:0 0 34px rgba(0,216,255,.20), inset 0 0 18px rgba(255,255,255,.035)!important;
}
.v140-core b{font-size:32px!important;margin-top:8px!important;}
.v140-core p{max-width:480px!important;}
.v140-node{
  position:relative!important;
  min-height:126px!important;
  padding:20px!important;
  border-radius:24px!important;
  border-color:rgba(255,255,255,.11)!important;
  background:
    linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.027)),
    radial-gradient(circle at 20% 15%,rgba(0,216,255,.08),transparent 40%)!important;
  box-shadow:0 18px 46px rgba(0,0,0,.22),inset 0 0 0 1px rgba(255,255,255,.018)!important;
  transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease,background .18s ease!important;
  z-index:2!important;
}
.v140-node:before{
  content:"";
  position:absolute;
  width:9px;height:9px;
  border-radius:999px;
  background:var(--v140-cyan);
  box-shadow:0 0 18px rgba(0,216,255,.8);
  opacity:.6;
  top:18px;right:18px;
}
.v140-node:hover{
  transform:translateY(-4px)!important;
  border-color:rgba(0,216,255,.34)!important;
  box-shadow:0 24px 60px rgba(0,0,0,.30),0 0 46px rgba(0,216,255,.09)!important;
  background:
    linear-gradient(180deg,rgba(255,255,255,.095),rgba(255,255,255,.035)),
    radial-gradient(circle at 20% 15%,rgba(0,216,255,.14),transparent 42%)!important;
}
.v140-node span{
  width:38px!important;
  height:38px!important;
  display:grid!important;
  place-items:center!important;
  color:var(--v140-cyan)!important;
  background:rgba(0,216,255,.075)!important;
  border:1px solid rgba(0,216,255,.16)!important;
  border-radius:14px!important;
  margin-bottom:6px!important;
}
.v140-node span svg{width:20px!important;height:20px!important;}
.v140-node b{font-size:16px!important;color:#fff!important;}
.v140-node small{color:#aebcd0!important;}
.v140-map .v140-node:nth-of-type(2){grid-column:1!important;grid-row:1!important;}
.v140-map .v140-node:nth-of-type(3){grid-column:6!important;grid-row:1!important;}
.v140-map .v140-node:nth-of-type(4){grid-column:1!important;grid-row:2!important;}
.v140-map .v140-node:nth-of-type(5){grid-column:6!important;grid-row:2!important;}
.v140-map .v140-node:nth-of-type(6){grid-column:1!important;grid-row:3!important;}
.v140-map .v140-node:nth-of-type(7){grid-column:2 / span 2!important;grid-row:3!important;}
.v140-map .v140-node:nth-of-type(8){grid-column:4 / span 2!important;grid-row:3!important;}
.v140-map .v140-node:nth-of-type(9){grid-column:6!important;grid-row:3!important;}
@media(min-width:761px){
  .v140-core span{animation:v143-core-pulse 4.8s ease-in-out infinite;}
  @keyframes v143-core-pulse{
    0%,100%{box-shadow:0 0 28px rgba(0,216,255,.18), inset 0 0 18px rgba(255,255,255,.035);}
    50%{box-shadow:0 0 44px rgba(0,216,255,.30),0 0 70px rgba(124,92,255,.12), inset 0 0 18px rgba(255,255,255,.055);}
  }
}
@media(max-width:1180px){
  .v140-map{grid-template-columns:repeat(2,minmax(0,1fr))!important;padding:24px!important;border-radius:34px!important;}
  .v140-map:before,.v140-map:after{display:none!important;}
  .v140-core{grid-column:1 / -1!important;grid-row:auto!important;min-height:auto!important;}
  .v140-map .v140-node{grid-column:auto!important;grid-row:auto!important;}
}
@media(max-width:760px){
  .v140-architecture:before{opacity:.14!important;}
  .v140-map{grid-template-columns:1fr!important;padding:16px!important;border-radius:28px!important;gap:12px!important;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015))!important;}
  .v140-core{padding:24px!important;border-radius:24px!important;}
  .v140-core span{width:58px!important;height:58px!important;border-radius:20px!important;animation:none!important;}
  .v140-core b{font-size:24px!important;}
  .v140-node{min-height:auto!important;padding:16px!important;border-radius:20px!important;}
  .v140-node:hover{transform:none!important;}
  .v140-node:before{width:7px;height:7px;top:16px;right:16px;}
}
