/* =============================================
   AniBlend — Neon Cyberpunk Premium CSS
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=Space+Grotesk:wght@300;400;500;600;700&display=swap');

/* ── TOKENS ─────────────────────────────────── */
:root {
  --neon-purple: #9d00ff;
  --neon-cyan:   #00f5ff;
  --neon-pink:   #ff006e;
  --neon-green:  #39ff14;
  --neon-gold:   #ffbe0b;

  --bg:          #020205;
  --bg-2:        #07070f;
  --bg-card:     rgba(255,255,255,0.03);
  --border:      rgba(255,255,255,0.07);
  --border-neon: rgba(157,0,255,0.35);

  --txt:         #f0f0ff;
  --txt-2:       #8888aa;
  --txt-3:       #444466;

  --grad-main:   linear-gradient(135deg, var(--neon-purple), var(--neon-cyan));
  --grad-hot:    linear-gradient(135deg, var(--neon-pink), var(--neon-purple));
  --grad-glow:   linear-gradient(135deg, var(--neon-purple) 0%, var(--neon-cyan) 100%);

  --radius:      18px;
  --radius-sm:   10px;
  --ease:        cubic-bezier(0.23, 1, 0.32, 1);
  --trans:       all 0.4s var(--ease);
}

/* ── RESET ───────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family: 'Space Grotesk', sans-serif;
  background: var(--bg);
  color: var(--txt);
  overflow-x: hidden;
  cursor: none;
}
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
img { max-width:100%; display:block; }
button, input, select, textarea { font-family:inherit; }

/* ── NOISE OVERLAY ───────────────────────────── */
.noise-overlay {
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 9999;
  opacity: 0.4;
}

/* ── CURSOR ──────────────────────────────────── */
.cursor {
  width: 10px; height: 10px;
  background: var(--neon-purple);
  border-radius: 50%;
  position: fixed; pointer-events:none;
  z-index: 99999;
  transform: translate(-50%,-50%);
  transition: transform 0.1s, background 0.3s;
  mix-blend-mode: screen;
}
.cursor-follower {
  width: 36px; height: 36px;
  border: 1.5px solid rgba(157,0,255,0.5);
  border-radius: 50%;
  position: fixed; pointer-events: none;
  z-index: 99998;
  transform: translate(-50%,-50%);
  transition: all 0.12s ease-out;
}

/* ── LOADER ──────────────────────────────────── */
.loader {
  position: fixed; inset: 0;
  background: #000007;
  display: flex; align-items:center; justify-content:center;
  z-index: 99997;
  transition: opacity 0.8s var(--ease), visibility 0.8s;
}
.loader.out { opacity: 0; visibility: hidden; pointer-events:none; }
.loader-inner { text-align:center; position:relative; }
.loader-logo-wrap {
  font-family: 'Syne', sans-serif;
  font-size: clamp(3rem,9vw,7rem);
  font-weight: 900;
  letter-spacing: -4px;
  line-height: 1;
  margin-bottom: 12px;
}
.ldr-ani { color: var(--txt); }
.ldr-blend {
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.loader-tagline {
  font-size: 12px;
  color: var(--txt-2);
  letter-spacing: 4px;
  text-transform: uppercase;
  margin-bottom: 40px;
}
.loader-bar-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
  width: 280px;
  margin: 0 auto;
}
.loader-bar {
  flex: 1; height: 2px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  overflow: hidden;
  position: relative;
}
.loader-bar::after {
  content:'';
  position:absolute; inset:0;
  background: var(--grad-main);
  width: 0%;
  transition: width 0.05s linear;
}
.loader-pct {
  font-size: 12px;
  color: var(--txt-2);
  font-weight: 500;
  letter-spacing: 1px;
  min-width: 36px;
  text-align:right;
}
.loader-scanlines {
  position:absolute; inset:0;
  background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(157,0,255,0.02) 2px, rgba(157,0,255,0.02) 4px);
  pointer-events:none;
  animation: scanAnim 8s linear infinite;
}
@keyframes scanAnim { from {background-position:0 0;} to {background-position:0 100%;} }

