
/* =========================================
   SALEEM AKHTER V5 — CLEAN OPTIMIZED BUILD
   Zero console errors | Fast | SEO Ready
   ========================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Space Grotesk',sans-serif;background:#02040a;color:#d8e8ff;overflow-x:hidden;-webkit-font-smoothing:antialiased}
::selection{background:#00ff88;color:#000}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
ul{list-style:none}
button{font-family:inherit;border:none;background:none;cursor:pointer}

:root{
  --bg:#02040a;--bg1:#060d18;--card:#0d1e30;--card2:#111e2e;
  --g:#00ff88;--g2:#00cc6a;--c:#00d4ff;--p:#9b59ff;--o:#ff6b35;--y:#ffd700;
  --t:#d8e8ff;--m:#4a637a;--m2:#253545;
  --b1:rgba(0,255,136,.14);--b2:rgba(0,212,255,.12);--b3:rgba(255,255,255,.07);
  --glow:0 0 50px rgba(0,255,136,.35),0 0 100px rgba(0,255,136,.1);
  --glow-c:0 0 50px rgba(0,212,255,.3);
  --ease:cubic-bezier(.22,1,.36,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
  --fh:'Orbitron',monospace;--fs:'Space Grotesk',sans-serif;--fb:'Barlow Condensed',sans-serif;
}

/* ── CUSTOM CURSOR ── */
#cur-dot,#cur-ring{
  position:fixed;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition-property:width,height,background,border-color,opacity;
  transition-duration:.2s;
}
#cur-dot{
  width:8px;height:8px;background:var(--g);border-radius:50%;
  box-shadow:0 0 12px var(--g),0 0 24px rgba(0,255,136,.4);
  will-change:left,top;
}
#cur-ring{
  width:36px;height:36px;border:1.5px solid rgba(0,255,136,.5);
  border-radius:50%;will-change:left,top;
  transition:left .08s linear,top .08s linear,width .3s var(--ease),height .3s var(--ease),border-color .3s;
}
.hover-active #cur-dot{width:12px;height:12px;background:var(--c);box-shadow:0 0 16px var(--c)}
.hover-active #cur-ring{width:52px;height:52px;border-color:rgba(0,212,255,.45)}
@media(hover:none),(max-width:768px){#cur-dot,#cur-ring{display:none}}

/* ── CANVAS ── */
#bgCanvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.7}

/* ── GRAIN ── */
#grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px;animation:grn .5s steps(3) infinite}
@keyframes grn{0%{transform:translate(0,0)}50%{transform:translate(-3px,2px)}100%{transform:translate(2px,-2px)}}

/* ── DOT GRID ── */
.dot-bg{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(0,255,136,.22) 1px,transparent 1px);
  background-size:30px 30px;
  mask-image:radial-gradient(ellipse 90% 85% at 50% 50%,rgba(0,0,0,.6) 0%,transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 90% 85% at 50% 50%,rgba(0,0,0,.6) 0%,transparent 70%);
  animation:dotShift 18s linear infinite;
}
@keyframes dotShift{from{background-position:0 0}to{background-position:30px 30px}}

/* ── LAYOUT ── */
.W{max-width:1320px;margin:0 auto;padding:0 60px;position:relative;z-index:2}
.pad{padding:120px 0}
section{position:relative;z-index:2}

/* ── TYPOGRAPHY ── */
.lbl{display:inline-flex;align-items:center;gap:10px;font-family:var(--fb);font-size:.68rem;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--g);margin-bottom:14px}
.lbl::before{content:'';width:28px;height:1px;background:linear-gradient(90deg,var(--g),var(--c))}
.hdg{font-family:var(--fh);font-size:clamp(1.8rem,3.4vw,3.2rem);font-weight:900;line-height:1.08;letter-spacing:-.5px;color:var(--t)}
.hdg .ag{color:var(--g)}.hdg .ac{color:var(--c)}.hdg .ap{color:var(--p)}
.sub{font-size:.96rem;color:var(--m);line-height:1.85;max-width:550px;margin-top:14px}

/* ── REVEAL ── */
.rv,.rl,.rr{opacity:0;transition:opacity .9s var(--ease),transform .9s var(--ease)}
.rv{transform:translateY(45px)}
.rl{transform:translateX(-55px)}
.rr{transform:translateX(55px)}
.rv.on,.rl.on,.rr.on{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}
.d4{transition-delay:.4s}.d5{transition-delay:.5s}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--fb);font-size:.78rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;border-radius:3px;padding:13px 30px;transition:all .35s var(--ease);position:relative;overflow:hidden;white-space:nowrap}
.bg{background:var(--g);color:#000}
.bg::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--g),var(--c));opacity:0;transition:opacity .35s}
.bg:hover{box-shadow:var(--glow);transform:translateY(-3px)}.bg:hover::before{opacity:1}
.bg>*{position:relative;z-index:1}
.bc{border:1px solid rgba(0,212,255,.32);color:var(--c);background:rgba(0,212,255,.04)}
.bc:hover{border-color:var(--c);box-shadow:var(--glow-c);transform:translateY(-3px);background:rgba(0,212,255,.08)}
.bgh{border:1px solid var(--b3);color:var(--m)}.bgh:hover{border-color:var(--b1);color:var(--t);background:rgba(0,255,136,.04)}

/* ==========================================
   NAVIGATION
   ========================================== */
#nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:22px 60px;display:flex;align-items:center;justify-content:space-between;transition:all .5s var(--ease)}
#nav.sc{padding:12px 60px;background:rgba(2,4,10,.95);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border-bottom:1px solid var(--b1)}
.nlogo{font-family:var(--fh);font-size:1.05rem;font-weight:900;letter-spacing:4px;display:flex;align-items:center;gap:8px}
.nlogo-dot{width:8px;height:8px;background:var(--g);border-radius:50%;box-shadow:0 0 10px var(--g);animation:blink 2.2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.nlogo span{color:var(--g)}
.nlinks{display:flex;gap:32px;align-items:center}
.nlinks a{font-family:var(--fb);font-size:.75rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--m);transition:color .3s;position:relative}
.nlinks a::after{content:'';position:absolute;bottom:-5px;left:0;width:0;height:1px;background:linear-gradient(90deg,var(--g),var(--c));transition:width .35s var(--ease)}
.nlinks a:hover{color:var(--t)}.nlinks a:hover::after{width:100%}
.nhire{display:flex;align-items:center;gap:7px;font-family:var(--fb);font-size:.73rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:9px 22px;border:1px solid var(--g);color:var(--g);border-radius:2px;transition:all .3s}
.nhire:hover{background:var(--g);color:#000;box-shadow:var(--glow)}
.nham{display:none;flex-direction:column;gap:5px;background:none;border:none}
.nham span{width:22px;height:1.5px;background:var(--t);display:block;transition:all .3s}
#nmob{display:none;position:fixed;inset:0;background:rgba(2,4,10,.97);backdrop-filter:blur(20px);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:32px}
#nmob.on{display:flex}
#nmob a{font-family:var(--fh);font-size:1.4rem;letter-spacing:4px;text-transform:uppercase;color:var(--t);transition:color .3s}
#nmob a:hover{color:var(--g)}
#nmbtn{position:absolute;top:22px;right:22px;font-size:1.8rem;color:var(--t);background:none;border:none}

/* ==========================================
   HERO SECTION
   ========================================== */
#hero{min-height:100vh;display:flex;align-items:center;padding-top:100px;padding-bottom:60px;overflow:hidden;background:var(--bg)}
.hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}

/* Gradient orbs */
.orb{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none;animation:orbFloat 12s ease-in-out infinite}
.orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(0,255,136,.1),transparent 70%);right:-80px;top:-100px;animation-duration:11s}
.orb-2{width:450px;height:450px;background:radial-gradient(circle,rgba(0,212,255,.09),transparent 70%);left:-80px;bottom:5%;animation-duration:14s;animation-delay:-5s}
.orb-3{width:350px;height:350px;background:radial-gradient(circle,rgba(155,95,255,.08),transparent 70%);top:40%;right:28%;animation-duration:9s;animation-delay:-3s}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(25px,-30px) scale(1.06)}}

/* Horizontal light lines */
.hlines{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.hline{position:absolute;height:1px;background:linear-gradient(90deg,transparent,rgba(0,255,136,.28),transparent);animation:hlineAnim 12s ease-in-out infinite}
.hline:nth-child(1){top:22%;width:50%;left:0;animation-delay:0s}
.hline:nth-child(2){top:52%;width:65%;right:0;animation-delay:2.5s}
.hline:nth-child(3){top:76%;width:42%;left:12%;animation-delay:5s}
@keyframes hlineAnim{0%,100%{opacity:0;transform:scaleX(0);transform-origin:left}50%{opacity:1;transform:scaleX(1)}}

/* Conic sweep */
.conic-sweep{position:absolute;width:130vw;height:130vw;top:50%;left:50%;transform:translate(-50%,-50%);
  background:conic-gradient(from 0deg,transparent 0%,rgba(0,255,136,.025) 8%,transparent 18%,rgba(0,212,255,.02) 32%,transparent 42%,rgba(155,95,255,.018) 58%,transparent 68%,rgba(0,255,136,.025) 83%,transparent 100%);
  animation:conicSpin 45s linear infinite;pointer-events:none}
@keyframes conicSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}

/* Code floating chars */
.float-code{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.fc{position:absolute;font-family:var(--fh);font-size:.62rem;color:rgba(0,255,136,.07);letter-spacing:2px;animation:fcFloat linear infinite}
@keyframes fcFloat{0%{transform:translateY(110vh);opacity:0}10%{opacity:1}90%{opacity:.5}100%{transform:translateY(-15vh);opacity:0}}

/* HERO GRID */
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;width:100%}

/* HERO LEFT */
.hero-badge{display:inline-flex;align-items:center;gap:9px;padding:6px 16px;border:1px solid var(--b1);border-radius:100px;font-family:var(--fb);font-size:.66rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--g);background:rgba(0,255,136,.05);margin-bottom:24px;opacity:0;animation:fadeUp .8s var(--ease) .2s forwards}
.badge-dot{width:7px;height:7px;background:var(--g);border-radius:50%;box-shadow:0 0 10px var(--g);flex-shrink:0;animation:blink 2s ease-in-out infinite}
@keyframes fadeUp{from{opacity:0;transform:translateY(25px)}to{opacity:1;transform:none}}

