/* ===== Base / Theme ===== */
:root{
  --blue: #0b5cab;
  --blue-dark: #083e77;
  --red: #c62828;
  --bg: #f6f7f9;
  --panel: #ffffff;
  --text: #1d1d1f;
  --muted: #6b7280;
  --line: #e5e7eb;
  --shadow: 0 2px 14px rgba(0,0,0,.06);
}

*{box-sizing:border-box}
html,body{height:100%}
html, body { overflow-x: hidden; }
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.55;
}
img{max-width:100%; display:block}
.wrap{width:min(1200px,92%); margin:0 auto}

/* ===== Utility Bar ===== */
.utility{
  background:var(--blue);
  color:#fff;
  font-weight:600;
  letter-spacing:.2px;
  font-size:.95rem;
}
.util-inner{display:flex; align-items:center; justify-content:space-between; padding:.6rem 0}
.util-phone{color:#fff; text-decoration:none}
.util-phone:hover{text-decoration:underline}

/* ===== Header (black with logo) ===== */
.site-header{
  background:#000;                 /* changed to black */
  position:sticky; top:0; z-index:30;
  box-shadow:var(--shadow);
}
.header-inner{display:flex; align-items:center; justify-content:space-between; padding:1.05rem 0}
.brand-link{display:flex; align-items:center; text-decoration:none}
.brand-logo{
  height: 160px;                    /* larger logo */
  width: auto;
  display: block;
}
.main-nav a{
  text-decoration:none; color:#fff;/* white nav text on black header */
  margin-left:1.25rem; font-weight:600;
}
.main-nav a:first-child{margin-left:0}
.btn.btn-outline{
  background: transparent; color:#fff; border-color:#fff; /* white outline button */
}
.btn.btn-outline:hover{background: rgba(255,255,255,.08)}

/* Buttons */
.btn{
  display:inline-block; cursor:pointer; user-select:none;
  border-radius:6px; border:1px solid transparent;
  padding:.7rem 1rem; font-weight:700; text-decoration:none;
}
.btn-primary{background:var(--red); color:#fff; border-color:var(--red)}
.btn-primary:hover{filter:brightness(.95)}
.btn-secondary{background:var(--blue); color:#fff; border-color:var(--blue)}
.btn-secondary:hover{filter:brightness(.97)}
.btn-lg{padding:.9rem 1.25rem; font-size:1.05rem}
.btn-sm{padding:.45rem .75rem; font-size:.9rem}

/* ===== Hero ===== */
.hero{position:relative; background:#000; overflow:hidden}
.hero-bg{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover;
  opacity:.38; /* readable text over photo */
  filter:saturate(.95) contrast(1.05) brightness(.9);
}
.hero-inner{position:relative; min-height:62vh; display:flex; align-items:center}
.hero-copy{max-width:720px; color:#fff; padding:4rem 0}
.hero-copy h1{
  margin:0 0 .35rem 0;
  font-size:clamp(30px,5vw,46px);
  line-height:1.15; letter-spacing:.2px;
}
.hero-copy p{margin:.4rem 0 1rem; font-size:clamp(16px,2.2vw,19px); color:#e6e9ee}
.hero-cta{display:flex; gap:.75rem; flex-wrap:wrap; margin:.75rem 0 1rem}
.trust-list{
  display:flex; gap:1rem; flex-wrap:wrap;
  padding:0; margin:.5rem 0 0; list-style:none; color:#dfe4ea;
  font-size:.95rem;
}

/* ===== Sections ===== */
.section{padding:3rem 0}
.section-muted{background:#f2f4f7}
.section-head{text-align:center; margin:0 0 1.25rem}
.section-head h2{margin:.1rem 0 .25rem; font-size:clamp(22px,3.4vw,34px)}
.section-head p{margin:0; color:var(--muted)}

/* ===== Services ===== */
.cards{
  margin-top:1.25rem;
  display:grid; gap:1rem;
  grid-template-columns:repeat(12,1fr);
}
.card{
  grid-column:span 4;
  background:var(--panel); border:1px solid var(--line);
  border-radius:8px; box-shadow:var(--shadow);
  padding:1.25rem;
}
.card h3{margin:.1rem 0 .35rem; font-size:1.15rem}
.card p{margin:0; color:var(--muted)}

/* ===== Areas ===== */
.areas-grid{
  margin-top:.75rem;
  display:grid; gap:.6rem;
  grid-template-columns:repeat(12,1fr);
}
.areas-grid span{
  grid-column:span 3;
  background:#fff; border:1px solid var(--line); border-radius:20px;
  padding:.5rem .75rem; text-align:center; box-shadow:var(--shadow);
  font-weight:600; color:#273547;
  line-height:1.2;
}

/* ===== Gallery ===== */
.gallery{
  display:grid; gap:.9rem; margin-top:1rem;
  grid-template-columns:repeat(12,1fr);
}
.gallery img{
  grid-column:span 4; aspect-ratio:4/3; object-fit:cover;
  border-radius:8px; border:1px solid var(--line); box-shadow:var(--shadow);
}

/* ===== Footer ===== */
.site-footer{background:var(--blue-dark); color:#fff}
.footer-inner{
  display:grid; gap:1rem; align-items:start;
  grid-template-columns:repeat(12,1fr);
  padding:1.25rem 0;
}
.footer-col{grid-column:span 4}
.footer-phone{color:#fff; text-decoration:none; font-weight:800}
.footer-phone:hover{text-decoration:underline}
.footer-nav a{color:#cfe1ff; text-decoration:none; display:inline-block; margin:.15rem .75rem .15rem 0}
.footer-nav a:hover{text-decoration:underline}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.15);
  text-align:center; padding:.9rem 0; color:#e5efff; font-size:.95rem;
}

/* ===== Sticky Call Button (mobile) ===== */
.call-now{
  position:fixed; left:0; right:0; bottom:0; z-index:50;
  background:linear-gradient(90deg, var(--red), #e03a3a);
  color:#fff; text-align:center; text-decoration:none; font-weight:800;
  padding:14px 16px;
  border-top:1px solid rgba(255,255,255,.25);
  padding-bottom:calc(14px + env(safe-area-inset-bottom));
}
.call-now:active{filter:brightness(.95)}
@media (min-width: 900px){ .call-now{display:none} }

/* ===== Mobile polish ===== */
@media (max-width: 640px){
  .utility { font-size: 1rem; }
  .util-phone { font-size: 1.05rem; font-weight: 800; }
  .main-nav{display:none}                        /* cleaner header on phones */
  .hero-inner{min-height:52vh}
  .hero-copy{padding:2.25rem 0}
  .hero-cta .btn{ width:100%; text-align:center }/* full-width buttons */
  .cards .card,
  .gallery img,
  .areas-grid span{grid-column:span 12}
  .cards{gap:1rem}
  .gallery{gap:.75rem}
}

@media (max-width: 1024px){
  .cards .card{grid-column:span 6}
  .gallery img{grid-column:span 6}
  .areas-grid span{grid-column:span 4}
}





