/* =============================================
   TrueScal — Premium Dark Theme
   CLEAN REWRITE — No z-index overlay bugs
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700;800&display=swap');

/* ============================================
   DESIGN TOKENS
   ============================================ */
:root {
  --clr-bg:         #07090F;
  --clr-bg2:        #0C0F1A;
  --clr-surface:    rgba(255,255,255,0.04);
  --clr-surface2:   rgba(255,255,255,0.07);
  --clr-border:     rgba(255,255,255,0.08);
  --clr-border2:    rgba(255,255,255,0.14);

  --clr-primary:       #6C63FF;
  --clr-primary-dark:  #4F46E5;
  --clr-secondary:     #06B6D4;
  --clr-accent:        #EC4899;
  --clr-success:       #10B981;

  --clr-text:       #EEF2FF;
  --clr-text-muted: #94A3B8;
  --clr-text-sub:   #64748B;

  --grad-primary:   linear-gradient(135deg, #6C63FF 0%, #4F46E5 40%, #06B6D4 100%);
  --grad-card:      linear-gradient(135deg, rgba(108,99,255,0.08) 0%, rgba(6,182,212,0.04) 100%);

  --shadow-glow:  0 8px 32px rgba(108,99,255,0.4);
  --shadow-card:  0 8px 32px rgba(0,0,0,0.5), 0 1px 0 rgba(255,255,255,0.04);
  --shadow-lg:    0 24px 64px rgba(0,0,0,0.6);

  --font-main:    'Inter', sans-serif;
  --font-display: 'Space Grotesk', sans-serif;

  --radius:    14px;
  --radius-sm: 8px;
  --radius-lg: 24px;
  --radius-xl: 32px;

  --ease:       cubic-bezier(0.16, 1, 0.3, 1);
  --transition: all 0.35s var(--ease);
}

/* ============================================
   RESET & BASE — no body overlays
   ============================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }

body {
  font-family: var(--font-main);
  background: var(--clr-bg);
  color: var(--clr-text);
  line-height: 1.65;
  overflow-x: hidden;
  /* Simple dark gradient — no overlay pseudoelements blocking content */
  background: linear-gradient(160deg, #07090F 0%, #0A0D18 100%);
}

a { text-decoration: none; color: inherit; }
ul { list-style: none; }
img { max-width: 100%; display: block; }
button { cursor: pointer; border: none; outline: none; font-family: inherit; }

/* Scrollbar */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--clr-bg); }
::-webkit-scrollbar-thumb { background: var(--clr-primary); border-radius: 4px; }
::selection { background: var(--clr-primary); color: #fff; }

/* ============================================
   UTILITY
   ============================================ */
.container { width: 90%; max-width: 1200px; margin: 0 auto; }

.section-tag {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(108,99,255,0.1);
  border: 1px solid rgba(108,99,255,0.25);
  color: #A5A0FF;
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 6px 16px; border-radius: 50px;
  margin-bottom: 20px;
}
.section-tag span {
  display: inline-block; width: 6px; height: 6px;
  background: var(--clr-secondary); border-radius: 50%;
  box-shadow: 0 0 8px var(--clr-secondary);
}

.section-title {
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 3.5vw, 2.9rem);
  font-weight: 800; line-height: 1.12;
  color: var(--clr-text);
  margin-bottom: 16px;
  letter-spacing: -0.02em;
}
.section-title .highlight {
  background: var(--grad-primary);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-desc {
  font-size: 1.05rem; color: var(--clr-text-muted);
  max-width: 540px; line-height: 1.75;
}
.text-center { text-align: center; }
.text-center .section-desc { margin: 0 auto; }

/* ============================================
   BUTTONS
   ============================================ */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.95rem; font-weight: 600;
  padding: 13px 28px; border-radius: 50px;
  transition: var(--transition);
  position: relative; overflow: hidden;
  white-space: nowrap;
  cursor: pointer;
}

.btn-primary {
  background: var(--grad-primary);
  color: #fff;
  box-shadow: var(--shadow-glow);
  border: none;
}
.btn-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 40px rgba(108,99,255,0.55);
}

.btn-outline {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--clr-border2);
  color: var(--clr-text);
}
.btn-outline:hover {
  border-color: var(--clr-primary);
  color: #A5A0FF;
  background: rgba(108,99,255,0.1);
  transform: translateY(-2px);
}

.btn-lg { padding: 16px 36px; font-size: 1rem; }
.btn-arrow { font-size: 1.1em; transition: transform 0.3s ease; }
.btn:hover .btn-arrow { transform: translateX(4px); }

/* ============================================
   NAVBAR
   ============================================ */
