:root{
  --bg:#ffffff; --panel:#f8fafc; --text:#0f172a; --muted:#475569;
  --brand:#2563eb; --brand2:#7c3aed; --border:#e2e8f0;
  --max:1100px; --r:18px;
  --shadow:0 10px 30px rgba(2,6,23,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font:16px/1.55 ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial;
  color:var(--text);
  background:radial-gradient(1200px 600px at 20% -10%, rgba(37,99,235,.10), transparent 60%),
             radial-gradient(1000px 500px at 90% 0%, rgba(124,58,237,.08), transparent 55%),
             var(--bg);
}
a{color:inherit}
.container{max-width:var(--max); margin:0 auto; padding:0 18px}
header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.78); backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(226,232,240,.9);
}
.nav{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:14px 0}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none}
.logo{width:34px; height:34px; border-radius:12px; background:linear-gradient(135deg, var(--brand), var(--brand2)); box-shadow:0 10px 25px rgba(110,168,254,.25); display:block; flex-shrink:0; overflow:hidden}
.icon-box{display:inline-flex; align-items:center; justify-content:center; width:44px; height:44px; border-radius:14px; background:linear-gradient(135deg, rgba(37,99,235,.10), rgba(124,58,237,.10)); margin-bottom:8px}
.icon-box svg{width:24px; height:24px; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; fill:none; stroke:var(--brand)}
.hero-illustration{display:flex; align-items:center; justify-content:center; padding:24px; opacity:.85}
.hero-illustration svg{width:100%; max-width:340px; height:auto}
.blog-hero{display:flex; align-items:center; justify-content:center; padding:18px; margin:14px 0; border-radius:var(--r); background:linear-gradient(135deg, rgba(37,99,235,.06), rgba(124,58,237,.06)); border:1px solid rgba(226,232,240,.95)}
.blog-hero svg{width:100%; max-width:260px; height:auto}
.blog-card-thumb{display:flex; align-items:center; justify-content:center; padding:14px; border-radius:14px 14px 0 0; background:linear-gradient(135deg, rgba(37,99,235,.06), rgba(124,58,237,.06)); border-bottom:1px solid rgba(226,232,240,.95)}
.blog-card-thumb svg{width:60px; height:60px}
.blog-grid{display:grid; grid-template-columns:repeat(auto-fill, minmax(280px, 1fr)); gap:14px}
.legal-content h2{font-size:20px; margin:28px 0 10px; color:var(--text)}
.legal-content h3{font-size:16px; margin:20px 0 8px; color:var(--text)}
.legal-content p{color:var(--muted); margin:0 0 12px; line-height:1.65}
.legal-content ul{margin:0 0 12px; padding-left:20px; color:var(--muted)}
.legal-content li{margin-bottom:6px; line-height:1.65}
.brand b{letter-spacing:.2px}
.navlinks{display:flex; flex-wrap:wrap; gap:14px; align-items:center}
.navlinks a{text-decoration:none; color:var(--muted); font-weight:600; font-size:14px; padding:8px 10px; border-radius:12px}
.navlinks a:hover{color:var(--text); background:rgba(226,232,240,.75)}
.cta{display:flex; gap:10px; align-items:center}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px; padding:10px 14px; border-radius:14px;
  border:1px solid rgba(226,232,240,.95);
  background:#ffffff; color:var(--text);
  text-decoration:none; font-weight:800; font-size:14px;
}
.btn:hover{border-color:rgba(110,168,254,.65); box-shadow:0 10px 30px rgba(110,168,254,.12)}
.btn.primary{border-color:transparent; background:linear-gradient(135deg, var(--brand), var(--brand2))}
.btn.primary:hover{box-shadow:0 12px 34px rgba(110,168,254,.22)}
main{padding:26px 0 70px}
.hero{padding:54px 0 26px}
.kicker{
  display:inline-flex; gap:10px; align-items:center;
  padding:7px 10px; border-radius:999px;
  border:1px solid rgba(226,232,240,.95);
  color:var(--muted); background:rgba(255,255,255,.9);
  font-weight:700; font-size:13px;
}
h1{font-size:44px; line-height:1.08; margin:16px 0 10px; letter-spacing:-.6px}
p.lead{font-size:18px; color:var(--muted); max-width:780px; margin:0}
.heroGrid{display:grid; grid-template-columns:1.15fr .85fr; gap:18px; align-items:stretch; margin-top:22px}
.card{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(226,232,240,.95);
  border-radius:var(--r);
  box-shadow:var(--shadow);
}
.heroCard{padding:18px}
.heroActions{display:flex; flex-wrap:wrap; gap:10px; margin-top:16px}
.badges{display:flex; flex-wrap:wrap; gap:8px; margin-top:14px}
.badge{font-size:12px; color:var(--muted); padding:6px 10px; border-radius:999px; border:1px solid rgba(226,232,240,.95); background:rgba(248,250,252,.9)}
.panel{padding:18px}
.panel h2{margin:0 0 8px; font-size:16px; color:var(--text)}
.panel p{margin:0; color:var(--muted); font-size:14px}
.list{margin:14px 0 0; padding:0; list-style:none; display:grid; gap:10px}
.li{display:flex; gap:10px; align-items:flex-start; padding:10px 12px; border-radius:14px; border:1px solid rgba(226,232,240,.95); background:rgba(248,250,252,.9)}
.dot{width:10px; height:10px; border-radius:99px; margin-top:6px; background:linear-gradient(135deg, var(--brand), var(--brand2))}
.section{padding:34px 0}
.section h2{font-size:26px; margin:0 0 10px}
.section p{color:var(--muted); margin:0 0 16px; max-width:780px}
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.feature{padding:16px}
.feature h3{margin:6px 0 6px; font-size:16px}
.feature p{margin:0; color:var(--muted); font-size:14px}
hr.sep{border:0; border-top:1px solid rgba(226,232,240,.9); margin:26px 0}
.twoCol{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.faq details{border:1px solid rgba(226,232,240,.95); background:rgba(255,255,255,.92); border-radius:16px; padding:12px 14px}
.faq summary{cursor:pointer; font-weight:800}
.faq p{margin:8px 0 0; color:var(--muted)}
.footer{border-top:1px solid rgba(226,232,240,.9); padding:26px 0 40px; color:var(--muted)}
.footerGrid{display:grid; grid-template-columns:2fr 1fr 1fr; gap:14px; align-items:start}
.footer a{text-decoration:none; color:var(--muted)}
.footer a:hover{color:var(--text)}
.small{font-size:13px}
.table{width:100%; border-collapse:separate; border-spacing:0; overflow:hidden; border-radius:16px; border:1px solid rgba(226,232,240,.95)}
.table th,.table td{padding:12px 12px; text-align:left; border-bottom:1px solid rgba(226,232,240,.85)}
.table th{color:var(--text); font-size:13px; background:rgba(248,250,252,.9)}
.table td{color:var(--muted); font-size:14px}
.table tr:last-child td{border-bottom:0}
.notice{border:1px dashed rgba(110,168,254,.45); background:rgba(110,168,254,.08); padding:12px 14px; border-radius:16px; color:var(--muted)}
@media (max-width: 900px){
  h1{font-size:36px}
  .heroGrid{grid-template-columns:1fr}
  .grid3{grid-template-columns:1fr}
  .twoCol{grid-template-columns:1fr}
  .footerGrid{grid-template-columns:1fr}
  .navlinks{display:none}
  .blog-grid{grid-template-columns:1fr}
  .hero-illustration svg{max-width:240px}
}
