/* ============ TOKENS ============ */
:root{
  --bg:#020818;
  --bg-2:#050e22;
  --bg-3:#071530;
  --panel:rgba(8,22,48,.72);
  --frame:rgba(255,140,0,.28);
  --frame-soft:rgba(255,140,0,.12);
  --grid:rgba(255,140,0,.045);
  --ink:#d8e6fb;
  --ink-2:#9ab0d0;
  --ink-dim:#5d7597;
  --accent:#ff8c00;
  --accent-hot:#ff5a1f;
  --accent-2:#00c8ff;
  --accent-3:#12d38f;
  --danger:#ff4d4d;
  --f-display:'Archivo',system-ui,sans-serif;
  --f-mono:'IBM Plex Mono',ui-monospace,monospace;
  --f-body:'Manrope',system-ui,sans-serif;
  --maxw:1240px;
  --corner:18px;
  --shadow-hud:0 0 0 1px rgba(255,140,0,.18), 0 30px 60px -30px rgba(0,0,0,.9), inset 0 0 50px rgba(0,200,255,.035);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--f-body);-webkit-font-smoothing:antialiased;overflow-x:hidden}
body{
  background:
    radial-gradient(1200px 700px at 85% -10%, rgba(0,200,255,.09), transparent 60%),
    radial-gradient(1000px 600px at -5% 35%, rgba(255,140,0,.10), transparent 60%),
    radial-gradient(900px 600px at 50% 110%, rgba(255,140,0,.07), transparent 60%),
    var(--bg);
  min-height:100vh;
  position:relative;
}
/* subtle grid + scanlines overlay */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:56px 56px, 56px 56px;
  mask-image: radial-gradient(ellipse at center, black 40%, transparent 85%);
}
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:2;
  background:repeating-linear-gradient(0deg, transparent 0, transparent 3px, rgba(0,200,255,.015) 3px, rgba(0,200,255,.015) 4px);
  mix-blend-mode:overlay;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:#0a0a0a}

/* ============ HUD VIEWPORT FRAME ============ */
.hud-frame{position:fixed;inset:18px;pointer-events:none;z-index:40}
.hud-frame .c{position:absolute;width:26px;height:26px}
.hud-frame .c.tl{top:0;left:0;border-top:2px solid var(--accent);border-left:2px solid var(--accent)}
.hud-frame .c.tr{top:0;right:0;border-top:2px solid var(--accent);border-right:2px solid var(--accent)}
.hud-frame .c.bl{bottom:0;left:0;border-bottom:2px solid var(--accent);border-left:2px solid var(--accent)}
.hud-frame .c.br{bottom:0;right:0;border-bottom:2px solid var(--accent);border-right:2px solid var(--accent)}
.hud-frame .mark{position:absolute;font:500 10px/1 var(--f-mono);letter-spacing:.25em;color:var(--accent);text-transform:uppercase;background:var(--bg);padding:0 6px}
.hud-frame .mark.tl{top:-6px;left:40px}
.hud-frame .mark.tr{top:-6px;right:40px;color:var(--accent-2)}
.hud-frame .mark.bl{bottom:-6px;left:40px;color:var(--accent-2)}
.hud-frame .mark.br{bottom:-6px;right:40px}

