/* Unified product modals (pizza, drinks, fastfood) */

.pizza-modal,
.drink-modal {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 16px;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
    z-index: 9999;
}

.pizza-modal.active,
.drink-modal.active {
    display: flex;
}

/* Container */
.pizza-modal__container,
.drink-modal__container {
    width: 100%;
    max-width: 880px;
    border-radius: 16px;
    background: #fff;
    color: #222;
    box-shadow: 0 20px 60px rgba(0, 0, 0, .25);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* Ensure inner content respects rounding on all sides */
.pizza-modal__content,
.drink-modal__content {
    border-radius: 16px;
    background: #fff;
    display: grid;
    grid-template-rows: auto 1fr auto;
    /* header, scrollable body, sticky footer */
    /* Fallback */
    max-height: calc(100vh - 32px);
    /* Small viewport (iOS safari when bars visible) */
    max-height: calc(100svh - 32px);
    /* Dynamic viewport (most reliable on mobile) */
    max-height: calc(100dvh - 32px);
}

/* Header */
.pizza-modal__header,
.drink-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 20px 12px 20px;
    border-bottom: 1px solid #f0f0f0;
}

.pizza-modal__title,
.drink-modal__title,
.fastfood-modal__title {
    font-size: 18px;
    font-weight: 700;
    margin: 0;
}

.pizza-modal__close,
.drink-modal__close,
.modal__close {
    background: none;
    border: 0;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: grid;
    place-items: center;
    color: #666;
}

.pizza-modal__close:hover,
.drink-modal__close:hover {
    background: #f5f5f5;
}

/* Body */
.pizza-modal__body,
.drink-modal__body {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 16px;
    padding: 14px 18px;
    /* Allow scrolling past sticky footer (prevent last elements from being hidden) */
    padding-bottom: 120px;
    overflow: auto;
    /* only body scrolls */
    overflow-x: hidden;
    /* disable horizontal scroll */
}

/* Image */
.pizza-modal__image,
.drink-modal__image {
    width: 100%;
    max-width: 240px;
}

.pizza-modal__img,
.drink-modal__img {
    width: 100%;
    height: auto;
    border-radius: 12px;
    border: 1px solid #f0f0f0;
}

/* Info column */
.pizza-modal__info,
.drink-modal__info {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.pizza-modal__description,
.drink-modal__description {
    color: #555;
}

/* Ingredients block */
.pizza-modal__ingredients,
.drink-modal__ingredients {
    background: #fafafa;
    border: 1px solid #f0f0f0;
    border-radius: 10px;
    padding: 10px 12px;
}

.pizza-modal__ingredients h4,
.drink-modal__ingredients h4 {
    margin: 0 0 6px 0;
    font-size: 14px;
}

.pizza-modal__ingredients-text,
.drink-modal__ingredients-text {
    color: #666;
    font-size: 14px;
}

/* Size selector */
.size-selector {
    display: grid;
    gap: 10px;
}

.size-option {
    display: grid;
    grid-template-columns: 1fr auto auto;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border: 1px solid #eee;
    border-radius: 10px;
}

.size-option__info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.size-option__price {
    white-space: nowrap;
    font-weight: 700;
    color: #ff6b35;
}

.size-option.active {
    border-color: #ff6b35;
    background: #fff8f5;
}

.size-option__name {
    font-weight: 700;
}

.size-option__visual {
    display: flex;
    align-items: center;
    gap: 8px;
}

.size-option__circle {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: #ffe3d8;
}

.size-option__price {
    font-weight: 700;
    color: #ff6b35;
    white-space: nowrap;
}

.size-option__quantity {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Ensure combo global quantity aligns to the right on mobile like pizza */
@media (max-width: 720px) {
    .pizza-modal__info>#combo-qty-wrap.size-option__quantity {
        justify-content: flex-end;
        margin-left: auto;
    }
}

/* Make combo description fully visible (no clamp on mobile) */
.combo-modal__desc {
    display: block;
}

@media (max-width: 720px) {
    .combo-modal__desc {
        display: block !important;
        -webkit-line-clamp: unset;
        line-clamp: unset;
        -webkit-box-orient: unset;
        overflow: visible;
    }
}

.size-quantity-btn {
    width: 26px;
    height: 26px;
    border: 1px solid #eee;
    border-radius: 8px;
    background: #fff;
}

.size-quantity-value {
    min-width: 16px;
    text-align: center;
    font-weight: 700;
}

/* Unified extras quantity control (same look as upsell) */
.qty {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #f9fafb;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    padding: 4px 8px;
}

.qty__btn {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #e5e7eb;
    background: #fff;
    border-radius: 8px;
    font-weight: 700;
    cursor: pointer;
}

.qty__val {
    min-width: 18px;
    text-align: center;
    font-weight: 700;
}

/* Extras */
.pizza-modal__extras,
.fastfood-modal__extras,
.drink-modal__extras {
    display: block;
}

.pizza-modal__extras #combo-extras-list label {
    display: flex;
    align-items: center;
    gap: 10px;
}

