/* Base */
:root{
  --font-primary: "p22-underground", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-pc: "p22-underground-pc", var(--font-primary);
  --font-sc: "p22-underground-sc", var(--font-primary);
  --bg:#ffffff;
  --panel:#f8f9fb;
  --ink:#111111;
  --muted:#555d66;
  --brand:#f0b429; /* warm gold accent */
  --link:#003366;
  --max:1140px;
  --radius:16px;
  --gap:clamp(16px,2.5vw,28px);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: var(--font-primary);
  color:var(--ink);
  background:#ffffff;
  line-height:1.6;
}

/* Utilities */
.container{width:100%;max-width:var(--max);margin-inline:auto;padding:0 var(--gap)}
.flow>*+*{margin-top:clamp(8px,1.2vw,14px)}
.section-title{
  font-size:clamp(1.4rem,2.2vw,1.8rem);
  margin:0 0 0.75rem;
  font-family: var(--font-primary);
}
.lead{font-size:clamp(1.05rem,2vw,1.25rem);color:var(--muted)}
.eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:.85rem}

/* Buttons & links */
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}
.btn{
  display:inline-block;padding:0.7rem 1rem;border-radius:999px;border:1px solid transparent;
  text-decoration:none;font-weight:600
}
.btn-primary{background:var(--brand);color:#111;box-shadow:0 6px 24px rgba(240,180,41,.25)}
.btn-ghost{border-color:#d0d7e2;color:#003366;background:transparent}

/* Editorial outline button */
.btn-outline{
  display:inline-block;
  padding:.65rem 1rem;
  border:1px solid #cbd5e1;
  border-radius:6px;
  background:transparent;
  color:#2b3440;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
  text-decoration:none;
  box-shadow:none;
}
.btn-outline:hover{
  background:#f5f7fa;
  border-color:#2b3440;
  text-decoration:none;
}
.btn-outline:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(0,51,102,.15);
}

/* Accessible focus states */
a:focus-visible,
.btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(0,51,102,.25);
  border-radius:6px;
}

.text-link{font-weight:600}

/* Header */
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:8px;top:8px;width:auto;height:auto;padding:.5rem 1rem;background:#fff;color:#000;border-radius:8px;z-index:999}

