/* ============================================================
   EgeaINC — promotional rebuild
   ============================================================ */
:root{
  --bg:#0A0C10;
  --bg-2:#0F131A;
  --card:#12171F;
  --card-2:#161C26;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.15);
  --ink:#EAF0F6;
  --muted:#97A4B4;
  --muted-2:#6B7787;
  --green:#04CE78;
  --green-bright:#1FFF9D;
  --green-dim:rgba(4,206,120,.14);
  --blue:#2E9BFF;
  --blue-deep:#1763E8;
  --grad:linear-gradient(135deg,var(--green) 0%,var(--blue) 100%);
  --maxw:1200px;
  --pad:clamp(20px,5vw,40px);
  --radius:16px;
  --font-display:"Space Grotesk",system-ui,sans-serif;
  --font-body:"Inter",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.06;letter-spacing:-.02em}
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--green);color:#04130B;padding:10px 16px;border-radius:0 0 8px 0;font-weight:600}
.skip-link:focus{left:0}
:focus-visible{outline:2px solid var(--green-bright);outline-offset:3px;border-radius:4px}

.kicker{font-family:var(--font-mono);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--green);margin-bottom:14px;font-weight:500}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:600;font-size:15px;
  padding:13px 22px;border-radius:10px;border:1px solid transparent;cursor:pointer;
  transition:transform .18s ease,box-shadow .25s ease,background .25s ease,border-color .25s;white-space:nowrap}
.btn--primary{background:var(--green);color:#04130B;box-shadow:0 8px 24px -10px rgba(4,206,120,.8)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 14px 34px -10px rgba(4,206,120,1);background:var(--green-bright)}
.btn--glass{background:rgba(255,255,255,.08);color:var(--ink);border-color:rgba(255,255,255,.22);backdrop-filter:blur(6px)}
.btn--glass:hover{border-color:var(--green);color:var(--green-bright);transform:translateY(-2px)}
.btn--lg{padding:16px 30px;font-size:16px}
.btn svg{transition:transform .2s}
.btn--primary:hover svg{transform:translateX(3px)}

/* ============================================================ NAV */
.nav{position:sticky;top:0;z-index:100;backdrop-filter:blur(14px);background:rgba(10,12,16,.55);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.nav.scrolled{background:rgba(10,12,16,.9);border-bottom-color:var(--line)}
.nav__inner{max-width:var(--maxw);margin-inline:auto;padding:12px var(--pad);display:flex;align-items:center;gap:24px}
.brand__logo{height:42px;width:auto;filter:drop-shadow(0 2px 10px rgba(46,155,255,.4))}
.nav__links{display:flex;align-items:center;gap:6px;margin-left:14px}
.nav__links>a,.nav__dropdown-btn{font-size:14.5px;color:var(--muted);padding:8px 12px;border-radius:8px;
  transition:color .2s,background .2s;font-family:var(--font-body)}
.nav__links>a:hover,.nav__dropdown-btn:hover{color:var(--ink);background:rgba(255,255,255,.05)}
.nav__dropdown{position:relative}
.nav__dropdown-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer}
.nav__dropdown-btn svg{transition:transform .2s}
.nav__dropdown.open .nav__dropdown-btn svg{transform:rotate(180deg)}
.nav__menu{position:absolute;top:calc(100% + 10px);left:0;min-width:230px;background:var(--card);
  border:1px solid var(--line);border-radius:12px;padding:6px;box-shadow:0 24px 50px -20px rgba(0,0,0,.8);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.2s}
.nav__dropdown.open .nav__menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav__menu a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:14px;color:var(--muted);transition:.18s}
.nav__menu a:hover{background:var(--green-dim);color:var(--ink)}
.nav__menu .dot{width:6px;height:6px;border-radius:50%;background:var(--muted-2);transition:.18s}
.nav__menu a:hover .dot{background:var(--green);box-shadow:0 0 8px var(--green)}
.nav__right{margin-left:auto;display:flex;align-items:center;gap:14px}
.nav__cta{padding:10px 18px;font-size:14px}
.lang{display:inline-flex;gap:2px;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:9px;padding:3px}
.lang__btn{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border:none;background:none;cursor:pointer;border-radius:7px;
  color:var(--muted);font-family:var(--font-mono);font-size:11.5px;letter-spacing:.05em;opacity:.55;transition:opacity .2s,background .2s,color .2s}
