:root{--ink:#13251b;--text:#30483a;--muted:#5d7366;--forest:#008542;--forest-2:#006137;--leaf:#54c45a;--accent:#43b94f;--sun:#efa83b;--paper:#f9fcf8;--cream:#eaf7eb;--mint:#d9f1dd;--line:#cde5d2;--white:#fff;--shadow:0 12px 34px rgba(0,97,55,.11);--max:1120px;--r:8px;--pill:6px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:var(--paper);line-height:1.62;-webkit-font-smoothing:antialiased}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}h1,h2,h3{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.16;letter-spacing:0;margin:0;color:var(--ink)}h1{font-size:clamp(2rem,3.8vw,3.6rem);font-weight:800;max-width:18ch}h2{font-size:clamp(1.55rem,2.5vw,2.35rem);font-weight:750}h3{font-size:1.08rem;font-weight:750}p{margin:0;color:var(--text)}.skip-link{position:absolute;left:-999px;top:0;background:var(--forest);color:white;padding:12px 16px;z-index:99}.skip-link:focus{left:0}.header{position:sticky;top:0;z-index:30;background:rgba(251,252,248,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.nav{max-width:var(--max);margin:auto;padding:12px 22px;display:flex;align-items:center;justify-content:space-between;gap:20px}.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.05rem}.brand img{width:40px;height:40px;object-fit:contain}.links{display:flex;align-items:center;gap:2px;font-weight:700;font-size:.9rem}.links a{padding:9px 12px;border-radius:var(--pill);color:#33443b}.links a:hover,.links a.active{background:var(--mint);color:var(--forest)}.links .cta{background:var(--forest);color:white;padding:10px 16px}.links .cta:hover{background:var(--forest-2);color:white}.menu{display:none;border:1px solid var(--line);background:white;border-radius:var(--pill);padding:9px 13px;font-weight:750;color:var(--forest)}.wrap{max-width:var(--max);margin:auto;padding:0 22px}.section{padding:clamp(48px,7vw,86px) 0}.hero{background:linear-gradient(180deg,#f2f8f4,#fbfcf8)}.hero .wrap{min-height:560px;display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center;padding-top:46px;padding-bottom:46px}.eyebrow{display:inline-flex;align-items:center;gap:9px;margin-bottom:14px;text-transform:uppercase;letter-spacing:.13em;font-size:.7rem;font-weight:800;color:var(--forest)}.eyebrow:before{content:"";width:20px;height:2px;background:var(--leaf);border-radius:4px}.accent{color:var(--forest)}.lead{font-size:clamp(1rem,1.25vw,1.16rem);max-width:42rem;margin-top:18px;color:#33443b}.hero-actions,.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--pill);padding:13px 21px;font-weight:800;border:1px solid transparent;transition:.18s ease}.primary{background:var(--forest);color:white;box-shadow:0 10px 24px rgba(20,95,63,.18)}.primary:hover{background:var(--forest-2);transform:translateY(-1px)}.secondary{background:white;color:var(--forest);border-color:var(--line)}.secondary:hover{border-color:var(--leaf)}.hero-art img{width:min(380px,100%);margin:auto;filter:drop-shadow(0 18px 28px rgba(9,48,32,.18))}.band{background:var(--forest);color:white}.band p,.band h2,.band h3{color:white}.band .eyebrow{color:#9af0bd}.band-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:32px;align-items:start}.offer-grid,.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.card{background:white;border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow)}.card h3{margin-bottom:8px}.card p{color:var(--text)}.card ul,.clean-list{padding:0;margin:16px 0 0;list-style:none;display:grid;gap:8px}.card li,.clean-list li{position:relative;padding-left:24px;color:var(--text);font-weight:600}.card li:before,.clean-list li:before{content:"";position:absolute;left:0;top:8px;width:11px;height:11px;border:2px solid var(--leaf);border-radius:50%}.card.featured{border:2px solid var(--leaf)}.kicker{max-width:720px;margin:0 auto 30px;text-align:center}.kicker p{font-size:1rem;margin-top:12px}.split{display:grid;grid-template-columns:1fr 1fr;gap:38px;align-items:center}.split img{border-radius:var(--r);box-shadow:var(--shadow);border:1px solid var(--line)}.tint{background:var(--cream)}.fit-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.fit{padding:22px;border-radius:var(--r);border:1px solid var(--line);background:white}.fit.good{border-color:rgba(49,169,106,.45)}.fit.bad{background:#fffaf4;border-color:#ecd9bc}.price{display:flex;align-items:baseline;gap:8px;margin:12px 0}.amount{font-size:2rem;font-weight:800;color:var(--forest)}.per{font-size:.84rem;color:var(--muted);font-weight:700}.areas li{list-style:none;background:white;border:1px solid var(--line);border-radius:var(--pill);padding:9px 14px;font-weight:700;color:var(--forest);text-align:center}.areas ul{padding:0;margin:0;display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.faq{display:grid;gap:10px;max-width:820px;margin:auto}.faq details{background:white;border:1px solid var(--line);border-radius:8px;padding:0;box-shadow:0 4px 14px rgba(12,45,31,.04)}.faq summary{cursor:pointer;padding:18px 20px;font-weight:800;font-size:1rem;list-style:none}.faq summary::-webkit-details-marker{display:none}.faq details p{padding:0 20px 20px}.page-hero{background:linear-gradient(180deg,#f1f8f3,#fbfcf8);padding:clamp(48px,7vw,82px) 0 38px;text-align:center}.page-hero h1{margin:auto;max-width:20ch}.page-hero .lead{margin:18px auto 0;max-width:50rem}.crumbs{max-width:var(--max);margin:18px auto 0;padding:0 22px;color:var(--muted);font-size:.9rem}.crumbs a{color:var(--forest);font-weight:800}.contact-box{display:grid;grid-template-columns:.85fr 1.15fr;gap:28px}.form{display:grid;gap:13px;background:white;border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow)}label{display:grid;gap:7px;font-weight:750;color:var(--forest)}input,textarea,select{width:100%;border:1px solid #cfded5;border-radius:10px;padding:13px 14px;font:inherit;background:#fff;color:var(--ink)}input:focus,textarea:focus,select:focus{outline:3px solid rgba(49,169,106,.2);border-color:var(--leaf)}.note{font-size:.92rem;color:var(--muted);margin-top:10px}.footer{max-width:var(--max);margin:0 auto;padding:42px 22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:24px;color:var(--muted)}.footer strong{display:block;color:var(--ink);font-size:1.08rem}.footer a{color:var(--forest);font-weight:800}@media(max-width:920px){.menu{display:inline-flex}.links{display:none;position:absolute;right:22px;top:66px;background:white;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:12px;flex-direction:column;align-items:stretch;min-width:210px}.links.open{display:flex}.hero .wrap,.band-grid,.split,.contact-box{grid-template-columns:1fr}.hero .wrap{min-height:auto}.hero-art{order:-1}.offer-grid,.info-grid,.fit-grid{grid-template-columns:1fr}.footer{flex-direction:column}.nav{padding-inline:18px}h1{font-size:clamp(2rem,9vw,3rem)}}.seo-note{padding-top:0}.seo-box{max-width:820px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;box-shadow:var(--shadow)}.seo-box h2{font-size:clamp(1.35rem,2vw,1.9rem)}.seo-box p{margin-top:10px}.page-hero h1{max-width:24ch}.visual-seo{padding-top:clamp(36px,5vw,64px)}.visual-seo-grid{display:grid;grid-template-columns:1fr 1fr;gap:38px;align-items:center}.visual-seo-art img{width:100%;height:auto;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);background:var(--cream)}@media(max-width:920px){.visual-seo-grid{grid-template-columns:1fr}.visual-seo-art{order:-1}}
/* Long-form service content */
.content-depth { border-top: 1px solid var(--line); }
.content-depth .kicker { max-width: 820px; }
.editorial-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 28px; margin-top: 40px; }
.editorial-grid article { border-top: 3px solid var(--accent); padding-top: 20px; }
.editorial-grid h3 { margin-bottom: 10px; }
.editorial-grid p, .prose p { color: var(--muted); }
.prose { max-width: 860px; margin-top: 40px; }
.prose h3 { margin-top: 28px; margin-bottom: 10px; }
.prose h3:first-child { margin-top: 0; }
.content-depth p { max-width: 75ch; }
@media (max-width: 800px) { .editorial-grid { grid-template-columns: 1fr; gap: 22px; } }