/* Hero title - smaller to fit */
.hero-title{font-family:var(--fh);font-size:clamp(1.9rem,3.8vw,4rem);font-weight:900;line-height:1.05;letter-spacing:-1.5px;margin-bottom:22px;opacity:0;animation:fadeUp .9s var(--ease) .4s forwards}
.hero-title .t1{display:block;color:var(--t)}
.hero-title .t2{display:block;background:linear-gradient(90deg,var(--g) 0%,var(--c) 40%,var(--p) 70%,var(--g) 100%);background-size:250%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradShift 4s linear infinite}
@keyframes gradShift{0%{background-position:0%}100%{background-position:250%}}
.hero-title .t3{display:block;color:rgba(216,232,255,.65);font-size:.72em;font-weight:700;letter-spacing:-.5px;margin-top:3px}

.hero-sub{font-size:.96rem;line-height:1.88;color:var(--m);max-width:490px;margin-bottom:36px;opacity:0;animation:fadeUp .9s var(--ease) .6s forwards}
.hero-sub strong{color:var(--t);font-weight:500}

.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:52px;opacity:0;animation:fadeUp .9s var(--ease) .8s forwards}
.hero-stats{display:flex;gap:44px;flex-wrap:wrap;opacity:0;animation:fadeUp .9s var(--ease) 1s forwards}
.stat-n{font-family:var(--fh);font-size:2.3rem;font-weight:900;color:var(--g);display:block;line-height:1;text-shadow:0 0 35px rgba(0,255,136,.4)}
.stat-l{font-family:var(--fb);font-size:.66rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--m);display:block;margin-top:5px}

/* HERO RIGHT — Photo */
.hero-visual{display:flex;justify-content:center;align-items:center;position:relative;opacity:0;animation:fadeUp 1s var(--ease) .5s forwards}
.photo-wrap{position:relative;width:400px;height:480px}

/* Rotating border */
.photo-border{position:absolute;inset:-3px;border-radius:14px;animation:borderSpin 5s linear infinite;pointer-events:none}
@keyframes borderSpin{
  0%{background:conic-gradient(from 0deg,var(--g) 0%,var(--c) 25%,var(--p) 50%,transparent 60%,var(--g) 100%)}
  100%{background:conic-gradient(from 360deg,var(--g) 0%,var(--c) 25%,var(--p) 50%,transparent 60%,var(--g) 100%)}
}
.photo-border-inner{position:absolute;inset:2px;border-radius:12px;background:var(--bg);z-index:0}

.photo-glow{position:absolute;inset:-50px;background:radial-gradient(ellipse,rgba(0,255,136,.12),transparent 60%);animation:glowPulse 6s ease-in-out infinite;border-radius:50%;pointer-events:none}
@keyframes glowPulse{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}

.photo-frame{position:absolute;inset:0;border-radius:12px;overflow:hidden;background:#0a1525;z-index:1}
.photo-frame::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--g),var(--c),var(--p),transparent);z-index:2}
.photo-frame::after{content:'';position:absolute;bottom:0;left:0;right:0;height:130px;background:linear-gradient(to top,var(--bg),transparent);z-index:2;pointer-events:none}
.photo-frame img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;position:relative;z-index:1}

/* Scanlines */
.photo-scan{position:absolute;inset:0;z-index:3;border-radius:12px;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.06) 3px,rgba(0,0,0,.06) 4px)}

/* Corner brackets */
.ca{position:absolute;width:22px;height:22px;z-index:4}
.ca-tl{top:-11px;left:-11px;border-top:2.5px solid var(--g);border-left:2.5px solid var(--g)}
.ca-tr{top:-11px;right:-11px;border-top:2.5px solid var(--g);border-right:2.5px solid var(--g)}
.ca-bl{bottom:-11px;left:-11px;border-bottom:2.5px solid var(--g);border-left:2.5px solid var(--g)}
.ca-br{bottom:-11px;right:-11px;border-bottom:2.5px solid var(--g);border-right:2.5px solid var(--g)}

/* STATUS */
.photo-status{position:absolute;bottom:-36px;left:0;right:0;display:flex;align-items:center;gap:8px;font-family:var(--fh);font-size:.5rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--m);justify-content:center;z-index:5}
.photo-status::before,.photo-status::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--m2))}

/* FLOATING PILLS — right side */
.fpills{position:absolute;right:-170px;top:10px;display:flex;flex-direction:column;gap:10px;z-index:6}
.fpill{display:flex;align-items:center;gap:8px;padding:8px 14px;background:rgba(6,13,24,.92);border:1px solid;border-radius:100px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);font-family:var(--fb);font-size:.66rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;white-space:nowrap;animation:pillFloat 7s ease-in-out infinite}
.fpill i{font-size:.82rem;flex-shrink:0}
.fpill-g{border-color:rgba(0,255,136,.25);color:var(--g);animation-delay:0s}
.fpill-c{border-color:rgba(0,212,255,.25);color:var(--c);animation-delay:1.4s}
.fpill-p{border-color:rgba(155,95,255,.25);color:var(--p);animation-delay:2.8s}
.fpill-o{border-color:rgba(255,107,53,.25);color:var(--o);animation-delay:4.2s}
.fpill-y{border-color:rgba(255,215,0,.25);color:var(--y);animation-delay:5.6s}
@keyframes pillFloat{0%,100%{transform:translateX(0)}50%{transform:translateX(-8px)}}

/* Scroll hint */
.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:7px;z-index:3;opacity:0;animation:fadeUp 1s var(--ease) 1.6s forwards}
.sh-text{font-family:var(--fb);font-size:.6rem;letter-spacing:4px;text-transform:uppercase;color:var(--m)}
.sh-line{width:1px;height:32px;background:linear-gradient(var(--g),transparent);animation:shAnim 2s ease-in-out infinite}
@keyframes shAnim{0%,100%{transform:scaleY(1);opacity:.8}50%{transform:scaleY(.35);opacity:.3}}

/* SECTION DIVIDERS — clip-path */
.clip-top{clip-path:polygon(0 5vw,100% 0,100% 100%,0 100%);margin-top:-5vw}
.clip-top-r{clip-path:polygon(0 0,100% 5vw,100% 100%,0 100%);margin-top:-5vw}
.clip-both{clip-path:polygon(0 5vw,100% 0,100% calc(100% - 5vw),0 100%);margin-top:-5vw;padding-bottom:calc(120px + 5vw)}

/* ==========================================
   MARQUEE
   ========================================== */
#mq{background:var(--bg1);border-top:1px solid var(--b1);border-bottom:1px solid var(--b1);padding:15px 0;overflow:hidden;position:relative;z-index:3}
.mq-track{display:flex;animation:mqScroll 30s linear infinite;width:max-content}
.mq-track:hover{animation-play-state:paused}
@keyframes mqScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mq-item{display:flex;align-items:center;gap:11px;padding:0 34px;font-family:var(--fb);font-size:.7rem;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--m);white-space:nowrap}
.mq-item i{font-size:.75rem;flex-shrink:0}
.mq-g{color:var(--g)}.mq-c{color:var(--c)}.mq-p{color:var(--p)}

/* ==========================================
   SERVICES
   ========================================== */
#services{background:var(--bg1);padding:120px 0}
.srv-tabs{display:flex;border:1px solid var(--b1);border-radius:10px;overflow:hidden;margin-bottom:50px;background:rgba(6,13,24,.8)}
.srv-tab{flex:1;padding:14px 16px;text-align:center;font-family:var(--fb);font-size:.73rem;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--m);border-right:1px solid var(--b1);transition:all .35s;position:relative;display:flex;align-items:center;justify-content:center;gap:7px;cursor:pointer}
.srv-tab:last-child{border-right:none}
.srv-tab i{font-size:.85rem;transition:transform .35s var(--spring)}
.srv-tab.on{color:var(--g);background:rgba(0,255,136,.06)}
.srv-tab::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--g),var(--c));transform:scaleX(0);transition:transform .35s var(--ease)}
.srv-tab.on::after{transform:scaleX(1)}
.srv-tab:hover i{transform:scale(1.15) rotate(-5deg)}
.srv-panel{display:none;animation:panIn .5s var(--ease)}
.srv-panel.on{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@keyframes panIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* SERVICE CARDS */
.scard{background:var(--card);border:1px solid var(--b3);border-radius:12px;padding:34px 26px;transition:all .5s var(--ease);position:relative;overflow:hidden;cursor:default}
.scard::before{content:'';position:absolute;top:0;left:0;right:0;height:0;background:linear-gradient(180deg,rgba(0,255,136,.06),transparent);transition:height .5s var(--ease);pointer-events:none}
.scard::after{content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,255,136,.04),transparent);transition:left .8s var(--ease);pointer-events:none}
.scard:hover{border-color:rgba(0,255,136,.5);transform:translateY(-9px) scale(1.01);box-shadow:0 28px 70px rgba(0,0,0,.55),0 0 0 1px rgba(0,255,136,.08),0 0 40px rgba(0,255,136,.05)}
.scard:hover::before{height:100%}
.scard:hover::after{left:150%}
.scard-num{font-family:var(--fh);font-size:.48rem;letter-spacing:4px;color:var(--m2);margin-bottom:14px}
.scard-ico{width:54px;height:54px;border-radius:11px;margin-bottom:18px;display:flex;align-items:center;justify-content:center;background:rgba(0,255,136,.06);border:1px solid var(--b1);transition:all .5s var(--ease)}
.scard-ico i{font-size:1.35rem;color:var(--g);transition:transform .4s var(--spring)}
.scard:hover .scard-ico{background:rgba(0,255,136,.13);box-shadow:0 0 28px rgba(0,255,136,.22);border-color:rgba(0,255,136,.28)}
.scard:hover .scard-ico i{transform:scale(1.12) rotate(-5deg)}
.scard-title{font-family:var(--fb);font-size:1.05rem;font-weight:700;color:var(--t);margin-bottom:10px;transition:color .3s}
.scard:hover .scard-title{color:var(--g)}
.scard-desc{font-size:.875rem;color:var(--m);line-height:1.78}
.scard-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:14px}
.stag{padding:3px 9px;background:rgba(0,255,136,.04);border:1px solid var(--b1);border-radius:100px;font-size:.62rem;color:var(--m);transition:all .3s}
.scard:hover .stag{border-color:rgba(0,255,136,.2);color:rgba(0,255,136,.7)}

