/* ============================================
   Heatherdale Automotive - Premium Stylesheet
   Modern automotive design with Barlow + Inter
   ============================================ */

:root {
    --color-primary: #0071CC;
    --color-primary-dark: #005fa3;
    --color-primary-light: #e8f4fd;
    --color-secondary: #1e293b;
    --color-accent: #FFD700;
    --color-accent-dark: #e6c200;
    --color-bg: #ffffff;
    --color-bg-alt: #f8fafc;
    --color-bg-dark: #0f172a;
    --color-text: #334155;
    --color-text-light: #64748b;
    --color-text-white: #ffffff;
    --color-border: #e2e8f0;
    --color-success: #10b981;
    --color-star: #FFD700;
    --font-heading: 'Barlow', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --container-width: 1200px;
    --header-height: 80px;
    --radius: 8px;
    --radius-lg: 16px;
    --radius-xl: 24px;
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
    --shadow: 0 4px 12px rgba(0,0,0,0.08);
    --shadow-lg: 0 12px 32px rgba(0,0,0,0.12);
    --shadow-xl: 0 20px 40px rgba(0,0,0,0.15);
    --transition: 0.3s ease;
    --transition-slow: 0.5s ease;
}

/* 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(--color-text);
    background: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-primary-dark); }

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    color: var(--color-secondary);
    line-height: 1.15;
    font-weight: 700;
    letter-spacing: -0.01em;
}
h1 { font-size: 3rem; font-weight: 900; }
h2 { font-size: 2.25rem; font-weight: 800; }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.25rem; }
p { margin-bottom: 1rem; }

.screen-reader-text {
    clip: rect(1px,1px,1px,1px); clip-path: inset(50%);
    height: 1px; width: 1px; margin: -1px;
    overflow: hidden; padding: 0; position: absolute;
}

.container { max-width: var(--container-width); margin: 0 auto; padding: 0 1.5rem; }

/* Buttons */
.btn {
    display: inline-flex; align-items: center; gap: 0.5rem;
    padding: 0.8rem 1.75rem;
    font-family: var(--font-heading); font-size: 0.875rem; font-weight: 700;
    letter-spacing: 0.05em; text-transform: uppercase;
    border-radius: var(--radius); border: 2px solid transparent;
    cursor: pointer; transition: all var(--transition); text-decoration: none; line-height: 1.4;
}
.btn-lg { padding: 1rem 2.25rem; font-size: 0.9375rem; }

.btn-primary { background: var(--color-primary); color: var(--color-text-white); border-color: var(--color-primary); }
.btn-primary:hover { background: var(--color-primary-dark); border-color: var(--color-primary-dark); color: var(--color-text-white); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,113,204,0.35); }

.btn-accent { background: var(--color-accent); color: var(--color-secondary); border-color: var(--color-accent); font-weight: 800; }
.btn-accent:hover { background: var(--color-accent-dark); border-color: var(--color-accent-dark); color: var(--color-secondary); transform: translateY(-2px); box-shadow: 0 4px 12px rgba(255,215,0,0.4); }

.btn-outline { background: transparent; color: var(--color-primary); border-color: var(--color-primary); }
.btn-outline:hover { background: var(--color-primary); color: var(--color-text-white); transform: translateY(-2px); }

.btn-outline-white { background: transparent; color: var(--color-text-white); border-color: rgba(255,255,255,0.5); }
.btn-outline-white:hover { background: var(--color-text-white); color: var(--color-secondary); border-color: var(--color-text-white); }

/* Top Bar */
.top-bar {
    background: var(--color-primary); color: var(--color-text-white);
    font-size: 0.8125rem; font-family: var(--font-heading);
    letter-spacing: 0.04em; text-transform: uppercase; padding: 0.5rem 0;
}
.top-bar-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 0.5rem; }
.top-bar-left, .top-bar-right { display: flex; align-items: center; gap: 1.5rem; }
.top-bar-item { display: inline-flex; align-items: center; gap: 0.5rem; color: rgba(255,255,255,0.9); transition: color var(--transition); font-weight: 500; }
a.top-bar-item:hover { color: var(--color-accent); }
.top-bar svg { flex-shrink: 0; }

