/* ============================================
   ALEXBURD Roofing - Main Stylesheet
   Modern 2025/2026 Design System
   ============================================ */
img{image-orientation:from-image}

/* --- CSS Variables --- */
:root {
    --green: #2D5A3D;
    --green-light: #3A7A52;
    --green-tint: #E8F0EB;
    --navy: #1E2D4A;
    --navy-light: #3B5278;
    --white: #FFFFFF;
    --off-white: #F5F7FA;
    --dark: #1A1A2E;
    --gray-100: #F0F2F5;
    --gray-200: #E2E5EA;
    --gray-300: #C5CAD3;
    --gray-500: #6B7280;
    --gray-700: #374151;
    --gold: #F59E0B;
    --red: #EF4444;
    --font-heading: 'Montserrat', sans-serif;
    --font-body: 'DM Sans', sans-serif;
    --shadow-sm: 0 1px 3px rgba(0,0,0,.08);
    --shadow-md: 0 4px 12px rgba(0,0,0,.1);
    --shadow-lg: 0 8px 30px rgba(0,0,0,.12);
    --shadow-xl: 0 20px 60px rgba(0,0,0,.15);
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 16px;
    --transition: .3s ease;
    --header-h: 80px;
}

/* --- Skip Link (Accessibility) --- */
.skip-link{position:absolute;top:-100%;left:16px;z-index:100000;padding:12px 24px;background:var(--green);color:var(--white);font-family:var(--font-heading);font-weight:600;font-size:.9rem;border-radius:0 0 var(--radius-sm) var(--radius-sm);transition:top .2s ease}
.skip-link:focus{top:0;color:var(--white)}

/* --- Reset --- */
*,*::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(--dark);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
body.menu-open{overflow:hidden}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--green);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--green-light)}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:1rem}

/* --- Typography --- */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2;color:var(--dark)}
h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:800}
h2{font-size:clamp(1.75rem,4vw,2.75rem);font-weight:700}
h3{font-size:clamp(1.25rem,2.5vw,1.5rem);font-weight:600}
h4{font-size:1.125rem;font-weight:600}
p{margin-bottom:1rem;color:var(--gray-700)}
p:last-child{margin-bottom:0}

/* --- Container --- */
.container{width:100%;max-width:1320px;margin:0 auto;padding:0 20px}
.container--narrow{max-width:900px}
@media(min-width:768px){.container{padding:0 40px}}

/* --- Section --- */
.section{padding:60px 0}
@media(min-width:768px){.section{padding:80px 0}}
@media(min-width:1200px){.section{padding:100px 0}}
.section--dark{background:var(--navy);color:var(--white)}
.section--dark h2,.section--dark h3,.section--dark p{color:var(--white)}
.section--dark p{opacity:.85}
.section--light{background:var(--off-white)}

