:root{
  --navy:#0b2c48; --red:#b62f2f;
  --blue-050:#f7fbff; --blue-100:#edf4fa; --blue-200:#d9e9f7; --blue-300:#c7def3;
  --bg:#fff; --ink:#1b2530; --muted:#66707e;
  --line:1px solid rgba(11,44,72,.12);
  --radius:16px; --shadow:0 10px 28px rgba(0,0,0,.06);
  --maxw:1200px;
  --navH:72px; --padX:20px;
}
@media (max-width:768px){ :root{ --navH:60px; } }

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0}
body{
  font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink); background:var(--bg); line-height:1.55; -webkit-font-smoothing:antialiased;
  padding-top:var(--navH);
}
a{color:var(--navy)}
.container{max-width:var(--maxw); width:100%; margin-inline:auto; padding-inline:var(--padX)}
.row{display:flex; gap:16px; justify-content:space-between; align-items:center; flex-wrap:wrap}

/* Header */
.topbar{position:fixed; inset:0 0 auto 0; height:var(--navH); z-index:1000; background:#fff; border-bottom:var(--line); display:flex; align-items:center; box-shadow:0 2px 8px rgba(0,0,0,.04)}
.brand-row{display:flex; align-items:center; justify-content:space-between; gap:12px}
.social{display:flex; gap:10px}
.social a{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%; background:var(--blue-100); border:var(--line); transition:.15s}
.social a:hover{transform:translateY(-2px); box-shadow:0 6px 14px rgba(0,0,0,.08); background:#e5eff9}
.social svg{fill:var(--navy)}
nav.primary{display:flex; align-items:center; gap:10px}
nav.primary a{color:var(--navy); text-decoration:none; font-weight:700; padding:10px 12px; border-radius:10px}
nav.primary a:hover{ background:var(--blue-100) }
.btn{appearance:none; border:0; cursor:pointer; font-weight:800; letter-spacing:.02em; padding:12px 18px; border-radius:12px; text-decoration:none; display:inline-flex; align-items:center; gap:10px; box-shadow:var(--shadow)}
.btn-primary{ background:var(--red); color:#fff }
.btn-outline{ background:#fff; color:var(--navy); border:var(--line) }
@media (max-width:640px){ .btn{ width:100%; justify-content:center } }
.hamburger{display:none; background:var(--blue-100); border:var(--line); width:40px; height:40px; border-radius:10px; align-items:center; justify-content:center}
.hamburger span{display:block; width:20px; height:2px; background:var(--navy); position:relative}
.hamburger span::before,.hamburger span::after{content:""; position:absolute; left:0; right:0; height:2px; background:var(--navy)}
.hamburger span::before{top:-6px} .hamburger span::after{top:6px}
@media (max-width:992px){ nav.primary{display:none} .hamburger{display:inline-flex} }
.mobile-panel{position:fixed; inset:var(--navH) 0 auto 0; background:#fff; border-bottom:var(--line); transform:translateY(-110%); transition:.2s ease; z-index:950}
.mobile-panel.open{ transform:none }
.mobile-links{display:grid; gap:6px; padding:12px}
.mobile-links a{display:block; padding:14px 12px; text-decoration:none; color:var(--navy); font-weight:700; border-radius:10px}
.mobile-links a:hover{ background:var(--blue-100) }

/* Hero / slider */
.hero{ position:relative; width:100%; height:calc(100svh - var(--navH)); overflow:hidden }
.hero video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; background:#000; display:none }
.slider{ position:absolute; inset:0; overflow:hidden; background:#000 }
.slides{ display:flex; height:100%; transition:transform .6s ease-in-out }
.slide{ flex:0 0 100%; height:100%; position:relative; color:#fff; background-repeat:no-repeat; background-size:cover; background-position:center }

/* Contrast overlay (subtle) */
.slide::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,.10) 40%, rgba(0,0,0,.30) 100%),
    radial-gradient(ellipse at center, rgba(11,44,72,.10), rgba(11,44,72,0) 70%);
}

.label{ position:absolute; inset:auto 0 9% 0; z-index:2; display:grid; place-items:center; text-align:center; padding:0 var(--padX) }
.logo-wrap{ display:inline-flex; align-items:center; gap:14px; background:rgba(255,255,255,.9); padding:10px 14px; border-radius:999px; border:var(--line) }
.logo-wrap img{ height:42px; width:auto }
.title{ margin:14px 0 6px; font-family:Merriweather,Georgia,serif; font-weight:800; font-size:clamp(24px,5vw,44px) }
.sub{ font-size:clamp(15px,2.4vw,18px) }
.arrow{ position:absolute; top:50%; transform:translateY(-50%); z-index:4; background:rgba(255,255,255,.92); border:1px solid rgba(255,255,255,.75); width:44px; height:44px; border-radius:50%; display:grid; place-items:center; cursor:pointer; box-shadow:0 4px 12px rgba(0,0,0,.28) }
.arrow.left{left:14px} .arrow.right{right:14px}
.dots{position:absolute; bottom:14px; left:50%; transform:translateX(-50%); z-index:4; display:flex; gap:8px; filter:drop-shadow(0 2px 6px rgba(0,0,0,.35))}
.dot{width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.55); border:1px solid rgba(255,255,255,.9)}
.dot.active{background:#fff}

/* Sections */
.strip{ background:#fff; color:var(--navy); text-align:center; font-weight:700; padding:16px 0; border-top:var(--line); border-bottom:var(--line) }
.section{ padding:64px 0; background:#fff }
.section--band{ background:var(--blue-050); border-top:1px solid #e3eef8; border-bottom:1px solid #e3eef8 }
.section--flush-bottom{ padding-bottom:24px }
.section--flush-top{ padding-top:24px }
.section header.section-hd{ display:flex; justify-content:space-between; align-items:end; gap:16px; margin:0 0 14px; border-bottom:4px solid var(--blue-100); padding-bottom:10px }
.section h2{ font-family:Merriweather,Georgia,serif; color:var(--navy); font-size:clamp(24px,3.2vw,38px); margin:0 }
.lead{ color:#2b3642; margin:8px 0 0 }

/* Services grid */
.grid.services{ display:grid; gap:16px; grid-template-columns:repeat(auto-fit, minmax(250px, 1fr)); }
.card{ background:#fff; border:var(--line); border-radius:16px; padding:22px; transition:.12s; }
.section--band .card{ border-color:#dae7f3; box-shadow:0 6px 18px rgba(11,44,72,.06) }
.card h3{ margin:0 0 8px; color:var(--navy); font-size:1.1rem }
.service{ cursor:pointer; outline:none }
.service:hover{ transform:translateY(-2px); box-shadow:var(--shadow); background:var(--blue-100); border-color:#cbdcec }
.service:focus-visible{ box-shadow:0 0 0 3px var(--blue-300); background:var(--blue-100) }
.service.active{ background:var(--blue-200); border-color:#b9d3ee; box-shadow:0 8px 22px rgba(11,44,72,.12) }

/* Contact layout */
.contact-grid{ display:grid; gap:20px; grid-template-columns:1.2fr .8fr }
@media (max-width:992px){ .contact-grid{ grid-template-columns:1fr 1fr } }
@media (max-width:640px){ .contact-grid{ grid-template-columns:1fr } }

/* One-line email fix */
.email-oneline{ white-space:nowrap; }

/* Gallery */
.gallery{ display:grid; gap:16px; grid-template-columns:repeat(12,1fr); }
.gallery figure{ grid-column:span 4; margin:0; background:#fff; border:var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:0 6px 18px rgba(11,44,72,.06) }
.gallery img{display:block; width:100%; height:260px; object-fit:cover}
.gallery figcaption{padding:12px 14px; font-size:.95rem; color:#2b3642}
@media (max-width:900px){ .gallery figure{ grid-column:span 6 } .gallery img{ height:220px } }
@media (max-width:560px){ .gallery figure{ grid-column:span 12 } .gallery img{ height:200px } }

/* Footer */
footer{ background:#fff; border-top:var(--line); color:var(--muted); padding:22px 0 }

/* Per-slide framing tweaks (only what we need) */


#slides .slide[style*="Carpet2.jpg"]{ background-position:50% 68% !important; }
@media (max-width:520px){
  #slides .slide[style*="Carpet2.jpg"]{ background-position:50% 70% !important; }
  #slides .slide[style*="Carpet2.jpg"] .label{ inset:auto 0 12% 0 !important; }
}
#slides .slide[style*="tile-grout.jpeg"]{ background-position:60% 50% }
#slides .slide[style*="upholstery1.jpeg"]{ background-position:50% 50% }
#slides .slide[style*="Gutters.png"]{ background-position:50% 46% }
#slides .slide[style*="Test.jpeg"]{ background-position:50% 46% }
#slides .slide[style*="RealtorExpress3.jpeg"]{ background-position:50% 58% }
@media (max-width:430px){
  #slides .slide[style*="RealtorExpress3.jpeg"]{ background-position:3% 32% !important; }
  #slides .slide[style*="RealtorExpress3.jpeg"] .label{ inset:auto 0 10% 0 !important; }
}




/* First slide: remove tint if you want */
#slides .slide:first-child::after{ background:none !important; content:none !important }

/* Motion reduce */
@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto} .slides{transition:none} }


/* =========================
   ABOUT PAGE (layout only)
   ========================= */
.about-grid{
  display:grid;
  gap:22px;
  grid-template-columns:1.2fr .8fr;
  align-items:start;
}
.about-main{ grid-column:1 / 2; }
.about-aside{
  grid-column:2 / 3;
  background:var(--blue-050);
  border:1px solid #e3eef8;
  border-radius:var(--radius);
  padding:18px;
}
.tagline{ font-weight:800; color:var(--navy); margin:0 0 6px; }
.mission{ margin:0; color:#2b3642; }

@media (max-width:900px){
  .about-grid{ grid-template-columns:1fr; }
  .about-main, .about-aside{ grid-column:1 / -1; }
}

/* Shared contact grid (keep if not already in style.css) */
.contact-grid{ display:grid; gap:20px; grid-template-columns:1.2fr .8fr; }
@media (max-width:992px){ .contact-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .contact-grid{ grid-template-columns:1fr; } }

/* Keep the email on one line on the Contact card */
.email-oneline{
  white-space: nowrap;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}
/* Tiny phones: nudge size down so it still fits without wrapping */
@media (max-width:380px){
  .email-oneline{ font-size: .95rem; }
}

