:root{
  --bg:#050509;
  --bg-2:#080812;
  --panel:rgba(16,16,28,.76);
  --panel-2:rgba(255,255,255,.065);
  --text:#f7f5ef;
  --muted:#aaa7ba;
  --soft:#d9d7e5;
  --line:rgba(255,255,255,.12);
  --line-2:rgba(255,255,255,.22);
  --primary:#7a5cff;
  --cyan:#55f0d2;
  --pink:#ff4db8;
  --orange:#ff8a22;
  --radius:30px;
  --radius-sm:18px;
  --shadow:0 28px 90px rgba(0,0,0,.38);
  --ease:220ms cubic-bezier(.16,1,.32,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:96px}
body{
  min-height:100vh;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 14% -8%,rgba(122,92,255,.28),transparent 34%),
    radial-gradient(circle at 88% 0%,rgba(85,240,210,.14),transparent 28%),
    linear-gradient(180deg,#070711 0%,var(--bg) 48%,#07070d 100%);
  -webkit-font-smoothing:antialiased;
  text-rendering:geometricPrecision;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-3;
  pointer-events:none;
  opacity:.22;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:linear-gradient(to bottom,#000 0%,transparent 78%);
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background:radial-gradient(circle at 50% 18%,transparent 0 22%,rgba(5,5,9,.72) 62%,rgba(5,5,9,.96) 100%);
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit}
button{border:0}
.container{width:min(1180px,calc(100% - 44px));margin-inline:auto}
.skip{position:absolute;left:-999px;top:12px;z-index:999;background:#fff;color:#080812;padding:12px 16px;border-radius:999px;font-weight:800}
.skip:focus{left:12px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.hidden{display:none!important}

.site-header{
  position:fixed;
  inset:0 0 auto;
  z-index:50;
  border-bottom:1px solid var(--line);
  background:rgba(5,5,9,.62);
  backdrop-filter:blur(22px);
  transition:background var(--ease),box-shadow var(--ease),border-color var(--ease);
}
.site-header.is-scrolled{background:rgba(5,5,9,.88);box-shadow:0 16px 60px rgba(0,0,0,.34);border-color:rgba(255,255,255,.16)}
.header-inner{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:inline-flex;align-items:center;gap:12px;min-width:max-content}
.brand-logo{width:48px;height:48px;display:grid;place-items:center;border-radius:16px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.16);overflow:hidden;box-shadow:0 16px 42px rgba(0,0,0,.32)}
.brand-logo img{width:100%;height:100%;object-fit:cover;transform:scale(1.2)}
.brand-copy{display:grid;gap:4px}
.brand-title{font-weight:900;letter-spacing:.055em;font-size:14px;line-height:1;text-transform:uppercase}
.brand-title em{font-style:normal;background:linear-gradient(120deg,var(--orange),var(--pink),var(--primary));-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-subtitle{font-size:10px;color:var(--muted);letter-spacing:.18em;text-transform:uppercase}
.nav{display:flex;align-items:center;gap:28px;color:rgba(255,255,255,.72);font-size:14px;font-weight:650}
.nav a{position:relative;padding:6px 0;transition:color var(--ease)}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:linear-gradient(90deg,var(--orange),var(--pink),var(--primary),var(--cyan));transition:width var(--ease)}
.nav a:hover,.nav a:focus-visible{color:var(--text)}
.nav a:hover::after,.nav a:focus-visible::after{width:100%}
.menu-toggle{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:15px;background:rgba(255,255,255,.055);cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.menu-toggle span:not(.sr-only){display:block;width:19px;height:2px;border-radius:99px;background:#fff;transition:transform var(--ease),opacity var(--ease)}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:13px 20px;border-radius:999px;font-weight:850;font-size:14px;letter-spacing:-.01em;cursor:pointer;transition:transform var(--ease),box-shadow var(--ease),border-color var(--ease),background var(--ease);white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn:focus-visible{outline:3px solid rgba(85,240,210,.35);outline-offset:4px}
.btn-primary{color:#050509;background:linear-gradient(120deg,#fff 0%,#fff0d6 12%,var(--orange) 30%,var(--pink) 64%,var(--primary) 100%);box-shadow:0 0 42px rgba(122,92,255,.38),0 16px 42px rgba(0,0,0,.28)}
.btn-secondary{border:1px solid var(--line-2);color:var(--text);background:rgba(255,255,255,.07);backdrop-filter:blur(14px)}
.btn-light{background:#fff;color:#070711;box-shadow:0 22px 58px rgba(255,255,255,.12)}

.hero{position:relative;overflow:hidden;padding:158px 0 84px;border-bottom:1px solid var(--line)}
.orb{position:absolute;border-radius:999px;filter:blur(88px);opacity:.72;pointer-events:none;animation:float-orb 16s ease-in-out infinite alternate}
.orb-1{width:430px;height:430px;left:-120px;top:20px;background:rgba(255,77,184,.42)}
.orb-2{width:520px;height:520px;right:-190px;top:80px;background:rgba(85,240,210,.26);animation-duration:22s}
.orb-3{width:360px;height:360px;left:45%;bottom:-170px;background:rgba(255,138,34,.28);animation-duration:26s}
@keyframes float-orb{to{transform:translate3d(42px,-28px,0) scale(1.08)}}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.badge{display:inline-flex;align-items:center;gap:10px;max-width:max-content;margin-bottom:24px;padding:9px 15px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.055);box-shadow:0 18px 56px rgba(0,0,0,.25);backdrop-filter:blur(16px);color:rgba(255,255,255,.78);font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:800}
.badge span{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 22px rgba(85,240,210,.95)}
h1{font-size:clamp(48px,7.4vw,91px);line-height:.96;letter-spacing:-.072em;font-weight:900;max-width:880px;background:linear-gradient(120deg,#fff,#f6f1ff 45%,#9ef6e7);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-text{max-width:720px;margin-top:28px;color:var(--muted);font-size:19px;line-height:1.72}
.hero-text strong{color:var(--text)}
.hero-actions{display:flex;gap:13px;flex-wrap:wrap;margin-top:34px}
.trust-list{display:flex;gap:12px 22px;flex-wrap:wrap;list-style:none;margin-top:28px;color:rgba(255,255,255,.79);font-size:14px}
.trust-list li{display:inline-flex;align-items:center;gap:9px}
.trust-list li::before{content:"";width:7px;height:7px;border-radius:50%;background:linear-gradient(120deg,var(--cyan),var(--primary));box-shadow:0 0 15px rgba(85,240,210,.65)}
.hero-visual{position:relative;min-height:560px;display:grid;place-items:center;perspective:1000px}
.visual-card{position:relative;width:min(470px,100%);aspect-ratio:1/1.12;border:1px solid rgba(255,255,255,.16);border-radius:42px;background:linear-gradient(155deg,rgba(255,255,255,.12),rgba(255,255,255,.035));box-shadow:var(--shadow),inset 0 1px 0 rgba(255,255,255,.16);overflow:hidden;backdrop-filter:blur(18px);transform:rotateX(5deg) rotateY(-8deg)}
.visual-card::before{content:"";position:absolute;inset:-1px;background:radial-gradient(circle at 50% 36%,rgba(85,240,210,.24),transparent 32%),radial-gradient(circle at 65% 70%,rgba(122,92,255,.28),transparent 30%);z-index:0}
.visual-card img{position:absolute;inset:8% 6% auto;margin:auto;width:88%;z-index:1;filter:drop-shadow(0 30px 70px rgba(0,0,0,.55));animation:logo-float 5s ease-in-out infinite}
@keyframes logo-float{0%,100%{transform:translateY(0) scale(1.02)}50%{transform:translateY(-12px) scale(1.04)}}
.scanline{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,transparent 0 46%,rgba(85,240,210,.28) 48%,transparent 51%);animation:scan 4.5s ease-in-out infinite;mix-blend-mode:screen;opacity:.75}
@keyframes scan{0%,100%{transform:translateY(-45%)}50%{transform:translateY(45%)}}
.visual-caption{position:absolute;left:26px;right:26px;bottom:24px;z-index:3;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:17px 18px;border:1px solid var(--line);border-radius:22px;background:rgba(5,5,9,.66);backdrop-filter:blur(16px)}
.visual-caption span{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.16em;font-weight:800}.visual-caption strong{font-size:15px}
.floating-chip{position:absolute;z-index:4;padding:11px 14px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.095);box-shadow:0 18px 48px rgba(0,0,0,.28);backdrop-filter:blur(16px);font-size:13px;font-weight:850}
.chip-a{top:82px;left:0}.chip-b{right:0;top:270px}.chip-c{left:28px;bottom:88px}
.metrics{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:78px}
.metric{min-height:126px;padding:22px;border:1px solid var(--line);border-radius:24px;background:rgba(255,255,255,.055);box-shadow:0 18px 70px rgba(0,0,0,.24);backdrop-filter:blur(18px)}
.metric strong{display:block;margin-bottom:18px;font-size:13px;color:var(--cyan);letter-spacing:.18em}.metric span{color:rgba(255,255,255,.84);line-height:1.45;font-weight:700}

.section{position:relative;padding:112px 0}.section-dark{overflow:hidden;background:radial-gradient(circle at 18% 18%,rgba(85,240,210,.12),transparent 29%),radial-gradient(circle at 82% 60%,rgba(122,92,255,.2),transparent 34%),linear-gradient(135deg,#101023 0%,#06060c 68%);border-block:1px solid var(--line)}
.section-head{max-width:790px;margin-bottom:54px}.section-head.centered{margin-inline:auto;text-align:center}.eyebrow{margin-bottom:16px;color:var(--cyan);font-size:12px;font-weight:900;letter-spacing:.22em;text-transform:uppercase}.section h2{font-size:clamp(34px,5vw,58px);line-height:1.04;letter-spacing:-.05em;font-weight:900;background:linear-gradient(120deg,#fff,#dcdcff 52%,#8af6e3);-webkit-background-clip:text;background-clip:text;color:transparent}.section-head p,.sticky-copy p,.contact-copy p{margin-top:20px;color:var(--muted);font-size:18px;line-height:1.72}
.service-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.service-card{position:relative;overflow:hidden;min-height:350px;padding:31px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:0 18px 70px rgba(0,0,0,.27);backdrop-filter:blur(18px);transition:transform var(--ease),border-color var(--ease),background var(--ease)}
.service-card:hover{transform:translateY(-6px);border-color:var(--line-2);background:rgba(24,24,42,.86)}
.service-card::before{content:"";position:absolute;width:240px;height:240px;top:-140px;right:-110px;border-radius:50%;background:radial-gradient(circle,rgba(122,92,255,.26),transparent 68%);transition:transform var(--ease)}
.service-card:hover::before{transform:scale(1.45)}
.card-icon{width:56px;height:56px;margin-bottom:26px;border-radius:19px;display:grid;place-items:center;color:#06060c;background:linear-gradient(120deg,var(--orange),var(--pink),var(--primary));box-shadow:0 0 38px rgba(122,92,255,.38);font-weight:950;letter-spacing:-.04em}.card-kicker{margin-bottom:11px;color:var(--cyan);font-size:12px;text-transform:uppercase;letter-spacing:.16em;font-weight:900}.service-card h3{font-size:29px;line-height:1.08;letter-spacing:-.035em;margin-bottom:15px}.service-card p:not(.card-kicker){color:var(--muted);line-height:1.68}.tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:26px}.tags span{padding:8px 11px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.04);font-size:12px;color:rgba(255,255,255,.8);font-weight:750}
.process-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:58px;align-items:start}.sticky-copy{position:sticky;top:118px}.sticky-copy .btn{margin-top:28px}.steps{display:grid;gap:15px}.step{display:grid;grid-template-columns:80px 1fr;gap:24px;padding:28px;border:1px solid rgba(255,255,255,.15);border-radius:26px;background:rgba(255,255,255,.07);backdrop-filter:blur(16px);transition:transform var(--ease),background var(--ease),border-color var(--ease)}.step:hover{transform:translateX(8px);background:rgba(255,255,255,.095);border-color:rgba(255,255,255,.26)}.step span{color:var(--cyan);font-size:36px;font-weight:900;letter-spacing:-.06em}.step h3{font-size:22px;margin-bottom:8px}.step p{color:rgba(255,255,255,.72);line-height:1.62}
.feature-panel{display:grid;grid-template-columns:.95fr 1.05fr;gap:34px;align-items:center;padding:34px;border:1px solid var(--line);border-radius:36px;background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.035));box-shadow:var(--shadow);backdrop-filter:blur(18px)}.feature-copy{padding:24px}.feature-copy h3{font-size:clamp(28px,4vw,44px);line-height:1.05;letter-spacing:-.045em}.feature-copy p{margin-top:20px;color:var(--muted);font-size:17px;line-height:1.75}.feature-list{display:grid;gap:12px}.feature-list div{display:flex;align-items:center;gap:12px;padding:18px;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.055);color:rgba(255,255,255,.82);font-weight:750}.feature-list span{width:9px;height:9px;border-radius:999px;background:linear-gradient(120deg,var(--cyan),var(--primary));box-shadow:0 0 18px rgba(85,240,210,.6)}
.pricing-grid{display:grid;grid-template-columns:.86fr 1.14fr;gap:52px;align-items:start}.pricing-table{overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow);backdrop-filter:blur(18px)}.pricing-row{display:grid;grid-template-columns:1.15fr .75fr .85fr;gap:18px;align-items:center;padding:20px 22px;border-bottom:1px solid var(--line);transition:background var(--ease),padding-left var(--ease)}.pricing-row:last-child{border-bottom:0}.pricing-row:not(.pricing-head):hover{background:rgba(122,92,255,.09);padding-left:30px}.pricing-head{background:rgba(255,255,255,.055);color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.16em;font-weight:900}.pricing-row strong{font-size:16px}.pricing-row span{color:rgba(255,255,255,.72)}.pricing-row em{justify-self:start;padding:8px 11px;border-radius:999px;background:rgba(85,240,210,.1);color:var(--cyan);font-style:normal;font-size:12px;font-weight:900}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:start}.contact-actions{display:grid;gap:12px;margin-top:30px}.contact-link{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 20px;border:1px solid rgba(255,255,255,.15);border-radius:22px;background:rgba(255,255,255,.07);transition:transform var(--ease),border-color var(--ease),background var(--ease)}.contact-link:hover{transform:translateX(6px);background:rgba(255,255,255,.095);border-color:rgba(255,255,255,.25)}.contact-link span{color:var(--cyan);font-size:12px;text-transform:uppercase;letter-spacing:.16em;font-weight:900}.contact-link strong{font-size:15px}.contact-form{display:grid;gap:15px;padding:30px;border:1px solid var(--line);border-radius:var(--radius);background:rgba(255,255,255,.075);box-shadow:var(--shadow);backdrop-filter:blur(18px)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.contact-form label{display:grid;gap:9px;color:rgba(255,255,255,.88);font-size:13px;font-weight:800}.contact-form input,.contact-form textarea,.contact-form select{width:100%;border:1px solid rgba(255,255,255,.16);border-radius:17px;background:rgba(5,5,9,.4);color:var(--text);padding:15px 15px;outline:none;transition:border-color var(--ease),background var(--ease),box-shadow var(--ease)}.contact-form select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 20px) 50%,calc(100% - 14px) 50%;background-size:6px 6px,6px 6px;background-repeat:no-repeat}.contact-form textarea{min-height:144px;resize:vertical}.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(255,255,255,.38)}.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{border-color:rgba(85,240,210,.58);background:rgba(5,5,9,.55);box-shadow:0 0 0 4px rgba(85,240,210,.08)}.contact-form .btn{width:max-content}.form-note{color:rgba(255,255,255,.55);font-size:12px;line-height:1.55}
.footer{border-top:1px solid var(--line);background:rgba(5,5,9,.92);padding:34px 0}.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;color:var(--muted);font-size:13px}.brand-footer .brand-logo{width:42px;height:42px}.brand-footer .brand-title{font-size:13px}
.reveal{opacity:0;transform:translateY(22px);transition:opacity 720ms ease,transform 720ms ease}.reveal.is-visible{opacity:1;transform:translateY(0)}
@media (max-width:1020px){.header-cta{display:none}.hero-grid,.process-grid,.pricing-grid,.contact-grid{grid-template-columns:1fr}.hero-content{text-align:center}.hero-content .badge,.hero-actions,.trust-list{justify-content:center;margin-inline:auto}.hero-text{margin-inline:auto}.hero-visual{min-height:500px}.sticky-copy{position:static}.section-head{max-width:100%}}
@media (max-width:860px){html{scroll-padding-top:78px}.menu-toggle{display:flex}.nav{position:absolute;left:22px;right:22px;top:88px;display:grid;gap:4px;padding:16px;border:1px solid var(--line);border-radius:22px;background:rgba(5,5,9,.94);box-shadow:0 18px 70px rgba(0,0,0,.42);transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity var(--ease),transform var(--ease)}.nav.is-open{opacity:1;transform:translateY(0);pointer-events:auto}.nav a{padding:13px 12px;border-radius:14px}.nav a:hover{background:rgba(255,255,255,.055)}.hero{padding-top:126px}.metrics,.service-grid{grid-template-columns:1fr 1fr}.feature-panel{grid-template-columns:1fr}.pricing-row{grid-template-columns:1fr;gap:8px}.pricing-head{display:none}.pricing-row em{justify-self:start}}
@media (max-width:620px){.container{width:min(100% - 34px,1180px)}.brand-subtitle{display:none}.brand-logo{width:44px;height:44px}.hero{padding-bottom:66px}h1{font-size:clamp(43px,13vw,62px)}.hero-text{font-size:16px}.hero-actions{flex-direction:column}.btn{width:100%}.hero-visual{min-height:380px}.visual-card{border-radius:30px}.floating-chip{display:none}.metrics,.service-grid{grid-template-columns:1fr}.section{padding:84px 0}.service-card{min-height:auto;padding:25px}.step{grid-template-columns:1fr;gap:12px}.feature-panel{padding:18px}.feature-copy{padding:10px}.form-row{grid-template-columns:1fr}.contact-form .btn{width:100%}.footer-inner{flex-direction:column;text-align:center}.contact-link{display:grid}.badge{max-width:100%;font-size:10px;line-height:1.45}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}.reveal{opacity:1;transform:none}}

/* Ajustes v2: CTAs superiores, proceso más legible y footer legal */
.header-actions{display:flex;align-items:center;gap:10px;min-width:max-content}
.btn-call{border:1px solid rgba(85,240,210,.28);color:var(--text);background:rgba(255,255,255,.075);box-shadow:0 0 28px rgba(85,240,210,.14),0 16px 42px rgba(0,0,0,.22)}
.btn-call span{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:999px;background:rgba(85,240,210,.15);color:var(--cyan);font-size:13px}
.nav-phone{display:none!important}

.process-grid{grid-template-columns:1fr;gap:36px}
.process-intro{position:static;max-width:940px}
.process-intro .btn{margin-top:28px;width:max-content}
.steps-wide{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.step{grid-template-columns:72px minmax(0,1fr);align-items:flex-start;min-height:214px;padding:30px}
.step h3{font-size:24px;line-height:1.15;margin-bottom:10px}
.step p{font-size:16px;line-height:1.72;color:rgba(255,255,255,.76);max-width:none}
.step > div{min-width:0}

.checkbox-line{display:flex!important;align-items:flex-start;gap:12px;padding:14px 15px;border:1px solid rgba(255,255,255,.13);border-radius:17px;background:rgba(5,5,9,.28);font-size:12px!important;line-height:1.55;color:rgba(255,255,255,.72)!important;font-weight:650!important}
.checkbox-line input{width:18px!important;height:18px;margin-top:2px;accent-color:var(--cyan);flex:0 0 auto}
.checkbox-line a{color:var(--cyan);text-decoration:underline;text-underline-offset:3px}
.form-note strong{color:rgba(255,255,255,.78)}

.footer{padding:46px 0;background:linear-gradient(180deg,rgba(5,5,9,.96),rgba(5,5,9,.92));}
.footer-inner{display:grid;grid-template-columns:minmax(280px,1fr) minmax(280px,1.2fr);align-items:start;gap:34px;color:var(--muted);font-size:13px}
.footer-brand-block{display:grid;gap:14px}.footer-brand-block p{line-height:1.65;max-width:520px}.footer-links{display:flex;justify-content:flex-end;gap:10px 18px;flex-wrap:wrap}.footer-links a{padding:8px 0;color:rgba(255,255,255,.72);font-weight:700;transition:color var(--ease)}.footer-links a:hover,.footer-links a:focus-visible{color:var(--cyan)}

.legal-hero{padding:148px 0 56px;border-bottom:1px solid var(--line);background:radial-gradient(circle at 20% 0%,rgba(122,92,255,.18),transparent 32%)}
.legal-hero .eyebrow{margin-bottom:14px}.legal-hero h1{max-width:880px;font-size:clamp(42px,6vw,72px);line-height:.98;letter-spacing:-.055em}.legal-hero p{max-width:760px;margin-top:22px;color:var(--muted);font-size:18px;line-height:1.7}
.legal-section{padding:72px 0 100px}.legal-layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:34px;align-items:start}.legal-nav{position:sticky;top:104px;display:grid;gap:8px;padding:18px;border:1px solid var(--line);border-radius:24px;background:rgba(255,255,255,.055);backdrop-filter:blur(18px)}.legal-nav a{padding:11px 12px;border-radius:14px;color:rgba(255,255,255,.72);font-weight:750}.legal-nav a:hover,.legal-nav a[aria-current="page"]{background:rgba(85,240,210,.1);color:var(--cyan)}
.legal-card{padding:34px;border:1px solid var(--line);border-radius:30px;background:rgba(255,255,255,.065);box-shadow:var(--shadow);backdrop-filter:blur(18px)}.legal-card + .legal-card{margin-top:18px}.legal-card h2{font-size:clamp(26px,3vw,38px);line-height:1.12;margin-bottom:18px;letter-spacing:-.035em;background:none;color:var(--text);-webkit-text-fill-color:currentColor}.legal-card h3{font-size:21px;margin:24px 0 10px}.legal-card p,.legal-card li{color:rgba(255,255,255,.75);line-height:1.78}.legal-card ul{display:grid;gap:9px;margin:12px 0 0 20px}.legal-card a{color:var(--cyan);text-decoration:underline;text-underline-offset:3px}.legal-note{margin-top:18px;padding:16px;border:1px solid rgba(85,240,210,.2);border-radius:18px;background:rgba(85,240,210,.08);color:rgba(255,255,255,.8)}.legal-table{display:grid;gap:10px;margin-top:16px}.legal-table div{display:grid;grid-template-columns:210px 1fr;gap:16px;padding:14px;border:1px solid rgba(255,255,255,.1);border-radius:16px;background:rgba(5,5,9,.26)}.legal-table strong{color:#fff}.placeholder{color:#ffd08a;font-weight:800}

@media (max-width:1100px){.header-actions{display:none}}
@media (max-width:860px){.nav-phone{display:block!important;color:var(--cyan)!important}.steps-wide{grid-template-columns:1fr}.legal-layout{grid-template-columns:1fr}.legal-nav{position:static;grid-template-columns:1fr 1fr}.footer-inner{grid-template-columns:1fr}.footer-links{justify-content:flex-start}}
@media (max-width:620px){.process-intro .btn{width:100%}.step{grid-template-columns:1fr;min-height:auto;padding:24px}.step:hover{transform:translateY(-4px)}.legal-hero{padding-top:124px}.legal-card{padding:24px}.legal-table div{grid-template-columns:1fr;gap:6px}.legal-nav{grid-template-columns:1fr}.footer-links{display:grid;grid-template-columns:1fr;text-align:center;width:100%}}



/* Mascota interactiva LUSAE STUDIO v7: recorre la pantalla y cambia de postura */
.visual-card img.hero-mascot-image{inset:3% 2% auto;width:96%;height:86%;object-fit:contain;object-position:center top;filter:drop-shadow(0 34px 78px rgba(0,0,0,.62));animation:mascot-hero-float 5.4s ease-in-out infinite;transform-origin:50% 82%}
@keyframes mascot-hero-float{0%,100%{transform:translateY(0) rotate(-1.5deg) scale(1.01)}50%{transform:translateY(-14px) rotate(1.5deg) scale(1.035)}}

.mascot-companion{--x:78vw;--y:70vh;--float-x:0px;--float-y:0px;--look-x:0px;--look-y:0px;--rot:0deg;--scale:1;position:fixed;left:var(--x);top:var(--y);right:auto;bottom:auto;z-index:48;width:clamp(116px,11.5vw,178px);transform:translate3d(-50%,-50%,0) translate3d(var(--float-x),var(--float-y),0);pointer-events:none;transition:left 900ms cubic-bezier(.16,1,.32,1),top 900ms cubic-bezier(.16,1,.32,1),width 420ms ease,opacity var(--ease),filter var(--ease);will-change:left,top,transform;filter:drop-shadow(0 26px 50px rgba(0,0,0,.46))}
.mascot-companion::before{content:"";position:absolute;left:50%;top:50%;width:132%;height:132%;border-radius:999px;background:radial-gradient(circle,rgba(85,240,210,.16),rgba(122,92,255,.09) 44%,transparent 68%);filter:blur(16px);opacity:.82;transform:translate(-50%,-50%) scale(.92);transition:transform 500ms ease,opacity 500ms ease;z-index:0}
.mascot-shell{position:relative;z-index:2;display:block;width:100%;border:0;background:transparent;padding:0;cursor:pointer;pointer-events:auto;transform:translate3d(var(--look-x),var(--look-y),0) rotate(var(--rot)) scale(var(--scale));transform-origin:50% 88%;transition:transform 140ms ease,filter 220ms ease;will-change:transform}
.mascot-shell:focus-visible{outline:3px solid rgba(85,240,210,.45);outline-offset:8px;border-radius:32px}
.mascot-shell:hover{--scale:1.055;filter:brightness(1.1) saturate(1.05)}
.mascot-shell img{position:relative;z-index:2;display:block;width:100%;height:auto;animation:mascot-idle 4.8s ease-in-out infinite;transform-origin:50% 86%;user-select:none;-webkit-user-drag:none;transition:filter 260ms ease}
.mascot-glow{position:absolute;inset:10% 3% 0;border-radius:999px;background:radial-gradient(circle at 50% 30%,rgba(85,240,210,.22),transparent 56%),radial-gradient(circle at 50% 74%,rgba(122,92,255,.26),transparent 52%);filter:blur(18px);z-index:1;opacity:.9;animation:mascot-pulse 3.8s ease-in-out infinite}
.mascot-bubble{position:absolute;top:10px;width:min(270px,38vw);padding:13px 15px;border:1px solid rgba(255,255,255,.16);border-radius:18px;background:rgba(8,8,16,.78);box-shadow:0 18px 54px rgba(0,0,0,.32);backdrop-filter:blur(18px);color:rgba(255,255,255,.86);font-size:12px;line-height:1.45;font-weight:750;letter-spacing:-.01em;opacity:.94;transform:translateY(0);transition:opacity var(--ease),transform var(--ease),border-color var(--ease),left var(--ease),right var(--ease);pointer-events:none}
.mascot-bubble::after{content:"";position:absolute;top:24px;width:14px;height:14px;border-top:1px solid rgba(255,255,255,.16);border-right:1px solid rgba(255,255,255,.16);background:rgba(8,8,16,.78)}
.mascot-companion[data-side="left"] .mascot-bubble{right:82%;border-radius:18px 18px 4px 18px;text-align:left}
.mascot-companion[data-side="left"] .mascot-bubble::after{right:-8px;transform:rotate(45deg)}
.mascot-companion[data-side="right"] .mascot-bubble{left:82%;border-radius:18px 18px 18px 4px;text-align:left}
.mascot-companion[data-side="right"] .mascot-bubble::after{left:-8px;transform:rotate(225deg)}
.mascot-companion.is-moving .mascot-shell img{animation:mascot-walk .54s ease-in-out infinite}
.mascot-companion.is-moving .mascot-bubble,.mascot-companion.is-hovered .mascot-bubble{border-color:rgba(85,240,210,.36);transform:translateY(-6px)}
.mascot-companion.is-changing-section::before{opacity:1;transform:translate(-50%,-50%) scale(1.14)}
.mascot-companion.is-clicked .mascot-shell img{animation:mascot-celebrate .62s ease-in-out 2}
.mascot-companion.is-surprise .mascot-shell img{animation:mascot-surprise 1.15s ease-in-out 1}
.mascot-companion.is-hidden{opacity:0;transform:translate3d(28px,20px,0) scale(.86);pointer-events:none}

.mascot-companion[data-pose="hero"] .mascot-shell img{animation:mascot-hero-pose 5s ease-in-out infinite}
.mascot-companion[data-pose="point"] .mascot-shell img{animation:mascot-point 1.6s ease-in-out infinite;filter:drop-shadow(0 0 16px rgba(85,240,210,.1))}
.mascot-companion[data-pose="walk"] .mascot-shell img{animation:mascot-walk .72s ease-in-out infinite}
.mascot-companion[data-pose="think"] .mascot-shell img{animation:mascot-think 3.2s ease-in-out infinite}
.mascot-companion[data-pose="money"] .mascot-shell img{animation:mascot-money 2.2s ease-in-out infinite}
.mascot-companion[data-pose="celebrate"] .mascot-shell img{animation:mascot-celebrate 1.15s ease-in-out infinite}
.mascot-companion[data-pose="think"] .mascot-shell::after{content:"?";position:absolute;right:2%;top:4%;z-index:3;width:30px;height:30px;display:grid;place-items:center;border-radius:999px;background:rgba(85,240,210,.14);border:1px solid rgba(85,240,210,.3);color:var(--cyan);font-weight:950;box-shadow:0 0 24px rgba(85,240,210,.18);animation:mascot-symbol 1.8s ease-in-out infinite}
.mascot-companion[data-pose="money"] .mascot-shell::after{content:"€";position:absolute;right:-2%;top:3%;z-index:3;width:32px;height:32px;display:grid;place-items:center;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;font-weight:950;box-shadow:0 0 24px rgba(122,92,255,.2);animation:mascot-symbol 1.8s ease-in-out infinite}
.mascot-companion[data-pose="celebrate"] .mascot-shell::after{content:"✦";position:absolute;right:-4%;top:0;z-index:3;width:34px;height:34px;display:grid;place-items:center;border-radius:999px;background:linear-gradient(135deg,rgba(85,240,210,.18),rgba(122,92,255,.2));border:1px solid rgba(255,255,255,.22);color:#fff;font-weight:950;box-shadow:0 0 28px rgba(85,240,210,.22);animation:mascot-symbol 1.25s ease-in-out infinite}

@keyframes mascot-pulse{0%,100%{opacity:.68;transform:scale(.94)}50%{opacity:1;transform:scale(1.04)}}
@keyframes mascot-idle{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-8px) rotate(1deg)}}
@keyframes mascot-hero-pose{0%,100%{transform:translateY(0) rotate(-2deg) scale(1)}50%{transform:translateY(-12px) rotate(2deg) scale(1.035)}}
@keyframes mascot-walk{0%,100%{transform:translateY(0) rotate(-5deg)}25%{transform:translateY(-8px) translateX(3px) rotate(5deg)}50%{transform:translateY(1px) rotate(2deg)}75%{transform:translateY(-7px) translateX(-3px) rotate(-3deg)}}
@keyframes mascot-point{0%,100%{transform:translateY(0) translateX(0) rotate(-7deg) scale(1.01)}50%{transform:translateY(-7px) translateX(9px) rotate(-13deg) scale(1.035)}}
@keyframes mascot-think{0%,100%{transform:translateY(0) rotate(8deg) scale(.98)}45%{transform:translateY(-5px) rotate(-2deg) scale(1.02)}70%{transform:translateY(0) rotate(6deg) scale(.99)}}
@keyframes mascot-money{0%,100%{transform:translateY(0) rotate(-2deg) scale(1)}35%{transform:translateY(-10px) rotate(3deg) scale(1.04)}65%{transform:translateY(-3px) rotate(-4deg) scale(1.02)}}
@keyframes mascot-celebrate{0%,100%{transform:translateY(0) rotate(0) scale(1)}30%{transform:translateY(-16px) rotate(-8deg) scale(1.07)}62%{transform:translateY(-5px) rotate(8deg) scale(1.04)}}
@keyframes mascot-surprise{0%,100%{transform:translateY(0) rotate(0) scale(1)}20%{transform:translateY(-12px) rotate(-11deg) scale(1.08)}42%{transform:translateY(0) rotate(10deg) scale(1.02)}64%{transform:translateY(-8px) rotate(-6deg) scale(1.05)}}
@keyframes mascot-symbol{0%,100%{transform:translateY(0) scale(1);opacity:.74}50%{transform:translateY(-8px) scale(1.1);opacity:1}}

@media (max-width:860px){.mascot-companion{width:104px}.mascot-bubble{display:none}}
@media (max-width:620px){.mascot-companion{width:82px;opacity:.92}.mascot-shell:focus-visible{outline-offset:4px}}
@media (prefers-reduced-motion:reduce){.mascot-companion,.mascot-shell,.mascot-shell img,.mascot-bubble,.visual-card img.hero-mascot-image{animation:none!important;transition:none!important;transform:none!important}.mascot-companion{left:auto!important;right:12px!important;top:auto!important;bottom:12px!important}}

/* Mascota interactiva LUSAE STUDIO v8: salida desde portada + caída + paseo por secciones */
.launch-portal{
  position:absolute;
  inset:9% 7% 15%;
  z-index:2;
  display:grid;
  place-items:center;
  pointer-events:none;
  opacity:0;
  transform:scale(.88);
  transition:opacity 360ms ease,transform 560ms cubic-bezier(.16,1,.32,1);
}
.launch-portal span{
  width:58%;
  aspect-ratio:1;
  border-radius:999px;
  border:1px solid rgba(85,240,210,.35);
  background:
    radial-gradient(circle,rgba(85,240,210,.22),transparent 54%),
    radial-gradient(circle,rgba(122,92,255,.22),transparent 68%);
  box-shadow:0 0 72px rgba(85,240,210,.28),inset 0 0 46px rgba(255,255,255,.08);
  animation:portal-breathe 2.1s ease-in-out infinite;
}
.visual-card.is-launching .launch-portal{opacity:1;transform:scale(1.04)}
.visual-card.is-launching{overflow:visible}
.visual-card.is-launching::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-48px;
  z-index:5;
  width:52%;
  height:82px;
  transform:translateX(-50%) perspective(420px) rotateX(66deg);
  border-radius:50%;
  background:radial-gradient(circle,rgba(85,240,210,.34),rgba(122,92,255,.18) 45%,transparent 72%);
  filter:blur(2px);
  opacity:.85;
  animation:launch-shadow .9s ease-in-out infinite alternate;
}
.visual-card.is-mascot-launched .hero-mascot-image{
  opacity:0;
  animation:none!important;
  transform:translate3d(22%,46%,0) rotate(18deg) scale(.72)!important;
  transition:opacity 260ms ease,transform 720ms cubic-bezier(.17,.67,.18,1.12);
}
.visual-card.is-mascot-launched .visual-caption{transform:translateY(8px);opacity:.76;transition:transform 420ms ease,opacity 420ms ease}
@keyframes portal-breathe{0%,100%{transform:scale(.96);opacity:.65}50%{transform:scale(1.08);opacity:1}}
@keyframes launch-shadow{to{transform:translateX(-50%) perspective(420px) rotateX(66deg) scale(1.12);opacity:1}}

