
:root{
  --purple:#6F4CCF;
  --purple-200:#EDE7FF;
  --orange:#EB6D3A;
  --orange-dark:#D85C2B;
  --ink:#1E2434;
  --text:#55627A;
  --line:#DDD8F0;
  --bg:#F7F7FB;
  --card:#FFFFFF;
  --footer:#1F1640;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,Segoe UI,Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
}
a{text-decoration:none;color:inherit}
.container{max-width:1180px;margin:0 auto;padding:0 24px}

.site-header{
  position:sticky;
  top:0;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(10px);
  border-bottom:1px solid #ece9f6;
  z-index:20;
}
.header-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px 24px;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  font-size:18px;
  color:var(--ink);
}
.brand img{width:34px;height:34px}
.site-nav{display:flex;align-items:center;gap:28px}
.site-nav a{font-size:15px;color:#647089;font-weight:600}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:13px 22px;
  border-radius:14px;
  font-weight:700;
  transition:.2s ease;
}
.btn-sm{padding:10px 18px;border-radius:12px}
.btn-primary{
  background:var(--orange);
  color:#fff;
  box-shadow:0 12px 24px rgba(235,109,58,.18);
}
.btn-primary:hover{background:var(--orange-dark);transform:translateY(-1px)}
.btn-secondary{
  background:#fff;
  color:#5C44D6;
  border:1px solid var(--line);
}
.btn-secondary:hover{transform:translateY(-1px);box-shadow:0 10px 18px rgba(76,58,151,.08)}

