/* =============================================================
   GAME ROOT — Static Site Stylesheet
   Cyberpunk: Electric Green (#59FF00 / #95FF77) + Dark (#1A1C1B)
   ============================================================= */

:root {
  --neon:          #59FF00;
  --neon-soft:     #95FF77;
  --neon-dim:      #3db800;
  --neon-glow:     rgba(89, 255, 0, 0.55);
  --neon-glow-sm:  rgba(89, 255, 0, 0.25);
  --neon-glow-xs:  rgba(89, 255, 0, 0.10);

  --bg-void:       #0e100f;
  --bg-dark:       #1A1C1B;
  --bg-card:       #1f2221;
  --bg-card2:      #2A2E2E;
  --bg-elevated:   #303635;
  --bg-border:     #2A2E2E;
  --bg-border2:    #555D58;

  --text-primary:  #e8f0e8;
  --text-secondary:#a8b8a4;
  --text-muted:    #555D58;
  --text-neon:     #59FF00;

  --font-display:  'Orbitron', sans-serif;
  --font-body:     'Rajdhani', sans-serif;
  --font-mono:     'Share Tech Mono', monospace;

  --radius-sm: 3px;
  --radius-md: 8px;
  --radius-lg: 14px;
  --radius-xl: 22px;

  --t-fast:  0.18s ease;
  --t-base:  0.32s ease;
  --t-slow:  0.55s ease;

  --navbar-h:  70px;
  --section-py:100px;
}

/* ── Reset ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{
  scroll-behavior:smooth;
  scrollbar-width:thin;
  scrollbar-color:var(--neon) var(--bg-dark);
}
html::-webkit-scrollbar{width:5px}
html::-webkit-scrollbar-track{background:var(--bg-dark)}
html::-webkit-scrollbar-thumb{background:var(--neon);border-radius:3px}

body{
  font-family:var(--font-body);
  background:var(--bg-void);
  color:var(--text-primary);
  font-size:17px;
  line-height:1.65;
  overflow-x:hidden;
}

/* ── Noise ───────────────────────────────────────────────────── */
.gr-noise{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  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.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:0.04;
}

/* ── Scanlines ───────────────────────────────────────────────── */
.gr-scanlines{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.04) 2px,rgba(0,0,0,0.04) 4px);
}

/* ── Custom Cursor ───────────────────────────────────────────── */
.gr-cursor{
  width:8px;height:8px;
  background:var(--neon);border-radius:50%;
  position:fixed;top:0;left:0;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .2s,height .2s;
  box-shadow:0 0 10px var(--neon),0 0 22px var(--neon-glow);
}
.gr-cursor-follower{
  width:30px;height:30px;
  border:1px solid rgba(89,255,0,0.45);border-radius:50%;
  position:fixed;top:0;left:0;pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s;
}
@media(hover:none){.gr-cursor,.gr-cursor-follower{display:none}}

/* ── Typography ──────────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display);
  font-weight:700;line-height:1.12;letter-spacing:.02em;
}

.gr-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:.72rem;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--neon);
  padding:5px 14px;
  border:1px solid rgba(89,255,0,.28);
  border-radius:var(--radius-sm);
  background:rgba(89,255,0,.06);
  margin-bottom:1.2rem;
}
.gr-badge::before{
  content:'';width:6px;height:6px;
  background:var(--neon);border-radius:50%;
  box-shadow:0 0 8px var(--neon);
  animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.65)}}

.gr-section-title{
  font-size:clamp(1.9rem,3.8vw,3.1rem);
  color:var(--text-primary);margin-bottom:1rem;
}
.gr-neon{
  color:var(--neon);
  text-shadow:0 0 18px var(--neon-glow),0 0 40px var(--neon-glow-sm);
}
.gr-section-sub{
  font-size:1.05rem;color:var(--text-secondary);max-width:580px;
}

/* ── Section ─────────────────────────────────────────────────── */
.gr-section{padding:var(--section-py) 0;position:relative}
.gr-section-dark{background:var(--bg-dark)}
.gr-section-card{background:var(--bg-card)}

.gr-divider{
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(89,255,0,.3),transparent);
  margin:2rem 0;
}

/* ── Buttons ─────────────────────────────────────────────────── */
.gr-btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-display);font-size:.72rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;text-decoration:none;
  padding:13px 30px;border-radius:var(--radius-sm);
  border:none;cursor:pointer;position:relative;overflow:hidden;
  transition:var(--t-base);z-index:1;
}
.gr-btn::before{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,.04);
  transform:translateX(-101%);transition:transform .32s ease;z-index:-1;
}
.gr-btn:hover::before{transform:translateX(0)}

