
/* ============================================================
   RESET
============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:#050810;color:#EDEEFF;
  font-family:'Space Grotesk',sans-serif;
  overflow-x:hidden;cursor:none;
  -webkit-font-smoothing:antialiased;
}

/* ============================================================
   DESIGN TOKENS
============================================================ */
:root{
  --bg0:#050810;--bg1:#080C18;--bg2:#0C1220;--bg3:#101828;
  --v:#6C63FF;--v2:#8B85FF;--c:#00D4FF;--c2:#22DFFF;
  --gold:#FFB347;--rose:#FF4D6D;--green:#25D366;
  --w:#EDEEFF;--w70:rgba(237,238,255,0.7);--w40:rgba(237,238,255,0.4);
  --w15:rgba(237,238,255,0.15);--w08:rgba(237,238,255,0.08);--w04:rgba(237,238,255,0.04);
  --bv:rgba(108,99,255,0.2);--bc:rgba(0,212,255,0.15);
  --gv:rgba(108,99,255,0.1);--gc:rgba(0,212,255,0.08);
}

/* ============================================================
   CURSOR
============================================================ */
#cur{position:fixed;inset:0;pointer-events:none;z-index:99999}
#cur-d{
  position:absolute;width:10px;height:10px;
  background:var(--c);border-radius:50%;
  transform:translate(-50%,-50%);
  box-shadow:0 0 12px var(--c),0 0 28px rgba(0,212,255,0.35);
  transition:background 0.2s,width 0.15s,height 0.15s;
}
#cur-r{
  position:absolute;width:38px;height:38px;
  border:1.5px solid rgba(108,99,255,0.55);border-radius:50%;
  transform:translate(-50%,-50%);transition:all 0.16s ease;
}
body.hov #cur-d{width:14px;height:14px;background:var(--v)}
body.hov #cur-r{width:54px;height:54px;border-color:var(--v2);opacity:0.9}

/* ============================================================
   NAVBAR
============================================================ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 5rem;
  background:rgba(5,8,16,0.65);
  backdrop-filter:blur(28px) saturate(1.6);
  border-bottom:1px solid rgba(108,99,255,0.15);
  transition:background 0.3s,padding 0.3s;
}
#nav.scrolled{background:rgba(5,8,16,0.96);padding:0.75rem 5rem;box-shadow:0 4px 40px rgba(0,0,0,0.4)}
.n-logo{
  font-size:1.35rem;font-weight:800;text-decoration:none;letter-spacing:-0.02em;
  background:linear-gradient(120deg,var(--v),var(--c));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.n-links{display:flex;align-items:center;gap:0.2rem;list-style:none}
.n-links a{
  color:var(--w40);text-decoration:none;font-size:0.875rem;font-weight:500;
  padding:0.45rem 0.9rem;border-radius:8px;transition:all 0.2s;
}
.n-links a:hover,.n-links a.on{color:var(--w);background:var(--w08)}
.n-links a.on{color:var(--c2)}
.n-right{display:flex;align-items:center;gap:0.75rem}
.n-adm{
  padding:0.5rem 1rem;border:1px solid rgba(108,99,255,0.25);border-radius:8px;
  color:var(--v2);font-size:0.78rem;font-family:'JetBrains Mono',monospace;
  text-decoration:none;background:transparent;cursor:none;transition:all 0.2s;
}
.n-adm:hover{background:var(--gv);border-color:var(--v)}
.n-cta{
  padding:0.6rem 1.5rem;border-radius:8px;font-weight:700;font-size:0.875rem;
  text-decoration:none;color:#000;letter-spacing:0.01em;
  background:linear-gradient(135deg,var(--v),var(--c));
  transition:all 0.25s;position:relative;overflow:hidden;
}
.n-cta::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,0.18) 50%,transparent 70%);
  transform:translateX(-100%);transition:transform 0.45s;
}
.n-cta:hover::after{transform:translateX(100%)}
.n-cta:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(108,99,255,0.45)}

/* ============================================================
   BG CANVAS (fixed, behind everything)
============================================================ */
#bgc{
  position:fixed;top:0;left:0;width:100%;height:100%;
  z-index:0;pointer-events:none;display:block;
}

/* ============================================================
   HERO
============================================================ */
#hero{
  min-height:100vh;position:relative;z-index:1;
  display:flex;align-items:center;
  padding:0 5rem;
  padding-top:calc(var(--nav-h,80px) + 2rem);
  padding-bottom:4rem;
}
.hero-wrap{
  display:grid;grid-template-columns:1fr 1fr;
  gap:3rem;align-items:center;width:100%;
  max-width:1300px;margin:0 auto;
}
.hero-l{position:relative;z-index:2}
.hero-badge{
  display:inline-flex;align-items:center;gap:0.6rem;
  background:rgba(0,212,255,0.07);border:1px solid rgba(0,212,255,0.28);
  border-radius:100px;padding:0.38rem 1.1rem;margin-bottom:2rem;
  font-family:'JetBrains Mono',monospace;font-size:0.7rem;
  color:var(--c);letter-spacing:0.09em;text-transform:uppercase;
  opacity:0;animation:slideDown 0.8s 0.1s ease forwards;
}
.live{
  width:7px;height:7px;background:var(--c);border-radius:50%;
  animation:livePing 1.8s infinite;box-shadow:0 0 8px var(--c);
}
@keyframes livePing{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.3;transform:scale(1.7)}}

