/* ===== Dinámica Tecnológica — Edición cinematográfica 2026 ===== */
:root{
  --bg:#05060A;
  --bg-2:#0A0C14;
  --panel:#0E1119;
  --ink:#F4F6FB;
  --muted:#9AA3B6;
  --line:rgba(255,255,255,.10);
  --blue:#2D6BFF;
  --cyan:#36E0FF;
  --violet:#8B5CFF;
  --maxw:1200px;
  --font:'Plus Jakarta Sans',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--bg);color:var(--ink)}
body{font-family:var(--font);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}
h1,h2,h3,h4{line-height:1.05;letter-spacing:-.03em;font-weight:800}
a{color:inherit;text-decoration:none}
section{position:relative}

.kicker{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;color:var(--cyan);margin-bottom:20px}
.grad{background:linear-gradient(100deg,var(--cyan),var(--blue) 55%,var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}
.dark-h{color:var(--ink)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:.95rem;padding:14px 30px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.25s ease;font-family:inherit;letter-spacing:.01em}
.btn-light{background:#fff;color:#05060A}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 16px 40px -12px rgba(255,255,255,.4)}
.btn-light.full{width:100%}
.btn-outline{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.28);backdrop-filter:blur(8px)}
.btn-outline:hover{background:rgba(255,255,255,.14)}
.btn-pill{background:var(--blue);color:#fff;padding:11px 22px;font-size:.88rem}
.btn-pill:hover{background:#1b58f0;transform:translateY(-1px)}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:.35s ease;border-bottom:1px solid transparent}
.site-header.solid{background:rgba(5,6,10,.72);backdrop-filter:blur(16px);border-bottom-color:var(--line)}
.header-inner{display:flex;align-items:center;gap:24px;height:72px}
.brand{display:flex;align-items:center;gap:11px;color:#fff;font-weight:800}
.brand-mark{color:var(--cyan);display:flex}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text strong{font-size:1.08rem}
.brand-text span{font-size:.66rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.main-nav{display:flex;gap:32px;margin-left:auto;font-weight:500;font-size:.92rem}
.main-nav a{color:rgba(255,255,255,.82);transition:.2s}
.main-nav a:hover{color:#fff}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.25s}

/* ---------- Aurora / FX ---------- */
.aurora{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}
.aurora span{position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;mix-blend-mode:screen;animation:float 18s ease-in-out infinite}
.aurora span:nth-child(1){width:46vw;height:46vw;background:var(--blue);top:-10%;left:-6%}
.aurora span:nth-child(2){width:40vw;height:40vw;background:var(--violet);top:10%;right:-10%;animation-delay:-6s}
.aurora span:nth-child(3){width:34vw;height:34vw;background:var(--cyan);bottom:-14%;left:30%;animation-delay:-11s}
.aurora.soft span{opacity:.32}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(4%,6%) scale(1.12)}66%{transform:translate(-5%,-4%) scale(.94)}}
.grid-overlay{position:absolute;inset:0;z-index:0;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:54px 54px;-webkit-mask-image:radial-gradient(120% 80% at 50% 30%,#000,transparent 75%);mask-image:radial-gradient(120% 80% at 50% 30%,#000,transparent 75%)}

/* ---------- (Snap retirado: navegación por anclas más fiable) ---------- */
html{scroll-padding-top:72px}

/* ---------- Hero ---------- */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 0 90px;overflow:hidden}
.hero-content{position:relative;z-index:2;max-width:920px;padding:0 28px}
.hero h1{font-size:clamp(2.6rem,7.4vw,6rem);letter-spacing:-.04em}
.hero-sub{font-size:clamp(1.05rem,1.7vw,1.32rem);color:var(--muted);max-width:680px;margin:26px auto 38px;font-weight:400}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.scroll-cue span{width:22px;height:36px;border:1.5px solid rgba(255,255,255,.3);border-radius:12px;position:relative}
.scroll-cue span::after{content:"";position:absolute;top:7px;left:50%;width:3px;height:7px;background:#fff;border-radius:2px;transform:translateX(-50%);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}

/* ---------- Showcase (Tesla-style slides) ---------- */
.showcase{min-height:100vh;display:flex;align-items:center;overflow:hidden;border-top:1px solid var(--line)}
.showcase-bg{position:absolute;inset:0;z-index:0}
.sc-ia .showcase-bg{background:radial-gradient(80% 90% at 78% 30%,rgba(139,92,255,.35),transparent 60%),radial-gradient(70% 80% at 18% 80%,rgba(45,107,255,.30),transparent 60%),var(--bg)}
.sc-renting .showcase-bg{background:radial-gradient(80% 90% at 20% 25%,rgba(54,224,255,.26),transparent 60%),radial-gradient(70% 80% at 85% 75%,rgba(45,107,255,.30),transparent 60%),var(--bg-2)}
.sc-cloud .showcase-bg{background:radial-gradient(85% 90% at 75% 75%,rgba(54,224,255,.30),transparent 60%),radial-gradient(70% 70% at 15% 20%,rgba(139,92,255,.22),transparent 60%),var(--bg)}
.sc-itil .showcase-bg{background:radial-gradient(80% 90% at 50% 20%,rgba(45,107,255,.34),transparent 62%),radial-gradient(60% 70% at 80% 90%,rgba(54,224,255,.20),transparent 60%),var(--bg-2)}
.ghost-word{position:absolute;right:2vw;bottom:-4vh;z-index:0;font-size:28vw;font-weight:800;letter-spacing:-.05em;line-height:.8;color:rgba(255,255,255,.04);user-select:none;pointer-events:none}
.showcase-content{position:relative;z-index:2;max-width:680px;padding:0 28px;margin:0 auto;width:100%;max-width:var(--maxw)}
.showcase-content .kicker{color:var(--cyan)}
.showcase h2{font-size:clamp(2rem,5.4vw,4.4rem)}
.showcase-sub{font-size:clamp(1rem,1.5vw,1.22rem);color:#C6CDDD;max-width:560px;margin:22px 0 32px;font-weight:400}

/* ---------- Más servicios ---------- */
.services{padding:120px 0;background:var(--bg)}
.section-head{max-width:760px;margin:0 auto 60px}
.section-head.center{text-align:center}
.section-head h2{font-size:clamp(1.9rem,3.6vw,3rem)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service-card{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:20px;padding:34px 30px;transition:.3s}
.service-card:hover{transform:translateY(-6px);border-color:rgba(54,224,255,.45);background:linear-gradient(180deg,rgba(54,224,255,.08),rgba(255,255,255,.02))}
.svc-n{font-size:.85rem;font-weight:700;color:var(--cyan);letter-spacing:.1em;margin-bottom:18px}
.service-card h3{font-size:1.4rem;margin-bottom:12px}
.service-card p{color:var(--muted);font-size:.98rem;font-weight:400}

/* ---------- Experiencia ---------- */
.experience{padding:130px 0;overflow:hidden;border-top:1px solid var(--line)}
.exp-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.exp-copy h2{font-size:clamp(1.9rem,3.6vw,3rem);margin-bottom:22px}
.exp-copy p{color:var(--muted);margin-bottom:28px;font-weight:400;font-size:1.05rem}
.counters{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.counter{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:18px;padding:30px 26px}
.counter strong{display:block;font-size:clamp(2.4rem,4vw,3.4rem);line-height:1;background:linear-gradient(100deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.counter span{display:block;margin-top:10px;font-size:.92rem;color:var(--muted)}

/* ---------- Casos ---------- */
.cases{padding:120px 0;background:var(--bg-2)}
.cases-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.case{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:18px;height:130px;display:flex;align-items:center;justify-content:center;transition:.3s}
.case:hover{transform:translateY(-5px);background:rgba(255,255,255,.08);border-color:rgba(54,224,255,.4)}
.case span{font-weight:700;font-size:1.2rem}
.cases-note{text-align:center;color:var(--muted);margin:30px 0 50px}
.partner-strip{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}
.partner-strip span{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:999px;padding:11px 24px;font-weight:600;color:#C6CDDD;font-size:.92rem}

/* ---------- Sectores ---------- */
.sectors{padding:120px 0;border-top:1px solid var(--line)}
.sectors-inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.sectors-copy h2{font-size:clamp(1.8rem,3.2vw,2.7rem);margin-bottom:18px}
.sectors-copy p{color:var(--muted);font-weight:400}
.sectors-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sectors-list li{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:14px;padding:18px 22px;font-weight:600;position:relative;padding-left:44px}
.sectors-list li::before{content:"";position:absolute;left:20px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 12px var(--cyan)}

/* ---------- CTA ---------- */
.cta-band{padding:150px 0;text-align:center;overflow:hidden;border-top:1px solid var(--line)}
.cta-inner{position:relative;z-index:2}
.cta-inner h2{font-size:clamp(2rem,4.6vw,3.6rem)}
.cta-inner .btn{margin-top:34px}

/* ---------- Contacto ---------- */
.contact{padding:120px 0;background:var(--bg-2);border-top:1px solid var(--line)}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.contact-info h2{font-size:clamp(1.8rem,3.2vw,2.6rem);margin-bottom:30px}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:20px;margin-bottom:30px}
.contact-list li{display:flex;flex-direction:column;gap:4px}
.contact-list span{font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:700}
.contact-list a{color:var(--cyan);font-weight:600}
.social{display:flex;gap:22px;font-weight:600}
.social a{color:var(--muted)}
.social a:hover{color:#fff}
.contact-form{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:22px;padding:36px;display:flex;flex-direction:column;gap:16px}
.contact-form label{display:flex;flex-direction:column;gap:7px;font-weight:600;font-size:.88rem}
.contact-form input,.contact-form textarea{font-family:inherit;font-size:.96rem;padding:13px 15px;border:1px solid var(--line);border-radius:12px;background:rgba(0,0,0,.3);color:#fff;resize:vertical}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--cyan)}
.form-note{font-size:.76rem;color:var(--muted);font-weight:400}

/* ---------- Footer ---------- */
.site-footer{background:var(--bg);padding-top:70px;border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;padding-bottom:44px}
.footer-brand .brand-text strong{font-size:1.2rem}
.footer-brand p{margin-top:12px;font-size:.92rem;color:var(--muted);max-width:300px;font-weight:400}
.footer-legal-id{font-size:.8rem!important;color:#697086!important}
.footer-col h4{font-size:.92rem;margin-bottom:16px}
.footer-col a{display:block;color:var(--muted);font-size:.9rem;padding:6px 0;transition:.2s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding:24px 28px 30px;font-size:.84rem;color:#697086}
.footer-bottom-legal:hover{color:#fff}

/* ---------- WhatsApp float ---------- */
.wa-float{position:fixed;right:22px;bottom:22px;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px -6px rgba(37,211,102,.6);z-index:90;transition:.2s}
.wa-float:hover{transform:scale(1.08)}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s cubic-bezier(.16,.84,.44,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}.aurora span{animation:none}.scroll-cue span::after{animation:none}}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .services-grid{grid-template-columns:1fr}
  .exp-inner,.sectors-inner,.contact-inner{grid-template-columns:1fr;gap:40px}
  .cases-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .main-nav,.header-cta{display:none}
  .main-nav.open{display:flex;position:fixed;top:72px;left:0;right:0;flex-direction:column;background:rgba(5,6,10,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);padding:22px 28px;gap:20px}
  .nav-toggle{display:flex;margin-left:auto}
  .counters,.sectors-list{grid-template-columns:1fr}
  .cases-grid{grid-template-columns:1fr 1fr}
  .footer-grid,.footer-bottom{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
  .ghost-word{font-size:40vw;bottom:2vh}
  section,.services,.experience,.cases,.sectors,.contact,.cta-band{padding-top:90px;padding-bottom:90px}
}