.section-header{text-align:center;max-width:700px;margin:0 auto 48px}
.section-header--light .section-header__tag{color:var(--green-light);border-color:var(--green-light);box-shadow:inset 0 0 0 1.5px var(--green-light),inset 0 0 0 3.5px transparent,inset 0 0 0 4.5px rgba(58,122,82,.3)}
.section-header--light .section-header__title{color:var(--white)}
.section-header__tag{display:inline-block;font-family:var(--font-heading);font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:3px;color:var(--green);padding:8px 18px;border:2px solid var(--green);border-radius:2px;margin-bottom:18px;background:none;transform:rotate(-2deg);box-shadow:inset 0 0 0 1.5px transparent,inset 0 0 0 3.5px transparent,inset 0 0 0 4.5px rgba(45,90,61,.15)}
.section-header__tag::before,.section-header__tag::after{display:none}
.section--dark .section-header__tag{color:var(--green-light);border-color:var(--green-light);box-shadow:inset 0 0 0 1.5px transparent,inset 0 0 0 3.5px transparent,inset 0 0 0 4.5px rgba(58,122,82,.25)}
.section-header__title{margin-bottom:16px}
.section-header__desc{font-size:1.05rem;color:var(--gray-500);max-width:600px;margin:0 auto}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 32px;font-family:var(--font-heading);font-size:.9rem;font-weight:600;border-radius:var(--radius-sm);transition:all var(--transition);border:2px solid transparent;text-transform:uppercase;letter-spacing:1px;gap:8px;white-space:nowrap}
.btn span{display:inline-block}
.btn--primary{background:var(--green);color:var(--white);border-color:var(--green);position:relative;overflow:hidden}
.btn--primary::before{content:'';position:absolute;bottom:0;left:0;width:50%;height:50%;border-bottom:1.5px solid rgba(255,255,255,.4);border-left:1.5px solid rgba(255,255,255,.4);border-radius:0 0 0 inherit;pointer-events:none;transition:all var(--transition)}
.btn--primary::after{content:'';position:absolute;top:0;right:0;width:50%;height:50%;border-top:1.5px solid rgba(255,255,255,.4);border-right:1.5px solid rgba(255,255,255,.4);border-radius:0 inherit 0 0;pointer-events:none;transition:all var(--transition)}
.btn--primary:hover{background:var(--green-light);border-color:var(--green-light);color:var(--white);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--primary:hover::before,.btn--primary:hover::after{width:70%;height:70%;border-color:rgba(255,255,255,.6)}
.btn--secondary{background:var(--navy);color:var(--white);border-color:var(--navy);position:relative;overflow:hidden}
.btn--secondary::before{content:'';position:absolute;bottom:0;left:0;width:50%;height:50%;border-bottom:1.5px solid rgba(255,255,255,.25);border-left:1.5px solid rgba(255,255,255,.25);border-radius:0 0 0 inherit;pointer-events:none;transition:all var(--transition)}
.btn--secondary::after{content:'';position:absolute;top:0;right:0;width:50%;height:50%;border-top:1.5px solid rgba(255,255,255,.25);border-right:1.5px solid rgba(255,255,255,.25);border-radius:0 inherit 0 0;pointer-events:none;transition:all var(--transition)}
.btn--secondary:hover{background:var(--navy-light);border-color:var(--navy-light);color:var(--white);transform:translateY(-2px)}
.btn--secondary:hover::before,.btn--secondary:hover::after{width:70%;height:70%;border-color:rgba(255,255,255,.45)}
.btn--outline{background:transparent;color:var(--green);border-color:var(--green)}
.btn--outline:hover{background:var(--green);color:var(--white);transform:translateY(-2px)}
.btn--white{background:var(--white);color:var(--navy);border-color:var(--white)}
.btn--white:hover{background:var(--off-white);transform:translateY(-2px);box-shadow:var(--shadow-md);color:var(--navy)}
.btn--outline-white{background:transparent;color:var(--white);border-color:rgba(255,255,255,.5)}
.btn--outline-white:hover{background:var(--white);color:var(--navy);border-color:var(--white);transform:translateY(-2px)}
.btn--skew{transform:skewX(-10deg);border-radius:4px}
.btn--skew span{transform:skewX(10deg)}
.btn--skew:hover{transform:skewX(-10deg) translateY(-2px)}
.btn--lg{padding:16px 40px;font-size:.95rem}
.btn--full{width:100%}
.btn:focus-visible{outline:3px solid var(--green-light);outline-offset:2px}

/* --- Top Bar --- */
.top-bar{background:#0a1628;color:rgba(255,255,255,.9);font-size:.8rem;padding:9px 0;display:none;font-family:var(--font-heading);letter-spacing:.5px;font-weight:500}
@media(min-width:768px){.top-bar{display:block}}
.top-bar__inner{display:flex;justify-content:space-between;align-items:center}
.top-bar__left{display:flex;align-items:center;gap:16px}
.top-bar__phone,.top-bar__hours{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,.85)}
.top-bar__phone:hover{color:var(--white)}
.top-bar__phone svg,.top-bar__hours svg{opacity:.7}
.top-bar__divider{opacity:.3}
.top-bar__right{display:flex;align-items:center;height:100%}
.top-bar__socials{display:flex;align-items:center;gap:12px}
.top-bar__socials a{display:flex;align-items:center;color:rgba(255,255,255,.7);transition:color var(--transition)}
.top-bar__socials a:hover{color:var(--white)}

/* --- Header --- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .4s ease;padding:12px 0;background:transparent}
.site-header.header--scrolled,.site-header.header--solid{background:var(--white);box-shadow:var(--shadow-md);padding:8px 0}
@media(min-width:768px){.site-header{top:36px}.site-header.header--scrolled{top:0}}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.site-header__logo{display:flex;align-items:center;flex-shrink:0}
.site-header__logo img{height:55px;width:auto;transition:all var(--transition)}
.logo-light{filter:brightness(0) invert(1)}
.site-header.header--scrolled .site-header__logo img,.site-header.header--solid .site-header__logo img{height:45px;filter:none}
.logo-light{display:block}
.logo-dark{display:none}
.site-header.header--scrolled .logo-light,.site-header.header--solid .logo-light{display:none}
.site-header.header--scrolled .logo-dark,.site-header.header--solid .logo-dark{display:block}
.menu-open .site-header .logo-light{display:none}
.menu-open .site-header .logo-dark{display:block;filter:none}

/* Navigation */
.site-header__nav{display:none}
@media(min-width:992px){.site-header__nav{display:block}}
.nav-menu{display:flex;gap:4px}
.nav-menu>li>a{font-family:var(--font-heading);font-size:.85rem;font-weight:600;color:var(--white);padding:10px 16px;display:flex;align-items:center;gap:4px;transition:color var(--transition);text-transform:uppercase;letter-spacing:.5px}
.site-header.header--scrolled .nav-menu>li>a,.site-header.header--solid .nav-menu>li>a{color:var(--dark)}
.nav-menu>li>a:hover{color:var(--green-light)}
.nav-menu>li.is-active>a{color:var(--white);position:relative}
.nav-menu>li.is-active>a::after{content:'';position:absolute;bottom:6px;left:16px;right:16px;height:2px;background:linear-gradient(90deg,var(--green),var(--green-light));border-radius:2px}
.site-header.header--scrolled .nav-menu>li>a:hover{color:var(--green)}
.site-header.header--scrolled .nav-menu>li.is-active>a{background:linear-gradient(135deg,var(--green),var(--green-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.site-header.header--scrolled .nav-menu>li.is-active>a::after{background:linear-gradient(90deg,var(--green),var(--green-light))}
.dropdown-arrow{transition:transform var(--transition)}
.nav-menu>li:hover .dropdown-arrow{transform:rotate(180deg)}
.nav-menu .submenu-toggle{display:none}

/* Dropdown */
.nav-menu .sub-menu{position:absolute;top:100%;left:0;background:var(--white);min-width:260px;padding:12px 0;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(10px);transition:all var(--transition);z-index:100}
.nav-menu>li{position:relative}
.nav-menu>li:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.sub-menu li a{display:block;padding:10px 24px;font-size:.85rem;color:var(--dark);transition:all var(--transition);font-weight:500}
.sub-menu li a:hover{background:var(--green-tint);color:var(--green);padding-left:28px}

/* Header Actions */
.site-header__actions{display:flex;align-items:center;gap:12px}
.header-phone{color:var(--white);padding:8px;border-radius:50%;transition:all var(--transition);display:none}
.site-header.header--scrolled .header-phone{color:var(--navy)}
.header-phone:hover{color:var(--green-light)}
.site-header__actions .btn{display:none}
@media(min-width:992px){.site-header__actions .btn{display:inline-flex}}

/* Mobile Toggle */
.mobile-toggle{display:flex;flex-direction:column;gap:5px;padding:8px;width:40px;z-index:1001}
@media(min-width:992px){.mobile-toggle{display:none}}
.mobile-toggle__line{width:24px;height:2px;background:var(--white);border-radius:2px;transform-origin:center}
.mobile-toggle__line:nth-child(1){transition:transform .8s cubic-bezier(.23,1,.32,1) .15s,background .5s ease}
.mobile-toggle__line:nth-child(2){transition:opacity .3s ease .1s,background .5s ease}
.mobile-toggle__line:nth-child(3){transition:transform .6s cubic-bezier(.23,1,.32,1) .15s,background .5s ease}
.site-header.header--scrolled .mobile-toggle__line{background:var(--dark)}
.mobile-toggle.is-active .mobile-toggle__line:nth-child(1){transform:translateY(7px) rotate(405deg);transition:transform .8s cubic-bezier(.25,.46,.45,.94) .15s,background .5s ease}
.mobile-toggle.is-active .mobile-toggle__line:nth-child(2){opacity:0;transition:opacity .2s ease 0s,background .5s ease}
.mobile-toggle.is-active .mobile-toggle__line:nth-child(3){transform:translateY(-7px) rotate(-45deg);transition:transform .6s cubic-bezier(.23,1,.32,1) .15s,background .5s ease}
.mobile-toggle.is-active .mobile-toggle__line{background:var(--dark)}

/* --- Mobile Menu --- */
.mobile-menu{position:fixed;inset:0;background:var(--white);z-index:999;opacity:0;visibility:hidden;transition:all .4s ease;display:flex;flex-direction:column}
.mobile-menu.is-open{opacity:1;visibility:visible}
.mobile-menu__inner{display:flex;flex-direction:column;height:100%;padding:120px 24px 24px;overflow-y:auto}
.mobile-menu__header{margin-bottom:32px}
.mobile-menu__header img{height:50px;width:auto}
.mobile-nav-menu>li{border-bottom:1px solid var(--gray-200);position:relative}
.mobile-nav-menu>li>a{display:block;padding:16px 0;font-family:var(--font-heading);font-weight:600;color:var(--dark);font-size:1.1rem;padding-right:48px}
.mobile-nav-menu>li>a>.dropdown-arrow{display:none}
.submenu-toggle{position:absolute;right:0;top:0;width:48px;height:56px;display:flex;align-items:center;justify-content:center;background:none;border:none;outline:none;color:var(--dark);cursor:pointer;transition:transform .3s ease;padding:0;-webkit-tap-highlight-color:transparent}
.is-expanded>.submenu-toggle{transform:rotate(180deg);top:auto;bottom:0}
.mobile-nav-menu .sub-menu{display:none;padding:0 0 12px 16px}
.mobile-nav-menu .sub-menu.is-open{display:block}
.mobile-nav-menu .sub-menu li a{padding:10px 0;font-size:.95rem;color:var(--gray-500)}
.mobile-menu__footer{margin-top:auto;display:flex;flex-direction:column;gap:12px;padding-top:24px}

/* --- Hero --- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:120px 0 80px}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.hero__fallback{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(30,45,74,.85) 0%,rgba(45,90,61,.7) 100%);z-index:2}
.hero__shapes{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.hero__shape{position:absolute;background:rgba(255,255,255,.03);transform:rotate(-15deg)}
.hero__shape--1{width:400px;height:400px;top:-100px;right:-100px;clip-path:polygon(25% 0%,100% 0%,75% 100%,0% 100%)}
.hero__shape--2{width:300px;height:300px;bottom:-50px;left:-80px;clip-path:polygon(25% 0%,100% 0%,75% 100%,0% 100%)}
.hero__content{position:relative;z-index:3;text-align:center;max-width:800px;margin:0 auto}
.hero__badge{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-heading);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:2.5px;color:rgba(255,255,255,.9);padding:0 0 10px;margin-bottom:28px;position:relative;animation:badgeIn .8s ease .3s both}
.hero__badge::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:40px;height:1.5px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.hero__badge-icon{flex-shrink:0}
@keyframes badgeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.hero__title{color:var(--white);margin-bottom:20px;text-shadow:0 2px 20px rgba(0,0,0,.2)}
.hero__subtitle{color:rgba(255,255,255,.85);font-size:clamp(1rem,2vw,1.2rem);margin-bottom:36px;max-width:600px;margin-left:auto;margin-right:auto}
.hero__actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-bottom:24px}
.hero__phone{color:rgba(255,255,255,.7);font-size:.9rem}
.hero__phone a{color:var(--white);font-weight:600;font-size:1.1rem}
.hero__phone a:hover{color:var(--green-light)}
.hero__divider{position:absolute;bottom:-1px;left:0;right:0;z-index:4}
.hero__divider svg{display:block;width:100%;height:60px}
@media(min-width:768px){.hero__divider svg{height:120px}}

/* --- Trust Bar --- */
.trust-bar{padding:40px 0;background:var(--off-white);position:relative;overflow:hidden}
.trust-bar__deco{position:absolute;right:0;bottom:0;width:160px;height:100px;pointer-events:none;z-index:0}
.trust-bar__deco img{width:100%;height:100%;object-fit:contain;object-position:right bottom}
@media(max-width:991px){.trust-bar__deco{width:130px;height:82px;opacity:.7}}
@media(max-width:767px){.trust-bar__deco{width:100px;height:62px;opacity:.5}}
.trust-bar__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;text-align:center}
@media(min-width:768px){.trust-bar__grid{grid-template-columns:repeat(4,1fr)}}
.trust-bar__item{padding:20px}
.trust-bar__number{font-family:var(--font-heading);font-size:clamp(2rem,4vw,3rem);font-weight:800;display:flex;align-items:baseline;justify-content:center;gap:2px}
.trust-bar__number .counter,.trust-bar__number .trust-bar__suffix{display:inline-block;background:linear-gradient(135deg,#1a3d2a,#4a9960);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:transparent}
.trust-bar__label{font-size:.85rem;color:var(--gray-500);font-weight:500;margin-top:4px;text-transform:uppercase;letter-spacing:1px}

/* --- Services Overview --- */
.services-overview{position:relative}
.services-overview__grid{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:768px){.services-overview__grid{grid-template-columns:1fr 1fr}}
.services-overview__column{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);transition:all .4s ease;position:relative;overflow:hidden;border:1px solid rgba(0,0,0,.06)}
.services-overview__column:hover{box-shadow:var(--shadow-xl);transform:translateY(-6px)}
/* Large faded number watermark */
.services-overview__column:nth-child(1) .services-overview__header::before{content:'01'}
.services-overview__column:nth-child(2) .services-overview__header::before{content:'02'}
.services-overview__header::before{position:absolute;right:16px;top:8px;font-family:var(--font-heading);font-size:5rem;font-weight:900;color:rgba(255,255,255,.08);line-height:1;pointer-events:none;z-index:0}
.services-overview__header{position:relative;padding:40px 32px 32px;text-align:left;z-index:1;display:flex;align-items:flex-start;gap:20px}
.services-overview__header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:6px;background:linear-gradient(180deg,rgba(0,0,0,.04),transparent);pointer-events:none;z-index:2}
.services-overview__column:nth-child(1) .services-overview__header{background:linear-gradient(135deg,rgba(45,90,61,.6),rgba(34,70,48,.7)),url('../images/IMG_3200.webp') center/cover no-repeat}
.services-overview__column:nth-child(2) .services-overview__header{background:linear-gradient(135deg,rgba(27,43,68,.6),rgba(20,35,58,.7)),url('../images/IMG_3209.webp') center/cover no-repeat}
.services-overview__header-text{position:relative;z-index:1}
.services-overview__header h3{color:var(--white);margin-bottom:6px;font-size:1.3rem}
.services-overview__header p{font-size:.85rem;color:rgba(255,255,255,.75);margin:0}
.services-overview__icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;flex-shrink:0;border-radius:var(--radius-md);background:rgba(255,255,255,.15);color:var(--white);backdrop-filter:blur(4px);border:1.5px solid rgba(255,255,255,.2);transition:all var(--transition);position:relative;z-index:1}
.services-overview__column:hover .services-overview__icon{transform:scale(1.08);background:rgba(255,255,255,.25)}
.services-overview__body{background:var(--white);padding:24px 32px 32px}
.services-overview__list{margin-bottom:24px;position:relative;z-index:1;counter-reset:svc}
.services-overview__list li{padding:0;border-bottom:none;margin-bottom:2px;counter-increment:svc}
.services-overview__list a{color:var(--dark);font-weight:500;display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-sm);transition:all .25s ease;position:relative}
.services-overview__list a::before{content:counter(svc,decimal-leading-zero);font-family:var(--font-heading);font-size:.7rem;font-weight:700;color:var(--gray-300);width:22px;text-align:center;flex-shrink:0;transition:all .25s ease}
.services-overview__list a::after{content:'';position:absolute;right:14px;width:16px;height:16px;background:url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%232D5A3D' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E") center/contain no-repeat;opacity:0;transform:translateX(-6px);transition:all .25s ease}
.services-overview__list a:hover{background:var(--green-tint);color:var(--green);padding-left:20px}
.services-overview__list a:hover::before{color:var(--green)}
.services-overview__list a:hover::after{opacity:.5;transform:translateX(0)}
.services-overview__body .btn{width:100%}
@media(max-width:767px){
    .services-overview__header{padding:24px 20px;gap:14px}
    .services-overview__header::before{font-size:3.5rem;right:10px;top:6px}
    .services-overview__header h3{font-size:1.1rem}
    .services-overview__header p{font-size:.8rem}
    .services-overview__icon{width:46px;height:46px}
    .services-overview__body{padding:16px 20px 24px}
    .services-overview__list a{padding:10px 12px;font-size:.9rem}
    .services-overview__list a::after{display:none}
}
.section-divider{position:absolute;bottom:-1px;left:0;right:0;pointer-events:none}
.section-divider--green{color:var(--navy)}
.section-divider svg{display:block;width:100%;height:40px}
@media(min-width:768px){.section-divider svg{height:80px}}

/* --- Why Choose Us --- */
.why-us__grid{display:grid;grid-template-columns:1fr;gap:24px;counter-reset:why}
@media(min-width:576px){.why-us__grid{grid-template-columns:1fr 1fr}}
@media(min-width:992px){.why-us__grid{grid-template-columns:repeat(4,1fr)}}
.why-us__card{text-align:center;padding:36px 24px;border-radius:var(--radius-md);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);transition:all var(--transition);position:relative;overflow:hidden;counter-increment:why}
.why-us__card:hover{background:rgba(255,255,255,.1);transform:translateY(-6px)}
.why-us__card-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:var(--radius-md);background:rgba(58,122,82,.12);color:var(--green-light);margin-bottom:20px;transition:all var(--transition)}
.why-us__card:hover .why-us__card-icon{background:rgba(58,122,82,.25);transform:scale(1.08)}
.why-us__card-title{font-size:1.1rem;margin-bottom:12px;color:var(--white)}
.why-us__card-desc{font-size:.9rem;color:rgba(255,255,255,.7);line-height:1.6}
.why-us__card-head{display:contents}
.why-us__card-chevron{display:none}
@media(max-width:575px){
    .why-us__grid{gap:0;padding:0}
    .why-us__card{display:block;text-align:left;padding:0;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.1);border-radius:0;overflow:hidden}
    .why-us__card:first-child{border-top:1px solid rgba(255,255,255,.1)}
    .why-us__card:hover{background:none;transform:none}
    .why-us__card::before{display:none}
    .why-us__card-head{display:flex;align-items:center;gap:14px;padding:16px 0;cursor:pointer;position:relative;padding-right:36px}
    .why-us__card-chevron{display:flex;position:absolute;right:4px;top:50%;transform:translateY(-50%);color:rgba(255,255,255,.4);transition:transform .3s ease}
    .why-us__card.is-open .why-us__card-chevron{transform:translateY(-50%) rotate(180deg);color:var(--green-light)}
    .why-us__card-icon{width:44px;height:44px;min-width:44px;margin:0;border-radius:var(--radius-sm);background:rgba(58,122,82,.2);color:var(--green-light)}
    .why-us__card-icon svg{width:22px;height:22px}
    .why-us__card-title{font-size:1rem;margin:0;color:var(--white);flex:1}
    .why-us__card-desc{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;font-size:.88rem;line-height:1.6;color:rgba(255,255,255,.65);padding:0 0 0 58px}
    .why-us__card.is-open .why-us__card-desc{max-height:200px;padding:0 0 20px 58px}
}