.hero-h1{
  font-size:clamp(3rem,5.2vw,5.6rem);font-weight:800;
  line-height:1.05;letter-spacing:-0.035em;
  opacity:0;animation:slideUp 0.9s 0.2s ease forwards;
}
.hero-h1 .hl{
  display:inline-block;
  background:linear-gradient(135deg,var(--v) 0%,var(--c) 50%,var(--v2) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  animation:gradMove 5s ease infinite;
}
@keyframes gradMove{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

.hero-p{
  font-size:1.05rem;color:var(--w70);line-height:1.82;
  margin-top:1.5rem;max-width:520px;font-weight:400;
  opacity:0;animation:slideUp 0.9s 0.3s ease forwards;
}
.hero-btns{
  display:flex;gap:1rem;flex-wrap:wrap;margin-top:2.8rem;
  opacity:0;animation:slideUp 0.9s 0.4s ease forwards;
}
.btn-p{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.95rem 2.3rem;border-radius:10px;
  background:linear-gradient(135deg,var(--v),var(--c));
  color:#000;font-weight:700;font-size:0.95rem;
  text-decoration:none;border:none;cursor:none;
  font-family:'Space Grotesk',sans-serif;
  position:relative;overflow:hidden;transition:all 0.3s;
}
.btn-p::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,0.18) 50%,transparent 70%);
  transform:translateX(-100%);transition:transform 0.45s;
}
.btn-p:hover::before{transform:translateX(100%)}
.btn-p:hover{transform:translateY(-3px);box-shadow:0 16px 42px rgba(108,99,255,0.5)}
.btn-o{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.95rem 2.3rem;border-radius:10px;
  border:1px solid rgba(108,99,255,0.3);color:var(--v2);
  font-size:0.95rem;text-decoration:none;background:var(--gv);
  transition:all 0.3s;cursor:none;
  font-family:'Space Grotesk',sans-serif;font-weight:600;
}
.btn-o:hover{border-color:var(--v);color:var(--w);background:rgba(108,99,255,0.16);transform:translateY(-2px)}

