/* Яндекс Доставка — чекаут: минимализм, «резиновая» сетка, без лишних рамок */
:root {
    --rk-red: #e31e24;
    --rk-green: #10c44c;
    --rk-dark: #1a1a2e;
    --rk-border: #e8e8e8;
    --rk-line: #ececec;
    --rk-white: #ffffff;
    --rk-muted: #f8f8f8;
    --rk-radius: 10px;
    --rk-checkout-pad: clamp(14px, 3.5vw, 28px);
    --rk-checkout-gap: clamp(16px, 3vw, 32px);
    --rk-checkout-side: clamp(12px, 4vw, 28px);
}

/* Фон страницы оформления — один слой, карточки без «двойных» рамок */
body.woocommerce-checkout,
.woocommerce-checkout .woocommerce {
    background-color: var(--rk-muted);
}

/* ===== СТРАНУ СКРЫВАЕМ ===== */
#billing_country_field { display: none !important; }
.woocommerce-checkout .shop_table thead { display: none !important; }

/* ===== СЕТКА ЧЕКАУТА — симметричные колонки, резиновая ширина ===== */
form.checkout,
.woocommerce-checkout form.checkout,
.woocommerce form.checkout {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: var(--rk-checkout-gap) !important;
    width: 100% !important;
    max-width: min(1080px, calc(100vw - 2 * var(--rk-checkout-side))) !important;
    margin: 0 auto !important;
    padding: var(--rk-checkout-pad) !important;
    align-items: start !important;
    box-sizing: border-box !important;
}

#customer_details,
.col2-set {
    grid-column: 1 !important;
    grid-row: 1 / 20 !important;
    background: var(--rk-white);
    border-radius: var(--rk-radius);
    padding: var(--rk-checkout-pad) !important;
    border: none !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
}

/* «Ваш заказ» — заголовок внутри #order_review визуально через margin, без gap */
#order_review_heading {
    grid-column: 2 !important;
    grid-row: 1 !important;
    display: none !important; /* Скрываем отдельный элемент — рисуем через ::before внутри order_review */
}

#order_review {
    grid-column: 2 !important;
    grid-row: 1 / 20 !important;
    background: var(--rk-white);
    border-radius: var(--rk-radius) !important;
    padding: var(--rk-checkout-pad) !important;
    border: none !important;
    box-shadow: none !important;
    position: sticky !important;
    top: clamp(8px, 2vw, 20px);
    box-sizing: border-box !important;
}
/* Заголовок «Ваш заказ» через ::before — всегда внутри белого блока */
#order_review::before {
    content: "Ваш заказ";
    display: block;
    font-size: clamp(1rem, 2.2vw, 1.125rem);
    font-weight: 700;
    color: var(--rk-dark);
    margin-bottom: 14px;
}

/* Заголовок «Ваши данные» над формой — вместо скрытого h3 */
.woocommerce-billing-fields > h3 {
    display: block !important;
    font-size: clamp(1rem, 2.2vw, 1.125rem) !important;
    font-weight: 700 !important;
    margin: 0 0 16px 0 !important;
    padding: 0 !important;
    color: var(--rk-dark) !important;
}
.woocommerce-additional-fields > h3,
#ship-to-different-address { display: none !important; }
.col2-set .col-1, .col2-set .col-2 { float: none !important; width: 100% !important; }
.col2-set .col-2 { display: none !important; }
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-NoticeGroup { grid-column: 1 / -1 !important; }

/* ===== ПОЛЯ ВВОДА — тонкая обводка ===== */
.woocommerce-checkout .form-row { margin-bottom: 14px !important; }
.woocommerce-checkout .form-row label {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #333 !important;
    margin-bottom: 6px !important;
    display: block !important;
}
.woocommerce-checkout .input-text,
.woocommerce-checkout select {
    width: 100% !important;
    min-height: 46px !important;
    border: 1px solid var(--rk-border) !important;
    border-radius: 6px !important;
    padding: 0 14px !important;
    font-size: 15px !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
    background: var(--rk-white) !important;
    box-sizing: border-box !important;
    color: #333 !important;
}
.woocommerce-checkout .input-text:-webkit-autofill,
.woocommerce-checkout .input-text:-webkit-autofill:focus,
.woocommerce-checkout select:-webkit-autofill {
    -webkit-text-fill-color: #333 !important;
    transition: background-color 5000s ease-in-out 0s !important;
}
.woocommerce-checkout .input-text:focus,
.woocommerce-checkout select:focus {
    border-color: var(--rk-red) !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(227, 30, 36, 0.12) !important;
}
.woocommerce-invalid .input-text { border-color: var(--rk-red) !important; }
.woocommerce-validated .input-text { border-color: var(--rk-green) !important; }

