*{box-sizing:border-box}

:root{
  --bg:#f6f8fc;
  --text:#172033;
  --muted:#5f6b7a;
  --blue:#2563eb;
  --blue-dark:#1d4ed8;
  --soft:#eef4ff;
  --dark:#101827;
  --line:#e5e9f0;
  --white:#ffffff;
  --shadow:0 18px 45px rgba(16,24,39,.08);
}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
}

a{color:inherit}

.container{
  max-width:1160px;
  margin:0 auto;
  padding:0 24px;
}

.site-header{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}

.nav{
  height:74px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.logo,.footer-logo{
  text-decoration:none;
  font-weight:900;
  font-size:22px;
  letter-spacing:-.03em;
}

.logo-mark{
  color:var(--blue);
}

.nav-links{
  display:flex;
  gap:24px;
  font-size:14px;
  color:var(--muted);
}

.nav-links a{
  text-decoration:none;
}

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:14px 22px;
  border:0;
  border-radius:14px;
  background:var(--blue);
  color:white;
  text-decoration:none;
  font-weight:900;
  font-size:15px;
  cursor:pointer;
}

.button:hover{background:var(--blue-dark)}

.button-secondary{
  background:#e8efff;
  color:var(--text);
}

.button-secondary:hover{background:#dbe6ff}

.button-small{
  min-height:40px;
  padding:10px 16px;
  font-size:14px;
}

.button.full{width:100%}

.hero{
  background:
    radial-gradient(circle at 85% 5%, rgba(37,99,235,.23), transparent 32%),
    linear-gradient(180deg,#fff 0%,#f6f8fc 100%);
  padding:92px 0 78px;
}

.hero-grid{
  display:grid;
  grid-template-columns:1.18fr .82fr;
  gap:48px;
  align-items:center;
}

.eyebrow{
  margin:0 0 14px;
  color:var(--blue);
  font-weight:900;
  letter-spacing:.09em;
  text-transform:uppercase;
  font-size:13px;
}

.eyebrow.light{color:#93c5fd}

h1{
  margin:0 0 22px;
  max-width:760px;
  font-size:clamp(44px,7vw,78px);
  line-height:.96;
  letter-spacing:-.055em;
}

h2{
  margin:0 0 18px;
  font-size:clamp(31px,4vw,48px);
  line-height:1.08;
  letter-spacing:-.035em;
}

h3{
  margin:0 0 10px;
  font-size:22px;
  line-height:1.2;
}

.hero-subtitle{
  max-width:720px;
  color:#465467;
  font-size:21px;
}

.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin:32px 0 14px;
}

.microcopy{
  color:#697586;
  font-size:14px;
}

.hero-card,.card,.step,.waitlist,.faq-list details,.future-card{
  background:white;
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:var(--shadow);
}

.hero-card{
  padding:34px;
  border-top:5px solid var(--blue);
}

.card-label{
  margin:0 0 10px;
  color:var(--blue);
  font-weight:900;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.trust-list{
  display:grid;
  gap:10px;
  margin-top:24px;
}

.trust-list div{
  padding:12px 14px;
  border-radius:14px;
  background:#f8fafc;
  font-weight:800;
}

.section{
  padding:82px 0;
}

.intro-strip{
  background:var(--dark);
  color:white;
}

.strip-grid,.two-column,.future-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:44px;
  align-items:start;
}

.intro-strip p:not(.eyebrow),.dark p{
  color:#d8e1ed;
}

.section-heading{
  max-width:820px;
  margin-bottom:34px;
}

.section-heading p{
  color:var(--muted);
  font-size:18px;
}

.cards{
  display:grid;
  gap:22px;
}

.cards.three{
  grid-template-columns:repeat(3,1fr);
}

.cards.five{
  grid-template-columns:repeat(5,1fr);
}

.card{
  padding:28px;
}

.card.compact{
  font-weight:900;
}

.icon{
  width:44px;
  height:44px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  background:#e8efff;
  color:var(--blue);
  font-weight:900;
}

.soft{
  background:#fff;
}

.check-grid,.mini-list{
  display:grid;
  gap:14px;
}

.check-grid div,.mini-list div{
  padding:16px 18px;
  border:1px solid var(--line);
  border-radius:16px;
  background:#f8fafc;
  font-weight:850;
}

.dark{
  background:var(--dark);
  color:white;
}

.steps{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:18px;
}

.step{
  padding:26px;
}

.step span{
  display:inline-flex;
  width:42px;
  height:42px;
  align-items:center;
  justify-content:center;
  margin-bottom:16px;
  border-radius:50%;
  background:#e8efff;
  color:var(--blue);
  font-weight:900;
}

.future-section{
  background:
    radial-gradient(circle at top left, rgba(37,99,235,.12), transparent 28%),
    #fff;
}

.future-grid{
  align-items:center;
}

.future-card{
  padding:34px;
  border-left:5px solid var(--blue);
}

.faq-list{
  display:grid;
  gap:14px;
  max-width:900px;
}

.faq-list details{
  padding:20px 22px;
}

.faq-list summary{
  font-weight:900;
  cursor:pointer;
}

.waitlist-section{
  background:linear-gradient(180deg,var(--soft) 0%,#fff 100%);
}

.waitlist{
  padding:44px;
  display:grid;
  grid-template-columns:.9fr 1fr;
  gap:44px;
}

.included{
  list-style:none;
  padding:0;
  margin:24px 0 0;
  display:grid;
  gap:10px;
  font-weight:850;
}

.form{
  display:grid;
  gap:16px;
}

label{
  font-weight:850;
}

input,select,textarea{
  width:100%;
  margin-top:6px;
  padding:14px;
  border:1px solid #cfd7e3;
  border-radius:12px;
  font:inherit;
  background:white;
}

textarea{
  min-height:110px;
  resize:vertical;
}

.checkbox{
  display:flex;
  gap:10px;
  align-items:flex-start;
  font-size:14px;
  font-weight:400;
}

.checkbox input{
  width:auto;
  margin-top:5px;
}

.checkbox a{
  color:var(--blue);
}

.footer{
  padding:54px 0;
  background:var(--dark);
  color:white;
}

.footer-grid{
  display:flex;
  justify-content:space-between;
  gap:32px;
}

.footer p{
  color:#cbd5e1;
}

.footer a{
  color:white;
  text-decoration:none;
}

@media(max-width:980px){
  .nav-links{display:none}
  .hero-grid,.strip-grid,.two-column,.waitlist,.future-grid{
    grid-template-columns:1fr;
  }
  .cards.three,.cards.five,.steps{
    grid-template-columns:1fr 1fr;
  }
}

@media(max-width:640px){
  .hero{
    padding:62px 0;
  }

  .section{
    padding:58px 0;
  }

  .cards.three,.cards.five,.steps{
    grid-template-columns:1fr;
  }

  .hero-actions{
    flex-direction:column;
  }

  .button{
    width:100%;
  }

  .footer-grid{
    flex-direction:column;
  }
}
