/* =============================================================
   MosPayCapital — marketing site · shared foundation
   Design tokens mirror the platform (teal #14b8a6 / #2dd4bf,
   indigo #6366f1, dark canvas, Inter, 12px card radius).
   ============================================================= */

:root{
  /* canvas */
  --bg:        #080b10;
  --bg-2:      #0b0f16;
  --bg-3:      #0e131c;
  --surface:   #111722;
  --surface-2: #161d29;
  --surface-3: #1c2431;

  /* hairlines */
  --line:        rgba(255,255,255,.07);
  --line-2:      rgba(255,255,255,.11);
  --line-strong: rgba(255,255,255,.16);

  /* text */
  --text:      #eaf0f7;
  --text-2:    #aeb9c8;
  --text-dim:  #8493a6;
  --text-faint:#5b6779;

  /* brand — from the platform design system */
  --teal:    #2dd4bf;
  --teal-2:  #14b8a6;
  --emerald: #10b981;
  --indigo:  #818cf8;
  --indigo-2:#6366f1;
  --amber:   #f59e0b;
  --green:   #22c55e;
  --red:     #ef4444;
  --blue:    #3b82f6;
  --purple:  #a855f7;

  --accent:   var(--teal);
  --accent-2: var(--indigo);
  --glow:     rgba(45,212,191,.50);
  --glow-soft:rgba(45,212,191,.16);

  /* gradients */
  --grad-brand: linear-gradient(115deg,#10b981 0%,#14b8a6 45%,#2dd4bf 100%);
  --grad-ind:   linear-gradient(120deg,#2dd4bf,#6366f1);
  --grad-text:  linear-gradient(180deg,#ffffff 0%,#b9c6d6 100%);

  /* radii */
  --r-sm: 8px;
  --r:    12px;
  --r-lg: 16px;
  --r-xl: 22px;
  --r-2xl:28px;
  --r-pill:999px;

  /* shadow / elevation */
  --sh-1: 0 1px 0 rgba(255,255,255,.04) inset, 0 1px 2px rgba(0,0,0,.4);
  --sh-2: 0 10px 30px -12px rgba(0,0,0,.7);
  --sh-3: 0 30px 80px -30px rgba(0,0,0,.8);
  --sh-glow: 0 0 0 1px rgba(45,212,191,.25), 0 18px 50px -18px rgba(20,184,166,.45);

  --container: 1200px;
  --nav-h: 70px;

  --font: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", "Roboto Mono", Menlo, monospace;

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"cv02","cv03","cv04","ss01";
  overflow-x:hidden;
}
img,svg,video{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
ul{ list-style:none; padding:0; }
h1,h2,h3,h4{ line-height:1.05; font-weight:700; letter-spacing:-.02em; }
:focus-visible{ outline:2px solid var(--teal); outline-offset:3px; border-radius:6px; }
::selection{ background:rgba(45,212,191,.28); color:#fff; }

/* thin scrollbar (matches platform) */
*{ scrollbar-width:thin; scrollbar-color:rgba(255,255,255,.16) transparent; }
::-webkit-scrollbar{ width:9px; height:9px; }
::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.14); border-radius:99px; }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:24px; }
.section{ position:relative; padding:clamp(64px,9vw,130px) 0; }
.center{ text-align:center; }
.stack{ display:flex; flex-direction:column; }
.row{ display:flex; align-items:center; }
.wrap{ flex-wrap:wrap; }
.gap-8{ gap:8px } .gap-12{ gap:12px } .gap-16{ gap:16px } .gap-24{ gap:24px }
.hidden{ display:none !important; }

/* ---------- type helpers ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-size:12.5px; font-weight:600; letter-spacing:.14em; text-transform:uppercase;
  color:var(--teal);
  padding:7px 14px; border-radius:var(--r-pill);
  background:var(--glow-soft); border:1px solid rgba(45,212,191,.22);
}
.eyebrow .dot{ width:6px; height:6px; border-radius:50%; background:var(--teal); box-shadow:0 0 10px var(--teal); }
.display{ font-size:clamp(2.5rem,6.4vw,5.3rem); line-height:.98; letter-spacing:-.03em; font-weight:800; }
.h2{ font-size:clamp(1.9rem,3.8vw,3.1rem); letter-spacing:-.025em; font-weight:800; }
.h3{ font-size:clamp(1.3rem,2.2vw,1.7rem); font-weight:700; }
.lead{ font-size:clamp(1.05rem,1.5vw,1.28rem); color:var(--text-2); line-height:1.6; }
.muted{ color:var(--text-dim); }
.mono{ font-family:var(--mono); font-feature-settings:"tnum"; letter-spacing:-.01em; }
.tnum{ font-variant-numeric:tabular-nums; }
.grad-text{
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.teal-text{
  background:var(--grad-brand); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.section-head{ max-width:660px; }
.section-head.center{ margin-inline:auto; }
.section-head .h2{ margin:16px 0 14px; }

/* ---------- buttons ---------- */
.btn{
  --bh:48px;
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  height:var(--bh); padding:0 22px; border-radius:var(--r);
  font-weight:600; font-size:15px; letter-spacing:-.01em;
  transition:transform .2s var(--ease), box-shadow .3s var(--ease), background .3s, border-color .3s, color .2s;
  white-space:nowrap; border:1px solid transparent;
}
.btn svg{ width:18px; height:18px; }
.btn:active{ transform:translateY(1px) scale(.99); }
.btn-primary{
  color:#04120e; background:var(--grad-brand);
  box-shadow:0 10px 30px -10px rgba(20,184,166,.6), inset 0 1px 0 rgba(255,255,255,.35);
  font-weight:700;
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 18px 44px -12px rgba(20,184,166,.75), inset 0 1px 0 rgba(255,255,255,.4); }
.btn-ghost{ background:rgba(255,255,255,.04); border-color:var(--line-2); color:var(--text); }
.btn-ghost:hover{ background:rgba(255,255,255,.08); border-color:var(--line-strong); transform:translateY(-2px); }
.btn-outline{ border-color:rgba(45,212,191,.4); color:var(--teal); }
.btn-outline:hover{ background:var(--glow-soft); transform:translateY(-2px); }
.btn-lg{ --bh:56px; padding:0 30px; font-size:16px; }
.btn-sm{ --bh:40px; padding:0 16px; font-size:14px; }
.btn-block{ width:100%; }

/* ---------- generic surfaces ---------- */
.card{
  background:linear-gradient(180deg,var(--surface),var(--bg-3));
  border:1px solid var(--line-2); border-radius:var(--r-lg);
  box-shadow:var(--sh-1);
}
.glass{
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1px solid var(--line-2);
}
.hairline{ height:1px; background:linear-gradient(90deg,transparent,var(--line-strong),transparent); }

/* decorative backdrop bits */
.grid-bg{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.028) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 80% at 50% 0%,#000 30%,transparent 78%);
          mask-image:radial-gradient(120% 80% at 50% 0%,#000 30%,transparent 78%);
}
.orb{ position:absolute; border-radius:50%; filter:blur(70px); opacity:.5; pointer-events:none; z-index:0; }
.orb.teal{ background:radial-gradient(circle,rgba(20,184,166,.7),transparent 65%); }
.orb.indigo{ background:radial-gradient(circle,rgba(99,102,241,.55),transparent 65%); }

/* =============================================================
   NAVBAR
   ============================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60; height:var(--nav-h);
  display:flex; align-items:center;
  transition:background .3s,border-color .3s,backdrop-filter .3s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(8,11,16,.72); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.nav .container{ display:flex; align-items:center; justify-content:space-between; gap:20px; }
.brand{ display:flex; align-items:center; gap:11px; font-weight:800; font-size:19px; letter-spacing:-.02em; }
.brand img{ height:34px; width:auto; }
.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  padding:9px 14px; border-radius:var(--r-sm); font-size:14.5px; color:var(--text-2); font-weight:500;
  transition:color .2s,background .2s;
}
.nav-links a:hover{ color:var(--text); background:rgba(255,255,255,.05); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav-burger{ display:none; width:44px; height:44px; border-radius:var(--r-sm); border:1px solid var(--line-2); align-items:center; justify-content:center; }
.nav-burger svg{ width:22px; height:22px; }
.mobile-menu{
  position:fixed; inset:var(--nav-h) 0 auto 0; z-index:55;
  background:rgba(8,11,16,.97); backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line-2);
  padding:16px 24px 26px; display:none; flex-direction:column; gap:6px;
}
.mobile-menu.open{ display:flex; }
.mobile-menu a{ padding:14px 12px; border-radius:var(--r); font-size:17px; font-weight:500; color:var(--text-2); border-bottom:1px solid var(--line); }
.mobile-menu .btn{ margin-top:12px; }

/* =============================================================
   CURRENCY CHIPS + floating field
   ============================================================= */
.ccy{
  display:inline-flex; align-items:center; gap:9px;
  padding:8px 14px 8px 8px; border-radius:var(--r-pill);
  background:var(--surface-2); border:1px solid var(--line-2);
  font-weight:600; font-size:14px; white-space:nowrap;
  box-shadow:var(--sh-1);
}
.ccy .flag{
  width:26px; height:26px; border-radius:50%; overflow:hidden; flex:none;
  box-shadow:0 0 0 1px rgba(255,255,255,.14); background:#222;
}
.ccy .flag svg,.ccy .flag img{ width:100%; height:100%; object-fit:cover; }
.ccy small{ color:var(--text-dim); font-weight:500; }
.ccy .usdt{ background:linear-gradient(135deg,#26a17b,#12463b); display:flex; align-items:center; justify-content:center; color:#fff; font-weight:800; font-size:14px; }

/* USDT / crypto badge */
.badge-usdt{ width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#26a17b,#0f3d31);display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;box-shadow:0 0 0 1px rgba(255,255,255,.14);}

/* floating currency field (hero background) */
.ccy-field{ position:absolute; inset:0; z-index:1; overflow:hidden; pointer-events:none; }
.ccy-float{
  position:absolute; opacity:0; will-change:transform;
  animation:floatUp linear infinite;
  filter:drop-shadow(0 8px 20px rgba(0,0,0,.5));
}
@keyframes floatUp{
  0%{ opacity:0; transform:translateY(30px) scale(.9); }
  10%{ opacity:.9; }
  90%{ opacity:.9; }
  100%{ opacity:0; transform:translateY(-120px) scale(1); }
}

/* =============================================================
   KPI METRIC CARD  (mirrors platform MetricCard)
   ============================================================= */
.kpi{
  position:relative; padding:20px; border-radius:var(--r-lg);
  background:linear-gradient(180deg,var(--surface),var(--bg-3));
  border:1px solid var(--line-2); overflow:hidden;
}
.kpi::after{ content:""; position:absolute; inset:0; background:radial-gradient(120% 60% at 100% 0%,var(--glow-soft),transparent 60%); opacity:.7; }
.kpi-top{ display:flex; align-items:center; gap:11px; position:relative; z-index:1; }
.kpi-ico{ width:38px; height:38px; border-radius:10px; display:flex; align-items:center; justify-content:center; background:rgba(20,184,166,.14); color:var(--teal); flex:none; }
.kpi-ico svg{ width:20px; height:20px; }
.kpi-ico.ind{ background:rgba(99,102,241,.16); color:var(--indigo); }
.kpi-ico.amb{ background:rgba(245,158,11,.15); color:var(--amber); }
.kpi-ico.grn{ background:rgba(34,197,94,.15); color:var(--green); }
.kpi-label{ font-size:11px; letter-spacing:.09em; text-transform:uppercase; color:var(--text-dim); font-weight:600; }
.kpi-val{ font-size:clamp(1.5rem,2.4vw,1.9rem); font-weight:800; font-variant-numeric:tabular-nums; margin-top:14px; position:relative; z-index:1; letter-spacing:-.02em; }
.kpi-trend{ display:inline-flex; align-items:center; gap:5px; font-size:12.5px; font-weight:600; margin-top:6px; position:relative; z-index:1; }
.kpi-trend.up{ color:var(--green); } .kpi-trend.down{ color:var(--red); }
.kpi-trend span{ color:var(--text-faint); font-weight:500; }

/* =============================================================
   APP / DASHBOARD MOCKUP  (English MosPayCapital product UI)
   ============================================================= */
.app{
  border-radius:var(--r-xl); overflow:hidden; position:relative;
  background:var(--bg-2); border:1px solid var(--line-2);
  box-shadow:var(--sh-3);
}
.app-bar{ display:flex; align-items:center; gap:8px; padding:12px 16px; background:var(--bg-3); border-bottom:1px solid var(--line); }
.app-bar .dots{ display:flex; gap:7px; }
.app-bar .dots i{ width:11px; height:11px; border-radius:50%; background:#2a3340; display:block; }
.app-bar .url{ margin-left:10px; font-size:12.5px; color:var(--text-dim); font-family:var(--mono); display:flex; align-items:center; gap:7px; }
.app-bar .url::before{ content:"🔒"; font-size:10px; filter:grayscale(1); }

.app-top{ display:flex; align-items:center; justify-content:space-between; padding:12px 18px; border-bottom:1px solid var(--line); background:var(--bg-2); }
.app-brand{ display:flex; align-items:center; gap:9px; font-weight:800; font-size:15px; }
.app-brand img{ height:24px; width:auto; }
.app-menu{ display:flex; gap:4px; }
.app-menu a{ font-size:13px; color:var(--text-dim); padding:7px 12px; border-radius:99px; font-weight:500; }
.app-menu a.on{ color:#04120e; background:var(--grad-brand); font-weight:600; }
.app-right{ display:flex; align-items:center; gap:10px; }
.app-pill{ display:flex; align-items:center; gap:7px; font-size:12.5px; color:var(--text-2); padding:7px 11px; border-radius:99px; border:1px solid var(--line-2); }
.app-av{ width:30px; height:30px; border-radius:50%; background:linear-gradient(135deg,#334155,#1e293b); border:1px solid var(--line-2); }

.app-body{ padding:22px; }
.app-h{ display:flex; align-items:flex-start; justify-content:space-between; gap:16px; margin-bottom:20px; flex-wrap:wrap; }
.app-h h4{ font-size:22px; font-weight:800; letter-spacing:-.02em; }
.app-h p{ font-size:13px; color:var(--text-dim); margin-top:3px; }
.seg{ display:inline-flex; padding:4px; border-radius:99px; background:var(--surface); border:1px solid var(--line-2); gap:2px; }
.seg button{ font-size:12px; padding:6px 12px; border-radius:99px; color:var(--text-dim); font-weight:500; }
.seg button.on{ color:#04120e; background:var(--grad-brand); font-weight:600; }

.kpi-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.app-panels{ display:grid; grid-template-columns:1.5fr 1fr; gap:14px; margin-top:16px; }
.panel{ padding:18px; border-radius:var(--r-lg); background:linear-gradient(180deg,var(--surface),var(--bg-3)); border:1px solid var(--line-2); }
.panel-h{ display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.panel-h .pi{ width:34px;height:34px;border-radius:9px;background:rgba(20,184,166,.14);color:var(--teal);display:flex;align-items:center;justify-content:center;}
.panel-h .pi svg{ width:18px; height:18px; }
.panel-h b{ font-size:14.5px; font-weight:700; }
.panel-h small{ display:block; font-size:11.5px; color:var(--text-dim); font-weight:400; }

/* bar chart */
.bars{ display:flex; align-items:flex-end; gap:8px; height:150px; padding-top:8px; }
.bars .col{ flex:1; display:flex; flex-direction:column; justify-content:flex-end; gap:3px; height:100%; }
.bars .b{ width:100%; border-radius:4px 4px 2px 2px; }
.bars .b.pin{ background:linear-gradient(180deg,#2dd4bf,#0f9b8a); }
.bars .b.pout{ background:linear-gradient(180deg,#818cf8,#4f46e5); }
.bars .col span{ text-align:center; font-size:9.5px; color:var(--text-faint); font-family:var(--mono); }
.legend{ display:flex; gap:16px; margin-top:12px; font-size:11.5px; color:var(--text-dim); }
.legend i{ width:9px; height:9px; border-radius:3px; display:inline-block; margin-right:6px; vertical-align:middle; }

/* donut */
.donut-wrap{ display:flex; align-items:center; gap:18px; }
.donut{ position:relative; width:130px; height:130px; flex:none; }
.donut .mid{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.donut .mid b{ font-size:20px; font-weight:800; }
.donut .mid small{ font-size:10px; color:var(--text-dim); }
.dleg{ display:flex; flex-direction:column; gap:9px; }
.dleg div{ display:flex; align-items:center; gap:9px; font-size:12.5px; color:var(--text-2); }
.dleg i{ width:9px; height:9px; border-radius:3px; }

/* deals table */
.tbl{ width:100%; border-collapse:collapse; font-size:12.5px; }
.tbl th{ text-align:left; padding:9px 12px; color:var(--text-faint); font-size:10px; letter-spacing:.06em; text-transform:uppercase; font-weight:600; border-bottom:1px solid var(--line); }
.tbl td{ padding:11px 12px; border-bottom:1px solid var(--line); color:var(--text-2); }
.tbl tr:last-child td{ border-bottom:none; }
.tbl .id{ font-family:var(--mono); color:var(--text-dim); }
.tbl .amt{ font-family:var(--mono); font-weight:600; color:var(--text); }
.pill{ display:inline-flex; align-items:center; gap:5px; padding:3px 9px; border-radius:99px; font-size:10.5px; font-weight:600; }
.pill.done{ background:rgba(34,197,94,.14); color:#5ee89b; }
.pill.exp{ background:rgba(245,158,11,.14); color:#fbbf5a; }
.pill.pend{ background:rgba(168,85,247,.15); color:#c99bf5; }
.pct{ padding:2px 7px; border-radius:6px; background:rgba(45,212,191,.12); color:var(--teal); font-family:var(--mono); font-size:11px; font-weight:600; }

/* =============================================================
   WORLD DOT MAP
   ============================================================= */
.map-wrap{ position:relative; width:100%; }
.map-wrap svg{ width:100%; height:auto; overflow:visible; }
.dot{ fill:#2a3340; }
.dot.r1{ fill:var(--teal); }        /* LATAM */
.dot.r2{ fill:#34d399; }            /* Africa */
.dot.r3{ fill:#5eead4; }            /* Australia */
.dot.hl{ animation:dotPulse 3s var(--ease) infinite; }
@keyframes dotPulse{ 0%,100%{ opacity:.55; } 50%{ opacity:1; } }
.map-glow{ filter:drop-shadow(0 0 6px rgba(45,212,191,.85)); }
.map-legend{ display:flex; gap:18px; flex-wrap:wrap; justify-content:center; margin-top:22px; }
.map-legend div{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--text-2); }
.map-legend i{ width:10px; height:10px; border-radius:50%; }
.map-ping{ position:absolute; width:12px; height:12px; }
.map-ping::before{ content:""; position:absolute; inset:0; border-radius:50%; background:var(--teal); box-shadow:0 0 10px var(--teal); }
.map-ping::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid var(--teal); animation:ping 2.4s var(--ease-out) infinite; }
@keyframes ping{ 0%{ transform:scale(1); opacity:.9; } 100%{ transform:scale(3.4); opacity:0; } }

/* =============================================================
   FEATURE / STAT / STEP CARDS
   ============================================================= */
.grid{ display:grid; gap:20px; }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }
/* grid/flex items default to min-width:auto, which lets text content force a
   track wider than its container — this is what clipped the mobile contact
   form. min-width:0 lets items shrink to fit and text wrap normally. */
.grid > *, .kpi-grid > *, .app-panels > *, .footer-grid > *{ min-width:0; }

.feature{
  position:relative; padding:26px; border-radius:var(--r-lg); overflow:hidden;
  background:linear-gradient(180deg,var(--surface),var(--bg-3)); border:1px solid var(--line-2);
  transition:transform .3s var(--ease), border-color .3s, box-shadow .3s;
}
.feature:hover{ transform:translateY(-4px); border-color:rgba(45,212,191,.3); box-shadow:var(--sh-2); }
.feature .fic{ width:50px; height:50px; border-radius:14px; display:flex; align-items:center; justify-content:center; background:rgba(20,184,166,.12); color:var(--teal); margin-bottom:18px; border:1px solid rgba(45,212,191,.2); }
.feature .fic svg{ width:24px; height:24px; }
.feature h3{ font-size:18px; margin-bottom:9px; }
.feature p{ font-size:14.5px; color:var(--text-dim); line-height:1.6; }

.stat-num{ font-size:clamp(2.2rem,4vw,3.4rem); font-weight:800; font-variant-numeric:tabular-nums; letter-spacing:-.03em; line-height:1; }
.stat-lbl{ font-size:14px; color:var(--text-dim); margin-top:8px; }

/* marquee */
.marquee{ overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track{ display:flex; gap:14px; width:max-content; animation:scrollX 34s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
@keyframes scrollX{ to{ transform:translateX(-50%); } }
.rail{ display:inline-flex; align-items:center; gap:9px; padding:12px 20px; border-radius:var(--r); background:var(--surface); border:1px solid var(--line-2); font-weight:600; font-size:15px; color:var(--text-2); white-space:nowrap; }
.rail .rdot{ width:9px; height:9px; border-radius:50%; }

/* steps */
.step{ position:relative; padding:26px; border-radius:var(--r-lg); background:linear-gradient(180deg,var(--surface),var(--bg-3)); border:1px solid var(--line-2); }
.step .num{ font-family:var(--mono); font-size:13px; font-weight:700; color:var(--teal); background:rgba(45,212,191,.1); border:1px solid rgba(45,212,191,.25); width:38px; height:38px; border-radius:11px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.step h3{ font-size:17px; margin-bottom:8px; }
.step p{ font-size:14px; color:var(--text-dim); }

/* footer */
.footer{ border-top:1px solid var(--line); padding:64px 0 34px; position:relative; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:30px; }
.footer h5{ font-size:13px; text-transform:uppercase; letter-spacing:.08em; color:var(--text-faint); margin-bottom:16px; font-weight:600; }
.footer a{ display:block; color:var(--text-dim); font-size:14.5px; padding:6px 0; transition:color .2s; }
.footer a:hover{ color:var(--teal); }
.footer-bot{ display:flex; align-items:center; justify-content:space-between; gap:16px; margin-top:44px; padding-top:26px; border-top:1px solid var(--line); color:var(--text-faint); font-size:13px; flex-wrap:wrap; }

/* CTA band */
.cta-band{ position:relative; overflow:hidden; border-radius:var(--r-2xl); padding:clamp(40px,6vw,72px); border:1px solid rgba(45,212,191,.25); background:linear-gradient(135deg,rgba(20,184,166,.12),rgba(99,102,241,.1)); }

/* =============================================================
   REVEAL ANIMATIONS
   ============================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s } .reveal.d2{ transition-delay:.16s } .reveal.d3{ transition-delay:.24s } .reveal.d4{ transition-delay:.32s }

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width:1024px){
  .app-panels{ grid-template-columns:1fr; }
  .g-4{ grid-template-columns:repeat(2,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:820px){
  .nav-links{ display:none; }
  .nav-burger{ display:flex; }
  .nav-cta .btn:not(.nav-burger){ display:none; }
  .kpi-grid{ grid-template-columns:repeat(2,1fr); }
  .g-3{ grid-template-columns:1fr; }
  .app-menu,.app-right .app-pill{ display:none; }
}
@media (max-width:560px){
  .container{ padding-inline:18px; }
  .g-2,.g-4{ grid-template-columns:1fr; }
  .kpi-grid{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr; gap:22px; }
  .app-body{ padding:16px; }
  .kpi-grid{ gap:10px; }
  .btn-block-sm{ width:100%; }
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}
