/* ════════════════════════════════════════════════════════════════
   Watch Hill Technology Group — shared stylesheet (wh.css)
   Design tokens + nav + footer + page patterns.
   Astro port: drop in as global.css; nav/footer → layout components.
   ════════════════════════════════════════════════════════════════ */

:root{
  --navy:#0B1B3B;
  --navy-2:#10254f;
  --navy-ink:#0a1730;
  --crimson:#A6192E;
  --crimson-dark:#7c1222;
  --ink:#1b2230;
  --muted:#5d6675;
  --paper:#ffffff;
  --mist-1:#eef4fb;
  --mist-2:#dbe8f6;
  --fog:#f1f1f3;          /* warm gray section bg (construction/proserv) */
  --rule:rgba(11,27,59,0.16);
  --hsans:'Montserrat', system-ui, sans-serif;
  --bsans:'Mulish', system-ui, sans-serif;
  --maxw:1180px;
  --gut:48px;
  --nav-h:74px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth; overflow-x:clip;}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--bsans); font-size:17px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{color:inherit;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 var(--gut);}
.wrap-wide{max-width:1340px; margin:0 auto; padding:0 var(--gut);}

/* ── shared type ── */
.eyebrow{
  font-family:var(--hsans); font-weight:700; font-size:13px;
  letter-spacing:0.26em; text-transform:uppercase; color:var(--crimson);
}
.section-head{
  font-family:var(--hsans); font-weight:700; color:var(--crimson);
  letter-spacing:0.16em; text-transform:uppercase; line-height:1.25;
  margin:0; font-size:clamp(22px,2.4vw,30px);
}
.lead{
  font-family:var(--bsans); font-weight:400; color:var(--muted);
  font-size:clamp(17px,1.35vw,19px); line-height:1.75; text-wrap:pretty;
}
.prose p{color:var(--muted); margin:0 0 20px; text-wrap:pretty;}
.prose p:last-child{margin-bottom:0;}

/* ── buttons ── */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--hsans); font-weight:700; font-size:12px; letter-spacing:0.16em;
  text-transform:uppercase; text-decoration:none; color:#fff;
  background:var(--crimson); padding:15px 30px; border-radius:3px; border:0; cursor:pointer;
  transition:background .25s ease, transform .25s ease, box-shadow .25s ease;
}
.btn:hover{background:var(--crimson-dark); transform:translateY(-2px); box-shadow:0 12px 28px rgba(166,25,46,0.28);}
.btn-ghost{background:transparent; border:1.5px solid rgba(255,255,255,0.6); color:#fff;}
.btn-ghost:hover{background:rgba(255,255,255,0.1); border-color:#fff;}

/* ════════════ NAV ════════════ */
header.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gut);
  transition:background .35s ease, box-shadow .35s ease, padding .35s ease;
}
header.nav.solid{
  background:rgba(255,255,255,0.96); backdrop-filter:saturate(1.2) blur(8px);
  box-shadow:0 1px 0 rgba(11,27,59,0.10), 0 8px 30px rgba(11,27,59,0.06);
  padding:12px var(--gut);
}
.brand{position:relative; display:flex; align-items:center; text-decoration:none;}
.brand .logo{display:block; height:38px; width:auto; transition:opacity .35s ease;}
.brand .logo-color{position:absolute; left:0; top:0; opacity:0;}
header.nav.solid .brand .logo-white{opacity:0;}
header.nav.solid .brand .logo-color{opacity:1;}

