/* ═══════════════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════════════ */
:root {
  --bg-base:        #020817;
  --bg-surface:     #0d1526;
  --bg-elevated:    #111d35;
  --bg-card:        #0f1a2e;
  --bg-card-hover:  #142040;
  --border-subtle:  rgba(99,120,170,0.14);
  --border-default: rgba(99,120,170,0.22);
  --border-strong:  rgba(99,120,170,0.38);
  --border-accent:  rgba(59,130,246,0.35);
  --blue-100: #dbeafe;
  --blue-300: #93c5fd;
  --blue-400: #60a5fa;
  --blue-500: #3b82f6;
  --blue-600: #2563eb;
  --blue-700: #1d4ed8;
  --green-300: #86efac;
  --green-400: #4ade80;
  --green-500: #22c55e;
  --green-600: #16a34a;
  --text-primary:   #f0f4ff;
  --text-secondary: #c8d4f0;
  --text-muted:     #7a8fb5;
  --text-faint:     #3d5080;
  --r-sm:  6px;
  --r-md:  10px;
  --r-lg:  14px;
  --r-xl:  20px;
  --r-2xl: 28px;
  --shadow-card:       0 4px 24px rgba(0,0,0,0.35),0 1px 4px rgba(0,0,0,0.2);
  --shadow-modal:      0 24px 80px rgba(0,0,0,0.7),0 0 0 1px rgba(59,130,246,0.12);
  --shadow-glow-blue:  0 0 40px rgba(59,130,246,0.18);
  --shadow-glow-green: 0 0 40px rgba(34,197,94,0.14);
  --t-fast: 0.15s ease;
  --t-med:  0.28s ease;
}

/* ═══════════════════════════════════════════
   RESET
═══════════════════════════════════════════ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg-base); color:var(--text-primary);
  line-height:1.6; -webkit-font-smoothing:antialiased;
  overflow-x:hidden; min-height:100vh;
}
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
img { max-width:100%; display:block; }
ul,ol { list-style:none; }

/* ═══════════════════════════════════════════
   BACKGROUND
═══════════════════════════════════════════ */
body::before {
  content:""; position:fixed; inset:0; z-index:-2;
  background:
    linear-gradient(to right,rgba(59,130,246,0.04) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(59,130,246,0.04) 1px,transparent 1px);
  background-size:44px 44px;
}
body::after {
  content:""; position:fixed; inset:0; z-index:-1;
  background:
    radial-gradient(ellipse 80% 50% at 10% -10%,rgba(37,99,235,0.22) 0,transparent 60%),
    radial-gradient(ellipse 60% 40% at 90% 5%,rgba(139,92,246,0.14) 0,transparent 55%),
    radial-gradient(ellipse 70% 50% at 50% 110%,rgba(34,197,94,0.12) 0,transparent 60%);
  animation:orbDrift 18s ease-in-out infinite alternate;
}

/* ═══════════════════════════════════════════
   KEYFRAMES
═══════════════════════════════════════════ */
@keyframes orbDrift {
  0%  { transform:translate(0,0) scale(1); }
  50% { transform:translate(-18px,12px) scale(1.04); }
  100%{ transform:translate(14px,-8px) scale(0.97); }
}
@keyframes fadeUp    { from{opacity:0;transform:translateY(22px);}  to{opacity:1;transform:translateY(0);} }
@keyframes fadeLeft  { from{opacity:0;transform:translateX(-22px);} to{opacity:1;transform:translateX(0);} }
@keyframes fadeRight { from{opacity:0;transform:translateX(22px);}  to{opacity:1;transform:translateX(0);} }
@keyframes scaleIn   { from{opacity:0;transform:scale(0.93);}       to{opacity:1;transform:scale(1);} }
@keyframes fadeIn    { from{opacity:0;}                              to{opacity:1;} }
@keyframes shimmer   { 0%{background-position:-200% center;} 100%{background-position:200% center;} }
@keyframes pulseRing { 0%{transform:scale(1);opacity:1;} 100%{transform:scale(1.7);opacity:0;} }
@keyframes floatY    { 0%,100%{transform:translateY(0);} 50%{transform:translateY(-7px);} }
@keyframes spin      { to{transform:rotate(360deg);} }
@keyframes mobileNavIn {
  from{opacity:0;transform:translateX(-50%) translateY(-10px);}
  to{opacity:1;transform:translateX(-50%) translateY(0);}
}

/* Scroll reveal */
.reveal,.reveal-left,.reveal-right {
  opacity:0; transition:opacity 0.65s ease,transform 0.65s ease;
}
.reveal       { transform:translateY(28px); }
.reveal-left  { transform:translateX(-28px); }
.reveal-right { transform:translateX(28px); }
.reveal.visible,.reveal-left.visible,.reveal-right.visible {
  opacity:1; transform:translate(0);
}
.delay-1{transition-delay:0.08s;}
.delay-2{transition-delay:0.16s;}
.delay-3{transition-delay:0.24s;}
.delay-4{transition-delay:0.32s;}
.delay-5{transition-delay:0.40s;}
.delay-6{transition-delay:0.48s;}

/* ═══════════════════════════════════════════
   LAYOUT
═══════════════════════════════════════════ */
.page       { min-height:100vh; display:flex; flex-direction:column; }
.container  { max-width:1180px; margin:0 auto; padding:0 1.5rem; }
.section    { padding:4rem 0; }
.section-sm { padding:2.5rem 0; }

.section-label {
  display:inline-flex; align-items:center; gap:0.5rem;
  font-size:0.7rem; font-weight:700; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--blue-400); margin-bottom:0.6rem;
}
.section-label::before {
  content:""; display:block; width:20px; height:2px;
  background:var(--blue-500); border-radius:2px;
}
.section-heading {
  font-size:clamp(1.5rem,2.5vw + 0.8rem,2.1rem);
  font-weight:800; color:var(--text-primary); line-height:1.2; margin-bottom:0.5rem;
}
.section-sub {
  font-size:0.95rem; color:var(--text-muted); max-width:36rem; line-height:1.7;
}
.section-header {
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:1.5rem; margin-bottom:2rem;
}

.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:1.4rem; }
.grid-2-asym { display:grid; grid-template-columns:1.35fr 2fr; gap:1.6rem; }

@media(max-width:900px) {
  .grid-3 { grid-template-columns:repeat(2,1fr); }
  .grid-2,.grid-2-asym { grid-template-columns:1fr; }
}
@media(max-width:560px) { .grid-3 { grid-template-columns:1fr; } }
@media(max-width:768px) {
  .section { padding:2.8rem 0; }
  .section-header { flex-direction:column; align-items:flex-start; }
}

