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

:root{
  --green:#16613B;
  --green-dark:#0D4228;
  --green-light:#E8F5E9;
  --amber:#F59E0B;
  --amber-dark:#D97706;
  --gray-900:#111827;
  --gray-800:#1f2937;
  --gray-700:#374151;
  --gray-600:#4b5563;
  --gray-400:#9ca3af;
  --gray-200:#e5e7eb;
  --gray-100:#f3f4f6;
  --gray-50:#f9fafb;
  --white:#ffffff;
  --shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);
  --shadow-lg:0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05);
  --radius:8px;
  --transition:0.2s ease;
}

html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,sans-serif;color:var(--gray-800);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--green);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--green-dark)}

.container{max-width:1140px;margin:0 auto;padding:0 20px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;border:2px solid transparent;transition:all var(--transition);text-decoration:none}
.btn-primary{background:var(--amber);color:var(--gray-900);border-color:var(--amber)}
.btn-primary:hover{background:var(--amber-dark);border-color:var(--amber-dark);color:var(--gray-900);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-outline{background:transparent;color:var(--white);border-color:var(--white)}
.btn-outline:hover{background:var(--white);color:var(--green-dark)}
.btn-green{background:var(--green);color:var(--white);border-color:var(--green)}
.btn-green:hover{background:var(--green-dark);border-color:var(--green-dark);color:var(--white);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-lg{padding:16px 36px;font-size:1.1rem}
.btn-sm{padding:8px 20px;font-size:.9rem}

/* Navigation */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--white);box-shadow:var(--shadow);height:72px;display:flex;align-items:center}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:1140px;margin:0 auto;padding:0 20px}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.1rem;color:var(--green-dark);text-decoration:none}
.nav-logo img{height:48px;width:auto}
.nav-links{display:flex;align-items:center;gap:8px;list-style:none}
.nav-links a{padding:8px 14px;color:var(--gray-700);font-weight:500;font-size:.95rem;border-radius:var(--radius);transition:all var(--transition)}
.nav-links a:hover,.nav-links a.active{color:var(--green);background:var(--green-light)}
.nav-links .btn{margin-left:8px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--gray-700);margin:5px 0;transition:all var(--transition)}

/* Hero */
.hero{position:relative;min-height:85vh;display:flex;align-items:center;padding:120px 0 80px;background:var(--gray-900);overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.3}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(13,66,40,.92) 0%,rgba(22,97,59,.8) 50%,rgba(17,24,39,.9) 100%)}
.hero-content{position:relative;z-index:1;max-width:700px}
.hero h1{font-size:clamp(2rem,5vw,3.2rem);color:var(--white);line-height:1.15;margin-bottom:16px;font-weight:800}
.hero h1 span{color:var(--amber)}
.hero p{font-size:clamp(1rem,2vw,1.25rem);color:var(--gray-200);margin-bottom:32px;max-width:550px}
.hero-badges{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:32px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);color:var(--white);padding:8px 16px;border-radius:100px;font-size:.9rem;font-weight:500;backdrop-filter:blur(4px)}
.hero-badge svg{width:18px;height:18px;flex-shrink:0}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px}

/* Page Hero (smaller, for inner pages) */
.page-hero{padding:120px 0 60px;background:linear-gradient(135deg,var(--green-dark) 0%,var(--green) 100%);color:var(--white);text-align:center}
.page-hero h1{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:12px;font-weight:800}
.page-hero p{font-size:1.1rem;color:var(--gray-200);max-width:600px;margin:0 auto}

/* Sections */
.section{padding:80px 0}
.section-alt{background:var(--gray-50)}
.section-dark{background:var(--gray-900);color:var(--white)}
.section-header{text-align:center;margin-bottom:48px}
.section-header h2{font-size:clamp(1.6rem,3vw,2.2rem);color:var(--gray-900);margin-bottom:12px;font-weight:700}
.section-dark .section-header h2{color:var(--white)}
.section-header p{font-size:1.05rem;color:var(--gray-600);max-width:600px;margin:0 auto}
.section-dark .section-header p{color:var(--gray-400)}

