/* =============================================================
   McCombs Handyman — shared stylesheet
   Static site. Works from file:// — no external fonts or CDNs.
   ============================================================= */

/* ---------- Design tokens ---------- */
:root {
  /* Neutral base */
  --ink:        #0E0E10;
  --ink-soft:   #1C1C1F;
  --paper:      #FAF8F4;
  --paper-2:    #F1EEE7;
  --line:       #D9D4C8;
  --muted:      #5C5A55;
  --text:       #1A1A1C;

  /* Brand — McCombs Home Renovations (dark + burnt orange) */
  --mccombs-bg:     #0E0E10;
  --mccombs-panel:  #1A1A1D;
  --mccombs-accent: #E8751A;
  --mccombs-accent-2:#FFA24D;
  --mccombs-text:   #F4F1EA;
  --mccombs-mute:   #A7A39A;

  /* Brand — Pawpaw G's Pet Waste Pros (cream + forest green) */
  --pawpaw-bg:      #F5F7EF;
  --pawpaw-panel:   #FFFFFF;
  --pawpaw-accent:  #3E6B2B;
  --pawpaw-accent-2:#5A9C3B;
  --pawpaw-warm:    #E8751A; /* echoes sibling brand */
  --pawpaw-text:    #1E2A14;
  --pawpaw-mute:    #55614A;

  /* Brand — Permanent LED Lighting (deep navy + warm amber) */
  --led-bg:         #0B1424;
  --led-panel:      #122038;
  --led-accent:     #F2B53A;  /* warm-white LED feel */
  --led-accent-2:   #6FB7FF;  /* cool LED accent */
  --led-text:       #EAF1FB;
  --led-mute:       #9FB0C9;

  /* Geometry */
  --container: 1120px;
  --radius:    14px;
  --radius-sm: 8px;
  --shadow:    0 6px 24px rgba(10,10,12,0.10);
  --shadow-lg: 0 18px 50px rgba(10,10,12,0.22);

  /* Type */
  --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  --font-display: Georgia, "Iowan Old Style", "Palatino Linotype",
                  "URW Palladio L", P052, serif;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  line-height: 1.55;
  color: var(--text);
  background: var(--paper);
}
img, svg { max-width: 100%; height: auto; display: block; }
a { color: inherit; }
button { font: inherit; cursor: pointer; }