.hero-stats{
  display:flex;align-items:center;gap:2.5rem;
  margin-top:3.5rem;padding-top:2.5rem;
  border-top:1px solid var(--w08);
  opacity:0;animation:slideUp 0.9s 0.5s ease forwards;
}
.hs-v{
  font-size:2.1rem;font-weight:800;letter-spacing:-0.04em;
  background:linear-gradient(135deg,var(--w),var(--c));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.hs-l{font-size:0.73rem;color:var(--w40);margin-top:0.1rem;font-family:'JetBrains Mono',monospace;letter-spacing:0.04em}
.hs-sep{width:1px;height:40px;background:var(--w15);flex-shrink:0}

/* Hero right — 3D orb */
.hero-r{
  position:relative;z-index:2;
  display:flex;justify-content:center;align-items:center;
  align-self:center;
  opacity:0;animation:fadeScale 1s 0.4s ease forwards;
}
@keyframes fadeScale{from{opacity:0;transform:scale(0.88)}to{opacity:1;transform:scale(1)}}
#orbc{display:block;width:100%;max-width:520px;height:480px;margin:0 auto}

/* Floating badges */
.fb{
  position:absolute;
  background:rgba(8,12,24,0.88);border:1px solid rgba(108,99,255,0.28);
  border-radius:12px;padding:0.65rem 1rem;backdrop-filter:blur(14px);
  font-size:0.78rem;font-weight:600;color:var(--w);
  display:flex;align-items:center;gap:0.5rem;
  pointer-events:none;
  animation:fbFloat 4s ease-in-out infinite;
}
.fb:nth-child(1){top:10%;left:-2%;animation-delay:0s}
.fb:nth-child(2){top:52%;right:-2%;animation-delay:1.4s}
.fb:nth-child(3){bottom:8%;left:6%;animation-delay:2.6s}
.fb-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
@keyframes fbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

@keyframes slideDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   SECTIONS
============================================================ */
section{position:relative;z-index:1;padding:8rem 5rem}
.cont{max-width:1300px;margin:0 auto}
.stag{
  display:inline-flex;align-items:center;gap:0.5rem;
  font-family:'JetBrains Mono',monospace;font-size:0.68rem;
  letter-spacing:0.14em;color:var(--c);text-transform:uppercase;
  margin-bottom:0.9rem;
}
.stag::before{content:'//';color:var(--v);margin-right:0.1rem}
.sh{
  font-size:clamp(2.2rem,3.8vw,3.8rem);font-weight:800;
  letter-spacing:-0.03em;line-height:1.1;
}
.sh .g{
  background:linear-gradient(135deg,var(--v),var(--c));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.sp{color:var(--w40);font-size:0.96rem;line-height:1.82;max-width:540px;margin-top:1rem}

/* ============================================================
   SERVICES
============================================================ */
#services{background:linear-gradient(180deg,var(--bg0),var(--bg1))}
.svc-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3.5rem;gap:2rem;flex-wrap:wrap}
.svc-alink{
  color:var(--v2);font-size:0.83rem;font-family:'JetBrains Mono',monospace;
  text-decoration:none;border-bottom:1px solid rgba(108,99,255,0.3);
  padding-bottom:2px;transition:all 0.2s;white-space:nowrap;
}
.svc-alink:hover{color:var(--c);border-color:var(--c)}
.sg{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2px;background:rgba(108,99,255,0.12);
  border-radius:16px;overflow:hidden;
  border:1px solid rgba(108,99,255,0.18);
}
.sc-glow{
  position:absolute;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,rgba(108,99,255,0.08),transparent 70%);
  top:-90px;right:-90px;opacity:0;transition:opacity 0.4s;pointer-events:none;
}
.sc-n{
  font-family:'JetBrains Mono',monospace;font-size:0.67rem;
  color:var(--v2);letter-spacing:0.1em;margin-bottom:1.1rem;opacity:0.7;
  transition:color 0.3s,text-shadow 0.3s;
}
.sc-ico{
  font-size:1.9rem;margin-bottom:1.1rem;display:block;
  transition:transform 0.3s;
}
.sc-t{font-size:1.02rem;font-weight:700;margin-bottom:0.65rem;letter-spacing:-0.01em;transition:all 0.3s}
.sc-d{font-size:0.82rem;color:var(--w40);line-height:1.75;margin-bottom:1.1rem;transition:color 0.3s}
.sc-ul{list-style:none;display:flex;flex-direction:column;gap:0.38rem}
.sc-ul li{
  font-size:0.77rem;color:var(--w40);
  display:flex;align-items:flex-start;gap:0.45rem;line-height:1.55;
  transition:color 0.3s;
}
.sc-ul li::before{content:'▸';color:var(--c);font-size:0.63rem;margin-top:0.18rem;flex-shrink:0;transition:color 0.3s,text-shadow 0.3s}
.sc-pill{
  display:inline-block;margin-top:1.2rem;
  padding:0.2rem 0.65rem;border-radius:100px;
  font-family:'JetBrains Mono',monospace;font-size:0.63rem;
  letter-spacing:0.08em;color:var(--v2);
  border:1px solid rgba(108,99,255,0.22);background:rgba(108,99,255,0.06);
  transition:box-shadow 0.3s,border-color 0.3s;
}
.sc-cta{
  background:linear-gradient(135deg,rgba(108,99,255,0.09),rgba(0,212,255,0.05));
  display:flex;flex-direction:column;justify-content:center;
}
.sc-cta h3{font-size:1.4rem;font-weight:800;line-height:1.25;margin:0.8rem 0 1rem;letter-spacing:-0.02em}
.sc-cta p{font-size:0.83rem;color:var(--w40);line-height:1.72;margin-bottom:1.8rem}

/* ============================================================
   SERVICE CARD ENHANCED VISUAL EFFECTS
============================================================ */

/* Shimmer sweep animation on hover */
@keyframes cardShimmer{
  0%{background-position:-200% 0}
  100%{background-position:200% 0}
}
/* Floating pulse for service icons */
@keyframes iconFloat{
  0%,100%{transform:translateY(0) scale(1)}
  50%{transform:translateY(-6px) scale(1.08)}
}
/* Glow pulse on card hover */
@keyframes glowPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(108,99,255,0)}
  50%{box-shadow:0 0 32px 4px rgba(108,99,255,0.18)}
}
/* Staggered entry for list items */
@keyframes listReveal{
  from{opacity:0;transform:translateX(-12px)}
  to{opacity:1;transform:translateX(0)}
}
/* Pill glow pulse */
@keyframes pillGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(108,99,255,0);border-color:rgba(108,99,255,0.22)}
  50%{box-shadow:0 0 14px 2px rgba(108,99,255,0.28);border-color:rgba(108,99,255,0.55)}
}
/* Corner accent sweep */
@keyframes cornerLight{
  0%{opacity:0;transform:translate(-50%,-50%) scale(0.7)}
  50%{opacity:1}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.3)}
}
/* Number count shimmer */
@keyframes numShimmer{
  0%,100%{color:var(--v2);text-shadow:none}
  50%{color:var(--c);text-shadow:0 0 12px rgba(0,212,255,0.5)}
}

/* Enhanced card base */
.sc{
  background:var(--bg1);padding:2.4rem 2rem;position:relative;
  overflow:hidden;transition:background 0.4s,transform 0.35s,box-shadow 0.4s;cursor:none;
}
/* Hover lift + glow */
.sc:hover{
  background:var(--bg2);
  transform:translateY(-4px);
  box-shadow:0 20px 50px rgba(0,0,0,0.35),0 0 40px rgba(108,99,255,0.12);
}

