.allpave-home {
        --ap-blue: var(--site-blue);
        --ap-blue-deep: var(--site-blue-deep);
        --ap-gold: #ffd300;
        --ap-gold-strong: #ffbf00;
        --ap-ink: #0a102a;
        --ap-text: #e8edf8;
        --ap-muted: rgba(232, 237, 248, 0.78);
        --ap-panel: rgba(10, 16, 42, 0.76);
        --ap-panel-border: rgba(255, 255, 255, 0.12);
        --ap-light-panel: rgba(255, 255, 255, 0.92);
        --ap-light-border: rgba(15, 23, 42, 0.08);
        --ap-shadow: 0 24px 80px rgba(10, 16, 42, 0.24);
        --ap-radius-xl: 34px;
        --ap-radius-lg: 24px;
        --ap-radius-md: 18px;
        background:
            radial-gradient(circle at top left, rgba(255, 211, 0, 0.12), transparent 28%),
            linear-gradient(180deg, #f6f8fe 0%, #f4f5f8 100%);
        color: #122033;
        font-family: "Manrope", sans-serif;
    }

    .allpave-home section {
        position: relative;
    }

    .allpave-shell {
        width: min(1320px, calc(100% - 2rem));
        margin: 0 auto;
    }

    .allpave-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: 0.55rem;
        padding: 0.7rem 1rem;
        border-radius: 999px;
        background: rgba(255, 211, 0, 0.16);
        border: 1px solid rgba(255, 211, 0, 0.28);
        color: #fff1a1;
        font-size: 0.82rem;
        font-weight: 800;
        letter-spacing: 0.12em;
        text-transform: uppercase;
    }

    .allpave-hero {
        overflow: hidden;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
        background: #08112f;
    }

    .allpave-hero-media,
    .allpave-hero-overlay {
        position: absolute;
        inset: 0;
    }

    .allpave-hero-media {
        background:
            linear-gradient(90deg, rgba(8, 17, 47, 0.88) 0%, rgba(8, 17, 47, 0.70) 44%, rgba(8, 17, 47, 0.5) 100%),
            linear-gradient(180deg, rgba(255, 211, 0, 0.08), transparent 40%),
            url("/images/all-pave/JPEG/All Pave Block Paving  (23).jpg") center/cover no-repeat;
        filter: saturate(1.02);
    }

    .allpave-hero-overlay {
        background:
            radial-gradient(circle at top right, rgba(255, 211, 0, 0.18), transparent 24%),
            radial-gradient(circle at bottom left, rgba(31, 33, 156, 0.24), transparent 34%);
    }

    .allpave-hero-grid {
        position: relative;
        z-index: 1;
        display: grid;
        grid-template-columns: minmax(0, 0.95fr) minmax(540px, 660px);
        gap: 1.5rem;
        align-items: start;
        width: min(1440px, calc(100% - 2rem));
        margin: 0 auto;
        padding: 4.5rem 0 4rem;
    }

    .allpave-hero-form-panel {
        align-self: start;
        margin-top: 0.5rem;
    }

    .allpave-hero-copy {
        max-width: 760px;
        color: var(--ap-text);
    }

    .allpave-hero-copy h1 {
        margin: 1rem 0 1.25rem;
        max-width: 10.6ch;
        color: #ffffff;
        font-family: "Oswald", sans-serif;
        font-size: clamp(3.2rem, 6.8vw, 6.6rem);
        line-height: 0.93;
        letter-spacing: 0.01em;
        text-transform: uppercase;
    }

    .allpave-hero-copy p {
        margin: 0;
        color: var(--ap-muted);
        font-size: 1.08rem;
        line-height: 1.82;
        max-width: 63ch;
    }

    .allpave-hero-actions,
    .allpave-inline-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 0.9rem;
        margin-top: 2rem;
    }

    .allpave-btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        padding: 0.95rem 1.4rem;
        font-weight: 800;
        font-size: 0.98rem;
        transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease;
    }

    .allpave-btn:hover {
        transform: translateY(-1px);
    }

    .allpave-btn-primary {
        background: linear-gradient(135deg, var(--ap-gold), var(--ap-gold-strong));
        color: var(--ap-blue-deep);
        box-shadow: 0 16px 40px rgba(255, 211, 0, 0.24);
    }

    .allpave-home-form-submit {
        width: 100%;
        margin-top: 1rem;
    }

    .allpave-btn-secondary {
        background: rgba(255, 255, 255, 0.12);
        color: #fff;
        border: 1px solid rgba(255, 255, 255, 0.16);
    }

    .allpave-trust-row {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 1rem;
        margin-top: 2rem;
    }

    .allpave-trust-card,
    .allpave-panel,
    .allpave-service-card,
    .allpave-stat-card,
    .allpave-gallery-card,
    .allpave-process-card,
    .allpave-coverage-card {
        border-radius: var(--ap-radius-lg);
        box-shadow: var(--ap-shadow);
    }

    .allpave-trust-card {
        padding: 1.2rem 1.1rem;
        background: rgba(255, 255, 255, 0.06);
        border: 1px solid rgba(255, 255, 255, 0.1);
        backdrop-filter: blur(8px);
        color: #fff;
    }

    .allpave-trust-card strong {
        display: block;
        color: #ffe56c;
        font-size: 0.95rem;
        margin-bottom: 0.45rem;
    }

    .allpave-contact-strip {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 1rem;
        margin-top: 1.2rem;
    }

    .allpave-contact-card {
        border-radius: var(--ap-radius-md);
        padding: 1rem 1.05rem;
        background: rgba(255, 255, 255, 0.05);
        border: 1px solid rgba(255, 255, 255, 0.1);
        color: rgba(255, 255, 255, 0.92);
    }

    .allpave-contact-card span {
        display: block;
        font-size: 0.76rem;
        font-weight: 800;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        color: rgba(255, 229, 108, 0.92);
        margin-bottom: 0.4rem;
    }

    .allpave-panel {
        padding: 1.6rem;
        background: var(--ap-panel);
        border: 1px solid var(--ap-panel-border);
        color: #fff;
        backdrop-filter: blur(14px);
    }

    .allpave-panel h2,
    .allpave-section-title,
    .allpave-form-heading,
    .allpave-service-card h3,
    .allpave-process-card h3,
    .allpave-gallery-card h3 {
        font-family: "Oswald", sans-serif;
        letter-spacing: 0.02em;
        text-transform: uppercase;
    }

    .allpave-form-heading {
        margin: 0 0 0.75rem;
        font-size: 2.25rem;
        text-align: center;
    }

    .allpave-form-copy {
        margin: 0 0 1.5rem;
        text-align: center;
        color: rgba(255, 255, 255, 0.78);
        line-height: 1.7;
    }

    .allpave-form-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1rem;
    }

    .allpave-form-grid .field.full {
        grid-column: 1 / -1;
    }

    .allpave-home .neo-label {
        display: block;
        margin-bottom: 0.45rem;
        font-size: 0.9rem;
        font-weight: 700;
        color: rgba(255, 255, 255, 0.98);
    }

    .allpave-home .neo-input,
    .allpave-home .neo-select,
    .allpave-home .neo-textarea {
        width: 100%;
        border-radius: 16px;
        border: 1px solid rgba(255, 255, 255, 0.16);
        background: rgba(255, 255, 255, 0.96);
        color: #0f172a;
        padding: 0.92rem 1rem;
        font: inherit;
    }

    .allpave-home .neo-textarea {
        min-height: 150px;
        resize: vertical;
    }

    .allpave-home .neo-checkbox-row {
        display: flex;
        align-items: flex-start;
        gap: 0.8rem;
        padding: 0.95rem 1rem;
        border-radius: 16px;
        border: 1px solid rgba(255, 255, 255, 0.16);
        background: rgba(255, 255, 255, 0.96);
        color: #334155;
        line-height: 1.6;
    }

    .allpave-home .neo-checkbox {
        margin-top: 0.25rem;
        width: 1rem;
        height: 1rem;
        flex: 0 0 auto;
    }

    .allpave-home .neo-checkbox-copy {
        display: grid;
        gap: 0.2rem;
        color: #475569;
    }

    .allpave-home .neo-checkbox-copy strong {
        color: #0f172a;
        font-size: 0.94rem;
        font-weight: 700;
        line-height: 1.45;
    }

    .allpave-home .help,
    .allpave-home .neo-errors,
    .allpave-home .neo-alert {
        font-size: 0.9rem;
    }

    .allpave-home .help {
        color: rgba(255, 255, 255, 0.88);
        font-weight: 600;
        line-height: 1.55;
        text-shadow: 0 1px 2px rgba(0, 0, 0, 0.32);
    }

    .allpave-home .neo-errors,
    .allpave-home .neo-alert {
        margin-bottom: 1rem;
        border-radius: 16px;
        padding: 0.95rem 1rem;
    }

    .allpave-home .neo-errors {
        background: rgba(127, 29, 29, 0.35);
        border: 1px solid rgba(248, 113, 113, 0.35);
    }

    .allpave-home .neo-alert {
        position: relative;
        overflow: hidden;
        padding: 1.15rem 1.2rem 1.15rem 4.2rem;
        border: 1px solid rgba(185, 255, 218, 0.5);
        background:
            radial-gradient(circle at 16% 18%, rgba(255, 255, 255, 0.42), transparent 24%),
            linear-gradient(135deg, #00b67a 0%, #25d366 58%, #0fbf7a 100%);
        color: #052417;
        text-align: left !important;
        box-shadow:
            0 22px 58px rgba(0, 182, 122, 0.28),
            0 1px 0 rgba(255, 255, 255, 0.35) inset;
    }

    .allpave-home .neo-alert::before {
        content: "\2713";
        position: absolute;
        left: 1.1rem;
        top: 50%;
        display: inline-flex;
        width: 2.25rem;
        height: 2.25rem;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.92);
        color: #00a36c;
        font-weight: 900;
        transform: translateY(-50%);
        box-shadow: 0 12px 26px rgba(5, 36, 23, 0.18);
    }

    .allpave-home .neo-alert strong {
        color: #052417;
        font-weight: 900;
    }

    .allpave-home .neo-alert a {
        color: #062315;
        font-weight: 900;
        text-decoration: underline;
        text-decoration-color: rgba(6, 35, 21, 0.42);
        text-underline-offset: 3px;
    }

    .allpave-home .hp {
        position: absolute;
        left: -9999px;
        width: 1px;
        height: 1px;
        overflow: hidden;
    }

    .allpave-section {
        padding: 5.5rem 0;
    }

    .allpave-work-section,
    .allpave-journey-section,
    .allpave-price-section,
    .allpave-coverage-section,
    .allpave-reviews-section {
        overflow: hidden;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
        padding-left: calc(50vw - 50%);
        padding-right: calc(50vw - 50%);
    }

    .allpave-work-section {
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(238, 242, 247, 0.92) 100%);
        box-shadow: inset 0 28px 48px rgba(10, 16, 42, 0.06);
    }

    .allpave-work-section::before,
    .allpave-price-section::before,
    .allpave-coverage-section::before {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(10, 16, 42, 0.16), transparent);
    }

    .allpave-journey-section {
        background:
            linear-gradient(180deg, #eef2f7 0%, #f8fafc 100%);
    }

    .allpave-price-section {
        background:
            linear-gradient(180deg, #f8fafc 0%, #e9eef7 100%);
    }

    .allpave-coverage-section {
        background:
            linear-gradient(145deg, rgba(9, 18, 47, 0.98), rgba(31, 33, 156, 0.94));
        color: #fff;
        box-shadow: inset 0 38px 72px rgba(0, 0, 0, 0.22);
    }

    .allpave-coverage-section .allpave-section-title {
        color: #fff;
    }

    .allpave-coverage-section .allpave-section-copy {
        color: rgba(255, 255, 255, 0.78);
    }

    .allpave-section-header {
        max-width: 760px;
        margin-bottom: 2rem;
    }

    .allpave-section-title {
        margin: 0 0 0.9rem;
        font-size: clamp(2.3rem, 4vw, 3.6rem);
        line-height: 1;
        color: #09122f;
    }

    .allpave-section-copy {
        margin: 0;
        color: #475569;
        line-height: 1.86;
        font-size: 1.02rem;
    }

    .allpave-stats-grid,
    .allpave-services-grid,
    .allpave-gallery-grid,
    .allpave-process-grid,
    .allpave-coverage-grid {
        display: grid;
        gap: 1.2rem;
    }

    .allpave-stats-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .allpave-stat-card,
    .allpave-service-card,
    .allpave-gallery-card,
    .allpave-process-card,
    .allpave-coverage-card {
        padding: 1.45rem;
        background: var(--ap-light-panel);
        border: 1px solid var(--ap-light-border);
    }

    .allpave-stat-card strong {
        display: block;
        font-size: clamp(2rem, 4vw, 3rem);
        color: var(--ap-blue);
        line-height: 1;
    }

    .allpave-stat-card span {
        display: block;
        margin-top: 0.6rem;
        color: #475569;
        line-height: 1.65;
    }

    .allpave-services-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .allpave-service-card h3,
    .allpave-gallery-card h3,
    .allpave-process-card h3,
    .allpave-coverage-card h3 {
        margin: 0 0 0.7rem;
        font-size: 1.45rem;
        color: #09122f;
    }

    .allpave-service-card p,
    .allpave-gallery-card p,
    .allpave-process-card p,
    .allpave-coverage-card p {
        margin: 0;
        color: #475569;
        line-height: 1.78;
    }

    .allpave-service-card a,
    .allpave-coverage-card a {
        display: inline-flex;
        align-items: center;
        margin-top: 1rem;
        color: var(--ap-blue);
        font-weight: 800;
    }

    .allpave-proof-band {
        background: linear-gradient(135deg, var(--ap-blue-deep), var(--ap-blue));
        color: #fff;
    }

    .allpave-proof-band .allpave-section-title {
        color: #fff;
    }

    .allpave-proof-band .allpave-section-copy {
        color: rgba(255, 255, 255, 0.82);
    }

    .allpave-proof-grid {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
        gap: 1.4rem;
        align-items: center;
    }

    .allpave-proof-list {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1rem;
        margin-top: 1.5rem;
    }

    .allpave-proof-item {
        padding: 1rem 1.05rem;
        border-radius: var(--ap-radius-md);
        background: rgba(255, 255, 255, 0.08);
        border: 1px solid rgba(255, 255, 255, 0.12);
    }

    .allpave-proof-item strong {
        display: block;
        margin-bottom: 0.45rem;
        color: #ffe56c;
    }

    .allpave-review-card {
        padding: 1.6rem;
        border-radius: var(--ap-radius-xl);
        background: rgba(255, 255, 255, 0.1);
        border: 1px solid rgba(255, 255, 255, 0.14);
        backdrop-filter: blur(10px);
    }

    .allpave-review-card blockquote {
        margin: 0 0 1.2rem;
        font-size: 1.06rem;
        line-height: 1.85;
        color: rgba(255, 255, 255, 0.9);
    }

    .allpave-reviews-section {
        background:
            radial-gradient(circle at 14% 12%, rgba(255, 211, 0, 0.22), transparent 28%),
            radial-gradient(circle at 86% 6%, rgba(31, 33, 156, 0.18), transparent 32%),
            linear-gradient(180deg, #eef5ff 0%, #dce8f7 48%, #eef4fb 100%);
        box-shadow:
            inset 0 34px 72px rgba(10, 16, 42, 0.08),
            inset 0 -34px 76px rgba(10, 16, 42, 0.08);
    }

    .allpave-reviews-section::before {
        content: "";
        position: absolute;
        inset: 0;
        background:
            repeating-linear-gradient(90deg, rgba(10, 16, 42, 0.045) 0 1px, transparent 1px 88px),
            repeating-linear-gradient(0deg, rgba(10, 16, 42, 0.035) 0 1px, transparent 1px 88px);
        pointer-events: none;
        opacity: 0.55;
    }

    .allpave-reviews-section .allpave-shell {
        position: relative;
        z-index: 1;
    }

    .allpave-reviews-header {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 1.4rem;
        align-items: end;
    }

    .allpave-google-pill {
        display: inline-flex;
        align-items: center;
        gap: 0.65rem;
        width: fit-content;
        padding: 0.55rem 0.85rem 0.55rem 0.55rem;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.86);
        border: 1px solid rgba(15, 23, 42, 0.08);
        color: #1f2937;
        font-size: 0.84rem;
        font-weight: 900;
        letter-spacing: 0.05em;
        text-transform: uppercase;
        box-shadow:
            0 18px 48px rgba(10, 16, 42, 0.12),
            0 1px 0 rgba(255, 255, 255, 0.9) inset;
    }

    .allpave-google-mark,
    .allpave-google-badge {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        font-weight: 900;
        font-family: "Manrope", sans-serif;
    }

    .allpave-google-mark {
        width: 2.1rem;
        height: 2.1rem;
        background: conic-gradient(from -20deg, #4285f4 0 26%, #34a853 26% 48%, #fbbc05 48% 72%, #ea4335 72% 100%);
        color: #fff;
        font-size: 1.1rem;
        box-shadow: 0 10px 24px rgba(66, 133, 244, 0.28);
    }

    .allpave-google-badge {
        width: 2rem;
        height: 2rem;
        background: #fff;
        color: #4285f4;
        border: 1px solid rgba(15, 23, 42, 0.08);
        box-shadow: 0 10px 22px rgba(10, 16, 42, 0.08);
    }

    .allpave-reviews-summary {
        max-width: 320px;
        padding: 1rem 1.1rem;
        border-radius: var(--ap-radius-md);
        background: linear-gradient(180deg, rgba(9, 18, 47, 0.94), rgba(31, 33, 156, 0.86));
        border: 1px solid rgba(255, 255, 255, 0.14);
        color: #fff;
        box-shadow: 0 24px 62px rgba(10, 16, 42, 0.24);
    }

    .allpave-reviews-score {
        display: flex;
        align-items: center;
        gap: 0.6rem;
        color: #ffe56c;
        font-weight: 900;
        letter-spacing: 0.08em;
    }

    .allpave-reviews-summary p {
        margin: 0.55rem 0 0;
        color: rgba(255, 255, 255, 0.76);
        line-height: 1.65;
        font-size: 0.92rem;
    }

    .allpave-review-marquee {
        position: relative;
        z-index: 1;
        width: 100vw;
        margin-top: 2rem;
        margin-left: calc(50% - 50vw);
        overflow: hidden;
        padding: 1.25rem 0 2.25rem;
        cursor: grab;
        mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
        touch-action: pan-y;
        user-select: none;
    }

    .allpave-review-track {
        --allpave-review-slide-duration: 370s;
        display: flex;
        width: max-content;
        gap: 1rem;
        padding: 0 1rem;
        animation: allpaveReviewsSlide var(--allpave-review-slide-duration) linear infinite;
        will-change: transform;
    }

    .allpave-review-marquee.is-dragging {
        cursor: grabbing;
    }

    .allpave-review-marquee.is-dragging .allpave-review-track {
        animation-play-state: paused;
    }

    .allpave-google-review-card {
        position: relative;
        display: flex;
        flex: 0 0 360px;
        min-height: 330px;
        flex-direction: column;
        padding: 1.25rem;
        border-radius: 22px;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 251, 255, 0.96) 100%);
        border: 1px solid rgba(15, 23, 42, 0.09);
        box-shadow:
            0 30px 82px rgba(10, 16, 42, 0.18),
            0 1px 0 rgba(255, 255, 255, 0.95) inset;
    }

    .allpave-google-review-card::before {
        content: "";
        position: absolute;
        left: 1.25rem;
        right: 1.25rem;
        top: 0;
        height: 5px;
        border-radius: 0 0 999px 999px;
        background: linear-gradient(90deg, #4285f4, #34a853, #fbbc05, #ea4335);
    }

    .allpave-google-review-top {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 1rem;
        padding-top: 0.5rem;
    }

    .allpave-review-author {
        display: flex;
        min-width: 0;
        align-items: center;
        gap: 0.75rem;
    }

    .allpave-review-avatar {
        display: inline-flex;
        width: 2.75rem;
        height: 2.75rem;
        flex: 0 0 2.75rem;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        background: linear-gradient(135deg, var(--ap-blue-deep), var(--ap-blue));
        color: #fff;
        font-weight: 900;
        box-shadow: 0 14px 28px rgba(31, 33, 156, 0.22);
    }

    .allpave-review-name {
        display: block;
        overflow: hidden;
        color: #0f172a;
        font-weight: 900;
        white-space: nowrap;
        text-overflow: ellipsis;
    }

    .allpave-review-date {
        display: block;
        margin-top: 0.2rem;
        color: #64748b;
        font-size: 0.86rem;
        font-weight: 700;
    }

    .allpave-review-stars {
        margin-top: 1rem;
        color: #fbbc05;
        font-size: 1.1rem;
        letter-spacing: 0.08em;
        text-shadow: 0 8px 20px rgba(251, 188, 5, 0.2);
    }

    .allpave-google-review-card blockquote {
        margin: 1rem 0 1.2rem;
        color: #334155;
        font-size: 0.98rem;
        line-height: 1.75;
    }

    .allpave-review-footer {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        margin-top: auto;
        padding-top: 1rem;
        border-top: 1px solid rgba(15, 23, 42, 0.08);
        color: #64748b;
        font-size: 0.82rem;
        font-weight: 800;
    }

    .allpave-review-link {
        color: var(--ap-blue);
        font-weight: 900;
    }

    @keyframes allpaveReviewsSlide {
        from {
            transform: translateX(0);
        }

        to {
            transform: translateX(-50%);
        }
    }

    .allpave-gallery-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        align-items: stretch;
    }

    .allpave-gallery-card {
        position: relative;
        overflow: hidden;
        padding: 0;
        background: #fff;
        border: 1px solid rgba(15, 23, 42, 0.08);
        box-shadow:
            0 30px 80px rgba(10, 16, 42, 0.18),
            0 2px 0 rgba(255, 255, 255, 0.72) inset;
        transform: translateZ(0);
        transition: transform 180ms ease, box-shadow 180ms ease;
    }

    .allpave-gallery-card:hover {
        transform: translateY(-4px);
        box-shadow:
            0 38px 96px rgba(10, 16, 42, 0.24),
            0 2px 0 rgba(255, 255, 255, 0.74) inset;
    }

    .allpave-gallery-card:first-child {
        grid-column: span 2;
    }

    .allpave-gallery-media {
        position: relative;
        overflow: hidden;
        min-height: 230px;
        background: #09122f;
    }

    .allpave-gallery-card:first-child .allpave-gallery-media {
        min-height: 315px;
    }

    .allpave-gallery-media::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg, rgba(9, 18, 47, 0), rgba(9, 18, 47, 0.22));
        box-shadow: inset 0 -26px 42px rgba(10, 16, 42, 0.3);
    }

    .allpave-gallery-card img {
        width: 100%;
        height: 100%;
        min-height: inherit;
        object-fit: cover;
        transition: transform 260ms ease;
    }

    .allpave-gallery-card:hover img {
        transform: scale(1.045);
    }

    .allpave-gallery-body {
        position: relative;
        padding: 1.35rem 1.45rem 1.5rem;
        background:
            linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    }

    .allpave-gallery-body::before {
        content: "";
        position: absolute;
        left: 1.45rem;
        right: 1.45rem;
        top: 0;
        height: 4px;
        border-radius: 999px;
        background: linear-gradient(90deg, var(--ap-gold), var(--ap-blue));
    }

    .allpave-process-grid {
        position: relative;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        align-items: start;
        gap: 1.35rem;
    }

    .allpave-process-grid::before {
        content: "";
        position: absolute;
        left: 8%;
        right: 8%;
        top: 3.1rem;
        height: 6px;
        border-radius: 999px;
        background: linear-gradient(90deg, rgba(255, 211, 0, 0.9), rgba(31, 33, 156, 0.38));
        box-shadow: 0 16px 34px rgba(31, 33, 156, 0.2);
    }

    .allpave-process-card {
        position: relative;
        min-height: 280px;
        padding: 1.6rem;
        background:
            linear-gradient(180deg, #ffffff 0%, #f6f8fc 100%);
        border: 1px solid rgba(15, 23, 42, 0.09);
        box-shadow:
            0 24px 70px rgba(10, 16, 42, 0.14),
            0 1px 0 rgba(255, 255, 255, 0.9) inset;
    }

    .allpave-process-card:nth-child(2) {
        margin-top: 2rem;
    }

    .allpave-process-card:nth-child(3) {
        margin-top: 4rem;
    }

    .allpave-process-card strong {
        display: inline-flex;
        width: 58px;
        height: 58px;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        background: linear-gradient(135deg, var(--ap-gold), var(--ap-gold-strong));
        color: var(--ap-blue-deep);
        box-shadow: 0 18px 36px rgba(255, 191, 0, 0.28);
        font-size: 1.12rem;
        font-weight: 800;
        margin-bottom: 1.1rem;
    }

    .allpave-coverage-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
        align-items: stretch;
    }

    .allpave-coverage-card {
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.07));
        border: 1px solid rgba(255, 255, 255, 0.14);
        box-shadow:
            0 28px 80px rgba(0, 0, 0, 0.26),
            0 1px 0 rgba(255, 255, 255, 0.15) inset;
        color: #fff;
        backdrop-filter: blur(10px);
    }

    .allpave-coverage-card h3 {
        color: #fff;
    }

    .allpave-coverage-card p {
        color: rgba(255, 255, 255, 0.76);
    }

    .allpave-coverage-card ul {
        margin: 0.85rem 0 0;
        padding: 0;
        list-style: none;
        display: grid;
        gap: 0.45rem;
        color: rgba(255, 255, 255, 0.88);
    }

    .allpave-coverage-card li {
        position: relative;
        padding-left: 1rem;
    }

    .allpave-coverage-card li::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0.68em;
        width: 6px;
        height: 6px;
        border-radius: 999px;
        background: var(--ap-gold);
        box-shadow: 0 0 0 4px rgba(255, 211, 0, 0.12);
    }

    .allpave-cta-band {
        position: relative;
        overflow: hidden;
        padding: 4rem 0;
        background:
            linear-gradient(90deg, rgba(9, 18, 47, 0.94), rgba(31, 33, 156, 0.84)),
            url("/images/all-pave/JPEG/All Pave Block Paving  (23).jpg") center/cover no-repeat;
        color: #fff;
        box-shadow: inset 0 32px 70px rgba(0, 0, 0, 0.24);
    }

    .allpave-cta-band::before {
        content: "";
        position: absolute;
        inset: 0;
        background:
            linear-gradient(180deg, rgba(255, 211, 0, 0.12), transparent 42%),
            repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.04) 0 1px, transparent 1px 86px);
        pointer-events: none;
    }

    .allpave-cta-wrap {
        position: relative;
        z-index: 1;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1.5rem;
        flex-wrap: wrap;
    }

    .allpave-cta-wrap h2 {
        margin: 0 0 0.8rem;
        font-size: clamp(2rem, 3vw, 3rem);
        font-family: "Oswald", sans-serif;
        text-transform: uppercase;
        line-height: 1;
    }

    .allpave-cta-wrap p {
        margin: 0;
        max-width: 60ch;
        color: rgba(255, 255, 255, 0.82);
        line-height: 1.8;
    }

    .allpave-finish-layout,
    .allpave-layer-grid,
    .allpave-price-grid {
        display: grid;
        gap: 1.2rem;
    }

    .allpave-finish-layout {
        grid-template-columns: minmax(420px, 0.95fr) minmax(0, 1.05fr);
        align-items: stretch;
    }

    .allpave-finish-feature {
        min-height: 620px;
        position: relative;
        overflow: hidden;
        border-radius: var(--ap-radius-xl);
        box-shadow: var(--ap-shadow);
        background: #09122f;
    }

    .allpave-finish-feature img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .allpave-finish-feature::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg, rgba(9, 18, 47, 0.08), rgba(9, 18, 47, 0.78));
    }

    .allpave-finish-caption {
        position: absolute;
        left: 1.4rem;
        right: 1.4rem;
        bottom: 1.4rem;
        z-index: 1;
        color: #fff;
    }

    .allpave-finish-caption strong {
        display: block;
        margin-bottom: 0.5rem;
        color: #ffe56c;
        font-size: 0.82rem;
        font-weight: 900;
        letter-spacing: 0.14em;
        text-transform: uppercase;
    }

    .allpave-finish-caption h2 {
        margin: 0;
        max-width: 12ch;
        font-family: "Oswald", sans-serif;
        font-size: clamp(2.6rem, 5vw, 5rem);
        line-height: 0.95;
        text-transform: uppercase;
    }

    .allpave-finish-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1rem;
    }

    .allpave-finish-card {
        min-height: 230px;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        overflow: hidden;
        position: relative;
        border-radius: var(--ap-radius-lg);
        padding: 1.15rem;
        background: #09122f;
        color: #fff;
        box-shadow: 0 18px 48px rgba(10, 16, 42, 0.16);
    }

    .allpave-finish-card img {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        opacity: 0.72;
        transition: transform 220ms ease, opacity 220ms ease;
    }

    .allpave-finish-card:hover img {
        transform: scale(1.04);
        opacity: 0.86;
    }

    .allpave-finish-card::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(180deg, rgba(9, 18, 47, 0.04), rgba(9, 18, 47, 0.86));
    }

    .allpave-finish-card-content {
        position: relative;
        z-index: 1;
    }

    .allpave-finish-card h3 {
        margin: 0 0 0.45rem;
        color: #fff;
        font-family: "Oswald", sans-serif;
        font-size: 1.55rem;
        line-height: 1;
        text-transform: uppercase;
    }

    .allpave-finish-card p {
        margin: 0;
        color: rgba(255, 255, 255, 0.82);
        line-height: 1.62;
        font-size: 0.92rem;
    }

    .allpave-layer-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .allpave-layer-card,
    .allpave-price-card {
        position: relative;
        overflow: hidden;
        padding: 1.45rem;
        border-radius: var(--ap-radius-lg);
        background: rgba(255, 255, 255, 0.94);
        border: 1px solid var(--ap-light-border);
        box-shadow: var(--ap-shadow);
    }

    .allpave-layer-card::before {
        content: "";
        display: block;
        width: 100%;
        height: 9px;
        margin-bottom: 1.1rem;
        border-radius: 999px;
        background: repeating-linear-gradient(90deg, rgba(255, 211, 0, 0.95) 0 24px, rgba(31, 33, 156, 0.95) 24px 48px);
    }

    .allpave-layer-card span,
    .allpave-price-card span {
        display: inline-flex;
        margin-bottom: 0.8rem;
        color: var(--ap-blue);
        font-size: 0.8rem;
        font-weight: 900;
        letter-spacing: 0.14em;
        text-transform: uppercase;
    }

    .allpave-layer-card h3,
    .allpave-price-card h3 {
        margin: 0 0 0.65rem;
        color: #09122f;
        font-family: "Oswald", sans-serif;
        font-size: 1.45rem;
        line-height: 1;
        text-transform: uppercase;
    }

    .allpave-layer-card p,
    .allpave-price-card p {
        margin: 0;
        color: #475569;
        line-height: 1.75;
    }

    .allpave-price-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .allpave-price-card {
        min-height: 290px;
        background:
            linear-gradient(180deg, #ffffff 0%, #f8fafc 72%, #eef3fb 100%);
        box-shadow:
            0 30px 80px rgba(10, 16, 42, 0.17),
            0 1px 0 rgba(255, 255, 255, 0.9) inset;
    }

    .allpave-price-card::before {
        content: "";
        position: absolute;
        left: 1.45rem;
        right: 1.45rem;
        top: 1.15rem;
        height: 8px;
        border-radius: 999px;
        background: linear-gradient(90deg, var(--ap-gold), rgba(31, 33, 156, 0.34));
        box-shadow: 0 14px 28px rgba(255, 191, 0, 0.18);
    }

    .allpave-price-card span {
        margin-top: 1.25rem;
    }

    .allpave-work-section,
    .allpave-journey-section,
    .allpave-price-section,
    .allpave-coverage-section,
    .allpave-reviews-section {
        padding-top: 4.6rem;
        padding-bottom: 4.6rem;
    }

    .allpave-work-section {
        background:
            linear-gradient(180deg, rgba(6, 12, 31, 0.96), rgba(12, 22, 47, 0.96)),
            url("/images/all-pave/JPEG/All Pave Block Paving  (23).jpg") center/cover no-repeat;
        box-shadow:
            inset 0 42px 80px rgba(0, 0, 0, 0.34),
            inset 0 -42px 80px rgba(0, 0, 0, 0.28);
    }

    .allpave-work-section::after,
    .allpave-journey-section::after,
    .allpave-price-section::after {
        content: "";
        position: absolute;
        inset: 0;
        background:
            repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.035) 0 1px, transparent 1px 82px),
            repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.026) 0 1px, transparent 1px 82px);
        pointer-events: none;
        opacity: 0.72;
    }

    .allpave-work-section .allpave-shell,
    .allpave-journey-section .allpave-shell,
    .allpave-price-section .allpave-shell {
        position: relative;
        z-index: 1;
    }

    .allpave-work-section .allpave-section-header,
    .allpave-journey-section .allpave-section-header,
    .allpave-price-section .allpave-section-header {
        max-width: 900px;
        margin-bottom: 1.35rem;
    }

    .allpave-work-section .allpave-section-title,
    .allpave-journey-section .allpave-section-title,
    .allpave-price-section .allpave-section-title {
        color: #fff;
        text-shadow: 0 16px 42px rgba(0, 0, 0, 0.42);
    }

    .allpave-work-section .allpave-section-copy,
    .allpave-journey-section .allpave-section-copy,
    .allpave-price-section .allpave-section-copy {
        color: rgba(255, 255, 255, 0.78);
    }

    .allpave-gallery-grid {
        grid-template-columns: repeat(12, minmax(0, 1fr));
        grid-auto-rows: minmax(240px, 20vw);
        gap: 0.9rem;
    }

    .allpave-gallery-card,
    .allpave-gallery-card:first-child {
        grid-column: auto;
        grid-row: auto;
    }

    .allpave-gallery-card {
        min-height: 0;
        border-radius: 18px;
        background: #07112d;
        border: 1px solid rgba(255, 255, 255, 0.13);
        box-shadow:
            0 34px 90px rgba(0, 0, 0, 0.38),
            0 1px 0 rgba(255, 255, 255, 0.16) inset;
    }

    .allpave-gallery-card:first-child {
        grid-column: 1 / span 6;
        grid-row: 1 / span 2;
    }

    .allpave-gallery-card:nth-child(2) {
        grid-column: 7 / span 6;
        grid-row: 1;
    }

    .allpave-gallery-card:nth-child(3) {
        grid-column: 7 / span 3;
        grid-row: 2;
    }

    .allpave-gallery-card:nth-child(4) {
        grid-column: 10 / span 3;
        grid-row: 2;
    }

    .allpave-gallery-card:hover {
        transform: translateY(-3px);
        box-shadow:
            0 44px 110px rgba(0, 0, 0, 0.44),
            0 1px 0 rgba(255, 255, 255, 0.18) inset;
    }

    .allpave-gallery-media,
    .allpave-gallery-card:first-child .allpave-gallery-media {
        position: absolute;
        inset: 0;
        min-height: 0;
        height: 100%;
    }

    .allpave-gallery-media::after {
        background:
            linear-gradient(180deg, rgba(7, 17, 45, 0.04) 0%, rgba(7, 17, 45, 0.35) 45%, rgba(7, 17, 45, 0.9) 100%),
            linear-gradient(90deg, rgba(7, 17, 45, 0.42), transparent 58%);
        box-shadow: inset 0 -80px 90px rgba(0, 0, 0, 0.5);
    }

    .allpave-gallery-card img {
        position: absolute;
        inset: 0;
        min-height: 100%;
        opacity: 0.82;
        filter: saturate(1.04) contrast(1.03);
    }

    .allpave-gallery-body {
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1;
        padding: 1.35rem;
        background: transparent;
    }

    .allpave-gallery-body::before {
        left: 1.35rem;
        right: auto;
        top: -0.15rem;
        width: min(70%, 280px);
        height: 5px;
        background: linear-gradient(90deg, var(--ap-gold), rgba(255, 255, 255, 0.18));
    }

    .allpave-gallery-card h3 {
        color: #fff;
        text-shadow: 0 14px 34px rgba(0, 0, 0, 0.5);
    }

    .allpave-gallery-card p {
        color: rgba(255, 255, 255, 0.8);
    }

    .allpave-gallery-card:first-child h3 {
        max-width: 13ch;
        font-size: clamp(2rem, 3vw, 3.25rem);
        line-height: 0.98;
    }

    .allpave-journey-section {
        background:
            linear-gradient(180deg, #16212d 0%, #0b1426 100%);
        box-shadow: inset 0 34px 70px rgba(0, 0, 0, 0.24);
    }

    .allpave-process-grid::before {
        top: 3rem;
        background: linear-gradient(90deg, var(--ap-gold), rgba(255, 255, 255, 0.2), rgba(31, 33, 156, 0.72));
    }

    .allpave-process-card,
    .allpave-process-card:nth-child(2),
    .allpave-process-card:nth-child(3) {
        margin-top: 0;
    }

    .allpave-process-card {
        min-height: 250px;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.07));
        border: 1px solid rgba(255, 255, 255, 0.15);
        box-shadow:
            0 28px 86px rgba(0, 0, 0, 0.28),
            0 1px 0 rgba(255, 255, 255, 0.16) inset;
        color: #fff;
        backdrop-filter: blur(12px);
    }

    .allpave-process-card h3 {
        color: #fff;
    }

    .allpave-process-card p {
        color: rgba(255, 255, 255, 0.74);
    }

    .allpave-price-section {
        background:
            linear-gradient(145deg, #1b2324 0%, #0c162a 52%, #1f219c 135%);
        box-shadow: inset 0 40px 76px rgba(0, 0, 0, 0.28);
    }

    .allpave-price-card {
        min-height: 275px;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.07));
        border: 1px solid rgba(255, 255, 255, 0.14);
        color: #fff;
        box-shadow:
            0 30px 92px rgba(0, 0, 0, 0.32),
            0 1px 0 rgba(255, 255, 255, 0.16) inset;
        backdrop-filter: blur(12px);
    }

    .allpave-price-card h3 {
        color: #fff;
    }

    .allpave-price-card p {
        color: rgba(255, 255, 255, 0.75);
    }

    .allpave-price-card span {
        color: #ffe56c;
    }

    @media (max-width: 1180px) {
        .allpave-hero-grid,
        .allpave-proof-grid {
            grid-template-columns: 1fr;
        }

        .allpave-finish-layout,
        .allpave-layer-grid,
        .allpave-price-grid,
        .allpave-reviews-header {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        .allpave-services-grid,
        .allpave-gallery-grid,
        .allpave-coverage-grid {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        .allpave-gallery-card:first-child {
            grid-column: span 2;
        }

        .allpave-stats-grid {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }
    }

    @media (max-width: 820px) {
        .allpave-hero-grid,
        .allpave-process-grid,
        .allpave-proof-list,
        .allpave-trust-row,
        .allpave-contact-strip,
        .allpave-form-grid,
        .allpave-finish-layout,
        .allpave-layer-grid,
        .allpave-price-grid,
        .allpave-reviews-header {
            grid-template-columns: 1fr;
        }

        .allpave-reviews-summary {
            max-width: none;
        }

        .allpave-finish-feature {
            min-height: 440px;
        }

        .allpave-section {
            padding: 4rem 0;
        }

        .allpave-process-grid::before {
            display: none;
        }

        .allpave-process-card:nth-child(2),
        .allpave-process-card:nth-child(3) {
            margin-top: 0;
        }

        .allpave-hero-grid {
            padding: 3rem 0 2.5rem;
        }

        .allpave-hero-form-panel {
            order: -1;
            margin-top: 0;
        }
    }

    @media (max-width: 640px) {
        .allpave-services-grid,
        .allpave-finish-grid,
        .allpave-gallery-grid,
        .allpave-process-grid,
        .allpave-stats-grid,
        .allpave-coverage-grid {
            grid-template-columns: 1fr;
        }

        .allpave-gallery-card:first-child {
            grid-column: auto;
        }

        .allpave-hero-copy h1 {
            max-width: 100%;
        }
    }

    @media (max-width: 1180px) {
        .allpave-gallery-grid {
            grid-template-columns: repeat(2, minmax(0, 1fr));
            grid-auto-rows: minmax(340px, auto);
        }

        .allpave-gallery-card:first-child,
        .allpave-gallery-card:nth-child(2),
        .allpave-gallery-card:nth-child(3),
        .allpave-gallery-card:nth-child(4) {
            grid-column: auto;
            grid-row: auto;
        }

        .allpave-gallery-card:first-child {
            grid-column: 1 / -1;
            min-height: 480px;
        }

        .allpave-gallery-card {
            min-height: 340px;
        }
    }

    @media (max-width: 640px) {
        .allpave-gallery-grid {
            grid-template-columns: 1fr;
            grid-auto-rows: auto;
        }

        .allpave-gallery-card:first-child,
        .allpave-gallery-card:nth-child(2),
        .allpave-gallery-card:nth-child(3),
        .allpave-gallery-card:nth-child(4) {
            grid-column: auto;
            grid-row: auto;
            min-height: 360px;
        }

        .allpave-work-section,
        .allpave-journey-section,
        .allpave-price-section,
        .allpave-coverage-section,
        .allpave-reviews-section {
            padding-top: 3.5rem;
            padding-bottom: 3.5rem;
        }

        .allpave-google-review-card {
            flex-basis: calc(100vw - 2.25rem);
            min-height: 320px;
        }
    }

    @media (prefers-reduced-motion: reduce) {
        .allpave-review-marquee {
            overflow-x: auto;
            mask-image: none;
        }

        .allpave-review-track {
            animation: none;
        }
    }
