/* BOMCAS Canada — Clean, fast, accessible, mobile-first */
:root{
  --c-navy:#0d2c54;--c-navy-2:#0a2247;--c-blue:#1a4d8f;--c-accent:#c8102e;
  --c-gray-900:#1b1f29;--c-gray-700:#3a4250;--c-gray-500:#6a7384;--c-gray-300:#cfd5df;
  --c-gray-100:#f3f5f9;--c-gray-50:#f8fafc;--c-white:#fff;--c-success:#0e7a4f;--c-err:#b00020;
  --radius:.5rem;--radius-lg:.85rem;
  --shadow-sm:0 1px 2px rgba(13,44,84,.06);--shadow:0 6px 22px rgba(13,44,84,.08);
  --t:.18s ease;--maxw:1200px;
  --font:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--c-gray-900);background:var(--c-white);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-blue);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-weight:700;line-height:1.25;color:var(--c-navy);margin:0 0 .75rem}
h1{font-size:clamp(1.85rem,4.2vw,2.7rem)}
h2{font-size:clamp(1.5rem,3vw,2.1rem)}
h3{font-size:1.25rem}
h4{font-size:1.05rem}
p{margin:0 0 1rem}
.container{max-width:var(--maxw);margin:0 auto;padding:0 1.25rem}
.skip-link{position:absolute;left:-9999px;top:0}
.skip-link:focus{position:static;background:var(--c-navy);color:#fff;padding:.5rem 1rem;display:inline-block}

/* Header */
.site-header{background:#fff;border-bottom:1px solid var(--c-gray-100);position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}
.topbar{background:var(--c-navy);color:#fff;font-size:.85rem}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:.45rem 1.25rem;gap:1rem}
.topbar-msg{opacity:.9}
.topbar-phone{color:#fff;display:inline-flex;align-items:center;gap:.4rem;font-weight:600}
.nav-inner{display:flex;align-items:center;gap:1.25rem;padding:.85rem 1.25rem}
.logo{display:flex;flex-direction:column;line-height:1}
.logo-mark{font-weight:900;font-size:1.45rem;color:var(--c-navy);letter-spacing:.04em}
.logo-sub{font-size:.7rem;color:var(--c-gray-500);letter-spacing:.18em;text-transform:uppercase;margin-top:2px}
.nav-toggle{display:none;flex-direction:column;gap:4px;background:none;border:0;cursor:pointer;padding:.5rem;margin-left:auto}
.nav-toggle span{display:block;width:26px;height:2px;background:var(--c-navy);transition:var(--t)}
.primary-nav{flex:1}
.nav-list{display:flex;gap:.25rem;list-style:none;margin:0;padding:0;justify-content:flex-end;flex-wrap:wrap}
.nav-item>a{padding:.65rem .9rem;display:inline-flex;align-items:center;gap:.3rem;color:var(--c-gray-900);font-weight:600;border-radius:var(--radius)}
.nav-item>a:hover{background:var(--c-gray-100);text-decoration:none}
.caret{font-size:.7em;color:var(--c-gray-500)}
.has-mega{position:relative}
.mega-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);min-width:min(1100px,96vw);background:#fff;border:1px solid var(--c-gray-100);box-shadow:var(--shadow);border-radius:var(--radius-lg);padding:1.5rem;opacity:0;visibility:hidden;transition:var(--t);pointer-events:none;z-index:60}
.has-mega:hover .mega-menu,.has-mega:focus-within .mega-menu{opacity:1;visibility:visible;pointer-events:auto}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.mega-col h4{font-size:.85rem;text-transform:uppercase;color:var(--c-blue);margin-bottom:.6rem;letter-spacing:.06em}
.mega-col ul{list-style:none;margin:0;padding:0}
.mega-col li{margin-bottom:.4rem}
.mega-col a{color:var(--c-gray-700);font-size:.95rem}
.mega-col a:hover{color:var(--c-navy)}
.mega-feature{background:var(--c-gray-50);padding:1rem;border-radius:var(--radius)}
.mega-feature .btn{display:block;margin-top:.5rem;text-align:center}

/* Buttons */
.btn{display:inline-block;padding:.7rem 1.2rem;border-radius:var(--radius);font-weight:600;text-decoration:none;cursor:pointer;transition:var(--t);border:0;font-size:.95rem;line-height:1.2}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--c-navy);color:#fff}
.btn-primary:hover{background:var(--c-navy-2);color:#fff}
.btn-accent{background:var(--c-accent);color:#fff}
.btn-ghost{background:transparent;color:var(--c-navy);border:1px solid var(--c-navy)}
.btn-ghost:hover{background:var(--c-navy);color:#fff}
.btn-outline-light{background:transparent;color:#fff;border:1px solid #fff}
.btn-outline-light:hover{background:#fff;color:var(--c-navy)}
.btn-lg{padding:.95rem 1.6rem;font-size:1rem}
.nav-cta{white-space:nowrap}

/* Breadcrumbs */
.breadcrumbs{background:var(--c-gray-50);border-bottom:1px solid var(--c-gray-100);font-size:.875rem}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;margin:0;padding:.75rem 0}
.breadcrumbs li:not(:last-child)::after{content:"›";color:var(--c-gray-500);margin-left:.5rem}
.breadcrumbs a{color:var(--c-gray-700)}

/* Hero */
.hero{position:relative;color:#fff;padding:5rem 0 6rem;background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-blue) 100%);overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:url('../images/hero.webp') center/cover;opacity:.18;z-index:0}
.hero-inner{position:relative;z-index:1;max-width:780px}
.hero h1{color:#fff;font-size:clamp(2rem,5vw,3.4rem);line-height:1.15}
.hero p.lead{font-size:1.15rem;opacity:.94;margin:1.25rem 0 2rem}
.hero-cta{display:flex;gap:.75rem;flex-wrap:wrap}
.hero .badges{display:flex;gap:1.5rem;margin-top:2.5rem;flex-wrap:wrap;color:#dbe3f0;font-size:.9rem}
.hero .badges span{display:inline-flex;align-items:center;gap:.4rem}

/* Sections */
section.section{padding:4.5rem 0}
section.section-alt{background:var(--c-gray-50)}
.section-head{text-align:center;max-width:760px;margin:0 auto 3rem}
.section-head .eyebrow{color:var(--c-blue);text-transform:uppercase;letter-spacing:.12em;font-size:.82rem;font-weight:700;margin-bottom:.5rem}

/* Cards */
.cards{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{background:#fff;border:1px solid var(--c-gray-100);border-radius:var(--radius-lg);padding:1.5rem;transition:var(--t);box-shadow:var(--shadow-sm)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--c-gray-300)}
.card .icon{width:42px;height:42px;background:var(--c-gray-50);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--c-navy);margin-bottom:1rem;font-size:1.3rem;font-weight:700}
.card h3{margin-bottom:.5rem}
.card p{color:var(--c-gray-700);margin-bottom:.85rem}
.card .more{color:var(--c-blue);font-weight:600;font-size:.92rem}

/* Two-column content layout */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.two-col img{border-radius:var(--radius-lg);box-shadow:var(--shadow)}
@media (max-width:840px){.two-col{grid-template-columns:1fr}}

/* Long-form content */
.prose{max-width:780px;margin:0 auto}
.prose h2{margin-top:2.5rem}
.prose h3{margin-top:1.75rem;color:var(--c-navy-2)}
.prose ul,.prose ol{padding-left:1.5rem;margin:0 0 1.25rem}
.prose ul li,.prose ol li{margin-bottom:.45rem}
.prose blockquote{border-left:4px solid var(--c-blue);padding:.25rem 0 .25rem 1rem;background:var(--c-gray-50);color:var(--c-gray-700);margin:1.5rem 0;font-style:italic}

/* FAQ */
.faq{max-width:840px;margin:0 auto}
.faq-item{border:1px solid var(--c-gray-100);border-radius:var(--radius);padding:1.1rem 1.25rem;margin-bottom:.75rem;background:#fff}
.faq-item summary{cursor:pointer;font-weight:600;color:var(--c-navy);list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";float:right;color:var(--c-blue);font-size:1.3rem;line-height:1}
.faq-item[open] summary::after{content:"−"}
.faq-item div{padding-top:.85rem;color:var(--c-gray-700)}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--c-navy) 0%,var(--c-blue) 100%);color:#fff;padding:3.5rem 0}
.cta-band h2{color:#fff;margin-bottom:.5rem}
.cta-band p{opacity:.9;margin-bottom:0}
.cta-band-inner{display:grid;grid-template-columns:2fr 1fr;gap:2rem;align-items:center}
.cta-actions{display:flex;flex-direction:column;gap:.6rem;align-items:flex-end}
@media (max-width:840px){.cta-band-inner{grid-template-columns:1fr}.cta-actions{align-items:stretch}}

/* Forms */
.bomcas-form{background:#fff;border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow);border:1px solid var(--c-gray-100)}
.form-title{margin-bottom:.5rem}
.form-intro{color:var(--c-gray-700);margin-bottom:1.5rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-row{display:flex;flex-direction:column}
.form-row-full{grid-column:1/-1}
.form-row label{font-weight:600;font-size:.92rem;margin-bottom:.35rem;color:var(--c-gray-900)}
.form-row .req{color:var(--c-accent)}
.form-row input,.form-row select,.form-row textarea{border:1px solid var(--c-gray-300);border-radius:var(--radius);padding:.7rem .85rem;font-size:1rem;font-family:inherit;background:#fff;transition:var(--t)}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:none;border-color:var(--c-blue);box-shadow:0 0 0 3px rgba(26,77,143,.15)}
.form-consent label{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem;color:var(--c-gray-700);font-weight:400}
.hp-field{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}
.form-status{margin-left:1rem;font-size:.92rem}
.form-status.success{color:var(--c-success)}
.form-status.error{color:var(--c-err)}
@media (max-width:640px){.form-grid{grid-template-columns:1fr}}

/* Trust band */
.trust-band{background:var(--c-gray-50);padding:2rem 0;border-bottom:1px solid var(--c-gray-100)}
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;text-align:center;color:var(--c-gray-700);font-weight:600;font-size:.92rem}
.trust-grid div{padding:.5rem}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;text-align:center;margin-top:2rem}
.stat{background:#fff;padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--c-gray-100)}
.stat .num{font-size:2rem;font-weight:800;color:var(--c-navy);display:block}
.stat .label{color:var(--c-gray-700);font-size:.9rem;margin-top:.2rem}

/* Pills / tag links */
.pills{display:flex;flex-wrap:wrap;gap:.45rem}
.pill{display:inline-block;background:var(--c-gray-100);color:var(--c-navy);padding:.35rem .8rem;border-radius:99px;font-size:.85rem;font-weight:600}
.pill:hover{background:var(--c-navy);color:#fff;text-decoration:none}

/* Footer */
.site-footer{background:var(--c-navy-2);color:#cfd9ec;padding:3.5rem 0 0;font-size:.92rem}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:.85rem}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin-bottom:.4rem}
.site-footer a{color:#cfd9ec}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:2rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .logo .logo-mark{color:#fff}
.footer-brand .logo .logo-sub{color:#9fb3d6}
.footer-brand p{color:#aabad6;margin:1rem 0}
.footer-brand address{font-style:normal;color:#cfd9ec;line-height:1.7;font-size:.9rem}
.footer-bottom{padding:1.25rem 0;color:#9fb3d6}
.footer-bottom-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
@media (max-width:980px){.footer-grid{grid-template-columns:1fr 1fr 1fr}}
@media (max-width:640px){.footer-grid{grid-template-columns:1fr 1fr}}

/* Location grids */
.locations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.5rem}
.locations-grid a{display:block;padding:.6rem .9rem;background:var(--c-gray-50);border-radius:var(--radius);color:var(--c-navy);font-weight:500;border:1px solid var(--c-gray-100)}
.locations-grid a:hover{background:var(--c-navy);color:#fff;text-decoration:none}

/* Mobile nav */
@media (max-width:960px){
  .nav-toggle{display:flex}
  .primary-nav{position:fixed;top:0;right:0;height:100vh;width:min(360px,90vw);background:#fff;flex-direction:column;padding:5rem 1.5rem 2rem;transform:translateX(100%);transition:var(--t);box-shadow:var(--shadow);overflow-y:auto;z-index:55}
  .primary-nav.open{transform:translateX(0)}
  .nav-list{flex-direction:column;align-items:stretch}
  .nav-item>a{padding:.85rem 0;border-bottom:1px solid var(--c-gray-100)}
  .has-mega .mega-menu{position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;min-width:0;box-shadow:none;border:0;padding:.5rem 0 1rem;display:none}
  .has-mega.open .mega-menu{display:block}
  .mega-grid{grid-template-columns:1fr;gap:1rem}
  .nav-cta{display:none}
  body.menu-open{overflow:hidden}
}
