@import url('https://fonts.googleapis.com/css2?family=Oswald%3Awght%40400%3B500%3B600%3B700%26family%3DBarlow%3Awght%40400%3B500%3B600&display=swap');
:root{
--clr-accent:#ef4444;
--clr-primary:#f59e0b;
--clr-text:#e5e5e5;
--clr-bg:#0f0f0f;
--clr-surface:#1a1a1a;
--clr-heading:#fafafa;
--clr-muted:#a3a3a3;
--card-radius:0;
--btn-radius:0;
--clr-alert-info:#2563eb;
--clr-alert-info-bg:#eff6ff;
--clr-alert-success:#16a34a;
--clr-alert-success-bg:#f0fdf4;
--clr-alert-warning:#d97706;
--clr-alert-warning-bg:#fffbeb;
--clr-alert-error:#dc2626;
--clr-alert-error-bg:#fef2f2;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;line-height:1.6;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:'Barlow','Helvetica Neue',Arial,sans-serif;color:#e5e5e5;background:#0f0f0f}
img{max-width:100%;height:auto;display:block}
a{color:#f59e0b;text-decoration:none}
a:hover{color:#fbbf24;text-decoration:underline}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
header{background:#000000;border-bottom:1px solid #2a2a2a;padding:1rem 0;position:relative;z-index:50}
header .container{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo{font-size:1.25rem;font-weight:700;color:#fafafa;font-family:'Oswald','Impact',sans-serif;text-decoration:none}
.logo:hover{text-decoration:none}
.main-nav{display:block}
nav ul{list-style:none;display:flex;gap:1.5rem;flex-wrap:wrap;align-items:center}
nav a{color:#6b7280;font-weight:600;font-size:0.875rem;font-family:'Barlow','Helvetica Neue',Arial,sans-serif;text-decoration:none}
nav a:hover{color:#f59e0b;text-decoration:none}
.has-dropdown{position:relative}
.has-dropdown>a::after{content:'';display:inline-block;width:0;height:0;margin-left:5px;vertical-align:middle;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid currentColor}
.dropdown-menu{display:none;position:absolute;top:100%;left:0;background:#000000;border:1px solid #2a2a2a;border-radius:0;min-width:200px;padding:0.5rem 0;box-shadow:0 4px 12px rgba(0,0,0,0.12);z-index:100;flex-direction:column;gap:0}
.has-dropdown:hover>.dropdown-menu{display:flex}
.has-dropdown.open>.dropdown-menu{display:flex}
.dropdown-menu li{width:100%}
.dropdown-menu a{display:block;padding:0.5rem 1rem;white-space:nowrap;color:#e5e5e5}
.dropdown-menu a:hover{background:#1a1a1a;color:#f59e0b}
.hamburger-toggle{display:none;background:none;border:none;cursor:pointer;padding:0.5rem;flex-direction:column;gap:4px}
.hamburger-toggle span{display:block;width:24px;height:2px;background:#fafafa;transition:transform 0.3s,opacity 0.3s}
.hamburger-toggle.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hamburger-toggle.active span:nth-child(2){opacity:0}
.hamburger-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
main{min-height:60vh}
footer{background:#000000;color:#a3a3a3;padding:3rem 0 1.5rem;margin-top:4rem}
footer a{color:#e5e5e5}
footer .container{display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between}
.footer-bottom{border-top:1px solid #2a2a2a;margin-top:2rem;padding-top:1rem;text-align:center;font-size:0.875rem}
.hero{padding:5rem 0 5rem}
.hero h1{font-size:3.5rem;font-weight:700;color:#fafafa;margin-bottom:1rem;line-height:1.2;font-family:'Oswald','Impact',sans-serif}
.hero p{font-size:1.125rem;color:#6b7280;max-width:640px}
.section{padding:3.5rem 0}
.section h2{font-size:2.25rem;font-weight:700;color:#fafafa;margin-bottom:1.5rem;font-family:'Oswald','Impact',sans-serif}
.section h3{font-size:1.375rem;font-weight:700;color:#e5e5e5;margin-bottom:0.75rem;font-family:'Oswald','Impact',sans-serif}
.section p{color:#6b7280;margin-bottom:1rem}
.section-bg-wrap{position:relative}
.section-bg-overlay{position:absolute;inset:0;pointer-events:none;z-index:0}
.grid{display:grid;gap:1.5rem}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.card{background:#1a1a1a;border:2px solid #2a2a2a;border-radius:0;padding:1.75rem;box-shadow:none}
.btn{display:inline-block;padding:0.8rem 2rem;border-radius:0;font-weight:700;font-size:0.875rem;text-align:center;cursor:pointer;border:none;transition:all 0.2s;text-transform:uppercase;box-shadow:none;letter-spacing:0.05em}
.btn-primary{background:#f59e0b;color:#000000}
.btn-primary:hover{background:#d97706;text-decoration:none}
.btn-secondary{background:#2a2a2a;color:#e5e5e5}
.btn-secondary:hover{background:#3a3a3a;text-decoration:none}
.btn-outline{background:transparent;border:2px solid #f59e0b;color:#f59e0b}
.btn-outline:hover{background:#f59e0b;color:#000000;text-decoration:none}
.badge{display:inline-block;padding:0.25rem 0.625rem;border-radius:9999px;font-size:0.75rem;font-weight:500;background:#451a03;color:#fcd34d}
input[type="text"],input[type="email"],input[type="tel"],input[type="url"],input[type="search"],input[type="number"],input[type="password"],textarea,select{font-family:inherit;font-size:0.9375rem;padding:0.625rem 0.875rem;border:2px solid #3a3a3a;border-radius:0;background:#1a1a1a;color:#e5e5e5;width:100%;transition:border-color 0.2s,box-shadow 0.2s}
input[type="text"]:focus,input[type="email"]:focus,input[type="tel"]:focus,input[type="url"]:focus,input[type="search"]:focus,input[type="number"]:focus,input[type="password"]:focus,textarea:focus,select:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}
label{display:block;font-size:0.875rem;font-weight:500;color:#fafafa;margin-bottom:0.375rem}
.form-group{margin-bottom:1rem}
.breadcrumb{padding:0.75rem 0;font-size:0.875rem;color:#a3a3a3}
.breadcrumb a{color:#6b7280}
.breadcrumb span{margin:0 0.5rem}
ul.list{list-style:disc;padding-left:1.5rem;margin-bottom:1rem}
ul.list li{margin-bottom:0.5rem;color:#6b7280}
ul.list.icon-bullets{list-style:none;padding-left:0}
ul.list.icon-bullets li{display:flex;align-items:flex-start;gap:0.5rem;padding-left:0}
ul.list.icon-bullets .bullet-icon{width:1em;height:1em;flex-shrink:0;margin-top:0.2em;color:currentColor}
.faq-item{border-bottom:1px solid #2a2a2a;padding:1rem 0}
.faq-item h3{cursor:pointer;font-size:1.0625rem}
.faq-item p{margin-top:0.5rem;display:none}
.faq-item.open p{display:block}
.cta-section{background:#f59e0b;color:#000000;padding:3.5rem 0;text-align:center}
.cta-section h2{color:#000000}
.cta-section p{color:rgba(255,255,255,0.9);margin-bottom:1.5rem}
.cta-section .btn{background:#000000;color:#f59e0b}
.testimonial{padding:1.5rem;border-left:4px solid #f59e0b;background:#1a1a1a;margin-bottom:1rem;border-radius:0 0 0 0}
.testimonial cite{display:block;margin-top:0.5rem;font-style:normal;font-weight:600;color:#fafafa}
.map-embed{width:100%;height:400px;border:none;border-radius:0}
.contact-info p{margin-bottom:0.5rem}
table{width:100%;border-collapse:collapse;margin-bottom:1.5rem}
th,td{padding:0.75rem;text-align:left;border-bottom:1px solid #2a2a2a}
th{background:#2a2a2a;font-weight:600;color:#fafafa}
.hero{background-image:repeating-linear-gradient(45deg,color-mix(in srgb,#f59e0b 8%,transparent) 0,color-mix(in srgb,#f59e0b 8%,transparent) 1px,transparent 0,transparent 50%),linear-gradient(135deg,#1a1a1a 0%,#0f0f0f 100%);background-size:14px 14px,auto}
footer .container{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem}
footer .container p:first-child{font-weight:600;margin-bottom:0.75rem;color:#e5e5e5}
.btn{border-radius:0;clip-path:polygon(0.65rem 0%,100% 0%,calc(100% - 0.65rem) 100%,0% 100%);padding-left:1.4rem;padding-right:1.4rem}
.section,.section-bg-wrap{clip-path:polygon(0 0,100% 0,100% calc(100% - 3rem),50% calc(100% - 3rem),50% 100%,0 100%);padding-bottom:calc(3.5rem + 3rem);margin-bottom:-3rem;position:relative;z-index:1}
.section-bg-wrap>.section{clip-path:none;padding-bottom:3.5rem;margin-bottom:0}
nav a{position:relative;padding-bottom:0.3rem}
nav a::before{content:'';position:absolute;bottom:-1px;left:0;right:0;height:3px;background:#f59e0b;border-radius:9999px;opacity:0;transition:opacity 0.2s}
nav a:hover::before,nav a.active::before,nav a[aria-current="page"]::before{opacity:1}
.logo{font-size:1.625rem}
.hero h1,.section h1,.section h2,.section h3{letter-spacing:0.03em;text-transform:uppercase}
@media(max-width:768px){
.hero h1{font-size:1.75rem}
.section h2{font-size:1.375rem}
.hamburger-toggle{display:flex}
.main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#000000;border-bottom:1px solid #2a2a2a;padding:1rem;z-index:99}
.main-nav.nav-open{display:block}
.main-nav ul{flex-direction:column;gap:0.5rem}
.has-dropdown:hover>.dropdown-menu{display:none}
.has-dropdown.open>.dropdown-menu{display:flex}
.dropdown-menu{position:static;border:none;box-shadow:none;padding-left:1rem;min-width:0}
nav ul{gap:0.75rem}
.container{padding:0 1rem}
.layout-body{grid-template-columns:1fr!important;flex-direction:column!important}
.layout-sidebar-col{min-width:0;width:100%}
.layout-main-col{min-width:0;width:100%}
.layout-editorial-col,.layout-minimal-col,.layout-case-study-body{max-width:100%;padding:0 1rem}
.layout-two-col-grid,.layout-three-col-grid{grid-template-columns:1fr!important}
.layout-magazine-grid{grid-template-columns:1fr!important}
}

/* ── Layout system ── */
.layout-body{display:grid;gap:1.5rem;align-items:start}
.layout-sidebar-right .layout-body{grid-template-columns:1fr 300px}
.layout-sidebar-left .layout-body{grid-template-columns:300px 1fr}
.layout-local-service .layout-body,.layout-profile-card .layout-body,.layout-faq-hub .layout-body,.layout-news-feed .layout-body,.layout-location-page .layout-body{grid-template-columns:1fr 300px}
.layout-sidebar-left .layout-body{grid-template-columns:300px 1fr}
.layout-main-col{min-width:0}
.layout-sidebar-col{min-width:0}
.layout-sidebar-col .section{padding:3.5rem 1.25rem;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:0;margin-bottom:1rem;clip-path:none}
.layout-sidebar-col .section-bg-wrap{clip-path:none;padding-bottom:3.5rem;margin-bottom:1rem}
.layout-sidebar-col .section:last-child{margin-bottom:0}
.layout-sidebar-col .hero{display:none}
.layout-editorial-col,.layout-case-study-body{max-width:740px;margin:0 auto;padding:3.5rem 1.5rem}
.layout-editorial-col .section,.layout-editorial-col .section-bg-wrap,.layout-case-study-body .section,.layout-case-study-body .section-bg-wrap{padding-left:0;padding-right:0;padding-bottom:3.5rem;margin-bottom:0;clip-path:none}
.layout-minimal-col{max-width:680px;margin:0 auto;padding:3.5rem 1.5rem}
.layout-minimal-col .section,.layout-minimal-col .section-bg-wrap{padding-left:0;padding-right:0;padding-bottom:3.5rem;margin-bottom:0;clip-path:none}
.layout-two-col-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.layout-two-col-grid>.section,.layout-two-col-grid>.section-bg-wrap{margin:0;padding-bottom:3.5rem;clip-path:none}
.layout-three-col-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.layout-three-col-grid>.section,.layout-three-col-grid>.section-bg-wrap{margin:0;padding-bottom:3.5rem;clip-path:none}
.layout-magazine-feature{border-bottom:1px solid #2a2a2a;margin-bottom:3.5rem}
.layout-magazine-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.layout-directory-main .section:first-child{padding-top:0}
.layout-hub-spokes{border-top:1px solid #2a2a2a;padding-top:3.5rem}
.layout-landing-feature{background:#1a1a1a;border-top:1px solid #2a2a2a;border-bottom:1px solid #2a2a2a}
.layout-comparison-cta{background:#f59e0b;color:#000000;text-align:center}
.layout-comparison-cta h2{color:#000000}
.layout-wide-feature-main>.section:nth-child(even) .container>div[style*="grid-template-columns"]{direction:rtl}
.layout-wide-feature-main>.section:nth-child(even) .container>div[style*="grid-template-columns"]>*{direction:ltr}
.zone-full-bleed{width:100%}
.zone-feature,.zone-below-fold,.zone-pre-footer{clear:both}
/* sticky_sidebar layout */
.layout-sticky-sidebar .layout-body{grid-template-columns:1fr 300px;align-items:start}
.layout-sticky-sidebar-col{position:sticky;top:6rem;max-height:calc(100vh - 8rem);overflow-y:auto}
.layout-sticky-sidebar-col .section{padding:3.5rem 1.25rem;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:0;margin-bottom:1rem;clip-path:none}
.layout-sticky-sidebar-col .section-bg-wrap{clip-path:none;padding-bottom:3.5rem;margin-bottom:1rem}
.layout-sticky-sidebar-col .section:last-child{margin-bottom:0}
/* overlay_hero layout */
.layout-overlay-hero .zone-overlay-hero{position:relative;min-height:60vh;display:flex;align-items:flex-end}
.layout-overlay-hero .zone-overlay-hero .hero{background:none;padding-bottom:3rem;width:100%}
.layout-overlay-hero .zone-overlay-hero .hero h1{color:#fff;text-shadow:0 2px 8px rgba(0,0,0,0.5)}
.layout-overlay-hero .zone-overlay-hero .hero p{color:rgba(255,255,255,0.9);text-shadow:0 1px 4px rgba(0,0,0,0.4)}
.layout-overlay-feature{background:#1a1a1a;border-top:4px solid #f59e0b;padding:3.5rem 0}
/* section-bg-wrap overrides: placed last so source order beats equal-specificity layout rules */
.section-bg-wrap>.section,.section-bg-wrap>.hero,.section-bg-wrap>.cta-section{position:relative;z-index:1;background:transparent}
/* section text-color override: user can force light/dark text over any background */
.section-bg-wrap[style*="--sec-text"] h1,.section-bg-wrap[style*="--sec-text"] h2,.section-bg-wrap[style*="--sec-text"] h3,.section-bg-wrap[style*="--sec-text"] h4,.section-bg-wrap[style*="--sec-text"] p,.section-bg-wrap[style*="--sec-text"] li,.section-bg-wrap[style*="--sec-text"] cite,.section-bg-wrap[style*="--sec-text"] label,.section-bg-wrap[style*="--sec-text"] a:not(.btn){color:var(--sec-text)!important}