/* --- Projects Gallery (Our Works page) --- */
.projects__filters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:36px}
.projects__filter{padding:10px 24px;font-family:var(--font-heading);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--gray-500);border:1.5px solid var(--gray-200);border-radius:50px;transition:all var(--transition);background:var(--white)}
.projects__filter:hover,.projects__filter.is-active{background:var(--green);color:var(--white);border-color:var(--green)}
.projects__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(min-width:768px){.projects__grid{grid-template-columns:repeat(3,1fr);gap:20px}}
@media(min-width:1200px){.projects__grid{grid-template-columns:repeat(4,1fr)}}
.projects__item{position:relative;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:4/3;cursor:pointer;transition:opacity .4s ease}
.projects__item.is-hidden{display:none}
.projects__item-image{position:absolute;inset:0}
.projects__item-image img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.projects__item:hover .projects__item-image img{transform:scale(1.08)}
.projects__item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(30,45,74,.9) 0%,transparent 60%);display:flex;flex-direction:column;justify-content:flex-end;padding:20px;opacity:0;transition:opacity var(--transition)}
.projects__item:hover .projects__item-overlay{opacity:1}
.projects__item-overlay h4{color:var(--white);font-size:1rem;margin-bottom:4px}
.projects__item-overlay p{color:rgba(255,255,255,.7);font-size:.8rem;display:flex;align-items:center;gap:4px}

/* --- Before & After Slider --- */
.before-after{background:var(--white)}
.ba-slider__wrapper{position:relative;width:100%;max-width:900px;margin:0 auto;aspect-ratio:16/9;overflow:hidden;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);cursor:col-resize;-webkit-user-select:none;user-select:none}
.ba-slider__after,.ba-slider__before{position:absolute;inset:0}
.ba-slider__after img,.ba-slider__before img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.ba-slider__before{clip-path:inset(0 50% 0 0)}
.ba-slider__label{position:absolute;top:20px;padding:8px 18px;font-family:var(--font-heading);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;border-radius:4px;pointer-events:none;z-index:3}
.ba-slider__label--before{left:16px;background:rgba(30,30,30,.75);color:var(--white);backdrop-filter:blur(4px)}
.ba-slider__label--after{right:16px;background:rgba(45,90,61,.85);color:var(--white);backdrop-filter:blur(4px)}
.ba-slider__handle{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:4px;display:flex;flex-direction:column;align-items:center;z-index:5;pointer-events:none}
.ba-slider__line{flex:1;width:3px;background:var(--white);box-shadow:0 0 6px rgba(0,0,0,.3)}
.ba-slider__knob{width:48px;height:48px;border-radius:50%;background:var(--white);box-shadow:0 2px 12px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;color:var(--green);flex-shrink:0;pointer-events:auto;transition:transform .2s ease}
.ba-slider__knob:hover{transform:scale(1.1)}
.ba-slider__knob svg{width:16px;height:16px}
@media(max-width:767px){.ba-slider__wrapper{aspect-ratio:4/3;border-radius:var(--radius-md)}.ba-slider__knob{width:40px;height:40px}.ba-slider__label{font-size:.65rem;padding:6px 12px;top:12px}}

