.ctq-page {
    color: #10243d;
}

.ctq-hero {
    background-image: linear-gradient(90deg, rgba(2, 19, 43, .86) 0%, rgba(3, 28, 60, .62) 48%, rgba(3, 28, 60, .28) 100%), url('/newassets/images/car-transport-quotes-hero.webp') !important;
    background-size: cover;
    background-position: center right;
    min-height: 620px;
    padding: 150px 0 245px;
    position: relative;
    overflow: hidden;
}

.ctq-hero::after {
    content: "";
    position: absolute;
    left: -4%;
    right: -4%;
    bottom: -58px;
    height: 124px;
    background: #fff;
    transform: rotate(-3deg);
    transform-origin: left top;
}

.ctq-hero .page-content {
    max-width: 1100px;
    margin: 0 auto;
    position: relative;
    z-index: 2;
}

.ctq-steps-wrap {
    position: relative;
    z-index: 5;
    margin-top: -258px;
    padding: 0 0 76px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0, #fff 118px, #f5f8fb 100%);
}

.ctq-banner-boxes {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 44px;
    margin-top: 0;
    padding-bottom: 46px;
}

.ctq-banner-box {
    position: relative;
    display: grid;
    grid-template-columns: 62px minmax(0, 1fr);
    align-items: center;
    gap: 20px;
    text-align: left;
    background: rgba(255, 255, 255, .97);
    border: 1px solid rgba(209, 225, 239, .92);
    border-radius: 14px;
    padding: 36px 30px 30px;
    box-shadow: 0 26px 54px rgba(0, 18, 44, .16);
    backdrop-filter: blur(10px);
    min-height: 205px;
    overflow: visible;
}

.ctq-banner-box::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 32px;
    height: 26px;
    background: #00548a;
    clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.ctq-step-number {
    position: absolute;
    top: -30px;
    right: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    border-radius: 999px;
    background: #00548a;
    color: #fff;
    font-weight: 900;
    font-size: 18px;
    box-shadow: 0 15px 28px rgba(0, 35, 78, .22);
}

.ctq-step-one .ctq-step-number,
.ctq-step-one .ctq-step-icon {
    background: #ff6f00;
}

.ctq-step-three .ctq-step-number,
.ctq-step-three .ctq-step-icon {
    background: #0a4c7c;
}

.ctq-step-icon {
    width: 58px;
    height: 58px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    background: #00548a;
    color: #fff;
    font-size: 24px;
    box-shadow: 0 0 0 12px rgba(0, 84, 138, .08);
}

.ctq-banner-box h2 {
    color: #071d38;
    font-size: 21px;
    line-height: 1.2;
    margin: 0 0 10px;
    font-weight: 900;
}

.ctq-banner-box p {
    color: #43536a;
    margin: 0;
    line-height: 1.55;
    font-size: 15px;
}

.ctq-step-track {
    position: absolute;
    left: 11%;
    right: 11%;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.ctq-step-track::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    height: 2px;
    background: linear-gradient(90deg, transparent 0, #ff6f00 9%, #ff6f00 91%, transparent 100%);
    transform: translateY(-50%);
}

.ctq-step-track span {
    position: relative;
    z-index: 1;
    min-width: 94px;
    padding: 8px 18px;
    border-radius: 999px;
    border: 1px solid rgba(255, 111, 0, .72);
    background: rgba(255, 255, 255, .98);
    color: #e45f00;
    font-size: 12px;
    line-height: 1;
    font-weight: 900;
    text-align: center;
    box-shadow: 0 10px 24px rgba(0, 18, 44, .10);
}

.ctq-mobile-step-label {
    display: none;
}

.ctq-process-panel {
    position: relative;
    overflow: hidden;
    border-radius: 14px;
    background: #061d38;
    padding: 34px 34px 30px;
    box-shadow: 0 24px 58px rgba(0, 24, 64, .18);
}

.ctq-process-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: inherit;
    pointer-events: none;
}

.ctq-process-list {
    position: relative;
    display: grid;
    gap: 26px;
    margin-bottom: 28px;
}

.ctq-process-list::before {
    content: "";
    position: absolute;
    left: 21px;
    top: 26px;
    bottom: 25px;
    width: 1px;
    background: rgba(255, 255, 255, .22);
}

