/* ============================================================
 * Colorado Dependable Locksmith — Main Stylesheet
 * Mobile-first | Zero frameworks | CWV-optimized
 * Target: < 8KB minified + gzipped
 * ============================================================ */

/* ── CSS Custom Properties ──────────────────────── */
:root {
    /* Colors */
    --c-primary:     #1B365D;
    --c-primary-d:   #132848;
    --c-primary-dd:  #0F1D2F;
    --c-accent:      #E8A838;
    --c-accent-d:    #D49530;
    --c-success:     #22C55E;
    --c-error:       #EF4444;
    --c-text:        #1F2937;
    --c-text-light:  #6B7280;
    --c-bg:          #FFFFFF;
    --c-bg-alt:      #F8FAFC;
    --c-border:      #E5E7EB;
    --c-footer-bg:   #111827;
    --c-footer-text: #D1D5DB;

    /* Typography */
    --font-family:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --fs-xs:    0.75rem;
    --fs-sm:    0.875rem;
    --fs-base:  1rem;
    --fs-lg:    1.125rem;
    --fs-xl:    1.25rem;
    --fs-2xl:   1.5rem;
    --fs-3xl:   1.75rem;
    --fs-4xl:   2.25rem;

    /* Spacing */
    --sp-1:  0.25rem;
    --sp-2:  0.5rem;
    --sp-3:  0.75rem;
    --sp-4:  1rem;
    --sp-5:  1.25rem;
    --sp-6:  1.5rem;
    --sp-8:  2rem;
    --sp-10: 2.5rem;
    --sp-12: 3rem;
    --sp-16: 4rem;
    --sp-20: 5rem;

    /* Layout */
    --max-width:   1200px;
    --radius:      8px;
    --radius-lg:   12px;
    --shadow-sm:   0 1px 2px rgba(0,0,0,.05);
    --shadow-md:   0 4px 12px rgba(0,0,0,.08);
    --shadow-lg:   0 8px 24px rgba(0,0,0,.12);
    --transition:  200ms ease;
}

/* ── Reset (supplement to inline critical CSS) ──── */
h1,h2,h3,h4,h5,h6 { line-height: 1.25; font-weight: 700; color: var(--c-primary); }
h1 { font-size: var(--fs-4xl); font-weight: 800; }
h2 { font-size: var(--fs-3xl); }
h3 { font-size: var(--fs-xl); font-weight: 600; }
p  { margin-bottom: var(--sp-4); }
ul,ol { list-style: none; }
a:hover { color: var(--c-accent); }

/* ── Utility ────────────────────────────────────── */
.container { width: 100%; max-width: var(--max-width); margin: 0 auto; padding: 0 var(--sp-4); }
.section { padding: var(--sp-20) 0; }
.section--alt { background: var(--c-bg-alt); }
.section--centered { text-align: center; }
.section-title { font-size: var(--fs-3xl); margin-bottom: var(--sp-3); }
.section-subtitle { color: var(--c-text-light); font-size: var(--fs-lg); margin-bottom: var(--sp-10); }
.prose p { margin-bottom: var(--sp-5); line-height: 1.7; }
.prose h2 { margin: var(--sp-10) 0 var(--sp-4); }
.prose h3 { margin: var(--sp-8) 0 var(--sp-3); }
.prose ul, .prose ol { margin: var(--sp-4) 0; padding-left: var(--sp-6); }
.prose ul { list-style: disc; }
.prose ol { list-style: decimal; }
.prose li { margin-bottom: var(--sp-2); }

/* ── Buttons ────────────────────────────────────── */
.btn {
    display: inline-flex; align-items: center; gap: var(--sp-2);
    padding: var(--sp-3) var(--sp-6);
    font-family: var(--font-family); font-size: var(--fs-base); font-weight: 700;
    letter-spacing: 0.025em; text-decoration: none;
    border-radius: var(--radius); border: 2px solid transparent;
    cursor: pointer; transition: all var(--transition);
    min-height: 48px; /* WCAG tap target */
}
/* Primary CTA — solid gold, navy text (WCAG AA 5.82:1) */
.btn--cta {
    background: var(--c-accent); color: var(--c-primary); border-color: var(--c-accent);
    box-shadow: 0 2px 8px rgba(232,168,56,.35);
}
.btn--cta:hover {
    background: var(--c-accent-d); border-color: var(--c-accent-d); color: var(--c-primary);
    box-shadow: 0 4px 16px rgba(232,168,56,.45); transform: translateY(-1px);
}
.btn--cta:focus-visible {
    outline: 3px solid var(--c-primary); outline-offset: 2px;
    box-shadow: 0 0 0 6px rgba(27,54,93,.2);
}
.btn--cta:active { transform: translateY(0); box-shadow: 0 1px 4px rgba(232,168,56,.3); }