.navbar {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000;
  transition: var(--transition);
}
.navbar.scrolled {
  background: rgba(7,9,15,0.9);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--clr-border);
  box-shadow: 0 4px 24px rgba(0,0,0,0.4);
}
.nav-inner {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 20px 0;
}
.nav-logo { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); }
.logo-icon {
  width: 36px; height: 36px;
  background: var(--grad-primary); border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; box-shadow: var(--shadow-glow);
}
.logo-text { font-size: 1.3rem; font-weight: 800; color: var(--clr-text); }
.logo-text span { color: #A5A0FF; }

.nav-links { display: flex; align-items: center; gap: 36px; }
.nav-links a {
  font-size: 0.9rem; font-weight: 500;
  color: var(--clr-text-muted); position: relative;
  transition: var(--transition);
}
.nav-links a::after {
  content: ''; position: absolute; bottom: -4px; left: 0;
  width: 0; height: 1.5px; background: var(--grad-primary);
  border-radius: 2px; transition: width 0.3s ease;
}
.nav-links a:hover { color: var(--clr-text); }
.nav-links a:hover::after { width: 100%; }
.nav-cta { display: flex; align-items: center; gap: 12px; }
.hamburger { display: none; flex-direction: column; gap: 5px; background: none; padding: 4px; }
.hamburger span { display: block; width: 22px; height: 2px; background: var(--clr-text); border-radius: 2px; transition: var(--transition); }
.mobile-menu {
  display: none;
  position: fixed; top: 70px; left: 0; right: 0; bottom: 0;
  background: rgba(7,9,15,0.97); backdrop-filter: blur(24px);
  z-index: 999; padding: 40px;
  flex-direction: column; gap: 32px;
  border-top: 1px solid var(--clr-border);
}
.mobile-menu.open { display: flex; }
.mobile-menu a { font-size: 1.4rem; font-weight: 600; color: var(--clr-text-muted); transition: var(--transition); }
.mobile-menu a:hover { color: var(--clr-text); }

/* ============================================
   HERO — INTERACTIVE DARK PREMIUM BACKGROUND
   ============================================ */
.hero {
  min-height: 100vh;
  display: flex; align-items: center;
  position: relative; overflow: hidden;
  padding: 160px 0 120px;
  background:
    radial-gradient(ellipse 70% 60% at 70% 25%, rgba(108,99,255,0.30) 0%, transparent 65%),
    radial-gradient(ellipse 55% 45% at 15% 75%, rgba(6,182,212,0.20) 0%, transparent 60%),
    radial-gradient(ellipse 45% 40% at 88% 80%, rgba(236,72,153,0.14) 0%, transparent 55%),
    radial-gradient(ellipse 60% 55% at 45% 5%, rgba(79,70,229,0.15) 0%, transparent 60%),
    #07090F;
}

/* Canvas for interactive orbs */
.saas-canvas {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none; z-index: 1;
}
/* Cursor glow */
.cursor-glow-ring {
  position: absolute;
  width: 480px; height: 480px; border-radius: 50%;
  background: radial-gradient(circle closest-side, rgba(108,99,255,0.18) 0%, rgba(79,70,229,0.08) 45%, transparent 70%);
  pointer-events: none; z-index: 2;
  transform: translate(-50%, -50%);
  left: 50%; top: 50%;
  transition: opacity 0.4s ease; opacity: 0;
}

.hero .container { position: relative; z-index: 10; }

.hero-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center;
}

/* Badge */
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(108,99,255,0.1);
  border: 1px solid rgba(108,99,255,0.25);
  color: #C4C0FF;
  font-size: 0.8rem; font-weight: 600;
  padding: 7px 18px; border-radius: 50px;
  margin-bottom: 28px;
}
.badge-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--clr-secondary);
  box-shadow: 0 0 8px var(--clr-secondary);
  animation: blink 2s infinite;
}
@keyframes blink { 0%,100% { opacity:1; transform:scale(1); } 50% { opacity:0.5; transform:scale(1.4); } }

.hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 3.8rem);
  font-weight: 800; line-height: 1.08;
  color: var(--clr-text);
  margin-bottom: 24px;
  letter-spacing: -0.03em;
}
.line-gradient {
  background: var(--grad-primary);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  display: block; padding: 4px 0;
}
.hero-subtitle {
  font-size: 1.1rem; color: var(--clr-text-muted);
  line-height: 1.75; max-width: 480px; margin-bottom: 40px;
}
.hero-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 14px; margin-bottom: 52px; }

/* Trust bar */
.hero-trust {
  display: flex; align-items: stretch; gap: 0;
  padding: 18px 24px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  width: fit-content;
}
.trust-item {
  display: flex; flex-direction: column; gap: 4px;
  padding: 0 24px;
  border-right: 1px solid var(--clr-border);
}
.trust-item:first-child { padding-left: 0; }
.trust-item:last-child { border-right: none; }
.trust-icon { width: 16px; height: 16px; stroke: var(--clr-secondary); margin-bottom: 2px; }
.trust-num { font-family: var(--font-display); font-size: 1.35rem; font-weight: 800; color: var(--clr-text); line-height: 1; }
.trust-label { font-size: 0.73rem; color: var(--clr-text-muted); }

