/* ===================================================================
   JyA Security — Design System
   =================================================================== */
:root{
  /* brand */
  --green:#39e75f;
  --green-soft:#7cf79a;
  --cyan:#1ea7ff;
  --cyan-soft:#6fd0ff;
  --silver:#c8d3dd;

  /* surfaces */
  --bg:#05070a;
  --bg-2:#080b11;
  --bg-3:#0c111a;
  --card:rgba(255,255,255,.025);
  --card-brd:rgba(255,255,255,.08);
  --card-brd-hi:rgba(57,231,95,.45);

  /* text — contraste corregido (WCAG AA) */
  --text:#e8eef4;
  --muted:#94a1b2;
  --muted-2:#7a8696;
  --danger:#ff6b6b;

  /* fx */
  --grad:linear-gradient(135deg,var(--cyan),var(--green));
  --grad-green:linear-gradient(135deg,var(--green-soft),var(--green));
  --glow-green:0 0 40px rgba(57,231,95,.25);
  --glow-cyan:0 0 40px rgba(30,167,255,.25);

  /* elevación */
  --sh-1:0 8px 24px rgba(0,0,0,.35);
  --sh-2:0 18px 44px rgba(0,0,0,.45);
  --sh-3:0 30px 80px rgba(0,0,0,.6);

  --radius:16px;
  --radius-lg:24px;
  --radius-sm:12px;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);

  --font:'Inter',system-ui,sans-serif;
  --display:'Space Grotesk',var(--font);
  --mono:'JetBrains Mono',ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  position:relative;
}

/* ambient color blobs */
body::before,body::after{
  content:"";position:fixed;z-index:-3;border-radius:50%;
  filter:blur(120px);opacity:.5;pointer-events:none;
}
body::before{width:600px;height:600px;top:-200px;right:-150px;
  background:radial-gradient(circle,rgba(30,167,255,.25),transparent 70%)}
body::after{width:650px;height:650px;bottom:-250px;left:-200px;
  background:radial-gradient(circle,rgba(57,231,95,.18),transparent 70%)}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ---------- background canvas + grid ---------- */
#net-canvas{position:fixed;inset:0;z-index:-2;pointer-events:none}
.grid-overlay{
  position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.4;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 90% 60% at 50% 0%,#000 30%,transparent 80%);
}

/* ---------- cursor glow ---------- */
.cursor-glow{
  position:fixed;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(57,231,95,.10),transparent 65%);
  transform:translate(-50%,-50%);left:50%;top:30%;
  z-index:-1;pointer-events:none;transition:opacity .4s;
}
@media (hover:none){.cursor-glow{display:none}}

/* ---------- scroll progress ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;z-index:100;
  background:var(--grad);box-shadow:var(--glow-green);
}

/* ===================================================================
   NAV
   =================================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(18px,5vw,48px);
  transition:.4s var(--ease);
}
.nav.scrolled{
  background:rgba(5,7,10,.72);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--card-brd);
  padding-top:12px;padding-bottom:12px;
}
.nav__brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:700;font-size:1.35rem;letter-spacing:.5px}
.nav__logo{width:42px;height:42px;object-fit:contain;filter:drop-shadow(0 0 12px rgba(57,231,95,.35))}
.nav__name .accent{color:var(--green)}
.nav__links{display:flex;align-items:center;gap:28px;font-size:.95rem;font-weight:500}
.nav__links a{color:var(--muted);transition:color .25s;position:relative}
.nav__links a:not(.nav__cta):hover{color:var(--text)}
.nav__links a:not(.nav__cta)::after{
  content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;
  background:var(--grad);transition:width .3s var(--ease)}
.nav__links a:not(.nav__cta):hover::after{width:100%}
.nav__cta{
  padding:9px 18px;border-radius:999px;color:var(--bg)!important;font-weight:600;
  background:var(--grad-green);box-shadow:var(--glow-green);transition:transform .25s,box-shadow .25s}
.nav__cta:hover{transform:translateY(-2px);box-shadow:0 0 50px rgba(57,231,95,.5)}
.nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav__toggle span{width:26px;height:2px;background:var(--text);border-radius:2px;transition:.3s}

/* ===================================================================
   HERO
   =================================================================== */
.hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding:140px clamp(18px,5vw,48px) 80px;position:relative;
}
.hero__inner{max-width:920px}
.hero__badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 18px;border-radius:999px;font-size:.85rem;color:var(--silver);
  border:1px solid var(--card-brd);background:var(--card);backdrop-filter:blur(8px);margin-bottom:28px}
.pulse-dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(57,231,95,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(57,231,95,.5)}70%{box-shadow:0 0 0 12px rgba(57,231,95,0)}100%{box-shadow:0 0 0 0 rgba(57,231,95,0)}}

.hero__title{
  font-family:var(--display);font-weight:700;letter-spacing:-.03em;
  font-size:clamp(2.4rem,6vw,4.6rem);line-height:1.05;margin-bottom:26px}
.hero__sub{font-size:clamp(1rem,1.6vw,1.2rem);color:var(--muted);max-width:680px;margin:0 auto 38px}
.hero__sub strong{color:var(--text);font-weight:600}

