/* === Layout === */
main#content .woocommerce-checkout .woocommerce {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 16px;
}

/* === Inputs === */
main#content .woocommerce-checkout input:not([type="radio"]):not([type="checkbox"]),
main#content .woocommerce-checkout select,
main#content .woocommerce-checkout textarea {
    background: #0d1117 !important;
    border: 1px solid #2d3748 !important;
    color: #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 11px 14px !important;
    width: 100% !important;
    font-size: 14px !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
    outline: none !important;
    box-shadow: none !important;
}
main#content .woocommerce-checkout input:not([type="radio"]):not([type="checkbox"]):focus,
main#content .woocommerce-checkout select:focus,
main#content .woocommerce-checkout textarea:focus {
    border-color: #6366f1 !important;
    box-shadow: 0 0 0 3px rgba(99,102,241,0.12) !important;
}
main#content .woocommerce-checkout input::placeholder,
main#content .woocommerce-checkout textarea::placeholder {
    color: #4b5563 !important;
}
main#content .woocommerce-checkout select {
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    padding-right: 36px !important;
}

/* === Labels === */
main#content .woocommerce-checkout .woocommerce-billing-fields label,
main#content .woocommerce-checkout .woocommerce-additional-fields label {
    color: #94a3b8;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 6px;
    display: block;
}

/* === Billing section card === */
main#content .woocommerce-checkout .woocommerce-billing-fields,
main#content .woocommerce-checkout .woocommerce-additional-fields {
    background: #0d1117;
    border: 1px solid #1e293b;
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 16px;
}
main#content .woocommerce-checkout h3 {
    color: #f1f5f9;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.02em;
    padding-bottom: 14px;
    border-bottom: 1px solid #1e293b;
    margin-bottom: 20px;
    margin-top: 0;
}

/* Order notes textarea */
main#content .woocommerce-checkout #order_comments_field textarea {
    min-height: 80px !important;
}

/* === Order review box === */
main#content .woocommerce-checkout-review-order {
    background: #0d1117;
    border: 1px solid #1e293b;
    padding: 24px;
    border-radius: 12px;
}
main#content .woocommerce-checkout-review-order table {
    width: 100%;
    border-collapse: collapse;
}
main#content .woocommerce-checkout-review-order table th,
main#content .woocommerce-checkout-review-order table td {
    padding: 10px 0;
    border-bottom: 1px solid #1e293b;
    color: #cbd5e1;
    font-size: 14px;
}
main#content .woocommerce-checkout-review-order table th {
    color: #64748b;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-weight: 600;
}
main#content .woocommerce-checkout-review-order .cart-subtotal td,
main#content .woocommerce-checkout-review-order .order-total td {
    color: #f1f5f9;
    font-weight: 600;
}
main#content .woocommerce-checkout-review-order .order-total {
    border-top: 1px solid #334155;
}
main#content .woocommerce-checkout-review-order .order-total td {
    font-size: 18px;
    color: #818cf8;
    padding-top: 14px;
}

/* === Payment box wrapper === */
main#content .woocommerce-checkout #payment {
    background: #0d1117;
    border: 1px solid #1e293b;
    border-radius: 12px;
    padding: 20px;
    min-width: 0;
}
main#content .woocommerce-checkout #payment h3 {
    border-bottom: 1px solid #1e293b;
    padding-bottom: 14px;
    margin-bottom: 16px;
}

/* === Payment methods GRID === */
main#content .woocommerce-checkout #payment ul.payment_methods {
    list-style: none;
    margin: 0 0 20px 0;
    padding: 0 0 20px 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    border-bottom: 1px solid #1e293b;
}
main#content .woocommerce-checkout #payment ul.payment_methods::before { display: none !important; }
main#content .woocommerce-checkout #payment ul.payment_methods li {
    padding: 0;
    margin: 0;
    position: relative;
}
main#content .woocommerce-checkout #payment ul.payment_methods li input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}
main#content .woocommerce-checkout #payment ul.payment_methods li label > img { display: none; }

main#content .woocommerce-checkout #payment ul.payment_methods li label {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 8px 6px;
    background: #111827;
    border: 1.5px solid #1e293b;
    border-radius: 8px;
    cursor: pointer;
    margin: 0;
    width: 100%;
    height: 70px;
    line-height: 1.1;
    font-size: .8rem;
    box-sizing: border-box;
    text-align: center;
    transition: border-color 0.15s, background 0.15s;
    position: relative;
    overflow: hidden;
}
main#content .woocommerce-checkout #payment ul.payment_methods li label svg {
    max-height: 55px;
    max-width: 110px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    filter: none;
    opacity: 1;
}
main#content .woocommerce-checkout #payment ul.payment_methods li label span {
    font-size: 9px;
    color: #64748b;
    font-weight: 500;
    text-align: center;
    line-height: 1.2;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 3px;
}
main#content .woocommerce-checkout #payment ul.payment_methods li label:hover {
    border-color: #334155;
    background: #1a2235;
}
main#content .woocommerce-checkout #payment ul.payment_methods li label .payment_fee {
    position: absolute;
    top: 3px;
    right: 3px;
    font-size: 8px;
    color: #f59e0b;
    background: rgba(245,158,11,0.12);
    border-radius: 3px;
    padding: 1px 3px;
    line-height: 1.4;
    font-weight: 600;
}
main#content .woocommerce-checkout #payment ul.payment_methods li input[type="radio"]:checked + label,
main#content .woocommerce-checkout #payment ul.payment_methods li.active label {
    border-color: #6366f1 !important;
    background: rgba(99,102,241,0.08) !important;
}
main#content .woocommerce-checkout #payment ul.payment_methods li input[type="radio"]:checked + label span,
main#content .woocommerce-checkout #payment ul.payment_methods li.active label span {
    color: #a5b4fc;
}
main#content .woocommerce-checkout #payment .payment_box { display: none !important; }

@media (max-width: 480px) {
    main#content .woocommerce-checkout #payment ul.payment_methods {
        grid-template-columns: repeat(2, 1fr);
    }
}