.mascot-companion{
  --mascot-size:clamp(122px,11.8vw,184px);
  width:var(--mascot-size);
  opacity:0;
  visibility:hidden;
  transition:left 900ms cubic-bezier(.16,1,.32,1),top 900ms cubic-bezier(.16,1,.32,1),width 420ms ease,opacity 260ms ease,visibility 260ms ease,filter var(--ease);
}
.mascot-companion.is-released{opacity:1;visibility:visible}
.mascot-companion.is-docked{opacity:0;visibility:hidden;pointer-events:none}
.mascot-companion.is-launching-out{
  z-index:62;
  transition:left 540ms cubic-bezier(.2,1.1,.3,1),top 760ms cubic-bezier(.22,.72,.15,1.2),width 420ms ease,opacity 180ms ease,filter 240ms ease;
  filter:drop-shadow(0 34px 72px rgba(0,0,0,.58)) brightness(1.08);
}
.mascot-companion.is-falling{
  transition:left 760ms cubic-bezier(.22,.68,.24,1),top 920ms cubic-bezier(.12,.78,.24,1.28),width 420ms ease,filter 240ms ease;
}
.mascot-companion.is-launching-out::before,.mascot-companion.is-falling::before{opacity:1;transform:translate(-50%,-50%) scale(1.18)}
.mascot-companion[data-pose="fall"] .mascot-shell img{animation:mascot-fall .62s cubic-bezier(.25,.8,.22,1) infinite}
.mascot-companion[data-pose="wave"] .mascot-shell img{animation:mascot-wave 1.25s ease-in-out infinite}
.mascot-companion[data-pose="wave"] .mascot-shell::after{
  content:"👋";
  position:absolute;
  right:-6%;
  top:10%;
  z-index:4;
  font-size:clamp(22px,2.8vw,34px);
  filter:drop-shadow(0 0 18px rgba(255,255,255,.28));
  transform-origin:20% 80%;
  animation:mascot-hand-wave .72s ease-in-out infinite;
}
.mascot-companion[data-pose="fall"] .mascot-shell::after{
  content:"";
  position:absolute;
  left:-18%;
  top:22%;
  z-index:1;
  width:76%;
  height:14px;
  border-radius:999px;
  background:linear-gradient(90deg,transparent,rgba(85,240,210,.55),rgba(255,255,255,.35),transparent);
  filter:blur(2px);
  transform:rotate(-28deg);
  animation:fall-trail .38s linear infinite;
}
.mascot-companion.is-hovered .mascot-shell img{animation:mascot-wave .82s ease-in-out infinite!important}
@keyframes mascot-fall{0%,100%{transform:translateY(-4px) rotate(16deg) scale(1.02)}50%{transform:translateY(10px) rotate(-12deg) scale(1.04)}}
@keyframes mascot-wave{0%,100%{transform:translateY(0) rotate(-3deg) scale(1.01)}35%{transform:translateY(-9px) rotate(7deg) scale(1.045)}70%{transform:translateY(-3px) rotate(-6deg) scale(1.02)}}
@keyframes mascot-hand-wave{0%,100%{transform:rotate(-18deg) scale(1)}50%{transform:rotate(18deg) scale(1.08)}}
@keyframes fall-trail{0%{opacity:.35;transform:translateX(0) rotate(-28deg) scaleX(.82)}50%{opacity:1;transform:translateX(-10px) rotate(-28deg) scaleX(1.08)}100%{opacity:.25;transform:translateX(-22px) rotate(-28deg) scaleX(.72)}}