/* ═══════════════════════════════════════════
   FLOATING PILL HEADER
═══════════════════════════════════════════ */
.site-header {
  position:fixed; top:1rem; left:50%; transform:translateX(-50%);
  width:calc(100% - 2.5rem); max-width:1100px; z-index:100;
  background:rgba(10,15,35,0.72);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(99,120,170,0.18); border-radius:999px;
  box-shadow:0 8px 32px rgba(0,0,0,0.45),
             0 1px 0 rgba(255,255,255,0.04) inset,
             0 0 0 1px rgba(37,99,235,0.06);
  transition:background var(--t-med),border-color var(--t-med),
             box-shadow var(--t-med),top var(--t-med);
}
.site-header.scrolled {
  background:rgba(8,12,28,0.92);
  border-color:rgba(99,120,170,0.28);
  box-shadow:0 12px 48px rgba(0,0,0,0.6),
             0 1px 0 rgba(255,255,255,0.05) inset,
             0 0 0 1px rgba(37,99,235,0.1),
             0 0 40px rgba(37,99,235,0.06);
  top:0.6rem;
}
.site-header::before {
  content:""; position:absolute; top:0; left:15%; right:15%; height:1px;
  border-radius:999px;
  background:linear-gradient(90deg,transparent,rgba(37,99,235,0.55),rgba(34,197,94,0.4),transparent);
  background-size:200% 100%; animation:shimmer 5s linear infinite;
  pointer-events:none;
}
.site-header::after {
  content:""; position:absolute; inset:0; border-radius:999px;
  background:radial-gradient(ellipse 60% 100% at 50% 0%,rgba(37,99,235,0.05) 0,transparent 70%);
  pointer-events:none;
}

.nav {
  display:flex; align-items:center; justify-content:space-between;
  gap:1rem; height:56px; padding:0 1.2rem;
}

/* Logo */
.logo {
  display:flex; align-items:center; gap:0.6rem;
  flex-shrink:0; transition:opacity var(--t-fast);
}
.logo:hover { opacity:0.85; }

/* Base pill styling (keeps gradient + shimmer) */
.logo-mark {
  width:40px;
  height:40px;
  border-radius:8px;  /* rounded square, not circle */
  background:linear-gradient(135deg,#1e40af 0%,#1d4ed8 40%,#0f766e 100%);
  border:1px solid rgba(59,130,246,0.4);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:0.65rem;
  font-weight:900;
  color:#fff;
  position:relative;
  overflow:hidden;
  flex-shrink:0;
}
.logo-mark::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg,transparent 35%,rgba(255,255,255,0.15) 50%,transparent 65%);
  background-size:200% 200%; animation:shimmer 4s linear infinite;
}

/* Icon inside pill */
.logo-mark-icon {
  width:100%;
  height:100%;
  display:block;
}

/* Text logo */
.logo-name    { font-size:0.85rem; font-weight:700; color:var(--text-primary); line-height:1.2; }
.logo-tagline { font-size:0.62rem; font-weight:500; color:var(--text-faint); letter-spacing:0.14em; text-transform:uppercase; }


/* Nav links */
.nav-links { display:flex; align-items:center; gap:0; }
.nav-link {
  padding:0.32rem 0.62rem; border-radius:999px;
  font-size:0.8rem; font-weight:500; color:var(--text-muted);
  transition:color var(--t-fast),background var(--t-fast);
  cursor:pointer; white-space:nowrap; display:inline-flex; align-items:center; gap:0.3rem;
}
.nav-link:hover,
.nav-link.active {
  color:var(--text-primary); background:rgba(255,255,255,0.06);
}

/* Nav dropdown */
.nav-dropdown { position:relative; }
.nav-dropdown-toggle { cursor:pointer; }
.nav-dropdown-menu {
  position:absolute; top:calc(100% + 0.6rem); left:50%;
  transform:translateX(-50%);
  background:rgba(8,12,28,0.97);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--border-default); border-radius:var(--r-lg);
  padding:0.4rem; min-width:200px;
  box-shadow:0 16px 48px rgba(0,0,0,0.55);
  opacity:0; pointer-events:none;
  transform:translateX(-50%) translateY(-6px);
  transition:opacity var(--t-fast),transform var(--t-fast);
  z-index:200;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu {
  opacity:1; pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.nav-dropdown-item {
  display:flex; align-items:center; justify-content:space-between;
  gap:0.5rem; padding:0.55rem 0.75rem; border-radius:var(--r-md);
  font-size:0.82rem; font-weight:500; color:var(--text-secondary);
  transition:all var(--t-fast);
}
.nav-dropdown-item:hover {
  background:rgba(37,99,235,0.1); color:var(--text-primary);
}
.nav-dropdown-item--soon { opacity:0.6; cursor:default; }
.nav-dropdown-item--soon:hover { background:none; color:var(--text-secondary); }

/* Nav CTAs */
.nav-actions { display:flex; align-items:center; gap:0.4rem; flex-shrink:0; }
.btn-nav-ghost {
  padding:0.36rem 0.85rem; border-radius:999px;
  border:1px solid var(--border-default);
  font-size:0.73rem; font-weight:600; letter-spacing:0.07em;
  text-transform:uppercase; color:var(--text-secondary);
  background:transparent; transition:all var(--t-fast);
  display:inline-flex; align-items:center; gap:0.3rem; white-space:nowrap;
}
.btn-nav-ghost:hover {
  border-color:rgba(34,197,94,0.45);
  color:var(--green-300); background:rgba(34,197,94,0.06);
}
.btn-nav-primary {
  padding:0.38rem 0.95rem; border-radius:999px;
  border:1px solid rgba(37,99,235,0.5);
  font-size:0.73rem; font-weight:700; letter-spacing:0.07em;
  text-transform:uppercase; color:var(--blue-100);
  background:rgba(37,99,235,0.14); transition:all var(--t-fast);
  display:inline-flex; align-items:center; gap:0.3rem; white-space:nowrap;
}
.btn-nav-primary:hover {
  background:rgba(37,99,235,0.26); border-color:rgba(37,99,235,0.75);
  color:#fff; box-shadow:0 0 20px rgba(37,99,235,0.2);
}

/* Soon pill */
.soon-pill {
  display:inline-block; padding:0.06rem 0.4rem; border-radius:999px;
  background:rgba(139,92,246,0.15); border:1px solid rgba(139,92,246,0.3);
  font-size:0.62rem; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; color:#c4b5fd;
}

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:4px;
  padding:5px; background:none; border:none; cursor:pointer; flex-shrink:0;
}
.hamburger span {
  display:block; width:20px; height:2px;
  background:var(--text-muted); border-radius:2px; transition:all var(--t-fast);
}
.hamburger.open span:nth-child(1) { transform:translateY(6px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-6px) rotate(-45deg); }

