
:root {
  --gs-purple:  #4B44CC;
  --gs-purple2: #6C63FF;
  --gs-blue:    #2F6FE0;
  --gs-deep:    #FFFFFF;
  --gs-navy:    #F4F4F8;
  --gs-surface: #EEEEF5;
  --gs-card:    #F8F8FC;
  --gs-border:  rgba(75,68,204,0.15);
  --gs-white:   #1A1A2E;
  --gs-muted:   #5A6380;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--gs-deep) !important;
  color: var(--gs-white) !important;
  font-family: 'DM Sans', sans-serif !important;
  touch-action: manipulation;
  overflow-x: hidden;
  width: 100%;
}

/* Hide WordPress header/footer from theme */
#masthead, #colophon, .site-header, .site-footer,
.ast-above-header, .ast-below-header,
.ast-primary-header-bar { display: none !important; }

#page, #content, .site, .ast-container,
.entry-content, .post-content, .page-content {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
}

img, svg, video, iframe {
  max-width: 100%;
}

input, select, textarea, button {
  font: inherit;
}

a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--gs-blue);
  outline-offset: 2px;
}


/* NOISE */
body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:9990; opacity:.08;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
}

/* KEYFRAMES */
@keyframes gs-slide-up { from{opacity:0;transform:translateY(42px)} to{opacity:1;transform:translateY(0)} }
@keyframes gs-float    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-28px)} }
@keyframes gs-float-r  { 0%,100%{transform:translateY(0)} 50%{transform:translateY(22px)} }
@keyframes gs-marquee  { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes gs-pulse    { 0%,100%{opacity:1;transform:scaleY(1)} 50%{opacity:.3;transform:scaleY(.45)} }

/* ── SCROLL PROGRESS ── */
.gs-progress {
  position:fixed; top:0; left:0; height:2px; width:0%;
  background:linear-gradient(90deg,var(--gs-purple),var(--gs-blue));
  z-index:99997; transition:width .08s linear;
  box-shadow:0 0 8px rgba(108,99,255,.5);
}

/* ── HERO CANVAS ── */
#gs-canvas {
  position:absolute; inset:0; width:100%; height:100%;
  pointer-events:none; z-index:0; opacity:.5;
}

/* ── GLOBE ── */
.gs-globe-wrap {
  position:absolute; right:5rem; top:50%; transform:translateY(-50%);
  width:min(400px,36vw); aspect-ratio:1;
  pointer-events:none; z-index:1;
}
.gs-globe-svg { width:100%; height:100%; overflow:visible; }