main#content .nv-page-title { margin-bottom: 0 !important; }

/* === Terms как кнопка === */
main#content .woocommerce-checkout p.terms {
    display: flex !important;
    align-items: center;
    gap: 10px;
    background: rgba(99,102,241,0.06);
    border: 1px solid #2d3748;
    border-radius: 8px;
    padding: 10px 14px;
    margin: 12px 0 0 0;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
}
main#content .woocommerce-checkout p.terms:hover {
    border-color: #6366f1;
    background: rgba(99,102,241,0.1);
}
main#content .woocommerce-checkout p.terms input[type="checkbox"] {
    all: revert;
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    accent-color: #6366f1;
    cursor: pointer;
    margin: 0;
}
main#content .woocommerce-checkout p.terms label {
    color: #94a3b8;
    font-size: 12px;
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    cursor: pointer;
    margin: 0;
    display: inline;
    line-height: 1.5;
}
main#content .woocommerce-checkout p.terms label a { color: #818cf8; text-decoration: underline; }
main#content .woocommerce-checkout p.terms label a:hover { color: #a5b4fc; }
main#content .woocommerce-checkout p.terms .required { color: #ef4444; }

/* === Place order button === */
main#content .woocommerce-checkout #place_order {
    background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    padding: 16px 28px !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    width: 100% !important;
    display: block !important;
    margin-top: 16px !important;
    transition: opacity 0.2s, transform 0.15s, box-shadow 0.2s !important;
    box-shadow: 0 4px 24px rgba(99, 102, 241, 0.4) !important;
    position: relative !important;
    overflow: hidden !important;
}
main#content .woocommerce-checkout #place_order::before {
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 100%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
    transition: left 0.5s;
}
main#content .woocommerce-checkout #place_order:hover::before { left: 100%; }
main#content .woocommerce-checkout #place_order:hover {
    opacity: 0.92 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 32px rgba(99, 102, 241, 0.5) !important;
}
main#content .woocommerce-checkout #place_order:active {
    transform: translateY(0) !important;
    box-shadow: 0 4px 16px rgba(99, 102, 241, 0.3) !important;
}

/* === Cart message / undo notification === */
main#content .woocommerce-checkout .woocommerce-message,
main#content .woocommerce-message {
    background: rgba(99, 102, 241, 0.08) !important;
    border: 1px solid #3730a3 !important;
    border-radius: 8px !important;
    padding: 10px 14px !important;
    font-size: 13px !important;
    color: #c7d2fe !important;
    margin-bottom: 12px !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}
main#content .woocommerce-checkout .woocommerce-message::before,
main#content .woocommerce-message::before { display: none !important; }

/* Скрываем строку Subtotal в обзоре заказа */
main#content .woocommerce-checkout-review-order .cart-subtotal { display: none !important; }


/* ========================================================================
 *  НОВЫЕ БЛОКИ
 * ====================================================================== */

/* Пустой оригинальный контейнер купона/логина после переноса */
main#content #neve-checkout-coupon.hb-empty,
main#content #hb-checkout-coupon-source.hb-empty { display: none !important; }

/* Пустой блок "Additional information" (order notes перенесены в billing) */
main#content .woocommerce-checkout .woocommerce-additional-fields { display: none !important; }

/* --- Купон (компактный, над кнопкой оплаты) --- */
main#content .hb-coupon-wrap { margin: 0 0 14px 0; }
main#content .hb-coupon-wrap .woocommerce-info {
    background: rgba(99, 102, 241, 0.06);
    border: 1px solid #2d3748;
    border-radius: 8px;
    padding: 8px 12px;
    font-size: 12px;
    color: #94a3b8;
    margin: 0 0 8px 0;
}
main#content .hb-coupon-wrap .woocommerce-info::before { display: none !important; }
main#content .hb-coupon-wrap .showcoupon {
    color: #818cf8; text-decoration: none; font-weight: 500;
}
main#content .hb-coupon-wrap .showcoupon:hover { color: #a5b4fc; text-decoration: underline; }
main#content .hb-coupon-wrap form.checkout_coupon {
    background: #0d1117;
    border: 1px solid #1e293b;
    border-radius: 10px;
    padding: 10px;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}
main#content .hb-coupon-wrap form.checkout_coupon .form-row { margin: 0 !important; padding: 0 !important; flex: 1; }
main#content .hb-coupon-wrap form.checkout_coupon .form-row-last { flex: 0 0 auto; }
main#content .hb-coupon-wrap #coupon_code {
    background: #111827 !important;
    border: 1.5px solid #2d3748 !important;
    color: #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 8px 12px !important;
    font-size: 13px !important;
    width: 100% !important;
}
main#content .hb-coupon-wrap #coupon_code:focus {
    border-color: #6366f1 !important;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.12) !important;
}
main#content .hb-coupon-wrap #coupon_code::placeholder { color: #4b5563 !important; }
main#content .hb-coupon-wrap form.checkout_coupon button[name="apply_coupon"] {
    background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 8px 14px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    box-shadow: 0 4px 14px rgba(99, 102, 241, 0.3) !important;
    transition: opacity 0.2s, transform 0.15s !important;
}
main#content .hb-coupon-wrap form.checkout_coupon button[name="apply_coupon"]:hover { opacity: .9; transform: translateY(-1px); }

/* --- Логин (Returning) — под платёжными системами --- */
main#content .hb-login-wrap {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid #1e293b;
}
main#content .hb-login-wrap .woocommerce-info {
    background: rgba(99, 102, 241, 0.06);
    border: 1px solid #2d3748;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 13px;
    color: #94a3b8;
    margin: 0 0 10px 0;
}
main#content .hb-login-wrap .woocommerce-info::before { display: none !important; }
main#content .hb-login-wrap .showlogin,
main#content .hb-login-wrap .hb-show-login { color: #818cf8; text-decoration: none; font-weight: 500; }
main#content .hb-login-wrap .showlogin,
main#content .hb-login-wrap .hb-show-login:hover { color: #a5b4fc; text-decoration: underline; }
main#content .hb-login-wrap form.login {
    background: #0d1117;
    border: 1px solid #1e293b;
    border-radius: 10px;
    padding: 16px;
    margin: 0 0 10px 0;
}
main#content .hb-login-wrap form.login > p:first-child {
    color: #94a3b8;
    font-size: 12px;
    line-height: 1.5;
    margin-top: 0;
}
main#content .hb-login-wrap form.login label {
    color: #94a3b8;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    display: block;
    margin-bottom: 6px;
}
main#content .hb-login-wrap form.login label.woocommerce-form-login__rememberme {
    text-transform: none;
    font-weight: 400;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
