/* CommsGap — styles */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Poppins',Arial,sans-serif;font-weight:300;color:#2C4A3E;background:#F5F2EC;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:#3F8E5C;text-decoration:none;transition:color .3s}
a:hover{color:#2C4A3E}
h1,h2,h3,h4,h5{font-weight:600;color:#2C4A3E;line-height:1.25}
h1{font-size:2.4rem;margin-bottom:1rem}
h2{font-size:1.8rem;margin:0 0 1rem}
h3{font-size:1.2rem;margin:0 0 .6rem}
p{margin:0 0 1rem;max-width:700px}
ul,ol{margin:0 0 1rem 1.4rem}
li{margin-bottom:.4rem}

.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* Header */
.site-header{background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.05);position:sticky;top:0;z-index:50}
.nav-wrap{display:flex;justify-content:space-between;align-items:center;padding:18px 24px}
.logo{font-weight:700;font-size:1.3rem;color:#2C4A3E;display:flex;align-items:center;gap:8px}
.logo-mark{color:#3F8E5C;font-size:1.5rem}
.main-nav{display:flex;gap:28px}
.main-nav a{color:#2C4A3E;font-weight:400;position:relative;padding:6px 0}
.main-nav a.active,.main-nav a:hover{color:#3F8E5C}
.main-nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:#3F8E5C}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.nav-toggle span{display:block;width:24px;height:2px;background:#2C4A3E}

/* Hero */
.hero{min-height:520px;display:flex;align-items:center;background-size:cover;background-position:center;color:#fff;padding:80px 0}
.hero-inner{max-width:1200px}
.hero h1{color:#fff;font-size:2.8rem;max-width:880px}
.hero .lead{color:#F5F2EC;max-width:720px;font-size:1.15rem;margin-bottom:2rem}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.page-hero{padding:90px 0 70px;background-size:cover;background-position:center;color:#fff}
.page-hero h1{color:#fff}
.page-hero .lead{color:#F5F2EC;max-width:780px;font-size:1.1rem}
.page-hero-plain{background:#2C4A3E}

/* Buttons */
.btn{display:inline-block;padding:12px 26px;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;border:0;transition:all .3s;text-align:center}
.btn-primary{background:#3F8E5C;color:#fff}
.btn-primary:hover{background:#2C4A3E;color:#fff}
.btn-ghost{background:transparent;color:#fff;border:2px solid #fff;padding:10px 24px}
.btn-ghost:hover{background:#fff;color:#2C4A3E}
.btn-lg{padding:14px 34px;font-size:1.05rem}
.btn-sm{padding:8px 18px;font-size:.85rem}

/* Sections */
.section{padding:80px 0}
.section-alt{background:#EAE5DA}
.section-dark{background:#2C4A3E;color:#F5F2EC}
.section-dark h2{color:#fff}
.section-title{text-align:center;margin-bottom:.6rem;max-width:none}
.section-sub{text-align:center;max-width:780px;margin:0 auto 3rem;color:#4A6B82}

/* Grid */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* Cards */
.card{background:#fff;padding:32px 24px;border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,.08);transition:transform .3s,box-shadow .3s}
.card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.icon-box{width:56px;height:56px;border-radius:12px;background:rgba(63,142,92,.1);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.info-block{background:#fff;padding:28px;border-radius:12px;border-left:4px solid #4A6B82}
.section-dark .info-block{background:rgba(255,255,255,.06);color:#F5F2EC;border-left-color:#3F8E5C}
.section-dark .info-block h3{color:#fff}

/* Two column */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.two-col-img img{border-radius:12px;box-shadow:0 8px 28px rgba(0,0,0,.12)}
.two-col-text h2{margin-bottom:1.2rem}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stats .num{display:block;font-size:3rem;font-weight:700;color:#3F8E5C;margin-bottom:.4rem;line-height:1}
.stats .lbl{display:block;color:#F5F2EC;font-weight:300}

/* CTA */
.cta{background:linear-gradient(135deg,#2C4A3E 0%,#3F8E5C 100%);color:#fff;padding:70px 0}
.cta h2{color:#fff;text-align:center}
.cta-inner{text-align:center}
.cta-inner p{color:#F5F2EC;margin:0 auto 2rem;max-width:640px}

/* Service rows */
.service-row{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:center;margin-bottom:80px;padding-bottom:60px;border-bottom:1px solid rgba(44,74,62,.12)}
.service-row:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}
.service-row.reverse{grid-template-columns:1.2fr 1fr}
.service-row.reverse .service-img{order:2}
.service-img img{border-radius:12px;box-shadow:0 8px 28px rgba(0,0,0,.12);width:100%;height:340px;object-fit:cover}
.service-icon{width:64px;height:64px;border-radius:14px;background:rgba(63,142,92,.12);display:flex;align-items:center;justify-content:center;margin-bottom:18px}

/* Steps */
.steps{counter-reset:step;list-style:none;margin:0;padding:0;max-width:820px}
.steps li{counter-increment:step;padding:18px 22px 18px 70px;position:relative;background:#fff;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.05);margin-bottom:14px}
.steps li::before{content:counter(step);position:absolute;left:18px;top:18px;width:36px;height:36px;border-radius:50%;background:#3F8E5C;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}

/* Feature list */
.feat-list{list-style:none;margin:0;padding:0;max-width:820px}
.feat-list li{padding:14px 0 14px 32px;position:relative;border-bottom:1px solid rgba(44,74,62,.08)}
.feat-list li::before{content:"◆";position:absolute;left:0;top:14px;color:#3F8E5C}

/* Blog */
.blog-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.08);display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.blog-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.12)}
.blog-thumb{display:block;height:220px;overflow:hidden}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.blog-card:hover .blog-thumb img{transform:scale(1.05)}
.blog-body{padding:24px}
.blog-meta{font-size:.85rem;color:#4A6B82;margin-bottom:.6rem;text-transform:uppercase;letter-spacing:.5px}
.blog-body h2{font-size:1.25rem;margin-bottom:.6rem}
.blog-body h2 a{color:#2C4A3E}
.blog-body h2 a:hover{color:#3F8E5C}
.read-more{font-weight:600;display:inline-block;margin-top:.4rem}

/* Article */
.article-page{padding:60px 0 80px}
.article-narrow{max-width:780px}
.breadcrumb{margin-bottom:1.4rem}
.article-meta{color:#4A6B82;font-size:.9rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.5px}
.article-page h1{font-size:2.2rem;margin-bottom:1.2rem}
.article-page h2{font-size:1.5rem;margin-top:2rem;margin-bottom:.8rem}
.article-page h3{font-size:1.15rem;margin-top:1.4rem}
.article-lead{font-size:1.1rem;color:#3a5b4d;margin-bottom:2rem;border-left:4px solid #3F8E5C;padding-left:18px}
.article-nav{display:flex;justify-content:space-between;gap:16px;margin-top:48px;padding-top:32px;border-top:1px solid rgba(44,74,62,.12);flex-wrap:wrap}

/* Forms */
.contact-form{display:flex;flex-direction:column;gap:14px;max-width:560px}
.contact-form label{display:flex;flex-direction:column;font-weight:400;font-size:.95rem;color:#2C4A3E;gap:6px}
.contact-form input,.contact-form textarea{padding:12px 14px;border:1px solid rgba(44,74,62,.18);border-radius:8px;font-family:inherit;font-size:.95rem;background:#fff;transition:border-color .3s}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#3F8E5C}
.contact-form textarea{resize:vertical;min-height:120px}
.contact-form .check{flex-direction:row;align-items:flex-start;gap:10px;font-size:.88rem;line-height:1.45}
.contact-form .check input{margin-top:3px}
.form-status{font-size:.9rem;color:#3F8E5C;margin-top:.6rem}

.hours{list-style:none;margin:0 0 1rem;padding:0;max-width:380px}
.hours li{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(44,74,62,.1)}

/* Map */
.map-wrap iframe{width:100%;height:380px;border:0;border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.map-link{margin-top:.8rem;font-size:.9rem}

/* FAQ */
.faq-item{background:#fff;border-radius:12px;padding:18px 22px;margin-bottom:14px;box-shadow:0 2px 10px rgba(0,0,0,.05)}
.faq-item summary{cursor:pointer;font-weight:600;color:#2C4A3E;font-size:1.05rem;list-style:none;position:relative;padding-right:36px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:6px;top:-2px;font-size:1.6rem;color:#3F8E5C;transition:transform .3s}
.faq-item[open] summary::after{content:"−"}
.faq-item p{margin-top:.8rem}

/* Footer */
.site-footer{background:#1f3329;color:#cfd5d2;padding:60px 0 24px;margin-top:0}
.footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-bottom:32px}
.site-footer h4{color:#fff;margin-bottom:14px;font-size:1.1rem}
.site-footer a{color:#cfd5d2}
.site-footer a:hover{color:#3F8E5C}
.footer-links{list-style:none;margin:0;padding:0}
.footer-links li{margin-bottom:6px}
.copy{border-top:1px solid rgba(255,255,255,.08);padding-top:18px;font-size:.88rem;color:#9da6a2;text-align:center}

/* Cookie banner */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;background:#2C4A3E;color:#F5F2EC;padding:18px 22px;border-radius:12px;display:none;align-items:center;gap:18px;box-shadow:0 8px 28px rgba(0,0,0,.25);z-index:100;flex-wrap:wrap}
.cookie-banner.visible{display:flex}
.cookie-banner p{margin:0;flex:1;min-width:240px;font-size:.9rem}
.cookie-banner a{color:#a4d4b6}

/* Responsive */
@media(max-width:980px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .two-col,.service-row,.service-row.reverse{grid-template-columns:1fr;gap:30px}
  .service-row.reverse .service-img{order:0}
  .stats{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero h1{font-size:2.1rem}
  h1{font-size:2rem}
}
@media(max-width:640px){
  .grid-3,.grid-4{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:18px}
  .stats .num{font-size:2.4rem}
  .footer-grid{grid-template-columns:1fr}
  .nav-toggle{display:flex}
  .main-nav{display:none;position:absolute;top:64px;left:0;right:0;background:#fff;flex-direction:column;padding:16px 24px;box-shadow:0 8px 16px rgba(0,0,0,.08);gap:14px}
  .main-nav.open{display:flex}
  .hero{padding:60px 0;min-height:auto}
  .hero h1{font-size:1.8rem}
  .section{padding:60px 0}
  h1{font-size:1.7rem}
  h2{font-size:1.4rem}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{text-align:center}
}