
:root{
  --bg:#eef5ff;
  --bg-soft:#f7fbff;
  --surface:#ffffff;
  --surface-2:#f2f7ff;
  --text:#0d1b2a;
  --muted:#5f7085;
  --line:#d9e6f6;
  --blue:#2563eb;
  --blue-2:#1d4ed8;
  --blue-3:#dbeafe;
  --sky:#38bdf8;
  --success:#16a34a;
  --danger:#c62828;
  --shadow:0 20px 60px rgba(37,99,235,.10);
  --radius:22px;
  --radius-sm:16px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 0% 0%, rgba(56,189,248,.18), transparent 34%),
    radial-gradient(circle at 100% 0%, rgba(37,99,235,.16), transparent 28%),
    linear-gradient(180deg,#f8fbff 0%,#edf4ff 100%);
  line-height:1.6;
}
a{color:var(--blue-2); text-decoration:none}
img{max-width:100%; display:block}
.container{max-width:var(--max); margin:0 auto; padding:0 18px}
.header{
  position:sticky; top:0; z-index:1000;
  backdrop-filter:blur(16px);
  background:rgba(248,251,255,.88);
  border-bottom:1px solid rgba(37,99,235,.08);
}
.header-inner{
  min-height:74px; display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.brand{
  display:flex; align-items:center; gap:12px; color:var(--text); font-weight:800; letter-spacing:-.03em;
}
.brand-mark{
  width:42px; height:42px; border-radius:13px;
  background:linear-gradient(135deg,var(--blue) 0%,var(--sky) 100%);
  color:#fff; display:flex; align-items:center; justify-content:center; font-weight:900;
  box-shadow:0 12px 24px rgba(37,99,235,.22);
}
.brand-copy small{display:block; color:var(--muted); font-weight:700; font-size:11px; letter-spacing:.12em; text-transform:uppercase}
.brand-copy span{display:block; font-size:18px}
.nav-toggle{display:none}
.nav-button{
  display:none;
  width:48px; height:48px; border-radius:14px; border:1px solid var(--line);
  background:#fff; align-items:center; justify-content:center; cursor:pointer;
  box-shadow:var(--shadow);
}
.nav-button span,.nav-button span:before,.nav-button span:after{
  content:""; display:block; width:18px; height:2px; background:var(--text); border-radius:2px; position:relative;
}
.nav-button span:before{position:absolute; top:-6px; left:0}
.nav-button span:after{position:absolute; top:6px; left:0}
.nav{
  display:flex; align-items:center; gap:10px;
}
.nav a{
  padding:10px 12px; color:var(--muted); font-size:14px; font-weight:700; border-radius:12px;
}
.nav a:hover,.nav a:focus{background:var(--surface); color:var(--blue-2)}
.cta-link{
  display:inline-flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue-2) 100%);
  color:#fff !important; padding:12px 18px; border-radius:14px; font-weight:800;
  box-shadow:0 14px 28px rgba(37,99,235,.22);
}
.hero{padding:42px 0 22px}
.hero-shell{
  display:grid; grid-template-columns:1.15fr .85fr; gap:22px; align-items:stretch;
}
.panel{
  background:rgba(255,255,255,.84); border:1px solid rgba(37,99,235,.10);
  border-radius:30px; box-shadow:var(--shadow);
}
.hero-main{
  padding:34px; overflow:hidden; position:relative;
}
.hero-main:after{
  content:""; position:absolute; right:-80px; top:-80px; width:280px; height:280px;
  background:radial-gradient(circle, rgba(37,99,235,.15), transparent 65%);
  pointer-events:none;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px; flex-wrap:wrap;
  background:#eff6ff; color:var(--blue-2); border:1px solid #cfe0ff;
  padding:8px 14px; border-radius:999px; font-size:12px; font-weight:800;
  text-transform:uppercase; letter-spacing:.12em;
}
.dot{width:8px; height:8px; border-radius:50%; background:var(--success)}
h1{
  margin:16px 0 14px; font-size:clamp(34px,6vw,68px); line-height:1.02; letter-spacing:-.05em;
}
.lead{font-size:18px; color:var(--muted); max-width:760px; margin:0 0 22px}
.action-row{display:flex; gap:14px; flex-wrap:wrap; margin:22px 0 18px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; text-align:center;
  min-height:52px; padding:0 20px; border-radius:16px; font-weight:800; font-size:15px;
  transition:.2s ease;
}
.btn-primary{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-2) 100%); color:#fff; box-shadow:0 16px 30px rgba(37,99,235,.2)}
.btn-secondary{background:#fff; color:var(--text); border:1px solid var(--line)}
.btn:hover{transform:translateY(-1px)}
.tiny-note{font-size:12px; color:var(--muted)}
.hero-side{
  display:grid; gap:18px;
}
.offer-card, .license-card, .mini-card, .legal-card{
  padding:24px;
}
.card-label{
  color:var(--blue-2); font-size:12px; font-weight:900; text-transform:uppercase; letter-spacing:.13em;
}
.offer-amount{
  display:flex; align-items:flex-end; gap:10px; margin:10px 0 12px;
}
.offer-amount strong{
  font-size:56px; line-height:1; letter-spacing:-.06em;
}
.pill-row{display:flex; flex-wrap:wrap; gap:10px; margin-top:14px}
.pill{
  background:var(--surface-2); color:var(--text); border:1px solid var(--line);
  padding:8px 10px; border-radius:999px; font-size:12px; font-weight:700;
}
.section{padding:22px 0}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.grid-2{display:grid; grid-template-columns:repeat(2,1fr); gap:18px}
.card-title{margin:8px 0 10px; font-size:26px; line-height:1.1; letter-spacing:-.03em}
.card p,.panel p{margin:0 0 10px}
.step-card{
  background:var(--surface); border:1px solid var(--line); border-radius:24px; padding:22px; box-shadow:var(--shadow)
}
.step-no{
  width:42px; height:42px; border-radius:14px; background:var(--blue-3); color:var(--blue-2);
  display:flex; align-items:center; justify-content:center; font-weight:900; margin-bottom:14px;
}
.highlight-strip{
  background:linear-gradient(135deg,#0f172a 0%,#17346f 100%);
  color:#fff; border-radius:28px; padding:26px; box-shadow:var(--shadow);
}
.highlight-strip a{color:#fff}
.metric-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:16px}
.metric{
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.10); border-radius:18px; padding:16px;
}
.metric strong{display:block; font-size:28px; line-height:1.05}
.table-list{display:grid; gap:10px; margin-top:14px}
.table-row{
  display:flex; gap:16px; justify-content:space-between; align-items:flex-start;
  padding:14px 0; border-bottom:1px solid var(--line);
}
.table-row:last-child{border-bottom:none}
.table-row b{display:block; color:var(--muted); font-size:12px; text-transform:uppercase; letter-spacing:.1em; margin-bottom:4px}
.table-row span:last-child{text-align:right; font-weight:700}
.alert{
  margin-top:18px; background:#eff6ff; border:1px solid #cfe0ff; padding:16px; border-radius:16px;
}
.faq details{
  background:var(--surface); border:1px solid var(--line); border-radius:18px; padding:0 18px; box-shadow:var(--shadow); margin-bottom:12px;
}
.faq summary{
  list-style:none; cursor:pointer; padding:18px 0; font-weight:800; display:flex; justify-content:space-between; gap:12px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+"; color:var(--blue-2); font-size:26px; line-height:1}
.faq details[open] summary:after{content:"–"}
.faq .answer{padding:0 0 18px; color:var(--muted)}
.band{
  background:#dbeafe; border-top:1px solid #bfdbfe; border-bottom:1px solid #bfdbfe;
  padding:16px 0; margin-top:24px;
}
.band strong{color:var(--blue-2)}
.footer{
  padding:34px 0 44px;
}
.footer-top{
  display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:18px;
}
.footer-card{
  background:rgba(255,255,255,.72); border:1px solid rgba(37,99,235,.08); border-radius:24px; padding:22px; box-shadow:var(--shadow)
}
.footer h4{margin:0 0 12px; font-size:15px; text-transform:uppercase; letter-spacing:.08em}
.footer ul{list-style:none; padding:0; margin:0}
.footer li{margin:0 0 10px}
.footer p,.footer li a{color:var(--muted); font-size:14px}
.footer-bottom{
  margin-top:18px; color:var(--muted); font-size:12px;
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
}
.page-hero{
  padding:28px 0 8px;
}
.page-hero .panel{padding:28px}
.page-hero h1{font-size:clamp(28px,5vw,54px); margin-bottom:12px}
.content-panel{padding:26px}
.content-panel h2{font-size:28px; margin:0 0 12px; letter-spacing:-.03em}
.content-panel h3{font-size:20px; margin:20px 0 8px}
.content-panel ul{padding-left:18px}
.content-panel li{margin:0 0 8px}
.stacked{display:grid; gap:18px}
.mobile-cta{display:none}

@media (max-width: 980px){
  .hero-shell,.grid-3,.grid-2,.footer-top,.metric-grid{grid-template-columns:1fr}
  .hero-main,.offer-card,.license-card,.mini-card,.legal-card,.content-panel{padding:24px}
  .nav{
    position:fixed; left:14px; right:14px; top:84px;
    background:rgba(255,255,255,.98); border:1px solid var(--line); border-radius:22px;
    box-shadow:0 30px 80px rgba(13,27,42,.18); padding:10px; display:none; flex-direction:column; align-items:stretch;
  }
  .nav a{padding:14px 14px; border-radius:14px}
  .nav .cta-link{margin-top:4px}
  .nav-button{display:flex}
  .nav-toggle:checked ~ .nav{display:flex}
  .nav-toggle:checked + .nav-button{background:#eff6ff}
  .header-inner{min-height:72px}
  .mobile-cta{display:inline-flex}
}
@media (max-width: 640px){
  .container{padding:0 14px}
  .hero{padding-top:18px}
  .hero-main{padding:22px}
  h1{font-size:clamp(30px,10vw,50px)}
  .lead{font-size:16px}
  .action-row{flex-direction:column}
  .btn{width:100%}
  .brand-copy span{font-size:16px}
  .brand-mark{width:38px; height:38px; border-radius:12px}
  .offer-amount strong{font-size:46px}
  .table-row{flex-direction:column}
  .table-row span:last-child{text-align:left}
  .header{border-bottom-color:#dce8f9}
}