.hero{
  padding:72px 0 64px;
  background:linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(237,231,255,.65) 100%);
}
.hero-grid{
  display:grid;
  grid-template-columns:1.03fr .97fr;
  gap:46px;
  align-items:center;
}
.kicker{
  display:inline-block;
  padding:8px 14px;
  border-radius:999px;
  background:var(--purple-200);
  color:#5C44D6;
  font-weight:800;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.hero-copy{max-width:640px}
.hero h1{
  max-width:610px;
  font-size:70px;
  line-height:.96;
  letter-spacing:-.045em;
  margin:18px 0 22px;
  font-weight:900;
}
.hero p.lead{
  font-size:18px;
  max-width:580px;
  color:var(--text);
  margin:0 0 26px;
}
.hero-actions{display:flex;gap:14px;margin-bottom:22px}
.hero-list{margin:0;padding-left:20px;color:#657286}
.hero-list li{margin:4px 0}

.platform-card{
  background:rgba(255,255,255,.80);
  border:1px solid var(--line);
  box-shadow:0 18px 40px rgba(76,58,151,.10);
  border-radius:28px;
  padding:24px;
}
.platform-dots{display:flex;gap:8px;margin-bottom:16px}
.platform-dots span{width:12px;height:12px;border-radius:50%;background:#D7CCF9}
.platform-top{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:18px;
}
.stat-card,.feature-strip{
  border:1px solid var(--line);
  border-radius:20px;
  padding:18px 20px;
  background:#fff;
}
.stat-card .label{font-size:14px;color:#76819A}
.stat-card .value{
  font-size:54px;
  font-weight:900;
  line-height:1;
  color:#5C44D6;
  margin-top:14px;
}
.stat-card .value.orange{color:var(--orange)}
.feature-stack{display:grid;gap:14px}
.feature-strip{font-weight:800;color:var(--ink)}
.feature-strip span{
  display:block;
  font-size:12px;
  font-weight:800;
  color:#7A6BB7;
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:8px;
}
.feature-strip.billing{background:#FFF4EE}
.feature-strip.protect{background:#F5F1FF}
.feature-strip.visible{background:#EDF8F3}

.section{padding:88px 0}
.section.alt{background:#fff}
.section h2{
  font-size:52px;
  line-height:1.02;
  letter-spacing:-.03em;
  text-align:center;
  margin:12px auto 10px;
  max-width:760px;
}
.section .section-sub{
  max-width:760px;
  text-align:center;
  color:#73809A;
  margin:0 auto 36px;
}

.cards-3,.cards-4{display:grid;gap:20px}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-4{grid-template-columns:repeat(4,1fr)}

.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:20px;
  padding:24px;
  box-shadow:0 8px 24px rgba(56,41,116,.05);
  transition:all .2s ease;
}
.cards-3 .card{
  min-height:260px;
  display:flex;
  flex-direction:column;
}
.cards-4 .card{
  min-height:190px;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:0 14px 32px rgba(56,41,116,.08);
}
.card .icon{
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;margin-bottom:18px;
}
.icon.orange{background:#FFF1E9;color:var(--orange)}
.icon.purple{background:#F2ECFF;color:#7D5BEE}
.icon.green{background:#EAF8F3;color:#4AAE83}
.card h3{
  font-size:30px;
  line-height:1.05;
  letter-spacing:-.02em;
  margin:0 0 10px;
}
.card p{
  color:#66748B;
  margin:0 0 14px;
  max-width:31ch;
}
.link-arrow{
  margin-top:auto;
  font-weight:800;
  color:#5C44D6;
}

.center{text-align:center}
.cta-band{padding:72px 0 86px}
.cta-band h2{
  font-size:48px;
  line-height:1.05;
  letter-spacing:-.03em;
  text-align:center;
  max-width:760px;
  margin:0 auto 10px;
}
.cta-band p{
  text-align:center;
  color:#748098;
  max-width:680px;
  margin:0 auto 28px;
}
.cta-actions{display:flex;justify-content:center;gap:14px}

.site-footer{
  background:var(--footer);
  color:#fff;
  padding:34px 0 14px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 1fr;
  gap:40px;
  align-items:start;
}
.footer-brand{
  padding-top:4px;
}
.footer-brand img{
  width:46px;height:46px;
  margin-bottom:10px;
}
.footer-brand p{
  max-width:220px;
  color:rgba(255,255,255,.78);
  font-size:13px;
  margin:0;
}
.site-footer h4{
  font-size:14px;
  margin:4px 0 12px;
  color:#fff;
}
.site-footer a{
  display:block;
  color:rgba(255,255,255,.78);
  font-size:13px;
  margin:0 0 7px;
}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  margin-top:20px;
  padding-top:10px;
  color:rgba(255,255,255,.62);
  font-size:12px;
  text-align:center;
}

.page-shell{padding:72px 0 92px}
.page-card{
  max-width:900px;
  margin:0 auto;
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:34px;
  box-shadow:0 10px 26px rgba(56,41,116,.06);
}
.page-card h1{
  font-size:40px;
  line-height:1.05;
  margin:0 0 8px;
}
.page-card p{color:#68758E}

@media (max-width: 1024px){
  .hero-grid,.cards-3,.cards-4,.footer-grid{grid-template-columns:1fr}
  .hero h1,.section h2,.cta-band h2{font-size:48px}
  .site-nav{gap:16px}
  .hero-copy,.hero h1,.hero p.lead{max-width:none}
  .cards-3 .card,.cards-4 .card{min-height:auto}
}
@media (max-width: 720px){
  .header-inner{flex-direction:column;gap:14px}
  .site-nav{flex-wrap:wrap;justify-content:center}
  .hero h1,.section h2,.cta-band h2{font-size:38px}
  .platform-top{grid-template-columns:1fr}
  .hero-actions,.cta-actions{flex-direction:column}
}


.layout{display:grid;grid-template-columns:280px 1fr;gap:24px;align-items:start}
.sidebar{position:sticky;top:96px}
.side-title{font-weight:800;margin-bottom:14px}
.side-nav{display:grid;gap:8px}
.side-nav a{padding:10px 12px;border-radius:12px;color:#66748B;font-weight:700}
.side-nav a.active,.side-nav a:hover{background:#F2ECFF;color:#5C44D6}
.content-area{min-width:0}
.pagehead{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:22px}
.pagehead h1{margin:0 0 8px;font-size:40px;line-height:1.02;letter-spacing:-.03em}
.pagehead p{margin:0;color:#73809A;max-width:62ch}
.panel{background:#fff;border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:0 8px 24px rgba(56,41,116,.05)}
.metric .label,.metric-label{font-size:14px;color:#76819A;font-weight:700}
.metric .value,.metric-value{font-size:42px;font-weight:900;line-height:1;margin-top:10px;color:#5C44D6}
.product-card .product-tag{display:inline-flex;padding:7px 10px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}
.tag-pay{background:#FFF1E9;color:var(--orange)}
.tag-shield{background:#F2ECFF;color:#7D5BEE}
.tag-analytics{background:#EAF8F3;color:#37906b}
.analytics-shell .cards-4{margin-bottom:22px}
.analytics-metrics .card{min-height:unset}
.analytics-metrics .card p{max-width:none;margin-top:8px}
.analytics-grid{display:grid;grid-template-columns:1.45fr .95fr;gap:22px;margin-bottom:22px}
.analytics-grid-bottom{grid-template-columns:1.35fr .65fr}
.card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:18px}
.card-head h3{font-size:26px;line-height:1.06;margin:0 0 6px}
.card-head p{margin:0;color:#73809A;max-width:none}
.inline-actions{display:flex;gap:12px;flex-wrap:wrap}
.bar-chart{display:grid;grid-template-columns:repeat(14,minmax(34px,1fr));gap:10px;align-items:end;height:280px}
.bar-col{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:0}
.bar-wrap{height:180px;width:100%;display:flex;align-items:flex-end;justify-content:center;background:linear-gradient(180deg,#F7F4FF 0%,#FFF 100%);border:1px solid var(--line);border-radius:16px;padding:8px}
.bar{display:block;width:100%;max-width:22px;border-radius:999px 999px 10px 10px;background:linear-gradient(180deg,#8A6BF2 0%, #EB6D3A 100%)}
.bar-value{font-size:12px;font-weight:800;color:#5C44D6}
.bar-label{font-size:11px;color:#7B879C;text-align:center;line-height:1.2}
.mix-list{display:grid;gap:16px}
.mix-top{display:flex;justify-content:space-between;gap:10px;margin-bottom:8px}
.mix-top strong{font-size:14px}
.mix-top span{font-size:13px;color:#73809A;font-weight:700}
.mix-track{height:12px;border-radius:999px;background:#F3F0FE;overflow:hidden}
.mix-track span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#7D5BEE 0%, #EB6D3A 100%)}
.table-wrap{overflow:auto}
.data-table{width:100%;border-collapse:collapse}
.data-table th,.data-table td{padding:12px 10px;border-bottom:1px solid #EEEAF8;text-align:left;font-size:14px;vertical-align:top}
.data-table th{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:#7B879C}
.code-block{background:#17132b;color:#fff;border-radius:16px;padding:14px 16px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:14px;margin:4px 0 16px}
.feature-list{padding-left:20px;margin:0}
.feature-list li{margin:8px 0;color:#66748B}
.compact-list li{font-size:14px}
.muted{color:#7B879C}
.reporting-card{max-width:1040px}
.reporting-actions{margin-top:22px}
.mini-feature-grid{margin-top:22px}
@media (max-width: 1024px){.layout,.analytics-grid,.analytics-grid-bottom{grid-template-columns:1fr}.sidebar{position:static}.pagehead{flex-direction:column}.bar-chart{grid-template-columns:repeat(7,minmax(34px,1fr));height:auto}.bar-wrap{height:140px}}
@media (max-width: 720px){.cards-4{grid-template-columns:1fr}.bar-chart{grid-template-columns:repeat(4,minmax(34px,1fr))}.pagehead h1{font-size:32px}}


.auth-shell{padding-top:78px}.auth-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:24px;align-items:stretch}.auth-copy,.auth-card{background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:0 10px 26px rgba(56,41,116,.06)}.auth-copy{padding:38px}.auth-copy h1{font-size:52px;line-height:1.02;letter-spacing:-.03em;margin:8px 0 14px}.auth-copy p{color:#6f7c95;max-width:56ch}.eyebrow{display:inline-flex;padding:8px 12px;border-radius:999px;background:#F2ECFF;color:#6c53dd;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.auth-points{display:grid;gap:14px;margin-top:26px}.auth-point{padding:16px 18px;border:1px solid #eeeaf8;border-radius:18px;background:linear-gradient(180deg,#fff 0%,#fbfaff 100%)}.auth-point strong{display:block;font-size:15px;margin-bottom:4px}.auth-point span{display:block;color:#73809A;font-size:14px}.auth-card{padding:34px;align-self:stretch}.auth-card-head h2{margin:0 0 8px;font-size:34px;line-height:1.04}.auth-card-head p{margin:0 0 20px;color:#73809A}.auth-form{display:grid;gap:16px}.auth-form label{display:grid;gap:8px}.auth-form span{font-size:14px;font-weight:700;color:#5a657c}.auth-form input{width:100%;height:52px;border:1px solid #ddd6fb;border-radius:16px;padding:0 16px;font-size:15px;background:#fff}.auth-form input:focus{outline:none;border-color:#7D5BEE;box-shadow:0 0 0 4px rgba(125,91,238,.12)}.btn-block{width:100%;justify-content:center}.auth-meta{margin-top:18px;color:#7B879C;font-size:14px}.alert{padding:14px 16px;border-radius:16px;margin-bottom:18px;font-size:14px;font-weight:700}.alert-error{background:#FFF2EE;border:1px solid #FFD9CB;color:#C65528}@media (max-width: 1024px){.auth-grid{grid-template-columns:1fr}.auth-copy h1{font-size:42px}}@media (max-width: 720px){.auth-card,.auth-copy{padding:24px}.auth-copy h1{font-size:34px}}

/* === v2.8 safe product logo/theme patch === */
.product-logo-tile{
  width:92px;
  height:92px;
  border-radius:24px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  box-shadow:0 10px 24px rgba(31,41,55,0.08);
  border:1px solid rgba(99,102,241,0.10);
}
.product-logo-tile img{
  width:62px;
  height:62px;
  display:block;
  filter:drop-shadow(0 6px 12px rgba(31,41,55,0.10));
}
.product-logo-tile.pay{background:linear-gradient(180deg,#FFF1E7 0%,#FFE7D7 100%);}
.product-logo-tile.shield{background:linear-gradient(180deg,#F1EAFF 0%,#E9DEFF 100%);}
.product-logo-tile.analytics{background:linear-gradient(180deg,#E7FAF1 0%,#DCF7EB 100%);}
.cards-3 .card{
  background:#F3F5FA;
  border:1px solid rgba(99,102,241,0.18);
  box-shadow:0 10px 24px rgba(31,41,55,0.08);
  border-radius:20px;
  transition:all .2s ease;
}
.cards-3 .card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 32px rgba(31,41,55,0.12);
}
.product-page-logo{
  width:104px;
  height:104px;
  display:block;
  margin-bottom:14px;
  filter:drop-shadow(0 10px 18px rgba(31,41,55,.12));
}
@media (max-width:900px){
  .product-logo-tile{width:80px;height:80px;}
  .product-logo-tile img{width:54px;height:54px;}
  .product-page-logo{width:86px;height:86px;}
}
/* v2.9 card polish */

.cards-3 .card{
    background:#F3F5FA;
    border:1px solid rgba(99,102,241,0.22);
    box-shadow:0 12px 28px rgba(31,41,55,0.08);
    border-radius:20px;
    transition:all .2s ease;
    padding:28px 26px 26px 26px;
}

.cards-3 .card:hover{
    transform:translateY(-6px);
    box-shadow:0 20px 40px rgba(31,41,55,0.12);
}

/* center + balance logo */
.product-logo-tile{
    margin:0 auto 20px auto;
}

/* improve spacing */
.cards-3 .card h3{
    margin-top:6px;
    margin-bottom:10px;
}

.cards-3 .card p{
    margin-bottom:14px;
    line-height:1.5;
}

/* improve link weight */
.cards-3 .card .link-arrow{
    font-weight:600;
}