/* ===== КОМПАКТНАЯ ФОРМА ===== */
#billing_first_name_field, #billing_last_name_field { width: 48% !important; display: inline-block !important; vertical-align: top !important; }
#billing_last_name_field { float: right !important; }
#billing_city_field { width: 100% !important; clear: both !important; }
#billing_phone_field { width: 48% !important; display: inline-block !important; vertical-align: top !important; }
#billing_email_field { width: 48% !important; display: inline-block !important; float: right !important; vertical-align: top !important; }
#billing_address_1_field[style*="none"],
#billing_address_2_field[style*="none"],
#billing_postcode_field[style*="none"],
#billing_state_field[style*="none"] { margin: 0 !important; padding: 0 !important; height: 0 !important; overflow: hidden !important; }

/* ===== ВСЯ ТАБЛИЦА — display:block чтобы tfoot не зажимался колонками thead ===== */
.woocommerce-checkout .shop_table,
.woocommerce-checkout .shop_table thead,
.woocommerce-checkout .shop_table tbody,
.woocommerce-checkout .shop_table tfoot,
.woocommerce-checkout .shop_table tr,
.woocommerce-checkout .shop_table th,
.woocommerce-checkout .shop_table td {
    display: block !important;
    width: 100% !important;
    border: none !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}
.woocommerce-checkout .shop_table { border: none !important; }

/* Шапка: ТОВАР ... ПОДЫТОГ */
.woocommerce-checkout .shop_table thead tr {
    display: flex !important;
    justify-content: space-between !important;
    padding: 0 0 8px !important;
    border-bottom: 1px solid var(--rk-border) !important;
}
.woocommerce-checkout .shop_table thead th {
    display: inline !important;
    width: auto !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #888 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.04em !important;
}

/* Строки товаров: название ... цена */
.woocommerce-checkout .shop_table tbody .cart_item {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 12px !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid var(--rk-line) !important;
}
.woocommerce-checkout .shop_table tbody .cart_item td {
    width: auto !important;
}
.woocommerce-checkout .shop_table .product-name {
    flex: 1 !important;
    min-width: 0 !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    line-height: 1.45 !important;
}
.woocommerce-checkout .shop_table .product-name .product-quantity {
    color: #888 !important;
    font-weight: 400 !important;
}
.woocommerce-checkout .shop_table .product-total {
    flex-shrink: 0 !important;
    width: auto !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    white-space: nowrap !important;
    text-align: right !important;
}

/* ===== TFOOT: подытог, доставка, итого — всё на 100% ширины ===== */
.woocommerce-checkout .shop_table tfoot tr {
    display: flex !important;
    justify-content: space-between !important;
    align-items: baseline !important;
    padding: 10px 0 !important;
    border-bottom: 1px solid var(--rk-line) !important;
}
.woocommerce-checkout .shop_table tfoot th { display: inline !important; width: auto !important; }
.woocommerce-checkout .shop_table tfoot td { display: inline !important; width: auto !important; margin-left: auto !important; text-align: right !important; }

