*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cyan:#0096C7; --cyan-dk:#006d91; --cyan-lt:#e0f4fa;
  --magenta:#D4006A; --magenta-lt:#ffe0f2;
  --yellow:#F5C400;
  --ink:#111111; --dark:#1c1c1c;
  --gray:#555; --gray-lt:#aaa;
  --border:#e5e9ed; --bg:#fafafa; --bg2:#f0f4f8; --white:#fff;
  --font:'Montserrat',sans-serif; --body:'Lato',sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
  --sh-sm:0 2px 12px rgba(0,150,199,.08);
  --sh-md:0 8px 32px rgba(0,150,199,.14);
  --sh-lg:0 20px 60px rgba(0,0,0,.1);
}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--ink);font-family:var(--body);font-weight:300;line-height:1.6;overflow-x:hidden}
img{display:block;width:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;font-family:var(--font);border:none;background:none}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--cyan);border-radius:10px}

/* ── KEYFRAMES ── */
@keyframes up{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
@keyframes fadein{from{opacity:0}to{opacity:1}}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes float1{0%,100%{transform:rotate(-5deg) translateY(0)}50%{transform:rotate(-5deg) translateY(-10px)}}
@keyframes float2{0%,100%{transform:rotate(4deg) translateY(0)}50%{transform:rotate(4deg) translateY(-8px)}}
@keyframes float3{0%,100%{transform:rotate(-2deg) translateY(0)}50%{transform:rotate(-2deg) translateY(-6px)}}
@keyframes wapulse{0%{opacity:.5;transform:scale(1)}100%{opacity:0;transform:scale(1.6)}}
@keyframes wapop{from{opacity:0;transform:scale(.5) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes dot{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(8px);opacity:.3}}

/* ── LOGO ── */
.logo-wrap{
  display:inline-flex;
  align-items:center;
  overflow:visible;
}
.logo-svg{
  height:58px;
  width:auto;
  overflow:visible;
  display:block;
}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:2000;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 5vw;
  min-height:64px;
  background:transparent;
  transition:background .3s var(--ease),box-shadow .3s var(--ease)
}
.nav.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--border),var(--sh-sm)}
.nav__links{display:flex;gap:2.2rem;align-items:center}
.nav__links a{
  font-family:var(--font);font-size:.74rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gray);
  position:relative;transition:color .3s
}
.nav__links a::after{
  content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;
  background:var(--cyan);transform:scaleX(0);transform-origin:left;transition:transform .3s
}
.nav__links a:hover{color:var(--cyan)}
.nav__links a:hover::after{transform:scaleX(1)}
.nav__cta{
  padding:.52rem 1.3rem!important;background:var(--cyan);
  color:var(--white)!important;border-radius:4px;
  font-size:.72rem!important;font-weight:700!important;letter-spacing:.07em;
  box-shadow:0 4px 14px rgba(0,150,199,.3);
  transition:background .3s,transform .3s,box-shadow .3s!important
}
.nav__cta:hover{background:var(--cyan-dk)!important;transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,150,199,.4)!important}
.nav__cta::after{display:none!important}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:5px}
.nav__burger span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s}
.nav__mobile{
  display:none;
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  z-index:1001;
  background:var(--white);
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2rem;
  padding-top:64px;
}
.nav__mobile.open{
  display:flex;
}
.nav__mobile.open{
  display:flex;
}