/* Top Bar - Mobile (hidden on desktop, shown at 768px and below) */
.top-bar-mobile { display: none; align-items: center; justify-content: center; gap: 0.4rem; padding: 0.45rem 0.75rem; flex-wrap: nowrap; }
.top-bar-mobile-btn {
    display: inline-flex; align-items: center; gap: 0.25rem;
    background: rgba(255,255,255,0.15); color: #fff;
    padding: 0.3rem 0.6rem; border-radius: 5px;
    font-size: 0.65rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.03em; text-decoration: none; white-space: nowrap;
    transition: background var(--transition);
}
.top-bar-mobile-btn:hover { background: rgba(255,255,255,0.25); color: #fff; }
.top-bar-mobile-btn svg { flex-shrink: 0; width: 13px; height: 13px; }
.top-bar-mobile-hours {
    display: inline-flex; align-items: center; gap: 0.2rem;
    color: rgba(255,255,255,0.7); font-size: 0.6rem;
    font-weight: 500; letter-spacing: 0.02em; white-space: nowrap;
    margin-left: auto;
}
.top-bar-mobile-hours svg { width: 11px; height: 11px; }

/* Header */
.site-header {
    background: rgba(255,255,255,0.97); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(0,0,0,0.06);
    position: sticky; top: 0; z-index: 1000;
    height: var(--header-height); transition: box-shadow var(--transition);
}
.site-header.scrolled { box-shadow: 0 4px 20px rgba(0,0,0,0.08); }
.header-inner { display: flex; align-items: center; justify-content: space-between; height: var(--header-height); }
.site-branding a { display: inline-flex; align-items: center; }
.site-branding img { max-height: 56px; width: auto; height: auto; object-fit: contain; }
.site-title-link { text-decoration: none; }
.site-title { font-family: var(--font-heading); font-size: 1.5rem; font-weight: 800; color: var(--color-secondary); letter-spacing: 0.02em; text-transform: uppercase; }

/* Navigation */
.main-navigation { display: flex; align-items: center; gap: 0.5rem; }
.nav-menu { list-style: none; display: flex; align-items: center; gap: 0; margin: 0; padding: 0; }
.nav-menu li { position: relative; }
.nav-menu li a {
    display: block; padding: 0.5rem 0.875rem; color: var(--color-text);
    font-family: var(--font-heading); font-weight: 600; font-size: 0.8125rem;
    text-transform: uppercase; letter-spacing: 0.06em; transition: color var(--transition);
}
.nav-menu li a:hover, .nav-menu li.current-menu-item > a, .nav-menu li.current_page_item > a { color: var(--color-primary); }

.nav-menu li .sub-menu {
    position: absolute; top: 100%; left: 0; background: var(--color-bg);
    box-shadow: var(--shadow-lg); border-radius: var(--radius); min-width: 220px;
    padding: 0.5rem 0; list-style: none; opacity: 0; visibility: hidden;
    transform: translateY(10px); transition: all var(--transition); z-index: 100;
}
.nav-menu li:hover > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-menu .sub-menu li a { padding: 0.5rem 1.25rem; font-size: 0.8125rem; text-transform: none; letter-spacing: 0; }
.header-cta { margin-left: 1rem; }

/* Hamburger */
.menu-toggle { display: none; background: none; border: none; cursor: pointer; padding: 0.5rem; z-index: 1001; }
.hamburger, .hamburger::before, .hamburger::after { display: block; width: 24px; height: 2px; background: var(--color-secondary); transition: all 0.3s ease; }
.hamburger { position: relative; }
.hamburger::before, .hamburger::after { content: ''; position: absolute; left: 0; }
.hamburger::before { top: -7px; }
.hamburger::after { top: 7px; }
.menu-toggle[aria-expanded="true"] .hamburger { background: transparent; }
.menu-toggle[aria-expanded="true"] .hamburger::before { transform: rotate(45deg); top: 0; }
.menu-toggle[aria-expanded="true"] .hamburger::after { transform: rotate(-45deg); top: 0; }

/* Hero */
.hero {
    position: relative; min-height: 600px; display: flex; align-items: center;
    background-size: cover; background-position: center; background-color: var(--color-secondary); overflow: hidden;
}
.hero::before { content: ''; position: absolute; inset: 0; background: var(--color-secondary); opacity: 0.7; mix-blend-mode: multiply; z-index: 1; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, var(--color-secondary) 0%, transparent 50%, rgba(15,23,42,0.4) 100%); z-index: 2; }
.hero-content { position: relative; z-index: 3; max-width: 720px; padding: 5rem 0; }
.hero-title { font-family: var(--font-heading); font-size: 3.5rem; font-weight: 900; color: var(--color-text-white); margin-bottom: 1rem; line-height: 1.08; letter-spacing: -0.02em; animation: fadeSlideUp 0.7s ease forwards; }
.hero-subtitle { font-size: 1.25rem; color: rgba(255,255,255,0.85); margin-bottom: 2rem; line-height: 1.7; max-width: 540px; animation: fadeSlideUp 0.7s 0.15s ease both; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; animation: fadeSlideUp 0.7s 0.3s ease both; }

@keyframes fadeSlideUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.animate-on-scroll { opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease, transform 0.6s ease; }
.animate-on-scroll.is-visible { opacity: 1; transform: translateY(0); }

/* Trust Badges */
.trust-badges { background: var(--color-bg); border-bottom: 1px solid var(--color-border); padding: 2.5rem 0; }
.trust-badges-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; }
.trust-badge { display: flex; align-items: center; gap: 1rem; padding: 0.5rem 0; }
.trust-badge svg { flex-shrink: 0; color: var(--color-primary); }
.trust-badge strong { display: block; font-family: var(--font-heading); font-size: 0.9375rem; font-weight: 700; color: var(--color-secondary); letter-spacing: 0.02em; }
.trust-badge span { font-size: 0.8125rem; color: var(--color-text-light); }

/* Sections */
.section { padding: 5rem 0; }
.section-header { text-align: center; max-width: 640px; margin: 0 auto 3.5rem; }
.section-title { font-family: var(--font-heading); margin-bottom: 0.75rem; letter-spacing: -0.01em; }
.section-eyebrow { display: block; font-family: var(--font-heading); font-size: 0.8125rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.15em; color: var(--color-primary); margin-bottom: 0.5rem; }
.section-subtitle { color: var(--color-text-light); font-size: 1.0625rem; line-height: 1.7; }
.section-cta { text-align: center; margin-top: 3rem; }

/* Services (home page grid) */
.services-section { background: var(--color-bg-alt); }
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }

.service-card {
    background: var(--color-bg); padding: 2rem; border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm); transition: all var(--transition);
    border: 1px solid var(--color-border); position: relative; overflow: hidden;
}
.service-card::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px; background: var(--color-primary); transform: scaleX(0); transition: transform var(--transition); }
.service-card:hover { box-shadow: var(--shadow-xl); transform: translateY(-4px); }
.service-card:hover::after { transform: scaleX(1); }

.service-icon { width: 56px; height: 56px; display: flex; align-items: center; justify-content: center; background: var(--color-primary-light); border-radius: var(--radius); color: var(--color-primary); margin-bottom: 1.25rem; }

.service-card h3 { font-family: var(--font-heading); font-size: 1.25rem; font-weight: 700; margin-bottom: 0.625rem; transition: color var(--transition); }
.service-card:hover h3 { color: var(--color-primary); }
.service-card p { color: var(--color-text-light); font-size: 0.9375rem; margin-bottom: 0; line-height: 1.7; }

/* ===== Services Page (premium layout) ===== */
.services-banner {
    background: var(--color-secondary); color: #fff; padding: 5rem 0 4rem; text-align: center;
    position: relative; overflow: hidden;
}
.services-banner::before {
    content: ''; position: absolute; inset: 0; opacity: 0.06;
    background-image: 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='1'%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");
}
.services-banner .section-eyebrow { color: var(--color-accent); }
.services-banner-title {
    font-family: var(--font-heading); font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 900; text-transform: uppercase; margin-bottom: 1rem; position: relative;
}
.services-banner-desc { color: rgba(255,255,255,0.7); max-width: 640px; margin: 0 auto; font-size: 1.0625rem; line-height: 1.7; position: relative; }

