/* =========================================================
   PHX CHECKOUT — MODERN CUSTOM LAYOUT
========================================================= */

.phx-checkout-page {
    --phx-bg: #f7f4ef;
    --phx-surface: #ffffff;
    --phx-surface-soft: #fcfaf7;
    --phx-border: #e8ddd1;
    --phx-border-strong: #dbc6af;
    --phx-text: #201710;
    --phx-muted: #6f6257;
    --phx-primary: #9a5417;
    --phx-primary-dark: #7d4310;
    --phx-success: #1f9d55;
    --phx-danger: #d63638;
    --phx-radius-xl: 24px;
    --phx-radius-lg: 18px;
    --phx-radius-md: 14px;
    --phx-radius-sm: 10px;
    --phx-shadow-sm: 0 8px 24px rgba(22, 16, 10, 0.05);
    --phx-shadow-md: 0 18px 42px rgba(22, 16, 10, 0.08);
    background: linear-gradient(180deg, #faf7f3 0%, #f4efe9 100%);
    padding: 42px 0 84px;
}

.phx-checkout-shell {
    max-width: 1360px;
    margin: 0 auto;
    padding: 0 20px;
}

.phx-checkout-header {
    margin-bottom: 28px;
}

.phx-checkout-header__content {
    max-width: 760px;
}

.phx-checkout-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: 999px;
    background: #f2e8df;
    border: 1px solid #ead7c5;
    color: var(--phx-primary);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.02em;
    margin-bottom: 14px;
}

.phx-checkout-title {
    margin: 0 0 10px;
    font-size: 44px;
    line-height: 1.06;
    font-weight: 800;
    color: var(--phx-text);
}

.phx-checkout-subtitle {
    margin: 0;
    max-width: 680px;
    font-size: 17px;
    line-height: 1.7;
    color: var(--phx-muted);
}

.phx-checkout-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(360px, 0.9fr);
    gap: 28px;
    align-items: start;
}

.phx-checkout-main,
.phx-checkout-sidebar {
    min-width: 0;
}

.phx-checkout-main {
    display: grid;
    gap: 24px;
}

.phx-checkout-sidebar {
    position: sticky;
    top: 110px;
}

.phx-card {
    background: var(--phx-surface);
    border: 1px solid var(--phx-border);
    border-radius: var(--phx-radius-xl);
    box-shadow: var(--phx-shadow-sm);
}

.phx-card--section {
    padding: 28px;
}

.phx-card--summary {
    padding: 26px;
    box-shadow: var(--phx-shadow-md);
}

.phx-card__head {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 24px;
}

.phx-card__icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #f7ede3;
    color: var(--phx-primary);
    flex-shrink: 0;
}

.phx-card__icon svg {
    width: 22px;
    height: 22px;
}

.phx-card__title {
    margin: 0 0 4px;
    font-size: 24px;
    line-height: 1.2;
    font-weight: 750;
    color: var(--phx-text);
}

.phx-card__text {
    margin: 0;
    font-size: 15px;
    line-height: 1.6;
    color: var(--phx-muted);
}

.phx-summary-head {
    margin-bottom: 20px;
}

.phx-summary-title {
    margin: 0 0 6px;
    font-size: 26px;
    line-height: 1.2;
    font-weight: 800;
    color: var(--phx-text);
}

.phx-summary-subtitle {
    margin: 0;
    color: var(--phx-muted);
    font-size: 14px;
    line-height: 1.6;
}

/* -----------------------------------------
   RESET WOOCOMMERCE FIELD FLOATS
------------------------------------------ */
.phx-checkout-form .form-row,
.phx-checkout-form .form-row-first,
.phx-checkout-form .form-row-last,
.phx-checkout-form .form-row-wide {
    float: none !important;
    clear: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

.phx-checkout-form .woocommerce-billing-fields > h3,
.phx-checkout-form .woocommerce-shipping-fields,
.phx-checkout-form .woocommerce-additional-fields > h3 {
    display: none !important;
}

/* -----------------------------------------
   BILLING / ORDER FIELD GRIDS
------------------------------------------ */
.phx-billing-wrap .woocommerce-billing-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}

.phx-order-fields-wrap {
    display: grid;
    gap: 18px;
}

.phx-billing-wrap .form-row-wide,
.phx-billing-wrap #billing_company_field,
.phx-billing-wrap #billing_country_field,
.phx-billing-wrap #billing_address_1_field,
.phx-billing-wrap #billing_address_2_field,
.phx-billing-wrap #billing_city_field,
.phx-billing-wrap #billing_state_field,
.phx-billing-wrap #billing_postcode_field,
.phx-billing-wrap #billing_phone_field,
.phx-billing-wrap #billing_email_field,
.phx-billing-wrap #travel_date_field {
    grid-column: 1 / -1;
}