#pizza-extras-list,
#fastfood-extras-list {
    display: grid;
    grid-template-columns: 1fr;
    /* единая вертикальная колонка */
    gap: 8px;
    overflow-x: hidden;
}

#pizza-extras-list label,
#fastfood-extras-list label {
    display: flex;
    /* унификация с JS */
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border: 1px solid #f5f5f5;
    border-radius: 8px;
}

/* Total */
.pizza-modal__total,
.drink-modal__total {
    display: flex;
    justify-content: flex-end;
    font-weight: 800;
    color: #ff6b35;
}

.pizza-modal__price-value,
.drink-modal__price-value {
    font-weight: 800;
}

/* Footer */
.pizza-modal__footer,
.drink-modal__footer {
    padding: 10px 14px;
    /* Ensure the footer content (button) stays above iOS Safari bottom controls */
    /* Older iOS fallback */
    padding-bottom: calc(10px + constant(safe-area-inset-bottom));
    /* Modern iOS */
    padding-bottom: calc(10px + env(safe-area-inset-bottom));
    border-top: 1px solid #f0f0f0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: sticky;
    bottom: 0;
    background: #fff;
    box-shadow: 0 -6px 16px rgba(0, 0, 0, .06);
}

.pizza-modal__footer .pizza-modal__price,
.drink-modal__footer .drink-modal__price {
    font-weight: 800;
    color: #ff6b35;
    margin-right: auto;
}

/* Responsive */
@media (max-width: 900px) {

    .pizza-modal__body,
    .drink-modal__body {
        grid-template-columns: 200px 1fr;
    }

    .pizza-modal__image,
    .drink-modal__image {
        max-width: 200px;
    }
}

@media (max-width: 720px) {

    .pizza-modal__body,
    .drink-modal__body {
        grid-template-columns: 1fr;
        gap: 12px;
        padding: 10px 12px 12px 12px;
    }

    .pizza-modal__image,
    .drink-modal__image {
        max-width: 100%;
    }

    #pizza-extras-list,
    #fastfood-extras-list {
        grid-template-columns: 1fr;
    }

    /* Более компактный заголовок, кнопки и описание */
    .pizza-modal__header,
    .drink-modal__header {
        padding: 12px;
    }

    .pizza-modal__title,
    .drink-modal__title {
        font-size: 16px;
    }

    .pizza-modal__close,
    .drink-modal__close {
        width: 32px;
        height: 32px;
    }

    .pizza-modal__description,
    .drink-modal__description {
        font-size: 13px;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    /* Список размеров в одну колонку на мобильном */
    .size-selector {
        grid-template-columns: 1fr;
        gap: 6px;
    }

    .size-option {
        grid-template-columns: 1fr auto auto;
        padding: 8px;
    }

    .size-option__circle {
        width: 10px;
        height: 10px;
    }

    .size-quantity-btn {
        width: 24px;
        height: 24px;
    }
}

/* Fastfood modal aligns to unified pizza styles */
.fastfood-modal__title {
    font-size: 18px;
    font-weight: 700;
    margin: 0;
}

.fastfood-modal__img {
    border-radius: 12px;
    border: 1px solid #f0f0f0;
}

.fastfood-modal__description {
    color: #555;
}

.fastfood-modal__price-value {
    font-weight: 800;
}