/* Keep the mascot illustration series at its original 1100x880 format. */
.split > img,
.visual-seo-art img {
  width: 100%;
  aspect-ratio: 5 / 4;
  object-fit: contain;
}

/* Fresh spring-green bands with a quiet leaf-line texture. */
.hero,
.page-hero,
.tint,
.band {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.hero,
.page-hero { background: #eef9ef; }

.hero::before,
.page-hero::before,
.tint::before,
.band::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-repeat: repeat;
  background-size: 64px 64px;
  opacity: .34;
}

.hero::before,
.page-hero::before,
.tint::before {
  background-image: url("../images/kodiak-bg-section-pattern-vector.webp");
}

.hero::before,
.page-hero::before {
  background-image: url("../images/kodiak-bg-nova-hero-vector.webp");
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: cover;
}

.hero::before { opacity: .28; }
.page-hero::before { opacity: .38; }

.band::before {
  background-image: url("../images/kodiak-bg-service-forest-vector.webp");
  background-repeat: no-repeat;
  background-position: center 62%;
  background-size: cover;
  opacity: .12;
  filter: grayscale(1) brightness(.72) contrast(1.12);
}

.eyebrow::before { background: var(--sun); }
.editorial-grid article { border-top-color: var(--accent); }

/* HTML dimensions reserve space; CSS controls the responsive rendered size. */
img { height: auto; }
.hero-art img {
  width: min(380px, 100%);
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: contain;
}

/* Transparent mascot art floats on the page instead of sitting in a box. */
.split > img,
.visual-seo-art img {
  border: 0;
  background: transparent;
  box-shadow: none;
  filter: drop-shadow(0 14px 22px rgba(0, 97, 55, .14));
}

/* Location hub and conversion-focused city pages. */
.location-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.location-grid .card {
  box-shadow: none;
}
.location-grid .card h3 a,
.text-link {
  color: var(--forest);
}
.text-link {
  display: inline-block;
  margin-top: 14px;
  font-weight: 800;
}
.text-link:hover,
.location-grid .card h3 a:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}
.process-list {
  counter-reset: location-process;
  display: grid;
  gap: 16px;
  margin: 24px 0 0;
  padding: 0;
  list-style: none;
}
.process-list li {
  counter-increment: location-process;
  position: relative;
  min-height: 38px;
  padding-left: 52px;
  color: var(--text);
}
.process-list li::before {
  content: counter(location-process);
  position: absolute;
  left: 0;
  top: -3px;
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--forest);
  color: white;
  font-weight: 800;
}
.location-hero .lead {
  max-width: 60rem;
}
@media (max-width: 760px) {
  .location-grid { grid-template-columns: 1fr; }
}