/* --- Projects Strip (Homepage carousel) --- */
.projects-strip__wrapper{position:relative;overflow:hidden;width:100%}
.projects-strip__track{display:flex;gap:0;width:max-content}
.projects-strip__item{flex-shrink:0;width:280px;aspect-ratio:3/2;border-radius:0;overflow:hidden;position:relative;display:block}
@media(min-width:576px){.projects-strip__item{width:320px;border-radius:var(--radius-md)}.projects-strip__track{gap:16px}}
@media(min-width:768px){.projects-strip__item{width:400px}}
@media(min-width:1200px){.projects-strip__item{width:460px}}
.projects-strip__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.projects-strip__item:hover img{transform:scale(1.06)}
.projects-strip__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(30,45,74,.85) 0%,transparent 50%);display:flex;flex-direction:column;justify-content:flex-end;padding:20px;opacity:0;transition:opacity var(--transition)}
.projects-strip__item:hover .projects-strip__overlay{opacity:1}
.projects-strip__overlay h4{color:var(--white);font-size:1rem;margin-bottom:2px}
.projects-strip__overlay p{color:rgba(255,255,255,.7);font-size:.85rem;margin:0}
.projects-strip__arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--navy);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);border:none;cursor:pointer;transition:all var(--transition);z-index:5;backdrop-filter:blur(4px)}
.projects-strip__arrow:hover{background:var(--green);color:var(--white);transform:translateY(-50%) scale(1.1)}
.projects-strip__arrow--left{left:16px}
.projects-strip__arrow--right{right:16px}

/* --- Service Areas --- */
.service-areas__grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:576px){.service-areas__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:992px){.service-areas__grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1200px){.service-areas__grid{grid-template-columns:repeat(5,1fr)}}
.service-areas__card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 20px;background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:all var(--transition);color:var(--dark);position:relative}
.service-areas__card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px);border-color:var(--green);color:var(--dark)}
.service-areas__card-icon{color:var(--green);margin-bottom:12px}
.service-areas__card h3{font-size:1.05rem;margin-bottom:8px}
.service-areas__card p{font-size:.85rem;color:var(--gray-500);margin-bottom:12px}
.service-areas__card-arrow{color:var(--green);transition:transform var(--transition)}
.service-areas__card:hover .service-areas__card-arrow{transform:translateX(4px)}

/* --- Testimonials --- */
.testimonials{position:relative;overflow:hidden}
.testimonials::after{content:'\201D';position:absolute;font-family:Georgia,serif;font-weight:700;font-size:clamp(200px,30vw,400px);color:var(--green);opacity:.04;pointer-events:none;line-height:1;z-index:0;bottom:-100px;right:-20px}
.testimonials .container{position:relative;z-index:1}
.testimonials__slider{position:relative;overflow:hidden}
.testimonials__track{display:flex;transition:transform .5s ease}
.testimonials__slide{flex:0 0 100%;padding:0 12px}
@media(min-width:768px){.testimonials__slide{flex:0 0 50%}}
@media(min-width:992px){.testimonials__slide{flex:0 0 33.333%}}
.testimonials__card{background:var(--white);border-radius:var(--radius-md);padding:32px;box-shadow:var(--shadow-md);border:1px solid var(--gray-200);height:100%;display:flex;flex-direction:column}
.testimonials__stars{display:flex;gap:2px;margin-bottom:16px}
.testimonials__text{font-size:1rem;line-height:1.8;color:var(--gray-700);flex:1;margin-bottom:20px;font-style:italic}
.testimonials__text::before{content:'\201C';font-size:2rem;font-family:Georgia,serif;color:var(--green);line-height:1;display:block;margin-bottom:8px}
.testimonials__author strong{display:block;color:var(--dark);font-size:.95rem}
.testimonials__author span{font-size:.8rem;color:var(--gray-500)}
.testimonials__google-badge{position:absolute;top:16px;right:16px;display:inline-flex;align-items:center;opacity:.7;transition:all var(--transition);z-index:2}
.testimonials__google-badge:hover{opacity:1;transform:scale(1.15)}
.testimonials__card--google{position:relative;border-color:rgba(66,133,244,.15)}
.testimonials__dots{display:flex;justify-content:center;gap:6px;margin-top:32px}
.testimonials__bar{width:40px;height:3px;background:var(--gray-200);border:none;border-radius:2px;cursor:pointer;position:relative;overflow:hidden;padding:0;transition:background var(--transition)}
.testimonials__bar:hover{background:var(--gray-300)}
.testimonials__bar-fill{position:absolute;left:0;top:0;height:100%;width:0;background:var(--green);border-radius:2px}
.testimonials__bar.is-done .testimonials__bar-fill{width:100%}
.testimonials__bar.is-active{background:var(--gray-200)}

/* --- CTA Banner --- */
.cta-banner{position:relative;padding:80px 0;overflow:hidden}
.cta-banner__bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--navy) 0%,var(--green) 100%)}
.cta-banner__overlay{position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.cta-banner__content{position:relative;z-index:1;text-align:center;max-width:700px;margin:0 auto}
.cta-banner__content h2{color:var(--white);margin-bottom:16px}
.cta-banner__content p{color:rgba(255,255,255,.8);font-size:1.1rem;margin-bottom:32px}
.cta-banner__actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}

/* --- Contact Form --- */
.home-contact__grid{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:992px){.home-contact__grid{grid-template-columns:1.2fr .8fr}}
.contact-form__row{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:16px}
@media(min-width:576px){.contact-form__row{grid-template-columns:1fr 1fr}}
.contact-form__field{margin-bottom:16px}
.contact-form__field label{display:block;font-weight:600;font-size:.85rem;margin-bottom:6px;color:var(--dark)}
.contact-form__field input,.contact-form__field select,.contact-form__field textarea{width:100%;padding:14px 16px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:.95rem;transition:border-color var(--transition);background:var(--white)}
.contact-form__field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%236B7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:44px;cursor:pointer;color:var(--dark)}
.contact-form__field select:invalid,.contact-form__field select option[value=""]{color:var(--gray-500)}
.contact-form__field select option{color:var(--dark);padding:8px}
.contact-form__field input:focus,.contact-form__field select:focus,.contact-form__field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(45,90,61,.1)}
.contact-form__field textarea{resize:vertical;min-height:100px}
.contact-form__note{font-size:.8rem;color:var(--gray-500);margin-top:12px;text-align:center}

.home-contact__info-card{background:var(--navy);color:var(--white);border-radius:var(--radius-lg);padding:36px;position:sticky;top:120px}
.home-contact__info-card h3{color:var(--white);margin-bottom:24px;font-size:1.3rem}
.home-contact__details{margin-bottom:24px}
.home-contact__details li{display:flex;align-items:flex-start;gap:16px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.home-contact__details li:last-child{border-bottom:none}
.home-contact__details svg{flex-shrink:0;color:var(--green-light);margin-top:2px}
.home-contact__details strong{display:block;font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.5);margin-bottom:4px}
.home-contact__details a{color:var(--white)}
.home-contact__details a:hover{color:var(--green-light)}
.home-contact__details span{color:rgba(255,255,255,.85);font-size:.9rem}
.home-contact__map{border-radius:var(--radius-md);overflow:hidden;margin-top:8px}

/* --- Pre-Footer CTA --- */
.pre-footer-cta{background:var(--green);padding:40px 0}
.pre-footer-cta__inner{display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center}
@media(min-width:768px){.pre-footer-cta__inner{flex-direction:row;justify-content:space-between;text-align:left}}
.pre-footer-cta__content h3{color:var(--white);font-size:1.4rem;margin-bottom:4px}
.pre-footer-cta__content p{color:rgba(255,255,255,.8);margin:0}
.pre-footer-cta__actions{display:flex;gap:12px;flex-wrap:wrap}
@media(max-width:767px){.pre-footer-cta__actions{justify-content:center}}

