:root{
  --navy:#061326;
  --navy2:#10244b;
  --blue:#2f7dff;
  --blue2:#82c7ff;
  --green:#20b86a;
  --green2:#78f0a0;
  --cyan:#43d8d2;
  --white:#fff;
  --font-display:'Sora','Manrope',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-body:'Manrope',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth}
body.page-group-home{min-height:100vh;overflow-x:hidden;background:#050e1e;color:#fff;font-family:var(--font-body);line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit}
ul{list-style:none;padding:0}
.group-container{width:min(1280px,calc(100% - 44px));margin:0 auto}
.group-navbar{position:sticky;top:0;z-index:50;background:linear-gradient(90deg,#091632,#16254c);box-shadow:0 14px 30px rgba(6,19,38,.18)}
.group-navbar__inner{min-height:82px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.group-brand{display:flex;align-items:center;gap:12px;min-width:0}
.group-brand__mark{width:54px;height:54px;border-radius:50%;overflow:hidden;border:2px solid rgba(255,255,255,.75);background:#fff;flex:0 0 auto}
.group-brand__mark img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.group-brand__text{display:grid;line-height:1.05}
.group-brand__text strong{font-family:var(--font-display);font-size:1.08rem;font-weight:800;color:#fff;letter-spacing:-.01em}
.group-brand__text strong span{background:linear-gradient(100deg,#85c8ff 0%,#76ec9c 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.group-brand__text small{color:rgba(255,255,255,.82);font-size:.74rem;margin-top:5px}
.group-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.group-nav a{color:rgba(255,255,255,.92);font-size:.83rem;padding:8px 10px;border-radius:999px;transition:background .18s ease,color .18s ease,transform .18s ease;white-space:nowrap}
.group-nav>a:not(.group-btn):hover,.group-nav>a.active:not(.group-btn){color:#fff;background:rgba(255,255,255,.09)}
.group-btn{display:inline-flex;align-items:center;justify-content:center;min-width:94px;font-weight:800;padding:10px 18px!important;color:#fff!important}
.group-btn--whatsapp{background:linear-gradient(135deg,var(--green),#43bf6c)}
.group-btn--ingresar{background:linear-gradient(135deg,#2e73ff,var(--blue2))}
.group-btn:hover{transform:translateY(-1px)}
.group-nav-toggle{display:none;border:0;background:rgba(255,255,255,.08);color:#fff;width:44px;height:44px;border-radius:14px;align-items:center;justify-content:center;cursor:pointer}
.group-main{background:#050e1e}

/* HERO PROFESIONAL */
.group-hero{position:relative;overflow:hidden;height:calc(100vh - 82px);min-height:560px;background:#0b1734;contain:layout paint}
.group-hero__image,.group-hero__overlay{position:absolute;inset:0}
.group-hero__image img{width:100%;height:100%;object-fit:cover;object-position:center;filter:saturate(1.07) contrast(1.03) brightness(.92);will-change:transform;backface-visibility:hidden}
.group-hero__overlay{background:linear-gradient(180deg,rgba(3,10,26,.38),rgba(6,18,42,.45) 38%,rgba(4,12,30,.84)),linear-gradient(115deg,rgba(3,12,33,.76),rgba(14,63,104,.28) 45%,rgba(7,52,37,.38) 100%);}
.group-hero__content{position:relative;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding-top:54px;padding-bottom:60px;max-width:1040px;isolation:isolate}
.group-hero__content::before{content:"";position:absolute;z-index:-1;width:min(920px,88vw);height:390px;border-radius:999px;background:radial-gradient(circle at 44% 45%,rgba(12,36,78,.45),rgba(8,24,48,.24) 52%,transparent 74%),radial-gradient(circle at 72% 48%,rgba(26,150,92,.22),transparent 42%);filter:blur(4px);pointer-events:none}
.group-hero__eyebrow{display:inline-flex;align-items:center;justify-content:center;margin-bottom:18px;padding:8px 20px;border-radius:999px;border:1px solid rgba(130,199,255,.28);background:linear-gradient(90deg,rgba(47,125,255,.18),rgba(32,184,106,.14));backdrop-filter:blur(12px);color:rgba(239,248,255,.92);font-size:clamp(.66rem,.86vw,.76rem);font-weight:800;letter-spacing:.13em;text-transform:uppercase;text-shadow:0 1px 8px rgba(0,0,0,.22);box-shadow:0 14px 35px rgba(0,0,0,.16)}
.group-hero__content h1{font-family:var(--font-display);font-size:clamp(3.8rem,8.1vw,7.65rem);line-height:.92;letter-spacing:-.035em;margin-bottom:16px;font-weight:800;text-transform:uppercase;filter:drop-shadow(0 16px 30px rgba(0,0,0,.36))}
.group-hero__content h1 span{display:inline-block;color:#eef8ff;background:linear-gradient(98deg,#f2fbff 0%,#94d2ff 28%,#4dd9d2 55%,#77ef96 82%,#e8fff0 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:none}
.group-hero__content h2{font-family:var(--font-body);font-size:clamp(1.25rem,2.35vw,2.2rem);line-height:1.16;margin-bottom:18px;font-weight:700;color:#edf7ff;letter-spacing:-.025em;text-shadow:0 2px 14px rgba(0,0,0,.38)}
.group-hero__content h2 span{display:inline-block;margin:0 .24em;color:#7cefa0;text-shadow:0 0 24px rgba(120,240,160,.28)}
.group-hero__service-line{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin:4px 0 20px}
.group-hero__pill{display:inline-flex;align-items:center;gap:8px;padding:8px 17px;border-radius:999px;font-size:clamp(.75rem,.96vw,.86rem);font-weight:800;letter-spacing:.005em;border:1px solid rgba(255,255,255,.2);box-shadow:0 14px 30px rgba(0,0,0,.2);backdrop-filter:blur(12px)}
.group-hero__pill--blue{background:linear-gradient(135deg,rgba(47,125,255,.34),rgba(130,199,255,.15));color:#e5f2ff}
.group-hero__pill--green{background:linear-gradient(135deg,rgba(32,184,106,.34),rgba(120,240,160,.15));color:#e7fff0}
.group-hero__dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.72);box-shadow:0 0 20px rgba(255,255,255,.45)}
.group-hero__lead{font-size:clamp(.98rem,1.25vw,1.16rem);color:rgba(239,248,255,.88);max-width:780px;text-shadow:0 1px 8px rgba(0,0,0,.3);line-height:1.72;font-weight:500}
.group-hero__lead strong{color:#fff;font-weight:900}

.choose-section{position:relative;background:#050e1e;content-visibility:auto;contain-intrinsic-size:900px}
.choose-label{text-align:center;padding:52px 20px 0}
.choose-label span{display:inline-block;font-size:.78rem;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.13);padding:7px 22px;border-radius:999px}
.choose-split{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;min-height:620px;margin-top:32px}
.choose-panel{position:relative;overflow:hidden;min-height:620px;isolation:isolate;background:#0c1a35}
.choose-panel__bg,.choose-panel__overlay{position:absolute;inset:0}
.choose-panel__bg img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .32s ease;will-change:transform;backface-visibility:hidden}
.choose-panel:hover .choose-panel__bg img{transform:scale(1.025)}
.choose-panel__overlay{background:linear-gradient(160deg,rgba(5,18,48,.76),rgba(14,40,100,.58) 50%,rgba(5,18,48,.9));opacity:.98}
.choose-panel__overlay--green{background:linear-gradient(160deg,rgba(5,38,22,.76),rgba(16,90,42,.58) 50%,rgba(5,38,22,.9))}
.choose-panel__stripe{position:absolute;bottom:0;left:0;right:0;height:5px}
.choose-panel__stripe--telecom{background:linear-gradient(90deg,var(--blue),var(--blue2))}
.choose-panel__stripe--ambiental{background:linear-gradient(90deg,var(--green),var(--green2))}
.choose-panel__content{position:relative;z-index:2;min-height:620px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:42px 40px;text-align:center;gap:20px}
.choose-panel__logo img{height:72px;width:72px;object-fit:cover;border-radius:50%;background:rgba(255,255,255,.14);padding:6px;box-shadow:0 22px 55px rgba(3,12,28,.24)}
.choose-panel__text{display:flex;flex-direction:column;align-items:center;gap:10px}
.choose-panel__eyebrow{font-size:.7rem;font-weight:800;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.58)}
.choose-panel__title{font-family:var(--font-display);font-size:clamp(1.7rem,2.8vw,2.65rem);font-weight:800;color:#fff;line-height:1;letter-spacing:-.025em;text-shadow:0 4px 20px rgba(0,0,0,.36)}
.choose-panel__desc{font-size:clamp(.88rem,1.1vw,1rem);color:rgba(255,255,255,.82);max-width:360px;line-height:1.5}
.choose-panel__tags{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}
.choose-panel__tags li{font-size:.75rem;font-weight:700;color:rgba(255,255,255,.92);background:rgba(255,255,255,.13);padding:5px 13px;border-radius:999px;border:1px solid rgba(255,255,255,.18);white-space:nowrap}
.choose-panel__cta{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:999px;background:linear-gradient(135deg,var(--blue),#5b9bff);color:#fff;font-weight:800;font-size:.92rem;box-shadow:0 12px 32px rgba(46,115,255,.28);transition:transform .2s ease,box-shadow .2s ease}
.choose-panel__cta--green{background:linear-gradient(135deg,var(--green),#43bf6c);box-shadow:0 12px 32px rgba(43,159,86,.28)}
.choose-panel:hover .choose-panel__cta{transform:translateY(-2px)}

/* Animaciones livianas: solo opacity + transform para evitar trabas */
.group-navbar,.group-hero__eyebrow,.group-hero__content h1,.group-hero__content h2,.group-hero__service-line,.group-hero__lead,.choose-label,.choose-panel{will-change:transform,opacity}
.group-motion-ready .group-navbar{opacity:0;transform:translate3d(0,-16px,0)}
.group-motion-start .group-navbar{animation:groupSlideDown .52s cubic-bezier(.2,.7,.2,1) forwards}
.group-motion-ready .group-hero__eyebrow,.group-motion-ready .group-hero__content h1,.group-motion-ready .group-hero__content h2,.group-motion-ready .group-hero__service-line,.group-motion-ready .group-hero__lead{opacity:0;transform:translate3d(0,22px,0)}
.group-motion-start .group-hero__eyebrow{animation:groupFadeUp .58s cubic-bezier(.2,.7,.2,1) .08s forwards}
.group-motion-start .group-hero__content h1{animation:groupFadeUp .72s cubic-bezier(.2,.7,.2,1) .17s forwards}
.group-motion-start .group-hero__content h2{animation:groupFadeUp .72s cubic-bezier(.2,.7,.2,1) .28s forwards}
.group-motion-start .group-hero__service-line{animation:groupFadeUp .7s cubic-bezier(.2,.7,.2,1) .39s forwards}
.group-motion-start .group-hero__lead{animation:groupFadeUp .72s cubic-bezier(.2,.7,.2,1) .5s forwards}
.group-motion-start .group-hero__image img{animation:groupHeroBreath 18s ease-out both}
.group-hero::after{content:"";position:absolute;inset:auto 8% 8% 8%;height:36%;z-index:1;pointer-events:none;background:radial-gradient(circle at 28% 50%,rgba(47,125,255,.24),transparent 38%),radial-gradient(circle at 70% 40%,rgba(120,240,160,.23),transparent 36%);filter:blur(26px);opacity:.72;transform:translate3d(0,0,0);animation:groupGlowDrift 9s ease-in-out infinite alternate}
.group-hero__overlay{z-index:2}.group-hero__content{z-index:3}
.group-motion-ready .choose-label,.group-motion-ready .choose-panel{opacity:0;transform:translate3d(0,28px,0)}
.group-motion-ready .choose-panel:nth-child(2){transform:translate3d(0,38px,0)}
.group-motion-ready .choose-label.is-visible,.group-motion-ready .choose-panel.is-visible{animation:groupFadeUp .68s cubic-bezier(.2,.7,.2,1) forwards}
.group-motion-ready .choose-panel:nth-child(2).is-visible{animation-delay:.12s}
.choose-panel{transition:transform .24s ease,filter .24s ease}
.choose-panel:hover{transform:translate3d(0,-4px,0);filter:saturate(1.06)}
.choose-panel__logo{transition:transform .24s ease}
.choose-panel:hover .choose-panel__logo{transform:translate3d(0,-3px,0) scale(1.03)}
.choose-panel__cta svg{transition:transform .2s ease}
.choose-panel:hover .choose-panel__cta svg{transform:translate3d(4px,0,0)}
.choose-panel::before{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.12) 42%,transparent 56%);opacity:0;transform:translate3d(-105%,0,0);transition:transform .7s ease,opacity .25s ease}
.choose-panel:hover::before{opacity:1;transform:translate3d(105%,0,0)}
@keyframes groupSlideDown{to{opacity:1;transform:translate3d(0,0,0)}}
@keyframes groupFadeUp{to{opacity:1;transform:translate3d(0,0,0)}}
@keyframes groupHeroBreath{0%{transform:scale(1.035)}100%{transform:scale(1)}}
@keyframes groupGlowDrift{0%{opacity:.5;transform:translate3d(-16px,4px,0) scale(.98)}100%{opacity:.88;transform:translate3d(16px,-8px,0) scale(1.03)}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
@media(max-width:980px){.group-navbar__inner{min-height:76px}.group-nav{position:fixed;left:18px;right:18px;top:82px;padding:16px;border-radius:20px;background:rgba(9,22,50,.98);border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 38px rgba(6,19,38,.34);display:none;flex-direction:column;align-items:stretch}.group-nav.is-open{display:flex}.group-nav a{text-align:center}.group-nav-toggle{display:inline-flex}.group-hero{height:calc(100vh - 76px)}}
@media(max-width:768px){.group-container{width:min(100% - 24px,1280px)}.group-brand__text small{display:none}.group-hero{min-height:560px}.group-hero__content{padding-top:70px;padding-bottom:44px}.group-hero__dot{display:none}.group-hero__service-line{gap:8px}.choose-label{padding-top:38px}.choose-split{grid-template-columns:1fr;min-height:0}.choose-panel,.choose-panel__content{min-height:430px}.choose-panel__content{padding:34px 24px}}
@media(max-width:420px){.group-brand__mark{width:48px;height:48px}.group-brand__text strong{font-size:1rem}.group-hero__content h1{font-size:clamp(3rem,17vw,4.3rem);letter-spacing:-.04em}.group-hero__lead{max-width:310px}.choose-panel,.choose-panel__content{min-height:390px}}


/* Ajuste v31: tipografía más fina y gama azul/verde profesional */
.group-hero__content{max-width:1120px}
.group-hero__content h1 span::selection,.group-hero__content h2::selection{background:rgba(67,216,210,.35);color:#fff}
@supports (text-wrap:balance){.group-hero__content h2,.group-hero__lead{text-wrap:balance}}
@media(max-width:768px){.group-hero__eyebrow{letter-spacing:.08em}.group-hero__content h2{max-width:92vw}.group-hero__service-line{max-width:94vw}.group-hero__pill{padding:7px 13px}}