/* Mobile nav */
.mobile-nav {
  display:none; position:fixed;
  top:calc(1rem + 56px + 0.5rem); left:50%; transform:translateX(-50%);
  width:calc(100% - 2.5rem); max-width:1100px;
  background:rgba(8,12,28,0.96);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(99,120,170,0.2); border-radius:20px;
  padding:1rem 1.25rem 1.4rem;
  flex-direction:column; gap:0.25rem; z-index:99;
  box-shadow:0 16px 48px rgba(0,0,0,0.55);
  animation:mobileNavIn 0.22s ease;
}
.mobile-nav.open { display:flex; }
.mobile-nav .nav-link {
  font-size:0.92rem; padding:0.62rem 0.6rem;
  border-radius:var(--r-md);
  border-bottom:1px solid var(--border-subtle);
  color:var(--text-secondary); display:block;
}
.mobile-nav-ctas {
  display:flex; flex-direction:column; gap:0.55rem;
  margin-top:0.75rem; padding-top:0.75rem;
  border-top:1px solid var(--border-subtle);
}
.mobile-nav-ctas button {
  width:100%; justify-content:center;
  padding:0.7rem 1rem; font-size:0.84rem;
}

/* Push content below floating header */
main { padding-top:5.5rem; }

@media(max-width:900px) {
  .site-header { width:calc(100% - 2rem); top:0.75rem; }
  .site-header.scrolled { top:0.5rem; }
  .mobile-nav { top:calc(0.75rem + 56px + 0.5rem); width:calc(100% - 2rem); }
}
@media(max-width:820px) {
  .nav-links,.nav-actions { display:none; }
  .hamburger { display:flex; }
}
@media(max-width:480px) {
  .site-header { width:calc(100% - 1.5rem); top:0.6rem; border-radius:18px; }
  .site-header.scrolled { top:0.4rem; }
  .mobile-nav { width:calc(100% - 1.5rem); top:calc(0.6rem + 56px + 0.4rem); border-radius:16px; }
  .nav { height:52px; padding:0 1rem; }
  main { padding-top:4.8rem; }
}

/* ═══════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:0.45rem;
  font-family:inherit; font-weight:700; letter-spacing:0.06em; text-transform:uppercase;
  border-radius:999px; cursor:pointer; transition:all var(--t-fast);
  position:relative; overflow:hidden; white-space:nowrap;
}
.btn::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,0.08) 50%,transparent 60%);
  background-size:200% 200%; opacity:0; transition:opacity var(--t-fast);
}
.btn:hover::after { opacity:1; animation:shimmer 0.7s linear; }
.btn:active { transform:scale(0.97); }
.btn-lg { font-size:0.88rem; padding:0.78rem 1.9rem; }
.btn-md { font-size:0.82rem; padding:0.65rem 1.5rem; }
.btn-sm { font-size:0.76rem; padding:0.5rem 1.1rem; }
.btn-blue {
  background:linear-gradient(135deg,var(--blue-600),var(--blue-700));
  border:1px solid rgba(37,99,235,0.7); color:#fff;
  box-shadow:0 4px 16px rgba(37,99,235,0.3);
}
.btn-blue:hover {
  background:linear-gradient(135deg,var(--blue-500),var(--blue-600));
  box-shadow:0 6px 24px rgba(37,99,235,0.45); transform:translateY(-2px);
}
.btn-green {
  background:linear-gradient(135deg,rgba(34,197,94,0.18),rgba(22,163,74,0.14));
  border:1px solid rgba(34,197,94,0.45); color:var(--green-300);
  box-shadow:0 4px 16px rgba(34,197,94,0.12);
}
.btn-green:hover {
  background:linear-gradient(135deg,rgba(34,197,94,0.28),rgba(22,163,74,0.22));
  border-color:rgba(34,197,94,0.75); color:#fff;
  box-shadow:0 6px 24px rgba(34,197,94,0.22); transform:translateY(-2px);
}
.btn-ghost {
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border-default); color:var(--text-secondary);
}
.btn-ghost:hover {
  background:rgba(255,255,255,0.08);
  border-color:var(--border-strong); color:var(--text-primary); transform:translateY(-1px);
}

/* ═══════════════════════════════════════════
   BADGES / PILLS / TAGS
═══════════════════════════════════════════ */
.badge {
  display:inline-flex; align-items:center; gap:0.5rem;
  padding:0.3rem 0.8rem; border-radius:999px;
  border:1px solid rgba(34,197,94,0.25);
  background:rgba(34,197,94,0.07);
  font-size:0.74rem; font-weight:500; color:var(--green-300);
}
.badge-dot {
  width:7px; height:7px; border-radius:999px;
  background:var(--green-500); position:relative; flex-shrink:0;
}
.badge-dot::after {
  content:""; position:absolute; inset:-3px; border-radius:999px;
  background:rgba(34,197,94,0.35); animation:pulseRing 1.8s ease-out infinite;
}
.badge-pill {
  padding:0.08rem 0.5rem; border-radius:999px;
  background:rgba(34,197,94,0.12); color:var(--green-400);
  font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase;
}
.tag {
  display:inline-block; padding:0.22rem 0.6rem; border-radius:999px;
  border:1px solid var(--border-default); background:rgba(15,26,53,0.8);
  font-size:0.74rem; font-weight:500; color:var(--text-secondary);
  transition:all var(--t-fast);
}
.tag:hover { border-color:var(--border-accent); color:var(--blue-300); }
.step-badge {
  display:inline-block; padding:0.1rem 0.55rem; border-radius:999px;
  background:rgba(37,99,235,0.12); border:1px solid rgba(37,99,235,0.22);
  font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--blue-300); margin-bottom:0.5rem;
}

/* ═══════════════════════════════════════════
   CARD BASE
═══════════════════════════════════════════ */
.card {
  background:var(--bg-card); border:1px solid var(--border-default);
  border-radius:var(--r-lg); padding:1.4rem;
  transition:border-color var(--t-med),transform var(--t-med),box-shadow var(--t-med);
}
.card:hover {
  border-color:var(--border-accent); transform:translateY(-3px);
  box-shadow:var(--shadow-card),var(--shadow-glow-blue);
}
.card-icon {
  width:40px; height:40px; border-radius:var(--r-md);
  background:rgba(37,99,235,0.1); border:1px solid rgba(37,99,235,0.2);
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; margin-bottom:0.9rem;
}
.card-title { font-size:1rem; font-weight:700; color:var(--text-primary); margin-bottom:0.45rem; }
.card-body  { font-size:0.875rem; color:var(--text-muted); line-height:1.7; }

/* ═══════════════════════════════════════════
   STATS BAR
═══════════════════════════════════════════ */
.stats-bar {
  background:var(--bg-card); border:1px solid var(--border-default);
  border-radius:var(--r-xl); padding:1.6rem 2rem;
  display:grid; grid-template-columns:repeat(4,1fr); gap:1rem;
  position:relative; overflow:hidden;
}
.stats-bar::before {
  content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(37,99,235,0.5),rgba(34,197,94,0.4),transparent);
}
@media(max-width:640px) { .stats-bar { grid-template-columns:repeat(2,1fr); } }
.stat { text-align:center; }
.stat-num { font-size:2rem; font-weight:900; color:var(--text-primary); line-height:1; margin-bottom:0.3rem; }
.stat-num .unit { color:var(--blue-400); }
.stat-label { font-size:0.72rem; font-weight:600; text-transform:uppercase; letter-spacing:0.12em; color:var(--text-faint); }

