*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#060C1A;--navy-2:#0D1526;--navy-3:#111E35;--navy-card:#0F1929;
  --blue:#2563EB;--blue-2:#3B82F6;--cyan:#38BDF8;--cyan-2:#7DD3FC;
  --white:#F1F5FF;--muted:#64748B;--muted-2:#94A3B8;
  --border:rgba(255,255,255,0.06);--border-2:rgba(255,255,255,0.12);
  --glow-blue:rgba(37,99,235,0.3);--glow-cyan:rgba(56,189,248,0.2);
}
html{scroll-behavior:smooth;cursor:none;overflow-x:hidden;width:100%}
body{font-family:'Inter',sans-serif;background:var(--navy);color:var(--white);overflow-x:hidden;cursor:none;width:100%;max-width:100vw;position:relative}

/* ── CUSTOM CURSOR ── */
#cursor{position:fixed;width:12px;height:12px;border-radius:50%;background:var(--cyan);pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width 0.2s,height 0.2s,background 0.2s;mix-blend-mode:screen}
#cursor-ring{position:fixed;width:40px;height:40px;border-radius:50%;border:1px solid rgba(56,189,248,0.5);pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width 0.35s,height 0.35s,border-color 0.3s;will-change:transform}
body:has(a:hover) #cursor,body:has(button:hover) #cursor{width:20px;height:20px;background:var(--blue)}
body:has(a:hover) #cursor-ring,body:has(button:hover) #cursor-ring{width:56px;height:56px;border-color:rgba(37,99,235,0.6)}
@media(pointer:coarse){#cursor,#cursor-ring{display:none}html,body{cursor:auto}}

/* ── PAGE LOADER ── */
#loader{position:fixed;inset:0;background:var(--navy);z-index:10000;display:flex;align-items:center;justify-content:center;transition:opacity 0.6s,visibility 0.6s}
#loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-inner{display:flex;flex-direction:column;align-items:center;gap:24px}
.loader-logo{font-family:'Syne',sans-serif;font-size:2rem;font-weight:800;color:var(--white)}
.loader-logo span{color:var(--cyan)}
.loader-bar{width:200px;height:2px;background:var(--border-2);border-radius:2px;overflow:hidden}
.loader-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:2px;width:0;animation:loadAnim 1.6s cubic-bezier(0.4,0,0.2,1) forwards}
@keyframes loadAnim{0%{width:0}60%{width:80%}100%{width:100%}}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:22px 6%;transition:all 0.4s}
nav.scrolled{background:rgba(6,12,26,0.88);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:14px 6%;border-bottom:1px solid var(--border)}
.nav-logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1.4rem;color:var(--white);text-decoration:none}
.nav-logo span{color:var(--cyan)}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{color:var(--muted-2);text-decoration:none;font-size:0.875rem;font-weight:500;letter-spacing:0.01em;position:relative;padding-bottom:2px;transition:color 0.2s}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--cyan);transition:width 0.3s}
.nav-links a:hover{color:var(--white)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--blue);color:var(--white);padding:10px 22px;border-radius:8px;font-weight:600;font-size:0.85rem;text-decoration:none;border:none;cursor:none;transition:box-shadow 0.2s,transform 0.2s}
.nav-cta:hover{box-shadow:0 0 28px rgba(37,99,235,0.5);transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{width:24px;height:1.5px;background:var(--white);border-radius:2px;transition:all 0.3s;display:block}

/* ── HERO ── */
#hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:140px 6% 100px;overflow:hidden}
#hero-canvas{position:absolute;inset:0;z-index:0;width:100%;height:100%}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0}
.orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(37,99,235,0.18) 0%,transparent 70%);right:-100px;top:-100px;animation:orbFloat1 12s ease-in-out infinite}
.orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(56,189,248,0.12) 0%,transparent 70%);left:-80px;bottom:50px;animation:orbFloat2 16s ease-in-out infinite}
.orb-3{width:300px;height:300px;background:radial-gradient(circle,rgba(37,99,235,0.1) 0%,transparent 70%);left:40%;top:30%;animation:orbFloat3 9s ease-in-out infinite}
@keyframes orbFloat1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-30px,40px) scale(1.1)}66%{transform:translate(20px,-20px) scale(0.95)}}
@keyframes orbFloat2{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-60px)}}
@keyframes orbFloat3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-20px,30px) scale(1.15)}}
.hero-content{position:relative;z-index:1;max-width:720px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(37,99,235,0.12);border:1px solid rgba(37,99,235,0.3);color:var(--cyan-2);padding:6px 16px;border-radius:100px;font-size:0.75rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;margin-bottom:32px;opacity:0;transform:translateY(20px)}
.hero-badge .badge-dot{width:6px;height:6px;background:var(--cyan);border-radius:50%;animation:pulseDot 2s infinite}
@keyframes pulseDot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:0.5}}
.hero-title{font-family:'Syne',sans-serif;font-size:clamp(2.8rem,6.5vw,5rem);font-weight:800;line-height:1.05;letter-spacing:-0.025em;margin-bottom:28px}
.hero-title .line{display:block;overflow:hidden}
.hero-title .line span{display:block;transform:translateY(110%);opacity:0}
.hero-title .accent{color:transparent;-webkit-text-stroke:1.5px var(--cyan)}
.hero-title .accent-fill{color:var(--cyan)}
.hero-sub{color:var(--muted-2);font-size:1.1rem;line-height:1.75;max-width:540px;margin-bottom:44px;opacity:0;transform:translateY(20px)}
.hero-sub strong{color:var(--white)}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;opacity:0;transform:translateY(20px)}
.btn-primary{background:var(--blue);color:var(--white);padding:15px 32px;border-radius:10px;font-weight:600;font-size:0.95rem;text-decoration:none;border:none;cursor:none;position:relative;overflow:hidden;transition:box-shadow 0.25s,transform 0.2s;box-shadow:0 4px 24px rgba(37,99,235,0.3)}
.btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.15) 0%,transparent 60%);opacity:0;transition:opacity 0.3s}
.btn-primary:hover{box-shadow:0 8px 40px rgba(37,99,235,0.5);transform:translateY(-2px)}
.btn-primary:hover::before{opacity:1}
.btn-ghost{background:transparent;color:var(--white);padding:15px 32px;border-radius:10px;font-weight:600;font-size:0.95rem;text-decoration:none;border:1px solid var(--border-2);cursor:none;transition:border-color 0.25s,background 0.25s,transform 0.2s}
.btn-ghost:hover{border-color:rgba(56,189,248,0.4);background:rgba(56,189,248,0.06);transform:translateY(-2px)}
.hero-scroll-hint{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;animation:fadeIn 1s 2.5s forwards}
.scroll-line{width:1px;height:60px;background:linear-gradient(to bottom,transparent,var(--cyan-2));position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:-100%;width:100%;height:100%;background:var(--cyan);animation:scrollDrop 2s ease-in-out infinite}
@keyframes scrollDrop{0%{top:-100%}100%{top:200%}}
@keyframes fadeIn{to{opacity:1}}
.scroll-label{font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}