.lang__btn .flag{width:20px;height:13px;border-radius:2px;box-shadow:0 0 0 1px rgba(255,255,255,.14);flex:none}
.lang__btn:hover{opacity:1}
.lang__btn.active{opacity:1;background:rgba(4,206,120,.15);color:var(--ink)}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav__burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.drawer{display:none;flex-direction:column;gap:4px;padding:10px var(--pad) 24px;border-top:1px solid var(--line);background:rgba(10,12,16,.97)}
.drawer.open{display:flex}
.drawer>a{padding:12px 6px;color:var(--ink);border-bottom:1px solid var(--line);font-size:16px}
.drawer .btn{margin-top:14px;justify-content:center}
.drawer__group{display:flex;flex-direction:column;gap:2px;padding:10px 0}
.drawer__label{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--green);padding:6px 6px}
.drawer__group a{padding:9px 14px;color:var(--muted);font-size:14.5px}

/* ============================================================ HERO SLIDER */
.hero{position:relative;height:clamp(520px,78vh,760px);overflow:hidden;background:#000;border-bottom:1px solid var(--line)}
.hero__slides{position:absolute;inset:0}
.slide{position:absolute;inset:0;overflow:hidden;background:#000;
  opacity:0;visibility:hidden;transition:opacity .9s ease,visibility .9s;display:flex;align-items:center}
.slide::before{content:"";position:absolute;inset:0;z-index:0;background-image:inherit;
  background-size:cover;background-position:center;background-repeat:no-repeat}
.slide.is-active{opacity:1;visibility:visible;z-index:2}
.slide.is-active::before{animation:kenburns 8s ease-out both}
@keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.14)}}
.slide__scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg,rgba(8,10,14,.94) 0%,rgba(8,10,14,.78) 38%,rgba(8,10,14,.35) 70%,rgba(8,10,14,.55) 100%),
    linear-gradient(0deg,rgba(8,10,14,.7),transparent 45%)}
.slide__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw)}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--green);border:1px solid var(--line-2);background:rgba(4,206,120,.08);
  padding:7px 14px;border-radius:100px;margin-bottom:22px}
.eyebrow__dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(4,206,120,.5)}70%{box-shadow:0 0 0 7px rgba(4,206,120,0)}100%{box-shadow:0 0 0 0 rgba(4,206,120,0)}}
.slide__title{font-size:clamp(38px,6.4vw,76px);letter-spacing:-.035em;margin-bottom:20px;max-width:16ch;
  text-shadow:0 4px 30px rgba(0,0,0,.6)}
.slide__sub{color:#cdd6e0;font-size:clamp(15px,1.5vw,19px);max-width:50ch;margin-bottom:30px;text-shadow:0 2px 16px rgba(0,0,0,.6)}
.slide__actions{display:flex;flex-wrap:wrap;gap:14px}
/* slide entrance animation for content */
.slide.is-active .eyebrow{animation:rise .6s .15s both}
.slide.is-active .slide__title{animation:rise .6s .25s both}
.slide.is-active .slide__sub{animation:rise .6s .35s both}
.slide.is-active .slide__actions{animation:rise .6s .45s both}
@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* slide de apps (sin foto, cluster de iconos) */
.slide--apps{background:
  radial-gradient(720px 480px at 80% 28%,rgba(46,155,255,.16),transparent 60%),
  radial-gradient(620px 460px at 12% 95%,rgba(4,206,120,.15),transparent 60%),
  var(--bg)}
.slide__inner--split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,56px);align-items:center}
.slide__apps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:360px;margin-left:auto;width:100%}
.slide__apps img{width:100%;aspect-ratio:1;border-radius:22px;border:1px solid var(--line-2);background:#0A0C10;
  box-shadow:0 18px 34px -16px rgba(0,0,0,.85);animation:appFloat 4.5s ease-in-out infinite}
