/* =================================================================
   A1 TECHNOVATION — Design System 2025
   Premium Digital Marketing Agency
================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,400&family=Inter:wght@400;500;600&display=swap');

/* ── TOKENS ──────────────────────────────────────────────────── */
:root {
  --c-primary:       #4f46e5;
  --c-primary-h:     #3730a3;
  --c-primary-l:     #818cf8;
  --c-secondary:     #06b6d4;
  --c-accent:        #f43f5e;
  --c-success:       #10b981;

  --c-900: #0f172a;
  --c-800: #1e293b;
  --c-700: #334155;
  --c-600: #475569;
  --c-500: #64748b;
  --c-400: #94a3b8;
  --c-300: #cbd5e1;
  --c-200: #e2e8f0;
  --c-100: #f1f5f9;
  --c-50:  #f8fafc;

  --bg-dark:   #060b18;
  --bg-dark-2: #0d1526;
  --bg-dark-3: #111827;

  --g-primary:   linear-gradient(135deg,#4f46e5 0%,#7c3aed 55%,#a855f7 100%);
  --g-secondary: linear-gradient(135deg,#06b6d4 0%,#3b82f6 100%);
  --g-hero:      linear-gradient(145deg,#060b18 0%,#0d1526 55%,#160826 100%);
  --g-text:      linear-gradient(135deg,#818cf8 0%,#c084fc 50%,#f472b6 100%);

  --f-head: 'Plus Jakarta Sans', system-ui, sans-serif;
  --f-body: 'Inter', system-ui, sans-serif;

  --r-sm:   8px;  --r-md:  12px; --r-lg:   16px; --r-xl: 20px;
  --r-2xl: 28px; --r-3xl: 36px; --r-full: 9999px;

  --sh-sm:  0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  --sh-md:  0 4px 16px rgba(0,0,0,.10),0 2px 8px rgba(0,0,0,.06);
  --sh-lg:  0 10px 40px rgba(0,0,0,.12),0 4px 16px rgba(0,0,0,.08);
  --sh-xl:  0 20px 60px rgba(0,0,0,.15),0 8px 24px rgba(0,0,0,.10);
  --sh-pri: 0 8px 32px rgba(79,70,229,.38);

  --ease: cubic-bezier(.4,0,.2,1);
  --tr:      all .3s var(--ease);
  --tr-fast: all .15s var(--ease);

  --nav-h: 72px;
  --max-w: 1280px;
}

/* ── RESET ───────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; font-size:16px; -webkit-text-size-adjust:100% }
body {
  font-family: var(--f-body);
  color: var(--c-900);
  background: #fff;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
body.menu-open { overflow: hidden }
img,video { max-width:100%; display:block }
a { color:inherit; text-decoration:none }
button { cursor:pointer; border:none; background:none; font:inherit }
ul,ol { list-style:none }
input,textarea,select { font:inherit }

/* ── LAYOUT ──────────────────────────────────────────────────── */
.container { max-width:var(--max-w); margin:0 auto; padding:0 24px }
.section    { padding:96px 0 }
.section-sm { padding:64px 0 }
.section-gray { background:var(--c-50) }
.section-dark { background:var(--bg-dark) }
.section-dark h1,.section-dark h2,.section-dark h3,
.section-dark h4,.section-dark h5 { color:#fff }
.section-dark p { color:rgba(255,255,255,.6) }

/* ── TYPOGRAPHY ──────────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--f-head);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -.02em;
  color: var(--c-900);
}
h1 { font-size:clamp(2.5rem,6vw,4.75rem);   font-weight:900; letter-spacing:-.04em }
h2 { font-size:clamp(2rem,4vw,3rem);         font-weight:800; letter-spacing:-.03em }
h3 { font-size:clamp(1.25rem,2.5vw,1.75rem); font-weight:700 }
h4 { font-size:1.25rem;    font-weight:700 }
h5 { font-size:1.0625rem;  font-weight:600 }
h6 { font-size:.9375rem;   font-weight:600 }
p  { color:var(--c-600); line-height:1.75 }

.text-grad {
  background: var(--g-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.text-grad-hero {
  background: var(--g-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── LABELS ──────────────────────────────────────────────────── */
.label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .8125rem;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: 6px 16px;
  border-radius: var(--r-full);
  margin-bottom: 16px;
}
.label-primary { color:var(--c-primary); background:rgba(79,70,229,.08); border:1px solid rgba(79,70,229,.2) }
.label-light   { color:#a5b4fc; background:rgba(165,180,252,.1); border:1px solid rgba(165,180,252,.2) }
.label-dot::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
  opacity: .7;
}

.section-header { max-width:720px; margin:0 auto 64px; text-align:center }
.section-header h2 { margin-bottom:16px }
.section-header p  { font-size:1.0625rem; color:var(--c-500); max-width:560px; margin:0 auto }
.section-header .label { margin-bottom:20px }

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: var(--r-full);
  font-family: var(--f-head);
  font-weight: 600;
  font-size: .9375rem;
  transition: var(--tr);
  white-space: nowrap;
  cursor: pointer;
  border: none;
}
.btn-primary {
  background: var(--g-primary);
  color: #fff;
  box-shadow: var(--sh-pri);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 14px 44px rgba(79,70,229,.5) }
.btn-secondary {
  background: #fff;
  color: var(--c-900);
  border: 1.5px solid var(--c-200);
  box-shadow: var(--sh-sm);
}
.btn-secondary:hover { border-color:var(--c-primary); color:var(--c-primary); transform:translateY(-2px); box-shadow:var(--sh-md) }
.btn-ghost {
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.3);
  background: transparent;
}
.btn-ghost:hover { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.6) }
.btn-outline {
  color: var(--c-primary);
  border: 1.5px solid var(--c-primary);
  background: transparent;
}
.btn-outline:hover { background:var(--c-primary); color:#fff; box-shadow:var(--sh-pri) }
.btn-lg { padding:18px 36px; font-size:1rem }
.btn-sm { padding:10px 20px; font-size:.875rem }
.btn i { font-size:.875em; transition:transform .25s var(--ease) }
.btn:hover i { transform:translateX(2px) }

/* ── BADGES ──────────────────────────────────────────────────── */
.badge { display:inline-flex; align-items:center; gap:6px; padding:5px 12px; border-radius:var(--r-full); font-size:.8125rem; font-weight:600 }
.badge-green  { background:rgba(16,185,129,.1);   color:#059669; border:1px solid rgba(16,185,129,.2) }
.badge-blue   { background:rgba(59,130,246,.1);    color:#2563eb; border:1px solid rgba(59,130,246,.2) }
.badge-purple { background:rgba(124,58,237,.1);    color:#7c3aed; border:1px solid rgba(124,58,237,.2) }

/* ── NAVBAR ──────────────────────────────────────────────────── */
.navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--nav-h);
  transition: var(--tr);
}
.navbar.scrolled {
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid rgba(0,0,0,.07);
  box-shadow: 0 4px 24px rgba(0,0,0,.06);
}

.navbar-inner {
  display: flex;
  align-items: center;
  height: var(--nav-h);
  gap: 32px;
}
.navbar-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.logo-mark {
  position: relative;
  width: 220px;
  height: 52px;
  flex-shrink: 0;
}
.logo-brand {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left center;
  transition: opacity .25s var(--ease);
}
.logo-brand-light { opacity: 0; }
.navbar.scrolled .logo-brand-dark { opacity: 0; }
.navbar.scrolled .logo-brand-light { opacity: 1; }

.navbar-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 1;
  justify-content: center;
}
.nav-link {
  font-family: var(--f-head);
  font-weight: 500;
  font-size: .9375rem;
  color: rgba(255,255,255,.78);
  padding: 8px 14px;
  border-radius: var(--r-full);
  transition: var(--tr);
  display: flex;
  align-items: center;
  gap: 4px;
}
.nav-link:hover,.nav-link.active { color:#fff; background:rgba(255,255,255,.1) }
.navbar.scrolled .nav-link            { color:var(--c-600) }
.navbar.scrolled .nav-link:hover,
.navbar.scrolled .nav-link.active     { color:var(--c-primary); background:rgba(79,70,229,.08) }
.nav-link:focus-visible,
.dropdown-item:focus-visible,
.mobile-menu-link:focus-visible,
.mobile-submenu-link:focus-visible {
  outline: 2px solid rgba(129,140,248,.9);
  outline-offset: 3px;
}

.nav-item { position:relative }
.nav-item.current > .nav-link { color:#fff; background:rgba(255,255,255,.1) }
.navbar.scrolled .nav-item.current > .nav-link { color:var(--c-primary); background:rgba(79,70,229,.08) }
.dropdown {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  min-width: 268px;
  background: #fff;
  border: 1px solid var(--c-200);
  border-radius: var(--r-2xl);
  box-shadow: var(--sh-xl);
  padding: 8px;
  opacity: 0;
  visibility: hidden;
  transition: var(--tr);
  z-index: 100;
}
.nav-item:hover .dropdown,
.nav-item:focus-within .dropdown { opacity:1; visibility:visible; transform:translateX(-50%) translateY(0) }
.dropdown-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: var(--r-lg);
  transition: var(--tr-fast);
  color: var(--c-700);
}
.dropdown-item:hover { background:var(--c-50); color:var(--c-primary) }
.dropdown-group {
  display: flex;
  flex-direction: column;
  border-radius: var(--r-lg);
}
.dropdown-parent-link {
  justify-content: space-between;
}
.dd-caret {
  margin-left: auto;
  font-size: .75rem;
  color: var(--c-400);
  transition: var(--tr-fast);
}
.dropdown-submenu {
  display: grid;
  grid-template-rows: 0fr;
  margin: 0 8px 4px 52px;
  transition: var(--tr-fast);
}
.dropdown-submenu-inner {
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.dropdown-group:hover .dropdown-submenu,
.dropdown-group:focus-within .dropdown-submenu {
  grid-template-rows: 1fr;
}
.dropdown-group:hover .dropdown-parent-link,
.dropdown-group:focus-within .dropdown-parent-link {
  background: var(--c-50);
  color: var(--c-primary);
}
.dropdown-group:hover .dd-caret,
.dropdown-group:focus-within .dd-caret {
  color: var(--c-primary);
  transform: translateX(2px);
}
.dropdown-subitem {
  font-family: var(--f-head);
  font-size: .8125rem;
  font-weight: 600;
  color: var(--c-500);
  padding: 7px 12px;
  border-left: 1px solid var(--c-200);
  transition: var(--tr-fast);
}
.dropdown-subitem:hover {
  color: var(--c-primary);
  background: rgba(79,70,229,.04);
  border-left-color: rgba(79,70,229,.35);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  padding-left: 16px;
}
.dd-icon {
  width: 38px; height: 38px;
  border-radius: var(--r-md);
  background: rgba(79,70,229,.08);
  color: var(--c-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .875rem;
  flex-shrink: 0;
}
.dd-body { display:flex; flex-direction:column; gap:2px }
.dd-title { font-family:var(--f-head); font-weight:600; font-size:.875rem; color:var(--c-900) }
.dd-desc  { font-size:.75rem; color:var(--c-400) }

/* ── MEGAMENU ──────────────────────────────────────────────────── */
.megamenu-item { position: relative }
.megamenu {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  width: 760px;
  background: #fff;
  border: 1px solid var(--c-200);
  border-radius: var(--r-2xl);
  box-shadow: var(--sh-xl);
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  transition: var(--tr);
  z-index: 100;
}
.megamenu-item:hover .megamenu,
.megamenu-item:focus-within .megamenu {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}
.megamenu-inner {
  display: grid;
  grid-template-columns: 1fr 1fr 220px;
  gap: 0;
}
.mm-col-head {
  font-family: var(--f-head);
  font-size: .6875rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--c-400);
  margin: 0 0 8px;
  padding: 0 4px;
}
.mm-col-main { padding-right: 12px }
.mm-service {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: var(--r-lg);
  transition: var(--tr-fast);
  color: var(--c-700);
}
.mm-service:hover { background: var(--c-50) }
.mm-service:hover .mm-icon { background: rgba(79,70,229,.15) }
.mm-icon {
  width: 36px; height: 36px;
  border-radius: var(--r-md);
  background: rgba(79,70,229,.08);
  color: var(--c-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8125rem;
  flex-shrink: 0;
  transition: var(--tr-fast);
}
.mm-body { display: flex; flex-direction: column; gap: 1px }
.mm-title { font-family: var(--f-head); font-weight: 600; font-size: .875rem; color: var(--c-900) }
.mm-desc  { font-size: .75rem; color: var(--c-400) }
.mm-service:hover .mm-title { color: var(--c-primary) }
.mm-col-links {
  padding: 0 8px 0 20px;
  border-left: 1px solid var(--c-100);
}
.mm-link {
  display: block;
  font-family: var(--f-head);
  font-weight: 500;
  font-size: .8125rem;
  color: var(--c-600);
  padding: 6px 8px;
  border-radius: var(--r-md);
  transition: var(--tr-fast);
}
.mm-link:hover {
  color: var(--c-primary);
  background: rgba(79,70,229,.06);
  padding-left: 12px;
}
.mm-col-feature {
  border-left: 1px solid var(--c-100);
  padding-left: 16px;
}
.mm-feature-card {
  background: linear-gradient(135deg, rgba(79,70,229,.06) 0%, rgba(139,92,246,.08) 100%);
  border: 1px solid rgba(79,70,229,.12);
  border-radius: var(--r-xl);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  height: 100%;
  box-sizing: border-box;
}
.mm-feature-badge {
  align-self: flex-start;
  background: rgba(79,70,229,.1);
  color: var(--c-primary);
  font-family: var(--f-head);
  font-weight: 700;
  font-size: .625rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: var(--r-full);
}
.mm-feature-title {
  font-family: var(--f-head);
  font-size: .9375rem;
  font-weight: 700;
  color: var(--c-900);
  line-height: 1.3;
  margin: 0;
}
.mm-feature-body {
  font-size: .8125rem;
  color: var(--c-500);
  line-height: 1.5;
  margin: 0;
  flex: 1;
}
.mm-feature-link {
  font-family: var(--f-head);
  font-size: .8125rem;
  font-weight: 600;
  color: var(--c-primary);
  opacity: .75;
  transition: var(--tr-fast);
}
.mm-feature-link:hover { opacity: 1 }
@media (max-width: 1200px) {
  .megamenu { width: 520px }
  .megamenu-inner { grid-template-columns: 1fr 1fr }
  .mm-col-feature { display: none }
}

.navbar-right {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
  margin-left: auto;
}

.mobile-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px; height: 40px;
  border-radius: var(--r-md);
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
}
.mobile-toggle:focus-visible {
  outline: 2px solid rgba(129,140,248,.9);
  outline-offset: 3px;
}
.mobile-toggle span {
  display: block;
  height: 2px;
  border-radius: 2px;
  background: #fff;
  transition: var(--tr);
  transform-origin: center;
}
.navbar.scrolled .mobile-toggle span { background:var(--c-900) }
.mobile-toggle.open span:nth-child(1) { transform:translateY(7px) rotate(45deg) }
.mobile-toggle.open span:nth-child(2) { opacity:0; transform:scaleX(0) }
.mobile-toggle.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg) }

.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--bg-dark);
  z-index: 998;
  display: flex;
  flex-direction: column;
  padding: 96px 24px 40px;
  transform: translateX(100%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: transform .45s cubic-bezier(.4,0,.2,1);
  overflow-y: auto;
  overscroll-behavior: contain;
}
.mobile-menu.open {
  transform:translateX(0);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.mobile-menu-link {
  font-family: var(--f-head);
  font-weight: 700;
  font-size: 1.625rem;
  color: rgba(255,255,255,.8);
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
  transition: var(--tr);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.mobile-menu-link:hover { color:#fff; padding-left:8px }
.mobile-menu-link.active,
.mobile-submenu-link.active { color:#fff }
.mobile-menu-group {
  display:flex;
  flex-direction:column;
  padding-bottom: 4px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.mobile-menu-group .mobile-menu-link { border-bottom: 0; }
.mobile-menu-group.current > .mobile-menu-link { color:#fff }
.mobile-submenu {
  display:flex;
  flex-direction:column;
  gap:2px;
  padding:12px 0 4px 18px;
  border-left: 1px solid rgba(255,255,255,.12);
}
.mobile-submenu-nested {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin: 2px 0 10px 6px;
  padding-left: 14px;
  border-left: 1px solid rgba(255,255,255,.08);
}
.mobile-submenu-link {
  font-family:var(--f-head);
  font-weight:600;
  font-size:.95rem;
  color:rgba(255,255,255,.58);
  padding:8px 0;
  transition:var(--tr-fast);
}
.mobile-submenu-link:hover { color:#fff; padding-left:6px }
.mobile-submenu-sublink {
  font-size: .875rem;
  color: rgba(255,255,255,.48);
}
.mobile-menu-footer {
  margin-top: 40px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.mobile-menu-note {
  font-size: .875rem;
  color: rgba(255,255,255,.4);
  text-align: center;
}

/* ── HERO ─────────────────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  background: var(--g-hero);
  overflow: hidden;
  padding-top: var(--nav-h);
}

.hero-bg { position:absolute; inset:0; pointer-events:none }
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse at 50% 0%,black 40%,transparent 80%);
}
.hero-glow-1 {
  position:absolute; top:-15%; left:5%;
  width:700px; height:700px;
  background:radial-gradient(circle,rgba(79,70,229,.3) 0%,transparent 70%);
  filter:blur(80px);
  animation:drift1 14s ease-in-out infinite;
}
.hero-glow-2 {
  position:absolute; bottom:-10%; right:5%;
  width:550px; height:550px;
  background:radial-gradient(circle,rgba(168,85,247,.22) 0%,transparent 70%);
  filter:blur(80px);
  animation:drift2 18s ease-in-out infinite;
}
.hero-glow-3 {
  position:absolute; top:35%; right:18%;
  width:350px; height:350px;
  background:radial-gradient(circle,rgba(6,182,212,.12) 0%,transparent 70%);
  filter:blur(60px);
}
@keyframes drift1 { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(40px,-30px) scale(1.06)} 66%{transform:translate(-20px,20px) scale(.94)} }
@keyframes drift2 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-30px,20px)} }

.hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  padding: 80px 0 96px;
  position: relative;
  z-index: 1;
}
.hero-content { display:flex; flex-direction:column; gap:24px }

.hero-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  padding: 8px 18px;
  border-radius: var(--r-full);
  font-size: .8125rem;
  font-weight: 500;
  color: rgba(255,255,255,.75);
  backdrop-filter: blur(8px);
  width: fit-content;
}
.chip-dot {
  width:7px; height:7px;
  background:#10b981;
  border-radius:50%;
  flex-shrink:0;
  box-shadow:0 0 0 3px rgba(16,185,129,.25);
  animation:pulse-g 2.5s infinite;
}
@keyframes pulse-g { 0%,100%{box-shadow:0 0 0 3px rgba(16,185,129,.25)} 50%{box-shadow:0 0 0 6px rgba(16,185,129,.1)} }

.hero-title {
  font-size: clamp(2.75rem,5.5vw,4.75rem);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -.04em;
  color: #fff;
}
.hero-title .line   { display:block }
.hero-title .accent {
  display: inline-block;
  background: var(--g-text);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-desc {
  font-size: 1.0625rem;
  color: rgba(255,255,255,.6);
  max-width: 480px;
  line-height: 1.75;
}
.hero-actions { display:flex; align-items:center; gap:16px; flex-wrap:wrap }

.hero-social-proof {
  display: flex;
  align-items: center;
  gap: 32px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.proof-avatars { display:flex }
.proof-avatars img {
  width: 34px; height: 34px;
  border-radius: 50%;
  border: 2px solid var(--bg-dark);
  object-fit: cover;
}
.proof-avatars img:not(:first-child) { margin-left:-10px }
.proof-text { display:flex; flex-direction:column; gap:2px }
.proof-stars { color:#fbbf24; font-size:.875rem; letter-spacing:2px }
.proof-label { font-size:.8125rem; color:rgba(255,255,255,.45); font-weight:500 }
.hero-stats { display:flex; gap:40px }
.hs-item   { display:flex; flex-direction:column; gap:4px }
.hs-num    { font-family:var(--f-head); font-size:2rem; font-weight:800; color:#fff; line-height:1 }
.hs-lbl    { font-size:.8125rem; color:rgba(255,255,255,.4); font-weight:500 }

/* Hero Visual */
.hero-visual {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding-top: 12px;
}
.hero-img-wrap { position:relative; width:100%; max-width:560px }
.hero-img-frame {
  border-radius: var(--r-2xl);
  overflow: hidden;
  box-shadow: 0 48px 120px rgba(0,0,0,.6);
  border: 1px solid rgba(255,255,255,.07);
  position: relative;
}
.hero-img-frame img {
  width: 100%;
  height: 460px;
  object-fit: cover;
  display: block;
}
.hero-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top,rgba(6,11,24,.35) 0%,transparent 55%);
}

/* Floating cards */
.fc {
  position: absolute;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: var(--r-xl);
  padding: 14px 18px;
  box-shadow: var(--sh-xl);
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 185px;
}
.fc-1 { top:-20px; right:-20px; animation:fa 5s ease-in-out infinite }
.fc-2 { bottom:40px; left:-28px; animation:fb 6.5s ease-in-out infinite }
.fc-3 { bottom:-14px; right:28px; animation:fa 4s ease-in-out infinite 1s }
@keyframes fa { 0%,100%{transform:translateY(0)}  50%{transform:translateY(-10px)} }
@keyframes fb { 0%,100%{transform:translateY(0)}  50%{transform:translateY(-7px)} }

.fi {
  width:42px; height:42px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.125rem;
  flex-shrink: 0;
}
.fi-green  { background:rgba(16,185,129,.12);  color:#059669 }
.fi-blue   { background:rgba(59,130,246,.12);  color:#2563eb }
.fi-purple { background:rgba(124,58,237,.12);  color:#7c3aed }
.fi-orange { background:rgba(245,158,11,.12);  color:#d97706 }

.fc-body  { display:flex; flex-direction:column; gap:2px }
.fc-lbl   { font-size:.7rem; color:var(--c-400); font-weight:600; text-transform:uppercase; letter-spacing:.05em }
.fc-val   { font-family:var(--f-head); font-size:1.0625rem; font-weight:700; color:var(--c-900); line-height:1.2 }
.fc-sub   { font-size:.8125rem; font-weight:600 }
.fc-sub.up   { color:#059669 }
.fc-sub.blue { color:#2563eb }

/* ── CLIENTS BAR ─────────────────────────────────────────────── */
.clients-bar {
  padding:40px 0;
  background:var(--c-50);
  border-top:1px solid var(--c-200);
  border-bottom:1px solid var(--c-200);
}
.clients-label {
  text-align:center;
  font-size:.8125rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--c-400);
  margin-bottom:28px;
}
.clients-logos {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:48px;
  flex-wrap:wrap;
}
.client-logo {
  display:flex;
  align-items:center;
  gap:8px;
  font-family:var(--f-head);
  font-weight:700;
  font-size:1.0625rem;
  color:var(--c-300);
  transition:var(--tr);
}
.client-logo i { font-size:1.375rem }
.client-logo:hover { color:var(--c-400) }

/* ── SERVICES ────────────────────────────────────────────────── */
.svc-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px }
.svc-card {
  background: #fff;
  border: 1px solid var(--c-200);
  border-radius: var(--r-2xl);
  padding: 36px;
  transition: var(--tr);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.svc-bar {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--g-primary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .4s var(--ease);
}
.svc-card:hover { border-color:rgba(79,70,229,.2); box-shadow:var(--sh-xl); transform:translateY(-6px) }
.svc-card:hover .svc-bar { transform:scaleX(1) }

.svc-icon {
  width:60px; height:60px;
  border-radius:var(--r-lg);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem;
  flex-shrink:0;
}
.si-blue   { background:rgba(59,130,246,.1);  color:#2563eb }
.si-purple { background:rgba(124,58,237,.1);  color:#7c3aed }
.si-green  { background:rgba(16,185,129,.1);  color:#059669 }
.si-orange { background:rgba(245,158,11,.1);  color:#d97706 }

.svc-card h3 { font-size:1.375rem; margin:0 }
.svc-card > p { font-size:.9375rem; line-height:1.72; flex:1; margin:0 }
.svc-img { width:100%; height:210px; object-fit:cover; border-radius:var(--r-lg); margin-top:4px }

.svc-list { display:flex; flex-direction:column; gap:9px }
.svc-li {
  display:flex; align-items:center; gap:8px;
  font-size:.875rem; color:var(--c-600); font-weight:500;
}
.svc-li i { color:var(--c-primary); font-size:.75rem; flex-shrink:0 }

.svc-link {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--f-head); font-weight:600; font-size:.9375rem;
  color:var(--c-primary); transition:var(--tr);
}
.svc-link:hover { gap:14px }

/* ── STATS BAND ──────────────────────────────────────────────── */
.stats-band {
  background: var(--g-primary);
  padding: 80px 0;
  position: relative;
  overflow: hidden;
}
.stats-band::before {
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:40px 40px;
}
.stats-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:32px;
  text-align:center;
  position:relative; z-index:1;
}
.stat-item  { display:flex; flex-direction:column; align-items:center; gap:12px }
.stat-num   { font-family:var(--f-head); font-size:clamp(2.5rem,5vw,3.75rem); font-weight:900; color:#fff; line-height:1; letter-spacing:-.03em }
.stat-lbl   { font-size:.9375rem; color:rgba(255,255,255,.75); font-weight:500 }
.stat-sub   { font-size:.8125rem; color:rgba(255,255,255,.4) }

/* ── PROCESS ─────────────────────────────────────────────────── */
.process-wrap { position:relative }
.process-line {
  position:absolute; top:43px; left:12.5%; right:12.5%;
  height:2px;
  background:linear-gradient(90deg,transparent,var(--c-200) 25%,var(--c-200) 75%,transparent);
}
.process-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; position:relative; z-index:1 }
.process-step { display:flex; flex-direction:column; align-items:center; text-align:center; gap:16px }
.step-icon-wrap {
  width:86px; height:86px;
  border-radius:var(--r-xl);
  display:flex; align-items:center; justify-content:center;
  background:#fff;
  border:2px solid var(--c-200);
  transition:var(--tr);
  flex-shrink:0;
}
.step-icon-wrap i { font-size:1.875rem; color:var(--c-400); transition:var(--tr) }
.step-icon-wrap.active { background:var(--g-primary); border-color:transparent; box-shadow:var(--sh-pri) }
.step-icon-wrap.active i { color:#fff }
.process-step:hover .step-icon-wrap { background:var(--g-primary); border-color:transparent; box-shadow:var(--sh-pri) }
.process-step:hover .step-icon-wrap i { color:#fff }
.process-step h5 { font-size:1rem; font-weight:700; color:var(--c-900) }
.process-step p  { font-size:.875rem; color:var(--c-500); line-height:1.6; max-width:200px }

/* ── ABOUT SPLIT ─────────────────────────────────────────────── */
.about-split { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center }
.about-img-wrap { position:relative }
.about-img-frame { border-radius:var(--r-2xl); overflow:hidden; box-shadow:var(--sh-xl) }
.about-img-frame img { width:100%; height:520px; object-fit:cover; display:block }
.about-badge {
  position:absolute; bottom:-24px; right:-24px;
  background:#fff;
  border-radius:var(--r-xl);
  padding:20px 24px;
  box-shadow:var(--sh-xl);
  border:1px solid var(--c-100);
  text-align:center; min-width:160px;
}
.about-badge-num {
  font-family:var(--f-head); font-size:2.75rem; font-weight:900; line-height:1;
  background:var(--g-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.about-badge-lbl { font-size:.8125rem; color:var(--c-500); font-weight:500; margin-top:4px }
.about-content { display:flex; flex-direction:column; gap:24px }
.about-content h2 { margin:0 }
.about-vals { display:flex; flex-direction:column; gap:12px }
.val-row {
  display:flex; align-items:flex-start; gap:16px;
  padding:16px; border-radius:var(--r-lg);
  background:var(--c-50); border:1px solid var(--c-100);
  transition:var(--tr);
}
.val-row:hover { border-color:rgba(79,70,229,.2); background:rgba(79,70,229,.03) }
.val-icon-w {
  width:44px; height:44px;
  border-radius:var(--r-md);
  background:var(--g-primary);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:1rem; flex-shrink:0;
}
.val-text h5 { margin-bottom:4px; font-size:.9375rem }
.val-text p  { font-size:.875rem; line-height:1.6; margin:0 }

/* ── RESULTS ─────────────────────────────────────────────────── */
.results-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.result-card {
  background:var(--bg-dark-2);
  border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r-2xl);
  overflow:hidden; transition:var(--tr);
}
.result-card:hover { border-color:rgba(79,70,229,.4); transform:translateY(-5px); box-shadow:0 24px 64px rgba(0,0,0,.4) }
.result-img { width:100%; height:200px; object-fit:cover; display:block }
.result-body { padding:24px; display:flex; flex-direction:column; gap:16px }
.result-tags { display:flex; gap:8px; flex-wrap:wrap }
.result-tag {
  font-size:.72rem; font-weight:700;
  padding:4px 10px; border-radius:var(--r-full);
  background:rgba(79,70,229,.2); color:#a5b4fc;
  border:1px solid rgba(79,70,229,.3);
  letter-spacing:.04em; text-transform:uppercase;
}
.result-card h4 { font-size:1.0625rem; color:#fff; line-height:1.4 }
.result-card p  { font-size:.875rem; line-height:1.65; color:rgba(255,255,255,.45); margin:0 }
.result-metrics { display:flex; gap:24px; padding-top:16px; border-top:1px solid rgba(255,255,255,.07) }
.r-metric  { display:flex; flex-direction:column; gap:4px }
.r-val     { font-family:var(--f-head); font-size:1.625rem; font-weight:800; line-height:1 }
.r-val.g   { color:#34d399 }
.r-val.b   { color:#60a5fa }
.r-val.y   { color:#fbbf24 }
.r-lbl     { font-size:.75rem; color:rgba(255,255,255,.35); font-weight:500; text-transform:uppercase; letter-spacing:.04em }

/* ── TESTIMONIALS ────────────────────────────────────────────── */
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.testi-card {
  background:#fff;
  border:1px solid var(--c-200);
  border-radius:var(--r-2xl);
  padding:32px;
  display:flex; flex-direction:column; gap:20px;
  transition:var(--tr); position:relative;
}
.testi-card:hover { border-color:rgba(79,70,229,.25); box-shadow:var(--sh-lg); transform:translateY(-4px) }
.testi-card.featured { background:var(--g-primary); border-color:transparent }
.testi-card.featured .testi-body  { color:rgba(255,255,255,.85) }
.testi-card.featured .a-name      { color:#fff }
.testi-card.featured .a-role      { color:rgba(255,255,255,.6) }
.testi-card.featured hr           { border-color:rgba(255,255,255,.15) }

.t-quote { font-size:2.25rem; line-height:1; color:var(--c-200); font-family:Georgia,serif; margin-bottom:-8px }
.testi-card.featured .t-quote { color:rgba(255,255,255,.28) }
.t-stars  { display:flex; gap:3px }
.t-stars i { color:#fbbf24; font-size:.875rem }
.testi-body { font-size:.9375rem; line-height:1.78; color:var(--c-700); flex:1; font-style:italic }
.t-hr { border:none; border-top:1px solid var(--c-100); margin:0 }
.testi-author { display:flex; align-items:center; gap:12px }
.t-avatar { width:48px; height:48px; border-radius:50%; object-fit:cover; flex-shrink:0 }
.a-name { font-family:var(--f-head); font-weight:700; font-size:.9375rem; color:var(--c-900) }
.a-role { font-size:.8125rem; color:var(--c-500) }

/* ── BLOG ────────────────────────────────────────────────────── */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.blog-card {
  background:#fff;
  border:1px solid var(--c-200);
  border-radius:var(--r-xl);
  overflow:hidden; transition:var(--tr);
}
.blog-card:hover { box-shadow:var(--sh-lg); transform:translateY(-4px); border-color:rgba(79,70,229,.2) }
.blog-img-box { overflow:hidden; height:220px }
.blog-img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease) }
.blog-card:hover .blog-img { transform:scale(1.06) }
.blog-body { padding:20px 24px 24px; display:flex; flex-direction:column; gap:12px }
.blog-meta { display:flex; align-items:center; gap:10px }
.b-cat  { font-size:.75rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--c-primary) }
.b-dot  { color:var(--c-300); font-size:.5rem }
.b-date { font-size:.8125rem; color:var(--c-400) }
.blog-card h4 { font-size:1.0625rem; line-height:1.4; transition:var(--tr) }
.blog-card:hover h4 { color:var(--c-primary) }
.blog-card > p { font-size:.875rem; line-height:1.65; color:var(--c-500); margin:0 }
.blog-footer { display:flex; align-items:center; justify-content:space-between; padding-top:16px; border-top:1px solid var(--c-100) }
.b-author { display:flex; align-items:center; gap:8px; font-size:.8125rem; color:var(--c-500); font-weight:500 }
.b-author-img { width:28px; height:28px; border-radius:50%; object-fit:cover }
.b-read { font-size:.8125rem; color:var(--c-400); display:flex; align-items:center; gap:4px }

/* ── CTA ─────────────────────────────────────────────────────── */
.cta-wrap { padding:96px 0; background:var(--bg-dark); position:relative; overflow:hidden }
.cta-glow {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 20% 50%,rgba(79,70,229,.22) 0%,transparent 50%),
    radial-gradient(ellipse at 80% 50%,rgba(168,85,247,.15) 0%,transparent 50%);
}
.cta-inner {
  position:relative; z-index:1;
  text-align:center;
  max-width:820px; margin:0 auto;
  display:flex; flex-direction:column; align-items:center; gap:32px;
}
.cta-inner h2 { font-size:clamp(2rem,4.5vw,3.25rem); color:#fff }
.cta-inner > p { font-size:1.0625rem; color:rgba(255,255,255,.6); max-width:540px }
.cta-buttons { display:flex; align-items:center; gap:16px; flex-wrap:wrap; justify-content:center }
.cta-trust { display:flex; align-items:center; gap:24px; flex-wrap:wrap; justify-content:center }
.cta-trust-item { display:flex; align-items:center; gap:8px; font-size:.875rem; color:rgba(255,255,255,.45) }
.cta-trust-item i { color:#10b981 }

/* ── FOOTER ──────────────────────────────────────────────────── */
.footer { background:#040911; padding:80px 0 40px }
.footer-top {
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px;
  padding-bottom:64px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-brand { display:flex; flex-direction:column; gap:20px; padding-right:24px }
.footer-brand p { font-size:.9375rem; color:rgba(255,255,255,.4); line-height:1.75 }
.footer-logo { display:flex; align-items:center; gap:10px }
.footer-logo-image {
  width: auto;
  height: 52px;
  object-fit: contain;
  display: block;
}
.footer-socials { display:flex; gap:10px }
.f-social {
  width:40px; height:40px;
  border-radius:var(--r-md);
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.45); font-size:.9375rem;
  transition:var(--tr);
}
.f-social:hover { background:var(--c-primary); border-color:var(--c-primary); color:#fff; transform:translateY(-2px) }
.footer-col h6 { font-family:var(--f-head); font-size:.9375rem; font-weight:700; color:#fff; margin-bottom:20px }
.footer-links  { display:flex; flex-direction:column; gap:12px }
.f-link { font-size:.9rem; color:rgba(255,255,255,.4); transition:var(--tr); display:flex; align-items:center; gap:6px }
.f-link:hover { color:rgba(255,255,255,.8); gap:10px }
.f-contact-item { display:flex; align-items:flex-start; gap:12px; font-size:.875rem; color:rgba(255,255,255,.4); line-height:1.65 }
.f-contact-item + .f-contact-item { margin-top:12px }
.f-contact-item i { color:var(--c-primary-l); font-size:.875rem; margin-top:2px; flex-shrink:0 }
.f-contact-item a { color:rgba(255,255,255,.5); transition:var(--tr) }
.f-contact-item a:hover { color:#fff }
.footer-bottom {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:32px; gap:16px; flex-wrap:wrap;
}
.f-copy { font-size:.875rem; color:rgba(255,255,255,.25) }
.f-bottom-links { display:flex; gap:24px }
.f-bl { font-size:.875rem; color:rgba(255,255,255,.25); transition:var(--tr) }
.f-bl:hover { color:rgba(255,255,255,.55) }

/* ── PAGE HERO (inner pages) ─────────────────────────────────── */
.page-hero {
  background:var(--g-hero);
  padding:calc(var(--nav-h) + 80px) 0 80px;
  position:relative; overflow:hidden; text-align:center;
}
.page-hero .hero-grid { opacity:.4 }
.page-hero-inner {
  position:relative; z-index:1;
  max-width:760px; margin:0 auto;
  display:flex; flex-direction:column; align-items:center; gap:20px;
}
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:.875rem; color:rgba(255,255,255,.45) }
.breadcrumb a { color:rgba(255,255,255,.45); transition:var(--tr) }
.breadcrumb a:hover { color:rgba(255,255,255,.75) }
.breadcrumb i { font-size:.75rem }
.page-hero h1 { color:#fff }
.page-hero p  { font-size:1.0625rem; color:rgba(255,255,255,.6); max-width:540px }

/* ── REUSABLE CONTENT PANELS ────────────────────────────────── */
.hero-badges {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
  margin-top:8px;
}
.media-card {
  border-radius:var(--r-2xl);
  overflow:hidden;
  box-shadow:var(--sh-xl);
  position:relative;
}
.media-card img {
  width:100%;
  height:460px;
  object-fit:cover;
  object-position:center 20%;
  display:block;
  transition:transform .6s var(--ease);
}
.media-card:hover img { transform:scale(1.02) }
.content-panel {
  background:#fff;
  border:1px solid var(--c-200);
  border-radius:var(--r-2xl);
  box-shadow:var(--sh-md);
}
.stat-cluster {
  display:flex;
  gap:20px 28px;
  flex-wrap:wrap;
  padding-top:8px;
}
.stat-chip {
  min-width:120px;
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:16px 20px;
  background:rgba(79,70,229,.04);
  border:1px solid rgba(79,70,229,.1);
  border-radius:var(--r-lg);
}
.stat-chip strong {
  font-family:var(--f-head);
  font-size:2rem;
  font-weight:900;
  color:var(--c-primary);
  line-height:1;
}
.stat-chip span {
  font-size:.8125rem;
  color:var(--c-500);
  font-weight:500;
  line-height:1.4;
}
.info-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.info-card {
  background:#fff;
  border:1px solid var(--c-200);
  border-radius:var(--r-xl);
  padding:28px;
  display:flex;
  flex-direction:column;
  gap:16px;
  transition:var(--tr);
  box-shadow:inset 3px 0 0 transparent;
}
.info-card:hover {
  border-color:rgba(79,70,229,.2);
  box-shadow:inset 3px 0 0 var(--c-primary),0 8px 28px rgba(79,70,229,.09),0 2px 8px rgba(0,0,0,.05);
  transform:translateY(-3px);
}
.info-card h4 { font-size:1.0625rem; margin:0 }
.info-card p { font-size:.9375rem; margin:0 }
.info-card-icon {
  width:44px; height:44px;
  border-radius:var(--r-md);
  background:rgba(79,70,229,.08);
  border:1px solid rgba(79,70,229,.15);
  display:flex; align-items:center; justify-content:center;
  color:var(--c-primary); font-size:1rem; flex-shrink:0;
}
.info-list {
  display:flex;
  flex-direction:column;
  gap:12px;
}
.info-list li {
  position:relative;
  padding-left:18px;
  font-size:.9rem;
  color:var(--c-600);
  line-height:1.65;
}
.info-list li::before {
  content:'';
  position:absolute;
  top:.68em;
  left:0;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--c-primary);
}
.section-card {
  background:var(--c-50);
  border:1px solid var(--c-200);
  border-radius:var(--r-2xl);
  padding:32px;
}

/* ── FEATURE CARDS ───────────────────────────────────────────── */
.feat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.feat-card {
  background:#fff; border:1px solid var(--c-200);
  border-radius:var(--r-xl); padding:28px 28px 32px;
  display:flex; flex-direction:column; gap:16px;
  transition:var(--tr);
  position:relative;
  box-shadow:inset 0 2px 0 transparent;
}
.feat-card:hover {
  border-color:rgba(79,70,229,.18);
  box-shadow:inset 0 2px 0 var(--c-primary), 0 12px 40px rgba(79,70,229,.1), 0 4px 12px rgba(0,0,0,.06);
  transform:translateY(-4px);
}
.feat-icon {
  width:52px; height:52px;
  border-radius:var(--r-md);
  background:var(--g-primary);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:1.25rem;
  transition:transform .3s var(--ease);
}
.feat-card:hover .feat-icon { transform:scale(1.08) }
.feat-card h4 { font-size:1.0625rem }
.feat-card p  { font-size:.9rem; line-height:1.65; margin:0 }

/* ── PRICING ─────────────────────────────────────────────────── */
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.pricing-card {
  background:#fff; border:1.5px solid var(--c-200);
  border-radius:var(--r-2xl); padding:36px;
  display:flex; flex-direction:column; gap:20px;
  transition:var(--tr); position:relative;
}
.pricing-card:hover { box-shadow:var(--sh-lg); transform:translateY(-4px) }
.pricing-card.popular { border-color:var(--c-primary); box-shadow:var(--sh-pri) }
.pop-badge {
  position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  background:var(--g-primary); color:#fff;
  font-size:.75rem; font-weight:700;
  padding:5px 18px; border-radius:var(--r-full);
  white-space:nowrap; font-family:var(--f-head);
}
.p-tier   { font-size:.8125rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--c-primary) }
.p-price  { display:flex; align-items:baseline; gap:4px }
.p-cur    { font-size:1.25rem; font-weight:700; color:var(--c-700) }
.p-amt    { font-family:var(--f-head); font-size:3rem; font-weight:900; color:var(--c-900); line-height:1 }
.p-per    { font-size:.875rem; color:var(--c-500) }
.p-desc   { font-size:.9rem; line-height:1.65; margin:0 }
.p-feats  { display:flex; flex-direction:column; gap:10px; flex:1 }
.p-feat   { display:flex; align-items:center; gap:10px; font-size:.9rem; color:var(--c-600) }
.p-feat i { color:#10b981; font-size:.875rem; flex-shrink:0 }
.p-feat.x { color:var(--c-300) }
.p-feat.x i { color:var(--c-300) }

/* ── FAQ ─────────────────────────────────────────────────────── */
.faq-list { max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:12px }
.faq-item { border:1px solid var(--c-200); border-radius:var(--r-lg); overflow:hidden; transition:var(--tr) }
.faq-item.open { border-color:rgba(79,70,229,.35); box-shadow:var(--sh-sm) }
.faq-q {
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:20px 24px; cursor:pointer;
  font-family:var(--f-head); font-weight:600; font-size:.9375rem; color:var(--c-900);
  transition:var(--tr); user-select:none;
}
.faq-q:hover { background:var(--c-50) }
.faq-q i { color:var(--c-primary); font-size:.875rem; transition:transform .3s var(--ease); flex-shrink:0 }
.faq-item.open .faq-q i { transform:rotate(180deg) }
.faq-a { display:none; padding:0 24px 20px; font-size:.9375rem; color:var(--c-600); line-height:1.75 }
.faq-item.open .faq-a { display:block }

/* ── CONTACT FORM ────────────────────────────────────────────── */
.contact-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:64px; align-items:start }
.contact-info { display:flex; flex-direction:column; gap:32px }
.ci-item { display:flex; align-items:flex-start; gap:16px }
.ci-icon {
  width:50px; height:50px;
  border-radius:var(--r-md);
  background:rgba(79,70,229,.08);
  border:1px solid rgba(79,70,229,.15);
  display:flex; align-items:center; justify-content:center;
  color:var(--c-primary); font-size:1.125rem; flex-shrink:0;
}
.ci-text h5 { font-size:.9375rem; margin-bottom:4px }
.ci-text p,.ci-text a { font-size:.9375rem; color:var(--c-500); line-height:1.6 }
.ci-text a:hover { color:var(--c-primary) }
.contact-socials { display:flex; gap:10px; flex-wrap:wrap }
.contact-social {
  width:40px;
  height:40px;
  border-radius:10px;
  background:var(--c-50);
  border:1px solid var(--c-200);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--c-500);
  font-size:.9375rem;
  transition:var(--tr);
}
.contact-social:hover { color:#fff; transform:translateY(-2px) }
.contact-social.facebook:hover { background:#1877f2; border-color:#1877f2 }
.contact-social.instagram:hover { background:#e1306c; border-color:#e1306c }
.contact-social.linkedin:hover { background:#0a66c2; border-color:#0a66c2 }
.contact-social.telegram:hover { background:#0088cc; border-color:#0088cc }

.form-card { background:#fff; border:1px solid var(--c-200); border-radius:var(--r-2xl); padding:40px; box-shadow:var(--sh-lg) }
.form-alert {
  margin-bottom:20px; padding:14px 16px;
  border-radius:var(--r-md); border:1px solid transparent;
  font-size:.9375rem; line-height:1.6; font-weight:500;
}
.form-alert.success { background:#ecfdf5; color:#065f46; border-color:#a7f3d0 }
.form-alert.error { background:#fef2f2; color:#991b1b; border-color:#fecaca }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px }
.fg { display:flex; flex-direction:column; gap:8px }
.fg.full { grid-column:1/-1 }
.hp-field { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden }
.fl { font-family:var(--f-head); font-size:.875rem; font-weight:600; color:var(--c-700) }
.fi-input,.fi-select,.fi-textarea {
  width:100%; padding:14px 16px;
  border:1.5px solid var(--c-200);
  border-radius:var(--r-md);
  font:inherit; font-size:.9375rem;
  color:var(--c-900); background:#fff;
  transition:var(--tr-fast); outline:none;
}
.fi-input:focus,.fi-select:focus,.fi-textarea:focus {
  border-color:var(--c-primary);
  box-shadow:0 0 0 3px rgba(79,70,229,.1);
}
.fi-textarea { resize:vertical; min-height:130px; line-height:1.6 }
.fi-select {
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:16px; padding-right:42px;
}
.f-err { font-size:.8125rem; color:#ef4444; font-weight:500 }

/* ── PORTFOLIO ───────────────────────────────────────────────── */
.filter-bar { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-bottom:40px }
.f-btn {
  font-family:var(--f-head); font-weight:600; font-size:.875rem;
  padding:9px 22px; border-radius:var(--r-full);
  border:1.5px solid var(--c-200); color:var(--c-600);
  transition:var(--tr); background:#fff; cursor:pointer;
}
.f-btn:hover,.f-btn.active { background:var(--g-primary); border-color:transparent; color:#fff; box-shadow:var(--sh-pri) }
.port-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.port-card {
  border-radius:var(--r-xl); overflow:hidden;
  background:#fff; border:1px solid var(--c-200);
  box-shadow:var(--sh-sm); transition:var(--tr);
}
.port-card:hover { transform:translateY(-6px); box-shadow:var(--sh-xl) }
.port-img-box { overflow:hidden; height:240px }
.port-img { width:100%; height:100%; object-fit:cover; transition:transform .5s var(--ease) }
.port-card:hover .port-img { transform:scale(1.06) }
.port-body { padding:20px 24px }
.port-cat { font-size:.75rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--c-primary); margin-bottom:8px }
.port-body h4 { font-size:1.0625rem; margin-bottom:6px }
.port-body p  { font-size:.875rem; color:var(--c-500); line-height:1.6 }

/* ── TEAM / FEATURED CONTENT / LEGAL ────────────────────────── */
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px }
.team-card {
  background:#fff;
  border:1px solid var(--c-200);
  border-radius:var(--r-2xl);
  padding:20px;
  text-align:center;
  box-shadow:var(--sh-sm);
  transition:var(--tr);
}
.team-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); border-color:rgba(79,70,229,.22) }
.team-photo-wrap {
  border-radius:20px;
  overflow:hidden;
  margin-bottom:16px;
  box-shadow:var(--sh-md);
}
.team-photo-wrap img {
  width:100%;
  height:260px;
  object-fit:cover;
  display:block;
}
.team-role {
  color:var(--c-primary);
  font-weight:600;
  font-size:.875rem;
  margin:6px 0 10px;
}
.team-card p {
  font-size:.875rem;
  color:var(--c-500);
  margin:0;
}
.featured-panel {
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:stretch;
  background:#fff;
  border:1px solid rgba(79,70,229,.12);
  border-radius:var(--r-2xl);
  overflow:hidden;
  box-shadow:0 24px 64px rgba(79,70,229,.11),0 6px 20px rgba(0,0,0,.06);
  position:relative;
}
.featured-panel::before {
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:var(--g-primary);
  z-index:2;
}
.featured-panel-flip { direction:rtl }
.featured-panel-flip .featured-panel-copy,
.featured-panel-flip .featured-panel-media { direction:ltr }
.featured-panel-media {
  overflow:hidden;
  position:relative;
  min-height:460px;
}
.featured-panel-media img {
  width:100%;
  height:100%;
  min-height:460px;
  object-fit:cover;
  object-position:center 15%;
  display:block;
  transition:transform .7s var(--ease);
}
.featured-panel:hover .featured-panel-media img { transform:scale(1.04) }
.featured-panel-media::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to right,rgba(15,23,42,.2) 0%,transparent 55%);
  pointer-events:none;
}
.featured-panel-flip .featured-panel-media::after {
  background:linear-gradient(to left,rgba(15,23,42,.2) 0%,transparent 55%);
}
.featured-panel-copy {
  padding:56px 52px 56px 52px;
  display:flex;
  flex-direction:column;
  gap:20px;
  background:linear-gradient(160deg,#fff 0%,var(--c-50) 100%);
  position:relative;
  overflow:hidden;
}
.featured-panel-copy::after {
  content:'';
  position:absolute;
  top:-60px;right:-60px;
  width:260px;height:260px;
  background:radial-gradient(circle,rgba(79,70,229,.06) 0%,transparent 70%);
  border-radius:50%;
  pointer-events:none;
}
.featured-panel .stat-cluster { padding-top:4px }
.featured-panel .stat-chip strong { font-size:2.25rem }
.featured-panel .info-list li { color:var(--c-600) }
.featured-panel .info-list li::before {
  background: var(--g-primary);
  width:7px;height:7px;
  top:.7em;
}
/* Portrait variant — for panels where image is a person/portrait photo */
.featured-panel-portrait .featured-panel-media { min-height:540px }
.featured-panel-portrait .featured-panel-media img {
  min-height:540px;
  object-position:center top;
}
.newsletter-card {
  background:var(--g-primary);
  border-radius:var(--r-2xl);
  padding:64px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.newsletter-grid {
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:40px 40px;
}
.newsletter-content {
  position:relative;
  z-index:1;
  max-width:520px;
  margin:0 auto;
}
.newsletter-row {
  display:flex;
  gap:12px;
  max-width:440px;
  margin:0 auto;
}
.newsletter-input {
  flex:1;
  padding:14px 18px;
  border-radius:var(--r-full);
  border:none;
  font-size:.9375rem;
  outline:none;
  font-family:var(--f-body);
}
.legal-shell {
  max-width:920px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:24px;
}
.legal-intro {
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:24px;
  background:var(--c-50);
  border:1px solid var(--c-200);
  border-radius:var(--r-2xl);
  padding:28px;
}
.legal-intro h3 { margin-bottom:10px }
.legal-summary {
  background:#fff;
  border:1px solid var(--c-200);
  border-radius:var(--r-xl);
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.legal-summary-item {
  display:flex;
  flex-direction:column;
  gap:4px;
}
.legal-summary-item strong {
  font-family:var(--f-head);
  font-size:.9rem;
  color:var(--c-900);
}
.legal-summary-item span {
  font-size:.875rem;
  color:var(--c-500);
}
.legal-body {
  background:#fff;
  border:1px solid var(--c-200);
  border-radius:var(--r-2xl);
  padding:40px;
  box-shadow:var(--sh-sm);
}
.legal-body h3 {
  color:var(--c-900);
  margin:40px 0 16px;
}
.legal-body h3:first-child { margin-top:0 }
.legal-list {
  list-style:disc;
  margin:12px 0 16px 20px;
  color:var(--c-600);
}
.legal-list li + li { margin-top:8px }
.legal-contact {
  margin-top:18px;
  padding:20px 22px;
  background:var(--c-50);
  border:1px solid var(--c-200);
  border-radius:var(--r-xl);
}

/* ── SCROLL TO TOP ───────────────────────────────────────────── */
.scroll-top {
  position:fixed; bottom:32px; right:32px;
  width:48px; height:48px;
  background:var(--g-primary);
  color:#fff; border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; box-shadow:var(--sh-pri);
  opacity:0; visibility:hidden; transform:translateY(16px);
  transition:var(--tr); z-index:900; cursor:pointer;
}
.scroll-top.visible { opacity:1; visibility:visible; transform:translateY(0) }
.scroll-top:hover   { transform:translateY(-3px) }

/* ── REVEAL ──────────────────────────────────────────────────── */
.reveal       { opacity:0; transform:translateY(28px); transition:opacity .65s var(--ease),transform .65s var(--ease) }
.reveal.in    { opacity:1; transform:translateY(0) }
.reveal-l     { opacity:0; transform:translateX(-32px); transition:opacity .65s var(--ease),transform .65s var(--ease) }
.reveal-l.in  { opacity:1; transform:translateX(0) }
.reveal-r     { opacity:0; transform:translateX(32px);  transition:opacity .65s var(--ease),transform .65s var(--ease) }
.reveal-r.in  { opacity:1; transform:translateX(0) }
.reveal-s     { opacity:0; transform:scale(.94); transition:opacity .55s var(--ease),transform .55s var(--ease) }
.reveal-s.in  { opacity:1; transform:scale(1) }
.d1 { transition-delay:.1s } .d2 { transition-delay:.2s } .d3 { transition-delay:.3s }
.d4 { transition-delay:.4s } .d5 { transition-delay:.5s }

/* ── TOAST ───────────────────────────────────────────────────── */
.toast {
  position:fixed; top:24px; right:24px;
  background:#fff; border:1px solid var(--c-200);
  border-radius:var(--r-lg); padding:16px 20px;
  box-shadow:var(--sh-xl);
  display:flex; align-items:center; gap:12px;
  font-size:.9375rem; font-weight:500; color:var(--c-900);
  z-index:9000; transform:translateX(130%);
  transition:transform .4s var(--ease); max-width:360px;
}
.toast.show { transform:translateX(0) }
.toast.success .t-ico { color:#10b981 }
.toast.error   .t-ico { color:#ef4444 }
.t-ico { font-size:1.25rem; flex-shrink:0 }

/* ── MAP EMBED / CONTACT PAGE ────────────────────────────────── */
.map-embed {
  width:100%; height:360px;
  border-radius:var(--r-2xl);
  overflow:hidden; border:1px solid var(--c-200);
  box-shadow:var(--sh-md);
}
.map-embed iframe { width:100%; height:100%; display:block }

/* ── DIVIDER ─────────────────────────────────────────────────── */
.hr { height:1px; background:var(--c-200) }

/* ── MARQUEE ─────────────────────────────────────────────────── */
.marquee-outer {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 12%, black 88%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, black 12%, black 88%, transparent 100%);
  padding: 4px 0;
}
.marquee-track {
  display: flex;
  width: max-content;
  animation: marquee-scroll 34s linear infinite;
}
.marquee-track:hover { animation-play-state: paused; }
.marquee-track .client-logo { margin-right: 56px; flex-shrink: 0; }
@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ── COMPARISON / WHY A1 ─────────────────────────────────────── */
.compare-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: var(--r-2xl);
  overflow: hidden;
  box-shadow: var(--sh-xl);
  border: 1px solid var(--c-200);
  max-width: 900px;
  margin: 0 auto;
}
.compare-col { padding: 44px 48px; }
.compare-col.col-old { background: var(--c-50); }
.compare-col.col-new { background: var(--g-primary); }

.compare-col-head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding-bottom: 24px;
  margin-bottom: 24px;
}
.compare-col.col-old .compare-col-head { border-bottom: 1px solid var(--c-200); }
.compare-col.col-new .compare-col-head { border-bottom: 1px solid rgba(255,255,255,.2); }
.compare-col.col-old .compare-col-head h4 { color: var(--c-500); font-size: 1.0625rem; }
.compare-col.col-new .compare-col-head h4 { color: #fff; font-size: 1.0625rem; }
.cch-icon {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .875rem; flex-shrink: 0;
}
.cch-old { background: rgba(239,68,68,.12); color: #ef4444; }
.cch-new { background: rgba(255,255,255,.2); color: #fff; }

.compare-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
}
.compare-col.col-old .compare-row { border-bottom: 1px solid var(--c-100); }
.compare-col.col-new .compare-row { border-bottom: 1px solid rgba(255,255,255,.1); }
.compare-row:last-child { border-bottom: none !important; }
.cmp-icon {
  width: 26px; height: 26px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: .7rem; flex-shrink: 0;
}
.cmp-no  { background: rgba(239,68,68,.12); color: #ef4444; }
.cmp-yes { background: rgba(255,255,255,.25); color: #fff; }
.compare-col.col-old .compare-row span { font-size: .9375rem; color: var(--c-400); }
.compare-col.col-new .compare-row span { font-size: .9375rem; color: rgba(255,255,255,.9); font-weight: 500; }

/* ── INDUSTRIES ──────────────────────────────────────────────── */
.industry-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.industry-card {
  background: #fff;
  border: 1px solid var(--c-200);
  border-radius: var(--r-xl);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: var(--tr);
  position: relative;
  overflow: hidden;
}
.industry-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: var(--g-primary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .4s var(--ease);
}
.industry-card:hover { border-color: rgba(79,70,229,.25); box-shadow: var(--sh-lg); transform: translateY(-6px); }
.industry-card:hover::after { transform: scaleX(1); }
.industry-icon {
  width: 56px; height: 56px;
  border-radius: var(--r-lg);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.375rem;
}
.industry-card h4 { font-size: 1.0625rem; margin: 0; }
.industry-card > p { font-size: .875rem; color: var(--c-500); line-height: 1.65; margin: 0; flex: 1; }
.industry-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--f-head); font-size: .875rem; font-weight: 600;
  color: var(--c-primary); transition: var(--tr);
}
.industry-link:hover { gap: 10px; }

/* ── PROCESS STEP NUMBERS ────────────────────────────────────── */
.step-icon-wrap { position: relative; }
.step-num {
  position: absolute;
  top: -8px; right: -8px;
  width: 22px; height: 22px;
  background: var(--g-primary);
  color: #fff;
  border-radius: 50%;
  font-family: var(--f-head);
  font-size: .6875rem;
  font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(79,70,229,.4);
  letter-spacing: 0;
}

/* ── BADGE ORANGE ────────────────────────────────────────────── */
.badge-orange { background:rgba(245,158,11,.1); color:#d97706; border:1px solid rgba(245,158,11,.25) }

/* ── INFO CARD ICON ──────────────────────────────────────────── */
.info-card-icon {
  width:52px; height:52px;
  border-radius:var(--r-md);
  background:var(--g-primary);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.25rem;
  flex-shrink:0;
}

/* ── LOCAL SEO STATS STRIP ───────────────────────────────────── */
.lseo-stat-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.lseo-stat-card {
  background:#fff;
  border:1px solid var(--c-200);
  border-radius:var(--r-xl);
  padding:36px 28px;
  text-align:center;
  box-shadow:var(--sh-sm);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  transition:var(--tr);
}
.lseo-stat-card:hover { transform:translateY(-4px); box-shadow:var(--sh-md); border-color:rgba(79,70,229,.2) }
.lseo-stat-icon {
  width:56px; height:56px;
  border-radius:var(--r-lg);
  background:var(--g-primary);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.375rem;
  flex-shrink:0;
}
.lseo-stat-num {
  font-family:var(--f-head);
  font-size:3.25rem;
  font-weight:900;
  color:var(--c-primary);
  line-height:1;
  letter-spacing:-.03em;
}
.lseo-stat-text {
  font-size:.9375rem;
  color:var(--c-700);
  font-weight:500;
  line-height:1.55;
  max-width:220px;
}
.lseo-stat-source {
  font-size:.75rem;
  color:var(--c-400);
  font-style:italic;
}

/* ── FREE AUDIT STRIP ────────────────────────────────────────── */
.audit-strip {
  background: linear-gradient(135deg, #0f172a 0%, #1e1040 50%, #0f172a 100%);
  padding: 40px 0;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(79,70,229,.2);
  border-bottom: 1px solid rgba(79,70,229,.2);
}
.audit-strip::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30% 50%, rgba(79,70,229,.25) 0%, transparent 60%),
              radial-gradient(ellipse at 70% 50%, rgba(168,85,247,.15) 0%, transparent 60%);
}
.audit-inner {
  position: relative; z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}
.audit-text { display: flex; flex-direction: column; gap: 6px; }
.audit-text strong {
  font-family: var(--f-head);
  font-size: 1.25rem;
  font-weight: 800;
  color: #fff;
}
.audit-text span { font-size: .9375rem; color: rgba(255,255,255,.55); }
.audit-perks {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
}
.audit-perk {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: .875rem;
  color: rgba(255,255,255,.55);
}
.audit-perk i { color: #10b981; font-size: .75rem; }
