:root{
  --pink:#ec1b68;
  --pink-dark:#c91457;
  --green:#b8f22f;
  --green-dark:#79ad12;
  --ink:#071321;
  --navy:#06111f;
  --muted:#3f4a57;
  --soft:#f6fbff;
  --line:#dfe8ef;
  --white:#fff;
  --shadow:0 18px 50px rgba(7,19,33,.14);
  --shadow-strong:0 24px 65px rgba(7,19,33,.18);
  --radius:30px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  color:var(--ink);
  background:#fff;
  line-height:1.5;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto}
a{color:inherit}
.container{width:min(1180px,calc(100% - 40px));margin-inline:auto}
.skip-link{position:absolute;left:12px;top:-100px;z-index:999;background:#fff;color:#071321;padding:12px 14px;border-radius:12px;font-weight:800}
.skip-link:focus{top:12px}

/* HEADER */
.site-header{
  position:relative;
  z-index:10;
  background:#fff;
  border-bottom:1px solid rgba(236,27,104,.20);
  box-shadow:0 5px 24px rgba(7,19,33,.10);
}
.brand-band{
  display:flex;
  justify-content:center;
  align-items:center;
  padding:6px 10px 4px;
  background:
    radial-gradient(circle at 50% -40%,rgba(184,242,47,.18),transparent 42%),
    #fff;
}
.brand-mark{
  display:block;
  width:min(1500px,98vw);
}
.brand-mark img{
  display:block;
  width:100%;
  height:auto;
  max-height:230px;
  object-fit:contain;
}
.nav-band{
  background:var(--navy);
  border-top:4px solid var(--green);
}
.nav-row{
  min-height:56px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:34px;
}
.site-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:38px;
}
.site-nav a{
  color:#fff;
  text-decoration:none;
  text-transform:uppercase;
  letter-spacing:.055em;
  font-size:.9rem;
  font-weight:950;
  line-height:1;
}
.site-nav a:hover,.site-nav a:focus{color:var(--green)}
.phone-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--pink);
  color:#fff;
  text-decoration:none;
  font-weight:950;
  padding:11px 21px;
  border-radius:999px;
  border:2px solid rgba(255,255,255,.94);
  box-shadow:0 12px 28px rgba(236,27,104,.34);
  white-space:nowrap;
}
.menu-toggle{display:none}