.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% auto;animation:shimmer 6s linear infinite}
.grad-text--green{background:var(--grad-green);-webkit-background-clip:text;background-clip:text}
@keyframes shimmer{to{background-position:200% center}}

.hero__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:64px}

.btn{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:1rem;
  padding:14px 28px;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .25s var(--ease),box-shadow .25s,background .25s,border-color .25s;font-family:var(--font)}
.btn--primary{background:var(--grad-green);color:var(--bg);box-shadow:var(--glow-green)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(57,231,95,.45)}
.btn--primary svg{transition:transform .25s}
.btn--primary:hover svg{transform:translateX(4px)}
.btn--ghost{background:var(--card);border-color:var(--card-brd);color:var(--text)}
.btn--ghost:hover{border-color:var(--green);transform:translateY(-3px);box-shadow:var(--glow-green)}
.btn--block{width:100%;justify-content:center;margin-top:8px}

.hero__stats{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:760px;margin:0 auto}
.hero__stats li{display:flex;flex-direction:column;align-items:center}
.stat__num{font-family:var(--display);font-weight:700;font-size:clamp(2rem,4vw,3rem);letter-spacing:-.02em;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.stat__suffix{font-family:var(--display);font-weight:700;font-size:1.4rem;color:var(--green);margin-top:-6px}
.stat__label{font-size:.78rem;color:var(--muted-2);margin-top:8px;max-width:140px;text-align:center}

.hero__scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--muted-2);font-size:.7rem;letter-spacing:2px;text-transform:uppercase}
.hero__scroll-line{width:1px;height:46px;background:linear-gradient(var(--green),transparent);position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:var(--green);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{transform:translateY(-100%)}100%{transform:translateY(250%)}}

/* ===================================================================
   MARQUEE
   =================================================================== */
.marquee{overflow:hidden;border-top:1px solid var(--card-brd);border-bottom:1px solid var(--card-brd);
  background:rgba(255,255,255,.012);padding:18px 0;white-space:nowrap;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:inline-flex;gap:34px;animation:marquee 40s linear infinite;font-family:var(--display);font-weight:600;font-size:1rem;letter-spacing:1px;color:var(--muted)}
.marquee__track span:nth-child(odd){color:var(--text)}
.marquee__track span:nth-child(even){color:var(--green)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ===================================================================
   SECTIONS
   =================================================================== */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(70px,10vw,130px) clamp(18px,5vw,48px)}
.section__head{max-width:720px;margin:0 auto 60px;text-align:center}
.eyebrow{font-family:var(--mono);font-size:.78rem;font-weight:500;color:var(--green);
  text-transform:uppercase;letter-spacing:.14em}
.section__title{font-family:var(--display);font-weight:700;letter-spacing:-.02em;
  font-size:clamp(1.9rem,4.5vw,3.1rem);line-height:1.1;margin:16px 0 20px}
/* el degradado animado (shimmer) solo en el hero; en secciones es estático para jerarquía */
.section__title .grad-text,.section__title .grad-text--green{animation:none}
.section__lead{color:var(--muted);font-size:1.05rem}

/* ---------- cards ---------- */
.cards{display:flex;flex-wrap:wrap;justify-content:center;gap:22px}
.card{
  --accent:var(--green);
  flex:1 1 300px;max-width:362px;
  position:relative;padding:30px 26px;border-radius:var(--radius);
  background:var(--card);border:1px solid var(--card-brd);
  display:flex;flex-direction:column;
  backdrop-filter:blur(6px);overflow:hidden;cursor:pointer;
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
/* accent gradient border on hover */
.card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%),
            color-mix(in srgb,var(--accent) 60%,transparent),transparent 42%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .35s}
/* soft accent wash that fades in from the corner */
.card::after{
  content:"";position:absolute;top:-40%;right:-40%;width:75%;height:75%;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--accent) 22%,transparent),transparent 70%);
  opacity:0;transition:opacity .45s;pointer-events:none}
.card:hover{transform:translateY(-7px);
  border-color:color-mix(in srgb,var(--accent) 55%,transparent);
  box-shadow:0 22px 55px rgba(0,0,0,.55),0 0 38px color-mix(in srgb,var(--accent) 28%,transparent)}
.card:hover::before,.card:hover::after{opacity:1}

/* sweeping scan line */
.card__scan{position:absolute;left:0;right:0;top:0;height:2px;pointer-events:none;opacity:0;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  box-shadow:0 0 14px var(--accent);transition:opacity .3s}
.card:hover .card__scan{opacity:.9;animation:scan 1.5s var(--ease) infinite}
@keyframes scan{0%{top:0}100%{top:100%}}

.card__icon{width:62px;height:62px;display:grid;place-items:center;border-radius:14px;color:var(--accent);
  background:color-mix(in srgb,var(--accent) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);margin-bottom:18px;
  transition:transform .4s var(--ease),box-shadow .4s}