.gr-btn-primary{
  background:var(--neon);color:#0e100f;
  box-shadow:0 4px 20px var(--neon-glow-sm);
}
.gr-btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 30px var(--neon-glow),0 0 50px var(--neon-glow-sm);
  color:#0e100f;
}
.gr-btn-outline{
  background:transparent;color:var(--neon);
  border:1px solid var(--neon);
}
.gr-btn-outline:hover{
  background:rgba(89,255,0,.09);
  transform:translateY(-2px);
  box-shadow:0 0 22px var(--neon-glow-sm);
  color:var(--neon);
}
.gr-btn-ghost{
  background:transparent;color:var(--text-secondary);
  border:1px solid var(--bg-border2);
}
.gr-btn-ghost:hover{color:var(--neon);border-color:var(--neon)}

/* Nav button */
.gr-btn-nav{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-size:.68rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;text-decoration:none;
  padding:9px 20px;
  color:#0e100f;background:var(--neon);
  border-radius:var(--radius-sm);
  transition:var(--t-base);
  box-shadow:0 0 14px var(--neon-glow-sm);
}
.gr-btn-nav:hover{
  transform:translateY(-1px);
  box-shadow:0 0 28px var(--neon-glow);
  color:#0e100f;
}

/* ── NAVBAR ──────────────────────────────────────────────────── */
.gr-navbar{
  height:var(--navbar-h);
  background:rgba(14,16,15,.78);
  backdrop-filter:blur(20px) saturate(160%);
  border-bottom:1px solid rgba(89,255,0,.07);
  transition:background var(--t-base),box-shadow var(--t-base);
  z-index:1000;position:fixed;top:0;left:0;right:0;
}
.gr-navbar.scrolled{
  background:rgba(14,16,15,.97);
  box-shadow:0 4px 30px rgba(0,0,0,.7),0 1px 0 rgba(89,255,0,.12);
}
.container-xl{max-width:1280px;margin:0 auto;padding:0 24px}
.gr-navbar-inner{
  height:var(--navbar-h);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}

/* Brand */
.gr-brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.gr-brand-icon{
  width:38px;height:38px;border-radius:var(--radius-sm);
  background:var(--neon);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;color:#0e100f;
  box-shadow:0 0 14px var(--neon-glow-sm);
  flex-shrink:0;
}
.gr-brand-text{display:flex;flex-direction:column;line-height:1}
.gr-brand-game{
  font-family:var(--font-display);font-size:.6rem;font-weight:400;
  letter-spacing:.3em;color:var(--text-muted);
}
.gr-brand-root{
  font-family:var(--font-display);font-size:1.15rem;font-weight:900;
  letter-spacing:.15em;color:var(--neon);
  text-shadow:0 0 12px var(--neon-glow-sm);
}

/* Nav links */
.gr-nav-links{
  display:flex;align-items:center;gap:2px;list-style:none;
}
.gr-nav-link{
  font-family:var(--font-display);font-size:.65rem;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-secondary);text-decoration:none;
  padding:7px 11px;border-radius:var(--radius-sm);
  transition:var(--t-fast);position:relative;white-space:nowrap;
}
.gr-nav-link::after{
  content:'';position:absolute;bottom:3px;left:11px;right:11px;
  height:1px;background:var(--neon);
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--t-base);
}
.gr-nav-link:hover,.gr-nav-link.active{color:var(--neon)}
.gr-nav-link:hover::after,.gr-nav-link.active::after{transform:scaleX(1)}

/* Dropdown */
.gr-dropdown{position:relative}
.gr-dropdown-menu{
  position:absolute;top:calc(100% + 8px);left:0;
  min-width:180px;
  background:var(--bg-card);
  border:1px solid rgba(89,255,0,.18);
  border-radius:var(--radius-md);
  padding:8px;
  box-shadow:0 20px 60px rgba(0,0,0,.7),0 0 30px var(--neon-glow-xs);
  opacity:0;visibility:hidden;
  transform:translateY(6px);
  transition:opacity var(--t-fast),transform var(--t-fast),visibility var(--t-fast);
  z-index:200;
}
.gr-dropdown:hover .gr-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.gr-dropdown-item{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-size:.65rem;
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--text-secondary);text-decoration:none;
  padding:9px 12px;border-radius:var(--radius-sm);
  transition:var(--t-fast);
}
.gr-dropdown-item:hover{background:rgba(89,255,0,.08);color:var(--neon)}

