.noa-v2-date-grid,
.noa-v2-date-grid *,
.noa-v2-time-buttons,
.noa-v2-time-buttons * {
    box-sizing: border-box;
}

.noa-v2-date-grid {
    align-items: start;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.noa-v2-date-grid > * {
    min-width: 0;
    max-width: 100%;
}

.noa-v2-date-field {
    position: relative;
    min-width: 0;
    max-width: 100%;
}

.noa-v2-date-field label {
    display: block;
    color: #162033;
}

.noa-v2-date,
.noa-v2-booking input.noa-v2-date {
    color: #003b94 !important;
    font-weight: 700;
    cursor: pointer !important;
    pointer-events: auto !important;
    position: relative;
    z-index: 2;
    caret-color: #003b94 !important;
    background: #fff !important;
}

.noa-v2-booking.is-payment-active input.noa-v2-date,
.noa-v2-booking.is-payment-active .noa-v2-date {
    pointer-events: none !important;
}

.noa-v2-time-buttons {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin-top: 12px;
    min-height: 70px;
    overflow: hidden;
    contain: inline-size;
}

.noa-v2-time-buttons > span,
.noa-v2-interval-times > span {
    display: inline-block;
    color: #667085;
    font-weight: 600;
    font-size: 13px;
    padding: 8px 0;
}

.noa-v2-interval-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin-bottom: 10px;
    overflow: hidden;
}

.noa-v2-interval-tab,
.noa-v2-time-button {
    touch-action: manipulation;
    border: 1px solid #003b94 !important;
    background: #003b94 !important;
    color: #fff !important;
    border-radius: 12px !important;
    box-shadow: none !important;
    cursor: pointer;
}

.noa-v2-interval-tab {
    flex: 0 1 auto;
    max-width: 100%;
    min-width: 0;
    padding: 9px 13px;
    font-size: 13px;
    font-weight: 900;
    white-space: nowrap;
}

.noa-v2-interval-tab:hover,
.noa-v2-interval-tab.is-selected,
.noa-v2-time-button:hover,
.noa-v2-time-button.is-selected {
    background: #fff !important;
    color: #003b94 !important;
    border-color: #003b94 !important;
}

.noa-v2-interval-times {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    border-top: 1px dashed #d6dbe6;
    padding-top: 10px;
    overflow: hidden;
    contain: inline-size; /* Fix: megakadályozza az űrlap szétnyomását */
}

.noa-v2-interval-times button {
    margin: 2px;	
}

.noa-v2-time-button {
    flex: 0 1 auto;
    max-width: 100%;
    min-width: 0;
    padding: 8px 12px;
    line-height: 1;
    font-size: 13px;
    font-weight: 800;
    white-space: nowrap;
}

.noa-v2-time-button:disabled {
    background: #e5eaf3 !important;
    border-color: #d6dbe6 !important;
    color: #7a8699 !important;
    opacity: .45;
    cursor: not-allowed;
    text-decoration: line-through;
}

.noa-v2-time-buttons.noa-v2-invalid {
    border: 1px solid #d92d20 !important;
    border-radius: 12px !important;
    padding: 10px !important;
}

.noa-v2-datepicker {
    z-index: 100000;
    background: #fff;
    border: 1px solid rgba(0, 59, 148, .18);
    border-radius: 20px;
    box-shadow: 0 24px 70px rgba(0, 35, 90, .24);
    padding: 14px;
    color: #162033;
    box-sizing: border-box;
    overflow: hidden;
}

.noa-v2-datepicker:before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 5px;
    background: linear-gradient(90deg, #003b94, #df016f);
    pointer-events: none;
}

.noa-v2-datepicker-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin: 3px 0 10px;
}

.noa-v2-datepicker-kicker {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 900;
    color: #df016f;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.noa-v2-datepicker-kicker:before {
    content: "📅";
    font-size: 15px;
    line-height: 1;
}

.noa-v2-datepicker-close {
    width: 30px;
    height: 30px;
    border: 0 !important;
    border-radius: 999px !important;
    background: #eef4ff !important;
    color: #003b94 !important;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    font-weight: 900;
}

.noa-v2-datepicker-close:hover {
    background: #003b94 !important;
    color: #fff !important;
}

.noa-v2-datepicker-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 12px;
    padding: 10px 12px;
    border-radius: 15px;
    background: #f3f7ff;
    color: #003b94;
}