.card:hover .card__icon{transform:translateY(-2px) scale(1.05);box-shadow:0 0 26px color-mix(in srgb,var(--accent) 35%,transparent)}
.card__icon svg{width:34px;height:34px}
.card__icon svg [data-spin]{transform-origin:center;animation:spin 8s linear infinite}
.card__icon svg [data-pulse]{animation:iconpulse 2.4s var(--ease) infinite}
.card__icon svg [data-draw]{stroke-dasharray:60;stroke-dashoffset:60;animation:draw 2.6s var(--ease) infinite alternate}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes iconpulse{0%,100%{opacity:.35;transform:scale(.9)}50%{opacity:1;transform:scale(1.08)}}
@keyframes draw{to{stroke-dashoffset:0}}
@media (prefers-reduced-motion:reduce){.card__icon svg *{animation:none!important}.card:hover .card__scan{animation:none}}

.card h3{font-family:var(--display);font-size:1.2rem;line-height:1.25;letter-spacing:-.01em;margin-bottom:10px}
.card p{color:var(--muted);font-size:.95rem;margin-bottom:18px}
.card__tags{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.card__tags li{font-family:var(--mono);font-size:.72rem;color:color-mix(in srgb,var(--accent) 80%,#fff);
  padding:4px 10px;border-radius:999px;
  background:color-mix(in srgb,var(--accent) 10%,transparent);
  border:1px solid color-mix(in srgb,var(--accent) 25%,transparent)}
.card__more{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:var(--accent);
  margin-top:auto;align-self:flex-start;padding:9px 16px;border-radius:999px;
  border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);
  background:color-mix(in srgb,var(--accent) 8%,transparent);transition:background .25s,border-color .25s,color .25s}
.card:hover .card__more{background:color-mix(in srgb,var(--accent) 16%,transparent);border-color:color-mix(in srgb,var(--accent) 55%,transparent)}
.card__more i{font-style:normal;transition:transform .25s}
.card:hover .card__more i{transform:translateX(4px)}
.card--feature{background:linear-gradient(160deg,color-mix(in srgb,var(--accent) 9%,transparent),rgba(30,167,255,.04))}
.card__ribbon{position:absolute;top:16px;right:-34px;transform:rotate(45deg);z-index:2;
  background:var(--grad-green);color:var(--bg);font-size:.7rem;font-weight:700;padding:4px 40px}

/* ---------- boxes (modelos) ---------- */
.boxes{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}
.box{padding:30px 26px;border-radius:var(--radius);background:var(--card);border:1px solid var(--card-brd);transition:transform .35s var(--ease),border-color .35s}
.box:hover{transform:translateY(-6px);border-color:var(--card-brd-hi)}
.box__tag{display:inline-block;font-family:var(--mono);font-size:.75rem;padding:5px 12px;border-radius:999px;
  background:#0d0f12;border:1px solid #1c2128;color:var(--text);margin-bottom:16px}
.box__tag--gray{color:var(--silver);border-color:#2b333d}
.box__tag--white{color:#fff;border-color:#3a4450;background:#11151b}
.box h3{font-family:var(--display);font-size:1.2rem;line-height:1.25;letter-spacing:-.01em;margin-bottom:10px}
.box p{color:var(--muted);font-size:.93rem;margin-bottom:20px;min-height:62px}
.box__bar{height:8px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden;margin-bottom:10px}
.box__bar i{display:block;height:100%;width:0;border-radius:999px;background:var(--grad-green);box-shadow:var(--glow-green);transition:width 1.4s var(--ease)}
.box.in-view .box__bar i{width:var(--w)}
.box small{color:var(--muted-2);font-family:var(--mono);font-size:.75rem}

/* ---------- timeline ---------- */
.timeline{list-style:none;max-width:760px;margin:0 auto;position:relative;padding-left:8px}
.timeline::before{content:"";position:absolute;left:32px;top:10px;bottom:10px;width:2px;
  background:linear-gradient(var(--cyan),var(--green),transparent)}
.timeline li{position:relative;display:flex;gap:26px;padding:18px 0 18px 0;align-items:flex-start}
.timeline__num{flex:0 0 auto;width:64px;height:64px;display:grid;place-items:center;border-radius:50%;
  font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--green);
  background:var(--bg-2);border:1px solid var(--card-brd-hi);box-shadow:var(--glow-green);z-index:1}
.timeline h3{font-family:var(--display);font-size:1.2rem;margin-bottom:6px;margin-top:14px}
.timeline p{color:var(--muted);font-size:.95rem}

/* ---------- features ---------- */
.features{display:flex;flex-wrap:wrap;justify-content:center;gap:22px}
.feature{flex:1 1 300px;max-width:362px;padding:28px 24px;border-radius:var(--radius);background:var(--card);border:1px solid var(--card-brd);transition:transform .35s var(--ease),border-color .35s}
.feature:hover{transform:translateY(-5px);border-color:var(--card-brd-hi)}
.feature__ic{width:50px;height:50px;display:grid;place-items:center;border-radius:14px;color:var(--green);
  background:color-mix(in srgb,var(--green) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--green) 28%,transparent);margin-bottom:16px}
.feature__ic svg{width:26px;height:26px}
.feature h3{font-family:var(--display);font-size:1.2rem;line-height:1.25;letter-spacing:-.01em;margin-bottom:8px}
.feature p{color:var(--muted);font-size:.92rem}

/* ---------- CTA / form ---------- */
.cta__card{max-width:760px;margin:0 auto;text-align:center;padding:clamp(34px,5vw,60px);
  border-radius:var(--radius-lg);background:linear-gradient(160deg,rgba(30,167,255,.07),rgba(57,231,95,.05));
  border:1px solid var(--card-brd-hi);box-shadow:var(--glow-green)}
.form{margin-top:34px;text-align:left}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:end}
.form label{display:flex;flex-direction:column;gap:8px;font-size:.85rem;color:var(--muted);margin-bottom:16px;font-weight:500}
.form input,.form select,.form textarea{
  width:100%;height:48px;font-family:var(--font);font-size:.95rem;line-height:1.4;color:var(--text);
  padding:12px 14px;border-radius:12px;background:rgba(0,0,0,.35);
  border:1px solid var(--card-brd);transition:border-color .25s,box-shadow .25s;outline:none;box-sizing:border-box}
.form textarea{height:auto;resize:vertical}
.form select{
  -webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;padding-right:40px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238a97a8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(57,231,95,.15)}
.form select option{background:#0c111a}
.form__note{margin-top:14px;font-size:.9rem;text-align:center;min-height:20px}
.form__note.ok{color:var(--green)}
.form__note.err{color:var(--danger)}

/* ===================================================================
   FOOTER
   =================================================================== */
.footer{border-top:1px solid var(--card-brd);background:var(--bg-2);padding:60px clamp(18px,5vw,48px) 30px;margin-top:40px}
.footer__top{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--card-brd)}
.footer__brand img{width:54px;margin-bottom:16px;filter:drop-shadow(0 0 12px rgba(57,231,95,.3))}
.footer__brand p{color:var(--muted);font-size:.92rem}
.footer__col h4{font-family:var(--display);font-size:1rem;margin-bottom:16px}
.footer__col a{display:block;color:var(--muted);font-size:.9rem;margin-bottom:10px;transition:color .25s}
.footer__col a:hover{color:var(--green)}
.footer__bottom{max-width:var(--maxw);margin:24px auto 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--muted-2);font-size:.82rem}