@media (max-width:860px){.mascot-companion{--mascot-size:104px}}
@media (max-width:620px){.mascot-companion{--mascot-size:86px}.launch-portal{inset:8% 5% 18%}}
@media (prefers-reduced-motion:reduce){
  .launch-portal,.launch-portal span,.visual-card.is-launching::after{animation:none!important;transition:none!important}
  .visual-card.is-mascot-launched .hero-mascot-image{opacity:1!important;transform:none!important}
  .mascot-companion{left:auto!important;right:12px!important;top:auto!important;bottom:12px!important;opacity:1!important;visibility:visible!important}
}

/* Mascota interactiva LUSAE STUDIO v9: caminata natural sin teletransporte */
.mascot-companion{
  --walk-lean:0deg;
  --step-speed:.56s;
}
.mascot-companion.is-released:not(.is-launching-out):not(.is-falling){
  transition:width 420ms ease,opacity 260ms ease,visibility 260ms ease,filter var(--ease)!important;
}
.mascot-shell{
  transform:translate3d(var(--look-x),var(--look-y),0) rotate(calc(var(--rot) + var(--walk-lean))) scale(var(--scale));
}
.mascot-companion.is-walking{
  z-index:66;
  filter:drop-shadow(0 34px 72px rgba(0,0,0,.58)) brightness(1.08) saturate(1.08);
}
.mascot-companion.is-walking::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:1%;
  z-index:0;
  width:72%;
  height:13%;
  transform:translateX(-50%) perspective(260px) rotateX(68deg);
  border-radius:999px;
  background:radial-gradient(circle,rgba(85,240,210,.24),rgba(122,92,255,.15) 42%,transparent 72%);
  filter:blur(2px);
  opacity:.9;
  animation:mascot-walking-shadow var(--step-speed) ease-in-out infinite;
}
.mascot-companion.is-walking .mascot-shell{
  animation:mascot-body-step var(--step-speed) ease-in-out infinite;
}
.mascot-companion.is-walking .mascot-shell img,
.mascot-companion[data-pose="walk"].is-walking .mascot-shell img{
  animation:mascot-natural-walk var(--step-speed) cubic-bezier(.45,.05,.25,1) infinite!important;
  transform-origin:50% 90%;
}
.mascot-footstep{
  position:absolute;
  left:50%;
  bottom:3%;
  z-index:1;
  width:22%;
  height:6%;
  border-radius:999px;
  pointer-events:none;
  opacity:0;
  background:radial-gradient(ellipse,rgba(255,255,255,.45),rgba(85,240,210,.22) 48%,transparent 72%);
  filter:blur(.6px);
}
.mascot-footstep-a{transform:translateX(-118%) rotate(-7deg)}
.mascot-footstep-b{transform:translateX(18%) rotate(7deg)}
.mascot-companion.is-walking .mascot-footstep-a{animation:mascot-foot-left var(--step-speed) linear infinite}
.mascot-companion.is-walking .mascot-footstep-b{animation:mascot-foot-right var(--step-speed) linear infinite}
.mascot-companion[data-walk-direction="left"].is-walking .mascot-shell img{filter:drop-shadow(-10px 16px 18px rgba(0,0,0,.18))}
.mascot-companion[data-walk-direction="right"].is-walking .mascot-shell img{filter:drop-shadow(10px 16px 18px rgba(0,0,0,.18))}
.mascot-companion.is-idle-wander .mascot-bubble{opacity:.78}
.mascot-companion.is-hovered .mascot-shell,
.mascot-companion.is-clicked .mascot-shell{animation:none!important}

