/* LIRR Business Solutions - simple responsive site (no frameworks) */
:root{
  --bg:#f7fbff;
  --surface:#ffffff;
  --surface-2:#eef6ff;
  --text:#10233e;
  --muted:#4b6485;
  --primary:#0f5ea8;
  --primary-2:#2aa7df;
  --accent:#dff4ff;
  --border:#d6e7f7;
  --success:#0f9d58;
  --shadow:0 14px 34px rgba(15,94,168,.12);
  --radius:16px;
}
*{box-sizing:border-box;}html{scroll-behavior:smooth;}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,"Helvetica Neue",Arial,"Noto Sans","Apple Color Emoji","Segoe UI Emoji";color:var(--text);background:var(--bg);line-height:1.55;}
a{color:inherit;text-decoration:none;}img{max-width:100%;display:block;}
.container{width:min(1120px,92vw);margin-inline:auto;}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden;}
.skip-link:focus{left:12px;top:12px;width:auto;height:auto;padding:10px 12px;background:#fff;border:1px solid var(--border);border-radius:10px;z-index:9999;}
header{position:sticky;top:0;z-index:50;background:rgba(247,251,255,.9);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border);}
.navbar{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:14px;}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.2px;}
.logo{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--primary-2),var(--primary));display:grid;place-items:center;box-shadow:0 10px 18px rgba(11,95,255,.18);color:#fff;}
.logo span{font-weight:900;}
.navlinks{display:flex;gap:18px;align-items:center;font-weight:600;}
.navlinks a{padding:10px 10px;border-radius:12px;color:var(--muted);}
.navlinks a:hover,.navlinks a[aria-current="page"]{background:var(--surface-2);color:var(--text);}
.nav-actions{display:flex;align-items:center;gap:10px;}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:12px;border:1px solid var(--border);background:#fff;font-weight:700;cursor:pointer;transition:transform .04s ease,background .15s ease,border-color .15s ease;gap:10px;white-space:nowrap;}
.btn:hover{background:var(--surface);} .btn:active{transform:translateY(1px);}
.btn.primary{background:var(--primary);color:#fff;border-color:transparent;} .btn.primary:hover{background:var(--primary-2);}
.btn.ghost{background:transparent;}
.burger{display:none;width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:#fff;place-items:center;}
.mobile-drawer{display:none;border-top:1px solid var(--border);background:#fff;}
.mobile-drawer .container{padding:10px 0 14px 0;display:grid;gap:8px;}
.mobile-drawer a{padding:12px 12px;border-radius:12px;color:var(--muted);font-weight:650;}
.mobile-drawer a:hover{background:var(--surface);color:var(--text);}
.hero{padding:64px 0 26px 0;background:radial-gradient(900px 420px at 20% 10%,rgba(42,167,223,.22),rgba(42,167,223,0)),radial-gradient(700px 360px at 80% 0%,rgba(15,94,168,.12),rgba(15,94,168,0));}
.hero-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:28px;align-items:center;}
.kicker{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;background:rgba(11,95,255,.10);border:1px solid rgba(11,95,255,.18);color:var(--primary-2);font-weight:800;letter-spacing:.2px;}
h1{margin:14px 0 10px 0;font-size:clamp(34px,4vw,52px);line-height:1.06;letter-spacing:-.8px;}
.lead{font-size:clamp(16px,1.5vw,18px);color:var(--muted);margin:0 0 18px 0;}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px;}
.badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;}
.badge{display:inline-flex;gap:8px;align-items:center;padding:8px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--muted);font-weight:700;}
.card{border:1px solid var(--border);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow);padding:18px;}
.hero-card{display:grid;gap:12px;} .hero-card h3{margin:0;font-size:18px;} .hero-card p{margin:0;color:var(--muted);}
.pill{display:flex;gap:10px;align-items:flex-start;padding:12px;border-radius:14px;background:var(--surface);border:1px solid var(--border);}
.pill strong{display:block;margin-bottom:2px;}
.section{padding:44px 0;} .section.alt{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.section h2{margin:0 0 10px 0;font-size:clamp(26px,2.2vw,34px);letter-spacing:-.3px;}
.section p.sub{margin:0 0 22px 0;color:var(--muted);max-width:75ch;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.list{display:grid;gap:10px;padding-left:0;margin:0;list-style:none;}
.list li{display:flex;gap:10px;align-items:flex-start;color:var(--muted);}
.tick{width:22px;height:22px;border-radius:8px;background:rgba(15,157,88,.12);display:grid;place-items:center;color:var(--success);flex:0 0 auto;border:1px solid rgba(15,157,88,.22);}
.icon{width:20px;height:20px;flex:0 0 auto;display:inline-grid;place-items:center;}
.cta{border-radius:18px;padding:22px;border:1px solid rgba(11,95,255,.22);background:linear-gradient(180deg,rgba(11,95,255,.10),rgba(11,95,255,.04));display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;}
.cta p{margin:0;color:var(--muted);} .cta strong{font-size:18px;}
footer{padding:34px 0;border-top:1px solid var(--border);background:#fff;}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:18px;}
.small{color:var(--muted);font-size:14px;}
.footer-links{display:grid;gap:8px;} .footer-links a{color:var(--muted);} .footer-links a:hover{color:var(--text);}
.page-hero{padding:46px 0 18px 0;background:radial-gradient(900px 420px at 20% 10%,rgba(42,167,223,.16),rgba(42,167,223,0));border-bottom:1px solid var(--border);}
.page-hero h1{font-size:clamp(30px,3.2vw,44px);}
.breadcrumbs{display:flex;flex-wrap:wrap;gap:8px;color:var(--muted);font-weight:650;}
.breadcrumbs a{color:var(--muted);text-decoration:underline;text-underline-offset:3px;}
.breadcrumbs a:hover{color:var(--text);}
form{display:grid;gap:12px;} .field{display:grid;gap:6px;} label{font-weight:750;}
input,select,textarea{border:1px solid var(--border);border-radius:12px;padding:12px 12px;font:inherit;outline:none;background:#fff;}
textarea{min-height:140px;resize:vertical;}
input:focus,select:focus,textarea:focus{border-color:rgba(11,95,255,.55);box-shadow:0 0 0 4px rgba(11,95,255,.12);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.notice{border:1px solid var(--border);background:var(--surface);border-radius:14px;padding:12px;color:var(--muted);font-size:14px;}
@media (max-width:920px){
  .hero-grid{grid-template-columns:1fr;}
  .grid-3{grid-template-columns:1fr;}
  .grid-2{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .navlinks{display:none;}
  .burger{display:grid;}
  .mobile-drawer.open{display:block;}
  .form-row{grid-template-columns:1fr;}
}


/* FieldAssets-inspired branding refinements */
:root{
  --bg:#f5f9ff;
  --surface:#ffffff;
  --surface-2:#eef6ff;
  --text:#15314f;
  --muted:#59708e;
  --primary:#1565c0;
  --primary-2:#2aa7df;
  --accent:#e6f3ff;
  --border:#d7e7f8;
  --success:#0f9d58;
  --shadow:0 16px 36px rgba(21,101,192,.10);
  --radius:16px;
}

body{
  background:linear-gradient(180deg,#f5f9ff 0%,#ffffff 100%);
  color:var(--text);
}

header{
  background:rgba(245,249,255,.94);
  border-bottom:1px solid var(--border);
}

.navbar{
  min-height:96px;
  gap:24px;
}

.brand{
  flex:0 0 auto;
  min-width:280px;
}

.brand > div:last-child{
  display:none;
}

.brand img.site-logo,
img.site-logo{
  display:block;
  width:auto;
  object-fit:contain;
}

.brand img.site-logo.header-logo{
  height:62px !important;
  max-width:190px;
}

.brand img.site-logo.footer-logo{
  height:54px !important;
  max-width:170px;
}

.navlinks{
  gap:20px;
  flex:1 1 auto;
  justify-content:center;
}

.navlinks a{
  color:var(--muted);
  padding:12px 14px;
  border-radius:14px;
  font-weight:700;
}

.navlinks a:hover,
.navlinks a[aria-current="page"]{
  background:var(--surface-2);
  color:var(--primary);
}

.nav-actions{
  flex:0 0 auto;
}

.burger{
  border-color:var(--border);
}

.hero{
  background:
    radial-gradient(900px 420px at 20% 10%, rgba(42,167,223,.18), rgba(42,167,223,0)),
    radial-gradient(700px 360px at 80% 0%, rgba(21,101,192,.10), rgba(21,101,192,0));
}

.page-hero{
  background:
    radial-gradient(900px 420px at 20% 10%, rgba(42,167,223,.14), rgba(42,167,223,0));
}

.kicker{
  background:rgba(42,167,223,.10);
  border:1px solid rgba(42,167,223,.22);
  color:var(--primary);
}

.card{
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}

.pill,
.notice{
  background:var(--surface-2);
  border-color:var(--border);
}

.btn{
  border-radius:14px;
  border-color:var(--border);
}

.btn.primary{
  background:linear-gradient(135deg,var(--primary-2),var(--primary));
  color:#fff;
}

.btn.primary:hover{
  filter:brightness(.98);
}

.cta{
  border:1px solid rgba(42,167,223,.26);
  background:linear-gradient(180deg,rgba(42,167,223,.12),rgba(21,101,192,.05));
}

footer{
  background:#ffffff;
  border-top:1px solid var(--border);
}

@media (max-width: 1100px){
  .brand{
    min-width:220px;
  }
  .brand img.site-logo.header-logo{
    height:54px !important;
    max-width:165px;
  }
}

@media (max-width: 920px){
  .navbar{
    min-height:auto;
  }
  .brand{
    min-width:auto;
  }
  .brand img.site-logo.header-logo{
    height:48px !important;
    max-width:150px;
  }
  .brand img.site-logo.footer-logo{
    height:46px !important;
    max-width:145px;
  }
}



/* Consistent logo fix across all pages */
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  flex:0 0 auto;
  min-width:auto !important;
  text-decoration:none;
}

.brand img.site-logo{
  display:block;
  width:auto;
  object-fit:contain;
}

.brand img.site-logo.header-logo{
  height:58px !important;
  max-width:180px;
}

.brand img.site-logo.footer-logo{
  height:52px !important;
  max-width:165px;
}

.navbar{
  align-items:center;
}

.footer-grid .brand{
  align-items:center;
}

@media (max-width: 920px){
  .brand img.site-logo.header-logo{
    height:46px !important;
    max-width:145px;
  }
  .brand img.site-logo.footer-logo{
    height:42px !important;
    max-width:135px;
  }
}


/* Final header/footer consistency fix */
header{
  background: rgba(245,249,255,.96) !important;
  border-bottom: 1px solid var(--border) !important;
}

.navbar{
  min-height: 108px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap: 28px !important;
}

.brand{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  flex: 0 0 170px !important;
  min-width: 170px !important;
  max-width: 170px !important;
  text-decoration:none !important;
}

.footer-brand{
  flex: 0 0 auto !important;
  min-width: auto !important;
  max-width: none !important;
}

.site-logo{
  display:block !important;
  width:auto !important;
  object-fit:contain !important;
}

.header-logo{
  height: 72px !important;
  max-width: 150px !important;
}

.footer-logo{
  height: 54px !important;
  max-width: 120px !important;
}

.navlinks{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap: 18px !important;
  flex: 1 1 auto !important;
}

.navlinks a{
  padding: 12px 18px !important;
  border-radius: 18px !important;
  color: var(--muted) !important;
  font-weight: 700 !important;
}

.nav-actions{
  display:flex !important;
  align-items:center !important;
  gap: 16px !important;
  flex: 0 0 auto !important;
}

.nav-actions .btn{
  min-height: 48px !important;
}

.footer-grid{
  align-items:start !important;
}

@media (max-width: 920px){
  .navbar{
    min-height: auto !important;
    gap: 16px !important;
  }
  .brand{
    flex: 0 0 auto !important;
    min-width: auto !important;
    max-width: none !important;
  }
  .header-logo{
    height: 52px !important;
    max-width: 120px !important;
  }
  .footer-logo{
    height: 44px !important;
    max-width: 100px !important;
  }
}


/* Header logo/text lockup to match provided reference */
.brand{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:14px !important;
  flex:0 0 340px !important;
  min-width:340px !important;
  max-width:340px !important;
  text-decoration:none !important;
}

.brand .header-logo{
  height:72px !important;
  width:auto !important;
  max-width:120px !important;
  object-fit:contain !important;
  display:block !important;
}

.brand-text{
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  line-height:1.02 !important;
  color:var(--text) !important;
}

.brand-line1{
  display:block !important;
  font-size:18px !important;
  font-weight:800 !important;
  letter-spacing:.2px !important;
  color:#4f6787 !important;
}

.brand-line2{
  display:block !important;
  font-size:22px !important;
  font-weight:900 !important;
  color:#183153 !important;
}

.footer-brand{
  gap:10px !important;
}

.footer-brand .footer-logo{
  height:54px !important;
  max-width:120px !important;
}

@media (max-width: 1200px){
  .brand{
    flex:0 0 300px !important;
    min-width:300px !important;
    max-width:300px !important;
  }
  .brand .header-logo{
    height:66px !important;
    max-width:108px !important;
  }
  .brand-line1{
    font-size:17px !important;
  }
  .brand-line2{
    font-size:20px !important;
  }
}

@media (max-width: 920px){
  .brand{
    flex:0 0 auto !important;
    min-width:auto !important;
    max-width:none !important;
    gap:10px !important;
  }
  .brand .header-logo{
    height:52px !important;
    max-width:88px !important;
  }
  .brand-line1{
    font-size:14px !important;
  }
  .brand-line2{
    font-size:17px !important;
  }
}