nav.links{display:flex; align-items:center; gap:34px;}
nav.links > a, .has-sub > a{
  font-family:var(--hsans); font-weight:600; font-size:12.5px;
  letter-spacing:0.16em; text-transform:uppercase; text-decoration:none;
  color:rgba(255,255,255,0.92); padding:8px 0; position:relative; white-space:nowrap;
  transition:color .35s ease;
}
header.nav.solid nav.links > a, header.nav.solid .has-sub > a{color:var(--navy);}
nav.links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:0; height:2px;
  background:var(--crimson); transition:right .28s ease;
}
nav.links a:hover::after, nav.links a.current::after{right:0;}
.has-sub{position:relative; display:flex; align-items:center; cursor:default;}
/* invisible hover bridge fills the gap between trigger and dropdown */
.has-sub::after{content:''; position:absolute; top:100%; left:-8px; right:-8px; height:16px; z-index:59;}
.has-sub .sub{
  position:absolute; top:calc(100% + 10px); left:50%; transform:translateX(-50%) translateY(4px);
  background:#fff; border:1px solid var(--rule); border-radius:6px; padding:8px;
  min-width:210px; box-shadow:0 18px 50px rgba(11,27,59,0.16);
  opacity:0; visibility:hidden;
  transition:opacity .15s ease .08s, transform .15s ease .08s, visibility 0s .23s;
}
.has-sub:hover .sub{opacity:1; visibility:visible; transform:translateX(-50%) translateY(0);
  transition:opacity .15s ease 0s, transform .15s ease 0s, visibility 0s 0s;
}
/* Capabilities trigger — styled like a nav link but not a link */
.sub-trigger{
  font-family:var(--hsans); font-weight:600; font-size:12.5px;
  letter-spacing:0.16em; text-transform:uppercase;
  color:rgba(255,255,255,0.88); position:relative; padding-bottom:2px;
  cursor:default; user-select:none;
}
header.nav.solid .sub-trigger{color:var(--navy);}
.has-sub .sub a{
  display:block; font-family:var(--hsans); font-weight:600; font-size:11.5px;
  letter-spacing:0.14em; text-transform:uppercase; color:var(--navy);
  text-decoration:none; padding:10px 12px; border-radius:4px;
}
.has-sub .sub a:hover{background:var(--mist-1); color:var(--crimson);}