/* Top gradient bar — full slide on hover */
.sc::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--v),var(--c),var(--v2),var(--c));
  background-size:300% 100%;
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.5s ease;
}
.sc:hover::before{transform:scaleX(1);animation:cardShimmer 2s linear infinite}

/* Shimmer overlay sweep */
.sc::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,0.035) 50%,transparent 60%);
  background-size:200% 100%;
  opacity:0;transition:opacity 0.3s;
  pointer-events:none;
}
.sc:hover::after{opacity:1;animation:cardShimmer 1.8s ease infinite}

/* Bottom-left corner accent circle */
.sc .sc-glow{
  position:absolute;width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(108,99,255,0.1),rgba(0,212,255,0.04) 50%,transparent 70%);
  top:-100px;right:-100px;
  opacity:0;transition:opacity 0.5s,transform 0.5s;pointer-events:none;
  transform:scale(0.8);
}
.sc:hover .sc-glow{opacity:1;transform:scale(1)}

/* Second glow — bottom left */
.sc .sc-glow2{
  position:absolute;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(0,212,255,0.07),transparent 70%);
  bottom:-80px;left:-80px;
  opacity:0;transition:opacity 0.5s 0.1s;pointer-events:none;
}
.sc:hover .sc-glow2{opacity:1}

/* Card number — shimmer on hover */
.sc:hover .sc-n{animation:numShimmer 2s ease infinite}

/* Icon — float animation on hover */
.sc:hover .sc-ico{animation:iconFloat 2.2s ease-in-out infinite}

/* List items — stagger reveal on card hover */
.sc:hover .sc-ul li:nth-child(1){animation:listReveal 0.3s 0.0s ease both}
.sc:hover .sc-ul li:nth-child(2){animation:listReveal 0.3s 0.06s ease both}
.sc:hover .sc-ul li:nth-child(3){animation:listReveal 0.3s 0.12s ease both}
.sc:hover .sc-ul li:nth-child(4){animation:listReveal 0.3s 0.18s ease both}
.sc:hover .sc-ul li:nth-child(5){animation:listReveal 0.3s 0.24s ease both}

/* List item text brightens on hover */
.sc:hover .sc-ul li{color:var(--w70)}
.sc:hover .sc-ul li::before{color:var(--v2);text-shadow:0 0 8px rgba(0,212,255,0.5)}

/* Description text brightens */
.sc:hover .sc-d{color:rgba(237,238,255,0.62)}