.ctq-process-step {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 46px minmax(0, 1fr);
    gap: 20px;
    align-items: start;
}

.ctq-process-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    background: #ff6f00;
    color: #fff;
    font-size: 16px;
    font-weight: 900;
    box-shadow: 0 14px 28px rgba(255, 111, 0, .26);
}

.ctq-process-step h3 {
    color: #fff;
    font-size: 23px;
    line-height: 1.2;
    font-weight: 900;
    margin: 0 0 7px;
}

.ctq-process-step p {
    color: rgba(255, 255, 255, .88);
    font-size: 16px;
    line-height: 1.55;
    margin: 0;
}

.ctq-process-panel .hero-btn {
    position: relative;
    z-index: 1;
    box-shadow: 0 16px 30px rgba(255, 111, 0, .18);
}

.ctq-page .single-request-element .icon {
    color: #1dbf73;
    font-size: 24px;
}

.ctq-page .began-wrap p {
    color: #405168;
    font-size: 17px;
    line-height: 1.75;
}

.ctq-cost-section {
    padding: 0 0 70px;
}

.ctq-cost-guide {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
    gap: 34px;
    align-items: stretch;
    border-radius: 16px;
    padding: 34px;
    background: linear-gradient(135deg, #f5f9ff 0%, #ffffff 58%, #fff7ef 100%);
    border: 1px solid rgba(0, 90, 186, .12);
    box-shadow: 0 24px 60px rgba(0, 24, 64, .10);
}

.ctq-eyebrow {
    display: inline-flex;
    align-items: center;
    margin-bottom: 12px;
    color: #ff6f00;
    font-size: 12px;
    line-height: 1;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.ctq-cost-copy h2 {
    color: #005aba;
    font-size: 34px;
    line-height: 1.18;
    font-weight: 900;
    margin: 0 0 16px;
}

.ctq-cost-copy p {
    color: #405168;
    font-size: 16px;
    line-height: 1.72;
    margin: 0 0 14px;
}

.ctq-internal-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 22px;
}

.ctq-internal-links a {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 9px 14px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid rgba(0, 90, 186, .16);
    color: #071d38;
    font-size: 13px;
    font-weight: 800;
    box-shadow: 0 8px 20px rgba(0, 24, 64, .06);
}

.ctq-internal-links a:hover {
    color: #fff;
    background: #005aba;
    border-color: #005aba;
}

.ctq-action-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}

.ctq-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    min-height: 46px;
    padding: 12px 18px;
    border-radius: 999px;
    background: #061d38;
    color: #fff;
    font-size: 14px;
    font-weight: 900;
    box-shadow: 0 12px 26px rgba(0, 24, 64, .12);
}

.ctq-action-btn:hover {
    color: #fff;
    background: #005aba;
}

.ctq-action-primary {
    background: #ff6f00;
    box-shadow: 0 14px 28px rgba(255, 111, 0, .18);
}

.ctq-action-primary:hover {
    background: #e85f00;
}

.ctq-cost-cards {
    display: grid;
    gap: 14px;
}

.ctq-cost-card {
    position: relative;
    padding: 22px 22px 21px;
    border-radius: 14px;
    background: #fff;
    border: 1px solid rgba(0, 90, 186, .12);
    box-shadow: 0 14px 34px rgba(0, 24, 64, .08);
}

.ctq-cost-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 18px;
    bottom: 18px;
    width: 5px;
    border-radius: 0 999px 999px 0;
    background: #ff6f00;
}

.ctq-cost-card span {
    display: inline-flex;
    margin-bottom: 8px;
    color: #005aba;
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
}

.ctq-cost-card h3 {
    color: #071d38;
    font-size: 20px;
    font-weight: 900;
    margin: 0 0 8px;
}

.ctq-cost-card p {
    color: #516176;
    font-size: 15px;
    line-height: 1.55;
    margin: 0;
}