/* Structured buyer comparisons. */
.table-wrap {
  margin-top: 30px;
  overflow: visible;
  border: 1px solid var(--line);
  border-radius: var(--r);
  background: white;
}
.comparison-table {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
  border-collapse: collapse;
  text-align: left;
}
.comparison-table th,
.comparison-table td {
  padding: 15px 17px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
  overflow-wrap: anywhere;
}
.comparison-table th {
  background: var(--forest-2);
  color: white;
  font-size: .9rem;
}
.comparison-table tbody tr:last-child td { border-bottom: 0; }
.comparison-table tbody tr:nth-child(even) { background: #f5fbf6; }
.comparison-table td:first-child {
  color: var(--forest-2);
  font-weight: 800;
}

@media (max-width: 680px) {
  .table-wrap {
    border: 0;
    background: transparent;
    box-shadow: none;
  }

  .comparison-table,
  .comparison-table thead,
  .comparison-table tbody,
  .comparison-table tr,
  .comparison-table th,
  .comparison-table td {
    display: block;
    width: 100%;
  }

  .comparison-table thead {
    display: none;
  }

  .comparison-table tr {
    margin-bottom: 14px;
    border: 1px solid var(--line);
    border-radius: var(--r);
    background: white;
    box-shadow: var(--shadow);
    overflow: hidden;
  }

  .comparison-table td {
    border-bottom: 1px solid var(--line);
    padding: 13px 15px;
  }

  .comparison-table td:last-child {
    border-bottom: 0;
  }
}

/* Quote-form feedback keeps the conversion path clear without leaving the page. */
.botcheck {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
}
.form button:disabled {
  cursor: wait;
  opacity: .7;
}
.form-status {
  min-height: 1.5rem;
  margin: 2px 0 0;
  font-weight: 700;
}
.form-status.success { color: var(--forest-2); }
.form-status.error { color: #9b1c1c; }
.form-status a { color: inherit; text-decoration: underline; }

/* Header polish: tighter nav rhythm, stronger CTA contrast, calmer hero mark. */
.nav {
  max-width: 1240px;
  padding: 10px 22px;
  gap: 14px;
}
.brand {
  gap: 9px;
  font-size: 1rem;
  letter-spacing: 0;
  white-space: nowrap;
}
.brand img {
  width: 36px;
  height: 36px;
}
.links {
  gap: 3px;
  font-size: .84rem;
}
.links a {
  padding: 8px 9px;
}
.links .cta,
.btn.primary {
  background: #005f35;
  color: #fff;
  border-color: #005f35;
}
.links .cta {
  padding: 10px 18px;
  box-shadow: 0 8px 18px rgba(0, 95, 53, .18);
}
.links .cta:hover,
.btn.primary:hover {
  background: #003f27;
  border-color: #003f27;
  color: #fff;
}
.band .btn.primary {
  background: #fff;
  border-color: #fff;
  color: #005f35;
  box-shadow: none;
}
.band .btn.primary:hover {
  background: #eaf7eb;
  border-color: #eaf7eb;
  color: #003f27;
}
.hero-art {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 360px;
}
.hero-art::before {
  content: "";
  position: absolute;
  width: min(380px, 92%);
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,.88), rgba(234,247,235,.62) 72%, rgba(234,247,235,0));
  border: 1px solid rgba(205, 229, 210, .72);
}
.hero-art img {
  position: relative;
  width: min(330px, 88%);
  max-height: 360px;
  object-fit: contain;
  filter: drop-shadow(0 14px 22px rgba(9,48,32,.16));
}
@media (max-width: 920px) {
  .nav { padding: 10px 18px; }
  .links { gap: 4px; }
  .links a { padding: 9px 11px; }
  .hero-art { min-height: 250px; }
  .hero-art img { width: min(260px, 82%); }
}

/* Persistent form-first conversion prompt. */
.sticky-top-quote {
  position: sticky;
  top: 57px;
  z-index: 24;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  padding: 8px 18px;
  border-bottom: 1px solid rgba(0, 95, 53, .18);
  background: rgba(234, 247, 235, .96);
  color: #173324;
  font-size: .88rem;
  font-weight: 800;
  backdrop-filter: blur(10px);
}
.sticky-top-quote a,
.footer-quote {
  color: #005f35;
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 3px;
}
@media (max-width: 620px) {
  .sticky-top-quote {
    top: 57px;
    justify-content: space-between;
    font-size: .8rem;
    gap: 10px;
  }
}

/* Generated imagery and stronger readability pass. */
:root {
  --text: #24382d;
  --muted: #465f50;
  --surface: rgba(255, 255, 255, .86);
  --surface-strong: rgba(255, 255, 255, .94);
}