.mono{font-family:var(--mono)}

/* ===================================================================
   MODAL — detalle de servicio
   =================================================================== */
.modal{position:fixed;inset:0;z-index:120;display:flex;align-items:center;justify-content:center;
  padding:24px;visibility:hidden;opacity:0;transition:opacity .35s var(--ease),visibility .35s}
.modal.open{visibility:visible;opacity:1}
.modal__overlay{position:absolute;inset:0;background:rgba(2,4,7,.72);backdrop-filter:blur(8px)}
.modal__panel{--accent:var(--green);position:relative;z-index:1;width:min(720px,100%);max-height:88vh;overflow-y:auto;
  background:linear-gradient(165deg,#0c1119,#080b11);border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);
  border-radius:22px;padding:clamp(26px,4vw,40px);
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 60px color-mix(in srgb,var(--accent) 22%,transparent);
  transform:translateY(24px) scale(.97);opacity:0;transition:transform .4s var(--ease),opacity .4s}
.modal.open .modal__panel{transform:none;opacity:1}
.modal__glow{position:absolute;top:-60px;right:-60px;width:220px;height:220px;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,color-mix(in srgb,var(--accent) 35%,transparent),transparent 70%)}
.modal__close{position:absolute;top:16px;right:18px;width:40px;height:40px;border-radius:12px;cursor:pointer;
  background:rgba(255,255,255,.04);border:1px solid var(--card-brd);color:var(--text);font-size:1.5rem;line-height:1;
  transition:.25s;z-index:2}
.modal__close:hover{border-color:var(--accent);color:var(--accent);transform:rotate(90deg)}
.modal__head{display:flex;gap:20px;align-items:center;margin-bottom:26px;padding-right:40px}
.modal__icon{flex:0 0 auto;width:74px;height:74px;display:grid;place-items:center;border-radius:18px;color:var(--accent);
  background:color-mix(in srgb,var(--accent) 14%,transparent);border:1px solid color-mix(in srgb,var(--accent) 32%,transparent)}
.modal__icon svg{width:42px;height:42px}
.modal__eyebrow{font-family:var(--mono);font-size:.78rem;color:var(--accent)}
.modal__title{font-family:var(--display);font-size:clamp(1.4rem,3vw,1.9rem);line-height:1.1;margin:4px 0 6px}
.modal__tagline{color:var(--muted);font-size:.95rem}
.modal__body{display:grid;grid-template-columns:1fr 1fr;gap:22px 30px;margin-bottom:28px}
.modal__body .modal__col:first-child{grid-column:1 / -1}
.modal__col h4{font-family:var(--display);font-size:.95rem;margin-bottom:12px;display:flex;align-items:center;gap:9px;color:var(--text)}
.modal__col h4 .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent)}
.modal__list{list-style:none;display:grid;gap:9px}
.modal__list li{position:relative;padding-left:24px;color:var(--muted);font-size:.92rem;line-height:1.5}
.modal__list li::before{content:"";position:absolute;left:4px;top:.55em;width:8px;height:8px;border:1.5px solid var(--accent);
  border-bottom:0;border-left:0;transform:rotate(45deg);border-radius:1px}
