/* Google Fonts (Outfit for headings/nav, Alexandria for body) */
@import url('https://fonts.googleapis.com/css2?family=Alexandria:wght@300;400;500;600&family=Outfit:wght@400;500;600;700;800&display=swap');

:root{
  /* Core palette: dark blue + cream */
  --navy:#0b2637;
  --navy2:#103246;
  --cream:#f3efe3;
  --cream2:#fbf8ef;

  /* Text */
  --text:#0b1f33;
  --muted:rgba(11,31,51,.72);

  /* Accent (subtle teal that works with your brand) */
  --accent:#2f6f7a;

  /* UI */
  --line:rgba(11,31,51,.14);
  --shadow:0 16px 44px rgba(11,31,51,.12);
  --shadow2:0 10px 26px rgba(11,31,51,.10);
  --max:1120px;
  --radius:18px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: "Alexandria", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:400;
  color:var(--text);
  background: linear-gradient(180deg, var(--cream2) 0%, var(--cream) 100%);
  line-height:1.75;
}
a{color:inherit}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 18px}

/* =========================
   HEADER (large responsive logo + nav)
   ========================= */
.site-header{
  background:var(--navy);
  color:#fff;
  padding: clamp(24px, 4vw, 64px) 0;
  text-align:center;
}

.headerWrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}

/* Large responsive logo with a gentle cap (smooth visual balance) */
.brand img{
  width:auto;
  height: clamp(180px, 20vw, 340px);
  max-height: 360px;
  max-width: min(1100px, 92vw);
  display:block;
  margin: 0 auto;
}

/* Nav row beneath logo */
.navRow{
  margin-top: clamp(16px, 3vw, 32px);
  display:flex;
  justify-content:center;
  gap: clamp(16px, 4vw, 40px);
  flex-wrap:wrap;
}

.navLink,
.drop summary{
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:600;
  letter-spacing:.2px;
  color:rgba(255,255,255,.88);
  text-decoration:none;
  padding:6px 4px;
  border-bottom:2px solid transparent;
}
.navLink:hover,
.drop summary:hover{color:#fff}
.navLink.active{color:#fff;border-bottom-color:rgba(255,255,255,.65)}

/* Dropdown */
.drop{position:relative;display:inline-block}
.drop summary{list-style:none;cursor:pointer}
.drop summary::-webkit-details-marker{display:none}
.dropMenu{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  top:34px;
  min-width:240px;
  background:#fff;
  color:var(--text);
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:8px;
  z-index:50;
}
.dropMenu a{
  display:block;
  padding:10px 10px;
  text-decoration:none;
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:600;
  color:var(--text);
  border-radius:10px;
}
.dropMenu a:hover{background:rgba(11,31,51,.06)}
@media (max-width:520px){
  .dropMenu{left:0;transform:none}
}

/* =========================
   HERO (video + consistent CTA styling)
   ========================= */
.hero{
  position:relative;
  min-height: 470px;
  display:flex;
  align-items:center;
  color:#fff;
  overflow:hidden;
}
.heroMedia{position:absolute;inset:0;z-index:0}
.heroMedia video, .heroMedia img{width:100%;height:100%;object-fit:cover}
.heroOverlay{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(1200px 600px at 50% 30%, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 55%, rgba(0,0,0,.62) 100%),
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.55) 45%, rgba(0,0,0,.45) 100%);
}
.heroInner{position:relative;z-index:2;padding:62px 0;text-align:center}
.hero h1{
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:800;
  margin:0 0 12px;
  font-size:46px;
  line-height:1.12;
  letter-spacing:-0.02em;
}
.hero p{
  margin:0 auto 18px;
  max-width: 860px;
  color: rgba(255,255,255,.88);
  font-size:16px;
}

/* =========================
   BUTTON SYSTEM (no mismatched text)
   ========================= */
.btnRow{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:10px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 18px;border-radius:999px;
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:700;
  letter-spacing:.2px;
  text-decoration:none;
  border:1px solid transparent;
  box-shadow:0 10px 22px rgba(0,0,0,.16);
}