/* Доставка: th сверху, td с кнопкой ПВЗ на всю ширину */
.woocommerce-checkout .shop_table tfoot .shipping {
    flex-wrap: wrap !important;
}
.woocommerce-checkout .shop_table tfoot .shipping th {
    display: block !important;
    width: 100% !important;
    margin-bottom: 4px !important;
}
.woocommerce-checkout .shop_table tfoot .shipping td {
    display: block !important;
    width: 100% !important;
    text-align: left !important;
}
.woocommerce-checkout .woocommerce-shipping-methods { list-style: none !important; padding: 0 !important; margin: 6px 0 0 !important; }
.woocommerce-checkout .woocommerce-shipping-methods li {
    background: transparent !important;
    border: none !important;
    border-bottom: 1px solid var(--rk-line) !important;
    border-radius: 0 !important;
    margin-bottom: 0 !important;
    padding: 12px 0 !important;
    transition: background 0.15s ease;
}
.woocommerce-checkout .woocommerce-shipping-methods li:has(input:checked) {
    background: #fafafa !important;
    padding: 12px 8px !important;
    border-radius: 6px !important;
    margin: 2px 0 !important;
}

/* Обёртка кнопки ПВЗ — убираем inline margin от <p> */
.woocommerce-checkout .woocommerce-shipping-methods p {
    margin: 4px 0 8px 0 !important;
}
.woocommerce-checkout .woocommerce-shipping-methods .bxbbutton-wrap,
.woocommerce-checkout .shipping td .bxbbutton { margin-top: 8px; }

/* ===== КНОПКА ПВЗ ===== */
.bxbbutton, .nd-button {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    background: var(--rk-dark) !important;
    color: white !important;
    border: none !important;
    padding: 13px 16px !important;
    border-radius: 6px !important;
    text-transform: uppercase;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.08em;
    cursor: pointer;
    text-decoration: none !important;
    transition: background 0.2s, opacity 0.2s;
    min-height: 44px;
    box-sizing: border-box;
    box-shadow: none !important;
}
a.bxbbutton, a.nd-button { color: white !important; text-decoration: none !important; }
.bxbbutton:hover, .nd-button:hover { background: #2d2d45 !important; color: white !important; opacity: 0.95; }
.bxbbutton img, .nd-button img { display: inline; vertical-align: middle; box-shadow: none !important; }

/* ===== ВЫБРАННЫЙ ПВЗ ===== */
.nd-pvz-selected {
    margin: 10px 0 4px !important;
    padding: 10px 14px !important;
    background: #f3faf5 !important;
    border: 1px solid #c8e6d0 !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    color: #166534 !important;
}

/* ===== Стили для строк tfoot ===== */
.woocommerce-checkout .shop_table tfoot .cart-subtotal th,
.woocommerce-checkout .shop_table tfoot .shipping th {
    font-weight: 500 !important;
    font-size: 14px !important;
    color: #555 !important;
}
.woocommerce-checkout .shop_table tfoot .cart-subtotal td {
    font-weight: 600 !important;
    font-size: 14px !important;
}

/* ===== ИТОГО ===== */
.woocommerce-checkout .shop_table tfoot .order-total {
    border-bottom: none !important;
    border-top: 2px solid var(--rk-dark) !important;
    padding: 14px 0 4px !important;
}
.woocommerce-checkout .shop_table tfoot .order-total th {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--rk-dark) !important;
}
.woocommerce-checkout .shop_table tfoot .order-total td,
.woocommerce-checkout .shop_table tfoot .order-total .amount {
    font-size: clamp(1.1rem, 2.5vw, 1.3rem) !important;
    color: var(--rk-red) !important;
    font-weight: 700 !important;
}

/* Заголовок «Способ оплаты» */
.woocommerce-checkout #payment::before {
    content: "Способ оплаты";
    display: block;
    font-size: clamp(0.9rem, 2vw, 1rem);
    font-weight: 700;
    color: var(--rk-dark);
    margin-bottom: 12px;
}