/* ============ NAV ============ */
.nav{position:sticky;top:0;z-index:30;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:linear-gradient(180deg,rgba(2,8,24,.75) 0%,rgba(2,8,24,.35) 100%);border-bottom:1px solid var(--frame-soft)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:14px 36px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--f-display);font-weight:900;letter-spacing:-.02em;font-size:20px;color:#fff}
.logo .dot{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 16px var(--accent);animation:blink 1.6s ease-in-out infinite}
.logo small{font:500 10px/1 var(--f-mono);color:var(--accent);letter-spacing:.3em;margin-left:4px}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
.nav-links{display:flex;gap:26px;font:500 13px/1 var(--f-body);color:var(--ink-2)}
.nav-links a{position:relative;padding:6px 0;transition:color .2s}
.nav-links a:hover{color:var(--accent)}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--accent);transition:width .3s}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:10px;padding:10px 16px;border:1px solid var(--frame);color:var(--accent);font:600 12px/1 var(--f-mono);letter-spacing:.15em;text-transform:uppercase;transition:.25s;position:relative;overflow:hidden}
.nav-cta:hover{background:var(--accent);color:#0a0a0a;box-shadow:0 0 30px rgba(255,140,0,.5)}
.nav-cta .arrow{transition:.25s}
.nav-cta:hover .arrow{transform:translateX(4px)}
@media(max-width:760px){.nav-links{display:none}.nav-in{padding:14px 20px}}

/* ============ COMMON ============ */
.container{max-width:var(--maxw);margin:0 auto;padding:0 36px;position:relative;z-index:3}
@media(max-width:760px){.container{padding:0 20px}}
.phase{display:inline-flex;align-items:center;gap:10px;font:500 11px/1 var(--f-mono);color:var(--accent);letter-spacing:.3em;text-transform:uppercase;margin-bottom:18px}
.phase .bar{width:40px;height:1px;background:var(--accent)}
.phase .bar::after{content:'';display:block;width:6px;height:6px;background:var(--accent);border-radius:50%;margin-top:-3.5px;margin-left:35px;box-shadow:0 0 10px var(--accent)}
.h-section{font-family:var(--f-display);font-weight:800;font-size:clamp(32px,4vw,54px);line-height:1.02;letter-spacing:-.025em;color:#fff;margin-bottom:16px}
.h-section em{font-style:normal;color:var(--accent);position:relative;display:inline-block}
.p-lead{font-size:18px;line-height:1.6;color:var(--ink-2);max-width:640px}

/* panel with HUD corners */
.panel{position:relative;background:var(--panel);border:1px solid rgba(255,255,255,.06);padding:28px;backdrop-filter:blur(6px)}
.panel::before,.panel::after,.panel>.cr-tl,.panel>.cr-tr,.panel>.cr-bl,.panel>.cr-br{content:'';position:absolute;width:var(--corner);height:var(--corner);pointer-events:none}
.panel::before{top:-1px;left:-1px;border-top:2px solid var(--accent);border-left:2px solid var(--accent)}
.panel::after{bottom:-1px;right:-1px;border-bottom:2px solid var(--accent);border-right:2px solid var(--accent)}
.panel>.cr-tr{top:-1px;right:-1px;border-top:2px solid var(--accent-2);border-right:2px solid var(--accent-2)}
.panel>.cr-bl{bottom:-1px;left:-1px;border-bottom:2px solid var(--accent-2);border-left:2px solid var(--accent-2)}

/* ============ HERO ============ */
.hero{position:relative;padding:80px 0 100px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:40px}}
.hero-kicker{display:flex;align-items:center;gap:14px;margin-bottom:28px;font:500 11px/1 var(--f-mono);letter-spacing:.3em;color:var(--accent);text-transform:uppercase;opacity:0;animation:fadeUp .8s .1s forwards}
.hero-kicker .sq{width:8px;height:8px;background:var(--accent);box-shadow:0 0 12px var(--accent)}
.hero-kicker .line{flex:1;max-width:80px;height:1px;background:linear-gradient(90deg,var(--accent),transparent)}
.hero h1{font-family:var(--f-display);font-weight:900;font-size:clamp(44px,6vw,86px);line-height:.96;letter-spacing:-.035em;color:#fff;margin-bottom:24px;opacity:0;animation:fadeUp .9s .25s forwards}
.hero h1 .accent{color:transparent;-webkit-text-stroke:1.5px var(--accent);position:relative}
.hero h1 .accent::after{content:attr(data-text);position:absolute;inset:0;color:var(--accent);opacity:0;animation:glowIn 1.2s .6s forwards}
.hero-sub{font-size:19px;line-height:1.55;color:var(--ink-2);max-width:560px;margin-bottom:32px;opacity:0;animation:fadeUp .9s .4s forwards}
.hero-sub b{color:#fff;font-weight:600}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:40px;opacity:0;animation:fadeUp .9s .55s forwards}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;font:600 12px/1 var(--f-mono);letter-spacing:.18em;text-transform:uppercase;cursor:pointer;border:none;transition:.25s;position:relative;overflow:hidden}
.btn-primary{background:var(--accent);color:#0a0a0a;box-shadow:0 0 0 1px var(--accent), 0 10px 30px -10px rgba(255,140,0,.7)}
.btn-primary:hover{background:var(--accent-hot);box-shadow:0 0 0 1px var(--accent-hot), 0 0 40px rgba(255,90,31,.7);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--accent-2);border:1px solid rgba(0,200,255,.35)}
.btn-ghost:hover{background:rgba(0,200,255,.08);border-color:var(--accent-2);box-shadow:0 0 30px rgba(0,200,255,.2)}
.btn-paypal{background:#003087;color:#fff;border:1px solid #003087}
.btn-paypal:hover{background:#0070ba;border-color:#0070ba;transform:translateY(-1px)}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* dataline */
.dataline{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--frame);border:1px solid var(--frame);font-family:var(--f-mono);opacity:0;animation:fadeUp .9s .7s forwards;position:relative}
.dataline > div{background:var(--bg);padding:16px 18px 14px;position:relative;overflow:hidden}
.dataline > div::before{content:'';position:absolute;top:8px;right:8px;width:6px;height:6px;background:var(--accent);border-radius:50%;box-shadow:0 0 8px var(--accent);opacity:.6}
.dataline > div:nth-child(3)::before{background:var(--accent-3);box-shadow:0 0 8px var(--accent-3);animation:blink 1.4s ease-in-out infinite}
.dataline > div::after{content:'';position:absolute;bottom:0;left:0;height:2px;background:linear-gradient(90deg,var(--accent),transparent);opacity:.55}
.dataline > div:nth-child(2)::after{background:linear-gradient(90deg,var(--accent-2),transparent)}
.dataline > div:nth-child(3)::after{background:linear-gradient(90deg,var(--accent-3),transparent)}
.dataline .k{font-size:9px;letter-spacing:.28em;color:var(--ink-dim);text-transform:uppercase;margin-bottom:8px}
.dataline .v{font-size:17px;color:#fff;font-weight:500;line-height:1.1;letter-spacing:-.01em}
.dataline .v b{color:var(--accent);font-weight:600}
.dataline > div:nth-child(2) .v b{color:var(--accent-2)}
.dataline > div:nth-child(3) .v b{color:var(--accent-3)}

/* ============ BACKBONE (hero visual de marca) ============ */
.backbone{
  position:relative;
  max-width:460px;
  margin-left:auto;
  padding:20px 22px 16px;
  background:
    linear-gradient(180deg,rgba(2,8,24,.65) 0%,rgba(7,21,48,.85) 100%);
  border:1px solid var(--frame-soft);
  opacity:0;
  animation:fadeIn 1s .55s forwards;
  overflow:hidden;
}
.backbone::before{content:'';position:absolute;top:-1px;left:-1px;width:22px;height:22px;border-top:2px solid var(--accent);border-left:2px solid var(--accent);pointer-events:none}
.backbone::after{content:'';position:absolute;bottom:-1px;right:-1px;width:22px;height:22px;border-bottom:2px solid var(--accent);border-right:2px solid var(--accent);pointer-events:none}
.backbone .cr-sm-tr{position:absolute;top:-1px;right:-1px;width:14px;height:14px;border-top:1.5px solid var(--accent-2);border-right:1.5px solid var(--accent-2);pointer-events:none}
.backbone .cr-sm-bl{position:absolute;bottom:-1px;left:-1px;width:14px;height:14px;border-bottom:1.5px solid var(--accent-2);border-left:1.5px solid var(--accent-2);pointer-events:none}

/* subtle grid inside backbone */
.backbone::before, .backbone::after{z-index:2}
.bb-inner-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,140,0,.03) 1px,transparent 1px);background-size:100% 14px;pointer-events:none;z-index:0}

.bb-head{
  display:flex;align-items:center;gap:10px;
  font:500 10px/1 var(--f-mono);letter-spacing:.26em;
  color:var(--accent);text-transform:uppercase;
  margin-bottom:14px;padding:0 2px 10px;
  border-bottom:1px dashed rgba(255,140,0,.22);
  position:relative;z-index:1;
}
.bb-dot-sm{width:7px;height:7px;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:blink 1.4s ease-in-out infinite}
.bb-head-line{flex:1;height:1px;background:linear-gradient(90deg,var(--accent),transparent)}
.bb-head-end{color:var(--accent-3);letter-spacing:.28em}

.bb-stack{position:relative;padding:4px 0}
.bb-rail{
  position:absolute;left:27px;top:14px;bottom:14px;width:2px;
  background:linear-gradient(180deg,rgba(255,140,0,.55) 0%,rgba(0,200,255,.4) 50%,rgba(255,140,0,.55) 100%);
  z-index:0;
  box-shadow:0 0 8px rgba(255,140,0,.25);
}
.bb-flow{
  position:absolute;left:-5px;top:0;
  width:12px;height:12px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 18px var(--accent), 0 0 30px rgba(255,140,0,.5);
  animation:bb-flow 4.5s cubic-bezier(.66,.02,.36,1) infinite;
}
@keyframes bb-flow{
  0%{top:0;opacity:0;transform:scale(.5)}
  8%{opacity:1;transform:scale(1)}
  92%{opacity:1;transform:scale(1)}
  100%{top:100%;opacity:0;transform:scale(.5)}
}

.bb-mod{
  position:relative;
  display:grid;
  grid-template-columns:56px 1fr auto;
  align-items:center;
  gap:14px;
  padding:10px 2px;
  z-index:1;
  opacity:0;
  transform:translateX(14px);
  animation:bb-in .6s cubic-bezier(.22,.92,.43,1) forwards;
}
.bb-mod:nth-child(2){animation-delay:.75s}
.bb-mod:nth-child(3){animation-delay:.9s}
.bb-mod:nth-child(4){animation-delay:1.05s}
.bb-mod:nth-child(5){animation-delay:1.2s}
.bb-mod:nth-child(6){animation-delay:1.35s}
@keyframes bb-in{to{opacity:1;transform:none}}

.bb-node-c{
  width:44px;height:44px;border-radius:50%;
  border:1.5px solid var(--accent);
  background:radial-gradient(circle at 30% 30%,rgba(255,140,0,.18),rgba(2,8,24,.9));
  color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;
  box-shadow:0 0 18px rgba(255,140,0,.35), inset 0 0 10px rgba(255,140,0,.15);
  position:relative;
  z-index:2;
  margin-left:5px;
}
.bb-node-c::before{
  content:'';position:absolute;inset:-5px;border-radius:50%;
  border:1px solid rgba(255,140,0,.3);
  animation:pulse-ring 2.6s ease-out infinite;
}
.bb-mod:nth-child(2) .bb-node-c::before{animation-delay:.4s}
.bb-mod:nth-child(3) .bb-node-c::before{animation-delay:.8s}
.bb-mod:nth-child(4) .bb-node-c::before{animation-delay:1.2s}
.bb-mod:nth-child(5) .bb-node-c::before{animation-delay:1.6s}
.bb-mod:nth-child(6) .bb-node-c::before{animation-delay:2.0s}

.bb-info{display:flex;flex-direction:column;gap:3px;min-width:0}
.bb-code{font:500 9px/1 var(--f-mono);letter-spacing:.22em;color:var(--accent);text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bb-title{font:700 15px/1.1 var(--f-display);color:#fff;letter-spacing:-.01em}
.bb-meta{font:400 10px/1.3 var(--f-mono);color:var(--ink-dim);letter-spacing:.06em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.bb-side{
  font:500 11px/1 var(--f-mono);
  color:var(--accent-3);
  text-shadow:0 0 8px var(--accent-3);
  animation:blink 2.2s ease-in-out infinite;
}
.bb-mod:nth-child(2) .bb-side{animation-delay:.3s}
.bb-mod:nth-child(3) .bb-side{animation-delay:.6s}
.bb-mod:nth-child(4) .bb-side{animation-delay:.9s}
.bb-mod:nth-child(5) .bb-side{animation-delay:1.2s}
.bb-mod:nth-child(6) .bb-side{animation-delay:1.5s}

.bb-foot{
  display:flex;align-items:center;gap:10px;
  font:500 9px/1 var(--f-mono);letter-spacing:.22em;
  color:var(--ink-dim);text-transform:uppercase;
  padding:10px 2px 0;margin-top:12px;
  border-top:1px dashed rgba(0,200,255,.22);
  position:relative;z-index:1;
}
.bb-foot-sep{opacity:.4}
.bb-foot .bb-live{color:var(--accent-3);font-size:11px;text-shadow:0 0 8px var(--accent-3);animation:blink 1.4s infinite}

/* scan line cruzando el backbone */
.backbone .bb-scan{
  position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent-2),transparent);
  opacity:.6;pointer-events:none;z-index:3;
  animation:bb-scan 5s linear infinite;
}
@keyframes bb-scan{0%{top:-5%}100%{top:105%}}

@media(max-width:960px){
  .backbone{max-width:100%;margin:0 auto}
}

@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes glowIn{from{opacity:0}to{opacity:1}}

/* scanline across hero */
.scanline{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-2),transparent);animation:scan 7s linear infinite;opacity:.6;pointer-events:none}
@keyframes scan{0%{top:5%}100%{top:95%}}

/* ============ SECTION ============ */
section{position:relative;padding:110px 0}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:54px;flex-wrap:wrap}
.section-head .sub{font-family:var(--f-mono);font-size:12px;letter-spacing:.2em;color:var(--ink-dim);text-transform:uppercase;max-width:260px;text-align:right}