/* ── FLOATING STATS ROW ── */
.stats-row{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin:0 6%;transform:translateY(-30px)}
.stat-cell{background:var(--navy-2);padding:28px 32px;text-align:center;position:relative;overflow:hidden;transition:background 0.3s}
.stat-cell::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(37,99,235,0.08) 0%,transparent 60%);opacity:0;transition:opacity 0.3s}
.stat-cell:hover{background:var(--navy-3)}
.stat-cell:hover::before{opacity:1}
.stat-num{font-family:'Syne',sans-serif;font-size:2.2rem;font-weight:800;line-height:1;margin-bottom:6px}
.stat-num .n-val{color:var(--white)}
.stat-num .n-unit{color:var(--cyan);font-size:1.5rem}
.stat-label{font-size:0.82rem;color:var(--muted);letter-spacing:0.02em}

/* ── SECTIONS ── */
section{padding:110px 6%}
.section-eyebrow{font-size:0.72rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.section-eyebrow::before{content:'';width:24px;height:1px;background:var(--cyan)}
.section-title{font-family:'Syne',sans-serif;font-size:clamp(1.9rem,4vw,3rem);font-weight:800;line-height:1.12;letter-spacing:-0.02em;margin-bottom:18px}
.section-sub{color:var(--muted-2);font-size:1rem;line-height:1.75;max-width:520px}
.section-hdr{margin-bottom:64px}

/* ── ABOUT ── */
#about{background:var(--navy-2);overflow:hidden}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center}
.about-img-outer{position:relative}
.about-img-frame{border-radius:20px;overflow:hidden;position:relative;transform:perspective(1000px) rotateY(-4deg) rotateX(2deg);transition:transform 0.6s}
.about-img-frame:hover{transform:perspective(1000px) rotateY(0deg) rotateX(0deg)}
.about-img-frame img{width:100%;display:block;transition:transform 0.5s}
.about-img-frame:hover img{transform:scale(1.04)}
.about-img-glow{position:absolute;inset:-1px;border-radius:20px;background:linear-gradient(135deg,rgba(37,99,235,0.3),rgba(56,189,248,0.1),transparent);pointer-events:none;opacity:0;transition:opacity 0.4s}
.about-img-frame:hover .about-img-glow{opacity:1}
.about-badge-float{position:absolute;bottom:-24px;right:-24px;background:var(--navy-card);border:1px solid var(--border-2);border-radius:14px;padding:18px 22px;display:flex;align-items:center;gap:12px;box-shadow:0 20px 60px rgba(0,0,0,0.4)}
.badge-icon{width:40px;height:40px;background:rgba(37,99,235,0.15);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.badge-num{font-family:'Syne',sans-serif;font-size:1.4rem;font-weight:800;color:var(--white);line-height:1}
.badge-sub{font-size:0.75rem;color:var(--muted);margin-top:2px}
.skill-bars{margin-top:40px;display:flex;flex-direction:column;gap:22px}
.skill-row{}
.skill-meta{display:flex;justify-content:space-between;font-size:0.82rem;font-weight:500;margin-bottom:10px}
.skill-meta span:first-child{color:var(--muted-2)}
.skill-meta span:last-child{color:var(--cyan);font-weight:700}
.skill-track{height:3px;background:rgba(255,255,255,0.07);border-radius:3px;overflow:hidden;position:relative}
.skill-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:3px;width:0;position:relative;transition:width 1.4s cubic-bezier(0.4,0,0.2,1)}
.skill-fill::after{content:'';position:absolute;right:0;top:-2px;width:6px;height:6px;background:var(--cyan);border-radius:50%;box-shadow:0 0 10px var(--cyan)}

/* ── SERVICES ── */
#services{background:var(--navy);position:relative;overflow:hidden}
.services-marquee-bg{position:absolute;bottom:0;left:0;right:0;overflow:hidden;height:50px;pointer-events:none;opacity:0.04}
.marquee-text{display:flex;gap:48px;white-space:nowrap;animation:marqueeScroll 20s linear infinite;font-family:'Syne',sans-serif;font-size:2rem;font-weight:800;letter-spacing:0.05em;color:var(--white)}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-card{background:var(--navy-card);border:1px solid var(--border);border-radius:18px;padding:36px;cursor:none;position:relative;overflow:hidden;transition:border-color 0.35s,transform 0.35s,box-shadow 0.35s;transform:translateY(0)}
.svc-card::after{content:'';position:absolute;inset:0;border-radius:18px;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(37,99,235,0.12) 0%,transparent 60%);opacity:0;transition:opacity 0.4s}
.svc-card:hover{border-color:rgba(37,99,235,0.35);transform:translateY(-8px);box-shadow:0 30px 80px rgba(0,0,0,0.3),0 0 0 1px rgba(37,99,235,0.2)}
.svc-card:hover::after{opacity:1}
.svc-card-top{position:absolute;top:0;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,var(--blue),transparent);opacity:0;transition:opacity 0.35s}
.svc-card:hover .svc-card-top{opacity:1}
.svc-icon-wrap{width:56px;height:56px;background:rgba(37,99,235,0.1);border:1px solid rgba(37,99,235,0.2);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:24px;position:relative;z-index:1;transition:background 0.3s,transform 0.3s}
.svc-card:hover .svc-icon-wrap{background:rgba(37,99,235,0.2);transform:scale(1.1) rotate(-3deg)}
.svc-name{font-family:'Syne',sans-serif;font-size:1.05rem;font-weight:700;margin-bottom:12px;position:relative;z-index:1;transition:color 0.3s}
.svc-card:hover .svc-name{color:var(--cyan-2)}
.svc-desc{color:var(--muted);font-size:0.875rem;line-height:1.7;position:relative;z-index:1}
.svc-arrow{position:absolute;bottom:28px;right:28px;width:32px;height:32px;border-radius:50%;background:rgba(37,99,235,0.15);display:flex;align-items:center;justify-content:center;font-size:0.85rem;color:var(--cyan);transform:translate(60px,0);opacity:0;transition:all 0.3s}
.svc-card:hover .svc-arrow{transform:translate(0,0);opacity:1}

