/* ==========================================================================
   A.J. KRAIG LANDSCAPE AND DESIGN — Design System
   Premium-nature aesthetic: Playfair Display headings, Open Sans body,
   dark green brand, sharp corners, generous spacing
   ========================================================================== */

/* --- Custom Properties --- */
:root {
  --color-primary: #077F09;
  --color-secondary: #073A0D;
  --color-dark: #0B330C;
  --color-darkest: #0a1f0b;
  --color-accent: #2B9720;
  --color-light-green: #CBE2A1;
  --color-text: #333333;
  --color-text-muted: #666666;
  --color-heading: #1a1a1a;
  --color-bg: #FFFFFF;
  --color-bg-alt: #F8F6F3;
  --color-border: #e0ddd8;
  --color-error: #dc3545;
  --color-success: #077F09;
  --color-footer-link: #CBE2A1;
  --font-heading: 'Playfair Display', serif;
  --font-body: 'Open Sans', sans-serif;
  --section-padding: 80px;
  --section-padding-sm: 56px;
  --container-width: 1140px;
  --gap: 36px;
  --gap-sm: 20px;
  --radius: 2px;
  --radius-lg: 4px;
  --radius-btn: 4px;
  --shadow: 0 1px 8px rgba(0,0,0,0.04);
  --shadow-lg: 0 2px 16px rgba(0,0,0,0.08);
  --transition: 0.3s ease;
}