/* -----------------------------------------
   LABELS
------------------------------------------ */
.phx-checkout-form label {
    display: block;
    margin: 0 0 9px;
    font-size: 14px;
    line-height: 1.45;
    font-weight: 700;
    color: var(--phx-text);
}

.phx-checkout-form abbr.required {
    color: var(--phx-danger);
    border: 0;
    text-decoration: none;
    font-weight: 800;
}

/* -----------------------------------------
   INPUTS
------------------------------------------ */
.phx-checkout-form input[type="text"],
.phx-checkout-form input[type="email"],
.phx-checkout-form input[type="tel"],
.phx-checkout-form input[type="number"],
.phx-checkout-form input[type="date"],
.phx-checkout-form input[type="password"],
.phx-checkout-form select,
.phx-checkout-form textarea,
.phx-checkout-form .select2-selection--single {
    width: 100% !important;
    min-height: 56px;
    padding: 14px 16px !important;
    border: 1px solid #ddcfbf !important;
    border-radius: var(--phx-radius-md) !important;
    background: #fff !important;
    color: var(--phx-text) !important;
    font-size: 15px !important;
    line-height: 1.45 !important;
    box-sizing: border-box !important;
    box-shadow: none !important;
    text-align: left !important;
    margin: 0 !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease !important;
}

.phx-checkout-form textarea {
    min-height: 140px;
    resize: vertical;
    padding-top: 16px !important;
}

.phx-checkout-form input::placeholder,
.phx-checkout-form textarea::placeholder {
    color: #9b8c7f;
}

.phx-checkout-form input:focus,
.phx-checkout-form select:focus,
.phx-checkout-form textarea:focus,
.phx-checkout-form .select2-container--focus .select2-selection--single,
.phx-checkout-form .select2-container--open .select2-selection--single {
    border-color: var(--phx-primary) !important;
    box-shadow: 0 0 0 4px rgba(154, 84, 23, 0.10) !important;
    background: #fffdfa !important;
    outline: none !important;
}

.phx-checkout-form .woocommerce-input-wrapper {
    display: block !important;
    width: 100% !important;
}

.phx-checkout-form .select2-container {
    width: 100% !important;
}

.phx-checkout-form .select2-selection--single {
    display: flex !important;
    align-items: center !important;
    height: 56px !important;
    padding: 0 !important;
}

.phx-checkout-form .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: 56px !important;
    padding-left: 16px !important;
    padding-right: 42px !important;
    color: var(--phx-text) !important;
}

.phx-checkout-form .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 56px !important;
    right: 12px !important;
}

/* -----------------------------------------
   ORDER REVIEW TABLE
------------------------------------------ */
.phx-order-review table.shop_table {
    width: 100%;
    border-collapse: collapse;
    border: 0 !important;
    margin: 0 0 18px;
    background: transparent !important;
}

.phx-order-review table.shop_table th,
.phx-order-review table.shop_table td {
    padding: 14px 0;
    border-top: 0 !important;
    border-bottom: 1px solid #eee3d7 !important;
    vertical-align: top;
}

.phx-order-review table.shop_table th {
    color: var(--phx-text);
    font-size: 14px;
    font-weight: 800;
}

.phx-order-review table.shop_table td {
    color: var(--phx-muted);
    font-size: 14px;
    line-height: 1.55;
}

.phx-order-review table.shop_table .product-name {
    color: var(--phx-text);
    font-weight: 600;
}

.phx-order-review table.shop_table .product-total,
.phx-order-review table.shop_table .order-total td,
.phx-order-review table.shop_table .order-total th {
    color: var(--phx-text);
    font-weight: 800;
}

.phx-order-review table.shop_table .order-total .amount {
    color: var(--phx-primary);
    font-size: 20px;
    font-weight: 800;
}

/* -----------------------------------------
   PAYMENT BLOCK
------------------------------------------ */
.phx-order-review #payment {
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    margin-top: 22px;
}

.phx-order-review #payment ul.wc_payment_methods {
    list-style: none;
    padding: 0;
    margin: 0 0 18px;
    display: grid;
    gap: 12px;
}

.phx-order-review #payment ul.wc_payment_methods li {
    margin: 0 !important;
    padding: 16px 16px 14px !important;
    background: #fffdf9;
    border: 1px solid #eadccb;
    border-radius: 16px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.phx-order-review #payment ul.wc_payment_methods li:hover {
    border-color: #d6b896;
}

.phx-order-review #payment ul.wc_payment_methods li input[type="radio"] {
    accent-color: var(--phx-primary);
    margin-right: 10px;
    transform: translateY(1px);
}

