/* ============================================================
   Dastrix.ai — Shared Stylesheet
   ============================================================ */

/* ── Tokens ── */
:root {
  --bg-0:    #020510;
  --bg-1:    #070d20;
  --bg-card: rgba(10, 18, 40, 0.85);
  --border:  rgba(99, 130, 255, 0.18);
  --border-bright: rgba(99, 130, 255, 0.4);
  --cyan:    #22d3ee;
  --blue:    #6366f1;
  --violet:  #a855f7;
  --orange:  #f97316;
  --green:   #22c55e;
  --red:     #ef4444;
  --text:    #e2e8f0;
  --muted:   #94a3b8;
  --subtle:  #475569;
  --heading: #ffffff;
  --radius:  18px;
  --nav-bg:  rgba(2, 5, 16, 0.82);
  --glow-blue: 0 0 60px rgba(99, 102, 241, 0.25);
  --glow-cyan: 0 0 60px rgba(34, 211, 238, 0.2);
  --tag-bg:  rgba(99, 102, 241, 0.1);
  --tag-border: rgba(99, 102, 241, 0.25);
  --tag-text: #a5b4fc;
  --input-bg: rgba(7, 13, 32, 0.8);
  --footer-bg: transparent;
}

[data-theme="light"] {
  --bg-0:    #f0f4ff;
  --bg-1:    #e4ecff;
  --bg-card: rgba(255, 255, 255, 0.92);
  --border:  rgba(99, 102, 241, 0.15);
  --border-bright: rgba(99, 102, 241, 0.35);
  --text:    #1e293b;
  --muted:   #475569;
  --subtle:  #94a3b8;
  --heading: #0f172a;
  --nav-bg:  rgba(240, 244, 255, 0.92);
  --glow-blue: 0 4px 32px rgba(99, 102, 241, 0.12);
  --glow-cyan: 0 4px 32px rgba(34, 211, 238, 0.1);
  --tag-bg:  rgba(99, 102, 241, 0.08);
  --tag-border: rgba(99, 102, 241, 0.2);
  --tag-text: #4f46e5;
  --input-bg: rgba(241, 245, 249, 0.9);
}

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

body {
  font-family: 'Inter', system-ui, sans-serif;
  background-color: var(--bg-0);
  background-image:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(99,102,241,0.22) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 90%, rgba(34,211,238,0.10) 0%, transparent 55%);
  color: var(--text);
  line-height: 1.65;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  transition: background-color 0.3s ease, color 0.3s ease;
}

[data-theme="light"] body {
  background-image:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(99,102,241,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 90%, rgba(34,211,238,0.05) 0%, transparent 55%);
}

body::before {
  content: "";
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none; z-index: 0; opacity: 0.5;
  transition: opacity 0.3s;
}
[data-theme="light"] body::before { opacity: 0.15; }

.page { position: relative; z-index: 1; max-width: 1160px; margin: 0 auto; padding: 0 24px; }

/* ── Nav ── */
nav {
  position: sticky; top: 0; z-index: 100;
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  background: var(--nav-bg);
  border-bottom: 1px solid var(--border);
  transition: background 0.3s ease;
}
.nav-inner {
  max-width: 1160px; margin: 0 auto; padding: 0 24px;
  display: flex; align-items: center; justify-content: space-between;
  height: 64px; gap: 16px;
}
.logo { display: flex; align-items: center; gap: 10px; text-decoration: none; flex-shrink: 0; }
.logo-mark {
  width: 34px; height: 34px; border-radius: 10px;
  background: linear-gradient(135deg, var(--cyan), var(--blue));
  box-shadow: 0 0 20px rgba(99,102,241,0.55);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 14px; color: #fff; letter-spacing: -0.5px;
}
.logo-text { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 18px; color: var(--text); letter-spacing: -0.3px; }
.logo-text span { color: var(--cyan); }

.nav-links { display: flex; gap: 4px; list-style: none; align-items: center; }
.nav-links a {
  color: var(--muted); text-decoration: none; font-size: 13px; font-weight: 500;
  padding: 6px 10px; border-radius: 8px; transition: color 0.15s, background 0.15s;
  white-space: nowrap;
}
.nav-links a:hover { color: var(--text); background: rgba(99,102,241,0.08); }
.nav-links a.active { color: var(--cyan); }

.nav-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