body {
  background:
    linear-gradient(180deg, rgba(249,252,248,.96), rgba(249,252,248,.92)),
    url("../images/kodiak-bg-service-forest-vector.webp") center top / 1200px auto repeat-y;
}

p,
.card p,
.card li,
.clean-list li,
.process-list li,
.editorial-grid p,
.prose p {
  color: var(--text);
}

.note,
.per {
  color: var(--muted);
}

.hero,
.page-hero {
  background:
    linear-gradient(90deg, rgba(248,252,246,.98) 0%, rgba(248,252,246,.9) 34%, rgba(248,252,246,.62) 64%, rgba(248,252,246,.5) 100%),
    linear-gradient(180deg, rgba(238,249,239,.88), rgba(249,252,248,.96)),
    url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat;
}

.hero::before,
.page-hero::before {
  background-image: none;
}

.hero .wrap > div:first-child,
.page-hero .wrap {
  position: relative;
  z-index: 1;
}

.hero .wrap > div:first-child {
  max-width: 680px;
  padding: clamp(18px, 2.2vw, 28px);
  margin-left: calc(clamp(18px, 2.2vw, 28px) * -1);
  border-left: 4px solid var(--sun);
  background: linear-gradient(90deg, var(--surface-strong), rgba(255,255,255,.72));
  box-shadow: 0 18px 44px rgba(0, 63, 39, .10);
  backdrop-filter: blur(6px);
}

.page-hero .wrap {
  max-width: 900px;
  padding: clamp(22px, 3vw, 34px);
  border-top: 4px solid var(--sun);
  background: var(--surface-strong);
  box-shadow: 0 18px 42px rgba(0, 63, 39, .10);
  backdrop-filter: blur(7px);
}

.page-hero .eyebrow {
  margin-left: auto;
  margin-right: auto;
}

.section:not(.band):not(.tint):nth-of-type(odd) {
  background:
    linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.96)),
    url("../images/kodiak-bg-service-forest-vector.webp") center / cover no-repeat;
}

.tint {
  background:
    linear-gradient(180deg, rgba(234,247,235,.92), rgba(245,252,246,.94)),
    url("../images/kodiak-bg-service-forest-vector.webp") center / cover no-repeat;
}

.card,
.fit,
.form,
.seo-box,
.table-wrap,
.faq details {
  background: var(--surface-strong);
  border-color: rgba(0, 95, 53, .18);
  box-shadow: 0 14px 34px rgba(0, 63, 39, .08);
}

.editorial-grid article,
.prose {
  padding: 20px;
  background: rgba(255,255,255,.78);
  border-radius: var(--r);
  box-shadow: 0 10px 26px rgba(0, 63, 39, .06);
}

.band {
  background:
    linear-gradient(90deg, rgba(0, 47, 30, .96), rgba(0, 95, 53, .88)),
    url("../images/kodiak-bg-service-forest-vector.webp") center 70% / cover no-repeat;
}

.band::before {
  background-image: none;
}

.band .lead,
.band p,
.band h2,
.band h3 {
  color: #fff;
  text-shadow: 0 1px 1px rgba(0,0,0,.2);
}

.band .secondary {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.62);
  color: #fff;
}

.band .secondary:hover {
  background: rgba(255,255,255,.20);
  border-color: #fff;
  color: #fff;
}

.lead {
  color: #21362b;
  font-weight: 500;
}

.eyebrow {
  color: #005f35;
}

.hero-art::before {
  background: radial-gradient(circle, rgba(255,255,255,.9), rgba(234,247,235,.66) 70%, rgba(234,247,235,0));
}

@media (max-width: 920px) {
  .hero,
  .page-hero {
    background:
      linear-gradient(180deg, rgba(248,252,246,.96), rgba(248,252,246,.88)),
      url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat;
  }

  .hero .wrap > div:first-child {
    margin-left: 0;
    padding: 20px;
    background: rgba(255,255,255,.92);
  }

  .page-hero .wrap {
    padding: 22px 18px;
  }
}

@media (max-width: 620px) {
  body {
    background-size: 900px auto;
  }

  .hero .wrap {
    gap: 22px;
    padding-top: 26px;
  }

  .hero .wrap > div:first-child,
  .page-hero .wrap {
    border-radius: 8px;
    box-shadow: 0 12px 28px rgba(0, 63, 39, .10);
  }

  h1 {
    max-width: 11ch;
  }

  .page-hero h1 {
    max-width: 14ch;
  }

  .lead,
  p {
    font-size: 1rem;
  }

  .card,
  .fit,
  .form,
  .seo-box {
    padding: 20px;
  }
}

/* Keep the original sky, then add livelier no-sky section imagery. */
.hero,
.page-hero {
  background:
    linear-gradient(90deg, rgba(248,252,246,.98) 0%, rgba(248,252,246,.91) 38%, rgba(248,252,246,.66) 72%, rgba(248,252,246,.56) 100%),
    url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat;
}

.hero .wrap > div:first-child,
.page-hero .wrap {
  border: 1px solid rgba(255, 255, 255, .78);
  border-left: 4px solid var(--sun);
  background:
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(244,252,245,.86)),
    linear-gradient(90deg, rgba(255,255,255,.18), rgba(255,255,255,0));
}

.page-hero .wrap {
  border-left-width: 1px;
  border-top: 4px solid var(--sun);
}