/* Services Grid */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.service-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);padding:28px;transition:all var(--transition)}
.service-card:hover{border-color:var(--green);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.service-card svg{width:36px;height:36px;color:var(--green);margin-bottom:16px}
.service-card h3{font-size:1.15rem;margin-bottom:8px;color:var(--gray-900)}
.service-card p{font-size:.95rem;color:var(--gray-600);line-height:1.6}

/* Value Props */
.values-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:24px}
.value-card{text-align:center;padding:32px 20px}
.value-card svg{width:48px;height:48px;color:var(--green);margin:0 auto 16px}
.value-card h3{font-size:1.15rem;margin-bottom:8px;color:var(--gray-900)}
.value-card p{font-size:.95rem;color:var(--gray-600)}

/* Service Area */
.area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.area-card{display:flex;align-items:center;gap:8px;padding:14px 18px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-700);font-weight:500;transition:all var(--transition);text-decoration:none}
.area-card:hover{border-color:var(--green);color:var(--green);box-shadow:var(--shadow)}
.area-card svg{width:16px;height:16px;color:var(--green);flex-shrink:0}

/* CTA Banner */
.cta-banner{background:linear-gradient(135deg,var(--green-dark),var(--green));padding:60px 0;text-align:center;color:var(--white)}
.cta-banner h2{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:12px;font-weight:700}
.cta-banner p{font-size:1.1rem;color:var(--gray-200);margin-bottom:28px;max-width:500px;margin-left:auto;margin-right:auto}
.cta-banner .cta-buttons{display:flex;justify-content:center;flex-wrap:wrap;gap:12px}

/* About */
.about-content{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.about-text h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:16px;color:var(--gray-900);font-weight:700}
.about-text p{margin-bottom:16px;color:var(--gray-600);font-size:1.05rem}
.about-image{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.about-features{list-style:none;margin:24px 0;display:flex;flex-direction:column;gap:12px}
.about-features li{display:flex;align-items:center;gap:10px;font-weight:500;color:var(--gray-700)}
.about-features li svg{width:20px;height:20px;color:var(--green);flex-shrink:0}

/* Select Companies */
.select-companies{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);padding:32px;margin-top:32px}
.select-companies h3{font-size:1.15rem;margin-bottom:12px;color:var(--gray-900)}
.select-companies p{color:var(--gray-600);margin-bottom:16px}
.select-links{display:flex;flex-wrap:wrap;gap:12px}
.select-links a{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-700);font-weight:500;transition:all var(--transition)}
.select-links a:hover{border-color:var(--green);color:var(--green)}

/* FAQ */
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;background:var(--white)}
.faq-question{width:100%;padding:20px 24px;background:none;border:none;text-align:left;font-size:1.05rem;font-weight:600;color:var(--gray-900);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:background var(--transition)}
.faq-question:hover{background:var(--gray-50)}
.faq-question svg{width:20px;height:20px;color:var(--gray-400);flex-shrink:0;transition:transform var(--transition)}
.faq-item.open .faq-question svg{transform:rotate(180deg)}
.faq-answer{padding:0 24px;max-height:0;overflow:hidden;transition:all 0.3s ease}
.faq-item.open .faq-answer{padding:0 24px 20px;max-height:500px}
.faq-answer p{color:var(--gray-600);line-height:1.7;font-size:.95rem}
.faq-answer p+p{margin-top:12px}

/* Contact Form */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.contact-info h2{font-size:1.8rem;margin-bottom:16px;color:var(--gray-900);font-weight:700}
.contact-info>p{color:var(--gray-600);margin-bottom:32px;font-size:1.05rem}
.contact-methods{display:flex;flex-direction:column;gap:20px}
.contact-method{display:flex;gap:16px;align-items:flex-start}
.contact-method svg{width:24px;height:24px;color:var(--green);flex-shrink:0;margin-top:2px}
.contact-method h3{font-size:1rem;color:var(--gray-900);margin-bottom:2px}
.contact-method p{color:var(--gray-600);font-size:.95rem}
.contact-method a{color:var(--green);font-weight:600;font-size:1.1rem}