/* Theme toggle */
.theme-toggle {
  width: 36px; height: 36px; border-radius: 10px;
  background: var(--bg-card); border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.2s; color: var(--muted);
  flex-shrink: 0;
}
.theme-toggle:hover { border-color: var(--border-bright); color: var(--text); }
.theme-toggle svg { width: 16px; height: 16px; }
.icon-sun { display: none; }
.icon-moon { display: block; }
[data-theme="light"] .icon-sun { display: block; }
[data-theme="light"] .icon-moon { display: none; }

.nav-cta {
  background: linear-gradient(120deg, var(--cyan), var(--blue));
  color: #030816 !important; padding: 7px 16px; border-radius: 999px;
  font-weight: 600 !important; font-size: 13px !important;
  text-decoration: none; transition: opacity 0.15s, transform 0.15s;
  white-space: nowrap;
}
.nav-cta:hover { opacity: 0.88; transform: translateY(-1px); background: none !important; background: linear-gradient(120deg, var(--cyan), var(--blue)) !important; }

/* Hamburger */
.nav-hamburger {
  display: none; flex-direction: column; gap: 5px; cursor: pointer;
  padding: 8px; background: none; border: none; color: var(--muted);
}
.nav-hamburger span { display: block; width: 20px; height: 2px; background: currentColor; border-radius: 2px; transition: all 0.2s; }

/* Mobile menu */
.mobile-menu {
  display: none; position: fixed; top: 64px; left: 0; right: 0; bottom: 0;
  background: var(--bg-0); z-index: 99; padding: 24px;
  flex-direction: column; gap: 8px; border-top: 1px solid var(--border);
  overflow-y: auto;
}
.mobile-menu.open { display: flex; }
.mobile-menu a {
  color: var(--muted); text-decoration: none; font-size: 16px; font-weight: 500;
  padding: 14px 16px; border-radius: 12px; transition: all 0.15s; border: 1px solid transparent;
}
.mobile-menu a:hover { color: var(--text); background: rgba(99,102,241,0.08); border-color: var(--border); }
.mobile-menu .mob-cta {
  margin-top: 8px; background: linear-gradient(120deg, var(--cyan), var(--blue));
  color: #030816 !important; text-align: center; font-weight: 700;
}

/* ── Hero ── */
.hero {
  padding: 100px 0 80px;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 56px; align-items: center;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 12px;
  background: rgba(34,211,238,0.08); border: 1px solid rgba(34,211,238,0.28);
  border-radius: 999px; font-size: 11px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--cyan); margin-bottom: 20px;
}
.hero-eyebrow-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 8px rgba(34,197,94,0.9);
  animation: pulse 2s infinite;
}
@keyframes pulse { 0%,100%{opacity:1}50%{opacity:0.4} }