/* Services quick-links nav */
.services-nav {
    background: #fff; border-bottom: 1px solid var(--color-border);
    position: sticky; top: 0; z-index: 40; box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    overflow-x: auto; -webkit-overflow-scrolling: touch;
}
.services-nav::-webkit-scrollbar { display: none; }
.services-nav-inner {
    display: flex; gap: 1.75rem; padding: 1rem 0; justify-content: center; white-space: nowrap;
}
.services-nav-link {
    font-size: 0.8125rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--color-text-light); display: flex; align-items: center; gap: 0.5rem;
    transition: color var(--transition); text-decoration: none;
}
.services-nav-link:hover { color: var(--color-primary); }
.services-nav-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-accent); flex-shrink: 0; }

/* Services page content */
.services-page-content { padding: 4rem 0; background: var(--color-bg-alt); }

/* Individual service card */
.sp-card {
    display: flex; gap: 3rem; align-items: center;
    margin-bottom: 5rem; scroll-margin-top: 10rem;
}
.sp-card:last-child { margin-bottom: 0; }
.sp-card--reversed { flex-direction: row-reverse; }

/* Image side */
.sp-card__image { flex: 0 0 48%; max-width: 48%; }
.sp-card__image-wrap {
    position: relative; border-radius: 1rem; overflow: hidden;
    box-shadow: 0 20px 40px rgba(0,0,0,0.15);
}
.sp-card__image-wrap img {
    width: 100%; height: 400px; object-fit: cover; display: block;
    transition: transform 0.7s ease;
}
.sp-card__image-wrap:hover img { transform: scale(1.05); }
.sp-card__image-wrap::after {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(0,0,0,0.15), transparent);
    pointer-events: none; transition: opacity 0.5s;
}
.sp-card__image-wrap:hover::after { opacity: 0; }
.sp-card__icon-badge {
    position: absolute; top: 1.25rem; left: 1.25rem;
    background: rgba(0,113,204,0.9); backdrop-filter: blur(8px);
    color: #fff; width: 52px; height: 52px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 0.75rem; box-shadow: 0 8px 20px rgba(0,113,204,0.3);
}
.sp-card__icon-badge svg { width: 24px; height: 24px; }

/* Content side */
.sp-card__content { flex: 1; min-width: 0; }
.sp-card__eyebrow { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1rem; }
.sp-card__badge {
    background: var(--color-accent); color: #1a1a1a; font-size: 0.6875rem;
    font-weight: 900; text-transform: uppercase; letter-spacing: 0.12em;
    padding: 0.3rem 0.75rem; border-radius: 3px; white-space: nowrap;
}
.sp-card__line { flex: 1; height: 1px; background: var(--color-border); }

.sp-card__title {
    font-family: var(--font-heading); font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 900; color: var(--color-secondary); margin-bottom: 0.75rem;
}
.sp-card__desc {
    font-size: 1.0625rem; color: var(--color-text-light); line-height: 1.7;
    margin-bottom: 2rem; font-weight: 500;
}

/* Includes + Benefits columns */
.sp-card__details { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-bottom: 2rem; }
.sp-card__col-title {
    font-family: var(--font-heading); font-size: 0.9375rem; font-weight: 700;
    color: var(--color-secondary); margin-bottom: 1rem;
    display: flex; align-items: center; gap: 0.5rem;
}
.sp-card__col-title svg { color: var(--color-primary); flex-shrink: 0; }
.sp-card__col-title--benefits svg { color: var(--color-accent); }

.sp-card__list { list-style: none; padding: 0; margin: 0; }
.sp-card__list li {
    font-size: 0.875rem; color: var(--color-text-light); padding: 0.35rem 0;
    display: flex; align-items: flex-start; gap: 0.5rem; line-height: 1.5;
}
.sp-card__list--dots li::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: var(--color-border); margin-top: 0.4rem; flex-shrink: 0;
}
.sp-card__list--checks li svg { color: var(--color-accent); flex-shrink: 0; margin-top: 0.1rem; }

/* Action buttons */
.sp-card__actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.btn-outline {
    background: transparent; border: 2px solid var(--color-border);
    color: var(--color-text); font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.05em; transition: all var(--transition);
}
.btn-outline:hover { border-color: var(--color-primary); color: var(--color-primary); background: transparent; }

/* Why Choose Us */
.why-us-section { background: var(--color-bg); }
.why-us-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.why-us-content .section-title { text-align: left; margin-bottom: 1.5rem; }
.why-us-list { list-style: none; padding: 0; margin: 0 0 2rem; }
.why-us-list li { display: flex; align-items: center; gap: 0.875rem; padding: 0.875rem 0; font-size: 1.0625rem; font-weight: 500; border-bottom: 1px solid var(--color-border); }
.why-us-list li:last-child { border-bottom: none; }
.why-us-list svg { flex-shrink: 0; color: var(--color-success); width: 22px; height: 22px; }
.why-us-image { border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-xl); position: relative; }
.why-us-image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); }
.why-us-image:hover img { transform: scale(1.05); }

/* Testimonials */
.testimonials-section { background: var(--color-bg-dark); padding: 5rem 0; }
.testimonials-section .section-title { color: var(--color-text-white); }
.testimonials-section .section-subtitle { color: rgba(255,255,255,0.6); }
.testimonials-section .section-eyebrow { color: var(--color-accent); }
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.testimonials-grid-full { grid-template-columns: repeat(2, 1fr); }

.testimonial-card {
    background: rgba(255,255,255,0.05); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    padding: 2rem; border-radius: var(--radius-lg); border: 1px solid rgba(255,255,255,0.1);
    transition: all var(--transition);
}
.testimonial-card:hover { background: rgba(255,255,255,0.08); transform: translateY(-2px); }

.star-rating { display: flex; gap: 0.125rem; margin-bottom: 1rem; }
.star-filled { color: var(--color-star); }
.star-empty { color: rgba(255,255,255,0.2); }

