    /* ========== HERO ========== */
    .page-hero {
        --hero-bg: url('/assets/images/portfolio/cap-and-trim-style-fence-downtown-wilmington-opt.jpg');
        padding: 8rem 2rem 5rem;
    }

    .page-hero-badge {
        margin-bottom: 1.5rem;
    }

    .page-hero-ctas {
        justify-content: center;
    }

    /* ========== CATEGORY CARDS (Residential / Commercial) ========== */
    .svc-categories {
        padding: 5rem 2rem;
        background: white;
    }

    .svc-categories-container {
        max-width: 1200px;
        margin: 0 auto;
    }

    .svc-cat-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 2rem;
        margin-top: 3rem;
    }

    .svc-cat-card {
        background: var(--cream-100);
        border-radius: var(--radius-sm);
        padding: 2.5rem;
        display: flex;
        flex-direction: column;
        transition: box-shadow 0.2s ease;
        border: 2px solid transparent;
    }

    @media (hover: hover) and (pointer: fine) {
        .svc-cat-card:hover {
            box-shadow: var(--shadow-md);
            border-color: var(--green-200);
        }
    }

    .svc-cat-icon {
        width: 56px;
        height: 56px;
        background: var(--green-700);
        border-radius: var(--radius-sm);
        display: flex;
        align-items: center;
        justify-content: center;
        margin-bottom: 1.25rem;
    }

    .svc-cat-icon svg { width: 28px; height: 28px; color: white; }

    .svc-cat-card h3 {
        font-size: 1.5rem;
        color: var(--green-800);
        margin-bottom: 0.75rem;
    }

    .svc-cat-card p {
        font-size: 1rem;
        color: var(--text-medium);
        line-height: 1.7;
        margin-bottom: 1.5rem;
        flex: 1;
    }

    .svc-cat-link {
        display: inline-flex;
        align-items: center;
        gap: 0.5rem;
        font-family: var(--font-heading);
        font-size: 1rem;
        font-weight: 700;
        color: var(--green-700);
        text-decoration: none;
        text-transform: uppercase;
        transition: gap 0.2s ease;
    }

    .svc-cat-link:hover { gap: 0.75rem; }
    .svc-cat-link svg { width: 18px; height: 18px; }

    /* ========== FENCE TYPE CARDS ========== */
    .svc-types {
        padding: 5rem 2rem;
        background: var(--cream-100);
    }

    .svc-types-container {
        max-width: 1200px;
        margin: 0 auto;
    }

    .svc-types-intro {
        max-width: 700px;
        margin: 0 auto 3rem;
        text-align: center;
    }

    .svc-types-intro p {
        font-size: 1.0625rem;
        color: var(--text-medium);
    }

    .svc-types-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }

    .svc-type-card {
        background: white;
        border-radius: var(--radius-sm);
        overflow: hidden;
        box-shadow: var(--shadow-sm);
        display: flex;
        flex-direction: column;
        transition: box-shadow 0.2s ease, transform 0.2s ease;
        text-decoration: none;
        color: inherit;
    }

    @media (hover: hover) and (pointer: fine) {
        .svc-type-card:hover {
            box-shadow: var(--shadow-lg);
            transform: translateY(-4px);
        }
    }

    .svc-type-image {
        width: 100%;
        aspect-ratio: 3 / 2;
        object-fit: cover;
    }

    .svc-type-content {
        padding: 1.5rem;
        display: flex;
        flex-direction: column;
        flex: 1;
    }

    .svc-type-badge {
        display: inline-flex;
        align-items: center;
        gap: 0.375rem;
        background: var(--cream-100);
        color: var(--green-700);
        padding: 0.25rem 0.625rem;
        border-radius: var(--radius-sm);
        font-family: var(--font-heading);
        font-size: 0.75rem;
        font-weight: 700;
        text-transform: uppercase;
        margin-bottom: 0.75rem;
        width: fit-content;
    }

    .svc-type-content h3 {
        font-size: 1.375rem;
        color: var(--green-800);
        margin-bottom: 0.625rem;
    }

    .svc-type-content p {
        font-size: 0.9375rem;
        color: var(--text-medium);
        line-height: 1.6;
        margin-bottom: 1rem;
        flex: 1;
    }

    .svc-type-content .style-tags {
        margin-bottom: 1rem;
    }

    .svc-type-meta {
        display: flex;
        gap: 1.5rem;
        margin-bottom: 1rem;
        flex-wrap: wrap;
    }

    .svc-type-meta span {
        display: inline-flex;
        align-items: center;
        gap: 0.375rem;
        font-size: 0.8125rem;
        font-weight: 600;
        color: var(--green-700);
    }

    .svc-type-meta svg { width: 14px; height: 14px; }

    .svc-type-link {
        display: inline-flex;
        align-items: center;
        gap: 0.5rem;
        font-family: var(--font-heading);
        font-size: 0.9375rem;
        font-weight: 700;
        color: var(--accent-600);
        text-decoration: none;
        text-transform: uppercase;
        transition: gap 0.2s ease;
    }

    .svc-type-link:hover { gap: 0.75rem; }
    .svc-type-link svg { width: 16px; height: 16px; }

    /* ========== WHY US ========== */
    .svc-why {
        padding: 5rem 2rem;
        background: linear-gradient(135deg, var(--green-800) 0%, var(--green-900) 100%);
        color: white;
        position: relative;
        overflow: hidden;
    }

    .svc-why::before {
        content: '';
        position: absolute;
        inset: 0;
        background: url('/assets/images/hero-wood-fence.jpg') center/cover no-repeat;
        opacity: 0.08;
        pointer-events: none;
    }

    .svc-why::after {
        content: '';
        position: absolute;
        inset: 0;
        background:
            radial-gradient(ellipse 80% 50% at 20% 80%, rgba(174, 219, 91, 0.06) 0%, transparent 70%),
            radial-gradient(ellipse 60% 40% at 85% 20%, rgba(255, 255, 255, 0.03) 0%, transparent 60%);
        pointer-events: none;
    }

    .svc-why-container {
        max-width: 1200px;
        margin: 0 auto;
        position: relative;
        z-index: 1;
    }

    .svc-why h2 { color: white; }

    .svc-why-grid {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 2rem;
        margin-top: 3rem;
    }

    .svc-why-card {
        text-align: center;
        padding: 2rem 1.5rem;
    }

    .svc-why-icon {
        width: 64px;
        height: 64px;
        background: rgba(255,255,255,0.1);
        border-radius: var(--radius-sm);
        display: flex;
        align-items: center;
        justify-content: center;
        margin: 0 auto 1rem;
    }

    .svc-why-icon svg { width: 32px; height: 32px; color: var(--brand-400); }

    .svc-why-card h3 { color: white; font-size: 1.125rem; margin-bottom: 0.5rem; }
    .svc-why-card p { color: var(--green-100); font-size: 0.9375rem; line-height: 1.6; }

    /* ========== CTA ========== */
    .svc-cta {
        padding: 5rem 2rem;
        background: var(--cream-100);
    }

    .svc-cta-container {
        max-width: 800px;
        margin: 0 auto;
        text-align: center;
    }

    .svc-cta h2 {
        font-size: clamp(2rem, 4vw, 2.75rem);
        color: var(--green-900);
        margin-bottom: 1rem;
    }

    .svc-cta p {
        font-size: 1.125rem;
        color: var(--text-medium);
        margin-bottom: 2rem;
        max-width: 600px;
        margin-left: auto;
        margin-right: auto;
    }

    /* ========== SPECIALTY SERVICES ========== */
    .svc-specialty {
        padding: 5rem 2rem;
        background: var(--cream-50, #faf7f0);
    }

    .svc-specialty-container {
        max-width: 1200px;
        margin: 0 auto;
    }

    .svc-specialty-intro {
        max-width: 700px;
        margin: 0 auto 3rem;
        text-align: center;
    }

    .svc-specialty-intro p {
        font-size: 1.0625rem;
        color: var(--text-medium);
    }

    .svc-specialty-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 1.25rem;
    }

    .svc-specialty-card {
        background: white;
        border-radius: var(--radius-sm);
        padding: 1.75rem 1.5rem;
        box-shadow: var(--shadow-sm);
        text-decoration: none;
        color: inherit;
        display: flex;
        flex-direction: column;
        gap: 0.75rem;
        transition: box-shadow 0.2s ease, transform 0.2s ease;
    }

    @media (hover: hover) and (pointer: fine) {
        .svc-specialty-card:hover {
            box-shadow: var(--shadow-md);
            transform: translateY(-2px);
        }
    }

    .svc-specialty-icon {
        width: 44px;
        height: 44px;
        border-radius: 8px;
        background: var(--green-100, #e6efe7);
        color: var(--green-900);
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .svc-specialty-card h3 {
        margin: 0;
        font-size: 1.125rem;
        color: var(--green-900);
    }

    .svc-specialty-card p {
        margin: 0;
        font-size: 0.9375rem;
        color: var(--text-medium);
        line-height: 1.5;
    }

    .svc-specialty-link {
        margin-top: auto;
        font-size: 0.875rem;
        font-weight: 600;
        color: var(--green-900);
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
    }

    /* ========== RESPONSIVE ========== */
    @media (max-width: 1024px) {
        .svc-types-grid { grid-template-columns: repeat(2, 1fr); }
        .svc-why-grid { grid-template-columns: repeat(2, 1fr); }
        .svc-specialty-grid { grid-template-columns: repeat(2, 1fr); }
    }

    @media (max-width: 768px) {
        .page-hero { padding: 6rem 1.5rem 3rem; }
        .svc-cat-grid { grid-template-columns: 1fr; }
        .svc-why-grid { grid-template-columns: 1fr; max-width: 400px; margin-left: auto; margin-right: auto; }
    }

    @media (max-width: 600px) {
        .svc-types-grid { grid-template-columns: 1fr; max-width: 400px; margin: 0 auto; }
        .svc-specialty-grid { grid-template-columns: 1fr; max-width: 400px; margin: 0 auto; }
    }
