:root{--kb:#0D53FC;--kc:#77D1F3;--kd:#1D1D1B;--kw:#fff;--ok:#10B981;--wpp:#118c7e;--g0:#f8faff;--g1:#f1f5f9;--g2:#e2e8f0;--g4:#94a3b8;--g5:#64748b;--g6:#475569;--g7:#334155;--g8:#1e293b;--g9:#0f172a;--gb:linear-gradient(135deg,#0D53FC,#77D1F3);--ff:'DM Sans',sans-serif;--fp:'DM Sans',sans-serif;--r1:12px;--r2:20px;--r3:32px;--rf:9999px;--tf:.3s cubic-bezier(.4,0,.2,1);--tb:.5s cubic-bezier(.4,0,.2,1);--ts:.8s cubic-bezier(.16,1,.3,1)}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--ff);color:var(--g7);background:var(--kw);line-height:1.7;overflow-x:hidden}a{text-decoration:none;color:inherit;transition:color var(--tf)}img{max-width:100%;height:auto;display:block}ul{list-style:none}button{border:none;background:none;cursor:pointer;font-family:inherit}.ctn{max-width:1240px;margin:0 auto;padding:0 24px}
.sr{opacity:0;transform:translateY(40px);transition:opacity var(--ts),transform var(--ts)}.sr.v{opacity:1;transform:translateY(0)}.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}
/* ===== NAVBAR v2 — Dark Rounded Bar (design_system2) ===== */
.hdr{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;transition:padding .5s cubic-bezier(.4,0,.2,1);animation:hdrIn 1s cubic-bezier(.16,1,.3,1) both}
@keyframes hdrIn{from{opacity:0;transform:translateY(-40px)}to{opacity:1;transform:translateY(0)}}
.hdr.scrolled{padding:10px 0}
.hdr-bar{background:var(--g9);border-radius:60px;padding:12px 14px 12px 24px;display:flex;align-items:center;justify-content:space-between;border:1px solid rgba(255,255,255,.06);box-shadow:0 20px 60px rgba(0,0,0,.25);transition:all .5s;gap:12px}
.hdr.scrolled .hdr-bar{border-color:rgba(13,83,252,.12);box-shadow:0 12px 40px rgba(13,83,252,.12)}
.hdr-logo{display:flex;align-items:center;flex-shrink:0}.hdr-logo img{height:32px;transition:all .4s}.hdr-logo:hover img{filter:drop-shadow(0 0 12px rgba(13,83,252,.4));transform:scale(1.05)}
.nav{display:flex;align-items:center;gap:4px;list-style:none}
.nav-a{font-size:14px;font-weight:500;color:rgba(255,255,255,.5);padding:8px 16px;border-radius:40px;transition:all .3s;position:relative;white-space:nowrap}
.nav-a::after{content:'';position:absolute;bottom:2px;left:50%;width:0;height:2px;background:var(--kb);border-radius:2px;transition:all .3s;transform:translateX(-50%)}
.nav-a:hover{color:var(--kw)}
.nav-a:hover::after{width:60%}
.nav-a.act{color:var(--kw)}
.nav-a.act::after{width:100%;background:var(--gb)}
.hdr-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.hdr-icon{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:rgba(255,255,255,.5);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);transition:all .3s;position:relative;cursor:pointer}
.hdr-icon:hover{background:var(--kb);color:white;border-color:var(--kb);transform:scale(1.1);box-shadow:0 0 20px rgba(13,83,252,.4)}
.hdr-icon .badge{position:absolute;top:-3px;right:-3px;width:16px;height:16px;border-radius:50%;background:#EF4444;color:white;font-size:9px;font-weight:500;display:flex;align-items:center;justify-content:center;border:2px solid var(--g9);animation:badgePop .5s cubic-bezier(.4,0,.2,1)}
@keyframes badgePop{0%{transform:scale(0)}60%{transform:scale(1.3)}100%{transform:scale(1)}}
.hdr-cta{padding:10px 24px;border-radius:40px;font-size:13px;font-weight:500;color:white;background:var(--kb);display:inline-flex;align-items:center;gap:8px;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(13,83,252,.3)}
.hdr-cta::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);animation:shimCta 3s infinite}
@keyframes shimCta{0%{left:-100%}100%{left:100%}}
.hdr-cta:hover{background:var(--kc);color:var(--g9);transform:translateY(-2px);box-shadow:0 8px 30px rgba(119,209,243,.35)}
/* Hamburger */
.hamburger{display:none;width:36px;height:36px;position:relative;cursor:pointer;z-index:10;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);border-radius:10px;flex-direction:column;align-items:center;justify-content:center;transition:all .3s}
.hamburger:hover{background:var(--kb);border-color:var(--kb)}
.hamburger span{display:block;width:18px;height:2px;background:white;border-radius:2px;transition:all .4s cubic-bezier(.4,0,.2,1);position:absolute}
.hamburger span:nth-child(1){transform:translateY(-6px)}
.hamburger span:nth-child(3){transform:translateY(6px)}
.hamburger.open span:nth-child(1){transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:rotate(-45deg)}
/* Mobile fullscreen menu */
.mob-menu{position:fixed;inset:0;z-index:999;background:linear-gradient(135deg,#060E24 0%,#0D1B3E 40%,#0D53FC 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:0;pointer-events:none;transition:all .5s cubic-bezier(.4,0,.2,1);transform:scale(1.08)}
.mob-menu.open{opacity:1;pointer-events:auto;transform:scale(1)}
.mob-menu .mob-a{font-size:22px;color:rgba(255,255,255,.4);padding:14px 40px;border-radius:16px;transition:all .35s;position:relative}
.mob-menu .mob-a:hover,.mob-menu .mob-a.act{color:white;background:rgba(255,255,255,.08)}
.mob-menu .mob-a.act::before{content:'';position:absolute;left:12px;top:50%;transform:translateY(-50%);width:4px;height:20px;border-radius:4px;background:var(--gb)}
.mob-soc{display:flex;gap:14px;margin-top:32px}
.mob-soc a{width:44px;height:44px;border-radius:14px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.35);font-size:18px;transition:all .3s}
.mob-soc a:hover{background:var(--kb);color:white;transform:translateY(-3px)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:var(--r1);font-size:14px;font-weight:500;transition:all var(--tb);position:relative;overflow:hidden}.btn-p{background:var(--gb);color:white;box-shadow:0 4px 15px rgba(13,83,252,.25)}.btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(13,83,252,.35)}.btn-p::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s}.btn-p:hover::before{left:100%}.btn-o{border:2px solid var(--kb);color:var(--kb)}.btn-o:hover{background:var(--kb);color:white;transform:translateY(-2px)}.btn-w{background:var(--wpp);color:white;box-shadow:0 4px 15px rgba(17,140,126,.25)}.btn-w:hover{background:#0eb28e;transform:translateY(-2px)}.btn-lg{padding:16px 36px;font-size:16px;border-radius:var(--r2)}
/* ===== HERO v2 — design_system2 inspired ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background-color:#060E24;padding:150px 0 140px}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(13,83,252,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(13,83,252,.06) 1px,transparent 1px);background-size:60px 60px;animation:gridMove 30s linear infinite;mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%)}
@keyframes gridMove{to{transform:translate(60px,60px)}}
.hero-glow{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(13,83,252,.2) 0%,rgba(119,209,243,.05) 40%,transparent 70%);top:50%;left:55%;transform:translate(-50%,-50%);animation:glowPulse 6s infinite ease-in-out;pointer-events:none}
@keyframes glowPulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.6}50%{transform:translate(-50%,-50%) scale(1.15);opacity:1}}
.hero-graf{position:absolute;right:-60px;top:50%;transform:translateY(-50%);width:400px;height:700px;opacity:.04;pointer-events:none;background:url('../img/grafismo_edfcc614e90f.svg') center/contain no-repeat}
.hero-bp{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hero-bp i{position:absolute;border-radius:50%;opacity:0;animation:particleRise 8s infinite ease-in-out}
.hero-bp i:nth-child(1){width:6px;height:6px;background:rgba(13,83,252,.5);left:10%;animation-duration:7s}
.hero-bp i:nth-child(2){width:4px;height:4px;background:rgba(119,209,243,.6);left:25%;animation-delay:1.5s;animation-duration:9s}
.hero-bp i:nth-child(3){width:8px;height:8px;background:rgba(13,83,252,.3);left:40%;animation-delay:3s;animation-duration:6s}
.hero-bp i:nth-child(4){width:5px;height:5px;background:rgba(255,255,255,.15);left:55%;animation-delay:.5s;animation-duration:10s}
.hero-bp i:nth-child(5){width:7px;height:7px;background:rgba(119,209,243,.4);left:70%;animation-delay:2s;animation-duration:8s}
.hero-bp i:nth-child(6){width:3px;height:3px;background:rgba(13,83,252,.4);left:85%;animation-delay:4s;animation-duration:7s}
@keyframes particleRise{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(-10vh) scale(1);opacity:0}}
.hero .ctn{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.hero-c{color:white}
.hero-logo{animation:heroFadeUp .8s .2s cubic-bezier(.16,1,.3,1) forwards;opacity:0;margin-bottom:28px}
.hero-logo img{height:48px;filter:brightness(0) invert(1)}
.hero-tag{display:inline-flex;align-items:center;gap:10px;padding:8px 20px;background:rgba(13,83,252,.12);border:1px solid rgba(13,83,252,.25);backdrop-filter:blur(10px);border-radius:9999px;color:rgba(167,211,251,.9);font-size:14px;font-weight:500;margin-bottom:28px;animation:heroFadeUp .8s .35s cubic-bezier(.16,1,.3,1) forwards,tagFloat 3s infinite;opacity:0}
.hero-tag .pulse{width:8px;height:8px;border-radius:50%;background:var(--kc);animation:pulseDot 2s infinite}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 0 rgba(119,209,243,.4)}50%{box-shadow:0 0 0 6px rgba(119,209,243,0)}}
@keyframes tagFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.hero-t{font-family:var(--fp);font-size:clamp(2.6rem,5.5vw,4.2rem);font-weight:500;line-height:1.05;letter-spacing:-.02em;margin-bottom:24px;max-width:700px}
.hero-t .w{display:inline-block;overflow:hidden}.hero-t .w span{display:inline-block;animation:wordReveal .8s cubic-bezier(.16,1,.3,1) forwards;animation-delay:var(--d,0s);transform:translateY(100%)}
@keyframes wordReveal{to{transform:translateY(0)}}
.hero-t .gt{background:var(--gb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-d{font-size:18px;line-height:1.8;color:rgba(255,255,255,.78);max-width:520px;margin-bottom:40px;animation:heroFadeUp .8s .7s cubic-bezier(.16,1,.3,1) forwards;opacity:0;text-shadow:0 1px 2px rgba(0,0,0,.25)}
@keyframes heroFadeUp{to{opacity:1;transform:translateY(0)}}
.hero-acts{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:56px;animation:heroFadeUp .8s .85s cubic-bezier(.16,1,.3,1) forwards;opacity:0}
.hero-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;border-radius:9999px;font-size:15px;font-weight:500;border:2px solid transparent;cursor:pointer;position:relative;overflow:hidden;transition:all .3s}
.hero-btn--primary{background:var(--kb);color:white;box-shadow:0 4px 20px rgba(13,83,252,.35)}
.hero-btn--primary::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimBtn 3s infinite}
@keyframes shimBtn{0%{left:-100%}100%{left:100%}}
.hero-btn--primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(13,83,252,.45)}
.hero-btn--ghost{background:transparent;color:white;border-color:rgba(255,255,255,.2)}
.hero-btn--ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5);transform:translateY(-3px)}
.hero-btn i{transition:transform .3s}.hero-btn:hover i{transform:translateX(4px)}
.hero-stats{display:flex;gap:40px;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);animation:heroFadeUp .8s 1s cubic-bezier(.16,1,.3,1) forwards;opacity:0}
.h-st-n{font-size:36px;font-weight:500;color:white;line-height:1;display:flex;align-items:baseline}
.h-st-n .cs{color:var(--kc);font-size:22px;margin-left:2px}
.h-st-l{font-size:13px;color:rgba(255,255,255,.58);margin-top:6px}
/* Hero visual — floating product cards */
.hero-vis{position:relative;display:flex;justify-content:center;align-items:center;min-height:480px}
.hero-card{position:absolute;background:rgba(255,255,255,.04);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:16px;animation:cardFloat 6s infinite ease-in-out;box-shadow:0 20px 50px rgba(0,0,0,.3);transition:all .4s;cursor:pointer}
.hero-card:hover{transform:scale(1.06) translateY(-8px) !important;border-color:rgba(13,83,252,.4);box-shadow:0 0 40px rgba(13,83,252,.3)}
.hero-card--1{top:2%;right:5%;width:210px;animation-delay:0s}
.hero-card--2{top:44%;right:30%;width:195px;animation-delay:2s;background:rgba(255,255,255,.04);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08)}
.hero-card--3{bottom:2%;right:0;width:210px;animation-delay:4s;background:rgba(255,255,255,.04);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08)}
@keyframes cardFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
.hc-img{width:100%;height:110px;border-radius:10px;object-fit:cover;margin-bottom:10px;border:1px solid rgba(255,255,255,.08)}
.hc-icon{width:48px;height:48px;border-radius:12px;background:var(--gb);display:flex;align-items:center;justify-content:center;color:white;font-size:20px;margin-bottom:12px;box-shadow:0 0 20px rgba(13,83,252,.3)}
.hc-title{color:white;font-size:14px;font-weight:500;margin-bottom:4px}
.hc-desc{color:rgba(255,255,255,.58);font-size:12px}
/* Scroll indicator */
.scroll-ind{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.45);font-size:11px;letter-spacing:.12em;text-transform:uppercase;animation:scrollBounce 2s infinite;z-index:3}
.scroll-ind .sl{width:1px;height:40px;background:linear-gradient(to bottom,rgba(13,83,252,.5),transparent)}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@keyframes fC{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.fbar{position:relative;z-index:3;margin-top:-50px;padding-bottom:30px}
/* Floating particles for dark sections */
@keyframes floatParticle{0%,100%{transform:translateY(0) translateX(0);opacity:.3}25%{transform:translateY(-40px) translateX(20px);opacity:.6}50%{transform:translateY(-20px) translateX(-15px);opacity:.4}75%{transform:translateY(-60px) translateX(10px);opacity:.2}}
.sec-particles{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.sec-particles i{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--kc);animation:floatParticle 8s infinite ease-in-out;opacity:.3}.fbar-g{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.fcard{background:var(--kw);border-radius:var(--r2);padding:28px 24px;display:flex;align-items:flex-start;gap:16px;box-shadow:0 10px 40px rgba(13,83,252,.08);border:1px solid var(--g2);transition:all var(--tb)}.fcard:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(13,83,252,.15);border-color:var(--kb)}.fcard-ic{width:52px;height:52px;border-radius:14px;background:var(--gb);display:flex;align-items:center;justify-content:center;color:white;font-size:22px;flex-shrink:0}.fcard-t{font-family:var(--fp);font-size:16px;font-weight:500;color:var(--g8);margin-bottom:4px}.fcard-d{font-size:13px;color:var(--g5);line-height:1.6}
/* ===== SECTION BASE + DECORATIVE BACKGROUNDS ===== */
.sec{padding:100px 0;position:relative;overflow:hidden}.sec-alt{background:var(--g0)}.sec-alt .sec-d{color:var(--g6)}.sec-dk{background:var(--g9);color:white}
/* Decorative orbs */
.sec-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;opacity:.08;z-index:0}
.sec-orb--1{width:500px;height:500px;background:var(--kb);top:-200px;right:-150px}
.sec-orb--2{width:400px;height:400px;background:var(--kc);bottom:-150px;left:-100px}
.sec-orb--3{width:350px;height:350px;background:#a78bfa;top:50%;left:50%;transform:translate(-50%,-50%)}
/* Dot grid pattern overlay */
.sec-dots{position:absolute;inset:0;background-image:radial-gradient(rgba(13,83,252,.07) 1px,transparent 1px);background-size:24px 24px;pointer-events:none;z-index:0}
/* Mesh gradient sections */
.sec--mesh{background:linear-gradient(135deg,#f8faff 0%,#eef4ff 30%,#f0f7ff 60%,#f8faff 100%)}
.sec--mesh .sec-d{color:var(--g6)}
.sec--mesh-dark{background:linear-gradient(135deg,var(--g9) 0%,#0c1a3d 40%,#0a1628 70%,var(--g9) 100%);color:white}
.sec--mesh-dark .sec-t{color:white}
.sec--mesh-dark .sec-d{color:rgba(255,255,255,.76)}
.sec--mesh-dark .sec-lb{color:var(--kc)}
.sec--mesh-dark .blog-sec-all{margin-top:4px;margin-bottom:0}
.sec--mesh-dark .blog-sec-all__link{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:rgba(255,255,255,.9);text-decoration:none;transition:color .25s ease,gap .25s ease}
.sec--mesh-dark .blog-sec-all__link:hover{color:var(--kc);gap:12px}
.sec--mesh-dark .blog-sec-all__link i{font-size:12px;opacity:.85}
/* Wave divider */
.wave-div{position:relative;height:80px;margin-top:-1px;z-index:2}
.wave-div svg{position:absolute;bottom:0;width:100%;height:100%}
/* Gradient line accent */
.grad-line{height:3px;width:80px;border-radius:3px;background:var(--gb);margin-bottom:20px}
/* Animated gradient border for cards on dark bg */
.glow-border{position:relative}
.glow-border::before{content:'';position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(135deg,var(--kb),var(--kc),var(--kb));z-index:-1;opacity:0;transition:opacity .4s}
.glow-border:hover::before{opacity:1}
.sec-lb{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--kb);text-transform:uppercase;letter-spacing:2px;margin-bottom:12px}.sec-lb i{font-size:8px}.sec-t{font-family:var(--fp);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:500;color:var(--g9);line-height:1.2;margin-bottom:16px}.sec-dk .sec-t{color:white}.sec-d{font-size:16px;color:var(--g5);max-width:600px;line-height:1.8}.sec-hd{margin-bottom:60px;position:relative;z-index:1}.sec-hd-split{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}.sec-hd-split--center{width:100%;max-width:100%;justify-content:center;align-items:stretch;box-sizing:border-box}.sec-hd-split--center .btn{width:100%;max-width:100%;justify-content:center;box-sizing:border-box}.dvd{height:1px;background:linear-gradient(to right,transparent,var(--g2),transparent);margin:40px 0;position:relative;z-index:1}
.sec--mesh-dark .dvd{background:linear-gradient(to right,transparent,rgba(255,255,255,.08),transparent)}
.sec > .ctn{position:relative;z-index:1}
/* ===== ABOUT — split layout with overlapping stress-card (ref image "Our Service") ===== */
.ab-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.ab-imgs{position:relative}
.ab-main{border-radius:28px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.1)}.ab-main img{width:100%;height:450px;object-fit:cover;transition:transform var(--ts)}.ab-main:hover img{transform:scale(1.05)}
.ab-float{position:absolute;bottom:-20px;right:-20px;background:var(--kw);border-radius:20px;padding:20px 24px;box-shadow:0 16px 48px rgba(0,0,0,.12);border:1px solid var(--g2);max-width:260px;animation:fC 5s ease-in-out infinite}
.ab-float-ic{width:44px;height:44px;border-radius:12px;background:var(--gb);display:flex;align-items:center;justify-content:center;color:white;font-size:18px;margin-bottom:12px}
.ab-float-t{font-size:14px;font-weight:500;color:var(--g8);margin-bottom:4px}
.ab-float-d{font-size:12px;color:var(--g5);line-height:1.5}
.ab-chk{display:flex;flex-direction:column;gap:14px;margin-top:28px}
.ab-chk li{display:flex;align-items:center;gap:12px;font-size:15px;color:var(--g6);padding:10px 16px;border-radius:14px;border:1px solid var(--g2);background:var(--kw);transition:all .3s}
.ab-chk li:hover{border-color:var(--kb);background:rgba(13,83,252,.02);transform:translateX(6px)}
.ab-chk li i{color:var(--ok);font-size:14px;flex-shrink:0}
.ab-cta{margin-top:32px;width:100%;max-width:100%;box-sizing:border-box}.ab-cta .btn{width:100%;max-width:100%;justify-content:center;box-sizing:border-box}
/* ===== PRODUCT GRID ===== */
.ps-filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px}.ps-fb{padding:10px 24px;border-radius:50px;font-size:14px;font-weight:500;color:var(--g5);background:transparent;border:2px solid var(--g2);cursor:pointer;transition:all var(--tb);position:relative;overflow:hidden}.ps-fb::before{content:'';position:absolute;inset:0;background:var(--gb);opacity:0;transition:opacity var(--tb);border-radius:50px}.ps-fb:hover{border-color:var(--kb);color:var(--kb);transform:translateY(-2px)}.ps-fb.act{border-color:transparent;color:white;box-shadow:0 6px 20px rgba(13,83,252,.3);transform:translateY(-2px)}.ps-fb.act::before{opacity:1}.ps-fb span{position:relative;z-index:1}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pcard{background:var(--kw);border-radius:16px;border:1px solid var(--g2);overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.pcard:hover{box-shadow:0 12px 40px rgba(0,0,0,.08);border-color:var(--kc);transform:translateY(-4px)}
.pcard-img{position:relative;height:220px;background:#fff;display:flex;align-items:center;justify-content:center;padding:20px;overflow:hidden}
.pcard-img img{max-width:100%;max-height:100%;object-fit:contain;transition:transform .5s}
.pcard:hover .pcard-img img{transform:scale(1.06)}
.pcard-badge{position:absolute;top:12px;right:12px;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:500;z-index:2}
.badge-off{background:var(--wpp);color:white}.badge-new{background:var(--kb);color:white}
.pcard-body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column}
.pcard-name{font-size:14px;font-weight:500;color:var(--g8);line-height:1.4;margin-bottom:12px;min-height:40px}
.pcard:hover .pcard-name{color:var(--kb)}
.pcard-old{font-size:13px;color:var(--g4);text-decoration:line-through;margin-bottom:2px}
.pcard-row{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}
.pcard-price{font-size:20px;font-weight:500;color:var(--g8)}
.pcard-off{font-size:11px;font-weight:500;color:var(--wpp);background:rgba(17,140,126,.1);padding:2px 8px;border-radius:4px}
.pcard-inst{font-size:11px;color:var(--g5);margin-bottom:4px}
.pcard-pix{font-size:12px;color:var(--wpp);font-weight:500;margin-bottom:14px}
.pcard-cart{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.pcard-qty{display:flex;align-items:center;border:1px solid var(--g2);border-radius:8px;overflow:hidden}
.pcard-qty button{width:30px;height:34px;font-size:14px;color:var(--g6);background:var(--g1);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;border:none}
.pcard-qty button:hover{background:var(--g2)}
.pcard-qty input{width:36px;height:34px;text-align:center;border:none;font-size:13px;font-family:var(--ff);color:var(--g8);outline:none;background:var(--kw)}
.pcard-qty input::-webkit-outer-spin-button,.pcard-qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.pcard-atc{flex:1;height:34px;border-radius:8px;background:var(--g1);border:1px solid var(--g2);color:var(--g6);font-size:12px;font-weight:500;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:4px}
.pcard-atc:hover{background:var(--kb);color:white;border-color:var(--kb)}
.pcard-wpp{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:8px;background:var(--wpp);color:white;font-size:13px;font-weight:500;transition:all .3s;width:100%}
.pcard-wpp:hover{background:#0eb28e;transform:translateY(-1px);box-shadow:0 4px 12px rgba(17,140,126,.25)}
.pcard-wpp i{font-size:16px}
.ctrs{display:flex;gap:60px;flex-wrap:wrap}.ctr-n{font-family:var(--fp);font-size:48px;font-weight:500;line-height:1}.ctr-l{font-size:14px;color:var(--g5);margin-top:6px}
/* ===== CAPABILITIES — Editorial Layout (inspired ref) ===== */
/* Top: header row with label, title+desc, "view more" link */
.cap-header{display:grid;grid-template-columns:120px 1fr auto;gap:24px;align-items:start;margin-bottom:48px}
.cap-header-label{font-size:12px;font-weight:500;color:var(--kb);text-transform:uppercase;letter-spacing:2px;display:flex;align-items:center;gap:8px;padding-top:8px}
.cap-header-label i{font-size:7px}
.cap-header-content{min-width:0}
.cap-header-t{font-family:var(--fp);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:500;color:var(--g9);line-height:1.15;margin-bottom:16px}
.cap-header-t span{color:var(--kb)}
.cap-header-d{font-size:15px;color:var(--g6);line-height:1.8;max-width:580px}
.cap-header-link{padding-top:8px;font-size:14px;font-weight:500;color:var(--kb);white-space:nowrap;display:flex;align-items:center;gap:6px;transition:all .3s}
.cap-header-link:hover{gap:10px}
.cap-header-link i{font-size:11px;transition:transform .3s}
.cap-header-link:hover i{transform:translateX(3px)}
/* Big numbers row */
.cap-numbers{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-bottom:56px;padding-bottom:56px;border-bottom:1px solid var(--g2)}
.cap-num-item{position:relative;padding:24px 20px;border-radius:16px;background:var(--g0);border:1px solid var(--g2);transition:all .4s cubic-bezier(.4,0,.2,1)}
.cap-num-item:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(13,83,252,.08);border-color:var(--kb)}
.cap-num-icon{width:44px;height:44px;border-radius:12px;background:var(--gb);display:flex;align-items:center;justify-content:center;color:white;font-size:18px;margin-bottom:16px;box-shadow:0 4px 16px rgba(13,83,252,.2)}
.cap-num-n{font-family:var(--fp);font-size:clamp(2.4rem,4.5vw,3.6rem);font-weight:500;background:var(--gb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:8px}
.cap-num-n sup{font-size:.45em;font-weight:500;vertical-align:super}
.cap-num-l{font-size:13px;color:var(--g6);line-height:1.4}
.cap-num-item::after{display:none}
/* Wide image banner */
.cap-banner{position:relative;border-radius:24px;overflow:hidden;height:380px;margin-bottom:64px;box-shadow:0 20px 60px rgba(0,0,0,.1)}
.cap-banner img{position:relative;z-index:0;width:100%;height:100%;object-fit:cover;object-position:72% center;transition:transform .8s}
.cap-banner:hover img{transform:scale(1.06)}
.cap-banner-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(105deg,rgba(15,23,42,.93) 0%,rgba(15,23,42,.78) 40%,rgba(15,23,42,.52) 68%,rgba(15,23,42,.4) 100%);pointer-events:none}
.cap-banner-overlay::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(15,23,42,.55) 0%,transparent 42%);pointer-events:none}
.cap-banner-glow{position:absolute;top:-100px;left:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(13,83,252,.15) 0%,transparent 70%);pointer-events:none;animation:bannerGlow 8s infinite ease-in-out;z-index:1}
@keyframes bannerGlow{0%,100%{transform:translate(0,0) scale(1);opacity:.6}50%{transform:translate(60px,60px) scale(1.2);opacity:1}}
.cap-banner-text{position:absolute;bottom:40px;left:40px;right:32px;z-index:2;color:white;max-width:min(520px,92%)}
.cap-banner-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--rf);background:rgba(13,83,252,.22);border:1px solid rgba(119,209,243,.35);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#e0f2fe;font-size:12px;font-weight:600;margin-bottom:14px;line-height:1.2}
.cap-banner-badge i{font-size:14px;opacity:.95}
.cap-banner-text h3{font-family:var(--fp);font-size:28px;font-weight:500;margin-bottom:12px;line-height:1.2;text-shadow:0 2px 20px rgba(15,23,42,.85),0 1px 3px rgba(0,0,0,.35)}
.cap-banner-text p{font-size:14px;color:rgba(255,255,255,.88);line-height:1.65;margin-bottom:0;text-shadow:0 1px 14px rgba(15,23,42,.9),0 1px 2px rgba(0,0,0,.3)}
.cap-banner-stats{display:flex;gap:24px;flex-wrap:wrap}
.cap-banner-stat{font-size:12px;color:rgba(255,255,255,.5);padding:8px 0;border-left:2px solid var(--kb);padding-left:12px}
.cap-banner-stat strong{display:block;font-size:18px;font-weight:700;color:white;margin-bottom:2px}
/* Service subtitle row */
.cap-svc-header{display:grid;grid-template-columns:120px 1fr auto;gap:24px;align-items:start;margin-bottom:32px}
.cap-svc-t{font-family:var(--fp);font-size:clamp(1.4rem,2.5vw,2rem);font-weight:500;color:var(--g9);line-height:1.2}
.cap-svc-t span{color:var(--kb)}
/* 4-card service grid — alternating light/dark */
.cap-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cap-card{border-radius:20px;padding:32px 24px;display:flex;flex-direction:column;justify-content:space-between;min-height:300px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;border:1px solid transparent}
.cap-card--light{background:var(--g0);border-color:var(--g2)}
.cap-card--dark{background:var(--g9);color:white}
.cap-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.08)}
.cap-card--dark:hover{box-shadow:0 16px 48px rgba(13,83,252,.15)}
/* Card icon */
.cap-card-ic{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:auto}
.cap-card--light .cap-card-ic{background:rgba(13,83,252,.06);color:var(--kb)}
.cap-card--dark .cap-card-ic{background:rgba(255,255,255,.1);color:var(--kc)}
/* Card content at bottom */
.cap-card-body{margin-top:auto}
.cap-card-t{font-family:var(--fp);font-size:17px;font-weight:500;line-height:1.3;margin-bottom:12px}
.cap-card--light .cap-card-t{color:var(--g9)}
.cap-card--dark .cap-card-t{color:white}
.cap-card-list{display:flex;flex-direction:column;gap:6px}
.cap-card-list li{font-size:12px;line-height:1.5;display:flex;align-items:flex-start;gap:8px}
.cap-card--light .cap-card-list li{color:var(--g6)}
.cap-card--dark .cap-card-list li{color:rgba(255,255,255,.75)}
.cap-card-list li::before{content:'';width:4px;height:4px;border-radius:50%;flex-shrink:0;margin-top:6px}
.cap-card--light .cap-card-list li::before{background:var(--kb)}
.cap-card--dark .cap-card-list li::before{background:var(--kc)}
/* Hover glow for dark cards */
.cap-card--dark::before{content:'';position:absolute;top:-60px;right:-60px;width:140px;height:140px;background:var(--kb);border-radius:50%;filter:blur(60px);opacity:0;transition:opacity .4s;pointer-events:none}
.cap-card--dark:hover::before{opacity:.12}
/* ===== CTA — dark rounded inset banner (ref image "Why Wait / Book Today") ===== */
.cta-s{padding:40px 0}
.cta-banner{position:relative;border-radius:32px;overflow:hidden;padding:100px 60px;text-align:center;background:var(--g9)}
.cta-banner-bg{position:absolute;inset:0;z-index:0}
.cta-banner-bg img{width:100%;height:100%;object-fit:cover;opacity:.3}
.cta-banner-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--g9) 10%,rgba(15,23,42,.6) 100%)}
.cta-banner .cta-inner{position:relative;z-index:2;max-width:700px;margin:0 auto}
.cta-t{font-family:var(--fp);font-size:clamp(2.2rem,5vw,3.4rem);font-weight:500;line-height:1.1;color:#fff;margin-bottom:24px;text-shadow:0 2px 24px rgba(15,23,42,.55),0 1px 3px rgba(0,0,0,.35)}
.cta-d{font-size:17px;color:rgba(255,255,255,.74);line-height:1.8;margin-bottom:36px}
.cta-acts{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
/* ===== FAQ — accordion grid (ref image "Everything You Need to Know") ===== */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.faq-item{border:1px solid var(--g2);border-radius:16px;background:var(--kw);overflow:hidden;transition:all .3s}
.faq-item:hover{border-color:var(--kb)}
.faq-item.open{border-color:var(--kb);box-shadow:0 8px 30px rgba(13,83,252,.06)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;cursor:pointer;gap:16px;transition:background .3s}
.faq-q:hover{background:rgba(13,83,252,.02)}
.faq-q-text{font-size:15px;font-weight:500;color:var(--g8);flex:1}
.faq-q-icon{width:32px;height:32px;border-radius:50%;background:var(--g1);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--g6);flex-shrink:0;transition:all .3s}
.faq-item.open .faq-q-icon{background:var(--kb);color:white;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.faq-a-inner{padding:0 24px 20px;font-size:14px;color:var(--g6);line-height:1.8}
/* ===== BLOG — 3-column large rounded image cards (ref image style) ===== */
.bl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.bl-card{border-radius:24px;overflow:hidden;position:relative;height:340px;transition:all .5s;cursor:pointer}
.bl-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.bl-card:hover img{transform:scale(1.08)}
.bl-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(15,23,42,.82) 0%,rgba(15,23,42,.35) 42%,transparent 72%);transition:all .4s}
.bl-card:hover::after{background:linear-gradient(to top,rgba(13,83,252,.78) 0%,rgba(15,23,42,.25) 50%,transparent 72%)}
.bl-bd{position:absolute;bottom:0;left:0;right:0;padding:28px;z-index:2;color:white}
.bl-tt{font-family:var(--fp);font-size:17px;font-weight:500;color:#fff;line-height:1.4;margin-bottom:8px;text-shadow:0 2px 16px rgba(0,0,0,.5),0 1px 3px rgba(0,0,0,.4)}
.bl-mt{font-size:12px;color:rgba(255,255,255,.88);display:flex;align-items:center;gap:6px;text-shadow:0 1px 8px rgba(0,0,0,.45)}
.bl-arrow{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:white;font-size:14px;position:absolute;top:20px;right:20px;z-index:2;transition:all .3s}
.bl-card:hover .bl-arrow{background:white;color:var(--kb);border-color:white}
/* ===== FOOTER — reference-style: dark CTA card left + columns right ===== */
.ft-top{display:grid;grid-template-columns:1fr 1.8fr;gap:40px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.08)}
.ft-cta-card{background:var(--g8);border-radius:24px;padding:40px 32px;border:1px solid rgba(255,255,255,.08)}
.ft-cta-card h3{font-family:var(--fp);font-size:22px;font-weight:500;color:white;line-height:1.3;margin-bottom:12px}
.ft-cta-card p{font-size:14px;color:rgba(255,255,255,.45);line-height:1.7;margin-bottom:24px}
.ft-cta-card .btn{width:100%}
.ft-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.ft{background:var(--g9);padding:80px 0 0;color:rgba(255,255,255,.6)}
.ft-ct{font-size:15px;font-weight:500;color:white;margin-bottom:20px}
.ft-links{display:flex;flex-direction:column;gap:10px}.ft-links a{font-size:14px;color:rgba(255,255,255,.45);transition:color .3s}.ft-links a:hover{color:var(--kc)}
.ft-bot{padding:24px 0;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:rgba(255,255,255,.3);flex-wrap:wrap;gap:12px}
.stt{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:14px;background:var(--gb);color:white;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 8px 24px rgba(13,83,252,.3);z-index:999;opacity:0;transform:translateY(20px);transition:all var(--tb)}.stt.vis{opacity:1;transform:translateY(0)}.stt:hover{transform:translateY(-4px)}
.wpp-float{position:fixed;bottom:24px;left:24px;width:56px;height:56px;border-radius:50%;background:var(--wpp);color:white;display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 8px 24px rgba(17,140,126,.4);z-index:999;animation:wP 2s infinite}@keyframes wP{0%,100%{box-shadow:0 0 0 0 rgba(17,140,126,.4)}50%{box-shadow:0 0 0 14px rgba(17,140,126,0)}}
@media(max-width:1024px){.hero{min-height:0;padding:150px 0 140px}.hero .ctn{grid-template-columns:1fr}.hero-vis{display:none}.bl-grid{grid-template-columns:repeat(2,1fr)}.ab-grid{grid-template-columns:1fr}.ab-imgs{display:none}.ft-top{grid-template-columns:1fr}.ft-cols{grid-template-columns:repeat(3,1fr)}.fbar-g{grid-template-columns:1fr}.pgrid{grid-template-columns:repeat(2,1fr)}.nav-a{padding:6px 10px;font-size:12px}.faq-grid{grid-template-columns:1fr}.cap-header{grid-template-columns:1fr;gap:16px}.cap-header-link{justify-self:start}.cap-svc-header{grid-template-columns:1fr;gap:16px}.cap-cards{grid-template-columns:repeat(2,1fr)}.cap-numbers{grid-template-columns:repeat(2,1fr);gap:24px}.cap-num-item::after{display:none}.cap-banner{height:300px}.cap-banner img{object-position:80% center}.cta-banner{padding:60px 32px}}
@media(max-width:768px){.nav{display:none}.hdr-cta{display:none !important}.hamburger{display:flex}.hero-t{font-size:2rem}.hero-acts{flex-wrap:nowrap;gap:10px;align-items:stretch;margin-bottom:40px}.hero-btn{flex:1 1 0;min-width:0;justify-content:center;padding:14px 12px;font-size:max(14px,0.875rem);gap:8px;text-align:center}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px 10px;padding-top:24px;align-items:start}.hero-stats>div{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:0}.hero-stats .h-st-n{font-size:clamp(1.35rem,5.5vw,1.75rem);justify-content:center}.hero-stats .h-st-n .cs{font-size:clamp(.95rem,3.2vw,1.1rem)}.hero-stats .h-st-l{font-size:max(13px,0.8125rem);line-height:1.45;margin-top:6px;max-width:100%;color:rgba(255,255,255,.65);hyphens:auto;-webkit-hyphens:auto}.ps-filter{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;gap:8px;padding-bottom:8px;margin-bottom:32px;margin-left:-24px;margin-right:-24px;padding-left:24px;padding-right:24px;scroll-padding-inline:24px}.ps-filter::-webkit-scrollbar{height:4px}.ps-filter::-webkit-scrollbar-thumb{background:var(--g2);border-radius:4px}.ps-fb{flex-shrink:0}.bl-grid{grid-template-columns:1fr}.ft-top{grid-template-columns:1fr}.ft-cols{grid-template-columns:repeat(2,1fr)}.sec-hd-split{flex-direction:column;align-items:flex-start}.sec-hd-split.sec-hd-split--center{align-items:stretch;width:100%}.pgrid{grid-template-columns:1fr}.hdr-bar{padding:10px 12px 10px 16px}.cap-cards{grid-template-columns:repeat(2,1fr);gap:12px;align-items:stretch}.cap-card{padding:20px 14px;min-height:0}.cap-card-ic{width:40px;height:40px;font-size:17px;margin-bottom:12px}.cap-card-t{font-size:15px;margin-bottom:10px}.cap-card-list li{font-size:max(13px,0.8125rem);line-height:1.5}.cap-numbers{grid-template-columns:repeat(2,1fr)}.cap-banner{height:min(380px,78vw);min-height:300px}.cap-banner img{object-position:88% 35%}.cap-banner-overlay{background:linear-gradient(118deg,rgba(15,23,42,.96) 0%,rgba(15,23,42,.9) 35%,rgba(15,23,42,.62) 62%,rgba(15,23,42,.48) 100%)}.cap-banner-text{bottom:20px;left:18px;right:18px;max-width:none}.cap-banner-badge{margin-bottom:12px;padding:8px 14px;font-size:max(12px,0.75rem)}.cap-banner-text h3{font-size:clamp(1.2rem,4.8vw,1.55rem);margin-bottom:10px;line-height:1.25}.cap-banner-text p{font-size:max(14px,0.875rem);line-height:1.55;color:rgba(255,255,255,.9)}.cta-acts{flex-direction:column;flex-wrap:nowrap;gap:12px;align-items:stretch;width:100%}.cta-acts .btn{width:100%;max-width:100%;flex:none;box-sizing:border-box;justify-content:center;padding:14px 18px;font-size:max(15px,0.9375rem);gap:8px;text-align:center}.cta-inner{width:100%}.cta-banner{padding:48px 24px;border-radius:20px}.bl-card{height:280px}.bl-mt{font-size:max(13px,0.8125rem)}.bl-tt{font-size:max(16px,1rem)}.hero-d{font-size:max(16px,1rem)}.pcard-badge{font-size:max(12px,0.75rem)}.pcard-inst{font-size:max(13px,0.8125rem)}.pcard-off{font-size:max(12px,0.75rem)}.scroll-ind{font-size:max(12px,0.75rem)}.faq-q-text{font-size:max(16px,1rem)}.faq-a-inner{font-size:max(15px,0.9375rem)}}
.stt{bottom:max(24px,env(safe-area-inset-bottom,0px));right:max(24px,env(safe-area-inset-right,0px))}.wpp-float{bottom:max(24px,env(safe-area-inset-bottom,0px));left:max(24px,env(safe-area-inset-left,0px))}