/* ═══════════════════════════════════════════
   TESTIMONIALS
═══════════════════════════════════════════ */
.testimonial-card {
  background:var(--bg-card); border:1px solid var(--border-default);
  border-radius:var(--r-lg); padding:1.5rem;
  position:relative; transition:all var(--t-med);
  display:flex; flex-direction:column;
}
.testimonial-card:hover {
  border-color:var(--border-accent); transform:translateY(-4px);
  box-shadow:var(--shadow-card);
}
.testimonial-card::before {
  content:"\201C"; position:absolute; top:0.8rem; right:1.1rem;
  font-size:3.5rem; line-height:1; color:rgba(37,99,235,0.15);
  font-family:Georgia,serif; pointer-events:none;
}
.t-stars { display:flex; gap:0.18rem; margin-bottom:0.75rem; }
.t-star  { color:#fbbf24; font-size:0.82rem; }
.t-text  { font-size:0.9rem; color:var(--text-secondary); line-height:1.75; font-style:italic; flex:1; margin-bottom:1.1rem; }
.t-author { display:flex; align-items:center; gap:0.7rem; }
.t-avatar { width:40px; height:40px; border-radius:999px; display:flex; align-items:center; justify-content:center; font-size:0.82rem; font-weight:800; color:#fff; flex-shrink:0; }
.t-name  { font-size:0.86rem; font-weight:700; color:var(--text-primary); }
.t-role  { font-size:0.74rem; color:var(--text-faint); margin-top:0.05rem; }
.t-verified { display:inline-flex; align-items:center; gap:0.25rem; font-size:0.68rem; font-weight:600; color:var(--green-400); margin-top:0.3rem; }

/* ═══════════════════════════════════════════
   CTA BAND
═══════════════════════════════════════════ */
.cta-band {
  background:linear-gradient(135deg,rgba(13,21,38,0.97) 0%,rgba(9,15,30,0.99) 100%);
  border:1px solid rgba(34,197,94,0.2); border-radius:var(--r-2xl);
  padding:3rem 2.5rem; text-align:center; position:relative; overflow:hidden;
}
.cta-band::before {
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 60% at 20% 50%,rgba(34,197,94,0.07) 0,transparent 70%),
    radial-gradient(ellipse 60% 60% at 80% 50%,rgba(37,99,235,0.07) 0,transparent 70%);
  pointer-events:none;
}
.cta-band::after {
  content:""; position:absolute; top:0; left:10%; right:10%; height:1px;
  background:linear-gradient(90deg,transparent,rgba(34,197,94,0.6),rgba(37,99,235,0.5),transparent);
}
.cta-band-inner { position:relative; z-index:1; }
.cta-band h2 { font-size:clamp(1.5rem,2.5vw + 0.6rem,2rem); font-weight:900; color:var(--text-primary); margin-bottom:0.6rem; }
.cta-band p  { font-size:0.95rem; color:var(--text-muted); max-width:34rem; margin:0 auto 1.8rem; line-height:1.7; }
.cta-band-actions { display:flex; flex-wrap:wrap; gap:0.8rem; justify-content:center; align-items:center; }

/* ═══════════════════════════════════════════
   FAQ
═══════════════════════════════════════════ */
.faq-wrap { background:var(--bg-card); border:1px solid var(--border-default); border-radius:var(--r-xl); overflow:hidden; }
.faq-item { border-bottom:1px solid var(--border-subtle); }
.faq-item:last-child { border-bottom:none; }
.faq-btn {
  width:100%; background:none; border:none;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1.1rem 1.4rem; text-align:left; cursor:pointer;
  transition:background var(--t-fast);
}
.faq-btn:hover { background:rgba(255,255,255,0.025); }
.faq-btn.active { background:rgba(37,99,235,0.04); }
.faq-q { font-size:0.92rem; font-weight:600; color:var(--text-primary); flex:1; }
.faq-icon {
  width:24px; height:24px; border-radius:999px;
  border:1px solid var(--border-default);
  display:flex; align-items:center; justify-content:center;
  font-size:0.85rem; color:var(--text-faint); flex-shrink:0; transition:all var(--t-fast);
}
.faq-btn.active .faq-icon {
  background:rgba(37,99,235,0.12); border-color:rgba(37,99,235,0.35); color:var(--blue-300);
}
.faq-panel { max-height:0; overflow:hidden; transition:max-height 0.32s ease; }
.faq-panel-inner { padding:0 1.4rem 1.1rem; font-size:0.875rem; color:var(--text-muted); line-height:1.75; }

/* ═══════════════════════════════════════════
   PRICING TABS
═══════════════════════════════════════════ */
.pricing-tabs {
  display:flex; flex-wrap:wrap; gap:0.4rem;
  margin-bottom:1.5rem;
  background:var(--bg-card); border:1px solid var(--border-default);
  border-radius:999px; padding:0.3rem;
  width:fit-content;
}
.pricing-tab {
  padding:0.45rem 1.1rem; border-radius:999px;
  font-size:0.8rem; font-weight:600; color:var(--text-muted);
  cursor:pointer; transition:all var(--t-fast); border:none; background:none;
  white-space:nowrap;
}
.pricing-tab:hover { color:var(--text-primary); }
.pricing-tab.active {
  background:linear-gradient(135deg,var(--blue-600),var(--blue-700));
  color:#fff; box-shadow:0 2px 12px rgba(37,99,235,0.35);
}
.pricing-panel { display:none; animation:fadeUp 0.28s ease; }
.pricing-panel.active { display:block; }

.price-card {
  background:var(--bg-card); border:1px solid var(--border-default);
  border-radius:var(--r-xl); padding:1.8rem;
  transition:all var(--t-med); position:relative; overflow:hidden;
}
.price-card:hover {
  border-color:var(--border-accent); transform:translateY(-4px);
  box-shadow:var(--shadow-card),var(--shadow-glow-blue);
}
.price-card.featured {
  border-color:rgba(37,99,235,0.5);
  background:linear-gradient(160deg,rgba(13,21,38,0.97),rgba(9,15,30,0.99));
}
.price-card.featured::before {
  content:"Most Popular"; position:absolute; top:0; right:1.5rem;
  background:linear-gradient(135deg,var(--blue-600),var(--blue-700));
  color:#fff; font-size:0.68rem; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; padding:0.2rem 0.7rem;
  border-radius:0 0 var(--r-md) var(--r-md);
}
.price-amount {
  font-size:2.4rem; font-weight:900; color:var(--text-primary); line-height:1;
}
.price-amount sub {
  font-size:1rem; font-weight:400; color:var(--text-faint);
  vertical-align:baseline; margin-left:0.2rem;
}
.price-period { font-size:0.8rem; color:var(--text-faint); margin-top:0.2rem; }
.price-features {
  margin:1.2rem 0; display:flex; flex-direction:column; gap:0.5rem;
}
.price-feature {
  display:flex; align-items:flex-start; gap:0.5rem;
  font-size:0.875rem; color:var(--text-secondary); line-height:1.5;
}
.price-feature-icon {
  width:16px; height:16px; border-radius:999px;
  background:rgba(34,197,94,0.1); border:1px solid rgba(34,197,94,0.3);
  display:flex; align-items:center; justify-content:center;
  font-size:0.55rem; color:var(--green-300); flex-shrink:0; margin-top:2px;
}

/* ═══════════════════════════════════════════
   TABLE
═══════════════════════════════════════════ */
.table-wrap {
  background:var(--bg-card); border:1px solid var(--border-default);
  border-radius:var(--r-xl); overflow:hidden; overflow-x:auto;
}
.pricing-table { width:100%; border-collapse:collapse; font-size:0.85rem; color:var(--text-secondary); min-width:580px; }
.pricing-table thead { background:rgba(2,8,23,0.7); }
.pricing-table th,.pricing-table td { padding:0.75rem 1rem; border-bottom:1px solid var(--border-subtle); text-align:left; vertical-align:top; }
.pricing-table th { font-size:0.76rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-muted); }
.pricing-table th:nth-child(3) { color:var(--green-300); }
.pricing-table tbody tr { transition:background var(--t-fast); }
.pricing-table tbody tr:nth-child(even) { background:rgba(2,8,23,0.4); }
.pricing-table tbody tr:hover { background:rgba(37,99,235,0.05); }
.pricing-table tbody th { font-weight:600; color:var(--text-primary); }
.pricing-table tfoot td { font-size:0.8rem; color:var(--text-faint); border-bottom:none; padding-top:0.9rem; }
.yes { color:var(--green-300); font-weight:700; }