/* ===== ОПЛАТА — компактные строки ===== */
.woocommerce-checkout #payment {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
}
.woocommerce-checkout .wc_payment_methods {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
}
.woocommerce-checkout .wc_payment_method {
    background: transparent !important;
    border: none !important;
    border-bottom: 1px solid var(--rk-line) !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding: 10px 0 !important;
    box-shadow: none !important;
}
.woocommerce-checkout .wc_payment_method:last-child {
    border-bottom: none !important;
}
/* Радио + текст + иконка — всё в одну строку */
.woocommerce-checkout .wc_payment_method label {
    font-size: 14px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    display: inline !important;
}
.woocommerce-checkout .wc_payment_method input[type="radio"] {
    margin-right: 8px !important;
    vertical-align: middle !important;
}
.woocommerce-checkout .wc_payment_method label img {
    vertical-align: middle !important;
    height: 20px !important;
    width: auto !important;
    margin-left: 4px !important;
}
/* Описание способа оплаты — мелкий текст без фона */
.woocommerce-checkout .payment_box {
    margin: 4px 0 0 24px !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    font-size: 12px !important;
    color: #999 !important;
    line-height: 1.4 !important;
}
.woocommerce-checkout .payment_box::before { display: none !important; }

/* ===== КНОПКА ЗАКАЗА ===== */
#place_order {
    width: 100% !important;
    background: var(--rk-green) !important;
    color: white !important;
    min-height: 52px !important;
    font-size: clamp(15px, 2vw, 17px) !important;
    font-weight: 700 !important;
    border-radius: 6px !important;
    border: none !important;
    margin-top: 20px !important;
    box-shadow: none !important;
    cursor: pointer !important;
    transition: filter 0.2s, transform 0.15s;
}
#place_order:hover {
    filter: brightness(1.05);
    transform: translateY(-1px);
}

/* ===== ПОДСКАЗКИ DADATA ===== */
.nd-address-suggest, .nd-city-suggest {
    background: var(--rk-white) !important;
    border: 1px solid var(--rk-border) !important;
    border-top: none !important;
    border-radius: 0 0 6px 6px !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08) !important;
    max-height: 250px !important;
    overflow-y: auto !important;
    z-index: 9999 !important;
}
.nd-address-suggest-item, .nd-city-suggest > div {
    padding: 10px 16px !important;
    cursor: pointer !important;
    border-bottom: 1px solid var(--rk-line) !important;
    font-size: 14px !important;
}
.nd-address-suggest-item:hover, .nd-city-suggest > div:hover { background: var(--rk-muted) !important; }

.yandex-dostavka-courier-address { position: relative; }
.yandex-dostavka-courier-address .nd-address-suggest {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    z-index: 1000;
    margin-top: 2px;
    display: none;
}
.yandex-dostavka-courier-address .nd-address-suggest[aria-hidden="false"] { display: block; }

#yandex-dostavka-shipping-widget { margin-top: 10px; width: 100%; }
.yandex-dostavka-loading { pointer-events: none; opacity: 0.6; }

/* ===== КОРЗИНА ===== */
.woocommerce-cart .shop_table .amount { white-space: nowrap !important; }

/* ===== МОДАЛКА ПВЗ ===== */
#yd-pvz-overlay {
    z-index: 2147483647 !important;
    position: fixed !important;
}
#yd-pvz-overlay > div {
    position: relative;
    z-index: 1;
}

/* ===== Elementor Pro Checkout — та же логика ширины и меньше «коробок» ===== */
.elementor-widget-woocommerce-checkout-page .e-checkout__container {
    width: 100% !important;
    max-width: min(1080px, calc(100vw - 2 * var(--rk-checkout-side))) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    gap: var(--rk-checkout-gap) !important;
}

/* ===== АДАПТИВ ===== */
@media (max-width: 900px) {
    form.checkout,
    .woocommerce-checkout form.checkout,
    .woocommerce form.checkout {
        grid-template-columns: 1fr !important;
        padding: clamp(12px, 4vw, 20px) !important;
        gap: clamp(12px, 3vw, 20px) !important;
    }
    #customer_details, .col2-set, #order_review_heading, #order_review {
        grid-column: 1 !important;
        grid-row: auto !important;
        position: static !important;
    }
}

@media (max-width: 600px) {
    #billing_first_name_field, #billing_last_name_field,
    #billing_phone_field, #billing_email_field {
        width: 100% !important;
        float: none !important;
        display: block !important;
    }
    .woocommerce-checkout .input-text, .woocommerce-checkout select { font-size: 16px !important; }
    #place_order { min-height: 50px !important; }
    .bxbbutton, .nd-button { font-size: 12px !important; padding: 12px 14px !important; min-height: 46px; }
}