/* ── NAVBAR ──────────────────────────────────── */
.navbar {
  position:fixed; top:0; left:0; right:0;
  z-index: 1000;
  padding: 20px 0;
  transition: var(--trans);
}
.navbar.scrolled {
  background: rgba(2,2,5,0.9);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border);
  padding: 12px 0;
}
.nav-inner {
  max-width:1360px; margin:0 auto; padding:0 40px;
  display:flex; align-items:center; gap:32px;
}
.nav-brand {
  display:flex; align-items:center; gap:12px;
  flex-shrink:0;
}
.brand-logo { width:38px; height:38px; border-radius:10px; object-fit:cover; }
.brand-name {
  font-family:'Syne',sans-serif;
  font-size:20px; font-weight:800;
  letter-spacing:-0.5px;
}
.brand-accent {
  background: var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.nav-menu {
  display:flex; align-items:center; gap:4px;
  margin:0 auto;
}
.nav-item {
  padding:8px 16px;
  font-size:14px; font-weight:500;
  color: var(--txt-2);
  border-radius:8px;
  transition: var(--trans);
  position:relative;
}
.nav-item:hover, .nav-item.active { color:var(--txt); background:rgba(157,0,255,0.1); }
.nav-item.active::after {
  content:'';
  position:absolute; bottom:4px; left:50%;
  transform:translateX(-50%);
  width:4px; height:4px;
  background:var(--neon-purple);
  border-radius:50%;
}
.nav-phone {
  display:flex; align-items:center; gap:8px;
  padding:10px 20px;
  background: rgba(157,0,255,0.12);
  border:1px solid rgba(157,0,255,0.3);
  border-radius:50px;
  font-size:13px; font-weight:600;
  color: var(--neon-purple);
  transition: var(--trans);
  flex-shrink:0;
  white-space:nowrap;
}
.nav-phone:hover {
  background: rgba(157,0,255,0.2);
  box-shadow: 0 0 20px rgba(157,0,255,0.3);
}
.nav-toggle {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
}
.toggle-line {
  display:block; width:24px; height:2px;
  background:var(--txt); border-radius:2px;
  transition:var(--trans);
}

/* ── WRAP ────────────────────────────────────── */
.wrap {
  max-width:1360px; margin:0 auto; padding:0 40px;
}

/* ── NEON TEXT ───────────────────────────────── */
.neon-text {
  background: var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.neon-word {
  background: var(--grad-hot);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ── SECTION COMMONS ─────────────────────────── */
section { padding:120px 0; }
.sec-head { text-align:center; margin-bottom:80px; }
.label-tag {
  display:inline-block;
  padding:6px 18px;
  background:rgba(157,0,255,0.1);
  border:1px solid rgba(157,0,255,0.25);
  border-radius:50px;
  font-size:11px; font-weight:700;
  color:rgba(157,0,255,0.9);
  letter-spacing:3px; text-transform:uppercase;
  margin-bottom:20px;
}
.sec-title {
  font-family:'Syne',sans-serif;
  font-size:clamp(2rem,4.5vw,3.8rem);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-2px;
  margin-bottom:16px;
}
.sec-sub {
  font-size:1.05rem;
  color:var(--txt-2);
  max-width:520px;
  margin:0 auto;
  line-height:1.75;
}

/* ── BUTTONS ─────────────────────────────────── */
.cta-primary {
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 36px;
  background:var(--grad-main);
  border:none; border-radius:50px;
  font-size:15px; font-weight:700;
  color:#fff; cursor:pointer;
  transition: var(--trans);
  position:relative; overflow:hidden;
}
.cta-primary::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.15),transparent);
  opacity:0; transition:opacity 0.3s;
}
.cta-primary:hover { transform:translateY(-3px); box-shadow:0 16px 50px rgba(157,0,255,0.45), 0 0 30px rgba(0,245,255,0.2); }
.cta-primary:hover::before { opacity:1; }
.cta-primary svg { flex-shrink:0; transition:transform 0.3s; }
.cta-primary:hover svg { transform:translateX(4px); }
.cta-full { width:100%; justify-content:center; border-radius:12px; }

.cta-secondary {
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 32px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:50px;
  font-size:15px; font-weight:600;
  color:var(--txt); cursor:pointer;
  transition:var(--trans);
}
.cta-secondary:hover {
  background:rgba(157,0,255,0.1);
  border-color:rgba(157,0,255,0.4);
  box-shadow:0 0 20px rgba(157,0,255,0.15);
  transform:translateY(-2px);
}

/* ── HERO ────────────────────────────────────── */
.hero {
  min-height:100vh;
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  position:relative; overflow:hidden;
  padding:140px 40px 80px;
}
#hero-canvas {
  position:absolute; inset:0;
  width:100%; height:100%;
  pointer-events:none; z-index:0;
}
.hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0.2; z-index:0;
}
.hero-bg::after {
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(ellipse at center bottom, transparent 20%, var(--bg) 80%);
}
.hero-grid-lines {
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(157,0,255,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(157,0,255,0.05) 1px, transparent 1px);
  background-size: 60px 60px;
  z-index:0;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}