/* Hamburger */
.gr-hamburger{
  display:none;flex-direction:column;gap:5px;
  background:rgba(89,255,0,.06);
  border:1px solid rgba(89,255,0,.22);
  border-radius:var(--radius-sm);
  padding:9px 10px;cursor:pointer;
}
.gr-hamburger span{
  display:block;width:22px;height:2px;
  background:var(--neon);border-radius:2px;
  transition:var(--t-base);
}
.gr-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.gr-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.gr-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile nav */
.gr-mobile-nav{
  display:none;position:fixed;
  top:var(--navbar-h);left:0;right:0;
  background:rgba(14,16,15,.98);
  border-bottom:1px solid rgba(89,255,0,.12);
  padding:1.5rem 24px;
  z-index:999;
  transform:translateY(-8px);opacity:0;
  transition:opacity var(--t-base),transform var(--t-base);
  pointer-events:none;
}
.gr-mobile-nav.open{display:block;opacity:1;transform:translateY(0);pointer-events:auto}
.gr-mobile-nav a{
  display:block;padding:10px 0;
  font-family:var(--font-display);font-size:.72rem;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-secondary);text-decoration:none;
  border-bottom:1px solid var(--bg-border);
  transition:var(--t-fast);
}
.gr-mobile-nav a:hover{color:var(--neon);padding-left:8px}

/* ── HERO ────────────────────────────────────────────────────── */
.gr-hero{
  min-height:100vh;display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding-top:var(--navbar-h);
  background:var(--bg-void);
}
.gr-hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 70% 50%,rgba(89,255,0,.055) 0%,transparent 60%),
    radial-gradient(ellipse 50% 40% at 15% 80%,rgba(149,255,119,.035) 0%,transparent 50%),
    linear-gradient(180deg,var(--bg-void) 0%,#0c110c 100%);
}
.gr-hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(89,255,0,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(89,255,0,.035) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 80%);
}

.gr-hero-content{position:relative;z-index:2}

.gr-hero-eyebrow{
  font-family:var(--font-mono);font-size:.78rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--neon);
  display:flex;align-items:center;gap:12px;
  margin-bottom:1.75rem;
}
.gr-hero-eyebrow-line{
  width:38px;height:1px;
  background:linear-gradient(90deg,var(--neon),transparent);
  box-shadow:0 0 6px var(--neon);
}

.gr-hero-title{
  font-family:var(--font-display);
  font-size:clamp(2.8rem,7.5vw,6.5rem);
  font-weight:900;line-height:1.0;
  letter-spacing:-.01em;
  color:var(--text-primary);
  margin-bottom:1.5rem;
}
.gr-hero-title .gr-title-outline{
  display:block;
  -webkit-text-stroke:1.5px var(--neon);
  color:transparent;
  text-shadow:0 0 35px rgba(89,255,0,.25);
}
.gr-hero-title .gr-title-glow{
  display:block;color:var(--neon);
  text-shadow:0 0 28px var(--neon-glow),0 0 55px var(--neon-glow-sm);
}

.gr-hero-sub{
  font-size:1.1rem;color:var(--text-secondary);
  max-width:520px;margin-bottom:2.5rem;line-height:1.72;
}
.gr-hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:3rem}

.gr-hero-stats{
  display:flex;flex-wrap:wrap;gap:1.8rem;
  padding-top:2rem;border-top:1px solid var(--bg-border);
}
.gr-hero-stat-num{
  font-family:var(--font-display);font-size:1.7rem;font-weight:900;
  color:var(--neon);
  text-shadow:0 0 14px var(--neon-glow-sm);
  line-height:1;
}
.gr-hero-stat-label{
  font-size:.75rem;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.08em;margin-top:4px;
}