/* Hero right card */
.hero-visual { position: relative; display: flex; align-items: center; justify-content: center; }
.hero-card-main {
  background: rgba(13,15,26,0.85);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-lg);
  padding: 28px;
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  box-shadow: var(--shadow-card);
  width: 340px; position: relative; z-index: 2;
}
.card-chart-label { font-size: 0.75rem; font-weight: 600; color: var(--clr-text-muted); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 6px; }
.card-chart-value { font-family: var(--font-display); font-size: 1.75rem; font-weight: 800; color: var(--clr-text); margin-bottom: 20px; }
.card-chart-value span { font-size: 0.9rem; color: var(--clr-success); font-weight: 600; margin-left: 6px; }
.mini-chart { display: flex; align-items: flex-end; gap: 5px; height: 72px; margin-bottom: 18px; }
.bar { flex: 1; border-radius: 4px 4px 0 0; background: var(--grad-primary); opacity: 0.8; }
.card-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; border-top: 1px solid var(--clr-border); padding-top: 16px; }
.metric { display: flex; flex-direction: column; gap: 2px; }
.metric-label { font-size: 0.7rem; color: var(--clr-text-sub); text-transform: uppercase; letter-spacing: 0.06em; }
.metric-value { font-size: 1rem; font-weight: 700; color: var(--clr-text); }
.metric-value.cyan { color: var(--clr-secondary); }
.metric-value.up { color: var(--clr-success); }

/* Float badges */
.float-badge {
  position: absolute;
  background: rgba(13,15,26,0.9);
  border: 1px solid var(--clr-border);
  border-radius: 40px; padding: 9px 16px;
  font-size: 0.82rem; font-weight: 600; color: var(--clr-text);
  display: flex; align-items: center; gap: 8px;
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-card); white-space: nowrap;
}
.float-badge-1 { top: -8px; left: -28px; animation: floatBadge 4s ease-in-out infinite; }
.float-badge-2 { bottom: 20px; right: -36px; animation: floatBadge 5s ease-in-out infinite reverse; }
.float-icon svg { stroke: var(--clr-secondary); }
@keyframes floatBadge { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-10px); } }

/* Old canvas particles (kept in case script.js uses it) */
#particles-canvas { display: none; }

/* ============================================
   MEET THE FOUNDER
   ============================================ */
.founder-section{padding:7rem 5%;background:var(--clr-bg2);border-top:1px solid var(--clr-border);border-bottom:1px solid var(--clr-border);}
.founder-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:380px 1fr;gap:5rem;align-items:center;}
@media(max-width:900px){.founder-inner{grid-template-columns:1fr;gap:3rem;text-align:center;}}
.founder-photo-frame{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--clr-border2);box-shadow:var(--shadow-lg);}
.founder-photo-frame img{width:100%;display:block;object-fit:cover;object-position:top center;aspect-ratio:4/5;filter:none;transition:none;}
.founder-photo-badge{position:absolute;bottom:20px;left:20px;background:rgba(7,9,15,0.88);backdrop-filter:blur(12px);border:1px solid var(--clr-border2);border-radius:10px;padding:10px 16px;}
.founder-photo-badge .badge-name{font-size:0.875rem;font-weight:500;color:var(--clr-text);}
.founder-photo-badge .badge-role{font-size:0.75rem;color:var(--clr-text-muted);}
.founder-content{display:flex;flex-direction:column;gap:1.5rem;}
.founder-eyebrow{font-size:0.7rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--clr-primary);}
.founder-name{font-family:var(--font-display);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:700;letter-spacing:-0.03em;color:var(--clr-text);line-height:1.1;}
.founder-name span{color:var(--clr-primary);}
.founder-tagline{font-size:1rem;color:var(--clr-text-muted);line-height:1.7;max-width:480px;}
.founder-desc{font-size:0.95rem;color:var(--clr-text-sub);line-height:1.8;max-width:480px;}
.founder-desc strong{color:var(--clr-text);font-weight:500;}
.founder-pills{display:flex;flex-wrap:wrap;gap:10px;}
@media(max-width:900px){.founder-pills{justify-content:center;}.founder-tagline,.founder-desc{max-width:100%;}}
.founder-pill{font-size:0.78rem;font-weight:500;padding:7px 16px;border-radius:40px;border:1px solid var(--clr-border2);background:var(--clr-surface);color:var(--clr-text);white-space:nowrap;}
.founder-cta{display:inline-flex;align-items:center;gap:8px;padding:0.9rem 2rem;background:var(--grad-primary);border:none;border-radius:var(--radius-sm);color:#fff;font-family:var(--font-main);font-weight:600;font-size:1rem;text-decoration:none;width:fit-content;transition:var(--transition);box-shadow:var(--shadow-glow);}
.founder-cta:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(108,99,255,0.6);}
.founder-cta svg{width:16px;height:16px;transition:transform 0.2s;}
.founder-cta:hover svg{transform:translateX(3px);}

/* ============================================
   CLIENTS MARQUEE
   ============================================ */