.noa-v2-datepicker-header strong {
    font-size: 16px;
    font-weight: 900;
    text-transform: capitalize;
    line-height: 1.1;
    text-align: center;
    flex: 1;
}

.noa-v2-datepicker-nav {
    width: 36px !important;
    height: 36px;
    border: 1px solid #003b94 !important;
    border-radius: 12px !important;
    background: #003b94 !important;
    color: #fff !important;
    font-size: 24px !important;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 !important;
    box-shadow: 0 8px 18px rgba(0, 59, 148, .18) !important;
}

.noa-v2-datepicker-nav:hover {
    background: #fff !important;
    color: #003b94 !important;
}

.noa-v2-datepicker-nav:disabled {
    opacity: .28;
    cursor: not-allowed;
    background: #c9d4e6 !important;
    color: #fff !important;
    border-color: #c9d4e6 !important;
    box-shadow: none !important;
}

.noa-v2-datepicker-week,
.noa-v2-datepicker-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 6px;
}

.noa-v2-datepicker-week {
    margin-bottom: 6px;
}

.noa-v2-datepicker-week span {
    text-align: center;
    font-size: 11px;
    font-weight: 900;
    color: #60708a;
    padding: 4px 0;
}

.noa-v2-datepicker-empty {
    display: block;
    min-height: 38px;
}

.noa-v2-datepicker-day {
    min-width: 0;
    height: 39px;
    border: 1px solid #e1e7f0 !important;
    border-radius: 12px !important;
    background: #f8fafc !important;
    color: #003b94 !important;
    font-weight: 900;
    cursor: pointer;
    padding: 0 !important;
    box-shadow: none !important;
    transition: background .15s ease, color .15s ease, border-color .15s ease, transform .15s ease;
}

.noa-v2-datepicker-day:hover {
    background: #eef4ff !important;
    color: #003b94 !important;
    border-color: #003b94 !important;
    transform: translateY(-1px);
}

.noa-v2-datepicker-day.is-selected {
    background: #003b94 !important;
    color: #fff !important;
    border-color: #003b94 !important;
    box-shadow: 0 9px 20px rgba(0, 59, 148, .24) !important;
}

.noa-v2-datepicker-day.is-today:not(.is-selected) {
    border-color: #df016f !important;
    color: #df016f !important;
    background: #fff !important;
}

.noa-v2-datepicker-day.is-disabled,
.noa-v2-datepicker-day:disabled {
    background: #f1f5f9 !important;
    color: #aab3c2 !important;
    border-color: #edf1f6 !important;
    cursor: not-allowed;
    opacity: .75;
    transform: none !important;
    box-shadow: none !important;
}

@media (max-width: 720px) {
    .noa-v2-interval-tabs {
        gap: 6px;
    }

    .noa-v2-interval-tab {
        padding: 8px 10px;
        white-space: normal;
    }

    .noa-v2-time-button {
        padding: 8px 10px;
    }

    .noa-v2-datepicker {
        width: calc(100vw - 48px);
    }
}

/* ==========================================================================
   FIX: Kiválasztott időpont méretváltozásának és ugrálásának megakadályozása
   ========================================================================== */

.noa-v2-time-button,
.noa-v2-time-button.is-selected,
.noa-v2-time-button:hover,
.noa-v2-time-button:focus,
.noa-v2-time-button:active {
    flex: 0 1 auto !important;
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    transform: none !important;
    outline: none !important;
}

/* Kijelöléskori és Hover állapotok szigorú méret-fixálása */
.noa-v2-time-button,
.noa-v2-time-button:hover,
.noa-v2-time-button.is-selected {
   
    padding: 8px 12px !important;    /* A belső margó se változzon semmilyen állapotban */
    letter-spacing: 0 !important;    /* Betűköz fixálása */
    border-width: 1px !important;    /* Szegélyvastagság fixálása */
    white-space: nowrap !important;
}

/* Letiltott külső / beépített szelektorok által generált ikonok kiiktatása */
.noa-v2-time-button.is-selected::before,
.noa-v2-time-button.is-selected::after {
    display: none !important;
    content: none !important;
}


.noa-v2-model-combo-chevron{
	float: right;
    font-weight: 800 !important;
    color: black;
    margin-top: -4px;
}

.noa-v2-model-combo-text{
	float: left;
}