.section:not(.band):not(.tint):nth-of-type(odd) {
  background:
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,.96)),
    url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat;
}

.section:not(.band):not(.tint):nth-of-type(even) {
  background:
    linear-gradient(180deg, rgba(249,252,248,.92), rgba(249,252,248,.97)),
    url("../images/kodiak-bg-service-forest-vector.webp") center / cover no-repeat;
}

.tint {
  background:
    linear-gradient(180deg, rgba(236,249,238,.86), rgba(247,253,248,.94)),
    url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat;
}

.band {
  background:
    linear-gradient(90deg, rgba(0, 47, 30, .97), rgba(0, 95, 53, .9)),
    url("../images/kodiak-bg-service-forest-vector.webp") center 70% / cover no-repeat;
}

.kicker {
  padding: 18px 22px;
  border-radius: var(--r);
  background: rgba(255,255,255,.78);
  box-shadow: 0 12px 30px rgba(0, 63, 39, .07);
  backdrop-filter: blur(5px);
}

.band .kicker,
.band .wrap > div {
  background: transparent;
  box-shadow: none;
}

.split > div:first-child,
.visual-seo-grid > div:first-child,
.contact-box > div:first-child {
  padding: 22px;
  border-radius: var(--r);
  background: rgba(255,255,255,.82);
  box-shadow: 0 12px 30px rgba(0, 63, 39, .07);
  backdrop-filter: blur(5px);
}

.split > .visual-seo-art,
.visual-seo-grid > .visual-seo-art {
  padding: 0;
  background: transparent;
  box-shadow: none;
}

h2 {
  position: relative;
}

.kicker h2::after,
.split h2::after,
.seo-box h2::after,
.contact-box h2::after {
  content: "";
  display: block;
  width: 72px;
  height: 4px;
  margin: 12px auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--forest), var(--sun));
}

.split h2::after,
.seo-box h2::after,
.contact-box h2::after {
  margin-left: 0;
}

.card {
  border-top: 4px solid rgba(0, 133, 66, .72);
}

.card.featured {
  border-top-color: var(--sun);
}

@media (max-width: 920px) {
  .hero,
  .page-hero {
    background:
      linear-gradient(180deg, rgba(248,252,246,.96), rgba(248,252,246,.88)),
      url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat;
  }

  .section:not(.band):not(.tint):nth-of-type(odd),
  .section:not(.band):not(.tint):nth-of-type(even),
  .tint {
    background:
      linear-gradient(180deg, rgba(255,255,255,.92), rgba(249,252,248,.96)),
      url("../images/kodiak-bg-service-forest-vector.webp") 58% bottom / cover no-repeat;
  }
}

@media (max-width: 620px) {
  .hero .wrap > div:first-child,
  .page-hero .wrap,
  .kicker,
  .split > div:first-child,
  .visual-seo-grid > div:first-child,
  .contact-box > div:first-child {
    background: rgba(255,255,255,.94);
  }

  .kicker {
    padding: 18px;
  }

  h1,
  .page-hero h1 {
    max-width: 16ch;
  }
}

/* Bold contrast system: real image backgrounds, solid reading surfaces. */
.hero,
.page-hero,
.section,
.tint,
.band {
  position: relative;
  isolation: isolate;
}

.hero,
.page-hero {
  background:
    url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat,
    #eef9ef;
}

.hero::before,
.page-hero::before,
.tint::before,
.band::before {
  display: none;
}

.hero .wrap > div:first-child,
.page-hero .wrap {
  color: var(--ink);
  background: #fff;
  border: 1px solid rgba(0, 95, 53, .16);
  border-left: 7px solid var(--sun);
  box-shadow: 0 20px 54px rgba(0, 63, 39, .16);
  backdrop-filter: none;
}

.page-hero .wrap {
  border-left-width: 1px;
  border-top: 7px solid var(--sun);
}

.hero .lead,
.page-hero .lead {
  color: #24382d;
}

.section:not(.band):not(.tint):nth-of-type(odd) {
  background:
    url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat,
    #f7fbf6;
}

.section:not(.band):not(.tint):nth-of-type(even),
.tint {
  background:
    url("../images/kodiak-bg-service-forest-vector.webp") center / cover no-repeat,
    #f3fbf4;
}

.section:not(.band):not(.tint):nth-of-type(odd)::after,
.tint::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 10px;
  z-index: -1;
  background: linear-gradient(90deg, var(--forest-2), var(--forest), var(--sun));
}

.card,
.fit,
.form,
.seo-box,
.table-wrap,
.faq details,
.kicker,
.split > div:first-child,
.visual-seo-grid > div:first-child,
.contact-box > div:first-child,
.editorial-grid article,
.prose {
  background: #fff;
  border-color: rgba(0, 95, 53, .18);
  box-shadow: 0 14px 34px rgba(0, 63, 39, .10);
  backdrop-filter: none;
}

.kicker {
  border: 1px solid rgba(0, 95, 53, .14);
}

.split > div:first-child,
.visual-seo-grid > div:first-child,
.contact-box > div:first-child {
  border: 1px solid rgba(0, 95, 53, .14);
  border-left: 5px solid var(--forest);
}

.card {
  border-top: 5px solid var(--forest);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 20px 42px rgba(0, 63, 39, .14);
}