.slide__apps img:nth-child(3n+2){animation-delay:.7s}
.slide__apps img:nth-child(3n){animation-delay:1.4s}
@keyframes appFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@media(max-width:820px){
  .slide__inner--split{grid-template-columns:1fr}
  .slide__apps{display:none}
}

.hero__arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;color:#fff;background:rgba(10,12,16,.45);border:1px solid var(--line-2);
  backdrop-filter:blur(6px);cursor:pointer;transition:.2s;opacity:.85}
.hero__arrow:hover{background:var(--green);color:#04130B;border-color:var(--green);opacity:1}
.hero__arrow--prev{left:clamp(12px,2vw,28px)}
.hero__arrow--next{right:clamp(12px,2vw,28px)}
.hero__dots{position:absolute;bottom:28px;left:0;right:0;z-index:5;display:flex;justify-content:center;gap:10px}
.hero__dots button{width:10px;height:10px;border-radius:50%;border:none;cursor:pointer;background:rgba(255,255,255,.3);transition:.25s;padding:0}
.hero__dots button.active{background:var(--green);width:30px;border-radius:6px;box-shadow:0 0 12px var(--green)}
.hero__progress{position:absolute;bottom:0;left:0;right:0;height:3px;z-index:5;background:rgba(255,255,255,.08)}
.hero__progress span{display:block;height:100%;width:0;background:var(--grad);box-shadow:0 0 10px var(--green)}

/* ============================================================ TICKER */
.ticker{background:var(--bg-2);border-bottom:1px solid var(--line)}
.ticker__row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px;padding:18px var(--pad);
  font-family:var(--font-mono);font-size:13.5px;color:var(--muted);letter-spacing:.02em}
.ticker__row b{color:var(--ink);font-weight:600}
.ticker .dotsep{width:5px;height:5px;border-radius:50%;background:var(--green);opacity:.6}

/* ============================================================ SECTIONS */
.section{padding-block:clamp(64px,9vw,108px)}
.section__head{max-width:640px;margin-bottom:clamp(40px,5vw,58px)}
.section__head--center{margin-inline:auto;text-align:center}
.section__title{font-size:clamp(28px,3.6vw,46px)}
.section__lead{color:var(--muted);font-size:clamp(15px,1.3vw,18px);margin-top:16px}

/* service cards with image */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.scard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:transform .25s ease,border-color .25s,box-shadow .25s}
.scard:hover{transform:translateY(-7px);border-color:var(--line-2);box-shadow:0 24px 50px -26px rgba(0,0,0,.9)}
.scard__media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--bg-2)}
.scard__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.scard:hover .scard__media img{transform:scale(1.07)}
.scard__media::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(18,23,31,.55),transparent 55%)}
.scard__body{padding:22px}
.scard__tag{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--green);
  background:var(--green-dim);padding:4px 9px;border-radius:6px}
.scard h3{font-size:18.5px;margin:14px 0 10px}
.scard p{color:var(--muted);font-size:14.5px}