@keyframes mascot-natural-walk{
  0%{transform:translate3d(0,0,0) rotate(-4deg) skewX(-1.5deg) scale(1)}
  12%{transform:translate3d(4px,-9px,0) rotate(4.5deg) skewX(1.2deg) scale(1.018,.992)}
  25%{transform:translate3d(2px,-2px,0) rotate(2deg) skewX(.4deg) scale(.996,1.012)}
  38%{transform:translate3d(-3px,-8px,0) rotate(-3.2deg) skewX(-1.1deg) scale(1.018,.992)}
  50%{transform:translate3d(0,1px,0) rotate(3deg) skewX(1deg) scale(.997,1.014)}
  62%{transform:translate3d(4px,-9px,0) rotate(4deg) skewX(1.2deg) scale(1.018,.992)}
  75%{transform:translate3d(1px,-1px,0) rotate(-2deg) skewX(-.5deg) scale(.998,1.012)}
  88%{transform:translate3d(-4px,-8px,0) rotate(-4deg) skewX(-1.2deg) scale(1.018,.992)}
  100%{transform:translate3d(0,0,0) rotate(-4deg) skewX(-1.5deg) scale(1)}
}
@keyframes mascot-body-step{
  0%,100%{translate:0 0}
  25%{translate:0 -3px}
  50%{translate:0 1px}
  75%{translate:0 -3px}
}
@keyframes mascot-walking-shadow{
  0%,100%{transform:translateX(-50%) perspective(260px) rotateX(68deg) scale(.9);opacity:.56}
  50%{transform:translateX(-50%) perspective(260px) rotateX(68deg) scale(1.08);opacity:.92}
}
@keyframes mascot-foot-left{
  0%,46%,100%{opacity:0;translate:0 0;scale:.84}
  12%,32%{opacity:.86;translate:-4px 3px;scale:1}
}
@keyframes mascot-foot-right{
  0%,50%,100%{opacity:0;translate:0 0;scale:.84}
  62%,84%{opacity:.86;translate:4px 3px;scale:1}
}

@media (max-width:620px){
  .mascot-footstep{display:none}
  .mascot-companion.is-walking::after{height:10%}
}
@media (prefers-reduced-motion:reduce){
  .mascot-companion.is-walking::after,.mascot-footstep,.mascot-companion.is-walking .mascot-shell,.mascot-companion.is-walking .mascot-shell img{animation:none!important}
}