/* Secondary CTA — outline navy */
.btn--outline {
    background: transparent; color: var(--c-primary); border-color: var(--c-primary);
}
.btn--outline:hover { background: var(--c-primary); color: #fff; }
.btn--outline:focus-visible { outline: 3px solid var(--c-accent); outline-offset: 2px; }
.btn--outline:active { background: var(--c-primary-d); color: #fff; }

/* Ghost CTA — transparent with subtle border (lower visual weight than primary) */
.btn--ghost {
    background: transparent; color: var(--c-primary); border: 2px solid var(--c-border);
    box-shadow: none;
}
.btn--ghost:hover {
    background: var(--c-bg-alt); border-color: var(--c-primary); color: var(--c-primary);
}
.btn--ghost:focus-visible { outline: 3px solid var(--c-accent); outline-offset: 2px; }
.btn--ghost:active { background: var(--c-border); }
.btn--lg { padding: var(--sp-4) var(--sp-8); font-size: var(--fs-lg); }
.btn--full { width: 100%; justify-content: center; }

/* ── Focus Visible (WCAG 2.4.7 Keyboard Navigation) ── */
:focus-visible {
    outline: 3px solid var(--c-accent);
    outline-offset: 2px;
}
.btn:focus-visible {
    outline: 3px solid var(--c-accent);
    outline-offset: 2px;
    box-shadow: 0 0 0 6px rgba(232, 168, 56, 0.25);
}
.main-nav__link:focus-visible {
    outline: 2px solid var(--c-accent);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

/* ── Icons ──────────────────────────────────────── */
.icon { flex-shrink: 0; vertical-align: middle; }

/* ── Top Bar — darker than header ──────────────── */
.top-bar {
    background: var(--c-primary-dd); color: #fff; font-size: var(--fs-xs);
    padding: 6px 0; border-bottom: 1px solid rgba(255,255,255,.06);
}
.top-bar__inner { display: flex; justify-content: space-between; align-items: center; }
.top-bar__left, .top-bar__right { display: flex; align-items: center; gap: var(--sp-4); }
.top-bar__badge {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(232,168,56,.12); color: var(--c-accent);
    padding: 3px 12px; border-radius: 100px; font-size: var(--fs-xs); font-weight: 600;
}
.top-bar__hours { display: none; align-items: center; gap: 4px; color: rgba(255,255,255,.6); font-size: var(--fs-xs); }
.top-bar__trust { display: none; align-items: center; gap: 4px; color: rgba(255,255,255,.6); font-size: var(--fs-xs); }
.top-bar__phone { color: #fff; font-weight: 700; display: flex; align-items: center; gap: 4px; font-size: var(--fs-sm); }
.top-bar__phone:hover { color: var(--c-accent); }

/* ── Site Header — dark navy premium ──────────── */
.site-header {
    background: var(--c-primary); border-bottom: none;
    position: sticky; top: 0; z-index: 100;
    box-shadow: 0 4px 20px rgba(0,0,0,.25);
}
.site-header__inner {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--sp-3) var(--sp-4); min-height: 68px;
}
.site-header__logo img { height: 40px; width: auto; }
.site-header__cta { display: none; }
.site-header__mobile-actions { display: flex; align-items: center; gap: 8px; }
.site-header__mobile-phone {
    display: flex; align-items: center; justify-content: center;
    width: 44px; height: 44px; background: var(--c-accent); color: var(--c-primary);
    border-radius: 50%; transition: all var(--transition);
}
.site-header__mobile-phone:hover { background: var(--c-accent-d); color: var(--c-primary); }

/* ── Main Nav (desktop — hidden on mobile) ─────── */
.main-nav { display: none; }
.main-nav__list { display: flex; gap: var(--sp-6); }
.main-nav__link {
    font-family: inherit; line-height: inherit;
    font-size: var(--fs-sm); font-weight: 500; color: rgba(255,255,255,.85);
    padding: var(--sp-2) 0; background: none; border: none; cursor: pointer;
    display: flex; align-items: center; gap: var(--sp-1); transition: color var(--transition);
}
.main-nav__link:hover { color: var(--c-accent); }

/* Mega Menu */
.mega-menu {
    display: none; position: absolute; top: 100%; left: 0; right: 0;
    background: #fff; border-top: 3px solid var(--c-accent);
    box-shadow: 0 12px 40px rgba(0,0,0,.2); padding: var(--sp-8);
    z-index: 200;
}
.main-nav__item--dropdown:hover .mega-menu,
.main-nav__item--dropdown:focus-within .mega-menu { display: block; }
.mega-menu__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-8); max-width: var(--max-width); margin: 0 auto; }
.mega-menu__group-title { font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: 0.05em; color: var(--c-accent); margin-bottom: var(--sp-3); }
.mega-menu a { display: block; padding: var(--sp-1) 0; font-size: var(--fs-sm); color: var(--c-text); }
.mega-menu a:hover { color: var(--c-accent); }

/* ── Mobile Toggle ──────────────────────────────── */
.mobile-toggle {
    display: flex; flex-direction: column; gap: 5px;
    background: none; border: none; cursor: pointer; padding: var(--sp-2);
    min-width: 44px; min-height: 44px; justify-content: center; align-items: center;
}
.mobile-toggle__bar {
    display: block; width: 24px; height: 2px; background: #fff;
    transition: transform var(--transition), opacity var(--transition);
}
.mobile-toggle[aria-expanded="true"] .mobile-toggle__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mobile-toggle[aria-expanded="true"] .mobile-toggle__bar:nth-child(2) { opacity: 0; }
.mobile-toggle[aria-expanded="true"] .mobile-toggle__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Mobile Nav — dark theme ──────────────────── */
.mobile-nav {
    background: var(--c-primary-d); border-top: 1px solid rgba(255,255,255,.08);
    padding: 0 0 var(--sp-4); max-height: 80vh; overflow-y: auto;
}
.mobile-nav__eta {
    display: flex; align-items: center; gap: 8px;
    padding: 12px 16px; background: rgba(232,168,56,.08);
    color: var(--c-accent); font-size: var(--fs-xs); font-weight: 500;
    border-bottom: 1px solid rgba(255,255,255,.06);
}
.mobile-nav__list a, .mobile-nav__accordion {
    display: flex; align-items: center; justify-content: space-between;
    padding: var(--sp-3) var(--sp-4); font-size: var(--fs-base); font-weight: 500;
    color: rgba(255,255,255,.9); border-bottom: 1px solid rgba(255,255,255,.06);
    width: 100%; background: none; border: none; cursor: pointer; text-align: left;
    min-height: 48px; text-decoration: none;
}
.mobile-nav__list a:hover, .mobile-nav__accordion:hover { color: var(--c-accent); }
.mobile-nav__sub a { padding-left: var(--sp-8); font-weight: 400; font-size: var(--fs-sm); color: rgba(255,255,255,.65); }
.mobile-nav__accordion .icon { color: rgba(255,255,255,.5); }
.mobile-nav__cta { margin: var(--sp-4) var(--sp-4) 0; }

/* ── Sticky Mobile CTA — premium dark ────────── */
.sticky-cta {
    display: block; position: fixed; bottom: 0; left: 0; right: 0;
    z-index: 999; background: var(--c-primary); padding: var(--sp-3);
    box-shadow: 0 -4px 20px rgba(0,0,0,.3);
    border-top: 2px solid var(--c-accent);
}
.sticky-cta__btn {
    display: flex; align-items: center; justify-content: center; gap: 10px;
    color: var(--c-accent); font-weight: 700; font-size: var(--fs-lg);
    text-decoration: none; min-height: 52px; position: relative;
}
.sticky-cta__pulse {
    width: 10px; height: 10px; background: var(--c-success); border-radius: 50%;
    animation: pulse-glow 2s infinite;
}
@keyframes pulse-glow {
    0%, 100% { opacity: 1; transform: scale(1); box-shadow: 0 0 0 0 rgba(34,197,94,.5); }
    50% { opacity: .7; transform: scale(1.2); box-shadow: 0 0 8px 4px rgba(34,197,94,.25); }
}

/* ── Hero — Premium Dark Gradient ────────────── */
.hero {
    min-height: 700px;
    padding: 3rem 0 3.5rem;
    background: linear-gradient(135deg, #1B365D 0%, #132848 60%, #0F1D2F 100%);
    position: relative; overflow: hidden;
}
.hero::before {
    content: ''; position: absolute; top: -40%; right: -15%;
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(232,168,56,.06) 0%, transparent 70%);
    pointer-events: none;
}
.hero__inner { display: flex; flex-direction: column; gap: var(--sp-8); position: relative; z-index: 1; }
.hero__eta-badge {
    display: inline-flex; align-items: center; gap: 8px;
    background: rgba(34,197,94,.12); border: 1px solid rgba(34,197,94,.25);
    color: #4ade80; padding: 8px 16px; border-radius: 100px;
    font-size: var(--fs-xs); font-weight: 500; margin-bottom: var(--sp-3);
    width: fit-content;
}
.hero__eta-pulse {
    width: 8px; height: 8px; background: var(--c-success); border-radius: 50%;
    animation: pulse-glow 2s infinite;
}
.hero__eyebrow {
    font-size: var(--fs-sm); font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.1em; color: var(--c-accent); margin-bottom: var(--sp-2);
}
.hero__title { font-size: clamp(2rem, 5.5vw, 3.25rem); color: #fff; line-height: 1.08; font-weight: 800; }
.hero__subtitle { font-size: var(--fs-lg); color: rgba(255,255,255,.7); margin-bottom: var(--sp-2); }
.hero__desc { font-size: var(--fs-base); color: rgba(255,255,255,.65); max-width: 600px; line-height: 1.7; }
.hero__actions { display: flex; flex-direction: column; gap: var(--sp-3); margin-top: var(--sp-5); }
.hero__trust { display: flex; flex-wrap: wrap; gap: 10px; margin-top: var(--sp-6); }
.hero__image {
    position: relative; border-radius: var(--radius-lg); overflow: hidden;
    box-shadow: 0 16px 48px rgba(0,0,0,.4);
}
.hero__image picture { display: block; }
.hero__image img { border-radius: var(--radius-lg); width: 100%; height: auto; display: block; }
.hero__image-badge {
    position: absolute; bottom: var(--sp-3); left: var(--sp-3);
    background: rgba(27,54,93,.92); color: #fff; backdrop-filter: blur(10px);
    display: inline-flex; align-items: center; gap: var(--sp-2);
    padding: 8px 14px; border-radius: var(--radius);
    font-size: var(--fs-xs); font-weight: 600; border: 1px solid rgba(255,255,255,.08);
}
.hero__image-badge .icon { color: var(--c-accent); }
.trust-badge {
    display: inline-flex; align-items: center; gap: 8px;
    font-size: var(--fs-xs); font-weight: 500; color: rgba(255,255,255,.8);
    background: rgba(255,255,255,.08); padding: 6px 14px;
    border-radius: 100px; backdrop-filter: blur(4px); border: 1px solid rgba(255,255,255,.06);
}
.trust-badge .icon { color: var(--c-accent); width: 16px; height: 16px; }

/* Button variant for dark hero */
.btn--outline-light {
    background: transparent; color: #fff; border: 2px solid rgba(255,255,255,.3);
}
.btn--outline-light:hover { background: rgba(255,255,255,.1); color: #fff; border-color: rgba(255,255,255,.5); }
.btn--outline-light:focus-visible { outline: 3px solid var(--c-accent); outline-offset: 2px; }

/* Hero variant: service areas */
.hero--city { min-height: auto; }
.hero--service-areas { background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-d) 100%); color: #fff; }
.hero--city { min-height: auto; }
.hero--service-areas .hero__title { color: #fff; }
.hero--city { min-height: auto; }
.hero--service-areas .hero__eyebrow { color: var(--c-accent); }
.hero--city { min-height: auto; }
.hero--service-areas .hero__subtitle { color: rgba(255,255,255,.85); }
.hero--city { min-height: auto; }
.hero--service-areas .hero__desc { color: rgba(255,255,255,.8); }
.hero--city { min-height: auto; }
.hero--service-areas .trust-badge { background: rgba(255,255,255,.15); color: rgba(255,255,255,.9); }

/* ── Service Cards ──────────────────────────────── */
.service-cards { display: grid; grid-template-columns: 1fr; gap: var(--sp-6); }

/* Mobile: horizontal scroll-snap carousel to reduce vertical scroll */
.service-cards--snap {
    display: flex; gap: var(--sp-4); overflow-x: auto; scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch; padding-bottom: var(--sp-3);
    scrollbar-width: none; /* Firefox */
}
.service-cards--snap::-webkit-scrollbar { display: none; }
.service-cards--snap .service-card {
    flex: 0 0 82%; scroll-snap-align: start; min-width: 260px;
}

.service-card {
    display: flex; flex-direction: column; padding: var(--sp-6);
    background: #fff; border: 1px solid var(--c-border); border-radius: var(--radius-lg);
    border-top: 3px solid var(--c-accent);
    text-decoration: none; color: var(--c-text); transition: all var(--transition);
}
.service-card:hover { box-shadow: var(--shadow-md); border-color: var(--c-accent); border-top-color: var(--c-primary); transform: translateY(-2px); }
.service-card__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 48px; height: 48px; border-radius: var(--radius);
    background: rgba(232,168,56,.12); color: var(--c-accent);
    margin-bottom: var(--sp-3);
}
.service-card__title { font-size: var(--fs-lg); margin-bottom: var(--sp-2); color: var(--c-primary); }
.service-card__desc { font-size: var(--fs-sm); color: #4B5563; flex-grow: 1; line-height: 1.6; }
.service-card__cta {
    display: inline-flex; align-items: center; gap: var(--sp-1);
    font-size: var(--fs-sm); font-weight: 600; color: var(--c-accent);
    margin-top: var(--sp-3); transition: gap var(--transition);
}
.service-card:hover .service-card__cta { gap: var(--sp-2); }

/* ── Why Us Grid ────────────────────────────────── */
.why-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-8); }
.why-item { text-align: center; }
.why-item__icon { color: var(--c-accent); margin-bottom: var(--sp-3); }
.why-item__title { margin-bottom: var(--sp-2); }

/* ── Areas Ribbon ───────────────────────────────── */
.areas-ribbon__list { display: flex; flex-wrap: wrap; gap: var(--sp-3); justify-content: center; }
.area-tag {
    display: inline-block; padding: var(--sp-2) var(--sp-4);
    background: #fff; border: 1px solid var(--c-border); border-radius: 100px;
    font-size: var(--fs-sm); font-weight: 500; color: var(--c-text);
    text-decoration: none; transition: all var(--transition);
}
.area-tag:hover { background: var(--c-primary); color: #fff; border-color: var(--c-primary); }

/* ── FAQ ────────────────────────────────────────── */
.faq-section { padding: var(--sp-16) 0; }
.faq-list { max-width: 800px; }
.faq-item { padding: 0; border-bottom: 1px solid var(--c-border); }
.faq-item__question {
    font-size: var(--fs-lg); color: var(--c-primary); cursor: pointer;
    padding: var(--sp-5) var(--sp-8) var(--sp-5) 0; position: relative;
    list-style: none; font-weight: 600;
}
.faq-item__question::-webkit-details-marker { display: none; }
.faq-item__question::after {
    content: '+'; position: absolute; right: 0; top: 50%; transform: translateY(-50%);
    font-size: var(--fs-2xl); font-weight: 300; color: var(--c-accent);
    transition: transform var(--transition);
}
.faq-item[open] .faq-item__question::after { content: '−'; }
.faq-item__answer { color: var(--c-text); padding: 0 0 var(--sp-5); }

/* ── CTA Banner ─────────────────────────────────── */
.cta-banner {
    background: var(--c-primary); color: #fff; padding: var(--sp-16) 0; text-align: center;
}
.cta-banner__title { color: #fff; margin-bottom: var(--sp-3); }
.cta-banner__text { color: var(--c-footer-text); margin-bottom: var(--sp-6); font-size: var(--fs-lg); }
.cta-banner--compact { padding: var(--sp-10) 0; }

/* ── Content Layout (service pages) ─────────────── */
.content-layout {
    display: flex; flex-direction: column; gap: var(--sp-8);
    padding: var(--sp-8) var(--sp-4);
    max-width: var(--max-width); margin: 0 auto;
}
.content-main { flex: 1; }

/* ── Service Hero ───────────────────────────────── */
.service-hero { margin-bottom: var(--sp-6); }
.service-hero__title { margin-bottom: var(--sp-2); }
.service-hero__subtitle { font-size: var(--fs-lg); color: var(--c-text-light); margin-bottom: var(--sp-4); }
.service-hero__meta { display: flex; flex-wrap: wrap; gap: var(--sp-4); }
.service-image { margin-bottom: var(--sp-6); }
.service-image img { border-radius: var(--radius-lg); width: 100%; }
.service-intro { font-size: var(--fs-lg); margin-bottom: var(--sp-6); border-left: 3px solid var(--c-accent); padding-left: var(--sp-4); }
.inline-cta { margin: var(--sp-8) 0; text-align: center; }

/* ── Breadcrumb ─────────────────────────────────── */
.breadcrumb { padding: var(--sp-4) 0; background: var(--c-bg-alt); }
.breadcrumb__list {
    display: flex; flex-wrap: wrap; gap: var(--sp-1); font-size: var(--fs-sm);
    max-width: var(--max-width); margin: 0 auto; padding: 0 var(--sp-4);
}
.breadcrumb__list li::after { content: " / "; margin: 0 var(--sp-1); color: var(--c-text-light); }
.breadcrumb__list li:last-child::after { content: ""; }
.breadcrumb__list a { color: var(--c-text-light); }
.breadcrumb__list li:last-child { color: var(--c-text); font-weight: 500; }

/* ── Sidebar ────────────────────────────────────── */
.sidebar__card {
    background: #fff; border: 1px solid var(--c-border); border-radius: var(--radius-lg);
    padding: var(--sp-6); margin-bottom: var(--sp-6);
}
.sidebar__title { font-size: var(--fs-base); margin-bottom: var(--sp-4); }
.sidebar__links li { margin-bottom: var(--sp-1); }
.sidebar__link {
    display: flex; align-items: center; gap: var(--sp-2);
    padding: var(--sp-2) var(--sp-3); font-size: var(--fs-sm);
    border-radius: var(--radius); color: var(--c-text); transition: background var(--transition);
}
.sidebar__link:hover { background: var(--c-bg-alt); color: var(--c-accent); }
.sidebar__link--active { background: var(--c-bg-alt); color: var(--c-accent); font-weight: 600; }
.sidebar__view-all { display: block; margin-top: var(--sp-3); font-size: var(--fs-sm); font-weight: 600; color: var(--c-accent); }
.sidebar__cta-card {
    background: var(--c-primary); color: #fff; border-radius: var(--radius-lg);
    padding: var(--sp-6); text-align: center;
}
.sidebar__cta-title { color: #fff; margin-bottom: var(--sp-2); }
.sidebar__cta-text { font-size: var(--fs-sm); color: var(--c-footer-text); margin-bottom: var(--sp-4); }
.sidebar__cta-sub { font-size: var(--fs-xs); color: var(--c-footer-text); margin-top: var(--sp-3); display: flex; align-items: center; justify-content: center; gap: var(--sp-1); }

/* ── Contact ────────────────────────────────────── */
.contact-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-8); }
.form__group { margin-bottom: var(--sp-5); }
.form__label { display: block; font-size: var(--fs-sm); font-weight: 600; margin-bottom: var(--sp-1); color: var(--c-text); }
.form__input, .form__select, .form__textarea {
    width: 100%; padding: var(--sp-3) var(--sp-4);
    font-family: var(--font-family); font-size: var(--fs-base);
    border: 1px solid var(--c-border); border-radius: var(--radius);
    background: #fff; color: var(--c-text); min-height: 48px;
    transition: border-color var(--transition);
}
.form__input:focus, .form__select:focus, .form__textarea:focus {
    outline: none; border-color: var(--c-accent); box-shadow: 0 0 0 3px rgba(232,168,56,.15);
}
.form__input.error { border-color: var(--c-error); }
.form__error { font-size: var(--fs-xs); color: var(--c-error); min-height: 1.25rem; display: block; }
.form__textarea { min-height: 120px; resize: vertical; }
.form__privacy { font-size: var(--fs-xs); color: var(--c-text-light); margin-top: var(--sp-3); }
.form__submit { margin-top: var(--sp-2); }
.contact-info-card {
    background: var(--c-bg-alt); padding: var(--sp-6); border-radius: var(--radius-lg);
    margin-bottom: var(--sp-6);
}
.contact-info p { margin-bottom: var(--sp-3); display: flex; align-items: center; gap: var(--sp-2); }
.contact-info__phone { font-size: var(--fs-xl); font-weight: 700; color: var(--c-accent); }

/* ── Check List ─────────────────────────────────── */
.check-list li {
    display: flex; align-items: flex-start; gap: var(--sp-3);
    margin-bottom: var(--sp-3); font-size: var(--fs-base);
}
.check-list .icon { color: var(--c-success); margin-top: 3px; }

/* ── Footer ─────────────────────────────────────── */
.site-footer { background: var(--c-footer-bg); color: var(--c-footer-text); padding: var(--sp-16) 0 var(--sp-8); }
.footer-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-10); margin-bottom: var(--sp-10); }
.footer-logo { margin-bottom: var(--sp-3); width: 200px; height: 51px; }
.footer-tagline { font-size: var(--fs-sm); margin-bottom: var(--sp-4); }
.footer-nap p { display: flex; align-items: flex-start; gap: var(--sp-2); margin-bottom: var(--sp-3); font-size: var(--fs-sm); }
.footer-nap a { color: var(--c-footer-text); }
.footer-nap a:hover { color: var(--c-accent); }
.footer-heading { font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: 0.05em; color: #fff; margin-bottom: var(--sp-4); }
.footer-links li { margin-bottom: var(--sp-2); }
.footer-links a { color: var(--c-footer-text); font-size: var(--fs-sm); }
.footer-links a:hover { color: var(--c-accent); }
.footer-trust {
    display: flex; flex-wrap: wrap; gap: var(--sp-6); justify-content: center;
    padding: var(--sp-6) 0; border-top: 1px solid rgba(255,255,255,.1);
    border-bottom: 1px solid rgba(255,255,255,.1); margin-bottom: var(--sp-6);
}
.footer-trust__item { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--fs-sm); }
.footer-trust__item .icon { color: var(--c-accent); }
.footer-social { display: flex; justify-content: center; gap: var(--sp-4); margin-bottom: var(--sp-6); }
.footer-social__link { color: var(--c-footer-text); transition: color var(--transition); }
.footer-social__link:hover { color: var(--c-accent); }
.footer-copyright { text-align: center; font-size: var(--fs-xs); color: rgba(255,255,255,.5); }