.card.featured {
  border-top-color: var(--sun);
  box-shadow: 0 18px 44px rgba(0, 95, 53, .16);
}

.band {
  background:
    linear-gradient(90deg, rgba(0, 35, 24, .9), rgba(0, 95, 53, .78)),
    url("../images/kodiak-bg-service-forest-vector.webp") center 72% / cover no-repeat,
    #003f27;
}

.band-grid {
  padding: clamp(18px, 3vw, 30px);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: var(--r);
  background: rgba(0, 35, 24, .48);
  box-shadow: 0 24px 54px rgba(0, 35, 24, .28);
}

.band .kicker,
.band .wrap > div {
  background: transparent;
  border-color: transparent;
}

.band .eyebrow,
.band .lead,
.band p,
.band h2,
.band h3 {
  color: #fff;
}

.amount,
.accent,
.text-link,
.location-grid .card h3 a {
  color: #006137;
}

.btn {
  box-shadow: none;
}

.primary,
.links .cta {
  background: #004b2e;
  border-color: #004b2e;
}

.primary:hover,
.links .cta:hover {
  background: #002f20;
  border-color: #002f20;
}

@media (max-width: 920px) {
  .hero,
  .page-hero {
    background:
      url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat,
      #eef9ef;
  }

  .section:not(.band):not(.tint):nth-of-type(odd),
  .section:not(.band):not(.tint):nth-of-type(even),
  .tint {
      background:
        url("../images/kodiak-bg-service-forest-vector.webp") 58% bottom / cover no-repeat,
        #f7fbf6;
    }
  }

/* Mobile navigation refinement: larger tap targets and a cleaner menu panel. */
@media (max-width: 920px) {
  body {
    overflow-x: hidden;
  }

  .header {
    z-index: 60;
  }

  .nav {
    min-height: 64px;
    padding: 10px 16px;
    gap: 12px;
  }

  .brand.brand-text span {
    font-size: 1rem;
    line-height: 1;
  }

  .brand.brand-text small {
    font-size: .58rem;
    letter-spacing: .14em;
  }

  .menu {
    min-height: 44px;
    padding: 10px 15px;
    font-size: 1rem;
    font-weight: 900;
    border-color: rgba(0, 95, 53, .28);
    box-shadow: 0 6px 16px rgba(0, 95, 53, .08);
  }

  .links {
    position: fixed;
    left: 14px;
    right: 14px;
    top: 72px;
    min-width: 0;
    width: auto;
    padding: 10px;
    gap: 6px;
    border-radius: 10px;
    border: 1px solid rgba(0, 95, 53, .18);
    background: rgba(255, 255, 255, .98);
    box-shadow: 0 18px 45px rgba(9, 48, 32, .18);
  }

  .links.open {
    display: grid;
  }

  .links a {
    width: 100%;
    min-height: 46px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 13px 14px;
    border-radius: 8px;
    font-size: 1rem;
    line-height: 1.15;
    background: #f6fbf7;
  }

  .links a.active,
  .links a:hover {
    background: var(--mint);
  }

  .links .cta {
    justify-content: center;
    min-height: 50px;
    margin-top: 4px;
    font-size: 1rem;
    background: #004b2e;
  }

  .sticky-top-quote {
    top: 64px;
  }
}

@media (max-width: 620px) {
  .hero .wrap > div:first-child,
  .page-hero .wrap,
  .kicker,
  .split > div:first-child,
  .visual-seo-grid > div:first-child,
  .contact-box > div:first-child {
    background: #fff;
  }

  .band-grid {
    padding: 18px;
  }
}

/* Final header/background cleanup. */
body {
  background: var(--paper);
}

.brand.brand-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  line-height: 1;
}

.brand.brand-text span {
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: .03em;
}

.brand.brand-text small {
  display: block;
  margin-top: 3px;
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .18em;
  color: #006137;
}

.brand img {
  display: none;
}

.nav {
  min-height: 58px;
}

.hero-art::before {
  display: none;
}

.section:not(.band):not(.tint):nth-of-type(even),
.tint {
  background:
    linear-gradient(135deg, #eef9ef, #f9fcf8 58%, #eaf7eb),
    #f3fbf4;
}

.section:not(.band):not(.tint):nth-of-type(odd) {
  background:
    url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat,
    #f7fbf6;
}

.section:not(.band):not(.tint):nth-of-type(odd) > .wrap,
.tint > .wrap {
  position: relative;
  z-index: 1;
}

@media (max-width: 920px) {
  .brand.brand-text span {
    font-size: .92rem;
  }

  .brand.brand-text small {
    font-size: .56rem;
  }

  .section:not(.band):not(.tint):nth-of-type(even),
  .tint {
    background: #f3fbf4;
  }
}

/* Lead form and hosting page refinement. */
.contact-intake .contact-box {
  align-items: start;
}

.simple-form {
  gap: 12px;
}

.simple-form label {
  color: #173324;
}

.simple-form input,
.simple-form select,
.simple-form textarea {
  border-color: #b9d4c1;
  background: #fff;
}

.lead-list {
  margin-top: 22px;
}

.service-visual {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  object-position: center;
  border: 1px solid rgba(0, 95, 53, .18);
  border-radius: 8px;
  box-shadow: 0 18px 36px rgba(9, 48, 32, .14);
}

.hosting-feature {
  align-items: center;
}

.management-feature {
  align-items: center;
}

@media (max-width: 920px) {
  .page-hero {
    text-align: left;
    padding: 34px 0 24px;
  }

  .page-hero h1,
  .page-hero .lead {
    margin-left: 0;
    margin-right: 0;
  }

  .page-hero h1 {
    max-width: 12ch;
    font-size: clamp(2rem, 10vw, 2.7rem);
  }

  .page-hero .lead,
  .lead {
    font-size: 1rem;
    line-height: 1.55;
  }

  .section {
    padding: 42px 0;
  }

  .kicker {
    text-align: left;
    margin-left: 0;
    margin-right: 0;
  }

  .kicker h2,
  .section h2 {
    font-size: clamp(1.42rem, 7vw, 2rem);
  }

  .contact-box {
    gap: 22px;
  }

  .form {
    padding: 18px;
  }

  input,
  textarea,
  select {
    min-height: 48px;
    font-size: 16px;
  }

  .service-visual {
    aspect-ratio: 4 / 3;
  }
}

/* Selective page depth. */
.page-hero {
  position: relative;
  overflow: hidden;
}

.page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(115deg, rgba(255, 255, 255, .78), rgba(255, 255, 255, 0) 44%),
    radial-gradient(circle at 18% 24%, rgba(84, 196, 90, .13), transparent 30%);
}

