
:root{--header-h:136px;--lex-blue:#1F4B6E;--lex-deep:#153A59;--lex-slate:#334155;--lex-ink:#0B2239;--lex-sky:#F1F5F9;--lex-line:#E2E8F0;--acc:#16A34A;--radius:14px;--shadow:0 10px 30px rgba(15,23,42,.08)}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:var(--lex-ink);background:#fff;line-height:1.5}
a{color:var(--lex-blue);text-decoration:none} a:hover{text-decoration:underline}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--lex-line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:136px;gap:24px}
.brand{display:flex;align-items:center;gap:14px}
.brand img{width:129px;height:129px}
.brand .name{display:none}
nav ul{display:flex;gap:24px;list-style:none;margin:0;padding:0}
nav a{font-weight:600;color:var(--lex-slate)}
nav ul li a{display:flex;align-items:center;height:48px}
.cta{display:inline-flex;align-items:center;gap:8px;background:var(--lex-blue);color:#fff;padding:14px 22px;border-radius:999px;border:0;box-shadow:var(--shadow);font-weight:800;cursor:pointer;font-size:17px;line-height:1;min-height:48px}
.cta.secondary{background:#fff;color:var(--lex-blue);border:1px solid var(--lex-blue);line-height:1;min-height:48px}

/* HERO: real bright city photo with light scrim; dark text */
.hero{position:relative;padding:88px 0;background:url('assets/hero-chicago.jpg') center/cover no-repeat;color:var(--lex-ink)}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.78) 0%, rgba(255,255,255,.50) 40%, rgba(255,255,255,.24) 100%);}
.hero > .container{position:relative;z-index:1}
.hero h1{color:var(--lex-deep);text-shadow:0 1px 0 rgba(255,255,255,.45)}
.hero .lead{color:var(--lex-slate)}
.hero .badges .badge{background:rgba(255,255,255,0.92);border-color:rgba(15,23,42,0.06);color:var(--lex-slate)}
.hero .card{background:rgba(255,255,255,0.96);backdrop-filter:saturate(120%) blur(2px)}
.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center}