/* Hero Visual */
.gr-hero-visual{
  position:relative;display:flex;
  align-items:center;justify-content:center;
}
.gr-orb{
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,rgba(89,255,0,.13) 0%,rgba(89,255,0,.05) 45%,transparent 70%);
  border:1px solid rgba(89,255,0,.14);
  display:flex;align-items:center;justify-content:center;
  position:relative;
  animation:orb-pulse 4s ease-in-out infinite;
}
@keyframes orb-pulse{
  0%,100%{box-shadow:0 0 40px rgba(89,255,0,.08),0 0 80px rgba(89,255,0,.04)}
  50%{box-shadow:0 0 60px rgba(89,255,0,.16),0 0 120px rgba(89,255,0,.08)}
}
.gr-orb-inner{
  width:270px;height:270px;border-radius:50%;
  border:1px solid rgba(89,255,0,.22);
  display:flex;align-items:center;justify-content:center;
  animation:orb-pulse 4s ease-in-out infinite reverse;
}
.gr-orb-core{
  width:155px;height:155px;border-radius:50%;
  background:linear-gradient(135deg,rgba(89,255,0,.22),rgba(89,255,0,.1));
  border:2px solid rgba(89,255,0,.4);
  display:flex;align-items:center;justify-content:center;
  font-size:3.5rem;color:var(--neon);
  box-shadow:0 0 28px var(--neon-glow-sm),inset 0 0 28px rgba(89,255,0,.08);
}
.gr-orbit{
  position:absolute;border-radius:50%;
  border:1px dashed rgba(89,255,0,.14);
  animation:spin-slow linear infinite;
}
.gr-orbit-1{width:310px;height:310px;animation-duration:18s}
.gr-orbit-2{width:370px;height:370px;animation-duration:28s;animation-direction:reverse}
@keyframes spin-slow{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.gr-orbit-dot{
  position:absolute;top:-4px;left:50%;transform:translateX(-50%);
  width:8px;height:8px;border-radius:50%;
  background:var(--neon);box-shadow:0 0 10px var(--neon);
}
.gr-float-badge{
  position:absolute;
  background:var(--bg-card2);
  border:1px solid rgba(89,255,0,.28);
  border-radius:var(--radius-md);
  padding:9px 15px;
  font-family:var(--font-display);font-size:.67rem;
  color:var(--neon);white-space:nowrap;
}

/* ── Cards ───────────────────────────────────────────────────── */
.gr-card{
  background:var(--bg-card);
  border:1px solid var(--bg-border);
  border-radius:var(--radius-lg);
  overflow:hidden;transition:var(--t-base);position:relative;
}
.gr-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--neon),transparent);
  opacity:0;transition:opacity var(--t-base);
}
.gr-card:hover{
  border-color:rgba(89,255,0,.35);
  transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 30px var(--neon-glow-xs);
}
.gr-card:hover::before{opacity:1}
.gr-card-body{padding:2rem}

/* Service Card */
.gr-service-card{
  background:var(--bg-card);border:1px solid var(--bg-border);
  border-radius:var(--radius-lg);padding:2.2rem 1.8rem;
  transition:var(--t-base);position:relative;overflow:hidden;height:100%;
}
.gr-service-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--neon),var(--neon-soft));
  transform:scaleX(0);transform-origin:left;transition:transform .4s ease;
}
.gr-service-card:hover{
  border-color:rgba(89,255,0,.28);
  transform:translateY(-8px);
  box-shadow:0 30px 60px rgba(0,0,0,.4),0 0 40px var(--neon-glow-xs);
}
.gr-service-card:hover::after{transform:scaleX(1)}
.gr-svc-icon{
  width:58px;height:58px;border-radius:var(--radius-md);
  background:rgba(89,255,0,.08);border:1px solid rgba(89,255,0,.18);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;color:var(--neon);margin-bottom:1.4rem;
  transition:var(--t-base);
}
.gr-service-card:hover .gr-svc-icon{
  background:rgba(89,255,0,.16);
  box-shadow:0 0 18px var(--neon-glow-sm);
}
.gr-service-card h4{font-size:1.05rem;margin-bottom:.65rem}
.gr-service-card p{color:var(--text-secondary);font-size:.92rem}

/* Feature check */
.gr-feature-check{
  display:flex;align-items:center;gap:9px;
  padding:7px 0;font-size:.88rem;color:var(--text-secondary);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.gr-feature-check i{color:var(--neon);min-width:14px}

/* Project Card */
.gr-project-card{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:var(--bg-card);border:1px solid var(--bg-border);
  transition:var(--t-base);height:100%;
}
.gr-project-card:hover{
  border-color:rgba(89,255,0,.28);
  transform:translateY(-8px);
  box-shadow:0 30px 60px rgba(0,0,0,.5),0 0 40px var(--neon-glow-xs);
}
.gr-project-img{
  width:100%;aspect-ratio:16/10;object-fit:cover;
  display:block;transition:transform .6s ease;
  background:linear-gradient(135deg,rgba(89,255,0,.12),rgba(89,255,0,.04));
}
.gr-project-card:hover .gr-project-img{transform:scale(1.05)}
.gr-project-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(14,16,15,.96) 0%,rgba(14,16,15,.45) 55%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:1.6rem;
}
.gr-project-cat{
  font-family:var(--font-mono);font-size:.68rem;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--neon);margin-bottom:6px;
}
.gr-project-title{
  font-family:var(--font-display);font-size:1.05rem;font-weight:700;
  color:var(--text-primary);margin-bottom:6px;
}
.gr-project-desc{font-size:.85rem;color:var(--text-secondary);display:none}
.gr-project-card:hover .gr-project-desc{display:block}
.gr-project-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.gr-tag{
  font-family:var(--font-mono);font-size:.65rem;padding:3px 9px;
  background:rgba(89,255,0,.1);border:1px solid rgba(89,255,0,.2);
  border-radius:2px;color:var(--neon);
}