/* HERO */
.hero{
  position:relative;
  overflow:hidden;
  min-height:705px;
  background:
    linear-gradient(90deg,rgba(248,252,255,.98) 0%,rgba(246,251,252,.94) 44%,rgba(250,244,250,.82) 100%);
}
.hero-mountains{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 10% 18%,rgba(184,242,47,.12),transparent 24%),
    radial-gradient(circle at 92% 18%,rgba(236,27,104,.10),transparent 24%),
    url("data:image/svg+xml,%3Csvg width='1800' height='820' viewBox='0 0 1800 820' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3ClinearGradient id='sky' x1='0' y1='0' x2='0' y2='1'%3E%3Cstop offset='0' stop-color='%23eff8ff'/%3E%3Cstop offset='.48' stop-color='%23f8fcff'/%3E%3Cstop offset='1' stop-color='%23ffffff'/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect width='1800' height='820' fill='url(%23sky)'/%3E%3Cpath d='M0 590 L210 340 L365 510 L565 255 L760 565 L940 320 L1110 560 L1295 220 L1800 615 L1800 820 L0 820Z' fill='%23dce9f2' opacity='.74'/%3E%3Cpath d='M0 650 L245 455 L455 620 L665 390 L875 650 L1110 430 L1290 638 L1510 390 L1800 650 L1800 820 L0 820Z' fill='%23cfdde8' opacity='.55'/%3E%3Cpath d='M565 255 L620 420 L665 390 L704 486 L760 565Z' fill='%23ffffff' opacity='.75'/%3E%3Cpath d='M1295 220 L1360 410 L1406 340 L1475 485 L1800 615Z' fill='%23ffffff' opacity='.82'/%3E%3Cpath d='M940 320 L1002 468 L1048 402 L1110 560Z' fill='%23ffffff' opacity='.68'/%3E%3C/svg%3E") center bottom/cover no-repeat;
}
.hero-trees{
  position:absolute;
  inset-inline:0;
  bottom:0;
  height:300px;
  opacity:.24;
  background:
    linear-gradient(to top,rgba(184,242,47,.12),transparent 55%),
    url("data:image/svg+xml,%3Csvg width='1400' height='320' viewBox='0 0 1400 320' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23071321'%3E%3Cpath d='M30 320h42V190h48L52 72 5 190h48z'/%3E%3Cpath d='M145 320h38V208h43L164 102 122 208h43z'/%3E%3Cpath d='M260 320h52V165h62L286 20 224 165h62z'/%3E%3Cpath d='M430 320h40V190h48L450 72 402 190h48z'/%3E%3Cpath d='M540 320h48V160h56L565 28 508 160h56z'/%3E%3Cpath d='M720 320h42V184h50L742 65 692 184h50z'/%3E%3Cpath d='M860 320h54V155h64L887 8 824 155h64z'/%3E%3Cpath d='M1055 320h46V170h54L1078 42 1024 170h54z'/%3E%3Cpath d='M1220 320h54V155h64L1247 8 1184 155h64z'/%3E%3C/g%3E%3C/svg%3E") bottom center/cover no-repeat;
}
.hero-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1.02fr .98fr;
  gap:30px;
  align-items:center;
  min-height:705px;
  padding:48px 0 38px;
}
.hero-copy{max-width:735px}
.eyebrow{
  color:var(--pink);
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.18em;
  margin:0 0 16px;
}
.hero h1{
  margin:0;
  text-transform:uppercase;
  font-size:clamp(4.25rem,7.1vw,7.15rem);
  line-height:.88;
  letter-spacing:-.07em;
}
.hero-lead{
  margin:28px 0 0;
  font-size:clamp(1.25rem,2vw,1.62rem);
  line-height:1.35;
  font-weight:950;
  max-width:720px;
}
.hero-sub{
  margin:13px 0 0;
  color:var(--muted);
  font-size:1.04rem;
  font-weight:750;
  max-width:760px;
}
.hero-promise{
  margin:18px 0 0;
  font-size:clamp(1.35rem,2vw,1.82rem);
  font-weight:950;
}
.button-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:14px 25px;
  border-radius:999px;
  border:2px solid var(--ink);
  font-weight:950;
  text-decoration:none;
  transition:transform .18s ease,box-shadow .18s ease;
}
.btn:hover,.btn:focus{transform:translateY(-2px)}
.btn-primary{
  background:var(--pink);
  color:#fff;
  box-shadow:0 14px 30px rgba(236,27,104,.30);
}
.btn-secondary{background:#fff;color:var(--ink)}
.hero-scout-wrap{
  align-self:end;
  display:flex;
  justify-content:center;
  position:relative;
}
.hero-scout-wrap:after{
  content:"";
  position:absolute;
  bottom:18px;
  left:12%;
  right:12%;
  height:46px;
  background:rgba(7,19,33,.16);
  filter:blur(22px);
  border-radius:50%;
}
.hero-scout-wrap img{
  position:relative;
  z-index:2;
  max-height:670px;
  object-fit:contain;
  filter:drop-shadow(0 24px 22px rgba(7,19,33,.23));
}
.trust-strip{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  margin-top:0;
}
.trust-strip article{
  display:grid;
  grid-template-columns:54px minmax(0,1fr);
  column-gap:16px;
  align-items:center;
  background:rgba(255,255,255,.96);
  border:1px solid var(--line);
  border-radius:24px;
  padding:20px 24px;
  box-shadow:0 14px 32px rgba(7,19,33,.10);
  min-width:0;
}
.trust-strip span{
  width:52px;
  height:52px;
  border-radius:17px;
  background:var(--green);
  display:grid;
  place-items:center;
  font-size:1.35rem;
  font-weight:950;
}
.trust-strip h2{
  margin:0 0 4px;
  font-size:1.08rem;
  line-height:1.15;
  white-space:nowrap;
}
.trust-strip p{
  margin:0;
  color:var(--muted);
  font-size:.94rem;
  line-height:1.3;
  font-weight:700;
  white-space:nowrap;
}

/* SECTIONS */
.section{padding-block:82px}
.section-heading{text-align:center;max-width:820px;margin-inline:auto}
.section-heading h2,.why-card h2,.about-copy h2,.cta-box h2{
  margin:0;
  font-size:clamp(2.25rem,4vw,3.55rem);
  line-height:1;
  letter-spacing:-.048em;
}
.section-heading p:not(.eyebrow){
  color:var(--muted);
  font-size:1.15rem;
  font-weight:650;
}
.service-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  margin-top:42px;
}
.service-card{
  text-align:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:34px 24px;
  box-shadow:0 14px 35px rgba(7,19,33,.08);
  transition:transform .18s ease,box-shadow .18s ease;
}
.service-card:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 48px rgba(7,19,33,.12);
}
.service-icon{
  width:72px;
  height:72px;
  margin-inline:auto;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:var(--pink);
  color:#fff;
  font-size:1.9rem;
  box-shadow:0 12px 26px rgba(236,27,104,.24);
}
.service-card h3{
  margin:20px 0 10px;
  font-size:1.22rem;
  line-height:1.1;
}
.service-card p{margin:0;color:var(--muted);font-weight:650}

