
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  --bg:#ffffff;
  --bg-soft:#f6f8fa;
  --surface:#ffffff;
  --surface-2:#fbfcfd;
  --text:#0f1720;
  --muted:#5b6672;
  --navy:#0f2f4a;
  --navy-soft:#34526d;
  --line:#e7ecf1;
  --line-strong:#d6dee7;
  --shadow:0 20px 50px rgba(15,23,32,.06);
  --shadow-soft:0 10px 24px rgba(15,23,32,.04);
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:16px;
  --maxw:1200px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-size:16px;
  margin:0;
  font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.68;
}
img{max-width:100%;display:block}
iframe{max-width:100%;display:block}
a{
  color:var(--navy);
  text-decoration:none;
  transition:color .18s ease, opacity .18s ease, transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
a:hover{color:#0a2135}
p{margin:0 0 16px}
ul{margin:0 0 18px;padding-left:20px}
li{margin-bottom:8px}
h1,h2,h3,h4{
  margin:0 0 14px;
  letter-spacing:-.04em;
  line-height:1.06;
  color:var(--text);
  font-weight:700;
}
h1{font-size:clamp(2.5rem,5vw,5rem)}
h2{font-size:clamp(1.75rem,2.7vw,2.6rem)}
h3{font-size:clamp(1.2rem,1.6vw,1.45rem)}
h4{font-size:1rem}
.container{width:min(var(--maxw), calc(100% - 40px));margin:0 auto}

.site-header{
  position:sticky;
  top:0;
  z-index:60;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav-wrap{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
}
.brand{
  color:var(--text);
  font-size:.95rem;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  white-space:nowrap;
}
.main-nav{
  display:flex;
  align-items:center;
  gap:24px;
}
.main-nav>a,
.dropbtn{
  font:inherit;
  font-weight:600;
  color:var(--text);
  background:none;
  border:none;
  padding:10px 0;
  cursor:pointer;
  position:relative;
}
.main-nav>a::after,
.dropbtn::after{
  content:"";
  position:absolute;
  left:0;
  bottom:2px;
  width:100%;
  height:2px;
  background:var(--navy);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .18s ease;
}
.main-nav>a:hover::after,
.main-nav>a.active::after,
.dropbtn:hover::after{transform:scaleX(1)}

.dropdown{position:relative}
.dropdown-menu{
  display:none;
  position:absolute;
  top:calc(100% + 12px);
  left:0;
  width:320px;
  max-height:min(70vh,560px);
  overflow:auto;
  list-style:none;
  margin:0;
  padding:10px;
  background:rgba(255,255,255,.98);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
}
.dropdown:hover .dropdown-menu,
.dropdown:focus-within .dropdown-menu,
.dropdown.is-open .dropdown-menu{display:block}
.dropdown-menu li a{
  display:block;
  padding:12px 14px;
  border-radius:12px;
  color:var(--text);
}
.dropdown-menu li a:hover{
  background:var(--bg-soft);
  color:var(--navy);
}

.nav-toggle{
  display:none;
  border:1px solid var(--line-strong);
  background:#fff;
  color:var(--text);
  border-radius:999px;
  padding:11px 14px;
  font:inherit;
  font-weight:700;
  cursor:pointer;
}

.hero{
  min-height:82vh;
  display:flex;
  align-items:center;
  background-size:cover;
  background-position:center;
  position:relative;
}
.hero::before{display:none;}
.hero .container{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  min-height:84vh;
  padding-top:24px;
  padding-bottom:24px;
}
.hero-card{
  max-width:660px;
  background:rgba(255,255,255,.84);
  backdrop-filter:blur(12px);
  padding:38px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 28px 60px rgba(8,22,36,.16);
  margin-left:0;
  transform:translateY(10px);
}
.hero h1{max-width:12ch}
.hero p{
  font-size:1.05rem;
  color:var(--muted);
  max-width:62ch;
}
.eyebrow{
  margin-bottom:10px;
  color:var(--navy);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.72rem;
  font-weight:800;
}

.page-hero{
  padding:92px 0 54px;
  background:linear-gradient(180deg, #f8fafc 0%, #ffffff 88%);
  border-bottom:1px solid var(--line);
}
.page-hero h1{font-size:clamp(2.2rem,3.9vw,3.45rem);max-width:16ch}
.page-hero p{max-width:820px;color:var(--muted);font-size:1rem}

.section{padding:84px 0}
.section.alt{background:var(--bg-soft)}

.grid-2,.service-grid,.contact-grid,.footer-grid,.stats-grid{
  display:grid;
  gap:28px;
}
.grid-2{grid-template-columns:1.05fr .95fr;align-items:center}
.service-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.contact-grid{grid-template-columns:1fr 1fr;align-items:start}
.footer-grid{grid-template-columns:1.2fr .8fr .8fr}
.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}

.card,.service-card,.content-card,.contact-info,.contact-form,.stat{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:var(--shadow-soft);
  overflow:hidden;
}
.card:hover,.service-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow);
}
.card img,.service-card img{
  width:100%;
  object-fit:cover;
}
.card img{height:400px}
.service-card{
  display:flex;
  flex-direction:column;
  height:100%;
}
.service-card img{height:240px}
.card-body,.service-card .pad{padding:28px}
.service-card .pad{display:flex;flex-direction:column;gap:10px;flex:1}
.service-card .btn{margin-top:auto}
.service-card p,.content-card p,.contact-info p{color:var(--muted)}

.content-card,.contact-info,.contact-form{
  padding:34px;
}
.service-page{max-width:980px}
.service-page h2{margin-top:28px}
.service-page h3{margin-top:22px}
.service-page p,.service-page li{color:var(--muted)}
.service-page .btn{margin-top:10px}
.service-hero-image{
  width:100%;
  height:430px;
  object-fit:cover;
  border-radius:24px;
  margin-bottom:30px;
  box-shadow:var(--shadow-soft);
}
.columns{columns:2;column-gap:34px}
.columns>*{break-inside:avoid}
.banner-image{
  margin-top:28px;
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.banner-image img{width:100%;height:460px;object-fit:cover}

.service-links{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:28px;
}
.service-link{
  padding:18px 18px;
  border-radius:16px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  font-weight:700;
}
.service-link:hover{
  border-color:var(--navy-soft);
  box-shadow:var(--shadow-soft);
  transform:translateY(-1px);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:14px 22px;
  border-radius:999px;
  font-weight:700;
  border:1px solid transparent;
}
.btn-primary{
  background:var(--navy);
  color:#fff;
  box-shadow:0 14px 26px rgba(15,47,74,.15);
}
.btn-primary:hover{background:#0b253a;color:#fff}
.btn-secondary{
  background:#fff;
  color:var(--text);
  border-color:var(--line-strong);
}
.btn-secondary:hover{border-color:var(--navy-soft)}
.hero-actions,.button-row{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:24px;
}
.tag-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.tag{
  padding:9px 13px;
  border-radius:999px;
  background:var(--bg-soft);
  color:var(--navy);
  border:1px solid var(--line);
  font-weight:700;
}
.stat{
  padding:28px 22px;
  text-align:center;
}
.stat strong{
  display:block;
  font-size:2rem;
  color:var(--navy);
  letter-spacing:-.04em;
  margin-bottom:6px;
}
.map-container{
  border-radius:24px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.contact-form input,.contact-form textarea{
  width:100%;
  padding:14px 15px;
  margin:0 0 14px;
  border:1px solid var(--line-strong);
  background:#fff;
  border-radius:14px;
  font:inherit;
}
.contact-form input:focus,.contact-form textarea:focus{
  outline:none;
  border-color:var(--navy-soft);
  box-shadow:0 0 0 4px rgba(15,47,74,.06);
}

.site-footer{
  background:#fff;
  border-top:1px solid var(--line);
  color:var(--muted);
  padding-top:56px;
  margin-top:40px;
}
.site-footer a,.site-footer h4,.footer-company{color:var(--text)}
.footer-logo{
  width:min(100%,340px);
  height:auto;
  display:block;
  margin-bottom:14px;
}
.footer-company{font-weight:800;margin-bottom:8px}
.footer-bottom{
  margin-top:26px;
  padding:18px 0 28px;
  border-top:1px solid var(--line);
  font-size:.94rem;
}
ul.clean{list-style:none;padding:0;margin:0}
.mobile-only{display:none}

.related-services{
  margin:28px 0 22px;
  padding:24px;
  border:1px solid var(--line);
  border-radius:22px;
  background:#fff;
}
.related-services ul{padding-left:20px;margin-bottom:0}

@media (max-width:980px){
  .service-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid-2,.contact-grid,.footer-grid,.stats-grid{grid-template-columns:1fr}
  .card img,.service-hero-image{height:auto}
  .columns{columns:1}
}
@media (max-width:860px){
  .nav-toggle{display:inline-flex}
  .nav-wrap{min-height:72px}
  .main-nav{
    position:absolute;
    left:16px; right:16px; top:78px;
    display:none;
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
    padding:14px;
    background:rgba(255,255,255,.98);
    border:1px solid var(--line);
    border-radius:20px;
    box-shadow:var(--shadow);
  }
  .main-nav.is-open{display:flex}
  .main-nav>a,.dropbtn{width:100%;text-align:left;padding:12px 4px}
  .dropdown{width:100%}
  .dropdown-menu{
    position:static;
    width:100%;
    margin-top:8px;
    box-shadow:none;
    border-radius:14px;
  }
  .hero-card{
  max-width:660px;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(12px);
  padding:38px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 28px 60px rgba(8,22,36,.16);
}
}
@media (max-width:640px){
  .container{width:min(calc(100% - 22px), var(--maxw))}
  .service-grid{grid-template-columns:1fr}
  .service-links{grid-template-columns:1fr}
  .hero{min-height:64vh}
  .page-hero{padding:76px 0 40px}
  .hero-card,.content-card,.contact-info,.contact-form{padding:24px}
  .btn{width:100%}
  .hero-actions .btn,.button-row .btn{width:auto}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  a,.btn,.card,.service-card{transition:none}
}


.service-card p,
.content-card p,
.contact-info p,
.card-body p,
.footer-bottom,
.site-footer p,
.site-footer li,
.dropdown-menu li a{
  font-size:0.98rem;
}

.service-card h3{font-size:1.45rem}
.content-card h2,
.contact-info h2,
.contact-form h2,
.service-page h2{font-size:clamp(1.8rem,2.4vw,2.45rem)}

.service-page h3{font-size:1.4rem}
.brand{font-size:.95rem}
.main-nav>a,.dropbtn{font-size:.98rem}
.btn{font-size:.97rem}

/* Riprap image bottom focus */
.service-hero-image[src*="armor-design.jpg"]{
  object-position: bottom;
}


/* Responsive crop tuning for armor image */
.service-hero-image[src*="armor-design.jpg"]{
  object-fit: cover;
  object-position: 50% 90%; /* desktop */
}

/* tablet */
@media (max-width: 980px){
  .service-hero-image[src*="armor-design.jpg"]{
    object-position: 50% 95%;
  }
}

/* mobile */
@media (max-width: 640px){
  .service-hero-image[src*="armor-design.jpg"]{
    object-position: 50% 100%;
    height: 320px;
  }
}

.image-overlay-wrapper{
  position:relative;
}
.image-overlay-label{
  position:absolute;
  bottom:20px;
  left:20px;
  background:rgba(8,22,36,0.75);
  color:#fff;
  padding:10px 16px;
  font-size:14px;
  font-weight:600;
  border-radius:6px;
  backdrop-filter:blur(4px);
}
@media (max-width:640px){
  .image-overlay-label{
    font-size:12px;
    padding:8px 12px;
  }
}

/* Pile image bottom focus */
.service-hero-image[src*="pile-design.jpg"],
.card img[src*="pile-design.jpg"]{
  object-fit: cover;
  object-position: 50% 90%;
}

@media (max-width: 980px){
  .service-hero-image[src*="pile-design.jpg"],
  .card img[src*="pile-design.jpg"]{
    object-position: 50% 95%;
  }
}

@media (max-width: 640px){
  .service-hero-image[src*="pile-design.jpg"],
  .card img[src*="pile-design.jpg"]{
    object-position: 50% 100%;
  }
}


/* Pier image specific crop */
.service-hero-image[src*="pier-design-custom.jpg"],
.card img[src*="pier-design-custom.jpg"]{
  object-fit: cover;
  object-position: 50% 78%;
}
@media (max-width: 980px){
  .service-hero-image[src*="pier-design-custom.jpg"],
  .card img[src*="pier-design-custom.jpg"]{
    object-position: 50% 84%;
  }
}
@media (max-width: 640px){
  .service-hero-image[src*="pier-design-custom.jpg"],
  .card img[src*="pier-design-custom.jpg"]{
    object-position: 50% 90%;
  }
}


/* Pier image top-focused crop */
.service-hero-image[src*="pier-design-global.jpg"],
.card img[src*="pier-design-global.jpg"]{
  object-fit: cover;
  object-position: 50% 10%;
}

@media (max-width: 980px){
  .service-hero-image[src*="pier-design-global.jpg"],
  .card img[src*="pier-design-global.jpg"]{
    object-position: 50% 5%;
  }
}

@media (max-width: 640px){
  .service-hero-image[src*="pier-design-global.jpg"],
  .card img[src*="pier-design-global.jpg"]{
    object-position: 50% 0%;
  }
}


/* Hero composition refinement */
.hero h1{
  max-width:10.5ch;
  margin-bottom:14px;
}
.hero p{
  max-width:50ch;
}
.hero-actions{
  margin-top:22px;
}

@media (max-width: 980px){
  .hero .container{
    justify-content:flex-start;
    min-height:72vh;
  }
  .hero-card{
    transform:translateY(0);
  }
}

@media (max-width: 640px){
  .hero .container{
    min-height:62vh;
    align-items:flex-end;
    padding-bottom:22px;
  }
  .hero-card{
    max-width:100%;
    padding:24px;
    border-radius:22px;
  }
  .hero h1{
    max-width:none;
  }
  .hero p{
    max-width:none;
  }
}


.card-image{
  width:100%;
  height:280px;
  object-fit:cover;
  object-position:50% 50%;
  display:block;
  border-radius:20px;
  margin:0 0 22px;
}

@media (max-width: 640px){
  .card-image{
    height:220px;
    margin-bottom:18px;
  }
}


/* Service-card image tuning for auto-assigned images */
.card img[src*="seawall-design.jpg"]{ object-fit:cover; object-position:50% 58%; }
.card img[src*="floating-dock.jpg"]{ object-fit:cover; object-position:50% 58%; }
.card img[src*="pile-design.jpg"]{ object-fit:cover; object-position:50% 90%; }
.card img[src*="gangway-design.jpg"]{ object-fit:cover; object-position:50% 14%; }
.card img[src*="fender-design.jpg"]{ object-fit:cover; object-position:50% 72%; }
.card img[src*="riprap-design.jpg"]{ object-fit:cover; object-position:50% 92%; }
.card img[src*="pier-design.jpg"]{ object-fit:cover; object-position:50% 14%; }
.card img[src*="wave-deflector.jpg"]{ object-fit:cover; object-position:50% 42%; }

@media (max-width: 980px){
  .card img[src*="pile-design.jpg"]{ object-position:50% 95%; }
  .card img[src*="riprap-design.jpg"]{ object-position:50% 96%; }
  .card img[src*="pier-design.jpg"],
  .card img[src*="gangway-design.jpg"]{ object-position:50% 8%; }
}

@media (max-width: 640px){
  .card img[src*="pile-design.jpg"]{ object-position:50% 100%; }
  .card img[src*="riprap-design.jpg"]{ object-position:50% 100%; }
  .card img[src*="pier-design.jpg"],
  .card img[src*="gangway-design.jpg"]{ object-position:50% 4%; }
}

/* Floating dock image crop */
.service-hero-image[src*="floating-dock-custom.jpg"],
.card img[src*="floating-dock-custom.jpg"]{
  object-fit:cover;
  object-position:50% 55%;
}

@media (max-width:640px){
  .service-hero-image[src*="floating-dock-custom.jpg"],
  .card img[src*="floating-dock-custom.jpg"]{
    object-position:50% 60%;
  }
}








/* About hero crane alignment (FULL LEFT) */
.hero img[src*="gantry-crane-design.jpg"],
.hero{
  object-position: 0% center;
}





/* Fender image zoom IN */
.service-hero-image[src*="fender-design.jpg"]{
  object-fit: cover;
  object-position: 50% 70%;
  transform: scale(1.15);
}


/* Footer logo */
.footer-logo{
  text-align:center;
  margin-top:20px;
}
.footer-logo img{
  max-width:220px;
  opacity:0.9;
}