/* ---------- Layout primitives ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(16px, 4vw, 32px);
}

.section {
  padding-block: clamp(48px, 8vw, 96px);
}

.grid {
  display: grid;
  gap: clamp(16px, 2.5vw, 28px);
}

.cols-3 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.cols-2 { grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); }

.eyebrow {
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 700;
}

h1, h2, h3 { font-family: var(--font-display); letter-spacing: -0.01em; line-height: 1.15; margin: 0 0 .5em; }
h1 { font-size: clamp(2rem, 5vw, 3.2rem); }
h2 { font-size: clamp(1.6rem, 3.6vw, 2.3rem); }
h3 { font-size: 1.2rem; font-family: var(--font-sans); font-weight: 700; }
p  { margin: 0 0 1em; }
ul.plain { list-style: none; padding: 0; margin: 0; }

/* ---------- Top nav (shared) ---------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(250,248,244,0.92);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--line);
}
.site-header .container {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding-block: 12px;
}
.brand {
  display: flex; align-items: center; gap: 12px;
  text-decoration: none; color: var(--text);
  font-weight: 800; letter-spacing: -0.01em;
}
.brand img { width: 40px; height: 40px; border-radius: 8px; object-fit: cover; }
.brand-text small { display: block; font-size: 0.72rem; color: var(--muted); font-weight: 600; }
.brand-text strong { font-size: 1rem; }

.nav { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.nav a {
  text-decoration: none;
  color: var(--text);
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.95rem;
}
.nav a:hover { background: var(--paper-2); }
.nav a.cta {
  background: var(--ink);
  color: var(--paper);
}
.nav a.cta:hover { background: #2a2a2e; }

/* Hamburger toggle button (hidden on desktop) */
.nav-toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--ink);
  border-radius: 4px;
  cursor: pointer;
  font-size: 1.1rem;
  line-height: 1;
  padding: 3px 9px;
  color: var(--ink);
}
body.theme-mccombs .nav-toggle,
body.theme-led .nav-toggle { border-color: rgba(255,255,255,0.6); color: #fff; }
body.theme-mccombs .nav.is-open { background: #1a1a1e; }
body.theme-led .nav.is-open { background: #0f1d35; }

/* Mobile nav */
@media (max-width: 640px) {
  .nav .only-desktop { display: none; }
  .nav .cta { display: none; }
  .nav-toggle { display: block; }

  .nav.is-open {
    position: absolute;
    inset: 100% 0 auto 0;
    background: var(--paper);
    border-bottom: 1px solid var(--border);
    flex-direction: column;
    align-items: stretch;
    padding: 4px 0 8px;
    z-index: 200;
  }
  .nav.is-open .only-desktop {
    display: block;
    border-radius: 0;
    padding: 10px 20px;
    font-size: 1rem;
  }
  .nav.is-open .cta {
    margin: 6px 16px;
    text-align: center;
    border-radius: 6px;
  }
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px;
  background: var(--ink);
  color: var(--paper);
  text-decoration: none;
  border-radius: 999px;
  font-weight: 700;
  border: 2px solid transparent;
  transition: transform .06s ease, background .15s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn.ghost {
  background: transparent;
  color: var(--text);
  border-color: currentColor;
}
.btn.lg { padding: 16px 28px; font-size: 1.05rem; }

/* ---------- Cards ---------- */
.card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: clamp(20px, 3vw, 28px);
  box-shadow: var(--shadow);
  display: flex; flex-direction: column;
}
.card h3 { margin-top: 0; }
.card .spacer { flex: 1; }

/* Business cards on home */
.biz-card {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  color: #fff;
  text-decoration: none;
  padding: clamp(22px, 3vw, 32px);
  min-height: 260px;
  display: flex; flex-direction: column; justify-content: flex-end;
  box-shadow: var(--shadow);
  transition: transform .12s ease, box-shadow .15s ease;
  isolation: isolate;
}
.biz-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.biz-card h3 { font-family: var(--font-display); font-size: clamp(1.4rem,2.6vw,1.9rem); margin-bottom: 6px; }
.biz-card p  { margin: 0; opacity: .92; }
.biz-card .more {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 14px; font-weight: 700; font-size: .95rem;
}
.biz-card.mccombs { background: linear-gradient(135deg, #111 0%, #2a1a0d 60%, var(--mccombs-accent) 160%); }
.biz-card.pawpaw  { background: linear-gradient(135deg, #264b18 0%, var(--pawpaw-accent) 60%, var(--pawpaw-accent-2) 140%); }
.biz-card.led     { background: linear-gradient(135deg, #061024 0%, #143a6d 60%, var(--led-accent) 170%); }

/* ---------- Hero (home) ---------- */
.hero {
  padding-block: clamp(48px, 9vw, 110px);
  background:
    radial-gradient(1200px 500px at 10% -10%, rgba(232,117,26,0.18), transparent 60%),
    radial-gradient(900px 500px at 90% 10%, rgba(62,107,43,0.14), transparent 60%),
    var(--paper);
  border-bottom: 1px solid var(--line);
}
.hero .container {
  display: grid; gap: clamp(24px, 5vw, 48px);
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 820px) {
  .hero .container { grid-template-columns: 1.2fr 1fr; }
}
.hero h1 span { color: var(--mccombs-accent); }
.hero .lead { font-size: clamp(1.05rem, 1.6vw, 1.2rem); color: var(--muted); max-width: 52ch; }
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 10px; }
.hero-art {
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  padding: 20px;
  box-shadow: var(--shadow-lg);
  aspect-ratio: 1 / 1;
  display: grid; place-items: center;
}
.hero-art img { width: min(320px, 100%); border-radius: 8px; }

/* ---------- Per-page theming ---------- */
body.theme-mccombs { background: var(--mccombs-bg); color: var(--mccombs-text); }
body.theme-mccombs .site-header { background: rgba(14,14,16,0.88); border-color: #2a2a2e; }
body.theme-mccombs .nav a { color: var(--mccombs-text); }
body.theme-mccombs .nav a:hover { background: #242428; }
body.theme-mccombs .nav a.cta { background: var(--mccombs-accent); color: #1a1a1a; }
body.theme-mccombs .btn { background: var(--mccombs-accent); color: #1a1a1a; }
body.theme-mccombs .btn.ghost { background: transparent; color: var(--mccombs-text); border-color: var(--mccombs-accent); }
body.theme-mccombs h1 span { color: var(--mccombs-accent); }
body.theme-mccombs .card { background: var(--mccombs-panel); color: var(--mccombs-text); border-color: #2a2a2e; }
body.theme-mccombs .muted { color: var(--mccombs-mute); }
body.theme-mccombs .brand-text small { color: var(--mccombs-mute); }
body.theme-mccombs .brand { color: var(--mccombs-text); }

body.theme-pawpaw { background: var(--pawpaw-bg); color: var(--pawpaw-text); }
body.theme-pawpaw .nav a.cta { background: var(--pawpaw-accent); color: #fff; }
body.theme-pawpaw .btn { background: var(--pawpaw-accent); color: #fff; }
body.theme-pawpaw .btn.ghost { background: transparent; color: var(--pawpaw-text); border-color: var(--pawpaw-accent); }
body.theme-pawpaw h1 span { color: var(--pawpaw-accent); }
body.theme-pawpaw .muted { color: var(--pawpaw-mute); }

body.theme-led { background: var(--led-bg); color: var(--led-text); }
body.theme-led .site-header { background: rgba(11,20,36,0.9); border-color: #1c2a44; }
body.theme-led .nav a { color: var(--led-text); }
body.theme-led .nav a:hover { background: #1a2a48; }
body.theme-led .nav a.cta { background: var(--led-accent); color: #1a1a1a; }
body.theme-led .btn { background: var(--led-accent); color: #1a1a1a; }
body.theme-led .btn.ghost { background: transparent; color: var(--led-text); border-color: var(--led-accent); }
body.theme-led h1 span { color: var(--led-accent); }
body.theme-led .card { background: var(--led-panel); color: var(--led-text); border-color: #1e2e4e; }
body.theme-led .muted { color: var(--led-mute); }
body.theme-led .brand-text small { color: var(--led-mute); }
body.theme-led .brand { color: var(--led-text); }

/* ---------- Credentials strip ---------- */
.creds {
  display: flex; flex-wrap: wrap; gap: 10px 16px;
  align-items: center;
  padding: 14px 18px;
  border: 1px solid currentColor;
  border-radius: 999px;
  font-weight: 700;
  font-size: .92rem;
  opacity: .92;
  width: max-content;
  max-width: 100%;
}
.creds .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; opacity:.5; }

/* ---------- Price table ---------- */
.pricing {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.pricing th, .pricing td {
  padding: 14px 18px;
  text-align: left;
  border-bottom: 1px solid var(--line);
}
.pricing th { background: var(--paper-2); font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.pricing tr:last-child td { border-bottom: 0; }
.pricing .amt { font-weight: 800; font-size: 1.1rem; color: var(--pawpaw-accent); white-space: nowrap; }

/* ---------- Gallery grid ---------- */
.gallery-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.gallery-tile {
  aspect-ratio: 4 / 3;
  background: linear-gradient(135deg, #ece7dc, #d7d0bf);
  border-radius: var(--radius-sm);
  display: grid; place-items: center;
  color: var(--muted);
  font-size: .85rem;
  text-align: center;
  padding: 10px;
  border: 1px dashed #b9b2a1;
}
.gallery-tile img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius-sm); }

/* ---------- Contact form ---------- */
.form {
  display: grid; gap: 14px;
  max-width: 560px;
}
.form label { font-weight: 700; font-size: .9rem; }
.form input, .form textarea {
  font: inherit;
  padding: 12px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  background: #fff;
  width: 100%;
}
.form textarea { min-height: 140px; resize: vertical; }
.form .hint { font-size: .85rem; color: var(--muted); }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--ink);
  color: var(--paper);
  padding-block: 40px;
  margin-top: 60px;
}
body.theme-mccombs .site-footer { background: #050506; }
body.theme-led     .site-footer { background: #060d1c; }
.site-footer .container {
  display: grid; gap: 18px;
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 720px) {
  .site-footer .container { grid-template-columns: 1fr auto; }
}
.site-footer a { color: inherit; }
.site-footer .small { color: #bdb9b1; font-size: .85rem; }

/* ---------- Utilities ---------- */
.center { text-align: center; }
.stack > * + * { margin-top: 12px; }
.flex { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.muted { color: var(--muted); }
.hr { border: 0; border-top: 1px solid var(--line); margin: 40px 0; }