.modal__chips{list-style:none;display:flex;flex-wrap:wrap;gap:8px;align-content:flex-start}
.modal__chips li{font-family:var(--mono);font-size:.74rem;padding:5px 11px;border-radius:999px;
  color:color-mix(in srgb,var(--accent) 85%,#fff);
  background:color-mix(in srgb,var(--accent) 10%,transparent);
  border:1px solid color-mix(in srgb,var(--accent) 26%,transparent)}
.modal__foot{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding-top:22px;border-top:1px solid var(--card-brd)}
.modal__foot .btn--primary{background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 78%,#fff),var(--accent));
  color:#04070b;box-shadow:0 0 30px color-mix(in srgb,var(--accent) 35%,transparent)}
.modal__meta{color:var(--muted-2);font-size:.78rem}
body.modal-open{overflow:hidden}
@media (max-width:560px){.modal__body{grid-template-columns:1fr}.modal__body .modal__col:first-child{grid-column:auto}}
@media (prefers-reduced-motion:reduce){.modal,.modal__panel{transition:none}.modal__close:hover{transform:none}}

/* ===================================================================
   REVEAL ANIMATION
   =================================================================== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in-view{opacity:1;transform:none}
.cards .reveal.in-view,.features .reveal.in-view,.boxes .reveal.in-view{transition-delay:var(--d,0s)}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.grad-text{animation:none}.marquee__track{animation:none}}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:860px){
  .nav__links{position:fixed;inset:0 0 0 auto;width:min(82vw,320px);flex-direction:column;justify-content:center;align-items:flex-start;
    gap:28px;padding:40px;background:rgba(8,11,17,.96);backdrop-filter:blur(20px);
    border-left:1px solid var(--card-brd);transform:translateX(100%);transition:transform .4s var(--ease);font-size:1.2rem}
  .nav__links.open{transform:none}
  .nav__toggle{display:flex;z-index:70}
  .nav__toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__toggle.open span:nth-child(2){opacity:0}
  .nav__toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .hero__stats{grid-template-columns:repeat(2,1fr);gap:30px}
  .footer__top{grid-template-columns:1fr 1fr}
}
@media (max-width:520px){
  .form__row{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .timeline__num{width:52px;height:52px;font-size:.95rem}
  .timeline::before{left:26px}
}

/* ===================================================================
   TRUST STRIP — certificaciones & marcos
   =================================================================== */
.trust{border-bottom:1px solid var(--card-brd);background:rgba(255,255,255,.012);padding:34px clamp(18px,5vw,48px)}
.trust__inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:40px}
.trust__group h4{font-family:var(--mono);font-size:.78rem;color:var(--muted-2);letter-spacing:1px;margin-bottom:16px;text-transform:uppercase}
.trust__badges{display:flex;flex-wrap:wrap;gap:10px}
.badge{font-family:var(--mono);font-size:.82rem;font-weight:500;color:var(--silver);
  padding:7px 14px;border-radius:10px;background:rgba(255,255,255,.025);border:1px solid var(--card-brd);
  transition:transform .25s var(--ease),border-color .25s,color .25s}
.badge:hover{transform:translateY(-3px);border-color:var(--card-brd-hi);color:#fff;box-shadow:var(--glow-green)}
.badge--fw:hover{border-color:rgba(30,167,255,.5);box-shadow:var(--glow-cyan)}
@media (max-width:740px){.trust__inner{grid-template-columns:1fr;gap:28px}}

/* ===================================================================
   SERVICE FILTER
   =================================================================== */
.filter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto 40px}
.filter__btn{font-family:var(--font);font-size:.9rem;font-weight:500;color:var(--muted);cursor:pointer;
  padding:9px 18px;border-radius:999px;background:var(--card);border:1px solid var(--card-brd);
  transition:.25s var(--ease)}
.filter__btn:hover{color:var(--text);border-color:var(--card-brd-hi)}
.filter__btn.active{color:var(--bg);background:var(--grad-green);border-color:transparent;box-shadow:var(--glow-green);font-weight:600}
.card.is-hidden{display:none}
.card.is-filtering{animation:cardin .5s var(--ease) both}
@keyframes cardin{from{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:none}}

/* ===================================================================
   SECTORES (prueba social)
   =================================================================== */
.sectors{text-align:center}
.sectors__lead{font-family:var(--mono);font-size:.85rem;color:var(--muted-2);letter-spacing:1px;margin-bottom:26px;text-transform:uppercase}
.sectors__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;max-width:var(--maxw);margin:0 auto}
.sector{display:flex;flex-direction:column;align-items:flex-start;text-align:left;
  padding:26px 22px;border-radius:var(--radius);background:var(--card);border:1px solid var(--card-brd);
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.sector:hover{transform:translateY(-6px);border-color:var(--card-brd-hi);box-shadow:var(--sh-2)}
.sector__ic{width:50px;height:50px;display:grid;place-items:center;border-radius:13px;color:var(--green);
  background:color-mix(in srgb,var(--green) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--green) 28%,transparent);margin-bottom:16px}