/* Title gets subtle gradient on hover */
.sc:hover .sc-t{
  background:linear-gradient(90deg,var(--w),var(--c2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}

/* Pill — glowing pulse on hover */
.sc:hover .sc-pill{animation:pillGlow 2s ease-in-out infinite}

/* Active (touch) states */
.sc:active{transform:translateY(-2px);transition:transform 0.1s}

/* Scroll-in stagger: cards already get .rv — enhance with per-card delays */
.sg .sc:nth-child(1).rv{transition-delay:0s}
.sg .sc:nth-child(2).rv{transition-delay:0.07s}
.sg .sc:nth-child(3).rv{transition-delay:0.14s}
.sg .sc:nth-child(4).rv{transition-delay:0.21s}
.sg .sc:nth-child(5).rv{transition-delay:0.28s}
.sg .sc:nth-child(6).rv{transition-delay:0.35s}

/* CTA card special hover */
.sc-cta:hover{
  background:linear-gradient(135deg,rgba(108,99,255,0.16),rgba(0,212,255,0.09)) !important;
  box-shadow:0 20px 50px rgba(0,0,0,0.35),0 0 40px rgba(108,99,255,0.18);
}
#about{background:var(--bg1)}
.abt-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.abt-canvas-box{
  position:relative;border-radius:20px;overflow:hidden;
  border:1px solid rgba(108,99,255,0.2);background:var(--bg2);
}
#fdc{width:100%;height:460px;display:block}
.abt-overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:2rem;
  background:linear-gradient(0deg,rgba(8,12,24,0.97) 0%,transparent 100%);
}
.abt-name{font-size:1.75rem;font-weight:800;letter-spacing:-0.02em;margin-bottom:0.25rem}
.abt-role{font-family:'JetBrains Mono',monospace;font-size:0.7rem;color:var(--c);letter-spacing:0.06em}
.abt-txt .stag{margin-bottom:0.8rem}
.abt-story{color:var(--w70);font-size:0.95rem;line-height:1.88;margin:1.3rem 0 2rem}
.abt-story strong{color:var(--w);font-weight:700}
.abt-sg{display:grid;grid-template-columns:1fr 1fr;gap:0.9rem;margin-bottom:2rem}
.abt-sb{
  background:var(--bg2);border:1px solid rgba(108,99,255,0.18);
  border-radius:12px;padding:1.2rem;transition:all 0.3s;cursor:none;
}
.abt-sb:hover{border-color:rgba(108,99,255,0.4);background:var(--gv);transform:translateY(-2px)}
.abt-sv{
  font-size:1.85rem;font-weight:800;letter-spacing:-0.03em;
  background:linear-gradient(135deg,var(--v),var(--c));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.abt-sl{font-size:0.7rem;color:var(--w40);margin-top:0.25rem;font-family:'JetBrains Mono',monospace;letter-spacing:0.04em}
.skills{display:flex;flex-wrap:wrap;gap:0.45rem}
.sk{
  padding:0.3rem 0.82rem;border:1px solid var(--w15);
  border-radius:100px;font-size:0.73rem;color:var(--w70);
  font-family:'JetBrains Mono',monospace;transition:all 0.2s;cursor:none;
}
.sk:hover{border-color:var(--v2);color:var(--v2);background:var(--gv)}

/* ============================================================
   HOW IT WORKS
============================================================ */
#how{background:linear-gradient(180deg,var(--bg1),var(--bg0))}
.how-steps{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:1.5rem;margin-top:4rem;position:relative;
}
.how-steps::before{
  content:'';position:absolute;top:1.35rem;left:5%;right:5%;height:1px;
  background:linear-gradient(90deg,var(--v),var(--c),var(--v));opacity:0.2;
}
.how-s{text-align:center;padding:0 0.8rem;position:relative}
.how-b{
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;
  background:linear-gradient(135deg,var(--gv),var(--gc));
  border:1px solid rgba(108,99,255,0.3);
  font-family:'JetBrains Mono',monospace;font-size:0.78rem;font-weight:600;color:var(--v2);
  position:relative;z-index:1;transition:all 0.3s;
}
.how-b::before{
  content:'';position:absolute;inset:-6px;border-radius:50%;
  border:1px solid rgba(108,99,255,0.12);
  animation:spinRing 9s linear infinite;
}
@keyframes spinRing{to{transform:rotate(360deg)}}
.how-s:hover .how-b{
  background:linear-gradient(135deg,var(--v),var(--c));
  color:#000;box-shadow:0 0 28px rgba(108,99,255,0.45);transform:scale(1.1);
}
.how-t{font-size:0.9rem;font-weight:700;margin-bottom:0.45rem;letter-spacing:-0.01em}
.how-d{font-size:0.77rem;color:var(--w40);line-height:1.65}

/* ============================================================
   CONTACT
============================================================ */
#contact{background:var(--bg2)}
.ct-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:6rem;align-items:start}
.ct-info h2{margin-bottom:1.2rem}
.ct-info p{color:var(--w40);font-size:0.93rem;line-height:1.85;margin-bottom:2.5rem}
.ct-chs{display:flex;flex-direction:column;gap:0.75rem}
.ct-ch{
  display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;
  background:var(--w04);border:1px solid var(--w08);border-radius:10px;
  text-decoration:none;transition:all 0.25s;cursor:none;
}
.ct-ch:hover{background:var(--gv);border-color:rgba(108,99,255,0.28);transform:translateX(4px)}
.ct-ico{
  width:36px;height:36px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,var(--gv),var(--gc));
  border:1px solid rgba(108,99,255,0.2);
  display:flex;align-items:center;justify-content:center;font-size:1rem;
}
.ct-tx strong{display:block;font-size:0.86rem;font-weight:600;margin-bottom:0.1rem}
.ct-tx span{font-size:0.75rem;color:var(--w40)}
.ct-form{
  background:var(--bg1);border:1px solid rgba(108,99,255,0.2);
  border-radius:16px;padding:2.5rem;position:relative;overflow:hidden;
}
.ct-form::before{
  content:'';position:absolute;top:-60px;right:-60px;width:180px;height:180px;
  background:radial-gradient(circle,rgba(108,99,255,0.1),transparent 70%);pointer-events:none;
}
.ct-fh{font-size:1.25rem;font-weight:800;margin-bottom:0.25rem;letter-spacing:-0.02em}
.ct-fs{font-family:'JetBrains Mono',monospace;font-size:0.7rem;color:var(--w40);margin-bottom:1.8rem;letter-spacing:0.04em}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.fg{display:flex;flex-direction:column;gap:0.42rem;margin-bottom:1rem}
.fg label{
  font-family:'JetBrains Mono',monospace;font-size:0.67rem;
  letter-spacing:0.1em;color:var(--w40);text-transform:uppercase;
}
.fg input,.fg select,.fg textarea{
  background:rgba(237,238,255,0.04);border:1px solid rgba(237,238,255,0.1);
  border-radius:8px;padding:0.85rem 1rem;
  color:var(--w);font-family:'Space Grotesk',sans-serif;font-size:0.87rem;
  outline:none;transition:all 0.2s;width:100%;
}
.fg input::placeholder,.fg textarea::placeholder{color:var(--w40)}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:rgba(108,99,255,0.42);
  background:rgba(108,99,255,0.06);
  box-shadow:0 0 0 3px rgba(108,99,255,0.1);
}
.fg select option{background:var(--bg1);color:var(--w)}
.fg textarea{height:110px;resize:none}
.fg-full{grid-column:1/-1}
.fsub{
  width:100%;padding:1rem;border:none;border-radius:10px;
  background:linear-gradient(135deg,var(--v),var(--c));
  color:#000;font-family:'Space Grotesk',sans-serif;
  font-weight:700;font-size:0.96rem;cursor:none;
  transition:all 0.3s;position:relative;overflow:hidden;
  letter-spacing:0.01em;
}
.fsub::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,0.2) 50%,transparent 70%);
  transform:translateX(-100%);transition:transform 0.5s;
}
.fsub:hover::before{transform:translateX(100%)}
.fsub:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(108,99,255,0.42)}
.fsub:disabled{opacity:0.65;cursor:not-allowed;transform:none}
#ferr{font-family:'JetBrains Mono',monospace;font-size:0.74rem;color:var(--rose);margin-top:0.6rem;min-height:1.1em}
#fok{display:none;text-align:center;padding:2.5rem 1rem}
.fok-icon{font-size:3rem;margin-bottom:0.8rem;animation:popIn 0.5s ease}
@keyframes popIn{from{transform:scale(0)}80%{transform:scale(1.2)}to{transform:scale(1)}}

