
:root{ --brand: var(--brand); --brand-2: var(--brand-2); --accent:#0077b6; --bg:#ffffff; --text:#222; --font: var(--font-sans); --maxw:1100px; --shadow:0 10px 30px rgba(0,0,0,.08) }
*{box-sizing:border-box} html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.55}
a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:20px}
.site-header{background:#fff;border-bottom:1px solid #e6e6e6}
.site-header .inner{display:flex;align-items:center;gap:20px;padding:14px 20px}
.logo img{height:var(--logo-height);width:auto} .nav{margin-left:auto;display:flex;gap:18px} .nav a{text-transform:uppercase;letter-spacing:.6px;font-size:.9rem;color:#222}
.cta{display:inline-block;padding:10px 16px;border-radius:4px;background:var(--brand);color:#fff}
.hero-banner{background:#f5f5f5 url('../oldsite/banner.jpg') center/cover no-repeat;padding:80px 0;border-bottom:1px solid #eee}
.hero-banner .container{display:flex;align-items:center;gap:24px}
.headline{background:rgba(255,255,255,.9);padding:18px 20px;border-radius:6px;box-shadow:0 8px 20px rgba(0,0,0,.05)}
.headline h1{margin:0 0 8px 0;font-size:2rem} .headline p{margin:0;color:#444}
.page-hero{background:#eef5ef url('../oldsite/default-hero.jpg') center/cover no-repeat;padding:64px 0;border-bottom:1px solid #ededed}
.page-hero .container{display:flex;align-items:center;justify-content:space-between;gap:20px}
.footer{background:#f4f4f4;color:#333;margin-top:40px} .footer a{color:#333} .footer .inner{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:30px 20px;max-width:var(--maxw);margin:0 auto}
.gallery{display:flex;gap:12px;flex-wrap:wrap;margin:1rem 0} .gallery img{max-width:32%;height:auto;border-radius:6px}
.notice{padding:10px 12px;border:1px dashed #b9cabc;background:#f8fff9;border-radius:8px;color:#3b5d45}
form.lead{display:grid;grid-template-columns:1fr 1fr;gap:12px}
form.lead input, form.lead select, form.lead textarea{width:100%;padding:10px;border:1px solid #cfd8d3;border-radius:8px;font-size:1rem}
form.lead textarea{grid-column:1/-1;min-height:120px} .actions{grid-column:1/-1}
button.btn{background:var(--brand);color:#fff;border:none;padding:12px 16px;border-radius:8px;font-size:1rem;cursor:pointer}
button.btn:hover{background:var(--brand-2)}
@media (max-width:800px){ .site-header .inner{flex-wrap:wrap} .nav{flex-wrap:wrap} .hero-banner .container{flex-direction:column} }


/* Sticky conversion bar */
.sticky-bar{position:fixed;bottom:0;left:0;right:0;background:#0b6b3a;color:#fff;z-index:9999;box-shadow:0 -6px 20px rgba(0,0,0,.15);}
.sticky-bar .inner{max-width:1100px;margin:0 auto;display:flex;gap:12px;align-items:center;justify-content:space-between;padding:10px 14px}
.sticky-bar a{color:#fff;text-decoration:none;font-weight:700}
.sticky-bar .cta{background:#fff;color:#0b6b3a;border-radius:999px;padding:8px 14px;font-weight:700}
@media (max-width:700px){ .sticky-bar .inner{flex-direction:column;gap:8px} }


/* === Pro visual upgrade === */
:root{
  --brand: var(--brand); --brand-2: var(--brand-2); --accent: var(--accent); --ink: var(--ink);
  --muted:#667085; --bg:#ffffff; --paper: var(--paper); --radius:18px; --shadow:0 12px 30px rgba(0,0,0,.08);
  --maxw:1200px; --header-h:72px;
}
body{color:var(--ink)}
.container{max-width:var(--maxw)}
.site-header{position:sticky; top:0; background:#fff; border-bottom:1px solid #eaeaea; z-index:30}
.site-header .inner{height:var(--header-h); display:flex; align-items:center; gap:24px; padding:0 20px}
.nav a{font-weight:600; color:#0f1720; opacity:.9}
.nav a:hover{opacity:1}
.hero.hero-pro{position:relative; padding:80px 0; background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.35)), url('assets/oldsite/banner.jpg') center/cover no-repeat; color:#fff}
.hero .kicker{font-weight:700; letter-spacing:.08em; text-transform:uppercase; opacity:.9}
.hero h1{font-size:2.2rem; margin:.25rem 0 .5rem}
.hero p.sub{font-size:1.1rem; opacity:.95; max-width:50ch}
.hero .cta-row{display:flex; gap:12px; flex-wrap:wrap; margin-top:12px}
.hero .cta{background:#fff; color:#0b6b3a; border-radius:999px; padding:10px 16px; font-weight:700}
.hero .mini-form{display:flex; gap:8px; flex-wrap:wrap; margin-top:14px}
.hero .mini-form input{padding:10px 12px; border-radius:10px; border:1px solid #d7e0db}
.section{padding:40px 0}
.section.alt{background:var(--paper); border-top:1px solid #e9eee9; border-bottom:1px solid #e9eee9}
.service-cards{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.service-cards .card{padding:18px; border-radius:var(--radius)}
.service-cards .card h3{margin:.25rem 0}
.trust-strip{display:flex; gap:16px; flex-wrap:wrap; align-items:center; color:#475467}
.trust-strip .badge{background:#fff; border:1px solid #e6ebe6; border-radius:999px; padding:8px 12px; font-weight:600}
.testimonials{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.testimonials .quote{background:#fff; border:1px solid #edf0ed; border-radius:16px; padding:16px}
.footer{margin-top:40px}
/* Mobile */
@media (max-width:900px){
  .service-cards{grid-template-columns:1fr}
  .testimonials{grid-template-columns:1fr}
}


/* === Credibility pass additions === */
.photostrip{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;overflow-x:auto;padding:8px 0}
.photostrip img{width:100%;height:140px;object-fit:cover;border-radius:12px;border:1px solid #e6ebe6}
.spec-table{width:100%;border-collapse:collapse;margin:12px 0;border:1px solid #e6ebe6;border-radius:12px;overflow:hidden}
.spec-table th,.spec-table td{padding:10px;border-bottom:1px solid #eef2ee;text-align:left;background:#fff}
.spec-table th{background:#f7faf7;font-weight:700}
.area-chips{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0}
.area-chips .chip{background:#fff;border:1px solid #e3e9e3;border-radius:999px;padding:6px 10px}
/* Floating 'Text Us' button (mobile) */
@media (max-width: 780px){
  .float-text{position:fixed;right:16px;bottom:84px;background:var(--brand);color:#fff;padding:12px 16px;border-radius:999px;box-shadow:0 10px 30px rgba(0,0,0,.2);z-index:9999;font-weight:700}
  .float-text:hover{opacity:.9}
}


/* --- Contrast fix: CTA buttons --- */
.cta {
  display: inline-block;
  padding: 12px 18px;
  border-radius: 999px;
  background: var(--brand);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  border: 1px solid transparent;
}
.cta:hover { background: var(--brand-2); color: #fff; }

/* Ensure hero CTAs are high-contrast even on light/white sections */
.page-hero .cta { background: var(--brand) !important; color: #fff !important; border-color: transparent !important; }


/* --- Outline variant for CTA (dark green text) --- */
.cta--outline {
  background: #fff !important;
  color: var(--brand) !important;
  border: 1px solid var(--brand) !important;
}
.cta--outline:hover {
  background: var(--brand-2) !important;
  color: #fff !important;
  border-color: var(--brand-2) !important;
}