/* ---------- stats ---------- */
.stats{background:radial-gradient(700px 300px at 50% 0%,rgba(4,206,120,.08),transparent 70%),var(--bg-2);border-block:1px solid var(--line)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding-block:clamp(48px,6vw,72px)}
.stat{text-align:center;padding:14px}
.stat__num{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(40px,5.5vw,62px);line-height:1;
  letter-spacing:-.03em;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__suffix{-webkit-text-fill-color:var(--ink);color:var(--ink);font-size:.5em;vertical-align:super}
.stat__label{display:block;margin-top:14px;font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

/* ---------- split ---------- */
.section--split{background:var(--bg)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,72px);align-items:center}
.split__left .btn{margin-top:30px}
.featlist{list-style:none;display:flex;flex-direction:column;gap:14px}
.feat{display:flex;gap:16px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px;
  transition:border-color .25s,transform .25s,background .25s}
.feat:hover{border-color:var(--line-2);transform:translateX(4px);background:var(--card-2)}
.feat__bullet{flex:none;width:12px;height:12px;border-radius:50%;margin-top:6px;background:var(--grad);box-shadow:0 0 12px -2px var(--green)}
.feat h3{font-size:17px;margin-bottom:6px}
.feat p{color:var(--muted);font-size:14.5px}

/* ============================================================ TESTIMONIO CARRUSEL */
.section--quotes{background:linear-gradient(180deg,var(--bg),var(--bg-2));overflow:hidden}
.tcar{position:relative;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(48px,6vw,72px)}
.tcar__viewport{overflow:hidden}
.tcar__track{display:flex;gap:20px;transition:transform .55s cubic-bezier(.22,.7,.2,1);will-change:transform}
.quote{flex:0 0 calc((100% - 40px)/3);background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;
  display:flex;flex-direction:column}
.quote blockquote{font-size:15.5px;color:var(--ink);line-height:1.55;position:relative;flex:1}
.quote blockquote::before{content:"\201C";font-family:var(--font-display);font-size:52px;color:var(--green);opacity:.45;line-height:0;
  position:absolute;top:14px;left:-4px}
.quote figcaption{display:flex;align-items:center;gap:12px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
.quote__av{flex:none;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-family:var(--font-mono);
  font-size:13px;font-weight:600;color:#04130B;background:var(--grad)}
.quote figcaption b{display:block;font-size:14.5px}
.quote figcaption em{font-style:normal;font-family:var(--font-mono);font-size:11.5px;color:var(--muted-2);letter-spacing:.05em}
.tcar__arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:44px;height:44px;border-radius:50%;
  display:grid;place-items:center;color:var(--ink);background:var(--card);border:1px solid var(--line-2);cursor:pointer;transition:.2s}
.tcar__arrow:hover{background:var(--green);color:#04130B;border-color:var(--green)}
.tcar__arrow--prev{left:0}
.tcar__arrow--next{right:0}
.tcar__dots{display:flex;justify-content:center;gap:10px;margin-top:30px}
.tcar__dots button{width:10px;height:10px;border-radius:50%;border:none;cursor:pointer;background:rgba(255,255,255,.18);transition:.25s;padding:0}
.tcar__dots button.active{background:var(--green);width:28px;border-radius:6px}

/* ---------- cta band ---------- */
.ctaband{background:linear-gradient(120deg,rgba(4,206,120,.12),rgba(46,155,255,.12)),var(--bg-2);border-block:1px solid var(--line)}
.cta{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-block:clamp(48px,6vw,72px)}
.cta__title{font-size:clamp(26px,3.2vw,40px);max-width:18ch}
.cta__sub{color:var(--muted);margin-top:12px;max-width:46ch}

/* ---------- posts (clickable) ---------- */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.post{position:relative;display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 24px;overflow:hidden;transition:transform .25s,border-color .25s,background .25s}
.post::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad)}
.post:hover{transform:translateY(-6px);border-color:var(--line-2);background:var(--card-2)}
.post__cat{align-self:flex-start;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--green);background:var(--green-dim);padding:4px 9px;border-radius:6px}
.post h3{font-size:18.5px;margin:16px 0 10px;line-height:1.2}
.post p{color:var(--muted);font-size:14px;margin-bottom:20px;flex:1}
.post__more{font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--green);transition:gap .2s,transform .2s}
.post:hover .post__more{color:var(--green-bright)}
.posts__more{display:flex;justify-content:center;margin-top:40px}