main#content .hb-login-wrap form.login input.input-text,
main#content .hb-login-wrap form.login .password-input input {
    background: #111827 !important;
    border: 1.5px solid #2d3748 !important;
    color: #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 10px 12px !important;
    width: 100% !important;
    font-size: 14px !important;
}
main#content .hb-login-wrap form.login input:focus {
    border-color: #6366f1 !important;
    box-shadow: 0 0 0 3px rgba(99,102,241,0.12) !important;
}
main#content .hb-login-wrap form.login .form-row-first,
main#content .hb-login-wrap form.login .form-row-last {
    width: 100%;
    float: none;
    margin: 0 0 12px 0;
}
main#content .hb-login-wrap form.login .woocommerce-form-login__submit {
    background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 10px 20px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    box-shadow: 0 4px 14px rgba(99, 102, 241, 0.3) !important;
    transition: opacity .2s, transform .15s !important;
}
main#content .hb-login-wrap form.login .woocommerce-form-login__submit:hover { opacity: .9; transform: translateY(-1px); }
main#content .hb-login-wrap .lost_password a { color: #818cf8; font-size: 12px; }
main#content .hb-login-wrap .password-input { position: relative; display: block; }

/* ========================================================================
 *  ПК-РАСКЛАДКА: сводка заказа слева под Billing
 * ====================================================================== */
main#content .hb-left-summary {
    background: #0d1117;
    border: 1px solid #1e293b;
    border-radius: 12px;
    padding: 24px;
    margin-bottom: 16px;
}
main#content .hb-left-summary table { width: 100%; border-collapse: collapse; }
main#content .hb-left-summary table th,
main#content .hb-left-summary table td {
    padding: 10px 0;
    border-bottom: 1px solid #1e293b;
    color: #cbd5e1;
    font-size: 14px;
}
main#content .hb-left-summary table th {
    color: #64748b;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-weight: 600;
}
main#content .hb-left-summary .cart-subtotal { display: none !important; }
main#content .hb-left-summary .cart-subtotal td,
main#content .hb-left-summary .order-total td { color: #f1f5f9; font-weight: 600; }
main#content .hb-left-summary .order-total { border-top: 1px solid #334155; }
main#content .hb-left-summary .order-total td { font-size: 18px; color: #818cf8; padding-top: 14px; }
main#content .hb-left-summary .hb-coupon-wrap { margin: 14px 0 0 0; }

/* На ПК review-order служит лишь обёрткой для #payment (у него своя карточка) */
@media (min-width: 769px) {
    main#content .woocommerce-checkout-review-order {
        background: transparent;
        border: none;
        padding: 0;
    }
}

main#content #order_review_heading {
    display: none;
}

main#content .woocommerce-checkout form.checkout {
    grid-template-columns: 3fr 2.5fr;
    grid-column-gap: 45px;
}

main#content .woocommerce form .form-row {
    margin-bottom: 0 !important;
}


/* ========================================================================
 *  МОБИЛЬНАЯ ВЕРСИЯ
 * ====================================================================== */
@media (max-width: 768px) {

    /* Убираем горизонтальную прокрутку */
    html, body { overflow-x: hidden !important; max-width: 100%; }
    main#content .woocommerce-checkout,
    main#content .woocommerce-checkout .woocommerce,
    main#content .woocommerce-checkout form.checkout,
    main#content .wfacp_main_form,
    main#content [class*="wfacp_"] { max-width: 100% !important; }
    main#content .woocommerce-checkout .woocommerce { padding-left: 12px; padding-right: 12px; }
    main#content .woocommerce form .form-row { margin-left: 0; margin-right: 0; }
    main#content .woocommerce-checkout #payment ul.payment_methods { 
        grid-template-columns: repeat(2, 1fr);
        margin-left: 0; 
        margin-right: 0; 
    }

    /* Sticky BUY — прилипает к низу экрана */
    main#content .woocommerce-checkout #place_order {
        position: fixed !important;
        left: 0; right: 0; bottom: 0;
        width: 100% !important;
        margin: 0 !important;
        border-radius: 0 !important;
        z-index: 99999;
        box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.45) !important;
    }
    main#content .woocommerce-checkout form.checkout,
    main#content .woocommerce-checkout .woocommerce-checkout-review-order { padding-bottom: 84px; }
}

    main#content li.payment_method_custom_a69a8e250d7465b svg {
        max-height: 30px !important;
    }

    .woocommerce form .show-password-input, .woocommerce-page form .show-password-input {
        display: none;
    }




/* === HB checkout coupon visibility hard-fix (desktop + mobile) === */
main#content .hb-coupon-wrap,
main#content .hb-coupon-wrap .woocommerce-info {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}
main#content .hb-coupon-wrap form.checkout_coupon {
    visibility: visible !important;
    opacity: 1 !important;
}
main#content .hb-left-summary .hb-coupon-wrap {
    width: 100%;
    clear: both;
}

/* === HB checkout placement fix v1.0.2 === */
main#content #hb-checkout-coupon-source.hb-empty,
main#content #neve-checkout-coupon.hb-empty { display: none !important; }

main#content .hb-left-summary .hb-coupon-wrap {
    margin: 14px 0 0 0 !important;
    width: 100%;
    clear: both;
}

main#content .hb-coupon-wrap .woocommerce-info,
main#content .hb-login-wrap .woocommerce-info {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