/* ==========================================
   ABOUT
   ========================================== */
#about{background:var(--bg);padding:120px 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-photo{position:relative;height:520px}
.ap-shadow{position:absolute;inset:20px -20px -20px 20px;background:var(--card);border:1px solid var(--b1);border-radius:12px}
.ap-frame{position:absolute;inset:0;overflow:hidden;border-radius:12px;border:1px solid rgba(0,255,136,.25)}
.ap-frame::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--g),var(--c),transparent);z-index:2}
.ap-frame::after{content:'';position:absolute;bottom:0;left:0;right:0;height:150px;background:linear-gradient(to top,var(--bg),transparent);z-index:2;pointer-events:none}
.ap-frame img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.ap-badge{position:absolute;bottom:28px;right:-14px;z-index:3;background:var(--card);border:1px solid var(--b1);border-radius:10px;padding:16px 20px;text-align:center;box-shadow:0 18px 50px rgba(0,0,0,.5)}
.apb-n{font-family:var(--fh);font-size:2rem;font-weight:900;color:var(--g);text-shadow:0 0 25px rgba(0,255,136,.4);display:block;line-height:1}
.apb-l{font-family:var(--fb);font-size:.64rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--m)}

.about-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:22px 0}
.acard{background:var(--card);border:1px solid var(--b3);border-radius:8px;padding:13px 15px;transition:all .35s var(--ease);position:relative;overflow:hidden}
.acard::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--g),var(--c));transform:scaleX(0);transition:transform .35s}
.acard:hover{border-color:var(--b1);transform:translateY(-3px)}.acard:hover::after{transform:scaleX(1)}
.acard-n{font-family:var(--fh);font-size:1.55rem;font-weight:900;color:var(--g);text-shadow:0 0 18px rgba(0,255,136,.35);display:block;line-height:1}
.acard-l{font-family:var(--fb);font-size:.66rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--m);margin-top:3px}

.about-list{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:26px}
.ali{display:flex;align-items:center;gap:8px;font-family:var(--fb);font-size:.8rem;font-weight:600;color:var(--t)}
.ali i{color:var(--g);font-size:.82rem;width:14px;flex-shrink:0}

/* ==========================================
   NUMBERS STRIP
   ========================================== */
#numbers{background:var(--bg1);border-top:1px solid var(--b3);border-bottom:1px solid var(--b3);position:relative;z-index:3}
.num-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(255,255,255,.05);border-radius:12px;overflow:hidden}
.num-item{text-align:center;padding:52px 16px;border-right:1px solid var(--b3);position:relative;overflow:hidden;transition:background .4s}
.num-item:last-child{border-right:none}
.num-item::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(0,255,136,.05),transparent 70%);opacity:0;transition:opacity .5s;pointer-events:none}
.num-item:hover::before{opacity:1}
.num-item i{font-size:1.5rem;color:var(--g);margin-bottom:10px;display:block;opacity:.7;transition:transform .4s var(--spring)}
.num-item:hover i{transform:scale(1.18) rotate(-5deg)}
.num-n{font-family:var(--fh);font-size:2.8rem;font-weight:900;color:var(--g);text-shadow:0 0 35px rgba(0,255,136,.38);display:block;line-height:1}
.num-l{font-family:var(--fb);font-size:.68rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--m);margin-top:7px;display:block}

/* ==========================================
   SKILLS
   ========================================== */
#skills{background:var(--bg);padding:120px 0}
.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.sk-row{margin-bottom:26px}
.sk-top{display:flex;justify-content:space-between;margin-bottom:9px;align-items:center}
.sk-name{font-family:var(--fb);font-size:.8rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--t);display:flex;align-items:center;gap:8px}
.sk-name i{color:var(--g);font-size:.85rem}
.sk-pct{font-family:var(--fh);font-size:.7rem;color:var(--g)}
.sk-track{height:3px;background:rgba(255,255,255,.06);border-radius:100px;overflow:visible;position:relative}
.sk-fill{height:100%;border-radius:100px;width:0;transition:width 1.8s var(--ease);position:relative}
.sk-fill::after{content:'';position:absolute;right:-2px;top:-6px;width:14px;height:14px;border-radius:50%;background:inherit;box-shadow:0 0 16px currentColor;animation:dotPulse 2.2s ease-in-out infinite}
@keyframes dotPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.4)}}
.fill-g{background:linear-gradient(90deg,var(--g2),var(--g))}
.fill-c{background:linear-gradient(90deg,#007799,var(--c))}
.fill-p{background:linear-gradient(90deg,#5d1fe0,var(--p))}

.circles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.circle-wrap{text-align:center}
.circ{width:100px;height:100px;margin:0 auto 10px;position:relative}
.circ svg{width:100%;height:100%;transform:rotate(-90deg)}
.circ-track{fill:none;stroke:rgba(255,255,255,.05);stroke-width:7}
.circ-fill{fill:none;stroke-width:7;stroke-linecap:round;stroke-dasharray:283;stroke-dashoffset:283;transition:stroke-dashoffset 1.9s var(--ease)}
.fill-stroke-g{stroke:var(--g)}.fill-stroke-c{stroke:var(--c)}.fill-stroke-p{stroke:var(--p)}
.circ-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.85rem;font-weight:800;color:var(--t)}
.circ-label{font-family:var(--fb);font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--m)}

/* ==========================================
   PORTFOLIO — FULLY FIXED
   ========================================== */
#port{background:var(--bg1);padding:120px 0}
.port-filters{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:48px}
.pf-btn{padding:8px 18px;border:1px solid var(--b3);border-radius:3px;font-family:var(--fb);font-size:.7rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--m);transition:all .3s;display:flex;align-items:center;gap:6px;cursor:pointer}
.pf-btn i{font-size:.78rem;transition:transform .3s var(--spring)}
.pf-btn:hover,.pf-btn.on{border-color:var(--g);color:var(--g);background:rgba(0,255,136,.05)}
.pf-btn:hover i{transform:scale(1.15)}
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

.pf-card{background:var(--card);border:1px solid var(--b3);border-radius:12px;overflow:hidden;transition:border-color .5s,transform .5s var(--ease),box-shadow .5s;cursor:default}
.pf-card:hover{border-color:rgba(0,255,136,.45);transform:translateY(-10px);box-shadow:0 32px 80px rgba(0,0,0,.6),0 0 35px rgba(0,255,136,.05)}
.pf-card.hidden{display:none}

/* IMAGE SCROLL EFFECT — image scrolls first, overlay appears after */
.pf-thumb{height:250px;overflow:hidden;position:relative;background:var(--card2)}
.pf-thumb img{
  width:100%;height:220%;
  object-fit:cover;object-position:top center;
  transform:translateY(0);
  transition:transform 5.5s cubic-bezier(.19,.9,.37,.99);
  display:block;will-change:transform;
  pointer-events:none;
}
.pf-card:hover .pf-thumb img{transform:translateY(-45.4%)}

/* Overlay with delay — see full image first */
.pf-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(13,30,48,.95) 0%,rgba(13,30,48,.3) 55%,transparent 100%);
  opacity:0;
  transition:opacity .6s ease;
  transition-delay:2s;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
}
.pf-card:hover .pf-overlay{opacity:1;pointer-events:all}

.pf-view-btn{
  display:flex;align-items:center;gap:8px;
  padding:10px 22px;background:var(--g);color:#000;
  border-radius:3px;font-family:var(--fb);font-size:.73rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;
  transform:translateY(16px);
  transition:transform .5s var(--ease),box-shadow .3s;
  transition-delay:2.1s;
  cursor:pointer;border:none;font-family:var(--fb);
}
.pf-card:hover .pf-view-btn{transform:translateY(0);box-shadow:var(--glow)}
.pf-view-btn i{font-size:.8rem}

.pf-info{padding:18px 22px}
.pf-cat{font-family:var(--fb);font-size:.6rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g);margin-bottom:6px}
.pf-name{font-family:var(--fb);font-size:1rem;font-weight:700;color:var(--t);margin-bottom:9px;line-height:1.3}
.pf-techs{display:flex;gap:5px;flex-wrap:wrap}
.pf-tech{padding:2px 8px;background:rgba(0,255,136,.04);border:1px solid var(--b1);border-radius:100px;font-size:.6rem;color:var(--m)}

/* LIGHTBOX */
#lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:99990;align-items:center;justify-content:center;padding:30px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
#lightbox.on{display:flex;animation:lbFade .3s ease}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
#lb-img{max-width:88%;max-height:88vh;border-radius:10px;border:1px solid var(--b1);box-shadow:0 0 80px rgba(0,0,0,.9);object-fit:contain}
#lb-close{position:absolute;top:22px;right:26px;font-size:1.8rem;color:var(--t);transition:color .3s,transform .3s;background:none;border:none;cursor:pointer;line-height:1}
#lb-close:hover{color:var(--g);transform:rotate(90deg)}

/* ==========================================
   COMPETENCIES
   ========================================== */
