:root{
  --teal:#1bbdb4;
  --teal-2:#0d8f8a;
  --teal-dark:#063f42;
  --yellow:#f6bd1f;
  --ink:#081214;
  --ink-2:#101c20;
  --muted:#647176;
  --line:#dde7e8;
  --surface:#ffffff;
  --soft:#f3f7f7;
  --radius:22px;
  --shadow:0 26px 70px rgba(4,22,26,.16);
  --shadow-soft:0 16px 40px rgba(4,22,26,.1);
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:linear-gradient(180deg,#f6fafa 0,#fff 34%,#f5f8f8 100%);line-height:1.5;overflow-x:hidden}
a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.container{width:min(var(--max),calc(100% - 42px));margin-inline:auto}.skip-link{position:absolute;left:-999px;top:0;background:#fff;padding:12px;z-index:99}.skip-link:focus{left:10px}
.site-header{position:fixed;inset:16px 0 auto 0;z-index:50;transition:.3s ease}.site-header.is-scrolled{inset:8px 0 auto 0}.nav-shell{width:min(1240px,calc(100% - 36px));height:76px;margin:auto;padding:0 14px 0 22px;display:flex;align-items:center;gap:28px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:rgba(6,18,20,.68);backdrop-filter:blur(18px);box-shadow:0 18px 50px rgba(0,0,0,.22)}.brand{display:flex;align-items:center;gap:12px;min-width:max-content}.brand-mark{display:flex;align-items:center;gap:4px;color:#fff;font-weight:950;letter-spacing:-.06em;font-size:42px;line-height:.8}.brand-mark b{display:inline-grid;place-items:center;width:40px;height:40px;border:7px solid currentColor;border-radius:50%;font-size:0}.brand-mark i{font-style:normal;font-size:41px;transform:skew(-11deg);font-weight:1000}.brand-text{color:#fff;font-size:18px;line-height:.78;font-weight:800;letter-spacing:.23em}.main-nav{display:flex;align-items:center;gap:28px;margin-left:auto}.main-nav a{color:#fff;font-size:14px;font-weight:800;opacity:.88;position:relative}.main-nav a:after{content:"";position:absolute;left:0;right:0;bottom:-10px;height:3px;background:var(--teal);border-radius:99px;transform:scaleX(0);transition:.25s}.main-nav a:hover:after,.main-nav a.is-active:after{transform:scaleX(1)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;min-height:48px;padding:0 24px;border-radius:12px;border:1px solid transparent;font-weight:900;font-size:15px;transition:.25s ease;cursor:pointer}.btn:hover{transform:translateY(-2px);filter:saturate(1.05)}.btn-yellow{background:linear-gradient(135deg,#ffd539,var(--yellow));color:#111;box-shadow:0 12px 24px rgba(246,189,31,.26)}.btn-primary{background:linear-gradient(135deg,var(--teal),#0da39d);color:#fff;box-shadow:0 14px 28px rgba(27,189,180,.26)}.btn-glass,.btn-outline-light{border-color:rgba(255,255,255,.45);color:#fff;background:rgba(255,255,255,.06)}.btn-wa{background:#172326;color:#fff;border-color:rgba(255,255,255,.18)}.nav-toggle{display:none;margin-left:auto;background:transparent;border:0;width:44px;height:44px}.nav-toggle span{display:block;height:2px;background:#fff;margin:7px 6px;border-radius:2px}
.hero{min-height:770px;position:relative;display:grid;align-items:center;isolation:isolate;overflow:hidden;background:#071416;padding-bottom:150px}.hero-bg{position:absolute;inset:0;background:linear-gradient(90deg,rgba(3,13,15,.94) 0%,rgba(4,25,28,.82) 34%,rgba(4,13,15,.24) 68%,rgba(4,13,15,.78) 100%),url('../img/antena.webp') center 42%/cover no-repeat;z-index:-3;transform:scale(1.02)}.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:70px 70px;mask-image:linear-gradient(90deg,#000,transparent 70%);z-index:-2}.hero:after{content:"";position:absolute;inset:auto -16vw -19vw auto;width:46vw;height:46vw;border-radius:50%;background:radial-gradient(circle,rgba(27,189,180,.48),transparent 64%);z-index:-1}.hero-diagonal{position:absolute;right:-80px;bottom:110px;width:360px;height:86px;transform:rotate(-45deg);z-index:-1}.hero-diagonal-a{background:var(--teal)}.hero-diagonal-b{right:-54px;bottom:36px;background:var(--yellow);width:310px;height:42px}.hero-inner{padding-top:100px;display:grid;grid-template-columns:1fr;gap:50px;align-items:end}.hero-copy{padding-top:90px;max-width:760px}.eyebrow,.section-kicker{margin:0 0 15px;color:var(--teal);font-weight:950;text-transform:uppercase;letter-spacing:.16em;font-size:12px}.eyebrow span{display:inline-block;width:30px;height:3px;border-radius:99px;background:var(--yellow);vertical-align:middle;margin-right:8px}.hero h1{margin:0;color:#fff;font-size:clamp(48px,7vw,94px);line-height:.9;letter-spacing:-.06em;max-width:760px}.hero h1 em{font-style:normal;color:var(--teal);display:block;text-shadow:0 14px 42px rgba(0,0,0,.32)}.hero-text{max-width:610px;margin:24px 0 0;color:rgba(255,255,255,.88);font-size:21px;font-weight:650}.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}.hero-panel{align-self:center;margin-top:160px;border:1px solid rgba(255,255,255,.18);border-radius:26px;background:rgba(9,24,27,.58);backdrop-filter:blur(20px);padding:28px;color:#fff;box-shadow:var(--shadow)}.panel-kicker{margin:0 0 12px;color:var(--yellow);font-size:12px;text-transform:uppercase;letter-spacing:.16em;font-weight:900}.hero-panel strong{display:block;font-size:20px;line-height:1.25}.panel-row{display:flex;align-items:center;gap:14px;border-top:1px solid rgba(255,255,255,.12);padding-top:16px;margin-top:16px}.panel-row span{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:rgba(27,189,180,.18);color:var(--teal);font-weight:950}.panel-row p{margin:0;color:rgba(255,255,255,.8);font-weight:750}
.trust-strip{position:relative;z-index:5;margin-top:-78px;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;border-radius:24px;background:#dce6e7;box-shadow:var(--shadow);overflow:hidden}.trust-card{background:rgba(255,255,255,.94);padding:28px;display:grid;grid-template-columns:54px 1fr;column-gap:16px;align-items:start}.trust-icon{grid-row:span 2;width:54px;height:54px;border:2px solid rgba(27,189,180,.35);border-radius:18px;display:grid;place-items:center;color:var(--teal);font-size:25px;font-weight:900;background:linear-gradient(180deg,#fff,#eefafa)}.trust-card h3{margin:3px 0 6px;font-size:18px}.trust-card p{margin:0;color:var(--muted);font-size:14px}.section{padding:96px 0}.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:center}.intro-copy h2,.section-head h2,.solution-copy h2,.cta h2{margin:0;color:var(--ink);font-size:clamp(36px,4.6vw,62px);letter-spacing:-.055em;line-height:.95}.intro-copy p:not(.section-kicker),.section-head p:not(.section-kicker),.solution-copy p,.cta p{color:var(--muted);font-size:18px}.intro-card{position:relative;border-radius:30px;overflow:hidden;box-shadow:var(--shadow);background:#fff;padding:14px}.intro-card img{border-radius:22px;width:100%;height:360px;object-fit:cover}.intro-badge{position:absolute;left:32px;right:32px;bottom:30px;padding:14px 18px;border-radius:18px;background:rgba(7,20,22,.78);color:#fff;backdrop-filter:blur(10px);font-weight:800}.section-head{max-width:740px;margin-bottom:34px}.section-head.center{text-align:center;margin-inline:auto}.services{background:#fff}.service-grid{display:grid;grid-template-columns:1.15fr 1fr 1fr;gap:18px}.service-card{min-height:270px;border-radius:24px;overflow:hidden;position:relative;background:#111;box-shadow:var(--shadow-soft);isolation:isolate}.service-card.big{grid-row:span 2;min-height:558px}.service-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.45s ease;z-index:-2}.service-card:hover img{transform:scale(1.07)}.service-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.06),rgba(0,0,0,.82));z-index:-1}.service-content{position:absolute;left:22px;right:22px;bottom:22px;color:#fff}.service-content span{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:14px;background:var(--teal);font-weight:950;margin-bottom:16px}.service-content h3{font-size:24px;line-height:1;margin:0 0 10px;letter-spacing:-.035em}.service-content p{margin:0;color:rgba(255,255,255,.82)}.solution{padding:105px 0;background:radial-gradient(circle at 70% 20%,rgba(27,189,180,.21),transparent 34%),linear-gradient(135deg,#071416,#101c20 62%,#062f34);color:#fff;position:relative;overflow:hidden}.solution:before{content:"";position:absolute;right:-100px;top:0;width:260px;height:800px;background:linear-gradient(180deg,var(--yellow),var(--teal));transform:skewX(-26deg);opacity:.95}.solution-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}.solution-copy h2{color:#fff}.solution-copy p{color:rgba(255,255,255,.78)}.solution-copy ul{margin:24px 0 30px;padding:0;list-style:none;display:grid;gap:12px}.solution-copy li{padding-left:30px;position:relative;color:rgba(255,255,255,.88);font-weight:700}.solution-copy li:before{content:"";position:absolute;left:0;top:.55em;width:14px;height:14px;border-radius:50%;background:var(--yellow);box-shadow:0 0 0 6px rgba(246,189,31,.12)}.solution-photo{border-radius:32px;overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.35);transform:rotate(-1.5deg)}.solution-photo img{height:520px;width:100%;object-fit:cover}.sector-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.sector-card{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-soft);transition:.3s}.sector-card:hover{transform:translateY(-6px)}.sector-card img{height:170px;width:100%;object-fit:cover}.sector-card div{padding:22px}.sector-card span{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:14px;background:rgba(27,189,180,.12);color:var(--teal);font-size:24px;margin-bottom:12px}.sector-card h3{font-size:20px;margin:0 0 8px}.sector-card p{margin:0;color:var(--muted);font-size:15px}.gallery{background:#fff}.gallery-head{display:flex;justify-content:space-between;gap:24px;align-items:end;margin-bottom:28px}.gallery-head h2{margin:0;font-size:clamp(36px,4.6vw,62px);letter-spacing:-.055em;line-height:.95}.text-link{color:var(--teal-2);font-weight:950}.masonry-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.masonry-gallery img{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;border-radius:18px;box-shadow:var(--shadow-soft);transition:transform .3s}.masonry-gallery img:hover{transform:scale(1.03)}.process{padding:92px 0;background:linear-gradient(180deg,#f5f9f9,#fff)}.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step}.process-grid article{position:relative;padding:30px 24px;border-radius:24px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-soft)}.process-grid article:not(:last-child):after{content:"→";position:absolute;right:-18px;top:50%;transform:translateY(-50%);font-size:26px;color:var(--teal);font-weight:900;z-index:2}.process-grid span{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;background:var(--teal);color:#fff;font-weight:950;margin-bottom:22px}.process-grid h3{margin:0 0 8px;font-size:22px}.process-grid p{margin:0;color:var(--muted)}.cta{padding:76px 0;background:linear-gradient(135deg,#0c9891,#12b8b0);position:relative;overflow:hidden;color:#fff}.cta:before{content:"OV";position:absolute;left:3vw;top:-40px;font-size:210px;line-height:1;font-weight:1000;color:rgba(255,255,255,.08);letter-spacing:-.08em}.cta:after{content:"";position:absolute;right:-40px;bottom:-40px;width:220px;height:70px;background:var(--yellow);transform:rotate(-45deg)}.cta-grid{position:relative;display:grid;grid-template-columns:1.05fr minmax(340px,440px);gap:48px;align-items:center}.cta h2{color:#fff}.cta p{color:rgba(255,255,255,.86);max-width:680px}.cta-actions{display:flex;gap:14px;flex-wrap:wrap}.site-footer{background:#071416;color:#fff;padding:68px 0 24px}.footer-grid{display:grid;grid-template-columns:1.5fr .9fr 1.1fr 1.4fr;gap:40px}.footer-grid h3{margin:0 0 16px}.footer-grid a,.footer-grid p{display:block;color:rgba(255,255,255,.7);margin:0 0 9px}.footer-main p{margin-top:18px}.wa-box{border:1px solid rgba(246,189,31,.45);border-radius:22px;padding:24px;background:rgba(255,255,255,.035)}.wa-box strong{display:block;font-size:21px}.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:46px;padding-top:20px;display:flex;justify-content:space-between;gap:24px}.footer-bottom p,.footer-bottom a{margin:0;color:rgba(255,255,255,.55);font-size:14px}.reveal{transition:opacity .65s ease,transform .65s ease}.js .reveal{opacity:0;transform:translateY(28px)}.reveal.is-visible{opacity:1;transform:none}
@media (max-width:980px){.nav-shell{height:auto;min-height:72px;flex-wrap:wrap;border-radius:28px}.nav-toggle{display:block}.main-nav{display:none;order:5;width:100%;padding:12px 0 18px;grid-template-columns:1fr;gap:0}.main-nav.is-open{display:grid}.main-nav a{padding:12px}.header-cta{display:none}.hero{min-height:760px}.hero-inner{grid-template-columns:1fr}.hero-bg{background-position:72% 40%}.hero-panel{display:none}.trust-strip{grid-template-columns:repeat(2,1fr)}.intro-grid,.solution-grid,.cta-grid{grid-template-columns:1fr}.service-grid,.sector-grid,.process-grid{grid-template-columns:repeat(2,1fr)}.service-card.big{grid-row:auto;min-height:320px}.masonry-gallery{grid-template-columns:repeat(3,1fr)}.footer-grid{grid-template-columns:1fr 1fr}.solution:before{opacity:.35}}
@media (max-width:640px){.container{width:min(100% - 28px,var(--max))}.brand-text{font-size:15px}.brand-mark{font-size:34px}.brand-mark b{width:33px;height:33px;border-width:6px}.brand-mark i{font-size:34px}.hero{min-height:720px;padding-bottom:96px}.hero-copy{padding-top:110px}.hero h1{font-size:48px}.hero-text{font-size:17px}.btn{width:100%}.trust-strip{grid-template-columns:1fr;margin-top:-44px}.trust-card{grid-template-columns:46px 1fr;padding:22px}.intro-card img,.solution-photo img{height:330px}.service-grid,.sector-grid,.process-grid{grid-template-columns:1fr}.service-card{min-height:300px}.masonry-gallery{grid-template-columns:repeat(2,1fr)}.gallery-head{display:block}.process-grid article:after{display:none}.footer-grid{grid-template-columns:1fr}.footer-bottom{display:block}.site-header{inset:10px 0 auto}.nav-shell{width:calc(100% - 20px);padding-left:16px}}

/* --- mejoras: anclas, logo svg, iconos, contacto, reduced-motion --- */
section[id],.cta,.hero{scroll-margin-top:104px}
.brand-mark{font-size:0!important}
.brand-mark svg{display:block;height:30px;width:auto}
.footer-brand .brand-mark svg{height:30px}
.trust-icon svg{width:26px;height:26px;stroke:var(--teal);fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.sector-card span svg{width:24px;height:24px;stroke:var(--teal);fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.cta-contact{list-style:none;margin:22px 0 0;padding:0;display:grid;gap:10px}
.cta-contact li{display:flex;align-items:center;gap:12px;color:#fff;font-weight:700;font-size:15px}
.cta-contact li a{color:#fff}
.cta-contact li a:hover{color:#06303a}
.cta-contact svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .js .reveal{opacity:1!important;transform:none!important;transition:none}
  .btn:hover,.sector-card:hover,.service-card:hover img,.masonry-gallery img:hover{transform:none}
}

/* ===== servicios: cards ordenadas ===== */
.svc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:28px 26px;box-shadow:var(--shadow-soft);transition:transform .25s,box-shadow .25s}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.svc-ic{display:inline-grid;place-items:center;width:52px;height:52px;border-radius:16px;background:rgba(27,189,180,.1);color:var(--teal);margin-bottom:16px}
.svc-ic svg{width:27px;height:27px;stroke:var(--teal);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.svc-card h3{font-size:21px;margin:0 0 14px;letter-spacing:-.02em}
.svc-card ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.svc-card li{position:relative;padding-left:22px;color:var(--muted);font-size:14.5px;line-height:1.35}
.svc-card li:before{content:"";position:absolute;left:2px;top:.5em;width:8px;height:8px;border-radius:50%;background:var(--teal)}
@media(max-width:980px){.svc-cards{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.svc-cards{grid-template-columns:1fr}}

/* ===== formulario contacto ===== */
.cta-form-wrap{background:#fff;border-radius:24px;padding:24px;box-shadow:var(--shadow)}
.cta-form{display:grid;gap:12px}
.ff-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cta-form label{display:grid;gap:6px;font-size:11.5px;font-weight:800;color:#0c3a3a;text-transform:uppercase;letter-spacing:.05em}
.cta-form input,.cta-form select,.cta-form textarea{font:inherit;font-weight:600;padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:#f6fafa;color:var(--ink);width:100%}
.cta-form textarea{resize:vertical;min-height:84px}
.cta-form input:focus,.cta-form select:focus,.cta-form textarea:focus{outline:2px solid var(--teal);border-color:transparent;background:#fff}
.cta-form .btn{width:100%;margin-top:2px}
.cta-form .btn-wa{background:#1f2d30;color:#fff;border-color:transparent}
.form-msg{margin:2px 0 0;padding:11px 13px;border-radius:12px;font-weight:700;font-size:14px}
.form-msg.ok{background:#e6f7f1;color:#0c6b50}
.form-msg.err{background:#fdecec;color:#9b2c2c}
@media(max-width:640px){.ff-row{grid-template-columns:1fr}}

/* ===== whatsapp flotante ===== */
.wa-fab{position:fixed;right:18px;bottom:18px;z-index:60;width:58px;height:58px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 14px 30px -8px rgba(0,0,0,.4);transition:transform .2s}
.wa-fab:hover{transform:scale(1.08)}
.wa-fab svg{width:30px;height:30px;fill:#fff}

/* --- formulario: honeypot + consentimiento --- */
.cta-form .hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}
.ff-consent{display:flex!important;align-items:flex-start;gap:9px;font-size:13px;color:var(--muted);font-weight:500;margin:2px 0 4px;cursor:pointer}
.ff-consent input{width:16px;height:16px;flex:none;margin-top:1px}
.ff-consent a{color:var(--teal-2);font-weight:700}