/* ── HERO ── */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;
  background:var(--white);padding:0 5vw;overflow:hidden
}
.hero__blur{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hb{position:absolute;border-radius:50%;filter:blur(90px)}
.hb1{width:600px;height:600px;background:var(--cyan);opacity:.1;top:-150px;right:-100px}
.hb2{width:400px;height:400px;background:var(--magenta);opacity:.07;bottom:-50px;right:20%}
.hb3{width:300px;height:300px;background:var(--yellow);opacity:.07;top:40%;left:-60px}
.hero__dots{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,var(--border) 1px,transparent 1px);
  background-size:30px 30px;opacity:.7
}
.hero__inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;
  width:100%;max-width:1200px;margin:0 auto;padding:120px 0 80px
}
.hero__tag{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.32rem .9rem .32rem .32rem;background:var(--cyan-lt);border-radius:100px;
  margin-bottom:1.4rem;opacity:0;animation:up .6s .2s forwards
}
.hero__tag-dot{width:22px;height:22px;background:var(--cyan);border-radius:50%;display:flex;align-items:center;justify-content:center}
.hero__tag-dot svg{width:11px;height:11px;stroke:white;fill:none;stroke-width:2.5}
.hero__tag-text{font-family:var(--font);font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan-dk)}
.hero__h1{
  font-family:var(--font);font-weight:900;
  font-size:clamp(2.6rem,5.2vw,4.4rem);line-height:1.06;letter-spacing:-.025em;
  color:var(--ink);opacity:0;animation:up .7s .35s forwards
}
.hero__h1 .c{color:var(--cyan)}.hero__h1 .m{color:var(--magenta)}
.hero__sub{
  margin-top:1.3rem;font-size:1rem;color:var(--gray);line-height:1.8;max-width:470px;
  opacity:0;animation:up .7s .5s forwards
}
.hero__btns{margin-top:2.2rem;display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:up .7s .65s forwards}
.btn-primary{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.82rem 1.75rem;background:var(--cyan);color:var(--white);
  font-family:var(--font);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  border-radius:4px;box-shadow:0 4px 18px rgba(0,150,199,.35);
  transition:background .3s,transform .3s,box-shadow .3s
}
.btn-primary:hover{background:var(--cyan-dk);transform:translateY(-2px);box-shadow:0 8px 26px rgba(0,150,199,.45)}
.btn-outline{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.82rem 1.75rem;border:2px solid var(--border);color:var(--ink);
  font-family:var(--font);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  border-radius:4px;transition:border-color .3s,color .3s,transform .3s
}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan);transform:translateY(-2px)}
.btn-wa{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.82rem 1.75rem;background:#25D366;color:var(--white);
  font-family:var(--font);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  border-radius:4px;box-shadow:0 4px 16px rgba(37,211,102,.35);
  transition:background .3s,transform .3s
}
.btn-wa:hover{background:#1ebe5b;transform:translateY(-2px)}
.hero__trust{
  margin-top:2.2rem;display:flex;gap:1.5rem;flex-wrap:wrap;
  opacity:0;animation:fadein .8s .9s forwards
}
.trust-item{display:flex;align-items:center;gap:.4rem;font-family:var(--font);font-size:.7rem;font-weight:600;color:var(--gray-lt);letter-spacing:.04em}
.trust-item svg{width:15px;height:15px;stroke:var(--cyan);fill:none;stroke-width:2.5}

/* Hero visual */
.hero__visual{
  position:relative;aspect-ratio:1/1.05;
  display:flex;align-items:center;justify-content:center;
  opacity:0;animation:up .9s .5s forwards
}
.vis-circle{
  position:absolute;width:88%;aspect-ratio:1;border-radius:50%;
  background:linear-gradient(135deg,var(--cyan-lt) 0%,#e8f9ff 55%,var(--magenta-lt) 100%)
}
.vis-card{
  position:absolute;background:var(--white);border-radius:10px;
  box-shadow:var(--sh-lg);overflow:hidden
}
.vc1{width:150px;top:10%;left:3%;animation:float1 4s ease-in-out infinite}
.vc2{width:125px;bottom:15%;right:2%;animation:float2 4s 1.2s ease-in-out infinite}
.vc3{width:105px;bottom:8%;left:10%;animation:float3 4s 2.3s ease-in-out infinite}
.vc-top{height:6px}
.vc1 .vc-top{background:var(--cyan)}
.vc2 .vc-top{background:var(--magenta)}
.vc3 .vc-top{background:var(--yellow)}
.vc-body{padding:10px 12px 12px}
.vc-line{height:6px;border-radius:3px;background:var(--bg2);margin-bottom:5px}
.vc-line.w80{width:80%}.vc-line.w60{width:60%}.vc-line.w45{width:45%}
.vc-line.accent{background:var(--cyan-lt);width:45%}
.vis-center{
  position:relative;z-index:2;background:var(--white);border-radius:16px;
  padding:2rem 1.8rem;box-shadow:0 24px 70px rgba(0,0,0,.13);text-align:center;
  width:58%
}
.vis-center-logo{display:flex;justify-content:center;margin-bottom:1.2rem}
.vis-center-sub{font-family:var(--font);font-size:.6rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-lt);margin-top:3px}
.vis-divider{height:1px;background:var(--border);margin:1rem 0}
.vis-lines{display:flex;flex-direction:column;gap:5px}
.vis-ln{height:6px;border-radius:3px;background:var(--bg2)}
.vis-ln.c{background:rgba(0,150,199,.15);width:70%;margin:0 auto}
.vis-ln.m{background:rgba(212,0,106,.1);width:50%;margin:0 auto}
.vis-badge{
  position:absolute;z-index:3;background:var(--white);border-radius:100px;
  padding:.38rem .8rem;box-shadow:var(--sh-md);
  display:flex;align-items:center;gap:.4rem;
  font-family:var(--font);font-size:.63rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase
}
.vbd{width:8px;height:8px;border-radius:50%}
.vb1{top:7%;right:8%}.vb1 .vbd{background:var(--cyan)}
.vb2{bottom:7%;left:7%}.vb2 .vbd{background:var(--magenta)}
.vb3{bottom:7%;right:8%}.vb3 .vbd{background:var(--yellow)}
/* ── TICKER ── */
.ticker{background:var(--ink);padding:.7rem 0;overflow:hidden}
.ticker-track{display:flex;gap:2rem;width:max-content;animation:ticker 22s linear infinite}
.ticker-item{display:flex;align-items:center;gap:.8rem;font-family:var(--font);font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.65);white-space:nowrap}
.td{width:7px;height:7px;border-radius:50%}
.td-c{background:#00B4D8}.td-m{background:#E5007E}.td-y{background:#F5C400}

/* ── LAYOUT ── */
.section{padding:6rem 5vw}
.inner{max-width:1200px;margin:0 auto}
.s-white{background:var(--white)}.s-light{background:var(--bg2)}.s-dark{background:var(--dark)}

.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font);font-size:.67rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan);margin-bottom:.9rem}
.eyebrow::before{content:'';display:block;width:22px;height:2px;background:var(--cyan)}
.eyebrow.wh{color:rgba(255,255,255,.65)}.eyebrow.wh::before{background:rgba(255,255,255,.35)}
.eyebrow.mg{color:var(--magenta)}.eyebrow.mg::before{background:var(--magenta)}

