﻿/* ===================================================
   PREME FENCING SERVICE - PRODUCTION STYLESHEET
   Core Web Vitals Optimized | Mobile-First Design
   =================================================== */
:root {
  --green-900: #1a3c2a;
  --green-800: #1e4d35;
  --green-700: #2a6045;
  --green-600: #2e7d52;
  --green-500: #3a9e6a;
  --green-100: #e8f5ee;
  --green-50:  #f0faf4;
  --gold:      #d4a017;
  --gold-light:#f5c842;
  --text-900:  #111827;
  --text-700:  #374151;
  --text-500:  #6b7280;
  --text-300:  #d1d5db;
  --white:     #ffffff;
  --bg-light:  #f9fafb;
  --radius:    8px;
  --radius-lg: 16px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,.12);
  --shadow-lg: 0 12px 32px rgba(0,0,0,.16);
  --font-sans: "Inter",system-ui,-apple-system,sans-serif;
  --font-head: "Poppins",var(--font-sans);
  --transition: .2s ease;
  --max-w: 1200px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);color:var(--text-700);background:var(--white);line-height:1.65;font-size:1rem}
img{max-width:100%;height:auto;display:block}
a{color:var(--green-700);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--green-500)}
ul{list-style:none}
h1,h2,h3,h4,h5{font-family:var(--font-head);line-height:1.25;color:var(--text-900);font-weight:700}
h1{font-size:clamp(1.75rem,4vw,2.75rem)}
h2{font-size:clamp(1.4rem,3vw,2.1rem)}
h3{font-size:clamp(1.1rem,2.5vw,1.4rem)}
h4{font-size:1.1rem}
p{margin-bottom:.9rem}
p:last-child{margin-bottom:0}
.container{max-width:var(--max-w);margin-inline:auto;padding-inline:1.25rem}
.section{padding:5rem 0}
.section--alt{background:var(--bg-light)}
.section--green{background:var(--green-900);color:var(--white)}
.section--green h2,.section--green h3{color:var(--white)}
.section-header{text-align:center;max-width:700px;margin:0 auto 3rem}
.section-header p{color:var(--text-500);font-size:1.1rem}
.text-green{color:var(--green-700)}
.text-gold{color:var(--gold)}
.text-center{text-align:center}
.lead{font-size:1.15rem;color:var(--text-700)}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.75rem;border-radius:var(--radius);font-weight:600;font-size:.95rem;cursor:pointer;border:2px solid transparent;text-align:center;transition:all var(--transition);text-decoration:none;line-height:1.2;white-space:nowrap}
.btn-primary{background:var(--green-800);color:var(--white);border-color:var(--green-800)}
.btn-primary:hover{background:var(--green-700);color:var(--white);border-color:var(--green-700);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-secondary{background:var(--white);color:var(--green-800);border-color:var(--green-800)}
.btn-secondary:hover{background:var(--green-50);color:var(--green-800)}
.btn-gold{background:var(--gold);color:var(--text-900);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-light);color:var(--text-900);transform:translateY(-2px)}
.btn-outline-white{background:transparent;color:var(--white);border-color:rgba(255,255,255,.7)}
.btn-outline-white:hover{background:rgba(255,255,255,.1);color:var(--white)}
.btn-lg{padding:1rem 2.25rem;font-size:1.05rem}
.btn-sm{padding:.55rem 1.2rem;font-size:.875rem}
/* NAVBAR */
.navbar{background:var(--white);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:900;padding:.75rem 0}
.navbar .container{display:flex;align-items:center;gap:1rem}
.navbar-logo{display:flex;align-items:center;gap:.75rem;flex-shrink:0;text-decoration:none}
.navbar-logo img{height:48px;width:auto}
.navbar-logo-text{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--green-900);line-height:1.2}
.navbar-menu{display:flex;align-items:center;gap:.25rem;margin-left:auto}
.navbar-menu > li > a{padding:.5rem .85rem;border-radius:var(--radius);font-weight:500;color:var(--text-700);font-size:.925rem;display:block;transition:all var(--transition)}
.navbar-menu > li > a:hover,.navbar-menu > li.active > a{color:var(--green-700);background:var(--green-50)}
.dropdown{position:relative}
.dropdown-menu{display:none;position:absolute;top:calc(100% + .5rem);left:0;background:var(--white);border:1px solid var(--text-300);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:220px;z-index:100;padding:.5rem 0}
.dropdown:hover .dropdown-menu{display:block}
.dropdown-menu a{display:block;padding:.6rem 1.1rem;font-size:.9rem;color:var(--text-700)}
.dropdown-menu a:hover{background:var(--green-50);color:var(--green-700)}
.navbar-phone{display:flex;align-items:center;gap:.5rem;background:var(--green-800);color:var(--white);padding:.6rem 1.1rem;border-radius:var(--radius);font-weight:600;font-size:.9rem;text-decoration:none;flex-shrink:0;transition:background var(--transition)}
.navbar-phone:hover{background:var(--green-700);color:var(--white)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;margin-left:auto}
.hamburger span{display:block;width:24px;height:2px;background:var(--text-900);border-radius:2px;transition:all var(--transition)}
/* HERO */
.hero{background:linear-gradient(135deg,var(--green-900) 0%,var(--green-700) 100%);color:var(--white);padding:5rem 0}
.hero h1{color:var(--white);margin-bottom:1rem;max-width:750px}
.hero .hero-sub{font-size:1.1rem;color:rgba(255,255,255,.85);margin-bottom:2rem;max-width:600px}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero-badges{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}
.hero-badge{display:flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:50px;padding:.4rem .9rem;font-size:.85rem;color:rgba(255,255,255,.9)}
/* TRUST BAR */
.trust-bar{background:var(--green-50);border-bottom:1px solid #d1e7da;padding:1.1rem 0}
.trust-bar .container{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 2rem}
.trust-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:var(--text-700)}
.trust-item .check{color:var(--green-700);font-size:1.1rem}
/* SERVICE CARDS */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.service-card{background:var(--white);border:1px solid #e5e7eb;border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition);text-decoration:none;display:flex;flex-direction:column}
.service-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--green-500)}
.service-card-img{width:100%;height:200px;object-fit:cover}
.service-card-body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.service-card-body h3{color:var(--text-900);margin-bottom:.5rem;font-size:1.1rem}
.service-card-body p{color:var(--text-500);font-size:.9rem;flex:1;margin-bottom:1rem}
.service-card-link{font-weight:600;color:var(--green-700);font-size:.9rem}
/* SERVICES LIST */
.services-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.services-list-item{display:flex;align-items:flex-start;gap:.75rem;padding:1.1rem;background:var(--white);border:1px solid #e5e7eb;border-radius:var(--radius);transition:border-color var(--transition)}
.services-list-item:hover{border-color:var(--green-500)}
.sli-icon{font-size:1.4rem;flex-shrink:0;margin-top:2px}
.sli-text h4{font-size:.95rem;color:var(--text-900);margin-bottom:.2rem}
.sli-text p{font-size:.85rem;color:var(--text-500);margin:0}
/* WHY CHOOSE US */
.why-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.5rem}
.why-card{background:var(--white);border-radius:var(--radius-lg);padding:1.75rem;text-align:center;box-shadow:var(--shadow-sm);border:1px solid #e5e7eb}
.why-icon{width:56px;height:56px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;background:var(--green-100);border-radius:50%;font-size:1.5rem}
.why-card h3{margin-bottom:.5rem;font-size:1rem}
.why-card p{font-size:.875rem;color:var(--text-500);margin:0}
/* FAQ */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:.6rem}
.faq-item{border:1px solid #e5e7eb;border-radius:var(--radius);overflow:hidden;background:var(--white)}
.faq-btn{width:100%;text-align:left;padding:1.1rem 1.3rem;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.95rem;color:var(--text-900);gap:1rem;font-family:var(--font-sans)}
.faq-btn:hover{background:var(--green-50)}
.faq-icon{flex-shrink:0;width:20px;height:20px;color:var(--green-700);transition:transform var(--transition);font-size:1.2rem;line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-body-inner{padding:0 1.3rem 1.1rem;color:var(--text-700);font-size:.93rem;line-height:1.75}
.faq-item.open .faq-body{max-height:600px}
/* TESTIMONIALS */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.testimonial-card{background:var(--white);border:1px solid #e5e7eb;border-radius:var(--radius-lg);padding:1.75rem}
.testimonial-stars{color:var(--gold);font-size:1.1rem;margin-bottom:.75rem}
.testimonial-text{font-style:italic;color:var(--text-700);margin-bottom:1rem;font-size:.95rem;line-height:1.75}
.testimonial-author{font-weight:700;font-size:.875rem;color:var(--text-900)}
/* CITIES */
.cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}
.city-link{display:block;padding:.75rem 1rem;background:var(--white);border:1px solid #e5e7eb;border-radius:var(--radius);text-align:center;font-weight:500;font-size:.9rem;color:var(--text-700);transition:all var(--transition)}
.city-link:hover{background:var(--green-800);color:var(--white);border-color:var(--green-800)}
/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.75rem}
.blog-card{display:flex;flex-direction:column;background:var(--white);border:1px solid #e5e7eb;border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition)}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.blog-card-img{width:100%;height:200px;object-fit:cover}
.blog-card-body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.blog-card-body h3{color:var(--text-900);margin-bottom:.6rem;font-size:1rem}
.blog-card-body h3 a{color:inherit}
.blog-card-body h3 a:hover{color:var(--green-700)}
.blog-card-body p{color:var(--text-500);font-size:.875rem;flex:1;margin-bottom:1rem}
.blog-read-more{font-weight:600;color:var(--green-700);font-size:.875rem}
/* CTA SECTION */
.cta-section{padding:4.5rem 0;background:var(--green-900)}
.cta-section h2{color:var(--white);margin-bottom:1rem}
.cta-section p{color:rgba(255,255,255,.8);margin-bottom:2rem;font-size:1.05rem;max-width:560px}
.cta-buttons{display:flex;flex-wrap:wrap;gap:1rem}
/* CONTACT */
.contact-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-form{background:var(--white);padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-weight:600;margin-bottom:.35rem;font-size:.875rem;color:var(--text-900)}
.form-control{width:100%;padding:.7rem 1rem;border:1px solid #d1d5db;border-radius:var(--radius);font-size:.93rem;font-family:var(--font-sans);background:var(--white);color:var(--text-900);transition:border-color var(--transition)}
.form-control:focus{outline:none;border-color:var(--green-600);box-shadow:0 0 0 3px rgba(42,96,69,.12)}
textarea.form-control{resize:vertical;min-height:110px}
.contact-info-block{display:flex;flex-direction:column;gap:1.25rem}
.contact-info-item .ci-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-500);font-weight:600;margin-bottom:.2rem}
.contact-info-item .ci-value{font-weight:600;color:var(--text-900)}
.contact-info-item .ci-value a{color:var(--green-700)}
/* PAGE LAYOUT */
.page-header{background:linear-gradient(135deg,var(--green-900),var(--green-700));color:var(--white);padding:3.5rem 0}
.page-header h1{color:var(--white);margin-bottom:.75rem}
.page-header p{color:rgba(255,255,255,.8);font-size:1.05rem;max-width:650px}
.breadcrumb{display:flex;flex-wrap:wrap;gap:.4rem;font-size:.85rem;color:rgba(255,255,255,.7);margin-bottom:.75rem;align-items:center}
.breadcrumb a{color:rgba(255,255,255,.7)}
.breadcrumb a:hover{color:var(--white)}
.breadcrumb-sep{color:rgba(255,255,255,.45)}
.content-wrapper{display:grid;grid-template-columns:1fr 320px;gap:3rem;align-items:start}
.content-main h2{margin-top:2rem;margin-bottom:1rem;padding-top:.5rem;border-top:1px solid #e5e7eb}
.content-main h2:first-child{border-top:none;margin-top:0}
.content-main h3{margin:1.5rem 0 .75rem;color:var(--green-800)}
.content-main ul,.content-main ol{padding-left:1.5rem;margin-bottom:1rem}
.content-main ul{list-style:disc}
.content-main ol{list-style:decimal}
.content-main li{margin-bottom:.4rem;color:var(--text-700)}
.content-main p{color:var(--text-700);line-height:1.75}
.content-main hr{border:none;border-top:1px solid #e5e7eb;margin:2rem 0}
.content-main table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.9rem}
.content-main th{background:var(--green-800);color:var(--white);padding:.7rem 1rem;text-align:left;font-weight:600}
.content-main td{padding:.65rem 1rem;border-bottom:1px solid #e5e7eb;color:var(--text-700)}
.content-main tr:nth-child(even) td{background:var(--bg-light)}
.sidebar{position:sticky;top:80px;display:flex;flex-direction:column;gap:1.5rem}
.sidebar-card{background:var(--white);border:1px solid #e5e7eb;border-radius:var(--radius-lg);padding:1.5rem}
.sidebar-card h3{font-size:.95rem;margin-bottom:1rem;color:var(--text-900);padding-bottom:.6rem;border-bottom:2px solid var(--green-700)}
.sidebar-links{display:flex;flex-direction:column;gap:.3rem}
.sidebar-links a{padding:.5rem .7rem;font-size:.875rem;color:var(--text-700);border-radius:var(--radius);display:block}
.sidebar-links a:hover{background:var(--green-50);color:var(--green-700)}
.sidebar-cta{background:var(--green-800);color:var(--white);border-radius:var(--radius-lg);padding:1.75rem;text-align:center}
.sidebar-cta h3{color:var(--white);margin-bottom:.75rem;font-size:1rem}
.sidebar-cta p{color:rgba(255,255,255,.8);font-size:.875rem;margin-bottom:1.2rem}
.stats-row{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin:2rem 0}
.stat-box{text-align:center}
.stat-number{font-size:2.5rem;font-weight:700;color:var(--white);font-family:var(--font-head);line-height:1;display:block}
.stat-label{font-size:.875rem;color:rgba(255,255,255,.7);margin-top:.3rem;display:block}
.related-section{margin-top:2.5rem;padding-top:2rem;border-top:1px solid #e5e7eb}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;margin-top:1rem}
.related-link{display:block;padding:.85rem 1rem;background:var(--bg-light);border:1px solid #e5e7eb;border-radius:var(--radius);color:var(--text-700);font-size:.875rem;font-weight:500;transition:all var(--transition);text-align:center}
.related-link:hover{background:var(--green-800);color:var(--white);border-color:var(--green-800)}
.info-box{background:var(--green-50);border-left:4px solid var(--green-700);border-radius:var(--radius);padding:1.25rem 1.5rem;margin:1.5rem 0}
.info-box h4{margin-bottom:.4rem;color:var(--green-900)}
/* FOOTER */
.footer{background:var(--text-900);color:var(--white);padding:4rem 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:2.5rem;margin-bottom:3rem}
.footer-brand img{height:52px;margin-bottom:1rem}
.footer-brand p{color:rgba(255,255,255,.6);font-size:.875rem;line-height:1.75}
.footer-col h4{color:var(--white);font-size:.85rem;font-weight:700;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.06em}
.footer-col ul li{margin-bottom:.5rem}
.footer-col ul a{color:rgba(255,255,255,.6);font-size:.875rem}
.footer-col ul a:hover{color:var(--gold-light)}
.footer-contact-item{display:flex;align-items:center;gap:.6rem;color:rgba(255,255,255,.7);font-size:.875rem;margin-bottom:.6rem}
.footer-contact-item a{color:rgba(255,255,255,.8)}
.footer-contact-item a:hover{color:var(--gold-light)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.25rem 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.8rem;color:rgba(255,255,255,.45)}
.footer-bottom a{color:rgba(255,255,255,.45)}
.footer-bottom a:hover{color:var(--gold-light)}
/* RESPONSIVE */
@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .content-wrapper{grid-template-columns:1fr}
  .sidebar{position:static}
  .contact-wrapper{grid-template-columns:1fr}
}
@media(max-width:768px){
  .navbar-menu,.navbar-phone{display:none}
  .hamburger{display:flex}
  .navbar-menu.open{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--white);overflow-y:auto;padding:5rem 1.5rem 2rem;gap:.25rem;z-index:800}
  .navbar-menu.open .dropdown-menu{display:block;position:static;box-shadow:none;border:none;border-left:3px solid var(--green-100);padding-left:1rem;margin-top:.25rem}
  .navbar-menu > li > a{font-size:1.05rem;padding:.75rem 1rem}
  .hero{padding:3.5rem 0}
  .section{padding:3.5rem 0}
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .hero-cta,.cta-buttons{flex-direction:column;align-items:flex-start}
  .hero-badges{display:none}
  .stats-row{gap:1.5rem}
  h1{font-size:1.75rem}
  h2{font-size:1.4rem}
}
@media(max-width:480px){
  .cities-grid{grid-template-columns:repeat(2,1fr)}
  .trust-bar .container{gap:.75rem 1.5rem}
  .navbar-phone{display:none}
}
@media print{.navbar,.footer,.cta-section,.sidebar{display:none}.content-wrapper{grid-template-columns:1fr}}
/* === HOMEPAGE COMPONENT ADDITIONS === */
.navbar-brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.logo-img{height:48px;width:auto;border-radius:50%}
.company-name{font-family:var(--font-head);font-weight:700;font-size:1.05rem;color:var(--green-900);line-height:1.2}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--text-900);border-radius:2px;transition:all var(--transition)}
.menu-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.phone-cta{display:flex;align-items:center;gap:.5rem;background:var(--green-800);color:var(--white)!important;padding:.6rem 1.1rem;border-radius:var(--radius);font-weight:600;font-size:.9rem;text-decoration:none;flex-shrink:0;transition:background var(--transition)}
.phone-cta:hover{background:var(--green-700)!important;color:var(--white)!important}
.hero-subtitle{font-size:1.1rem;color:rgba(255,255,255,.85);margin-bottom:2rem;max-width:620px;line-height:1.7}
.trust-items{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 2rem}
.trust-item i{font-size:1.3rem;color:var(--green-700);flex-shrink:0}
.trust-item > div strong{display:block;font-size:.9rem;color:var(--text-900)}
.trust-item > div span{font-size:.8rem;color:var(--text-500)}
.services-section{padding:5rem 0}
.service-card-img{width:100%;height:200px;overflow:hidden}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.service-card:hover .service-card-img img{transform:scale(1.04)}
.card-link{font-weight:600;color:var(--green-700);font-size:.875rem;margin-top:auto;display:flex;align-items:center;gap:.35rem}
.section-footer{text-align:center;margin-top:2.5rem}
.why-us-section{padding:5rem 0;background:var(--bg-light)}
.why-us-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.feature-list{list-style:none;padding:0;margin:1.5rem 0;display:flex;flex-direction:column;gap:.75rem}
.feature-list li{display:flex;gap:.75rem;align-items:flex-start;font-size:.93rem;color:var(--text-700)}
.feature-list li i{color:var(--green-600);margin-top:.2rem;flex-shrink:0}
.why-us-image img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;height:auto}
.problems-section{padding:5rem 0}
.problems-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}
.problem-card{background:var(--bg-light);border:1px solid #e5e7eb;border-radius:var(--radius-lg);padding:1.75rem;transition:all var(--transition)}
.problem-card:hover{box-shadow:var(--shadow-md);border-color:var(--green-500);background:var(--white)}
.problem-card > i{font-size:2rem;color:var(--green-700);margin-bottom:1rem;display:block}
.problem-card h3{margin-bottom:.5rem;font-size:1rem}
.problem-card p{font-size:.875rem;color:var(--text-500);margin:0}
.cities-section{padding:5rem 0;background:var(--bg-light)}
.city-badge{display:block;padding:.75rem 1rem;background:var(--white);border:1px solid #e5e7eb;border-radius:var(--radius);text-align:center;font-weight:500;font-size:.9rem;color:var(--text-700);transition:all var(--transition);text-decoration:none}
.city-badge:hover{background:var(--green-800);color:var(--white);border-color:var(--green-800)}
.testimonials-section{padding:5rem 0;background:var(--green-900)}
.testimonials-section .section-header h2{color:var(--white)}
.testimonials-section .section-header p{color:rgba(255,255,255,.75)}
.testimonials-section .testimonial-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15)}
.testimonials-section .testimonial-card p{color:rgba(255,255,255,.85);font-style:italic;line-height:1.75}
.testimonials-section .testimonial-author strong{color:var(--white)}
.testimonials-section .testimonial-author span{color:rgba(255,255,255,.6);font-size:.8rem}
.stars{color:var(--gold);margin-bottom:.75rem}
.testimonial-author{margin-top:1rem}
.testimonial-author strong{display:block;font-size:.875rem}
.blog-section{padding:5rem 0}
.blog-card a{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}
.blog-card:hover h3{color:var(--green-700)}
.blog-card-img{width:100%;height:200px;overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover}
.blog-tag{display:inline-block;background:var(--green-100);color:var(--green-700);border-radius:50px;padding:.2rem .7rem;font-size:.78rem;font-weight:600;margin-bottom:.5rem}
.faq-section{padding:5rem 0;background:var(--bg-light)}
.faq-question{width:100%;text-align:left;padding:1.1rem 1.3rem;background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.95rem;color:var(--text-900);gap:1rem;font-family:var(--font-sans)}
.faq-question:hover{background:var(--green-50)}
.faq-question i{flex-shrink:0;color:var(--green-700);transition:transform var(--transition)}
.faq-item.open .faq-question i{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-answer p{padding:.25rem 1.3rem 1.1rem;color:var(--text-700);font-size:.93rem;line-height:1.75;margin:0}
.faq-item.open .faq-answer{max-height:500px}
.footer-cta{padding:4.5rem 0;background:var(--green-900);color:var(--white);text-align:center}
.footer-cta h2{color:var(--white);margin-bottom:.75rem}
.footer-cta p{color:rgba(255,255,255,.8);margin-bottom:2rem;font-size:1.05rem}
.footer-cta .cta-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.cta-hours{margin-top:1.25rem;color:rgba(255,255,255,.65);font-size:.875rem}
footer{background:var(--text-900);color:var(--white);padding:4rem 0 0}
.footer-section h3{color:var(--white);font-size:.85rem;font-weight:700;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.06em}
.footer-section ul{list-style:none;padding:0}
.footer-section ul li{margin-bottom:.5rem}
.footer-section ul a{color:rgba(255,255,255,.6);font-size:.875rem}
.footer-section ul a:hover{color:var(--gold-light)}
.footer-about p{color:rgba(255,255,255,.6);font-size:.875rem;line-height:1.75}
.social-links{display:flex;gap:.6rem;margin-top:.75rem}
.social-links a{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);color:rgba(255,255,255,.7);font-size:.9rem;transition:all var(--transition)}
.social-links a:hover{background:var(--green-700);color:var(--white)}
.contact-list{list-style:none;padding:0}
.contact-list li{display:flex;align-items:center;gap:.6rem;color:rgba(255,255,255,.7);font-size:.875rem;margin-bottom:.6rem}
.contact-list i{width:16px;flex-shrink:0;color:var(--green-500)}
.contact-list a{color:rgba(255,255,255,.8)}
.contact-list a:hover{color:var(--gold-light)}
.btn-outline{background:transparent;color:var(--white);border-color:rgba(255,255,255,.7)}
.btn-outline:hover{background:rgba(255,255,255,.1);color:var(--white)}
@media(max-width:1024px){.why-us-grid{grid-template-columns:1fr}.why-us-image{display:none}}
@media(max-width:768px){
  .menu-toggle{display:flex}
  .navbar-menu{display:none}
  .navbar-menu.active{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--white);overflow-y:auto;padding:5rem 1.5rem 2rem;gap:.25rem;z-index:800}
  .navbar-menu.active .dropdown-menu{display:block;position:static;box-shadow:none;border:none;border-left:3px solid var(--green-100);padding-left:.75rem;margin:.25rem 0}
  .navbar-menu.active > li > a{font-size:1rem;padding:.7rem .85rem}
  .why-us-section,.problems-section,.services-section,.cities-section,.testimonials-section,.blog-section,.faq-section{padding:3.5rem 0}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .phone-cta{display:none}
}