.hero-step-layout {
    grid-template-columns: minmax(0, 1.18fr) minmax(380px, .82fr);
    gap: 36px;
}

.hero-note-card {
    display: none !important;
}

.step-booking-card {
    max-width: 430px;
    padding: 24px;
    justify-self: end;
}

.step-booking-card h2 {
    margin-bottom: 16px;
    font-size: 24px;
}

.step-progress {
    gap: 5px;
    margin-bottom: 16px;
}

.step-dot {
    padding: 7px 3px;
    border-radius: 10px;
}

.step-dot span {
    width: 23px;
    height: 23px;
    margin-bottom: 4px;
    font-size: 12px;
}

.step-dot em {
    font-size: 10px;
}

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

.step-help {
    margin-bottom: 12px;
    font-size: 13px;
}

.step-calendar {
    padding: 12px;
    margin-bottom: 12px;
}

.client-calendar-top {
    margin-bottom: 10px;
}

.client-calendar-top strong {
    font-size: 17px;
}

.client-calendar-weekdays,
.client-calendar-grid {
    gap: 4px;
}

.client-day {
    min-height: 34px;
    border-radius: 8px;
    font-size: 13px;
}

.client-day small {
    display: none;
}

.booking-form label {
    margin-bottom: 11px;
    font-size: 13px;
}

.booking-form input,
.booking-form select {
    height: 42px;
}

.booking-form textarea {
    min-height: 72px;
}

.step-actions {
    margin-top: 14px;
}

.service-choice-grid,
.car-size-grid {
    gap: 8px;
    margin-bottom: 14px;
}

.service-choice span,
.choice-card span {
    padding: 12px 13px;
}

.service-choice strong {
    font-size: 15px;
}

.service-choice em {
    margin-bottom: 4px;
    font-size: 13px;
}

.service-choice small {
    font-size: 12px;
}

.choice-card span {
    font-size: 15px;
}

.booking-summary {
    padding: 12px 13px;
    margin-bottom: 13px;
    font-size: 13px;
}

.quick-prices {
    flex-wrap: nowrap;
    gap: 12px;
}

.quick-card {
    min-width: 0;
    flex: 1 1 0;
    padding: 16px 15px;
    gap: 10px;
}

.quick-card .icon {
    width: 30px;
    height: 30px;
}

.quick-card strong {
    font-size: 14px;
}

.quick-card span {
    font-size: 13px;
}

.quick-card b {
    font-size: 23px;
}

.quick-card small {
    font-size: 12px;
}

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

    .step-booking-card {
        max-width: 560px;
        justify-self: start;
    }

    .quick-prices {
        flex-wrap: wrap;
    }

    .quick-card {
        min-width: 190px;
        flex: 0 1 auto;
    }
}

@media (max-width: 640px) {
    .step-booking-card {
        max-width: 100%;
        padding: 22px;
    }

    .quick-prices {
        flex-wrap: wrap;
    }

    .quick-card {
        width: 100%;
        flex: 1 1 100%;
    }
}