/* --- Footer --- */
.site-footer{background:var(--dark)}
.site-footer__main{padding:60px 0 40px}
.site-footer__grid{display:grid;grid-template-columns:1fr;gap:36px}
@media(min-width:576px){.site-footer__grid{grid-template-columns:1fr 1fr}}
@media(min-width:992px){.site-footer__grid{grid-template-columns:1.5fr 1fr 1fr 1.2fr}}
.site-footer__col--info{padding-right:20px}
.site-footer__logo{display:inline-block;margin-bottom:16px}
.site-footer__logo img{height:50px;width:auto;filter:brightness(1.2)}
.site-footer__tagline{color:rgba(255,255,255,.6);font-size:.9rem;margin-bottom:20px;line-height:1.7}
.certification-badge{display:inline-block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--green-light);border:1px solid rgba(58,122,82,.3);padding:6px 14px;border-radius:4px;margin-bottom:16px}
.site-footer__socials{display:flex;gap:12px}
.site-footer__socials a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);color:rgba(255,255,255,.6);transition:all var(--transition)}
.site-footer__socials a:hover{background:var(--green);color:var(--white)}
.site-footer__heading{color:var(--white);font-size:.95rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:20px;position:relative;padding-bottom:12px}
.site-footer__heading::after{content:'';position:absolute;bottom:0;left:0;width:30px;height:2px;background:var(--green)}
.site-footer__heading--areas{margin-top:24px}
.site-footer__links li{margin-bottom:10px}
.site-footer__links a{color:rgba(255,255,255,.6);font-size:.9rem;transition:all var(--transition)}
.site-footer__links a:hover{color:var(--white);padding-left:4px}
.site-footer__contact li{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px;color:rgba(255,255,255,.6);font-size:.9rem}
.site-footer__contact svg{flex-shrink:0;color:var(--green-light);margin-top:2px}
.site-footer__contact a{color:rgba(255,255,255,.6)}
.site-footer__contact a:hover{color:var(--white)}
.site-footer__areas{display:flex;flex-wrap:wrap;gap:8px}
.site-footer__areas li a{display:inline-block;padding:4px 12px;font-size:.8rem;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.1);border-radius:4px;transition:all var(--transition)}
.site-footer__areas li a:hover{border-color:var(--green);color:var(--green-light)}
.site-footer__bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 0}
.site-footer__bottom-inner{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
@media(min-width:768px){.site-footer__bottom-inner{flex-direction:row;justify-content:space-between}}
.site-footer__copyright{color:rgba(255,255,255,.4);font-size:.8rem}
.site-footer__credit{color:rgba(255,255,255,.55);transition:color var(--transition);font-weight:500}
.site-footer__credit:hover{color:var(--green-light)}
.site-footer__legal{display:flex;gap:12px}
.site-footer__legal a{color:rgba(255,255,255,.4);font-size:.8rem;transition:color var(--transition)}
.site-footer__legal a:hover{color:var(--white)}
.site-footer__legal span{color:rgba(255,255,255,.2)}

/* --- Page Hero (Inner Pages) --- */
.page-hero{position:relative;padding:160px 0 80px;background:var(--navy);background-size:cover;background-position:center;overflow:hidden}
.page-hero--short{padding:140px 0 60px}
.page-hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(30,45,74,.9) 0%,rgba(45,90,61,.75) 100%)}
.page-hero__content{position:relative;z-index:2}
.page-hero__title{color:var(--white);margin-bottom:12px}
.page-hero__subtitle{color:rgba(255,255,255,.85);font-size:1.1rem;margin:0}
.breadcrumbs{font-size:max(.85rem, 14px)}
.breadcrumbs a{color:rgba(255,255,255,.6);transition:color var(--transition)}
.breadcrumbs a:hover{color:var(--white)}
.breadcrumbs__sep{color:rgba(255,255,255,.3);margin:0 8px}
.breadcrumbs__current{color:var(--green-light)}
.page-hero__divider{position:absolute;bottom:-2px;left:0;right:0;z-index:3}
.page-hero__divider svg{display:block;width:100%;height:30px}
@media(min-width:768px){.page-hero__divider svg{height:60px}}

/* --- About Page --- */
.about-story__grid,.about-team__grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:768px){.about-story__grid,.about-team__grid{grid-template-columns:1fr 1fr}}
.about-story__content h2,.about-team__content h2{margin-bottom:20px}
.about-story__image,.about-team__image{position:relative;border-radius:var(--radius-lg);overflow:hidden}
.about-story__image img,.about-team__image img{border-radius:var(--radius-lg);width:100%}
.about-story__accent{position:absolute;bottom:-20px;right:-20px;width:60%;height:60%;border:3px solid var(--green);border-radius:var(--radius-lg);z-index:-1}
.about-values__grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:576px){.about-values__grid{grid-template-columns:1fr 1fr}}
@media(min-width:992px){.about-values__grid{grid-template-columns:repeat(4,1fr)}}
.about-values__card{text-align:center;padding:32px 24px;background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition)}
.about-values__card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.about-values__icon{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;background:var(--green-tint);color:var(--green);margin-bottom:16px}
.about-values__card h3{margin-bottom:8px}
.about-values__card p{font-size:.9rem;color:var(--gray-500)}
.about-certs__grid{display:flex;flex-wrap:wrap;justify-content:center;gap:24px}
.about-certs__item{padding:20px 32px;background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;align-items:center}
.about-certs__item img{height:48px;width:auto}
.about-certs__badge{font-family:var(--font-heading);font-weight:700;font-size:1rem;color:var(--navy);text-transform:uppercase;letter-spacing:1px}

/* --- Service Single Pages --- */

/* Intro Section */
.service-intro__grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
@media(min-width:768px){.service-intro__grid{grid-template-columns:1.2fr .8fr}}
.service-intro__content h2{font-size:1.6rem;margin-bottom:16px;color:var(--dark)}
@media(min-width:768px){.service-intro__content h2{font-size:2rem}}
.service-intro__text{font-size:1rem;color:var(--gray-700);line-height:1.8;margin-bottom:24px}
.service-intro__text p{margin-bottom:12px}
.service-intro__image{position:relative;border-radius:var(--radius-lg);overflow:hidden}
.service-intro__image img{border-radius:var(--radius-lg);width:100%;display:block}
.service-intro__accent{position:absolute;bottom:-8px;right:-8px;width:60%;height:60%;border:3px solid var(--green);border-radius:var(--radius-lg);z-index:-1}

/* Details Section */
.service-details__content{max-width:820px;margin:0 auto;font-size:1.05rem;line-height:1.8;color:var(--gray-700)}
.service-details__content h2,.service-details__content h3{color:var(--dark);margin:28px 0 12px}
.service-details__content p{margin-bottom:16px}
.service-details__content ul,.service-details__content ol{margin:0 0 16px 24px;color:var(--gray-700)}
.service-details__content li{margin-bottom:8px}

/* Benefits Section — Parallelogram Cards (Outline + Gradient Reveal) */
.service-benefits__grid{display:grid;grid-template-columns:1fr;gap:20px;overflow:hidden;padding:0 8px}
@media(min-width:576px){.service-benefits__grid{grid-template-columns:1fr 1fr;padding:0}}
@media(min-width:992px){.service-benefits__grid{grid-template-columns:repeat(3,1fr);gap:24px}}
.service-benefits__card{transform:skewX(-4deg);background:transparent;border-radius:4px;transition:all .5s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden;opacity:0;translate:120px 0;border:1px dashed rgba(255,255,255,.2)}
.service-benefits__card.is-visible{opacity:1;translate:0 0}
/* Gradient fill — sweeps up from bottom on hover */
.service-benefits__card::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--navy) 0%,var(--green) 120%);opacity:0;transition:opacity .5s ease;z-index:0}
.service-benefits__card:hover::before{opacity:1}
.service-benefits__card:hover{border:1px solid rgba(58,122,82,.5);box-shadow:0 8px 36px rgba(45,90,61,.2);translate:0 -4px}
.service-benefits__card-inner{transform:skewX(4deg);padding:32px 28px;position:relative;z-index:1}
.service-benefits__card-number{font-family:var(--font-heading);font-size:2.4rem;font-weight:800;color:rgba(255,255,255,.12);margin-bottom:10px;line-height:1;transition:color .5s ease}
.service-benefits__card:hover .service-benefits__card-number{color:rgba(255,255,255,.3)}
.service-benefits__card-title{font-size:1.1rem;margin-bottom:10px;color:rgba(255,255,255,.75);font-weight:700;transition:color .5s ease}
.service-benefits__card:hover .service-benefits__card-title{color:var(--white)}
.service-benefits__card-desc{font-size:.88rem;color:rgba(255,255,255,.4);line-height:1.7;margin:0;transition:color .5s ease}
.service-benefits__card:hover .service-benefits__card-desc{color:rgba(255,255,255,.8)}
@media(max-width:767px){
    .service-benefits__card{transform:skewX(-3deg)}
    .service-benefits__card-inner{transform:skewX(3deg);padding:24px 20px}
    /* Disable hover on mobile */
    .service-benefits__card:hover::before{opacity:0}
    .service-benefits__card:hover{border-color:rgba(255,255,255,.2);box-shadow:none;translate:0 0}
    .service-benefits__card:hover .service-benefits__card-number{color:rgba(255,255,255,.3)}
    .service-benefits__card:hover .service-benefits__card-title{color:var(--white)}
    .service-benefits__card:hover .service-benefits__card-desc{color:rgba(255,255,255,.75)}
    /* All cards filled */
    .service-benefits__card{border:1px solid rgba(255,255,255,.08)}
    .service-benefits__card::before{opacity:1}
    .service-benefits__card .service-benefits__card-number{color:rgba(255,255,255,.3)}
    .service-benefits__card .service-benefits__card-title{color:var(--white)}
    .service-benefits__card .service-benefits__card-desc{color:rgba(255,255,255,.75)}
    /* Even cards — shifted gradient angle for subtle rhythm */
    .service-benefits__card:nth-child(even)::before{background:linear-gradient(to top right,var(--navy) 0%,var(--green) 140%)}
    .service-benefits__card:nth-child(even){border-color:rgba(58,122,82,.15)}
}