/* ---------- clientes (marquee 2 filas) ---------- */
.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}
.clients{border-top:1px solid var(--line);background:var(--bg);padding-block:clamp(48px,6vw,68px);overflow:hidden}
.clients__lead{text-align:center;font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:36px}
.marquee{position:relative;padding-block:16px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent)}
.mrow{display:flex;align-items:center;list-style:none;width:max-content;will-change:transform}
.mrow.l{animation:mqL var(--dur,90s) linear infinite}
.marquee:hover .mrow,.marquee:focus-within .mrow{animation-play-state:paused}
@keyframes mqL{from{transform:translateX(0)}to{transform:translateX(calc(var(--shift,1000px) * -1))}}
.mrow.static{width:auto;flex-wrap:wrap;justify-content:center;row-gap:12px;animation:none}
.cl-card{flex:none;margin-right:14px;padding:15px 28px;border-radius:12px;
  background:linear-gradient(180deg,var(--card-2),var(--card));
  border:1px solid var(--line-2);
  transition:background .25s,border-color .25s,transform .25s}
.cl-card__name{font-family:var(--font-display);font-weight:500;font-size:16px;color:var(--muted);
  white-space:nowrap;letter-spacing:.005em;transition:color .25s}
.cl-card:hover{border-color:var(--green);transform:translateY(-2px)}
.cl-card:hover .cl-card__name{color:var(--ink)}

/* ---------- aplicaciones ---------- */
.apps{background:var(--bg-2);border-block:1px solid var(--line)}
.appgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:16px}
.appcard{display:flex;align-items:center;gap:15px;padding:16px 18px;background:var(--card);border:1px solid var(--line);
  border-radius:15px;transition:transform .22s ease,border-color .22s,background .22s}
