
:root{
  --navy:#16324F;
  --slate:#2F3A45;
  --amber:#E89B1C;
  --bg:#F7F9FB;
  --text:#1E2933;
  --line:#D9E1E8;
  --white:#fff;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.65}
a{color:var(--navy);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.site-shell > div[dm\:templateorder]{display:block}
.dmHomeRespTmpl{max-width:1180px;margin:0 auto;padding:20px}
.dmRespRow{background:var(--white);border:1px solid var(--line);border-radius:22px;padding:28px;margin:18px 0;box-shadow:0 10px 24px rgba(22,50,79,.05)}
.dmRespRow:first-child{background:linear-gradient(135deg,var(--navy),#214a73);color:#fff;border:none;padding:52px 36px}
.dmRespRow:first-child h1, .dmRespRow:first-child a, .dmRespRow:first-child p{color:#fff}
.dmRespColsWrapper{display:flex;gap:28px;flex-wrap:wrap;align-items:flex-start}
.dmRespCol{flex:1 1 0;min-width:280px}
.large-12,.medium-12,.small-12{flex-basis:100%}
.large-7{flex:0 0 calc(58.333% - 14px)}
.large-6{flex:0 0 calc(50% - 14px)}
.large-5{flex:0 0 calc(41.667% - 14px)}
.large-4{flex:0 0 calc(33.333% - 19px)}
.text-align-center{text-align:center}
.text-align-left{text-align:left}
h1,h2,h3{margin:0 0 14px;color:var(--navy);line-height:1.15}
h1{font-size:clamp(2rem,4vw,3.5rem)}
h2{font-size:clamp(1.6rem,3vw,2.45rem)}
h3{font-size:clamp(1.15rem,2vw,1.45rem)}
p,ul{margin:0 0 16px}
strong{font-weight:800}
.imageWidget img,.injected-image img{border-radius:18px;box-shadow:0 14px 28px rgba(22,50,79,.14);object-fit:cover}
.dmPhotoGalleryHolder{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.photoGalleryThumbs{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 10px 24px rgba(22,50,79,.06)}
.photoGalleryThumbs .image-container img{aspect-ratio:4/3;object-fit:cover;width:100%}
.caption-container{padding:14px 16px}
.caption-title{font-size:1rem;margin:0;color:var(--navy)}
.caption-text{display:none}
.logo-strip{display:flex;gap:22px;justify-content:center;align-items:center;flex-wrap:wrap;padding:8px 0 18px}
.logo-strip img{max-height:84px;width:auto;object-fit:contain;background:#fff;border-radius:12px;padding:6px 10px;border:1px solid var(--line)}
.logo-strip.compact img{max-height:70px}
.dmform,.site-form{background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:24px}
.dmform-title{font-size:1.55rem;color:var(--navy);margin-bottom:18px}
.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.field.full{grid-column:1/-1}
.field label{display:block;font-weight:700;color:var(--slate);margin-bottom:8px}
.field input,.field textarea{width:100%;padding:14px 15px;border:1px solid #c6d1db;border-radius:12px;font:inherit;background:#fff}
.form-actions{margin-top:18px}
button,input[type=submit]{background:var(--amber);color:#1f2933;border:none;border-radius:12px;padding:14px 22px;font-weight:800;font:inherit;cursor:pointer}
.defaultList.bullet{padding-left:22px}
.defaultList.bullet li{margin-bottom:10px}
#ContactUs,.u_ContactUs{scroll-margin-top:90px}
@media (max-width:900px){
  .large-7,.large-6,.large-5,.large-4,.dmRespCol{flex-basis:100%}
  .form-grid{grid-template-columns:1fr}
  .dmRespRow:first-child{padding:36px 22px}
}

.hero-visual img{width:100%;aspect-ratio:16/10;object-fit:cover;border:4px solid rgba(255,255,255,.12)}
.dmRespRow:first-child .imageWidget{height:100%}

.top-nav{max-width:1180px;margin:16px auto 0;padding:0 20px;display:flex;justify-content:flex-end;gap:20px;font-weight:700}
.top-nav a{color:var(--navy);background:#fff;border:1px solid var(--line);padding:10px 14px;border-radius:999px;box-shadow:0 6px 18px rgba(22,50,79,.06)}
.top-nav a:hover{text-decoration:none;background:var(--bg)}
.photoGalleryThumbs img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.dmPhotoGalleryHolder.gallery4inArow{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:20px}
.dmPhotoGalleryHolder.gallery4inArow .photoGalleryThumbs>div:last-child{padding:14px 16px}
.logo-strip{display:flex;justify-content:center;align-items:center;gap:22px;flex-wrap:wrap}
.logo-strip .dmRespCol{flex:0 0 auto;min-width:0}
@media (max-width:900px){.dmPhotoGalleryHolder.gallery4inArow{grid-template-columns:1fr}.top-nav{justify-content:center;flex-wrap:wrap}}


/* Latest visual fixes */
.dmRespRow:first-child h1 span{color:#fff !important}
.hero-visual img.hero-portrait{object-fit:contain;object-position:center top;background:rgba(255,255,255,.08)}
#GutterInspections .blue-pill{background:linear-gradient(135deg,var(--navy),#214a73);border:none;color:#fff;padding:32px}
#GutterInspections .blue-pill h2,
#GutterInspections .blue-pill p,
#GutterInspections .blue-pill span,
#GutterInspections .blue-pill strong,
#GutterInspections .blue-pill a{color:#fff !important}
#GutterInspections .blue-pill a{text-decoration:underline}
.photoGalleryThumbs img.portrait-fit{object-fit:contain !important;background:#eef3f7}