/* ── FLOATING DATA CHIPS ── */
.gs-chip {
  position:absolute; background:rgba(255,255,255,.88);
  border:1px solid var(--gs-border); border-radius:40px;
  padding:.45rem 1rem; font-size:.72rem; letter-spacing:.5px;
  color:var(--gs-purple); font-family:'DM Sans',sans-serif;
  backdrop-filter:blur(8px); pointer-events:none; z-index:2;
  white-space:nowrap; box-shadow:0 4px 20px rgba(75,68,204,.1);
  display:flex; align-items:center; gap:.4rem;
  opacity:0; animation:gs-chip-appear .6s forwards;
}
.gs-chip-dot { width:6px; height:6px; border-radius:50%; background:var(--gs-purple); flex-shrink:0; animation:gs-chip-blink 1.8s ease-in-out infinite; }
@keyframes gs-chip-blink  { 0%,100%{opacity:1} 50%{opacity:.25} }
@keyframes gs-chip-appear { to{opacity:1} }
@keyframes gs-chip-float  { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes gs-chip-floatr { 0%,100%{transform:translateY(0)} 50%{transform:translateY(8px)} }
.gs-chip-1 { top:26%; right:calc(5rem + min(400px,36vw) + 1.5rem); animation-delay:.9s,0s; animation-name:gs-chip-appear,gs-chip-float; animation-duration:.6s,7s; animation-fill-mode:forwards,none; animation-iteration-count:1,infinite; animation-timing-function:ease,ease-in-out; }
.gs-chip-2 { top:52%; right:calc(5rem + min(400px,36vw) - 2rem); animation-delay:1.2s,0s; animation-name:gs-chip-appear,gs-chip-floatr; animation-duration:.6s,9s; animation-fill-mode:forwards,none; animation-iteration-count:1,infinite; animation-timing-function:ease,ease-in-out; }
.gs-chip-3 { bottom:22%; right:calc(5rem + min(400px,36vw) + 3rem); animation-delay:1.5s,0s; animation-name:gs-chip-appear,gs-chip-float; animation-duration:.6s,11s; animation-fill-mode:forwards,none; animation-iteration-count:1,infinite; animation-timing-function:ease,ease-in-out; }

/* ── GLITCH on hero italic ── */
@keyframes gs-glitch-1 {
  0%,93%,100% { clip-path:none; transform:none; color:var(--gs-purple); }
  94% { clip-path:inset(15% 0 55% 0); transform:translate(-4px,1px); color:var(--gs-blue); }
  95% { clip-path:inset(55% 0 15% 0); transform:translate(4px,-1px); }
  96% { clip-path:inset(35% 0 35% 0); transform:translate(-2px,0); color:var(--gs-purple2); }
  97% { clip-path:none; transform:none; color:var(--gs-purple); }
}
.gs-h1 em { display:inline-block; animation:gs-glitch-1 7s steps(1) infinite; }

/* ── MOBILE: hide globe + chips ── */
@media(max-width:900px){
  .gs-globe-wrap,.gs-chip { display:none; }
  #gs-canvas { opacity:.25; }
}

/* SCROLL REVEAL */
.gs-reveal { opacity:0; transform:translateY(38px); transition:opacity .8s ease, transform .8s ease; }
.gs-reveal.in { opacity:1; transform:translateY(0); }
.d1 { transition-delay:.12s; }
.d2 { transition-delay:.24s; }
.d3 { transition-delay:.36s; }
.d4 { transition-delay:.48s; }

/* ── HERO ── */
.gs-hero-push { padding-top:5rem; }
.gs-hero {
  min-height:100vh; display:flex; flex-direction:column; justify-content:flex-end;
  padding:7rem 5rem 5rem; position:relative; overflow:hidden;
  background:linear-gradient(135deg,#FFFFFF 0%,#F0F0FA 100%);
}
.gs-grid {
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:linear-gradient(rgba(75,68,204,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(75,68,204,.06) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center,black 25%,transparent 75%);
}
.gs-orb {
  position:absolute; border-radius:50%; filter:blur(80px);
  pointer-events:none; z-index:0;
}
.gs-orb-1 {
  width:650px; height:650px;
  background:radial-gradient(circle,rgba(75,68,204,.1),transparent 70%);
  top:-180px; right:-180px;
  animation:gs-float 9s ease-in-out infinite;
}
.gs-orb-2 {
  width:420px; height:420px;
  background:radial-gradient(circle,rgba(47,111,224,.08),transparent 70%);
  bottom:60px; left:-80px;
  animation:gs-float-r 11s ease-in-out infinite;
}
.gs-hero-inner { position:relative; z-index:3; max-width:1100px; }
.gs-tag {
  font-size:.72rem; letter-spacing:5px; text-transform:uppercase;
  color:var(--gs-purple); margin-bottom:1.4rem;
  animation:gs-slide-up .8s cubic-bezier(.22,1,.36,1) forwards; opacity:0; animation-delay:.25s;
}
.gs-h1 {
  font-family:'Playfair Display',serif;
  font-size:clamp(3rem,7vw,6.5rem); font-weight:700; line-height:1.06; max-width:820px;
  color:var(--gs-white);
  animation:gs-slide-up .9s cubic-bezier(.22,1,.36,1) forwards; opacity:0; animation-delay:.45s;
}
.gs-h1 em { font-style:italic; color:var(--gs-purple); }
.gs-hero-desc {
  margin-top:2rem; max-width:580px;
  color:var(--gs-muted); font-size:1.05rem; line-height:1.82;
  padding-left:1.4rem; border-left:2px solid var(--gs-purple);
  animation:gs-slide-up .9s cubic-bezier(.22,1,.36,1) forwards; opacity:0; animation-delay:.65s;
}
.gs-hero-desc strong { color:var(--gs-white); }
.gs-hero-cta {
  margin-top:2.8rem; display:flex; gap:1.8rem; align-items:center;
  animation:gs-slide-up .9s cubic-bezier(.22,1,.36,1) forwards; opacity:0; animation-delay:.85s;
}
.gs-hero-trust {
  margin-top: 1.1rem;
  font-size: .78rem;
  letter-spacing: .4px;
  color: var(--gs-muted);
  animation: gs-slide-up .9s cubic-bezier(.22,1,.36,1) forwards;
  opacity: 0;
  animation-delay: .95s;
}
.gs-btn {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.95rem 2.4rem; background:var(--gs-purple); color:#fff;
  font-family:'DM Sans',sans-serif; font-size:.88rem; letter-spacing:1.5px;
  text-transform:uppercase; border:none;
  position:relative; overflow:hidden; transition:transform .3s; text-decoration:none;
}
.gs-btn::before {
  content:''; position:absolute; inset:0;
  background:var(--gs-purple2); transform:translateX(-101%); transition:transform .4s ease;
}
.gs-btn:hover::before { transform:translateX(0); }
.gs-btn:hover { transform:translateY(-2px); color:#fff; }
.gs-btn span { position:relative; z-index:1; }
.gs-ghost {
  color:var(--gs-purple); font-size:.88rem; letter-spacing:1px;
  text-decoration:none; display:flex; align-items:center; gap:.5rem;
  transition:color .3s;
}
.gs-ghost:hover { color:var(--gs-blue); }
.gs-ghost .arr { transition:transform .3s; }
.gs-ghost:hover .arr { transform:translateX(5px); }
.gs-scroll {
  position:absolute; bottom:2.5rem; right:3.5rem;
  display:flex; flex-direction:column; align-items:center; gap:.5rem; z-index:4;
  animation:gs-slide-up 1s forwards; opacity:0; animation-delay:1.1s;
}
.gs-scroll span {
  font-size:.62rem; letter-spacing:3px; text-transform:uppercase;
  color:var(--gs-muted); writing-mode:vertical-rl;
}
.gs-scroll-line {
  width:1px; height:58px;
  background:linear-gradient(to bottom,var(--gs-purple),transparent);
  animation:gs-pulse 2.2s ease-in-out infinite;
}

/* ── MARQUEE ── */
.gs-marquee-wrap { overflow:hidden; background:linear-gradient(135deg,var(--gs-purple),var(--gs-blue)); padding:.9rem 0; }
.gs-marquee-track { display:flex; width:max-content; animation:gs-marquee 22s linear infinite; gap:3rem; }
.gs-marquee-item {
  font-family:'Bebas Neue',sans-serif; font-size:1rem; letter-spacing:3px;
  color:rgba(255,255,255,.92); white-space:nowrap; display:flex; align-items:center; gap:3rem;
}
.gs-dot { width:5px; height:5px; background:rgba(255,255,255,.4); border-radius:50%; flex-shrink:0; display:inline-block; }

/* ── STATS ── */
.gs-stats { display:grid; grid-template-columns:repeat(3,1fr); background:var(--gs-surface); border-top:1px solid var(--gs-border); border-bottom:1px solid var(--gs-border); }
.gs-stat { padding:3rem 2rem; text-align:center; border-right:1px solid var(--gs-border); }
.gs-stat:last-child { border-right:none; }
.gs-stat-num { font-family:'Bebas Neue',sans-serif; font-size:3.8rem; color:var(--gs-purple); display:block; line-height:1; }
.gs-stat-label { font-size:.72rem; letter-spacing:3px; text-transform:uppercase; color:var(--gs-muted); margin-top:.5rem; }

/* ── SHARED SECTION ── */
.gs-section { padding:8rem 5rem; position:relative; }
.gs-section-dark { background:var(--gs-navy); }
.gs-inner { max-width:1200px; margin:0 auto; }
.gs-label { font-size:.7rem; letter-spacing:5px; text-transform:uppercase; color:var(--gs-purple); margin-bottom:1.2rem; }
.gs-line  { width:52px; height:2px; background:var(--gs-purple); margin-bottom:1.4rem; }
.gs-title { font-family:'Playfair Display',serif; font-size:clamp(2rem,4vw,3.2rem); font-weight:700; line-height:1.2; color:var(--gs-white); }
.gs-divider::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(to right,transparent,var(--gs-purple),transparent); }

/* ── WHY ── */
.gs-why-grid { display:grid; grid-template-columns:1fr 2fr; gap:6rem; align-items:center; }
.gs-why-text { font-size:1.04rem; line-height:1.9; color:var(--gs-muted); position:relative; padding-top:2rem; }
.gs-why-text::before { content:'"'; position:absolute; top:-1.5rem; left:-1rem; font-family:'Playfair Display',serif; font-size:7rem; color:rgba(108,99,255,.08); line-height:1; }

/* ── GALLERY ── */
.gs-gallery { background:var(--gs-navy); padding:3rem 0; overflow:hidden; }
.gs-gallery-track { display:flex; gap:1.5rem; padding:0 1.5rem; animation:gs-marquee 30s linear infinite; width:max-content; }
.gs-gallery-img { width:320px; height:200px; object-fit:cover; flex-shrink:0; border:1px solid var(--gs-border); filter:saturate(.8); transition:transform .4s,filter .4s; }
.gs-gallery-img:hover { transform:scale(1.04); filter:saturate(1); }

/* ── SERVICES ── */
.gs-svc-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5px; margin-top:3.5rem; }
.gs-svc {
  background:var(--gs-card); padding:2.5rem 2rem;
  position:relative; overflow:hidden;
  transition:transform .4s cubic-bezier(.25,.46,.45,.94), box-shadow .4s;
}
.gs-svc::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(75,68,204,.06),transparent); opacity:0; transition:opacity .4s; }
.gs-svc::after  { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--gs-purple); transition:width .45s ease; }
.gs-svc:hover { transform:translateY(-7px); box-shadow:0 22px 44px rgba(75,68,204,.1); }
.gs-svc:hover::before { opacity:1; }
.gs-svc:hover::after  { width:100%; }
.gs-svc-num { font-family:'Bebas Neue',sans-serif; font-size:3.2rem; color:rgba(108,99,255,.15); line-height:1; margin-bottom:1.5rem; transition:color .4s; }
.gs-svc:hover .gs-svc-num { color:rgba(108,99,255,.4); }
.gs-svc-title { font-family:'Playfair Display',serif; font-size:1.12rem; margin-bottom:1rem; color:var(--gs-white); }
.gs-svc-desc  { font-size:.9rem; line-height:1.72; color:var(--gs-muted); }
.gs-svc-desc a { color:var(--gs-purple); text-decoration:none; }