main#content .hb-coupon-wrap .woocommerce-info .showcoupon,
main#content .hb-login-wrap .woocommerce-info .showlogin,
main#content .hb-login-wrap .woocommerce-info .hb-show-login {
    margin-left: auto;
    white-space: nowrap;
}

/* Coupon form must stay collapsed until user clicks. */
main#content .hb-coupon-wrap form.checkout_coupon:not([style*="display: block"]) {
    display: none;
}

/* Returning customer lives below Create an account, not in payment box. */
main#content .hb-login-wrap {
    margin: 10px 0 16px 0 !important;
    padding-top: 0 !important;
    border-top: 0 !important;
}

@media (max-width: 768px) {
    main#content .hb-coupon-wrap .woocommerce-info,
    main#content .hb-login-wrap .woocommerce-info {
        padding: 12px 14px !important;
        min-height: auto !important;
        line-height: 1.35 !important;
    }
    main#content .hb-coupon-wrap .woocommerce-info .showcoupon,
    main#content .hb-login-wrap .woocommerce-info .showlogin,
main#content .hb-login-wrap .woocommerce-info .hb-show-login {
        white-space: normal !important;
        text-align: right;
        max-width: 55%;
    }
    main#content .hb-left-summary .hb-coupon-wrap {
        margin-top: 12px !important;
    }
}


/* === HB v1.0.3 hard coupon/login placement fixes === */
main#content .woocommerce-form-coupon-toggle,
main#content #hb-checkout-coupon-source,
main#content .wfacp_coupon_field_box,
main#content .wfacp_coupon_section,
main#content .wfacp_coupon_wrapper,
main#content .wfacp_form_coupon_wrap,
main#content .wfacp_show_coupon_msg,
main#content .wfacp-coupon-page {
    display: none !important;
}
main#content #hb-one-coupon,
main#content #hb-one-coupon .woocommerce-info {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}
main#content #hb-one-coupon form.checkout_coupon {
    display: none;
}
main#content #hb-one-coupon form.checkout_coupon[style*="display: block"] {
    display: flex !important;
}
main#content .hb-login-wrap {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}
@media (max-width: 768px) {
    main#content #hb-one-coupon .woocommerce-info {
        display: grid !important;
        grid-template-columns: 1fr auto;
        gap: 10px;
        align-items: center;
        min-height: 52px;
    }
    main#content #hb-one-coupon .woocommerce-info .showcoupon {
        text-align: right;
        display: inline-block;
    }
    main#content #hb-one-coupon form.checkout_coupon[style*="display: block"] {
        display: block !important;
    }
    main#content #hb-one-coupon form.checkout_coupon .form-row,
    main#content #hb-one-coupon form.checkout_coupon .form-row-last {
        width: 100% !important;
        margin-bottom: 8px !important;
    }
}


/* === HB v1.0.4 coupon/login final placement + compact design === */
main#content #hb-one-coupon .woocommerce-info,
main#content #hb-one-login .woocommerce-info,
main#content #hb-one-login .woocommerce-form-login-toggle {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    min-height: 52px !important;
    padding: 10px 14px !important;
    background: #111827 !important;
    border: 1px solid #263244 !important;
    border-radius: 10px !important;
    color: #94a3b8 !important;
    font-size: 13px !important;
    line-height: 1.25 !important;
    margin: 0 !important;
}
main#content #hb-one-coupon .showcoupon,
main#content #hb-one-login .showlogin,
main#content #hb-one-login .hb-show-login {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 170px !important;
    min-height: 38px !important;
    padding: 8px 14px !important;
    border: 1px solid #38bdf8 !important;
    border-radius: 8px !important;
    color: #c4b5fd !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    text-align: center !important;
    box-sizing: border-box !important;
    white-space: normal !important;
}
main#content #hb-one-login {
    margin: 12px 0 16px 0 !important;
    clear: both !important;
}
main#content #hb-one-login form.login {
    margin-top: 10px !important;
    background: #0d1117 !important;
    border: 1px solid #263244 !important;
    border-radius: 10px !important;
    padding: 16px !important;
}
main#content #hb-one-login form.login .form-row-first,
main#content #hb-one-login form.login .form-row-last {
    width: 100% !important;
    float: none !important;
    margin-bottom: 12px !important;
}
main#content .hb-left-summary #hb-one-coupon {
    margin-top: 14px !important;
}

@media (min-width: 769px) {
    main#content #hb-one-login {
        max-width: 100% !important;
    }
}

@media (max-width: 768px) {
    main#content #hb-one-coupon .woocommerce-info,
    main#content #hb-one-login .woocommerce-info,
    main#content #hb-one-login .woocommerce-form-login-toggle {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        min-height: 54px !important;
        padding: 10px 12px !important;
        text-align: left !important;
    }
    main#content #hb-one-coupon .showcoupon,
    main#content #hb-one-login .showlogin,
main#content #hb-one-login .hb-show-login {
        min-width: 0 !important;
        width: 52% !important;
        min-height: 40px !important;
        padding: 8px 10px !important;
        font-size: 12px !important;
    }
    main#content #hb-one-coupon .woocommerce-info { grid-template-columns: none !important; }
    main#content #hb-one-login {
        margin: 12px 0 0 0 !important;
    }
    main#content #payment #hb-one-login {
        border-top: 1px solid #1e293b !important;
        padding-top: 12px !important;
    }
    main#content #hb-one-login form.login {
        font-size: 13px !important;
    }
}


/* === HB v1.0.5 login placement + currency-safe classes === */
main#content #hb-one-login .hb-show-login {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 170px !important;
    min-height: 38px !important;
    padding: 8px 14px !important;
    border: 1px solid #38bdf8 !important;
    border-radius: 8px !important;
    color: #c4b5fd !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    text-align: center !important;
    box-sizing: border-box !important;
    white-space: normal !important;
}
main#content #hb-one-login form.login {
    order: 2 !important;
    width: 100% !important;
    margin-top: 10px !important;
    margin-bottom: 0 !important;
}
main#content #hb-one-login .woocommerce-info,
main#content #hb-one-login .woocommerce-form-login-toggle {
    order: 1 !important;
}
@media (min-width: 769px) {
    main#content #hb-one-login {
        display: block !important;
        width: 100% !important;
    }
    main#content #hb-one-login form.login {
        clear: both !important;
    }
}
@media (max-width: 768px) {
    main#content #hb-one-login .hb-show-login {
        min-width: 0 !important;
        width: 52% !important;
        min-height: 40px !important;
        padding: 8px 10px !important;
        font-size: 12px !important;
    }
}