.clients-section {
  padding: 36px 0;
  background: var(--clr-bg2);
  border-top: 1px solid var(--clr-border);
  border-bottom: 1px solid var(--clr-border);
  overflow: hidden;
}
.clients-label {
  text-align: center;
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--clr-text-sub);
  margin-bottom: 24px;
}
.marquee-track { display: flex; gap: 36px; animation: marquee 26s linear infinite; width: max-content; }
@keyframes marquee { 0% { transform:translateX(0); } 100% { transform:translateX(-50%); } }
.client-logo {
  display: flex; align-items: center; gap: 9px;
  font-size: 0.88rem; font-weight: 600; color: var(--clr-text-sub);
  white-space: nowrap; padding: 9px 22px;
  border: 1px solid var(--clr-border); border-radius: 40px;
  transition: var(--transition);
}
.client-logo:hover { color: var(--clr-text); border-color: var(--clr-border2); }
.cl-icon { stroke: var(--clr-text-sub); flex-shrink: 0; }

/* ============================================
   SERVICES
   ============================================ */
.services {
  padding: 120px 0;
  background: var(--clr-bg);
  border-bottom: 1px solid var(--clr-border);
}
.services-header {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 48px; margin-bottom: 56px; flex-wrap: wrap;
}
.services-grid { 
  display: grid; 
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); 
  gap: 20px; 
  align-items: start; /* CRITICAL: Prevents other cards from stretching when one is opened */
}

/* Lottie Wrappers */
.card-lottie-wrapper {
  width: 100%; height: 180px;
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(circle at center, rgba(108,99,255,0.04) 0%, transparent 60%);
  border-radius: var(--radius);
  margin-bottom: 24px;
}

.service-card {
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  cursor: pointer; transition: var(--transition);
  position: relative; overflow: hidden;
}
.service-card::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 2px; background: var(--grad-primary);
  opacity: 0; transition: opacity 0.3s;
}
.service-card:hover { border-color: rgba(108,99,255,0.3); background: rgba(108,99,255,0.05); transform: translateY(-4px); box-shadow: var(--shadow-card); }
.service-card:hover::after { opacity: 1; }

.card-header { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; }
.accordion-icon {
  width: 42px; height: 42px;
  background: rgba(108,99,255,0.12); border: 1px solid rgba(108,99,255,0.2);
  border-radius: 12px; display: flex; align-items: center; justify-content: center;
  color: var(--clr-primary); flex-shrink: 0; transition: var(--transition);
}
.service-card:hover .accordion-icon { background: var(--clr-primary); color: #fff; }
.accordion-title { font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; color: var(--clr-text); }
.service-hook { font-size: 0.88rem; color: var(--clr-text-muted); line-height: 1.6; margin-bottom: 14px; }
.card-lottie-wrapper { border-radius: var(--radius); overflow: hidden; background: rgba(255,255,255,0.02); margin-bottom: 14px; }
.service-best-for {
  font-size: 0.75rem; font-weight: 600; color: var(--clr-text-sub);
  background: rgba(108,99,255,0.07); border: 1px solid rgba(108,99,255,0.12);
  border-radius: 6px; padding: 5px 10px; margin-bottom: 18px; display: inline-block;
}
/* Premium Explore CTA */
.btn-explore-cta {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 24px; font-weight: 600; cursor: pointer;
  background: linear-gradient(90deg, rgba(108,99,255,0.1) 0%, rgba(6,182,212,0.05) 100%);
  border: 1px solid rgba(108,99,255,0.25);
  border-radius: var(--radius-sm);
  color: #fff; margin-top: 12px;
  transition: all 0.4s var(--ease);
  box-shadow: 0 4px 14px rgba(108,99,255,0.0);
}
.btn-explore-cta:hover { 
  background: linear-gradient(90deg, rgba(108,99,255,0.2) 0%, rgba(6,182,212,0.15) 100%);
  border-color: rgba(108,99,255,0.5);
  transform: scale(1.02);
  box-shadow: 0 8px 24px rgba(108,99,255,0.25);
}
.btn-explore-cta .accordion-arrow { 
  transition: transform 0.4s var(--ease);
  animation: bounce-right 1.5s infinite;
  display: inline-block;
}
@keyframes bounce-right {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(5px); }
}
/* Stop bouncing and rotate 90deg (down) when open */
.service-card[aria-expanded="true"] .btn-explore-cta .accordion-arrow {
  animation: none;
  transform: rotate(90deg);
}

.accordion-body { max-height: 0; overflow: hidden; transition: max-height 0.45s ease, padding-top 0.3s ease; }
.service-card[aria-expanded="true"] .accordion-body { max-height: 800px; padding-top: 24px; }