/* ── ABOUT ── */
.gs-about { padding:8rem 5rem; position:relative; overflow:hidden; background:var(--gs-deep); }
.gs-about::after { content:''; position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse at 80% 50%,rgba(75,68,204,.05),transparent 60%); }
.gs-about-grid { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:3fr 2fr; gap:6rem; position:relative; z-index:1; }
.gs-about-text { font-size:1.02rem; line-height:1.9; color:var(--gs-muted); margin-top:2rem; }
.gs-about-text strong { color:var(--gs-white); }
.gs-pillars { display:flex; flex-direction:column; gap:2rem; margin-top:.5rem; }
.gs-pillar { border-left:2px solid transparent; padding-left:1.5rem; transition:border-color .4s; }
.gs-pillar:hover { border-left-color:var(--gs-purple); }
.gs-pillar-t { font-family:'Bebas Neue',sans-serif; font-size:1.05rem; letter-spacing:2px; color:var(--gs-purple); margin-bottom:.5rem; }
.gs-pillar-p { font-size:.9rem; line-height:1.72; color:var(--gs-muted); }
.gs-img { width:100%; height:auto; display:block; border:1px solid var(--gs-border); filter:saturate(.75); transition:transform .5s,filter .5s; }
.gs-img:hover { transform:scale(1.02); filter:saturate(1); }