/* Gallery Section */
.service-gallery__masonry{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(min-width:768px){.service-gallery__masonry{grid-template-columns:repeat(3,1fr);gap:16px}}
.service-gallery__item{border-radius:var(--radius-md);overflow:hidden;aspect-ratio:4/3}
.service-gallery__link{display:block;width:100%;height:100%;position:relative}
.service-gallery__link img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-gallery__item:hover img{transform:scale(1.06)}
.service-gallery__overlay{position:absolute;inset:0;background:rgba(30,45,74,.4);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition);color:var(--white)}
.service-gallery__item:hover .service-gallery__overlay{opacity:1}

/* FAQ Section */
.service-faq__accordion{max-width:800px;margin:0 auto}
.service-faq__item{border-bottom:1px solid var(--gray-200)}
.service-faq__item:first-child{border-top:1px solid var(--gray-200)}
.service-faq__question{display:flex;align-items:center;justify-content:space-between;width:100%;padding:20px 0;font-size:1.05rem;font-weight:600;color:var(--dark);text-align:left;background:none;border:none;cursor:pointer;font-family:var(--font-heading);gap:16px;transition:color var(--transition)}
.service-faq__question:hover{color:var(--green)}
.service-faq__chevron{flex-shrink:0;transition:transform .3s ease;color:var(--gray-500)}
.service-faq__item--active .service-faq__chevron,.service-faq__question[aria-expanded="true"] .service-faq__chevron{transform:rotate(180deg);color:var(--green)}
.service-faq__answer{max-height:0;overflow:hidden;transition:max-height .35s ease}
.service-faq__item--active .service-faq__answer,.service-faq__question[aria-expanded="true"]+.service-faq__answer{max-height:500px}
.service-faq__answer p{padding:0 0 20px;font-size:.95rem;color:var(--gray-700);line-height:1.7}

/* Related Services */
.service-related__grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:576px){.service-related__grid{grid-template-columns:1fr 1fr}}
@media(min-width:992px){.service-related__grid{grid-template-columns:repeat(3,1fr)}}
.service-related__card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:all var(--transition);display:flex;flex-direction:column}
.service-related__card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px);border-color:var(--green)}
.service-related__card-image{aspect-ratio:16/10;overflow:hidden;background:var(--gray-100)}
.service-related__card-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-related__card:hover .service-related__card-image img{transform:scale(1.06)}
.service-related__card-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,var(--green-tint),var(--gray-100));color:var(--green)}
.service-related__card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.service-related__card-title{font-size:1.1rem;margin-bottom:10px}
.service-related__card-title a{color:var(--dark);transition:color var(--transition)}
.service-related__card-title a:hover{color:var(--green)}
.service-related__card-excerpt{font-size:.9rem;color:var(--gray-500);line-height:1.6;margin-bottom:20px;flex:1}

/* Service Cards */
.service-card{display:block;background:var(--white);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:all var(--transition);color:var(--dark)}
.service-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px);color:var(--dark)}
.service-card__image{aspect-ratio:16/10;overflow:hidden}
.service-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-card:hover .service-card__image img{transform:scale(1.06)}
.service-card__content{padding:24px}
.service-card__title{font-size:1.1rem;margin-bottom:8px}
.service-card__excerpt{font-size:.9rem;color:var(--gray-500);margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.service-card__link{font-size:.85rem;font-weight:600;color:var(--green);display:flex;align-items:center;gap:6px;transition:gap var(--transition)}
.service-card:hover .service-card__link{gap:10px}

/* --- Service Parent Intro --- */
.service-parent-intro__content{max-width:800px;margin:0 auto;text-align:center}
.service-parent-intro__text{font-size:1.05rem;color:var(--gray-700);line-height:1.8;margin-top:20px}
.service-parent-intro__text p{margin-bottom:16px}

/* --- Service Parent Grid --- */
.service-parent-grid__cards{display:grid;grid-template-columns:1fr;gap:28px}
@media(min-width:576px){.service-parent-grid__cards{grid-template-columns:1fr 1fr}}
@media(min-width:992px){.service-parent-grid__cards{grid-template-columns:repeat(3,1fr)}}
.service-parent-grid__card{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:all var(--transition);display:flex;flex-direction:column}
.service-parent-grid__card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px);border-color:var(--green)}
.service-parent-grid__card-image{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--gray-100)}
.service-parent-grid__card-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-parent-grid__card:hover .service-parent-grid__card-image img{transform:scale(1.06)}
.service-parent-grid__card-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,var(--green-tint),var(--gray-100));color:var(--green)}
.service-parent-grid__card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.service-parent-grid__card-title{font-size:1.15rem;margin-bottom:10px}
.service-parent-grid__card-title a{color:var(--dark);transition:color var(--transition)}
.service-parent-grid__card-title a:hover{color:var(--green)}
.service-parent-grid__card-excerpt{font-size:.9rem;color:var(--gray-500);line-height:1.6;margin-bottom:20px;flex:1}
.service-parent-grid__card-body .btn{align-self:flex-start}

/* --- Service Process Timeline --- */
.service-process__timeline{display:grid;grid-template-columns:1fr;gap:0;position:relative;max-width:700px;margin:0 auto}
@media(min-width:768px){.service-process__timeline{max-width:none;grid-template-columns:repeat(4,1fr);gap:24px}}
.service-process__step{display:flex;gap:20px;padding:28px 0;position:relative}
@media(min-width:768px){.service-process__step{flex-direction:column;text-align:center;padding:0}}
.service-process__step-marker{display:flex;flex-direction:column;align-items:center;position:relative;z-index:2}
.service-process__step-number{display:flex;align-items:center;justify-content:center;width:52px;height:52px;min-width:52px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-light));color:var(--white);font-family:var(--font-heading);font-weight:700;font-size:1.15rem;box-shadow:0 4px 16px rgba(45,90,61,.25)}
@media(min-width:768px){.service-process__step-number{width:60px;height:60px;min-width:60px;font-size:1.25rem;margin-bottom:20px}}
.service-process__step-line{display:none}
@media(max-width:767px){.service-process__step-line{display:block;width:2px;flex:1;background:linear-gradient(180deg,var(--green),var(--green-tint));margin-top:8px}}
@media(min-width:768px){.service-process__step:not(:last-child)::after{content:'';position:absolute;top:30px;left:calc(50% + 38px);right:calc(-50% + 38px);height:2px;background:linear-gradient(90deg,var(--green),var(--green-tint));z-index:1}}
.service-process__step-content{flex:1;padding-bottom:8px}
@media(min-width:768px){.service-process__step-content{padding-bottom:0}}
.service-process__step-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-sm);background:var(--green-tint);color:var(--green);margin-bottom:12px}
@media(min-width:768px){.service-process__step-icon{margin:0 auto 12px}}
.service-process__step-title{font-size:1.05rem;margin-bottom:8px;color:var(--dark)}
.service-process__step-desc{font-size:.88rem;color:var(--gray-500);line-height:1.6}

/* Process Steps (legacy) */
.process__steps{display:grid;grid-template-columns:1fr;gap:32px;position:relative}
@media(min-width:768px){.process__steps{grid-template-columns:repeat(4,1fr)}}
.process__step{text-align:center;position:relative}
.process__step-number{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:var(--green);color:var(--white);font-family:var(--font-heading);font-weight:700;font-size:1.2rem;margin-bottom:16px}
.process__step h4{margin-bottom:8px}
.process__step p{font-size:.85rem;color:var(--gray-500)}

/* --- Location Pages --- */

/* Location Intro */
.location-intro__content{max-width:800px;margin:0 auto;text-align:center}
.location-intro__content h2{margin-bottom:16px}
.location-intro__text{color:var(--gray-700);margin-bottom:32px;line-height:1.8}
.location-intro__text p{margin-bottom:16px}
.location-intro__read-more{display:none}
@media(max-width:767px){
.location-intro__text.is-collapsed{max-height:11.4em;overflow:hidden;position:relative}
.location-intro__text.is-collapsed::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3em;background:linear-gradient(transparent,#fff)}
.location-intro__text.is-collapsed+.location-intro__read-more,.location-intro__read-more{display:inline-block;background:none;border:none;color:var(--green);font-weight:600;font-size:.95rem;cursor:pointer;padding:0;margin-bottom:24px}
.location-intro__text:not(.is-collapsed)+.location-intro__read-more{margin-top:-16px}
}
.location-intro__actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}

/* Location Services Grid */
.location-services__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(min-width:768px){.location-services__grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:992px){.location-services__grid{grid-template-columns:repeat(4,1fr)}}
.location-services__card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 20px;background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:all var(--transition);color:var(--dark);text-decoration:none}
.location-services__card:hover{box-shadow:var(--shadow-md);border-color:var(--green);transform:translateY(-3px);color:var(--dark)}
.location-services__icon{color:var(--green);margin-bottom:14px}
.location-services__icon svg{width:36px;height:36px}
.location-services__card h3{font-size:.95rem;margin-bottom:8px;color:var(--dark)}
.location-services__card p{font-size:.85rem;color:var(--gray-500);line-height:1.6;margin-bottom:12px;flex:1}
.location-services__link{font-size:.8rem;font-weight:600;color:var(--green);margin-top:auto;transition:color var(--transition)}
.location-services__card:hover .location-services__link{color:var(--green-light)}