#comp{background:var(--bg);padding:120px 0}
.comp-tabs{display:flex;flex-wrap:wrap;border:1px solid var(--b1);border-radius:12px;overflow:hidden;margin-bottom:50px;background:rgba(6,13,24,.8)}
.comp-tab{flex:1;min-width:120px;padding:15px 16px;font-family:var(--fb);font-size:.72rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--m);transition:all .35s;text-align:center;border-right:1px solid var(--b1);display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;position:relative}
.comp-tab:last-child{border-right:none}
.comp-tab i{font-size:.88rem}
.comp-tab::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,255,136,.07),rgba(0,212,255,.04));opacity:0;transition:opacity .35s}
.comp-tab.on{color:var(--g);background:rgba(0,255,136,.05)}.comp-tab.on::before{opacity:1}
.comp-panel{display:none;animation:panIn .4s var(--ease)}
.comp-panel.on{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.comp-feat{display:flex;gap:14px;margin-bottom:24px;align-items:flex-start}
.comp-ico{width:44px;height:44px;background:rgba(0,255,136,.06);border:1px solid var(--b1);border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}
.comp-ico i{font-size:1.05rem;color:var(--g);transition:transform .35s var(--spring)}
.comp-feat:hover .comp-ico{background:rgba(0,255,136,.12);box-shadow:0 0 18px rgba(0,255,136,.15)}
.comp-feat:hover .comp-ico i{transform:scale(1.15) rotate(-5deg)}
.comp-h{font-family:var(--fb);font-size:.98rem;font-weight:700;color:var(--t);margin-bottom:5px}
.comp-d{font-size:.86rem;color:var(--m);line-height:1.72}
.comp-stats{background:var(--card);border:1px solid var(--b1);border-radius:12px;padding:28px;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}
.comp-stats::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--g),var(--c),transparent)}
.cs-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--b3)}
.cs-row:last-child{border-bottom:none}
.cs-l{font-family:var(--fb);font-size:.75rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--m)}
.cs-v{font-family:var(--fh);font-size:1.25rem;font-weight:800;color:var(--g)}

/* ==========================================
   REVIEWS — 3 AT A TIME (FIXED)
   ========================================== */
#reviews{background:var(--bg1);padding:120px 0}
.reviews-wrap{overflow:hidden;position:relative;border-radius:4px}
.reviews-track{display:flex;gap:20px;transition:transform .85s var(--ease);will-change:transform}
.review-card{
  flex-shrink:0;
  background:var(--card);border:1px solid var(--b3);border-radius:12px;
  padding:32px 28px;position:relative;overflow:hidden;
  transition:border-color .4s,transform .4s var(--ease),box-shadow .4s;
  cursor:default;
}
.review-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--g),transparent);opacity:0;transition:opacity .4s}
.review-card::after{content:'';position:absolute;top:0;left:-80%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(0,255,136,.055),transparent);transform:skewX(-15deg);transition:left .75s var(--ease);pointer-events:none}
.review-card:hover{border-color:rgba(0,255,136,.4);transform:translateY(-8px) scale(1.012);box-shadow:0 24px 60px rgba(0,0,0,.55),0 0 0 1px rgba(0,255,136,.08),0 0 40px rgba(0,255,136,.07)}
.review-card:hover::before{opacity:1}
.review-card:hover::after{left:130%}
.rq-mark{position:absolute;top:14px;right:18px;font-family:Georgia,serif;font-size:5rem;color:rgba(0,255,136,.06);line-height:1}
.r-stars{color:var(--y);font-size:1rem;letter-spacing:3px;margin-bottom:13px;display:inline-block;transition:transform .3s var(--spring),filter .3s}
.review-card:hover .r-stars{transform:scale(1.1);filter:drop-shadow(0 0 6px rgba(255,215,0,.5))}
.r-text{font-size:.88rem;line-height:1.85;color:var(--m);font-style:italic;margin-bottom:22px}
.r-author{display:flex;align-items:center;gap:11px}
.r-av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--g),var(--c));display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.75rem;font-weight:800;color:#000;flex-shrink:0}
.r-name{font-family:var(--fb);font-size:.93rem;font-weight:700;color:var(--t)}
.r-role{font-size:.76rem;color:var(--m)}
.r-plat{display:inline-flex;align-items:center;gap:4px;font-family:var(--fb);font-size:.6rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:2px 8px;border:1px solid var(--b1);border-radius:100px;color:var(--g);margin-top:4px}
.r-plat i{font-size:.68rem}

.reviews-nav{display:flex;justify-content:center;gap:11px;margin-top:40px;align-items:center}
.rnav-btn{width:40px;height:40px;background:var(--card);border:1px solid var(--b3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--m);font-size:.95rem;transition:all .3s;cursor:pointer}
.rnav-btn:hover{border-color:var(--g);color:var(--g);box-shadow:0 0 20px rgba(0,255,136,.22)}
.r-dots{display:flex;gap:7px;align-items:center}
.r-dot{width:6px;height:6px;background:var(--m2);border-radius:100px;transition:all .4s;cursor:pointer}
.r-dot.on{background:var(--g);width:20px;box-shadow:0 0 9px var(--g)}

/* ==========================================
   PARTNERS
   ========================================== */
#partners{background:var(--bg);padding:65px 0;border-top:1px solid var(--b3)}
.pt-label{text-align:center;font-family:var(--fb);font-size:.66rem;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--m);margin-bottom:36px}
.pt-outer{overflow:hidden;position:relative}
.pt-outer::before,.pt-outer::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.pt-outer::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.pt-outer::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.pt-track{display:flex;animation:ptScroll 22s linear infinite;width:max-content}
.pt-track:hover{animation-play-state:paused}
@keyframes ptScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.pt-item{padding:0 44px;opacity:.35;filter:grayscale(1);transition:all .3s}
.pt-item:hover{opacity:1;filter:grayscale(0)}
.pt-name{font-family:var(--fh);font-size:.85rem;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--t);white-space:nowrap}
.pt-name span{color:var(--g)}

/* ==========================================
   PROCESS
   ========================================== */
#process{background:var(--bg1);padding:120px 0;overflow:hidden}
.proc-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;position:relative}
.proc-grid::before{content:'';position:absolute;left:50%;top:50px;bottom:50px;width:1px;background:linear-gradient(to bottom,var(--g),var(--c),var(--p),transparent);opacity:.18;transform:translateX(-50%)}
.proc-left{padding-right:55px;display:flex;flex-direction:column;gap:56px;text-align:right;align-items:flex-end}
.proc-right{padding-left:55px;display:flex;flex-direction:column;gap:56px;margin-top:90px}
.proc-item{max-width:400px}
.proc-step{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.82rem;font-weight:800;margin-bottom:16px;transition:transform .35s var(--spring),box-shadow .35s}
.proc-left .proc-step{margin-left:auto}
.proc-item:hover .proc-step{transform:scale(1.08)}
.ps1{background:rgba(0,255,136,.08);border:1px solid rgba(0,255,136,.32);color:var(--g)}
.ps2{background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.32);color:var(--c)}
.ps3{background:rgba(155,95,255,.08);border:1px solid rgba(155,95,255,.32);color:var(--p)}
.ps4{background:rgba(255,107,53,.08);border:1px solid rgba(255,107,53,.32);color:var(--o)}
.proc-item:hover .ps1{box-shadow:0 0 28px rgba(0,255,136,.28)}
.proc-item:hover .ps2{box-shadow:0 0 28px rgba(0,212,255,.28)}
.proc-item:hover .ps3{box-shadow:0 0 28px rgba(155,95,255,.28)}
.proc-item:hover .ps4{box-shadow:0 0 28px rgba(255,107,53,.28)}
.proc-t{font-family:var(--fb);font-size:1.08rem;font-weight:700;color:var(--t);margin-bottom:8px}
.proc-d{font-size:.86rem;color:var(--m);line-height:1.75}

/* ==========================================
   BLOG
   ========================================== */
#blog{background:var(--bg);padding:120px 0}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.blog-card{background:var(--card);border:1px solid var(--b3);border-radius:12px;overflow:hidden;transition:all .5s var(--ease)}
.blog-card:hover{border-color:rgba(0,255,136,.38);transform:translateY(-7px);box-shadow:0 26px 65px rgba(0,0,0,.5)}
.blog-img{height:195px;overflow:hidden;position:relative;background:var(--card2)}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);display:block}
.blog-card:hover .blog-img img{transform:scale(1.06)}
.blog-cat{position:absolute;top:13px;left:13px;background:rgba(2,4,10,.82);backdrop-filter:blur(8px);padding:4px 11px;border-radius:100px;font-family:var(--fb);font-size:.6rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g);border:1px solid var(--b1)}
.blog-body{padding:22px}
.blog-title{font-family:var(--fb);font-size:1rem;font-weight:700;color:var(--t);margin-bottom:9px;line-height:1.35}
.blog-exc{font-size:.85rem;color:var(--m);line-height:1.72;margin-bottom:14px}
.blog-meta{display:flex;gap:14px;font-family:var(--fb);font-size:.64rem;font-weight:600;letter-spacing:1px;color:var(--m2)}
.blog-meta i{font-size:.72rem}
.blog-link{display:inline-flex;align-items:center;gap:6px;color:var(--g);font-family:var(--fb);font-size:.68rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-top:11px;transition:gap .3s}
.blog-card:hover .blog-link{gap:10px}

/* ==========================================
   CTA
   ========================================== */