/* ============================================================
   CTA
============================================================ */
#cta{text-align:center;padding:11rem 5rem;background:var(--bg0);position:relative;overflow:hidden}
.cta-rings{position:absolute;top:50%;left:50%;pointer-events:none}
.cr{
  position:absolute;border-radius:50%;border:1px solid rgba(108,99,255,0.07);
  transform:translate(-50%,-50%);
}
.cr:nth-child(1){width:380px;height:380px}
.cr:nth-child(2){width:650px;height:650px;border-color:rgba(0,212,255,0.055);animation:crSpin 28s linear infinite}
.cr:nth-child(3){width:920px;height:920px;animation:crSpin 45s linear infinite reverse}
@keyframes crSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.cta-glow{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:500px;height:280px;pointer-events:none;
  background:radial-gradient(ellipse,rgba(108,99,255,0.07),transparent 70%);
}
#cta .cont{position:relative;z-index:1}
#cta .stag{justify-content:center;margin-bottom:1.5rem}
#cta .sh{font-size:clamp(2.8rem,5vw,4.5rem);margin-bottom:1.2rem}
#cta .sp{margin:0 auto 3rem;text-align:center}
.cta-bs{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}
.wa-b{
  display:inline-flex;align-items:center;gap:0.65rem;
  padding:1rem 2.3rem;background:#25D366;color:#000;
  border-radius:10px;font-weight:700;font-size:0.94rem;
  text-decoration:none;transition:all 0.3s;font-family:'Space Grotesk',sans-serif;
}
.wa-b:hover{transform:translateY(-3px);box-shadow:0 14px 42px rgba(37,211,102,0.42)}