/* === HB v1.0.6 anti-flash + mobile account/login placement + terms click === */
main#content .woocommerce-form-coupon-toggle:not(#hb-one-login *),
main#content .woocommerce-form-login-toggle:not(#hb-one-login *) {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
}
main#content #hb-one-login .woocommerce-form-login-toggle {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
}
main#content .woocommerce-checkout p.terms,
main#content .woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
    cursor: pointer !important;
}
main#content .woocommerce-checkout p.terms label,
main#content .woocommerce-checkout .woocommerce-terms-and-conditions-checkbox-text {
    cursor: pointer !important;
}
main#content .hb-mobile-create-account {
    display: block !important;
    margin: 12px 0 0 0 !important;
    padding: 0 !important;
    color: #e2e8f0 !important;
}
@media (max-width: 768px) {
    main#content #payment .hb-mobile-create-account {
        order: 20 !important;
        width: 100% !important;
    }
    main#content #payment #hb-one-login {
        order: 21 !important;
        width: 100% !important;
        border-top: 0 !important;
        padding-top: 0 !important;
        margin-top: 12px !important;
    }
    main#content #hb-one-login .woocommerce-form-login-toggle,
    main#content #hb-one-login .woocommerce-info {
        background: #111827 !important;
        border: 1px solid #263244 !important;
        border-radius: 10px !important;
    }
}

/* === HB v1.0.7 final mobile coupon/login + clickable terms fixes === */
main#content #hb-one-coupon .hb-show-coupon,
main#content #hb-one-login .hb-show-login {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid #38bdf8 !important;
    border-radius: 8px !important;
    color: #c4b5fd !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    text-align: center !important;
    box-sizing: border-box !important;
}
main#content #hb-one-coupon .showcoupon { display: none !important; }
main#content #hb-one-coupon .hb-coupon-info,
main#content #hb-one-login .hb-login-info,
main#content #hb-one-login .woocommerce-info,
main#content #hb-one-login .woocommerce-form-login-toggle {
    cursor: pointer !important;
}
main#content #hb-one-coupon form.checkout_coupon[style*="display: block"] {
    display: flex !important;
}
main#content .woocommerce-checkout p.terms,
main#content .woocommerce-checkout p.terms *,
main#content .woocommerce-checkout .woocommerce-terms-and-conditions-wrapper,
main#content .woocommerce-checkout .woocommerce-terms-and-conditions-checkbox-text {
    cursor: pointer !important;
}
main#content .woocommerce-checkout p.terms a,
main#content .woocommerce-checkout .woocommerce-terms-and-conditions-wrapper a {
    pointer-events: auto !important;
}
@media (max-width: 768px) {
    main#content #hb-one-coupon {
        margin-top: 16px !important;
    }
    main#content #hb-one-coupon .woocommerce-info,
    main#content #hb-one-coupon .hb-coupon-info {
        display: grid !important;
        grid-template-columns: 1fr 1.1fr !important;
        align-items: center !important;
        gap: 10px !important;
        min-height: 64px !important;
        padding: 12px 14px !important;
        background: #111827 !important;
        border: 1px solid #263244 !important;
        border-radius: 10px !important;
        text-align: left !important;
    }
    main#content #hb-one-coupon .hb-coupon-label {
        font-size: 14px !important;
        color: #cbd5e1 !important;
        line-height: 1.25 !important;
    }
    main#content #hb-one-coupon .hb-show-coupon {
        width: 100% !important;
        min-width: 0 !important;
        min-height: 44px !important;
        padding: 8px 10px !important;
        font-size: 13px !important;
        line-height: 1.25 !important;
        white-space: normal !important;
    }
    main#content #hb-one-coupon form.checkout_coupon[style*="display: block"] {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 10px !important;
        padding: 12px !important;
        margin-top: 10px !important;
    }
    main#content #hb-one-coupon form.checkout_coupon .form-row,
    main#content #hb-one-coupon form.checkout_coupon .form-row-last {
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    main#content #hb-one-coupon form.checkout_coupon button[name="apply_coupon"] {
        width: 100% !important;
        min-height: 42px !important;
    }
    main#content #payment {
        display: flex !important;
        flex-direction: column !important;
    }
    main#content #payment ul.payment_methods { order: 10 !important; }
    main#content #payment .hb-mobile-create-account { order: 20 !important; display: block !important; }
    main#content #payment #hb-one-login { order: 21 !important; display: block !important; visibility: visible !important; opacity: 1 !important; }
    main#content #payment #hb-one-login .woocommerce-info,
    main#content #payment #hb-one-login .woocommerce-form-login-toggle,
    main#content #payment #hb-one-login .hb-login-info {
        display: grid !important;
        grid-template-columns: 1fr 1.1fr !important;
        gap: 10px !important;
        min-height: 64px !important;
        padding: 12px 14px !important;
    }
    main#content #payment #hb-one-login .hb-show-login {
        width: 100% !important;
        min-width: 0 !important;
        min-height: 44px !important;
        font-size: 13px !important;
    }
}