.site-header{position:sticky;top:0;z-index:50;background:#003366;backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.08)}
/* Light header (corporate look) */
.site-header.light{
  background:rgba(255,255,255,.82);
  -webkit-backdrop-filter:saturate(180%) blur(10px);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid rgba(0,0,0,.06);
}
.site-header.light .logo{
  color:#111111;
  font-family: var(--font-primary);
}
.site-header.light .nav-list a,
.site-header.light .nav-parent{
  color:#2b3440;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:1rem;
  font-family: var(--font-sc);
}
.site-header.light .nav-list a:hover,
.site-header.light .nav-parent:hover{
  color:#003366;
  text-decoration:none;
}
.site-header.light .nav-list a[href="/contact"]{
  border:1px solid #cbd5e1;
  border-radius:6px;
  padding:.4rem .75rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.site-header.light .nav-list a[href="/contact"]:hover{
  background:#f5f7fa;
  border-color:#2b3440;
  text-decoration:none;
}
.site-header.light .nav-toggle{
  border-color:#d0d7e2;
  color:#2b3440;
}
.site-header.light .subnav{
  background:#ffffff;
  border:1px solid #e0e4ea;
  box-shadow:0 12px 32px rgba(0,0,0,.08);
}
.site-header.light .subnav a:hover{
  background:#f5f7fa;
}
.site-header.light .nav-list a.active{
  position:relative;
  color:#2b3440;
}
.site-header.light .nav-list a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:#2b3440;border-radius:2px;
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:flex-start; /* logo sits left, nav follows */
  min-height:56px;
  gap:24px;
  padding-inline:0; /* remove container padding so logo hits viewport edge */
}
.site-header.light .nav{
  flex:1;
  display:flex;
  justify-content:flex-start;
  align-items:center;
  gap:28px;
  margin-left:clamp(12px,2vw,24px);
}
.site-header.light .nav-list{align-items:center}
.logo{
  font-weight:800;
  letter-spacing:.2px;
  color:#ffffff;
  font-size:1.15rem;
  font-family: var(--font-primary);
}
.site-header .logo img{
  display:block;
  height:64px;
  width:auto;
}
.logo span{color:var(--brand)}

.nav-toggle{
  display:none;              /* shown on mobile in media query */
  position:relative;
  background:transparent;
  border:2px solid currentColor;
  color:#2b3440;             /* default for light header */
  border-radius:12px;
  width:48px;
  height:48px;
  padding:0;
  line-height:0;
  cursor:pointer;
  transition:border-color .2s ease, color .2s ease;
}
/* Hamburger icon (three bars) */
.nav-toggle::before{
  content:"";
  position:absolute; left:50%; top:50%;
  width:22px; height:2px; background:currentColor;
  transform:translate(-50%,-50%);
  box-shadow:0 -6px 0 currentColor, 0 6px 0 currentColor;
  border-radius:2px;
  transition: transform .25s ease, box-shadow .2s ease, opacity .2s ease;
}
.nav-toggle::after{
  content:"";
  position:absolute; left:50%; top:50%;
  width:22px; height:2px; background:currentColor;
  transform:translate(-50%,-50%) rotate(0deg);
  opacity:0; /* hidden until open */
  border-radius:2px;
  transition: transform .25s ease, opacity .2s ease;
}
.nav-toggle[aria-expanded="true"]::before{
  transform:translate(-50%,-50%) rotate(45deg);
  box-shadow:none; /* hide top/bottom clones */
}
.nav-toggle[aria-expanded="true"]::after{
  opacity:1;
  transform:translate(-50%,-50%) rotate(-45deg);
}
/* Dark header variant */
.site-header:not(.light) .nav-toggle{
  color:#ffffff;
  border-color:rgba(255,255,255,.9);
}
.site-header.light .nav-toggle{
  color:#2b3440;
  border-color:#2b3440;
}
.nav-list{display:flex;gap:28px;align-items:center;list-style:none;margin:0;padding:0}
.nav-list a{color:#ffffff}
.nav-list .btn{margin-left:8px}

.has-children{position:relative}
.nav-parent{
  background:none;border:none;color:#ffffff;cursor:pointer;font:inherit;display:flex;align-items:center;gap:6px
}
.subnav{
  position:absolute;inset:auto auto auto 0;top:100%;
  display:none;min-width:220px;padding:10px;border-radius:12px;background:var(--panel);
  border:1px solid #e0e4ea;box-shadow:0 12px 32px rgba(0,0,0,.35)
}
.subnav.open{display:block}
.subnav li{list-style:none}
.subnav a{display:block;padding:8px 10px;border-radius:8px}
.subnav a:hover{background:#f1f4f8;text-decoration:none}
.nav-list a.active{color:var(--brand);font-weight:700}

/* Hero */
.hero{
  padding:clamp(48px,8vw,96px) 0;background:
  radial-gradient(1200px 400px at 10% -10%, rgba(240,180,41,.15), transparent 60%),
  radial-gradient(900px 300px at 90% 0%, rgba(111,168,255,.12), transparent 60%)
}
.hero h1{
  font-size:clamp(1.8rem,3.6vw,2.6rem);
  line-height:1.2;
  margin:.25rem 0 .75rem;
  font-weight:500;
  letter-spacing:-0.5px;
}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}

/* Hero below style */
.hero--below{
  padding:clamp(24px,5vw,56px) 0;
  background:none;
  border-top:1px solid #e0e4ea;
}
.hero--below .hero-inner{max-width:var(--max)}
.hero--below .btn-outline{margin-top:.25rem}

/* Trust */
.trust{padding:24px 0;border-top:1px solid #e0e4ea;border-bottom:1px solid #e0e4ea;background:#ffffff}
.logo-row{display:flex;gap:clamp(16px,2vw,28px);flex-wrap:wrap;align-items:center;margin:8px 0 0;padding:0;list-style:none}
.logo-row li{opacity:.85}

/* Cards */
.cards{padding:clamp(36px,6vw,72px) 0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.card{
  background:#ffffff;border:1px solid #e0e4ea;border-radius:var(--radius);
  padding:clamp(16px,2vw,22px);box-shadow:0 6px 20px rgba(0,0,0,.08)
}
.card h3{
  margin:0 0 .35rem;
  font-size:1.05rem;
  font-family: var(--font-primary);
}

/* Testimonial */
.testimonial{padding:clamp(36px,6vw,64px) 0}
blockquote{
  margin:0;background:#f8f9fb;
  border:1px solid #e0e4ea;border-radius:var(--radius);padding:clamp(16px,2vw,22px)
}
blockquote p{font-size:1.05rem}
blockquote footer{color:var(--muted);margin-top:.5rem}

/* Content sections */
.content{padding:clamp(32px,5vw,56px) 0}
.content.alt{background:#f8f9fb;border-block:1px solid #e0e4ea}
.checklist, .bullets{padding-left:1.2rem}
.checklist li{margin:.35rem 0}
.note{
  margin-top:12px;padding:12px;border:1px dashed #cbd5e1;
  border-radius:12px;background:#f9fafb;color:var(--muted)
}

/* CTA band */
.cta-band{padding:clamp(36px,6vw,72px) 0;background:linear-gradient(180deg, rgba(240,180,41,.08), transparent 60%)}
.cta-inner{text-align:center}
.cta-inner h2{margin:0 0 .4rem}
.micro{color:var(--muted);font-size:.9rem;margin-top:.5rem}

/* Footer */
.site-footer{
  border-top:1px solid rgba(255,255,255,.06);
  margin-top:24px;
  background:#003366;
  color:#ffffff; /* ensure dark footer text is readable */
}
.site-footer.light{
  background:var(--panel);
  border-top:1px solid #d0d7e2;
  color:#2b3440; /* set default text colour for light footer */
}
.site-footer.light a{ color:var(--link); }
.footer-inner{padding:24px 0;text-align:center}
.footer-brand{font-weight:700;margin:.2rem 0}
.footer-nap{color:inherit;margin:.2rem 0}
.footer-legal{color:inherit;margin:.2rem 0}

/* Responsive */
@media (max-width: 960px){
  .grid-3{grid-template-columns:1fr 1fr}
}
@media (max-width: 720px){
  .header-inner{
    flex-direction:column;           /* stack */
    align-items:center;              /* center logo row */
    justify-content:flex-start;
    gap:8px;
    padding-inline:var(--gap);
    padding-top:8px;
    padding-bottom:6px;
  }
  /* Reorder: menu row first, logo second (Mark-style) */
  .site-header .logo{ order:2; }
  .site-header .nav{ order:1; width:100%; display:flex; justify-content:flex-end; align-items:center; }

  /* Make mobile logo a touch larger now it has its own row */
  .site-header .logo img{ height:48px; }

  /* Keep hamburger right-aligned and compact spacing */
  .nav-toggle{ margin-left:auto; }

  /* Adjust dropdown position since header stacks */
  .nav-list{ top:56px; } /* was 72px */

  .nav-toggle{ display:inline-block; }
  .nav-list{
    position:absolute;
    z-index:999; /* ensure dropdown overlays hero/panels */
    right:var(--gap);
    left:var(--gap);
    flex-direction:column;
    background:var(--panel);
    border:1px solid rgba(0,0,0,.06);
    border-radius:14px;
    padding:12px;
    display:none
  }
  /* Ensure nav-list is always above the backdrop */
  .nav-list{ z-index:999; }
  .site-header.light .nav-list{
    background:#ffffff;
    border:1px solid #e0e4ea;
  }
  .site-header.light .nav-list a{color:#2b3440}
  .nav-list.open{display:flex}
  .subnav{position:static;display:none;border:none;box-shadow:none;padding:6px 0;margin-top:6px;background:transparent}
  .subnav.open{display:block}
  .grid-3{grid-template-columns:1fr}
  .site-header.light .nav{
    flex:0 0 auto;
    margin-left:0;
    justify-content:flex-end;
    gap:16px;
  }

  /* Mobile nav backdrop when menu is open */
  @supports(selector(.site-header:has(.nav-toggle[aria-expanded="true"]))) {
    .site-header:has(.nav-toggle[aria-expanded="true"])::after{
      content:"";
      position:fixed;
      inset:0;
      background:rgba(0,0,0,.45);
      -webkit-backdrop-filter: blur(2px);
      backdrop-filter: blur(2px);
      z-index:998; /* sits below .nav-list (999) but above content */
      opacity:1;
      transition:opacity .2s ease;
    }
  }
}

/* === Services Visual Nav Grid (restored, compact gaps, square tiles) === */
.services-grid, .grid-sq, .service-grid.grid-sq{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:6px; /* small, even gap */
}

/* Homepage services: 4×1 on desktop, 2×2 on tablet/mobile */
.services-nav .service-grid{
  display:grid;
  gap:6px;
}
@media (min-width:1024px){
  .services-nav .service-grid{ grid-template-columns:repeat(4, minmax(0,1fr)); }
  .services-nav .service-grid .service-tile{ aspect-ratio:3/2; }
}
@media (max-width:1023.98px){
  .services-nav .service-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
  .services-nav .service-grid .service-tile{ aspect-ratio:1/1; }
}

/* Make any direct children square tiles */
.services-grid > *, .grid-sq > *, .service-grid.grid-sq > *{
  position:relative;
  border-radius:0;
  overflow:hidden;
  aspect-ratio:1/1; /* perfect squares */
  background:#e9eef5;
}

/* Images fill and crop correctly */
.services-grid img, .grid-sq img, .service-grid.grid-sq img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

/* Optional overlay label used across the site */
.service-label{
  position:absolute;
  left:8px; right:8px; bottom:8px;
  padding:.35rem .5rem;
  border-radius:8px;
  background:rgba(0,0,0,.55);
  color:#fff;
  font-size:1.5rem;
  font-weight:700; /* pairs with var(--font-sc) already set */
  line-height:1.1;
}

/* Responsive columns */
@media (max-width: 960px){
  .services-grid, .grid-sq, .service-grid.grid-sq{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width: 600px){
  .services-grid, .grid-sq, .service-grid.grid-sq{grid-template-columns:repeat(2, 1fr)}
}

/* === Home Visual Grids (3:2 aspect) === */
.grid-rect{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:6px;
}
.grid-rect > *{
  position:relative;
  border-radius:0;
  overflow:hidden;
  aspect-ratio:3/2; /* 3:2 tiles for homepage */
  background:#e9eef5;
}
.grid-rect img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}
/* Responsive columns for home grids */
@media (max-width: 960px){
  .grid-rect{grid-template-columns:repeat(2, minmax(0,1fr))}
}

/* === Homepage Services Collage (Mark-style) === */
.services-nav{padding-top:16px; padding-bottom:0}
.services-nav .container{max-width:100%; padding:0}
.service-grid{margin:0; width:100%; background:transparent; padding:0; border-radius:0}
.service-grid.grid-rect{
  display:grid !important; 
  grid-template-columns:repeat(3, minmax(0,1fr)) !important; 
  gap:6px;
  border-radius:0;
}
.service-grid.grid-rect > *{
  border-radius:0 !important;
}
/* Hover overlay label (Mark-style) — high contrast */
.service-grid .service-tile{position:relative}
.service-grid .service-tile::after{
  content:"";position:absolute;inset:0;background:rgba(0,0,0,0);opacity:0;
  transition:opacity .25s ease, background .25s ease; z-index:1;
}
.service-grid .service-label{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.98);
  padding:0;border-radius:0;background:transparent;color:#fff;
  font-family: var(--font-sc); font-size:1.5rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700;
  opacity:0;transition:opacity .25s ease, transform .25s ease; text-align:center; width:100%; z-index:2;
  text-shadow:0 2px 6px rgba(0,0,0,.55), 0 8px 24px rgba(0,0,0,.35);
  -webkit-text-stroke: .5px rgba(0,0,0,.25);
}
.service-grid .service-tile:hover::after{background:rgba(0,0,0,.45);opacity:1}
.service-grid .service-tile:hover .service-label{opacity:1;transform:translate(-50%,-50%) scale(1)}

/* Touch devices: label always visible, darker overlay for readability */
@media (hover: none){
  .service-grid .service-label{
    opacity:1 !important;
    transform:translate(-50%,-50%) scale(1) !important;
    font-size:1.25rem !important;
  }
}
@media (hover: none) and (max-width: 960px){
  .service-grid .service-label{
    text-shadow:0 3px 10px rgba(0,0,0,.6), 0 14px 36px rgba(0,0,0,.4);
  }
}

/* responsive */
@media (max-width: 960px){
  .service-grid.grid-rect{grid-template-columns:repeat(2, minmax(0,1fr)) !important; gap:6px !important}
}

/* Force labels visible on small screens (fallback for devices misreporting hover) */
@media (max-width: 960px){
  .service-grid .service-tile::after{background:rgba(0,0,0,.45); opacity:1 !important;}
  .service-grid .service-label{
    opacity:1 !important;
    transform:translate(-50%, -50%) scale(1) !important;
    font-size:1.25rem;
  }
}
.service-grid.grid-sq > figure,
.service-grid.grid-sq > a.service-tile,
.service-grid.grid-rect > figure,
.service-grid.grid-rect > a.service-tile{
  margin:0 !important;
}
.service-grid.grid-sq figure > *,
.service-grid.grid-rect figure > *{ margin:0; }
.service-grid.grid-sq figcaption,
.service-grid.grid-rect figcaption{ margin:0; padding:0; }

/* Ensure images fully fill tiles */
.service-grid.grid-sq img,
.service-grid.grid-rect img{ display:block; width:100%; height:100%; object-fit:cover; }

/* Full-bleed helper: run grids to the viewport edges */
.full-bleed{
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  width:100vw;
}

/* Stronger page title styling when used below the grid */
.hero--below h1{
  font-size:clamp(2rem, 4vw, 3rem);
  font-weight:600;
  letter-spacing:.02em;
}
.hero--below .lead{font-size:clamp(1.05rem, 2.2vw, 1.3rem)}

/* Trim any stray spacing around full-bleed grid */
.full-bleed{padding:0}
.full-bleed > *{margin:0}

/* === Lightbox (accessible modal) === */
.lightbox {
  position: fixed; inset: 0; z-index: 9999;
  display: none; align-items: center; justify-content: center;
  background: rgba(0,0,0,.85);
}
.lightbox.open { display: flex; }
.lightbox__inner { position: relative; max-width: 92vw; max-height: 92vh; }
.lightbox__img { display:block; max-width:100%; max-height:100%; object-fit:contain; }
.lightbox__close {
  position:absolute; top:8px; right:8px;
  background:rgba(255,255,255,.9); border:none; border-radius:6px;
  padding:.45rem .6rem; cursor:pointer; font-weight:700;
}
.lightbox__caption {
  margin-top:10px; color:#fff; text-align:center; font-size:.95rem;
  opacity:.9;
}

/* === Parallax hero stack === */
.parallax-stack{position:relative}
.parallax-stack .panel{
  position:relative;
  min-height:100vh;
  display:grid;
  place-items:center;
  overflow:hidden;
  isolation:isolate;
}
.parallax-stack .panel__bg{position:absolute;inset:0;z-index:-1;will-change:transform}
.parallax-stack .panel__bg img{width:100%;height:100%;object-fit:cover;display:block}
.parallax-stack .panel::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.15) 40%,rgba(0,0,0,0) 70%);
}
.parallax-stack .panel__content{color:#fff;max-width:min(780px,90vw)}
.parallax-stack .panel__content h1,
.parallax-stack .panel__content h2{margin:0 0 .4rem;text-shadow:0 6px 22px rgba(0,0,0,.45)}
.parallax-stack .panel__content .lead{color:#eef2f6;margin-bottom:.65rem}

/* === Parallax hero stack === */
.parallax-stack { position: relative; }
.parallax-stack .panel {
  position: relative;
  min-height: 100vh;
  display: grid;
  place-items: center;
  overflow: hidden;
  isolation: isolate;
}
.parallax-stack .panel__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  will-change: transform; /* parallax transform set by JS */
}
.parallax-stack .panel__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.parallax-stack .panel::after {
  /* subtle gradient for readability */
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(0,0,0,.35) 0%,
    rgba(0,0,0,.15) 40%,
    rgba(0,0,0,0) 70%
  );
}

/* If you kept any text overlays, they inherit this styling */
.parallax-stack .panel__content { color: #fff; max-width: min(780px, 90vw); }
.parallax-stack .panel__content h1,
.parallax-stack .panel__content h2 {
  margin: 0 0 .4rem;
  text-shadow: 0 6px 22px rgba(0,0,0,.45);
}
.parallax-stack .panel__content .lead { color: #eef2f6; margin-bottom: .65rem; }

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .parallax-stack .panel__bg { transform: none !important; }
}

/* === Single-word labels on each panel === */
.panel__label{
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--font-sc, var(--font-primary));
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: clamp(1.6rem, 6vw, 3rem);
  color: #ffffff;
  text-align: center;
  text-shadow: 0 6px 22px rgba(0,0,0,.45), 0 18px 48px rgba(0,0,0,.35);
  pointer-events: none;
  z-index: 1;
}

/* Allow whole parallax panel to be clickable */
.panel-link {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: inherit;
}
.panel-link .panel__label {
  pointer-events: none; /* keep label visible but non-blocking */
}
.panel-link:hover::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.25);
  z-index: 2;
}