h1{font-size:48px;line-height:1.1;margin:0 0 16px;color:var(--lex-deep)}
.lead{font-size:20px;margin:0 0 24px}
.badges{display:flex;gap:16px;flex-wrap:wrap;margin:24px 0}
.badge{border:1px solid var(--lex-line);border-radius:999px;padding:8px 12px;font-weight:600;color:var(--lex-slate);background:#fff}
.card{background:#fff;border:1px solid var(--lex-line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.section{padding:56px 0}
.section h2{font-size:32px;margin:0 0 16px;color:var(--lex-deep)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:16px}
.kpi{background:var(--lex-sky);border:1px solid var(--lex-line);border-radius:12px;padding:16px;text-align:center}
.kpi b{font-size:28px;color:var(--lex-blue)}
.muted{color:#64748B}.small{font-size:14px}
footer{border-top:1px solid var(--lex-line);background:#fff;padding:32px 0;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px}
.logo-lockup{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.logo-lockup img{width:36px;height:36px}

/* Modal: below header; Close on right edge */
.modal-backdrop{position:fixed;inset:0;background:rgba(2,6,23,.6);display:none;align-items:flex-start;justify-content:center;padding:140px 10px 10px;z-index:1000}
.modal{max-width:900px;width:min(100%,900px);max-height:80vh;background:#fff;border-radius:14px;box-shadow:var(--shadow);overflow:hidden;position:relative}
.modal header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--lex-line);z-index:2}
.modal header .nav{height:auto;padding:6px 8px;justify-content:space-between}
.modal header .nav .brand{order:1}
.modal header .nav .cta.secondary{order:2;margin-left:auto}
.modal .body{display:grid;grid-template-columns:1fr 0.9fr;gap:0}
.form{padding:12px}
.form label{display:block;font-weight:700;margin:6px 0 4px;color:var(--lex-ink);font-size:13px}
.form input,.form select,.form textarea{width:100%;padding:8px 10px;border:1px solid var(--lex-line);border-radius:10px;background:#fff;font-size:14px}
.form textarea{min-height:56px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.form .actions{display:flex;gap:10px;align-items:center;margin-top:10px;flex-wrap:wrap}
.summary{background:var(--lex-sky);border-left:1px solid var(--lex-line);padding:12px}
.summary h3{margin:4px 0 8px;font-size:16px}
.summary .box{background:#fff;border:1px solid var(--lex-line);border-radius:10px;padding:10px;margin-bottom:8px}
.summary .price{font-size:28px;color:var(--lex-blue);font-weight:900}
.tag{display:inline-block;background:var(--lex-sky);border:1px solid var(--lex-line);padding:4px 8px;border-radius:999px;font-weight:600;font-size:12px;margin:4px 6px 0 0}
.note{background:#FEFCE8;border:1px solid #FDE68A;border-radius:10px;padding:8px;font-size:12px}
.modal .close-x{position:absolute;top:8px;right:8px;border:1px solid var(--lex-line);background:#fff;border-radius:999px;padding:4px 8px;cursor:pointer;font-weight:700}
#box-perword{display:none}
.menu-btn{display:none}

@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:2fr 2fr}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .modal-backdrop{padding-top:96px}
  .modal .body{grid-template-columns:1fr}
  .nav{height:84px}
  .brand img{width:56px;height:56px}
  nav ul{display:none}
  .menu-btn{display:inline-flex}
}

/* Larger gap between hero CTAs */
.hero .actions{display:flex;gap:32px;align-items:center;flex-wrap:wrap}

/* Ensure anchor navigation doesn't hide section titles behind the sticky header */
section[id]{scroll-margin-top:var(--header-h)}
@media (max-width:960px){
  :root{--header-h:84px}
}

/* Centered hero CTAs above KPIs with slightly reduced spacing */
.hero .actions{display:flex;justify-content:center;align-items:center;gap:20px;flex-wrap:wrap;margin:8px 0 6px}

/* Double-size primary hero CTA */
.hero .actions .main-cta{
  font-size:34px;
  padding:28px 44px;
  min-height:96px;
  border-radius:9999px;
}
@media (max-width:960px){
  .hero .actions .main-cta{
    font-size:22px;
    padding:18px 28px;
    min-height:64px;
  }
}

/* Revert main-cta to default button sizing */
.hero .actions .main-cta{
  font-size:17px;
  padding:14px 22px;
  min-height:48px;
  border-radius:999px;
}
@media (max-width:960px){
  .hero .actions .main-cta{
    font-size:17px;
    padding:14px 22px;
    min-height:48px;
  }
}

.alert{margin-top:8px;padding:8px 10px;border-radius:10px;font-size:14px}
.alert.success{background:#ECFDF5;border:1px solid #A7F3D0;color:#065F46}
.alert.error{background:#FEF2F2;border:1px solid #FECACA;color:#7F1D1D}

/* Ripple effect for Get a quote triggers */
.cta-quote{position:relative;overflow:hidden}
.cta-quote .ripple{position:absolute;border-radius:9999px;transform:scale(0);opacity:.55;pointer-events:none;animation:ripple .6s linear}
@keyframes ripple{to{transform:scale(4);opacity:0}}

/* Modal open/close animation */
.modal-backdrop{opacity:0;transition:opacity .25s ease}
.modal-backdrop.show{opacity:1}
.modal{transform:translateY(8px) scale(.98);opacity:0;transition:transform .28s cubic-bezier(.2,.8,.2,1), opacity .28s ease}
.modal-backdrop.show .modal{transform:translateY(0) scale(1);opacity:1}

/* Stronger, universal ripple for .cta-quote (buttons & links) */
.cta-quote{position:relative;overflow:hidden}
.cta-quote .ripple{position:absolute;border-radius:9999px;transform:scale(0);opacity:.35;pointer-events:none;animation:ripple .55s ease-out;mix-blend-mode:screen}
@keyframes ripple{to{transform:scale(4);opacity:0}}

/* Keep submit button width on click and show a spinner */
#submit-btn.is-loading{position:relative}
#submit-btn.is-loading::after{
  content:"";
  position:absolute;
  top:50%;
  right:14px;
  width:18px;height:18px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.6);
  border-top-color:#fff;
  transform:translateY(-50%);
  animation:lex-spin .8s linear infinite
}
@keyframes lex-spin{to{transform:translateY(-50%) rotate(360deg)}}
@media (max-width:960px){
  #submit-btn{min-width:min(100%, 260px)}
}