#cta{background:var(--bg1);padding:120px 0;text-align:center;position:relative;overflow:hidden}
.cta-orb{position:absolute;width:650px;height:650px;background:radial-gradient(circle,rgba(0,255,136,.07),transparent 60%);border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;animation:glowPulse 5s ease-in-out infinite}
.cta-ring1{position:absolute;width:480px;height:480px;border:1px solid rgba(0,255,136,.07);border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);animation:conicSpin 20s linear infinite;pointer-events:none}
.cta-ring2{position:absolute;width:340px;height:340px;border:1px solid rgba(0,212,255,.06);border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);animation:conicSpin 14s linear infinite reverse;pointer-events:none}
.cta-title{font-family:var(--fh);font-size:clamp(1.9rem,4.2vw,3.9rem);font-weight:900;line-height:1.07;color:var(--t);margin-bottom:20px;position:relative;z-index:1}
.cta-grad{background:linear-gradient(90deg,var(--g),var(--c));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cta-sub{font-size:.96rem;color:var(--m);max-width:480px;margin:0 auto 44px;line-height:1.82;position:relative;z-index:1}
.cta-btns{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.btn-wa{display:inline-flex;align-items:center;gap:9px;padding:13px 34px;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;font-family:var(--fb);font-size:.78rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;border-radius:3px;transition:all .35s}
.btn-wa:hover{box-shadow:0 0 40px rgba(37,211,102,.4);transform:translateY(-3px)}

/* ==========================================
   CONTACT
   ========================================== */
#contact{background:var(--bg);padding:120px 0}
.contact-grid{display:grid;grid-template-columns:1fr 1.55fr;gap:60px;align-items:start}
.c-info-block{display:flex;gap:14px;align-items:flex-start;margin-bottom:24px}
.c-icon{width:48px;height:48px;background:rgba(0,255,136,.06);border:1px solid var(--b1);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}
.c-icon i{font-size:1.15rem;color:var(--g);transition:transform .35s var(--spring)}
.c-info-block:hover .c-icon{background:rgba(0,255,136,.12);box-shadow:0 0 18px rgba(0,255,136,.14)}
.c-info-block:hover .c-icon i{transform:scale(1.12) rotate(-5deg)}
.c-label{font-family:var(--fb);font-size:.66rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--m);margin-bottom:3px}
.c-val{font-size:.9rem;color:var(--t);line-height:1.6}
.c-socials{display:flex;gap:9px;margin-top:28px}
.c-soc{width:40px;height:40px;background:var(--card);border:1px solid var(--b3);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--m);transition:all .35s}
.c-soc i{font-size:.95rem;transition:transform .35s var(--spring)}
.c-soc:hover{color:var(--g);border-color:var(--g);background:rgba(0,255,136,.06);transform:translateY(-3px)}
.c-soc:hover i{transform:scale(1.12)}

.c-form{background:var(--card);border:1px solid var(--b1);border-radius:12px;padding:40px 36px;position:relative;overflow:hidden}
.c-form::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--g),var(--c),transparent)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-group{margin-bottom:14px}
.form-label{display:block;font-family:var(--fb);font-size:.66rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--m);margin-bottom:7px}
.form-input,.form-select,.form-textarea{width:100%;background:rgba(255,255,255,.03);border:1px solid var(--b3);border-radius:6px;padding:11px 14px;font-family:var(--fs);font-size:.9rem;color:var(--t);transition:border-color .3s,box-shadow .3s;outline:none;-webkit-appearance:none;appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(0,255,136,.08)}
.form-textarea{resize:vertical;min-height:115px}
.form-select option{background:var(--card);color:var(--t)}
::placeholder{color:var(--m2)}
.form-submit{width:100%;padding:14px;background:var(--g);color:#000;font-family:var(--fb);font-size:.8rem;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;border-radius:3px;display:flex;align-items:center;justify-content:center;gap:9px;transition:all .35s;cursor:pointer;border:none}
.form-submit i{transition:transform .35s var(--spring)}
.form-submit:hover{box-shadow:var(--glow);transform:translateY(-2px)}
.form-submit:hover i{transform:translateX(4px)}
.form-success{display:none;margin-top:13px;text-align:center;font-family:var(--fb);font-size:.75rem;font-weight:700;letter-spacing:2.5px;color:var(--g)}

/* ==========================================
   FOOTER
   ========================================== */
#footer{background:var(--bg1);border-top:1px solid var(--b1);padding:65px 0 36px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:52px}
.foot-logo{font-family:var(--fh);font-size:1.02rem;font-weight:900;letter-spacing:4px;display:flex;align-items:center;gap:7px;margin-bottom:13px}
.foot-logo span{color:var(--g)}
.foot-p{font-size:.86rem;color:var(--m);line-height:1.8;max-width:250px;margin-bottom:22px}
.foot-socs{display:flex;gap:8px}
.foot-soc{width:36px;height:36px;background:var(--card);border:1px solid var(--b3);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--m);font-size:.88rem;transition:all .35s}
.foot-soc i{transition:transform .35s var(--spring)}
.foot-soc:hover{color:var(--g);border-color:var(--g);background:rgba(0,255,136,.06);transform:translateY(-3px)}
.foot-soc:hover i{transform:scale(1.12)}
.foot-col-title{font-family:var(--fb);font-size:.7rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--t);margin-bottom:16px}
.foot-link{display:flex;align-items:center;gap:7px;font-size:.85rem;color:var(--m);margin-bottom:10px;transition:color .3s}
.foot-link i{font-size:.77rem;color:var(--m2);transition:color .3s,transform .3s}
.foot-link:hover{color:var(--g)}.foot-link:hover i{color:var(--g);transform:translateX(3px)}
.foot-bottom{border-top:1px solid var(--b3);padding-top:26px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px}
.foot-cr{font-family:var(--fb);font-size:.68rem;font-weight:600;letter-spacing:1.5px;color:var(--m2)}
.foot-cr span{color:var(--g)}
.foot-legal{display:flex;gap:18px}
.foot-legal a{font-family:var(--fb);font-size:.66rem;letter-spacing:1.5px;color:var(--m2);transition:color .3s}
.foot-legal a:hover{color:var(--g)}

/* ==========================================
   RESPONSIVE
   ========================================== */
@media(max-width:1200px){
  .W{padding:0 40px}#nav,#nav.sc{padding-left:40px;padding-right:40px}
  .fpills{display:none}.hero-grid{gap:44px}.photo-wrap{width:350px;height:420px}
  .foot-grid{grid-template-columns:1.4fr 1fr 1fr}.foot-grid>div:last-child{display:none}
}
@media(max-width:1024px){
  .W{padding:0 32px}#nav,#nav.sc{padding-left:32px;padding-right:32px}
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-sub,.hero-btns,.hero-stats{margin-left:auto;margin-right:auto}
  .hero-btns,.hero-stats{justify-content:center}
  .hero-visual{margin-top:24px;justify-content:center}.photo-wrap{width:300px;height:360px}
  .about-grid{grid-template-columns:1fr;gap:50px}
  .about-photo{height:380px;max-width:380px;margin:0 auto}
  .skills-grid{grid-template-columns:1fr}
  .port-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
  .comp-panel.on{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr;gap:36px}
  .proc-grid::before{display:none}
  .proc-left,.proc-right{text-align:left;align-items:flex-start;padding:0;margin-top:0}
  .proc-left .proc-step{margin-left:0}
  .num-grid{grid-template-columns:repeat(2,1fr)}
  .review-card{flex-shrink:0}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:768px){
  .W{padding:0 18px}#nav,#nav.sc{padding:12px 18px}
  .nlinks,.nhire{display:none}.nham{display:flex}
  .port-grid,.blog-grid{grid-template-columns:1fr}
  .srv-panel.on{grid-template-columns:1fr!important}
  .circles-grid{grid-template-columns:repeat(2,1fr)}
  .comp-tabs{flex-direction:column}
  .comp-tab{border-right:none!important;border-bottom:1px solid var(--b1)}
  .num-grid{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:30px}
  .foot-bottom{flex-direction:column;text-align:center}
  .review-card{flex-shrink:0}
  .srv-tabs{flex-direction:column}
  .srv-tab{border-right:none!important;border-bottom:1px solid var(--b1)}
  .hero-grid{gap:36px}
  .about-grid{gap:36px}
  .port-filters{gap:6px}
  .pf-btn{padding:6px 13px;font-size:.65rem}
}
@media(max-width:480px){
  .hero-stats{flex-direction:column;align-items:center;gap:20px}
  .hero-btns,.cta-btns{flex-direction:column;align-items:center}
  .circles-grid{grid-template-columns:repeat(2,1fr)}
  .num-grid{grid-template-columns:1fr 1fr}
}

/* ═══════════════════════════════════════════════════
   ENHANCED ANIMATIONS & ICON STYLES
   ═══════════════════════════════════════════════════ */

/* ── Page Loader ── */
#lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;align-items:center;justify-content:center}
#lightbox.on{display:flex}

/* ── Animated Icon Base ── */
.ico-anim{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;transition:all .4s cubic-bezier(.34,1.56,.64,1)}

/* ── Floating animated icons in service cards ── */
.scard-ico{position:relative;width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:12px;margin-bottom:14px;background:rgba(0,255,136,.08);border:1px solid rgba(0,255,136,.15);transition:all .4s var(--ease)}
.scard-ico i{font-size:1.3rem;color:var(--g);transition:all .4s var(--ease)}
.scard:hover .scard-ico{background:rgba(0,255,136,.15);border-color:rgba(0,255,136,.4);transform:scale(1.1) rotate(-5deg);box-shadow:0 0 20px rgba(0,255,136,.2)}
.scard:hover .scard-ico i{transform:scale(1.1);animation:iconBounce .5s ease forwards}

@keyframes iconBounce{0%{transform:scale(1)}30%{transform:scale(1.25) rotate(10deg)}60%{transform:scale(0.95)}100%{transform:scale(1.05)}}

/* ── Pulse ring on stat icons ── */
.num-item i{position:relative;display:inline-block;animation:iconPulse 2.5s ease-in-out infinite}
.num-item:nth-child(2) i{animation-delay:.3s}
.num-item:nth-child(3) i{animation-delay:.6s}
.num-item:nth-child(4) i{animation-delay:.9s}
.num-item:nth-child(5) i{animation-delay:1.2s}
.num-item:nth-child(6) i{animation-delay:2.5s}
.num-item:nth-child(7) i{animation-delay:1.8s}
.num-item:nth-child(8) i{animation-delay:2.1s}
@keyframes iconPulse{0%,100%{transform:scale(1);filter:drop-shadow(0 0 4px currentColor)}50%{transform:scale(1.15);filter:drop-shadow(0 0 12px currentColor)}}