.hero-title {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(34px, 5.5vw, 52px); font-weight: 700;
  line-height: 1.06; letter-spacing: -1.2px; margin-bottom: 20px; color: var(--heading);
}
.gradient-text {
  background: linear-gradient(110deg, var(--cyan) 0%, var(--blue) 50%, var(--violet) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-desc { font-size: 15.5px; color: var(--muted); max-width: 460px; margin-bottom: 32px; line-height: 1.72; }
.hero-desc strong { color: var(--text); }
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; margin-bottom: 44px; }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 11px 22px; border-radius: 999px; font-size: 14px; font-weight: 600;
  text-decoration: none; transition: all 0.18s ease; cursor: pointer; border: none;
}
.btn-primary { background: linear-gradient(120deg, var(--cyan), var(--blue)); color: #030816; box-shadow: 0 8px 32px rgba(99,102,241,0.42); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 14px 40px rgba(99,102,241,0.6); }
.btn-outline { background: transparent; color: var(--muted); border: 1px solid var(--border-bright); }
.btn-outline:hover { color: var(--text); border-color: rgba(99,130,255,0.65); background: rgba(99,130,255,0.06); }
.btn-sm { padding: 8px 16px; font-size: 13px; }

/* ── Hero stats ── */
.hero-stats { display: flex; gap: 32px; flex-wrap: wrap; }
.stat-item { display: flex; flex-direction: column; gap: 2px; }
.stat-value { font-family: 'Space Grotesk', sans-serif; font-size: 24px; font-weight: 700; color: var(--heading); }
.stat-value span { color: var(--cyan); }
.stat-label { font-size: 12px; color: var(--muted); }

/* ── Hero card ── */
.hero-card {
  background: var(--bg-card); border: 1px solid var(--border-bright);
  border-radius: 24px; padding: 24px;
  box-shadow: var(--glow-blue); backdrop-filter: blur(12px);
}
.hero-card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.hero-card-title { font-size: 13px; font-weight: 600; color: var(--muted); }
.status-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; background: rgba(34,197,94,0.1);
  border: 1px solid rgba(34,197,94,0.32); border-radius: 999px;
  font-size: 11px; color: var(--green); font-weight: 600;
}
.status-pill::before { content:""; width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px rgba(34,197,94,0.9); }
.pipeline-steps { display: grid; gap: 10px; }
.pipeline-step {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 14px;
  background: rgba(7,13,32,0.8); border: 1px solid var(--border);
  transition: border-color 0.2s;
}
[data-theme="light"] .pipeline-step { background: rgba(241,245,249,0.8); }
.pipeline-step:hover { border-color: var(--border-bright); }
.step-icon { width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.step-icon.blue   { background: rgba(99,102,241,0.18); }
.step-icon.cyan   { background: rgba(34,211,238,0.14); }
.step-icon.violet { background: rgba(168,85,247,0.16); }
.step-icon.orange { background: rgba(249,115,22,0.16); }
.step-icon svg { width:16px;height:16px; }
.step-info { flex:1; min-width:0; }
.step-name { font-size:12.5px;font-weight:600;color:var(--text); }
.step-sub  { font-size:11px;color:var(--muted); }
.step-badge { font-size:10px;font-weight:600;padding:3px 8px;border-radius:999px;white-space:nowrap; }
.badge-running  { background:rgba(34,211,238,0.12);color:var(--cyan);  border:1px solid rgba(34,211,238,0.3); }
.badge-done     { background:rgba(34,197,94,0.12); color:var(--green); border:1px solid rgba(34,197,94,0.3);  }
.badge-training { background:rgba(168,85,247,0.12);color:var(--violet);border:1px solid rgba(168,85,247,0.3); }
.badge-serving  { background:rgba(249,115,22,0.12);color:var(--orange);border:1px solid rgba(249,115,22,0.3); }

/* ── Tech strip ── */
.logos-strip {
  padding: 26px 0;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  overflow: hidden; position: relative;
}
.logos-strip::before,.logos-strip::after {
  content:""; position:absolute; top:0;bottom:0;width:80px;z-index:2;
}
.logos-strip::before { left:0; background:linear-gradient(to right,var(--bg-0),transparent); }
.logos-strip::after  { right:0;background:linear-gradient(to left, var(--bg-0),transparent); }
.logos-track {
  display:flex;gap:56px;align-items:center;width:max-content;
  animation: scroll-logos 32s linear infinite;
}
@keyframes scroll-logos { from{transform:translateX(0)}to{transform:translateX(-50%)} }
.logo-item {
  display:flex;align-items:center;gap:8px;white-space:nowrap;
  font-size:13px;font-weight:600;color:var(--subtle);letter-spacing:0.02em;transition:color 0.2s;
}
.logo-item:hover{color:var(--muted);}
.logo-item svg{width:20px;height:20px;flex-shrink:0;}
.logo-item .brand-badge {
  width: 22px; height: 22px; border-radius: 5px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  font-size: 9px; font-weight: 800; color: #fff;
}

/* ── Section generic ── */
section { padding: 88px 0; }
.section-eyebrow { font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:10px; }
.section-title { font-family:'Space Grotesk',sans-serif;font-size:clamp(26px,4vw,38px);font-weight:700;letter-spacing:-0.7px;color:var(--heading);margin-bottom:12px;line-height:1.12; }
.section-sub { font-size:15px;color:var(--muted);max-width:560px;line-height:1.72; }
.section-head { margin-bottom:52px; }
.section-head-center { text-align:center;margin-bottom:52px; }
.section-head-center .section-sub { margin:0 auto; }

/* ── Page hero (inner pages) ── */
.page-hero { padding: 72px 0 56px; }
.page-hero .section-eyebrow { margin-bottom: 12px; }
.page-hero h1 { font-family:'Space Grotesk',sans-serif;font-size:clamp(30px,5vw,48px);font-weight:700;letter-spacing:-1px;color:var(--heading);margin-bottom:16px;line-height:1.1; }
.page-hero p { font-size:16px;color:var(--muted);max-width:600px;line-height:1.75; }

/* ── Tags ── */
.tag { font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--tag-bg);border:1px solid var(--tag-border);color:var(--tag-text); }
.tag-cyan { background:rgba(34,211,238,0.07);border-color:rgba(34,211,238,0.2);color:#67e8f9; }
[data-theme="light"] .tag-cyan { color:#0891b2; }

/* ── Service cards ── */
.services-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:20px; }
.service-card {
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  padding:28px 24px;backdrop-filter:blur(10px);
  transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s;
  position:relative;overflow:hidden;
}
.service-card::before {
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 0% 0%,rgba(99,102,241,0.07) 0%,transparent 60%);pointer-events:none;
}
[data-theme="light"] .service-card::before { background:radial-gradient(circle at 0% 0%,rgba(99,102,241,0.04) 0%,transparent 60%); }
.service-card:hover { border-color:var(--border-bright);transform:translateY(-3px);box-shadow:var(--glow-blue); }
.service-icon-wrap { width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;background:rgba(99,102,241,0.12);border:1px solid rgba(99,102,241,0.22); }
.service-icon-wrap svg{width:20px;height:20px;}
.service-card h3 { font-family:'Space Grotesk',sans-serif;font-size:17px;font-weight:700;color:var(--heading);margin-bottom:8px; }
.service-card p  { font-size:13.5px;color:var(--muted);line-height:1.65;margin-bottom:18px; }
.service-tags{display:flex;flex-wrap:wrap;gap:6px;}