.testimonial-card blockquote { font-size: 0.9375rem; color: rgba(255,255,255,0.75); line-height: 1.8; margin: 0 0 1.25rem; font-style: italic; }
.testimonial-author { display: flex; align-items: center; gap: 0.75rem; }
.testimonial-avatar { width: 40px; height: 40px; border-radius: 50%; background: linear-gradient(135deg, var(--color-primary), #2563eb); display: flex; align-items: center; justify-content: center; color: white; font-family: var(--font-heading); font-weight: 700; font-size: 0.875rem; flex-shrink: 0; }
.testimonial-author strong { display: block; font-size: 0.9375rem; color: var(--color-text-white); font-family: var(--font-heading); font-weight: 600; }
.testimonial-author span { font-size: 0.8125rem; color: rgba(255,255,255,0.5); }

/* Testimonials on light background pages */
.site-content .testimonial-card { background: var(--color-bg); border: 1px solid var(--color-border); box-shadow: var(--shadow-sm); }
.site-content .testimonial-card:hover { background: var(--color-bg); box-shadow: var(--shadow-lg); }
.site-content .testimonial-card blockquote { color: var(--color-text); }
.site-content .testimonial-author strong { color: var(--color-secondary); }
.site-content .testimonial-author span { color: var(--color-text-light); }
.site-content .star-empty { color: var(--color-border); }
.site-content .testimonial-avatar { background: linear-gradient(135deg, var(--color-primary), #2563eb); }

/* CTA Strip */
.cta-strip { background: var(--color-accent); padding: 3.5rem 0; }
.cta-strip-inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.cta-strip-content h2 { font-family: var(--font-heading); color: var(--color-secondary); margin-bottom: 0.25rem; font-weight: 800; }
.cta-strip-content p { color: rgba(30,41,59,0.8); margin-bottom: 0; }
.cta-strip-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.cta-strip .btn-accent { background: var(--color-secondary); color: var(--color-text-white); border-color: var(--color-secondary); }
.cta-strip .btn-accent:hover { background: var(--color-primary); border-color: var(--color-primary); }
.cta-strip .btn-outline-white { color: var(--color-secondary); border-color: var(--color-secondary); }
.cta-strip .btn-outline-white:hover { background: var(--color-secondary); color: var(--color-text-white); }

/* Page Banner */
.page-banner { background: var(--color-bg-dark); padding: 4rem 0; text-align: center; position: relative; overflow: hidden; }
.page-banner::before { content: ''; position: absolute; top: -50%; right: -10%; width: 400px; height: 400px; border-radius: 50%; background: var(--color-primary); opacity: 0.08; filter: blur(80px); }
.page-banner h1 { font-family: var(--font-heading); color: var(--color-text-white); font-size: 2.75rem; font-weight: 900; margin-bottom: 0.5rem; letter-spacing: -0.01em; position: relative; }
.page-banner-subtitle { color: rgba(255,255,255,0.65); font-size: 1.125rem; position: relative; }
.breadcrumbs { font-size: 0.875rem; color: rgba(255,255,255,0.5); margin-top: 0.75rem; position: relative; }
.breadcrumbs a { color: rgba(255,255,255,0.7); }
.breadcrumbs a:hover { color: var(--color-accent); }
.post-meta-banner { color: rgba(255,255,255,0.5); font-size: 0.875rem; margin-top: 0.5rem; }
.post-meta-banner a { color: rgba(255,255,255,0.7); }

/* Site Content */
.site-content { padding: 4rem 0; }
.page-content { max-width: 800px; }
.fullwidth-content { max-width: 100%; }
.entry-content { font-size: 1.0625rem; line-height: 1.8; }
.entry-content h2 { margin-top: 2.5rem; margin-bottom: 1rem; }
.entry-content h3 { margin-top: 2rem; margin-bottom: 0.75rem; }
.entry-content ul, .entry-content ol { margin: 1rem 0; padding-left: 1.5rem; }
.entry-content li { margin-bottom: 0.5rem; }
.entry-content img { border-radius: var(--radius); margin: 1.5rem 0; }
.page-featured-image { margin-bottom: 2rem; border-radius: var(--radius-lg); overflow: hidden; }
.page-intro { max-width: 800px; margin: 0 auto 3rem; text-align: center; font-size: 1.125rem; color: var(--color-text-light); line-height: 1.8; }

/* About */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.about-text { font-size: 1.0625rem; line-height: 1.8; }
.about-image { border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-xl); position: relative; }
.about-image img { transition: transform var(--transition-slow); }
.about-image:hover img { transform: scale(1.05); }
.values-section { padding-top: 4rem; }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.value-card { text-align: center; padding: 2.5rem 2rem; background: var(--color-bg); border-radius: var(--radius-lg); border: 1px solid var(--color-border); transition: all var(--transition); position: relative; overflow: hidden; }
.value-card::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 4px; background: var(--color-primary); }
.value-card:nth-child(2)::after { background: var(--color-accent); }
.value-card:nth-child(3)::after { background: var(--color-secondary); }
.value-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.value-card svg { color: var(--color-primary); margin-bottom: 1rem; }
.value-card h3 { font-family: var(--font-heading); margin-bottom: 0.5rem; font-weight: 700; }
.value-card p { color: var(--color-text-light); font-size: 0.9375rem; margin-bottom: 0; line-height: 1.7; }

/* Gallery */
.gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1rem; }
.gallery-item { display: block; border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/3; position: relative; }
.gallery-item::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.4), transparent); opacity: 0; transition: opacity var(--transition); }
.gallery-item:hover::after { opacity: 1; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.gallery-item:hover img { transform: scale(1.1); }
.no-gallery, .no-testimonials { text-align: center; padding: 3rem; color: var(--color-text-light); font-size: 1.125rem; }

/* Blog */
.blog-layout { display: grid; grid-template-columns: 1fr 300px; gap: 3rem; }
.posts-grid { display: grid; gap: 2rem; }
.post-card { background: var(--color-bg); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); border: 1px solid var(--color-border); transition: all var(--transition); }
.post-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.post-card-image { display: block; overflow: hidden; }
.post-card-image img { width: 100%; height: 220px; object-fit: cover; transition: transform var(--transition-slow); }
.post-card:hover .post-card-image img { transform: scale(1.08); }
.post-card-content { padding: 1.5rem; }
.post-card-meta { font-size: 0.8125rem; color: var(--color-text-light); margin-bottom: 0.5rem; }
.post-card-meta a { color: var(--color-text-light); }
.meta-sep { margin: 0 0.5rem; }
.post-card-title { font-size: 1.25rem; margin-bottom: 0.5rem; }
.post-card-title a { color: var(--color-secondary); }
.post-card-title a:hover { color: var(--color-primary); }
.post-card-excerpt { color: var(--color-text-light); font-size: 0.9375rem; margin-bottom: 1rem; line-height: 1.7; }
.read-more { font-family: var(--font-heading); font-weight: 700; font-size: 0.8125rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-primary); display: inline-flex; align-items: center; gap: 0.375rem; transition: gap var(--transition); }
.read-more:hover { gap: 0.625rem; }