.page-hero > .wrap {
  position: relative;
  z-index: 1;
}

/* Selective engagement overlays: used only where they add depth or breathing room. */
.section:has(.service-visual),
.section:has(.visual-seo-grid),
.section:has(.offer-grid),
.section:has(.table-wrap),
.section:has(.faq),
.contact-intake,
.content-depth {
  position: relative;
  overflow: hidden;
}

.section:has(.service-visual)::before,
.section:has(.visual-seo-grid)::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 8% 18%, rgba(239, 168, 59, .14), transparent 24%),
    linear-gradient(120deg, rgba(255,255,255,.72), rgba(255,255,255,0) 46%),
    repeating-linear-gradient(90deg, rgba(0,97,55,.045) 0 1px, transparent 1px 38px);
  opacity: .7;
}

.contact-intake::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 82% 20%, rgba(84, 196, 90, .16), transparent 25%),
    radial-gradient(circle at 14% 78%, rgba(239, 168, 59, .11), transparent 28%);
}

.section:has(.offer-grid)::after,
.section:has(.table-wrap)::after,
.section:has(.faq)::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 42%;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.58)),
    radial-gradient(circle at 92% 82%, rgba(0, 97, 55, .10), transparent 28%);
}

.content-depth::before {
  content: "";
  position: absolute;
  top: 28px;
  left: 50%;
  width: min(720px, calc(100% - 44px));
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, rgba(0, 97, 55, .32), rgba(239, 168, 59, .32), transparent);
}

.section:has(.service-visual) > .wrap,
.section:has(.visual-seo-grid) > .wrap,
.section:has(.offer-grid) > .wrap,
.section:has(.table-wrap) > .wrap,
.section:has(.faq) > .wrap,
.contact-intake > .wrap,
.content-depth > .wrap {
  position: relative;
  z-index: 1;
}

.offer-grid,
.editorial-grid,
.table-wrap,
.faq {
  position: relative;
}

.offer-grid::before,
.editorial-grid::before,
.table-wrap::before,
.faq::before {
  content: "";
  position: absolute;
  inset: -18px;
  z-index: -1;
  border-radius: 12px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.48), rgba(255,255,255,0)),
    radial-gradient(circle at 12% 0%, rgba(239, 168, 59, .10), transparent 28%);
  border: 1px solid rgba(205, 229, 210, .42);
}

.service-visual,
.visual-seo-art img {
  outline: 1px solid rgba(255,255,255,.72);
  outline-offset: -8px;
}

.visual-seo-grid > div:first-child {
  position: relative;
}

.visual-seo-grid > div:first-child::after {
  content: "";
  position: absolute;
  inset: 14px;
  pointer-events: none;
  border: 1px solid rgba(255,255,255,.68);
  border-radius: 8px;
}

@media (max-width: 620px) {
  .section:has(.service-visual)::before,
  .section:has(.visual-seo-grid)::before,
  .section:has(.offer-grid)::after,
  .section:has(.table-wrap)::after,
  .section:has(.faq)::after,
  .contact-intake::before {
    opacity: .45;
  }

  .offer-grid::before,
  .editorial-grid::before,
  .table-wrap::before,
  .faq::before {
    inset: -10px;
  }

  .service-visual,
  .visual-seo-art img {
    outline-offset: -6px;
  }
}

/* Final table guard: avoid nested horizontal scrollbars on comparison sections. */
.table-wrap {
  overflow: visible;
}

.comparison-table {
  min-width: 0;
  table-layout: fixed;
}

.comparison-table th,
.comparison-table td {
  overflow-wrap: anywhere;
}

@media (max-width: 680px) {
  .table-wrap {
    overflow: visible;
    border: 0;
    background: transparent;
  }

  .comparison-table,
  .comparison-table thead,
  .comparison-table tbody,
  .comparison-table tr,
  .comparison-table th,
  .comparison-table td {
    display: block;
    width: 100%;
  }

  .comparison-table thead {
    display: none;
  }

  .comparison-table tr {
    margin-bottom: 14px;
    border: 1px solid var(--line);
    border-radius: var(--r);
    background: white;
    box-shadow: var(--shadow);
    overflow: hidden;
  }
}