/* Brand accent colors for service icons */
.icon-wrap-aws { background:rgba(255,153,0,0.12);border-color:rgba(255,153,0,0.22); }
.icon-wrap-azure { background:rgba(0,120,212,0.12);border-color:rgba(0,120,212,0.22); }
.icon-wrap-databricks { background:rgba(255,70,20,0.12);border-color:rgba(255,70,20,0.22); }
.icon-wrap-ai { background:rgba(168,85,247,0.12);border-color:rgba(168,85,247,0.22); }
.icon-wrap-data { background:rgba(34,211,238,0.1);border-color:rgba(34,211,238,0.2); }
.icon-wrap-green { background:rgba(34,197,94,0.1);border-color:rgba(34,197,94,0.2); }

/* ── Industry cards ── */
.industries-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:20px; }
.industry-card {
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:28px 24px;
  backdrop-filter:blur(10px);
  transition:border-color 0.22s,transform 0.22s,box-shadow 0.22s;
  position:relative;overflow:hidden;cursor:default;
}
.industry-card::after {
  content:"";position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--cyan),var(--blue));
  opacity:0;transition:opacity 0.22s;
  border-radius:0 0 var(--radius) var(--radius);
}
.industry-card:hover { border-color:var(--border-bright);transform:translateY(-4px);box-shadow:var(--glow-blue); }
.industry-card:hover::after { opacity:1; }
.industry-icon-wrap {
  width:46px;height:46px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
  background:rgba(34,211,238,0.08);border:1px solid rgba(34,211,238,0.2);
}
.industry-icon-wrap svg{width:20px;height:20px;}
.industry-card h3 { font-family:'Space Grotesk',sans-serif;font-size:16px;font-weight:700;color:var(--heading);margin-bottom:8px; }
.industry-card p  { font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:16px; }
.industry-tags{display:flex;flex-wrap:wrap;gap:6px;}
.industry-tag{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;background:rgba(34,211,238,0.07);border:1px solid rgba(34,211,238,0.2);color:#67e8f9;}
[data-theme="light"] .industry-tag{color:#0891b2;}

/* ── Accelerator cards ── */
.accel-section { margin-bottom: 72px; }
.accel-section-header {
  display: flex; align-items: center; gap: 16px; margin-bottom: 32px;
  padding-bottom: 20px; border-bottom: 1px solid var(--border);
}
.brand-logo-wrap {
  width: 56px; height: 56px; border-radius: 16px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  border: 1px solid var(--border); background: var(--bg-card);
}
.brand-logo-wrap svg { width: 32px; height: 32px; }
.accel-section-header h2 { font-family:'Space Grotesk',sans-serif;font-size:26px;font-weight:700;color:var(--heading); }
.accel-section-header p { font-size:14px;color:var(--muted);margin-top:4px; }
.accel-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.accel-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 16px;
  padding: 22px 20px; backdrop-filter: blur(10px);
  transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
  position: relative; overflow: hidden;
}
.accel-card:hover { border-color: var(--border-bright); transform: translateY(-2px); box-shadow: var(--glow-blue); }
.accel-card-icon {
  width: 38px; height: 38px; border-radius: 11px;
  display: flex; align-items: center; justify-content: center; margin-bottom: 14px;
}
.accel-card-icon svg { width: 18px; height: 18px; }
.accel-card h4 { font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;color:var(--heading);margin-bottom:6px; }
.accel-card p { font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:14px; }
.accel-tags { display:flex;flex-wrap:wrap;gap:5px; }

/* ── How it works ── */
.how-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:18px;position:relative; }
.how-grid::before {
  content:"";position:absolute;top:26px;
  left:calc(12.5% + 14px);right:calc(12.5% + 14px);
  height:1px;background:linear-gradient(90deg,transparent,var(--border-bright),transparent);
}
.how-step { display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;padding:24px 14px; }
.how-num {
  width:52px;height:52px;border-radius:50%;
  background:var(--bg-1);border:1px solid var(--border-bright);
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;font-size:18px;font-weight:700;color:var(--cyan);
  position:relative;z-index:1;box-shadow:0 0 28px rgba(34,211,238,0.18);
}
.how-step h4 { font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;color:var(--heading); }
.how-step p  { font-size:13px;color:var(--muted);line-height:1.6; }

