/* ============================================================
   QUANTORYXCODE — styles.css
   Estudio de software · oscuro, sobrio, técnico, premium
   ============================================================ */

:root{
  --void:#0A0B0D;
  --void-2:#0E1014;
  --panel:#13161B;
  --panel-2:#101317;
  --line:rgba(255,255,255,.07);
  --line-2:rgba(255,255,255,.13);
  --chrome:#ECEEF1;
  --silver:#A4ABB4;
  --steel:#646B75;
  --steel-2:#444A52;
  --accent:#C9D4E0;
  --ok:#46B978;
  --data:#6F90C4;
  --max:1200px;
  --ease:cubic-bezier(.16,1,.3,1);
  --r:16px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--void);color:var(--chrome);line-height:1.55;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--chrome);color:var(--void)}
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--void)}
::-webkit-scrollbar-thumb{background:#23262c;border-radius:10px}
section[id]{scroll-margin-top:92px}

.chrome{background:linear-gradient(176deg,#fff 0%,#d2d8df 38%,#9aa1ab 56%,#eef1f4 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.mono{font-family:'JetBrains Mono',monospace}

/* ============================================================
   FONDO POR CAPAS (base · grilla · binario · veladura · luz)
   ============================================================ */
.bg{position:fixed;inset:0;z-index:-6;pointer-events:none;overflow:hidden;background:
  radial-gradient(120% 80% at 78% 18%, #101319 0%, transparent 55%),
  linear-gradient(180deg,#0B0C0F 0%, #090A0C 100%)}
/* imagen de fondo del inicio (debajo de la lluvia) */
.hero-bg{position:fixed;top:0;left:0;right:0;height:100vh;z-index:-5;pointer-events:none;
  background:linear-gradient(180deg, rgba(10,11,13,.40), rgba(10,11,13,.72)),
    url('imagenes/fondo.png') center center / contain no-repeat;
  -webkit-mask-image:linear-gradient(180deg,#000 62%,transparent 96%);
  mask-image:linear-gradient(180deg,#000 62%,transparent 96%)}
.bg-grid{position:fixed;inset:0;z-index:-4;pointer-events:none;
  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:58px 58px;
  -webkit-mask-image:radial-gradient(130% 100% at 50% 0%,#000 0%,transparent 80%);
  mask-image:radial-gradient(130% 100% at 50% 0%,#000 0%,transparent 80%)}
.bg-binary{position:fixed;inset:0;z-index:-3;pointer-events:none;opacity:.42}
.bg-veil{position:fixed;inset:0;z-index:-2;pointer-events:none;background:
  linear-gradient(90deg, rgba(10,11,13,.92) 0%, rgba(10,11,13,.55) 34%, transparent 60%),
  radial-gradient(90% 70% at 50% 120%, rgba(0,0,0,.6), transparent 60%)}
.bg-glow{position:fixed;top:-10vh;right:-6vw;width:48vw;height:48vw;z-index:-1;pointer-events:none;border-radius:50%;
  background:radial-gradient(circle, rgba(140,165,200,.10), transparent 62%)}
.grain{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.028;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ============================================================
   PRELOADER
   ============================================================ */
#preloader{position:fixed;inset:0;z-index:9999;background:var(--void);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;animation:plOut .6s var(--ease) 2.3s forwards}
#preloader img{height:88px;width:auto;mix-blend-mode:screen;filter:saturate(0) brightness(1.25) contrast(1.05);animation:plPulse 1.7s ease-in-out infinite}
#preloader .pl-bar{position:relative;width:170px;height:2px;background:rgba(255,255,255,.12);border-radius:2px;overflow:hidden}
#preloader .pl-bar::after{content:"";position:absolute;inset:0;width:45%;background:linear-gradient(90deg,transparent,var(--chrome),transparent);animation:plLoad 1.2s var(--ease) infinite}
#preloader .pl-word{font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.34em;text-transform:uppercase;color:var(--steel)}
#preloader.done{opacity:0;visibility:hidden;transition:opacity .5s ease,visibility .5s ease}
@keyframes plOut{to{opacity:0;visibility:hidden}}
@keyframes plPulse{0%,100%{opacity:.55}50%{opacity:1}}
@keyframes plLoad{0%{transform:translateX(-180%)}100%{transform:translateX(420%)}}

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,4vw,44px)}
.pad{padding-top:clamp(80px,11vw,140px);padding-bottom:clamp(80px,11vw,140px)}
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--silver)}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--steel)}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:color-mix(in srgb,var(--void) 74%,transparent);border-bottom:1px solid var(--line)}
.nav__in{max-width:var(--max);margin:0 auto;padding:0 clamp(20px,4vw,44px);height:74px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:42px;width:auto;mix-blend-mode:screen;filter:saturate(0) brightness(1.25) contrast(1.05)}
.brand__name{font-family:'Sora',sans-serif;font-weight:700;font-size:1.02rem;letter-spacing:.02em;line-height:1}
.brand__name small{display:block;font-family:'JetBrains Mono',monospace;font-size:.54rem;letter-spacing:.26em;color:var(--steel);margin-top:4px}
.nav__links{display:flex;align-items:center;gap:32px}
.nav__links a{font-size:.85rem;font-weight:500;color:var(--silver);transition:color .25s}
.nav__links a:hover{color:var(--chrome)}
.nav__cta{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(180deg,#fff,#c8cfd7);color:var(--void);padding:11px 19px;border-radius:9px;font-size:.82rem;font-weight:700;transition:transform .3s var(--ease)}
.nav__cta:hover{transform:translateY(-2px)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:8px}
.burger span{width:26px;height:2px;background:var(--chrome);border-radius:2px}

.mob{position:fixed;inset:0;z-index:80;background:var(--void);transform:translateY(-100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;padding:24px}
.mob.open{transform:translateY(0)}
.mob__top{display:flex;justify-content:space-between;align-items:center;height:50px}
.mob__close{background:none;border:0;color:var(--chrome);font-size:2.2rem;line-height:1}
.mob__links{display:flex;flex-direction:column;margin-top:8vh}
.mob__links a{display:flex;align-items:baseline;gap:16px;font-family:'Sora',sans-serif;font-size:2.2rem;font-weight:600;letter-spacing:-.02em;padding:16px 0;border-bottom:1px solid var(--line)}
.mob__links a span{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--steel)}
.mob__foot{margin-top:auto}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:15px 26px;border-radius:10px;font-size:.92rem;font-weight:600;border:1px solid transparent;transition:transform .26s var(--ease),background .3s,color .3s,border-color .3s}
.btn--chrome{background:linear-gradient(180deg,#fff,#c8cfd7);color:var(--void);font-weight:700}
.btn--chrome:hover{transform:translateY(-2px)}
.btn--ghost{background:transparent;border-color:var(--line-2);color:var(--chrome)}
.btn--ghost:hover{border-color:var(--chrome);background:rgba(255,255,255,.03);transform:translateY(-2px)}
.btn--wa{background:#1FAE54;color:#fff;font-weight:700}
.btn--wa:hover{transform:translateY(-2px)}

/* ============================================================
   HERO (2 columnas: copy + producto)
   ============================================================ */
.hero{position:relative;min-height:82vh;display:flex;align-items:center;padding-top:clamp(44px,6vw,84px);padding-bottom:clamp(44px,6vw,84px)}
.hero__grid{display:grid;grid-template-columns:1fr;width:100%}
.hero__copy{max-width:600px}
.hero h1{font-family:'Sora',sans-serif;font-weight:700;font-size:clamp(1.85rem,6.2vw,3.7rem);line-height:1.08;letter-spacing:-.03em;margin:22px 0 0}
.hero__sub{margin-top:24px;font-size:clamp(1rem,1.35vw,1.16rem);color:var(--silver);line-height:1.6;max-width:48ch}
.hero__cta{margin-top:34px;display:flex;flex-wrap:wrap;gap:12px}
.hero__trust{margin-top:30px;display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line-2);border-radius:8px;padding:8px 13px;font-size:.76rem;color:var(--silver)}
.chip::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--ok)}

/* ---------- dashboard / producto ---------- */
.hero__product{position:relative}
.dash{position:relative;background:linear-gradient(180deg,#13161b 0%,#0d0f13 100%);border:1px solid var(--line-2);border-radius:16px;overflow:hidden;box-shadow:0 50px 90px -45px rgba(0,0,0,.95),0 0 0 1px rgba(255,255,255,.02)}
.dash__top{height:46px;display:flex;align-items:center;gap:10px;padding:0 14px;border-bottom:1px solid var(--line);background:#0e1116}
.dash__dots{display:flex;gap:6px}
.dash__dots i{width:10px;height:10px;border-radius:50%;background:#2a2e35;display:block}
.dash__title{font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.06em;color:var(--silver)}
.dash__live{margin-left:auto;display:inline-flex;align-items:center;gap:7px;font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ok)}
.dash__live i{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok)}
.dash__body{display:grid;grid-template-columns:52px 1fr}
.dash__nav{border-right:1px solid var(--line);padding:14px 0;display:flex;flex-direction:column;gap:7px;align-items:center}
.dash__nav span{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--steel)}
.dash__nav span.on{background:rgba(255,255,255,.06);color:var(--chrome)}
.dash__main{padding:15px;display:flex;flex-direction:column;gap:11px;min-width:0}
.dash__row{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.card{border:1px solid var(--line);border-radius:12px;padding:13px 14px;background:var(--panel-2);min-width:0}
.card__k{font-family:'JetBrains Mono',monospace;font-size:.58rem;letter-spacing:.13em;text-transform:uppercase;color:var(--steel);display:flex;align-items:center;justify-content:space-between;gap:8px}
.card__v{font-family:'Sora',sans-serif;font-weight:700;font-size:1.45rem;letter-spacing:-.02em;margin-top:7px}
.card__v small{font-size:.78rem;font-weight:500;color:var(--silver)}
.trend{font-size:.66rem;font-weight:600;color:var(--ok)}
.trend.down{color:#C98A8A}
.spark{display:flex;align-items:flex-end;gap:3px;height:30px;margin-top:9px}
.spark i{flex:1;background:var(--data);opacity:.55;border-radius:2px 2px 0 0;display:block}
.bars{display:flex;flex-direction:column;gap:7px;margin-top:9px}
.bar{height:6px;border-radius:4px;background:rgba(255,255,255,.07);overflow:hidden}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--data),rgba(111,144,196,.4));border-radius:4px}
.crm{display:flex;flex-direction:column;gap:9px;margin-top:10px}
.crm__row{display:flex;align-items:center;gap:9px}
.crm__av{width:26px;height:26px;border-radius:7px;background:linear-gradient(180deg,#2a2f37,#1b1f25);display:flex;align-items:center;justify-content:center;font-family:'Sora';font-size:.6rem;font-weight:700;color:var(--silver);flex-shrink:0}
.crm__nm{font-size:.74rem;color:var(--chrome);line-height:1.1}
.crm__nm small{display:block;color:var(--steel);font-size:.62rem}
.crm__st{margin-left:auto;font-family:'JetBrains Mono';font-size:.56rem;letter-spacing:.08em;text-transform:uppercase;color:var(--steel)}
.wa{display:flex;align-items:center;gap:11px}
.wa__ic{width:34px;height:34px;border-radius:9px;background:rgba(31,174,84,.12);border:1px solid rgba(31,174,84,.3);display:flex;align-items:center;justify-content:center;color:#1FAE54;flex-shrink:0}
.wa__t{font-size:.76rem;color:var(--chrome);line-height:1.15}
.wa__t small{display:block;color:var(--ok);font-family:'JetBrains Mono';font-size:.58rem;letter-spacing:.1em;text-transform:uppercase}
.sys{display:flex;flex-direction:column;gap:8px;margin-top:9px}
.sys__row{display:flex;align-items:center;gap:9px;font-size:.72rem;color:var(--silver)}
.sys__row i{width:7px;height:7px;border-radius:50%;background:var(--ok);flex-shrink:0}
.sys__row .ms{margin-left:auto;font-family:'JetBrains Mono';font-size:.6rem;color:var(--steel)}
.dash__tag{position:absolute;top:11px;right:12px;z-index:3;font-family:'JetBrains Mono';font-size:.54rem;letter-spacing:.16em;text-transform:uppercase;color:var(--steel)}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.shead{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:48px}
.shead h2{font-family:'Sora',sans-serif;font-weight:700;font-size:clamp(1.5rem,5vw,2.9rem);line-height:1.08;letter-spacing:-.03em;max-width:20ch;margin-top:16px}
.shead h2 em{font-style:normal;color:var(--accent)}
.snum{font-family:'JetBrains Mono',monospace;font-size:.74rem;color:var(--steel);letter-spacing:.12em;white-space:nowrap}

/* ============================================================
   SERVICIOS (pestañas que abren su sección)
   ============================================================ */
.svc-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.svc-tab{position:relative;overflow:hidden;display:flex;align-items:center;gap:14px;text-align:left;border:1px solid var(--line);border-radius:14px;padding:18px;background:linear-gradient(180deg,var(--void-2),var(--panel-2));transition:border-color .35s,transform .35s var(--ease),box-shadow .35s}
.svc-tab::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;transition:opacity .35s;background:radial-gradient(380px circle at var(--mx,50%) var(--my,50%),rgba(201,212,224,.13),transparent 42%)}
.svc-tab:hover{border-color:var(--line-2);transform:translateY(-4px);box-shadow:0 26px 54px -32px rgba(0,0,0,.95)}
.svc-tab:hover::after{opacity:1}
.svc-tab>*{position:relative;z-index:1}
.svc-tab__ic{width:44px;height:44px;border-radius:12px;border:1px solid var(--line-2);background:rgba(255,255,255,.02);display:flex;align-items:center;justify-content:center;color:var(--silver);flex-shrink:0;transition:color .3s,border-color .3s,background .3s}
.svc-tab:hover .svc-tab__ic{color:var(--chrome);border-color:rgba(201,212,224,.5);background:rgba(201,212,224,.07)}
.svc-tab__txt{min-width:0;flex:1}
.svc-tab__t{font-family:'Sora',sans-serif;font-weight:600;font-size:.98rem;letter-spacing:-.01em;line-height:1.15;display:block;transition:color .3s}
.svc-tab__m{font-family:'JetBrains Mono',monospace;font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;color:var(--steel);display:block;margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.svc-tab__go{width:30px;height:30px;border-radius:9px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--steel);flex-shrink:0;transition:color .3s,border-color .3s,transform .3s,background .3s}
.svc-tab:hover .svc-tab__go{color:var(--void);background:var(--chrome);border-color:var(--chrome);transform:translateX(3px)}

.svc-panel{display:none;position:relative;margin-top:16px;border:1px solid var(--line);border-radius:16px;background:var(--void-2);overflow:hidden}
.svc-wrap.open .svc-tabs{display:none}
.svc-wrap.open .svc-panel{display:block}
.svc-panel__head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px 12px 18px;border-bottom:1px solid var(--line)}
.svc-panel__head .lbl{font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--steel)}
.svc-back{display:inline-flex;align-items:center;gap:7px;background:var(--void);border:1px solid var(--line-2);color:var(--silver);border-radius:9px;padding:9px 15px;font-size:.8rem;font-weight:600;transition:border-color .2s,color .2s,background .2s}
.svc-back:hover{color:var(--void);background:var(--chrome);border-color:var(--chrome)}

/* detalle de servicio a pantalla completa (el nav queda arriba) */
.svc-overlay{position:fixed;inset:0;z-index:48;background:var(--void);overflow-y:auto;opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s}
.svc-overlay.open{opacity:1;visibility:visible}
.svc-overlay::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(120% 80% at 80% 0%, rgba(140,165,200,.07), transparent 55%)}
.svc-overlay__in{position:relative;z-index:1;max-width:1080px;margin:0 auto;padding:calc(74px + clamp(30px,5vw,58px)) clamp(20px,4vw,44px) 64px}
.svc-overlay__head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:clamp(26px,4vw,44px)}
.svc-overlay__crumb{font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--steel)}
.svc-overlay__crumb b{color:var(--chrome);font-weight:500}
.svc-content{display:none}
.svc-content.active{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,4vw,48px);padding:clamp(26px,4vw,44px);animation:fadeUp .5s var(--ease)}
.svc-content.svc-intro.active{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;min-height:220px}
.svc-intro__ic{width:50px;height:50px;border-radius:13px;border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:var(--silver)}
.svc-intro p{color:var(--silver);font-size:1rem;max-width:34ch}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.svc-content h3{font-family:'Sora',sans-serif;font-weight:700;font-size:clamp(1.5rem,2.4vw,2rem);letter-spacing:-.02em;margin-bottom:14px}
.svc-content p{color:var(--silver);font-size:1rem;line-height:1.6;max-width:46ch}
.svc-list{list-style:none;display:flex;flex-direction:column;gap:11px;margin-top:22px}
.svc-list li{display:flex;gap:11px;font-size:.92rem;color:var(--chrome)}
.svc-list svg{flex-shrink:0;margin-top:3px;color:var(--accent)}
.svc-content .btn{margin-top:26px}
.svc-aside{border:1px solid var(--line);border-radius:14px;background:var(--panel-2);padding:22px;display:flex;flex-direction:column;gap:12px}
.svc-feat{display:flex;align-items:center;gap:12px;padding:13px;border:1px solid var(--line);border-radius:11px;background:var(--void-2)}
.svc-feat__ic{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;color:var(--silver);flex-shrink:0}
.svc-feat b{font-family:'Sora';font-size:.86rem;font-weight:600;display:block}
.svc-feat span{font-size:.74rem;color:var(--steel)}
.svc-aside__label{font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--steel);margin-bottom:4px}
.price-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 15px;border:1px solid var(--line);border-radius:11px;background:var(--void-2)}
.price-row.feat{border-color:var(--chrome);background:linear-gradient(180deg,rgba(255,255,255,.05),transparent 75%)}
.price-row__l b{font-family:'Sora';font-weight:600;font-size:.92rem;display:block;line-height:1.1}
.price-row__l span{font-size:.72rem;color:var(--steel)}
.price-row__p{font-family:'Sora';font-weight:700;font-size:1.15rem;letter-spacing:-.02em;white-space:nowrap}
.price-row__p small{font-size:.68rem;color:var(--steel);font-weight:500}
.svc-aside__note{font-family:'JetBrains Mono',monospace;font-size:.62rem;color:var(--steel);letter-spacing:.04em;margin-top:2px}

/* ============================================================
   PLANES
   ============================================================ */
.plans{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.plan{padding:34px 30px;display:flex;flex-direction:column;border-right:1px solid var(--line);transition:background .4s}
.plan:last-child{border-right:0}
.plan:hover{background:var(--void-2)}
.plan--feat{background:linear-gradient(180deg,rgba(201,212,224,.06),transparent 55%)}
.plan__tag{font-family:'JetBrains Mono',monospace;font-size:.64rem;letter-spacing:.15em;text-transform:uppercase;color:var(--steel);display:flex;align-items:center;gap:9px}
.plan__tag .star{color:var(--accent)}
.plan__name{font-family:'Sora',sans-serif;font-size:1.6rem;font-weight:700;letter-spacing:-.02em;margin:13px 0 4px}
.plan__for{font-size:.86rem;color:var(--silver);min-height:40px}
.plan__price{font-family:'Sora',sans-serif;font-size:3rem;font-weight:700;letter-spacing:-.03em;margin:16px 0 2px;display:flex;align-items:baseline;gap:7px}
.plan__price small{font-size:.95rem;font-weight:500;color:var(--steel);font-family:'Inter'}
.plan__renew{font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--steel);margin-bottom:24px}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:12px;flex-grow:1;margin-bottom:26px}
.plan li{display:flex;gap:11px;font-size:.9rem;color:var(--silver)}
.plan li svg{flex-shrink:0;margin-top:3px;color:var(--accent)}
.plan__btn{text-align:center;padding:13px;border-radius:10px;font-weight:600;font-size:.88rem;transition:transform .26s var(--ease),background .3s,color .3s,border-color .3s;border:1px solid var(--line-2);color:var(--chrome)}
.plan__btn:hover{background:rgba(255,255,255,.05);border-color:var(--chrome);transform:translateY(-2px)}
.plan__btn--chrome{background:linear-gradient(180deg,#fff,#c8cfd7);color:var(--void);border-color:transparent;font-weight:700}
.plan__btn--chrome:hover{transform:translateY(-2px)}
.plans-note{text-align:center;margin-top:22px;font-size:.9rem;color:var(--silver)}
.plans-note b{color:var(--chrome);font-weight:600}

/* ============================================================
   CLIENTES (marquee)
   ============================================================ */
.clients{padding:clamp(54px,8vw,96px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.clients__label{text-align:center;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--steel);margin-bottom:40px}
.clients__viewport{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.clients__track{display:flex;width:max-content;gap:clamp(26px,5vw,60px);animation:cmarq 30s linear infinite}
.clients__viewport:hover .clients__track{animation-play-state:paused}
.clients__track .client-logo{white-space:nowrap;font-family:'Sora',sans-serif;font-weight:600;font-size:clamp(.95rem,1.8vw,1.2rem);color:#737a83}
@keyframes cmarq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   CONTACTO
   ============================================================ */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.contact h2{font-family:'Sora',sans-serif;font-weight:700;font-size:clamp(1.7rem,5.4vw,3.4rem);line-height:1.05;letter-spacing:-.03em;margin-top:16px}
.contact__p{color:var(--silver);margin-top:20px;font-size:1.04rem;max-width:40ch}
.contact__direct{margin-top:32px;display:flex;flex-direction:column}
.contact__direct a{display:flex;align-items:center;gap:15px;padding:18px 0;border-top:1px solid var(--line);font-size:1.02rem;transition:color .25s,padding-left .35s var(--ease)}
.contact__direct a:last-child{border-bottom:1px solid var(--line)}
.contact__direct a:hover{color:var(--accent);padding-left:8px}
.contact__direct svg{flex-shrink:0;color:var(--silver)}
.form{display:flex;flex-direction:column;gap:14px;background:var(--void-2);border:1px solid var(--line);border-radius:18px;padding:32px}
.field label{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--steel);display:block;margin-bottom:8px}
.field input,.field select{width:100%;background:var(--void);border:1px solid var(--line-2);border-radius:10px;padding:14px 15px;font-family:'Inter';font-size:.94rem;color:var(--chrome);transition:border-color .25s}
.field input::placeholder{color:var(--steel)}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent)}
.field select option{background:var(--void-2)}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{border-top:1px solid var(--line);padding:clamp(64px,8vw,100px) 0 38px}
.foot__brand{font-family:'Sora',sans-serif;font-size:clamp(2.4rem,10vw,6.5rem);font-weight:700;letter-spacing:-.045em;line-height:.85}
.foot__row{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-top:46px;padding-top:38px;border-top:1px solid var(--line)}
.foot__col h5{font-family:'JetBrains Mono',monospace;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--steel);margin-bottom:15px}
.foot__col a{display:block;font-size:.92rem;padding:5px 0;color:var(--silver);transition:color .2s}
.foot__col a:hover{color:var(--chrome)}
.foot__legal{margin-top:38px;font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--steel);letter-spacing:.05em;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}