/* ── PROJECTS ── */
.gs-proj-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:2rem; margin-top:3.5rem; }
.gs-proj {
  background:var(--gs-card); overflow:hidden; position:relative;
  transition:transform .4s,box-shadow .4s; border:1px solid var(--gs-border);
  color:inherit;
}
a.gs-proj:hover { color:inherit; }
.gs-proj:hover { transform:translateY(-8px); box-shadow:0 28px 56px rgba(75,68,204,.12); }
.gs-proj-img { width:100%; height:220px; overflow:hidden; position:relative; }
.gs-proj-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; filter:saturate(.8); }
.gs-proj:hover .gs-proj-img img { transform:scale(1.06); filter:saturate(1); }
.gs-shimmer { position:absolute; inset:0; pointer-events:none; background:linear-gradient(105deg,transparent 40%,rgba(75,68,204,.1) 50%,transparent 60%); transform:translateX(-101%); }
.gs-proj:hover .gs-shimmer { transform:translateX(101%); transition:transform .75s ease; }
.gs-proj-body { padding:2rem 2rem 3.5rem; }
.gs-proj-tag   { font-size:.68rem; letter-spacing:3px; text-transform:uppercase; color:var(--gs-purple); margin-bottom:.9rem; }
.gs-proj-title { font-family:'Playfair Display',serif; font-size:1.22rem; margin-bottom:.9rem; color:var(--gs-white); }
.gs-proj-desc  { font-size:.9rem; line-height:1.72; color:var(--gs-muted); }
.gs-proj-arrow { position:absolute; bottom:2rem; right:2rem; width:38px; height:38px; border:1px solid var(--gs-border); display:flex; align-items:center; justify-content:center; color:var(--gs-purple); font-size:1rem; transition:all .3s; }
.gs-proj:hover .gs-proj-arrow { background:var(--gs-purple); color:#fff; border-color:var(--gs-purple); }

/* ── CLIENTS ── */
.gs-clients-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5px; margin-top:3.5rem; }
.gs-client { background:var(--gs-card); padding:2.5rem; position:relative; overflow:hidden; transition:transform .3s,box-shadow .3s; }
.gs-client::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(75,68,204,.06),transparent); opacity:0; transition:opacity .3s; pointer-events:none; }
.gs-client:hover { transform:translateY(-5px); box-shadow:0 20px 40px rgba(75,68,204,.1); }
.gs-client:hover::after { opacity:1; }
.gs-client-icon { width:46px; height:46px; border:1px solid var(--gs-border); display:flex; align-items:center; justify-content:center; font-size:1.2rem; color:var(--gs-purple); margin-bottom:1.5rem; transition:all .3s; }
.gs-client:hover .gs-client-icon { background:var(--gs-purple); color:#fff; border-color:var(--gs-purple); }
.gs-client-title { font-family:'Playfair Display',serif; font-size:1.08rem; margin-bottom:.75rem; color:var(--gs-white); }
.gs-client-desc  { font-size:.87rem; line-height:1.72; color:var(--gs-muted); }

/* ── CTA ── */
.gs-cta { padding:8rem 5rem; background:var(--gs-deep); position:relative; overflow:hidden; }
.gs-cta::before { content:''; position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse at center,rgba(75,68,204,.06),transparent 70%); }
.gs-cta-grid { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:3fr 2fr; gap:5rem; align-items:start; position:relative; z-index:1; }
.gs-cta-h { font-family:'Playfair Display',serif; font-size:clamp(2.4rem,5vw,4.2rem); font-weight:700; line-height:1.15; color:var(--gs-white); }
.gs-cta-h em { font-style:italic; color:var(--gs-purple); }
.gs-cta-sub { font-size:1rem; color:var(--gs-muted); line-height:1.8; margin-top:1.5rem; }
.gs-cta-cards { display:flex; flex-direction:column; gap:1.5rem; }
.gs-cta-card { border:1px solid var(--gs-border); padding:1.8rem; position:relative; overflow:hidden; transition:border-color .3s; }
.gs-cta-card:hover { border-color:var(--gs-purple); }
.gs-cta-card::before { content:''; position:absolute; top:0; right:0; width:80px; height:80px; background:radial-gradient(circle at top right,rgba(75,68,204,.08),transparent); }
.gs-cta-card-label { font-size:.68rem; letter-spacing:3px; text-transform:uppercase; color:var(--gs-purple); margin-bottom:.7rem; }
.gs-cta-card-text  { font-size:.9rem; line-height:1.72; color:var(--gs-muted); }