/* Testimonial Card */
.gr-testi-card{
  background:var(--bg-card);border:1px solid var(--bg-border);
  border-radius:var(--radius-lg);padding:2.2rem;
  position:relative;height:100%;transition:var(--t-base);
}
.gr-testi-card::before{
  content:'\201C';
  position:absolute;top:1.2rem;right:1.8rem;
  font-family:Georgia,serif;font-size:5.5rem;line-height:1;
  color:rgba(89,255,0,.08);
}
.gr-testi-card:hover{border-color:rgba(89,255,0,.25);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.gr-testi-stars{color:var(--neon);margin-bottom:.9rem;font-size:.9rem}
.gr-testi-text{color:var(--text-secondary);line-height:1.78;margin-bottom:1.4rem}
.gr-testi-author{display:flex;align-items:center;gap:11px}
.gr-testi-avatar{
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--bg-card2),var(--bg-elevated));
  border:2px solid rgba(89,255,0,.28);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;color:var(--neon);font-size:.95rem;
  flex-shrink:0;
}
.gr-testi-name{font-family:var(--font-display);font-size:.88rem;font-weight:700}
.gr-testi-role{font-size:.78rem;color:var(--text-muted)}

/* Blog Card */
.gr-blog-card{
  background:var(--bg-card);border:1px solid var(--bg-border);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:var(--t-base);height:100%;display:flex;flex-direction:column;
}
.gr-blog-card:hover{
  border-color:rgba(89,255,0,.28);transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(0,0,0,.4),0 0 20px var(--neon-glow-xs);
}
.gr-blog-img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.gr-blog-img-placeholder{
  width:100%;aspect-ratio:16/9;
  background:linear-gradient(135deg,rgba(89,255,0,.1),rgba(89,255,0,.03));
  display:flex;align-items:center;justify-content:center;
  font-size:2.2rem;color:rgba(89,255,0,.3);
}
.gr-blog-body{padding:1.65rem;flex:1;display:flex;flex-direction:column}
.gr-blog-cat{
  font-family:var(--font-mono);font-size:.68rem;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--neon);margin-bottom:7px;
}
.gr-blog-title{
  font-family:var(--font-display);font-size:.98rem;font-weight:600;
  color:var(--text-primary);margin-bottom:8px;line-height:1.4;flex:1;
}
.gr-blog-excerpt{font-size:.86rem;color:var(--text-secondary);margin-bottom:.9rem}
.gr-blog-meta{font-size:.76rem;color:var(--text-muted);display:flex;gap:12px}

/* Stat Card */
.gr-stat-card{
  background:var(--bg-card);border:1px solid var(--bg-border);
  border-radius:var(--radius-md);padding:1.4rem;text-align:center;
  transition:var(--t-base);
}
.gr-stat-card:hover{border-color:rgba(89,255,0,.28)}
.gr-stat-num{
  font-family:var(--font-display);font-size:1.85rem;font-weight:900;
  color:var(--neon);text-shadow:0 0 14px var(--neon-glow-sm);line-height:1;
}
.gr-stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:5px}

/* Job Card */
.gr-job-card{
  background:var(--bg-card);border:1px solid var(--bg-border);
  border-radius:var(--radius-lg);padding:1.8rem;
  transition:var(--t-base);position:relative;overflow:hidden;
}
.gr-job-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--neon),var(--neon-soft));
  transform:scaleY(0);transition:transform .3s ease;
}
.gr-job-card:hover{border-color:rgba(89,255,0,.28);transform:translateX(6px)}
.gr-job-card:hover::before{transform:scaleY(1)}
.gr-job-title{font-family:var(--font-display);font-size:1rem;font-weight:700;margin-bottom:6px}
.gr-job-dept{font-size:.83rem;color:var(--neon);margin-bottom:11px}
.gr-job-meta{display:flex;flex-wrap:wrap;gap:7px}
.gr-job-badge{
  font-family:var(--font-mono);font-size:.68rem;padding:3px 9px;
  border-radius:2px;
  background:rgba(255,255,255,.04);border:1px solid var(--bg-border2);
  color:var(--text-secondary);
}
.gr-job-badge.type{background:rgba(89,255,0,.09);border-color:rgba(89,255,0,.2);color:var(--neon)}

/* Tech Pill */
.gr-tech-pill{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--font-mono);font-size:.7rem;
  padding:5px 12px;border-radius:2px;
  background:var(--bg-elevated);border:1px solid var(--bg-border2);
  color:var(--text-secondary);transition:var(--t-fast);
}
.gr-tech-pill:hover{border-color:rgba(89,255,0,.28);color:var(--neon)}