.appcard:hover{transform:translateY(-4px);border-color:var(--line-2);background:var(--card-2)}
.appcard__icon{width:54px;height:54px;border-radius:14px;flex:none;border:1px solid var(--line);
  box-shadow:0 8px 18px -8px rgba(0,0,0,.7);background:#0A0C10}
.appcard__info{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.appcard__info b{font-family:var(--font-display);font-size:15.5px;font-weight:600;color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appcard__info em{font-style:normal;font-size:13px;color:var(--muted)}
.appcard__go{flex:none;color:var(--muted-2);font-size:16px;transition:color .22s,transform .22s}
.appcard:hover .appcard__go{color:var(--green);transform:translateX(3px)}
.apps__more{display:flex;justify-content:center;margin-top:38px}

/* ---------- contacto ---------- */
.contact{background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px);align-items:start}
.contact__list{list-style:none;display:flex;flex-direction:column;gap:12px;margin:26px 0}
.contact__list li{display:flex;align-items:center;gap:11px;color:var(--muted);font-size:15px}
.contact__ic{width:26px;text-align:center}
.contact__list a{color:var(--ink)}
.contact__list a:hover{color:var(--green)}
.contact__ctas{display:flex;flex-wrap:wrap;gap:12px}
.contact__form{background:linear-gradient(180deg,var(--card-2),var(--card));border:1px solid var(--line);
  border-radius:18px;padding:clamp(22px,3vw,30px);display:flex;flex-direction:column;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-family:var(--font-mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea{background:#0A0C10;border:1px solid var(--line);border-radius:11px;padding:13px 15px;
  color:var(--ink);font-family:var(--font-body);font-size:15px;resize:vertical;transition:border-color .2s,box-shadow .2s}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(4,206,120,.15)}
.contact__form .btn{justify-content:center;margin-top:4px}
.contact__note{font-size:12.5px;color:var(--muted-2);text-align:center;margin-top:-4px}

/* ============================================================ FOOTER */
.footer{border-top:1px solid var(--line);background:var(--bg-2);padding-top:clamp(48px,6vw,72px)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:34px;padding-bottom:44px}
.footer__logo{height:48px;width:auto;margin-bottom:16px}
.footer__tag{color:var(--muted);font-size:14.5px;max-width:30ch}
.footer__col h4{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:16px;font-weight:500}
.footer__col a{display:block;color:var(--muted);font-size:14.5px;padding:5px 0;transition:color .2s}
.footer__col a:hover{color:var(--green)}
.footer__loc{color:var(--muted-2);font-size:13px;margin-bottom:8px}
.footer__ig{display:inline-flex;align-items:center;gap:9px}
.footer__ticket{margin-top:14px;color:var(--green)!important}
.footer__bar{border-top:1px solid var(--line);padding:22px var(--pad);max-width:var(--maxw);margin-inline:auto;display:flex;
  justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-family:var(--font-mono);font-size:12px;color:var(--muted-2);letter-spacing:.04em}

/* ============================================================ FLOATING */
/* WhatsApp widget con burbuja */
.wa{position:fixed;left:22px;bottom:22px;z-index:95;display:flex;flex-direction:column;align-items:flex-start;gap:14px}
.wa__btn{position:relative;width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;display:grid;place-items:center;
  color:#fff;background:#25D366;box-shadow:0 12px 30px -8px rgba(37,211,102,.75);transition:transform .2s}
.wa__btn::before{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 rgba(37,211,102,.6);animation:waPulse 2.6s infinite}
@keyframes waPulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 14px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.wa__btn:hover{transform:scale(1.08)}
.wa__badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#EF4444;
  color:#fff;font-family:var(--font-mono);font-size:11px;display:grid;place-items:center;box-shadow:0 0 0 2px var(--bg)}
.wa.open .wa__badge{display:none}
.wa__bubble{width:290px;max-width:78vw;background:var(--card);border:1px solid var(--line-2);border-radius:18px;padding:16px;
  box-shadow:0 30px 60px -22px rgba(0,0,0,.85);position:relative;
  transform-origin:bottom left;animation:waIn .28s cubic-bezier(.2,.7,.2,1)}
.wa__bubble[hidden]{display:none}
@keyframes waIn{from{opacity:0;transform:translateY(10px) scale(.94)}to{opacity:1;transform:none}}
.wa__close{position:absolute;top:8px;right:10px;background:none;border:none;color:var(--muted);font-size:22px;line-height:1;cursor:pointer}
.wa__close:hover{color:var(--ink)}
.wa__head{display:flex;align-items:center;gap:11px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.wa__avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;
  color:#04130B;background:var(--grad)}
.wa__id b{display:block;font-family:var(--font-display);font-size:14.5px}
.wa__id em{font-style:normal;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.wa__dot{width:7px;height:7px;border-radius:50%;background:#25D366;box-shadow:0 0 8px #25D366}
.wa__msg{font-size:14.5px;color:var(--ink);margin:14px 0 16px;line-height:1.5}
.wa__cta{display:flex;align-items:center;justify-content:center;gap:9px;background:#25D366;color:#fff;
  font-family:var(--font-display);font-weight:600;font-size:14.5px;padding:11px;border-radius:11px;transition:filter .2s,transform .2s}
.wa__cta:hover{filter:brightness(1.08);transform:translateY(-1px)}
.totop{position:fixed;right:22px;bottom:22px;z-index:90;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  color:var(--ink);background:var(--card);border:1px solid var(--line-2);cursor:pointer;opacity:0;visibility:hidden;transform:translateY(10px);transition:.25s}
.totop.show{opacity:1;visibility:visible;transform:translateY(0)}
.totop:hover{border-color:var(--green);color:var(--green)}

/* ============================================================ REVEAL */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ============================================================ RESPONSIVE */
@media(max-width:980px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .nav__cta{display:none}
  .cards{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .posts{grid-template-columns:repeat(2,1fr)}
  .quote{flex:0 0 calc((100% - 20px)/2)}
  .footer__grid{grid-template-columns:1fr 1fr}
  .contact__grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .cards,.posts,.stats__grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .cta{flex-direction:column;align-items:flex-start}
  .quote{flex:0 0 100%}
  .hero{height:clamp(540px,88vh,640px)}
  .ticker__row{gap:10px;font-size:12.5px}
  .ticker .dotsep{display:none}
  .wa{left:16px;bottom:16px}
  .wa__btn{width:50px;height:50px}
  .hero__arrow{width:38px;height:38px}
  .lang__btn span{display:none}
  .lang__btn{padding:5px 7px}
  .nav__inner{gap:12px}
  .slide__title{font-size:clamp(32px,8vw,44px)}
  .slide__sub{font-size:14.5px}
}

/* ============================================================ REDUCED MOTION */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .slide.is-active::before{animation:none}
}

/* ===================== DOMÓTICA — DEMO EN VIVO (celu) ===================== */
.hademo{position:relative;overflow:hidden}
.hademo::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(620px 420px at 82% 40%,rgba(46,155,255,.10),transparent 62%),
             radial-gradient(520px 380px at 12% 90%,rgba(4,206,120,.08),transparent 60%)}
.hademo__grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center}
.hademo__feats{list-style:none;margin:22px 0 26px;padding:0;display:grid;gap:12px}
.hademo__feats li{display:flex;align-items:flex-start;gap:12px;color:var(--muted);font-size:15.5px;line-height:1.5}
.hademo__feats .feat__bullet{margin-top:7px;flex:0 0 auto}
.hademo__actions{display:flex;flex-wrap:wrap;gap:14px}

.hademo__device{display:flex;flex-direction:column;align-items:center;gap:16px}
.phone{position:relative;width:clamp(280px,80vw,330px);aspect-ratio:325/670;
  background:linear-gradient(160deg,#20252e,#0e1218);border-radius:46px;
  padding:14px;box-shadow:0 50px 90px -34px rgba(0,0,0,.95),0 0 0 1px rgba(255,255,255,.06),inset 0 0 0 2px rgba(255,255,255,.04)}
.phone__cam{position:absolute;top:20px;left:50%;transform:translateX(-50%);z-index:3;
  width:52px;height:7px;border-radius:6px;background:#05070a;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.phone__scr{position:relative;width:100%;height:100%;border-radius:34px;overflow:hidden;background:#0b0f14;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.6)}
.phone__frame{position:absolute;inset:0;width:100%;height:100%;border:0;background:#fff;opacity:0;transition:opacity .5s ease}
.phone__frame.ready{opacity:1}
.phone__load{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  color:var(--muted);font-family:var(--font-mono);font-size:12.5px;background:#0b0f14;transition:opacity .4s ease}
.phone__load.hide{opacity:0;pointer-events:none}
.phone__spin{width:30px;height:30px;border-radius:50%;border:3px solid rgba(255,255,255,.12);border-top-color:var(--green);animation:haspin .8s linear infinite}
@keyframes haspin{to{transform:rotate(360deg)}}
.hademo__hint{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:12.5px;color:var(--muted-2);letter-spacing:.02em}
.livedot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(4,206,120,.6);animation:livepulse 1.8s ease-out infinite}
@keyframes livepulse{0%{box-shadow:0 0 0 0 rgba(4,206,120,.55)}70%{box-shadow:0 0 0 10px rgba(4,206,120,0)}100%{box-shadow:0 0 0 0 rgba(4,206,120,0)}}

@media(max-width:900px){
  .hademo__grid{grid-template-columns:1fr;gap:36px;justify-items:center;text-align:center}
  .hademo__copy{max-width:60ch}
  .hademo__feats li{text-align:left}
  .hademo__actions{justify-content:center}
}
@media(prefers-reduced-motion:reduce){.phone__spin,.livedot{animation:none}}