/* Primary: dark blue button with cream text (works everywhere) */
.btn.primary{
  background:var(--btn, #264d63);
  background:var(--navy2);
  color:var(--cream2);
  border-color:rgba(255,255,255,.18);
}
.btn.primary:hover{filter:brightness(.95)}

/* Secondary: outline on light backgrounds */
.btn.secondary{
  background:transparent;
  color:var(--navy);
  border-color:rgba(11,31,51,.28);
  box-shadow:none;
}
.btn.secondary:hover{background:rgba(11,31,51,.06)}

/* Hero secondary: outline but white text */
.hero .btn.secondary{
  color:#fff;
  border-color:rgba(255,255,255,.48);
  background:transparent;
}
.hero .btn.secondary:hover{background:rgba(255,255,255,.10)}

/* =========================
   SECTIONS / TYPOGRAPHY
   ========================= */
.section{padding:56px 0}
.sectionAlt{background: linear-gradient(180deg, rgba(11,38,55,.07) 0%, rgba(11,38,55,.09) 100%)}

.h2, h2{
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:800;
  font-size:34px;
  line-height:1.12;
  letter-spacing:-0.02em;
  margin:0 0 14px;
}

.lead{margin:0 0 18px;color:var(--muted);max-width:920px}

.twoCol{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:18px;
  align-items:start;
}
@media (max-width:900px){
  .twoCol{grid-template-columns:1fr}
  .hero h1{font-size:36px}
}

/* Cards + grids */
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
@media (max-width:900px){.grid{grid-template-columns:1fr}}

.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow2);
  padding:18px;
}
.card h3{
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:800;
  margin:0 0 8px;
  font-size:18px;
  letter-spacing:-0.01em;
}
.card p{margin:0;color:var(--muted)}
.card a{
  display:inline-block;margin-top:10px;
  color:var(--navy);
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:700;
  text-decoration:none
}
.card a:hover{text-decoration:underline}

/* Image card: make photos look intentional */
.imgCard{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
}
.imgCard img{
  width:100%;
  height:100%;
  object-fit:cover;
  aspect-ratio:4/3;
  object-position:center;
  filter:saturate(1.05) contrast(1.02);
}

/* QUOTE PAGE: portrait-ish crop option */
.imgCard.portrait img{
  aspect-ratio:3/4; /* looks better beside forms */
  object-position:50% 35%;
}

/* Form */
.form{display:grid;gap:12px;margin-top:10px}
.inline{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media (max-width:900px){.inline{grid-template-columns:1fr}}

.field{display:grid;gap:6px}
label{
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:700;
}
input, textarea, select{
  width:100%;
  padding:12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#fff;
  outline:none;
  font-family:"Alexandria", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}
input:focus, textarea:focus, select:focus{
  border-color: rgba(47,111,122,.55);
  box-shadow: 0 0 0 4px rgba(47,111,122,.14);
}
textarea{min-height:140px;resize:vertical}
small{color:var(--muted)}

/* Footer */
footer{
  background:var(--navy);
  color:rgba(255,255,255,.86);
  border-top:1px solid rgba(255,255,255,.10);
  padding:26px 0;
}
.footerRow{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.footerBrand{display:flex;align-items:center;gap:12px}
.footerMark{height:34px;width:auto;display:block;opacity:.95}
.footerCopy{white-space:nowrap}
.footerRow a{color:rgba(255,255,255,.86);text-decoration:none}
.footerRow a:hover{text-decoration:underline}


/* =========================
   Ops-focused additions
   ========================= */
.muted{color:var(--muted)}
.kpiRow{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-top:16px;
}
@media (max-width:900px){.kpiRow{grid-template-columns:1fr}}
.kpi{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  border-radius:16px;
  padding:12px 14px;
  backdrop-filter: blur(10px);
}
.kpi strong{
  display:block;
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:800;
  letter-spacing:-0.01em;
}
.kpi span{display:block;opacity:.92;font-size:14px;line-height:1.4;margin-top:4px}

.bullets{margin:10px 0 0;padding-left:18px}
.bullets li{margin:6px 0;color:var(--muted)}
.steps{list-style:none;margin:10px 0 0;padding:0;display:grid;gap:10px}
.steps li{display:grid;grid-template-columns:34px 1fr;gap:10px;align-items:start}
.steps span{
  width:34px;height:34px;border-radius:12px;
  background:rgba(47,111,122,.14);
  border:1px solid rgba(47,111,122,.22);
  display:flex;align-items:center;justify-content:center;
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  font-weight:800;color:var(--navy);
}
.matrixWrap{overflow:auto;border-radius:14px;border:1px solid var(--line)}
.matrix{width:100%;border-collapse:collapse;background:#fff}
.matrix th,.matrix td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left}
.matrix th{font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;font-weight:800;background:rgba(11,31,51,.04)}
.matrix td:last-child{text-align:center;font-weight:800}
