/* Arab Pest Pros — shared stylesheet — multi-page */
/* System font stack — no Google Fonts */
:root {
  --green: #2d6a2f;
  --green-dark: #1e4a20;
  --amber: #e67e22;
  --amber-dark: #b5641c;
  --text: #1a1a1a;
  --text-muted: #555;
  --bg: #fff;
  --bg-alt: #f5f7f5;
  --border: #ddd;
  --radius: 4px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:var(--green);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Utility ─────────────────────────────────────────── */
.container{max-width:1100px;margin:0 auto;padding:0 1.25rem}
.btn{display:inline-block;padding:.75rem 1.5rem;border-radius:var(--radius);font-weight:700;font-size:1rem;cursor:pointer;text-align:center;border:none;text-decoration:none}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--amber);color:#fff}
.btn-primary:hover{background:var(--amber-dark)}
.btn-call{background:var(--green);color:#fff;font-size:1.1rem;padding:.85rem 1.75rem}
.btn-call:hover{background:var(--green-dark)}
.section{padding:3rem 0;border-top:1px solid var(--border)}
.section-alt{background:var(--bg-alt)}
.section-title{font-size:1.75rem;font-weight:800;color:var(--green-dark);margin-bottom:.5rem;line-height:1.2}
.section-sub{color:var(--text-muted);margin-bottom:2rem;font-size:1.05rem}
.tag{display:inline-block;background:var(--green);color:#fff;font-size:.75rem;font-weight:700;padding:.2rem .55rem;border-radius:var(--radius);text-transform:uppercase;letter-spacing:.04em}

/* ── Nav ─────────────────────────────────────────────── */
.site-nav{background:var(--green-dark);padding:.75rem 0;position:sticky;top:0;z-index:100;border-bottom:2px solid #0f2e11}
.nav-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.nav-brand{color:#fff;font-size:1.1rem;font-weight:800}
.nav-brand:hover{text-decoration:none;color:#c8e6c9}
.nav-links{display:flex;gap:1.1rem;flex-wrap:wrap;align-items:center}
.nav-links a{color:#c8e6c9;font-size:.88rem;font-weight:600}
.nav-links a:hover{color:#fff;text-decoration:none}
.nav-cta{background:var(--amber);color:#fff!important;padding:.35rem .9rem;border-radius:var(--radius);font-weight:700!important}
.nav-cta:hover{background:var(--amber-dark)!important}

/* ── Hero ────────────────────────────────────────────── */
.hero{background:var(--green-dark);color:#fff;padding:3.5rem 0 3rem;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:url('images/hero.webp') center/cover no-repeat;opacity:.25}
.hero-inner{display:grid;grid-template-columns:1fr;gap:2rem;align-items:center;position:relative;z-index:1}
@media(min-width:700px){.hero-inner{grid-template-columns:1fr 1fr}}
.hero-badge{display:inline-block;background:var(--amber);color:#fff;font-size:.8rem;font-weight:700;padding:.3rem .8rem;border-radius:var(--radius);text-transform:uppercase;letter-spacing:.06em;margin-bottom:1rem}
.hero h1{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:900;line-height:1.15;margin-bottom:.75rem}
.hero-sub{font-size:1.1rem;color:#c8e6c9;margin-bottom:1.5rem;line-height:1.5}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}
.hero-phone{font-size:1.3rem;font-weight:800;color:#fff;border:2px solid rgba(255,255,255,.5);padding:.65rem 1.25rem;border-radius:var(--radius);display:inline-flex;align-items:center;gap:.4rem}
.hero-phone:hover{background:rgba(255,255,255,.1);text-decoration:none;color:#fff}
.hero-trust{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:.75rem}
.hero-trust span{color:#e8f5e9;font-size:.85rem;border-left:3px solid var(--amber);padding-left:.5rem}
.hero-img{border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.15)}
.hero-img img{width:100%;height:260px;object-fit:cover}
.hero-img-placeholder{width:100%;height:260px;background:var(--green-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;color:rgba(255,255,255,.6);font-size:.9rem;gap:.5rem;border-radius:var(--radius);border:1px solid rgba(255,255,255,.15)}

/* ── Services grid ───────────────────────────────────── */
.services-grid{margin-top:2rem}
.service-card{border-top:1px solid var(--border);padding:1.25rem 0}
.service-card:last-child{border-bottom:1px solid var(--border)}
.service-icon{font-size:1.5rem;margin-bottom:.5rem}
.service-card h3{font-size:1.1rem;font-weight:800;color:var(--green-dark);margin-bottom:.4rem}
.service-card p{font-size:.95rem;color:var(--text-muted);margin-bottom:.75rem;line-height:1.55}
.service-card a{color:var(--green);font-weight:700;font-size:.9rem}
.service-card a:hover{color:var(--green-dark)}

/* ── Trust pillars ───────────────────────────────────── */
.trust-grid{margin-top:2rem}
.trust-item{padding:1rem 0 1rem 1rem;border-left:4px solid var(--green);margin-bottom:1.25rem}
.trust-icon{font-size:1.5rem;margin-bottom:.4rem}
.trust-item h3{font-size:1.1rem;font-weight:800;color:var(--green-dark);margin-bottom:.3rem}
.trust-item p{font-size:.9rem;color:var(--text-muted)}

/* ── Service area chips ──────────────────────────────── */
.area-chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.5rem}
.area-chip{display:inline-block;background:var(--bg-alt);border:1px solid var(--border);color:var(--green-dark);font-size:.88rem;font-weight:600;padding:.35rem .8rem;border-radius:var(--radius)}
.area-chip:hover{background:var(--green);color:#fff;text-decoration:none}

/* ── Process steps ───────────────────────────────────── */
.process-steps{margin-top:2rem;counter-reset:steps}
.process-step{border-top:1px solid var(--border);padding:1.25rem 0 1.25rem 3.5rem;position:relative}
.process-step:last-child{border-bottom:1px solid var(--border)}
.process-step::before{content:counter(steps);counter-increment:steps;position:absolute;left:0;top:1.25rem;background:var(--green);color:#fff;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem}
.process-step h3{font-size:1.05rem;font-weight:800;color:var(--green-dark);margin-bottom:.4rem}
.process-step p{font-size:.92rem;color:var(--text-muted)}

/* ── FAQ ─────────────────────────────────────────────── */
.faq-list{margin-top:1.5rem}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:first-child{border-top:1px solid var(--border)}
.faq-item h3{font-size:1rem;font-weight:700;color:var(--green-dark);margin-bottom:.5rem;padding-top:1rem}
.faq-item p{font-size:.93rem;color:var(--text-muted);line-height:1.6;padding-bottom:1rem}
.faq-item a{color:var(--green);font-weight:600}

/* ── Reviews ─────────────────────────────────────────── */
.reviews-grid{margin-top:2rem}
.review-card{border-top:1px solid var(--border);padding:1.25rem 0}
.review-card:last-child{border-bottom:1px solid var(--border)}
.review-stars{color:#f4b400;font-size:1.1rem;margin-bottom:.6rem}
.review-text{font-size:.95rem;color:var(--text-muted);font-style:italic;margin-bottom:.5rem;line-height:1.55}
.review-author{font-size:.85rem;font-weight:700;color:var(--green-dark)}
.review-placeholder-notice{font-size:.75rem;color:#c0392b;font-style:normal;display:block;margin-top:.35rem;font-weight:600}

/* ── Contact section ─────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-top:2rem}
@media(min-width:700px){.contact-grid{grid-template-columns:1fr 1fr}}
.contact-info h3{font-size:1.1rem;font-weight:800;color:var(--green-dark);margin-bottom:1rem}
.contact-info p{font-size:.95rem;color:var(--text-muted);margin-bottom:.5rem}
.contact-phone-big{font-size:1.8rem;font-weight:900;color:var(--green);display:block;margin-bottom:.5rem}
.contact-form{background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem}
.contact-form h3{font-size:1.1rem;font-weight:800;color:var(--green-dark);margin-bottom:1.25rem}
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:.88rem;font-weight:700;color:var(--text);margin-bottom:.3rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.65rem .85rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;font-family:inherit;color:var(--text);background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:2px solid var(--green);outline-offset:0}
.form-group textarea{resize:vertical;min-height:90px}
.form-submit{width:100%;padding:.85rem;font-size:1rem;font-weight:700;background:var(--green);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-family:inherit}
.form-submit:hover{background:var(--green-dark)}
.form-success{display:none;background:#e8f5e9;border:1px solid var(--green);color:var(--green-dark);padding:1rem;border-radius:var(--radius);font-weight:600;margin-top:1rem}

/* ── Map placeholder ─────────────────────────────────── */
.map-wrap{margin-top:1.5rem}
.map-static{display:block;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.map-static img{width:100%;height:200px;object-fit:cover}
.map-placeholder{width:100%;height:200px;background:var(--bg-alt);display:flex;align-items:center;justify-content:center;border-radius:var(--radius);border:1px solid var(--border);color:var(--green-dark);font-weight:600;font-size:.95rem}
.directions-link{display:inline-block;margin-top:.75rem;font-size:.9rem;font-weight:600;color:var(--green)}

/* ── CTA bar ─────────────────────────────────────────── */
.cta-bar{background:var(--green);color:#fff;padding:2.5rem 0;text-align:center}
.cta-bar h2{font-size:1.6rem;font-weight:900;margin-bottom:.5rem}
.cta-bar p{color:#c8e6c9;margin-bottom:1.5rem}
.cta-bar-btns{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.cta-bar .btn-call{background:#fff;color:var(--green);font-size:1.15rem}
.cta-bar .btn-call:hover{background:#e8f5e9}
.cta-bar .btn-primary{background:var(--amber)}

/* ── Breadcrumb ──────────────────────────────────────── */
.breadcrumb{background:var(--bg-alt);border-bottom:1px solid var(--border);padding:.6rem 0}
.breadcrumb nav{font-size:.85rem;color:var(--text-muted)}
.breadcrumb a{color:var(--green)}
.breadcrumb span{color:var(--text-muted)}

/* ── Page hero (subpages) ────────────────────────────── */
.page-hero{background:var(--green-dark);color:#fff;padding:2.75rem 0 2.25rem;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:url('../images/hero.webp') center/cover no-repeat;opacity:.2}
.page-hero-inner{position:relative;z-index:1}
.page-hero h1{font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:900;line-height:1.2;margin-bottom:.6rem}
.page-hero p{color:#c8e6c9;font-size:1rem;margin-bottom:1.25rem;max-width:650px}
.page-hero-ctas{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}
.page-phone{font-size:1.15rem;font-weight:800;color:#fff;border:2px solid rgba(255,255,255,.5);padding:.55rem 1.1rem;border-radius:var(--radius);display:inline-flex;align-items:center;gap:.35rem}
.page-phone:hover{background:rgba(255,255,255,.1);text-decoration:none;color:#fff}

/* ── Content prose ───────────────────────────────────── */
.prose{max-width:760px}
.prose h2{font-size:1.4rem;font-weight:800;color:var(--green-dark);margin:2rem 0 .6rem}
.prose h3{font-size:1.1rem;font-weight:700;color:var(--green-dark);margin:1.5rem 0 .4rem}
.prose p{color:var(--text-muted);margin-bottom:1rem;line-height:1.7;font-size:.97rem}
.prose ul{margin:.5rem 0 1rem 1.25rem;color:var(--text-muted);font-size:.97rem}
.prose ul li{margin-bottom:.35rem;line-height:1.6}
.prose strong{color:var(--text)}

/* ── Related services ────────────────────────────────── */
.related-grid{margin-top:1.5rem}
.related-card{border-top:1px solid var(--border);padding:1rem 0}
.related-card:last-child{border-bottom:1px solid var(--border)}
.related-card h4{font-size:.95rem;font-weight:700;color:var(--green-dark);margin-bottom:.3rem}
.related-card p{font-size:.85rem;color:var(--text-muted);margin-bottom:.4rem}
.related-card a{font-size:.88rem;font-weight:600;color:var(--green)}

/* ── Locations hub ───────────────────────────────────── */
.locations-grid{margin-top:2rem}
.location-card{border-top:1px solid var(--border);padding:1.25rem 0}
.location-card:last-child{border-bottom:1px solid var(--border)}
.location-card h3{font-size:1.1rem;font-weight:800;color:var(--green-dark);margin-bottom:.4rem}
.location-card p{font-size:.9rem;color:var(--text-muted);margin-bottom:.6rem;line-height:1.5}
.location-card a{font-size:.9rem;font-weight:600;color:var(--green)}

/* ── Inline chip row ─────────────────────────────────── */
.chip-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}
.chip{display:inline-block;background:var(--bg-alt);border:1px solid var(--border);color:var(--green-dark);font-size:.82rem;padding:.25rem .6rem;border-radius:var(--radius)}

/* ── Hub grid (services hub, locations hub) ──────────── */
.hub-grid{margin-top:2rem}
.hub-card{border-top:1px solid var(--border);padding:1.25rem 0}
.hub-card:last-child{border-bottom:1px solid var(--border)}
.hub-card-icon{font-size:1.5rem;margin-bottom:.4rem}
.hub-card h3{font-size:1.1rem;font-weight:800;color:var(--green-dark);margin-bottom:.4rem}
.hub-card p{font-size:.9rem;color:var(--text-muted);margin-bottom:.75rem;line-height:1.55}
.hub-card a.btn-sm{display:inline-block;font-size:.88rem;font-weight:700;color:#fff;background:var(--green);padding:.4rem .9rem;border-radius:var(--radius)}
.hub-card a.btn-sm:hover{background:var(--green-dark);text-decoration:none}

/* ── Footer ──────────────────────────────────────────── */
.site-footer{background:#1a2e1a;color:#c8e6c9;padding:2.5rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}
.footer-col h4{font-size:.95rem;font-weight:800;color:#fff;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.04em}
.footer-col p,.footer-col li{font-size:.85rem;color:#a5d6a7;line-height:1.7}
.footer-col ul{list-style:none}
.footer-col a{color:#a5d6a7}
.footer-col a:hover{color:#fff;text-decoration:none}
.footer-nap p{font-size:.88rem;color:#a5d6a7;line-height:1.8}
.footer-nap strong{color:#fff}
.footer-disclosure{border-top:1px solid #2d4a2d;padding-top:1.25rem;font-size:.8rem;color:#7cb37e;line-height:1.6;max-width:700px}
.footer-copy{margin-top:.75rem;font-size:.78rem;color:#4a7a4a}

/* ── Responsive ──────────────────────────────────────── */
@media(max-width:600px){
  .section{padding:2.5rem 0}
  .hero{padding:2.5rem 0 2rem}
  .hero h1{font-size:1.7rem}
  .cta-bar h2{font-size:1.3rem}
  .nav-links{gap:.6rem}
  .nav-links a{font-size:.82rem}
}

/* ── Skip link ───────────────────────────────────────── */
.skip-link{position:absolute;top:-100px;left:0;background:var(--green);color:#fff;padding:.5rem 1rem;font-weight:700;z-index:9999}
.skip-link:focus{top:0}