.hero-body {
  position:relative; z-index:2;
  text-align:center;
  max-width:960px; margin:0 auto;
}
.hero-chip {
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 22px;
  background:rgba(157,0,255,0.1);
  border:1px solid rgba(157,0,255,0.3);
  border-radius:50px;
  font-size:13px; font-weight:500;
  color:rgba(157,0,255,0.9);
  letter-spacing:0.5px;
  margin-bottom:36px;
}
.chip-dot {
  width:8px; height:8px;
  background:var(--neon-purple);
  border-radius:50%;
  animation:chipBlink 2s infinite;
}
@keyframes chipBlink {
  0%,100% { box-shadow:0 0 0 0 rgba(157,0,255,0.7); }
  50% { box-shadow:0 0 0 6px rgba(157,0,255,0); }
}
.hero-heading {
  font-family:'Syne',sans-serif;
  font-size:clamp(3.5rem,8vw,8rem);
  font-weight:900;
  line-height:0.95;
  letter-spacing:-5px;
  margin-bottom:32px;
}
.hline {
  display:block;
  opacity:0; transform:translateY(50px);
  animation:hReveal 0.9s var(--ease) forwards;
}
.hline-1 { animation-delay:0.4s; }
.hline-2 { animation-delay:0.6s; }
.hline-3 { animation-delay:0.8s; }
@keyframes hReveal { to { opacity:1; transform:translateY(0); } }

.hero-sub {
  font-size:clamp(0.95rem,1.8vw,1.15rem);
  color:var(--txt-2);
  max-width:680px;
  margin:0 auto 48px;
  line-height:1.75;
  opacity:0; animation:fadeUp 0.8s 1s var(--ease) forwards;
}
.hero-sub strong { color:var(--txt); }
@keyframes fadeUp { from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:none;} }

.hero-ctas {
  display:flex; align-items:center; justify-content:center;
  gap:20px; flex-wrap:wrap;
  margin-bottom:80px;
  opacity:0; animation:fadeUp 0.8s 1.2s var(--ease) forwards;
}
.hero-numbers {
  display:flex; align-items:center; justify-content:center;
  gap:48px; flex-wrap:wrap;
  opacity:0; animation:fadeUp 0.8s 1.4s var(--ease) forwards;
}
.num-item { text-align:center; }
.num-val {
  font-family:'Syne',sans-serif;
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:900;
  background:var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
}
.num-label {
  font-size:12px; color:var(--txt-2);
  letter-spacing:0.5px; margin-top:6px;
}
.num-sep {
  width:1px; height:50px;
  background:var(--border);
}
.hero-scroll-hint {
  position:absolute; bottom:36px; left:50%;
  transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-size:10px; letter-spacing:3px; text-transform:uppercase;
  color:var(--txt-3); z-index:2;
}
.scroll-pulse {
  width:20px; height:32px;
  border:1.5px solid rgba(157,0,255,0.4);
  border-radius:10px;
  position:relative;
}
.scroll-pulse::after {
  content:'';
  width:4px; height:4px;
  background:var(--neon-purple);
  border-radius:50%;
  position:absolute; top:6px; left:50%;
  transform:translateX(-50%);
  animation:scrollBob 2s infinite var(--ease);
}
@keyframes scrollBob { 0%,100%{top:6px;opacity:1;} 80%{top:16px;opacity:0;} }

/* Neon Orbs */
.neon-orbs { position:absolute; inset:0; pointer-events:none; z-index:1; }
.orb {
  position:absolute; border-radius:50%;
  filter:blur(100px); opacity:0.4;
  animation:orbFloat 10s infinite ease-in-out;
}
.orb-1 { width:500px;height:500px; background:radial-gradient(circle,rgba(157,0,255,0.25),transparent); top:-100px;right:-100px; animation-delay:0s; }
.orb-2 { width:350px;height:350px; background:radial-gradient(circle,rgba(0,245,255,0.15),transparent); bottom:-50px;left:-50px; animation-delay:3s; }
.orb-3 { width:250px;height:250px; background:radial-gradient(circle,rgba(255,0,110,0.12),transparent); top:40%;left:20%; animation-delay:6s; }
@keyframes orbFloat {
  0%,100% { transform:translate(0,0) scale(1); }
  33% { transform:translate(25px,-40px) scale(1.05); }
  66% { transform:translate(-20px,25px) scale(0.95); }
}