/* Benefit Card */
.gr-benefit-card{
  background:var(--bg-card);border:1px solid var(--bg-border);
  border-radius:var(--radius-lg);padding:1.8rem;
  transition:var(--t-base);text-align:center;
}
.gr-benefit-card:hover{border-color:rgba(89,255,0,.28);transform:translateY(-4px)}
.gr-benefit-icon{
  width:54px;height:54px;border-radius:var(--radius-md);
  background:rgba(89,255,0,.08);border:1px solid rgba(89,255,0,.18);
  display:flex;align-items:center;justify-content:center;
  font-size:1.35rem;color:var(--neon);margin:0 auto 1rem;
}

/* Engagement Card */
.gr-engage-card{
  background:var(--bg-card);border:1px solid var(--bg-border);
  border-radius:var(--radius-lg);padding:2.2rem 1.8rem;
  height:100%;transition:var(--t-base);position:relative;
}
.gr-engage-card.popular{
  border-color:rgba(89,255,0,.38);
  background:linear-gradient(135deg,rgba(89,255,0,.05) 0%,rgba(89,255,0,.02) 100%);
  box-shadow:0 0 40px var(--neon-glow-xs);
}
.gr-engage-card:hover{border-color:rgba(89,255,0,.3);transform:translateY(-6px)}
.gr-popular-badge{
  position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  background:var(--neon);padding:4px 18px;
  border-radius:0 0 var(--radius-sm) var(--radius-sm);
  font-family:var(--font-display);font-size:.6rem;
  letter-spacing:.1em;color:#0e100f;text-transform:uppercase;font-weight:700;
}

/* Team Card */
.gr-team-card{
  background:var(--bg-card);border:1px solid var(--bg-border);
  border-radius:var(--radius-lg);padding:1.8rem;
  text-align:center;transition:var(--t-base);
}
.gr-team-card:hover{border-color:rgba(89,255,0,.28);transform:translateY(-6px)}
.gr-team-avatar{
  width:88px;height:88px;border-radius:50%;
  background:linear-gradient(135deg,rgba(89,255,0,.2),rgba(89,255,0,.08));
  border:2px solid rgba(89,255,0,.28);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1rem;font-size:2.2rem;color:var(--neon);
}
.gr-team-name{font-family:var(--font-display);font-size:.95rem;font-weight:700;margin-bottom:4px}
.gr-team-title{font-size:.82rem;color:var(--neon);margin-bottom:10px}
.gr-team-socials{display:flex;justify-content:center;gap:7px}
.gr-team-soc{
  width:30px;height:30px;border-radius:50%;
  background:var(--bg-elevated);border:1px solid var(--bg-border2);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);font-size:.75rem;text-decoration:none;
  transition:var(--t-fast);
}
.gr-team-soc:hover{background:rgba(89,255,0,.1);border-color:var(--neon);color:var(--neon)}

/* Timeline */
.gr-timeline{position:relative;padding-left:2rem}
.gr-timeline::before{
  content:'';position:absolute;left:0;top:8px;bottom:8px;width:1px;
  background:linear-gradient(180deg,var(--neon),var(--neon-soft),transparent);
}
.gr-timeline-item{position:relative;padding-bottom:2.2rem}
.gr-timeline-item::before{
  content:'';position:absolute;left:-2.35rem;top:6px;
  width:9px;height:9px;border-radius:50%;
  background:var(--neon);border:2px solid var(--bg-void);
  box-shadow:0 0 9px var(--neon);
}
.gr-timeline-year{font-family:var(--font-mono);font-size:.78rem;color:var(--neon);letter-spacing:.1em;margin-bottom:3px}
.gr-timeline-title{font-family:var(--font-display);font-size:.98rem;font-weight:700;margin-bottom:3px}
.gr-timeline-desc{font-size:.88rem;color:var(--text-secondary)}

/* Filter Tabs */
.gr-filter-tabs{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:2.8rem}
.gr-filter-tab{
  font-family:var(--font-display);font-size:.67rem;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;
  padding:7px 16px;border:1px solid var(--bg-border2);
  border-radius:var(--radius-sm);background:transparent;
  color:var(--text-secondary);cursor:pointer;text-decoration:none;
  transition:var(--t-fast);
}
.gr-filter-tab:hover,.gr-filter-tab.active{
  background:rgba(89,255,0,.09);border-color:var(--neon);color:var(--neon);
}

/* Page Hero */
.gr-page-hero{
  min-height:50vh;display:flex;align-items:center;
  padding:calc(var(--navbar-h) + 60px) 0 80px;
  position:relative;overflow:hidden;background:var(--bg-void);
}
.gr-page-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 50% 100%,rgba(89,255,0,.05) 0%,transparent 60%);
}
.gr-page-hero-title{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,4.8vw,4.8rem);
  font-weight:900;line-height:1.0;margin-bottom:.9rem;
}
.gr-page-hero-sub{font-size:1.05rem;color:var(--text-secondary);max-width:580px}

