:root{
  --primary: #0598e8;
  --accent: #19c2ff;
  --dark: #012d74;
  --text: #1f2a44;
  --muted: #5b6b88;
  --bg: #ffffff;
  --card: #ffffff;
  --border: #e7eef7;
}*{
  box-sizing: border-box;
}html{
  scroll-behavior: smooth;
}body{
  margin: 0;
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color: var(--text);
  background: var(--bg);
}.container{
  width: min(1120px,94%);
  margin: 0 auto;
}a{
  color: var(--primary);
  text-decoration: none;
}header{
  position: sticky;
  top: 0;
  background: rgba(255,255,255,.95);
  backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid var(--border);
  z-index: 50;
}.nav{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
}.brand{
  display: flex;
  align-items: center;
  gap: 12px;
}.logo{
  height: auto;
  width: auto;
  max-height: 60px;
  object-fit: contain;
}.links a{
  margin: 0 10px;
  font-weight: 600;
}.cta{
  padding: 10px 14px;
  border-radius: 12px;
  background: var(--primary);
  color: #fff;
  font-weight: 700;
}.menu-toggle{
  display: none;
  border: 1px solid var(--border);
  padding: 8px 10px;
  border-radius: 10px;
  background: #fff;
}@media (max-width:880px){
  .links{display: none;
}.menu-toggle{
  display: block;
}}#hero{
  background: #3CA5B0;
  color: #fff;
  position: relative;
}#hero::after{
  content: '';
  position: absolute;
  inset: 0;
  background: none !important;
}.hero-inner{
  position: relative;
  z-index: 1;
  padding: 100px 0;
}h1{
  font-size: clamp(28px,4vw,48px);
  margin: 0 0 10px;
}.lead{
  font-size: clamp(16px,2.2vw,20px);
  opacity: .95;
  max-width: 62ch;
}.buttons{
  display: flex;
  gap: 12px;
  margin-top: 18px;
  flex-wrap: wrap;
}.btn{
  display: inline-block;
  padding: 12px 18px;
  border-radius: 12px;
  font-weight: 800;
}.btn.primary{
  background: var(--primary);
  color: #fff;
}.btn.ghost{
  border: 2px solid #fff;
  color: #fff;
}.section{
  padding: 64px 0;
}.section h2{
  font-size: clamp(24px,3vw,36px);
  margin: 0 0 18px;
}.grid{
  display: grid;
  grid-template-columns: repeat(12,1fr);
  gap: 24px;
}.card{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 18px;
  box-shadow: 0 6px 28px rgba(18,34,66,.06);
}.card img{
  width: 100%;
  border-radius: 12px;
}.features .card{
  grid-column: span 6;
}@media (max-width:720px){
  .features .card{grid-column: span 12;
}}blockquote{
  border-left: 4px solid var(--primary);
  padding-left: 12px;
  color: #334;
  background: #f7fbff;
  border-radius: 8px;
}footer{
  background: #0b172a;
  color: #c9d6e8;
  padding: 28px 0;
}footer a{
  color: #fff;
}ul.clean{
  list-style: none;
  padding-left: 0;
}.small{
  font-size: 14px;
  opacity: .85;
}form input,form textarea,form select{
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #ccd9ea;
  border-radius: 10px;
  outline: none;
}form button{
  margin-top: 10px;
}.badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: #e8f3ff;
  border: 1px solid #cfe6ff;
  border-radius: 12px;
  font-weight: 700;
  color: var(--dark);
}.notice{
  background: #fffaf0;
  border: 1px solid #ffe1a6;
  border-radius: 12px;
  padding: 12px;
}/* === Footer visibility enhancements === */
footer{
  background: #0b172a;
  color: #fff;
  padding: 28px 0;
}footer .card{
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.12);
}footer a{
  color: #fff;
  text-decoration: underline;
}footer .big{
  font-size: clamp(18px,2.6vw,22px);
  font-weight: 800;
}footer .mono{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}/* Mobile nav improvements */
.hamburger{
  display: none;
  border: 1px solid var(--border);
  padding: 10px 12px;
  border-radius: 10px;
  background: #fff;
}@media (max-width:880px){
  .hamburger{display: block;
}.links{
  display: none;
}.mobile-menu{
  position: fixed;
  inset: 0;
  background: #fff;
  z-index: 999;
  padding: 20px;
  display: none;
  overflow-y: auto;
}.mobile-menu.open{
  display: block;
}.mobile-menu a{
  display: block;
  padding: 16px 0;
  border-bottom: 1px solid #eef3fb;
  font-weight: 800;
  font-size: 18px;
}.mobile-menu .close{
  display: block;
  margin-bottom: 10px;
  font-weight: 800;
}
}/* === Sticky call-to-action banner (mobile only) === */
@media (max-width:768px){
  .cta-banner{position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  display: flex;
  justify-content: space-around;
  gap: 2px;
  background: var(--primary);
  color: #fff;
}.cta-banner a{
  flex: 1;
  text-align: center;
  padding: 14px 0;
  color: #fff;
  font-weight: 800;
  font-size: 16px;
  text-decoration: none;
}body{
  padding-bottom: 56px;
} /* reserve space so footer not hidden */
}/* === Mobile & overlap fixes (v3) === */
header{
  z-index: 1000;
}@media (max-width:880px){
  .links{display: none !important;
}.nav .cta{
  display: none !important;
}/* top CTA hidden on mobile to avoid overlap with hero */
  .hamburger{
  display: block;
}
}#hero{
  position: relative;
  overflow: hidden;
}.hero-inner{
  padding-top: clamp(64px,12vw,110px);
  padding-bottom: clamp(72px,14vw,128px);
}/* Ensure next section starts below buttons on small screens */
.section:first-of-type{
  margin-top: 0;
}.section{
  scroll-margin-top: 72px;
}/* Mobile overlay menu styling & stacking */
.mobile-menu{
  position: fixed;
  inset: 0;
  background: #fff;
  z-index: 1100;
  padding: 20px;
  display: none;
  overflow-y: auto;
}.mobile-menu.open{
  display: block;
}.mobile-menu a{
  display: block;
  padding: 16px 0;
  border-bottom: 1px solid #eef3fb;
  font-weight: 800;
  font-size: 18px;
  color: #0b1b33;
  text-decoration: none;
}.mobile-menu .close{
  display: block;
  margin-bottom: 8px;
  font-weight: 800;
  font-size: 20px;
}/* === Logo enlargement === */
.logo{
  height: 64px !important;
  width: auto !important;
}@media (max-width:600px){
  .logo{height: 54px !important;
}
}/* Hero logo */
#hero img[alt*="Logo"]{
  height: 96px !important;
  padding: 8px;
  border-radius: 14px;
}/* About page logo */
.card img[alt*="Logo"]{
  max-width: 80% !important;
}/* === Menu & animation fixes === */
/* Strongly hide desktop links on small screens */
@media (max-width: 940px){
  header .links, .links-desktop{display: none !important;
}.nav .cta{
  display: none !important;
}.hamburger{
  display: inline-block;
}
}/* Overlay menu full-screen and above everything */
.mobile-menu{
  position: fixed;
  inset: 0;
  background: #fff;
  z-index: 2000;
  padding: 20px;
  display: none;
  overflow-y: auto;
}.mobile-menu.open{
  display: block;
}.mobile-menu a{
  display: block;
  padding: 16px 0;
  border-bottom: 1px solid #eef3fb;
  font-weight: 800;
  font-size: 18px;
  color: #0b1b33;
  text-decoration: none;
}.mobile-menu .close{
  display: block;
  margin-bottom: 8px;
  font-weight: 800;
  font-size: 20px;
}/* Subtle logo animation */
@keyframes softPop{
  from { transform: scale(.98);
  opacity: 0;
}to{
  transform: scale(1);
  opacity: 1;
} }.logo, #hero img[alt*="Logo"]{
  animation: softPop .6s ease-out both;
  transform-origin: left center;
}@media (hover:hover){
  .logo: hover, #hero img[alt*="Logo"]:hover{ transform:scale(1.03);
}
}@media (prefers-reduced-motion: reduce){
  .logo, #hero img[alt*="logo"]{ animation: none !important;
}
}/* When menu is open, hide bottom CTA banner to avoid double bars */
.menu-open .cta-banner{
  display: none !important;
}/* Fix logo proportion */
header .logo img{
  width: auto !important;
  height: auto !important;
  max-height: 60px;
  object-fit: contain;
}/* --- V9: Fix hero logo proportions (no stretching) --- */
.hero img.logo, .hero .hero-inner img.logo{
  width: auto !important;
  height: auto !important;
  max-width: 90%;
  max-height: 140px;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}/* V10: Mobile menu behaviour */
.hamburger{
  display: none;
  border: 0;
  background: transparent;
  font-size: 28px;
  line-height: 1;
  padding: 8px;
  cursor: pointer;
}nav.open .hamburger{
  position: relative;
  z-index: 1001;
}@media (min-width:901px){
  .hamburger{display: none;
}nav .links{
  display: flex;
  gap: .8rem;
  align-items: center;
}
}@media (max-width:900px){
  .hamburger{display: inline-block;
}nav .links{
  display: none;
}nav.open .links{
  display: block;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #fff;
  border-bottom: 1px solid #e6eaf0;
  padding: 12px 16px;
}nav .links a{
  display: block;
  padding: 10px 6px;
}
}/* V10: Hero logo safeguard */
.hero img.logo{
  width: auto!important;
  height: auto!important;
  max-width: 90%;
  max-height: 140px;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}@media (max-width:600px){
  .hero img.logo{max-height: 110px;
}}/* LOGAN EAU hero logo size override */
#hero .hero-inner img.logo{
  max-height: 350px!important;
  width: auto!important;
  height: auto!important;
}