/* Improved Dropdown List Layout */
.accordion-list.improved-list {
  list-style: none; padding: 0; margin: 0 0 24px 0;
  display: flex; flex-direction: column; gap: 18px;
}
.improved-list li {
  display: flex; flex-direction: column; align-items: flex-start; gap: 6px;
}
.improved-list .acc-title {
  font-weight: 700; color: #EEF2FF; display: flex; align-items: center; gap: 10px; font-size: 1.05rem;
}
.improved-list .acc-bullet {
  color: var(--clr-primary); font-size: 1.3rem; line-height: 1; margin-top: -2px;
}
.improved-list .service-detail-text {
  padding-left: 20px; font-size: 0.95rem; color: var(--clr-text-muted);
  font-weight: 400; line-height: 1.6;
}
.btn-service-start {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 18px; padding: 10px 20px;
  background: var(--grad-primary); color: #fff;
  font-size: 0.86rem; font-weight: 600; border-radius: 50px;
  transition: var(--transition); box-shadow: var(--shadow-glow);
}
.btn-service-start:hover { transform: translateY(-2px); box-shadow: 0 10px 30px rgba(108,99,255,0.5); }

/* ============================================
   STATS
   ============================================ */
.stats {
  padding: 80px 0;
  background: var(--clr-bg2);
  border-bottom: 1px solid var(--clr-border);
}
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat-item { text-align: center; padding: 24px 20px; border-right: 1px solid var(--clr-border); }
.stat-item:last-child { border-right: none; }
.stat-num {
  font-family: var(--font-display); font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 800; line-height: 1;
  background: var(--grad-primary);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; margin-bottom: 8px;
}
.stat-label { font-size: 0.88rem; color: var(--clr-text-muted); font-weight: 500; }

/* ============================================
   PROCESS
   ============================================ */
.process { padding: 120px 0; background: var(--clr-bg); border-bottom: 1px solid var(--clr-border); }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 64px; }
.process-step {
  background: var(--clr-surface); border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg); padding: 28px 22px; text-align: center;
  transition: var(--transition);
}
.process-step:hover { border-color: rgba(108,99,255,0.3); background: rgba(108,99,255,0.06); transform: translateY(-6px); box-shadow: var(--shadow-card); }
.step-num {
  font-family: var(--font-display); font-size: 2.6rem; font-weight: 800; line-height: 1;
  background: var(--grad-primary); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  margin-bottom: 8px;
}
.step-icon { font-size: 2rem; margin-bottom: 14px; }
.step-title { font-family: var(--font-display); font-size: 1rem; font-weight: 700; color: var(--clr-text); margin-bottom: 10px; }
.step-desc { font-size: 0.85rem; color: var(--clr-text-muted); line-height: 1.6; }

/* ============================================
   PORTFOLIO
   ============================================ */