/* ═══════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════ */
.site-footer {
  background:rgba(2,8,23,0.98); border-top:1px solid var(--border-subtle);
  padding:3rem 0 1.5rem; margin-top:auto;
}
.footer-grid {
  display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr; gap:2rem;
  padding-bottom:2rem; border-bottom:1px solid var(--border-subtle); margin-bottom:1.5rem;
}
@media(max-width:820px) { .footer-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:480px) { .footer-grid { grid-template-columns:1fr; } }
.footer-brand-desc { font-size:0.82rem; color:var(--text-faint); line-height:1.65; margin-top:0.6rem; max-width:20rem; }
.footer-col-title { font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.14em; color:var(--text-faint); margin-bottom:0.75rem; }
.footer-links { display:flex; flex-direction:column; gap:0.35rem; }
.footer-links a { font-size:0.82rem; color:var(--text-faint); transition:color var(--t-fast); display:inline-flex; align-items:center; gap:0.3rem; }
.footer-links a:hover { color:var(--blue-300); }
.footer-bottom { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:0.6rem; font-size:0.76rem; color:var(--text-faint); }
.footer-legal { display:flex; flex-wrap:wrap; gap:0.6rem; align-items:center; }
.footer-legal a { color:var(--text-faint); transition:color var(--t-fast); }
.footer-legal a:hover { color:var(--text-muted); }
.social-btn {
  width:32px; height:32px; border-radius:999px;
  border:1px solid var(--border-default); background:rgba(255,255,255,0.03);
  display:flex; align-items:center; justify-content:center;
  font-size:0.85rem; color:var(--text-faint); transition:all var(--t-fast);
}
.social-btn:hover { border-color:var(--border-accent); color:var(--blue-300); background:rgba(37,99,235,0.08); }

/* ═══════════════════════════════════════════
   MODAL SYSTEM
═══════════════════════════════════════════ */
.modal-overlay {
  position:fixed; inset:0; z-index:200;
  background:rgba(2,8,23,0.82);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  display:none; align-items:center; justify-content:center; padding:1rem;
}
.modal-overlay.open { display:flex; animation:fadeIn 0.2s ease; }
.modal-box {
  width:100%; max-width:540px; max-height:92vh; overflow-y:auto;
  background:var(--bg-surface); border:1px solid var(--border-default);
  border-radius:var(--r-2xl); box-shadow:var(--shadow-modal);
  padding:1.75rem 1.75rem 2rem; position:relative; animation:scaleIn 0.25s ease;
}
.modal-box::-webkit-scrollbar { width:4px; }
.modal-box::-webkit-scrollbar-thumb { background:var(--border-default); border-radius:4px; }
.modal-top { display:flex; align-items:flex-start; justify-content:space-between; gap:0.75rem; margin-bottom:1.4rem; }
.modal-title { font-size:1.05rem; font-weight:800; color:var(--text-primary); }
.modal-sub   { font-size:0.82rem; color:var(--text-faint); margin-top:0.2rem; line-height:1.5; }
.modal-close-btn {
  width:30px; height:30px; border-radius:999px;
  border:1px solid var(--border-default); background:rgba(255,255,255,0.04);
  color:var(--text-faint); font-size:1rem;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; cursor:pointer; transition:all var(--t-fast);
}
.modal-close-btn:hover { border-color:var(--border-strong); color:var(--text-primary); background:rgba(255,255,255,0.08); }

/* Progress */
.form-progress { margin-bottom:1.4rem; }
.progress-labels { display:flex; justify-content:space-between; margin-bottom:0.45rem; }
.progress-label { font-size:0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-faint); transition:color var(--t-fast); }
.progress-label.active { color:var(--blue-300); }
.progress-label.done   { color:var(--green-400); }
.progress-track { height:3px; background:var(--border-subtle); border-radius:999px; overflow:hidden; }
.progress-fill  { height:100%; background:linear-gradient(90deg,var(--blue-600),var(--green-500)); border-radius:999px; transition:width 0.4s ease; }
.step-dots { display:flex; justify-content:center; gap:0.5rem; margin-bottom:1.3rem; }
.step-dot { width:8px; height:8px; border-radius:999px; background:var(--border-default); transition:all var(--t-med); }
.step-dot.active { background:var(--blue-500); width:24px; }
.step-dot.done   { background:var(--green-500); }

/* Form steps */
.form-step { display:none; flex-direction:column; gap:0.9rem; animation:fadeUp 0.28s ease; }
.form-step.active { display:flex; }
.step-heading { font-size:0.9rem; font-weight:700; color:var(--text-primary); }
.step-sub     { font-size:0.78rem; color:var(--text-faint); }