.sh2{font-family:var(--font);font-weight:900;font-size:clamp(2.1rem,4.2vw,3.6rem);line-height:1.08;letter-spacing:-.022em;color:var(--ink)}
.sh2.wh{color:var(--white)}.sh2 .c{color:var(--cyan)}.sh2 .m{color:var(--magenta)}
.sdesc{margin-top:.9rem;max-width:490px;font-size:1rem;color:var(--gray);line-height:1.8}
.sdesc.wh{color:rgba(255,255,255,.6)}

/* ── SERVICES ── */
.svc-grid{margin-top:3.5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.svc-card{
  background:var(--white);border:1.5px solid var(--border);border-radius:12px;padding:2rem 1.8rem;
  position:relative;overflow:hidden;
  transition:transform .3s,box-shadow .3s,border-color .3s;cursor:default
}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--sh-md);border-color:var(--cyan)}
.svc-bar{position:absolute;top:0;left:0;right:0;height:4px;border-radius:12px 12px 0 0;transform:scaleX(0);transform-origin:left;transition:transform .3s}
.svc-card:hover .svc-bar{transform:scaleX(1)}
.svc-card:nth-child(1) .svc-bar,.svc-card:nth-child(4) .svc-bar{background:var(--cyan)}
.svc-card:nth-child(2) .svc-bar,.svc-card:nth-child(5) .svc-bar{background:var(--magenta)}
.svc-card:nth-child(3) .svc-bar,.svc-card:nth-child(6) .svc-bar{background:var(--yellow)}
.svc-num{position:absolute;top:1.2rem;right:1.5rem;font-family:var(--font);font-size:2.8rem;font-weight:900;color:var(--bg2);line-height:1;transition:color .3s}
.svc-card:hover .svc-num{color:rgba(0,150,199,.07)}
.svc-icon{width:46px;height:46px;border-radius:10px;background:var(--cyan-lt);display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;transition:background .3s}
.svc-card:hover .svc-icon{background:var(--cyan)}
.svc-icon svg{width:21px;height:21px;stroke:var(--cyan);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .3s}
.svc-card:hover .svc-icon svg{stroke:var(--white)}
.svc-card:nth-child(2) .svc-icon,.svc-card:nth-child(5) .svc-icon{background:var(--magenta-lt)}
.svc-card:nth-child(2) .svc-icon svg,.svc-card:nth-child(5) .svc-icon svg{stroke:var(--magenta)}
.svc-card:nth-child(2):hover .svc-icon,.svc-card:nth-child(5):hover .svc-icon{background:var(--magenta)}
.svc-card:nth-child(2):hover .svc-icon svg,.svc-card:nth-child(5):hover .svc-icon svg{stroke:var(--white)}
.svc-title{font-family:var(--font);font-weight:800;font-size:1.05rem;color:var(--ink);margin-bottom:.6rem}
.svc-text{font-size:.875rem;color:var(--gray);line-height:1.75}
.svc-tags{margin-top:1.1rem;display:flex;flex-wrap:wrap;gap:.4rem}
.tag{padding:.18rem .62rem;background:var(--bg2);border-radius:100px;font-family:var(--font);font-size:.63rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--gray-lt);transition:background .3s,color .3s}
.svc-card:hover .tag{background:var(--cyan-lt);color:var(--cyan-dk)}