/* Location Why Choose Us */
.location-why__grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:start}
@media(min-width:992px){.location-why__grid{grid-template-columns:1.2fr .8fr}}
.location-why__content h2{margin-bottom:16px}
.location-why__content p{color:var(--gray-700);line-height:1.8;margin-bottom:24px}
.location-why__list{display:flex;flex-direction:column;gap:14px}
.location-why__list li{display:flex;align-items:center;gap:12px;font-size:.95rem;color:var(--dark);font-weight:500}
.location-why__list li svg{flex-shrink:0;color:var(--green)}
.location-why__stats{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.location-why__stat{text-align:center;padding:28px 16px;background:var(--green-tint);border-radius:var(--radius-md);border:1px solid rgba(45,90,61,.1)}
.location-why__stat-number{display:block;font-family:var(--font-heading);font-size:2rem;font-weight:800;color:var(--green);line-height:1.1;margin-bottom:6px}
.location-why__stat-label{font-size:.8rem;color:var(--gray-500);font-weight:500;text-transform:uppercase;letter-spacing:.03em}

/* Location Testimonials */
.location-testimonials__grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.location-testimonials__grid{grid-template-columns:repeat(3,1fr)}}
.location-testimonials__card{background:var(--white);border-radius:var(--radius-md);padding:32px 28px;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);display:flex;flex-direction:column;gap:16px}
.location-testimonials__card-top{display:flex;align-items:center;justify-content:space-between}
.location-testimonials__stars{display:flex;gap:2px}
.location-testimonials__stars svg{color:var(--gold)}
.location-testimonials__google-badge{display:flex;align-items:center;opacity:.7;transition:opacity var(--transition)}
.location-testimonials__google-badge:hover{opacity:1}
.location-testimonials__text{font-size:.95rem;color:var(--gray-700);line-height:1.7;font-style:italic;flex:1;margin:0;border:none;padding:0}
.location-testimonials__author{display:flex;flex-direction:column;gap:2px}
.location-testimonials__name{font-size:.85rem;font-weight:600;color:var(--dark);font-style:normal}
.location-testimonials__location{font-size:.8rem;color:var(--gray-500)}

/* Location Map */
.location-map__embed{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.location-map__embed iframe{width:100%;height:450px;border:none;display:block}
@media(max-width:767px){.location-map__embed iframe{height:320px}}

/* Location Contact Form */
.location-contact__form-wrapper{max-width:800px;margin:0 auto}
.contact-form__grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:576px){.contact-form__grid{grid-template-columns:1fr 1fr}}
.contact-form__field--full{grid-column:1/-1}
.section--dark .contact-form__field label{display:block;font-size:.85rem;font-weight:600;color:rgba(255,255,255,.9);margin-bottom:6px}
.section--dark .contact-form__field .required{color:var(--gold)}
.section--dark .contact-form__field input,.section--dark .contact-form__field select,.section--dark .contact-form__field textarea{width:100%;padding:12px 16px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.08);color:var(--white);font-size:.95rem;transition:all var(--transition)}
.section--dark .contact-form__field input::placeholder,.section--dark .contact-form__field textarea::placeholder{color:rgba(255,255,255,.4)}
.section--dark .contact-form__field input:focus,.section--dark .contact-form__field select:focus,.section--dark .contact-form__field textarea:focus{outline:none;border-color:var(--green-light);background:rgba(255,255,255,.12)}
.section--dark .contact-form__field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.5)' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.section--dark .contact-form__field select option{background:var(--navy);color:var(--white)}
.contact-form__submit{margin-top:28px;text-align:center}

/* --- Contact Page --- */
.contact-main__grid{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:992px){.contact-main__grid{grid-template-columns:1.3fr .7fr}}
.contact-main__form h2{margin-bottom:8px}
.contact-main__form>p{color:var(--gray-500);margin-bottom:24px}
.contact-main__form .required{color:var(--red)}
.contact-form__grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:576px){.contact-form__grid{grid-template-columns:1fr 1fr}}
.contact-form__field--full{grid-column:1 / -1}
.contact-info-card{background:var(--navy);color:var(--white);border-radius:var(--radius-lg);padding:36px;position:sticky;top:120px}
.contact-info-card h3{color:var(--white);margin-bottom:8px;font-size:1.3rem}
.contact-info-card>p{color:rgba(255,255,255,.7);font-size:.9rem;margin-bottom:28px}
.contact-info-card__items{margin-bottom:28px}
.contact-info-card__item{display:flex;align-items:flex-start;gap:16px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.contact-info-card__item:last-child{border-bottom:none}
.contact-info-card__icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;flex-shrink:0;border-radius:var(--radius-sm);background:rgba(58,122,82,.2);color:var(--green-light)}
.contact-info-card__details{display:flex;flex-direction:column;gap:2px}
.contact-info-card__details strong{font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.5)}
.contact-info-card__details a,.contact-info-card__details span{color:rgba(255,255,255,.9);font-size:.95rem;line-height:1.5}
.contact-info-card__details a:hover{color:var(--green-light)}
.contact-info-card__note{font-size:.8rem;color:var(--green-light);font-weight:600;margin-top:2px}
.contact-info-card__social{padding-top:20px;border-top:1px solid rgba(255,255,255,.1);margin-bottom:20px}
.contact-info-card__social strong{display:block;font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.5);margin-bottom:12px}
.contact-info-card__social-links{display:flex;gap:10px}
.contact-info-card__social-links a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);transition:all var(--transition)}
.contact-info-card__social-links a:hover{background:var(--green);color:var(--white)}
.contact-info-card__cta{padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}
.contact-info-card__cta p{color:rgba(255,255,255,.6);font-size:.85rem;margin-bottom:12px}
.btn--block{width:100%}
.contact-map__embed{line-height:0}
.contact-map__embed iframe{width:100%;height:450px;border:none}
@media(max-width:767px){.contact-map__embed iframe{height:300px}}
.section--flush{padding:0}
/* Contact FAQ */
.contact-faq__list{max-width:800px;margin:0 auto}
.contact-faq__item{border:1px solid var(--gray-200);border-radius:var(--radius-md);margin-bottom:12px;overflow:hidden;background:var(--white);transition:border-color var(--transition)}
.contact-faq__item.is-open{border-color:var(--green)}
.contact-faq__question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:20px 24px;font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--dark);text-align:left;gap:16px;transition:all var(--transition);background:none;border:none;cursor:pointer}
.contact-faq__question:hover{color:var(--green)}
.contact-faq__item.is-open .contact-faq__question{color:var(--green);background:var(--green-tint)}
.contact-faq__chevron{flex-shrink:0;transition:transform var(--transition)}
.contact-faq__item.is-open .contact-faq__chevron{transform:rotate(180deg)}
.contact-faq__answer{max-height:0;overflow:hidden;transition:max-height .4s ease}
.contact-faq__item.is-open .contact-faq__answer{max-height:300px}
.contact-faq__answer p{padding:0 24px 20px;color:var(--gray-700);line-height:1.8}

/* --- FAQ Accordion --- */
.faq-accordion__item{border:1px solid var(--gray-200);border-radius:var(--radius-md);margin-bottom:12px;overflow:hidden;background:var(--white)}
.faq-accordion__trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:20px 24px;font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--dark);text-align:left;gap:16px;transition:all var(--transition)}
.faq-accordion__trigger:hover{color:var(--green)}
.faq-accordion__trigger[aria-expanded="true"]{color:var(--green);background:var(--green-tint)}
.faq-accordion__icon{flex-shrink:0;transition:transform var(--transition)}
.faq-accordion__trigger[aria-expanded="true"] .faq-accordion__icon{transform:rotate(45deg)}
.faq-accordion__panel{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-accordion__content{padding:0 24px 20px;color:var(--gray-700);line-height:1.8}
.faq-accordion__content p{margin-bottom:12px}

/* --- Legal Pages --- */
.legal-content{padding:60px 0}
.legal-content h2{font-size:1.5rem;margin:36px 0 16px;color:var(--dark)}
.legal-content h3{font-size:1.2rem;margin:24px 0 12px}
.legal-content p{margin-bottom:16px;line-height:1.8}
.legal-content ul{margin:0 0 16px 24px;list-style:disc}
.legal-content ul li{margin-bottom:8px;color:var(--gray-700)}
.legal-content a{color:var(--green);text-decoration:underline}
.legal-content .last-updated{font-size:.85rem;color:var(--gray-500);margin-bottom:32px}

/* --- 404 --- */
.error-404__number{font-family:var(--font-heading);font-size:clamp(6rem,15vw,10rem);font-weight:900;color:var(--green-tint);line-height:1}
.error-404 h2{margin-bottom:12px}
.error-404 p{color:var(--gray-500);margin-bottom:32px}
.error-404__actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}

