
:root{
  --bg:#0b0f14;
  --panel:#10151b;
  --muted:#9aa4af;
  --text:#e7edf3;
  --accent:#3aa6ff;
  --accent-2:#66d18f;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Ubuntu,'Helvetica Neue',Arial,sans-serif;background:#fff;color:#0b0f14}
a{color:#0b67c2;text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1080px;margin-inline:auto;padding:clamp(12px,2vw,24px)}
.site-header{background:#0a1220;color:#fff;position:sticky;top:0;z-index:20;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.header-inner{display:flex;align-items:center;gap:16px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none;font-weight:700;font-size:1.1rem}
.logo{width:105px;height:50px;margin-right:20px;}
.nav-toggle{display:none;border:1px solid rgba(255,255,255,.25);background:transparent;color:#fff;padding:.4rem .6rem;border-radius:8px}
.nav ul,.nav-list{list-style:none;margin:0;padding:0;display:flex;gap:18px}
.nav a{color:#fff;opacity:.95}
.header-cta{margin-left:auto;display:flex;align-items:center;gap:16px}
.phone{background:#ffffff14;color:#fff;padding:.4rem .6rem;border-radius:8px}
.social a{color:#fff;opacity:.8}
.hero{background:linear-gradient(180deg,#0a1220, #122242);color:#fff;padding:0px 0}
.hero h1{font-size:clamp(1.8rem,3.4vw,2.8rem);margin:0 0 6px}
.hero p{opacity:.9;font-size:1.1rem;margin:.25rem 0 1rem}
.hero-points{display:grid;gap:8px;margin:0;padding-left:18px}
.about{padding:28px 0 8px}
.makes{padding-left:18px}
.brand-strip{padding:16px 0 8px}
.brand-logos{display:flex;gap:24px;align-items:center;opacity:.95}
.brand-logos img{height:40px;object-fit:contain;filter:grayscale(10%)}
.cta{display:flex;gap:12px;padding:28px 0 50px}
.button{display:inline-block;line-height:1;padding:.8rem 1rem;border-radius:10px;border:1px solid #0b67c2;background:#0b67c2;color:#fff;font-weight:600}
.button:hover{background:#084d91}
.button-secondary{background:#ffffff;border-color:#c6d3e3;color:#0b0f14}
.grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:24px}
.card{border:1px solid #e5ecf5;border-radius:14px;padding:18px;background:#fff;box-shadow:0 8px 24px rgba(16,21,27,.06)}
label{display:block;font-weight:600;margin:.5rem 0 .25rem}
input,textarea{width:100%;font:inherit;padding:.7rem;border-radius:10px;border:1px solid #ccd7e6;background:#fff}
.hp{display:none} /* honeypot */
.form-note{font-size:.9rem;color:#546173}
.muted{color:#6b7683;font-size:.95rem}
.site-footer{background:#0a1220;color:#c6d3e3}
.site-footer h4{color:#fff;margin:.2rem 0 .6rem}
.site-footer a{color:#d7e7ff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:26px}
.legal{border-top:1px solid #1b2b4a;opacity:.9;padding-top:12px}
@media (max-width:860px){
  .nav-list{display:none}
  .nav-toggle{display:inline-block}
  .header-cta{display:none}
  .grid-2,.footer-grid{grid-template-columns:1fr}
}

/* Fix contrast for secondary buttons on hover/focus */
.button.button-secondary:hover,
.button.button-secondary:focus-visible {
  background: #084d91;   /* same dark blue as .button:hover */
  color: #fff;           /* invert text to white for contrast */
  border-color: #084d91;
}

/* (optional) smooth transition */
.button, .button-secondary {
  transition: background-color .15s ease, color .15s ease, border-color .15s ease;
}


.responsive-wrapper {
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9 ratio */
  /* this defines the aspect-ratio box */
}

.responsive-wrapper img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  /* Apply these here 👇 */
  object-fit: contain;         /* or 'cover' if you prefer cropping */
  background-color: #fff;      /* optional letterbox background */
}

.about-split {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr; /* text | image */
  gap: 24px;
  align-items: start;
  margin-top: 18px;
}

.about-right .about-ph {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;     /* keeps a nice box even before a real image is set */
  object-fit: cover;
  border-radius: 12px;
  border: 1px solid #e5ecf5;
  display: block;
}

@media (max-width: 860px) {
  .about-split {
    grid-template-columns: 1fr;  /* stack on mobile */
  }
  .about-right {
    order: 2; /* optional: ensure image appears after text when stacked */
  }
}