/* ── TICKER ──────────────────────────────────── */
.ticker {
  padding:18px 0;
  background:rgba(157,0,255,0.06);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  overflow:hidden;
}
.ticker-track {
  display:flex; align-items:center; gap:32px;
  white-space:nowrap;
  font-size:13px; font-weight:600;
  color:var(--txt-2);
  letter-spacing:1.5px; text-transform:uppercase;
  animation:tickerRun 30s linear infinite;
}
.ticker-track .sep { color:var(--neon-purple); font-size:8px; }
@keyframes tickerRun { from{transform:translateX(0);} to{transform:translateX(-50%);} }

/* ── ABOUT ───────────────────────────────────── */
.about { background: var(--bg-2); }
.about-layout {
  display:grid; grid-template-columns:1fr 1fr;
  gap:80px; align-items:center;
}
.about-media { position:relative; }
.about-img-frame {
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border-neon);
  position:relative;
  box-shadow:0 0 60px rgba(157,0,255,0.1), inset 0 0 60px rgba(157,0,255,0.03);
}
.about-img-frame img { width:100%; aspect-ratio:4/3; object-fit:cover; }
.img-glitch-border {
  position:absolute; inset:0;
  border-radius:var(--radius);
  background:linear-gradient(135deg,rgba(157,0,255,0.15),transparent 40%,rgba(0,245,255,0.1));
  pointer-events:none;
}
.about-badge-float {
  position:absolute;
  background:rgba(7,7,15,0.9);
  border:1px solid var(--border-neon);
  border-radius:14px;
  padding:14px 18px;
  display:flex; align-items:center; gap:12px;
  backdrop-filter:blur(10px);
  box-shadow:0 0 20px rgba(157,0,255,0.15);
}
.badge-f1 { top:-20px; right:-20px; animation:floatBadge 4s ease-in-out infinite; }
.badge-f2 { bottom:30px; left:-20px; animation:floatBadge 4s 2s ease-in-out infinite; }
@keyframes floatBadge { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-8px);} }
.badge-icon { font-size:26px; }
.badge-t { font-size:14px; font-weight:700; }
.badge-s { font-size:11px; color:var(--txt-2); }

.about-text { display:flex; flex-direction:column; gap:0; }
.about-text .label-tag { display:inline-block; margin-bottom:20px; }
.about-para {
  font-size:1rem; color:var(--txt-2); line-height:1.85;
  margin-bottom:20px;
}
.about-para strong { color:var(--txt); }
.tools-row {
  display:flex; gap:8px; flex-wrap:wrap;
  margin:8px 0 28px;
}
.tool-pill {
  padding:6px 14px;
  background:rgba(157,0,255,0.08);
  border:1px solid rgba(157,0,255,0.2);
  border-radius:50px;
  font-size:12px; font-weight:600;
  color:rgba(157,0,255,0.85);
  letter-spacing:0.5px;
}
.about-checklist { margin-bottom:36px; display:flex; flex-direction:column; gap:16px; }
.check-row { display:flex; align-items:flex-start; gap:14px; }
.ck {
  color:var(--neon-cyan); font-size:14px;
  margin-top:2px; flex-shrink:0;
}
.check-row strong { display:block; font-size:15px; margin-bottom:2px; }
.check-row div { font-size:14px; color:var(--txt-2); }

