/* ============================================================
   Peninsula Leak 'n' Locate — Site Stylesheet
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  color: #1a1a1a;
  background: #f5f7fa;
  line-height: 1.7;
}

a { color: inherit; text-decoration: none; }

/* ── HEADER ── */
.site-header {
  background: #0C3D6E;
  padding: 1rem 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}
.header-logo { display: flex; align-items: center; gap: 14px; }
.header-logo img { height: 64px; width: auto; }
.header-logo-text { color: #fff; }
.header-logo-text strong { display: block; font-size: 17px; font-weight: 600; letter-spacing: 0.01em; }
.header-logo-text span { font-size: 12px; color: #93bbdf; letter-spacing: 0.05em; text-transform: uppercase; }
.header-contact { text-align: right; }
.header-contact a { display: block; color: #fff; font-size: 20px; font-weight: 600; letter-spacing: 0.02em; }
.header-contact span { display: block; font-size: 12px; color: #93bbdf; }

/* ── NAV ── */
.site-nav {
  background: #0a3360;
  padding: 0 2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border-top: 1px solid #1a5090;
}
.site-nav a {
  color: #c5ddf2;
  font-size: 13px;
  padding: 0.65rem 1rem;
  display: block;
  font-weight: 500;
  transition: background 0.15s, color 0.15s;
  white-space: nowrap;
}
.site-nav a:hover,
.site-nav a.active { background: #185FA5; color: #fff; }

/* ── HERO ── */
.hero {
  background: linear-gradient(135deg, #0C3D6E 0%, #185FA5 60%, #1D7DC4 100%);
  color: #fff;
  padding: 3.5rem 2rem 3rem;
  text-align: center;
}
.hero-eyebrow { font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: #93bbdf; margin-bottom: 1rem; }
.hero h1 { font-size: clamp(24px, 4vw, 36px); font-weight: 700; line-height: 1.2; margin-bottom: 1rem; max-width: 640px; margin-left: auto; margin-right: auto; }
.hero p { font-size: 16px; color: #c5ddf2; max-width: 560px; margin: 0 auto 1rem; line-height: 1.7; }
.hero-location { margin-top: 1.25rem; font-size: 13px; color: #93bbdf; }
.hero-small { padding: 2.75rem 2rem 2.25rem; }
.hero-small h1 { font-size: clamp(22px, 4vw, 32px); }

/* ── LAYOUT ── */
.container { max-width: 960px; margin: 0 auto; padding: 0 1.5rem; }
.section { padding: 3rem 0; }
.section-sm { padding: 2.5rem 0; }
.section-bg { background: #fff; }
.section-eyebrow { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: #185FA5; margin-bottom: 0.5rem; font-weight: 600; }
.section h2 { font-size: clamp(20px, 3vw, 26px); font-weight: 700; margin-bottom: 0.5rem; color: #0C3D6E; }
.section-intro { font-size: 15px; color: #555; max-width: 660px; margin-bottom: 2rem; line-height: 1.75; }
.body-text { font-size: 15px; color: #444; line-height: 1.8; margin-bottom: 1rem; max-width: 720px; }
.divider { border: none; border-top: 1px solid #dde4ee; }

/* ── SERVICE CARDS ── */
.services-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 16px; }
.service-card { background: #f5f7fa; border: 1px solid #dde4ee; border-radius: 10px; padding: 1.4rem; transition: box-shadow 0.2s; }
.service-card:hover { box-shadow: 0 4px 16px rgba(12,61,110,0.10); }
.service-icon { font-size: 28px; margin-bottom: 0.75rem; }
.service-card h3 { font-size: 15px; font-weight: 600; color: #0C3D6E; margin-bottom: 0.4rem; }
.service-card p { font-size: 13px; color: #555; line-height: 1.6; margin-bottom: 0.75rem; }
.tags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 0.5rem; }
.tag { font-size: 11px; background: #e0ebf7; color: #0C3D6E; padding: 2px 9px; border-radius: 20px; font-weight: 500; }

/* ── SUBURB CHIPS ── */
.suburb-chip-row { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 1.25rem; }
.suburb-chip { font-size: 13px; background: #e0ebf7; color: #0C3D6E; padding: 5px 14px; border-radius: 20px; font-weight: 600; }
.suburb-list { display: flex; flex-wrap: wrap; gap: 7px; }
.suburb { font-size: 12px; background: #f0f4fa; border: 1px solid #ccd8ec; border-radius: 20px; padding: 3px 12px; color: #444; }

/* ── BANNERS ── */
.info-banner { background: #e8f5ee; border: 1px solid #a3d9bb; border-left: 4px solid #1D9E75; border-radius: 10px; padding: 1.25rem 1.5rem; display: flex; gap: 1rem; align-items: flex-start; margin: 1.75rem 0; }
.info-banner .icon { font-size: 24px; flex-shrink: 0; margin-top: 2px; }
.info-banner h3 { font-size: 15px; font-weight: 600; color: #0a4a2c; margin-bottom: 0.3rem; }
.info-banner p { font-size: 13px; color: #1D6B4A; line-height: 1.6; margin: 0; }

.warn-banner { background: #FAEEDA; border: 1px solid #EF9F27; border-left: 4px solid #BA7517; border-radius: 10px; padding: 1.4rem 1.6rem; display: flex; gap: 1rem; align-items: flex-start; margin-bottom: 2rem; }
.warn-banner .icon { font-size: 26px; flex-shrink: 0; margin-top: 2px; }
.warn-banner h3 { font-size: 16px; font-weight: 700; color: #633806; margin-bottom: 0.4rem; }
.warn-banner p { font-size: 14px; color: #854F0B; line-height: 1.65; margin: 0; }

/* ── WHY GRID ── */
.why-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 16px; }
.why-card { background: #f5f7fa; border-radius: 10px; padding: 1.25rem; text-align: center; border: 1px solid #dde4ee; }
.why-icon { font-size: 28px; margin-bottom: 0.6rem; }
.why-card strong { display: block; font-size: 14px; color: #0C3D6E; margin-bottom: 0.3rem; }
.why-card p { font-size: 13px; color: #666; line-height: 1.5; }

/* ── AUDIENCE GRID ── */
.audience-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; }
.audience-card { background: #fff; border: 1px solid #dde4ee; border-radius: 10px; padding: 1rem 1.25rem; display: flex; align-items: flex-start; gap: 10px; }
.audience-card .icon { font-size: 20px; margin-top: 2px; flex-shrink: 0; }
.audience-card strong { display: block; font-size: 14px; color: #0C3D6E; font-weight: 600; }
.audience-card span { font-size: 12px; color: #666; }

/* ── PROCESS STEPS ── */
.process-list { display: flex; flex-direction: column; gap: 14px; margin-top: 1.25rem; }
.process-step { display: flex; gap: 1rem; align-items: flex-start; }
.step-num { width: 32px; height: 32px; border-radius: 50%; background: #0C3D6E; color: #fff; font-size: 14px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 2px; }
.process-step h3 { font-size: 15px; font-weight: 600; color: #0C3D6E; margin-bottom: 0.25rem; }
.process-step p { font-size: 13px; color: #555; line-height: 1.6; margin: 0; }

/* ── SIGNS GRID ── */
.signs-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; margin-top: 1rem; }
.sign-chip { background: #FCEBEB; border: 1px solid #F09595; border-radius: 8px; padding: 0.75rem 1rem; font-size: 13px; color: #791F1F; font-weight: 500; }

/* ── FAQ ── */
.faq-list { display: flex; flex-direction: column; gap: 16px; margin-top: 1rem; }
.faq-item { background: #fff; border: 1px solid #dde4ee; border-radius: 10px; padding: 1.25rem 1.4rem; }
.faq-item h3 { font-size: 15px; font-weight: 600; color: #0C3D6E; margin-bottom: 0.4rem; }
.faq-item p { font-size: 13px; color: #555; line-height: 1.65; margin: 0; }

/* ── AREAS BOX ── */
.areas-box { background: #fff; border: 1px solid #dde4ee; border-radius: 10px; padding: 1.5rem; }
.areas-box h3 { font-size: 15px; font-weight: 600; color: #0C3D6E; margin-bottom: 1rem; }

/* ── CTA STRIP ── */
.cta-strip { background: #0C3D6E; color: #fff; text-align: center; padding: 1.75rem 1.5rem; border-radius: 10px; margin-top: 2rem; }
.cta-strip h3 { font-size: 18px; font-weight: 700; margin-bottom: 0.5rem; }
.cta-strip p { color: #c5ddf2; font-size: 14px; margin-bottom: 0.75rem; }
.cta-strip a.phone { font-size: 22px; font-weight: 700; color: #fff; display: inline-block; }

/* ── INTERNAL LINKS ── */
.page-links { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 1.25rem; }
.page-link { font-size: 13px; background: #e0ebf7; color: #0C3D6E; padding: 6px 14px; border-radius: 20px; font-weight: 600; border: 1px solid #b8d0ec; transition: background 0.15s; }
.page-link:hover { background: #185FA5; color: #fff; }

/* ── FOOTER ── */
.site-footer { background: #0C3D6E; color: #93bbdf; text-align: center; padding: 2rem 1rem 1.5rem; font-size: 13px; line-height: 1.9; margin-top: 0; }
.site-footer strong { color: #fff; }
.footer-links { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px 20px; margin-top: 0.75rem; }
.footer-links a { color: #93bbdf; font-size: 12px; }
.footer-links a:hover { color: #fff; }

/* ── RESPONSIVE ── */
@media (max-width: 700px) {
  .site-header { flex-direction: column; text-align: center; }
  .header-contact { text-align: center; }
  .hero { padding: 2.5rem 1.25rem 2rem; }
  .site-nav { padding: 0 0.5rem; }
  .site-nav a { font-size: 12px; padding: 0.55rem 0.6rem; }
}
