/* page frame */
.page{ padding-top: var(--header-h); }

/* hero */
.page-hero{
  position: relative;
  height: 78vh;
  min-height: 560px;
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background:#0b1220;
  background-size: cover;
  background-position:center;
  transform: scale(1.02);
}
.hero-overlay{
  position:absolute; inset:0;
  background: linear-gradient(90deg, rgba(9,31,58,.74) 0%, rgba(9,31,58,.42) 54%, rgba(9,31,58,.18) 100%);
}

.hero-inner{
  position: relative;
  height: 100%;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 18px;
  align-items:end;
  padding: 56px 0 48px;
}

.hero-copy{ color:#fff; }
.kicker{
  margin:0 0 10px;
  display:flex; gap:10px; align-items:center;
  color: rgba(255,255,255,.9);
  font-weight:800;
}
.hero-copy h1{
  margin:0;
  font-size: clamp(34px, 4vw, 54px);
  line-height:1.05;
  letter-spacing:-0.6px;
}
.lead{
  margin: 14px 0 0;
  max-width: 620px;
  color: rgba(255,255,255,.88);
  line-height: 1.7;
  font-size: 16px;
}
.hero-actions{
  margin-top: 18px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* right card */
.hero-card{
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
  border-radius: 22px;
  padding: 16px;
  color:#fff;
}
.mini-row{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.92);
  font-weight: 700;
  font-size: 13px;
}
.hero-card__list{
  margin-top: 14px;
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.hero-card__list > div{
  display:flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
}
.hero-card__list strong{ font-weight:900; }
.hero-card__list span{ color: rgba(255,255,255,.85); }

/* sections */
.section{ padding: 70px 0; }
.section.alt{ background: #f6f7fb; }

.section-head{ margin-bottom: 20px; }
.section-title{ margin:0; font-size: 30px; letter-spacing: -0.5px; }
.section-sub{ margin: 10px 0 0; color: var(--sub); line-height: 1.6; }

.grid-3{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
.card{
  border: 1px solid rgba(229,231,235,.9);
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
  padding: 18px 16px;
}
.card i{ color: var(--brand); font-size: 18px; }
.card h3{ margin: 10px 0 6px; font-size: 16px; }
.card p{ margin:0; color: var(--sub); line-height:1.6; font-size: 13px; }

.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  align-items:center;
}
.media{
  height: 520px;
  border-radius: 22px;
  border: 1px solid rgba(229,231,235,.9);
  box-shadow: var(--shadow);
  background: #eaeef6;
  background-size: cover;
  background-position:center;
}
.copy .steps{
  list-style:none;
  padding:0;
  margin: 16px 0 0;
  display:flex;
  flex-direction: column;
  gap: 12px;
}
.copy .steps li{
  display:flex;
  gap: 12px;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(229,231,235,.9);
  background:#fff;
  box-shadow: 0 10px 24px rgba(15,23,42,.05);
}
.badge{
  min-width: 42px;
  height: 42px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  font-weight: 900;
  color: #fff;
  background: var(--brand);
}
.copy h4{ margin:0; font-size: 15px; }
.copy p{ margin: 6px 0 0; color: var(--sub); line-height: 1.6; font-size: 13px; }

.cta-row{
  margin-top: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* faq */
.faq{ display:flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.faq-item{
  border: 1px solid rgba(229,231,235,.9);
  border-radius: 18px;
  background:#fff;
  box-shadow: 0 10px 24px rgba(15,23,42,.05);
  padding: 12px 14px;
}
.faq-item summary{
  cursor:pointer;
  font-weight: 800;
  color: var(--text);
}
.faq-item p{
  margin: 10px 0 0;
  color: var(--sub);
  line-height: 1.65;
  font-size: 13px;
}

/* bottom cta */
.bottom-cta{
  padding: 60px 0;
  background: linear-gradient(135deg, rgba(9,31,58,1) 0%, rgba(9,31,58,.92) 65%, rgba(9,31,58,.86) 100%);
  color:#fff;
}
.bottom-cta__inner{
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 14px;
  flex-wrap: wrap;
  padding: 18px 0;
}
.bottom-cta__inner h3{ margin:0; font-size: 22px; }
.bottom-cta__inner p{ margin: 8px 0 0; color: rgba(255,255,255,.86); line-height: 1.6; }

@media (max-width: 980px){
  .hero-inner{ grid-template-columns: 1fr; align-items:end; }
  .page-hero{ height: 86vh; }
  .grid-3{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .media{ height: 320px; }
}