.sector__ic svg{width:26px;height:26px}
.sector h3{font-family:var(--display);font-size:1.05rem;line-height:1.25;letter-spacing:-.01em;margin-bottom:6px}
.sector p{color:var(--muted);font-size:.85rem;line-height:1.45}
@media (max-width:900px){.sectors__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.sectors__grid{grid-template-columns:1fr}}

/* ===================================================================
   TESTIMONIOS
   =================================================================== */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.quote{position:relative;display:flex;flex-direction:column;height:100%;padding:32px 28px;border-radius:var(--radius);
  background:var(--card);border:1px solid var(--card-brd);overflow:hidden;transition:.35s var(--ease)}
.quote:hover{transform:translateY(-5px);border-color:var(--card-brd-hi);box-shadow:var(--sh-2)}
.quote::before{content:"\201C";position:absolute;top:6px;right:24px;font-family:var(--display);font-size:4rem;
  line-height:1;color:var(--green);opacity:.16;pointer-events:none}
.quote__stars{position:relative;z-index:1;color:var(--green);font-size:.9rem;letter-spacing:2px;margin-bottom:14px}
.quote p{color:var(--text);font-size:.98rem;line-height:1.7;margin:0 0 22px;position:relative;z-index:1}
.quote__by{display:flex;align-items:center;gap:14px;margin-top:auto;padding-top:18px;border-top:1px solid var(--card-brd)}
.quote__av{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-weight:700;
  color:var(--bg);background:var(--grad-green);flex:0 0 auto}
.quote__by strong{display:block;font-size:.95rem}
.quote__by small{color:var(--muted);font-size:.82rem}
@media (max-width:900px){.quotes{grid-template-columns:1fr;max-width:520px;margin:0 auto}}

/* ===================================================================
   FAQ
   =================================================================== */
.faq{max-width:820px;margin:0 auto;display:grid;gap:14px}
.faq__item{border:1px solid var(--card-brd);border-radius:14px;background:var(--card);overflow:hidden;transition:border-color .3s}
.faq__item[open]{border-color:var(--card-brd-hi)}
.faq__q{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:20px 24px;font-family:var(--display);font-weight:600;font-size:1.05rem;color:var(--text)}
.faq__q::-webkit-details-marker{display:none}
.faq__q .ic{flex:0 0 auto;width:26px;height:26px;display:grid;place-items:center;border-radius:50%;
  border:1px solid var(--card-brd-hi);color:var(--green);position:relative;transition:transform .3s var(--ease)}
.faq__q .ic::before,.faq__q .ic::after{content:"";position:absolute;background:var(--green);border-radius:2px}
.faq__q .ic::before{width:12px;height:2px}.faq__q .ic::after{width:2px;height:12px;transition:transform .3s}
.faq__item[open] .faq__q .ic::after{transform:scaleY(0)}
.faq__item[open] .faq__q .ic{transform:rotate(180deg)}
.faq__a{padding:0 24px 22px;color:var(--muted);font-size:.96rem;line-height:1.7}

/* ===================================================================
   ICONOS RASTER PROPIOS (generados con IA, neón sobre negro)
   mix-blend-mode:screen -> el negro desaparece, sólo brilla el neón
   =================================================================== */
.ico-img{width:100%;height:100%;object-fit:contain;mix-blend-mode:screen;
  filter:drop-shadow(0 0 7px color-mix(in srgb,var(--accent) 45%,transparent))}
.card__icon--img,.modal__icon--img{background:rgba(0,0,0,.4);padding:5px;overflow:hidden}
.card:hover .card__icon--img .ico-img{filter:drop-shadow(0 0 12px color-mix(in srgb,var(--accent) 70%,transparent))}
.modal__icon--img{padding:8px}

/* ===================================================================
   MICRO-GARANTÍAS (bajo el formulario / hero)
   =================================================================== */
.guarantees{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 26px;margin-top:22px}
.guarantee{display:inline-flex;align-items:center;gap:9px;font-size:.86rem;color:var(--muted)}
.guarantee svg{width:18px;height:18px;color:var(--green);flex:0 0 auto}
.guarantee strong{color:var(--text);font-weight:600}

/* ===================================================================
   BANDA CTA INTERMEDIA
   =================================================================== */
.ctaband{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,5vw,48px)}
.ctaband__inner{position:relative;overflow:hidden;border-radius:var(--radius-lg);
  padding:clamp(34px,5vw,56px);text-align:center;
  background:linear-gradient(135deg,rgba(30,167,255,.10),rgba(57,231,95,.08));
  border:1px solid var(--card-brd-hi);box-shadow:var(--sh-2)}
.ctaband__inner::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:radial-gradient(600px circle at 50% -20%,rgba(57,231,95,.18),transparent 60%)}
.ctaband h2{position:relative;font-family:var(--display);font-weight:700;letter-spacing:-.02em;
  font-size:clamp(1.6rem,3.5vw,2.4rem);line-height:1.15;margin-bottom:14px}