/* Mascota interactiva LUSAE STUDIO v10: movimiento más natural y bocadillo hacia el exterior */
.mascot-companion{
  --face-scale:1;
  --step-speed:.68s;
  transition:width 460ms ease,opacity var(--ease),filter var(--ease);
}
.mascot-shell{
  transform:translate3d(var(--look-x),var(--look-y),0) rotate(var(--rot)) scale(var(--scale));
  transition:transform 180ms cubic-bezier(.2,.8,.2,1),filter 220ms ease;
}
.mascot-shell img{
  scale:var(--face-scale) 1;
  transform-origin:50% 88%;
  transition:scale 260ms cubic-bezier(.2,.8,.2,1),filter 260ms ease;
}
.mascot-bubble{
  top:3px;
  width:min(252px,28vw);
  max-width:calc(50vw - 34px);
  padding:12px 14px;
  font-size:11.8px;
  line-height:1.44;
  opacity:.92;
}
.mascot-companion[data-side="left"] .mascot-bubble{
  right:90%;
  left:auto;
  border-radius:18px 18px 4px 18px;
  text-align:left;
}
.mascot-companion[data-side="left"] .mascot-bubble::after{
  right:-8px;
  left:auto;
  transform:rotate(45deg);
}
.mascot-companion[data-side="right"] .mascot-bubble{
  left:90%;
  right:auto;
  border-radius:18px 18px 18px 4px;
  text-align:left;
}
.mascot-companion[data-side="right"] .mascot-bubble::after{
  left:-8px;
  right:auto;
  transform:rotate(225deg);
}
.mascot-companion.is-walking .mascot-bubble{
  opacity:.76;
  transform:translateY(-9px) scale(.975);
}
.mascot-companion.is-resting .mascot-bubble{
  opacity:1;
  transform:translateY(-4px) scale(1);
  border-color:rgba(85,240,210,.32);
}
.mascot-companion.is-walking .mascot-shell{
  animation:mascot-body-step-v10 var(--step-speed) cubic-bezier(.45,.05,.25,1) infinite;
}
.mascot-companion.is-walking .mascot-shell img,
.mascot-companion[data-pose="walk"].is-walking .mascot-shell img{
  animation:mascot-natural-walk-v10 var(--step-speed) cubic-bezier(.45,.05,.25,1) infinite!important;
}
.mascot-companion.is-resting .mascot-shell img{
  animation:mascot-resting-v10 1.45s ease-in-out 1!important;
}
.mascot-companion[data-walk-direction="left"].is-walking .mascot-shell img{filter:drop-shadow(-8px 15px 17px rgba(0,0,0,.18))}
.mascot-companion[data-walk-direction="right"].is-walking .mascot-shell img{filter:drop-shadow(8px 15px 17px rgba(0,0,0,.18))}

@keyframes mascot-natural-walk-v10{
  0%{transform:translate3d(0,0,0) rotate(-2.8deg) skewX(-.8deg) scale(1)}
  10%{transform:translate3d(1.8px,-4.8px,0) rotate(2.8deg) skewX(.7deg) scale(1.01,.996)}
  22%{transform:translate3d(1px,-1px,0) rotate(1.4deg) skewX(.2deg) scale(.998,1.006)}
  35%{transform:translate3d(-1.6px,-4.4px,0) rotate(-2.4deg) skewX(-.65deg) scale(1.01,.996)}
  50%{transform:translate3d(0,.4px,0) rotate(1.5deg) skewX(.3deg) scale(.998,1.006)}
  64%{transform:translate3d(1.8px,-4.8px,0) rotate(2.5deg) skewX(.7deg) scale(1.01,.996)}
  78%{transform:translate3d(.8px,-.8px,0) rotate(-1.2deg) skewX(-.2deg) scale(.999,1.005)}
  90%{transform:translate3d(-1.8px,-4.4px,0) rotate(-2.6deg) skewX(-.7deg) scale(1.01,.996)}
  100%{transform:translate3d(0,0,0) rotate(-2.8deg) skewX(-.8deg) scale(1)}
}
@keyframes mascot-body-step-v10{
  0%,100%{translate:0 0;rotate:0deg}
  25%{translate:0 -1.8px;rotate:.5deg}
  50%{translate:0 .5px;rotate:0deg}
  75%{translate:0 -1.8px;rotate:-.5deg}
}
@keyframes mascot-resting-v10{
  0%{transform:translateY(-5px) rotate(-3deg) scale(1.02)}
  55%{transform:translateY(1px) rotate(2deg) scale(.995,1.01)}
  100%{transform:translateY(0) rotate(0) scale(1)}
}

@media (max-width:1100px){
  .mascot-bubble{width:min(230px,30vw);font-size:11.4px}
  .mascot-companion[data-side="left"] .mascot-bubble{right:84%}
  .mascot-companion[data-side="right"] .mascot-bubble{left:84%}
}
@media (max-width:860px){
  .mascot-bubble{display:none}
}
@media (prefers-reduced-motion:reduce){
  .mascot-shell img{scale:1 1!important}
}

/* V11 final: mascota más natural y sin tapar textos */
.hero-grid,
.metrics,
.section > .container,
.footer > .container{
  position:relative;
  z-index:34;
}

.mascot-companion{
  z-index:18!important;
  pointer-events:none;
  max-width:calc((100vw - min(1180px, calc(100vw - 44px))) / 2 - 20px);
}
.mascot-companion.is-launching-out,
.mascot-companion.is-falling{
  z-index:42!important;
}
.mascot-companion.is-safety-hidden{
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
}
.mascot-shell{
  pointer-events:auto;
  isolation:isolate;
}
.mascot-shell img{
  transition:opacity 220ms ease, scale 260ms cubic-bezier(.2,.8,.2,1), filter 260ms ease;
}
.mascot-main-img{
  opacity:1;
}
.mascot-walk-img{
  position:absolute!important;
  inset:-6% -4% auto!important;
  width:108%!important;
  height:112%!important;
  object-fit:contain!important;
  opacity:0;
  z-index:3!important;
  pointer-events:none;
}
.mascot-companion.is-walking .mascot-main-img{
  opacity:0;
}
.mascot-companion.is-walking .mascot-walk-img{
  opacity:1;
}
.mascot-companion:not(.is-walking) .mascot-walk-img{
  opacity:0;
}
.mascot-companion.is-walking .mascot-shell img,
.mascot-companion[data-pose="walk"].is-walking .mascot-shell img{
  animation:mascot-photo-walk-v11 var(--step-speed) cubic-bezier(.45,.05,.25,1) infinite!important;
}
.mascot-companion.is-walking .mascot-shell{
  animation:mascot-body-step-v11 var(--step-speed) cubic-bezier(.45,.05,.25,1) infinite!important;
}
.mascot-companion.is-resting .mascot-shell img{
  animation:mascot-resting-v11 1.15s ease-in-out 1!important;
}

.mascot-companion[data-bubble="hidden"] .mascot-bubble{
  display:none!important;
}
.mascot-companion[data-bubble="show"] .mascot-bubble{
  display:block!important;
  left:50%!important;
  right:auto!important;
  top:auto!important;
  bottom:calc(100% - 8px)!important;
  width:var(--bubble-width, 190px)!important;
  max-width:var(--bubble-width, 190px)!important;
  transform:translateX(-50%) translateY(0)!important;
  border-radius:18px!important;
  text-align:center!important;
  opacity:.96;
  font-size:11.2px;
  line-height:1.38;
}
.mascot-companion[data-bubble="show"] .mascot-bubble::after{
  left:50%!important;
  right:auto!important;
  top:auto!important;
  bottom:-8px!important;
  transform:translateX(-50%) rotate(135deg)!important;
}
.mascot-companion.is-walking[data-bubble="show"] .mascot-bubble{
  opacity:.64;
  transform:translateX(-50%) translateY(3px) scale(.97)!important;
}
.mascot-companion.is-resting[data-bubble="show"] .mascot-bubble,
.mascot-companion.is-hovered[data-bubble="show"] .mascot-bubble{
  opacity:1;
  transform:translateX(-50%) translateY(-2px) scale(1)!important;
}

@keyframes mascot-photo-walk-v11{
  0%{transform:translate3d(0,0,0) rotate(-1.8deg) scale(1)}
  16%{transform:translate3d(1.4px,-3.5px,0) rotate(1.6deg) scale(1.006,.998)}
  32%{transform:translate3d(.4px,-.8px,0) rotate(.7deg) scale(.999,1.004)}
  50%{transform:translate3d(-1.1px,-3.2px,0) rotate(-1.4deg) scale(1.006,.998)}
  66%{transform:translate3d(1px,-.5px,0) rotate(.9deg) scale(.999,1.004)}
  82%{transform:translate3d(-1.4px,-3.4px,0) rotate(-1.7deg) scale(1.006,.998)}
  100%{transform:translate3d(0,0,0) rotate(-1.8deg) scale(1)}
}
@keyframes mascot-body-step-v11{
  0%,100%{translate:0 0;rotate:0deg}
  25%{translate:0 -1.2px;rotate:.35deg}
  50%{translate:0 .4px;rotate:0deg}
  75%{translate:0 -1.2px;rotate:-.35deg}
}
@keyframes mascot-resting-v11{
  0%{transform:translateY(-3px) rotate(-2deg) scale(1.01)}
  58%{transform:translateY(.8px) rotate(1.2deg) scale(.998,1.006)}
  100%{transform:translateY(0) rotate(0) scale(1)}
}

@media (max-width:1240px){
  .mascot-companion[data-safe="false"]{display:none!important}
}
@media (max-width:860px){
  .mascot-companion{display:none!important}
}