/* ── SERVICES ────────────────────────────────── */
.services { background:var(--bg); }
.srv-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.srv-card {
  position:relative;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:36px 28px;
  overflow:hidden;
  cursor:pointer;
  transition:var(--trans);
}
.srv-card::before {
  content:''; position:absolute;
  inset:0; border-radius:var(--radius);
  background:var(--grad-main);
  opacity:0; transition:opacity 0.4s;
  z-index:0;
}
.srv-card:hover {
  border-color:rgba(157,0,255,0.5);
  transform:translateY(-10px);
  box-shadow:0 30px 80px rgba(157,0,255,0.18), 0 0 40px rgba(0,245,255,0.08);
}
.srv-card.hot {
  background:linear-gradient(135deg,rgba(255,0,110,0.06),rgba(157,0,255,0.06));
  border-color:rgba(255,0,110,0.3);
}
.srv-hot-badge {
  position:absolute; top:18px; right:18px;
  padding:4px 12px;
  background:var(--grad-hot);
  border-radius:50px;
  font-size:11px; font-weight:700; color:#fff;
}
.srv-glow {
  position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse at top right, rgba(157,0,255,0.08), transparent 60%);
  transition:opacity 0.4s;
}
.srv-card:hover .srv-glow { opacity:1.5; }
.srv-icon-wrap {
  width:64px; height:64px;
  margin-bottom:24px;
  position:relative; z-index:1;
  transition:transform 0.4s var(--ease);
}
.srv-card:hover .srv-icon-wrap { transform:scale(1.1) rotate(5deg); }
.srv-card h3 {
  font-family:'Syne',sans-serif;
  font-size:1.25rem; font-weight:800;
  margin-bottom:12px; position:relative; z-index:1;
  letter-spacing:-0.5px;
}
.srv-card p {
  font-size:14px; color:var(--txt-2); line-height:1.75;
  margin-bottom:20px; position:relative; z-index:1;
}
.srv-tags {
  display:flex; gap:6px; flex-wrap:wrap;
  margin-bottom:20px; position:relative; z-index:1;
}
.srv-tags span {
  padding:3px 10px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:50px; font-size:11px; color:var(--txt-3);
}
.srv-cta {
  font-size:13px; font-weight:700;
  color:var(--neon-purple);
  position:relative; z-index:1;
  transition:var(--trans);
}
.srv-card:hover .srv-cta { letter-spacing:2px; }
.srv-card[data-num]::after {
  content:attr(data-num);
  position:absolute; bottom:-10px; right:16px;
  font-family:'Syne',sans-serif;
  font-size:5rem; font-weight:900;
  color:rgba(255,255,255,0.025);
  line-height:1; z-index:0;
  pointer-events:none;
  user-select:none;
}

/* ── WORK ────────────────────────────────────── */
.work { background:var(--bg-2); }
.work-filters {
  display:flex; justify-content:center; gap:10px;
  margin-bottom:50px; flex-wrap:wrap;
}
.wf-btn {
  padding:10px 24px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  border-radius:50px;
  font-size:13px; font-weight:600;
  color:var(--txt-2); cursor:pointer;
  transition:var(--trans);
}
.wf-btn.active, .wf-btn:hover {
  background:var(--grad-main);
  border-color:transparent;
  color:#fff;
  box-shadow:0 0 20px rgba(157,0,255,0.3);
}
.work-masonry {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:280px;
  gap:20px;
}
.wk-item {
  border-radius:var(--radius);
  overflow:hidden;
  position:relative;
  cursor:pointer;
  transition:transform 0.4s var(--ease);
}
.wk-item.wide { grid-column:span 2; }
.wk-item:hover { transform:scale(1.02); }
.wk-thumb { width:100%; height:100%; position:relative; display:flex; align-items:center; justify-content:center; }
.wk-overlay {
  position:absolute; inset:0;
  background:rgba(157,0,255,0.25);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity 0.3s;
  backdrop-filter:blur(2px);
}
.wk-item:hover .wk-overlay { opacity:1; }
.wk-overlay span {
  padding:12px 28px;
  background:#fff; border-radius:50px;
  font-size:14px; font-weight:700;
  color:var(--bg);
  box-shadow:0 0 30px rgba(157,0,255,0.5);
}
.wk-info {
  position:absolute; bottom:0; left:0; right:0;
  padding:24px;
  background:linear-gradient(to top, rgba(0,0,0,0.9), transparent);
}
.wk-cat {
  display:block; font-size:11px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--neon-cyan); margin-bottom:6px;
}
.wk-info h4 { font-family:'Syne',sans-serif; font-size:1rem; font-weight:700; }

