/* Broadsheet masthead nav, shared across landing, inspections, reports
   browse, and every page that extends _base_page.html. The hamburger
   shows at <=768px; on desktop the inline nav-right is visible.

   Pages opt out of the CTA by passing `nav_cta=false` to the include. */

.site-nav {
  padding: 22px 0 18px;
  display: flex; justify-content: space-between; align-items: baseline;
  border-top: 2px solid #121111; border-bottom: 1px solid #1c1c1c;
  position: relative;
}
.site-nav::after {
  content: ""; position: absolute; left: 0; right: 0;
  top: 4px; height: 1px; background: #1c1c1c;
}

.site-nav .nav-logo {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 30px; font-weight: 900; letter-spacing: -1.2px;
  color: #121111; line-height: 1;
  text-decoration: none;
}

.site-nav .nav-right { display: flex; align-items: center; gap: 22px; }
.site-nav .nav-right a {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 1.6px; color: #3A3633;
  text-decoration: none;
}
.site-nav .nav-right a:hover { color: #121111; }

.site-nav .nav-cta {
  background: #121111; color: #fff !important;
  padding: 8px 16px; font-size: 11px; font-weight: 800;
  letter-spacing: 1.4px; border-radius: 2px;
}
.site-nav .nav-cta:hover { background: #234F60; }

/* ---- Hamburger toggle (hidden on desktop, shown <=768px) ---- */
.site-nav .nav-toggle {
  display: none;
  width: 40px; height: 40px; padding: 0;
  border: 1px solid #1c1c1c; background: transparent;
  cursor: pointer; position: relative; border-radius: 2px;
}
.site-nav .nav-toggle:hover { background: #121111; }
.site-nav .nav-toggle:hover .nav-toggle-bar { background: #fff; }
.site-nav .nav-toggle-bar {
  display: block; position: absolute;
  left: 9px; width: 20px; height: 2px; background: #121111;
  transition: transform .15s ease, opacity .15s ease, top .15s ease;
}
.site-nav .nav-toggle-bar:nth-child(1) { top: 12px; }
.site-nav .nav-toggle-bar:nth-child(2) { top: 19px; }
.site-nav .nav-toggle-bar:nth-child(3) { top: 26px; }
.site-nav .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(1) {
  top: 19px; transform: rotate(45deg);
}
.site-nav .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(2) { opacity: 0; }
.site-nav .nav-toggle[aria-expanded="true"] .nav-toggle-bar:nth-child(3) {
  top: 19px; transform: rotate(-45deg);
}

@media (max-width: 768px) {
  .site-nav { align-items: center; }
  .site-nav .nav-toggle { display: block; }
  .site-nav .nav-right {
    display: none;
    position: absolute; top: 100%; left: 0; right: 0;
    background: #F4EFE6; border-bottom: 2px solid #121111;
    padding: 4px 32px 16px;
    flex-direction: column; align-items: stretch; gap: 0;
    z-index: 100;
  }
  .site-nav .nav-right.open { display: flex; }
  .site-nav .nav-right a {
    padding: 14px 0; font-size: 13px;
    border-top: 1px solid #E5E1D6;
  }
  .site-nav .nav-right a:first-child { border-top: none; }
  .site-nav .nav-right .nav-cta {
    margin-top: 10px; padding: 14px;
    text-align: center; border-top: none;
  }
}

@media (max-width: 500px) {
  .site-nav .nav-right { padding-left: 16px; padding-right: 16px; }
}