/* ── TICKER ── */
.ticker-wrap{background:var(--navy-3);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:14px 0;overflow:hidden;position:relative}
.ticker-track{display:flex;gap:60px;white-space:nowrap;animation:tickerAnim 25s linear infinite}
.ticker-item{font-size:0.8rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px}
.ticker-item .dot{width:4px;height:4px;background:var(--cyan);border-radius:50%;flex-shrink:0}
@keyframes tickerAnim{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ── PROCESS ── */
#process{background:var(--navy-2);overflow:hidden}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;margin-top:60px}
.process-steps::after{content:'';position:absolute;top:42px;left:80px;right:80px;height:1px;background:linear-gradient(90deg,transparent,var(--border-2) 10%,var(--border-2) 90%,transparent);z-index:0}
.process-step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 20px;position:relative;z-index:1}
.step-num-wrap{width:84px;height:84px;border-radius:50%;border:1px solid var(--border-2);background:var(--navy-card);display:flex;align-items:center;justify-content:center;position:relative;margin-bottom:24px;transition:border-color 0.4s,background 0.4s,transform 0.4s;cursor:none}
.step-num-wrap:hover{border-color:rgba(56,189,248,0.5);background:rgba(37,99,235,0.12);transform:scale(1.1)}
.step-num-ring{position:absolute;inset:-6px;border-radius:50%;border:1px dashed rgba(56,189,248,0.2);animation:stepSpin 12s linear infinite}
@keyframes stepSpin{to{transform:rotate(360deg)}}
.step-num{font-family:'Syne',sans-serif;font-size:1.6rem;font-weight:800;color:var(--white)}
.step-icon{position:absolute;top:-8px;right:-8px;width:24px;height:24px;background:var(--navy-3);border:1px solid var(--border-2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.7rem}
.step-title{font-family:'Syne',sans-serif;font-size:1rem;font-weight:700;margin-bottom:10px;color:var(--white)}
.step-desc{font-size:0.82rem;color:var(--muted);line-height:1.65}

/* ── PROJECTS ── */
#projects{background:var(--navy)}
.proj-filter{display:flex;gap:10px;margin-bottom:52px;flex-wrap:wrap}
.pf-btn{padding:8px 20px;border-radius:8px;font-size:0.82rem;font-weight:600;cursor:none;border:1px solid var(--border);background:transparent;color:var(--muted-2);transition:all 0.25s;position:relative;overflow:hidden}
.pf-btn::before{content:'';position:absolute;inset:0;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform 0.3s;z-index:0}
.pf-btn span{position:relative;z-index:1}
.pf-btn.active,.pf-btn:hover{color:var(--white);border-color:var(--blue)}
.pf-btn.active::before,.pf-btn:hover::before{transform:scaleX(1)}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.proj-card{border-radius:18px;overflow:hidden;background:var(--navy-card);border:1px solid var(--border);cursor:none;position:relative;transition:transform 0.4s,box-shadow 0.4s}
.proj-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 30px 80px rgba(0,0,0,0.4)}
.proj-img-wrap{aspect-ratio:16/9;overflow:hidden;position:relative}
.proj-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s}
.proj-card:hover .proj-img-wrap img{transform:scale(1.08)}
.proj-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,12,26,0.9) 0%,rgba(6,12,26,0.3) 50%,transparent 100%);opacity:0;transition:opacity 0.4s;display:flex;align-items:flex-end;padding:20px}
.proj-card:hover .proj-overlay{opacity:1}
.proj-overlay-link{background:var(--blue);color:var(--white);padding:8px 20px;border-radius:8px;text-decoration:none;font-size:0.82rem;font-weight:700;letter-spacing:0.03em;transition:background 0.2s}
.proj-overlay-link:hover{background:var(--blue-2)}
.proj-body{padding:22px 24px}
.proj-cat{font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--cyan);margin-bottom:7px}
.proj-name{font-family:'Syne',sans-serif;font-size:0.95rem;font-weight:700;color:var(--white);line-height:1.4}