/* ── Skill bar fill animation ── */
.sk-fill{height:100%;border-radius:2px;width:0;transition:width 1.4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.sk-fill::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);animation:shimmer 2.5s ease-in-out infinite}
@keyframes shimmer{0%{left:-100%}100%{left:200%}}
.sk-fill.fill-g{background:linear-gradient(90deg,var(--g),#00ffaa)}
.sk-fill.fill-c{background:linear-gradient(90deg,var(--c),#00aaff)}
.sk-fill.fill-p{background:linear-gradient(90deg,var(--p),#cc44ff)}

/* ── Circle progress ── */
.circ-fill{fill:none;stroke:var(--g);stroke-width:6;stroke-linecap:round;stroke-dasharray:283;stroke-dashoffset:283;transform-origin:50% 50%;transform:rotate(-90deg);transition:stroke-dashoffset 1.6s cubic-bezier(.4,0,.2,1)}
.circ-track{fill:none;stroke:rgba(255,255,255,.06);stroke-width:6}
.fill-stroke-g{stroke:var(--g);filter:drop-shadow(0 0 6px rgba(0,255,136,.5))}
.fill-stroke-c{stroke:var(--c);filter:drop-shadow(0 0 6px rgba(0,212,255,.5))}
.fill-stroke-p{stroke:var(--p);filter:drop-shadow(0 0 6px rgba(155,89,255,.5))}

/* ── Portfolio card hover ── */
.pf-card{position:relative;overflow:hidden;background:var(--card);border:1px solid var(--b1);border-radius:12px;transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s}
.pf-card:hover{transform:translateY(-8px);box-shadow:0 20px 60px rgba(0,0,0,.4),0 0 0 1px rgba(0,255,136,.2);border-color:rgba(0,255,136,.25)}
.pf-thumb{position:relative;overflow:hidden;height:200px;background:var(--card2)}
.pf-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.pf-card:hover .pf-thumb img{transform:scale(1.06)}
.pf-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,255,136,.85),rgba(0,212,255,.85));display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s var(--ease)}
.pf-card:hover .pf-overlay{opacity:1}
.pf-view-btn{background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.3);color:#fff;padding:10px 20px;border-radius:4px;font-family:var(--fb);font-size:.72rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transform:translateY(10px);transition:all .3s;display:flex;align-items:center;gap:7px}
.pf-card:hover .pf-view-btn{transform:translateY(0)}
.pf-info{padding:18px}
.pf-cat{font-family:var(--fb);font-size:.62rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g);margin-bottom:6px}
.pf-name{font-family:var(--fh);font-size:.95rem;font-weight:800;color:var(--t);margin-bottom:8px;line-height:1.25}
.pf-tech{display:inline-block;background:rgba(255,255,255,.05);border:1px solid var(--b3);border-radius:3px;padding:2px 8px;font-family:var(--fb);font-size:.6rem;font-weight:600;letter-spacing:1px;color:var(--m);margin:2px;transition:all .2s}
.pf-tech:hover{border-color:var(--g);color:var(--g)}

/* ── Blog card ── */
.blog-card{background:var(--card);border:1px solid var(--b1);border-radius:12px;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s,border-color .4s}
.blog-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.35);border-color:rgba(0,212,255,.2)}
.blog-img{position:relative;height:200px;overflow:hidden;background:var(--card2)}
.blog-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.blog-card:hover .blog-img img{transform:scale(1.05)}
.blog-cat{position:absolute;bottom:12px;left:12px;background:var(--g);color:#000;font-family:var(--fb);font-size:.6rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:3px}
.blog-body{padding:20px}
.blog-title{font-family:var(--fh);font-size:1rem;font-weight:800;color:var(--t);margin-bottom:9px;line-height:1.3;transition:color .3s}
.blog-card:hover .blog-title{color:var(--g)}
.blog-exc{font-size:.83rem;color:var(--m);line-height:1.7;margin-bottom:12px}
.blog-meta{display:flex;gap:14px;flex-wrap:wrap;font-family:var(--fb);font-size:.65rem;letter-spacing:1px;color:var(--m);margin-bottom:12px}
.blog-meta i{color:var(--g);margin-right:4px}
.blog-link{display:inline-flex;align-items:center;gap:6px;font-family:var(--fb);font-size:.7rem;font-weight:700;letter-spacing:1.5px;color:var(--g);text-transform:uppercase;transition:gap .3s}
.blog-link:hover{gap:10px}
.blog-link i{transition:transform .3s}
.blog-link:hover i{transform:translateX(4px)}

/* ── Review card ── */
.review-card{background:var(--card);border:1px solid var(--b1);border-radius:12px;padding:28px;min-width:320px;max-width:400px;flex-shrink:0;transition:transform .4s var(--ease),box-shadow .4s,border-color .4s}
.review-card:hover{transform:translateY(-5px);box-shadow:0 20px 50px rgba(0,0,0,.3);border-color:rgba(0,255,136,.2)}
.rq-mark{font-family:Georgia,serif;font-size:4rem;line-height:.5;color:var(--g);opacity:.3;margin-bottom:12px}
.r-stars{color:var(--y);font-size:.9rem;margin-bottom:12px;letter-spacing:2px}
.r-text{font-size:.87rem;color:var(--m);line-height:1.78;margin-bottom:18px;font-style:italic}
.r-author{display:flex;align-items:center;gap:12px}
.r-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,rgba(0,255,136,.2),rgba(0,212,255,.2));border:1px solid rgba(0,255,136,.3);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.9rem;font-weight:900;color:var(--g);flex-shrink:0}
.r-name{font-weight:700;font-size:.88rem;color:var(--t)}
.r-role{font-size:.76rem;color:var(--m)}
.r-plat{font-family:var(--fb);font-size:.62rem;letter-spacing:1px;color:var(--g);margin-top:2px}
.r-plat i{margin-right:4px}

/* ── Contact form ── */
.c-info-block{display:flex;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:1px solid var(--b3)}
.c-icon{width:42px;height:42px;border-radius:10px;background:rgba(0,255,136,.08);border:1px solid rgba(0,255,136,.15);display:flex;align-items:center;justify-content:center;color:var(--g);font-size:1rem;flex-shrink:0;transition:all .3s}
.c-info-block:hover .c-icon{background:rgba(0,255,136,.18);border-color:rgba(0,255,136,.4);transform:scale(1.08);animation:iconBounce .4s ease}
.c-label{font-family:var(--fb);font-size:.62rem;font-weight:700;letter-spacing:2px;color:var(--m);text-transform:uppercase;margin-bottom:3px}
.c-val{font-size:.9rem;color:var(--t)}
.c-val a{color:var(--g);transition:opacity .3s}
.c-val a:hover{opacity:.75}
.c-socials{display:flex;gap:10px;margin-top:20px}
.c-soc{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid var(--b1);display:flex;align-items:center;justify-content:center;color:var(--m);font-size:.85rem;transition:all .4s cubic-bezier(.34,1.56,.64,1)}
.c-soc:hover{transform:scale(1.18) translateY(-3px);border-color:var(--g);color:var(--g);background:rgba(0,255,136,.08);box-shadow:0 8px 20px rgba(0,255,136,.2)}

/* ── CTA section ── */
.cta-title{font-family:var(--fh);font-size:clamp(2rem,5vw,3.2rem);font-weight:900;color:var(--t);margin-bottom:16px;line-height:1.1}
.cta-grad{background:linear-gradient(135deg,var(--g),var(--c));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cta-sub{color:var(--m);font-size:1rem;margin-bottom:36px;max-width:520px;margin-left:auto;margin-right:auto;line-height:1.75}
.cta-btns{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.btn-wa{display:inline-flex;align-items:center;gap:9px;font-family:var(--fb);font-size:.78rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;padding:13px 28px;background:#25d366;color:#000;border-radius:3px;transition:all .35s var(--ease)}
.btn-wa:hover{background:#20bf5b;transform:translateY(-3px);box-shadow:0 12px 40px rgba(37,211,102,.4)}

/* ── Marquee ── */
#mq{overflow:hidden;padding:14px 0;border-top:1px solid var(--b3);border-bottom:1px solid var(--b3);background:rgba(255,255,255,.015)}
.mq-track{display:flex;gap:0;animation:marqueeScroll 32s linear infinite;width:max-content}
.mq-track:hover{animation-play-state:paused}
.mq-item{display:flex;align-items:center;gap:9px;padding:6px 28px;font-family:var(--fb);font-size:.72rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;white-space:nowrap;border-right:1px solid var(--b3)}
.mq-item i{font-size:.8rem}
.mq-g{color:var(--g)}.mq-c{color:var(--c)}.mq-p{color:var(--p)}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── Floating pill badges on photo ── */
.fpills{position:absolute;inset:0;pointer-events:none}
.fpill{position:absolute;display:flex;align-items:center;gap:7px;background:rgba(2,4,10,.85);border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(10px);border-radius:100px;padding:7px 14px;font-family:var(--fb);font-size:.65rem;font-weight:700;letter-spacing:1px;white-space:nowrap;animation:pillFloat 4s ease-in-out infinite}
.fpill i{font-size:.75rem}
.fpill-g{color:var(--g);border-color:rgba(0,255,136,.3);top:10%;left:-20%;animation-duration:4.2s}
.fpill-c{color:var(--c);border-color:rgba(0,212,255,.3);top:28%;right:-18%;animation-duration:5s;animation-delay:.8s}
.fpill-p{color:var(--p);border-color:rgba(155,89,255,.3);bottom:32%;left:-22%;animation-duration:4.5s;animation-delay:2.5s}
.fpill-o{color:var(--o);border-color:rgba(255,107,53,.3);bottom:16%;right:-15%;animation-duration:5.5s;animation-delay:2s}
.fpill-y{color:var(--y);border-color:rgba(255,215,0,.3);top:50%;left:-24%;animation-duration:4.8s;animation-delay:.4s}
@keyframes pillFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ── About cards ── */
.about-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:22px 0}
.acard{background:var(--card2);border:1px solid var(--b1);border-radius:8px;padding:14px;text-align:center;transition:all .3s var(--ease)}
.acard:hover{border-color:var(--g);transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,255,136,.12)}
.acard-n{font-family:var(--fh);font-size:1.4rem;font-weight:900;color:var(--g);display:block}
.acard-l{font-family:var(--fb);font-size:.58rem;letter-spacing:2px;color:var(--m);text-transform:uppercase}
.about-list{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:16px 0 22px}
.ali{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--m)}
.ali i{color:var(--g);font-size:.7rem}

/* ── Process steps ── */
.proc-step{font-family:var(--fh);font-size:2.5rem;font-weight:900;line-height:1;margin-bottom:10px}
.ps1{color:var(--g)}.ps2{color:var(--c)}.ps3{color:var(--p)}.ps4{color:var(--o)}
.proc-t{font-family:var(--fh);font-size:1.1rem;font-weight:800;color:var(--t);margin-bottom:8px}
.proc-d{font-size:.85rem;color:var(--m);line-height:1.8}
.proc-item{padding:28px;background:var(--card);border:1px solid var(--b1);border-radius:12px;transition:all .4s var(--ease)}
.proc-item:hover{border-color:var(--g);transform:translateX(6px)}

/* ── Number items ── */
.num-item{text-align:center;padding:28px 20px;border-right:1px solid var(--b3);border-bottom:1px solid var(--b3);transition:background .3s}
.num-item:hover{background:rgba(0,255,136,.03)}
.num-item:nth-child(4n){border-right:none}
.num-item i{font-size:1.6rem;color:var(--g);display:block;margin-bottom:10px}
.num-n{font-family:var(--fh);font-size:2.2rem;font-weight:900;color:var(--t);display:block}
.num-l{font-family:var(--fb);font-size:.62rem;letter-spacing:2px;color:var(--m);text-transform:uppercase;margin-top:4px}

/* ── Hero stats ── */
.hero-stats{display:flex;gap:32px;margin-top:36px}
.stat-n{font-family:var(--fh);font-size:1.5rem;font-weight:900;color:var(--g);display:block}
.stat-l{font-family:var(--fb);font-size:.6rem;letter-spacing:2px;color:var(--m);text-transform:uppercase}

/* ── Hero badge ── */
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:rgba(0,255,136,.07);border:1px solid rgba(0,255,136,.2);border-radius:100px;padding:7px 18px;margin-bottom:24px}
.badge-dot{width:7px;height:7px;background:var(--g);border-radius:50%;box-shadow:0 0 8px var(--g);animation:badgePulse 1.8s ease-in-out infinite}
@keyframes badgePulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}}
.hero-badge span{font-family:var(--fb);font-size:.68rem;font-weight:700;letter-spacing:2px;color:var(--g);text-transform:uppercase}