/* Breadcrumb */
.gr-breadcrumb{
  display:flex;align-items:center;gap:7px;list-style:none;padding:0;margin:0 0 1.5rem;
  font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);
}
.gr-breadcrumb li+li::before{content:'/';margin-right:7px;color:rgba(89,255,0,.35)}
.gr-breadcrumb a{color:var(--text-muted);text-decoration:none}
.gr-breadcrumb a:hover{color:var(--neon)}
.gr-breadcrumb .active{color:var(--neon)}

/* CTA Section */
.gr-cta-section{
  background:linear-gradient(135deg,rgba(89,255,0,.06) 0%,rgba(89,255,0,.03) 50%,transparent 100%);
  border-top:1px solid rgba(89,255,0,.1);border-bottom:1px solid rgba(89,255,0,.1);
  padding:var(--section-py) 0;position:relative;overflow:hidden;
}
.gr-cta-section::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,rgba(89,255,0,.05) 0%,transparent 70%);
  pointer-events:none;
}
.gr-cta-title{font-size:clamp(1.9rem,3.8vw,3.2rem);font-weight:900}

/* Gallery */
.gr-gallery-item{
  overflow:hidden;border-radius:var(--radius-md);
  border:1px solid var(--bg-border);
  aspect-ratio:4/3;cursor:pointer;
  background:var(--bg-card2);
  display:flex;align-items:center;justify-content:center;
}
.gr-gallery-img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s ease;
}
.gr-gallery-item:hover .gr-gallery-img{transform:scale(1.08)}

/* Process Step */
.gr-process-step{text-align:center;position:relative}
.gr-process-num{
  width:60px;height:60px;border-radius:50%;
  background:rgba(89,255,0,.09);border:2px solid rgba(89,255,0,.28);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:1.2rem;font-weight:900;
  color:var(--neon);margin:0 auto 1.1rem;
  box-shadow:0 0 18px var(--neon-glow-xs);
}

/* Contact Info */
.gr-contact-item{
  display:flex;align-items:flex-start;gap:1.1rem;margin-bottom:1.8rem;
}
.gr-contact-icon{
  width:50px;height:50px;min-width:50px;border-radius:var(--radius-md);
  background:rgba(89,255,0,.09);border:1px solid rgba(89,255,0,.18);
  display:flex;align-items:center;justify-content:center;
  font-size:1.15rem;color:var(--neon);
}
.gr-contact-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:3px}
.gr-contact-value{font-size:.98rem;color:var(--text-primary)}
.gr-contact-value a{color:var(--text-primary);text-decoration:none}
.gr-contact-value a:hover{color:var(--neon)}

/* Map */
.gr-map-wrap{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--bg-border)}
.gr-map-wrap iframe{display:block;filter:invert(90%) hue-rotate(180deg)}

/* FOOTER */
.gr-footer{
  background:var(--bg-dark);border-top:1px solid rgba(89,255,0,.09);
  position:relative;overflow:hidden;
}
.gr-footer-glow{
  position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:500px;height:280px;
  background:radial-gradient(ellipse at center bottom,rgba(89,255,0,.04) 0%,transparent 70%);
  pointer-events:none;
}
.gr-footer-top{padding:64px 0 48px}
.gr-footer-brand-wrap{display:inline-flex;align-items:center;gap:11px;text-decoration:none;margin-bottom:.5rem}
.gr-footer-desc{font-size:.92rem;color:var(--text-secondary);line-height:1.7}
.gr-footer-heading{
  font-family:var(--font-display);font-size:.68rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--neon);margin-bottom:1.1rem;
}
.gr-footer-links{list-style:none;padding:0}
.gr-footer-links li{margin-bottom:9px}
.gr-footer-links a{
  color:var(--text-secondary);text-decoration:none;font-size:.88rem;
  transition:color var(--t-fast),padding-left var(--t-fast);
}
.gr-footer-links a:hover{color:var(--neon);padding-left:5px}
.gr-footer-contact-list{list-style:none;padding:0}
.gr-footer-contact-list li{
  display:flex;align-items:flex-start;gap:9px;
  margin-bottom:11px;font-size:.88rem;color:var(--text-secondary);
}
.gr-footer-contact-list i{color:var(--neon);margin-top:3px;min-width:13px}
.gr-footer-contact-list a{color:var(--text-secondary);text-decoration:none}
.gr-footer-contact-list a:hover{color:var(--neon)}
.gr-footer-bottom{border-top:1px solid var(--bg-border);padding:1.4rem 0}
.gr-copyright{margin:0;font-size:.82rem;color:var(--text-muted)}
.gr-footer-tagline{
  font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);
  display:flex;align-items:center;gap:7px;justify-content:flex-end;
}
.gr-neon-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--neon);box-shadow:0 0 7px var(--neon);
  display:inline-block;animation:pulse-dot 2s infinite;
}