/* V12 final: engranaje que cobra vida + mascota sin fondo negro */
.visual-card img.hero-mascot-image{display:none!important}
.visual-card .gear-creature{
  position:absolute;
  left:50%;
  top:43%;
  width:min(76%,340px);
  aspect-ratio:1;
  z-index:2;
  transform:translate(-50%,-50%) rotate(-2deg) scale(1);
  transform-origin:50% 54%;
  filter:drop-shadow(0 36px 82px rgba(0,0,0,.62));
  animation:gear-idle-v12 5.2s ease-in-out infinite;
  will-change:transform,opacity;
}
.visual-card .gear-creature::before{
  content:"";
  position:absolute;
  inset:10%;
  border-radius:999px;
  background:radial-gradient(circle,rgba(85,240,210,.18),rgba(122,92,255,.10) 42%,transparent 68%);
  filter:blur(20px);
  opacity:.9;
  transform:scale(.96);
  transition:opacity 420ms ease,transform 420ms ease;
}
.visual-card .gear-creature img.hero-gear-image{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
  z-index:4!important;
  animation:none!important;
  filter:none!important;
}
.gear-limb{
  position:absolute;
  display:block;
  z-index:2;
  opacity:0;
  border:1px solid rgba(255,255,255,.34);
  background:
    linear-gradient(110deg,rgba(255,255,255,.66),rgba(117,210,255,.18) 26%,rgba(0,0,0,.06) 50%,rgba(255,255,255,.56) 72%,rgba(122,92,255,.18)),
    rgba(55,135,180,.18);
  box-shadow:inset 0 0 18px rgba(255,255,255,.18),0 0 24px rgba(85,240,210,.16);
  backdrop-filter:blur(2px);
  transition:opacity 260ms ease,transform 620ms cubic-bezier(.17,1.35,.32,1),left 520ms ease,right 520ms ease,top 520ms ease,bottom 520ms ease;
}
.gear-arm{width:18%;height:47%;border-radius:999px;top:53%;transform-origin:50% 8%;transform:scaleY(.15) rotate(0deg)}
.gear-arm-left{left:25%;transform:scaleY(.1) rotate(42deg)}
.gear-arm-right{right:25%;transform:scaleY(.1) rotate(-42deg)}
.gear-leg{width:19%;height:43%;border-radius:999px;top:80%;transform-origin:50% 5%;transform:scaleY(.1) rotate(0deg)}
.gear-leg-left{left:37%;transform:scaleY(.1) rotate(8deg)}
.gear-leg-right{right:35%;transform:scaleY(.1) rotate(-8deg)}
.visual-card.is-transforming .gear-creature{
  animation:gear-awaken-v12 .78s cubic-bezier(.17,1.22,.26,1) both;
}
.visual-card.is-transforming .gear-creature::before{opacity:1;transform:scale(1.16)}
.visual-card.is-transforming .gear-limb{opacity:1}
.visual-card.is-transforming .gear-arm-left{left:8%;top:55%;transform:scaleY(1) rotate(28deg)}
.visual-card.is-transforming .gear-arm-right{right:8%;top:55%;transform:scaleY(1) rotate(-28deg)}
.visual-card.is-transforming .gear-leg-left{left:36%;top:83%;transform:scaleY(1) rotate(13deg)}
.visual-card.is-transforming .gear-leg-right{right:33%;top:83%;transform:scaleY(1) rotate(-13deg)}
.visual-card.is-launching .gear-creature{
  opacity:0;
  transform:translate(-50%,-28%) rotate(18deg) scale(.72);
  transition:opacity 380ms ease,transform 640ms cubic-bezier(.16,1,.32,1);
}
.visual-card.is-mascot-launched .gear-creature{opacity:0!important;visibility:hidden}
.visual-card.is-transforming .scanline{opacity:.72}
.visual-card.is-transforming .visual-caption{transform:translateY(8px);opacity:.74;transition:transform 380ms ease,opacity 380ms ease}
.mascot-walk-img{background:transparent!important;mix-blend-mode:normal!important}
.mascot-companion.is-walking .mascot-walk-img{filter:drop-shadow(0 24px 28px rgba(0,0,0,.35)) saturate(1.03)}
.mascot-companion.is-walking .mascot-shell{animation:mascot-body-step-v12 var(--step-speed) cubic-bezier(.45,.05,.25,1) infinite!important}
.mascot-companion.is-walking .mascot-shell img,
.mascot-companion[data-pose="walk"].is-walking .mascot-shell img{animation:mascot-photo-walk-v12 var(--step-speed) cubic-bezier(.45,.05,.25,1) infinite!important}

@keyframes gear-idle-v12{
  0%,100%{transform:translate(-50%,-50%) rotate(-2deg) scale(1)}
  50%{transform:translate(-50%,-54%) rotate(2deg) scale(1.035)}
}
@keyframes gear-awaken-v12{
  0%{transform:translate(-50%,-50%) rotate(-2deg) scale(1)}
  25%{transform:translate(-50%,-55%) rotate(8deg) scale(1.035)}
  52%{transform:translate(-50%,-48%) rotate(-6deg) scale(1.05)}
  78%{transform:translate(-50%,-52%) rotate(3deg) scale(1.02)}
  100%{transform:translate(-50%,-50%) rotate(0) scale(1.02)}
}
@keyframes mascot-photo-walk-v12{
  0%{transform:translate3d(0,0,0) rotate(-1.4deg) scale(1)}
  12%{transform:translate3d(1.8px,-4.2px,0) rotate(1.9deg) scale(1.007,.998)}
  24%{transform:translate3d(.6px,-.7px,0) rotate(.8deg) scale(.999,1.004)}
  38%{transform:translate3d(-1.4px,-3.8px,0) rotate(-1.7deg) scale(1.007,.998)}
  52%{transform:translate3d(.5px,.4px,0) rotate(.6deg) scale(.999,1.004)}
  66%{transform:translate3d(1.5px,-4.1px,0) rotate(1.6deg) scale(1.007,.998)}
  82%{transform:translate3d(-1.4px,-3.6px,0) rotate(-1.6deg) scale(1.006,.999)}
  100%{transform:translate3d(0,0,0) rotate(-1.4deg) scale(1)}
}
@keyframes mascot-body-step-v12{
  0%,100%{translate:0 0;rotate:0deg}
  25%{translate:0 -1.5px;rotate:.28deg}
  50%{translate:0 .3px;rotate:0deg}
  75%{translate:0 -1.5px;rotate:-.28deg}
}
@media (max-width:860px){
  .visual-card .gear-creature{width:min(82%,300px);top:45%}
  .gear-limb{display:none!important}
}
@media (prefers-reduced-motion:reduce){
  .visual-card .gear-creature,.visual-card.is-transforming .gear-creature{animation:none!important;transition:none!important}
  .gear-limb{display:none!important}
}
.visual-card.is-launching .gear-creature{animation:none!important}

/* V13 pulida: transformación y caminata más fluidas, carriles seguros y mascota sin fondo visible */
.visual-card .gear-creature{
  animation:gear-idle-v13 6.4s ease-in-out infinite!important;
  transform-origin:50% 56%!important;
}
.visual-card .gear-creature::before{
  transition:opacity 720ms ease, transform 920ms cubic-bezier(.16,1,.32,1)!important;
}
.gear-limb{
  transition:opacity 420ms ease, transform 980ms cubic-bezier(.16,1.25,.28,1), left 780ms ease, right 780ms ease, top 780ms ease!important;
}
.visual-card.is-transforming .gear-creature{
  animation:gear-awaken-v13 1.25s cubic-bezier(.16,1.18,.24,1) both!important;
}
.visual-card.is-transforming .gear-arm-left{animation:gear-arm-left-v13 1.2s ease-in-out both!important}
.visual-card.is-transforming .gear-arm-right{animation:gear-arm-right-v13 1.2s ease-in-out both!important}
.visual-card.is-transforming .gear-leg-left{animation:gear-leg-left-v13 1.2s ease-in-out both!important}
.visual-card.is-transforming .gear-leg-right{animation:gear-leg-right-v13 1.2s ease-in-out both!important}
.visual-card.is-launching .gear-creature{
  opacity:0!important;
  transform:translate(-50%,-34%) rotate(14deg) scale(.76)!important;
  transition:opacity 560ms ease, transform 920ms cubic-bezier(.16,1,.32,1)!important;
}
.visual-card.is-launching::after{
  animation:launch-shadow-v13 1.2s ease-in-out infinite alternate!important;
}
.mascot-companion{
  --step-speed:.96s;
  --walk-lean:0deg;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  transform:translate3d(-50%,-50%,0) translate3d(var(--float-x),var(--float-y),0);
  filter:drop-shadow(0 22px 42px rgba(0,0,0,.42));
  backface-visibility:hidden;
  will-change:left,top,transform,opacity;
}
.mascot-companion.is-released:not(.is-launching-out):not(.is-falling){
  transition:width 540ms cubic-bezier(.16,1,.32,1), opacity 340ms ease, visibility 340ms ease, filter 360ms ease!important;
}
.mascot-companion.is-launching-out,
.mascot-companion.is-falling{
  transition:width 540ms ease, opacity 340ms ease, visibility 340ms ease, filter 360ms ease!important;
}
.mascot-companion.is-edge-crossing{
  filter:drop-shadow(0 18px 34px rgba(0,0,0,.34)) brightness(1.04);
}
.mascot-companion.is-edge-crossing .mascot-bubble,
.mascot-companion.is-walking .mascot-bubble{
  opacity:0!important;
  transform:translateX(-50%) translateY(8px) scale(.96)!important;
}
.mascot-shell{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  transform:translate3d(var(--look-x),var(--look-y),0) rotate(calc(var(--rot) + var(--walk-lean))) scale(var(--scale));
  transition:transform 260ms cubic-bezier(.16,1,.32,1), filter 260ms ease!important;
  will-change:transform;
}
.mascot-glow{
  opacity:.72!important;
  filter:blur(20px)!important;
  animation:mascot-pulse-v13 4.8s ease-in-out infinite!important;
}
.mascot-shell img,
.mascot-walk-img,
.mascot-main-img{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  image-rendering:auto!important;
  backface-visibility:hidden;
}
.mascot-walk-img{
  inset:-7% -5% auto!important;
  width:110%!important;
  height:114%!important;
  object-fit:contain!important;
  mix-blend-mode:normal!important;
  filter:drop-shadow(0 18px 22px rgba(0,0,0,.22));
}
.mascot-companion.is-walking .mascot-main-img{opacity:0!important}
.mascot-companion.is-walking .mascot-walk-img{opacity:1!important}
.mascot-companion:not(.is-walking) .mascot-walk-img{opacity:0!important}
.mascot-companion.is-walking .mascot-shell{
  animation:mascot-body-step-v13 var(--step-speed) cubic-bezier(.45,.05,.25,1) infinite!important;
}
.mascot-companion.is-walking .mascot-shell img,
.mascot-companion[data-pose="walk"].is-walking .mascot-shell img{
  animation:mascot-photo-walk-v13 var(--step-speed) cubic-bezier(.45,.05,.25,1) infinite!important;
}
.mascot-companion.is-resting .mascot-shell img{
  animation:mascot-resting-v13 1.05s ease-out 1!important;
}
.mascot-companion.is-walking::after{
  opacity:.34!important;
  height:8%!important;
  animation:mascot-walking-shadow-v13 var(--step-speed) ease-in-out infinite!important;
}
.mascot-footstep{
  opacity:.42!important;
  transform-origin:center!important;
}
.mascot-companion[data-bubble="show"] .mascot-bubble{
  bottom:calc(100% + 2px)!important;
  background:rgba(8,8,16,.70)!important;
  backdrop-filter:blur(14px)!important;
  box-shadow:0 14px 38px rgba(0,0,0,.22)!important;
  transition:opacity 320ms ease, transform 360ms cubic-bezier(.16,1,.32,1), border-color 320ms ease!important;
}
.mascot-companion.is-resting[data-bubble="show"] .mascot-bubble,
.mascot-companion.is-hovered[data-bubble="show"] .mascot-bubble{
  opacity:.96!important;
  transform:translateX(-50%) translateY(-3px) scale(1)!important;
}