.why-section{background:linear-gradient(135deg,#efffd2,#f6ffe7)}
.why-grid,.about-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:36px;
  align-items:center;
}
.why-card,.about-logo-card{
  background:#fff;
  border-radius:var(--radius);
  padding:40px;
  box-shadow:var(--shadow);
}
.why-card p:not(.eyebrow){color:var(--muted);font-size:1.15rem;font-weight:700}
.why-list{display:grid;gap:15px}
.why-list div{
  background:#fff;
  border-radius:18px;
  padding:19px 22px;
  font-size:1.06rem;
  font-weight:900;
  box-shadow:0 11px 26px rgba(7,19,33,.08);
}
.why-list span{color:var(--pink);margin-right:10px}
.about-logo-card p{
  font-size:1.45rem;
  font-weight:950;
  line-height:1.15;
  margin:28px 0 0;
}
.about-copy p{color:var(--muted);font-size:1.08rem;font-weight:650}
.about-copy blockquote{
  margin:26px 0;
  padding:23px 25px;
  background:#fff0f6;
  border-left:8px solid var(--pink);
  border-radius:20px;
  font-size:1.35rem;
  line-height:1.35;
  font-weight:950;
}
.about-copy .loyal{color:var(--pink);font-size:1.5rem;font-weight:950}

.areas-section{background:#f7f9fb}
.area-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:38px;
}
.area-grid div{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:18px 20px;
  font-weight:950;
  box-shadow:0 8px 20px rgba(7,19,33,.06);
}

.cta-box{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:30px;
  background:var(--ink);
  color:#fff;
  border-radius:34px;
  padding:46px;
  box-shadow:var(--shadow-strong);
}
.cta-box p{color:#dbe3ea;font-size:1.1rem;font-weight:650;max-width:710px}
.mini-pill{
  display:inline-flex;
  color:var(--ink)!important;
  background:var(--green);
  padding:7px 13px;
  border-radius:999px;
  font-size:.82rem!important;
  font-weight:950!important;
  text-transform:uppercase;
  letter-spacing:.14em;
}

.site-footer{
  background:#f7f9fb;
  border-top:1px solid var(--line);
  padding:50px 0 28px;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr 1fr;
  gap:34px;
}
.footer-logo{max-width:340px}
.site-footer h2{margin:0 0 14px;font-size:1.1rem}
.site-footer p{color:var(--muted);font-weight:650}
.site-footer a{color:var(--pink-dark);font-weight:900}
.copyright{margin-top:30px;padding-top:22px;border-top:1px solid var(--line);font-size:.9rem}

/* RESPONSIVE */
@media(max-width:1180px){
  .trust-strip h2,.trust-strip p{white-space:normal}
}
@media(max-width:1000px){
  .brand-mark{width:min(1150px,98vw)}
  .brand-mark img{max-height:190px}
  .nav-row{gap:16px}
  .site-nav{gap:18px}
  .hero-grid{grid-template-columns:1fr;min-height:unset}
  .hero-scout-wrap img{max-height:520px}
  .trust-strip,.service-grid,.area-grid,.footer-grid{grid-template-columns:1fr 1fr}
  .why-grid,.about-grid{grid-template-columns:1fr}
  .cta-box{flex-direction:column;align-items:flex-start}
}
@media(max-width:680px){
  .container{width:min(100% - 28px,1180px)}
  .brand-band{padding:8px 6px 4px}
  .brand-mark img{max-height:130px}
  .nav-row{flex-direction:column;padding:10px 0;gap:10px}
  .site-nav{flex-wrap:wrap;gap:10px 15px;font-size:.76rem}
  .phone-pill{padding:9px 14px;font-size:.86rem}
  .hero{min-height:auto}
  .hero-grid{padding-top:36px}
  .hero h1{font-size:clamp(3.4rem,16vw,4.6rem)}
  .hero-lead{font-size:1.13rem}
  .trust-strip,.service-grid,.area-grid,.footer-grid{grid-template-columns:1fr}
  .trust-strip article{grid-template-columns:48px 1fr}
  .trust-strip span{width:44px;height:44px}
  .section{padding-block:60px}
  .why-card,.about-logo-card,.cta-box{padding:28px}
}


/* FINAL POLISH PASS */
.hero-grid{
  min-height:725px;
  padding:58px 0 44px;
}
.hero-copy .eyebrow{
  margin-bottom:18px;
}
.hero h1{
  margin-bottom:0;
}
.hero-lead{
  margin-top:34px;
  line-height:1.42;
}
.hero-sub{
  margin-top:16px;
  line-height:1.48;
}
.hero-promise{
  margin-top:22px;
}
.button-row{
  margin-top:30px;
}
.hero-scout-wrap img{
  max-height:735px;
}
.hero-scout-wrap:after{
  bottom:12px;
  height:52px;
  background:rgba(7,19,33,.18);
}

.service-card{
  padding:38px 26px;
}
.service-icon{
  width:80px;
  height:80px;
  font-size:2.05rem;
}
.service-card:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 58px rgba(7,19,33,.14);
}

.trust-section{
  padding-block:70px;
  background:
    radial-gradient(circle at 12% 20%,rgba(184,242,47,.18),transparent 25%),
    linear-gradient(135deg,#f9fcff,#ffffff);
}
.trust-wide{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:34px;
  align-items:center;
  background:#fff;
  border:1px solid var(--line);
  border-radius:34px;
  padding:42px;
  box-shadow:var(--shadow);
}
.trust-wide-copy h2{
  margin:0;
  font-size:clamp(2rem,3.6vw,3.25rem);
  line-height:1;
  letter-spacing:-.045em;
}
.trust-wide-copy p:not(.eyebrow){
  margin:18px 0 0;
  color:var(--muted);
  font-size:1.12rem;
  font-weight:700;
}
.trust-badges{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.trust-badges div{
  background:#f7f9fb;
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px 18px;
  font-size:1rem;
  font-weight:950;
  box-shadow:0 8px 20px rgba(7,19,33,.06);
}
.trust-badges div:last-child{
  grid-column:1 / -1;
}
.trust-badges span{
  color:var(--pink);
  margin-right:8px;
}

.area-grid{
  gap:16px;
}
.area-grid div{
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
  min-height:58px;
  border-left:6px solid var(--green);
  background:linear-gradient(90deg,#fff,#fbfdff);
}
.area-grid div::after{
  content:"";
  position:absolute;
  right:-18px;
  top:-20px;
  width:72px;
  height:72px;
  border-radius:50%;
  background:rgba(236,27,104,.08);
}
.area-grid div:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(7,19,33,.10);
}

@media(max-width:1000px){
  .hero-grid{
    min-height:unset;
    padding:44px 0 42px;
  }
  .hero-scout-wrap img{
    max-height:570px;
  }
  .trust-wide{
    grid-template-columns:1fr;
  }
}
@media(max-width:680px){
  .hero-grid{
    padding:38px 0 36px;
  }
  .hero-lead{
    margin-top:24px;
  }
  .hero-scout-wrap img{
    max-height:470px;
  }
  .trust-wide{
    padding:28px;
  }
  .trust-badges{
    grid-template-columns:1fr;
  }
  .trust-badges div:last-child{
    grid-column:auto;
  }
}


/* FINAL HERO BACKGROUND - REAL WEBSITE CODE USING OPTIMIZED FOREST ASSET */
.hero{
  background:#f4faf5;
  min-height:720px;
}
.hero-mountains{
  position:absolute;
  inset:0;
  background-image:url("images/ponderosa-forest-hero-final.jpg");
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  opacity:1;
}
.hero-mountains::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(255,255,255,.88) 0%,rgba(255,255,255,.72) 36%,rgba(255,255,255,.34) 100%),
    linear-gradient(to bottom,rgba(255,255,255,.10),rgba(255,255,255,.00) 48%,rgba(7,19,33,.16) 100%);
}
.hero-mountains::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 14% 20%,rgba(184,242,47,.10),transparent 25%),
    radial-gradient(circle at 88% 20%,rgba(236,27,104,.08),transparent 25%);
}
.hero-trees{
  display:none;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    linear-gradient(90deg,rgba(255,255,255,.16),rgba(255,255,255,.04) 58%,rgba(255,255,255,0)),
    linear-gradient(to bottom,rgba(255,255,255,.06),rgba(255,255,255,0) 56%,rgba(7,19,33,.10));
}
.hero-grid{
  z-index:2;
}
.hero-copy{
  text-shadow:0 1px 0 rgba(255,255,255,.18);
}
.hero-scout-wrap img{
  filter:drop-shadow(0 32px 30px rgba(7,19,33,.38));
}
.trust-strip article{
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(5px);
}
@media(max-width:1000px){
  .hero-mountains{
    background-image:url("images/ponderosa-forest-hero-final-small.jpg");
    background-position:center center;
  }
  .hero-mountains::before{
    background:
      linear-gradient(90deg,rgba(255,255,255,.91),rgba(255,255,255,.68)),
      linear-gradient(to bottom,rgba(255,255,255,.14),rgba(7,19,33,.10));
  }
}
@media(max-width:680px){
  .hero-mountains::before{
    background:rgba(255,255,255,.84);
  }
}
