/* ===== RESET & BASE ===== */
:root {
  --primary: #6c3de8;
  --primary-dark: #4f28c0;
  --secondary: #3b82f6;
  --accent: #8b5cf6;
  --dark: #0b0f1a;
  --dark-card: #111827;
  --text: #111827;
  --text-muted: #6b7280;
  --text-light: #f9fafb;
  --border: rgba(108,61,232,0.12);
  --grad: linear-gradient(135deg, var(--primary), var(--secondary));
  --grad-soft: linear-gradient(135deg, rgba(108,61,232,0.08), rgba(59,130,246,0.06));
  --radius: 20px;
  --radius-sm: 12px;
  --shadow: 0 8px 32px rgba(108,61,232,0.12);
  --shadow-lg: 0 20px 60px rgba(108,61,232,0.18);
  --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body { font-family:'Inter',sans-serif; background:#f8f9ff; color:var(--text); line-height:1.6; overflow-x:hidden; }
img { max-width:100%; display:block; }
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.gradient-text { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
h1,h2,h3 { font-weight:800; line-height:1.15; letter-spacing:-0.03em; color:var(--text); }
h2 { font-size:clamp(2rem, 4vw, 2.75rem); }
p { color:var(--text-muted); }

/* ===== BUTTONS ===== */
.btn { display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:0.95rem; text-decoration:none; border:none; cursor:pointer; border-radius:100px; transition:var(--transition); font-family:'Inter',sans-serif; }
.btn-primary { background:var(--grad); color:#fff; padding:14px 28px; box-shadow:0 8px 24px rgba(108,61,232,0.3); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 14px 32px rgba(108,61,232,0.4); }
.btn-dark { background:#0b0f1a; color:#fff; padding:12px 28px; box-shadow:none; font-weight:600; font-size:0.95rem; border-radius:100px; }
.btn-dark:hover { background:#1f2937; transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,0.15); }
.btn-ghost { background:transparent; color:var(--primary); padding:14px 24px; border:2px solid var(--border); }
.btn-ghost:hover { background:rgba(108,61,232,0.06); border-color:var(--primary); }
.btn-white { background:#fff; color:var(--primary); padding:16px 36px; font-size:1.05rem; box-shadow:0 8px 24px rgba(0,0,0,0.15); }
.btn-white:hover { transform:translateY(-2px); box-shadow:0 14px 32px rgba(0,0,0,0.2); }
.btn-lg { padding:16px 36px; font-size:1.05rem; }
/* ===== NAVBAR ===== */
.navbar { position:fixed; top:24px; left:50%; transform:translateX(-50%); width:calc(100% - 48px); max-width:1100px; z-index:1000; padding:0; background:#fff; border-radius:100px; box-shadow:0 10px 40px rgba(0,0,0,0.08); transition:var(--transition); border:none; }
.navbar.scrolled { top:20px; box-shadow:0 15px 50px rgba(0,0,0,0.12); }
.nav-container { display:flex; align-items:center; height:64px; padding:0 12px 0 24px; }
.logo { display:flex; align-items:center; gap:10px; font-size:1.25rem; font-weight:900; color:#111827; text-decoration:none; letter-spacing:0; }
.logo-mark { width:32px; height:32px; background:var(--primary); border-radius:8px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.logo-inner-square { width:14px; height:14px; background:#fff; border-radius:4px; }
.nav-links { display:flex; gap:36px; flex:1; justify-content:center; }
.nav-links a { text-decoration:none; color:#4b5563; font-weight:600; font-size:0.95rem; transition:var(--transition); }
.nav-links a:hover { color:#111827; }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.hamburger span { width:24px; height:2px; background:var(--text); border-radius:2px; transition:var(--transition); display:block; }

/* ===== HERO ===== */
.hero { min-height:100vh; display:flex; align-items:center; padding:140px 0 80px; position:relative; overflow:hidden; }
.hero-bg-orb { position:absolute; border-radius:50%; filter:blur(80px); pointer-events:none; z-index:0; }
.orb-1 { width:600px; height:600px; background:rgba(108,61,232,0.1); top:-200px; right:-150px; }
.orb-2 { width:400px; height:400px; background:rgba(59,130,246,0.08); bottom:-100px; left:-100px; }
.hero-container { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; position:relative; z-index:1; }
.badge { display:inline-flex; align-items:center; gap:8px; background:rgba(108,61,232,0.08); color:var(--primary); font-size:0.8rem; font-weight:700; padding:8px 16px; border-radius:100px; border:1px solid rgba(108,61,232,0.2); margin-bottom:24px; letter-spacing:0.02em; text-transform:uppercase; }
.badge-dot { width:7px; height:7px; background:var(--primary); border-radius:50%; animation:pulse-dot 2s infinite; }
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.5;transform:scale(1.4)} }
.hero-headline { font-size:clamp(2.6rem, 5vw, 3.8rem); margin-bottom:24px; }
.hero-subheadline { font-size:1.15rem; color:var(--text-muted); margin-bottom:36px; max-width:480px; line-height:1.7; }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:48px; }
.hero-stats { display:flex; align-items:center; gap:24px; padding:20px 24px; background:#fff; border-radius:var(--radius-sm); border:1px solid var(--border); box-shadow:var(--shadow); }
.stat-item { display:flex; flex-direction:column; }
.stat-item strong { font-size:1.4rem; font-weight:900; color:var(--primary); letter-spacing:-0.02em; }
.stat-item span { font-size:0.75rem; color:var(--text-muted); font-weight:500; }
.stat-divider { width:1px; height:40px; background:var(--border); flex-shrink:0; }

/* Hero Dashboard Visual */
.hero-visual { position:relative; margin-top:-80px; }
.hero-dashboard-card { background:#fff; border-radius:var(--radius); box-shadow:var(--shadow-lg); border:1px solid var(--border); overflow:hidden; animation:float-card 6s ease-in-out infinite; }
@keyframes float-card { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
.dashboard-header { display:flex; align-items:center; gap:10px; padding:16px 20px; background:var(--dark); border-bottom:1px solid rgba(255,255,255,0.06); }
.dashboard-dots { display:flex; gap:6px; }
.dashboard-dots span { width:10px; height:10px; border-radius:50%; background:#374151; }
.dashboard-dots span:first-child { background:#ef4444; }
.dashboard-dots span:nth-child(2) { background:#f59e0b; }
.dashboard-dots span:nth-child(3) { background:#10b981; }
.dashboard-title { color:rgba(255,255,255,0.6); font-size:0.8rem; font-weight:500; flex:1; text-align:center; }
.dashboard-status { color:#10b981; font-size:0.75rem; font-weight:700; }
.dashboard-body { padding:24px; display:flex; flex-direction:column; gap:20px; }
.dash-metric { display:flex; align-items:center; gap:12px; }
.dash-metric-label { font-size:0.8rem; color:var(--text-muted); font-weight:500; width:170px; flex-shrink:0; }
.dash-metric-bar { flex:1; height:6px; background:#f3f4f6; border-radius:3px; overflow:hidden; }
.dash-metric-fill { height:100%; background:var(--grad); border-radius:3px; animation:bar-grow 1.5s ease-out both; }
@keyframes bar-grow { from{width:0!important} }
.dash-metric-value { font-size:0.8rem; font-weight:700; color:var(--primary); width:36px; text-align:right; }
.dash-tasks { display:flex; flex-direction:column; gap:10px; padding-top:4px; border-top:1px solid #f3f4f6; }
.dash-task { display:flex; align-items:center; gap:8px; font-size:0.8rem; font-weight:500; }
.dash-task.completed { color:var(--text); }
.dash-task.completed svg { color:#10b981; }
.dash-task.pending { color:var(--text-muted); }
.dash-task.pending svg { color:#f59e0b; }

/* Floating cards */
.float-card { position:absolute; background:#fff; border:1px solid var(--border); border-radius:var(--radius-sm); padding:12px 18px; display:flex; align-items:center; gap:12px; box-shadow:var(--shadow); }
.float-card svg { color:var(--primary); flex-shrink:0; }
.float-card strong { display:block; font-weight:800; font-size:0.95rem; color:var(--text); }
.float-card small { color:var(--text-muted); font-size:0.75rem; }
.card-a { top:-24px; left:-32px; animation:float-a 5s ease-in-out infinite; }
.card-b { bottom:-20px; right:-20px; animation:float-b 6s ease-in-out 1.5s infinite; }
@keyframes float-a { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes float-b { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }

/* ===== INTEGRATIONS ===== */
.integrations { padding:64px 0; background:#fff; border-top:1px solid rgba(0,0,0,0.05); border-bottom:1px solid rgba(0,0,0,0.05); overflow:hidden; }
.integrations-label { text-align:center; margin-bottom:28px; }
.integrations-label p { font-size:0.85rem; font-weight:700; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.08em; }
.marquee-wrapper { overflow:hidden; width:100%; }
.marquee-track { display:flex; gap:0; animation:marquee 40s linear infinite; width:max-content; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.tool-pill { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; padding:0 32px; border-right:1px solid #eef0f6; white-space:nowrap; }
.tool-pill-icon { width:64px; height:64px; border-radius:16px; background:#fff; display:flex; align-items:center; justify-content:center; flex-shrink:0; border:1px solid rgba(0,0,0,0.08); box-shadow:0 4px 12px rgba(0,0,0,0.08); }
.tool-pill-icon.tool-pill-svg { padding:6px; }
.tool-pill-icon.tool-pill-svg svg { display:block; width:36px; height:36px; }
.tool-pill-name { font-weight:600; font-size:0.8rem; color:var(--text-muted); text-align:center; }

/* ===== SECTION HEADER ===== */
.section-header { max-width:640px; margin:0 auto 64px; text-align:center; }
.section-eyebrow { font-size:0.8rem; font-weight:800; text-transform:uppercase; letter-spacing:0.1em; color:var(--primary); margin-bottom:12px; }
.section-sub { font-size:1.05rem; color:var(--text-muted); margin-top:16px; line-height:1.7; }

/* ===== SERVICES ===== */
.services { padding:120px 0; }
.services-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; }
.service-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:36px 28px; transition:var(--transition); display:flex; flex-direction:column; gap:12px; position:relative; overflow:hidden; }
.service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--grad); opacity:0; transition:var(--transition); }
.service-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:rgba(108,61,232,0.25); }
.service-card:hover::before { opacity:1; }
.service-card--wide { grid-column:span 3; flex-direction:row; align-items:flex-start; gap:28px; }
.service-card--wide h3 { font-size:1.4rem; }
.service-card--wide .service-icon-wrap { flex-shrink:0; }
.service-icon-wrap { width:56px; height:56px; background:var(--grad-soft); border-radius:14px; display:flex; align-items:center; justify-content:center; color:var(--primary); margin-bottom:4px; flex-shrink:0; border:1px solid rgba(108,61,232,0.15); }
.service-tag { position:absolute; top:20px; right:20px; font-size:0.7rem; font-weight:700; background:rgba(108,61,232,0.08); color:var(--primary); padding:4px 10px; border-radius:100px; border:1px solid rgba(108,61,232,0.2); }
.service-card h3 { font-size:1.1rem; font-weight:800; color:var(--text); line-height:1.3; }
.service-card p { font-size:0.9rem; line-height:1.7; flex:1; }
.service-footer { margin-top:auto; padding-top:12px; border-top:1px solid #f3f4f6; }
.service-benefit { font-size:0.8rem; font-weight:700; color:#10b981; }

/* Card color variants */
.card-blue .service-icon-wrap { background:rgba(59,130,246,0.08); color:#3b82f6; border-color:rgba(59,130,246,0.2); }
.card-blue:hover { box-shadow:0 20px 60px rgba(59,130,246,0.12); border-color:rgba(59,130,246,0.3); }
.card-blue::before { background:linear-gradient(90deg,#3b82f6,#60a5fa); }
.card-violet .service-icon-wrap { background:rgba(139,92,246,0.08); color:#8b5cf6; border-color:rgba(139,92,246,0.2); }
.card-violet:hover { box-shadow:0 20px 60px rgba(139,92,246,0.12); border-color:rgba(139,92,246,0.3); }
.card-violet::before { background:linear-gradient(90deg,#8b5cf6,#a78bfa); }
.card-emerald .service-icon-wrap { background:rgba(16,185,129,0.08); color:#10b981; border-color:rgba(16,185,129,0.2); }
.card-emerald:hover { box-shadow:0 20px 60px rgba(16,185,129,0.12); border-color:rgba(16,185,129,0.3); }
.card-emerald::before { background:linear-gradient(90deg,#10b981,#34d399); }
.card-amber .service-icon-wrap { background:rgba(245,158,11,0.08); color:#f59e0b; border-color:rgba(245,158,11,0.2); }
.card-amber:hover { box-shadow:0 20px 60px rgba(245,158,11,0.12); border-color:rgba(245,158,11,0.3); }
.card-amber::before { background:linear-gradient(90deg,#f59e0b,#fbbf24); }
.card-pink .service-icon-wrap { background:rgba(236,72,153,0.08); color:#ec4899; border-color:rgba(236,72,153,0.2); }
.card-pink:hover { box-shadow:0 20px 60px rgba(236,72,153,0.12); border-color:rgba(236,72,153,0.3); }
.card-pink::before { background:linear-gradient(90deg,#ec4899,#f472b6); }
.card-indigo .service-icon-wrap { background:rgba(99,102,241,0.08); color:#6366f1; border-color:rgba(99,102,241,0.2); }
.card-indigo:hover { box-shadow:0 20px 60px rgba(99,102,241,0.12); border-color:rgba(99,102,241,0.3); }
.card-indigo::before { background:linear-gradient(90deg,#6366f1,#818cf8); }

/* Featured wide card */
.service-card--featured { background:linear-gradient(135deg,#0f0c29,#302b63,#24243e); border-color:rgba(108,61,232,0.4); position:relative; overflow:hidden; }
.service-card--featured::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(108,61,232,0.15),rgba(59,130,246,0.08)); pointer-events:none; }
.service-card--featured h3 { color:#fff; font-size:1.5rem; }
.service-card--featured p { color:rgba(255,255,255,0.65); }
.service-card--featured .service-footer { border-top-color:rgba(255,255,255,0.1); }
.service-card--featured .service-benefit { color:#34d399; }
.service-content-left { flex:0 0 340px; display:flex; flex-direction:column; gap:14px; position:relative; z-index:1; }
.service-icon-featured { background:rgba(108,61,232,0.25); color:#a78bfa; border-color:rgba(108,61,232,0.4); }
.service-tag--gold { background:linear-gradient(90deg,#f59e0b,#fbbf24); color:#fff; border:none; font-size:0.7rem; font-weight:800; padding:4px 12px; border-radius:100px; display:inline-block; width:fit-content; }
.feature-pills { display:flex; flex-wrap:wrap; gap:8px; margin-top:4px; }
.feature-pill { background:rgba(255,255,255,0.08); color:rgba(255,255,255,0.8); font-size:0.75rem; font-weight:600; padding:5px 12px; border-radius:100px; border:1px solid rgba(255,255,255,0.12); }

/* ===== SAAS DASHBOARD MOCKUP ===== */
.saas-dashboard-mockup { flex:1; background:#f9fafb; border:1px solid var(--border); border-radius:var(--radius-sm); overflow:hidden; display:flex; min-width:0; height:400px; font-family:'Inter',sans-serif; position:relative; z-index:1; box-shadow:0 24px 64px rgba(0,0,0,0.35); }
.saas-sidebar { width:110px; background:#1e1b4b; display:flex; flex-direction:column; padding:14px 10px; flex-shrink:0; }
.saas-logo { margin-bottom:20px; padding-left:4px; }
.saas-logo-box { width:22px; height:22px; background:var(--grad); border-radius:6px; }
.saas-nav { display:flex; flex-direction:column; gap:2px; }
.saas-nav a { display:flex; align-items:center; gap:8px; padding:7px 8px; border-radius:6px; text-decoration:none; color:rgba(255,255,255,0.45); font-size:0.7rem; font-weight:600; transition:all 0.2s; }
.saas-nav a:hover, .saas-nav a.active { background:rgba(255,255,255,0.1); color:#fff; }
.saas-nav a svg { width:13px; height:13px; flex-shrink:0; }

.saas-main { flex:1; display:flex; flex-direction:column; overflow:hidden; background:#fff; }
.saas-topbar { height:44px; background:#fff; border-bottom:1px solid #f1f5f9; display:flex; align-items:center; justify-content:space-between; padding:0 16px; flex-shrink:0; }
.saas-page-title { font-size:0.8rem; font-weight:800; color:#111827; }
.saas-topbar-right { display:flex; align-items:center; gap:8px; }
.saas-search { display:flex; align-items:center; gap:6px; font-size:0.7rem; color:#9ca3af; background:#f3f4f6; padding:5px 10px; border-radius:100px; }
.saas-avatar { width:22px; height:22px; border-radius:50%; background:var(--grad); color:#fff; display:flex; align-items:center; justify-content:center; font-size:0.55rem; font-weight:800; flex-shrink:0; }

.saas-content { padding:14px 16px; display:flex; flex-direction:column; gap:12px; overflow-y:auto; }

/* KPI Row */
.saas-kpi-row { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; }
.saas-kpi { background:#fff; border:1px solid #f1f5f9; border-radius:8px; padding:10px; display:flex; align-items:center; gap:8px; box-shadow:0 1px 4px rgba(0,0,0,0.04); }
.saas-kpi-icon { width:28px; height:28px; border-radius:7px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.saas-kpi--purple .saas-kpi-icon { background:rgba(108,61,232,0.1); color:#6c3de8; }
.saas-kpi--amber .saas-kpi-icon { background:rgba(245,158,11,0.1); color:#f59e0b; }
.saas-kpi--red .saas-kpi-icon { background:rgba(239,68,68,0.1); color:#ef4444; }
.saas-kpi div { display:flex; flex-direction:column; gap:1px; }
.saas-kpi span { font-size:0.6rem; color:#6b7280; font-weight:600; text-transform:uppercase; letter-spacing:0.04em; }
.saas-kpi strong { font-size:1.1rem; font-weight:900; color:#111827; line-height:1; }
.trend-up { font-size:0.6rem; font-weight:700; color:#10b981; font-style:normal; }
.trend-down { font-size:0.6rem; font-weight:700; color:#ef4444; font-style:normal; }
.trend-alert { font-size:0.6rem; font-weight:700; color:#f59e0b; font-style:normal; }

/* Pipeline */
.saas-pipeline { background:#fafafa; border:1px solid #f1f5f9; border-radius:8px; padding:10px 12px; display:flex; flex-direction:column; gap:7px; }
.saas-pipeline-title { font-size:0.7rem; font-weight:800; color:#374151; margin-bottom:2px; }
.saas-pipe { display:flex; align-items:center; gap:8px; }
.saas-pipe span { font-size:0.62rem; color:#6b7280; font-weight:600; width:52px; flex-shrink:0; }
.saas-pipe-track { flex:1; height:6px; background:#e5e7eb; border-radius:3px; overflow:hidden; }
.saas-pipe-fill { height:100%; border-radius:3px; }
.saas-pipe b { font-size:0.62rem; font-weight:800; color:#374151; width:18px; text-align:right; flex-shrink:0; }

/* Table */
.saas-table-wrapper { background:#fff; border:1px solid #f1f5f9; border-radius:8px; overflow:hidden; }
.saas-table-header { padding:8px 12px; border-bottom:1px solid #f1f5f9; font-size:0.7rem; font-weight:800; color:#374151; background:#fafafa; }
.saas-table-row { display:flex; align-items:center; padding:8px 12px; border-bottom:1px solid #f8fafc; font-size:0.7rem; }
.saas-table-row:last-child { border-bottom:none; }
.col-client { flex:1.5; font-weight:600; color:#111827; display:flex; align-items:center; gap:6px; }
.dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
.dot.red { background:#ef4444; } .dot.yellow { background:#f59e0b; } .dot.green { background:#10b981; }
.col-task { flex:2; color:#6b7280; }
.col-status { flex:1; text-align:right; }
.badge-red { background:#fef2f2; color:#ef4444; padding:2px 6px; border-radius:100px; font-size:0.6rem; font-weight:700; border:1px solid rgba(239,68,68,0.2); }
.badge-yellow { background:#fffbeb; color:#f59e0b; padding:2px 6px; border-radius:100px; font-size:0.6rem; font-weight:700; border:1px solid rgba(245,158,11,0.2); }
.badge-green { background:#ecfdf5; color:#10b981; padding:2px 6px; border-radius:100px; font-size:0.6rem; font-weight:700; border:1px solid rgba(16,185,129,0.2); }

@media (max-width:768px) { .saas-sidebar { display:none; } }

/* ===== HOW IT WORKS ===== */
.how-it-works { padding:120px 0; background:var(--dark); }
.how-it-works .section-header { margin-bottom:64px; }
.how-it-works .section-eyebrow { color:rgba(139,92,246,0.9); }
.how-it-works h2 { color:#fff; }
.how-it-works .section-sub { color:rgba(255,255,255,0.5); }
.steps-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; position:relative; }
.steps-grid::before { content:''; position:absolute; top:36px; left:calc(16.6% + 20px); right:calc(16.6% + 20px); height:1px; background:linear-gradient(90deg,var(--primary),var(--secondary)); opacity:0.3; }
.step-card { background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:var(--radius); padding:40px 28px; text-align:center; position:relative; transition:var(--transition); }
.step-card:hover { background:rgba(108,61,232,0.08); border-color:rgba(108,61,232,0.3); transform:translateY(-4px); }
.step-num { width:72px; height:72px; background:var(--grad); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.5rem; font-weight:900; color:#fff; margin:0 auto 24px; border:4px solid var(--dark); box-shadow:0 0 0 1px rgba(108,61,232,0.4); }
.step-card h3 { font-size:1.2rem; font-weight:800; color:#fff; margin-bottom:12px; }
.step-card p { font-size:0.9rem; color:rgba(255,255,255,0.55); line-height:1.75; }

/* ===== TESTIMONIALS ===== */
.testimonials { padding:120px 0; background:#f8f9ff; }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testimonial-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:36px 28px; display:flex; flex-direction:column; gap:20px; transition:var(--transition); }
.testimonial-card:hover { transform:translateY(-4px); box-shadow:var(--shadow); }
.stars { color:#f59e0b; font-size:1rem; letter-spacing:2px; }
.testimonial-text { font-size:0.95rem; color:var(--text); line-height:1.75; font-style:italic; flex:1; }
.testimonial-author { display:flex; align-items:center; gap:14px; padding-top:16px; border-top:1px solid #f3f4f6; }
.author-avatar { width:44px; height:44px; background:var(--grad); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-weight:800; font-size:0.85rem; flex-shrink:0; }
.testimonial-author strong { display:block; font-weight:800; color:var(--text); font-size:0.9rem; }
.testimonial-author span { font-size:0.78rem; color:var(--text-muted); }

/* ===== FAQ ===== */
.faq { padding:120px 0; background:#fff; }
.faq-inner { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.faq .section-header { text-align:left; margin:0; }
.faq-list { display:flex; flex-direction:column; gap:0; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-item:last-child { border-bottom:none; }
.faq-question { width:100%; text-align:left; padding:22px 24px; background:none; border:none; font-family:'Inter',sans-serif; font-size:0.98rem; font-weight:700; color:var(--text); cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; transition:var(--transition); }
.faq-question:hover { color:var(--primary); background:rgba(108,61,232,0.03); }
.faq-chevron { flex-shrink:0; color:var(--primary); transition:transform 0.3s ease; }
.faq-item.active .faq-chevron { transform:rotate(180deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.35s ease, padding 0.3s ease; padding:0 24px; }
.faq-item.active .faq-answer { max-height:200px; padding-bottom:22px; }
.faq-answer p { font-size:0.9rem; line-height:1.75; color:var(--text-muted); }

/* ===== FINAL CTA ===== */
.final-cta { padding:120px 0; background:var(--dark); text-align:center; position:relative; overflow:hidden; }
.cta-orb { position:absolute; border-radius:50%; filter:blur(100px); pointer-events:none; }
.cta-orb-1 { width:500px; height:500px; background:rgba(108,61,232,0.2); top:-200px; left:-100px; }
.cta-orb-2 { width:400px; height:400px; background:rgba(59,130,246,0.15); bottom:-150px; right:-80px; }
.cta-content { position:relative; z-index:1; max-width:720px; }
.eyebrow-light { color:rgba(139,92,246,0.9); }
.final-cta h2 { font-size:clamp(2rem,4vw,3rem); color:#fff; margin:16px 0 20px; }
.final-cta p { color:rgba(255,255,255,0.6); font-size:1.1rem; margin-bottom:36px; }
.cta-note { font-size:0.82rem; color:rgba(255,255,255,0.35); margin-top:16px; margin-bottom:0; }

/* ===== FOOTER ===== */
.footer { background:var(--dark); border-top:1px solid rgba(255,255,255,0.06); padding:64px 0 0; }
.footer-inner { display:grid; grid-template-columns:2fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,0.06); }
.footer-brand .logo { color:#fff; margin-bottom:16px; }
.footer-brand p { font-size:0.88rem; color:rgba(255,255,255,0.4); max-width:260px; }
.footer-nav { display:flex; flex-direction:column; gap:12px; }
.footer-nav h4 { font-size:0.75rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; color:rgba(255,255,255,0.3); margin-bottom:4px; }
.footer-nav a { font-size:0.88rem; color:rgba(255,255,255,0.55); text-decoration:none; transition:var(--transition); }
.footer-nav a:hover { color:#fff; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding:24px 0; }
.footer-bottom p { font-size:0.8rem; color:rgba(255,255,255,0.25); }

/* ===== ANIMATIONS ===== */
[data-animate] { opacity:0; transform:translateY(28px); transition:opacity 0.6s ease, transform 0.6s ease; }
[data-animate="fade-left"] { transform:translateX(28px); }
[data-animate].visible { opacity:1; transform:translate(0); }

/* ===== RESPONSIVE ===== */
@media (max-width:1024px) {
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .service-card--wide { grid-column:span 2; }
  .faq-inner { grid-template-columns:1fr; gap:40px; }
  .faq .section-header { text-align:center; }
}
@media (max-width:900px) {
  .hero-container { grid-template-columns:1fr; text-align:center; }
  .hero-subheadline { max-width:100%; }
  .hero-actions { justify-content:center; }
  .hero-stats { justify-content:center; }
  .hero-visual { max-width:480px; margin:0 auto; }
  .steps-grid { grid-template-columns:1fr; }
  .steps-grid::before { display:none; }
  .testimonials-grid { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
  .nav-container { justify-content:space-between; }
  .nav-links, .nav-cta { display:none; }
  .hamburger { display:flex; }
  .badge { display:none; }
  
  .hero-content { min-width: 0; }
  .hero-actions .btn-lg { padding: 14px 20px; font-size: 0.9rem; }
  .hero-actions .btn-ghost { padding: 12px 20px; font-size: 0.9rem; }
  .hero-stats { gap: 8px; padding: 16px 12px; width: 100%; box-sizing: border-box; }
  .stat-item strong { font-size: 1.15rem; }
  .stat-item span { font-size: 0.65rem; }

  .services-grid { grid-template-columns:1fr; }
  .service-card { padding:24px 20px; }
  .service-card--wide { grid-column:span 1; flex-direction:column; gap:20px; }
  .service-content-left { flex:none; width:100%; }
  
  /* SaaS Dashboard Mobile Fixes */
  .saas-dashboard-mockup { height:auto; min-height:400px; width:100%; border-radius:8px; }
  .saas-topbar { padding:10px 12px; height:auto; }
  .saas-search { display:none; }
  .saas-content { padding:12px; gap:16px; }
  .saas-kpi-row { display:flex; overflow-x:auto; padding-bottom:6px; scrollbar-width:none; -ms-overflow-style:none; }
  .saas-kpi-row::-webkit-scrollbar { display:none; }
  .saas-kpi { min-width:130px; flex-shrink:0; }
  .saas-table-wrapper { overflow-x:auto; }
  .saas-table-row { min-width:320px; }
  
  .footer-inner { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; gap:8px; text-align:center; }
}