@keyframes gear-idle-v13{
  0%,100%{transform:translate(-50%,-50%) rotate(-1.5deg) scale(1)}
  50%{transform:translate(-50%,-53.5%) rotate(1.8deg) scale(1.025)}
}
@keyframes gear-awaken-v13{
  0%{transform:translate(-50%,-50%) rotate(-1.5deg) scale(1)}
  20%{transform:translate(-50%,-55%) rotate(7deg) scale(1.035)}
  42%{transform:translate(-50%,-48%) rotate(-5deg) scale(1.055)}
  64%{transform:translate(-50%,-53%) rotate(3deg) scale(1.032)}
  82%{transform:translate(-50%,-50%) rotate(-1deg) scale(1.018)}
  100%{transform:translate(-50%,-50%) rotate(0deg) scale(1.02)}
}
@keyframes gear-arm-left-v13{
  0%{opacity:0;transform:scaleY(.1) rotate(42deg)}
  30%{opacity:.55;transform:scaleY(.72) rotate(18deg)}
  60%{opacity:1;transform:scaleY(1.05) rotate(34deg)}
  100%{opacity:1;left:8%;top:55%;transform:scaleY(1) rotate(28deg)}
}
@keyframes gear-arm-right-v13{
  0%{opacity:0;transform:scaleY(.1) rotate(-42deg)}
  30%{opacity:.55;transform:scaleY(.72) rotate(-18deg)}
  60%{opacity:1;transform:scaleY(1.05) rotate(-34deg)}
  100%{opacity:1;right:8%;top:55%;transform:scaleY(1) rotate(-28deg)}
}
@keyframes gear-leg-left-v13{
  0%{opacity:0;transform:scaleY(.1) rotate(8deg)}
  40%{opacity:.62;transform:scaleY(.76) rotate(-7deg)}
  72%{opacity:1;transform:scaleY(1.05) rotate(18deg)}
  100%{opacity:1;left:36%;top:83%;transform:scaleY(1) rotate(13deg)}
}
@keyframes gear-leg-right-v13{
  0%{opacity:0;transform:scaleY(.1) rotate(-8deg)}
  40%{opacity:.62;transform:scaleY(.76) rotate(7deg)}
  72%{opacity:1;transform:scaleY(1.05) rotate(-18deg)}
  100%{opacity:1;right:33%;top:83%;transform:scaleY(1) rotate(-13deg)}
}
@keyframes launch-shadow-v13{
  to{transform:translateX(-50%) perspective(420px) rotateX(66deg) scale(1.08);opacity:.88}
}
@keyframes mascot-photo-walk-v13{
  0%{transform:translate3d(0,0,0) rotate(-1.1deg) scale(1)}
  14%{transform:translate3d(1.1px,-2.6px,0) rotate(1.15deg) scale(1.004,.999)}
  28%{transform:translate3d(.4px,-.5px,0) rotate(.45deg) scale(.999,1.002)}
  43%{transform:translate3d(-1px,-2.45px,0) rotate(-1.05deg) scale(1.004,.999)}
  57%{transform:translate3d(.35px,.25px,0) rotate(.35deg) scale(.999,1.002)}
  72%{transform:translate3d(1px,-2.55px,0) rotate(1.05deg) scale(1.004,.999)}
  86%{transform:translate3d(-.9px,-2.3px,0) rotate(-.95deg) scale(1.003,.999)}
  100%{transform:translate3d(0,0,0) rotate(-1.1deg) scale(1)}
}
@keyframes mascot-body-step-v13{
  0%,100%{translate:0 0;rotate:0deg}
  25%{translate:0 -1px;rotate:.2deg}
  50%{translate:0 .25px;rotate:0deg}
  75%{translate:0 -1px;rotate:-.2deg}
}
@keyframes mascot-resting-v13{
  0%{transform:translateY(-2px) rotate(-1.3deg) scale(1.006)}
  58%{transform:translateY(.45px) rotate(.8deg) scale(.999,1.003)}
  100%{transform:translateY(0) rotate(0) scale(1)}
}
@keyframes mascot-walking-shadow-v13{
  0%,100%{transform:translateX(-50%) perspective(260px) rotateX(68deg) scale(.92);opacity:.28}
  50%{transform:translateX(-50%) perspective(260px) rotateX(68deg) scale(1.02);opacity:.42}
}
@keyframes mascot-pulse-v13{
  0%,100%{opacity:.46;transform:scale(.96)}
  50%{opacity:.74;transform:scale(1.025)}
}
@media (prefers-reduced-motion:reduce){
  .visual-card .gear-creature,.visual-card.is-transforming .gear-creature,.gear-limb,.mascot-companion,.mascot-shell,.mascot-shell img,.mascot-glow{animation:none!important;transition:none!important}
}

/* LUSAE v14 — capa audiovisual premium */
.immersive-section{
  position:relative;
  overflow:hidden;
  padding-top:124px;
  padding-bottom:124px;
  background:
    radial-gradient(circle at 14% 22%,rgba(85,240,210,.12),transparent 28%),
    radial-gradient(circle at 80% 38%,rgba(255,77,184,.14),transparent 30%),
    linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.01));
}
.immersive-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.45;
  background:
    linear-gradient(90deg,transparent 0 49%,rgba(255,255,255,.08) 50%,transparent 51%),
    linear-gradient(0deg,transparent 0 49%,rgba(255,255,255,.055) 50%,transparent 51%);
  background-size:96px 96px;
  mask-image:radial-gradient(circle at 50% 40%,#000,transparent 72%);
}
.immersive-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:46px;
  align-items:center;
}
.immersive-copy{margin-bottom:0!important}
.lab-points{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:26px;
}
.lab-points span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 13px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:999px;
  background:rgba(255,255,255,.055);
  color:rgba(255,255,255,.82);
  font-size:13px;
  font-weight:750;
  box-shadow:0 18px 42px rgba(0,0,0,.16);
}
.lab-points span::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--cyan);
  box-shadow:0 0 16px rgba(85,240,210,.95);
}
.cinema-stack{
  display:grid;
  gap:16px;
  perspective:1200px;
}
.cinema-card,
.mini-cinema,
.mini-dashboard{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(135deg,rgba(255,255,255,.085),rgba(255,255,255,.035));
  border-radius:32px;
  box-shadow:0 30px 90px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.1);
  backdrop-filter:blur(18px);
}
.cinema-card::after,
.mini-cinema::after,
.mini-dashboard::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.16) 42%,transparent 58%);
  transform:translateX(-120%);
  animation:panelShine 5.6s ease-in-out infinite;
}
@keyframes panelShine{0%,42%{transform:translateX(-120%)}70%,100%{transform:translateX(120%)}}
.cinema-main{
  min-height:420px;
  transform:rotateX(3deg) rotateY(-7deg);
  transition:transform 600ms cubic-bezier(.16,1,.32,1),box-shadow 600ms cubic-bezier(.16,1,.32,1);
}
.cinema-main:hover{transform:rotateX(0deg) rotateY(0deg) translateY(-4px);box-shadow:0 42px 120px rgba(0,0,0,.48)}
.cinema-video,
.mini-cinema video{
  width:100%;
  height:100%;
  min-height:420px;
  object-fit:cover;
  opacity:.74;
  filter:saturate(1.25) contrast(1.08);
}
.live-canvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:.72;
  mix-blend-mode:screen;
  pointer-events:none;
}
.cinema-label{
  position:absolute;
  z-index:3;
  left:20px;
  top:20px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 12px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:rgba(5,5,9,.58);
  color:rgba(255,255,255,.88);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
  backdrop-filter:blur(12px);
}
.cinema-label span{
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--cyan);
  box-shadow:0 0 16px rgba(85,240,210,.9);
}
.mini-cinema-grid{
  display:grid;
  grid-template-columns:1fr .82fr;
  gap:16px;
}
.mini-cinema{min-height:230px;transform:rotateY(5deg)}
.mini-cinema video{min-height:230px}
.mini-dashboard{
  min-height:230px;
  padding:28px;
  display:grid;
  align-content:center;
  gap:13px;
  transform:rotateY(-5deg);
}
.dash-row{display:flex;align-items:center;justify-content:space-between;gap:20px;color:rgba(255,255,255,.76);font-size:14px;font-weight:700}
.dash-row strong{color:#fff;font-size:18px}
.dash-bar{height:8px;border-radius:999px;background:rgba(255,255,255,.085);overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.dash-bar i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--cyan),var(--primary),var(--pink));box-shadow:0 0 24px rgba(85,240,210,.36);animation:barPulse 3.2s ease-in-out infinite}
@keyframes barPulse{0%,100%{transform:scaleX(.88);transform-origin:left}50%{transform:scaleX(1)}}
.service-card,.step,.feature-panel,.pricing-table,.contact-form{will-change:transform}
.service-card:hover,.step:hover{
  box-shadow:0 34px 100px rgba(0,0,0,.36),0 0 54px rgba(122,92,255,.12);
}
.visual-card{box-shadow:0 44px 130px rgba(0,0,0,.48),0 0 90px rgba(122,92,255,.14)!important}
.visual-card::before{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:inherit;
  pointer-events:none;
  background:conic-gradient(from 120deg,transparent,rgba(85,240,210,.3),transparent,rgba(255,77,184,.24),transparent);
  opacity:.22;
  animation:slowSpin 10s linear infinite;
}
@keyframes slowSpin{to{transform:rotate(1turn)}}
@media (max-width: 980px){
  .immersive-grid{grid-template-columns:1fr;gap:34px}
  .cinema-main{transform:none;min-height:360px}
  .cinema-video{min-height:360px}
  .mini-cinema{transform:none}.mini-dashboard{transform:none}
}
@media (max-width: 680px){
  .immersive-section{padding-top:86px;padding-bottom:86px}
  .mini-cinema-grid{grid-template-columns:1fr}
  .cinema-main,.cinema-video{min-height:300px}
  .mini-cinema,.mini-cinema video,.mini-dashboard{min-height:210px}
  .lab-points span{width:100%;justify-content:center}
}
@media (prefers-reduced-motion: reduce){
  .cinema-card::after,.mini-cinema::after,.mini-dashboard::after,.dash-bar i,.visual-card::before{animation:none!important}
  .cinema-video,.mini-cinema video{display:none}
  .live-canvas{display:none}
}