/* === HB v1.0.8 hard coupon click + mobile duplicate cleanup === */
main#content #hb-one-coupon .hb-show-coupon,
main#content #hb-one-coupon .hb-coupon-info {
    pointer-events: auto !important;
    cursor: pointer !important;
}
main#content #hb-one-coupon form.checkout_coupon {
    cursor: default !important;
}
main#content #hb-one-coupon form.checkout_coupon[style*="display: block"],
main#content #hb-one-coupon form.checkout_coupon[style*="display:block"] {
    display: flex !important;
}
@media (max-width: 768px) {
    /* On mobile the only coupon should be the one inside Product/Summary block. */
    main#content .woocommerce-billing-fields > #hb-one-coupon,
    main#content .woocommerce-billing-fields .woocommerce-billing-fields__field-wrapper > #hb-one-coupon,
    main#content .wfacp_billing_form_field > #hb-one-coupon,
    main#content .wfacp-billing-fields > #hb-one-coupon {
        display: none !important;
        visibility: hidden !important;
        opacity: 0 !important;
        height: 0 !important;
        overflow: hidden !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    main#content .hb-left-summary #hb-one-coupon {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }
    main#content .hb-left-summary #hb-one-coupon .hb-coupon-info {
        display: grid !important;
        grid-template-columns: 1fr 1.1fr !important;
        align-items: center !important;
        gap: 10px !important;
        min-height: 64px !important;
        padding: 12px 14px !important;
    }
    main#content #hb-one-coupon form.checkout_coupon[style*="display: block"],
    main#content #hb-one-coupon form.checkout_coupon[style*="display:block"] {
        display: grid !important;
    }
}

/* === HB v1.0.9 independent coupon/login UI, no Woo toggle dependency === */
main#content .woocommerce-form-coupon-toggle,
main#content .woocommerce-form-login-toggle,
main#content form.checkout_coupon:not(#hb-one-coupon *),
main#content form.woocommerce-form-coupon:not(#hb-one-coupon *),
main#content form.login.woocommerce-form-login:not(#hb-one-login *),
main#content .wfacp_coupon_field_box,
main#content .wfacp_coupon_section,
main#content .wfacp_coupon_wrapper,
main#content .wfacp_form_coupon_wrap,
main#content .wfacp_show_coupon_msg,
main#content .wfacp-coupon-page {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
}

main#content #hb-one-coupon,
main#content #hb-one-login {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

main#content #hb-one-coupon .hb-coupon-info,
main#content #hb-one-login .hb-login-info {
    display: grid !important;
    grid-template-columns: 1fr auto !important;
    align-items: center !important;
    gap: 12px !important;
    background: #111827 !important;
    border: 1px solid #2d3748 !important;
    border-radius: 8px !important;
    padding: 10px 12px !important;
    min-height: 52px !important;
    cursor: pointer !important;
    color: #cbd5e1 !important;
}

main#content #hb-one-coupon .hb-coupon-label,
main#content #hb-one-login .hb-login-label {
    color: #cbd5e1 !important;
    font-size: 13px !important;
    line-height: 1.3 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-weight: 500 !important;
}

main#content #hb-one-coupon .hb-show-coupon,
main#content #hb-one-login .hb-show-login {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 38px !important;
    padding: 8px 16px !important;
    background: transparent !important;
    border: 1.5px solid #38bdf8 !important;
    border-radius: 7px !important;
    color: #c4b5fd !important;
    font-size: 12px !important;
    line-height: 1.25 !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    cursor: pointer !important;
    box-shadow: none !important;
    white-space: nowrap !important;
}

main#content #hb-one-coupon .hb-coupon-form {
    display: none;
    background: #111827 !important;
    border: 1px solid #1e293b !important;
    border-radius: 8px !important;
    padding: 10px !important;
    margin-top: 8px !important;
    grid-template-columns: 1fr auto !important;
    gap: 8px !important;
}
main#content #hb-one-coupon .hb-coupon-form[style*="display: block"],
main#content #hb-one-coupon .hb-coupon-form[style*="display:block"] {
    display: grid !important;
}

main#content #hb-one-coupon #hb_coupon_code {
    background: #0d1117 !important;
    border: 1.5px solid #2d3748 !important;
    color: #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 10px 12px !important;
    width: 100% !important;
    font-size: 13px !important;
    box-shadow: none !important;
}
main#content #hb-one-coupon .hb-apply-coupon {
    background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 10px 18px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
}
main#content #hb-one-coupon .hb-coupon-response {
    grid-column: 1 / -1 !important;
    color: #94a3b8 !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
}
main#content #hb-one-coupon .hb-coupon-response .woocommerce-error,
main#content #hb-one-coupon .hb-coupon-response .woocommerce-message,
main#content #hb-one-coupon .hb-coupon-response .woocommerce-info {
    margin: 6px 0 0 0 !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
    display: block !important;
}

main#content #hb-one-login .hb-login-form {
    display: none;
    background: #0d1117 !important;
    border: 1px solid #2d3748 !important;
    border-radius: 8px !important;
    padding: 16px !important;
    margin: 10px 0 0 0 !important;
    color: #e2e8f0 !important;
}
main#content #hb-one-login .hb-login-form[style*="display: block"],
main#content #hb-one-login .hb-login-form[style*="display:block"] {
    display: block !important;
}
main#content #hb-one-login .hb-login-text {
    color: #e2e8f0 !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
    margin: 0 0 14px 0 !important;
}
main#content #hb-one-login .hb-login-form label {
    color: #94a3b8 !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
    margin-bottom: 6px !important;
    display: block !important;
}
main#content #hb-one-login .hb-login-form .input-text {
    background: #111827 !important;
    border: 1.5px solid #2d3748 !important;
    color: #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 10px 12px !important;
    width: 100% !important;
}
main#content #hb-one-login .hb-login-submit {
    width: 100% !important;
    background: transparent !important;
    border: 1.5px solid #38bdf8 !important;
    color: #fff !important;
    border-radius: 0 !important;
    padding: 13px 20px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
}
main#content #hb-one-login .lost_password a { color: #c4b5fd !important; }
main#content #hb-one-login .hb-login-remember label {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    color: #e2e8f0 !important;
}
main#content p.terms,
main#content .woocommerce-terms-and-conditions-wrapper {
    cursor: pointer !important;
}