/* Fields */
.field { display:flex; flex-direction:column; gap:0.3rem; }
.field-row { display:flex; flex-wrap:wrap; gap:0.6rem; }
.field-row .field { flex:1; min-width:130px; }
.field-label { font-size:0.78rem; font-weight:600; color:var(--text-muted); }
.field-label .req,.req { color:#ef4444; margin-left:0.15rem; }
input,select,textarea {
  width:100%; padding:0.62rem 0.8rem; border-radius:var(--r-md);
  border:1px solid var(--border-default); background:rgba(2,8,23,0.7);
  color:var(--text-primary); font-size:0.86rem; font-family:inherit; outline:none;
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
input::placeholder,textarea::placeholder { color:var(--text-faint); }
input:focus,select:focus,textarea:focus {
  border-color:rgba(37,99,235,0.55); box-shadow:0 0 0 3px rgba(37,99,235,0.1);
}
input.err,select.err,textarea.err {
  border-color:rgba(239,68,68,0.5); box-shadow:0 0 0 3px rgba(239,68,68,0.08);
}
.field-err { font-size:0.72rem; color:#ef4444; display:none; }
.field-err.show { display:block; }
textarea { min-height:88px; resize:vertical; }
select {
  appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%237a8fb5' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 0.8rem center; padding-right:2.2rem;
}
select option { background:#0d1526; color:var(--text-primary); }

/* Option cards */
.option-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:0.5rem; }
@media(max-width:400px) { .option-grid { grid-template-columns:1fr; } }
.opt-card {
  border:1px solid var(--border-default); border-radius:var(--r-md);
  padding:0.7rem 0.8rem; cursor:pointer;
  display:flex; align-items:flex-start; gap:0.5rem;
  background:rgba(2,8,23,0.5); transition:all var(--t-fast);
}
.opt-card:hover { border-color:var(--border-accent); background:rgba(37,99,235,0.05); }
.opt-card.sel   { border-color:rgba(37,99,235,0.65); background:rgba(37,99,235,0.1); }
.opt-card input[type="radio"],.opt-card input[type="checkbox"] {
  width:15px; height:15px; min-width:15px; margin-top:1px; padding:0;
  accent-color:var(--blue-500); cursor:pointer;
}
.opt-label { font-size:0.82rem; color:var(--text-secondary); cursor:pointer; line-height:1.4; }
.opt-label strong { display:block; font-weight:700; color:var(--text-primary); font-size:0.84rem; }
.opt-label span   { font-size:0.73rem; color:var(--text-faint); }
.consent-text { font-size:0.72rem; color:var(--text-faint); line-height:1.6; }
.consent-text a { color:var(--text-muted); text-decoration:underline; }

/* Form nav */
.form-nav { display:flex; gap:0.6rem; align-items:center; margin-top:0.2rem; }
.btn-back {
  padding:0.62rem 1.1rem; border-radius:var(--r-md);
  border:1px solid var(--border-default); background:transparent;
  color:var(--text-faint); font-size:0.83rem; font-weight:600; cursor:pointer;
  display:flex; align-items:center; gap:0.3rem; transition:all var(--t-fast);
}
.btn-back:hover { border-color:var(--border-strong); color:var(--text-muted); }
.btn-next-step {
  flex:1; padding:0.68rem 1.2rem; border-radius:var(--r-md);
  border:1px solid rgba(37,99,235,0.5);
  background:linear-gradient(135deg,var(--blue-600),var(--blue-700));
  color:#fff; font-size:0.86rem; font-weight:700; cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:0.4rem;
  transition:all var(--t-fast);
}
.btn-next-step:hover {
  background:linear-gradient(135deg,var(--blue-500),var(--blue-600));
  box-shadow:0 6px 20px rgba(37,99,235,0.35); transform:translateY(-1px);
}
.btn-submit-form {
  flex:1; padding:0.7rem 1.2rem; border-radius:var(--r-md);
  border:1px solid rgba(34,197,94,0.45);
  background:linear-gradient(135deg,rgba(34,197,94,0.18),rgba(22,163,74,0.14));
  color:var(--green-300); font-size:0.86rem; font-weight:700; cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:0.4rem;
  transition:all var(--t-fast);
}
.btn-submit-form:hover {
  background:linear-gradient(135deg,rgba(34,197,94,0.28),rgba(22,163,74,0.22));
  border-color:rgba(34,197,94,0.7); color:#fff;
  box-shadow:0 6px 20px rgba(34,197,94,0.2); transform:translateY(-1px);
}
.btn-submit-form:disabled { opacity:0.55; cursor:not-allowed; transform:none; }

/* Summary */
.summary-card {
  background:rgba(2,8,23,0.7); border:1px solid var(--border-subtle);
  border-radius:var(--r-md); padding:0.9rem 1rem;
}
.summary-label { font-size:0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.12em; color:var(--text-faint); margin-bottom:0.6rem; }
.summary-row { display:flex; gap:0.5rem; font-size:0.82rem; margin-bottom:0.3rem; }
.summary-key   { color:var(--text-faint); min-width:72px; flex-shrink:0; }
.summary-value { color:var(--text-secondary); word-break:break-all; }

/* Spinner */
.spinner {
  width:16px; height:16px;
  border:2px solid rgba(134,239,172,0.25); border-top-color:var(--green-300);
  border-radius:999px; animation:spin 0.7s linear infinite; display:none;
}
.spinner.show { display:block; }

/* Success */
.form-success {
  display:none; flex-direction:column;
  align-items:center; text-align:center;
  gap:0.85rem; padding:1rem 0; animation:scaleIn 0.35s ease;
}
.form-success.show { display:flex; }
.success-ring {
  width:60px; height:60px; border-radius:999px;
  background:rgba(34,197,94,0.1); border:2px solid rgba(34,197,94,0.35);
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem; animation:floatY 3s ease-in-out infinite;
}
.success-title { font-size:1.1rem; font-weight:800; color:var(--text-primary); }
.success-body  { font-size:0.875rem; color:var(--text-muted); max-width:22rem; line-height:1.65; }

/* ═══════════════════════════════════════════
   CALENDLY MODAL
═══════════════════════════════════════════ */
.cal-overlay {
  position:fixed; inset:0; z-index:300;
  background:rgba(2,8,23,0.88);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  display:none; align-items:center; justify-content:center; padding:1rem;
}
.cal-overlay.open { display:flex; animation:fadeIn 0.2s ease; }
.cal-box {
  width:100%; max-width:720px; height:82vh;
  background:var(--bg-surface);
  border:1px solid rgba(34,197,94,0.2); border-radius:var(--r-2xl);
  box-shadow:var(--shadow-modal),var(--shadow-glow-green);
  display:flex; flex-direction:column; overflow:hidden; animation:scaleIn 0.25s ease;
}
.cal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:1rem 1.4rem; border-bottom:1px solid var(--border-subtle); flex-shrink:0;
}
.cal-title { display:flex; align-items:center; gap:0.6rem; font-size:0.95rem; font-weight:700; color:var(--text-primary); }
.cal-dot { width:8px; height:8px; border-radius:999px; background:var(--green-500); position:relative; }
.cal-dot::after { content:""; position:absolute; inset:-3px; border-radius:999px; background:rgba(34,197,94,0.3); animation:pulseRing 1.8s ease-out infinite; }
.cal-body { flex:1; position:relative; }
.cal-loading { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:0.8rem; background:var(--bg-surface); }
.cal-loading p { font-size:0.84rem; color:var(--text-faint); }
.cal-spinner { width:30px; height:30px; border:2px solid rgba(34,197,94,0.15); border-top-color:var(--green-500); border-radius:999px; animation:spin 0.8s linear infinite; }
.cal-body iframe { width:100%; height:100%; border:none; }

/* ═══════════════════════════════════════════
   TOAST
═══════════════════════════════════════════ */
.toast {
  position:fixed; bottom:1.5rem; right:1.5rem;
  background:var(--bg-elevated); border:1px solid rgba(34,197,94,0.25);
  border-radius:var(--r-lg); padding:0.8rem 1.1rem;
  display:flex; align-items:center; gap:0.6rem;
  font-size:0.84rem; color:var(--text-secondary);
  z-index:500; box-shadow:0 8px 32px rgba(0,0,0,0.45);
  max-width:320px;
  transform:translateY(80px); opacity:0; transition:all 0.3s ease;
}
.toast.show { transform:translateY(0); opacity:1; }
.toast-icon { font-size:1rem; flex-shrink:0; }

/* ═══════════════════════════════════════════
   SCROLL TO TOP
═══════════════════════════════════════════ */
.scroll-top-btn {
  position:fixed; bottom:1.5rem; left:1.5rem;
  width:40px; height:40px; border-radius:999px;
  background:var(--bg-elevated); border:1px solid var(--border-default);
  color:var(--text-faint); display:flex; align-items:center; justify-content:center;
  font-size:0.9rem; cursor:pointer; transition:all var(--t-fast);
  opacity:0; pointer-events:none; z-index:50;
}
.scroll-top-btn.show { opacity:1; pointer-events:auto; }
.scroll-top-btn:hover { border-color:var(--border-accent); color:var(--blue-300); background:rgba(37,99,235,0.1); }

/* ═══════════════════════════════════════════
   DIVIDER
═══════════════════════════════════════════ */
.divider { height:1px; background:linear-gradient(90deg,transparent,var(--border-default),transparent); }

/* ═══════════════════════════════════════════
   HERO SHELL (service pages)
═══════════════════════════════════════════ */
.hero-shell {
  background:linear-gradient(160deg,rgba(13,21,38,0.95) 0%,rgba(9,15,30,0.98) 100%);
  border:1px solid var(--border-default); border-radius:var(--r-2xl);
  padding:2.5rem 2.5rem 2.8rem;
  position:relative; overflow:hidden; box-shadow:var(--shadow-card);
}
.hero-shell::before {
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(to right,rgba(59,130,246,0.05) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(59,130,246,0.05) 1px,transparent 1px);
  background-size:56px 56px; pointer-events:none;
}
.hero-shell::after {
  content:""; position:absolute; top:0; left:8%; right:8%; height:1px;
  background:linear-gradient(90deg,transparent,rgba(37,99,235,0.7),rgba(34,197,94,0.5),transparent);
  background-size:200% 100%; animation:shimmer 5s linear infinite;
}
.hero-inner { position:relative; z-index:1; }

@media(max-width:768px) {
  .scroll-top-btn { display:none; }
  .toast { left:1rem; right:1rem; bottom:1rem; max-width:none; }
  .hero-shell { padding:1.8rem 1.4rem 2rem; }
  .cta-band { padding:2rem 1.25rem; }
  .cta-band-actions { flex-direction:column; align-items:stretch; }
  .cta-band-actions .btn { justify-content:center; }
}

/* ═══════════════════════════════════════════
   MISSING COMPONENTS — Pricing, Tags, etc.
═══════════════════════════════════════════ */

/* ── Step Badge ────────────────────────── */
.step-badge {
  display: inline-block;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.12);
  border: 1px solid rgba(37, 99, 235, 0.25);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--blue-300);
  margin-bottom: 0.5rem;
}