/* ── 404 Page ───────────────────────────────────── */
.error-page { padding: var(--sp-20) 0; }
.error-page__code { font-size: 6rem; font-weight: 800; color: var(--c-accent); }
.error-page__title { margin-bottom: var(--sp-4); }
.error-page__desc { max-width: 500px; margin: 0 auto var(--sp-8); color: var(--c-text-light); }
.error-page__actions { display: flex; gap: var(--sp-4); justify-content: center; }

/* ── Cities Grid (Service Areas Hub) ─────────────── */
.cities-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-6); }
.city-card {
    display: flex; flex-direction: column; padding: var(--sp-6);
    background: #fff; border: 1px solid var(--c-border); border-radius: var(--radius-lg);
    text-decoration: none; color: var(--c-text); transition: all var(--transition);
}
.city-card:hover { box-shadow: var(--shadow-md); border-color: var(--c-accent); transform: translateY(-2px); }
.city-card__name { font-size: var(--fs-lg); margin-bottom: var(--sp-2); color: var(--c-primary); }
.city-card__cta { font-size: var(--fs-sm); font-weight: 600; color: var(--c-accent); }

/* ============================================================
 * RESPONSIVE BREAKPOINTS — Mobile First
 * ============================================================ */

/* ── Mobile-only fixes (< 768px) ───────────────── */
@media (max-width: 767px) {
    .hero { min-height: auto; padding: 2rem 0 2.5rem; }
    .hero__image { aspect-ratio: 2 / 1; min-height: 200px; contain: layout style; }
    .hero__image img { aspect-ratio: 2 / 1; object-fit: cover; width: 100%; height: auto; }
    .hero__actions .btn { width: 100%; justify-content: center; }
    .site-footer { padding-bottom: calc(var(--sp-16) + 68px); } /* room for sticky CTA */
    .top-bar__hours, .top-bar__trust { display: none; }
    .top-bar__left { flex: 1; }
}

