:root{--navy:#0B1F3A;--blue:#143A66;--blue2:#1E5594;--gold:#9FC3E6;--gold2:#3F8EC9;--white:#fff;--light:#F5F7FA;--gray:#617287;--text:#1A2332;--mx:50vw;--my:50vh;--ease:all .3s cubic-bezier(.4,0,.2,1)}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Inter',sans-serif;color:var(--text);background:var(--white);overflow-x:hidden;width:100%;max-width:100vw}
body::before{content:'';position:fixed;inset:0;z-index:9998;pointer-events:none;background:radial-gradient(420px circle at var(--mx) var(--my),rgba(159,195,230,.14),rgba(30,85,148,.08) 32%,transparent 68%);mix-blend-mode:screen;opacity:.85;transition:opacity .25s ease}
h1,h2,h3,h4,h5{font-family:'Montserrat',sans-serif}
.cursor-light{position:fixed;left:0;top:0;width:18px;height:18px;border-radius:50%;z-index:9999;pointer-events:none;background:rgba(159,195,230,.45);box-shadow:0 0 24px rgba(63,142,201,.7),0 0 70px rgba(30,85,148,.45);transform:translate3d(calc(var(--mx) - 9px),calc(var(--my) - 9px),0);opacity:0;transition:opacity .2s ease,transform .08s linear}
body.has-pointer .cursor-light{opacity:1}
.aos-disabled [data-aos]{opacity:1!important;transform:none!important;transition:none!important}
.slabel{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem;display:block}
.stitle{font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:800;line-height:1.15;color:var(--navy)}
.stitle span{color:var(--gold)}
.ssub{font-size:.93rem;color:var(--gray);line-height:1.75;max-width:580px;margin:0 auto}
.btn-p{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff;font-family:'Montserrat',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;padding:.85rem 1.85rem;border-radius:5px;border:none;cursor:pointer;text-decoration:none;transition:var(--ease);box-shadow:0 4px 20px rgba(63,142,201,.3)}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(63,142,201,.5)}
.btn-o{display:inline-flex;align-items:center;gap:.5rem;background:transparent;color:#fff;font-family:'Montserrat',sans-serif;font-weight:600;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;padding:.85rem 1.85rem;border-radius:5px;border:2px solid rgba(255,255,255,.4);cursor:pointer;text-decoration:none;transition:var(--ease)}
.btn-o:hover{border-color:#fff;background:rgba(255,255,255,.08)}
section{padding:5.5rem 0}
.container{max-width:1180px;margin:0 auto;padding:0 1.5rem}
.shdr{text-align:center;margin-bottom:3.5rem}

/* HEADER */
#hdr{position:fixed;top:0;left:0;right:0;z-index:1000;transition:var(--ease);padding:1.1rem 0}
#hdr.sc{background:rgba(11,31,58,.97);backdrop-filter:blur(14px);padding:.65rem 0;box-shadow:0 2px 30px rgba(0,0,0,.3)}
.hi{max-width:1180px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:.7rem;text-decoration:none}
.logo-ic{width:40px;height:40px;background:linear-gradient(135deg,var(--gold),var(--gold2));border-radius:6px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;transition:background .3s cubic-bezier(.4,0,.2,1),border-radius .3s cubic-bezier(.4,0,.2,1)}
.logo.has-real-logo .logo-ic{width:213px;height:59px;background:transparent;border-radius:0}
.logo-img{width:100%;height:100%;object-fit:contain;padding:5px;display:block}
.logo.has-real-logo .logo-img{padding:0}
.logo-img+svg{display:none}
.logo-img.is-hidden{display:none}
.logo-img.is-hidden+svg{display:block}
.logo.has-real-logo .logo-tx{display:none}
.logo-tx{font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.2rem;color:#fff;line-height:1}
.logo-tx small{display:block;font-size:.48rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:2px}
nav{display:flex;align-items:center;gap:1.75rem}
nav a{color:rgba(255,255,255,.75);text-decoration:none;font-family:'Montserrat',sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;transition:color .25s ease,transform .25s cubic-bezier(.2,.9,.2,1),text-shadow .25s ease;position:relative;display:inline-flex;align-items:center;transform-origin:center bottom}
nav a:not(.btn-p)::after{content:'';position:absolute;left:50%;bottom:-.45rem;width:0;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--gold2));box-shadow:0 0 14px rgba(63,142,201,.45);transform:translateX(-50%);transition:width .25s cubic-bezier(.2,.9,.2,1),opacity .25s ease;opacity:0}
nav a:hover{color:var(--gold);transform:translateY(-3px) scale(1.05);text-shadow:0 8px 22px rgba(159,195,230,.28)}
nav a:not(.btn-p):hover::after{width:72%;opacity:1}
.nav-cta{padding:.6rem 1.2rem;font-size:.72rem}
.hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;z-index:1001;background:transparent;border:0}
.hbg span{width:23px;height:2px;background:#fff;border-radius:2px;transition:var(--ease)}
body.menu-open{overflow:hidden;touch-action:none;position:fixed;width:100%}
body.menu-open .hbg span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .hbg span:nth-child(2){opacity:0;transform:scaleX(0)}
body.menu-open .hbg span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* HERO */
#hero{min-height:100vh;background:var(--navy) url('../img/hero/hero-bg.svg') center/cover no-repeat;position:relative;display:flex;align-items:center;overflow:hidden;isolation:isolate}
.hero-media{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:0;filter:saturate(1.08) contrast(1.05);background:url('../img/hero/hero-bg.svg') center/cover no-repeat;transition:opacity 1.1s ease}
.hero-media.is-ready{opacity:.9}
.hbg2{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at 76% 42%,rgba(20,58,102,.2) 0%,transparent 54%),linear-gradient(90deg,rgba(8,15,26,.78) 0%,rgba(8,15,26,.62) 36%,rgba(11,31,58,.33) 68%,rgba(11,31,58,.23) 100%),linear-gradient(135deg,rgba(8,15,26,.54) 0%,rgba(13,40,69,.43) 60%,rgba(11,31,58,.52) 100%)}
.hpat{position:absolute;inset:0;z-index:1;opacity:.04;background-image:linear-gradient(30deg,#fff 1px,transparent 1px),linear-gradient(150deg,#fff 1px,transparent 1px);background-size:55px 55px}
.hacc{position:absolute;right:0;top:0;z-index:1;width:55%;height:100%;overflow:hidden;pointer-events:none}
.hacc::before{content:'';position:absolute;top:-10%;right:-8%;width:88%;height:118%;border:1px solid rgba(159,195,230,.12);transform:skewX(-11deg)}
.hacc::after{content:'';position:absolute;top:8%;right:8%;width:68%;height:86%;border:1px solid rgba(159,195,230,.1);transform:skewX(-11deg)}
.hcnt{position:relative;z-index:5;max-width:1180px;margin:0 auto;padding:8rem 1.5rem 4rem;width:100%;transform:translateZ(0);-webkit-transform:translateZ(0)}
.hero-social{position:absolute;right:2rem;top:50%;z-index:6;transform:translateY(-50%);display:flex;flex-direction:column;gap:.85rem;padding:5.4rem 0}
.hero-social::before,.hero-social::after{content:'';position:absolute;left:50%;width:1px;height:72px;background:linear-gradient(to bottom,transparent,rgba(159,195,230,.72),rgba(255,255,255,.32),transparent);box-shadow:0 0 18px rgba(159,195,230,.36);transform:translateX(-50%);pointer-events:none}
.hero-social::before{top:0}
.hero-social::after{bottom:0}
.hero-social a{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(10px);transition:var(--ease);font-size:1.2rem}
.hero-social a:hover{background:var(--gold);border-color:var(--gold);transform:translateX(-4px);box-shadow:0 10px 28px rgba(63,142,201,.35)}
.htag{display:inline-flex;align-items:center;gap:.5rem;background:rgba(159,195,230,.12);border:1px solid rgba(159,195,230,.28);color:var(--gold2);font-family:'Montserrat',sans-serif;font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;padding:.4rem 1rem;border-radius:100px;margin-bottom:1.4rem}
.htitle{font-family:'Montserrat',sans-serif;font-size:clamp(2rem,5vw,3.4rem);font-weight:900;line-height:1.08;color:#fff;max-width:680px;margin-bottom:1.4rem}
.htitle .ac{color:var(--gold2)}
.hsub{font-size:clamp(.88rem,1.4vw,1.05rem);color:rgba(255,255,255,.6);line-height:1.8;max-width:540px;margin-bottom:2.3rem}
.cert-badge{display:inline-flex;align-items:center;gap:.75rem;margin:-.7rem 0 1.8rem;padding:.72rem .95rem;background:linear-gradient(135deg,rgba(255,255,255,.13),rgba(255,255,255,.05));border:1px solid rgba(159,195,230,.34);border-radius:12px;color:#fff;backdrop-filter:blur(14px);box-shadow:0 16px 42px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.18);position:relative;overflow:hidden}
.cert-badge::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.14),transparent);transform:translateX(-120%);animation:certshine 4.5s infinite}
.cert-ic{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(159,195,230,.18);border:1px solid rgba(159,195,230,.34);box-shadow:0 0 24px rgba(63,142,201,.18);position:relative;z-index:1}
.cert-ic i{color:var(--gold);font-size:1.05rem}
.cert-badge strong{display:block;font-family:'Montserrat',sans-serif;font-size:.78rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase;line-height:1.1;position:relative;z-index:1}
.cert-badge span{display:block;font-size:.72rem;color:rgba(255,255,255,.62);margin-top:.18rem;position:relative;z-index:1}
.hact{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:3.5rem}
.hstats{display:grid;grid-template-columns:repeat(4,auto);gap:2rem;width:fit-content;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08)}
.hstat .n{font-family:'Montserrat',sans-serif;font-size:1.7rem;font-weight:800;color:var(--gold2);line-height:1}
.hstat .l{font-size:.65rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.1em;margin-top:.2rem}