/* ── Tag ───────────────────────────────── */
.tag {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.08);
  border: 1px solid rgba(37, 99, 235, 0.2);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--blue-300);
  text-decoration: none;
  transition: all var(--t-fast);
}
.tag:hover {
  background: rgba(37, 99, 235, 0.15);
  border-color: rgba(37, 99, 235, 0.35);
  color: var(--blue-200);
}

/* ── Table "Yes" checkmark ─────────────── */
.yes {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background: rgba(34, 197, 94, 0.15);
  color: var(--green-300);
  font-size: 0.75rem;
  font-weight: 700;
}

/* ── Screen reader only ────────────────── */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ═══════════════════════════════════════════
   PRICING COMPONENTS
═══════════════════════════════════════════ */

/* ── Pricing Tabs ──────────────────────── */
.pricing-tabs-wrap {
  position: relative;
}

.pricing-tabs {
  display: flex;
  gap: 0.5rem;
  padding: 0.4rem;
  background: rgba(2, 8, 23, 0.7);
  border: 1px solid var(--border-default);
  border-radius: var(--r-xl);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(99, 120, 170, 0.3) transparent;
}
.pricing-tabs::-webkit-scrollbar {
  height: 6px;
}
.pricing-tabs::-webkit-scrollbar-track {
  background: transparent;
}
.pricing-tabs::-webkit-scrollbar-thumb {
  background: rgba(99, 120, 170, 0.3);
  border-radius: 999px;
}

.pricing-tab {
  flex-shrink: 0;
  padding: 0.6rem 1.2rem;
  border-radius: var(--r-lg);
  background: transparent;
  border: 1px solid transparent;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-faint);
  cursor: pointer;
  transition: all var(--t-fast);
  white-space: nowrap;
}
.pricing-tab:hover {
  color: var(--text-secondary);
  background: rgba(99, 120, 170, 0.08);
}
.pricing-tab.active {
  background: rgba(37, 99, 235, 0.12);
  border-color: rgba(37, 99, 235, 0.3);
  color: var(--blue-300);
}

.pricing-panel {
  display: none;
  animation: fadeUp 0.4s ease;
}
.pricing-panel.active {
  display: block;
}

/* ── Price Cards ───────────────────────── */
.price-card {
  background: var(--bg-card);
  border: 1px solid var(--border-default);
  border-radius: var(--r-xl);
  padding: 1.8rem 1.5rem;
  transition: all var(--t-normal);
  position: relative;
  overflow: hidden;
}
.price-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--blue-500), var(--blue-400));
  opacity: 0;
  transition: opacity var(--t-fast);
}
.price-card:hover {
  border-color: rgba(37, 99, 235, 0.4);
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
}
.price-card:hover::before {
  opacity: 1;
}

