/* ================================================================
   NEOFLOW — Design System v3
   Premium Light Theme | Three.js + GSAP ready
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ─── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font);background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.6}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}
ul,ol{list-style:none}

/* ─── Tokens ─────────────────────────────────────────────────── */
:root {
  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  /* Backgrounds */
  --bg:        #FFFFFF;
  --bg-soft:   #EEF0FF;
  --bg-alt:    #F5F6FF;
  --bg-muted:  #E6E9FF;

  /* Brand */
  --primary:        #313ADF;
  --primary-h:      #2530C4;
  --primary-light:  #DDE0FF;
  --primary-glow:   rgba(49,58,223,.2);
  --purple:         #6B21E8;
  --navy:           #040741;

  /* Text */
  --text:   #08103A;
  --text-2: #4B5568;
  --text-3: #6B7280;

  /* Borders */
  --border:   rgba(49,58,223,.15);
  --border-2: rgba(49,58,223,.3);

  /* Gradients */
  --grad-primary: linear-gradient(135deg,#313ADF 0%,#6B21E8 100%);
  --grad-soft:    linear-gradient(135deg,#ECEEFF 0%,#F0EBFF 100%);

  /* Shadows */
  --s-xs: 0 1px 4px rgba(4,7,65,.08);
  --s-sm: 0 4px 16px rgba(4,7,65,.11);
  --s-md: 0 12px 36px rgba(4,7,65,.13);
  --s-lg: 0 28px 64px rgba(4,7,65,.15);
  --s-xl: 0 48px 100px rgba(4,7,65,.18);
  --glow: 0 0 40px rgba(49,58,223,.18),0 0 80px rgba(49,58,223,.08);

  /* Radius */
  --r-sm:  8px;
  --r-md:  14px;
  --r-lg:  20px;
  --r-xl:  28px;
  --r-2xl: 40px;
  --r-full: 999px;

  /* Transitions */
  --t-fast:   150ms cubic-bezier(.4,0,.2,1);
  --t-base:   260ms cubic-bezier(.4,0,.2,1);
  --t-slow:   450ms cubic-bezier(.4,0,.2,1);
  --t-spring: 600ms cubic-bezier(.34,1.56,.64,1);
}

/* ─── Typography ─────────────────────────────────────────────── */
h1,h2,h3,h4 { font-weight:900; line-height:1.05; letter-spacing:-.04em; color:var(--text); }
h1 { font-size:clamp(3rem,6.5vw,5.6rem); }
h2 { font-size:clamp(2.1rem,4vw,3.6rem); }
h3 { font-size:clamp(1.15rem,2vw,1.5rem); }
p  { color:var(--text-2); line-height:1.72; }
strong { color:var(--text); font-weight:700; }

/* ─── Layout ─────────────────────────────────────────────────── */
.container { max-width:1180px; margin:0 auto; padding:0 28px; }
.container--sm { max-width:720px; }
section { padding:96px 0; }

/* ─── Utility ────────────────────────────────────────────────── */
.eyebrow {
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:var(--primary); margin-bottom:16px;
  padding:4px 12px; background:var(--primary-light); border-radius:var(--r-full);
  border:1px solid var(--border-2);
}
.grad-text {
  background:var(--grad-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

/* ─── Buttons ────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:14px;
  letter-spacing:-.01em; border-radius:var(--r-full); padding:12px 24px;
  transition:all var(--t-base); cursor:pointer; border:none; white-space:nowrap;
}
.btn-primary { background:var(--primary); color:#fff; }
.btn-primary:hover {
  background:var(--primary-h); transform:translateY(-1px);
  box-shadow:0 4px 20px var(--primary-glow),0 0 0 3px rgba(49,58,223,.12);
}
.btn-white {
  background:#fff; color:var(--text);
  box-shadow:var(--s-sm); border:1.5px solid var(--border);
}
.btn-white:hover { box-shadow:var(--s-md); transform:translateY(-1px); border-color:var(--border-2); }
.btn-ghost {
  background:var(--primary-light); color:var(--primary); border:1.5px solid var(--border-2);
}
.btn-ghost:hover { background:#E0E3FF; }
.btn-outline-dark {
  background:transparent; color:var(--text); border:1.5px solid rgba(8,16,58,.15);
}
.btn-outline-dark:hover { border-color:rgba(8,16,58,.3); background:rgba(8,16,58,.03); }
.btn-outline-white {
  background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.3);
}
.btn-outline-white:hover { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.55); }
.btn--lg { font-size:15px; padding:15px 32px; }
.btn--sm { font-size:13px; padding:9px 18px; }
.btn svg { transition:transform var(--t-base); }
.btn:hover svg.arrow { transform:translateX(3px); }

/* ─── Navbar ─────────────────────────────────────────────────── */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background var(--t-base),box-shadow var(--t-base);
}
.navbar__inner {
  max-width:1180px; margin:0 auto; padding:0 28px; height:68px;
  display:flex; align-items:center; justify-content:space-between;
}
.navbar--light { background:transparent; }
.navbar--light.scrolled {
  background:rgba(255,255,255,.9); backdrop-filter:blur(20px) saturate(200%);
  box-shadow:0 1px 0 var(--border);
}
.navbar--dark { background:transparent; }
.navbar--dark.scrolled {
  background:rgba(4,7,65,.96); backdrop-filter:blur(20px);
  box-shadow:0 1px 0 rgba(255,255,255,.07);
}

/* Logo */
.nav-logo { display:flex; align-items:center; gap:10px; font-weight:800; font-size:17px; letter-spacing:-.025em; }
.nav-logo img { height:36px; width:auto; }
.nav-logo-text { color:var(--text); }
.nav-logo-text span { color:var(--primary); }
.nav-logo-text--white { color:#fff; }
.nav-logo-text--white span { color:#818CF8; }

/* Links */
.nav-links { display:flex; align-items:center; gap:4px; }
.nav-link { font-size:14px; font-weight:500; padding:8px 14px; border-radius:var(--r-sm); transition:all var(--t-fast); color:var(--text-2); }
.nav-link:hover { color:var(--primary); background:var(--primary-light); }
.nav-link--white { color:rgba(255,255,255,.65); }
.nav-link--white:hover { color:#fff; background:rgba(255,255,255,.1); }

.nav-actions { display:flex; align-items:center; gap:10px; }
.nav-burger { display:none; align-items:center; padding:8px; border-radius:var(--r-sm); }
.nav-burger--light { color:var(--text); }
.nav-burger--light:hover { background:var(--bg-muted); }
.nav-burger--dark { color:#fff; }
.nav-burger--dark:hover { background:rgba(255,255,255,.1); }

/* ─── Mobile nav overlay ─────────────────────────────────────── */
.mobile-nav {
  position:fixed; inset:0; z-index:200; display:none; flex-direction:column;
  padding:28px; background:rgba(4,7,65,.98); backdrop-filter:blur(24px);
}
.mobile-nav.open { display:flex; }
.mobile-nav__head { display:flex; justify-content:space-between; align-items:center; margin-bottom:48px; }
.mobile-nav__close { color:#fff; background:rgba(255,255,255,.1); border-radius:10px; padding:10px; }
.mobile-nav a { color:rgba(255,255,255,.6); font-size:22px; font-weight:800; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.07); display:block; }
.mobile-nav a:hover { color:#fff; }
.mobile-nav__cta { margin-top:auto; }

/* ─── Hero ───────────────────────────────────────────────────── */
.hero {
  min-height:100vh; display:flex; align-items:center;
  padding:140px 0 100px; position:relative; overflow:hidden;
  background:linear-gradient(145deg,#E3E8FF 0%,#EAE5FF 38%,#F5F0FF 68%,#FAFBFF 100%);
}
/* Vibrant radial overlays */
.hero::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(ellipse 65% 60% at 10% 20%, rgba(49,58,223,.22) 0%, transparent 55%),
    radial-gradient(ellipse 55% 70% at 88% 8%, rgba(107,33,232,.15) 0%, transparent 55%),
    radial-gradient(ellipse 50% 50% at 55% 96%, rgba(49,58,223,.1) 0%, transparent 55%);
}

/* Three.js canvas wrapper */
.canvas-wrap { position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:0; }
.canvas-wrap canvas { width:100% !important; height:100% !important; display:block; }

/* Animated blobs */
.blob { position:absolute; border-radius:50%; pointer-events:none; filter:blur(72px); }
.blob--1 { width:600px; height:600px; top:-180px; left:-120px; background:radial-gradient(circle, rgba(49,58,223,.2) 0%, transparent 70%); animation:blobDrift1 14s ease-in-out infinite; }
.blob--2 { width:520px; height:520px; top:-90px; right:-70px; background:radial-gradient(circle, rgba(107,33,232,.16) 0%, transparent 70%); animation:blobDrift2 18s ease-in-out infinite; }
.blob--3 { width:400px; height:400px; bottom:-40px; left:45%; background:radial-gradient(circle, rgba(49,58,223,.1) 0%, transparent 70%); animation:blobDrift3 11s ease-in-out infinite; }
@keyframes blobDrift1 { 0%,100%{transform:translate(0,0)} 33%{transform:translate(22px,-14px)} 66%{transform:translate(-16px,20px)} }
@keyframes blobDrift2 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-28px,22px)} }
@keyframes blobDrift3 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(16px,-22px)} }

/* Hero grid layout */
.hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; position:relative; z-index:1; }
.hero-tag {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--primary-light); border:1px solid var(--border-2); border-radius:var(--r-full);
  padding:5px 14px 5px 8px; font-size:11px; font-weight:700; letter-spacing:.08em;
  text-transform:uppercase; color:var(--primary); margin-bottom:24px;
}
.hero-tag .dot { width:6px; height:6px; border-radius:50%; background:var(--primary); animation:pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(1.3)} }
.hero-h1 { margin-bottom:20px; }
.hero-sub { font-size:1.1rem; color:var(--text-2); line-height:1.7; max-width:480px; margin-bottom:36px; }
.hero-actions { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.hero-trust { margin-top:28px; display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text-3); }
.hero-trust-sep { height:1px; width:20px; background:var(--border-2); }