/* ============================================================
   FLOATING + CHAT
   ============================================================ */
.fab{position:fixed;right:22px;bottom:22px;z-index:70;display:flex;flex-direction:column;gap:12px;align-items:flex-end}
.fab__btn{width:54px;height:54px;border-radius:13px;display:flex;align-items:center;justify-content:center;border:0;box-shadow:0 16px 36px -12px rgba(0,0,0,.8);transition:transform .3s var(--ease)}
.fab__btn:hover{transform:translateY(-3px)}
.fab__wa{background:#1FAE54;color:#fff}
.fab__bot{background:linear-gradient(180deg,#fff,#c8cfd7);color:var(--void)}
.chat{position:fixed;right:22px;bottom:88px;z-index:71;width:min(360px,calc(100vw - 44px));height:470px;background:var(--void-2);border:1px solid var(--line-2);border-radius:18px;box-shadow:0 40px 80px -20px rgba(0,0,0,.8);display:flex;flex-direction:column;overflow:hidden;transform:translateY(20px) scale(.96);opacity:0;pointer-events:none;transition:all .35s var(--ease)}
.chat.open{transform:none;opacity:1;pointer-events:auto}
.chat__head{background:var(--panel);padding:15px 17px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line)}
.chat__avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(180deg,#fff,#c8cfd7);color:var(--void);display:flex;align-items:center;justify-content:center;font-family:'Sora';font-weight:700;font-size:1rem}
.chat__head b{font-family:'Sora';font-size:.95rem;display:block;line-height:1.1}
.chat__head small{font-size:.66rem;color:var(--ok);font-family:'JetBrains Mono';display:flex;align-items:center;gap:6px}
.chat__head small::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok)}
.chat__x{margin-left:auto;background:none;border:0;color:var(--chrome);font-size:1.5rem;opacity:.6}
.chat__x:hover{opacity:1}
.chat__body{flex:1;overflow-y:auto;padding:17px;display:flex;flex-direction:column;gap:10px}
.msg{max-width:86%;padding:11px 14px;border-radius:13px;font-size:.86rem;line-height:1.45}
.msg--bot{background:var(--panel);border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:3px;color:var(--chrome)}
.msg--bot b{color:var(--accent);font-weight:600}
.msg--user{background:linear-gradient(180deg,#fff,#c8cfd7);color:var(--void);align-self:flex-end;border-bottom-right-radius:3px;font-weight:600}
.chat__opts{padding:13px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px;background:var(--panel)}
.opt{text-align:left;background:var(--void-2);border:1px solid var(--line-2);border-radius:9px;padding:11px 13px;font-size:.81rem;font-weight:500;color:var(--chrome);transition:.2s}
.opt:hover{border-color:var(--accent);color:var(--accent)}
.opt--wa{background:#1FAE54;color:#fff;border-color:#1FAE54;text-align:center;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px}
.typing{display:flex;gap:4px;align-self:flex-start;padding:13px 14px;background:var(--panel);border:1px solid var(--line);border-radius:13px}
.typing span{width:6px;height:6px;border-radius:50%;background:var(--silver);animation:blink 1.2s infinite both}
.typing span:nth-child(2){animation-delay:.2s}
.typing span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.25}40%{opacity:1}}

/* ---------- reveal ---------- */
.reveal{transition:opacity .8s var(--ease),transform .8s var(--ease)}
html.js .reveal{opacity:0;transform:translateY(26px)}
html.js .reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:960px){
  .hero__grid{grid-template-columns:1fr;gap:44px}
  .hero__copy{max-width:none}
  .svc-content.active{grid-template-columns:1fr;gap:26px}
  .contact{grid-template-columns:1fr;gap:38px}
  .bg-veil{background:linear-gradient(180deg,rgba(10,11,13,.7),rgba(10,11,13,.4) 40%,transparent 70%),radial-gradient(90% 70% at 50% 120%,rgba(0,0,0,.6),transparent 60%)}
}
@media(max-width:820px){
  .nav__links{display:none}
  .burger{display:flex}
  .svc-tabs{grid-template-columns:1fr}
  .plans{grid-template-columns:1fr}
  .plan{border-right:0;border-bottom:1px solid var(--line)}
  .plan:last-child{border-bottom:0}
  .plan--feat{order:-1}
}
@media(max-width:480px){
  .svc-tabs{grid-template-columns:1fr}
  .dash__nav{display:none}
  .dash__body{grid-template-columns:1fr}
  .foot__row{flex-direction:column}
  .hero h1,.shead h2,.contact h2{overflow-wrap:break-word}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
  .bg-binary{display:none}
  #preloader{display:none}
  html{scroll-behavior:auto}
}