/* Social Links */
.gr-socials{display:flex;flex-wrap:wrap;gap:9px;margin-top:1.4rem}
.gr-social-link{
  width:36px;height:36px;border-radius:var(--radius-sm);
  background:var(--bg-elevated);border:1px solid var(--bg-border2);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-muted);text-decoration:none;font-size:.85rem;
  transition:var(--t-fast);
}
.gr-social-link:hover{
  background:rgba(89,255,0,.1);border-color:var(--neon);
  color:var(--neon);box-shadow:0 0 10px var(--neon-glow-xs);
}

/* Back to Top */
.gr-btt{
  position:fixed;bottom:28px;right:28px;z-index:500;
  width:42px;height:42px;
  background:var(--neon);border:none;border-radius:var(--radius-sm);
  color:#0e100f;font-size:.85rem;cursor:pointer;
  opacity:0;visibility:hidden;transition:var(--t-base);
  box-shadow:0 4px 14px var(--neon-glow-sm);
}
.gr-btt.visible{opacity:1;visibility:visible}
.gr-btt:hover{transform:translateY(-3px);box-shadow:0 8px 24px var(--neon-glow)}

/* Content body */
.gr-content-body{color:var(--text-secondary);line-height:1.82}
.gr-content-body h2,.gr-content-body h3{color:var(--text-primary);margin:1.4rem 0 .7rem}
.gr-content-body p{margin-bottom:.9rem}
.gr-content-body ul,.gr-content-body ol{padding-left:1.4rem;margin-bottom:.9rem}

/* Intro image */
.gr-intro-img-wrap{position:relative;border-radius:var(--radius-xl);overflow:hidden}
.gr-intro-img-wrap img{width:100%;display:block;border-radius:var(--radius-xl)}
.gr-intro-img-wrap::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(135deg,rgba(89,255,0,.1),transparent);
  pointer-events:none;
}
.gr-intro-img-frame{
  position:absolute;top:-10px;left:-10px;right:-10px;bottom:-10px;
  border:1px solid rgba(89,255,0,.12);
  border-radius:calc(var(--radius-xl) + 6px);pointer-events:none;
}
.gr-intro-img-placeholder{
  aspect-ratio:4/3;background:linear-gradient(135deg,rgba(89,255,0,.12),rgba(89,255,0,.04));
  border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;
  font-size:5rem;color:rgba(89,255,0,.28);
}

/* Glitch */
.gr-glitch{position:relative;display:inline-block}
.gr-glitch::before,.gr-glitch::after{
  content:attr(data-text);
  position:absolute;top:0;left:0;width:100%;height:100%;
}
.gr-glitch::before{
  color:rgba(89,255,0,.7);
  animation:glitch1 3.5s infinite linear alternate-reverse;
  clip-path:polygon(0 0,100% 0,100% 35%,0 35%);left:-2px;
}
.gr-glitch::after{
  color:rgba(149,255,119,.6);
  animation:glitch2 2.8s infinite linear alternate-reverse;
  clip-path:polygon(0 65%,100% 65%,100% 100%,0 100%);left:2px;
}
@keyframes glitch1{0%,78%,100%{transform:none;opacity:0}80%{transform:translateX(-3px) skewX(-5deg);opacity:.7}83%{transform:translateX(2px);opacity:0}}
@keyframes glitch2{0%,72%,100%{transform:none;opacity:0}74%{transform:translateX(3px);opacity:.6}77%{transform:translateX(-2px);opacity:0}}

/* Scroll line anim */
@keyframes scroll-pulse{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:.35;transform:scaleY(.65)}}

/* AOS pointer-events fix */
[data-aos]{pointer-events:none}
[data-aos].aos-animate{pointer-events:auto}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1200px){:root{--section-py:80px}}
@media(max-width:991px){
  .gr-nav-links,.gr-btn-nav{display:none!important}
  .gr-hamburger{display:flex}
  :root{--section-py:64px}
  .gr-orb{width:280px;height:280px}
  .gr-orb-inner{width:195px;height:195px}
  .gr-orb-core{width:115px;height:115px;font-size:2.6rem}
  .gr-orbit-1{width:215px;height:215px}
  .gr-orbit-2{width:260px;height:260px}
}
@media(max-width:768px){
  :root{--section-py:52px}
  .gr-hero-stats{gap:1.2rem}
  .gr-btt{bottom:18px;right:18px}
  .gr-footer-top{padding:44px 0 32px}
}
@media(max-width:576px){
  .gr-hero-actions{flex-direction:column}
  .gr-btn{justify-content:center}
}
/* Row / col grid helpers (avoid full Bootstrap dep — only using BS for grid) */
