:root{
      --bg:#0b0b0f;           /* casi negro */
      --panel:#12121a;        /* panel oscuro */
      --morado:#7c3aed;       /* violeta principal */
      --morado-2:#a78bfa;     /* violeta suave */
      --texto:#e7e7ee;        /* texto claro */
      --muted:#a2a2b3;        /* gris */
      --accent:#8b5cf6;       /* acento */
      --ok:#22c55e;
      --warn:#f59e0b;
      --danger:#ef4444;
      --shadow:0 20px 60px rgba(124,58,237,.25), 0 2px 8px rgba(0,0,0,.5);
      --radius:22px;
    }
    *{box-sizing:border-box}
    html,body{height:100%}
    body{
      margin:0; font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial; 
      color:var(--texto); background:radial-gradient(1200px 800px at 80% -10%, rgba(124,58,237,.22), transparent 60%),
                          radial-gradient(1000px 900px at -10% 20%, rgba(139,92,246,.18), transparent 60%),
                          var(--bg);
      overflow-x:hidden;
    }
    /* ======= Navbar ======= */
    .nav{position:fixed; inset-inline:0; top:0; z-index:1000; display:flex; justify-content:center;}
    .nav-inner{backdrop-filter:saturate(160%) blur(10px); background:rgba(18,18,26,.55); border:1px solid rgba(124,58,237,.25); box-shadow:var(--shadow); width:min(1120px,96%); margin:14px auto; border-radius:16px; padding:10px 18px; display:flex; align-items:center; gap:14px}
    .brand{display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--texto); font-weight:700; letter-spacing:.5px}
    .brand .dot{width:10px; height:10px; border-radius:999px; background:linear-gradient(135deg,var(--morado),var(--morado-2)); box-shadow:0 0 18px rgba(124,58,237,.8)}
    .nav a{color:var(--texto); text-decoration:none; font-weight:500; opacity:.85}
    .nav a:hover{opacity:1}
    .nav-links{display:flex; gap:18px; margin-left:auto}
    .cta{padding:10px 16px; border-radius:12px; background:linear-gradient(135deg,var(--morado),var(--accent)); box-shadow:0 8px 24px rgba(124,58,237,.35);}
    .cta:hover{transform:translateY(-1px)}
    @media (max-width:920px){.nav-links{display:none}}

    /* ======= Hero ======= */
    .hero{min-height:92vh; display:grid; place-items:center; position:relative; padding-top:86px}
    .grid-hero{width:min(1200px,92%); display:grid; grid-template-columns:1.1fr .9fr; gap:36px}
    @media(max-width:900px){.grid-hero{grid-template-columns:1fr; gap:22px}}
    .card{
      background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00)),
                 radial-gradient(600px 300px at 0% -10%, rgba(124,58,237,.10), transparent 60%);
      border:1px solid rgba(124,58,237,.22);
      border-radius:var(--radius);
      padding:32px; box-shadow:var(--shadow);
    }
    .headline{font-size:clamp(36px,5vw,64px); line-height:1.05; margin:0 0 14px; letter-spacing:-.5px}
    .sub{font-size:clamp(16px,2.2vw,19px); color:var(--muted); margin:0 0 22px}
    .badges{display:flex; flex-wrap:wrap; gap:10px; margin:16px 0 24px}
    .badge{border:1px solid rgba(139,92,246,.35); padding:8px 12px; border-radius:999px; font-size:13px; color:#d9d2ff; background:rgba(139,92,246,.08)}
    .buttons{display:flex; gap:12px; flex-wrap:wrap}
    .btn{padding:14px 18px; border-radius:14px; border:1px solid rgba(139,92,246,.35); color:var(--texto); background:#14121d; text-decoration:none; font-weight:600}
    .btn.primary{background:linear-gradient(135deg,var(--morado),var(--accent)); border-color:transparent}
    .btn:hover{transform:translateY(-2px)}

    .logo-wrap{ position:relative; isolation:isolate; }
    .glow{ position:absolute; inset: -40px -40px; background:radial-gradient(500px 260px at 60% 25%, rgba(124,58,237,.35), transparent 60%); filter:blur(40px); z-index:-1; opacity:.8}
    .logo{
      width:100%; aspect-ratio:3/1; object-fit:contain; filter:drop-shadow(0 10px 24px rgba(124,58,237,.35));
      animation: float 6s ease-in-out infinite;
    }
    @keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

    /* ======= Sections ======= */
    section{padding:86px 0}
    .wrap{width:min(1140px,92%); margin:0 auto}
    .title{font-size:clamp(28px,3.4vw,42px); margin:0 0 12px}
    .lead{color:var(--muted); max-width:840px}

    /* Servicios grid */
    .services{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:26px}
    @media(max-width:960px){.services{grid-template-columns:1fr 1fr}}
    @media(max-width:640px){.services{grid-template-columns:1fr}}
    .srv{
      position:relative; overflow:hidden; border-radius:18px; background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00));
      border:1px solid rgba(139,92,246,.25); padding:22px 20px 20px 20px; min-height:160px; transition:.35s ease; isolation:isolate
    }
    .srv:hover{transform:translateY(-4px); box-shadow:var(--shadow);}
    .srv i{font-size:24px; width:42px; height:42px; display:grid; place-items:center; border-radius:12px; background:rgba(139,92,246,.12); border:1px solid rgba(139,92,246,.35); margin-bottom:12px}
    .srv h3{margin:4px 0 8px; font-size:20px}
    .srv p{margin:0; color:var(--muted)}
    .srv .corner{position:absolute; right:-40px; top:-40px; width:120px; height:120px; background:radial-gradient(60px 60px at 50% 50%, rgba(124,58,237,.4), transparent 60%); filter:blur(30px); opacity:.6; z-index:-1}

    /* IA / Branding blocks */
    .flex2{display:grid; grid-template-columns:1.1fr .9fr; gap:18px}
    @media(max-width:980px){.flex2{grid-template-columns:1fr}}
    .block{
      border:1px solid rgba(124,58,237,.25); border-radius:18px; padding:28px; background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.0)); box-shadow:var(--shadow)
    }
    .block ul{margin:12px 0 0 0; padding:0; list-style:none; display:grid; gap:10px}
    .block li{display:flex; align-items:start; gap:10px; color:#dcd5ff}
    .block li i{color:var(--ok); margin-top:3px}

    /* Portfolio */
    .grid-portfolio{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
    @media(max-width:900px){.grid-portfolio{grid-template-columns:1fr 1fr}}
    @media(max-width:560px){.grid-portfolio{grid-template-columns:1fr}}
    .shot{position:relative; padding-top:62%; border-radius:16px; overflow:hidden; background:linear-gradient(135deg,#1a1724,#0f0f14); border:1px solid rgba(139,92,246,.25)}
    .shot::after{content:"Demo"; position:absolute; bottom:10px; right:14px; font-size:12px; letter-spacing:.2em; color:#b6a8ff; opacity:.85}
    .shot .shine{position:absolute; inset:0; background:linear-gradient(120deg, transparent 35%, rgba(255,255,255,.08) 50%, transparent 65%); transform:skewX(-20deg) translateX(-120%);}
    .shot:hover .shine{transition:transform .8s ease; transform:skewX(-20deg) translateX(120%)}

    /* Testimonios */
    .testis{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
    @media(max-width:980px){.testis{grid-template-columns:1fr 1fr}}
    @media(max-width:640px){.testis{grid-template-columns:1fr}}
    .t{border:1px solid rgba(139,92,246,.25); border-radius:16px; padding:22px; background:#12121a}
    .t .who{display:flex; align-items:center; gap:12px; margin-top:12px; color:#d6ccff}

    /* Footer */
    footer{padding:46px 0 70px; border-top:1px solid rgba(139,92,246,.25); background:linear-gradient(180deg, rgba(139,92,246,.08), rgba(139,92,246,.02))}
    .foot{display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:18px}
    @media(max-width:980px){.foot{grid-template-columns:1fr 1fr}} @media(max-width:640px){.foot{grid-template-columns:1fr}}
    .mini{color:var(--muted); font-size:14px}

    /* Scroll reveal */
    .reveal{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease}
    .reveal.show{opacity:1; transform:none}

    /* Partículas de fondo */
    #stars{position:fixed; inset:0; z-index:-2}

    /* Utilidades */
    .pill{display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px; border:1px solid rgba(139,92,246,.25); background:rgba(139,92,246,.08); color:#dcd5ff; font-weight:600}
    .sep{height:1px; background:linear-gradient(90deg, transparent, rgba(139,92,246,.35), transparent); margin:26px 0}
/* Inputs */
    .inp{background:#0f0f16; border:1px solid rgba(139,92,246,.35); color:var(--texto); padding:14px 12px; border-radius:12px; outline:none; transition:border .25s ease, box-shadow .25s ease}
    .inp:focus{border-color:var(--accent); box-shadow:0 0 0 4px rgba(139,92,246,.18)}
.shot img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