/* LUSAE v15 — homogeneización premium de todos los apartados */
.section::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;
  width:min(1180px,calc(100% - 44px));
  height:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),transparent);
  pointer-events:none;
}
.premium-services,
.premium-difference,
.premium-pricing{
  overflow:hidden;
  background:
    radial-gradient(circle at 8% 24%,rgba(122,92,255,.12),transparent 30%),
    radial-gradient(circle at 92% 42%,rgba(85,240,210,.08),transparent 28%);
}
.premium-services::before,
.premium-difference::before,
.premium-pricing::before,
.premium-contact::before{
  content:"";
  position:absolute;
  inset:0;
  opacity:.22;
  pointer-events:none;
  background:
    linear-gradient(120deg,transparent 0 48%,rgba(255,255,255,.055) 50%,transparent 52%),
    radial-gradient(circle at 50% 0%,rgba(255,255,255,.08),transparent 48%);
  background-size:180px 180px,100% 100%;
  mask-image:linear-gradient(to bottom,#000,transparent 88%);
}
.premium-service-grid{gap:20px}
.premium-card{
  min-height:390px;
  isolation:isolate;
  transform-style:preserve-3d;
  --tilt-x:0deg;
  --tilt-y:0deg;
  transform:perspective(900px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
}
.premium-card:hover{transform:perspective(900px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y)) translateY(-7px)}
.premium-card > *:not(.service-media){position:relative;z-index:2}
.service-media{
  position:absolute;
  inset:auto 24px 24px auto;
  width:172px;
  height:124px;
  z-index:1;
  border:1px solid rgba(255,255,255,.13);
  border-radius:26px;
  background:linear-gradient(145deg,rgba(255,255,255,.1),rgba(255,255,255,.035));
  box-shadow:0 24px 70px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.12);
  overflow:hidden;
  opacity:.88;
}
.service-media::before{
  content:"";
  position:absolute;
  inset:18px;
  border-radius:20px;
  border:1px solid rgba(85,240,210,.32);
  box-shadow:0 0 32px rgba(85,240,210,.12);
  animation:servicePulse 3.4s ease-in-out infinite;
}
.service-media span,
.service-media i,
.service-media b{
  position:absolute;
  display:block;
  border-radius:999px;
  background:linear-gradient(90deg,var(--cyan),var(--primary),var(--pink));
  box-shadow:0 0 22px rgba(85,240,210,.34);
}
.service-media span{left:22px;right:32px;bottom:28px;height:8px;transform-origin:left;animation:serviceBar 3.2s ease-in-out infinite}
.service-media i{left:26px;bottom:50px;width:42px;height:42px;background:radial-gradient(circle,var(--cyan),transparent 68%);animation:serviceDot 4.1s ease-in-out infinite}
.service-media b{right:24px;top:24px;width:48px;height:48px;background:radial-gradient(circle,var(--pink),transparent 70%);animation:serviceDot 4.6s ease-in-out infinite reverse}
.service-media-radar::before{border-radius:999px;inset:24px;animation:radarRing 2.8s linear infinite}
.service-media-radar span{inset:50% auto auto 50%;width:58px;height:2px;transform-origin:left;background:var(--cyan);animation:radarSweep 2.8s linear infinite}
.service-media-copy span{left:24px;right:24px;top:30px;bottom:auto;height:8px;animation:typingLine 3.8s steps(18,end) infinite}
.service-media-copy i{left:24px;right:52px;top:54px;width:auto;height:8px;border-radius:999px;animation:typingLine 4.4s steps(12,end) infinite}.service-media-copy b{left:24px;right:74px;top:78px;width:auto;height:8px;border-radius:999px;animation:typingLine 4.9s steps(10,end) infinite}
.service-media-ai::before{clip-path:polygon(50% 0,100% 30%,100% 70%,50% 100%,0 70%,0 30%);border-radius:0;animation:serviceSpin 5.2s linear infinite}
@keyframes servicePulse{0%,100%{opacity:.55;transform:scale(.94)}50%{opacity:1;transform:scale(1.02)}}
@keyframes serviceBar{0%,100%{transform:scaleX(.35)}50%{transform:scaleX(1)}}
@keyframes serviceDot{0%,100%{transform:translate3d(0,0,0) scale(.9)}50%{transform:translate3d(28px,-18px,0) scale(1.12)}}
@keyframes radarRing{to{transform:rotate(1turn)}}
@keyframes radarSweep{to{transform:rotate(1turn)}}
@keyframes typingLine{0%{transform:scaleX(.08)}55%,100%{transform:scaleX(1)}}
@keyframes serviceSpin{to{transform:rotate(1turn)}}
.premium-strip{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  padding:16px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:32px;
  background:rgba(255,255,255,.055);
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px);
}
.premium-strip div{
  position:relative;
  overflow:hidden;
  min-height:142px;
  padding:20px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:24px;
  background:linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.028));
}
.premium-strip div::after{content:"";position:absolute;inset:auto 16px 14px;height:3px;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--primary),var(--pink));box-shadow:0 0 26px rgba(85,240,210,.3);animation:stripLine 4s ease-in-out infinite}
.premium-strip span{display:block;margin-bottom:18px;color:var(--cyan);font-size:12px;font-weight:950;letter-spacing:.18em}.premium-strip strong{display:block;font-size:20px;margin-bottom:8px}.premium-strip small{color:rgba(255,255,255,.66);line-height:1.55}
@keyframes stripLine{0%,100%{transform:scaleX(.35);transform-origin:left}50%{transform:scaleX(1);transform-origin:left}}
.process-grid-premium{grid-template-columns:.72fr 1.28fr!important;align-items:start}.premium-process{padding-block:124px}.process-lab{position:relative;min-height:680px;padding:20px;border:1px solid rgba(255,255,255,.12);border-radius:40px;background:linear-gradient(150deg,rgba(255,255,255,.09),rgba(255,255,255,.028));box-shadow:var(--shadow);overflow:hidden;backdrop-filter:blur(18px)}
.process-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.24;filter:saturate(1.24) contrast(1.05);pointer-events:none}.process-lab::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,9,.12),rgba(5,5,9,.82) 78%);pointer-events:none}.process-hud{position:relative;z-index:2;display:flex;justify-content:space-between;gap:20px;align-items:center;margin-bottom:28px;padding:15px 17px;border:1px solid rgba(255,255,255,.13);border-radius:999px;background:rgba(5,5,9,.55);backdrop-filter:blur(14px)}.process-hud span{color:var(--cyan);font-size:12px;text-transform:uppercase;letter-spacing:.16em;font-weight:900}.process-hud strong{font-size:13px;color:rgba(255,255,255,.82)}.premium-steps{position:relative;z-index:2}.premium-steps .step{min-height:194px;background:rgba(8,8,18,.72);box-shadow:0 22px 70px rgba(0,0,0,.24)}.premium-steps .step::before{content:attr(data-step);position:absolute;right:22px;top:18px;font-size:64px;font-weight:950;letter-spacing:-.08em;color:rgba(255,255,255,.035)}
.feature-panel-premium{grid-template-columns:.9fr 1.1fr;overflow:hidden}.proof-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:26px}.proof-grid div{padding:18px;border:1px solid rgba(255,255,255,.12);border-radius:20px;background:rgba(255,255,255,.055)}.proof-grid strong{display:block;font-size:32px;letter-spacing:-.05em;background:linear-gradient(120deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}.proof-grid span{display:block;margin-top:6px;color:rgba(255,255,255,.66);font-size:12px;line-height:1.4}.brand-orbit-card{position:relative;min-height:520px;border-radius:32px;overflow:hidden;border:1px solid rgba(255,255,255,.13);background:#080812;box-shadow:0 30px 100px rgba(0,0,0,.35)}.brand-orbit-card video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.78;filter:saturate(1.18)}.feature-list-floating{position:absolute;inset:auto 20px 20px;z-index:2;background:rgba(5,5,9,.56);padding:14px;border:1px solid rgba(255,255,255,.12);border-radius:24px;backdrop-filter:blur(16px)}.feature-list-floating div{background:rgba(255,255,255,.05)}
.pricing-grid-premium{grid-template-columns:.86fr 1.14fr}.investment-card{margin-top:26px;padding:24px;border:1px solid rgba(255,255,255,.13);border-radius:28px;background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.035));box-shadow:0 22px 70px rgba(0,0,0,.26)}.investment-card span{color:var(--cyan);font-size:12px;text-transform:uppercase;letter-spacing:.18em;font-weight:900}.investment-card strong{display:block;margin-top:13px;font-size:23px;line-height:1.15}.investment-card p{margin-top:12px;color:var(--muted);line-height:1.7}.pricing-stack{display:grid;gap:16px}.pricing-stack .pricing-table{position:relative}.pricing-stack .pricing-table::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(120deg,transparent,rgba(255,255,255,.08),transparent);transform:translateX(-120%);animation:panelShine 6.4s ease-in-out infinite}.pricing-orbit{position:relative;min-height:210px;padding:30px;border:1px solid rgba(255,255,255,.13);border-radius:32px;background:radial-gradient(circle at 70% 45%,rgba(85,240,210,.16),transparent 32%),linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.035));box-shadow:var(--shadow);overflow:hidden}.pricing-orbit span{position:absolute;border-radius:999px;border:1px solid rgba(85,240,210,.22);animation:pricingOrbit 8s linear infinite}.pricing-orbit span:nth-child(1){width:240px;height:240px;right:-60px;top:-72px}.pricing-orbit span:nth-child(2){width:160px;height:160px;right:28px;top:-28px;animation-duration:6.4s;animation-direction:reverse}.pricing-orbit span:nth-child(3){width:84px;height:84px;right:66px;top:28px;box-shadow:0 0 32px rgba(85,240,210,.18)}.pricing-orbit strong,.pricing-orbit p{position:relative;z-index:2}.pricing-orbit strong{display:block;font-size:30px;letter-spacing:-.04em}.pricing-orbit p{max-width:420px;margin-top:14px;color:var(--muted);line-height:1.7}@keyframes pricingOrbit{to{transform:rotate(1turn)}}
.contact-grid-premium{align-items:center}.contact-signal{display:grid;gap:10px;margin-top:26px}.contact-signal div{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1px solid rgba(255,255,255,.13);border-radius:18px;background:rgba(255,255,255,.06)}.contact-signal span{width:10px;height:10px;border-radius:999px;background:var(--cyan);box-shadow:0 0 18px rgba(85,240,210,.8);animation:contactBlink 2.2s ease-in-out infinite}.contact-signal div:nth-child(2) span{animation-delay:.25s}.contact-signal div:nth-child(3) span{animation-delay:.5s}.contact-signal strong{font-size:14px;color:rgba(255,255,255,.82)}@keyframes contactBlink{0%,100%{opacity:.45;transform:scale(.84)}50%{opacity:1;transform:scale(1.15)}}.premium-form{position:relative;overflow:hidden}.premium-form::before{content:"";position:absolute;inset:-1px;border-radius:inherit;background:radial-gradient(circle at 85% 0%,rgba(85,240,210,.18),transparent 34%),radial-gradient(circle at 8% 80%,rgba(255,77,184,.13),transparent 30%);pointer-events:none}.premium-form > *{position:relative;z-index:2}.form-header{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:2px;padding:16px;border:1px solid rgba(255,255,255,.13);border-radius:20px;background:rgba(5,5,9,.36)}.form-header span{color:var(--cyan);font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:900}.form-header strong{font-size:15px}.contact-link{box-shadow:0 18px 54px rgba(0,0,0,.18)}
@media (max-width:1020px){.process-grid-premium,.pricing-grid-premium{grid-template-columns:1fr!important}.process-lab{min-height:auto}.process-video{display:none}.feature-panel-premium{grid-template-columns:1fr}.brand-orbit-card{min-height:430px}.premium-strip{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:860px){.premium-card{min-height:auto}.service-media{position:relative;inset:auto;width:100%;height:140px;margin:0 0 24px}.proof-grid{grid-template-columns:1fr}.brand-orbit-card{min-height:360px}.premium-strip{grid-template-columns:1fr}.process-hud{border-radius:22px;align-items:flex-start;flex-direction:column}.pricing-orbit{min-height:180px}}
@media (max-width:620px){.premium-services::before,.premium-difference::before,.premium-pricing::before,.premium-contact::before{opacity:.12}.feature-list-floating{position:relative;inset:auto;margin:16px}.brand-orbit-card video{opacity:.42}.brand-orbit-card{min-height:auto}.premium-steps .step::before{font-size:46px}.form-header{display:grid}.premium-strip div{min-height:auto}}
@media (prefers-reduced-motion:reduce){.service-media::before,.service-media span,.service-media i,.service-media b,.premium-strip div::after,.pricing-orbit span,.contact-signal span,.pricing-stack .pricing-table::before{animation:none!important}.process-video,.brand-orbit-card video{display:none}}
