:root{
  --navy:#061f4a;
  --navy2:#031d42;
  --blue:#0a70e8;
  --cyan:#11c6ec;
  --teal:#18c9c7;
  --green:#48b529;
  --lime:#80cf17;
  --muted:#4d6078;
  --line:#dce9f6;
  --white:#fff;
  --shadow:0 15px 34px rgba(7,33,76,.12);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  color:var(--navy);
  background:#fff;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
.container{width:min(1042px, calc(100% - 78px));margin-inline:auto}

.topbar{
  height:35px;
  background:#06204c;
  color:white;
  font-size:13px;
  font-weight:750;
}
.topbar-inner{
  height:35px;
  display:flex;
  align-items:center;
  gap:15px;
}
.top-location{
  margin-left:auto;
}
.top-location::first-letter{color:#75cd25}

.site-header{
  height:89px;
  background:white;
  border-bottom:1px solid #e7eef6;
  box-shadow:0 2px 16px rgba(3,29,66,.04);
  position:sticky;
  top:0;
  z-index:20;
}
.header-inner{
  height:89px;
  display:flex;
  align-items:center;
  gap:34px;
}
.logo img{
  width:213px;
  height:auto;
}
.nav{
  display:flex;
  gap:35px;
  align-items:center;
  margin-left:auto;
  color:#0b244d;
  font-size:14px;
  font-weight:850;
}
.nav a:first-child::after,
.nav a:nth-child(5)::after{
  content:"⌄";
  margin-left:6px;
  font-size:11px;
}
.header-cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:linear-gradient(180deg,#87d420,#3fb229);
  color:white;
  border-radius:9px;
  padding:15px 22px;
  font-weight:950;
  box-shadow:0 10px 18px rgba(63,178,41,.22);
  white-space:nowrap;
}
.mobile-toggle{
  display:none;
  width:42px;
  height:42px;
  background:#fff;
  border:0;
  margin-left:auto;
}
.mobile-toggle span{
  display:block;
  width:26px;
  height:3px;
  margin:5px auto;
  background:var(--navy);
  border-radius:99px;
}

.hero{
  height:499px;
  position:relative;
  overflow:hidden;
  background:#f3fbff;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:linear-gradient(90deg,#fff 0%,#fff 28%,rgba(255,255,255,.82) 45%,rgba(255,255,255,.2) 67%,rgba(255,255,255,0) 100%);
}
.hero-photo{
  position:absolute;
  inset:0 0 0 auto;
  width:66%;
  background:url("assets/lander1/hero-clean-photo.png") center right/cover no-repeat;
}
.hero-grid{
  height:100%;
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr 344px;
  align-items:center;
  gap:50px;
}
.hero-copy{
  max-width:520px;
  padding-top:6px;
}
.offer-pill{
  display:inline-block;
  background:#c8edff;
  color:#0473de;
  padding:6px 16px;
  border-radius:999px;
  text-transform:uppercase;
  font-size:14px;
  font-weight:950;
  letter-spacing:.02em;
  margin:0 0 15px;
}
h1{
  margin:0;
  color:var(--navy);
  font-size:63px;
  line-height:.96;
  letter-spacing:-.06em;
  font-weight:950;
}
h1 span{
  display:inline-block;
  color:#0b72ec;
  font-size:64px;
  background:linear-gradient(90deg,#0b68ec,#0aa7f4 58%,#15d2c3);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  position:relative;
}
h1 span::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-9px;
  height:11px;
  border-radius:50%;
  border-top:5px solid #56c72f;
  transform:rotate(-2deg);
}
.hero-sub{
  width:430px;
  margin:26px 0 27px;
  color:#14325b;
  font-size:18px;
  line-height:1.42;
}
.hero-icons{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  width:440px;
  gap:18px;
  align-items:start;
}
.hero-icons div{
  min-height:92px;
  border-right:1px solid rgba(20,50,91,.12);
  text-align:center;
}
.hero-icons div:last-child{border-right:0}
.hero-icons img{
  height:50px;
  max-width:62px;
  object-fit:contain;
  margin:0 auto 8px;
}
.hero-icons strong{
  display:block;
  font-size:13px;
  line-height:1.15;
  font-weight:950;
  color:#061f4a;
}

.lead-card{
  background:rgba(255,255,255,.96);
  border-radius:19px;
  box-shadow:0 15px 35px rgba(4,31,73,.14);
  padding:23px 22px 21px;
  align-self:center;
  min-height:459px;
}
.lead-card h2{
  margin:0 0 15px;
  font-size:25px;
  line-height:1;
  text-align:center;
  color:var(--navy);
}
.lead-card h2 span{color:#0577ee}
.lead-card label{
  height:39px;
  margin-bottom:10px;
  display:flex;
  align-items:center;
  gap:9px;
  background:#fff;
  border:1px solid #d6e2ee;
  border-radius:7px;
  color:#9aa6b4;
  padding:0 12px;
  box-shadow:inset 0 1px 0 rgba(7,33,76,.02);
}
.lead-card input,
.lead-card select{
  width:100%;
  border:0;
  outline:0;
  background:transparent;
  font:inherit;
  font-size:14px;
  color:#293a53;
}
.lead-card button{
  margin-top:5px;
  width:100%;
  height:48px;
  border:0;
  border-radius:7px;
  color:white;
  background:linear-gradient(180deg,#84cf1e,#3fb22a);
  box-shadow:0 11px 19px rgba(63,178,42,.24);
  font-size:20px;
  font-weight:950;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:22px;
}
.secure-note{
  text-align:center;
  color:#596b82;
  font-size:13px;
  margin:20px 0 0;
}

.benefits{
  padding:23px 0 28px;
}
.benefits h2,
.how-panel h2{
  text-align:center;
  font-size:21px;
  margin:0 0 17px;
}
.benefit-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}
.benefit-card{
  min-height:155px;
  background:white;
  border:1px solid var(--line);
  border-radius:12px;
  box-shadow:var(--shadow);
  padding:31px 22px;
  display:grid;
  grid-template-columns:67px 1fr;
  gap:20px;
  align-items:center;
}
.benefit-card img{
  width:62px;
  height:62px;
  object-fit:contain;
}
.benefit-card h3{
  margin:0 0 8px;
  font-size:16px;
  line-height:1.16;
  font-weight:950;
}
.benefit-card p{
  margin:0;
  font-size:13px;
  line-height:1.3;
  color:#243858;
}

.how{
  padding:0 0 24px;
}
.how-panel{
  background:#f2fbff;
  border:1px solid #bfe0f3;
  border-radius:11px;
  padding:18px 20px 25px;
}
.how-panel h2{
  margin-bottom:18px;
}
.steps{
  display:grid;
  grid-template-columns:1fr 34px 1fr 34px 1fr;
  gap:13px;
  align-items:center;
}
.step{
  display:grid;
  grid-template-columns:44px 66px 1fr;
  gap:11px;
  align-items:center;
}
.number{
  width:39px;
  height:39px;
  border-radius:50%;
  color:#fff;
  background:linear-gradient(135deg,#079bf3,#0d54d3);
  display:grid;
  place-items:center;
  font-size:21px;
  font-weight:950;
}
.step img{
  width:64px;
  height:64px;
  object-fit:contain;
}
.step h3{
  margin:0 0 5px;
  font-size:14px;
  font-weight:950;
}
.step p{
  margin:0;
  font-size:12px;
  line-height:1.3;
  color:#1d3559;
}
.arrow{
  font-size:35px;
  color:#667da0;
  text-align:center;
}

.proof{
  padding:0 0 24px;
}
.proof-grid{
  display:grid;
  grid-template-columns:405px 1fr;
  gap:12px;
}
.testimonial,
.trust-strip{
  background:white;
  border:1px solid var(--line);
  border-radius:12px;
  box-shadow:var(--shadow);
}
.testimonial{
  min-height:133px;
  display:grid;
  grid-template-columns:113px 1fr;
  align-items:center;
  padding:16px 24px;
  gap:10px;
}
.testimonial img{
  width:88px;
  height:88px;
  border-radius:50%;
  object-fit:cover;
}
.stars{
  color:#ffb400;
  letter-spacing:3px;
  font-size:19px;
  line-height:1;
  margin-bottom:7px;
}
.testimonial p{
  margin:0 0 7px;
  color:#08214a;
  font-size:15px;
  line-height:1.25;
  font-weight:850;
}
.testimonial strong{
  font-size:13px;
  color:#1b4490;
}
.trust-strip{
  min-height:133px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  align-items:center;
  padding:21px 25px;
}
.trust-strip>div{
  display:grid;
  grid-template-columns:56px 1fr;
  gap:13px;
  align-items:center;
  border-right:1px solid #e3edf6;
  min-height:78px;
}
.trust-strip>div:last-child{border-right:0}
.trust-strip img{
  width:55px;
  height:55px;
  object-fit:contain;
}
.trust-strip h3{
  margin:0 0 2px;
  font-size:16px;
  line-height:1.05;
  font-weight:950;
}
.trust-strip p{
  margin:0;
  font-size:12px;
  line-height:1.25;
  color:#536279;
}

.final-cta{
  padding:0 0 27px;
}
.cta-banner{
  background:linear-gradient(90deg,#061f4a 0%,#072759 48%,#043a78 100%);
  border-radius:13px;
  min-height:160px;
  box-shadow:var(--shadow);
  display:grid;
  grid-template-columns:150px 1fr 200px 280px;
  align-items:center;
  gap:20px;
  padding:20px 27px;
  color:white;
}
.cta-banner>img{
  width:128px;
  height:128px;
  object-fit:contain;
}
.cta-main p{
  font-size:21px;
  font-weight:850;
  margin:0 0 3px;
}
.cta-main h2{
  margin:0;
  font-size:53px;
  line-height:.96;
  letter-spacing:-.04em;
}
.cta-main span{
  display:block;
  font-size:17px;
  margin-top:13px;
}
.cta-banner ul{
  margin:0;
  padding:0;
  list-style:none;
}
.cta-banner li{
  margin:12px 0;
  font-size:15px;
}
.cta-banner li::before{
  content:"✓";
  color:#79d92e;
  border:1px solid #79d92e;
  border-radius:50%;
  display:inline-grid;
  place-items:center;
  width:22px;
  height:22px;
  margin-right:10px;
  font-weight:950;
}
.cta-action a{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:14px;
  width:266px;
  height:58px;
  border-radius:10px;
  background:linear-gradient(180deg,#8bd123,#40b12a);
  color:white;
  font-size:18px;
  font-weight:950;
  box-shadow:0 10px 24px rgba(87,205,40,.29);
}
.cta-action small{
  display:block;
  text-align:center;
  color:rgba(255,255,255,.82);
  font-size:12px;
  margin-top:13px;
}

@media(max-width:1050px){
  .container{width:min(100% - 30px,1042px)}
  .topbar{height:auto;padding:8px 0}
  .topbar-inner{height:auto;flex-wrap:wrap}
  .top-location{margin-left:0}
  .site-header{height:auto}
  .header-inner{height:auto;min-height:78px;flex-wrap:wrap;padding:10px 0}
  .mobile-toggle{display:block}
  .nav{
    display:none;
    width:100%;
    order:5;
    flex-direction:column;
    align-items:stretch;
    gap:0;
  }
  .nav.open{display:flex}
  .nav a{padding:12px;border-top:1px solid #e3edf6}
  .header-cta{margin-left:auto}

  .hero{
    height:auto;
    min-height:765px;
  }
  .hero::before{
    background:linear-gradient(180deg,#fff 0%,rgba(255,255,255,.96) 48%,rgba(255,255,255,.2) 100%);
  }
  .hero-photo{
    width:100%;
    height:46%;
    top:auto;
    bottom:0;
    background-position:center bottom;
  }
  .hero-grid{
    grid-template-columns:1fr;
    padding:32px 0 295px;
  }
  .hero-copy{max-width:100%}
  .hero-sub,.hero-icons{width:100%}
  .lead-card{max-width:420px;margin:0 auto;width:100%}
  .benefit-grid,.proof-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr}
  .arrow{display:none}
  .cta-banner{grid-template-columns:130px 1fr;gap:16px}
  .cta-banner ul,.cta-action{grid-column:1/-1}
  .cta-action a{width:100%}
}
@media(max-width:650px){
  h1,h1 span{font-size:48px}
  .logo img{width:195px}
  .header-cta{width:100%;justify-content:center}
  .hero-icons,.benefit-grid,.proof-grid,.trust-strip{grid-template-columns:1fr}
  .trust-strip>div{border-right:0;border-bottom:1px solid #e3edf6;padding-bottom:13px}
  .trust-strip>div:last-child{border-bottom:0}
  .testimonial{grid-template-columns:1fr;text-align:center}
  .testimonial img{margin:0 auto}
  .benefit-card{grid-template-columns:62px 1fr}
  .step{grid-template-columns:44px 66px 1fr}
  .cta-banner{grid-template-columns:1fr;text-align:center}
  .cta-banner>img{margin:0 auto}
  .cta-main h2{font-size:42px}
}

/* ---- Lead form status + accessibility additions ---- */
.form-status{
  margin:12px 0 0;
  font-size:13.5px;
  font-weight:700;
  padding:11px 13px;
  border-radius:8px;
  text-align:center;
  display:none;
}
.form-status.sending{display:block;background:#eef4fb;color:#0655c5;border:1px solid #cfe2f7}
.form-status.ok{display:block;background:#e9f9ee;color:#1c7a32;border:1px solid #bce9c8}
.form-status.err{display:block;background:#fdecec;color:#b3261e;border:1px solid #f3c2c0}
.lead-card label:focus-within{border-color:#0a6de4;box-shadow:0 0 0 3px rgba(10,109,228,.12)}
:focus-visible{outline:3px solid #0a6de4;outline-offset:2px;border-radius:4px}
.skip-link{position:absolute;left:-999px;top:0;background:#fff;color:var(--navy);padding:10px 16px;z-index:200}
.skip-link:focus{left:0}
.header-call{
  display:inline-flex;align-items:center;gap:8px;margin-left:18px;
  color:#0655c5;font-weight:900;font-size:14px;white-space:nowrap;
}
@media(max-width:1050px){.header-call{margin-left:auto}}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}

/* ---- Date picker field ---- */
.date-field{position:relative}
.date-field input[type="date"]{
  color:#293a53;
  font-size:14px;
  -webkit-appearance:none;
  appearance:none;
}
/* Show a clear hint while empty (native date inputs have no placeholder) */
.date-field input[type="date"]:not(.has-value)::-webkit-datetime-edit{color:#9aa6b4}
.date-field input[type="date"].has-value::-webkit-datetime-edit{color:#293a53}
.date-field input[type="date"]::-webkit-calendar-picker-indicator{
  cursor:pointer;opacity:.65;margin-left:auto;
}
.date-hint{
  display:block;font-size:11px;font-weight:800;color:#7488a3;
  text-transform:uppercase;letter-spacing:.03em;margin:-2px 0 4px 2px;
}
/* Invalid-field cue after a failed submit attempt */
.lead-card label.invalid{border-color:#e0564d;box-shadow:0 0 0 3px rgba(224,86,77,.15)}