@media (max-width: 768px) {
    main#content .woocommerce-billing-fields .hb-coupon-wrap,
    main#content .wfacp_billing_form_field .hb-coupon-wrap,
    main#content .wfacp-billing-fields .hb-coupon-wrap {
        display: none !important;
        visibility: hidden !important;
        opacity: 0 !important;
    }
    main#content .hb-left-summary #hb-one-coupon {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        margin-top: 18px !important;
    }
    main#content #hb-one-coupon .hb-coupon-info,
    main#content #hb-one-login .hb-login-info {
        grid-template-columns: 1fr auto !important;
        min-height: 70px !important;
        padding: 14px 16px !important;
    }
    main#content #hb-one-coupon .hb-coupon-label,
    main#content #hb-one-login .hb-login-label {
        font-size: 16px !important;
    }
    main#content #hb-one-coupon .hb-show-coupon,
    main#content #hb-one-login .hb-show-login {
        min-height: 46px !important;
        max-width: 210px !important;
        white-space: normal !important;
        font-size: 14px !important;
        text-align: center !important;
    }
    main#content #hb-one-coupon .hb-coupon-form[style*="display: block"],
    main#content #hb-one-coupon .hb-coupon-form[style*="display:block"] {
        display: block !important;
    }
    main#content #hb-one-coupon #hb_coupon_code,
    main#content #hb-one-coupon .hb-apply-coupon {
        width: 100% !important;
        margin-bottom: 8px !important;
    }
    main#content #payment .hb-mobile-create-account,
    main#content #payment #hb-one-login {
        margin-top: 14px !important;
        margin-bottom: 14px !important;
    }
}

/* === HB v1.1.0 compact login form, matched to coupon design === */
main#content #hb-one-login .hb-login-form {
    display: none !important;
    background: #111827 !important;
    border: 1px solid #1e293b !important;
    border-radius: 8px !important;
    padding: 10px !important;
    margin-top: 8px !important;
    color: #e2e8f0 !important;
    gap: 10px 12px !important;
    grid-template-columns: 1fr 1fr !important;
    align-items: end !important;
}
main#content #hb-one-login .hb-login-form[style*="display: block"],
main#content #hb-one-login .hb-login-form[style*="display:block"] {
    display: grid !important;
}
main#content #hb-one-login .hb-login-text {
    grid-column: 1 / -1 !important;
    color: #94a3b8 !important;
    font-size: 12px !important;
    line-height: 1.45 !important;
    margin: 0 0 2px 0 !important;
}
main#content #hb-one-login .hb-login-form .form-row {
    margin: 0 !important;
    padding: 0 !important;
}
main#content #hb-one-login .hb-login-form .form-row-first {
    grid-column: 1 / 2 !important;
    width: 100% !important;
    float: none !important;
}
main#content #hb-one-login .hb-login-form .form-row-last {
    grid-column: 2 / 3 !important;
    width: 100% !important;
    float: none !important;
}
main#content #hb-one-login .hb-login-form label {
    color: #94a3b8 !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: .05em !important;
    margin: 0 0 6px 0 !important;
    display: block !important;
}
main#content #hb-one-login .hb-login-form .input-text {
    background: #0d1117 !important;
    border: 1.5px solid #2d3748 !important;
    color: #e2e8f0 !important;
    border-radius: 8px !important;
    padding: 10px 12px !important;
    width: 100% !important;
    min-height: 42px !important;
    font-size: 13px !important;
    box-shadow: none !important;
}
main#content #hb-one-login .hb-login-form .input-text:focus {
    border-color: #6366f1 !important;
    box-shadow: 0 0 0 3px rgba(99,102,241,0.12) !important;
}
main#content #hb-one-login .hb-login-remember {
    grid-column: 1 / 2 !important;
    order: 4 !important;
    align-self: center !important;
}
main#content #hb-one-login .hb-login-remember label {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    color: #cbd5e1 !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    margin: 0 !important;
}
main#content #hb-one-login .lost_password {
    grid-column: 2 / 3 !important;
    order: 5 !important;
    justify-self: end !important;
    align-self: center !important;
    margin: 0 !important;
    padding: 0 !important;
}
main#content #hb-one-login .lost_password a {
    color: #c4b5fd !important;
    font-size: 12px !important;
    text-decoration: none !important;
}
main#content #hb-one-login .lost_password a:hover {
    color: #a5b4fc !important;
    text-decoration: underline !important;
}
main#content #hb-one-login .hb-login-form .form-row:has(.hb-login-submit),
main#content #hb-one-login .hb-login-form p:has(.hb-login-submit) {
    grid-column: 1 / -1 !important;
    order: 6 !important;
}
main#content #hb-one-login .hb-login-submit {
    width: 100% !important;
    background: linear-gradient(135deg, #6366f1, #8b5cf6) !important;
    border: none !important;
    color: #fff !important;
    border-radius: 8px !important;
    padding: 11px 18px !important;
    min-height: 42px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    box-shadow: 0 4px 14px rgba(99, 102, 241, 0.3) !important;
}
main#content #hb-one-login .hb-login-submit:hover {
    opacity: .92 !important;
    transform: translateY(-1px) !important;
}

@media (max-width: 768px) {
    main#content #hb-one-login .hb-login-form {
        grid-template-columns: 1fr !important;
        padding: 12px !important;
        gap: 10px !important;
    }
    main#content #hb-one-login .hb-login-form .form-row-first,
    main#content #hb-one-login .hb-login-form .form-row-last,
    main#content #hb-one-login .hb-login-remember,
    main#content #hb-one-login .lost_password,
    main#content #hb-one-login .hb-login-form .form-row:has(.hb-login-submit),
    main#content #hb-one-login .hb-login-form p:has(.hb-login-submit) {
        grid-column: 1 / -1 !important;
        justify-self: stretch !important;
    }
    main#content #hb-one-login .lost_password {
        justify-self: start !important;
    }
}


/* === HB Checkout v1.1.3: clean WooCommerce order-pay endpoint layout === */
body.hb-order-pay-page,
body.woocommerce-order-pay {
    background: #030712 !important;
}

body.hb-order-pay-page main#content .woocommerce,
body.woocommerce-order-pay main#content .woocommerce {
    max-width: 1180px !important;
    margin: 0 auto !important;
    padding: 0 18px 80px !important;
}