/* ── Tablet (≥768px) ────────────────────────────── */
@media (min-width: 768px) {
    .container { padding: 0 var(--sp-8); }
    .top-bar__hours { display: flex; }
    .top-bar__trust { display: flex; }
    .site-header__mobile-actions { display: none; }
    .site-header__cta { display: inline-flex; }
    .main-nav { display: flex; }

    .hero__inner { flex-direction: row; align-items: center; }
    .hero__content { flex: 1; }
    .hero__image { flex: 1; }
    .hero__actions { flex-direction: row; }

    /* Disable snap carousel on tablet, switch to 2-col grid */
    .service-cards--snap {
        display: grid; grid-template-columns: repeat(2, 1fr);
        overflow-x: visible; scroll-snap-type: none;
    }
    .service-cards--snap .service-card { flex: unset; min-width: unset; }
    .service-cards { grid-template-columns: repeat(2, 1fr); }
    .why-grid { grid-template-columns: repeat(2, 1fr); }
    .contact-grid { grid-template-columns: 1fr 1fr; }
    .footer-grid { grid-template-columns: repeat(2, 1fr); }
    .cities-grid { grid-template-columns: repeat(2, 1fr); }

    .content-layout { flex-direction: row; padding: var(--sp-8) var(--sp-8); }
    .content-main { flex: 1; min-width: 0; }
    .sidebar { width: 300px; flex-shrink: 0; }

    .sticky-cta { display: none; }
}