.single-post .post-featured-image { margin-bottom: 2rem; border-radius: var(--radius-lg); overflow: hidden; }
.post-tags { margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--color-border); font-size: 0.875rem; color: var(--color-text-light); }
.tags-label { font-weight: 600; }
.post-navigation { display: flex; justify-content: space-between; margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--color-border); }
.post-navigation a { font-size: 0.9375rem; font-weight: 500; }

/* Sidebar */
.blog-sidebar { align-self: start; position: sticky; top: calc(var(--header-height) + 2rem); }
.widget { background: var(--color-bg-alt); padding: 1.5rem; border-radius: var(--radius-lg); margin-bottom: 1.5rem; border: 1px solid var(--color-border); }
.widget-title { font-family: var(--font-heading); font-size: 1.125rem; font-weight: 700; margin-bottom: 1rem; padding-bottom: 0.75rem; border-bottom: 3px solid var(--color-primary); }
.widget ul { list-style: none; padding: 0; }
.widget ul li { padding: 0.375rem 0; border-bottom: 1px solid var(--color-border); }
.widget ul li:last-child { border-bottom: none; }
.widget ul li a { color: var(--color-text); font-size: 0.9375rem; }
.widget ul li a:hover { color: var(--color-primary); }

/* Pagination */
.pagination { margin-top: 2rem; }
.pagination .nav-links { display: flex; gap: 0.5rem; justify-content: center; }
.pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: var(--radius); font-family: var(--font-heading); font-weight: 600; color: var(--color-text); background: var(--color-bg-alt); border: 1px solid var(--color-border); transition: all var(--transition); }
.pagination .page-numbers.current { background: var(--color-primary); color: var(--color-text-white); border-color: var(--color-primary); }
.pagination .page-numbers:hover:not(.current) { background: var(--color-border); }

/* Comments */
.comments-area { margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--color-border); }
.comments-title { margin-bottom: 1.5rem; }
.comment-list { list-style: none; padding: 0; }
.comment-list .comment { padding: 1.5rem 0; border-bottom: 1px solid var(--color-border); }
.comment-author img { border-radius: 50%; float: left; margin-right: 1rem; }

/* Contact */
.contact-grid { display: grid; grid-template-columns: 1fr 380px; gap: 3rem; margin-bottom: 3rem; }
.contact-form-wrapper { background: var(--color-bg); padding: 2.5rem; border-radius: var(--radius-lg); border: 1px solid var(--color-border); box-shadow: var(--shadow-sm); }
.contact-form-wrapper h2 { font-family: var(--font-heading); margin-bottom: 0.5rem; padding-bottom: 0; border-bottom: none; font-size: 1.75rem; color: var(--color-secondary); }
.contact-form-subtitle { color: var(--color-text-light); font-size: 0.9375rem; margin-bottom: 1.25rem; line-height: 1.6; }

/* Contact Form Trust Badges */
.contact-form-wrapper .trust-badges { display: flex; flex-wrap: wrap; gap: 1rem; margin-bottom: 2rem; padding: 1rem 1.25rem; background: var(--color-primary-light); border-radius: var(--radius); border-left: 4px solid var(--color-primary); }
.contact-form-wrapper .trust-badge { display: flex; align-items: center; gap: 0.5rem; font-size: 0.8125rem; font-weight: 600; color: var(--color-secondary); font-family: var(--font-heading); white-space: nowrap; }
.contact-form-wrapper .trust-badge svg { color: var(--color-primary); flex-shrink: 0; }
.contact-form-wrapper .trust-badge:nth-child(3) svg { color: var(--color-accent); }

/* Lead Form Layout */
.lead-form { margin-top: 0.5rem; }
.lead-form-row { margin-bottom: 1rem; }
.lead-form-row--2col { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.lead-form-field label {
    display: block; font-family: var(--font-heading); font-weight: 600; margin-bottom: 0.375rem;
    font-size: 0.8125rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--color-text-light);
}
.lead-form-submit { padding-top: 0.5rem; }

