/* ==========================================================================
   A.J. KRAIG LANDSCAPE AND DESIGN — Design System
   Visual match to existing WordPress site (Flavor theme)
   ========================================================================== */

/* --- Custom Properties --- */
:root {
  --color-primary: #077F09;
  --color-secondary: #073A0D;
  --color-dark: #0B330C;
  --color-darkest: #000000;
  --color-accent: #2B9720;
  --color-light-green: #CBE2A1;
  --color-text: #46707F;
  --color-text-muted: #6a8c98;
  --color-heading: #17252A;
  --color-bg: #FFFFFF;
  --color-bg-alt: rgba(239,239,239,0.31);
  --color-border: #e5e5e5;
  --color-error: #dc3545;
  --color-success: #077F09;
  --color-footer-link: #03A9F4;
  --font-heading: 'Open Sans', sans-serif;
  --font-body: 'Open Sans', sans-serif;
  --font-h1: 'Mulish', 'Open Sans', sans-serif;
  --font-accent: 'Playfair Display', serif;
  --section-padding: 60px;
  --section-padding-sm: 40px;
  --container-width: 1100px;
  --gap: 32px;
  --gap-sm: 20px;
  --radius: 4px;
  --radius-lg: 8px;
  --radius-btn: 16px;
  --shadow: 0 2px 12px rgba(0,0,0,0.06);
  --shadow-lg: 0 4px 20px rgba(0,0,0,0.1);
  --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.3;color:var(--color-heading)}
h1{font-family:var(--font-h1);font-size:clamp(36px,5vw,54px);font-weight:300;letter-spacing:normal}
h2{font-size:clamp(28px,4vw,42px);font-weight:300}
h3{font-size:clamp(22px,3vw,36px);font-weight:300}
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}
.italic-accent{font-family:var(--font-accent);font-style:italic}

/* --- 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:60px 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:none}
.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)}

/* --- Wavy Section Divider — HIDDEN (not on old site) --- */
.wave-divider{display:none}

/* --- Header (transparent over hero, dark on scroll — matches old WP site) --- */
.header{position:fixed;top:0;left:0;right:0;z-index:100;background:transparent;padding:0;transition:background var(--transition),box-shadow var(--transition)}
.header .container{display:flex;align-items:center;justify-content:space-between;min-height:56px}
.header__logo img{height:50px;width:auto}
.header__nav{display:flex;align-items:center;gap:0;flex-wrap:nowrap}
.header__nav a{color:rgba(255,255,255,0.9);font-size:12px;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{background:rgba(255,255,255,0.1);color:#fff}
.header__nav .has-dropdown{position:relative}
.dropdown-arrow{font-size:8px;margin-left:2px;vertical-align:1px;opacity:0.7}
.header__nav .has-dropdown .dropdown{position:absolute;top:100%;left:0;background:rgba(0,0,0,0.85);min-width:200px;padding:4px 0;opacity:0;visibility:hidden;transform:translateY(4px);transition:all var(--transition);box-shadow:var(--shadow-lg);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}
.header__nav .dropdown a:hover{background:rgba(255,255,255,0.08)}
.header__cta{display:flex;align-items:center;gap:12px}
.header__phone{color:rgba(255,255,255,0.9);font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;white-space:nowrap}
.header__phone:hover{color:#fff}
.header__phone svg{color:var(--color-light-green)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all var(--transition)}
.nav-toggle span+span{margin-top:5px}
.header.scrolled{background:rgba(0,0,0,0.85);box-shadow:0 2px 12px rgba(0,0,0,0.2)}

/* --- Hero (full-viewport image with dark overlay — matches old WP site) --- */
.hero{position:relative;min-height:500px;display:flex;align-items:center;overflow:hidden;padding:80px 0 80px;color:#fff;text-align:center}
.hero--home{min-height:600px;padding:100px 0 90px}
.hero--inner{min-height:450px;padding:80px 0 70px}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;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.45);z-index:1}
.hero--inner .hero-overlay{background:rgba(0,0,0,0.4)}
.hero .container{position:relative;z-index:2;max-width:800px}
.hero h1{color:#fff;margin-bottom:16px}
.hero h3{color:#fff;font-weight:300;margin-bottom:8px;font-size:clamp(22px,3vw,36px)}
.hero h3 .italic-accent{color:#fff}
.hero h4{color:rgba(255,255,255,0.9);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 .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 (rounded to match old site) --- */
.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:300;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:300;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 (white bg cards — matches old site slider style) --- */
.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-accent);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-accent);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)}

/* --- 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 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)}
.area-card{background:#fff;padding:24px;border-radius:var(--radius-lg);border-left:3px solid var(--color-primary);transition:box-shadow var(--transition)}
.area-card:hover{box-shadow:var(--shadow-lg)}
.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 (black bg, compact — matches old WP site) --- */
.footer{background:var(--color-darkest);color:#fff;padding:20px 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;gap:12px;max-width:300px}
.footer__brand img{height:40px;width:auto;filter:brightness(0) invert(1)}
.footer__brand p{font-size:13px;color:rgba(255,255,255,0.6);line-height:1.6;display:none}
.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-size:14px;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;display:none}
.footer ul{display:none}
.footer__contact{display:flex!important;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-footer-link);flex-shrink:0;margin-top:2px}
.footer__contact a{color:var(--color-footer-link)}
.footer__contact a:hover{color:#fff}
.footer .btn--primary{display:none}
.footer__bottom{margin-top:16px;padding:10px 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}

/* --- 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:40px;--gap:20px}
  .header{background:rgba(0,0,0,0.7)}
  .header__nav{display:none}
  .header__nav.open{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.95);padding:70px 24px 24px;z-index:99;align-items:stretch;gap:0}
  .header__nav.open a{padding:14px 0;font-size:16px;border-bottom:1px solid rgba(255,255,255,0.08);border-radius:0}
  .header__nav.open .has-dropdown .dropdown{position:static;opacity:1;visibility:visible;transform:none;background:transparent;box-shadow:none;padding:0 0 0 16px;min-width:auto}
  .nav-toggle{display:block;z-index:100}
  .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:80px 0 60px}
  .hero--home{padding:90px 0 70px}
  .hero--inner{padding:80px 0 50px}
  .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}
}

/* --- Print --- */
@media print{
  .header,.footer,.scroll-top,.btn,.trust-bar,.partners,.wave-divider,.nav-toggle{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}
}