/* ─── Floating hero visual ───────────────────────────────────── */
.hero-visual { position:relative; z-index:1; }
.hero-visual-inner { position:relative; }
.floating-chip {
  position:absolute; background:#fff; border:1px solid var(--border); border-radius:var(--r-md);
  box-shadow:var(--s-md); padding:10px 14px; white-space:nowrap;
}
.floating-chip__label { font-size:9px; font-weight:600; color:var(--text-3); text-transform:uppercase; letter-spacing:.07em; margin-bottom:2px; }
.floating-chip__val { font-size:13px; font-weight:800; color:var(--text); }

/* ─── App mockup (CSS illustrated, no screenshots) ───────────── */
.app-mockup {
  background:#fff; border-radius:var(--r-xl); border:1px solid var(--border);
  box-shadow:var(--s-xl); overflow:hidden;
}
.app-topbar {
  background:#F7F8FC; height:36px; display:flex; align-items:center;
  padding:0 12px; gap:8px; border-bottom:1px solid var(--border); flex-shrink:0;
}
.app-dots { display:flex; gap:5px; }
.app-dot { width:10px; height:10px; border-radius:50%; }
.app-dot--r { background:#FF5F57; }
.app-dot--y { background:#FFBD2E; }
.app-dot--g { background:#28C940; }
.app-addr {
  flex:1; background:rgba(0,0,0,.05); border-radius:5px; height:20px;
  font-size:10px; color:var(--text-3); display:flex; align-items:center; padding:0 8px;
}
.app-body { display:flex; min-height:240px; }
.app-sidebar {
  width:44px; background:var(--navy); display:flex; flex-direction:column;
  align-items:center; padding:10px 0; gap:7px; flex-shrink:0;
}
.app-sidebar-icon { width:24px; height:24px; border-radius:7px; background:rgba(255,255,255,.08); }
.app-sidebar-icon.active { background:var(--primary); }
.app-main { flex:1; padding:12px; background:#F7F8FC; display:flex; flex-direction:column; gap:8px; overflow:hidden; }

/* KPI row */
.kpi-row { display:grid; grid-template-columns:repeat(3,1fr); gap:7px; }
.kpi-card { background:#fff; border:1px solid var(--border); border-radius:var(--r-sm); padding:9px 11px; }
.kpi-label { font-size:8.5px; color:var(--text-3); font-weight:600; text-transform:uppercase; letter-spacing:.05em; }
.kpi-value { font-size:13px; font-weight:800; color:var(--text); letter-spacing:-.02em; margin:2px 0; }
.kpi-trend { font-size:8.5px; font-weight:700; }
.kpi-trend--up { color:#16A34A; }
.kpi-trend--neutral { color:var(--text-3); }

/* Bar chart */
.mini-chart { background:#fff; border:1px solid var(--border); border-radius:var(--r-sm); padding:9px 11px; flex:1; }
.chart-title { font-size:9px; font-weight:700; color:var(--text); margin-bottom:7px; }
.chart-bars { display:flex; align-items:flex-end; gap:4px; height:52px; }
.chart-bar { flex:1; border-radius:3px 3px 0 0; background:var(--primary-light); min-height:6px; }
.chart-bar--active { background:var(--primary); }

/* Order list */
.order-tabs { display:flex; gap:0; padding:0 12px; background:#fff; border-bottom:1px solid var(--border); }
.order-tab { font-size:10px; font-weight:600; color:var(--text-3); padding:8px 8px; border-bottom:2px solid transparent; }
.order-tab.active { color:var(--primary); border-bottom-color:var(--primary); }
.order-row { display:flex; align-items:center; gap:8px; padding:9px 12px; border-bottom:1px solid var(--border); background:#fff; }
.order-row:last-child { border-bottom:none; }
.order-name { font-size:11px; font-weight:700; color:var(--text); flex:1; }
.order-sub { font-size:9.5px; color:var(--text-3); }
.order-amount { font-size:11px; font-weight:700; color:var(--text); }
.status-badge { font-size:9px; font-weight:700; border-radius:5px; padding:2px 6px; text-transform:uppercase; letter-spacing:.04em; }
.status-badge--pending { background:rgba(234,179,8,.1); color:#92400E; }
.status-badge--ok { background:rgba(22,163,74,.1); color:#166534; }
.status-badge--new { background:rgba(49,58,223,.1); color:var(--primary); }

/* Kanban */
.kanban-wrap { display:flex; gap:7px; padding:12px; background:#F7F8FC; overflow:hidden; }
.kanban-col { background:var(--bg-muted); border-radius:var(--r-sm); padding:8px; flex:1; min-width:0; }
.kanban-col-head { font-size:8.5px; font-weight:700; color:var(--text-3); text-transform:uppercase; letter-spacing:.08em; margin-bottom:5px; }
.kanban-card { background:#fff; border:1px solid var(--border); border-radius:6px; padding:7px 8px; margin-bottom:5px; font-size:10px; font-weight:700; color:var(--text); }
.kanban-card .sub { font-size:9px; color:var(--text-3); font-weight:400; margin-top:2px; }
.kanban-card--active { border-left:2px solid var(--primary); }
.kanban-card--done { opacity:.5; }

/* Invoice */
.invoice-preview { padding:18px; background:#fff; }
.invoice-head { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:14px; }
.invoice-logo-box { width:30px; height:30px; border-radius:7px; background:var(--primary); display:flex; align-items:center; justify-content:center; font-size:10px; font-weight:900; color:#fff; }
.invoice-title { font-size:13px; font-weight:900; color:var(--text); letter-spacing:-.02em; }
.invoice-num { font-size:9.5px; color:var(--text-3); margin-top:2px; }
.invoice-divider { height:1px; background:var(--border); margin:10px 0; }
.invoice-client-label { font-size:8.5px; color:var(--text-3); text-transform:uppercase; letter-spacing:.08em; font-weight:600; }
.invoice-client-name { font-size:11px; font-weight:800; color:var(--text); margin-top:2px; }
.invoice-line { display:flex; justify-content:space-between; padding:5px 0; border-bottom:1px solid var(--border); font-size:10px; }
.invoice-line:last-child { border-bottom:none; }
.invoice-line span { color:var(--text-2); }
.invoice-line strong { color:var(--text); font-weight:700; }
.invoice-total-row { display:flex; justify-content:space-between; padding:8px 0 0; font-size:12px; font-weight:800; color:var(--text); }

/* ─── Screenshot frame ───────────────────────────────────────── */
.screen-frame {
  border-radius:var(--r-lg); overflow:hidden;
  border:1px solid var(--border); box-shadow:var(--s-xl); background:#fff;
}
.screen-frame__bar {
  background:#f0f1f5; padding:9px 14px;
  display:flex; align-items:center; gap:10px;
  border-bottom:1px solid rgba(0,0,0,.06);
}
.screen-frame__dots { display:flex; gap:5px; flex-shrink:0; }
.screen-frame__dots span { width:10px; height:10px; border-radius:50%; }
.screen-frame__dots span:nth-child(1) { background:#fe5f57; }
.screen-frame__dots span:nth-child(2) { background:#febc2e; }
.screen-frame__dots span:nth-child(3) { background:#28c840; }
.screen-frame__url {
  flex:1; font-size:11px; color:#888; background:#fff;
  border:1px solid rgba(0,0,0,.08); border-radius:5px;
  padding:3px 10px; text-align:center;
  max-width:280px; margin:0 auto; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.screen-frame img { width:100%; display:block; }

/* Chat */
.chat-wrap { padding:12px; background:#fff; display:flex; flex-direction:column; gap:8px; min-height:200px; }
.chat-hdr { display:flex; align-items:center; gap:8px; padding-bottom:10px; border-bottom:1px solid var(--border); }
.chat-avatar { width:26px; height:26px; border-radius:50%; background:var(--grad-primary); display:flex; align-items:center; justify-content:center; font-size:10px; font-weight:800; color:#fff; flex-shrink:0; }
.chat-name-mock { font-size:11px; font-weight:800; color:var(--text); }
.chat-online { font-size:9px; color:#16A34A; font-weight:600; }
.chat-msgs { display:flex; flex-direction:column; gap:6px; }
.chat-bubble { max-width:88%; padding:7px 10px; border-radius:10px; font-size:10.5px; line-height:1.5; }
.chat-bubble--bot { background:var(--bg-muted); color:var(--text-2); border-radius:3px 10px 10px 10px; align-self:flex-start; }
.chat-bubble--user { background:var(--primary); color:#fff; border-radius:10px 3px 10px 10px; align-self:flex-end; }

/* ─── Section head ───────────────────────────────────────────── */
.sec-head { max-width:620px; margin:0 auto; text-align:center; margin-bottom:56px; }
.sec-head--left { margin:0 0 56px; text-align:left; }
.sec-head .intro { margin-top:16px; font-size:1.05rem; color:var(--text-2); line-height:1.72; }

/* ─── Stats strip ────────────────────────────────────────────── */
.stats-strip { background:var(--navy); padding:44px 0; position:relative; overflow:hidden; }
.stats-strip::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 80% 100% at 50% 50%, rgba(49,58,223,.25) 0%, transparent 65%); pointer-events:none; }
.stats-strip__row { display:flex; justify-content:center; position:relative; }
.stats-strip__item { flex:1; text-align:center; padding:12px 32px; border-right:1px solid rgba(255,255,255,.08); }
.stats-strip__item:last-child { border-right:none; }
.stats-strip__num { font-size:2.6rem; font-weight:900; color:#fff; letter-spacing:-.05em; display:block; line-height:1; }
.stats-strip__lbl { font-size:13px; color:rgba(255,255,255,.5); margin-top:6px; font-weight:500; }

/* ─── Section brand (dark navy) ──────────────────────────────── */
.section--brand {
  background:var(--navy); position:relative; overflow:hidden;
}
.section--brand::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(ellipse 55% 65% at 15% 50%, rgba(49,58,223,.2) 0%, transparent 60%),
    radial-gradient(ellipse 45% 55% at 85% 15%, rgba(107,33,232,.14) 0%, transparent 60%);
}
.section--brand > * { position:relative; }
.section--brand .eyebrow { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.14); color:rgba(255,255,255,.8); }
.section--brand h2 { color:#fff; }
.section--brand .grad-text { background:linear-gradient(135deg,#818CF8 0%,#C084FC 100%); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.section--brand .intro { color:rgba(255,255,255,.58); }
.section--brand p { color:rgba(255,255,255,.58); }
.section--brand strong { color:#fff; }

/* ─── Cards ──────────────────────────────────────────────────── */
.card { background:#fff; border:1.5px solid var(--border); border-radius:var(--r-lg); padding:32px; box-shadow:var(--s-sm); transition:box-shadow var(--t-base),transform var(--t-base),border-color var(--t-base); }
.card:hover { box-shadow:var(--s-md); transform:translateY(-3px); border-color:var(--border-2); }

/* Service cards */
.service-card {
  background:#fff; border:1.5px solid var(--border); border-radius:var(--r-xl);
  padding:40px 32px; transition:all var(--t-base);
  box-shadow:var(--s-sm); position:relative; overflow:hidden;
}
.service-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--grad-primary); opacity:.7;
}
.service-card:hover { box-shadow:var(--s-lg); transform:translateY(-5px); border-color:var(--border-2); }
.service-card:hover::before { opacity:1; }
.service-card h3 { font-size:1.12rem; font-weight:900; color:var(--text); margin:20px 0 12px; letter-spacing:-.025em; }
.service-card p { font-size:14.5px; color:var(--text-2); line-height:1.68; }

/* Icon box */
.icon-box { width:48px; height:48px; border-radius:var(--r-md); background:var(--primary-light); border:1.5px solid var(--border-2); display:flex; align-items:center; justify-content:center; color:var(--primary); flex-shrink:0; }
.icon-box--lg { width:56px; height:56px; border-radius:var(--r-lg); }

/* ─── Feature sections ───────────────────────────────────────── */
.features-wrap { padding-top:0; }
.feature-section { padding:72px 0; border-bottom:1px solid var(--border); }
.feature-section:last-child { border-bottom:none; padding-bottom:0; }
.feature-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.feature-grid--flip .feature-visual { order:-1; }
.feature-num { font-size:5.5rem; font-weight:900; line-height:1; color:rgba(49,58,223,.06); letter-spacing:-.08em; margin-bottom:-10px; display:block; }
.feature-title { font-size:clamp(1.4rem,2.5vw,1.9rem); font-weight:900; color:var(--text); letter-spacing:-.03em; line-height:1.1; margin-bottom:14px; }
.feature-desc { font-size:1rem; color:var(--text-2); line-height:1.72; margin-bottom:22px; }
.feature-list { display:flex; flex-direction:column; gap:10px; }
.feature-list li { display:flex; align-items:center; gap:10px; font-size:14px; color:var(--text); font-weight:500; }
.feature-list li .chk {
  width:18px; height:18px; border-radius:50%; flex-shrink:0;
  background:var(--primary-light); border:1.5px solid var(--border-2);
  display:flex; align-items:center; justify-content:center;
}

/* ─── Comparison (Avant/Après) ───────────────────────────────── */
.compare-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.compare-col { border-radius:var(--r-xl); padding:36px 32px; }
.compare-col--before { background:#fff; border:1.5px solid var(--border-2); box-shadow:var(--s-sm); }
.compare-col--after { background:linear-gradient(145deg,var(--primary) 0%,#1A23B8 100%); }
.compare-label { font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; display:flex; align-items:center; gap:10px; margin-bottom:28px; }
.compare-col--before .compare-label { color:var(--text-3); }
.compare-col--after .compare-label { color:rgba(255,255,255,.5); }
.compare-label::before { content:''; width:20px; height:2px; border-radius:2px; }
.compare-col--before .compare-label::before { background:var(--text-3); }
.compare-col--after .compare-label::before { background:rgba(255,255,255,.4); }
.compare-item { display:flex; align-items:flex-start; gap:12px; padding:11px 0; border-bottom:1px solid rgba(0,0,0,.05); }
.compare-col--after .compare-item { border-bottom-color:rgba(255,255,255,.07); }
.compare-item:last-child { border-bottom:none; }
.compare-dot { width:20px; height:20px; border-radius:50%; flex-shrink:0; margin-top:2px; display:flex; align-items:center; justify-content:center; }
.compare-col--before .compare-dot { background:rgba(239,68,68,.07); }
.compare-col--after .compare-dot { background:rgba(16,185,129,.15); }
.compare-item p { font-size:14px; line-height:1.55; }
.compare-col--before .compare-item p { color:var(--text-2); }
.compare-col--after .compare-item p { color:rgba(255,255,255,.72); }
.compare-col--after .compare-item strong { color:#fff; }

/* ─── Pour qui ───────────────────────────────────────────────── */
.pq-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; margin-top:48px; background:var(--border-2); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--s-md); border:1.5px solid var(--border-2); }
.pq-card { padding:36px 28px; background:#fff; transition:all var(--t-base); }
.pq-card:hover { background:var(--primary-light); }
.pq-card h3 { font-size:1rem; font-weight:800; color:var(--text); margin:18px 0 10px; letter-spacing:-.02em; }
.pq-card p { font-size:14px; color:var(--text-2); line-height:1.6; }
.pq-not { margin-top:28px; text-align:center; font-size:14px; color:var(--text-3); }
.pq-not strong { color:var(--text-2); }

/* ─── Situations ─────────────────────────────────────────────── */
.situ-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.situ-card { padding:32px; border-radius:var(--r-lg); background:#fff; border:1.5px solid var(--border); box-shadow:var(--s-sm); transition:all var(--t-base); }
.situ-card:hover { box-shadow:var(--s-md); transform:translateY(-2px); border-color:var(--border-2); }
.situ-head { display:flex; align-items:center; gap:14px; margin-bottom:12px; }
.situ-card h3 { font-size:.95rem; font-weight:800; color:var(--text); letter-spacing:-.02em; }
.situ-card p { font-size:14px; color:var(--text-2); line-height:1.65; }

/* ─── Process ────────────────────────────────────────────────── */
.process-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:52px;
  position:relative;
}
.process-grid::before {
  content:''; position:absolute; top:24px; left:14%; right:14%; height:1.5px;
  background:linear-gradient(90deg,transparent,var(--primary) 20%,var(--purple) 80%,transparent);
  opacity:.16; pointer-events:none; z-index:0;
}
.process-step {
  background:#fff; padding:36px 24px; border-radius:var(--r-lg);
  border:1.5px solid var(--border); position:relative; z-index:1;
  transition:box-shadow var(--t-base),transform var(--t-base),border-color var(--t-base);
}
.process-step:hover { border-color:var(--border-2); box-shadow:var(--s-md); transform:translateY(-3px); }
.process-step__num {
  width:48px; height:48px; border-radius:50%;
  background:linear-gradient(135deg,var(--primary) 0%,#1A23B8 100%);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; font-weight:900; color:#fff; letter-spacing:-.01em;
  margin-bottom:18px; box-shadow:0 6px 18px rgba(49,58,223,.28);
}
.process-step__title { font-size:1rem; font-weight:800; color:var(--text); margin-bottom:8px; letter-spacing:-.02em; }
.process-step__desc { font-size:13.5px; color:var(--text-2); line-height:1.6; }

/* ─── Forms ──────────────────────────────────────────────────── */
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-label { font-size:13px; font-weight:600; color:var(--text); letter-spacing:-.01em; }
.form-input {
  font-family:var(--font); font-size:14px; color:var(--text);
  background:#fff; border:1.5px solid var(--border);
  border-radius:var(--r-md); padding:11px 14px;
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
  outline:none; width:100%;
}
.form-input:focus { border-color:var(--primary); box-shadow:0 0 0 3px rgba(49,58,223,.1); }
.form-input::placeholder { color:var(--text-3); }
.form-textarea { resize:vertical; min-height:130px; line-height:1.6; }
.form-select {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 14px center; padding-right:36px;
}

/* ─── Pricing ────────────────────────────────────────────────── */
.price-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; max-width:860px; margin:0 auto; }
.price-card-label { font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--text-3); margin-bottom:6px; display:block; }
.price-badge { display:inline-block; background:linear-gradient(135deg,var(--primary) 0%,var(--purple) 100%); color:#fff; font-size:10px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; border-radius:6px; padding:3px 10px; margin-bottom:6px; }
.price-card {
  background:#fff; border:1.5px solid var(--border-2); border-radius:var(--r-2xl);
  padding:48px 40px; box-shadow:var(--s-md); position:relative; overflow:hidden;
}
.price-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--grad-primary); opacity:.5; }
.price-card--highlight { border-color:var(--primary); box-shadow:var(--s-xl),0 0 0 1.5px var(--primary); }
.price-card--highlight::before { opacity:1; }
.price-amount { display:flex; align-items:flex-start; gap:4px; margin:8px 0; }
.price-cur { font-size:1.5rem; font-weight:800; color:var(--primary); padding-top:10px; }
.price-val { font-size:4.8rem; font-weight:900; color:var(--text); line-height:1; letter-spacing:-.06em; }
.price-per { font-size:14px; color:var(--text-3); align-self:flex-end; padding-bottom:10px; }
.price-sub { font-size:13px; color:var(--text-3); margin-bottom:32px; }
.price-features { display:flex; flex-direction:column; margin-bottom:32px; }
.price-feat { display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--border); font-size:14px; color:var(--text-2); font-weight:500; }
.price-feat:last-child { border-bottom:none; }
.price-chk { width:20px; height:20px; border-radius:50%; flex-shrink:0; background:rgba(22,163,74,.1); border:1.5px solid rgba(22,163,74,.3); display:flex; align-items:center; justify-content:center; }

.launch-banner { display:flex; align-items:center; gap:14px; flex-wrap:wrap; background:linear-gradient(90deg,var(--primary-light),#F0EBFF); border:1.5px solid var(--border-2); border-radius:var(--r-md); padding:14px 20px; margin-bottom:40px; }
.launch-badge { background:var(--primary); color:#fff; font-size:10px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; border-radius:6px; padding:4px 10px; white-space:nowrap; }
.launch-text { font-size:14px; color:var(--text); font-weight:600; flex:1; }
.launch-text span { color:var(--text-3); font-weight:400; }

/* ─── CTA sections ───────────────────────────────────────────── */
.cta-break {
  background:linear-gradient(135deg,var(--primary) 0%,#1A23B8 55%,var(--purple) 100%);
  padding:88px 0; text-align:center; position:relative; overflow:hidden;
}
.cta-break::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 80% at 50% 50%, rgba(255,255,255,.07) 0%, transparent 65%); }
.cta-break h2 { color:#fff; position:relative; }
.cta-break p { color:rgba(255,255,255,.58); position:relative; margin-top:14px; font-size:1.05rem; }
.cta-break .cta-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative; margin-top:36px; }

.final-cta { background:var(--navy); padding:112px 0; text-align:center; position:relative; overflow:hidden; }
.final-cta::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 65% 70% at 50% 50%, rgba(49,58,223,.22) 0%, transparent 65%); }
.final-cta h2 { color:#fff; position:relative; }
.final-cta h2 em { font-style:normal; color:#818CF8; }
.final-cta p { color:rgba(255,255,255,.5); position:relative; margin-top:14px; }
.final-cta .cta-row { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; position:relative; margin-top:40px; }
.final-note { margin-top:24px; font-size:13px; color:rgba(255,255,255,.25); position:relative; }

/* ─── Sticky CTA bar ─────────────────────────────────────────── */
#stickyCta {
  position:fixed; bottom:0; left:0; right:0; z-index:99;
  background:rgba(255,255,255,.94); backdrop-filter:blur(20px) saturate(200%);
  border-top:1px solid var(--border); box-shadow:0 -8px 40px rgba(4,7,65,.08);
  padding:14px 28px; display:flex; align-items:center; justify-content:space-between; gap:16px;
  transform:translateY(100%); transition:transform var(--t-slow);
}
#stickyCta.visible { transform:translateY(0); }
#stickyCta .sc-text { font-size:14px; font-weight:600; color:var(--text); }
#stickyCta .sc-text span { color:var(--text-3); font-weight:400; }
#stickyCta .sc-actions { display:flex; gap:10px; }

/* ─── FAQ ────────────────────────────────────────────────────── */
.faq-list { max-width:720px; margin:0 auto; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-btn { width:100%; text-align:left; padding:22px 0; display:flex; align-items:center; justify-content:space-between; gap:16px; font-size:15px; font-weight:700; color:var(--text); }
.faq-btn svg { flex-shrink:0; color:var(--primary); transition:transform var(--t-base); }
.faq-btn.open svg { transform:rotate(45deg); }
.faq-answer { font-size:14.5px; color:var(--text-2); line-height:1.75; padding:0 0 22px; display:none; }
.faq-answer.open { display:block; }

/* ─── Footer ─────────────────────────────────────────────────── */
.footer { background:var(--navy); padding:64px 0 36px; }
.footer__inner { display:grid; grid-template-columns:1.5fr repeat(3,1fr); gap:40px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.07); }
.footer__brand p { font-size:14px; color:rgba(255,255,255,.38); line-height:1.65; margin-top:14px; max-width:260px; }
.footer__col h4 { font-size:11px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.3); margin-bottom:18px; }
.footer__col a { display:block; font-size:14px; color:rgba(255,255,255,.5); padding:5px 0; transition:color var(--t-fast); }
.footer__col a:hover { color:#fff; }
.footer__bottom { padding-top:28px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.footer__copy { font-size:12px; color:rgba(255,255,255,.22); }
.footer__logo-text { color:#fff; font-size:16px; font-weight:800; letter-spacing:-.025em; }
.footer__logo-text span { color:#818CF8; }

/* ─── Animations ─────────────────────────────────────────────── */
.reveal { opacity:0; transform:translateY(20px); transition:opacity .42s cubic-bezier(.4,0,.2,1),transform .42s cubic-bezier(.4,0,.2,1); }
.reveal.from-left  { transform:translateX(-24px) translateY(0); }
.reveal.from-right { transform:translateX(24px) translateY(0); }
.reveal.visible    { opacity:1; transform:none; }

@keyframes float1 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
@keyframes float2 { 0%,100%{transform:translateY(0)} 50%{transform:translateY(10px)} }
@keyframes float3 { 0%,100%{transform:translateY(0) rotate(0deg)} 50%{transform:translateY(-8px) rotate(.8deg)} }
.float-1 { animation:float1 6s ease-in-out infinite; }
.float-2 { animation:float2 7.5s ease-in-out 1s infinite; }
.float-3 { animation:float3 9s ease-in-out 2s infinite; }

/* ─── Responsive ─────────────────────────────────────────────── */
@media (max-width:1024px) {
  .footer__inner { grid-template-columns:1fr 1fr; }
  .feature-grid { gap:48px; }
}

@media (max-width:768px) {
  section { padding:72px 0; }
  .container { padding:0 20px; }
  .nav-links,.nav-actions { display:none; }
  .nav-burger { display:flex; }
  .hero { padding:110px 0 64px; min-height:auto; }
  .hero-grid { grid-template-columns:1fr; gap:40px; }
  .hero-visual { display:none; }
  .hero-sub { max-width:100%; font-size:1rem; }
  .hero-actions { flex-direction:column; align-items:stretch; }
  .hero-actions .btn { width:100%; justify-content:center; }
  .hero-trust { flex-direction:column; gap:6px; text-align:center; }
  .hero-trust-sep { display:none; }
  .feature-grid,.feature-grid--flip { grid-template-columns:1fr; gap:36px; }
  .feature-grid--flip .feature-visual { order:0; }
  .compare-grid,.situ-grid { grid-template-columns:1fr; }
  .pq-grid { grid-template-columns:1fr; background:none; gap:2px; }
  .pq-card { border:1px solid var(--border); border-radius:var(--r-md); }
  .process-grid { grid-template-columns:1fr 1fr; }
  .process-grid::before { display:none; }
  .sec-head { margin-bottom:40px; }
  .stats-strip__item { border-right:none; border-bottom:1px solid rgba(255,255,255,.08); padding:16px 24px; }
  .stats-strip__item:last-child { border-bottom:none; }
  .price-grid { grid-template-columns:1fr; }
  .price-card { padding:36px 24px; }
  .footer__inner { grid-template-columns:1fr; gap:28px; }
  #stickyCta { flex-direction:column; text-align:center; padding:14px 20px; gap:10px; }
  #stickyCta .sc-actions { width:100%; justify-content:center; }
}

@media (max-width:480px) {
  h1 { font-size:2.2rem; }
  h2 { font-size:1.7rem; }
  .process-grid { grid-template-columns:1fr; }
  .btn--lg { font-size:14px; padding:13px 22px; }
  .cta-break,.final-cta { padding:64px 0; }
  .price-card { padding:28px 20px; }
  .sec-head { margin-bottom:28px; }
  .cta-card { padding:28px 20px; }
}

/* ─── Mobile UX improvements ─────────────────────────────────── */

/* Stats: 2×2 grid on mobile */
@media (max-width:640px) {
  .stats-strip__row { flex-wrap:wrap; }
  .stats-strip__item { flex:0 0 50%; border-right:1px solid var(--border); border-bottom:1px solid var(--border); padding:18px 16px; }
  .stats-strip__item:nth-child(2n) { border-right:none; }
  .stats-strip__item:nth-last-child(-n+2) { border-bottom:none; }
  .stats-strip__num { font-size:1.8rem; }
}

/* Sticky CTA bar: one-button on mobile */
@media (max-width:640px) {
  #stickyCta { padding:12px 16px; gap:0; }
  #stickyCta .sc-text { display:none; }
  #stickyCta .sc-actions { width:100%; }
  #stickyCta .sc-actions .btn:first-child { display:none; }
  #stickyCta .sc-actions .btn:last-child { width:100%; justify-content:center; font-size:15px; padding:15px; border-radius:var(--r-md); }
}

/* App mockup: KPI row on very small screens */
@media (max-width:480px) {
  .kpi-row { grid-template-columns:repeat(2,1fr); }
  .kpi-row .kpi-card:last-child { display:none; }
  .app-body { min-height:180px; }
  .chart-bars { height:42px; }
}

/* Feature visuals: ensure mockup/screenshot fits on mobile */
@media (max-width:768px) {
  .feature-visual { overflow:hidden; }
  .app-mockup, .screen-frame { max-width:100%; }
  .kanban-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .kanban-col { min-width:90px; }
}

/* Hero on mobile: tighten spacing */
@media (max-width:768px) {
  .hero { padding:110px 0 64px; }
  .hero-actions { flex-direction:column; }
  .hero-actions .btn { width:100%; justify-content:center; }
  .hero-trust { flex-direction:column; text-align:center; gap:6px; }
  .hero-trust .hero-trust-sep { display:none; }
}

/* CTA sections on mobile */
@media (max-width:640px) {
  .cta-break .cta-actions, .final-cta .cta-row { flex-direction:column; align-items:stretch; }
  .cta-break .cta-actions .btn, .final-cta .cta-row .btn { justify-content:center; }
}

/* ─── Value strip (quick benefits) ──────────────────────────── */
.value-strip {
  background:#fff; border-bottom:1px solid var(--border); padding:20px 0;
}
.value-strip__row {
  display:flex; align-items:center; justify-content:center;
  gap:0; flex-wrap:wrap;
}
.value-strip__item {
  display:flex; align-items:center; gap:8px;
  padding:10px 24px; border-right:1px solid var(--border);
  font-size:13.5px; font-weight:600; color:var(--text-2);
}
.value-strip__item:last-child { border-right:none; }
.value-strip__item svg { color:var(--primary); flex-shrink:0; }
@media (max-width:768px) {
  .value-strip__item { flex:1 1 50%; border-right:1px solid var(--border); border-bottom:1px solid var(--border); padding:12px 16px; font-size:13px; }
  .value-strip__item:nth-child(2n) { border-right:none; }
  .value-strip__item:nth-last-child(-n+2) { border-bottom:none; }
}
@media (max-width:480px) {
  .value-strip__item { flex:1 1 100%; border-right:none; border-bottom:1px solid var(--border); }
  .value-strip__item:last-child { border-bottom:none; }
}

/* ─── Urgency note ───────────────────────────────────────────── */
.urgency-note {
  display:flex; align-items:flex-start; gap:12px;
  background:linear-gradient(90deg,rgba(234,179,8,.08),rgba(234,179,8,.04));
  border:1.5px solid rgba(234,179,8,.3); border-radius:var(--r-md);
  padding:14px 18px; margin-bottom:28px;
}
.urgency-note svg { color:#d97706; flex-shrink:0; margin-top:2px; }
.urgency-note p { font-size:14px; color:var(--text-2); line-height:1.55; }
.urgency-note strong { color:var(--text); }

/* ─── Trust proof strip ──────────────────────────────────────── */
.trust-strip {
  display:flex; align-items:center; justify-content:center; gap:28px;
  flex-wrap:wrap; padding:20px 0; border-top:1px solid var(--border);
  margin-top:28px;
}
.trust-item {
  display:flex; align-items:center; gap:8px;
  font-size:13px; font-weight:600; color:var(--text-3);
}
.trust-item svg { color:var(--primary); }

/* ─── Services grid (responsive) ────────────────────────────── */
.services-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:24px;
}
@media (max-width:640px) {
  .services-grid { grid-template-columns:1fr; }
}

/* ─── Progress indicator ─────────────────────────────────────── */
.funnel-progress {
  display:flex; align-items:center; justify-content:center; gap:0;
  padding:16px 0; margin-bottom:8px;
}
.funnel-step {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  flex:1; max-width:140px; position:relative;
}
.funnel-step::after {
  content:''; position:absolute; top:12px; left:calc(50% + 14px); right:calc(-50% + 14px);
  height:1.5px; background:var(--border);
}
.funnel-step:last-child::after { display:none; }
.funnel-dot {
  width:24px; height:24px; border-radius:50%; background:var(--primary-light);
  border:1.5px solid var(--border-2); display:flex; align-items:center;
  justify-content:center; font-size:10px; font-weight:800; color:var(--primary);
  position:relative; z-index:1; background:#fff;
}
.funnel-dot.active { background:var(--primary); color:#fff; border-color:var(--primary); }
.funnel-dot.done { background:rgba(22,163,74,.1); border-color:rgba(22,163,74,.3); color:#16a34a; }
.funnel-lbl { font-size:10px; font-weight:600; color:var(--text-3); text-align:center; }
@media (max-width:640px) { .funnel-progress { display:none; } }

/* ─── CTA card (inline conversion block) ────────────────────── */
.cta-card {
  background:linear-gradient(135deg,var(--primary-light) 0%,#F0EBFF 100%);
  border:1.5px solid var(--border-2); border-radius:var(--r-xl);
  padding:40px; text-align:center;
}
.cta-card h3 { font-size:1.3rem; font-weight:900; color:var(--text); margin-bottom:12px; }
.cta-card p { font-size:14px; color:var(--text-2); margin-bottom:24px; }

/* ================================================================
   AGENCY DARK THEME
   Activated via <body class="agency"> on agency pages
   ================================================================ */

.agency {
  --ag-bg:        #07070F;
  --ag-bg-2:      #0C0C1C;
  --ag-bg-3:      #111128;
  --ag-surface:   #12122A;
  --ag-border:    rgba(255,255,255,.07);
  --ag-border-2:  rgba(255,255,255,.14);
  --ag-text:      #F0F0FF;
  --ag-text-2:    rgba(240,240,255,.58);
  --ag-text-3:    rgba(240,240,255,.32);
  --ag-accent:    #7C5CFC;
  --ag-accent-2:  #A78BFA;
  --ag-glow:      rgba(124,92,252,.28);
  --ag-grad:      linear-gradient(135deg, #7C5CFC 0%, #A78BFA 100%);
  --ag-s-sm:      0 4px 20px rgba(0,0,0,.4);
  --ag-s-md:      0 12px 40px rgba(0,0,0,.5);
  --ag-s-lg:      0 28px 72px rgba(0,0,0,.6);

  background: var(--ag-bg);
  color: var(--ag-text);
}

/* ── Agency typography ── */
.agency h1,
.agency h2,
.agency h3,
.agency h4 { color: var(--ag-text); }

.agency p { color: var(--ag-text-2); }

.agency .grad-text {
  background: var(--ag-grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.agency .eyebrow {
  background: rgba(124,92,252,.15);
  border-color: rgba(124,92,252,.3);
  color: var(--ag-accent-2);
}

/* ── Agency navbar ── */
.agency .navbar--light { background: transparent; }
.agency .navbar--light.scrolled {
  background: rgba(7,7,15,.9);
  backdrop-filter: blur(20px) saturate(180%);
  box-shadow: 0 1px 0 var(--ag-border);
}
.agency .nav-logo-text { color: var(--ag-text); }
.agency .nav-logo-text span { color: var(--ag-accent-2); }
.agency .nav-link { color: var(--ag-text-2); }
.agency .nav-link:hover { color: var(--ag-text); background: rgba(124,92,252,.12); }
.agency .nav-burger--light { color: var(--ag-text); }
.agency .nav-burger--light:hover { background: rgba(255,255,255,.08); }
.agency .btn-ghost { background: rgba(124,92,252,.12); color: var(--ag-accent-2); border-color: rgba(124,92,252,.25); }
.agency .btn-ghost:hover { background: rgba(124,92,252,.22); }
.agency .btn-primary { background: var(--ag-accent); }
.agency .btn-primary:hover { background: #6B4EE8; box-shadow: 0 6px 28px var(--ag-glow); }
.agency .btn-outline-dark { color: var(--ag-text); border-color: var(--ag-border-2); }
.agency .btn-outline-dark:hover { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.22); }

/* ── Agency hero ── */
.ag-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 140px 0 100px;
  position: relative;
  overflow: hidden;
  background: var(--ag-bg);
  text-align: center;
}
.ag-hero::before {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 70% 55% at 50% 0%, rgba(124,92,252,.18) 0%, transparent 60%),
    radial-gradient(ellipse 40% 40% at 15% 80%, rgba(124,92,252,.1) 0%, transparent 55%),
    radial-gradient(ellipse 50% 50% at 85% 75%, rgba(167,139,250,.08) 0%, transparent 55%);
}
.ag-hero-tag {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(124,92,252,.12); border: 1px solid rgba(124,92,252,.25);
  border-radius: var(--r-full); padding: 5px 14px 5px 8px;
  font-size: 11px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ag-accent-2); margin-bottom: 28px;
}
.ag-hero-tag .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ag-accent); animation: pulse 2s ease-in-out infinite;
}
.ag-hero-content { position: relative; z-index: 1; max-width: 860px; margin: 0 auto; }
.ag-hero h1 { margin-bottom: 24px; color: var(--ag-text); }
.ag-hero .hero-sub {
  font-size: 1.15rem; color: var(--ag-text-2); line-height: 1.72;
  max-width: 560px; margin: 0 auto 40px;
}
.ag-hero-actions {
  display: flex; align-items: center; justify-content: center;
  gap: 14px; flex-wrap: wrap; margin-bottom: 64px;
}
.ag-hero-trust {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; font-size: 13px; color: var(--ag-text-3);
}
.ag-hero-trust-sep { width: 20px; height: 1px; background: var(--ag-border-2); }
.ag-scroll-hint {
  position: absolute; bottom: 36px; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  color: var(--ag-text-3); font-size: 11px; font-weight: 600; letter-spacing: .1em;
  text-transform: uppercase; z-index: 1; animation: float2 3s ease-in-out infinite;
}
.ag-scroll-hint::after {
  content: '';
  width: 1px; height: 40px;
  background: linear-gradient(to bottom, var(--ag-accent-2), transparent);
}

/* ── Agency logos strip ── */
.ag-logos {
  padding: 28px 0;
  border-top: 1px solid var(--ag-border);
  border-bottom: 1px solid var(--ag-border);
  background: var(--ag-bg);
  overflow: hidden;
}
.ag-logos__label {
  text-align: center; font-size: 11px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ag-text-3); margin-bottom: 20px;
}
.ag-logos__track {
  display: flex; align-items: center; justify-content: center;
  gap: 48px; flex-wrap: wrap;
}
.ag-logo-pill {
  display: flex; align-items: center; gap: 10px;
  background: var(--ag-surface); border: 1px solid var(--ag-border);
  border-radius: var(--r-full); padding: 10px 20px;
  font-size: 13px; font-weight: 700; color: var(--ag-text-3);
  letter-spacing: -.01em; transition: all var(--t-base);
}
.ag-logo-pill:hover { border-color: var(--ag-border-2); color: var(--ag-text); background: var(--ag-bg-3); }
.ag-logo-pill__icon {
  width: 22px; height: 22px; border-radius: 6px;
  background: var(--ag-grad); opacity: .7; flex-shrink: 0;
}

/* ── Agency section ── */
.ag-section {
  padding: 100px 0;
  background: var(--ag-bg);
}
.ag-section--alt { background: var(--ag-bg-2); }
.ag-section-head { text-align: center; margin-bottom: 64px; }
.ag-section-head h2 { margin-bottom: 16px; }
.ag-section-head p { max-width: 520px; margin: 0 auto; font-size: 1.05rem; }

/* ── Agency service cards ── */
.ag-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.ag-service-card {
  background: var(--ag-surface);
  border: 1px solid var(--ag-border);
  border-radius: var(--r-xl);
  padding: 36px 30px;
  position: relative;
  overflow: hidden;
  transition: all var(--t-base);
  cursor: default;
}
.ag-service-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--ag-grad); opacity: 0;
  transition: opacity var(--t-base);
}
.ag-service-card:hover {
  border-color: rgba(124,92,252,.25);
  background: var(--ag-bg-3);
  transform: translateY(-4px);
  box-shadow: var(--ag-s-md), 0 0 0 1px rgba(124,92,252,.1);
}
.ag-service-card:hover::before { opacity: 1; }
.ag-service-icon {
  width: 48px; height: 48px; border-radius: var(--r-md);
  background: rgba(124,92,252,.15); border: 1px solid rgba(124,92,252,.2);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 20px; color: var(--ag-accent-2);
}
.ag-service-card h3 { font-size: 1.15rem; margin-bottom: 10px; color: var(--ag-text); }
.ag-service-card p { font-size: 14px; line-height: 1.65; margin-bottom: 20px; }
.ag-service-tag {
  display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; color: var(--ag-accent); background: rgba(124,92,252,.1);
  border-radius: var(--r-full); padding: 3px 10px;
}
.ag-service-card .ag-service-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 700; color: var(--ag-accent-2);
  margin-top: 20px; transition: gap var(--t-fast);
}
.ag-service-card:hover .ag-service-link { gap: 10px; }

/* ── Agency stats ── */
.ag-stats { padding: 72px 0; background: var(--ag-bg-2); border-top: 1px solid var(--ag-border); border-bottom: 1px solid var(--ag-border); }
.ag-stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.ag-stat-item {
  text-align: center; padding: 32px 20px;
  border-right: 1px solid var(--ag-border);
}
.ag-stat-item:last-child { border-right: none; }
.ag-stat-num {
  font-size: clamp(2.4rem, 4vw, 3.6rem);
  font-weight: 900; letter-spacing: -.04em; line-height: 1;
  background: var(--ag-grad);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 8px;
}
.ag-stat-lbl { font-size: 13px; font-weight: 600; color: var(--ag-text-3); }

/* ── Agency process ── */
.ag-process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}
.ag-process-grid::before {
  content: '';
  position: absolute; top: 28px; left: 10%; right: 10%;
  height: 1px; background: linear-gradient(90deg, transparent, var(--ag-border), var(--ag-border), transparent);
}
.ag-process-step {
  text-align: center; padding: 0 24px;
  position: relative; z-index: 1;
}
.ag-process-num {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--ag-surface); border: 1px solid var(--ag-border-2);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 900; color: var(--ag-accent-2);
  margin: 0 auto 20px; position: relative;
  transition: all var(--t-slow);
}
.ag-process-step.active .ag-process-num {
  background: var(--ag-accent); border-color: var(--ag-accent);
  color: #fff; box-shadow: 0 0 0 8px rgba(124,92,252,.15);
}
.ag-process-step h3 { font-size: 1rem; margin-bottom: 8px; }
.ag-process-step p { font-size: 13px; line-height: 1.6; }
.ag-process-tag {
  display: inline-block; font-size: 10px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--ag-text-3); margin-bottom: 12px;
}

/* ── Agency testimonials ── */
.ag-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.ag-testimonial {
  background: var(--ag-surface);
  border: 1px solid var(--ag-border);
  border-radius: var(--r-xl);
  padding: 32px;
  position: relative;
  transition: all var(--t-base);
}
.ag-testimonial:hover {
  border-color: rgba(124,92,252,.2);
  transform: translateY(-3px);
  box-shadow: var(--ag-s-md);
}
.ag-testimonial__stars {
  display: flex; gap: 3px; margin-bottom: 16px;
}
.ag-testimonial__star { color: #FBBF24; font-size: 14px; }
.ag-testimonial__quote {
  font-size: 15px; line-height: 1.7; color: var(--ag-text-2);
  margin-bottom: 24px; font-style: normal;
}
.ag-testimonial__author { display: flex; align-items: center; gap: 12px; }
.ag-testimonial__avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--ag-grad); display: flex; align-items: center;
  justify-content: center; font-size: 15px; font-weight: 900;
  color: #fff; flex-shrink: 0;
}
.ag-testimonial__name { font-size: 13px; font-weight: 700; color: var(--ag-text); }
.ag-testimonial__role { font-size: 12px; color: var(--ag-text-3); margin-top: 2px; }

/* ── Agency BOS cross-sell ── */
.ag-bos-band {
  padding: 80px 0;
  background: linear-gradient(135deg, #07070F 0%, #0E0A1F 50%, #07070F 100%);
  border-top: 1px solid var(--ag-border);
  border-bottom: 1px solid var(--ag-border);
  position: relative; overflow: hidden;
}
.ag-bos-band::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 60% 80% at 80% 50%, rgba(49,58,223,.14) 0%, transparent 60%);
  pointer-events: none;
}
.ag-bos-band__inner {
  display: grid; grid-template-columns: 1fr auto;
  align-items: center; gap: 48px;
}
.ag-bos-band__badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(49,58,223,.15); border: 1px solid rgba(49,58,223,.3);
  border-radius: var(--r-full); padding: 4px 12px 4px 8px;
  font-size: 11px; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: #818CF8; margin-bottom: 14px;
}
.ag-bos-band__badge .dot { width: 5px; height: 5px; background: #313ADF; border-radius: 50%; }
.ag-bos-band h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); margin-bottom: 10px; }
.ag-bos-band p { font-size: 15px; color: var(--ag-text-2); max-width: 480px; }
.ag-bos-band__actions { display: flex; flex-direction: column; gap: 10px; align-items: flex-end; }

/* ── Agency CTA final ── */
.ag-cta-final {
  padding: 120px 0;
  background: var(--ag-bg);
  text-align: center;
  position: relative; overflow: hidden;
}
.ag-cta-final::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 60% 70% at 50% 100%, rgba(124,92,252,.15) 0%, transparent 60%);
}
.ag-cta-final h2 { font-size: clamp(2.4rem, 5vw, 4.2rem); margin-bottom: 20px; max-width: 700px; margin-left: auto; margin-right: auto; }
.ag-cta-final p { font-size: 1.1rem; color: var(--ag-text-2); margin-bottom: 40px; max-width: 480px; margin-left: auto; margin-right: auto; }
.ag-cta-actions { display: flex; align-items: center; justify-content: center; gap: 14px; flex-wrap: wrap; }

/* ── Agency footer ── */
.agency .footer { background: var(--ag-bg-2); border-top: 1px solid var(--ag-border); }
.agency .footer__logo-text span { color: var(--ag-accent-2); }

/* ── Page transition overlay ── */
#page-transition {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--ag-bg);
  pointer-events: none;
  opacity: 0;
  transform: translateY(100%);
}

/* ── Cursor glow (agency only) ── */
.cursor-glow {
  position: fixed; width: 400px; height: 400px;
  border-radius: 50%; pointer-events: none; z-index: 0;
  background: radial-gradient(circle, rgba(124,92,252,.08) 0%, transparent 70%);
  transform: translate(-50%, -50%);
  transition: transform 0.12s ease-out;
}

/* ── Magnetic button wrapper ── */
.mag-btn { display: inline-block; }

/* ── Text split animation ── */
.split-word { overflow: hidden; display: inline-block; }
.split-word span { display: inline-block; transform: translateY(110%); opacity: 0; }
.split-word span.in { transform: translateY(0); opacity: 1; transition: transform .65s cubic-bezier(.16,1,.3,1), opacity .4s ease; }

/* ── Counter animation ── */
.count-up { display: inline-block; }

/* ── Agency responsive ── */
@media (max-width: 1024px) {
  .ag-services-grid { grid-template-columns: repeat(2, 1fr); }
  .ag-stats__grid { grid-template-columns: repeat(2, 1fr); }
  .ag-stats__grid .ag-stat-item:nth-child(2) { border-right: none; }
  .ag-stats__grid .ag-stat-item:nth-child(3) { border-top: 1px solid var(--ag-border); }
  .ag-stats__grid .ag-stat-item:nth-child(4) { border-right: none; border-top: 1px solid var(--ag-border); }
  .ag-process-grid { grid-template-columns: repeat(2, 1fr); gap: 40px; }
  .ag-process-grid::before { display: none; }
  .ag-testimonials-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .ag-hero { padding: 120px 0 80px; text-align: left; }
  .ag-hero-content { text-align: left; }
  .ag-hero-actions { justify-content: flex-start; }
  .ag-hero-trust { justify-content: flex-start; }
  .ag-hero-chips { justify-content: flex-start; }
  .ag-hero .hero-sub { margin: 0 0 32px; }
  .ag-section { padding: 72px 0; }
  .ag-section-head { margin-bottom: 40px; }
  .ag-stats { padding: 56px 0; }
  .ag-services-grid { grid-template-columns: 1fr; }
  .ag-service-card { padding: 28px 22px; }
  .ag-process-grid { grid-template-columns: 1fr; gap: 24px; }
  .ag-process-step { padding: 0 12px; }
  .ag-testimonials-grid { grid-template-columns: 1fr; }
  .ag-testimonial { padding: 24px; }
  .ag-bos-band { padding: 56px 0; }
  .ag-bos-band__inner { grid-template-columns: 1fr; gap: 28px; }
  .ag-bos-band__actions { align-items: flex-start; flex-direction: row; flex-wrap: wrap; }
  .ag-cta-final { padding: 72px 0; }
  .ag-cta-final h2 { font-size: clamp(1.8rem, 7vw, 3rem); }
  .ag-logos__track { gap: 12px; }
  .cursor-glow { display: none; }
}

@media (max-width: 480px) {
  .ag-stats__grid { grid-template-columns: 1fr 1fr; }
  .ag-cta-final { padding: 60px 0; }
  .ag-hero-actions { flex-direction: column; align-items: stretch; }
  .ag-hero-actions .btn { width: 100%; justify-content: center; }
  .ag-hero-chips { gap: 8px; }
  .ag-hero-chip { font-size: 12px; padding: 6px 12px; }
  .ag-section-head { margin-bottom: 32px; }
}