.phx-order-review #payment ul.wc_payment_methods li label {
    display: inline-flex !important;
    align-items: center;
    gap: 10px;
    margin: 0 !important;
    font-size: 15px;
    font-weight: 700;
    color: var(--phx-text);
    cursor: pointer;
}

.phx-order-review #payment ul.wc_payment_methods li img {
    max-height: 26px;
    width: auto;
}

.phx-order-review #payment .payment_box {
    margin: 12px 0 0 !important;
    padding: 16px !important;
    background: #f9f5f0 !important;
    border: 1px solid #e9dac9 !important;
    border-radius: 14px !important;
    color: var(--phx-muted);
    font-size: 14px;
    line-height: 1.65;
    box-shadow: none !important;
}

.phx-order-review #payment .payment_box::before {
    display: none !important;
}

/* -----------------------------------------
   TERMS + PLACE ORDER
------------------------------------------ */
.phx-order-review .woocommerce-terms-and-conditions-wrapper {
    margin-top: 18px;
}

.phx-order-review .woocommerce-form__label-for-checkbox,
.phx-order-review .woocommerce-terms-and-conditions-wrapper .woocommerce-form__label {
    display: flex !important;
    align-items: flex-start;
    gap: 10px;
    margin: 0 !important;
    color: var(--phx-muted);
    font-size: 14px;
    line-height: 1.6;
}

.phx-order-review .woocommerce-terms-and-conditions-wrapper input[type="checkbox"] {
    margin-top: 3px;
    accent-color: var(--phx-primary);
    flex-shrink: 0;
}

.phx-order-review #place_order {
    width: 100% !important;
    min-height: 58px;
    margin-top: 20px !important;
    border: 0 !important;
    border-radius: 16px !important;
    background: linear-gradient(180deg, #a35a1a 0%, #8a4a11 100%) !important;
    color: #fff !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    letter-spacing: 0.01em;
    box-shadow: 0 16px 30px rgba(138, 74, 17, 0.20);
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.phx-order-review #place_order:hover {
    transform: translateY(-1px);
    box-shadow: 0 18px 34px rgba(138, 74, 17, 0.24);
}

.phx-order-review #place_order:disabled,
.phx-order-review #place_order[disabled] {
    opacity: 0.65;
    cursor: not-allowed;
}

/* -----------------------------------------
   COUPON / NOTICES
------------------------------------------ */
.phx-checkout-page .woocommerce-error,
.phx-checkout-page .woocommerce-message,
.phx-checkout-page .woocommerce-info {
    margin: 0 0 18px !important;
    padding: 14px 16px !important;
    border-radius: 14px !important;
    border: 1px solid transparent !important;
    list-style: none !important;
    box-shadow: none !important;
}

.phx-checkout-page .woocommerce-message {
    background: #eefbf3 !important;
    border-color: #cbeed8 !important;
    color: #176b3b !important;
}

.phx-checkout-page .woocommerce-info {
    background: #eef5ff !important;
    border-color: #d8e6ff !important;
    color: #2451a6 !important;
}

.phx-checkout-page .woocommerce-error {
    background: #fff2f2 !important;
    border-color: #ffd2d2 !important;
    color: #9f1f1f !important;
}

/* -----------------------------------------
   RESPONSIVE
------------------------------------------ */
@media (max-width: 1100px) {
    .phx-checkout-grid {
        grid-template-columns: 1fr;
    }

    .phx-checkout-sidebar {
        position: static;
    }
}

@media (max-width: 767px) {
    .phx-checkout-page {
        padding: 28px 0 60px;
    }

    .phx-checkout-shell {
        padding: 0 14px;
    }

    .phx-checkout-title {
        font-size: 32px;
    }

    .phx-checkout-subtitle {
        font-size: 15px;
    }

    .phx-card--section,
    .phx-card--summary {
        padding: 18px;
        border-radius: 18px;
    }

    .phx-card__head {
        gap: 12px;
        margin-bottom: 20px;
    }

    .phx-card__icon {
        width: 42px;
        height: 42px;
        border-radius: 12px;
    }

    .phx-card__title,
    .phx-summary-title {
        font-size: 22px;
    }

    .phx-billing-wrap .woocommerce-billing-fields__field-wrapper {
        grid-template-columns: 1fr;
    }

    .phx-checkout-form input[type="text"],
    .phx-checkout-form input[type="email"],
    .phx-checkout-form input[type="tel"],
    .phx-checkout-form input[type="number"],
    .phx-checkout-form input[type="date"],
    .phx-checkout-form input[type="password"],
    .phx-checkout-form select,
    .phx-checkout-form textarea,
    .phx-checkout-form .select2-selection--single {
        min-height: 52px;
        font-size: 15px !important;
    }
}