.portfolio { padding: 120px 0; background: var(--clr-bg2); border-bottom: 1px solid var(--clr-border); }
.portfolio-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 36px; flex-wrap: wrap; gap: 16px; }
.portfolio-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 36px; }
.filter-btn {
  padding: 7px 18px; border-radius: 50px;
  font-size: 0.83rem; font-weight: 600;
  background: var(--clr-surface); border: 1px solid var(--clr-border);
  color: var(--clr-text-muted); transition: var(--transition);
}
.filter-btn:hover, .filter-btn.active { background: var(--clr-primary); border-color: var(--clr-primary); color: #fff; box-shadow: 0 4px 16px rgba(108,99,255,0.4); }
.portfolio-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.portfolio-card { background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: var(--radius-lg); overflow: hidden; transition: var(--transition); }
.portfolio-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); border-color: rgba(108,99,255,0.2); }
.portfolio-thumb { position: relative; overflow: hidden; aspect-ratio: 16/10; }
.portfolio-thumb-bg { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; font-size: 3.5rem; transition: transform 0.5s ease; }
.portfolio-card:hover .portfolio-thumb-bg { transform: scale(1.06); }
.bg-1 { background: linear-gradient(135deg, #1a0533, rgba(108,99,255,0.2)); }
.bg-2 { background: linear-gradient(135deg, #001a33, rgba(6,182,212,0.2)); }
.bg-3 { background: linear-gradient(135deg, #001a0d, rgba(16,185,129,0.2)); }
.bg-4 { background: linear-gradient(135deg, #330a00, rgba(249,115,22,0.2)); }
.bg-5 { background: linear-gradient(135deg, #1a1a00, rgba(234,179,8,0.2)); }
.bg-6 { background: linear-gradient(135deg, #00001a, rgba(139,92,246,0.2)); }
.portfolio-overlay {
  position: absolute; inset: 0; background: rgba(7,9,15,0.75);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.3s; backdrop-filter: blur(4px);
}
.portfolio-card:hover .portfolio-overlay { opacity: 1; }
.portfolio-body { padding: 18px; }
.portfolio-tag { font-size: 0.7rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #A5A0FF; margin-bottom: 6px; }
.portfolio-title { font-family: var(--font-display); font-size: 0.98rem; font-weight: 700; color: var(--clr-text); margin-bottom: 6px; }
.portfolio-result { font-size: 0.84rem; color: var(--clr-text-muted); }
.portfolio-result strong { color: var(--clr-success); }

/* ============================================
   TESTIMONIALS
   ============================================ */
.testimonials { padding: 120px 0; background: var(--clr-bg); border-bottom: 1px solid var(--clr-border); }
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 60px; }
.testimonial-card {
  background: var(--clr-surface); border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg); padding: 28px; transition: var(--transition);
}
.testimonial-card:hover { border-color: rgba(108,99,255,0.25); transform: translateY(-4px); box-shadow: var(--shadow-card); }
.testi-stars { color: #FFC837; font-size: 0.88rem; letter-spacing: 2px; margin-bottom: 14px; }
.testi-quote { font-size: 3.5rem; line-height: 0.6; background: var(--grad-primary); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; margin-bottom: 14px; font-family: serif; }
.testi-text { font-size: 0.9rem; color: var(--clr-text-muted); line-height: 1.7; margin-bottom: 22px; }
.testi-author { display: flex; align-items: center; gap: 12px; border-top: 1px solid var(--clr-border); padding-top: 18px; }
.testi-avatar { width: 42px; height: 42px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.78rem; font-weight: 700; flex-shrink: 0; }
.av-1 { background: linear-gradient(135deg, #6C63FF, #EC4899); color: #fff; }
.av-2 { background: linear-gradient(135deg, #06B6D4, #6C63FF); color: #fff; }
.av-3 { background: linear-gradient(135deg, #10B981, #06B6D4); color: #fff; }
.av-4 { background: linear-gradient(135deg, #F97316, #EC4899); color: #fff; }
.av-5 { background: linear-gradient(135deg, #8B5CF6, #6C63FF); color: #fff; }
.av-6 { background: linear-gradient(135deg, #EAB308, #F97316); color: #fff; }
.testi-name { font-size: 0.88rem; font-weight: 700; color: var(--clr-text); }
.testi-role { font-size: 0.76rem; color: var(--clr-text-sub); }

/* ============================================
   PRICING
   ============================================ */
.pricing { padding: 120px 0; background: var(--clr-bg2); border-bottom: 1px solid var(--clr-border); }
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 60px; align-items: start; }
.pricing-card { background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: var(--radius-xl); padding: 32px 28px; transition: var(--transition); position: relative; }
.pricing-card:hover { transform: translateY(-5px); border-color: rgba(108,99,255,0.25); box-shadow: var(--shadow-card); }
.pricing-card.popular {
  background: linear-gradient(135deg, rgba(108,99,255,0.1), rgba(6,182,212,0.05));
  border-color: rgba(108,99,255,0.4);
  box-shadow: 0 0 40px rgba(108,99,255,0.15);
  transform: scale(1.03);
}
.pricing-card.popular:hover { transform: scale(1.03) translateY(-4px); }
.popular-badge {
  position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
  background: var(--grad-primary); color: #fff;
  font-size: 0.7rem; font-weight: 700;
  padding: 4px 16px; border-radius: 50px;
  white-space: nowrap; box-shadow: var(--shadow-glow);
}
.plan-name { font-family: var(--font-display); font-size: 0.85rem; font-weight: 700; color: var(--clr-text-muted); margin-bottom: 10px; text-transform: uppercase; letter-spacing: 0.06em; }
.pricing-card.popular .plan-name { color: #A5A0FF; }
.plan-price { font-family: var(--font-display); font-size: 2.2rem; font-weight: 800; color: var(--clr-text); margin-bottom: 10px; line-height: 1; }
.plan-price span { font-size: 0.95rem; font-weight: 400; color: var(--clr-text-sub); }
.plan-desc { font-size: 0.86rem; color: var(--clr-text-muted); line-height: 1.6; margin-bottom: 24px; }
.plan-features { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.plan-feature { display: flex; align-items: center; gap: 10px; font-size: 0.86rem; color: var(--clr-text-muted); }
.feat-icon { width: 18px; height: 18px; border-radius: 50%; background: rgba(16,185,129,0.15); color: var(--clr-success); display: flex; align-items: center; justify-content: center; font-size: 0.65rem; font-weight: 700; flex-shrink: 0; }
.feat-icon.no { background: rgba(239,68,68,0.1); color: #EF4444; }

/* ============================================
   CTA SECTION
   ============================================ */
.cta-section { padding: 80px 0; background: var(--clr-bg); }
.cta-box {
  background: linear-gradient(135deg, rgba(108,99,255,0.1), rgba(6,182,212,0.05));
  border: 1px solid rgba(108,99,255,0.2);
  border-radius: var(--radius-xl);
  padding: 72px 60px; text-align: center;
  position: relative; overflow: hidden;
}
.cta-box::before {
  content: '';
  position: absolute; top: 0; left: 50%; transform: translateX(-50%);
  width: 70%; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(108,99,255,0.5), transparent);
}
.cta-actions { display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 14px; margin-top: 32px; }

/* ============================================
   CONTACT
   ============================================ */
.contact { padding: 120px 0; background: var(--clr-bg2); border-top: 1px solid var(--clr-border); }
.contact-inner { display: grid; grid-template-columns: 1fr 1.4fr; gap: 72px; align-items: start; }
.contact-methods { display: flex; flex-direction: column; gap: 16px; margin-top: 36px; }
.contact-method {
  display: flex; align-items: flex-start; gap: 16px; padding: 18px;
  background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: var(--radius);
  transition: var(--transition);
}
.contact-method:hover { border-color: rgba(108,99,255,0.3); background: rgba(108,99,255,0.06); }
.cm-icon { font-size: 1.3rem; }
.cm-label { font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--clr-text-sub); margin-bottom: 3px; }
.cm-value { font-size: 0.92rem; font-weight: 600; color: var(--clr-text); }

.contact-form { background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: var(--radius-xl); padding: 36px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.form-group { display: flex; flex-direction: column; gap: 7px; margin-bottom: 14px; }
.form-group label { font-size: 0.8rem; font-weight: 600; color: var(--clr-text-muted); }
.form-group input,
.form-group select,
.form-group textarea {
  background: rgba(255,255,255,0.03); border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm); padding: 11px 14px;
  font-size: 0.9rem; color: var(--clr-text); font-family: var(--font-main);
  transition: var(--transition); outline: none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--clr-primary); box-shadow: 0 0 0 3px rgba(108,99,255,0.15);
  background: rgba(108,99,255,0.04);
}
.form-group input::placeholder, .form-group textarea::placeholder { color: var(--clr-text-sub); }
.form-group textarea { resize: vertical; min-height: 110px; }
.form-group select { cursor: pointer; }
.form-group select option { background: #0C0F1A; color: var(--clr-text); }

/* ============================================
   FOOTER
   ============================================ */
.footer { background: #050710; border-top: 1px solid var(--clr-border); padding: 72px 0 0; }
.footer-inner { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 48px; border-bottom: 1px solid var(--clr-border); }
.footer-brand p { font-size: 0.86rem; color: var(--clr-text-sub); line-height: 1.7; max-width: 280px; margin: 18px 0 24px; }
.socials { display: flex; gap: 8px; }
.social-btn { width: 36px; height: 36px; background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 0.84rem; color: var(--clr-text-muted); transition: var(--transition); }
.social-btn:hover { background: var(--clr-primary); color: #fff; border-color: transparent; }
.footer-col h4 { font-family: var(--font-display); font-size: 0.88rem; font-weight: 700; color: var(--clr-text); margin-bottom: 18px; text-transform: uppercase; letter-spacing: 0.06em; }
.footer-col ul { display: flex; flex-direction: column; gap: 9px; }
.footer-col ul li a { font-size: 0.85rem; color: var(--clr-text-sub); transition: var(--transition); }
.footer-col ul li a:hover { color: var(--clr-text); padding-left: 3px; }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding: 22px 0; font-size: 0.8rem; color: var(--clr-text-sub); flex-wrap: wrap; gap: 8px; }
.footer-bottom a { color: var(--clr-primary); }

/* ============================================
   REVEAL ANIMATIONS — progressive enhancement
   Content is ALWAYS visible; animation is a bonus
   ============================================ */
.reveal { opacity: 1; transform: none; transition: opacity 0.65s var(--ease), transform 0.65s var(--ease); }
/* JS adds .visible via IntersectionObserver — but we start visible */
.js-reveal-ready .reveal { opacity: 0; transform: translateY(28px); }
.js-reveal-ready .reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.08s; }
.reveal-delay-2 { transition-delay: 0.16s; }
.reveal-delay-3 { transition-delay: 0.24s; }
.reveal-delay-4 { transition-delay: 0.32s; }


/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1024px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .stat-item { border-bottom: 1px solid var(--clr-border); }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .portfolio-grid { grid-template-columns: repeat(2, 1fr); }
  .testimonials-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-inner { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .services-header { flex-direction: column; align-items: flex-start; }
  .nav-links, .nav-cta { display: none; }
  .hamburger { display: flex; }
  .hero { padding: 130px 0 80px; }
  .hero-title { font-size: 2.3rem; }
  .hero-trust { flex-direction: column; width: 100%; }
  .trust-item { border-right: none; border-bottom: 1px solid var(--clr-border); padding: 12px 0; }
  .trust-item:last-child { border-bottom: none; }
  .portfolio-grid { grid-template-columns: 1fr; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .pricing-grid { grid-template-columns: 1fr; }
  .pricing-card.popular { transform: none; }
  .cta-box { padding: 48px 24px; }
  .footer-inner { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .cursor-glow-ring { display: none; }
  .services-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .hero-actions { flex-direction: column; }
  .btn-lg { width: 100%; justify-content: center; }
  .process-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr; }
  .stat-item { border-right: none; }
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .badge-dot, .floatBadge, .blink,
  .marquee-track { animation: none !important; }
  .hero { animation: none !important; }
  .accordion-body { transition: none !important; }
}

/* LATEST BLOG SECTION - USER PROVIDED */
.latest-blog-section{padding:6rem 5%;border-top:1px solid rgba(255,255,255,0.06);}
.lb-container{max-width:1200px;margin:0 auto;}
.lb-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2.5rem;flex-wrap:wrap;gap:1rem;}
.lb-eyebrow{font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--clr-primary);margin-bottom:0.5rem;font-weight:500;}
.lb-header h2{font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:700;letter-spacing:-0.03em;color:var(--clr-text);margin-bottom:0.3rem;line-height:1.15;}
.lb-header p{font-size:0.9rem;color:var(--clr-text-muted);}
.lb-view-all{display:inline-flex;align-items:center;gap:6px;font-size:0.85rem;font-weight:500;color:var(--clr-primary);text-decoration:none;border:1px solid rgba(108,99,255,0.4);padding:0.6rem 1.2rem;border-radius:8px;transition:background 0.2s,border-color 0.2s;white-space:nowrap;}
.lb-view-all:hover{background:rgba(108,99,255,0.1);border-color:rgba(108,99,255,0.5);}
.lb-view-all svg{width:14px;height:14px;transition:transform 0.2s;}
.lb-view-all:hover svg{transform:translateX(3px);}
.lb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;}
@media(max-width:900px){.lb-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:580px){.lb-grid{grid-template-columns:1fr;}}
.lb-card{background:var(--clr-surface);border:1px solid rgba(255,255,255,0.07);border-radius:14px;overflow:hidden;text-decoration:none;display:flex;flex-direction:column;transition:transform 0.22s,border-color 0.22s,box-shadow 0.22s;cursor:pointer;}
.lb-card:hover{transform:translateY(-4px);border-color:rgba(108,99,255,0.4);box-shadow:0 16px 48px rgba(0,0,0,0.3);}
.lb-card-img{width:100%;aspect-ratio:16/9;background:var(--clr-bg);position:relative;overflow:hidden;flex-shrink:0;}
.lb-card-img img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;inset:0;transition:transform 0.4s ease;}
.lb-card:hover .lb-card-img img{transform:scale(1.04);}
.lb-card-img-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--clr-bg),var(--clr-surface));}
.lb-card-img-placeholder svg{width:24px;height:24px;stroke:rgba(108,99,255,0.3);fill:none;stroke-width:1.5;}
.lb-card-img-placeholder span{font-size:0.62rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(108,99,255,0.4);font-weight:500;}
.lb-cat-pill{position:absolute;bottom:10px;left:10px;font-size:0.65rem;letter-spacing:0.1em;text-transform:uppercase;font-weight:600;padding:3px 10px;border-radius:40px;background:var(--clr-bg);backdrop-filter:blur(8px);color:var(--clr-primary);border:1px solid rgba(108,99,255,0.2);}
.lb-card-body{padding:1.1rem 1.2rem 1.2rem;display:flex;flex-direction:column;flex:1;}
.lb-card-title{font-size:0.95rem;font-weight:600;color:var(--clr-text);line-height:1.35;margin-bottom:0.5rem;letter-spacing:-0.01em;}
.lb-card-excerpt{font-size:0.82rem;color:var(--clr-text-muted);line-height:1.65;margin-bottom:0.9rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1;}
.lb-card-meta{display:flex;align-items:center;justify-content:space-between;font-size:0.75rem;color:var(--clr-text-muted);border-top:1px solid rgba(255,255,255,0.06);padding-top:0.75rem;margin-top:auto;}
.lb-card-read{font-size:0.78rem;font-weight:500;color:var(--clr-primary);display:flex;align-items:center;gap:4px;}
.lb-card-read svg{width:12px;height:12px;transition:transform 0.2s;}
.lb-card:hover .lb-card-read svg{transform:translateX(2px);}

/* ============================================
   FOUNDER SECTION — MOBILE RESPONSIVE
   ============================================ */
@media (max-width: 768px) {
  .founder-section {
    overflow-x: hidden !important;
    padding: 3rem 1.25rem !important;
  }
  .founder-inner {
    flex-direction: column !important;
    gap: 0 !important;
    align-items: center !important;
  }
  .founder-photo-col {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    margin-bottom: 2rem !important;
  }
  .founder-photo-frame {
    max-width: 280px !important;
    width: 100% !important;
    margin: 0 auto !important;
  }
  .founder-photo-frame img {
    width: 100% !important;
    height: auto !important;
  }
  .founder-photo-badge {
    right: auto !important;
    bottom: -12px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    white-space: nowrap !important;
    z-index: 10 !important;
  }
  .founder-content {
    width: 100% !important;
    text-align: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
  }
  .founder-eyebrow,
  .founder-name,
  .founder-tagline,
  .founder-desc {
    text-align: center !important;
    width: 100% !important;
  }
  .founder-pills {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 8px !important;
    width: 100% !important;
  }
  .founder-cta {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-width: 80% !important;
    width: 80% !important;
    margin: 0 auto !important;
    text-align: center !important;
    min-height: 48px !important;
  }
}