.ctaband p{position:relative;color:var(--muted);max-width:560px;margin:0 auto 26px}
.ctaband__actions{position:relative;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ===================================================================
   PROCESO / CÓMO EMPEZAR
   =================================================================== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.step{position:relative;display:flex;flex-direction:column;padding:28px 24px;border-radius:var(--radius);background:var(--card);
  border:1px solid var(--card-brd);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.step:hover{transform:translateY(-6px);border-color:var(--card-brd-hi);box-shadow:var(--sh-2)}
.step__top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:18px}
.step__n{font-family:var(--display);font-weight:700;font-size:1.1rem;width:46px;height:46px;display:grid;place-items:center;
  border-radius:12px;color:var(--bg);background:var(--grad-green);box-shadow:var(--glow-green)}
.step__time{font-family:var(--mono);font-size:.7rem;color:var(--green);padding:5px 10px;border-radius:999px;
  background:color-mix(in srgb,var(--green) 10%,transparent);border:1px solid color-mix(in srgb,var(--green) 25%,transparent);white-space:nowrap}
.step h3{font-family:var(--display);font-size:1.18rem;line-height:1.25;letter-spacing:-.01em;margin-bottom:8px}
.step p{color:var(--muted);font-size:.92rem}
.step__list{list-style:none;display:grid;gap:9px;margin-top:auto;padding-top:16px;border-top:1px solid var(--card-brd)}
.step__list{margin-top:18px}
.step__list li{position:relative;padding-left:20px;font-size:.83rem;color:var(--muted);line-height:1.45}
.step__list li::before{content:"";position:absolute;left:2px;top:.45em;width:7px;height:7px;
  border:1.6px solid var(--green);border-top:0;border-left:0;transform:rotate(45deg)}
.step__arrow{position:absolute;top:40px;right:-22px;color:var(--muted-2);z-index:1}
@media (max-width:980px){.steps{grid-template-columns:repeat(2,1fr)}.step__arrow{display:none}}
@media (max-width:560px){.steps{grid-template-columns:1fr}}

/* ===================================================================
   WHATSAPP FLOTANTE
   =================================================================== */
.wa{position:fixed;right:20px;bottom:20px;z-index:90;display:inline-flex;align-items:center;gap:10px;
  padding:13px 18px;border-radius:999px;font-weight:600;font-size:.92rem;color:#04140a;
  background:linear-gradient(135deg,#5ff58a,#25d366);box-shadow:0 10px 30px rgba(37,211,102,.4);
  transition:transform .25s var(--ease),box-shadow .25s}
.wa:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 14px 40px rgba(37,211,102,.55)}
.wa svg{width:22px;height:22px}
.wa__txt{white-space:nowrap}
@media (max-width:560px){.wa{padding:14px;border-radius:50%}.wa__txt{display:none}}

/* ===================================================================
   SOBRE NOSOTROS (actitud hacker + terminal animada)
   =================================================================== */
.about__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;max-width:var(--maxw);margin:0 auto}
.about__copy p{color:var(--muted);font-size:1.02rem;margin-bottom:18px}
.about__copy p strong{color:var(--text);font-weight:600}
.about__copy .grad-text{font-weight:600}
.about__caps{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:14px 20px;margin-top:26px}
.about__caps li{position:relative;padding-left:30px;color:var(--text);font-size:.93rem;line-height:1.5}
.about__caps li span{color:var(--muted)}
.about__caps li::before{content:"";position:absolute;left:2px;top:3px;width:18px;height:18px;border-radius:6px;
  background:color-mix(in srgb,var(--green) 16%,transparent);border:1px solid color-mix(in srgb,var(--green) 40%,transparent)}
.about__caps li::after{content:"";position:absolute;left:7.5px;top:7px;width:6px;height:9px;
  border:2px solid var(--green);border-top:0;border-left:0;transform:rotate(45deg)}