.contact-form{background:var(--gray-900);border-radius:var(--radius);padding:36px}
.contact-form h3{color:var(--white);font-size:1.3rem;margin-bottom:24px}
.form-group{margin-bottom:20px}
.form-group label{display:block;color:var(--gray-400);font-size:.9rem;margin-bottom:6px;font-weight:500}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;background:var(--gray-800);border:1px solid var(--gray-700);border-radius:var(--radius);color:var(--white);font-size:1rem;font-family:inherit;transition:border-color var(--transition)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--green)}
.form-group textarea{resize:vertical;min-height:120px}
.form-submit{width:100%}
#form-status{margin-top:16px;padding:12px 16px;border-radius:var(--radius);font-size:.95rem;display:none}
#form-status.success{display:block;background:rgba(22,97,59,.15);border:1px solid var(--green);color:var(--green-light)}
#form-status.error{display:block;background:rgba(239,68,68,.15);border:1px solid #ef4444;color:#fca5a5}

/* Footer */
.footer{background:var(--gray-800);color:var(--gray-400);padding:60px 0 0}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--gray-700)}
.footer-companies a{font-size:.9rem;color:var(--gray-400);display:block;margin-bottom:6px;transition:color var(--transition)}
.footer-companies a:hover{color:var(--white)}
.footer-brand p{margin-top:12px;font-size:.9rem;line-height:1.6}
.footer h4{color:var(--white);font-size:1rem;margin-bottom:16px;font-weight:600}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-links a{color:var(--gray-400);font-size:.9rem;transition:color var(--transition)}
.footer-links a:hover{color:var(--white)}
.footer-contact p,.footer-contact a{font-size:.9rem;color:var(--gray-400);display:block;margin-bottom:6px}
.footer-contact a:hover{color:var(--white)}
.footer-select{margin-top:16px;font-size:.85rem;line-height:1.5}
.footer-select a{color:var(--green-light)}
.footer-select a:hover{color:var(--white)}
.footer-bottom{padding:20px 0;text-align:center;font-size:.85rem}

/* Service Area Page - Town Pages */
.area-hero{padding:120px 0 60px;background:linear-gradient(135deg,var(--green-dark),var(--green));color:var(--white);text-align:center}
.area-hero h1{font-size:clamp(1.8rem,4vw,2.5rem);margin-bottom:8px;font-weight:800}
.area-hero p{color:var(--gray-200);font-size:1.1rem}
.area-services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.area-service{display:flex;align-items:center;gap:10px;padding:16px;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius)}
.area-service svg{width:20px;height:20px;color:var(--green);flex-shrink:0}
.area-service span{font-weight:500;color:var(--gray-700)}
.nearby-areas{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.nearby-area{display:inline-flex;align-items:center;padding:8px 18px;border:1px solid var(--gray-200);border-radius:100px;color:var(--gray-700);font-size:.9rem;font-weight:500;transition:all var(--transition)}
.nearby-area:hover{border-color:var(--green);color:var(--green);background:var(--green-light)}

/* Phone link */
.phone-link{color:var(--amber);font-weight:700;font-size:1.2rem;text-decoration:none}
.phone-link:hover{color:var(--amber-dark)}

/* Responsive */
@media(max-width:768px){
  .nav-toggle{display:block}
  .nav-links{position:fixed;top:72px;left:0;right:0;background:var(--white);flex-direction:column;padding:20px;box-shadow:var(--shadow-lg);transform:translateY(-120%);transition:transform 0.3s ease;gap:4px}
  .nav-links.active{transform:translateY(0)}
  .nav-links a{padding:12px 16px;width:100%}
  .nav-links .btn{margin-left:0;width:100%;justify-content:center}
  .hero{min-height:auto;padding:100px 0 60px}
  .hero h1{font-size:clamp(1.8rem,6vw,2.5rem)}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{width:100%;justify-content:center}
  .about-content{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .area-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
  .section{padding:60px 0}
  .values-grid{grid-template-columns:1fr}
}

@media(max-width:480px){
  .hero-badges{flex-direction:column}
  .container{padding:0 16px}
  .service-card{padding:20px}
  .contact-form{padding:24px}
  .section{padding:48px 0}
}