body.hb-order-pay-page main#content form#order_review,
body.woocommerce-order-pay main#content form#order_review {
    display: grid !important;
    grid-template-columns: minmax(0, 1.08fr) minmax(360px, 430px) !important;
    gap: 28px !important;
    align-items: start !important;
    width: 100% !important;
}

body.hb-order-pay-page main#content form#order_review > .hb-left-summary,
body.woocommerce-order-pay main#content form#order_review > .hb-left-summary {
    grid-column: 1 !important;
    grid-row: 1 / span 3 !important;
    min-width: 0 !important;
    width: 100% !important;
    background: rgba(15, 23, 42, 0.88) !important;
    border: 1px solid rgba(0, 170, 255, 0.20) !important;
    border-radius: 22px !important;
    padding: 22px !important;
    box-shadow: 0 18px 55px rgba(0, 0, 0, 0.34) !important;
}

body.hb-order-pay-page main#content form#order_review > #payment,
body.woocommerce-order-pay main#content form#order_review > #payment {
    grid-column: 2 !important;
    grid-row: 1 !important;
    min-width: 0 !important;
    width: 100% !important;
    margin-top: 0 !important;
    position: sticky !important;
    top: 24px !important;
    display: block !important;
}

body.hb-order-pay-page main#content form#order_review > #hb-one-login,
body.woocommerce-order-pay main#content form#order_review > #hb-one-login,
body.hb-order-pay-page main#content #hb-one-login,
body.woocommerce-order-pay main#content #hb-one-login {
    display: none !important;
}

body.hb-order-pay-page main#content form#order_review table.shop_table,
body.woocommerce-order-pay main#content form#order_review table.shop_table {
    width: 100% !important;
    margin: 0 !important;
}

body.hb-order-pay-page main#content #payment ul.payment_methods li label,
body.woocommerce-order-pay main#content #payment ul.payment_methods li label {
    min-height: 68px !important;
}

body.hb-order-pay-page main#content #payment .form-row,
body.woocommerce-order-pay main#content #payment .form-row {
    margin-top: 16px !important;
}

@media (max-width: 900px) {
    body.hb-order-pay-page main#content form#order_review,
    body.woocommerce-order-pay main#content form#order_review {
        display: block !important;
    }

    body.hb-order-pay-page main#content form#order_review > #payment,
    body.woocommerce-order-pay main#content form#order_review > #payment {
        position: static !important;
        margin-top: 18px !important;
    }
}

/* === HB Checkout v1.1.6: restore payment method cards on order-pay without checkout form class === */
body.hb-order-pay-page main#content #payment ul.payment_methods,
body.woocommerce-order-pay main#content #payment ul.payment_methods {
    list-style: none !important;
    margin: 0 0 20px 0 !important;
    padding: 0 0 20px 0 !important;
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 8px !important;
    border-bottom: 1px solid #1e293b !important;
}
body.hb-order-pay-page main#content #payment ul.payment_methods::before,
body.woocommerce-order-pay main#content #payment ul.payment_methods::before {
    display: none !important;
}
body.hb-order-pay-page main#content #payment ul.payment_methods li,
body.woocommerce-order-pay main#content #payment ul.payment_methods li {
    padding: 0 !important;
    margin: 0 !important;
    position: relative !important;
}
body.hb-order-pay-page main#content #payment ul.payment_methods li input[type="radio"],
body.woocommerce-order-pay main#content #payment ul.payment_methods li input[type="radio"] {
    position: absolute !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    pointer-events: none !important;
}
body.hb-order-pay-page main#content #payment ul.payment_methods li label > img,
body.woocommerce-order-pay main#content #payment ul.payment_methods li label > img {
    display: none !important;
}
body.hb-order-pay-page main#content #payment ul.payment_methods li label,
body.woocommerce-order-pay main#content #payment ul.payment_methods li label {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 8px 6px !important;
    background: #111827 !important;
    border: 1.5px solid #1e293b !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    margin: 0 !important;
    width: 100% !important;
    height: 70px !important;
    line-height: 1.1 !important;
    font-size: .8rem !important;
    box-sizing: border-box !important;
    text-align: center !important;
    transition: border-color 0.15s, background 0.15s !important;
    position: relative !important;
    overflow: hidden !important;
}
body.hb-order-pay-page main#content #payment ul.payment_methods li label svg,
body.woocommerce-order-pay main#content #payment ul.payment_methods li label svg {
    max-height: 55px !important;
    max-width: 110px !important;
    width: auto !important;
    height: auto !important;
    display: block !important;
    flex-shrink: 0 !important;
    filter: none !important;
    opacity: 1 !important;
}
body.hb-order-pay-page main#content #payment ul.payment_methods li label span,
body.woocommerce-order-pay main#content #payment ul.payment_methods li label span {
    font-size: 9px !important;
    color: #64748b !important;
    font-weight: 500 !important;
    text-align: center !important;
    line-height: 1.2 !important;
    max-width: 100% !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    margin-top: 3px !important;
}
body.hb-order-pay-page main#content #payment ul.payment_methods li label:hover,
body.woocommerce-order-pay main#content #payment ul.payment_methods li label:hover {
    border-color: #334155 !important;
    background: #1a2235 !important;
}
body.hb-order-pay-page main#content #payment ul.payment_methods li input[type="radio"]:checked + label,
body.hb-order-pay-page main#content #payment ul.payment_methods li.active label,
body.woocommerce-order-pay main#content #payment ul.payment_methods li input[type="radio"]:checked + label,
body.woocommerce-order-pay main#content #payment ul.payment_methods li.active label {
    border-color: #6366f1 !important;
    background: rgba(99,102,241,0.08) !important;
}
body.hb-order-pay-page main#content #payment .payment_box,
body.woocommerce-order-pay main#content #payment .payment_box {
    display: none !important;
}
@media (max-width: 480px) {
    body.hb-order-pay-page main#content #payment ul.payment_methods,
    body.woocommerce-order-pay main#content #payment ul.payment_methods {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}