/* === Editorial copy section below the parallax === */
.hero-copy{
  padding: clamp(28px, 6vw, 64px) 0;
  background: #fff;
  border-bottom: 1px solid #e0e4ea;
}
.hero-copy .hero-inner { max-width: var(--max); }
.hero-copy h1{
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 600;
  letter-spacing: .01em;
  margin: 0 0 .5rem;
}
.hero-copy .lead { font-size: clamp(1.05rem, 2.2vw, 1.3rem); }
.hero-copy .micro { color: var(--muted); margin-top: .4rem; }

.page-hero {
  min-height: 520px;                 /* ensures presence on small laptops */
  height: clamp(520px, 78vh, 860px); /* taller, less "thin" on desktop */
  overflow: hidden;
}

.page-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 70% 50%; /* bias framing to the right-hand subject */
}

.headshot-bank {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-top: 16px;
  flex-wrap: wrap; /* stays neat on mobile */
}

.headshot-bank figure {
  margin: 0;
  flex: 1 1 120px;
  max-width: 120px; /* keeps them small, editorial */
}

.headshot-bank img {
  border-radius: 8px;
  display: block;
  width: 100%;
  height: auto;
}

.site-header.light{
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 50;
  background: rgba(255,255,255,.92);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

/* Small buffer between header and first section */
.site-header + *{ margin-top: 8px; }

/* Hide/reveal animation */
.site-header{ transition: transform .24s ease; }
.site-header.header-hide{ transform: translateY(-100%); }

/* === Consistent nav/header typography across all pages === */
.site-header .logo,
.site-header .nav-list a,
.site-header .nav-parent,
.site-header .nav-toggle{
  font-family: var(--font-sc, var(--font-primary));
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* Simple spacer utility (used between hero and grid on brand) */
.spacer{ margin-bottom: 2rem; }

/* Service hero block used below grids — matches Teams page look */
.hero--service{
  padding: clamp(24px, 5vw, 56px) 0;
  background: none;
  border-top: 1px solid #e0e4ea;
}
.hero--service .hero-inner{ max-width: var(--max); }
.hero--service h1{
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 600;
  letter-spacing: .02em;
  margin: 0 0 .4rem;
}
.hero--service h2{
  font-size: clamp(1.2rem, 2.4vw, 1.6rem);
  margin: 0 0 .2rem;
}
.hero--service .lead{ font-size: clamp(1.05rem, 2.2vw, 1.3rem); }

/* Remove unintended gap when header overlays hero */
.page-hero{ margin-top: 0; }