/* ── WHY US ── */
#why{background:var(--navy-2);position:relative;overflow:hidden}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:90px;align-items:center}
.why-points{display:flex;flex-direction:column;gap:20px;margin-top:44px}
.why-pt{display:flex;gap:18px;padding:22px;border-radius:14px;border:1px solid var(--border);background:var(--navy-card);cursor:none;transition:all 0.35s;position:relative;overflow:hidden}
.why-pt::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--blue),var(--cyan));transform:scaleY(0);transform-origin:top;transition:transform 0.4s}
.why-pt:hover{border-color:rgba(37,99,235,0.3);background:rgba(37,99,235,0.06);transform:translateX(6px)}
.why-pt:hover::before{transform:scaleY(1)}
.why-pt-icon{width:44px;height:44px;flex-shrink:0;background:rgba(37,99,235,0.1);border:1px solid rgba(37,99,235,0.2);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:transform 0.3s}
.why-pt:hover .why-pt-icon{transform:rotate(-8deg) scale(1.1)}
.why-pt-ttl{font-family:'Syne',sans-serif;font-size:0.95rem;font-weight:700;margin-bottom:5px}
.why-pt-desc{color:var(--muted);font-size:0.85rem;line-height:1.65}
.why-visual-card{background:var(--navy-card);border:1px solid var(--border-2);border-radius:22px;padding:44px;position:relative;overflow:hidden}
.why-visual-card::before{content:'';position:absolute;top:-80px;right:-80px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,0.15) 0%,transparent 70%)}
.savings-label{font-size:0.8rem;color:var(--muted);letter-spacing:0.05em;text-transform:uppercase;margin-bottom:10px}
.savings-huge{font-family:'Syne',sans-serif;font-size:5rem;font-weight:800;color:var(--cyan);line-height:0.9;margin-bottom:6px}
.savings-sub{font-size:0.85rem;color:var(--muted);margin-bottom:40px}
.cost-compare{display:flex;flex-direction:column;gap:18px;margin-bottom:40px}
.cc-item{}
.cc-meta{display:flex;justify-content:space-between;font-size:0.8rem;margin-bottom:8px}
.cc-meta span:first-child{color:var(--muted)}
.cc-meta span:last-child{font-weight:700;color:var(--white)}
.cc-track{height:10px;background:rgba(255,255,255,0.06);border-radius:6px;overflow:hidden}
.cc-fill{height:100%;border-radius:6px;transition:width 1.4s cubic-bezier(0.4,0,0.2,1);width:0}
.cc-fill.others{background:rgba(255,255,255,0.2)}
.cc-fill.ror{background:linear-gradient(90deg,var(--blue),var(--cyan))}
.testimonial-block{border-top:1px solid var(--border);padding-top:32px}
.quote-mark{font-family:'Syne',sans-serif;font-size:3rem;color:var(--cyan);line-height:0.5;margin-bottom:12px;opacity:0.5}
#testimonial-slider{position:relative;overflow:hidden}
.testimonial-item{opacity:0;transform:translateX(20px);transition:opacity 0.5s,transform 0.5s;position:absolute;top:0;left:0;width:100%}
.testimonial-item.active{opacity:1;transform:translateX(0);position:relative}
.quote-text{color:var(--muted-2);font-size:0.875rem;line-height:1.75;font-style:italic;margin-bottom:16px}
.quote-author{font-size:0.8rem;font-weight:700;color:var(--white)}