/* ============ PRODUCTOS ============ */
.products{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media(max-width:880px){.products{grid-template-columns:1fr}}
.product{position:relative;background:var(--panel);border:1px solid rgba(255,255,255,.05);padding:0;overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.product::before,.product::after,.product>.cr-tr,.product>.cr-bl{content:'';position:absolute;width:16px;height:16px;pointer-events:none;transition:.3s;opacity:.8}
.product::before{top:0;left:0;border-top:2px solid var(--accent);border-left:2px solid var(--accent)}
.product::after{bottom:0;right:0;border-bottom:2px solid var(--accent);border-right:2px solid var(--accent)}
.product>.cr-tr{top:0;right:0;border-top:2px solid var(--accent-2);border-right:2px solid var(--accent-2)}
.product>.cr-bl{bottom:0;left:0;border-bottom:2px solid var(--accent-2);border-left:2px solid var(--accent-2)}
.product:hover{transform:translateY(-4px);border-color:rgba(255,140,0,.25);box-shadow:0 30px 60px -30px rgba(255,140,0,.35)}
.product:hover::before,.product:hover::after,.product:hover>.cr-tr,.product:hover>.cr-bl{width:24px;height:24px;opacity:1}

.p-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid rgba(255,140,0,.12);background:linear-gradient(90deg,rgba(255,140,0,.05),transparent)}
.p-code{font:600 10px/1 var(--f-mono);letter-spacing:.3em;color:var(--accent);text-transform:uppercase}
.p-status{display:flex;align-items:center;gap:8px;font:500 10px/1 var(--f-mono);letter-spacing:.18em;text-transform:uppercase}
.p-status .live{color:var(--accent-3)}
.p-status .info{color:var(--accent-2)}
.p-status .dotlive{width:7px;height:7px;border-radius:50%;background:var(--accent-3);box-shadow:0 0 10px var(--accent-3);animation:blink 1.2s ease-in-out infinite}
.p-status .dotinfo{width:7px;height:7px;border-radius:50%;background:var(--accent-2);box-shadow:0 0 10px var(--accent-2)}

.p-body{padding:24px 22px 8px;flex:1}
.p-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--accent);border-radius:50%;color:var(--accent);font-size:20px;margin-bottom:18px;position:relative;box-shadow:0 0 24px rgba(255,140,0,.3)}
.p-icon::before{content:'';position:absolute;inset:-6px;border:1px solid rgba(255,140,0,.3);border-radius:50%;animation:pulse-ring 2.4s ease-out infinite}
.p-icon::after{content:'';position:absolute;inset:-12px;border:1px solid rgba(255,140,0,.15);border-radius:50%;animation:pulse-ring 2.4s ease-out infinite .6s}
@keyframes pulse-ring{0%{transform:scale(.85);opacity:1}100%{transform:scale(1.4);opacity:0}}
.p-title{font-family:var(--f-display);font-weight:800;font-size:28px;color:#fff;letter-spacing:-.02em;margin-bottom:6px}
.p-tag{font:500 11px/1 var(--f-mono);letter-spacing:.2em;color:var(--accent-2);text-transform:uppercase;margin-bottom:16px}
.p-desc{color:var(--ink-2);font-size:15px;line-height:1.55;margin-bottom:20px}
.p-feat{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.p-feat span{font:500 10px/1 var(--f-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2);padding:5px 9px;border:1px solid rgba(255,255,255,.08);border-radius:999px}

.p-actions{display:flex;gap:10px;padding:0 22px 22px}
.p-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;font:600 11px/1 var(--f-mono);letter-spacing:.14em;text-transform:uppercase;transition:.25s;cursor:pointer;border:none}
.p-btn.primary{background:var(--accent);color:#0a0a0a}
.p-btn.primary:hover{background:var(--accent-hot);box-shadow:0 0 24px rgba(255,90,31,.55)}
.p-btn.ghost{background:transparent;color:var(--ink);border:1px solid rgba(255,255,255,.14)}
.p-btn.ghost:hover{border-color:var(--accent-2);color:var(--accent-2)}
.p-btn i{font-size:12px}
.p-btn.wa{background:#25d366;color:#052;font-size:11px}
.p-btn.wa:hover{background:#1fb855}
.p-btn.info-cta{
  width:100%;
  background:linear-gradient(180deg,rgba(255,140,0,.06),rgba(255,140,0,.02));
  color:var(--accent);
  border:1px solid rgba(255,140,0,.32);
  letter-spacing:.22em;
  padding:15px 14px;
  position:relative;
  overflow:hidden;
}
.p-btn.info-cta::before{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,140,0,.18),transparent);
  transition:left .6s ease;
}
.p-btn.info-cta:hover{
  border-color:var(--accent);
  background:rgba(255,140,0,.14);
  box-shadow:0 0 26px rgba(255,140,0,.22);
  color:#fff;
}
.p-btn.info-cta:hover::before{left:100%}
.p-btn.info-cta .arrow{transition:transform .25s}
.p-btn.info-cta:hover .arrow{transform:translateX(4px)}

/* ============ PROCESO ============ */
@keyframes spin{to{transform:rotate(360deg)}}
.process{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:40px;padding-top:12px}
@media(max-width:960px){.process{grid-template-columns:repeat(2,1fr);gap:30px 0}}
@media(max-width:540px){.process{grid-template-columns:1fr}}

/* trayectoria SVG serpenteante */
.proc-track{
  position:absolute;top:0;left:0;width:100%;height:120px;
  pointer-events:none;z-index:0;
}
.proc-track .pt-guide{
  fill:none;stroke:rgba(255,140,0,.16);stroke-width:1.2;stroke-dasharray:5 5;
}
.proc-track .pt-draw{
  fill:none;stroke:url(#procGrad);stroke-width:2;stroke-linecap:round;
  stroke-dasharray:1800;stroke-dashoffset:1800;
  filter:drop-shadow(0 0 5px rgba(255,140,0,.45));
  transition:stroke-dashoffset 2.6s cubic-bezier(.22,.92,.43,1) .3s;
}
.process.in .proc-track .pt-draw{stroke-dashoffset:0}
.proc-marker{fill:#ff8c00;filter:drop-shadow(0 0 10px #ff8c00)}
.proc-marker-halo{fill:none;stroke:rgba(255,140,0,.6);stroke-width:1}
@media(max-width:960px){.proc-track{display:none}}

/* mini readout HUD por fase */
.step-readout{
  display:flex;align-items:center;gap:8px;
  font:500 9px/1 var(--f-mono);letter-spacing:.2em;
  color:var(--ink-dim);text-transform:uppercase;
  margin-bottom:10px;padding:6px 10px;
  border:1px solid rgba(255,140,0,.12);
  background:rgba(2,8,24,.6);
  width:fit-content;
  opacity:0;transform:translateY(6px);
  transition:opacity .6s ease 1.4s,transform .6s ease 1.4s;
}
.step.in .step-readout{opacity:1;transform:none}
.step-readout b{color:var(--accent);font-weight:600}
.step-readout .sep{color:rgba(255,140,0,.3)}
.step-readout .led{width:5px;height:5px;background:var(--accent-3);border-radius:50%;box-shadow:0 0 6px var(--accent-3);animation:blink 1.6s infinite}

.step{
  position:relative;padding:0 18px;text-align:left;z-index:1;
  opacity:0;transform:translateY(18px) scale(.96);
  transition:opacity .7s cubic-bezier(.22,.92,.43,1), transform .7s cubic-bezier(.22,.92,.43,1);
}
.step.in{opacity:1;transform:none}
.step:nth-child(1){transition-delay:.1s}
.step:nth-child(2){transition-delay:.25s}
.step:nth-child(3){transition-delay:.4s}
.step:nth-child(4){transition-delay:.55s}

.step-node{
  width:84px;height:84px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#0a1a36,#020818 75%);
  border:1px solid rgba(255,140,0,.12);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  margin-bottom:22px;position:relative;
  box-shadow:0 0 0 rgba(255,140,0,0);
  transition:box-shadow .8s ease 1.1s;
}
.step.in .step-node{box-shadow:0 0 32px rgba(255,140,0,.32), inset 0 0 18px rgba(0,200,255,.08)}

.step-node::after{
  content:'';position:absolute;inset:-9px;border-radius:50%;
  border:1px dashed rgba(255,140,0,.18);
  opacity:0;
  animation:spin 30s linear infinite;
  transition:opacity .8s ease 1.1s;
}
.step.in .step-node::after{opacity:1}

.step-arc{
  position:absolute;inset:-1px;
  width:calc(100% + 2px);height:calc(100% + 2px);
  transform:rotate(-90deg);pointer-events:none;overflow:visible;
}
.step-arc circle{
  fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;
  stroke-dasharray:263.89;stroke-dashoffset:263.89;
  filter:drop-shadow(0 0 6px rgba(255,140,0,.5));
  transition:stroke-dashoffset 1.4s cubic-bezier(.22,.92,.43,1) .3s;
}
.step.in .step-arc circle{stroke-dashoffset:0}

.step-node .num{
  font:800 22px/1 var(--f-display);color:var(--accent);letter-spacing:-.02em;
  text-shadow:0 0 10px rgba(255,140,0,.35);
}
.step-node .ph{font:500 8px/1 var(--f-mono);letter-spacing:.25em;color:var(--ink-2);text-transform:uppercase;margin-top:3px}
.step h4{font-family:var(--f-display);font-weight:700;font-size:20px;color:#fff;margin-bottom:8px;letter-spacing:-.01em}
.step p{font-size:14px;line-height:1.55;color:var(--ink-2)}
.step-code{font:500 10px/1 var(--f-mono);color:var(--accent-2);letter-spacing:.25em;margin-bottom:10px;text-transform:uppercase}

.process-more{display:flex;justify-content:center;margin-top:54px}
.process-link{display:inline-flex;align-items:center;gap:14px;padding:14px 22px;font:600 12px/1 var(--f-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--accent);border:1px solid rgba(255,140,0,.32);background:linear-gradient(180deg,rgba(255,140,0,.06),rgba(255,140,0,.02));transition:.25s;position:relative;overflow:hidden}
.process-link .pl-bar{width:28px;height:1px;background:var(--accent);transition:width .25s}
.process-link .pl-bar::after{content:'';display:block;width:5px;height:5px;background:var(--accent);border-radius:50%;margin-top:-3px;margin-left:23px;box-shadow:0 0 8px var(--accent)}
.process-link:hover{background:rgba(255,140,0,.12);border-color:var(--accent);color:#fff;box-shadow:0 0 24px rgba(255,140,0,.2)}
.process-link:hover .pl-bar{width:40px}
.process-link:hover .pl-bar::after{margin-left:35px}
.process-link .arrow{transition:transform .25s}
.process-link:hover .arrow{transform:translateX(5px)}

/* ============ STACK ============ */
.stack-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
@media(max-width:960px){.stack-wrap{grid-template-columns:1fr;gap:50px}}

.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--frame);border:1px solid var(--frame)}
.stat{background:var(--bg-2);padding:24px 22px;position:relative;overflow:hidden}
.stat::before{content:'';position:absolute;top:10px;right:12px;width:5px;height:5px;background:var(--accent);box-shadow:0 0 8px var(--accent);border-radius:50%;opacity:.8}
.stat:nth-child(2)::before{background:var(--accent-2);box-shadow:0 0 8px var(--accent-2)}
.stat:nth-child(3)::before{background:var(--accent-3);box-shadow:0 0 8px var(--accent-3);animation:blink 1.6s infinite}
.stat:nth-child(4)::before{background:var(--accent-hot);box-shadow:0 0 8px var(--accent-hot)}
.stat .n{font:800 48px/1 var(--f-display);color:#fff;letter-spacing:-.03em;margin-bottom:6px}
.stat .n b{color:var(--accent);font-weight:800}
.stat .l{font:500 10px/1.4 var(--f-mono);letter-spacing:.25em;color:var(--ink-dim);text-transform:uppercase;margin-bottom:12px}
.stat-bar{height:3px;background:rgba(255,140,0,.1);position:relative;overflow:hidden}
.stat-bar .fill{position:absolute;inset:0;background:linear-gradient(90deg,var(--accent),var(--accent-hot));transform:scaleX(0);transform-origin:left center;transition:transform 1.4s cubic-bezier(.22,.92,.43,1)}
.stat:nth-child(2) .stat-bar .fill{background:linear-gradient(90deg,var(--accent-2),#0099ff)}
.stat:nth-child(3) .stat-bar .fill{background:linear-gradient(90deg,var(--accent-3),#0aa36f)}
.stat:nth-child(4) .stat-bar .fill{background:linear-gradient(90deg,var(--accent-hot),var(--accent))}
.stack-wrap.in .stat-bar .fill{transform:scaleX(var(--w,1))}
.stat-bar .fill::after{content:'';position:absolute;right:0;top:-2px;bottom:-2px;width:10px;background:#fff;filter:blur(3px);opacity:.8}

/* ====== TECH RADIAL ====== */
.tech-radial{
  position:relative;aspect-ratio:1/1;
  max-width:500px;margin:0 auto;width:100%;
}
.radial-svg{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;overflow:visible}
.rline{
  stroke:rgba(255,140,0,.22);stroke-width:.3;
  stroke-dasharray:80;stroke-dashoffset:80;
  transition:stroke-dashoffset 1.1s cubic-bezier(.22,.92,.43,1);
}
.tech-radial.in .rline{stroke-dashoffset:0}
.tech-radial.in .rline:nth-child(1){transition-delay:.1s}
.tech-radial.in .rline:nth-child(2){transition-delay:.2s}
.tech-radial.in .rline:nth-child(3){transition-delay:.3s}
.tech-radial.in .rline:nth-child(4){transition-delay:.4s}
.tech-radial.in .rline:nth-child(5){transition-delay:.5s}
.tech-radial.in .rline:nth-child(6){transition-delay:.6s}
/* líneas con flow pattern tras dibujarse */
.tech-radial.in .rline{animation:rline-flow 6s linear 1.6s infinite}
@keyframes rline-flow{
  0%{stroke-dasharray:4 4;stroke-dashoffset:0}
  100%{stroke-dasharray:4 4;stroke-dashoffset:-80}
}

.radial-center{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:128px;height:128px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#0a1a36,#020818 75%);
  border:1.5px solid var(--accent);
  box-shadow:0 0 36px rgba(255,140,0,.45), inset 0 0 30px rgba(0,200,255,.1);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  z-index:3;
}
.radial-center::before,.radial-center::after{
  content:'';position:absolute;inset:-6px;border-radius:50%;
  border:1px dashed rgba(255,140,0,.35);
  animation:spin 22s linear infinite;
}
.radial-center::after{inset:-14px;border:1px solid rgba(0,200,255,.18);animation:spin 32s linear reverse infinite}
.radial-center .rc-label{font:800 22px/1 var(--f-display);color:#fff;letter-spacing:-.02em}
.radial-center .rc-sub{font:500 8px/1 var(--f-mono);color:var(--accent);letter-spacing:.3em;text-transform:uppercase;margin-top:6px}
.radial-center .rc-live{width:6px;height:6px;background:var(--accent-3);border-radius:50%;box-shadow:0 0 8px var(--accent-3);animation:blink 1.4s infinite;margin-top:8px}

.tech-node{
  position:absolute;transform:translate(-50%,-50%);
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;
  background:rgba(2,8,24,.92);
  border:1px solid rgba(255,140,0,.25);
  z-index:2;
  min-width:120px;
  opacity:0;transform:translate(-50%,-50%) scale(.8);
  transition:opacity .6s ease,transform .6s cubic-bezier(.22,.92,.43,1);
}
.tech-radial.in .tech-node{opacity:1;transform:translate(-50%,-50%) scale(1)}
.tech-radial.in .tech-node:nth-of-type(1){transition-delay:.7s}
.tech-radial.in .tech-node:nth-of-type(2){transition-delay:.8s}
.tech-radial.in .tech-node:nth-of-type(3){transition-delay:.9s}
.tech-radial.in .tech-node:nth-of-type(4){transition-delay:1.0s}
.tech-radial.in .tech-node:nth-of-type(5){transition-delay:1.1s}
.tech-radial.in .tech-node:nth-of-type(6){transition-delay:1.2s}
.tech-node::before{content:'';position:absolute;top:-1px;left:-1px;width:10px;height:10px;border-top:1.5px solid var(--accent);border-left:1.5px solid var(--accent)}
.tech-node::after{content:'';position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-bottom:1.5px solid var(--accent);border-right:1.5px solid var(--accent)}
.tech-node:hover{background:rgba(8,22,48,1);border-color:var(--accent);box-shadow:0 0 22px rgba(255,140,0,.3)}
.tech-node i{font-size:20px;color:var(--accent)}
.tech-node .nm{font:700 13px/1 var(--f-display);color:#fff;letter-spacing:-.01em}
.tech-node .v{font:500 9px/1 var(--f-mono);color:var(--ink-dim);letter-spacing:.12em;margin-top:3px;text-transform:uppercase}

/* posiciones hexagonales */
.tech-node[data-pos="top"]{top:14%;left:50%}
.tech-node[data-pos="tr"]{top:32%;left:86%}
.tech-node[data-pos="br"]{top:68%;left:86%}
.tech-node[data-pos="bot"]{top:86%;left:50%}
.tech-node[data-pos="bl"]{top:68%;left:14%}
.tech-node[data-pos="tl"]{top:32%;left:14%}

@media(max-width:540px){
  .tech-node{min-width:auto;padding:8px 10px}
  .tech-node .nm{font-size:11px}
  .tech-node .v{font-size:8px}
  .radial-center{width:100px;height:100px}
  .radial-center .rc-label{font-size:18px}
}

/* ============ CONTACTO · PANEL DE COMUNICACIONES ============ */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:880px){.contact-wrap{grid-template-columns:1fr}}

.contact-card{
  position:relative;
  background:
    linear-gradient(180deg,rgba(2,8,24,.85),rgba(7,21,48,.75)),
    linear-gradient(135deg,transparent 0%,rgba(255,140,0,.03) 100%);
  border:1px solid rgba(255,255,255,.06);
  padding:0;
  backdrop-filter:blur(6px);
  overflow:hidden;
}
.contact-card .cr-tl,.contact-card .cr-tr,.contact-card .cr-bl,.contact-card .cr-br{position:absolute;width:22px;height:22px;pointer-events:none;z-index:2}
.contact-card .cr-tl{top:-1px;left:-1px;border-top:2px solid var(--accent);border-left:2px solid var(--accent)}
.contact-card .cr-tr{top:-1px;right:-1px;border-top:2px solid var(--accent-2);border-right:2px solid var(--accent-2)}
.contact-card .cr-bl{bottom:-1px;left:-1px;border-bottom:2px solid var(--accent-2);border-left:2px solid var(--accent-2)}
.contact-card .cr-br{bottom:-1px;right:-1px;border-bottom:2px solid var(--accent);border-right:2px solid var(--accent)}

.cc-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:14px 22px;
  border-bottom:1px dashed rgba(255,140,0,.22);
  font:500 10px/1 var(--f-mono);letter-spacing:.25em;text-transform:uppercase;
  background:linear-gradient(90deg,rgba(255,140,0,.06),transparent);
}
.cc-head .cc-ch{color:var(--accent);display:flex;align-items:center;gap:8px}
.cc-head .cc-ch::before{content:'';width:7px;height:7px;background:var(--accent);border-radius:50%;box-shadow:0 0 8px var(--accent)}
.cc-head .cc-st{color:var(--accent-3);display:flex;align-items:center;gap:6px}
.cc-head .cc-st::after{content:'';width:7px;height:7px;background:var(--accent-3);border-radius:50%;box-shadow:0 0 10px var(--accent-3);animation:blink 1.4s infinite}

.cc-body{padding:26px 22px 24px}
.contact-card h3{font-family:var(--f-display);font-weight:800;font-size:24px;color:#fff;letter-spacing:-.02em;margin-bottom:6px}
.contact-card .lead{color:var(--ink-2);font-size:14px;line-height:1.6;margin-bottom:22px}

/* ── WhatsApp box con waves + signal bars ── */
.wa-box{
  display:flex;align-items:center;gap:14px;padding:18px 20px;
  border:1px solid rgba(37,211,102,.3);
  background:linear-gradient(90deg,rgba(37,211,102,.10),rgba(37,211,102,.02));
  margin-bottom:20px;transition:.3s;position:relative;cursor:pointer;overflow:hidden;
}
.wa-box::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:#25d366;box-shadow:0 0 12px rgba(37,211,102,.7)}
.wa-box:hover{border-color:rgba(37,211,102,.7);background:linear-gradient(90deg,rgba(37,211,102,.18),rgba(37,211,102,.05));transform:translateX(2px)}
.wa-box .wa-ic{position:relative;width:42px;height:42px;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:2}
.wa-box .wa-ic i{font-size:30px;color:#25d366;position:relative;z-index:2}
.wa-box .wa-ic::before,.wa-box .wa-ic::after{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  border:1px solid rgba(37,211,102,.5);
  animation:wa-ring 2.2s ease-out infinite;
}
.wa-box .wa-ic::after{animation-delay:1.1s}
@keyframes wa-ring{0%{transform:scale(.7);opacity:1}100%{transform:scale(1.8);opacity:0}}

.wa-box .wa-txt{flex:1;min-width:0;z-index:2}
.wa-box .t1{font:700 16px/1.2 var(--f-display);color:#fff;margin-bottom:3px;letter-spacing:-.01em}
.wa-box .t2{font:500 11px/1.3 var(--f-mono);letter-spacing:.12em;color:var(--ink-2);text-transform:uppercase}

.wa-sig{display:flex;align-items:flex-end;gap:3px;height:22px;z-index:2}
.wa-sig span{width:3px;background:#25d366;border-radius:1px;box-shadow:0 0 6px rgba(37,211,102,.6);animation:wa-sig 1.4s ease-in-out infinite}
.wa-sig span:nth-child(1){height:6px;animation-delay:0s}
.wa-sig span:nth-child(2){height:10px;animation-delay:.18s}
.wa-sig span:nth-child(3){height:14px;animation-delay:.36s}
.wa-sig span:nth-child(4){height:20px;animation-delay:.54s}
@keyframes wa-sig{0%,100%{opacity:.35;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ── Osciloscopio ── */
.cc-scope{
  margin:4px 0 22px;padding:12px 14px 10px;
  background:rgba(2,8,24,.7);
  border:1px solid rgba(0,200,255,.18);
  position:relative;
}
.cc-scope::before{content:'';position:absolute;top:-1px;left:-1px;width:10px;height:10px;border-top:1.5px solid var(--accent-2);border-left:1.5px solid var(--accent-2)}
.cc-scope::after{content:'';position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-bottom:1.5px solid var(--accent-2);border-right:1.5px solid var(--accent-2)}
.cc-scope-head{
  display:flex;justify-content:space-between;align-items:center;
  font:500 9px/1 var(--f-mono);letter-spacing:.22em;
  color:var(--ink-dim);text-transform:uppercase;margin-bottom:8px;
}
.cc-scope-head b{color:var(--accent-2);letter-spacing:.22em}
.cc-scope-head .freq{color:var(--accent-3)}
.cc-scope svg{display:block;width:100%;height:36px;overflow:visible}
.cc-wave{
  fill:none;stroke:var(--accent-2);stroke-width:1.5;stroke-linecap:round;
  filter:drop-shadow(0 0 4px var(--accent-2));
  stroke-dasharray:4 2;
  animation:wave-flow 2s linear infinite;
}
@keyframes wave-flow{from{stroke-dashoffset:0}to{stroke-dashoffset:-60}}
.cc-wave-bg{fill:none;stroke:rgba(0,200,255,.08);stroke-width:1}

/* ── Meta list HUD ── */
.meta-list{display:grid;gap:6px}
.meta-item{
  display:grid;grid-template-columns:74px 1fr auto;align-items:center;gap:12px;
  padding:11px 14px 11px 16px;
  border:1px solid rgba(255,255,255,.05);
  background:linear-gradient(90deg,rgba(255,140,0,.03),transparent);
  font-family:var(--f-mono);
  position:relative;
  transition:.2s;
}
.meta-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent);opacity:.6}
.meta-item:nth-child(2)::before{background:var(--accent-2)}
.meta-item:nth-child(3)::before{background:var(--accent-3)}
.meta-item:hover{background:linear-gradient(90deg,rgba(255,140,0,.08),transparent);border-color:rgba(255,140,0,.2)}
.meta-item .key{font-size:9px;letter-spacing:.24em;color:var(--ink-dim);text-transform:uppercase}
.meta-item .val{font-size:12.5px;color:#fff;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.02em}
.meta-item .val b{color:var(--accent);font-weight:500}
.meta-item .ind{font-size:9px;color:var(--accent-3);letter-spacing:.22em;text-transform:uppercase;display:flex;align-items:center;gap:5px}
.meta-item .ind::before{content:'';width:5px;height:5px;background:var(--accent-3);border-radius:50%;box-shadow:0 0 6px var(--accent-3)}

/* ── Form HUD ── */
.form-field{margin-bottom:14px;position:relative}
.form-field label{
  display:flex;justify-content:space-between;align-items:center;
  font:500 10px/1 var(--f-mono);letter-spacing:.22em;
  color:var(--ink-dim);text-transform:uppercase;margin-bottom:8px;
}
.form-field label .lb-pfx{color:var(--accent);margin-right:10px}
.form-field label .lb-hint{color:rgba(255,255,255,.18);font-size:9px;letter-spacing:.18em}
.form-field .wrap{position:relative}
.form-field .wrap::before,.form-field .wrap::after{
  content:'';position:absolute;width:9px;height:9px;
  pointer-events:none;opacity:0;transition:opacity .25s ease;z-index:1;
}
.form-field .wrap::before{top:-1px;left:-1px;border-top:1.5px solid var(--accent);border-left:1.5px solid var(--accent)}
.form-field .wrap::after{bottom:-1px;right:-1px;border-bottom:1.5px solid var(--accent);border-right:1.5px solid var(--accent)}
.form-field .wrap:focus-within::before,.form-field .wrap:focus-within::after{opacity:1}
.form-field input,.form-field select,.form-field textarea{
  width:100%;background:rgba(2,8,24,.6);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;padding:12px 14px;
  font:500 14px/1.2 var(--f-body);outline:none;transition:.2s;
}
.form-field textarea{resize:vertical;min-height:90px;line-height:1.5}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  border-color:var(--accent);
  background:rgba(255,140,0,.04);
  box-shadow:0 0 0 3px rgba(255,140,0,.12);
}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(154,176,208,.4);font-family:var(--f-mono);font-size:12px;letter-spacing:.05em}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:540px){.form-row{grid-template-columns:1fr}}

/* Form progress */
.form-progress{
  display:flex;align-items:center;gap:12px;margin:18px 0 14px;
  font:500 9px/1 var(--f-mono);letter-spacing:.22em;
  color:var(--ink-dim);text-transform:uppercase;
}
.form-progress .fp-label{min-width:60px}
.form-progress .fp-bar{flex:1;height:3px;background:rgba(255,140,0,.08);position:relative;overflow:hidden}
.form-progress .fp-fill{position:absolute;inset:0;background:linear-gradient(90deg,var(--accent),var(--accent-hot));transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.22,.92,.43,1)}
.form-progress .fp-fill::after{content:'';position:absolute;top:-2px;bottom:-2px;right:0;width:8px;background:#fff;filter:blur(3px);opacity:.8}
.form-progress .fp-pct{color:var(--accent);min-width:34px;text-align:right;font-weight:600}

/* Transmit button */
.btn-transmit{
  width:100%;position:relative;overflow:hidden;
  padding:15px 20px;
  background:linear-gradient(90deg,var(--accent),var(--accent-hot));
  color:#0a0a0a;
  font:700 12px/1 var(--f-mono);letter-spacing:.25em;text-transform:uppercase;
  border:none;cursor:pointer;transition:.25s;
  box-shadow:0 0 0 1px var(--accent), 0 10px 28px -10px rgba(255,140,0,.7);
}
.btn-transmit::after{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);
  transition:left .8s ease;
}
.btn-transmit:hover{transform:translateY(-1px);box-shadow:0 0 0 1px var(--accent-hot),0 0 40px rgba(255,90,31,.6)}
.btn-transmit:hover::after{left:100%}
.btn-transmit .arrow{transition:transform .25s;display:inline-block;margin-left:6px}
.btn-transmit:hover .arrow{transform:translateX(4px)}

/* ============ FOOTER ============ */
footer{border-top:1px solid var(--frame-soft);padding:40px 0 30px;margin-top:60px;position:relative;z-index:3}
.foot{max-width:var(--maxw);margin:0 auto;padding:0 36px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.foot .fl{display:flex;align-items:center;gap:14px;font:500 11px/1 var(--f-mono);letter-spacing:.22em;color:var(--ink-dim);text-transform:uppercase}
.foot .fl b{color:var(--accent)}
.foot .fr{display:flex;gap:18px;font:500 11px/1 var(--f-mono);letter-spacing:.18em;color:var(--ink-dim);text-transform:uppercase}
.foot .fr a:hover{color:var(--accent)}
@media(max-width:540px){.foot{padding:0 20px}}

/* ============ WA FLOAT ============ */
.wa-float{position:fixed;bottom:26px;right:26px;z-index:50;display:flex;align-items:center;gap:10px;padding:14px 20px 14px 16px;background:#25d366;color:#052;border-radius:999px;font:700 13px/1 var(--f-display);box-shadow:0 10px 30px -8px rgba(37,211,102,.7);transition:.25s}
.wa-float:hover{transform:translateY(-2px);box-shadow:0 14px 40px -8px rgba(37,211,102,.9)}
.wa-float i{font-size:22px}
.wa-float::after{content:'';position:absolute;inset:-6px;border-radius:999px;border:2px solid rgba(37,211,102,.4);animation:pulse-wa 2s ease-out infinite}
@keyframes pulse-wa{0%{transform:scale(1);opacity:1}100%{transform:scale(1.15);opacity:0}}
@media(max-width:540px){.wa-float span{display:none}.wa-float{padding:14px;border-radius:50%}}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ============ MODAL LIVE DEMO ============ */
.modal{position:fixed;inset:0;background:rgba(2,8,24,.85);backdrop-filter:blur(10px);z-index:100;display:none;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease}
.modal.show{display:flex}
.modal-in{position:relative;max-width:620px;width:100%;background:var(--bg-2);border:1px solid var(--frame);padding:38px 34px}
.modal-in .cr-tl{position:absolute;top:-1px;left:-1px;width:22px;height:22px;border-top:2px solid var(--accent);border-left:2px solid var(--accent)}
.modal-in .cr-tr{position:absolute;top:-1px;right:-1px;width:22px;height:22px;border-top:2px solid var(--accent-2);border-right:2px solid var(--accent-2)}
.modal-in .cr-bl{position:absolute;bottom:-1px;left:-1px;width:22px;height:22px;border-bottom:2px solid var(--accent-2);border-left:2px solid var(--accent-2)}
.modal-in .cr-br{position:absolute;bottom:-1px;right:-1px;width:22px;height:22px;border-bottom:2px solid var(--accent);border-right:2px solid var(--accent)}
.modal-in .close{position:absolute;top:14px;right:14px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--ink-2);border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:.2s}
.modal-in .close:hover{color:var(--accent);border-color:var(--accent)}
.modal-in .kicker{font:500 10px/1 var(--f-mono);letter-spacing:.25em;color:var(--accent);text-transform:uppercase;margin-bottom:10px}
.modal-in h3{font-family:var(--f-display);font-weight:800;font-size:28px;color:#fff;letter-spacing:-.02em;margin-bottom:6px}
.modal-in .m-tag{font:500 11px/1 var(--f-mono);letter-spacing:.22em;color:var(--accent-2);text-transform:uppercase;margin-bottom:18px}
.modal-in p{color:var(--ink-2);font-size:15px;line-height:1.6;margin-bottom:18px}
.modal-in .m-audience{padding:18px 18px 14px;border:1px solid rgba(255,140,0,.18);background:linear-gradient(180deg,rgba(255,140,0,.05),transparent);margin-bottom:22px;position:relative}
.modal-in .m-audience::before{content:'';position:absolute;top:-1px;left:-1px;width:14px;height:14px;border-top:1.5px solid var(--accent);border-left:1.5px solid var(--accent)}
.modal-in .m-audience::after{content:'';position:absolute;bottom:-1px;right:-1px;width:14px;height:14px;border-bottom:1.5px solid var(--accent);border-right:1.5px solid var(--accent)}
.modal-in .m-audience-label{font:500 10px/1 var(--f-mono);letter-spacing:.28em;color:var(--accent);text-transform:uppercase;margin-bottom:12px}
.modal-in .m-audience ul{list-style:none;padding:0;margin:0}
.modal-in .m-audience li{color:var(--ink);font-size:14px;line-height:1.5;padding:5px 0 5px 20px;position:relative}
.modal-in .m-audience li::before{content:'▸';position:absolute;left:0;top:5px;color:var(--accent);font-size:13px}
.modal-in .act{display:flex;gap:10px;flex-wrap:wrap}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--bg-2);border:1px solid var(--accent);padding:12px 18px;font:500 12px/1.4 var(--f-mono);letter-spacing:.12em;color:#fff;z-index:200;opacity:0;pointer-events:none;transition:opacity .3s}
.toast.show{opacity:1}