/* terminal */
.term{border-radius:var(--radius);overflow:hidden;border:1px solid var(--card-brd-hi);
  background:linear-gradient(180deg,#0a0f16,#070a0f);box-shadow:var(--sh-3),var(--glow-green)}
.term__bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:rgba(255,255,255,.03);
  border-bottom:1px solid var(--card-brd)}
.term__bar span{width:11px;height:11px;border-radius:50%;background:#2a323d}
.term__bar span:nth-child(1){background:#ff5f57}.term__bar span:nth-child(2){background:#febc2e}.term__bar span:nth-child(3){background:#28c840}
.term__bar em{margin-left:10px;font-family:var(--mono);font-size:.78rem;color:var(--muted-2);font-style:normal}
.term__body{font-family:var(--mono);font-size:.82rem;line-height:1.7;padding:20px;min-height:280px;
  white-space:pre-wrap;color:var(--silver);margin:0}
.term__body .c-prompt{color:var(--green)}
.term__body .c-ok{color:var(--green)}
.term__body .c-info{color:var(--cyan-soft)}
.term__body .c-warn{color:#ffb02e}
.term__body .c-dim{color:var(--muted-2)}
.term__cursor{display:inline-block;width:8px;height:1.05em;background:var(--green);
  vertical-align:-2px;margin-left:2px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
@media (prefers-reduced-motion:reduce){.term__cursor{animation:none}}
@media (max-width:860px){.about__grid{grid-template-columns:1fr;gap:32px}.about__caps{grid-template-columns:1fr}}

/* ===================================================================
   MODELOS DE EVALUACIÓN (cards mejoradas)
   =================================================================== */
.models{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.model{position:relative;display:flex;flex-direction:column;padding:30px 26px;border-radius:var(--radius);
  background:var(--card);border:1px solid var(--card-brd);overflow:hidden;
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.model:hover{transform:translateY(-6px);border-color:var(--card-brd-hi);box-shadow:var(--sh-2),var(--glow-green)}
.model--rec{border-color:var(--card-brd-hi);
  background:linear-gradient(165deg,color-mix(in srgb,var(--green) 9%,transparent),transparent 60%)}
.model__rib{position:absolute;top:0;right:20px;font-family:var(--mono);font-size:.68rem;font-weight:700;
  letter-spacing:.04em;color:#04140a;background:var(--grad-green);padding:5px 12px;border-radius:0 0 9px 9px;
  box-shadow:var(--glow-green)}
.model__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.model__dots{display:inline-flex;gap:5px}
.model__dots i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.13)}
.model__dots i.on{background:var(--green);box-shadow:0 0 8px var(--green)}
.model__tag{font-family:var(--mono);font-size:.76rem;color:var(--text);padding:5px 12px;border-radius:999px;
  background:#0d0f12;border:1px solid #1c2128}
.model__tag--gray{color:var(--silver);border-color:#2b333d}
.model__tag--white{color:#fff;border-color:#3a4450;background:#11151b}
.model h3{font-family:var(--display);font-size:1.2rem;line-height:1.25;letter-spacing:-.01em;margin-bottom:10px}
.model>p{color:var(--muted);font-size:.92rem;margin-bottom:22px}
.model__meters{display:grid;gap:14px;margin-bottom:22px}
.meter__l{display:block;font-family:var(--mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;
  color:var(--muted-2);margin-bottom:7px}
.meter__bar{height:7px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.meter__bar i{display:block;height:100%;width:0;border-radius:999px;background:var(--grad-green);
  box-shadow:var(--glow-green);transition:width 1.3s var(--ease)}
.model.in-view .meter__bar i{width:var(--w)}
.model__facts{list-style:none;display:grid;gap:11px;margin-top:auto;padding-top:18px;border-top:1px solid var(--card-brd)}
.model__facts li{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;color:var(--muted);line-height:1.4}
.model__facts li b{color:var(--text);font-weight:600}
.model__facts svg{width:15px;height:15px;color:var(--green);flex:0 0 auto;margin-top:2px}
@media (prefers-reduced-motion:reduce){.meter__bar i{transition:none}}
@media (max-width:860px){.models{grid-template-columns:1fr}}

/* ===================================================================
   FORMULARIO — marcas de campos requeridos / opcionales / nota
   =================================================================== */
.form .req{color:var(--green);font-weight:700}
.form .opt{color:var(--muted-2);font-weight:400;font-size:.92em}
.form__hint{margin-top:12px;font-size:.78rem;color:var(--muted-2);text-align:center;line-height:1.5}

/* ===================================================================
   TRUST STRIP — variante centrada (solo marcos)
   =================================================================== */
.trust__inner--single{grid-template-columns:1fr;justify-items:center;text-align:center}
.trust__inner--single .trust__group h4{margin-bottom:18px}
.trust__inner--single .trust__badges{justify-content:center}

/* ===================================================================
   CERTIFICACIONES — insignias tipo credencial (hexágono)
   =================================================================== */
.certs{display:flex;flex-wrap:wrap;justify-content:center;gap:22px}
.cert{flex:1 1 180px;max-width:210px;display:flex;flex-direction:column;align-items:center;text-align:center;
  padding:30px 18px;border-radius:var(--radius);background:var(--card);border:1px solid var(--card-brd);
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.cert:hover{transform:translateY(-6px);border-color:var(--card-brd-hi);
  box-shadow:var(--sh-2),0 0 30px color-mix(in srgb,var(--green) 18%,transparent)}
.cert__badge{width:94px;height:106px;padding:2px;margin-bottom:18px;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:linear-gradient(160deg,var(--cyan),var(--green));
  filter:drop-shadow(0 6px 16px rgba(57,231,95,.25))}
.cert__badge span{width:100%;height:100%;display:grid;place-items:center;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  background:linear-gradient(160deg,#0e1a22,#0a0f16);
  font-family:var(--display);font-weight:700;font-size:1rem;letter-spacing:.02em;color:#fff}
.cert h4{font-family:var(--display);font-size:.9rem;line-height:1.3;margin-bottom:8px;font-weight:600;
  min-height:2.6em;display:flex;align-items:center}
.cert__issuer{font-family:var(--mono);font-size:.72rem;color:var(--muted-2)}
@media (max-width:560px){.cert{flex-basis:130px}.cert__badge{width:84px;height:96px}}

/* avatar profesional (silueta) en testimonios */
.quote__av svg{width:24px;height:24px}

/* sello de "estándar verificado" en los marcos */
.badge{display:inline-flex;align-items:center;gap:7px}
.badge--fw svg{width:15px;height:15px;color:var(--cyan-soft);flex:0 0 auto}
.badge--fw:hover svg{color:var(--cyan)}

/* nota referencial de tiempos en "Cómo empezar" */
.steps__note{text-align:center;color:var(--muted-2);font-size:.82rem;margin-top:24px;font-family:var(--mono)}