/* ── Partners strip ── */
.pt-label{text-align:center;font-family:var(--fb);font-size:.62rem;font-weight:700;letter-spacing:4px;color:var(--m);text-transform:uppercase;padding:20px 0 14px;border-bottom:1px solid var(--b3)}
.pt-outer{overflow:hidden;padding:20px 0}
.pt-track{display:flex;gap:0;animation:marqueeScroll 24s linear infinite;width:max-content}
.pt-track:hover{animation-play-state:paused}
.pt-item{padding:8px 32px;border-right:1px solid var(--b3);display:flex;align-items:center;justify-content:center;min-width:140px;filter:grayscale(1) opacity(.5);transition:filter .3s}
.pt-item:hover{filter:grayscale(0) opacity(1)}
.pt-name{font-family:var(--fh);font-size:.75rem;font-weight:900;letter-spacing:3px;color:var(--m);white-space:nowrap}
.pt-name span{color:var(--g)}

/* ── Scroll hint ── */
.scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:.5;animation:scrollHint 2s ease-in-out infinite}
.sh-text{font-family:var(--fb);font-size:.6rem;letter-spacing:3px;text-transform:uppercase;color:var(--m)}
.sh-line{width:1px;height:36px;background:linear-gradient(to bottom,var(--g),transparent)}
@keyframes scrollHint{0%,100%{opacity:.5;transform:translateX(-50%) translateY(0)}50%{opacity:.9;transform:translateX(-50%) translateY(5px)}}

/* ── Form elements ── */
.form-input,.form-select,.form-textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:12px 16px;font-family:'Space Grotesk',sans-serif;font-size:.9rem;color:var(--t);outline:none;transition:border-color .3s,box-shadow .3s;resize:none}
.form-textarea{min-height:130px;resize:vertical}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--g);box-shadow:0 0 0 3px rgba(0,255,136,.08)}
.form-label{display:block;font-family:var(--fb);font-size:.65rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--m);margin-bottom:7px}
.form-group{margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.form-select option{background:var(--bg);color:var(--t)}
.form-submit{width:100%;padding:14px;background:var(--g);color:#000;font-family:var(--fb);font-size:.82rem;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;border:none;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;transition:all .35s var(--ease)}
.form-submit:hover{background:#00e07a;box-shadow:0 0 40px rgba(0,255,136,.4);transform:translateY(-2px)}
.form-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}
.form-success{display:none;padding:14px;background:rgba(0,255,136,.08);border:1px solid rgba(0,255,136,.25);border-radius:6px;color:var(--g);font-size:.86rem;text-align:center;margin-top:14px}
.form-success i{margin-right:7px}

/* ── Skills ── */
.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.sk-row{margin-bottom:20px}
.sk-top{display:flex;justify-content:space-between;margin-bottom:7px}
.sk-name{font-size:.85rem;color:var(--t);display:flex;align-items:center;gap:8px;font-weight:500}
.sk-name i{color:var(--g);font-size:.75rem}
.sk-pct{font-family:var(--fh);font-size:.85rem;font-weight:900;color:var(--g)}
.sk-track{background:rgba(255,255,255,.06);height:5px;border-radius:3px;overflow:hidden}
.circles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.circle-wrap{text-align:center}
.circ{position:relative;width:90px;height:90px;margin:0 auto 10px}
.circ svg{width:100%;height:100%}
.circ-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.95rem;font-weight:900;color:var(--g)}
.circ-label{font-family:var(--fb);font-size:.65rem;letter-spacing:1.5px;color:var(--m);text-transform:uppercase}

/* ── Photo frame ── */
.photo-wrap{position:relative;width:460px;max-width:100%}
.photo-frame{position:relative;border-radius:16px;overflow:hidden;border:1px solid rgba(0,255,136,.2);box-shadow:0 0 80px rgba(0,255,136,.08)}
.photo-frame img{width:100%;display:block;transition:transform 8s ease}
.photo-frame:hover img{transform:scale(1.03)}
.photo-scan{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--g),transparent);animation:scanLine 5s ease-in-out infinite;box-shadow:0 0 12px var(--g)}
@keyframes scanLine{0%{top:0;opacity:1}90%{top:100%;opacity:.3}100%{top:100%;opacity:0}}
.photo-glow{position:absolute;inset:-20px;background:radial-gradient(circle at 50% 50%,rgba(0,255,136,.12),transparent 70%);pointer-events:none;animation:glowPulse 6s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.6}50%{opacity:1}}
.photo-border{position:absolute;inset:-8px;border-radius:20px;background:linear-gradient(135deg,rgba(0,255,136,.3),transparent,rgba(0,212,255,.3),transparent,rgba(155,89,255,.3));animation:borderSpin 25s linear infinite;pointer-events:none}
.photo-border-inner{position:absolute;inset:3px;border-radius:17px;background:var(--bg)}
.photo-status{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);background:rgba(2,4,10,.85);border:1px solid rgba(0,255,136,.3);backdrop-filter:blur(8px);border-radius:100px;padding:6px 14px;font-family:var(--fb);font-size:.65rem;font-weight:700;letter-spacing:1px;color:var(--g);white-space:nowrap;display:flex;align-items:center;gap:7px}
.ca{position:absolute;width:14px;height:14px;border-color:var(--g);border-style:solid;opacity:.7}
.ca-tl{top:8px;left:8px;border-width:2px 0 0 2px}
.ca-tr{top:8px;right:8px;border-width:2px 2px 0 0}
.ca-bl{bottom:8px;left:8px;border-width:0 0 2px 2px}
.ca-br{bottom:8px;right:8px;border-width:0 2px 2px 0}
@keyframes borderSpin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}

/* ── About photo section ── */
.ap-frame{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--b1)}
.ap-frame img{width:100%;display:block;filter:contrast(1.05)}
.ap-shadow{position:absolute;bottom:-20px;left:20px;right:-20px;height:80px;background:radial-gradient(ellipse,rgba(0,255,136,.18),transparent);filter:blur(20px);z-index:-1}
.ap-badge{position:absolute;bottom:-14px;right:20px;background:var(--g);color:#000;font-family:var(--fh);padding:10px 16px;border-radius:8px;box-shadow:0 8px 24px rgba(0,255,136,.3)}
.apb-n{display:block;font-size:1.4rem;font-weight:900;line-height:1}
.apb-l{display:block;font-size:.58rem;font-weight:700;letter-spacing:1px;text-transform:uppercase}

/* ── Tab systems (Services & Competencies) ── */
.srv-tabs,.comp-tabs{display:flex;gap:8px;margin-bottom:32px;overflow-x:auto;padding-bottom:4px}
.srv-tab,.comp-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;border:1px solid var(--b1);border-radius:4px;color:var(--m);font-family:var(--fb);font-size:.72rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;white-space:nowrap;transition:all .3s}
.srv-tab.on,.comp-tab.on,.srv-tab:hover,.comp-tab:hover{background:rgba(0,255,136,.08);border-color:var(--g);color:var(--g)}
.srv-panel,.comp-panel{display:none;animation:fadeSlideIn .4s ease forwards}
.srv-panel.on,.comp-panel.on{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.comp-panel.on{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:start}
@keyframes fadeSlideIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── Competencies panel ── */
.comp-feat{display:flex;gap:14px;margin-bottom:20px;align-items:flex-start}
.comp-ico{width:42px;height:42px;border-radius:10px;background:rgba(0,255,136,.08);border:1px solid rgba(0,255,136,.15);display:flex;align-items:center;justify-content:center;color:var(--g);font-size:.95rem;flex-shrink:0;transition:all .3s}
.comp-feat:hover .comp-ico{background:rgba(0,255,136,.18);transform:scale(1.1) rotate(-5deg)}
.comp-h{font-size:.88rem;font-weight:700;color:var(--t);margin-bottom:4px}
.comp-d{font-size:.82rem;color:var(--m);line-height:1.7}
.comp-stats{background:var(--card2);border:1px solid var(--b1);border-radius:10px;padding:20px;min-width:200px}
.cs-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--b3);font-size:.82rem}
.cs-l{color:var(--m)}.cs-v{font-weight:700;color:var(--g)}