/* ── Mobile menu toggle (hamburger) ── */
.nav-toggle{
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:44px; height:44px; padding:0; border:0; background:none; cursor:pointer;
  position:relative; z-index:61;
}
.nav-toggle span{
  display:block; width:26px; height:2px; margin-left:auto; border-radius:2px;
  background:#fff; transition:transform .3s ease, opacity .2s ease, background .35s ease;
}
header.nav.solid .nav-toggle span{background:var(--navy);}
body.menu-open .nav-toggle span{background:#fff;}
body.menu-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);}
body.menu-open .nav-toggle span:nth-child(2){opacity:0;}
body.menu-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ── Mobile menu overlay ── */
.mobile-menu{
  display:none; position:fixed; inset:0; z-index:55; background:var(--navy-ink);
  padding:104px var(--gut) 48px; flex-direction:column; justify-content:center;
  opacity:0; visibility:hidden; transform:translateY(-10px);
  transition:opacity .32s ease, transform .32s ease, visibility .32s;
}
body.menu-open .mobile-menu{opacity:1; visibility:visible; transform:none;}
.mobile-menu .mm-links{display:flex; flex-direction:column; width:100%; max-width:560px; margin:0 auto;}
.mobile-menu .mm-links > a{
  font-family:var(--hsans); font-weight:800; font-size:clamp(22px,6vw,30px);
  letter-spacing:0.04em; text-transform:uppercase; color:#fff; text-decoration:none;
  padding:16px 0; border-bottom:1px solid rgba(255,255,255,0.12); transition:color .2s ease;
}
.mobile-menu .mm-links > a:hover{color:var(--crimson);}
.mm-group{padding:16px 0; border-bottom:1px solid rgba(255,255,255,0.12); display:flex; flex-direction:column;}
.mm-group .mm-label{
  font-family:var(--hsans); font-weight:700; font-size:12px; letter-spacing:0.2em;
  text-transform:uppercase; color:var(--crimson); margin-bottom:10px;
}
.mm-group a{
  font-family:var(--hsans); font-weight:600; font-size:17px; letter-spacing:0.04em;
  color:rgba(255,255,255,0.78); text-decoration:none; padding:13px 0 13px 18px;
  border-left:2px solid rgba(255,255,255,0.18); transition:color .2s ease, border-color .2s ease;
}
.mm-group a:hover{color:#fff; border-color:var(--crimson);}

/* When the menu is open, let the nav read on the navy overlay */
body.menu-open{overflow:hidden;}
body.menu-open header.nav{background:transparent !important; box-shadow:none !important;}
body.menu-open header.nav .brand .logo-white{opacity:1;}
body.menu-open header.nav .brand .logo-color{opacity:0;}

/* ════════════ HOME HERO ════════════ */
.hero{
  position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center;
  text-align:center; color:#fff; overflow:hidden;
  background:linear-gradient(160deg,#0a1c3d 0%, #122a55 55%, #0a1730 100%);
}
.hero image-slot{position:absolute; inset:0; width:100%; height:100%; z-index:0;}
.hero .scrim{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(7,18,40,0.62) 0%, rgba(7,18,40,0.30) 30%, rgba(7,18,40,0.55) 72%, rgba(7,18,40,0.92) 100%);
}
.hero .hero-inner{position:relative; z-index:2; padding:0 var(--gut); max-width:1000px; pointer-events:none;}
.hero h1{
  font-family:var(--hsans); font-weight:800; text-transform:uppercase;
  font-size:clamp(40px,7vw,104px); line-height:0.98; letter-spacing:0.01em; margin:0;
  text-shadow:0 4px 40px rgba(0,0,0,0.35);
}
.hero .tagline{
  font-family:var(--hsans); font-weight:600; text-transform:uppercase;
  letter-spacing:0.28em; font-size:clamp(14px,1.7vw,21px); margin:26px 0 0; color:rgba(255,255,255,0.92);
}
.hero .tagline .dots{color:var(--crimson);}
.hero .rule{width:54px; height:3px; background:var(--crimson); margin:34px auto 0;}
.scroll-cue{
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:2;
  font-family:var(--hsans); font-weight:600; font-size:10.5px; letter-spacing:0.24em;
  text-transform:uppercase; color:rgba(255,255,255,0.7); display:flex; flex-direction:column;
  align-items:center; gap:9px; pointer-events:none;
}
.scroll-cue .arr{width:1px; height:30px; background:linear-gradient(rgba(255,255,255,0.7), rgba(255,255,255,0)); animation:pulse 2.2s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:.35; transform:scaleY(.7);}50%{opacity:1; transform:scaleY(1);}}