/* --- Floating Call Button --- */
.floating-call{position:fixed;bottom:50px;right:30px;z-index:950;display:flex;align-items:center;gap:0;text-decoration:none;cursor:pointer}
.floating-call__icon{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--green) 0%,var(--green-light) 100%);color:var(--white);box-shadow:0 4px 20px rgba(45,90,61,.4);transition:all var(--transition)}
.floating-call:hover .floating-call__icon{transform:scale(1.1);box-shadow:0 6px 28px rgba(45,90,61,.5)}
.floating-call__label{display:none}
.floating-call__pulse{position:absolute;right:0;bottom:0;width:56px;height:56px;border-radius:50%;background:var(--green);opacity:.3;animation:floatingPulse 2s ease-out infinite;z-index:1}
.floating-call__pulse--2{animation-delay:1s}
@keyframes floatingPulse{0%{transform:scale(1);opacity:.3}100%{transform:scale(2.2);opacity:0}}
.floating-call.is-hidden{opacity:0;visibility:hidden;transform:translateY(20px)}

/* --- Back to Top --- */
.back-to-top{position:fixed;bottom:120px;right:36px;width:48px;height:48px;border-radius:50%;background:var(--green);color:var(--white);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transform:translateY(20px);transition:all var(--transition);z-index:900;border:none;cursor:pointer}
.back-to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--green-light);transform:translateY(-3px)}

/* --- Utility --- */
.text-center{text-align:center}
.text-green{color:var(--green)}
.bg-green-tint{background:var(--green-tint)}
.mt-0{margin-top:0}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mt-4{margin-top:32px}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* --- Responsive --- */
@media(max-width:991px){
    .hero{min-height:90vh;padding:100px 0 60px}
    .hero__shape{display:none}
    .page-hero{padding:120px 0 60px}
}
@media(max-width:767px){
    .hero{min-height:80vh}
    .hero__actions{flex-direction:column;align-items:center}
    .hero__actions .btn{width:100%;max-width:300px}
    .trust-bar__grid{gap:16px}
    .trust-bar__item{padding:12px}
    .cta-banner{padding:60px 0}
    .cta-banner__actions{flex-direction:column;align-items:center}
    .cta-banner__actions .btn{width:100%;max-width:300px}
    .about-story__accent{display:none}
}
@media(max-width:767px){
    .btn--skew{transform:skewX(-6deg);border-radius:4px}
    .btn--skew span{transform:skewX(6deg)}
    .btn--skew:hover{transform:skewX(-6deg) translateY(-2px)}
}
@media(max-width:575px){
    .projects__grid{grid-template-columns:1fr}
}
@media(max-width:393px){
    h1{font-size:1.6rem}
    .hero{min-height:95vh;padding:90px 0 50px}
    .hero__subtitle{font-size:.9rem;margin-bottom:24px}
    .hero__actions .btn{padding:12px 20px;font-size:.8rem;max-width:260px}
    .hero__phone{font-size:.8rem}
    .hero__phone a{font-size:.95rem}
    .btn--lg{padding:12px 24px;font-size:.82rem}
    .mobile-menu__inner{padding:96px 20px 20px}
    .mobile-nav-menu>li>a{padding:12px 0;font-size:1rem}
    .mobile-menu__footer{padding-top:16px;gap:8px}
}

/* --- Service Areas Page --- */
.areas-intro__content{max-width:800px;margin:0 auto;text-align:center}
.areas-intro__text{font-size:1.05rem;color:var(--gray-700);line-height:1.8;margin-top:20px}
.areas-intro__text p{margin-bottom:16px}

/* Area Cards Grid */
.areas-grid__cards{display:flex;flex-wrap:wrap;gap:24px;justify-content:center}
.areas-grid__card{width:100%}
@media(min-width:576px){.areas-grid__card{width:calc(50% - 12px)}}
@media(min-width:992px){.areas-grid__card{width:calc(33.333% - 16px)}}
@media(min-width:1200px){.areas-grid__card{width:calc(25% - 18px)}}
.areas-grid__card{transition:all var(--transition)}
.areas-grid__card-inner{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:all var(--transition);height:100%;display:flex;flex-direction:column}
.areas-grid__card:hover .areas-grid__card-inner{box-shadow:var(--shadow-lg);transform:translateY(-6px);border-color:var(--green)}
.areas-grid__card-image{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--gray-100)}
.areas-grid__card-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.areas-grid__card:hover .areas-grid__card-image img{transform:scale(1.06)}
.areas-grid__card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.areas-grid__card-icon{width:44px;height:44px;border-radius:50%;background:var(--green-tint);color:var(--green);display:flex;align-items:center;justify-content:center;margin-bottom:14px;transition:all var(--transition)}
.areas-grid__card:hover .areas-grid__card-icon{background:var(--green);color:var(--white)}
.areas-grid__card-title{font-size:1.1rem;margin-bottom:8px}
.areas-grid__card-title a{color:var(--dark);transition:color var(--transition)}
.areas-grid__card-title a:hover{color:var(--green)}
.areas-grid__card-excerpt{font-size:.88rem;color:var(--gray-500);line-height:1.6;margin-bottom:16px;flex:1}
.areas-grid__card-link{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:var(--green);transition:all var(--transition)}
.areas-grid__card-link:hover{color:var(--green-light);gap:10px}
.areas-grid__card-link svg{transition:transform var(--transition)}
.areas-grid__card:hover .areas-grid__card-link svg{transform:translateX(3px)}

/* Map Section */
.areas-map__wrapper{max-width:1032px;margin:0 auto}
.areas-map__embed{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--gray-200)}
.areas-map__embed iframe{width:100%;height:450px;border:0}
.areas-map__container{padding:0}
.areas-map__svg{width:100%;height:auto;max-height:520px;display:block}

/* Map Pins */
.areas-map__marker-link{text-decoration:none}
.areas-map__marker{animation:pin-drop .5s cubic-bezier(.34,1.56,.64,1) both}
.areas-map__pin{cursor:pointer;transition:opacity .25s ease}
.areas-map__marker:hover .areas-map__pin{opacity:.85}
@keyframes pin-drop{0%{opacity:0;transform:translateY(-15px)}100%{opacity:1;transform:translateY(0)}}
.areas-map__label{font-family:var(--font-heading);font-size:18px;font-weight:700;fill:rgba(255,255,255,.8);pointer-events:none;transition:fill .25s ease}
.areas-map__marker:hover .areas-map__label{fill:#fff}

/* Map Note */
.areas-map__note{text-align:center;margin-top:16px;padding:14px 24px;background:rgba(255,255,255,.04);border-radius:var(--radius-lg);border:1px dashed rgba(255,255,255,.1)}
.areas-map__note p{font-size:1.05rem;color:rgba(255,255,255,.55);margin:0}
.areas-map__note a{color:var(--green-light);font-weight:600}
.areas-map__note a:hover{color:#fff}

@media(max-width:767px){
    .areas-map__wrapper{margin-right:calc(-1 * (100vw - 100%) / 2);padding-right:0}
    .areas-map__container{overflow:hidden;margin-right:0}
    .areas-map__svg{max-height:none;width:200%;max-width:none;margin-left:-18%}
    .areas-map__label{font-size:18px}
    .areas-grid__card-body{padding:18px}
}

/* --- Lightbox --- */
.lightbox{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__image{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--radius-sm);box-shadow:0 8px 40px rgba(0,0,0,.5);opacity:0;transform:scale(.95);transition:opacity .3s ease .05s,transform .3s ease .05s}
.lightbox.is-open .lightbox__image{opacity:1;transform:scale(1)}
.lightbox__close{position:absolute;top:16px;right:16px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);color:var(--white);display:flex;align-items:center;justify-content:center;transition:all var(--transition);border:none;cursor:pointer;z-index:2}
.lightbox__close:hover{background:rgba(255,255,255,.25);transform:scale(1.1)}
.lightbox__arrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12);color:var(--white);display:flex;align-items:center;justify-content:center;transition:all var(--transition);border:none;cursor:pointer;z-index:2}
.lightbox__arrow:hover{background:rgba(255,255,255,.25);transform:translateY(-50%) scale(1.1)}
.lightbox__arrow--prev{left:16px}
.lightbox__arrow--next{right:16px}
.lightbox__counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);font-family:var(--font-heading);font-size:.85rem;font-weight:600;color:rgba(255,255,255,.7);letter-spacing:1px;z-index:2}
@media(max-width:767px){
    .lightbox__image{max-width:96vw;max-height:80vh}
    .lightbox__arrow{width:40px;height:40px}
    .lightbox__arrow--prev{left:8px}
    .lightbox__arrow--next{right:8px}
    .lightbox__close{top:10px;right:10px;width:40px;height:40px}
    .lightbox__counter{bottom:14px;font-size:.8rem}
}

/* --- Print --- */
@media print{
    .site-header,.top-bar,.mobile-menu,.pre-footer-cta,.cta-banner,.back-to-top,.floating-call,.hero__video{display:none!important}
    .hero{min-height:auto;padding:40px 0}
    body{color:#000;background:#fff}
}