@media (max-width: 991px) {
    .ctq-hero {
        min-height: auto;
        padding: 125px 0 205px;
    }

    .ctq-steps-wrap {
        margin-top: -184px;
        padding-bottom: 50px;
    }

    .ctq-banner-boxes {
        grid-template-columns: 1fr;
        max-width: 560px;
        margin-left: auto;
        margin-right: auto;
        padding-bottom: 0;
        gap: 28px;
    }

    .ctq-step-track {
        display: none;
    }

    .ctq-cost-guide {
        grid-template-columns: 1fr;
        padding: 28px;
    }
}

@media (max-width: 575px) {
    .ctq-hero {
        background-image: linear-gradient(90deg, rgba(2, 19, 43, .86) 0%, rgba(3, 28, 60, .62) 48%, rgba(3, 28, 60, .28) 100%), url('/newassets/images/car-transport-quotes-hero-mobile.webp') !important;
        background-position: center top;
        padding-top: 190px;
        padding-bottom: 345px;
    }

    .ctq-steps-wrap {
        margin-top: -255px;
        padding-bottom: 44px;
        background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0) 132px, #fff 133px, #f5f8fb 100%);
    }

    .ctq-banner-boxes {
        gap: 42px;
        padding-left: 0;
        padding-right: 0;
    }

    .ctq-banner-box {
        display: grid;
        grid-template-columns: 48px minmax(0, 1fr);
        align-items: center;
        gap: 15px;
        text-align: left;
        min-height: 0;
        padding: 30px 18px 32px;
        border-radius: 14px;
        box-shadow: 0 18px 42px rgba(0, 18, 44, .14);
    }

    .ctq-banner-box::before {
        display: none;
    }

    .ctq-banner-box h2 {
        font-size: 18px;
        margin-bottom: 8px;
    }

    .ctq-banner-box p {
        font-size: 13.5px;
        line-height: 1.55;
        max-width: none;
        margin: 0;
    }

    .ctq-step-number {
        width: 46px;
        height: 46px;
        top: -12px;
        right: auto;
        left: 16px;
        z-index: 3;
        font-size: 15px;
        box-shadow: 0 13px 24px rgba(0, 35, 78, .20);
    }

    .ctq-step-two .ctq-step-number {
        left: auto;
        right: 16px;
    }

    .ctq-step-three .ctq-step-number {
        left: 16px;
        right: auto;
    }

    .ctq-step-icon {
        position: static;
        width: 46px;
        height: 46px;
        transform: none;
        border-radius: 15px;
        color: #fff;
        font-size: 20px;
        box-shadow: 0 0 0 9px rgba(0, 84, 138, .08);
    }

    .ctq-step-track {
        display: none;
    }

    .ctq-mobile-step-label {
        position: absolute;
        left: 18px;
        bottom: -15px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 86px;
        height: 30px;
        padding: 0 16px;
        border-radius: 999px;
        background: #fff;
        border: 1px solid rgba(255, 111, 0, .78);
        color: #e45f00;
        font-size: 11px;
        font-weight: 900;
        line-height: 1;
        box-shadow: 0 11px 24px rgba(0, 18, 44, .12);
    }

    .ctq-step-two .ctq-mobile-step-label {
        left: auto;
        right: 18px;
    }

    .ctq-step-three .ctq-mobile-step-label {
        left: 18px;
        right: auto;
    }

    .ctq-process-panel {
        padding: 28px 20px 24px;
        border-radius: 13px;
    }

    .ctq-process-list {
        gap: 23px;
    }

    .ctq-process-step {
        grid-template-columns: 40px minmax(0, 1fr);
        gap: 16px;
    }

    .ctq-process-number {
        width: 40px;
        height: 40px;
        font-size: 14px;
    }

    .ctq-process-list::before {
        left: 19px;
    }

    .ctq-process-step h3 {
        font-size: 20px;
    }

    .ctq-process-step p {
        font-size: 15px;
    }

    .ctq-cost-section {
        padding-bottom: 48px;
    }

    .ctq-cost-guide {
        padding: 22px 18px;
        border-radius: 14px;
    }

    .ctq-cost-copy h2 {
        font-size: 26px;
    }

    .ctq-internal-links {
        gap: 8px;
    }

    .ctq-internal-links a {
        width: 100%;
        justify-content: center;
    }

    .ctq-action-row {
        display: grid;
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .ctq-cost-card {
        padding: 20px 18px 19px;
    }
}