/* --- Reset & Base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:16px;line-height:1.7;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-primary);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--color-accent)}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);line-height:1.25;color:var(--color-heading)}
h1{font-size:clamp(36px,5vw,54px);font-weight:700;letter-spacing:-0.5px}
h2{font-size:clamp(28px,4vw,42px);font-weight:600}
h3{font-size:clamp(22px,3vw,36px);font-weight:600}
h4{font-size:clamp(16px,2vw,20px);font-weight:600}
h5{font-size:16px;font-weight:600}
h6{font-size:15px;font-weight:400;color:var(--color-text-muted)}
p{margin-bottom:1rem}

/* --- Skip Link --- */
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--color-primary);color:#fff;padding:8px 24px;border-radius:0 0 var(--radius) var(--radius);z-index:9999;font-weight:600}
.skip-link:focus{top:0;color:#fff}

/* --- Container --- */
.container{max-width:var(--container-width);margin:0 auto;padding:0 24px}

/* --- Section Patterns --- */
.section{padding:var(--section-padding) 0;position:relative}
.section--alt{background:var(--color-bg-alt)}
.section--dark{background:var(--color-secondary);color:#fff}
.section--dark h2,.section--dark h3,.section--dark h4,.section--dark h5,.section--dark p,.section--dark li{color:#fff}
.section--dark a{color:var(--color-light-green)}
.section--dark a:hover{color:#fff}
.section--cta{background:var(--color-secondary);color:#fff;text-align:center;padding:80px 0;position:relative;overflow:hidden}
.section--cta .cta-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0.15}
.section--cta .container{position:relative;z-index:2}
.section--cta h2,.section--cta p{color:#fff}
.section-label{display:inline-block;font-family:var(--font-body);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--color-primary);margin-bottom:8px}
.section--dark .section-label{color:var(--color-light-green)}
.section--cta .section-label{color:var(--color-light-green)}
.section-header{text-align:center;max-width:700px;margin:0 auto 48px}
.section-header h2{margin-bottom:12px}
.section-header p{font-size:17px;color:var(--color-text-muted)}
.section--dark .section-header p{color:rgba(255,255,255,0.8)}

/* --- Wave Section Divider --- */
.wave-divider{height:60px;overflow:hidden;position:relative;margin-top:-1px}
.wave-divider svg{position:absolute;bottom:0;width:100%;height:100%}
.wave-divider--flip,.wave-divider--top{transform:rotate(180deg);margin-top:0;margin-bottom:-1px}

/* --- Utility Bar --- */
.utility-bar{background:var(--color-secondary);padding:6px 0;font-size:13px;font-weight:600}
.utility-bar .container{display:flex;justify-content:flex-end;align-items:center;gap:24px}
.utility-bar a{color:rgba(255,255,255,0.85);display:flex;align-items:center;gap:6px;transition:color var(--transition)}
.utility-bar a:hover{color:#fff}
.utility-bar svg{width:14px;height:14px;color:var(--color-light-green)}

/* --- Header (solid white, sticky) --- */
.header{position:sticky;top:0;left:0;right:0;z-index:100;background:#fff;padding:0;box-shadow:0 1px 4px rgba(0,0,0,0.06)}
.header .container{display:flex;align-items:center;justify-content:space-between;min-height:70px;max-width:1280px}
.header__logo img{height:58px;width:auto;margin:8px 40px 8px 0}
.header__nav{display:flex;align-items:center;gap:0;flex-wrap:nowrap}
.header__nav a{color:var(--color-heading);font-family:var(--font-body);font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;padding:18px 12px;transition:all var(--transition);display:inline-block;white-space:nowrap}
.header__nav a:hover,.header__nav a.active{color:var(--color-primary);background:transparent}
.header__nav .has-dropdown{position:relative}
.dropdown-arrow{font-size:8px;margin-left:2px;vertical-align:1px;opacity:0.5}
.header__nav .has-dropdown .dropdown{position:absolute;top:100%;left:0;background:#fff;min-width:200px;padding:4px 0;opacity:0;visibility:hidden;transform:translateY(4px);transition:all var(--transition);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);z-index:200}
.header__nav .has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.header__nav .dropdown a{display:block;padding:10px 18px;font-size:13px;white-space:nowrap;color:var(--color-text)}
.header__nav .dropdown a:hover{background:var(--color-bg-alt);color:var(--color-primary)}
.header__cta{display:flex;align-items:center;gap:12px;flex-shrink:0}
.header__cta .btn{white-space:nowrap}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--color-heading);border-radius:2px;transition:all var(--transition)}
.nav-toggle span+span{margin-top:5px}

/* --- Hero (full-viewport image with dark overlay) --- */
.hero{position:relative;min-height:480px;display:flex;align-items:center;overflow:hidden;padding:80px 0;color:#fff;text-align:center}
.hero--home{min-height:560px;padding:80px 0}
.hero--inner{min-height:400px;padding:70px 0 60px}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;display:block}
.hero-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.55);z-index:1}
.hero--inner .hero-overlay{background:rgba(0,0,0,0.55)}
.hero .container{position:relative;z-index:2;max-width:800px}
.hero h1{color:#fff;margin-bottom:16px}
.hero h3{color:#fff;font-weight:400;margin-bottom:8px;font-size:clamp(22px,3vw,36px)}
.hero h4{color:rgba(255,255,255,0.9);font-family:var(--font-body);font-weight:600;font-size:clamp(16px,2vw,20px);margin-bottom:32px;text-transform:none}
.hero p{color:rgba(255,255,255,0.9);font-size:17px;max-width:600px;margin:0 auto 28px}
.hero .section-label{color:var(--color-light-green)}
.hero .btn-group,.section--cta .btn-group{justify-content:center}

/* --- Breadcrumbs --- */
.breadcrumbs{font-size:14px;margin-bottom:20px}
.breadcrumbs a{color:rgba(255,255,255,0.7);font-weight:400}
.breadcrumbs a:hover{color:#fff}
.breadcrumbs span{margin:0 6px;color:rgba(255,255,255,0.5)}
.breadcrumbs .current{color:var(--color-light-green);font-weight:600}
.breadcrumbs--light{padding:12px 0}
.breadcrumbs--light a{color:var(--color-primary)}
.breadcrumbs--light a:hover{color:var(--color-accent)}
.breadcrumbs--light span{color:var(--color-text-muted)}
.breadcrumbs--light .current{color:var(--color-heading)}

/* --- Buttons (sharp corners, premium feel) --- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-size:15px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;padding:14px 40px;border:2px solid transparent;border-radius:var(--radius-btn);cursor:pointer;transition:all var(--transition);text-decoration:none;line-height:1.2}
.btn--primary{background:var(--color-primary);color:#fff}
.btn--primary:hover{background:#069408;color:#fff;transform:translateY(-1px)}
.btn--secondary{background:var(--color-secondary);color:#fff}
.btn--secondary:hover{background:#0a4a12;color:#fff}
.btn--outline{background:transparent;color:#fff;border-color:rgba(255,255,255,0.6)}
.btn--outline:hover{background:rgba(255,255,255,0.1);color:#fff}
.btn--white{background:#fff;color:var(--color-primary);font-weight:700}
.btn--white:hover{background:var(--color-bg-alt);color:var(--color-accent)}
.btn--sm{padding:8px 18px;font-size:13px}
.btn--lg{padding:16px 44px;font-size:15px}
.btn--outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,0.5)}
.btn--outline-white:hover{background:#fff;color:var(--color-secondary)}
.btn--full{width:100%;justify-content:center}
.btn-group{display:flex;gap:12px;flex-wrap:wrap}
.btn-group--center{justify-content:center}

/* --- Grids --- */
.grid{display:grid;gap:var(--gap)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--2-1{grid-template-columns:2fr 1fr}
.grid--1-2{grid-template-columns:1fr 2fr}
.grid--sidebar{grid-template-columns:1fr 360px}

/* --- Cards --- */
.card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;transition:transform var(--transition),box-shadow var(--transition);box-shadow:var(--shadow)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.card-img{position:relative;overflow:hidden;aspect-ratio:16/10}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition)}
.card:hover .card-img img{transform:scale(1.03)}
.card-body{padding:20px}
.card-body h3{font-size:18px;font-weight:600;margin-bottom:8px}
.card-body p{color:var(--color-text-muted);margin-bottom:0;font-size:15px}

/* Service cards */
.card--service{background:var(--color-bg-alt);color:var(--color-text);text-align:center;padding:32px 24px;border-radius:var(--radius-lg)}
.card--service .card__icon{width:56px;height:56px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}
.card--service .card__icon svg{width:40px;height:40px;color:var(--color-primary)}
.card--service h4{color:var(--color-heading);margin-bottom:8px}
.card--service p{color:var(--color-text-muted);font-size:15px}

/* Feature cards */
.card--feature{background:var(--color-bg-alt);padding:28px;border-radius:var(--radius-lg);text-align:center}
.card--feature .card__icon{width:48px;height:48px;background:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.card--feature .card__icon svg{width:24px;height:24px;color:#fff}

/* --- Trust Bar / Stats --- */
.trust-bar{background:var(--color-secondary);padding:16px 0}
.trust-bar .container{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.trust-bar__item{display:flex;align-items:center;gap:8px;color:#fff;font-size:14px;font-weight:600;white-space:nowrap}
.trust-bar__item svg{width:20px;height:20px;color:var(--color-light-green);flex-shrink:0}
.trust-bar__grid{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.trust-bar__number{font-size:clamp(24px,3vw,32px);font-weight:700;font-family:var(--font-heading);color:var(--color-light-green);line-height:1}
.trust-bar__label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,0.8)}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap);text-align:center}
.stat__number{font-size:clamp(32px,4vw,42px);font-weight:700;font-family:var(--font-heading);color:var(--color-primary);line-height:1}
.section--dark .stat__number{color:var(--color-light-green)}
.stat__label{font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-top:6px;color:var(--color-text-muted)}
.section--dark .stat__label{color:rgba(255,255,255,0.8)}

/* --- Partner Logo Bar --- */
.partners{background:#fff;padding:48px 0;overflow:hidden;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}
.partners .container{display:flex;align-items:center;justify-content:center;gap:60px;flex-wrap:wrap}
.partners a{display:block;opacity:0.7;transition:opacity var(--transition);flex-shrink:0}
.partners a:hover{opacity:1}
.partners img{height:60px;width:auto}
.partners__grid{display:flex;align-items:center;justify-content:center;gap:60px;flex-wrap:wrap}
.partner-logo{opacity:0.8;transition:opacity var(--transition)}
.partner-logo:hover{opacity:1}
.partner-logo .img-placeholder{color:var(--color-text-muted);font-size:15px;font-weight:600;white-space:nowrap}
.partner-logo img{height:60px;width:auto;display:block;filter:grayscale(50%);transition:filter var(--transition)}
.partner-logo:hover img{filter:grayscale(0)}

/* --- Testimonials --- */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--gap)}
.testimonial{background:#fff;padding:32px;border-radius:var(--radius-lg);box-shadow:var(--shadow);position:relative}
.section--dark .testimonial{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1)}
.testimonial::before{content:"\201C";font-family:var(--font-heading);font-size:64px;color:var(--color-primary);opacity:0.15;position:absolute;top:8px;left:20px;line-height:1}
.section--dark .testimonial::before{color:var(--color-light-green);opacity:0.25}
.testimonial p{font-size:15px;line-height:1.8;font-style:italic;margin-bottom:16px;position:relative}
.testimonial__author{display:flex;align-items:center;gap:10px}
.testimonial__name{font-weight:600;color:var(--color-heading)}
.section--dark .testimonial__name{color:#fff}
.testimonial__location{font-size:14px;color:var(--color-text-muted)}
.section--dark .testimonial__location{color:rgba(255,255,255,0.6)}
.testimonial__stars{display:flex;gap:3px;margin-bottom:12px}
.testimonial__stars svg{color:#f5a623}

/* Testimonial cards (dark section variant) */
.testimonial-card{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);padding:32px;border-radius:var(--radius-lg);position:relative}
.testimonial-card::before{content:"\201C";font-family:var(--font-heading);font-size:64px;color:var(--color-light-green);opacity:0.25;position:absolute;top:8px;left:20px;line-height:1}
.testimonial-card__stars{display:flex;gap:3px;margin-bottom:12px}
.testimonial-card blockquote{font-size:15px;line-height:1.8;font-style:italic;margin-bottom:16px;color:rgba(255,255,255,0.9)}
.testimonial-card cite{font-style:normal;font-weight:600;color:#fff;font-size:14px}
.testimonial-card cite span{display:block;font-weight:400;font-size:13px;color:rgba(255,255,255,0.6);margin-top:2px}

/* --- Gallery / Image Grid --- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.gallery__item{position:relative;overflow:hidden;border-radius:var(--radius);aspect-ratio:4/3}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition)}
.gallery__item:hover img{transform:scale(1.05)}

/* --- Before & After --- */
.before-after{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.before-after__item{position:relative;border-radius:var(--radius);overflow:hidden}
.before-after__item img{width:100%;height:100%;object-fit:cover;display:block}
.before-after__label{position:absolute;top:12px;left:12px;background:rgba(0,0,0,0.65);color:#fff;font-family:var(--font-body);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:6px 14px;border-radius:4px;z-index:2}
.before-after__label--after{background:var(--color-primary)}
@media(max-width:600px){.before-after{grid-template-columns:1fr}}

/* --- Gallery Filter Nav --- */
.gallery-filter{position:sticky;top:70px;z-index:50;background:#fff;border-bottom:1px solid var(--color-border);padding:0;box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.gallery-filter .container{padding-top:0;padding-bottom:0}
.gallery-filter__list{display:flex;align-items:center;justify-content:center;gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.gallery-filter__list::-webkit-scrollbar{display:none}
.gallery-filter__btn{display:inline-block;padding:14px 20px;font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--color-text-muted);text-decoration:none;text-transform:uppercase;letter-spacing:0.5px;white-space:nowrap;border-bottom:3px solid transparent;transition:all var(--transition)}
.gallery-filter__btn:hover{color:var(--color-primary)}
.gallery-filter__btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}
.gallery-filter ~ .section[id]{scroll-margin-top:140px}

/* --- FAQ Accordion --- */
.faq-list{max-width:750px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--color-border);overflow:hidden}
.faq-item__question{width:100%;background:none;border:none;padding:20px 40px 20px 0;font-family:var(--font-body);font-size:17px;font-weight:600;color:var(--color-heading);text-align:left;cursor:pointer;position:relative;transition:color var(--transition);display:block;line-height:1.4}
.faq-item__question:hover{color:var(--color-primary)}
.faq-item__icon{position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:22px;font-weight:300;color:var(--color-primary);transition:transform var(--transition)}
.faq-item__question[aria-expanded="true"] .faq-item__icon{transform:translateY(-50%) rotate(45deg)}
.faq-item__answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease,padding 0.3s ease}
.faq-item__answer.open{max-height:600px;padding-bottom:20px}
.faq-item__answer p{font-size:15px;line-height:1.8;color:var(--color-text)}

/* --- Forms --- */
.form{display:grid;gap:16px;max-width:600px}
.form--wide{max-width:100%}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-group label{font-size:14px;font-weight:600;color:var(--color-heading)}
.form-group input,.form-group textarea,.form-group select{font-family:var(--font-body);font-size:16px;padding:12px 14px;border:1px solid var(--color-border);border-radius:var(--radius);transition:border-color var(--transition);background:#fff;color:var(--color-heading)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(7,127,9,0.1)}
.form-group textarea{resize:vertical;min-height:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .btn{width:100%;justify-content:center;margin-top:4px}
.thanks-msg{text-align:center;padding:40px 20px}
.thanks-msg h2{color:var(--color-primary);margin-bottom:12px}
.contact-form{display:grid;gap:16px;max-width:100%}

/* --- Two Column Content --- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);align-items:center}
.split--reverse{direction:rtl}
.split--reverse > *{direction:ltr}
.split__img{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;max-height:500px}
.split__img--full{aspect-ratio:auto;max-height:none}
.split__img img{width:100%;height:100%;object-fit:cover}
.split__text h2{margin-bottom:12px}
.split__text h3{margin-bottom:12px}
.split__text p{margin-bottom:12px}
.split__text ul{margin-bottom:16px}
.split__text ul li{padding:4px 0 4px 24px;position:relative;font-size:15px}
.split__text ul li::before{content:"";position:absolute;left:0;top:12px;width:12px;height:12px;background:var(--color-primary);border-radius:50%;opacity:0.2}

/* --- Contact Sidebar --- */
.split__sidebar{display:flex;flex-direction:column;gap:var(--gap-sm)}
.sidebar-card{background:var(--color-bg-alt);padding:24px;border-radius:var(--radius-lg)}
.sidebar-card--dark{background:var(--color-secondary);color:#fff}
.sidebar-card--dark h4,.sidebar-card--dark p,.sidebar-card--dark li{color:#fff}
.sidebar-card--dark a{color:var(--color-light-green)}
.sidebar-card--dark a:hover{color:#fff}
.sidebar-card h4{margin-bottom:10px}
.hours-list li{display:flex;justify-content:space-between;padding:4px 0;font-size:14px;border-bottom:1px solid rgba(255,255,255,0.1)}
.hours-list li:last-child{border-bottom:none}
.area-list{display:grid;grid-template-columns:1fr 1fr;gap:2px 12px}
.area-list li{font-size:14px;padding:3px 0}
span.required{color:var(--color-error);margin-left:2px}

/* Contact info bar */
.contact-info-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--gap-sm);margin-bottom:40px}
.contact-info-card{background:var(--color-bg-alt);padding:24px;border-radius:var(--radius-lg);text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}
.contact-info-card__icon{width:40px;height:40px;background:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center}
.contact-info-card__icon svg{width:20px;height:20px;color:#fff}
.contact-info-card h4{margin-bottom:0;font-size:15px}
.contact-info-card p,.contact-info-card a{font-size:14px;color:var(--color-text-muted);margin-bottom:0}

/* --- Image Placeholders --- */
.img-placeholder{background:var(--color-bg-alt);display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative}
.img-placeholder span{font-size:14px;color:var(--color-text-muted);font-weight:500}
.img-real{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;z-index:1;transition:opacity 0.3s ease}
.img-real.loaded{opacity:1}
.img-real.loaded+.img-placeholder,.img-real.loaded~.img-placeholder{opacity:0}

/* --- Process Steps --- */
.process{counter-reset:step}
.process-step{counter-increment:step;padding:24px;background:var(--color-bg-alt);border-radius:var(--radius-lg);position:relative;padding-left:72px}
.process-step::before{content:counter(step);position:absolute;left:20px;top:24px;width:36px;height:36px;background:var(--color-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}
.process-step h4{margin-bottom:6px}
.process-step p{color:var(--color-text-muted);font-size:14px;margin-bottom:0}

/* --- Service Area Cards --- */
.areas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--gap-sm)}
a.area-card{text-decoration:none;color:inherit;display:block}
.area-card{background:#fff;padding:24px;border-radius:var(--radius-lg);border-left:3px solid var(--color-primary);transition:box-shadow var(--transition),transform var(--transition)}
.area-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.area-card h3{font-size:18px;font-weight:600;margin-bottom:6px;color:var(--color-heading)}
.area-card p{font-size:14px;color:var(--color-text-muted);margin-bottom:0}

/* --- Check List --- */
.check-list{margin-bottom:16px}
.check-list li{padding:4px 0 4px 24px;position:relative;font-size:15px}
.check-list li::before{content:"";position:absolute;left:0;top:12px;width:12px;height:12px;background:var(--color-primary);border-radius:50%;opacity:0.2}
.check-list--light li::before{background:var(--color-light-green);opacity:0.3}

/* --- Team Photo --- */
.team-photo{border-radius:var(--radius-lg);overflow:hidden}
.team-photo img{width:100%;height:100%;object-fit:cover}

/* --- Card Icon --- */
.card-icon{width:48px;height:48px;background:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.card-icon svg{width:24px;height:24px;color:#fff}

/* --- Scroll to Top --- */
.scroll-top{position:fixed;bottom:20px;right:20px;width:40px;height:40px;background:var(--color-primary);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(10px);transition:all var(--transition);z-index:99;box-shadow:var(--shadow)}
.scroll-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.scroll-top:hover{background:var(--color-secondary)}
.scroll-top svg{width:18px;height:18px}

/* --- Footer (dark green, full content visible) --- */
.footer{background:var(--color-darkest);color:#fff;padding:48px 0 0}
.footer .container{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--gap);flex-wrap:wrap}
.footer__brand{display:flex;flex-direction:column;align-items:flex-start;gap:12px;max-width:300px}
.footer__brand img{height:60px;width:auto;object-fit:contain}
.footer__brand p{font-size:13px;color:rgba(255,255,255,0.6);line-height:1.6}
.footer__social{display:flex;gap:10px;margin-top:4px}
.footer__social a{width:32px;height:32px;background:rgba(255,255,255,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.footer__social a:hover{background:var(--color-primary)}
.footer__social svg{width:16px;height:16px;color:#fff}
.footer h4{color:#fff;font-family:var(--font-body);font-size:14px;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:6px}
.footer ul a{color:rgba(255,255,255,0.6);font-size:14px;transition:color var(--transition)}
.footer ul a:hover{color:#fff}
.footer__contact{display:flex;flex-direction:column}
.footer__contact li{display:flex;gap:8px;align-items:flex-start;margin-bottom:10px;font-size:14px;color:rgba(255,255,255,0.6)}
.footer__contact svg{width:16px;height:16px;color:var(--color-light-green);flex-shrink:0;margin-top:2px}
.footer__contact a{color:var(--color-light-green)}
.footer__contact a:hover{color:#fff}
.footer .btn--primary{margin-top:8px}
.footer__bottom{margin-top:24px;padding:12px 0;border-top:1px solid rgba(255,255,255,0.08);background:rgba(0,0,0,0.3)}
.footer__bottom .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.footer__bottom p{font-size:12px;color:rgba(255,255,255,0.4)}
.footer__legal{display:flex;gap:16px}
.footer__legal a{font-size:12px;color:rgba(255,255,255,0.4);transition:color var(--transition)}
.footer__legal a:hover{color:#fff}

/* --- Utility --- */
.text-center{text-align:center}
.text-white{color:#fff}
.muted{color:var(--color-text-muted)}
.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}.mt-6{margin-top:48px}
.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* --- SMS Consent (A2P Compliance) --- */
.sms-consent{margin:16px 0}
.sms-consent__label{display:flex;align-items:flex-start;gap:10px;font-size:12px;line-height:1.5;color:var(--color-text-muted);cursor:pointer;margin-bottom:12px}
.sms-consent__label input[type="checkbox"]{margin-top:3px;flex-shrink:0;width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}
.sms-consent__label a{color:var(--color-primary);text-decoration:underline}

/* --- Responsive --- */
@media(max-width:1024px){
  .grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:var(--gap-sm)}
  .split--reverse{direction:ltr}
  .footer .container{flex-direction:column}
  .stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  :root{--section-padding:48px;--gap:20px}
  .utility-bar{font-size:12px}
  .utility-bar .container{gap:16px}
  .header__nav{display:none}
  .header__nav.open{display:flex;flex-direction:column;position:fixed;top:0;right:0;bottom:0;width:300px;background:#fff;padding:70px 24px 24px;z-index:10000;align-items:stretch;gap:0;box-shadow:-4px 0 20px rgba(0,0,0,0.1)}
  .header__nav.open a{padding:14px 0;font-size:16px;border-bottom:1px solid var(--color-border);border-radius:0;color:var(--color-heading)}
  .header__nav.open a:hover{color:var(--color-primary)}
  .header__nav.open .has-dropdown .dropdown{position:static;opacity:1;visibility:visible;transform:none;background:transparent;box-shadow:none;border:none;padding:0 0 0 16px;min-width:auto}
  .header__nav.open .dropdown a{color:var(--color-text-muted);border-bottom:none;font-size:14px;padding:8px 0}
  .nav-toggle{display:block;position:relative;z-index:10001}
  .nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
  .grid--2,.grid--3,.grid--4{grid-template-columns:1fr}
  .hero{min-height:auto;padding:60px 0}
  .hero--home{padding:70px 0}
  .hero--inner{padding:60px 0 50px}
  .gallery-filter{top:70px}
  .gallery-filter__btn{padding:12px 16px;font-size:13px}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .form-row{grid-template-columns:1fr}
  .footer__bottom .container{flex-direction:column;text-align:center}
  .stats{grid-template-columns:1fr 1fr}
  .trust-bar .container{gap:16px}
  .trust-bar__grid{gap:16px}
  .areas-grid{grid-template-columns:1fr}
  .contact-info-bar{grid-template-columns:1fr}
  .area-list{grid-template-columns:1fr}
  .btn-group{flex-direction:column;align-items:center}
  .btn-group .btn{width:auto}
  .testimonials-grid{grid-template-columns:1fr}
  .partners .container{gap:24px}
  .partners__grid{gap:24px}
  .grid--sidebar{grid-template-columns:1fr}
}
@media(max-width:480px){
  h1{font-size:28px}
  h2{font-size:24px}
  h3{font-size:20px}
  .gallery{grid-template-columns:1fr}
  .utility-bar .container{flex-direction:column;gap:4px;align-items:center}
}

/* --- Print --- */
@media print{
  .header,.footer,.scroll-top,.btn,.trust-bar,.partners,.wave-divider,.nav-toggle,.utility-bar{display:none!important}
  .hero{min-height:auto;padding:20px 0;background:#fff!important}
  .hero-bg,.hero-overlay{display:none!important}
  .hero h1,.hero h3,.hero p{color:#000!important}
  .section{padding:20px 0}
  body{font-size:12pt;color:#000}
  a{color:#000;text-decoration:underline}
}

/* --- Address Autocomplete Dropdown --- */
.address-dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;background:#fff;border:1px solid #ddd;border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 12px rgba(0,0,0,.1);list-style:none;margin:0;padding:0;max-height:240px;overflow-y:auto}
.address-dropdown__item{padding:10px 14px;cursor:pointer;font-size:14px;line-height:1.4;border-bottom:1px solid #f0f0f0;transition:background .15s}
.address-dropdown__item:last-child{border-bottom:none}
.address-dropdown__secondary{color:#888;font-size:13px}
.address-dropdown__item--active,.address-dropdown__item:hover{background:var(--color-primary-light,#f0f7ff)}

/* --- Lightbox --- */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s;cursor:zoom-out}
.lightbox.active{opacity:1;visibility:visible}
.lightbox__img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:4px;box-shadow:0 4px 40px rgba(0,0,0,.5);transform:scale(.95);transition:transform .25s}
.lightbox.active .lightbox__img{transform:scale(1)}
.lightbox__close{position:absolute;top:16px;right:20px;width:40px;height:40px;background:rgba(255,255,255,.12);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox__close:hover{background:rgba(255,255,255,.25)}
.lightbox__close svg{width:20px;height:20px;stroke:#fff;stroke-width:2}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background:rgba(255,255,255,.1);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lightbox__nav:hover{background:rgba(255,255,255,.22)}
.lightbox__nav svg{width:22px;height:22px;stroke:#fff;stroke-width:2;fill:none}
.lightbox__nav--prev{left:16px}
.lightbox__nav--next{right:16px}
.lightbox__counter{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:14px;font-family:var(--font-body)}
.gallery__item{cursor:zoom-in}

/* --- Featured Card (full-width, horizontal layout) --- */
.card--featured{grid-column:1/-1;display:grid;grid-template-columns:1.4fr 1fr;border:2px solid var(--color-primary)}
.card--featured .card-img{aspect-ratio:16/9}
.card--featured .card-body{display:flex;flex-direction:column;justify-content:center;padding:32px}
.card--featured .card-body h3{font-size:22px}
.card--featured .card-body p{font-size:16px}
@media(max-width:768px){.card--featured{grid-template-columns:1fr}}