/* ── STATS ── */
.stats-band{background:var(--dark);padding:3.5rem 5vw;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat-num{font-family:var(--font);font-weight:900;font-size:clamp(2.6rem,4.5vw,3.8rem);line-height:1;color:var(--cyan)}
.stat-label{font-family:var(--font);font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-top:.35rem}

/* ── PORTFOLIO ── */
.port-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;margin-bottom:3rem}
.port-filter{display:flex;gap:.5rem;flex-wrap:wrap}
.fbtn{
  padding:.42rem 1.1rem;border:1.5px solid var(--border);border-radius:100px;
  font-family:var(--font);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-lt);
  transition:all .3s
}
.fbtn.active,.fbtn:hover{background:var(--cyan);border-color:var(--cyan);color:var(--white)}
.port-grid{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:210px;gap:10px}
.port-item{position:relative;overflow:hidden;border-radius:10px;cursor:pointer;transition:opacity .35s,transform .35s}
.port-item:nth-child(1){grid-column:span 5;grid-row:span 2}
.port-item:nth-child(2){grid-column:span 4}
.port-item:nth-child(3){grid-column:span 3}
.port-item:nth-child(4){grid-column:span 4;grid-row:span 2}
.port-item:nth-child(5){grid-column:span 3}
.port-item:nth-child(6){grid-column:span 5}
.port-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transition:transform .5s}
.port-item:hover .port-bg{transform:scale(1.06)}
.port-item:nth-child(1) .port-bg{background:linear-gradient(135deg,#e0f4fa,#b3e9f7)}
.port-item:nth-child(2) .port-bg{background:linear-gradient(135deg,#ffe0f0,#ffc2e0)}
.port-item:nth-child(3) .port-bg{background:linear-gradient(135deg,#f0f4f8,#dde3ec)}
.port-item:nth-child(4) .port-bg{background:linear-gradient(135deg,#fff9e0,#faedb3)}
.port-item:nth-child(5) .port-bg{background:linear-gradient(135deg,#e0f4fa,#c2e7f5)}
.port-item:nth-child(6) .port-bg{background:linear-gradient(135deg,#ffe0f0,#fad2e8)}
.port-mock{background:var(--white);border-radius:6px;box-shadow:0 4px 20px rgba(0,0,0,.12);padding:10px 14px;min-width:80px}
.pm-bar{height:4px;border-radius:3px;margin-bottom:8px}
.port-item:nth-child(1) .pm-bar{background:var(--cyan)}
.port-item:nth-child(2) .pm-bar{background:var(--magenta)}
.port-item:nth-child(3) .pm-bar{background:var(--gray)}
.port-item:nth-child(4) .pm-bar{background:var(--yellow)}
.port-item:nth-child(5) .pm-bar{background:var(--cyan-dk)}
.port-item:nth-child(6) .pm-bar{background:var(--magenta)}
.pm-lines{display:flex;flex-direction:column;gap:4px}
.pm-line{height:5px;border-radius:2px;background:#eee}
.pm-line.w80{width:80%;margin:0 auto}.pm-line.w60{width:60%;margin:0 auto}.pm-line.w40{width:40%;margin:0 auto}
.port-overlay{
  position:absolute;inset:0;border-radius:10px;background:rgba(17,17,17,.72);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;
  opacity:0;transition:opacity .3s
}
.port-item:hover .port-overlay{opacity:1}
.po-title{font-family:var(--font);font-size:1.05rem;font-weight:800;color:var(--white);letter-spacing:-.01em}
.po-cat{font-family:var(--font);font-size:.63rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--cyan)}

/* ── ABOUT ── */
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:6vw;align-items:center}
.about-visual{position:relative}
.about-frame{border-radius:16px;overflow:hidden;box-shadow:var(--sh-lg);aspect-ratio:4/5;background:linear-gradient(135deg,var(--cyan-lt),#d0f0fb 50%,var(--magenta-lt));display:flex;align-items:center;justify-content:center}
.about-frame-inner{text-align:center;padding:2rem}
.about-cmyk{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:110px;margin:0 auto 1.3rem}
.ac{width:50px;height:50px;border-radius:50%}
.ac-c{background:#00B4D8}.ac-m{background:#E5007E}.ac-y{background:#F5C400}.ac-k{background:var(--ink)}
.about-brand{font-family:var(--font);font-weight:900;font-size:1.3rem;letter-spacing:-.01em;color:var(--ink)}
.about-brand span{color:var(--cyan)}
.about-brand-sub{font-family:var(--font);font-size:.55rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gray-lt);margin-top:3px}
.about-badge{
  position:absolute;bottom:-1.1rem;right:-1.1rem;
  width:106px;height:106px;border-radius:50%;background:var(--cyan);
  box-shadow:0 8px 30px rgba(0,150,199,.4);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center
}
.ab-num{font-family:var(--font);font-weight:900;font-size:2rem;color:var(--white);line-height:1}
.ab-txt{font-family:var(--font);font-size:.5rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-top:2px;line-height:1.3}
.about-deco{position:absolute;top:-12px;left:-12px;width:75px;height:75px;border-radius:50%;background:var(--magenta-lt);z-index:-1}
.about-list{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.2rem}
.about-item{display:flex;gap:1rem;align-items:flex-start}
.ai-icon{width:40px;height:40px;flex-shrink:0;border-radius:8px;background:var(--cyan-lt);display:flex;align-items:center;justify-content:center}
.ai-icon svg{width:18px;height:18px;stroke:var(--cyan);fill:none;stroke-width:2.2;stroke-linecap:round}
.ai-title{font-family:var(--font);font-weight:800;font-size:.93rem;margin-bottom:.2rem}
.ai-text{font-size:.85rem;color:var(--gray);line-height:1.7}

/* ── PROCESS ── */
.proc-steps{margin-top:4rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;position:relative}
.proc-steps::before{content:'';position:absolute;top:27px;left:calc(12.5% + 14px);right:calc(12.5% + 14px);height:2px;background:linear-gradient(90deg,var(--cyan),var(--magenta));border-radius:2px}
.proc-step{text-align:center;padding:0 .5rem}
.proc-dot{
  width:54px;height:54px;border-radius:50%;background:var(--dark);border:2px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;margin:0 auto 1.4rem;position:relative;z-index:1;
  transition:background .3s,border-color .3s,box-shadow .3s
}
.proc-dot svg{width:21px;height:21px;stroke:rgba(255,255,255,.4);fill:none;stroke-width:2;stroke-linecap:round;transition:stroke .3s}
.proc-step:hover .proc-dot{background:var(--cyan);border-color:var(--cyan);box-shadow:0 4px 20px rgba(0,150,199,.4)}
.proc-step:hover .proc-dot svg{stroke:var(--white)}
.proc-n{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:var(--cyan);color:var(--white);font-family:var(--font);font-size:.58rem;font-weight:800;display:flex;align-items:center;justify-content:center}
.proc-title{font-family:var(--font);font-weight:800;font-size:.98rem;color:var(--white);margin-bottom:.45rem}
.proc-text{font-size:.81rem;color:rgba(255,255,255,.45);line-height:1.7}

/* ── TESTIMONIALS ── */
.testi-grid{margin-top:3.5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.testi-card{background:var(--white);border:1.5px solid var(--border);border-radius:12px;padding:2rem;transition:box-shadow .3s,border-color .3s}
.testi-card:hover{box-shadow:var(--sh-md);border-color:var(--cyan)}
.testi-stars{display:flex;gap:3px;margin-bottom:.8rem}
.star{width:15px;height:15px;fill:var(--yellow)}
.testi-q{font-family:var(--font);font-size:2.8rem;font-weight:900;color:var(--cyan-lt);line-height:1;margin-bottom:.4rem}
.testi-text{font-size:.88rem;color:var(--gray);line-height:1.8;margin-bottom:1.4rem}
.testi-author{font-family:var(--font);font-weight:800;font-size:.82rem;color:var(--ink)}
.testi-co{font-family:var(--font);font-size:.68rem;font-weight:600;letter-spacing:.07em;color:var(--cyan);margin-top:2px}

/* ── CONTACT ── */
.contact-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:5vw;align-items:start}
.ci-list{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.4rem}
.ci-item{display:flex;gap:1rem;align-items:flex-start}
.ci-ico{width:42px;height:42px;flex-shrink:0;border-radius:10px;background:var(--cyan-lt);display:flex;align-items:center;justify-content:center}
.ci-ico svg{width:17px;height:17px;stroke:var(--cyan);fill:none;stroke-width:2;stroke-linecap:round}
.ci-lbl{font-family:var(--font);font-size:.63rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--cyan);margin-bottom:.22rem}
.ci-val{font-size:.88rem;color:rgba(255,255,255,.75);line-height:1.55}
.soc-row{margin-top:2.5rem;display:flex;gap:.7rem}
.soc-btn{width:42px;height:42px;border-radius:8px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:all .3s}
.soc-btn:hover{background:var(--cyan);border-color:var(--cyan);transform:translateY(-2px)}
.soc-btn svg{width:17px;height:17px;stroke:rgba(255,255,255,.55);fill:none;stroke-width:1.8;stroke-linecap:round}
.soc-btn:hover svg{stroke:var(--white)}
.form-wrap{background:var(--white);border-radius:16px;padding:2.5rem;box-shadow:var(--sh-lg)}
.form-title{font-family:var(--font);font-weight:900;font-size:1.35rem;letter-spacing:-.01em;color:var(--ink);margin-bottom:.35rem}
.form-sub{font-size:.84rem;color:var(--gray);margin-bottom:1.7rem}
.contact-form{display:flex;flex-direction:column;gap:1.1rem}
.fg{display:flex;flex-direction:column;gap:.32rem}
.fl{font-family:var(--font);font-size:.66rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink)}
.fi,.fta,.fsel{
  width:100%;padding:.72rem 1rem;border:1.5px solid var(--border);border-radius:6px;
  font-family:var(--body);font-size:.87rem;color:var(--ink);background:var(--bg);outline:none;
  transition:border-color .3s,box-shadow .3s
}
.fi::placeholder,.fta::placeholder{color:var(--gray-lt)}
.fi:focus,.fta:focus,.fsel:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(0,150,199,.1)}
.fta{resize:vertical;min-height:108px}
.fsel{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23aaa' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.btn-submit{
  padding:.88rem 2rem;background:var(--cyan);color:var(--white);border:none;
  font-family:var(--font);font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  border-radius:6px;cursor:pointer;align-self:flex-start;
  box-shadow:0 4px 14px rgba(0,150,199,.3);
  transition:background .3s,transform .3s,box-shadow .3s
}
.btn-submit:hover{background:var(--cyan-dk);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,150,199,.4)}

/* ── WA FLOAT ── */
.wa-float{position:fixed;bottom:2rem;right:2rem;z-index:900;display:flex;align-items:center;gap:.8rem;animation:wapop .5s 1.5s both}
.wa-lbl{background:var(--white);color:var(--ink);padding:.48rem 1rem;font-family:var(--font);font-size:.73rem;font-weight:700;border-radius:6px;box-shadow:var(--sh-md);white-space:nowrap;opacity:0;transform:translateX(10px);transition:opacity .3s,transform .3s;pointer-events:none}
.wa-float:hover .wa-lbl{opacity:1;transform:translateX(0)}
.wa-btn{width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);position:relative;transition:transform .3s}
.wa-btn:hover{transform:scale(1.08)}
.wa-btn svg{width:27px;height:27px;fill:white;position:relative;z-index:1}
.wa-btn::before{content:'';position:absolute;width:56px;height:56px;background:#25D366;border-radius:50%;animation:wapulse 2.5s infinite}

/* ── FOOTER ── */
.footer{background:#090909;padding:4rem 5vw 2rem;border-top:1px solid rgba(255,255,255,.05)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.06);max-width:1200px;margin:0 auto}
.footer-tagline{font-size:.87rem;color:rgba(255,255,255,.35);line-height:1.8;max-width:270px;margin-top:.9rem}
.fc-title{font-family:var(--font);font-size:.63rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:1.1rem}
.fc ul{display:flex;flex-direction:column;gap:.65rem}
.fc ul a{font-size:.84rem;color:rgba(255,255,255,.35);transition:color .3s}
.fc ul a:hover{color:var(--cyan)}
.footer-bottom{max-width:1200px;margin:2rem auto 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-family:var(--font);font-size:.7rem;color:rgba(255,255,255,.18);letter-spacing:.04em}
.footer-bottom a{color:var(--cyan)}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.rv.on{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}
.nav__mobile-close{display:none !important;}
/* ── RESPONSIVE ── */

@media(max-width:1024px){
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .about-inner{grid-template-columns:1fr}
  .about-visual{max-width:360px;margin:0 auto 3rem}
  .contact-inner{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
  .stats-band{grid-template-columns:repeat(2,1fr)}
  .proc-steps{grid-template-columns:repeat(2,1fr)}
  .proc-steps::before{display:none}
  .testi-grid{grid-template-columns:1fr 1fr}
  .port-grid{grid-template-columns:repeat(6,1fr)}
  .port-item:nth-child(1){grid-column:span 6;grid-row:span 1}
  .port-item:nth-child(2){grid-column:span 3}
  .port-item:nth-child(3){grid-column:span 3}
  .port-item:nth-child(4){grid-column:span 3}
  .port-item:nth-child(5){grid-column:span 3}
  .port-item:nth-child(6){grid-column:span 6}
}
@media(max-width:768px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .hero__inner{grid-template-columns:1fr;padding:100px 0 60px}
  .hero__visual{display:none}
  .svc-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .section{padding:4rem 5vw}
  .footer-top{grid-template-columns:1fr}
  .nav{padding:.75rem 5vw;}
  .logo-svg{height:72px;}
  .btn-wa, .btn-ig{
  width:100%;
  justify-content:center;
}
}

@media(max-width:480px){
  .port-grid{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .port-item{grid-column:span 1!important;grid-row:span 1!important}
  .stats-band{grid-template-columns:1fr 1fr}
  .proc-steps{grid-template-columns:1fr}
  .wa-lbl{display:none}
}

/* ── POR QUÉ ELEGIRNOS ── */
.why-section{
  background:#000;
  padding:5rem 0;
  overflow:hidden;
}
.why-title-main{
  font-family:var(--font);
  font-weight:900;
  font-size:clamp(2rem,4.5vw,3.5rem);
  color:var(--white);
  text-align:center;
  letter-spacing:-.02em;
  text-transform:uppercase;
  margin-bottom:4rem;
  padding:0 5vw;
}
.why-title-main span{color:var(--cyan);}

.why-timeline{
  position:relative;
  width:100%;
}

/* Línea CMYK horizontal — toca los bordes */
.why-hline{
  position:absolute;
  left:0;right:0;
  top:50%;transform:translateY(-50%);
  height:20px;
  background:linear-gradient(90deg,
    #555 0%,#555 25%,
    var(--yellow) 25%,var(--yellow) 50%,
    var(--magenta) 50%,var(--magenta) 75%,
    var(--cyan) 75%,var(--cyan) 100%
  );
  z-index:0;
}

/* Filas */
.why-top-row,
.why-bottom-row,
.why-connector-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  position:relative;
  z-index:1;
}

/* Fila superior */
.why-top-row .why-has-circle{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-end;
  min-height:160px;
}
.why-top-row .why-has-text{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  min-height:160px;
  padding:0 1rem 1.2rem;
  text-align:center;
}

/* Fila conectores */
.why-connector-row{
  height:20px;
  z-index:2;
}
.why-connector-cell{
  display:flex;
  align-items:center;
  justify-content:center;
}
.why-connector{
  width:16px;height:16px;
  border-radius:50%;
  background:white;
  position:relative;z-index:3;
}

/* Fila inferior */
.why-bottom-row .why-has-circle{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  min-height:160px;
}
.why-bottom-row .why-has-text{
  display:flex;
  align-items:flex-start;
  justify-content:center;
  min-height:160px;
  padding:1.2rem 1rem 0;
  text-align:center;
}

/* Círculos */
.why-dot{
  width:90px;height:90px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.why-dot svg{width:38px;height:38px;}

/* Líneas verticales delgadas */
.why-vline{
  width:2px;
  height:40px;
  flex-shrink:0;
}

/* Textos */
.why-text-wrap{text-align:center;}
.why-label{
  font-family:var(--font);
  font-weight:800;
  font-size:.92rem;
  color:var(--white);
  margin-bottom:.3rem;
  line-height:1.3;
}
.why-desc{
  font-size:.78rem;
  color:rgba(255,255,255,.5);
  line-height:1.6;
}

/* ── RESPONSIVE MÓVIL ── */
.why-mobile-grid{display:none;}

@media(max-width:768px){
  .why-section{padding:4rem 5vw;}
  .why-hline,
  .why-connector-row,
  .why-top-row,
  .why-bottom-row{display:none!important;}

  .why-mobile-grid{
    display:grid!important;
    grid-template-columns:1fr 1fr;
    gap:2.5rem;
  }
  .why-mobile-item{
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:.8rem;
  }
  .why-mobile-item .why-dot{
    width:70px;height:70px;
  }
  .why-mobile-item .why-dot svg{
    width:28px;height:28px;
  }
  .why-mobile-item .why-label{
    font-family:var(--font);
    font-weight:800;
    font-size:.92rem;
    color:var(--white);
    line-height:1.3;
  }
  .why-mobile-item .why-desc{
    font-size:.78rem;
    color:rgba(255,255,255,.5);
    line-height:1.6;
  }
}
@media(max-width:480px){
  .why-mobile-grid{grid-template-columns:1fr!important;}
}

/* Variante Instagram */
.btn-ig {
  background: linear-gradient(45deg, #f58529, #dd2a7b, #8134af, #515bd4);
}
.btn-ig {
  background: linear-gradient(45deg, #f58529, #dd2a7b, #8134af, #515bd4);
  box-shadow: 0 4px 16px rgba(221,42,123,.35);
}
.btn-ig:hover{
  background: linear-gradient(45deg, #e0762a, #c4256e, #7030a0, #4050c0);
  box-shadow: 0 6px 20px rgba(221,42,123,.5);
}
/* ── CARRUSEL CLIENTES ── */
.clientes-section{
  padding:5rem 0;
  background:var(--white);
  overflow:hidden;
}
.clientes-title{
  font-family:var(--font);font-weight:900;
  font-size:clamp(2.1rem,4.2vw,3.6rem);
  letter-spacing:-.022em;color:var(--ink);
  text-align:center;margin-bottom:.5rem;
}
.clientes-title span{color:var(--cyan);}
.clientes-sub{
  text-align:center;font-size:1rem;
  color:var(--gray);margin-bottom:3rem;
}
.clientes-track-wrap{
  position:relative;
  overflow:hidden;
}
/* Degradados en los bordes para efecto fade */
.clientes-track-wrap::before,
.clientes-track-wrap::after{
  content:'';
  position:absolute;top:0;bottom:0;
  width:120px;z-index:2;pointer-events:none;
}
.clientes-track-wrap::before{
  left:0;
  background:linear-gradient(90deg,var(--white),transparent);
}
.clientes-track-wrap::after{
  right:0;
  background:linear-gradient(270deg,var(--white),transparent);
}
.clientes-track{
  display:flex;
  gap:3rem;
  width:max-content;
  animation:ticker 40s linear infinite;
  align-items:center;
}
/* .clientes-track:hover{animation-play-state:paused;} */
.cliente-logo{
  height:100px;
  width:auto;
  object-fit:contain;
  filter:grayscale(0%);
  opacity:1;
  transition:transform .3s,filter .3s;
  flex-shrink:0;
}
.cliente-logo:hover{
  transform:scale(1.45);
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.15));
}