/* ============================================================
   FOOTER
============================================================ */
footer{
  background:var(--bg0);border-top:1px solid var(--w08);
  padding:2rem 5rem;position:relative;z-index:2;
  display:flex;align-items:center;justify-content:space-between;
}
.fl{
  font-size:1.1rem;font-weight:800;
  background:linear-gradient(120deg,var(--v),var(--c));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
footer p{font-size:0.75rem;color:var(--w40);font-family:'JetBrains Mono',monospace}
.fls{display:flex;gap:1.8rem}
.fls a{font-size:0.77rem;color:var(--w40);text-decoration:none;transition:color 0.2s;font-family:'JetBrains Mono',monospace}
.fls a:hover{color:var(--v2)}

/* ============================================================
   FLOATING WA
============================================================ */
.wa-float{
  position:fixed;bottom:2rem;right:2rem;z-index:400;
  width:56px;height:56px;background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1.55rem;
  text-decoration:none;cursor:none;
  box-shadow:0 4px 24px rgba(37,211,102,0.45);
  animation:waBounce 0.7s 1.8s cubic-bezier(0.175,0.885,0.32,1.275) both;
  transition:transform 0.25s,box-shadow 0.25s;
}
.wa-float:hover{transform:scale(1.12);box-shadow:0 8px 36px rgba(37,211,102,0.58)}
.wa-float::before{
  content:'';position:absolute;inset:-5px;border-radius:50%;
  border:1px solid rgba(37,211,102,0.38);animation:waPing 2.8s infinite;
}
@keyframes waBounce{from{transform:scale(0) rotate(-180deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
@keyframes waPing{0%,100%{transform:scale(1);opacity:0.55}50%{transform:scale(1.5);opacity:0}}

/* ============================================================
   SCROLL REVEAL
============================================================ */
.rv{opacity:0;transform:translateY(26px);transition:opacity 0.75s ease,transform 0.75s ease}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:0.1s}.rv.d2{transition-delay:0.2s}
.rv.d3{transition-delay:0.3s}.rv.d4{transition-delay:0.4s}.rv.d5{transition-delay:0.5s}

/* ============================================================
   ADMIN OVERLAY
============================================================ */
#adm{
  position:fixed;inset:0;z-index:9999;
  display:none;flex-direction:column;
  background:rgba(5,8,16,0.97);backdrop-filter:blur(40px);
}
#adm.open{display:flex}
.adm-lw{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.5rem}
.adm-lc{
  width:400px;background:var(--bg1);border:1px solid rgba(108,99,255,0.22);
  border-radius:16px;padding:3rem;text-align:center;position:relative;overflow:hidden;
}
.adm-lc::before{
  content:'';position:absolute;top:-55px;left:50%;transform:translateX(-50%);
  width:180px;height:180px;
  background:radial-gradient(circle,rgba(108,99,255,0.12),transparent 70%);pointer-events:none;
}
.adm-lc h3{
  font-size:1.65rem;font-weight:800;letter-spacing:-0.02em;margin-bottom:0.35rem;
  background:linear-gradient(135deg,var(--v),var(--c));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.adm-lc p{font-family:'JetBrains Mono',monospace;font-size:0.72rem;color:var(--w40);margin-bottom:2rem}
#adm-err{font-family:'JetBrains Mono',monospace;font-size:0.74rem;color:var(--rose);margin-top:0.75rem;min-height:1.1em}
.adm-cb{
  padding:0.55rem 1.3rem;background:var(--w08);border:1px solid var(--w15);
  border-radius:8px;color:var(--w40);font-family:'JetBrains Mono',monospace;
  font-size:0.77rem;cursor:pointer;transition:all 0.2s;
}
.adm-cb:hover{background:var(--w15);color:var(--w)}
.adm-panel{flex:1;display:none;flex-direction:column;overflow:hidden}
.adm-panel.open{display:flex}
.adm-tb{
  display:flex;align-items:center;gap:0.8rem;
  padding:1rem 2rem;background:var(--bg1);border-bottom:1px solid rgba(108,99,255,0.18);
}
.adm-brand{
  font-size:1.05rem;font-weight:800;margin-right:auto;
  background:linear-gradient(120deg,var(--v),var(--c));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.adm-btn{
  padding:0.48rem 1rem;background:var(--w08);border:1px solid var(--w15);
  border-radius:8px;color:var(--w40);font-family:'JetBrains Mono',monospace;
  font-size:0.77rem;cursor:pointer;transition:all 0.2s;
}
.adm-btn:hover{background:var(--gv);color:var(--v2);border-color:rgba(108,99,255,0.3)}
.adm-body{display:flex;flex:1;overflow:hidden}
.adm-side{
  width:195px;background:var(--bg1);border-right:1px solid rgba(108,99,255,0.15);
  padding:1.2rem 0.75rem;display:flex;flex-direction:column;gap:0.28rem;
}
.adm-nav{
  display:flex;align-items:center;gap:0.55rem;
  padding:0.62rem 1rem;border-radius:8px;
  font-family:'JetBrains Mono',monospace;font-size:0.79rem;color:var(--w40);
  cursor:pointer;transition:all 0.2s;
}
.adm-nav:hover,.adm-nav.on{background:var(--gv);color:var(--v2)}
.adm-main{flex:1;overflow-y:auto;padding:2rem;scrollbar-width:thin;scrollbar-color:rgba(108,99,255,0.2) transparent}
.adm-tab{display:none}
.adm-tab.on{display:block}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}
.kpi{
  background:var(--bg1);border:1px solid rgba(108,99,255,0.18);
  border-radius:10px;padding:1.2rem;text-align:center;transition:all 0.3s;
}
.kpi:hover{border-color:rgba(108,99,255,0.38);background:var(--gv)}
.kpi-v{
  font-size:1.9rem;font-weight:800;letter-spacing:-0.03em;
  background:linear-gradient(135deg,var(--v),var(--c));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.kpi-l{font-size:0.69rem;color:var(--w40);font-family:'JetBrains Mono',monospace;letter-spacing:0.05em;margin-top:0.25rem}
.adm-bar{display:flex;gap:0.75rem;margin-bottom:1.2rem;align-items:center}
.adm-inp{
  flex:1;padding:0.68rem 1rem;background:var(--w04);border:1px solid var(--w08);
  border-radius:8px;color:var(--w);font-family:'JetBrains Mono',monospace;font-size:0.8rem;outline:none;
}
.adm-inp:focus{border-color:rgba(108,99,255,0.38)}
.adm-sel{
  padding:0.68rem 1rem;background:var(--w04);border:1px solid var(--w08);
  border-radius:8px;color:var(--w);font-family:'JetBrains Mono',monospace;font-size:0.8rem;outline:none;
}
.adm-exp{
  padding:0.68rem 1.2rem;background:var(--gv);border:1px solid rgba(108,99,255,0.2);
  border-radius:8px;color:var(--v2);font-family:'JetBrains Mono',monospace;font-size:0.77rem;cursor:pointer;
}
.adm-exp:hover{background:rgba(108,99,255,0.18)}
.lt{width:100%;border-collapse:collapse;background:var(--bg1);border-radius:12px;overflow:hidden;border:1px solid rgba(108,99,255,0.18)}
.lt th{
  padding:0.82rem 1rem;background:rgba(108,99,255,0.07);
  font-family:'JetBrains Mono',monospace;font-size:0.67rem;
  color:var(--v2);letter-spacing:0.08em;text-align:left;border-bottom:1px solid rgba(108,99,255,0.18);
}
.lt td{padding:0.82rem 1rem;font-size:0.81rem;color:var(--w70);border-bottom:1px solid rgba(237,238,255,0.04)}
.lt tr:last-child td{border-bottom:none}
.lt tr:hover td{background:rgba(108,99,255,0.03)}
.sb{padding:0.18rem 0.6rem;border-radius:4px;font-size:0.67rem;font-weight:700;font-family:'JetBrains Mono',monospace}
.sb-n{background:rgba(108,99,255,0.12);color:var(--v2)}
.sb-c{background:rgba(0,212,255,0.1);color:var(--c2)}
.sb-v{background:rgba(37,211,102,0.1);color:#25D366}
.s-sel{
  background:var(--w04);border:1px solid var(--w08);border-radius:4px;
  color:var(--w);font-family:'JetBrains Mono',monospace;font-size:0.67rem;
  padding:0.14rem 0.38rem;outline:none;cursor:pointer;
}
.adm-ph{
  background:var(--bg1);border:1px solid rgba(108,99,255,0.18);
  border-radius:12px;padding:3rem;text-align:center;margin-top:1rem;
}
.adm-ph .phi{font-size:2.5rem;margin-bottom:0.8rem}
.adm-ph p{font-family:'JetBrains Mono',monospace;font-size:0.8rem;color:var(--w40)}

/* ============================================================
   RESPONSIVE
============================================================ */
@media(max-width:1024px){
  #nav{padding:1rem 2.5rem}
  section{padding:6rem 2.5rem}
  .hero-wrap{grid-template-columns:1fr}
  .hero-r{display:none}
  .sg{grid-template-columns:1fr 1fr}
  .abt-grid,.ct-grid{grid-template-columns:1fr;gap:3rem}
  .how-steps{grid-template-columns:repeat(3,1fr)}
  .how-steps::before{display:none}
  footer{flex-direction:column;gap:1rem;text-align:center;padding:2rem}
  .kpis{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  /* FIX 1: Mobile alignment corrections */
  #nav{padding:0.85rem 1.25rem;display:flex;align-items:center;justify-content:space-between}
  .n-logo{font-size:1.1rem}
  .n-right{gap:0.5rem}
  .n-adm{display:none}
  .n-cta{padding:0.5rem 1rem;font-size:0.8rem}
  section{padding:5rem 1.25rem}
  footer{padding:1.5rem 1.25rem}
  .n-links{display:none}

  /* Hero mobile fixes */
  #hero{padding:6rem 1.25rem 3rem;align-items:flex-start}
  .hero-wrap{gap:2rem}
  .hero-h1{font-size:clamp(2.2rem,8vw,3rem)}
  .hero-p{font-size:0.95rem;max-width:100%}
  .hero-btns{gap:0.75rem;margin-top:2rem}
  .btn-p,.btn-o{padding:0.8rem 1.6rem;font-size:0.87rem}
  .hero-stats{gap:1rem;flex-wrap:wrap;margin-top:2.5rem;padding-top:1.8rem}
  .hs-v{font-size:1.7rem}
  .hs-sep{height:30px}

  /* Services mobile */
  .sg{grid-template-columns:1fr}
  .svc-top{flex-direction:column;align-items:flex-start;gap:1rem}

  /* How steps */
  .how-steps{grid-template-columns:1fr 1fr}

  /* Contact + forms */
  .frow,.form-row{grid-template-columns:1fr}
  .cta-bs{flex-direction:column;align-items:center;gap:0.75rem}
  .ct-info{gap:1.5rem}

  /* FIX 2: WhatsApp icon visible on mobile */
  .wa-float{
    bottom:1.5rem;right:1.25rem;
    width:52px;height:52px;font-size:1.55rem;
    cursor:pointer;
    z-index:9000;
    display:flex !important;
    opacity:1 !important;
  }

  /* About section */
  .abt-grid{gap:2.5rem}
  .skills{gap:0.4rem}
  .sk{font-size:0.72rem;padding:0.3rem 0.65rem}
  .abt-sg{grid-template-columns:1fr 1fr;gap:1rem}

  /* Footer */
  footer{flex-direction:column;gap:0.75rem;text-align:center;padding:1.5rem 1.25rem}
  .kpis{grid-template-columns:1fr 1fr}
}