/* Work animations */
.wk-anim { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.wk-sphere {
  width:80px;height:80px;
  background:radial-gradient(circle at 30% 30%,rgba(157,0,255,0.9),rgba(0,245,255,0.4));
  border-radius:50%;
  animation:sFloat 4s ease-in-out infinite;
  box-shadow:0 0 50px rgba(157,0,255,0.6);
}
.wk-ring {
  position:absolute;
  width:130px;height:130px;
  border:1.5px solid rgba(157,0,255,0.4);
  border-radius:50%;
  animation:rPulse 3s ease-in-out infinite;
}
@keyframes sFloat { 0%,100%{transform:translateY(0);}50%{transform:translateY(-15px);} }
@keyframes rPulse { 0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.15);opacity:0.4;} }
.wk-rings-group { position:relative; }
.wk-circle { position:absolute; border:1.5px solid; border-radius:50%; animation:rPulse 3s ease-in-out infinite; transform:translate(-50%,-50%); }
.c1{width:50px;height:50px;border-color:rgba(0,245,255,0.9);animation-delay:0s;}
.c2{width:100px;height:100px;border-color:rgba(157,0,255,0.5);animation-delay:0.4s;}
.c3{width:160px;height:160px;border-color:rgba(255,0,110,0.3);animation-delay:0.8s;}
.wk-char {
  width:70px;height:70px;
  background:linear-gradient(135deg,#ff006e,#9d00ff);
  border-radius:50% 50% 40% 40%;
  animation:charB 2s ease-in-out infinite;
  box-shadow:0 0 30px rgba(255,0,110,0.5);
}
@keyframes charB{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
.wk-logo-spin {
  width:70px;height:70px;
  background:linear-gradient(135deg,#39ff14,#00f5ff);
  border-radius:16px;
  animation:logS 3s ease-in-out infinite;
  box-shadow:0 0 30px rgba(57,255,20,0.4);
}
@keyframes logS{0%,100%{border-radius:16px;transform:rotate(0deg);}50%{border-radius:50%;transform:rotate(180deg);}}
.wk-cube-3d {
  width:70px;height:70px;
  background:linear-gradient(135deg,#9d00ff,#00f5ff);
  animation:cubeR 4s linear infinite;
  box-shadow:0 0 40px rgba(157,0,255,0.6);
}
@keyframes cubeR{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
.wk-particles {
  width:120px;height:120px;
  background:radial-gradient(circle,rgba(255,190,11,0.4),transparent);
  border-radius:50%;
  animation:pGlow 3s ease-in-out infinite;
}
@keyframes pGlow{0%,100%{transform:scale(1);}50%{transform:scale(1.2);}}

/* ── PROCESS ─────────────────────────────────── */
.process { background:var(--bg); }
.proc-row {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0; position:relative;
}
.proc-row::before {
  content:'';
  position:absolute;
  top:32px; left:8%; right:8%;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--neon-purple),var(--neon-cyan),transparent);
}
.proc-step {
  text-align:center; padding:0 24px;
  opacity:0; transform:translateY(30px);
  transition:all 0.6s var(--ease);
}
.proc-step.visible { opacity:1; transform:none; }
.proc-num {
  font-family:'Syne',sans-serif;
  font-size:3rem; font-weight:900;
  background:var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:24px;
  display:inline-block;
  position:relative;
}
.proc-num::after {
  content:''; width:12px;height:12px;
  background:var(--neon-purple);
  border-radius:50%;
  position:absolute; top:50%; right:-26px;
  transform:translateY(-50%);
  box-shadow:0 0 15px var(--neon-purple);
}
.proc-step:last-child .proc-num::after { display:none; }
.proc-content h3 { font-family:'Syne',sans-serif; font-size:1.1rem; font-weight:800; margin-bottom:10px; }
.proc-content p { font-size:14px; color:var(--txt-2); line-height:1.75; }

/* ── TESTIMONIALS ────────────────────────────── */
.testi { background:var(--bg-2); }
.testi-track { position:relative; min-height:260px; }
.testi-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:44px 48px;
  max-width:860px; margin:0 auto;
  position:absolute; inset:0;
  opacity:0; transform:scale(0.97) translateX(20px);
  transition:all 0.6s var(--ease);
  pointer-events:none;
}
.testi-card.active { opacity:1; transform:scale(1) translateX(0); position:relative; pointer-events:all; }
.testi-quote {
  font-family:'Syne',sans-serif;
  font-size:6rem; line-height:1;
  background:var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:-20px; display:block;
}
.testi-text {
  font-size:1.1rem; line-height:1.85;
  color:var(--txt-2); font-style:italic;
  margin-bottom:32px;
}
.testi-author { display:flex; align-items:center; gap:16px; margin-bottom:16px; }
.auth-av {
  width:50px; height:50px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:15px; font-weight:800;
}
.testi-author strong { display:block; font-size:16px; }
.testi-author span { font-size:13px; color:var(--txt-2); }
.testi-stars { color:var(--neon-gold); font-size:18px; letter-spacing:3px; }
.testi-dots { display:flex; justify-content:center; gap:10px; margin-top:32px; }
.tdot {
  width:10px; height:10px;
  border-radius:50%;
  background:var(--border);
  border:none; cursor:pointer;
  transition:var(--trans); padding:0;
}
.tdot.active { background:var(--neon-purple); width:30px; border-radius:5px; box-shadow:0 0 10px var(--neon-purple); }

/* ── FAQ ─────────────────────────────────────── */
.faq { background:var(--bg); }
.faq-list {
  max-width:860px; margin:0 auto;
  display:flex; flex-direction:column; gap:12px;
}
.faq-item {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  overflow:hidden;
  transition:border-color 0.3s;
}
.faq-item:hover { border-color:rgba(157,0,255,0.35); }
.faq-item.open { border-color:rgba(157,0,255,0.5); box-shadow:0 0 20px rgba(157,0,255,0.08); }
.faq-q {
  width:100%;
  display:flex; justify-content:space-between; align-items:center;
  padding:22px 28px; gap:16px;
  background:none; border:none;
  color:var(--txt); font-family:inherit;
  font-size:1rem; font-weight:600;
  cursor:pointer; text-align:left;
  transition:background 0.3s;
}
.faq-q:hover { background:rgba(157,0,255,0.04); }
.faq-icon {
  width:28px; height:28px;
  background:rgba(157,0,255,0.1);
  border:1px solid rgba(157,0,255,0.25);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; color:var(--neon-purple);
  flex-shrink:0;
  transition:transform 0.3s, background 0.3s;
  line-height:1; font-weight:300;
}
.faq-item.open .faq-icon { transform:rotate(45deg); background:rgba(157,0,255,0.2); }
.faq-a {
  max-height:0; overflow:hidden;
  transition:max-height 0.4s var(--ease), padding 0.3s;
  padding:0 28px;
}
.faq-a.open { max-height:250px; padding:0 28px 22px; }
.faq-a p {
  font-size:15px; color:var(--txt-2); line-height:1.8;
  border-top:1px solid var(--border); padding-top:16px;
}
.faq-a a { color:var(--neon-cyan); }

/* ── CONTACT ─────────────────────────────────── */
.contact { background:var(--bg-2); }
.contact-grid {
  display:grid; grid-template-columns:1fr 1.2fr;
  gap:80px; align-items:start;
}
.contact-left .label-tag { display:inline-block; margin-bottom:20px; }
.contact-desc { font-size:1rem; color:var(--txt-2); line-height:1.8; margin-bottom:40px; }
.contact-cards {
  display:grid; grid-template-columns:1fr 1fr;
  gap:14px; margin-bottom:36px;
}
.contact-card {
  display:flex; align-items:center; gap:14px;
  padding:18px 20px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  transition:var(--trans);
  cursor:pointer;
}
.contact-card:hover {
  border-color:rgba(157,0,255,0.4);
  background:rgba(157,0,255,0.05);
  transform:translateY(-3px);
  box-shadow:0 10px 30px rgba(157,0,255,0.1);
}
.cc-icon { font-size:24px; flex-shrink:0; }
.cc-label { font-size:11px; color:var(--txt-2); letter-spacing:0.5px; margin-bottom:4px; }
.cc-val { font-size:14px; font-weight:600; }
.social-row { display:flex; gap:12px; }
.soc-btn {
  width:46px; height:46px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  color:var(--txt-2); transition:var(--trans);
}
.soc-btn svg { width:20px; height:20px; }
.soc-btn:hover {
  background:rgba(157,0,255,0.12);
  border-color:rgba(157,0,255,0.4);
  color:var(--neon-purple);
  transform:translateY(-3px);
  box-shadow:0 0 15px rgba(157,0,255,0.2);
}

/* Contact Form */
.contact-right {
  background:rgba(157,0,255,0.04);
  border:1px solid rgba(157,0,255,0.15);
  border-radius:var(--radius);
  padding:44px;
}
.form-title {
  font-family:'Syne',sans-serif;
  font-size:1.4rem; font-weight:800;
  margin-bottom:32px;
  letter-spacing:-0.5px;
}
.contact-form { display:flex; flex-direction:column; gap:20px; }
.form-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.fg { display:flex; flex-direction:column; gap:8px; }
.fg label { font-size:12px; font-weight:700; color:var(--txt-2); letter-spacing:0.5px; text-transform:uppercase; }
.fg input, .fg select, .fg textarea {
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  border-radius:10px;
  padding:14px 18px;
  font-size:15px; color:var(--txt);
  transition:var(--trans);
  outline:none; appearance:none;
}
.fg input::placeholder, .fg textarea::placeholder { color:var(--txt-3); }
.fg input:focus, .fg select:focus, .fg textarea:focus {
  border-color:rgba(157,0,255,0.5);
  background:rgba(157,0,255,0.04);
  box-shadow:0 0 0 3px rgba(157,0,255,0.1);
}
.fg select option { background:#07070f; }
.fg textarea { resize:vertical; min-height:120px; }
.form-note {
  font-size:13px; color:var(--txt-2); text-align:center;
  margin-top:8px;
}
.form-note a { color:var(--neon-cyan); }

/* ── FOOTER ──────────────────────────────────── */
.footer {
  background:#010103;
  border-top:1px solid var(--border);
  position:relative; overflow:hidden;
}
.footer-top-glow {
  position:absolute; top:-100px; left:50%;
  transform:translateX(-50%);
  width:600px; height:200px;
  background:radial-gradient(ellipse,rgba(157,0,255,0.08),transparent);
  pointer-events:none;
}
.footer-layout {
  display:grid;
  grid-template-columns:280px 1fr 1fr 1fr;
  gap:60px;
  padding:80px 0 60px;
}
.footer-logo {
  font-family:'Syne',sans-serif;
  font-size:1.8rem; font-weight:900;
  letter-spacing:-1px;
  margin-bottom:16px;
  display:block;
}
.footer-brand-col p { font-size:14px; color:var(--txt-2); line-height:1.75; margin-bottom:20px; }
.footer-contact-quick {
  display:flex; flex-direction:column; gap:8px;
  font-size:13px;
}
.footer-contact-quick a, .footer-contact-quick span {
  color:var(--txt-2); transition:color 0.3s;
}
.footer-contact-quick a:hover { color:var(--neon-cyan); }
.footer-links-col h4 {
  font-size:12px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--txt); margin-bottom:20px;
}
.footer-links-col a, .footer-links-col span {
  display:block; font-size:14px;
  color:var(--txt-2); margin-bottom:12px;
  transition:color 0.3s; cursor:pointer;
}
.footer-links-col a:hover { color:var(--neon-purple); }
.footer-bottom {
  border-top:1px solid var(--border);
  padding:24px 0;
  display:flex; justify-content:space-between; align-items:center;
  font-size:13px; color:var(--txt-3);
}
.footer-legal { display:flex; gap:24px; }
.footer-legal a { color:var(--txt-3); transition:color 0.3s; }
.footer-legal a:hover { color:var(--txt-2); }

/* ── SCROLL ANIMATIONS ───────────────────────── */
.reveal, .reveal-left, .reveal-right {
  opacity:0; transition:all 0.9s var(--ease);
}
.reveal { transform:translateY(40px); }
.reveal-left { transform:translateX(-40px); }
.reveal-right { transform:translateX(40px); }
.reveal.visible, .reveal-left.visible, .reveal-right.visible { opacity:1; transform:none; }

/* ── RESPONSIVE ──────────────────────────────── */
@media(max-width:1100px) {
  .srv-grid { grid-template-columns:repeat(2,1fr); }
  .work-masonry { grid-template-columns:repeat(2,1fr); }
  .wk-item.wide { grid-column:span 2; }
  .about-layout { grid-template-columns:1fr; }
  .about-media { max-width:520px; margin:0 auto; }
  .contact-grid { grid-template-columns:1fr; }
  .footer-layout { grid-template-columns:1fr 1fr; gap:40px; }
  .footer-brand-col { grid-column:span 2; }
}
@media(max-width:768px) {
  .wrap { padding:0 20px; }
  .nav-inner { padding:0 20px; }
  .nav-toggle { display:flex; }
  .nav-menu, .nav-phone { display:none; }
  .nav-menu.open {
    display:flex; flex-direction:column;
    position:fixed; top:0; left:0; right:0;
    background:rgba(2,2,5,0.97);
    height:100vh; padding:100px 40px 40px;
    gap:8px; z-index:999;
    backdrop-filter:blur(20px);
  }
  .nav-menu.open .nav-item { font-size:1.6rem; padding:16px 0; }
  section { padding:80px 0; }
  .proc-row { grid-template-columns:1fr 1fr; gap:40px; }
  .proc-row::before { display:none; }
  .proc-num::after { display:none; }
  .hero-numbers { gap:20px; }
  .num-sep { display:none; }
  .contact-cards { grid-template-columns:1fr; }
  .form-row-2 { grid-template-columns:1fr; }
  .contact-right { padding:24px; }
  .footer-layout { grid-template-columns:1fr; }
  .footer-brand-col { grid-column:auto; }
  .footer-bottom { flex-direction:column; gap:12px; }
  .badge-f1 { right:-10px; }
  .badge-f2 { left:-10px; }
  .testi-card { padding:28px 24px; }
  .srv-grid { grid-template-columns:1fr; }
  .work-masonry { grid-template-columns:1fr; grid-auto-rows:220px; }
  .wk-item.wide { grid-column:span 1; }
}
@media(max-width:480px) {
  .hero-ctas { flex-direction:column; align-items:center; }
  .proc-row { grid-template-columns:1fr; }
}
