:root{
  --bg:#f7f8fa;
  --bg2:#eef2f6;
  --panel:#ffffff;
  --panel2:#f9fbfd;
  --text:#1b1f24;
  --muted:#667085;
  --line:#dbe2ea;
  --brand:#2f80ed;
  --brand2:#89bdf8;
  --shadow:0 10px 30px rgba(16,24,40,.08);
  --radius:18px;
  --max:1100px
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 500px at 78% 18%, rgba(47,128,237,.10), transparent 42%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  line-height:1.6
}
a{color:inherit;text-decoration:none}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}

header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(10px);
  background:rgba(255,255,255,.88);
  border-bottom:1px solid var(--line)
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 0;
  gap:12px
}
.brand img{width:170px;height:auto;display:block}

.menu{
  display:flex;
  gap:18px;
  align-items:center;
  flex-wrap:wrap;
  justify-content:center
}
.menu a{
  color:#2a2f36;
  padding:8px 10px;
  border-radius:999px;
  font-weight:500
}
.menu a:hover{
  color:var(--text);
  background:rgba(47,128,237,.08)
}

.actions{
  display:flex;
  align-items:center;
  gap:10px;
  justify-content:flex-end
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 16px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  gap:10px;
  font-weight:800;
  transition:.18s ease;
  box-shadow:0 1px 0 rgba(16,24,40,.02)
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 20px rgba(16,24,40,.08)
}
.btn.primary{
  border-color:#2f80ed;
  background:linear-gradient(180deg,#4ea0ff,#2f80ed);
  color:#fff
}
.btn.primary:hover{filter:brightness(1.02)}
.btn.small{
  padding:9px 14px;
  border-radius:10px
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border:1px solid var(--line);
  background:#fff;
  color:#475467;
  border-radius:8px;
  font-size:14px;
  white-space:nowrap;
  box-shadow:0 2px 8px rgba(16,24,40,.04)
}

.hero{padding:54px 0 18px}
.heroGrid{
  display:grid;
  grid-template-columns:1.02fr .98fr;
  gap:30px;
  align-items:center
}
h1{
  font-size:60px;
  line-height:1.06;
  margin:0 0 16px;
  letter-spacing:-.03em;
  font-weight:900
}
.sub{
  color:#3d4856;
  font-size:18px;
  max-width:33ch
}
.kicker{
  display:inline-flex;
  gap:10px;
  align-items:center;
  padding:0 0 10px 0;
  border-bottom:1px solid #d8dee7;
  color:#6b7280;
  font-weight:700;
  margin-bottom:18px;
  font-size:16px
}
.heroCtas{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin:22px 0 16px
}
.valueStrip{
  display:flex;
  gap:8px;
  flex-wrap:nowrap;
  margin-top:6px;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border:1px solid var(--line);
  background:#fff;
  color:#475467;
  border-radius:8px;
  font-size:14px;
  white-space:nowrap;
  box-shadow:0 2px 8px rgba(16,24,40,.04);
  flex:0 0 auto;
}
.callout{
  border-radius:12px;
  border:1px solid #cfe0f8;
  background:linear-gradient(180deg,#ffffff,#f8fbff);
  padding:18px 20px;
  box-shadow:0 6px 16px rgba(47,128,237,.05)
}
.callout strong{color:#1f2937}


.heroArt{
  border-radius:24px;
  overflow:visible;
  background:transparent;
  min-height:420px;
  display:flex;
  align-items:flex-start;
  justify-content:flex-start;
  border:none;
  box-shadow:none;
  position:relative;
}

.heroArt img{
  width:300%;
  max-width:none;
  height:auto;
  display:block;
  margin-left:-420px;
  margin-top:18px;
  opacity:.90;
  filter:contrast(1.03) brightness(1.02);

  -webkit-mask-image: radial-gradient(circle at center, black 62%, transparent 92%);
  mask-image: radial-gradient(circle at center, black 62%, transparent 92%);
}

.section{padding:42px 0}
.section h2{
  font-size:38px;
  margin:0 0 10px;
  letter-spacing:-.02em
}
.section p.lead{
  color:var(--muted);
  margin:0 0 24px;
  max-width:74ch;
  font-size:18px
}

.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}

.card{
  border:1px solid #e4e8ee;
  background:rgba(255,255,255,.78);
  border-radius:18px;
  padding:22px;
  box-shadow:var(--shadow)
}
.card h3{
  margin:0 0 8px;
  font-size:19px;
  font-weight:800;
  letter-spacing:-.01em
}
.card p{margin:0;color:var(--muted)}

.icon{
  width:56px;
  height:56px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:linear-gradient(180deg,#f5faff,#ebf4ff);
  border:1px solid #d9e6f6;
  margin-bottom:14px
}
.icon svg{
  width:24px;
  height:24px;
  fill:none;
  stroke:#5d91d6;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round
}

hr.sep{
  border:none;
  border-top:1px solid #e2e8f0;
  margin:24px 0
}

.table{
  width:100%;
  border-collapse:collapse;
  overflow:hidden;
  border-radius:16px;
  border:1px solid #e3e8ef;
  background:#fff
}
.table th,.table td{
  padding:12px 14px;
  border-bottom:1px solid #edf1f5;
  text-align:left
}
.table th{
  color:#344054;
  font-weight:900;
  background:#f7faff
}
.table tr:last-child td{border-bottom:none}

.notice{
  color:var(--muted);
  font-size:14px
}

.footer{
  border-top:1px solid #e3e8ef;
  padding:30px 0 40px;
  margin-top:34px;
  color:#667085;
  background:rgba(255,255,255,.55)
}
.footerGrid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:18px
}
.footer a{color:#667085}
.footer a:hover{color:var(--text)}
.small{font-size:13px}

.faq details{
  border:1px solid #e3e8ef;
  background:#fff;
  border-radius:16px;
  padding:14px 16px;
  box-shadow:0 6px 16px rgba(16,24,40,.04)
}
.faq details + details{margin-top:12px}
.faq summary{cursor:pointer;font-weight:900}
.faq p{color:var(--muted);margin:10px 0 0}

.mobileToggle{display:none}

@media (max-width:920px){
  .heroGrid{grid-template-columns:1fr}
  h1{font-size:46px}
  .heroArt{min-height:auto}
}
@media (max-width:720px){
  .menu{display:none}
  .mobileToggle{display:inline-flex}
  .grid3,.grid2{grid-template-columns:1fr}
  .footerGrid{grid-template-columns:1fr}
  .brand img{width:150px}
  h1{font-size:40px}
}