/* CF7 Form Inputs */
.wpcf7 input[type="text"], .wpcf7 input[type="email"], .wpcf7 input[type="tel"], .wpcf7 input[type="date"], .wpcf7 textarea, .wpcf7 select {
    width: 100%; padding: 0.875rem 1rem; border: 1px solid var(--color-border); border-radius: var(--radius);
    font-family: var(--font-body); font-size: 0.9375rem; transition: all var(--transition); background: var(--color-bg-alt);
}
.wpcf7 input:focus, .wpcf7 textarea:focus, .wpcf7 select:focus { outline: none; border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(0,113,204,0.12); background: var(--color-bg); }
.wpcf7 textarea { min-height: 120px; resize: vertical; }
.wpcf7 select { cursor: pointer; -webkit-appearance: none; -moz-appearance: none; appearance: none; 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='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.5rem; }

/* Service dropdown highlight */
.lead-form-field--full .wpcf7-form-control-wrap[data-name="ServiceType"] select,
.wpcf7 select[name="ServiceType"] {
    font-weight: 600; font-size: 1rem; padding: 1rem; border: 2px solid var(--color-primary); background-color: rgba(0,113,204,0.03);
}
.wpcf7 select[name="ServiceType"]:focus { border-color: var(--color-primary); box-shadow: 0 0 0 4px rgba(0,113,204,0.15); }

/* Submit Button */
.wpcf7-submit { background: var(--color-accent) !important; color: var(--color-secondary) !important; border: none !important; padding: 1rem 3rem !important; font-family: var(--font-heading) !important; font-weight: 700 !important; font-size: 1rem !important; text-transform: uppercase !important; letter-spacing: 0.06em !important; border-radius: var(--radius) !important; cursor: pointer; transition: all var(--transition) !important; width: 100% !important; }
.wpcf7-submit:hover { background: var(--color-accent-dark) !important; transform: translateY(-2px) !important; box-shadow: 0 4px 16px rgba(255,215,0,0.4) !important; }
.wpcf7 p { margin-bottom: 0; }
.wpcf7 .wpcf7-response-output { margin: 1rem 0 0 !important; padding: 1rem !important; border-radius: var(--radius) !important; font-size: 0.9375rem; }

/* What Happens Next Card */
.next-steps-card { background: var(--color-bg); border: 1px solid var(--color-border); padding: 2rem; border-radius: var(--radius-lg); margin-top: 1.5rem; }
.next-steps-card h3 { font-family: var(--font-heading); font-size: 1.125rem; font-weight: 700; color: var(--color-secondary); margin-bottom: 1.5rem; padding-bottom: 0.75rem; border-bottom: 3px solid var(--color-accent); }
.next-steps { display: flex; flex-direction: column; gap: 1.25rem; }
.next-step { display: flex; gap: 1rem; align-items: flex-start; }
.next-step-number {
    flex-shrink: 0; width: 32px; height: 32px; border-radius: 50%;
    background: var(--color-primary); color: #fff; display: flex; align-items: center; justify-content: center;
    font-family: var(--font-heading); font-weight: 800; font-size: 0.875rem;
}
.next-step strong { display: block; font-family: var(--font-heading); font-size: 0.9375rem; font-weight: 700; color: var(--color-secondary); margin-bottom: 0.125rem; }
.next-step p { font-size: 0.8125rem; color: var(--color-text-light); margin: 0; line-height: 1.5; }

.contact-info-card { background: var(--color-bg-dark); padding: 2rem; border-radius: var(--radius-lg); color: rgba(255,255,255,0.85); }
.contact-info-card h3 { color: var(--color-text-white); font-family: var(--font-heading); margin-bottom: 1.5rem; padding-bottom: 1rem; border-bottom: 3px solid var(--color-primary); font-size: 1.25rem; }

/* Action Buttons - Call Now / Send Email */
.contact-action-buttons { display: flex; flex-direction: column; gap: 0.75rem; margin-bottom: 1.5rem; }
.contact-action-btn {
    display: flex; align-items: center; gap: 0.875rem; padding: 1rem 1.25rem;
    border-radius: var(--radius); text-decoration: none; transition: all var(--transition);
    border: 2px solid transparent;
}
.contact-action-btn:hover { transform: translateY(-2px); }
.contact-action-btn svg { flex-shrink: 0; }
.contact-action-btn__text { display: flex; flex-direction: column; }
.contact-action-btn__text strong {
    font-family: var(--font-heading); font-size: 1rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.04em;
}
.contact-action-btn__text small { font-size: 0.8125rem; opacity: 0.8; margin-top: 0.125rem; }

/* Call Now - Green */
.contact-action-btn--call {
    background: #059669; color: #fff; border-color: #059669;
}
.contact-action-btn--call:hover {
    background: #047857; border-color: #047857; color: #fff;
    box-shadow: 0 4px 16px rgba(5,150,105,0.4);
}

/* Send Email - Blue */
.contact-action-btn--email {
    background: transparent; color: rgba(255,255,255,0.9);
    border-color: rgba(255,255,255,0.25);
}
.contact-action-btn--email:hover {
    background: var(--color-primary); border-color: var(--color-primary); color: #fff;
    box-shadow: 0 4px 16px rgba(0,113,204,0.3);
}

.contact-divider { border: none; border-top: 1px solid rgba(255,255,255,0.1); margin: 0 0 1.5rem; }

.contact-detail { display: flex; gap: 1rem; margin-bottom: 1.75rem; align-items: flex-start; }
.contact-detail:last-child { margin-bottom: 0; }
.contact-detail svg { flex-shrink: 0; color: var(--color-accent); margin-top: 0.125rem; }
.contact-detail strong { display: block; font-family: var(--font-heading); font-size: 0.75rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: rgba(255,255,255,0.5); margin-bottom: 0.25rem; }
.contact-detail p { margin-bottom: 0; font-size: 0.9375rem; }
.contact-detail a { color: rgba(255,255,255,0.85); }
.contact-detail a:hover { color: var(--color-accent); }
.contact-directions-link { display: inline-block; margin-top: 0.375rem; font-size: 0.8125rem; font-weight: 600; color: var(--color-accent) !important; }
.contact-hours-note { font-size: 0.8125rem; color: rgba(255,255,255,0.4); margin-top: 0.25rem; }

.contact-map { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); filter: grayscale(0.3); transition: filter var(--transition); }
.contact-map:hover { filter: grayscale(0); }
.contact-map iframe { display: block; }

/* Contact Map Section */
.contact-map-section { padding: 0 0 0; }
.contact-map-heading {
    font-family: var(--font-heading); font-size: 1.75rem; font-weight: 800;
    display: flex; align-items: center; gap: 0.625rem;
    margin-bottom: 1.5rem; color: var(--color-secondary);
}
.contact-map-heading svg { color: var(--color-primary); flex-shrink: 0; }
.contact-map-wrap {
    border-radius: var(--radius-lg); overflow: hidden;
    box-shadow: var(--shadow-lg); margin-bottom: 0;
}
.contact-map-wrap iframe { display: block; width: 100%; }