/* ── TECH STACK ── */
#tech{background:var(--navy);padding:70px 6%}
.tech-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:40px}
.tech-pill{background:var(--navy-card);border:1px solid var(--border);border-radius:100px;padding:10px 20px;font-size:0.82rem;font-weight:600;color:var(--muted-2);cursor:none;transition:all 0.25s}
.tech-pill:hover{border-color:rgba(56,189,248,0.4);color:var(--cyan-2);background:rgba(56,189,248,0.06);transform:translateY(-3px)}

/* ── CONTACT ── */
#contact{background:var(--navy-2)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:90px;align-items:start}
.contact-info{margin-top:44px;display:flex;flex-direction:column;gap:24px}
.ci-item{display:flex;gap:16px;align-items:flex-start;padding:18px;border-radius:12px;border:1px solid transparent;cursor:none;transition:all 0.3s}
.ci-item:hover{border-color:var(--border);background:var(--navy-card)}
.ci-icon{width:44px;height:44px;flex-shrink:0;background:rgba(37,99,235,0.1);border:1px solid rgba(37,99,235,0.2);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:transform 0.3s}
.ci-item:hover .ci-icon{transform:scale(1.1) rotate(-5deg)}
.ci-ttl{font-weight:700;font-size:0.9rem;margin-bottom:4px}
.ci-val{color:var(--muted);font-size:0.875rem}
.contact-form{background:var(--navy-card);border:1px solid var(--border-2);border-radius:22px;padding:44px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.ff{display:flex;flex-direction:column;gap:8px}
.ff label{font-size:0.78rem;font-weight:700;color:var(--muted);letter-spacing:0.04em;text-transform:uppercase}
.ff input,.ff select,.ff textarea{background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:10px;padding:12px 16px;color:var(--white);font-family:'Inter',sans-serif;font-size:0.9rem;outline:none;transition:border-color 0.25s,background 0.25s;cursor:none}
.ff input:focus,.ff select:focus,.ff textarea:focus{border-color:rgba(56,189,248,0.5);background:rgba(56,189,248,0.04)}
.ff select option{background:var(--navy-card)}
.ff textarea{resize:vertical;min-height:110px}
.form-submit{width:100%;background:var(--blue);color:var(--white);border:none;border-radius:10px;padding:15px;font-family:'Syne',sans-serif;font-size:1rem;font-weight:700;cursor:none;position:relative;overflow:hidden;transition:box-shadow 0.25s,transform 0.2s;margin-top:4px}
.form-submit::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.15) 0%,transparent 50%);opacity:0;transition:opacity 0.3s}
.form-submit:hover{box-shadow:0 8px 40px rgba(37,99,235,0.5);transform:translateY(-2px)}
.form-submit:hover::before{opacity:1}