/* Final visual balance pass: contrast without the repeated white document box. */
.hero .wrap > div:first-child {
  padding: 0;
  margin-left: 0;
  border-left: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  text-shadow: 0 1px 0 rgba(255, 255, 255, .78), 0 14px 28px rgba(0, 45, 28, .12);
}

.page-hero .wrap {
  padding: 0 22px;
  border-top: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  text-shadow: 0 1px 0 rgba(255, 255, 255, .82), 0 12px 24px rgba(0, 45, 28, .11);
}

.page-hero::after {
  background:
    linear-gradient(90deg, rgba(242, 249, 238, .90), rgba(242, 249, 238, .68) 42%, rgba(242, 249, 238, .22) 78%),
    radial-gradient(circle at 18% 24%, rgba(84, 196, 90, .18), transparent 30%);
}

.hero {
  background:
    linear-gradient(90deg, rgba(242, 249, 238, .96), rgba(242, 249, 238, .76) 42%, rgba(242, 249, 238, .38) 76%),
    url("../images/kodiak-bg-nova-hero-vector.webp") center bottom / cover no-repeat;
}

.hero::before {
  opacity: .18;
}

/* Homepage-only breaks: enough visual rhythm without making every section busy. */
.home main > .section {
  position: relative;
  overflow: hidden;
}

.home main > .section:nth-of-type(2)::before,
.home main > .section:nth-of-type(4)::before,
.home main > .section:nth-of-type(6)::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: .34;
  background:
    linear-gradient(90deg, rgba(249,252,248,.96), rgba(249,252,248,.72) 50%, rgba(249,252,248,.92)),
    url("../images/kodiak-bg-section-pattern-vector.webp") center / 900px auto repeat;
}

.home main > .section:nth-of-type(4)::after,
.home main > .section:nth-of-type(6)::after {
  content: "";
  position: absolute;
  right: -8%;
  bottom: -18%;
  width: min(560px, 48vw);
  height: min(360px, 34vw);
  pointer-events: none;
  z-index: 0;
  opacity: .16;
  background: url("../images/kodiak-bg-service-forest-vector.webp") center bottom / cover no-repeat;
  -webkit-mask-image: radial-gradient(circle at 60% 58%, #000 0 52%, transparent 74%);
  mask-image: radial-gradient(circle at 60% 58%, #000 0 52%, transparent 74%);
}

.home main > .section > .wrap {
  position: relative;
  z-index: 1;
}

.home .content-depth .prose {
  padding: 24px;
  border-left: 3px solid rgba(239, 168, 59, .75);
  background: linear-gradient(90deg, rgba(255,255,255,.58), rgba(255,255,255,0));
}

@media (max-width: 920px) {
  .page-hero .wrap {
    padding: 0 22px;
  }

  .home main > .section:nth-of-type(4)::after,
  .home main > .section:nth-of-type(6)::after {
    opacity: .10;
    width: 82vw;
    height: 260px;
    right: -34vw;
  }

  .home .content-depth .prose {
    padding: 18px 0 18px 16px;
  }
}

/* White header text with a restrained dark overlay, no repeated white box. */
.hero,
.page-hero {
  background:
    linear-gradient(90deg, rgba(5, 42, 29, .78), rgba(5, 42, 29, .54) 46%, rgba(5, 42, 29, .24) 82%),
    url("../images/kodiak-bg-nova-hero-vector.webp") center bottom / cover no-repeat;
}

.hero::before,
.page-hero::before {
  display: none;
}

.hero::after,
.page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(circle at 18% 28%, rgba(239, 168, 59, .20), transparent 30%),
    linear-gradient(180deg, rgba(0, 31, 21, .16), rgba(0, 31, 21, .30));
}

.hero .wrap,
.page-hero .wrap {
  position: relative;
  z-index: 1;
}

.hero h1,
.hero .lead,
.page-hero h1,
.page-hero .lead {
  color: #fff;
  text-shadow: 0 2px 18px rgba(0, 28, 18, .36);
}

.hero .eyebrow,
.page-hero .eyebrow {
  color: #c9ffd7;
  text-shadow: 0 2px 14px rgba(0, 28, 18, .38);
}

.hero .secondary {
  background: rgba(255,255,255,.92);
  color: var(--forest-2);
  border-color: rgba(255,255,255,.72);
}

@media (max-width: 920px) {
  .hero,
  .page-hero {
    background:
      linear-gradient(90deg, rgba(5, 42, 29, .84), rgba(5, 42, 29, .66)),
      url("../images/kodiak-bg-nova-hero-vector.webp") center bottom / cover no-repeat;
  }
}


/* Desktop navigation readability pass. */
@media (min-width: 921px) {
  .nav {
    max-width: 1320px;
    min-height: 68px;
    padding: 12px 26px;
  }

  .brand.brand-text span {
    font-size: 1.08rem;
  }

  .brand.brand-text small {
    font-size: .66rem;
  }

  .links {
    gap: 5px;
    font-size: .96rem;
  }

  .links a {
    padding: 10px 12px;
  }

  .links .cta {
    padding: 12px 20px;
  }
}