/* 404 */
.error-404-content { text-align: center; padding: 5rem 0; }
.error-code { font-family: var(--font-heading); font-size: 10rem; font-weight: 900; background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; line-height: 1; margin-bottom: 1rem; }
.error-404-content p { font-size: 1.125rem; color: var(--color-text-light); margin-bottom: 2rem; }
.error-actions { display: flex; gap: 1rem; justify-content: center; }

/* Footer */
.site-footer { background: var(--color-bg-dark); color: rgba(255,255,255,0.7); padding-top: 4rem; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1.5fr; gap: 3rem; padding-bottom: 3rem; }
.footer-grid--4col { grid-template-columns: 1.4fr 0.8fr 1.1fr 1.1fr; gap: 2rem; }
.footer-logo { margin-bottom: 1rem; }
.footer-logo a { display: inline-block; }
.footer-logo img { max-height: 48px; width: auto; max-width: 200px; height: auto; object-fit: contain; }
.footer-brand { font-family: var(--font-heading); color: var(--color-text-white); font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 1rem; }
.footer-about { font-size: 0.9375rem; line-height: 1.7; margin-bottom: 1.5rem; }
.footer-social { display: flex; gap: 0.75rem; }
.social-link { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.7); transition: all var(--transition); }
.social-link:hover { background: var(--color-accent); color: var(--color-secondary); transform: translateY(-2px); }

.footer-col h4 { font-family: var(--font-heading); color: var(--color-text-white); font-size: 1rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 1.25rem; padding-bottom: 0.75rem; border-bottom: 2px solid var(--color-primary); }
.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: 0.625rem; }
.footer-links li a { color: rgba(255,255,255,0.6); font-size: 0.9375rem; transition: all var(--transition); }
.footer-links li a:hover { color: var(--color-accent); padding-left: 4px; }

.footer-contact { list-style: none; padding: 0; margin: 0; }
.footer-contact li { display: flex; align-items: flex-start; gap: 0.75rem; margin-bottom: 1rem; font-size: 0.9375rem; }
.footer-contact svg { flex-shrink: 0; color: var(--color-accent); margin-top: 0.2rem; }
.footer-contact a { color: rgba(255,255,255,0.7); }
.footer-contact a:hover { color: var(--color-accent); }

.footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); padding: 1.25rem 0; }
.footer-bottom-inner { text-align: center; font-size: 0.8125rem; color: rgba(255,255,255,0.35); }


/* No Results */
.no-results { text-align: center; padding: 4rem 2rem; }
.no-results h2 { margin-bottom: 1rem; }
.no-results p { color: var(--color-text-light); margin-bottom: 2rem; }

/* WP Core */
.wp-caption { max-width: 100%; }
.wp-caption-text { font-size: 0.8125rem; color: var(--color-text-light); text-align: center; margin-top: 0.5rem; }
.alignleft { float: left; margin: 0 1.5rem 1rem 0; }
.alignright { float: right; margin: 0 0 1rem 1.5rem; }
.aligncenter { display: block; margin: 1.5rem auto; }

/* Google Reviews Section */
.google-reviews-section { background: var(--color-bg-dark); padding: 5rem 0; }
.google-reviews-section .section-title { color: var(--color-text-white); }
.google-reviews-section .section-subtitle { color: rgba(255,255,255,0.6); }
.google-reviews-section .section-eyebrow { color: var(--color-accent); }
.google-reviews-section .testimonials-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }

/* Google Rating Badge */
.google-rating-badge { margin-bottom: 3rem; }
.google-rating-badge-inner {
    display: flex; align-items: center; gap: 1.5rem;
    background: rgba(255,255,255,0.06); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.1);
    padding: 1.25rem 2rem; border-radius: var(--radius-lg);
    justify-content: center; flex-wrap: wrap;
}
.google-rating-badge-page .google-rating-badge-inner {
    background: var(--color-bg); border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg); backdrop-filter: none;
}
.google-rating-badge-page { margin-bottom: 2rem; }
.google-g-icon { flex-shrink: 0; }
.google-rating-info { display: flex; flex-direction: column; gap: 0.125rem; }
.google-rating-score { display: flex; align-items: center; gap: 0.5rem; }
.google-rating-number { font-family: var(--font-heading); font-size: 2rem; font-weight: 900; color: var(--color-text-white); line-height: 1; }
.google-rating-badge-page .google-rating-number { color: var(--color-secondary); }
.google-rating-count { font-size: 0.8125rem; color: rgba(255,255,255,0.5); }
.google-rating-badge-page .google-rating-count { color: var(--color-text-light); }
.star-rating-lg svg { width: 22px; height: 22px; }
.google-review-btn { white-space: nowrap; margin-left: auto; }

/* Google Review Card */
.google-review-card { position: relative; }
.google-review-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0; }
.google-review-header .star-rating { margin-bottom: 0; }
.google-g-icon-sm { flex-shrink: 0; opacity: 0.6; }
.google-source-label { display: inline-flex; align-items: center; gap: 0.25rem; font-size: 0.75rem; color: rgba(255,255,255,0.4); }
.site-content .google-source-label { color: var(--color-text-light); }

/* Top Bar Badge */
.top-bar-badge { color: var(--color-accent) !important; font-weight: 700 !important; }

/* Footer Map (Column 4 - Find Us) */
.footer-map-compact { margin-top: 0.5rem; line-height: 0; border-radius: 8px; overflow: hidden; }
.footer-map-compact iframe { width: 100%; display: block; border-radius: 8px; }
.footer-directions-link {
    display: inline-flex; align-items: center; gap: 0.5rem;
    margin-top: 0.75rem; font-size: 0.875rem; font-weight: 600;
    color: var(--color-accent); transition: all var(--transition);
}
.footer-directions-link:hover { color: #fff; gap: 0.65rem; }
.footer-directions-link svg { flex-shrink: 0; }

/* Full-width Gallery */
.gallery-fullwidth { padding: 0 0 4rem; }
.gallery-grid-full {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 6px;
}
.gallery-item-full {
    display: block; overflow: hidden; position: relative;
    aspect-ratio: 1/1;
}
.gallery-item-full img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 0.5s ease;
}
.gallery-item-full:hover img { transform: scale(1.08); }
.gallery-item-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(0,113,204,0.6), rgba(0,0,0,0.2));
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transition: opacity var(--transition);
    color: white;
}
.gallery-item-full:hover .gallery-item-overlay { opacity: 1; }

