/* ============ VARIABLES ============ */
:root {
  --cyan: #00e5ff;
  --cyan-dim: rgba(0,229,255,0.08);
  --cyan-glow: rgba(0,229,255,0.15);
  --indigo: #6366f1;
  --green: #22c55e;
  --amber: #f59e0b;
  --pink: #ec4899;
  --dark: #09090b;
  --dark2: #111113;
  --dark3: #18181b;
  --white: #ffffff;
  --gray50: #fafafa;
  --gray100: #f4f4f5;
  --gray200: #e4e4e7;
  --gray400: #a1a1aa;
  --gray500: #71717a;
  --gray600: #52525b;
  --cyan-card: #0a1a24;
  --font-h: 'Satoshi', system-ui, sans-serif;
  --font-b: 'General Sans', system-ui, sans-serif;
  --font-m: 'JetBrains Mono', monospace;
}

/* ============ RESET ============ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-snap-type:y mandatory; }
body { background:var(--dark); color:#e4e4e7; font-family:var(--font-b); font-size:15px; line-height:1.6; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
/* Snap sections */
.snap-section {
  scroll-snap-align:start;
  scroll-snap-stop:always;
  min-height:100vh;
  display:flex; flex-direction:column; justify-content:center;
  position:relative;
}
/* Footer is part of CTA section flow — no separate snap */
a { color:inherit; text-decoration:none; }
.container { max-width:1140px; margin:0 auto; padding:0 28px; }
::selection { background:rgba(0,229,255,0.2); color:#fff; }

/* ============ REVEAL ============ */
/* Visible by default — animation is progressive enhancement */
.reveal {
  opacity:1;
  transform:translateY(0);
}
.js-ready .reveal {
  opacity:0;
  transform:translateY(24px);
  transition:opacity 0.6s cubic-bezier(0.16,1,0.3,1), transform 0.6s cubic-bezier(0.16,1,0.3,1);
}
.js-ready .reveal.visible {
  opacity:1;
  transform:translateY(0);
}
.reveal-d1 { transition-delay:0.1s; }
.reveal-d2 { transition-delay:0.15s; }
.reveal-d3 { transition-delay:0.2s; }
.reveal-d4 { transition-delay:0.25s; }

/* ============ NAV ============ */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(9,9,11,0.85);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,0.06);
  transition:border-color 0.3s, background 0.3s;
}
nav.scrolled {
  background:rgba(9,9,11,0.95);
  border-bottom-color:rgba(0,229,255,0.08);
}
.nav-inner {
  max-width:1140px; margin:0 auto; padding:0 28px;
  height:64px; display:flex; align-items:center; justify-content:space-between;
}
.logo {
  font-family:var(--font-h); font-size:1.05rem; font-weight:700;
  display:flex; align-items:center; gap:10px;
}
.logo-mark {
  width:38px; height:38px; border-radius:50%;
  background:linear-gradient(135deg, rgba(0,229,255,0.15), rgba(99,102,241,0.15));
  border:1px solid rgba(0,229,255,0.2);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; flex-shrink:0;
  transition:border-color 0.3s;
}
.logo:hover .logo-mark { border-color:rgba(0,229,255,0.5); }
.logo-img {
  width:100%; height:100%; object-fit:cover; display:block;
}
.nav-links {
  display:flex; align-items:center; gap:32px; font-size:0.85rem;
}
.nav-links a {
  color:var(--gray400); transition:color 0.2s; position:relative;
}
.nav-links a:hover { color:#fff; }
.nav-cta {
  background:#fff !important; color:var(--dark) !important;
  padding:9px 22px; border-radius:8px; font-weight:600; font-size:0.85rem;
  transition:all 0.2s;
}
.nav-cta:hover { background:var(--gray200) !important; transform:translateY(-1px); }

/* Burger */
.burger {
  display:none; background:none; border:none; cursor:pointer;
  width:28px; height:20px; position:relative; z-index:110;
}
.burger span {
  display:block; width:100%; height:2px; background:#fff;
  position:absolute; left:0; transition:all 0.3s;
}
.burger span:nth-child(1) { top:0; }
.burger span:nth-child(2) { top:9px; }
.burger span:nth-child(3) { top:18px; }
.burger.active span:nth-child(1) { top:9px; transform:rotate(45deg); }
.burger.active span:nth-child(2) { opacity:0; }
.burger.active span:nth-child(3) { top:9px; transform:rotate(-45deg); }

/* Mobile menu */
.mobile-menu {
  position:fixed; top:0; left:0; right:0; bottom:0; z-index:99;
  background:rgba(9,9,11,0.98); backdrop-filter:blur(24px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:28px;
  opacity:0; pointer-events:none; transition:opacity 0.3s;
}
.mobile-menu.open { opacity:1; pointer-events:auto; }
.mobile-menu a {
  font-family:var(--font-h); font-size:1.4rem; font-weight:600;
  color:var(--gray400); transition:color 0.2s;
}
.mobile-menu a:hover { color:#fff; }
.mobile-cta {
  background:#fff !important; color:var(--dark) !important;
  padding:14px 32px; border-radius:10px; font-weight:600; font-size:1rem;
  margin-top:12px;
}

/* ============ HERO ============ */
.hero {
  min-height:100vh; display:flex; align-items:center;
  padding:80px 0 60px; position:relative; overflow:hidden;
}
/* Subtle gradient orbs — not flat dark */
.hero::before {
  content:''; position:absolute; top:-120px; right:-120px;
  width:600px; height:600px;
  background:radial-gradient(circle, rgba(0,229,255,0.07) 0%, transparent 65%);
  pointer-events:none; animation:drift1 20s ease-in-out infinite;
}
.hero::after {
  content:''; position:absolute; bottom:-100px; left:-80px;
  width:500px; height:500px;
  background:radial-gradient(circle, rgba(99,102,241,0.05) 0%, transparent 65%);
  pointer-events:none; animation:drift2 25s ease-in-out infinite;
}
@keyframes drift1 {
  0%, 100% { transform:translate(0,0); }
  50% { transform:translate(-30px, 20px); }
}
@keyframes drift2 {
  0%, 100% { transform:translate(0,0); }
  50% { transform:translate(20px, -15px); }
}
.hero .container { position:relative; z-index:1; text-align:center; display:flex; flex-direction:column; align-items:center; }
.hero h1 {
  font-family:var(--font-h); font-size:clamp(2.6rem,5.5vw,4.5rem);
  font-weight:900; line-height:1.06; letter-spacing:-0.03em;
  margin-bottom:20px; max-width:750px;
}
.grad {
  background:linear-gradient(135deg, var(--cyan), var(--indigo));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-sub {
  color:var(--gray400); font-size:1.05rem; line-height:1.65;
  margin-bottom:12px; max-width:560px; text-align:center;
}
.hero-punch {
  color:var(--gray500); font-size:0.95rem; margin-bottom:36px; font-weight:500;
}
.hero-btns { display:flex; gap:12px; margin-bottom:48px; flex-wrap:wrap; }
.btn-w {
  background:#fff; color:var(--dark); padding:14px 28px; border-radius:10px;
  font-weight:600; display:inline-flex; align-items:center; gap:8px;
  font-size:0.95rem; transition:all 0.2s;
}
.btn-w:hover { background:var(--gray200); transform:translateY(-1px); }
.btn-o {
  border:1px solid rgba(255,255,255,0.1); padding:14px 28px; border-radius:10px;
  display:inline-flex; align-items:center; gap:8px;
  color:var(--gray400); font-size:0.95rem; transition:all 0.2s;
}
.btn-o:hover { border-color:rgba(255,255,255,0.2); color:#fff; }
.hero-metrics {
  display:flex; gap:40px; padding:28px 0;
  border-top:1px solid rgba(255,255,255,0.06); flex-wrap:wrap;
  justify-content:center;
}
.hm strong {
  font-family:var(--font-h); font-size:1.5rem; font-weight:700;
  color:#fff; display:block;
}
.hm span {
  font-size:0.75rem; color:var(--gray500); margin-top:2px; display:block;
}

/* ============ SECTION DIVIDER ============ */
.section-divider {
  height:1px; border:none; margin:0;
  background:linear-gradient(90deg, transparent 0%, rgba(0,229,255,0.12) 30%, rgba(0,229,255,0.12) 70%, transparent 100%);
}

/* ============ SERVICES ============ */
.services {
  padding:0; background:var(--dark);
  position:relative;
}
/* Subtle top gradient to create depth transition from hero */
.services::before {
  content:''; position:absolute; top:0; left:0; right:0; height:200px;
  background:linear-gradient(180deg, rgba(0,229,255,0.02) 0%, transparent 100%);
  pointer-events:none;
}

.stag {
  font-family:var(--font-m); font-size:0.7rem; letter-spacing:0.12em;
  color:var(--cyan); margin-bottom:12px; text-transform:uppercase;
}
.stitle {
  font-family:var(--font-h); font-size:clamp(1.8rem,3.5vw,2.6rem);
  font-weight:700; line-height:1.1; letter-spacing:-0.02em; margin-bottom:12px;
}
.sdesc {
  color:var(--gray400); font-size:0.95rem; max-width:480px; line-height:1.6;
}
.sheader { text-align:center; margin-bottom:48px; }
.sheader .sdesc { margin:0 auto; }

.services-slide {
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; padding:60px 0;
  position:relative;
  flex:1;
}
.services-slide .sdesc { margin:0 auto 32px; }
.slayers { display:flex; gap:16px; width:100%; align-items:stretch; }
.slayer {
  flex:1; border-radius:14px; padding:32px 28px;
  display:flex; align-items:flex-start; gap:18px;
  transition:transform 0.3s, box-shadow 0.3s, border-color 0.3s;
}
.slayer:hover { transform:translateY(-3px); box-shadow:0 12px 40px rgba(0,0,0,0.25); }
.slayer-light {
  background:var(--cyan-card); border:1px solid rgba(0,229,255,0.1);
}
.slayer-light:hover { border-color:rgba(0,229,255,0.25); }
.slayer-dark {
  background:var(--dark2); border:1px solid rgba(255,255,255,0.06);
}
.slayer-dark:hover { border-color:rgba(255,255,255,0.12); }
.slayer-num {
  font-family:var(--font-h); font-size:2.4rem; font-weight:700;
  line-height:1; flex-shrink:0;
}
.slayer-light .slayer-num { color:rgba(0,229,255,0.2); }
.slayer-dark .slayer-num { color:rgba(0,229,255,0.12); }
.slayer-body { text-align:left; flex:1; }
.scard-badge {
  font-family:var(--font-m); font-size:0.6rem; letter-spacing:0.12em;
  color:var(--cyan); background:var(--cyan-dim);
  display:inline-block; padding:4px 10px; border-radius:4px; margin-bottom:12px;
}
.slayer h3 { font-family:var(--font-h); font-size:1.1rem; font-weight:700; color:#fff; margin-bottom:8px; }
.slayer .slayer-main { font-size:0.85rem; color:var(--gray400); line-height:1.6; margin-bottom:14px; }
.slayer-delivers { display:flex; flex-wrap:wrap; gap:5px; }
.slayer-light .slayer-delivers span {
  font-size:0.65rem; padding:3px 9px; border-radius:100px;
  background:rgba(0,229,255,0.08); color:var(--cyan);
}
.slayer-dark .slayer-delivers span {
  font-size:0.65rem; padding:3px 9px; border-radius:100px;
  background:rgba(255,255,255,0.06); color:var(--gray400);
}

/* ============ CASES ============ */
.cases {
  padding:0; background:var(--dark2);
  position:relative; overflow:hidden;
}
.cases .container { position:relative; z-index:1; padding-top:64px; }
.cases .stag { color:var(--cyan); }
/* Horizontal carousel */
.cgrid {
  display:flex; gap:20px;
  overflow-x:auto; overflow-y:hidden;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding-bottom:32px;
  scrollbar-width:none;
}
.cgrid::-webkit-scrollbar { display:none; }
/* Scroll indicator dots */
.carousel-nav {
  display:flex; justify-content:center; gap:8px;
  padding:16px 0 0;
}
.carousel-dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,0.15);
  border:none; cursor:pointer; padding:0;
  transition:background 0.3s, width 0.3s;
}
.carousel-dot.active {
  background:var(--cyan); width:24px; border-radius:4px;
}
.ccard {
  background:var(--cyan-card); border:1px solid rgba(0,229,255,0.08);
  border-radius:14px; padding:28px 24px; transition:all 0.3s;
  position:relative; overflow:hidden;
  /* Carousel card sizing — exactly 2 cards visible */
  min-width:calc(50% - 10px); max-width:calc(50% - 10px);
  flex-shrink:0;
  scroll-snap-align:start;
}
/* Subtle top accent line per card */
.ccard::before {
  content:''; position:absolute; top:0; left:24px; right:24px; height:1px;
  background:linear-gradient(90deg, transparent, rgba(0,229,255,0.15), transparent);
}
.ccard:hover {
  box-shadow:0 8px 32px rgba(0,0,0,0.3); transform:translateY(-2px);
  border-color:rgba(0,229,255,0.2);
}
.ccard-top { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.ccard-dot { width:10px; height:10px; border-radius:50%; }
.ccard-label {
  font-family:var(--font-m); font-size:0.6rem; letter-spacing:0.12em;
  color:var(--gray400); text-transform:uppercase;
}
.ccard h3 {
  font-family:var(--font-h); font-size:1.05rem; font-weight:700;
  color:#fff; margin-bottom:6px;
}
.ccard p {
  font-size:0.82rem; color:var(--gray400); margin-bottom:14px; line-height:1.6;
}
.ccard-nums { display:flex; gap:20px; margin-bottom:14px; flex-wrap:wrap; }
.ccard-num strong {
  font-family:var(--font-h); font-size:1.25rem; font-weight:700;
  color:#fff; display:block;
}
.ccard-num span { font-size:0.65rem; color:var(--gray500); }
.ccard-pills { display:flex; gap:5px; flex-wrap:wrap; margin-bottom:12px; }
.ccard-pills span {
  font-size:0.65rem; padding:3px 9px; border-radius:100px;
  background:rgba(0,229,255,0.08); color:var(--cyan);
}
.ccard-quote {
  font-size:0.8rem; color:var(--gray400); font-style:italic;
  border-left:2px solid var(--cyan); padding-left:12px;
}
.ccard-link {
  display:inline-flex; align-items:center; gap:4px;
  font-size:0.8rem; font-weight:600; color:var(--cyan); margin-top:12px;
  transition:color 0.2s, gap 0.2s;
}
.ccard-link:hover { color:#fff; gap:8px; }

/* ============ CTA + FOOTER WRAPPER ============ */
.cta {
  padding:0; background:var(--dark);
  position:relative; overflow:hidden;
  justify-content:space-between;
}
/* CTA container fills remaining space above footer, centers the card */
.cta > .container:first-child {
  flex:1; display:flex; align-items:center; justify-content:center;
  position:relative; z-index:1;
  padding-top:64px; /* account for fixed nav */
}
.cta::before {
  content:''; position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%); width:800px; height:800px;
  background:radial-gradient(circle, rgba(0,229,255,0.04) 0%, transparent 50%);
  pointer-events:none;
}
.cta .container { position:relative; z-index:1; }
.cta-inner {
  background:var(--cyan-card);
  border:1px solid rgba(0,229,255,0.1);
  border-radius:20px;
  padding:60px 56px;
  display:flex; gap:48px; align-items:center;
  position:relative; overflow:hidden;
}
.cta-inner::before {
  content:''; position:absolute; top:-60px; right:-60px;
  width:300px; height:300px;
  background:radial-gradient(circle, rgba(0,229,255,0.06) 0%, transparent 70%);
  pointer-events:none;
}
.cta-content { flex:1; }
.cta-content .stitle { margin-bottom:14px; }
.cta-content .sdesc { margin-bottom:28px; color:var(--gray400); }
.cta-actions { display:flex; gap:12px; flex-wrap:wrap; }
.cta-actions .btn-w { padding:14px 32px; font-size:0.95rem; }
.cta-actions .btn-o { font-size:0.9rem; }
.cta-proof {
  flex-shrink:0; display:flex; flex-direction:column; gap:16px;
}
.cta-proof-item {
  display:flex; align-items:center; gap:12px;
  font-size:0.85rem; color:var(--gray400);
}
.cta-proof-item svg { flex-shrink:0; }

/* ============ FOOTER ============ */
footer {
  padding:48px 0; background:var(--dark2);
  border-top:1px solid rgba(255,255,255,0.06);
}
.finner {
  display:flex; justify-content:space-between; align-items:flex-start;
}
.fbrand p {
  font-size:0.82rem; color:var(--gray500); margin-top:10px;
  max-width:260px; line-height:1.5;
}
.fget { margin-top:10px; }
.fget a {
  display:inline-flex; align-items:center; gap:6px;
  font-size:0.82rem; font-weight:600; color:var(--cyan);
  transition:gap 0.2s;
}
.fget a:hover { gap:10px; }
.fsocial {
  display:flex; gap:14px; margin-top:14px;
}
.fsocial a {
  color:var(--gray500); transition:color 0.2s;
}
.fsocial a:hover { color:var(--cyan); }
.fcols { display:flex; gap:48px; }
.fcol h4 {
  font-size:0.65rem; letter-spacing:0.1em; color:var(--gray600);
  margin-bottom:10px; text-transform:uppercase;
}
.fcol a {
  display:block; font-size:0.82rem; color:var(--gray400);
  padding:3px 0; transition:color 0.2s;
}
.fcol a:hover { color:var(--cyan); }
.fbottom {
  display:flex; justify-content:space-between;
  margin-top:28px; padding-top:20px;
  border-top:1px solid rgba(255,255,255,0.06);
  font-size:0.72rem; color:var(--gray600);
}

/* ============ RESPONSIVE ============ */
@media (max-width:768px) {
  .snap-section { min-height:auto; scroll-snap-align:none; }
  .slayers { flex-direction:column; gap:12px; }
  .services-slide { padding:60px 0; }
  .cta { padding:40px 0 0; }
  .cta-inner { flex-direction:column; padding:32px 24px; gap:24px; }
  .cta-proof-item { font-size:0.8rem; gap:10px; }
  .cta-proof-item svg { width:18px; height:18px; }
  .cgrid { flex-direction:column; overflow-x:visible; scroll-snap-type:none; margin:0; padding:0; gap:14px; }
  .ccard { min-width:auto; max-width:none; padding:22px 20px; }
  .ccard p { font-size:0.78rem; margin-bottom:10px; line-height:1.5; }
  .ccard-nums { gap:16px; margin-bottom:10px; }
  .ccard-pills { margin-bottom:8px; }
  .ccard-pills span { font-size:0.6rem; padding:2px 7px; }
  .ccard-quote { font-size:0.75rem; }
  .carousel-nav { display:none; }
  .cases .container { padding-top:40px; }
  .hero h1 { font-size:2.4rem; }
  .hero .container { text-align:center; }
  .finner { flex-direction:column; gap:24px; }
  .nav-links { display:none; }
  .burger { display:block; }
  .hero-metrics { gap:24px; justify-content:center; }
  .fcols { flex-wrap:wrap; gap:28px; }
  .fbottom { flex-direction:column; gap:4px; }
}
@media (max-width:480px) {
  .cases .container { padding-top:30px; }
  .ccard-num strong { font-size:1.1rem; }
}