/* ── Why ── */
.why-grid { display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center; }
.why-list { display:grid;gap:20px; }
.why-item { display:flex;gap:14px;align-items:flex-start; }
.why-icon {
  width:38px;height:38px;border-radius:12px;
  background:rgba(34,211,238,0.1);border:1px solid rgba(34,211,238,0.22);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;
}
.why-icon svg{width:17px;height:17px;}
.why-item h4 { font-size:14.5px;font-weight:700;color:var(--heading);margin-bottom:4px; }
.why-item p  { font-size:13px;color:var(--muted);line-height:1.65; }
.why-visual { background:var(--bg-card);border:1px solid var(--border-bright);border-radius:24px;padding:28px;box-shadow:var(--glow-cyan); }
.metric-row{display:grid;gap:14px;}
.metric-item{background:var(--input-bg);border:1px solid var(--border);border-radius:14px;padding:14px 16px;}
.metric-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.metric-label{font-size:12px;color:var(--muted);font-weight:500;}
.metric-value{font-size:13px;font-weight:700;color:var(--cyan);}
.progress-bar{height:5px;border-radius:999px;background:rgba(99,130,255,0.12);overflow:hidden;}
.progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--blue));}

/* ── CTA banner ── */
.cta-banner {
  background:linear-gradient(135deg,rgba(99,102,241,0.18) 0%,rgba(34,211,238,0.1) 100%);
  border:1px solid var(--border-bright);border-radius:28px;
  padding:64px 48px;text-align:center;position:relative;overflow:hidden;box-shadow:var(--glow-blue);
}
[data-theme="light"] .cta-banner { background:linear-gradient(135deg,rgba(99,102,241,0.08) 0%,rgba(34,211,238,0.06) 100%); }
.cta-banner::before {
  content:"";position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:400px;height:200px;
  background:radial-gradient(ellipse,rgba(99,102,241,0.32) 0%,transparent 70%);pointer-events:none;
}
.cta-banner h2 { font-family:'Space Grotesk',sans-serif;font-size:clamp(24px,4vw,36px);font-weight:700;color:var(--heading);margin-bottom:14px;letter-spacing:-0.5px; }
.cta-banner p  { font-size:15px;color:var(--muted);margin-bottom:32px;max-width:500px;margin-left:auto;margin-right:auto; }
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* ── Contact form ── */
.contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 52px; align-items: start; }
.contact-info h2 { font-family:'Space Grotesk',sans-serif;font-size:32px;font-weight:700;color:var(--heading);margin-bottom:14px;letter-spacing:-0.5px; }
.contact-info p { font-size:15px;color:var(--muted);line-height:1.75;margin-bottom:32px; }
.contact-details { display:grid;gap:16px; }
.contact-detail {
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;
  text-decoration:none;color:var(--muted);transition:border-color 0.2s,color 0.2s;
}
.contact-detail:hover { border-color:var(--border-bright);color:var(--text); }
.contact-detail-icon { width:36px;height:36px;border-radius:10px;background:rgba(34,211,238,0.1);border:1px solid rgba(34,211,238,0.2);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
.contact-detail-icon svg{width:15px;height:15px;}
.contact-detail-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--subtle);margin-bottom:2px;}
.contact-detail-value{font-size:14px;font-weight:500;color:var(--text);}