/* ════════════ INNER-PAGE BANNER HERO ════════════ */
.page-hero{
  position:relative; overflow:hidden; color:#fff; text-align:center;
  min-height:clamp(340px,46vh,460px);
  display:flex; align-items:center; justify-content:center;
  padding:calc(var(--nav-h) + 40px) var(--gut) 56px;
  background:linear-gradient(160deg,#0a1c3d 0%, #122a55 60%, #0a1730 100%);
}
.page-hero image-slot{position:absolute; inset:0; width:100%; height:100%; z-index:0;}
.page-hero .scrim{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(7,18,40,0.66) 0%, rgba(7,18,40,0.5) 55%, rgba(7,18,40,0.8) 100%);
}
.page-hero.crimson{background:linear-gradient(135deg,#3a0810 0%, #6e0f1d 55%, #2a0710 100%);}
.page-hero.crimson .scrim{background:linear-gradient(180deg, rgba(40,7,12,0.55) 0%, rgba(70,8,16,0.55) 100%);}
.page-hero .ph-inner{position:relative; z-index:2; max-width:900px; pointer-events:none;}
.page-hero .eyebrow{color:#fff; opacity:0.78; margin-bottom:18px;}
.page-hero h1{
  font-family:var(--hsans); font-weight:800; text-transform:uppercase;
  font-size:clamp(34px,5vw,68px); line-height:1.02; letter-spacing:0.01em; margin:0;
  text-shadow:0 4px 34px rgba(0,0,0,0.34);
}
.page-hero .ph-sub{
  font-family:var(--hsans); font-weight:600; text-transform:uppercase; letter-spacing:0.22em;
  font-size:clamp(12px,1.4vw,15px); margin:20px 0 0; color:rgba(255,255,255,0.84);
}
.page-hero .rule{width:50px; height:3px; background:var(--crimson); margin:26px auto 0;}

/* ════════════ GENERIC SECTIONS ════════════ */
.section{padding:clamp(72px,9vw,120px) 0;}
.section.tight{padding:clamp(56px,7vw,88px) 0;}
.section.fog{background:var(--fog);}
.section.mist{background:linear-gradient(180deg,#fff 0%, var(--mist-1) 100%);}
.section.navy{background:var(--navy); color:#fff;}
.section.ink{background:#1c1c1f; color:#fff;}

.head-block{max-width:760px;}
.head-block.center{margin:0 auto; text-align:center;}
.head-block h2{
  font-family:var(--hsans); font-weight:800; color:var(--ink);
  font-size:clamp(28px,3.4vw,42px); line-height:1.08; letter-spacing:-0.01em; margin:14px 0 0;
}
.section.navy .head-block h2, .section.ink .head-block h2{color:#fff;}
.head-block .accent{width:64px; height:3px; background:var(--crimson); margin:24px 0 0;}
.head-block.center .accent{margin:24px auto 0;}

/* two-column content (text + media) */
.content-2col{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,5vw,80px); align-items:center;
}
.content-2col.media-left{direction:rtl;}
.content-2col.media-left > *{direction:ltr;}
.content-2col .media{
  position:relative; border-radius:6px; overflow:hidden; min-height:380px;
  box-shadow:0 24px 60px rgba(11,27,59,0.18);
}
.content-2col .media image-slot{position:absolute; inset:0; width:100%; height:100%;}
.content-2col .col-head{
  font-family:var(--hsans); font-weight:800; color:var(--ink);
  font-size:clamp(26px,3vw,38px); line-height:1.1; margin:0 0 8px;
}
.section.navy .col-head, .section.ink .col-head{color:#fff;}
.col-head + .accent{width:64px; height:3px; background:var(--crimson); margin:0 0 28px;}

/* ════════════ FEATURE GRID (fiber) ════════════ */
.feature-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(28px,3vw,44px);
}
.feature{position:relative; padding-top:26px; border-top:2px solid var(--rule);}
.feature .fnum{
  font-family:var(--hsans); font-weight:700; font-size:12px; letter-spacing:0.18em;
  color:var(--crimson); display:block; margin-bottom:12px;
}
.feature h3{
  font-family:var(--hsans); font-weight:700; color:var(--navy);
  font-size:19px; line-height:1.25; margin:0 0 12px;
}
.feature p{margin:0; color:var(--muted); font-size:15.5px; line-height:1.65;}

/* lead variant (fiber): 01 spans as a headline row; 02–05 sit in an even row of four */
.feature-grid.lead{grid-template-columns:repeat(4,1fr);}
.feature-grid.lead .feature:first-child{
  grid-column:1 / -1; display:grid; grid-template-columns:auto 1fr 1.4fr;
  column-gap:28px; align-items:baseline; padding-bottom:34px;
}
.feature-grid.lead .feature:first-child .fnum{margin:0;}
.feature-grid.lead .feature:first-child h3{font-size:26px; margin:0;}
.feature-grid.lead .feature:first-child p{margin:0; font-size:16.5px;}

/* who-we-serve list */
.serve-list{list-style:none; margin:18px 0 0; padding:0; display:grid; gap:12px;}
.serve-list li{
  position:relative; padding-left:26px; color:var(--muted); font-size:16px;
}
.serve-list li::before{
  content:""; position:absolute; left:0; top:9px; width:9px; height:9px;
  background:var(--crimson); transform:rotate(45deg);
}
.serve-label{
  font-family:var(--hsans); font-weight:700; font-size:13px; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--navy); display:block; margin:6px 0 4px;
}

/* ════════════ CTA BAND ════════════ */
.cta-band{padding:clamp(64px,8vw,100px) 0; text-align:center; background:linear-gradient(180deg,#fff 0%, var(--mist-1) 100%);}
.cta-band h2{
  font-family:var(--hsans); font-weight:800; color:var(--ink);
  font-size:clamp(26px,3vw,38px); margin:0 0 28px;
}

/* ════════════ GALLERY BAND ════════════ */
.gallery-band{background:var(--navy); padding:clamp(48px,6vw,80px) 0;}
.gallery-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1040px; margin:0 auto;}
.gallery-grid .shot{position:relative; aspect-ratio:4/3; border-radius:5px; overflow:hidden; box-shadow:0 16px 40px rgba(0,0,0,0.3);}
.gallery-grid .shot image-slot{position:absolute; inset:0; width:100%; height:100%;}
.gallery-grid.two{grid-template-columns:repeat(2,1fr); max-width:840px;}

/* ════════════ TEAM (about) ════════════ */
.team-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(28px,3vw,48px);
  max-width:920px; margin:0 auto;
}
.member{text-align:center;}
.member .photo{
  position:relative; width:100%; aspect-ratio:1/1; border-radius:6px; overflow:hidden;
  background:rgba(255,255,255,0.06); box-shadow:0 14px 36px rgba(0,0,0,0.28);
}
.member .photo image-slot{position:absolute; inset:0; width:100%; height:100%;}
/* real photos dropped into slots */
.page-hero img.fill, .content-2col .media img.fill, .gallery-grid .shot img.fill,
.member .photo img.fill, .quote-band img.fill, .hero img.fill{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
}
.member .photo img.fill{object-position:50% 20%;}
.member .name{
  font-family:var(--hsans); font-weight:700; font-size:16px; color:#fff; margin:18px 0 4px; letter-spacing:0.01em;
}
.member .role{font-size:13.5px; color:rgba(255,255,255,0.62); margin:0;}
.member .li{
  display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px;
  margin-top:12px; border-radius:3px; background:#0a66c2; color:#fff; text-decoration:none;
  transition:transform .2s ease, filter .2s ease;
}
.member .li:hover{transform:translateY(-2px); filter:brightness(1.1);}

/* ════════════ CERT LISTS (safety) ════════════ */
.cert-list{list-style:none; margin:0; padding:0; columns:2; column-gap:48px;}
.cert-list li{
  position:relative; padding:0 0 0 28px; margin:0 0 14px; break-inside:avoid;
  font-size:16px; color:var(--muted);
}
.cert-list li::before{
  content:""; position:absolute; left:0; top:3px; width:16px; height:16px; border-radius:50%;
  background:var(--crimson);
  -webkit-mask:no-repeat center/12px url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E");
  mask:no-repeat center/12px url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E");
}
.section.ink .cert-list li{color:rgba(255,255,255,0.82);}
.trainer-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px 40px; max-width:520px;}
.trainer-grid span{
  font-family:var(--hsans); font-weight:600; font-size:15px; color:#7fb2e6; letter-spacing:0.02em;
}

/* ════════════ FORMS ════════════ */
.form-card{
  background:#fff; border:1px solid var(--rule); border-radius:8px;
  padding:clamp(28px,3vw,40px); box-shadow:0 24px 60px rgba(11,27,59,0.10);
}
.field{margin-bottom:16px;}
.field label{
  display:block; font-family:var(--hsans); font-weight:600; font-size:11px; letter-spacing:0.12em;
  text-transform:uppercase; color:var(--muted); margin-bottom:7px;
}
.field input, .field textarea{
  width:100%; font-family:var(--bsans); font-size:16px; color:var(--ink);
  padding:13px 15px; border:1px solid var(--rule); border-radius:4px; background:#fff;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.field textarea{min-height:120px; resize:vertical;}
.field input:focus, .field textarea:focus{
  outline:none; border-color:var(--crimson); box-shadow:0 0 0 3px rgba(166,25,46,0.12);
}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.file-field{
  display:flex; align-items:center; gap:14px; padding:12px 15px;
  border:1px dashed var(--rule); border-radius:4px; color:var(--muted); font-size:14px;
}

/* ════════════ CAREERS HIRING LAYOUT ════════════ */
.hire-grid{display:grid; grid-template-columns:1.25fr 1fr; gap:clamp(40px,5vw,70px); align-items:start;}
.hire-form{position:sticky; top:100px;}
@media (max-width:900px){
  .hire-grid{grid-template-columns:1fr;}
  .hire-form{position:static;}
}

/* ════════════ ADDRESS CARDS (contact) ════════════ */
.address-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:20px;}
.addr-card{
  border:1px solid var(--rule); border-radius:6px; padding:24px 26px; background:#fff;
  transition:border-color .25s ease, box-shadow .25s ease, transform .25s ease;
}
.addr-card:hover{border-color:rgba(166,25,46,0.35); box-shadow:0 16px 40px rgba(11,27,59,0.10); transform:translateY(-3px);}
.addr-card h3{
  font-family:var(--hsans); font-weight:700; font-size:17px; color:var(--navy); margin:0 0 12px;
  display:flex; align-items:center; gap:10px;
}
.addr-card h3 .pin{width:10px; height:10px; border-radius:50%; background:var(--crimson); flex:0 0 auto;}
.addr-card p{margin:0; color:var(--muted); font-size:15px; line-height:1.7;}
.addr-card .phone{font-family:var(--hsans); font-weight:700; color:var(--ink); margin-top:8px; font-size:15px;}
.coverage{margin-top:clamp(40px,5vw,64px); text-align:center;}
.coverage img{display:block; width:100%; max-width:980px; height:auto; margin:0 auto;}
.coverage-note{max-width:560px; margin:clamp(8px,1.5vw,16px) auto 0; color:var(--muted); font-size:15px; line-height:1.7;}

/* ════════════ HOMEPAGE-ONLY SECTIONS ════════════ */
.about{padding:clamp(80px,11vw,140px) 0; text-align:center;}
.about .section-head{margin-bottom:10px;}
.about .underline{width:46px; height:3px; background:var(--crimson); margin:0 auto 34px;}
.about .lead{max-width:780px; margin:0 auto;}

.quote-band{
  position:relative; overflow:hidden; text-align:center; color:#fff;
  padding:clamp(64px,8vw,104px) 0;
  background:linear-gradient(120deg, #5c0f1c 0%, var(--crimson) 50%, #7c1222 100%);
}
.quote-band image-slot{position:absolute; inset:0; width:100%; height:100%; z-index:0;}
.quote-band .scrim{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(120deg, rgba(70,8,16,0.86) 0%, rgba(140,18,34,0.66) 50%, rgba(70,8,16,0.9) 100%);
}
.quote-band .q-inner{position:relative; z-index:2; pointer-events:none;}
.quote-band blockquote{
  margin:0 auto; max-width:920px;
  font-family:var(--hsans); font-weight:700; text-transform:uppercase;
  font-size:clamp(22px,3vw,38px); line-height:1.3; letter-spacing:0.04em;
  text-shadow:0 3px 24px rgba(0,0,0,0.3);
}
.quote-band .qmark{font-family:var(--hsans); font-weight:800; font-size:64px; line-height:0; opacity:0.45; display:block; margin-bottom:18px;}

.caps{padding:clamp(80px,11vw,140px) 0 0; text-align:center;}
.caps .section-head{margin-bottom:10px;}
.caps .underline{width:46px; height:3px; background:var(--crimson); margin:0 auto 34px;}
.caps .lead{max-width:800px; margin:0 auto;}
.caps-band{
  position:relative; margin-top:clamp(56px,7vw,88px); overflow:hidden;
  background:linear-gradient(180deg, var(--mist-1) 0%, var(--mist-2) 100%);
  padding:clamp(64px,8vw,96px) 0;
}
.caps-band .tower{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; object-position:right center;
  z-index:0; opacity:0.85; pointer-events:none;
  -webkit-mask-image:linear-gradient(90deg, transparent 0%, #000 60%);
  mask-image:linear-gradient(90deg, transparent 0%, #000 60%);
}
.caps-band .hexes{position:absolute; left:-60px; bottom:-60px; z-index:0; opacity:0.5; pointer-events:none;}
.cap-grid{position:relative; z-index:2; display:grid; grid-template-columns:repeat(3,1fr); gap:40px; max-width:920px; margin:0 auto;}
.cap{display:flex; flex-direction:column; align-items:center; gap:20px; text-decoration:none;}
.cap .disc{
  width:128px; height:128px; border-radius:50%; background:#fff;
  border:1px solid rgba(11,27,59,0.08); display:flex; align-items:center; justify-content:center;
  box-shadow:0 10px 30px rgba(11,27,59,0.10);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.cap:hover .disc{transform:translateY(-6px); box-shadow:0 18px 44px rgba(11,27,59,0.18); border-color:rgba(166,25,46,0.4);}
.cap .disc svg{width:62px; height:62px;}
.cap .disc img{width:74px; height:74px; object-fit:contain;}
/* Nudge each icon so its main navy circle (not the red accents) is optically centered in the disc */
.cap .disc img.ic-construction{transform:translate(4px,-7.5px);}
.cap .disc img.ic-fiber{transform:translate(0,-3.5px);}
.cap .disc img.ic-professional{transform:translate(3px,-2.5px);}
.cap .name{font-family:var(--hsans); font-weight:600; font-size:18px; letter-spacing:0.02em; color:var(--navy);}
.cap .more{
  font-family:var(--hsans); font-weight:700; font-size:10.5px; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--crimson); opacity:0; transform:translateY(-4px);
  transition:opacity .3s ease, transform .3s ease;
}
.cap:hover .more{opacity:1; transform:translateY(0);}

.home-safety{position:relative; padding:clamp(80px,11vw,130px) 0; text-align:center; overflow:visible;}
.home-safety::before{
  content:""; position:absolute; left:50%; top:46%; transform:translate(-50%,-50%);
  width:min(1700px,160%); aspect-ratio:768/564; z-index:0; pointer-events:none;
  background:url("../images/watermark-wh.png") no-repeat center center / contain;
  opacity:0.6;
}
.home-safety .wrap{position:relative; z-index:1;}
.home-safety .hr{height:1px; background:var(--rule); max-width:760px; margin:0 auto;}
.home-safety .core{padding:clamp(48px,6vw,72px) 0;}
.home-safety .section-head{margin-bottom:8px;}
.home-safety .section-head .sub-line{display:block; color:var(--navy); letter-spacing:0.14em;}
.home-safety .lead{max-width:760px; margin:26px auto 0;}

.loc{padding:0 0 clamp(72px,9vw,120px); text-align:center;}
.loc-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:36px; max-width:980px; margin:0 auto;}
.office h3{font-family:var(--hsans); font-weight:700; font-size:15px; letter-spacing:0.18em; text-transform:uppercase; color:var(--crimson); margin:0 0 14px;}
.office .corp{font-family:var(--hsans); font-weight:700; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:var(--navy); display:block; margin-bottom:6px;}
.office p{margin:0; font-size:15px; line-height:1.7; color:var(--muted);}
.office .phone{font-family:var(--hsans); font-weight:600; font-size:14px; color:var(--ink); margin-top:8px;}

/* ════════════ FOOTER (shared, site-wide) ════════════ */
footer.site{position:relative; overflow:hidden; background:var(--navy-ink); color:rgba(255,255,255,0.78); padding:clamp(56px,7vw,80px) 0 0;}
footer.site .hex-ghost{position:absolute; inset:0; z-index:0; opacity:0.06; pointer-events:none;}
footer.site .f-top{
  position:relative; z-index:2; display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr)) auto; gap:40px;
  padding-bottom:46px; border-bottom:1px solid rgba(255,255,255,0.12);
}
footer.site .f-col h4{
  font-family:var(--hsans); font-weight:700; font-size:12px; letter-spacing:0.18em;
  text-transform:uppercase; color:#fff; margin:0 0 18px;
}
footer.site .f-col a{
  display:block; text-decoration:none; color:rgba(255,255,255,0.68);
  font-size:15px; margin-bottom:11px; transition:color .2s ease;
}
footer.site .f-col a:hover{color:#fff;}
footer.site .f-brand{display:flex; flex-direction:column; align-items:flex-start; gap:16px;}
footer.site .f-brand .li{
  display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px;
  border-radius:4px; background:#0a66c2; color:#fff; text-decoration:none; transition:transform .2s ease;
}
footer.site .f-brand .li:hover{transform:translateY(-2px);}
footer.site .copyright{
  position:relative; z-index:2; text-align:center; padding:24px 0;
  font-family:var(--hsans); font-weight:500; font-size:11px; letter-spacing:0.14em;
  text-transform:uppercase; color:rgba(255,255,255,0.5);
}

/* ════════════ REAL MEDIA (video hero + image bg) ════════════ */
/* Poster = the video's first frame; shows during load or if the Vimeo embed is blocked/fails */
.hero-video{position:absolute;inset:0;z-index:0;overflow:hidden;background:#0a1730 url("../images/hero-poster.jpg") center/cover no-repeat;}
.hero-video iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:56.25vw;min-height:100%;min-width:177.78vh;border:0;pointer-events:none;}
.bg-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}

/* ════════════ REVEAL ════════════ */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .8s ease, transform .8s ease;}
.reveal.in{opacity:1; transform:none;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1; transform:none; transition:none;}
  .scroll-cue .arr{animation:none;}
  html{scroll-behavior:auto;}
}

/* ════════════ RESPONSIVE ════════════ */
@media (max-width:980px){
  .feature-grid{grid-template-columns:repeat(2,1fr);}
  .feature-grid.lead{grid-template-columns:repeat(2,1fr);}
  .feature-grid.lead .feature:first-child{display:block; padding-bottom:0;}
  .feature-grid.lead .feature:first-child .fnum{margin-bottom:12px;}
  .feature-grid.lead .feature:first-child h3{font-size:19px; margin-bottom:12px;}
  .feature-grid.lead .feature:first-child p{font-size:15.5px;}
  .team-grid{grid-template-columns:repeat(2,1fr); max-width:560px;}
  .gallery-grid{max-width:680px;}
}
@media (max-width:900px){
  :root{--gut:28px;}
  nav.links{display:none;}
  .nav-toggle{display:flex;}
  .mobile-menu{display:flex;}
  .content-2col{grid-template-columns:1fr; gap:36px;}
  .content-2col.media-left{direction:ltr;}
  .content-2col .media{min-height:300px;}
  .cap-grid{grid-template-columns:1fr; gap:48px; max-width:340px;}
  .loc-grid{grid-template-columns:repeat(2,1fr); gap:40px 28px; max-width:520px;}
  .caps-band .tower{display:none;}
  footer.site .f-top{grid-template-columns:1fr 1fr; gap:34px;}
  footer.site .f-brand{grid-column:1 / -1;}
}
@media (max-width:620px){
  .feature-grid, .feature-grid.lead{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:repeat(2,1fr); max-width:380px;}
  .gallery-grid, .gallery-grid.two{grid-template-columns:1fr; max-width:380px;}
  .address-grid{grid-template-columns:1fr;}
  .field-row{grid-template-columns:1fr;}
  .cert-list{columns:1;}
  .trainer-grid{grid-template-columns:1fr;}
  .loc-grid{grid-template-columns:1fr;}
  footer.site .f-top{grid-template-columns:1fr;}
}