/* ── Footer ── */
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding:60px 0 40px;border-bottom:1px solid var(--b3)}
.foot-logo{font-family:var(--fh);font-size:1.1rem;font-weight:900;letter-spacing:4px;color:var(--t);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.foot-logo span{color:var(--g)}
.foot-p{font-size:.84rem;color:var(--m);line-height:1.8;max-width:280px}
.foot-socs{display:flex;gap:10px;margin-top:18px}
.foot-soc{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid var(--b1);display:flex;align-items:center;justify-content:center;color:var(--m);font-size:.82rem;transition:all .4s cubic-bezier(.34,1.56,.64,1)}
.foot-soc:hover{transform:scale(1.2) translateY(-3px);border-color:var(--g);color:var(--g);background:rgba(0,255,136,.08)}
.foot-col-title{font-family:var(--fb);font-size:.65rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--t);margin-bottom:16px}
.foot-link{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--m);margin-bottom:10px;transition:color .3s,gap .3s}
.foot-link:hover{color:var(--g);gap:12px}
.foot-link i{font-size:.7rem;color:var(--g)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding:24px 0;flex-wrap:wrap;gap:12px}
.foot-cr{font-size:.83rem;color:var(--m)}.foot-cr span{color:var(--g)}
.foot-legal{display:flex;gap:20px}.foot-legal a{font-size:.8rem;color:var(--m);transition:color .3s}.foot-legal a:hover{color:var(--g)}

/* ── CTA section ── */
.cta-orb{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;background:radial-gradient(circle,rgba(0,255,136,.06),transparent 70%);pointer-events:none;animation:glowPulse 5s ease-in-out infinite}
.cta-ring1,.cta-ring2{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:1px solid rgba(0,255,136,.08);animation:ringExpand 6s ease-out infinite}
.cta-ring1{width:400px;height:400px}
.cta-ring2{width:600px;height:600px;animation-delay:2.5s}
@keyframes ringExpand{0%{transform:translate(-50%,-50%) scale(.8);opacity:.8}100%{transform:translate(-50%,-50%) scale(1.4);opacity:0}}

/* ── Port filters ── */
.port-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.pf-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;background:transparent;border:1px solid var(--b1);border-radius:4px;color:var(--m);font-family:var(--fb);font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:all .3s;text-decoration:none;white-space:nowrap}
.pf-btn:hover,.pf-btn.on,.pf-btn[class*="on"]{background:rgba(0,255,136,.08);border-color:var(--g);color:var(--g)}
.pf-btn i{font-size:.7rem}

/* ── Responsive ── */
@media(max-width:900px){
  .skills-grid{grid-template-columns:1fr}
  .about-cards{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .comp-panel.on{grid-template-columns:1fr}
  .comp-stats{display:none}
}
@media(max-width:640px){
  .about-cards{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr}
  .hero-stats{gap:18px}
  .circles-grid{grid-template-columns:repeat(3,1fr)}
  .photo-wrap{width:100%;max-width:320px;margin:0 auto}
  .fpill{display:none}
}

/* ─── HERO LAYOUT FIXES ─────────────────────────────────────────────── */
#hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: 120px 0 80px;
  position: relative;
  overflow: hidden;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1fr 460px;
  gap: 60px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
  position: relative;
  z-index: 2;
}
.hero-left { max-width: 600px; }
.hero-title {
  font-family: var(--fh);
  font-size: clamp(2.4rem, 5.5vw, 4rem);
  font-weight: 900;
  line-height: 1.0;
  letter-spacing: -1px;
  display: block;
}
.hero-title .t1 { display: block; color: var(--t); }
.hero-title .t2 { display: block; color: var(--m); }
.hero-title .t3 {
  display: block;
  background: linear-gradient(135deg, var(--g), var(--c));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero-sub {
  font-size: 1.05rem;
  color: var(--m);
  line-height: 1.8;
  margin: 20px 0 32px;
  max-width: 540px;
}
.hero-btns { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 40px; }
.hero-visual { position: relative; display: flex; justify-content: center; }

/* ─── PHOTO WRAP FIX ─────────────────────────────────────────────────── */
.photo-wrap {
  position: relative;
  width: 420px;
  max-width: 100%;
}
.photo-frame {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(0,255,136,0.2);
  box-shadow: 0 0 80px rgba(0,255,136,0.1), 0 40px 100px rgba(0,0,0,0.5);
}
.photo-frame img {
  width: 100%;
  display: block;
  object-fit: cover;
  transition: transform 8s ease;
}
.photo-frame:hover img { transform: scale(1.03); }

/* ─── FLOATING PILLS FIX ─────────────────────────────────────────────── */
.fpills {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 5;
}
.fpill {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 7px;
  background: rgba(2,4,10,0.9);
  border: 1px solid rgba(255,255,255,0.1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 100px;
  padding: 8px 16px;
  font-family: var(--fb);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 1px;
  white-space: nowrap;
  animation: pillFloat 6s ease-in-out infinite;
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
.fpill-g { color: var(--g); border-color: rgba(0,255,136,0.3); top: 8%;  left: -22%; animation-duration: 6.5s; }
.fpill-c { color: var(--c); border-color: rgba(0,212,255,0.3); top: 26%; right:-20%; animation-duration: 7.5s; animation-delay: 1s; }
.fpill-p { color: var(--p); border-color: rgba(155,89,255,0.3); bottom:30%; left:-24%; animation-duration: 7s; animation-delay: 2s; }
.fpill-o { color: var(--o); border-color: rgba(255,107,53,0.3); bottom:14%; right:-18%; animation-duration: 8s; animation-delay: 0.5s; }
.fpill-y { color: var(--y); border-color: rgba(255,215,0,0.3); top: 50%;  left:-26%; animation-duration: 7.2s; animation-delay: 1.5s; }

/* ─── ABOUT SECTION GRID ─────────────────────────────────────────────── */
.about-grid {
  display: grid;
  grid-template-columns: 480px 1fr;
  gap: 60px;
  align-items: center;
}
.about-photo { position: relative; }

/* ─── RESPONSIVE FIXES ───────────────────────────────────────────────── */
@media(max-width: 1100px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; text-align: center; }
  .hero-left { max-width: 100%; margin: 0 auto; }
  .hero-btns { justify-content: center; }
  .hero-stats { justify-content: center; }
  .hero-visual { justify-content: center; }
  .photo-wrap { width: 340px; }
  .fpill { display: none; }
  .about-grid { grid-template-columns: 1fr; gap: 32px; }
}
@media(max-width: 768px) {
  .hero-title { font-size: clamp(1.8rem, 7vw, 2.8rem); }
  .photo-wrap { width: 280px; }
  .photo-border { display: none; }
}

/* ─── BLOG GRID ────────────────────────────────────────────────────────── */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.blog-img {
  height: 220px;
  overflow: hidden;
  background: var(--card2);
  position: relative;
}
.blog-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--ease);
}
.blog-card:hover .blog-img img { transform: scale(1.05); }

/* ─── PORTFOLIO GRID ───────────────────────────────────────────────────── */
.port-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.pf-thumb { height: 220px; }
.pf-thumb img { width:100%; height:100%; object-fit:cover; }

/* ─── W (max-width wrapper) ─────────────────────────────────────────────── */
.W {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 60px;
}

/* ─── SECTION CLIPS ─────────────────────────────────────────────────────── */
.clip-top   { clip-path: polygon(0 40px, 100% 0, 100% 100%, 0 100%); padding-top: 80px; }
.clip-top-r { clip-path: polygon(0 0, 100% 40px, 100% 100%, 0 100%); padding-top: 80px; }

/* ─── NUMBERS GRID ──────────────────────────────────────────────────────── */
.num-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.num-item {
  text-align: center;
  padding: 36px 20px;
  border-right: 1px solid var(--b3);
  border-bottom: 1px solid var(--b3);
  transition: background 0.3s;
}
.num-item:nth-child(4n) { border-right: none; }
.num-item:hover { background: rgba(0,255,136,0.03); }

/* ─── CONTACT GRID ──────────────────────────────────────────────────────── */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 48px;
  align-items: start;
}
.c-form {
  background: var(--card);
  border: 1px solid var(--b1);
  border-radius: 12px;
  padding: 32px;
}

/* ─── PROC GRID ─────────────────────────────────────────────────────────── */
.proc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 900px;
  margin: 0 auto;
}
.proc-left, .proc-right { display: flex; flex-direction: column; gap: 24px; }
.proc-right { margin-top: 60px; }

/* ─── REVIEWS WRAP ──────────────────────────────────────────────────────── */
.reviews-wrap { overflow: hidden; }
.reviews-track {
  display: flex;
  gap: 0;
  transition: transform 0.6s cubic-bezier(0.4,0,0.2,1);
}
.review-card {
  min-width: 50%;
  padding: 28px 16px;
}

/* ─── RESPONSIVE all pages ─────────────────────────────────────────────── */
@media(max-width: 960px) {
  .W { padding: 0 32px; }
  .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .port-grid { grid-template-columns: repeat(2, 1fr); }
  .num-grid  { grid-template-columns: repeat(2, 1fr); }
  .num-item:nth-child(4n) { border-right: 1px solid var(--b3); }
  .num-item:nth-child(2n) { border-right: none; }
  .contact-grid { grid-template-columns: 1fr; }
  .about-grid { grid-template-columns: 1fr; }
  .proc-grid { grid-template-columns: 1fr; }
  .proc-right { margin-top: 0; }
  .review-card { min-width: 100%; }
}
@media(max-width: 640px) {
  .W { padding: 0 18px; }
  .blog-grid  { grid-template-columns: 1fr; }
  .port-grid  { grid-template-columns: 1fr; }
  .num-grid   { grid-template-columns: repeat(2, 1fr); }
  .foot-grid  { grid-template-columns: 1fr; }
  .hero-stats { gap: 16px; }
  .srv-tabs   { flex-wrap: nowrap; overflow-x: auto; }
}