/* TRUST */
#trust{background:var(--blue);padding:1.25rem 0;border-bottom:1px solid rgba(255,255,255,.05)}
.ti{max-width:1180px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap}
.titem{display:flex;align-items:center;gap:.55rem;color:rgba(255,255,255,.7);font-size:.75rem;font-weight:500}
.titem i{color:var(--gold);font-size:.95rem}

/* SERVICES */
#services{background:#fff;position:relative;overflow:hidden}
#services::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(159,195,230,.16),rgba(255,255,255,0) 28%),radial-gradient(720px circle at 12% 6%,rgba(63,142,201,.1),transparent 56%);pointer-events:none}
#services .container{position:relative;z-index:1}
.sgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:1.25rem}
.scard,.bcard,.fbox,.gi{--card-x:50%;--card-y:50%;position:relative}
.scard::before,.bcard::before,.fbox::before,.gi::before{content:'';position:absolute;inset:0;background:radial-gradient(260px circle at var(--card-x) var(--card-y),rgba(159,195,230,.18),transparent 58%);opacity:0;transition:opacity .25s ease;pointer-events:none;z-index:4}
.scard:hover::before,.bcard:hover::before,.fbox:hover::before,.gi:hover::before{opacity:1}
.scard>*,
.bcard>*,
.fbox>*,
.gi>*{position:relative;z-index:2}
.scard{background:#fff;border-radius:12px;overflow:hidden;transition:var(--ease);border:1px solid rgba(11,31,58,.08);cursor:pointer;box-shadow:0 10px 35px rgba(11,31,58,.06)}
.scard:hover{transform:translateY(-6px);box-shadow:0 20px 55px rgba(11,31,58,.13);border-color:rgba(63,142,201,.2)}
.svis{height:170px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.service-photo{background:linear-gradient(135deg,#0B1F3A,#143A66)}
.service-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .65s ease,filter .65s ease;filter:saturate(1.06) contrast(1.04)}
.service-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,31,58,.12),rgba(11,31,58,.68)),linear-gradient(135deg,rgba(63,142,201,.16),transparent 58%);z-index:1;transition:opacity .35s ease}
.scard:hover .service-photo img{transform:scale(1.08);filter:saturate(1.16) contrast(1.08)}
.scard:hover .service-photo::after{opacity:.82}
.svis i{font-size:1.2rem;color:#fff;position:absolute;right:1rem;bottom:1rem;z-index:2;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(10px);box-shadow:0 10px 26px rgba(0,0,0,.2)}
.svis .glow{position:absolute;bottom:-34px;right:-28px;width:150px;height:150px;background:radial-gradient(circle,rgba(63,142,201,.34),transparent 68%);border-radius:50%;z-index:2}
.sbody{padding:1.35rem 1.5rem 1.5rem}
.sbody h3{font-size:.93rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.sbody p{font-size:.82rem;color:var(--gray);line-height:1.65}
.slink{display:inline-flex;align-items:center;gap:.3rem;color:var(--gold);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:.85rem;text-decoration:none;transition:var(--ease)}
.slink:hover{gap:.6rem}

/* ABOUT */
#about{background:#fff}
.agrid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:center}
.avis{position:relative}
.aimg{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--navy),var(--blue2));border-radius:16px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.aimg::before{content:'';position:absolute;inset:0;background-image:linear-gradient(45deg,rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(-45deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:28px 28px}
.aimg i{font-size:4.5rem;color:rgba(63,142,201,.35);position:relative;z-index:1}
.about-photo{align-items:stretch;justify-content:stretch;box-shadow:0 22px 65px rgba(11,31,58,.14)}
.about-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.08) contrast(1.06);transition:transform .75s ease}
.about-photo::before{z-index:1;background:linear-gradient(135deg,rgba(11,31,58,.18),rgba(11,31,58,.04) 46%,rgba(159,195,230,.16)),linear-gradient(180deg,rgba(11,31,58,.02),rgba(11,31,58,.32))}
.about-photo:hover img{transform:scale(1.06)}
.abadge{position:absolute;bottom:-1.25rem;right:-1.25rem;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#fff;padding:1.1rem 1.35rem;border-radius:12px;text-align:center;box-shadow:0 10px 35px rgba(63,142,201,.4);z-index:5}
.abadge .big{font-family:'Montserrat',sans-serif;font-size:1.9rem;font-weight:900;line-height:1}
.abadge .sm{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;opacity:.88}
.acnt{padding-left:.5rem}
.acnt>p{color:var(--gray);line-height:1.8;margin-top:1rem;font-size:.92rem}
.afeat{margin-top:1.75rem;display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.fitem{display:flex;align-items:flex-start;gap:.7rem}
.fico{width:34px;height:34px;background:rgba(159,195,230,.14);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fico i{color:var(--gold);font-size:.8rem}
.ftxt strong{display:block;font-size:.82rem;font-weight:700;color:var(--navy)}
.ftxt p{font-size:.72rem;color:var(--gray)}

/* PROCESS */
#process{background:var(--navy)}
#process .stitle{color:#fff}
.psteps{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;position:relative}
.psteps::before{display:none}
.step{text-align:center;padding:1.25rem .75rem}
.snum{width:60px;height:60px;background:rgba(159,195,230,.08);border:1px solid rgba(63,142,201,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.1rem;font-family:'Montserrat',sans-serif;font-size:1.1rem;font-weight:800;color:var(--gold2);position:relative;z-index:1;transition:var(--ease)}
.step:hover .snum{background:var(--gold);border-color:var(--gold);color:#fff;transform:scale(1.08)}
.step h3{font-size:.8rem;font-weight:700;color:#fff;margin-bottom:.4rem}
.step p{font-size:.72rem;color:rgba(255,255,255,.4);line-height:1.55}

/* BENEFITS */
#benefits{background:linear-gradient(135deg,#07111F 0%,#0B1F3A 54%,#12345B 100%);position:relative;overflow:hidden}
#benefits::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:34px 34px;mask-image:linear-gradient(180deg,rgba(0,0,0,.88),transparent);-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.88),transparent)}
#benefits::after{content:'';position:absolute;right:-180px;top:-180px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(63,142,201,.26),transparent 66%);pointer-events:none}
#benefits .container{position:relative;z-index:1}
#benefits .stitle{color:#fff}
#benefits .slabel{color:var(--gold2)}
.bgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.bcard{background:linear-gradient(145deg,rgba(255,255,255,.1),rgba(255,255,255,.045));padding:1.75rem;border-radius:12px;border:1px solid rgba(255,255,255,.12);border-top:3px solid rgba(159,195,230,.58);transition:var(--ease);box-shadow:inset 0 1px 0 rgba(255,255,255,.08);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.bcard:hover{transform:translateY(-5px);border-top-color:var(--gold2);box-shadow:0 18px 45px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.12)}
.bico{width:48px;height:48px;border-radius:12px;background:rgba(159,195,230,.13);border:1px solid rgba(159,195,230,.22);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--gold2);margin-bottom:1rem}
.bcard h3{font-size:.93rem;font-weight:700;color:#fff;margin-bottom:.45rem}
.bcard p{font-size:.8rem;color:rgba(255,255,255,.62);line-height:1.65}
.benefit-cta{margin-top:2.5rem;padding:2rem;border-radius:16px;background:linear-gradient(135deg,rgba(63,142,201,.22),rgba(255,255,255,.055));border:1px solid rgba(255,255,255,.14);display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 22px 55px rgba(0,0,0,.18)}
.benefit-cta .slabel{text-align:left;display:block;margin-bottom:.65rem}
.benefit-cta .stitle{text-align:left;font-size:2rem;line-height:1.15;margin:0}
.benefit-cta p{max-width:640px;color:rgba(255,255,255,.64);font-size:.95rem;line-height:1.75;margin-top:.85rem}
.benefit-cta .btn-p{white-space:nowrap;font-size:.84rem;padding:1rem 1.6rem;background:linear-gradient(135deg,var(--gold),#62AFE4);box-shadow:0 14px 32px rgba(63,142,201,.28)}

/* GALLERY */
#gallery{background:#fff}
.gfilt{display:flex;gap:.4rem;justify-content:center;margin-bottom:2.25rem;flex-wrap:wrap}
.fb{padding:.45rem 1.1rem;border-radius:100px;border:1px solid rgba(0,0,0,.1);background:transparent;font-family:'Montserrat',sans-serif;font-size:.7rem;font-weight:600;cursor:pointer;transition:var(--ease);color:var(--gray)}
.fb.active,.fb:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.ggrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.15rem;align-items:start}
.gi{border-radius:12px;overflow:hidden;position:relative;cursor:pointer;background:#fff;border:1px solid rgba(11,31,58,.08);box-shadow:0 8px 32px rgba(11,31,58,.07);transition:var(--ease)}
.gi:hover{transform:translateY(-6px);box-shadow:0 18px 52px rgba(11,31,58,.13)}
.gthumb{width:100%;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;transition:transform .5s ease;background:linear-gradient(135deg,#0B1F3A,#1E5594)}
.project-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .25s ease,transform .5s ease}
.gi.has-image .project-img{opacity:1}
.gi:hover .project-img{transform:scale(1.04)}
.gthumb::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.08),transparent 42%,rgba(63,142,201,.2));opacity:.7}
.gi:hover .gthumb{transform:scale(1.05)}
.gi.has-image i{opacity:0}
.gi i{font-size:2.25rem;color:rgba(255,255,255,.45);position:relative;z-index:1;transition:opacity .25s ease}
.gover{position:absolute;left:0;right:0;top:0;background:linear-gradient(to bottom,rgba(11,31,58,.72),transparent);opacity:1;transition:var(--ease);display:flex;align-items:flex-start;padding:1rem}
.gi:hover .gover{opacity:1}
.gi.is-hidden{display:none}
.gcat{display:inline-flex;align-items:center;gap:.35rem;background:rgba(63,142,201,.92);color:#fff;border-radius:100px;padding:.35rem .75rem;font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;box-shadow:0 8px 24px rgba(0,0,0,.18)}
.gbody{padding:1.05rem 1.1rem 1.2rem;background:#fff}
.gbody h3{font-size:.88rem;font-weight:800;color:var(--navy);line-height:1.25;margin-bottom:.45rem}
.gbody p{color:var(--gray);font-size:.78rem;line-height:1.62}

/* PROJECT MODAL */
.project-modal{position:fixed;inset:0;z-index:2500;display:grid;place-items:center;padding:1.25rem;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s ease,visibility .28s ease;overscroll-behavior:contain;touch-action:none}
.project-modal.is-open{opacity:1;visibility:visible;pointer-events:auto}
.pm-backdrop{position:absolute;inset:0;background:rgba(7,17,31,.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.pm-card{position:relative;z-index:1;width:min(92vw,430px);max-height:88vh;overflow:hidden;background:#fff;border-radius:18px;box-shadow:0 28px 90px rgba(0,0,0,.34);transform:translateY(18px) scale(.98);opacity:0;transition:transform .32s cubic-bezier(.2,.9,.2,1),opacity .25s ease;touch-action:pan-y;overscroll-behavior:contain;display:flex;flex-direction:column}
.project-modal.is-open .pm-card{transform:translateY(0) scale(1);opacity:1}
.pm-close{position:absolute;top:.8rem;right:.8rem;z-index:3;width:38px;height:38px;border:0;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.86);color:var(--navy);cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.18);transition:var(--ease)}
.pm-close:hover{transform:scale(1.06);background:#fff}
.pm-media{position:relative;background:var(--navy);aspect-ratio:3/4;overflow:hidden;flex:0 0 auto;max-height:62vh}
.pm-media img{width:100%;height:100%;display:block;object-fit:cover}
.pm-media::after{content:'';position:absolute;inset:auto 0 0;height:34%;background:linear-gradient(to top,rgba(11,31,58,.42),transparent);pointer-events:none}
.pm-content{padding:1.35rem 1.45rem 1.5rem;overflow:auto;overscroll-behavior:contain;scrollbar-width:none}
.pm-content::-webkit-scrollbar{width:0;height:0}
.pm-category{display:inline-flex;align-items:center;background:rgba(159,195,230,.18);color:var(--blue2);border-radius:999px;padding:.36rem .72rem;font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:900;letter-spacing:.09em;text-transform:uppercase;margin-bottom:.8rem}
.pm-content h3{font-size:1.15rem;font-weight:900;color:var(--navy);margin-bottom:.5rem;line-height:1.25}
.pm-content p{font-size:.9rem;color:var(--gray);line-height:1.72;margin-bottom:1.15rem}
.pm-whatsapp{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;background:#25D366;color:#fff;text-decoration:none;border-radius:10px;padding:.9rem 1rem;font-family:'Montserrat',sans-serif;font-size:.78rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 10px 30px rgba(37,211,102,.28);transition:var(--ease)}
.pm-whatsapp:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(37,211,102,.4)}
body.modal-open{overflow:hidden}

/* CLIENTS */
#testimonials{background:var(--light)}
.client-marquee{position:relative;overflow:hidden;margin-top:-.5rem;padding:.4rem 0 1rem;mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.client-track{display:flex;width:max-content;gap:1rem;animation:clientScroll 34s linear infinite;will-change:transform}
.client-marquee:hover .client-track{animation-play-state:paused}
.client-logo{width:190px;height:106px;background:#fff;border:1px solid rgba(11,31,58,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;padding:1.25rem;position:relative;overflow:hidden;box-shadow:0 8px 28px rgba(11,31,58,.05);transition:var(--ease);flex:0 0 190px}
.client-logo::before{content:'';position:absolute;inset:0;background:radial-gradient(180px circle at var(--card-x,50%) var(--card-y,50%),rgba(159,195,230,.2),transparent 62%);opacity:0;transition:opacity .25s ease}
.client-logo:hover{transform:translateY(-4px);border-color:rgba(63,142,201,.28);box-shadow:0 16px 42px rgba(11,31,58,.1)}
.client-logo:hover::before{opacity:1}
.client-logo img{max-width:100%;max-height:58px;object-fit:contain;position:relative;z-index:1;filter:grayscale(1);opacity:.72;transition:var(--ease)}
.client-logo:hover img{filter:grayscale(0);opacity:1}
.client-logo-wide img{max-height:74px;transform:scale(1.18)}
.client-logo-wide:hover img{transform:scale(1.22)}
.client-logo-dark img{filter:grayscale(1) invert(1) brightness(.32) contrast(1.6);opacity:.86}
.client-logo-dark:hover img{filter:grayscale(1) invert(1) brightness(.18) contrast(1.8);opacity:1}
.client-logo span{display:none;position:relative;z-index:1;font-family:'Montserrat',sans-serif;font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--blue2)}
.client-logo.missing img{display:none}
.client-logo.missing span{display:block}
@keyframes clientScroll{from{transform:translateX(0)}to{transform:translateX(calc(-50% - .5rem))}}
/* CONTACT */
#contact{background:#fff}
.cgrid{display:grid;grid-template-columns:minmax(320px,430px) minmax(360px,480px);gap:4rem;align-items:center;justify-content:center;max-width:1020px;margin:0 auto}
.cinfo h3{font-size:1.4rem;font-weight:700;color:var(--navy);margin-bottom:.75rem}
.cinfo>p{color:var(--gray);line-height:1.7;margin-bottom:1.75rem;font-size:.88rem}
.cdet{display:flex;align-items:center;gap:.9rem;margin-bottom:.6rem;padding:.65rem .9rem;border-radius:8px;transition:var(--ease);text-decoration:none}
.cdet:hover{background:var(--light)}
.cico{width:38px;height:38px;background:rgba(159,195,230,.14);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cico i{color:var(--gold);font-size:.85rem}
.clbl{font-size:.64rem;color:var(--gray);text-transform:uppercase;letter-spacing:.1em}
.cval{font-size:.83rem;color:var(--text);font-weight:500}
.fbox{background:var(--light);padding:2.25rem;border-radius:16px;align-self:center}
.fg{margin-bottom:.85rem}
.fg label{display:block;font-size:.68rem;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}
.fg input,.fg select,.fg textarea{width:100%;padding:.72rem 1rem;border:1.5px solid rgba(0,0,0,.09);border-radius:8px;font-family:'Inter',sans-serif;font-size:.83rem;color:var(--text);background:#fff;transition:var(--ease);outline:none}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(159,195,230,.14)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.submit-btn{width:100%;justify-content:center}
.form-status{display:none;margin-top:.8rem;padding:.75rem .9rem;border-radius:8px;font-size:.78rem;line-height:1.55}
.form-status.show{display:block}
.form-status.ok{background:rgba(37,211,102,.12);color:#16733B}
.form-status.error{background:rgba(159,195,230,.18);color:var(--navy)}

/* FOOTER */
footer{background:#07111F;color:rgba(255,255,255,.55);padding:4rem 0 1.5rem}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.75rem;margin-bottom:2.75rem}
.fdesc{font-size:.78rem;line-height:1.75;margin-top:.9rem;max-width:255px}
.fsoc{display:flex;gap:.65rem;margin-top:1.35rem}
.soc{width:34px;height:34px;background:rgba(255,255,255,.06);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.55);text-decoration:none;transition:var(--ease);font-size:.8rem}
.soc:hover{background:var(--gold);color:#fff}
.fc .ftitle{font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:#fff;margin-bottom:1.1rem}
.fc ul{list-style:none}
.fc ul li{margin-bottom:.55rem}
.fc ul li a{color:rgba(255,255,255,.45);text-decoration:none;font-size:.78rem;transition:var(--ease)}
.fc ul li a:hover{color:var(--gold)}
.fbot{border-top:1px solid rgba(255,255,255,.06);padding-top:1.35rem;display:flex;align-items:center;justify-content:space-between;font-size:.7rem;flex-wrap:wrap;gap:.5rem}

/* FLOATING ACTIONS */
.float-action{position:fixed;right:1.75rem;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:999;text-decoration:none;transition:transform .28s cubic-bezier(.2,.9,.2,1),box-shadow .28s ease}
.float-action::before{content:attr(data-label);position:absolute;right:calc(100% + .8rem);top:50%;transform:translate(8px,-50%) scale(.98);transform-origin:right center;background:linear-gradient(135deg,rgba(255,255,255,.5),rgba(255,255,255,.26));color:rgba(11,31,58,.86);border:1px solid rgba(255,255,255,.46);border-radius:999px;padding:.48rem .75rem;font-family:'Montserrat',sans-serif;font-size:.62rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;box-shadow:inset 0 1px 0 rgba(255,255,255,.56),0 10px 26px rgba(11,31,58,.12);backdrop-filter:blur(14px) saturate(1.25);-webkit-backdrop-filter:blur(14px) saturate(1.25);opacity:0;pointer-events:none;transition:opacity .22s ease,transform .22s cubic-bezier(.2,.9,.2,1)}
.float-action::after{content:'';position:absolute;right:calc(100% + .55rem);top:50%;width:7px;height:7px;background:rgba(255,255,255,.38);border-top:1px solid rgba(255,255,255,.46);border-right:1px solid rgba(255,255,255,.46);box-shadow:0 6px 16px rgba(11,31,58,.1);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);transform:translate(5px,-50%) rotate(45deg);opacity:0;pointer-events:none;transition:opacity .22s ease,transform .22s cubic-bezier(.2,.9,.2,1)}
.float-action:hover,.float-action:focus-visible{transform:translateY(-3px) scale(1.08)}
.float-action:hover::before,.float-action:focus-visible::before{opacity:1;transform:translate(0,-50%) scale(1)}
.float-action:hover::after,.float-action:focus-visible::after{opacity:1;transform:translate(0,-50%) rotate(45deg)}
.float-action i{color:#fff;position:relative;z-index:1}
.payment-fab{position:fixed;right:1.75rem;bottom:6.35rem;width:56px;height:56px;z-index:1001}
.payment-fab::before{content:'';position:absolute;left:-112px;top:-96px;width:168px;height:214px;border-radius:999px;background:transparent;z-index:0}
.payment-fab .payfab{position:relative;right:auto;bottom:auto;z-index:2}
.payment-fab .payfab::before,.payment-fab .payfab::after{display:none}
.payfab{bottom:6.35rem;background:linear-gradient(135deg,#2ECC71 0%,#18A85C 48%,#6C38FF 100%);box-shadow:0 4px 20px rgba(24,168,92,.38),0 4px 18px rgba(108,56,255,.22);animation:pulseFloat 2.8s infinite}
.payfab:hover,.payfab:focus-visible{box-shadow:0 8px 30px rgba(24,168,92,.5),0 8px 28px rgba(108,56,255,.32)}
.payfab i{font-size:1.28rem}
.pay-option{position:absolute;left:7px;top:7px;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;color:#fff;background:linear-gradient(135deg,rgba(255,255,255,.52),rgba(255,255,255,.22));border:1px solid rgba(255,255,255,.5);box-shadow:inset 0 1px 0 rgba(255,255,255,.58),0 12px 28px rgba(11,31,58,.18);backdrop-filter:blur(14px) saturate(1.35);-webkit-backdrop-filter:blur(14px) saturate(1.35);opacity:0;pointer-events:none;transform:translate(0,0) scale(.55) rotate(-18deg);transition:opacity .22s ease,transform .34s cubic-bezier(.18,.9,.22,1.18),box-shadow .22s ease;z-index:1}
.pay-option i{font-size:.95rem;color:var(--navy);position:relative;z-index:1}
.pay-option::before{content:attr(data-label);position:absolute;right:calc(100% + .65rem);top:50%;transform:translate(7px,-50%) scale(.96);transform-origin:right center;background:linear-gradient(135deg,rgba(255,255,255,.58),rgba(255,255,255,.28));color:rgba(11,31,58,.86);border:1px solid rgba(255,255,255,.5);border-radius:999px;padding:.4rem .62rem;font-family:'Montserrat',sans-serif;font-size:.58rem;font-weight:800;letter-spacing:.035em;text-transform:uppercase;white-space:nowrap;box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 10px 22px rgba(11,31,58,.12);backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease}
.pay-option:hover,.pay-option:focus-visible{box-shadow:inset 0 1px 0 rgba(255,255,255,.7),0 16px 34px rgba(24,168,92,.2),0 10px 28px rgba(108,56,255,.18);transform:var(--open-transform) scale(1.08)}
.pay-option:hover::before,.pay-option:focus-visible::before{opacity:1;transform:translate(0,-50%) scale(1)}
.payment-fab.is-open .pay-option,.payment-fab:hover .pay-option,.payment-fab:focus-within .pay-option{opacity:1;pointer-events:auto;transform:var(--open-transform)}
.pay-pse{--open-transform:translate(-64px,-56px)}
.pay-transfer{--open-transform:translate(-82px,0)}
.pay-credit{--open-transform:translate(-64px,56px)}
.pay-card{--open-transform:translate(0,-78px)}
.wabtn{bottom:1.75rem;background:#25D366;box-shadow:0 4px 20px rgba(37,211,102,.4);animation:pulseFloat 2.6s infinite;z-index:1002}
.wabtn:hover,.wabtn:focus-visible{box-shadow:0 8px 30px rgba(37,211,102,.6)}
.wabtn i{font-size:1.45rem}
.wabtn .online-dot{position:absolute;top:2px;right:2px;width:14px;height:14px;background:#36F46B;border:2px solid #fff;border-radius:50%;z-index:2}
.wabtn .online-dot::after{content:'';position:absolute;inset:-2px;border-radius:50%;background:rgba(54,244,107,.4);z-index:-1;animation:onlinePulse 1.8s infinite}
@keyframes pulseFloat{0%,100%{transform:scale(1)}50%{transform:scale(1.055)}}
@keyframes onlinePulse{0%{opacity:.8;transform:scale(1)}70%,100%{opacity:0;transform:scale(2.2)}}
@keyframes certshine{0%,55%{transform:translateX(-120%)}75%,100%{transform:translateX(120%)}}

/* RESPONSIVE */
@media(max-width:1024px){
  .logo.has-real-logo .logo-ic{width:190px;height:53px}
  .agrid{grid-template-columns:1fr;gap:3rem}
  .psteps{grid-template-columns:repeat(3,1fr)}
  .psteps::before{display:none}
  .fgrid{grid-template-columns:1fr 1fr;gap:2rem}
  .cgrid{grid-template-columns:1fr}
  .bgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .logo.has-real-logo .logo-ic{width:160px;height:45px}
  nav{display:none}
  nav.op{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;width:100vw;height:100dvh;min-height:100vh;background:rgba(8,15,26,.98);justify-content:center;align-items:center;gap:2rem;z-index:999;overflow:auto;overscroll-behavior:contain;padding:6rem 1.5rem 3rem}
  nav.op a{font-size:1.1rem}
  .hbg{display:flex}
  #hero{min-height:100svh;align-items:flex-start}
  .hero-media{position:absolute;object-position:center top}
  .hbg2{background:linear-gradient(180deg,rgba(8,15,26,.72),rgba(8,15,26,.6)),linear-gradient(90deg,rgba(8,15,26,.78),rgba(11,31,58,.38))}
  .hacc{display:none}
  #hero [data-aos]{opacity:1!important;transform:none!important}
  .hcnt{padding:7.2rem 1.5rem 4.5rem;max-width:100%;overflow:hidden}
  .htag{font-size:.58rem;letter-spacing:.14em;max-width:100%;line-height:1.45}
  .cert-badge{max-width:100%;align-items:flex-start}
  .cert-badge span{line-height:1.35}
  .hact .btn-p,.hact .btn-o{min-height:48px}
  .hstats{grid-template-columns:repeat(2,minmax(120px,1fr));gap:1.5rem;justify-content:center;margin:0 auto;text-align:center}
  .hstat{display:flex;flex-direction:column;align-items:center}
  .sgrid{grid-template-columns:1fr}
  .ggrid{grid-template-columns:1fr 1fr}
  .psteps{grid-template-columns:1fr 1fr}
  .bgrid{grid-template-columns:1fr}
  .benefit-cta{grid-template-columns:1fr;text-align:center}
  .benefit-cta .slabel,.benefit-cta .stitle{text-align:center}
  .benefit-cta .btn-p{justify-self:center}
  .client-track{animation-duration:28s;gap:.8rem}
  .client-logo{width:160px;height:92px;flex-basis:160px}
  .fgrid{grid-template-columns:1fr}
  .fr{grid-template-columns:1fr}
  .fbox{padding:1.6rem}
  .hero-social{left:auto;right:1rem;top:55%;transform:translateY(-50%);display:flex;gap:.55rem;padding:2rem 0}
  .hero-social::before,.hero-social::after{height:24px}
  .hero-social a{width:36px;height:36px;font-size:.9rem}
}
@media(max-width:480px){
  section{padding:4rem 0}
  .container{padding:0 1.1rem}
  .shdr{margin-bottom:2.4rem}
  .stitle{font-size:1.72rem}
  .ssub{font-size:.88rem;line-height:1.65}
  .btn-p,.btn-o{width:100%;justify-content:center;padding:.9rem 1rem;text-align:center}
  .logo.has-real-logo .logo-ic{width:138px;height:39px}
  .hi{padding:0 1rem}
  .hcnt{padding:6.1rem 4.85rem 3.1rem 1rem}
  .htag{display:flex;width:100%;justify-content:center;text-align:center;padding:.44rem .62rem;letter-spacing:.1em;font-size:.52rem}
  .htitle{font-size:clamp(1.78rem,10.6vw,2.38rem);line-height:1.08;max-width:100%;overflow-wrap:break-word;text-wrap:balance}
  .hsub{margin-bottom:1.35rem;max-width:100%;font-size:.86rem;line-height:1.7}
  .cert-badge{padding:.62rem .72rem;gap:.58rem;margin:-.35rem 0 1.45rem}
  .cert-ic{width:36px;height:36px}
  .cert-badge strong{font-size:.7rem}
  .cert-badge span{font-size:.66rem}
  .hact{flex-direction:column;align-items:center;justify-content:center;margin:0 auto 2.2rem;max-width:320px}
  .hact .btn-p,.hact .btn-o{width:80%;min-height:42px;padding:.72rem .8rem;font-size:.68rem}
  .hstats{width:100%;max-width:300px;grid-template-columns:1fr 1fr;gap:1.25rem 1rem;margin-left:auto;margin-right:auto;justify-items:center;text-align:center}
  .hstat .n{font-size:1.45rem}
  .hstat .l{font-size:.58rem}
  .titem{width:100%;justify-content:center}
  .svis{height:155px}
  .sbody{padding:1.15rem}
  .agrid{gap:2.4rem}
  .abadge{right:.75rem;bottom:.75rem;padding:.8rem .95rem;border-radius:10px}
  .abadge .big{font-size:1.45rem}
  .abadge .sm{font-size:.5rem}
  .acnt{padding-left:0}
  .acnt .stitle{text-align:left!important}
  .ggrid{grid-template-columns:1fr}
  .gfilt{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:.25rem;margin-left:-.1rem;margin-right:-.1rem}
  .fb{flex:0 0 auto}
  .afeat{grid-template-columns:1fr}
  .psteps{grid-template-columns:1fr}
  .step{padding:1rem .75rem}
  .benefit-cta{padding:1.35rem;gap:1.35rem}
  .benefit-cta .stitle{font-size:1.55rem}
  .benefit-cta p{font-size:.88rem;line-height:1.7}
  .benefit-cta .btn-p{width:100%}
  .cgrid{gap:2.5rem}
  .cdet{padding:.65rem 0}
  .fbox{padding:1.2rem;border-radius:12px}
  .fg input,.fg select,.fg textarea{font-size:.9rem}
  .fdesc{max-width:none}
  .hero-social{left:auto;right:.7rem;top:49%;gap:.45rem;padding:1.8rem 0}
  .hero-social::before,.hero-social::after{height:20px}
  .hero-social a{width:34px;height:34px;font-size:.84rem}
  .project-modal{padding:.75rem}
  .pm-card{width:min(100%,390px);border-radius:14px;max-height:86vh}
  .pm-media{aspect-ratio:3/4}
  .pm-content{padding:1.1rem}
  .float-action{right:calc(.9rem + env(safe-area-inset-right));width:50px;height:50px}
  .payment-fab{right:calc(.9rem + env(safe-area-inset-right));bottom:calc(5.65rem + env(safe-area-inset-bottom));width:50px;height:50px}
  .payment-fab::before{display:none}
  .payment-fab .payfab{width:50px;height:50px}
  .payment-fab .pay-option{display:none}
  .wabtn{bottom:calc(1.15rem + env(safe-area-inset-bottom))}
  .float-action::before,.float-action::after{display:none}
}
@media(max-width:360px){
  .logo.has-real-logo .logo-ic{width:124px;height:35px}
  .hcnt{padding-left:.85rem;padding-right:4.35rem}
  .htag{font-size:.47rem;letter-spacing:.07em}
  .htitle{font-size:1.58rem}
  .hsub{font-size:.78rem}
  .hstats{grid-template-columns:1fr;max-width:220px}
  .hero-social{left:auto;right:.55rem}
  .hero-social a{width:31px;height:31px;font-size:.78rem}
  .cert-badge{display:flex}
  .client-logo{width:145px;height:84px;flex-basis:145px}
  .client-logo img{max-height:44px}
  .float-action{width:48px;height:48px;right:.75rem}
  .payment-fab{right:.75rem;bottom:5.45rem;width:48px;height:48px}
  .payment-fab .payfab{width:48px;height:48px}
  .wabtn{bottom:1.05rem}
}
@media(hover:none),(pointer:coarse){
  body::before,.cursor-light{display:none}
  .float-action:hover,.float-action:focus-visible{transform:none}
}
.payment-fab .payfab{right:auto;bottom:auto}