/* ── SUBSCRIBE ── */
.gs-subscribe { padding:4rem 5rem; background:linear-gradient(135deg,var(--gs-purple),var(--gs-blue)); position:relative; overflow:hidden; }
.gs-sub-inner { max-width:1200px; margin:0 auto; display:flex; justify-content:space-between; align-items:center; gap:3rem; }
.gs-sub-title { font-family:'Bebas Neue',sans-serif; font-size:2.4rem; letter-spacing:3px; color:#fff; }
.gs-sub-sub   { font-size:.9rem; color:rgba(255,255,255,.7); margin-top:.25rem; }
.gs-sub-form  { display:flex; flex:1; max-width:480px; }
.gs-sub-input { flex:1; padding:1rem 1.4rem; background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.25); border-right:none; color:#fff; font-family:'DM Sans',sans-serif; font-size:.95rem; outline:none; transition:background .3s; }
.gs-sub-input::placeholder { color:rgba(255,255,255,.55); }
.gs-sub-input:focus { background:rgba(255,255,255,.22); }
.gs-sub-btn { padding:1rem 2rem; background:#1A1A2E; color:#fff; border:none; font-family:'DM Sans',sans-serif; font-size:.84rem; letter-spacing:1.5px; text-transform:uppercase; transition:background .3s; }
.gs-sub-btn:hover { background:#2d2d4e; }

/* ── FOOTER ── */
.gs-footer { padding:2rem 5rem; background:#EEEEF5; border-top:1px solid var(--gs-border); display:flex; justify-content:space-between; align-items:center; }
.gs-footer-logo { font-family:'Bebas Neue',sans-serif; font-size:1.4rem; letter-spacing:3px; color:var(--gs-purple); }
.gs-footer-copy { font-size:.8rem; color:var(--gs-muted); }

/* ── NAV ── */
.gs-nav {
  position:fixed; top:0; left:0; right:0; z-index:9000;
  display:flex; align-items:center; justify-content:space-between;
  padding:.9rem 3rem;
  background:rgba(255,255,255,0.9);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(75,68,204,.08);
  box-shadow:0 2px 20px rgba(75,68,204,.04);
  transition:background .3s, box-shadow .3s;
}
.gs-nav.scrolled {
  background:rgba(255,255,255,.98);
  box-shadow:0 2px 24px rgba(75,68,204,.1);
}
.gs-nav-links {
  display:flex; align-items:center;
  gap:.3rem; list-style:none; margin-left:auto;
}
.gs-nav-link {
  display:inline-block; padding:.65rem 1.3rem;
  color:var(--gs-muted); font-size:.84rem; letter-spacing:.5px;
  text-decoration:none; font-family:'DM Sans',sans-serif;
  position:relative; transition:color .25s, background .25s;
  cursor:pointer; white-space:nowrap; border-radius:4px;
}
.gs-nav-link::after {
  content:''; position:absolute; bottom:5px; left:1.3rem; right:1.3rem;
  height:1.5px; background:var(--gs-purple);
  transform:scaleX(0); transform-origin:left; transition:transform .3s ease;
}
.gs-nav-link:hover, .gs-nav-link.active { color:var(--gs-purple); background:rgba(75,68,204,.05); }
.gs-nav-link:hover::after, .gs-nav-link.active::after { transform:scaleX(1); }
.gs-nav-cta {
  display:inline-flex; align-items:center; padding:.65rem 1.6rem;
  background:var(--gs-purple); color:#fff !important;
  font-size:.84rem; letter-spacing:1px; text-transform:uppercase;
  font-family:'DM Sans',sans-serif; text-decoration:none;
  border-radius:4px; position:relative; overflow:hidden;
  transition:transform .25s, box-shadow .25s; cursor:pointer; white-space:nowrap;
}
.gs-nav-cta::before {
  content:''; position:absolute; inset:0;
  background:var(--gs-purple2); transform:translateX(-101%); transition:transform .35s ease;
  pointer-events:none;
}
.gs-nav-cta span { position:relative; z-index:1; }
.gs-nav-cta:hover::before { transform:translateX(0); }
.gs-nav-cta:hover { transform:translateY(-1px); box-shadow:0 6px 20px rgba(75,68,204,.25); }
.gs-nav-cta.active { box-shadow:0 0 0 2px var(--gs-blue), 0 6px 20px rgba(75,68,204,.25); }
.gs-hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:.5rem; background:none; border:none;
  margin-left:auto; z-index:10001; position:relative; touch-action:manipulation; -webkit-tap-highlight-color:transparent;
}
.gs-hamburger span { width:24px; height:2px; background:var(--gs-purple); border-radius:2px; transition:all .3s; display:block; }

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .gs-nav { padding:.85rem 2rem; }
  .gs-hero { padding:7.2rem 2.4rem 4.2rem; }
  .gs-section, .gs-about, .gs-cta, .gs-sub { padding-left:2.4rem; padding-right:2.4rem; }
  .gs-footer { padding-left:2.4rem; padding-right:2.4rem; }
  .gs-svc-grid { grid-template-columns:repeat(2,1fr); }
  .gs-why-grid,.gs-about-grid,.gs-cta-grid { grid-template-columns:1fr; gap:3rem; }
}
@media(max-width:768px){
      /* nav */
  .gs-nav { padding:.75rem 1.5rem; }
  .gs-nav-links { display:none; }
  .gs-hamburger { display:flex !important; }
  .gs-nav-links.open {
    display:flex; flex-direction:column;
    position:fixed; top:4rem; left:50%; transform:translateX(-50%);
    width:90%; max-width:360px;
    background:#fff; border:1px solid var(--gs-border);
    border-radius:12px; padding:1rem;
    box-shadow:0 20px 60px rgba(75,68,204,.15);
    gap:.3rem; z-index:9999; align-items:stretch;
  }
  .gs-nav-link { padding:1rem 1.2rem; width:100%; font-size:.95rem; border-radius:8px; }
  .gs-nav-link::after { display:none; }
  .gs-nav-cta { padding:1rem 1.2rem; width:100%; justify-content:center; border-radius:8px; margin-top:.3rem; }

  /* hero */
  .gs-hero { padding:7rem 1.5rem 3.5rem; min-height:auto; }
  .gs-h1   { font-size:clamp(2.2rem,9vw,3.2rem); }
  .gs-hero-desc { font-size:.95rem; }
  .gs-hero-cta { flex-direction:column; align-items:flex-start; gap:1rem; }
  .gs-btn  { width:100%; justify-content:center; }
  .gs-scroll { display:none; }

  /* stats */
  .gs-stats { grid-template-columns:1fr 1fr; }
  .gs-stat  { padding:2rem 1rem; }
  .gs-stat-num { font-size:2.8rem; }

  /* sections */
  .gs-section  { padding:4rem 1.5rem; }
  .gs-about    { padding:4rem 1.5rem; }
  .gs-cta      { padding:4rem 1.5rem; }
  .gs-subscribe{ padding:2.5rem 1.5rem; }

  /* why */
  .gs-why-grid { grid-template-columns:1fr; gap:2rem; }

  /* services */
  .gs-svc-grid { grid-template-columns:1fr; }

  /* projects */
  .gs-proj-grid { grid-template-columns:1fr; }

  /* clients */
  .gs-clients-grid { grid-template-columns:1fr; }

  /* cta */
  .gs-cta-grid { grid-template-columns:1fr; gap:2.5rem; }
  .gs-cta-h    { font-size:clamp(2rem,8vw,3rem); }

  /* subscribe */
  .gs-sub-inner { flex-direction:column; gap:1.5rem; }
  .gs-sub-form  { max-width:100%; width:100%; }
  .gs-sub-title { font-size:1.8rem; }

  /* about */
  .gs-about-grid { grid-template-columns:1fr; gap:2.5rem; }

  /* footer */
  .gs-footer { flex-direction:column; gap:1rem; text-align:center; padding:1.5rem; }
}
@media(max-width:420px){
  .gs-stats { grid-template-columns:1fr; }
  .gs-stat  { border-right:none; border-bottom:1px solid var(--gs-border); }
  .gs-h1    { font-size:2rem; }
  .gs-hero  { padding-top:6rem; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .gs-cursor,
  .gs-cursor-ring,
  .gs-orb,
  .gs-chip,
  #gs-canvas {
    display: none !important;
  }
}