/* ── Desktop (≥1024px) ──────────────────────────── */
@media (min-width: 1024px) {
    .mobile-toggle { display: none; }

    .service-cards { grid-template-columns: repeat(4, 1fr); }
    .why-grid { grid-template-columns: repeat(4, 1fr); }
    .footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr; }
    .cities-grid { grid-template-columns: repeat(3, 1fr); }

    .sidebar { width: 340px; }
}

/* ── Large Desktop (≥1280px) ────────────────────── */
@media (min-width: 1280px) {
    .container { padding: 0; }
    .content-layout { padding: var(--sp-8) 0; }
}

/* ── Why Us Section ──────────────────────────────── */
.why-us-section { padding: var(--sp-16) 0; }

/* ── Service Areas Index — Content Sections ─────── */
.content-section { padding: var(--sp-12) 0; }
.content-section.section--alt { background: var(--c-bg-alt); }
.content-prose { max-width: 800px; margin: 0 auto var(--sp-6); line-height: 1.75; color: var(--c-text); }
.content-prose p { margin-bottom: var(--sp-4); }

.services-summary-grid { display: grid; gap: var(--sp-4); }
.service-summary-card { background: var(--c-bg); border: 1px solid var(--c-border); border-radius: var(--radius-md); padding: var(--sp-5); }
.service-summary-card h3 { font-size: var(--fs-lg); color: var(--c-primary); margin-bottom: var(--sp-2); }
.service-summary-card p { color: var(--c-text-light); line-height: 1.65; margin: 0; }
.service-summary-card__icon { color: var(--c-accent); margin-bottom: var(--sp-2); }