.contact-form-wrap {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 24px;
  padding: 36px; backdrop-filter: blur(10px);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { margin-bottom: 18px; }
.form-group label { display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px;letter-spacing:0.04em; }
.form-group input,
.form-group select,
.form-group textarea {
  width:100%;padding:11px 14px;
  background:var(--input-bg);border:1px solid var(--border);border-radius:12px;
  color:var(--text);font-family:'Inter',sans-serif;font-size:14px;
  transition:border-color 0.15s,box-shadow 0.15s;
  outline:none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:var(--subtle); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:rgba(34,211,238,0.5);box-shadow:0 0 0 3px rgba(34,211,238,0.08); }
.form-group select { appearance: none; cursor: pointer; }
.form-group select option { background: #070d20; color: #e2e8f0; }
[data-theme="light"] .form-group select option { background: #f0f4ff; color: #1e293b; }
.form-group textarea { resize: vertical; min-height: 120px; }
.form-submit-wrap { display:flex;align-items:center;gap:14px;flex-wrap:wrap; }
.form-submit-wrap .btn { flex:1; justify-content:center; }
.form-note { font-size:12px;color:var(--subtle); }
.form-success {
  display:none;align-items:center;gap:12px;
  padding:16px;background:rgba(34,197,94,0.1);border:1px solid rgba(34,197,94,0.3);
  border-radius:12px;color:var(--green);font-size:14px;font-weight:500;margin-top:16px;
}
.form-success.visible { display:flex; }
.form-error {
  display:none;align-items:center;gap:12px;
  padding:16px;background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.3);
  border-radius:12px;color:var(--red);font-size:14px;font-weight:500;margin-top:16px;
}
.form-error.visible { display:flex; }

/* ── Footer ── */
footer { border-top:1px solid var(--border);padding:52px 0 32px; }
.footer-inner { display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px; }
.footer-brand p { font-size:13px;color:var(--muted);line-height:1.7;margin-top:14px;max-width:240px; }
.footer-col h5 { font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--subtle);margin-bottom:14px; }
.footer-col ul{list-style:none;display:grid;gap:9px;}
.footer-col ul a{font-size:13px;color:var(--muted);text-decoration:none;transition:color 0.15s;}
.footer-col ul a:hover{color:var(--text);}
.footer-bottom {
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;border-top:1px solid var(--border);
  font-size:12px;color:var(--subtle);flex-wrap:wrap;gap:12px;
}
.footer-bottom a { color:inherit;text-decoration:none; }
.footer-bottom a:hover { color:var(--muted); }

/* ── Responsive ── */
@media(max-width:1050px){ .footer-inner{grid-template-columns:1fr 1fr 1fr;} }
@media(max-width:960px){
  .nav-links { display:none; }
  .nav-hamburger { display:flex; }
  .hero{grid-template-columns:1fr;gap:40px;padding:60px 0;}
  .hero-desc{max-width:100%;}
  .services-grid{grid-template-columns:1fr 1fr;}
  .industries-grid{grid-template-columns:1fr 1fr;}
  .accel-grid{grid-template-columns:1fr 1fr;}
  .how-grid{grid-template-columns:1fr 1fr;}
  .how-grid::before{display:none;}
  .why-grid{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr 1fr;}
  .cta-banner{padding:44px 28px;}
  .contact-grid{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .services-grid{grid-template-columns:1fr;}
  .industries-grid{grid-template-columns:1fr;}
  .accel-grid{grid-template-columns:1fr;}
  .how-grid{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;}
  .hero-stats{gap:20px;}
  .form-row{grid-template-columns:1fr;}
  .cta-banner{padding:32px 20px;}
}