/* Make some gallery items span 2 cols/rows for masonry effect */
.gallery-item-full:nth-child(1) { grid-column: span 2; grid-row: span 2; aspect-ratio: auto; }
.gallery-item-full:nth-child(5) { grid-column: span 2; aspect-ratio: 2/1; }
.gallery-item-full:nth-child(8) { grid-column: span 2; grid-row: span 2; aspect-ratio: auto; }

/* Responsive */
@media (max-width: 1024px) {
    .trust-badges-grid { grid-template-columns: repeat(2, 1fr); }
    .services-grid { grid-template-columns: repeat(2, 1fr); }
    .why-us-grid { grid-template-columns: 1fr; gap: 2rem; }
    .why-us-image { order: -1; }
    .about-grid { grid-template-columns: 1fr; gap: 2rem; }
    .footer-grid, .footer-grid--4col { grid-template-columns: 1fr 1fr; }
    .contact-grid { grid-template-columns: 1fr; }
    .contact-info-sidebar { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
    .testimonials-grid { grid-template-columns: repeat(2, 1fr); }
    .google-reviews-section .testimonials-grid { grid-template-columns: repeat(2, 1fr); }
    .gallery-grid-full { grid-template-columns: repeat(3, 1fr); }
    .gallery-item-full:nth-child(8) { grid-column: span 1; grid-row: span 1; aspect-ratio: 1/1; }
    .sp-card { gap: 2rem; }
    .sp-card__image { flex: 0 0 45%; max-width: 45%; }
    .sp-card__image-wrap img { height: 320px; }
    .sp-card__details { gap: 1.5rem; }
}

@media (max-width: 768px) {
    h1 { font-size: 2.25rem; }
    h2 { font-size: 1.75rem; }
    .top-bar-inner { display: none; }
    .top-bar-mobile { display: flex; }
    .menu-toggle { display: block; }
    .main-navigation { position: fixed; top: 0; right: -100%; width: 85%; max-width: 340px; height: 100vh; background: var(--color-bg); flex-direction: column; align-items: stretch; padding: 5rem 1.5rem 2rem; box-shadow: -8px 0 30px rgba(0,0,0,0.15); transition: right 0.3s ease; overflow-y: auto; z-index: 1000; }
    .main-navigation.is-open { right: 0; }
    .nav-menu { flex-direction: column; }
    .nav-menu li a { padding: 0.875rem 0; font-size: 1rem; border-bottom: 1px solid var(--color-border); }
    .nav-menu li .sub-menu { position: static; box-shadow: none; opacity: 1; visibility: visible; transform: none; padding-left: 1rem; }
    .header-cta { margin-left: 0; margin-top: 1.5rem; text-align: center; }
    .hero { min-height: 450px; }
    .hero-title { font-size: 2.5rem; }
    .hero-subtitle { font-size: 1.0625rem; }
    .trust-badges-grid { grid-template-columns: 1fr 1fr; gap: 1.25rem; }
    .services-grid, .services-grid-full { grid-template-columns: 1fr; }
    .testimonials-grid, .testimonials-grid-full { grid-template-columns: 1fr; }
    .values-grid { grid-template-columns: 1fr; }
    .cta-strip-inner { flex-direction: column; text-align: center; }
    .cta-strip-actions { justify-content: center; }
    .blog-layout { grid-template-columns: 1fr; }
    .footer-grid, .footer-grid--4col { grid-template-columns: 1fr; gap: 2rem; }
    .section { padding: 3.5rem 0; }
    .site-content { padding: 2.5rem 0; }
    .service-card-detailed { flex-direction: column; }
    .service-card-detailed .service-thumbnail { width: 100%; }
    .error-code { font-size: 6rem; }
    .error-actions { flex-direction: column; align-items: center; }
    .site-footer { padding-bottom: 1rem; }
    .contact-form-wrapper { padding: 1.5rem; }
    .lead-form-row--2col { grid-template-columns: 1fr; }
    .contact-form-wrapper .trust-badges { flex-direction: column; gap: 0.5rem; }
    .contact-info-sidebar { display: block; }
    .next-steps-card { margin-top: 1.5rem; }
    .google-reviews-section .testimonials-grid { grid-template-columns: 1fr; }
    .google-rating-badge-inner { flex-direction: column; text-align: center; gap: 1rem; }
    .google-review-btn { margin-left: 0; }
    .gallery-grid-full { grid-template-columns: repeat(2, 1fr); }
    .sp-card, .sp-card--reversed { flex-direction: column; }
    .sp-card__image { flex: none; max-width: 100%; width: 100%; }
    .sp-card__image-wrap img { height: 260px; }
    .sp-card__details { grid-template-columns: 1fr; gap: 1.5rem; }
    .sp-card { margin-bottom: 3.5rem; gap: 1.5rem; }
    .services-nav-inner { justify-content: flex-start; padding-left: 1rem; padding-right: 1rem; }
    .services-banner { padding: 3rem 0 2.5rem; }
    .sp-card__actions { flex-direction: column; }
    .sp-card__actions .btn { text-align: center; }
    .gallery-item-full:nth-child(1) { grid-column: span 2; grid-row: span 1; aspect-ratio: 2/1; }
    .gallery-item-full:nth-child(5) { grid-column: span 1; aspect-ratio: 1/1; }
    .gallery-item-full:nth-child(8) { grid-column: span 1; grid-row: span 1; }
    .top-bar-badge { display: none !important; }
}

@media (max-width: 480px) {
    h1 { font-size: 1.875rem; }
    .hero-title { font-size: 2rem; }
    .hero-content { padding: 3rem 0; }
    .hero-actions { flex-direction: column; }
    .hero-actions .btn { width: 100%; justify-content: center; }
    .page-banner h1 { font-size: 1.875rem; }
    .container { padding: 0 1rem; }
    .trust-badges-grid { grid-template-columns: 1fr; }
}