.county-grid { display: grid; gap: var(--sp-4); margin-top: var(--sp-4); }
.county-card { background: var(--c-bg); border-left: 4px solid var(--c-accent); padding: var(--sp-4) var(--sp-5); border-radius: 0 var(--radius-md) var(--radius-md) 0; }
.county-card h3 { font-size: var(--fs-base); font-weight: 700; color: var(--c-primary); margin-bottom: var(--sp-1); }
.county-card p { color: var(--c-text-light); margin: 0; font-size: var(--fs-sm); line-height: 1.6; }

.response-grid { display: grid; gap: var(--sp-3); margin-top: var(--sp-4); }
.response-item { display: flex; justify-content: space-between; align-items: center; padding: var(--sp-3) var(--sp-4); background: var(--c-bg); border: 1px solid var(--c-border); border-radius: var(--radius-md); }
.response-item strong { color: var(--c-text); }
.response-time { font-weight: 700; color: var(--c-primary); background: rgba(27, 54, 93, 0.08); padding: var(--sp-1) var(--sp-3); border-radius: var(--radius-sm); font-size: var(--fs-sm); }

@media (min-width: 640px) {
    .services-summary-grid { grid-template-columns: 1fr 1fr; }
    .county-grid { grid-template-columns: 1fr 1fr; }
    .response-grid { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1024px) {
    .county-grid { grid-template-columns: 1fr 1fr 1fr; }
}

/* ── Blog Listing ──────────────────────────────── */
.blog-listing { padding: var(--sp-12) 0; }
.blog-listing h1 { margin-bottom: var(--sp-2); }
.blog-subtitle { color: var(--c-text-light); font-size: var(--fs-lg); margin-bottom: var(--sp-8); }
.blog-grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-6); }
.blog-card {
    background: #fff; border: 1px solid var(--c-border); border-radius: var(--radius-lg);
    overflow: hidden; transition: all var(--transition);
}
.blog-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.blog-card__img { width: 100%; height: 200px; object-fit: cover; }
.blog-card-body { padding: var(--sp-5); }
.blog-card-body time { font-size: var(--fs-xs); color: var(--c-text-light); text-transform: uppercase; letter-spacing: 0.05em; }
.blog-card-body h2 { font-size: var(--fs-lg); margin: var(--sp-2) 0; }
.blog-card-body h2 a { color: var(--c-primary); }
.blog-card-body h2 a:hover { color: var(--c-accent); }
.blog-card-body p { font-size: var(--fs-sm); color: #4B5563; margin-bottom: var(--sp-3); }
.read-more { font-size: var(--fs-sm); font-weight: 600; color: var(--c-accent); }
@media (min-width: 640px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .blog-grid { grid-template-columns: repeat(3, 1fr); } }

/* ── Blog Single ───────────────────────────────── */
.blog-single { padding: var(--sp-8) 0; }
.blog-single__header { margin-bottom: var(--sp-6); }
.blog-single__meta { font-size: var(--fs-sm); color: var(--c-text-light); margin-bottom: var(--sp-2); }
.blog-single__title { font-size: var(--fs-4xl); margin-bottom: var(--sp-4); }
.blog-single__featured { width: 100%; max-height: 400px; object-fit: cover; border-radius: var(--radius-lg); margin-bottom: var(--sp-6); }
.blog-single__content { max-width: 800px; }
.blog-single__content h2 { margin: var(--sp-8) 0 var(--sp-4); }
.blog-single__content h3 { margin: var(--sp-6) 0 var(--sp-3); }
.blog-single__content p { margin-bottom: var(--sp-4); line-height: 1.75; }
.blog-single__content img { border-radius: var(--radius); margin: var(--sp-4) 0; }
.blog-single__content ul, .blog-single__content ol { padding-left: var(--sp-6); margin-bottom: var(--sp-4); }
.blog-single__content ul { list-style: disc; }
.blog-single__content ol { list-style: decimal; }
.blog-single__content li { margin-bottom: var(--sp-2); line-height: 1.7; }

/* ── City Page — ETA Badge & Service Cards ─────── */
.city-eta { padding: 20px 0 0; }
.city-eta__bar {
    display: flex; flex-direction: column; gap: 12px;
    background: var(--c-primary); border-radius: var(--radius-lg);
    overflow: hidden;
}
.city-eta__location {
    display: flex; align-items: center; gap: 8px;
    padding: 14px 20px; background: var(--c-primary-dd);
    color: rgba(255,255,255,.85); font-size: var(--fs-sm); font-weight: 500;
}
.city-eta__location svg { color: var(--c-accent); flex-shrink: 0; }
.city-eta__time {
    display: flex; align-items: center; gap: 16px;
    padding: 8px 20px 16px; flex-wrap: wrap;
}
.city-eta__label {
    display: flex; align-items: center; gap: 6px;
    background: var(--c-accent); color: var(--c-primary);
    padding: 10px 16px; border-radius: var(--radius);
    font-size: var(--fs-xs); font-weight: 800; letter-spacing: .05em;
}
.city-eta__value {
    font-size: 2rem; font-weight: 800; color: var(--c-accent);
    line-height: 1;
}
.city-eta__detail {
    font-size: var(--fs-sm); color: rgba(255,255,255,.6);
    line-height: 1.4;
}
.city-services { padding: 16px 0 24px; }
.city-services__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.city-service-card {
    display: flex; flex-direction: column; align-items: center;
    background: var(--c-primary); border-radius: var(--radius-lg);
    padding: 24px 16px; text-decoration: none; text-align: center;
    transition: transform var(--transition), box-shadow var(--transition);
    border: 1px solid rgba(255,255,255,.06);
}
.city-service-card:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,.2); }
.city-service-card__icon { color: var(--c-accent); margin-bottom: 10px; }
.city-service-card__title { color: var(--c-accent); font-size: var(--fs-base); font-weight: 700; margin-bottom: 6px; }
.city-service-card__desc { color: rgba(255,255,255,.6); font-size: var(--fs-xs); margin: 0; line-height: 1.4; }

@media (min-width: 768px) {
    .city-eta__bar { flex-direction: row; align-items: stretch; }
    .city-eta__location { border-radius: 0; }
    .city-eta__time { padding: 12px 20px; }
    .city-services__grid { grid-template-columns: repeat(4, 1fr); }
}

/* ── Print ──────────────────────────────────────── */
@media print {
    .top-bar, .site-header, .sticky-cta, .cta-banner, .sidebar { display: none; }
    .site-footer { background: #fff; color: #000; }
    body { font-size: 12pt; }
}