.price-card.featured {
  border-color: rgba(37, 99, 235, 0.5);
  background: linear-gradient(
    135deg,
    rgba(37, 99, 235, 0.04) 0%,
    rgba(2, 8, 23, 0.8) 100%
  );
  box-shadow: 0 8px 32px rgba(37, 99, 235, 0.15);
}
.price-card.featured::before {
  opacity: 1;
  background: linear-gradient(90deg, var(--blue-400), var(--green-400));
}

.price-amount {
  font-size: 2.5rem;
  font-weight: 900;
  color: var(--text-primary);
  line-height: 1;
  margin-bottom: 0.3rem;
  display: flex;
  align-items: baseline;
  gap: 0.3rem;
}
.price-amount sub {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-faint);
  bottom: 0;
}

.price-period {
  font-size: 0.8rem;
  color: var(--text-faint);
  margin-bottom: 1.5rem;
}

.price-features {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-bottom: 1.2rem;
}

.price-feature {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-size: 0.84rem;
  color: var(--text-secondary);
  line-height: 1.6;
}

.price-feature-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: rgba(34, 197, 94, 0.15);
  border: 1px solid rgba(34, 197, 94, 0.3);
  color: var(--green-300);
  font-size: 0.7rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 2px;
}

/* ── Pricing Table ─────────────────────── */
.table-wrap {
  overflow-x: auto;
  border-radius: var(--r-xl);
  border: 1px solid var(--border-default);
  background: var(--bg-card);
  margin-top: 2rem;
}

.pricing-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.84rem;
  min-width: 700px;
}
.pricing-table thead {
  background: rgba(2, 8, 23, 0.7);
}
.pricing-table th {
  padding: 0.9rem 1.2rem;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-faint);
  text-align: left;
  border-bottom: 1px solid var(--border-subtle);
}
.pricing-table th:first-child {
  text-align: left;
}
.pricing-table th:not(:first-child) {
  text-align: center;
}
.pricing-table td {
  padding: 0.8rem 1.2rem;
  border-bottom: 1px solid var(--border-subtle);
  vertical-align: middle;
}
.pricing-table td:not(:first-child) {
  text-align: center;
}
.pricing-table tbody tr:hover {
  background: rgba(37, 99, 235, 0.04);
}
.pricing-table tbody tr:last-child td {
  border-bottom: none;
}

/* ═══════════════════════════════════════════
   CTA BAND
═══════════════════════════════════════════ */
.cta-band {
  background: linear-gradient(
    135deg,
    rgba(37, 99, 235, 0.08) 0%,
    rgba(15, 118, 110, 0.08) 100%
  );
  border: 1px solid rgba(37, 99, 235, 0.25);
  border-radius: var(--r-xl);
  padding: 3rem 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-band::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(
    circle,
    rgba(37, 99, 235, 0.1) 0%,
    transparent 70%
  );
  animation: pulse 8s ease-in-out infinite;
  pointer-events: none;
}

.cta-band-inner {
  position: relative;
  z-index: 1;
  max-width: 640px;
  margin: 0 auto;
}
.cta-band-inner h2 {
  font-size: clamp(1.3rem, 2.5vw + 0.5rem, 1.8rem);
  font-weight: 900;
  color: var(--text-primary);
  margin-bottom: 0.6rem;
}
.cta-band-inner p {
  font-size: 0.95rem;
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}

.cta-band-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
}

@media (max-width: 600px) {
  .cta-band {
    padding: 2rem 1.5rem;
  }
  .cta-band-actions {
    flex-direction: column;
  }
  .cta-band-actions .btn {
    width: 100%;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════
   CHATBOT
═══════════════════════════════════════════ */
.chatbot-bubble {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--blue-600), var(--blue-700));
  border: 1px solid rgba(37, 99, 235, 0.5);
  box-shadow: 0 8px 24px rgba(37, 99, 235, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 1000;
  transition: all var(--t-fast);
}

.chatbot-bubble:hover {
  transform: scale(1.08);
  box-shadow: 0 12px 32px rgba(37, 99, 235, 0.45);
}

.chatbot-bubble svg {
  width: 24px;
  height: 24px;
  color: #fff;
}

.chatbot-window {
  position: fixed;
  bottom: 5.5rem;
  right: 1.5rem;
  width: 380px;
  max-width: calc(100vw - 3rem);
  height: 600px;
  max-height: calc(100vh - 8rem);
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-modal);
  display: none;
  flex-direction: column;
  z-index: 1000;
  animation: scaleIn 0.25s ease;
}

.chatbot-window.open {
  display: flex;
}

.chatbot-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.2rem;
  border-bottom: 1px solid var(--border-subtle);
  background: rgba(37, 99, 235, 0.08);
}

.chatbot-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-primary);
}

.chatbot-close {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid var(--border-default);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-faint);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--t-fast);
}

.chatbot-close:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-primary);
}

.chatbot-body {
  flex: 1;
  overflow-y: auto;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}

.chatbot-message {
  display: flex;
  gap: 0.6rem;
  max-width: 85%;
}

.chatbot-message.bot {
  align-self: flex-start;
}

.chatbot-message.user {
  align-self: flex-end;
  flex-direction: row-reverse;
}

.chatbot-avatar {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--blue-600), var(--blue-700));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}

.chatbot-message.user .chatbot-avatar {
  background: linear-gradient(135deg, var(--green-500), var(--green-600));
}

.chatbot-bubble-text {
  padding: 0.7rem 0.9rem;
  border-radius: var(--r-md);
  font-size: 0.85rem;
  line-height: 1.5;
  color: var(--text-secondary);
}

.chatbot-message.bot .chatbot-bubble-text {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
}

.chatbot-message.user .chatbot-bubble-text {
  background: rgba(37, 99, 235, 0.15);
  border: 1px solid rgba(37, 99, 235, 0.3);
  color: var(--text-primary);
}

.chatbot-footer {
  padding: 1rem;
  border-top: 1px solid var(--border-subtle);
  display: flex;
  gap: 0.5rem;
}

.chatbot-input {
  flex: 1;
  padding: 0.6rem 0.8rem;
  border-radius: var(--r-md);
  border: 1px solid var(--border-default);
  background: rgba(2, 8, 23, 0.7);
  color: var(--text-primary);
  font-size: 0.85rem;
  outline: none;
  transition: border-color var(--t-fast);
}

.chatbot-input:focus {
  border-color: rgba(37, 99, 235, 0.5);
}

.chatbot-send {
  padding: 0.6rem 1rem;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--blue-600), var(--blue-700));
  border: 1px solid rgba(37, 99, 235, 0.5);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--t-fast);
}

.chatbot-send:hover {
  background: linear-gradient(135deg, var(--blue-500), var(--blue-600));
  transform: translateY(-1px);
}

@media (max-width: 768px) {
  .chatbot-bubble {
    bottom: 1rem;
    right: 1rem;
    width: 52px;
    height: 52px;
  }
  
  .chatbot-window {
    bottom: 4.5rem;
    right: 1rem;
    width: calc(100vw - 2rem);
    height: calc(100vh - 7rem);
  }
}