/* ── FOOTER ── */
footer{background:var(--navy);border-top:1px solid var(--border);padding:72px 6% 36px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:60px;padding-bottom:60px;border-bottom:1px solid var(--border);margin-bottom:36px}
.footer-brand{}
.footer-brand p{color:var(--muted);font-size:0.875rem;line-height:1.75;margin-top:16px;max-width:300px}
.footer-socials{display:flex;gap:10px;margin-top:22px}
.soc-btn{width:36px;height:36px;background:var(--border);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:0.75rem;font-weight:800;color:var(--muted-2);cursor:none;transition:all 0.25s}
.soc-btn:hover{background:rgba(37,99,235,0.2);border-color:rgba(37,99,235,0.4);color:var(--white);transform:translateY(-3px)}
.footer-col h5{font-size:0.75rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links a{color:var(--muted);text-decoration:none;font-size:0.875rem;transition:color 0.2s,padding-left 0.2s;display:flex;align-items:center;gap:6px}
.footer-links a:hover{color:var(--white);padding-left:4px}
.footer-links a::before{content:'→';font-size:0.7rem;color:var(--cyan);opacity:0;transition:opacity 0.2s}
.footer-links a:hover::before{opacity:1}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{color:var(--muted);font-size:0.8rem}

/* ── WA FLOAT ── */
.wa-float{position:fixed;bottom:30px;right:30px;z-index:500;width:52px;height:52px;background:#25D366;border-radius:50%;box-shadow:0 4px 24px rgba(37,211,102,0.4);display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:1.4rem;cursor:none;transition:transform 0.25s,box-shadow 0.25s}
.wa-float:hover{transform:scale(1.12);box-shadow:0 8px 40px rgba(37,211,102,0.6)}

/* ── REVEAL / ANIMATION UTILITIES ── */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.75s cubic-bezier(0.4,0,0.2,1),transform 0.75s cubic-bezier(0.4,0,0.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-50px);transition:opacity 0.75s,transform 0.75s}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(50px);transition:opacity 0.75s,transform 0.75s}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(0.88);transition:opacity 0.7s,transform 0.7s}
.reveal-scale.visible{opacity:1;transform:scale(1)}
.stagger-1{transition-delay:0.05s}
.stagger-2{transition-delay:0.12s}
.stagger-3{transition-delay:0.19s}
.stagger-4{transition-delay:0.26s}
.stagger-5{transition-delay:0.33s}
.stagger-6{transition-delay:0.40s}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .services-grid{grid-template-columns:1fr 1fr}
  .proj-grid{grid-template-columns:1fr 1fr}
  .process-steps{grid-template-columns:1fr 1fr;gap:40px}
  .process-steps::after{display:none}
}
@media(max-width:900px){
  .about-grid,.why-grid,.contact-grid{grid-template-columns:1fr;gap:48px}
  .footer-grid{grid-template-columns:1fr;gap:40px}
  .stats-row{grid-template-columns:1fr 1fr}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  html,body{cursor:auto}
  #cursor,#cursor-ring{display:none}
}
@media(max-width:900px){
  .form-grid{grid-template-columns:1fr}
  .contact-form{padding:28px}
}
@media(max-width:600px){
  .services-grid,.proj-grid{grid-template-columns:1fr}
  section{padding:80px 5%}
  .stats-row{margin:0 5%;transform:translateY(-20px)}
  .wa-float{right:20px;bottom:20px;width:48px;height:48px}
  nav{padding:18px 5%}
  nav.scrolled{padding:12px 5%}
}