/* ============================================
   WOOCOMMERCE CHECKOUT - REFERENCE SCREENSHOT MATCH
   ============================================ */

/* CSS Variables */
:root {
    --checkout-bg: #f5f5f5;
    --checkout-box-bg: #ffffff;
    --checkout-primary: #1a1a1a;
    --checkout-secondary: #6b7280;
    --checkout-border: #e5e7eb;
    --checkout-button-bg: #111111;
    --checkout-green: #00d66c;
    --checkout-radius-box: 10px;
    --checkout-radius-input: 6px;
    --checkout-radius-button: 50px;
    --checkout-spacing: 16px;
}

/* ============================================
   GLOBAL CHECKOUT PAGE
   ============================================ */
.woocommerce-checkout {
    background-color: var(--checkout-bg) !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
    padding: 30px 20px 60px !important;
}

.woocommerce-checkout * {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif !important;
    box-sizing: border-box !important;
}

/* Hide page title */
.woocommerce-checkout .entry-header {
    padding-top: 20px !important;
}

/* .woocommerce-checkout .entry-title,
.woocommerce-checkout h1.entry-title {
    display: none !important;
} */

/* Max-width container */
.woocommerce-checkout .woocommerce {
    max-width: 1160px;
    margin: 0 auto;
}

/* ============================================
   LAYOUT — GRID
   ============================================ */
.checkout-grid {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 24px;
    align-items: start;
}

.checkout-left {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.checkout-right {
    position: sticky;
    top: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* ============================================
   CHECKOUT BOX (white cards)
   ============================================ */
.checkout-box {
    background: var(--checkout-box-bg);
    border-radius: var(--checkout-radius-box);
    padding: 28px 28px 24px;
    margin-bottom: 12px;
    border: 1px solid var(--checkout-border);
}

.checkout-box:last-child {
    margin-bottom: 0;
}

.checkout-box h3 {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--checkout-primary);
    margin: 0 0 6px 0;
    letter-spacing: -0.01em;
}

.checkout-box .section-desc {
    font-size: 0.8125rem;
    color: var(--checkout-secondary);
    margin-bottom: 18px;
    line-height: 1.5;
}

.checkout-box .section-desc strong {
    color: #c0392b;
    font-weight: 600;
}

/* ============================================
   EXPRESS CHECKOUT
   ============================================ */
.express-checkout {
    text-align: center;
}

.express-checkout h3 {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--checkout-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 14px;
}

.express-checkout-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 14px;
    font-size: 0.8125rem;
    color: var(--checkout-secondary);
}

.express-checkout-divider::before,
.express-checkout-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--checkout-border);
}

/* ============================================
   CONTACT INFORMATION
   ============================================ */
.contact-info-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.contact-info-header h3 {
    margin: 0;
}

.login-link {
    background: var(--checkout-button-bg);
    color: white;
    padding: 7px 18px;
    border-radius: var(--checkout-radius-button);
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    transition: opacity 0.2s;
    white-space: nowrap;
}

.login-link:hover {
    opacity: 0.8;
    color: white;
}

.contact-description {
    font-size: 0.8125rem;
    color: var(--checkout-secondary);
    margin-bottom: 18px;
    line-height: 1.5;
}

/* ============================================
   FORM FIELDS
   ============================================ */
.woocommerce-checkout .form-row {
    margin-bottom: 14px !important;
    padding: 0 !important;
}

.woocommerce-checkout .form-row input[type="text"],
.woocommerce-checkout .form-row input[type="email"],
.woocommerce-checkout .form-row input[type="tel"],
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
    width: 100% !important;
    padding: 11px 14px !important;
    border: 1px solid var(--checkout-border) !important;
    border-radius: var(--checkout-radius-input) !important;
    font-size: 0.9rem !important;
    color: var(--checkout-primary) !important;
    background: #ffffff !important;
    transition: border-color 0.2s !important;
    box-shadow: none !important;
    height: auto !important;
}

.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
    outline: none !important;
    border-color: var(--checkout-primary) !important;
}

.woocommerce-checkout .form-row label {
    font-size: 0.8125rem !important;
    font-weight: 500 !important;
    color: var(--checkout-secondary) !important;
    margin-bottom: 6px !important;
    display: block !important;
}

.woocommerce-checkout .form-row label .required {
    color: #e53e3e !important;
}

/* Guest notice */
.woocommerce-checkout .guest-notice {
    font-size: 0.8125rem;
    color: var(--checkout-secondary);
    padding: 8px 12px;
    background: #f9fafb;
    border-radius: 6px;
    margin-bottom: 14px;
}

/* Checkbox rows */
.woocommerce-checkout .form-row.woocommerce-form-row--wide.checkbox {
    margin: 10px 0 !important;
}

.woocommerce-checkout .woocommerce-form__label-for-checkbox {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 0.8125rem !important;
    color: var(--checkout-secondary) !important;
    cursor: pointer !important;
    font-weight: 400 !important;
}

.woocommerce-checkout input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    border-radius: 3px !important;
    border: 1.5px solid #d1d5db !important;
    cursor: pointer !important;
    accent-color: var(--checkout-button-bg) !important;
    flex-shrink: 0 !important;
}

/* Two-column field rows (shipping address) */
.custom-shipping-fields .field-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.custom-shipping-fields .field-two-col .form-row {
    margin-bottom: 0 !important;
}

.custom-shipping-fields .field-full {
    display: block;
}

/* ============================================
   SELECT2 / WC Select Overrides
   ============================================ */
.woocommerce-checkout .select2-container--default .select2-selection--single {
    border: 1px solid var(--checkout-border) !important;
    border-radius: var(--checkout-radius-input) !important;
    height: 42px !important;
    padding: 0 14px !important;
    display: flex !important;
    align-items: center !important;
    background: #ffffff !important;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
    line-height: normal !important;
    padding: 0 !important;
    font-size: 0.9rem !important;
    color: var(--checkout-primary) !important;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
    top: 50% !important;
    transform: translateY(-50%) !important;
}

/* ============================================
   APARTMENT TOGGLE
   ============================================ */
.apartment-toggle-row {
    margin-bottom: 14px !important;
}

.apartment-toggle-link {
    font-size: 0.8125rem;
    color: var(--checkout-secondary);
    text-decoration: none;
    transition: color 0.2s;
    display: inline-block;
    margin-bottom: 4px;
}

.apartment-toggle-link:hover {
    color: var(--checkout-primary);
    text-decoration: underline;
}

.apartment-field .form-row {
    margin-bottom: 0 !important;
    margin-top: 10px !important;
}

/* ============================================
   SAME BILLING ROW
   ============================================ */
.same-billing-row {
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid var(--checkout-border);
}

.same-billing-label {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.8125rem;
    color: var(--checkout-secondary);
    cursor: pointer;
}

.same-billing-label input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    accent-color: var(--checkout-button-bg) !important;
    flex-shrink: 0 !important;
}

/* ============================================
   DELIVERY TOGGLE (Section 2)
   ============================================ */
.delivery-section h3 {
    margin-bottom: 6px !important;
}

.delivery-options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 14px;
}

.delivery-option {
    padding: 16px 18px;
    border: 1.5px solid var(--checkout-border);
    border-radius: var(--checkout-radius-input);
    background: #ffffff;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 14px;
    transition: all 0.2s;
}

.delivery-option svg {
    flex-shrink: 0;
    color: var(--checkout-secondary);
    transition: color 0.2s;
}

.delivery-option-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.delivery-option strong {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--checkout-primary);
    transition: color 0.2s;
}

.delivery-option .delivery-price {
    font-size: 0.75rem;
    color: var(--checkout-secondary);
    transition: color 0.2s;
}

.delivery-option:hover {
    border-color: #9ca3af;
}

.delivery-option.active {
    background: var(--checkout-button-bg);
    border-color: var(--checkout-button-bg);
}

.delivery-option.active svg,
.delivery-option.active strong,
.delivery-option.active .delivery-price {
    color: white !important;
}

/* ============================================
   SHIPPING OPTIONS (Section 4)
   ============================================ */
.shipping-options-section h3 {
    margin-bottom: 14px !important;
}

.shipping-options-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.shipping-option-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--checkout-border);
    cursor: pointer;
    transition: background 0.15s;
}

.shipping-option-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.shipping-option-item:first-child {
    padding-top: 0;
}

.shipping-option-item input[type="radio"] {
    width: 18px !important;
    height: 18px !important;
    border: 2px solid #d1d5db !important;
    border-radius: 50% !important;
    cursor: pointer !important;
    accent-color: var(--checkout-button-bg) !important;
    flex-shrink: 0 !important;
}

.shipping-option-label {
    flex: 1;
    font-size: 0.9rem;
    color: var(--checkout-primary);
    font-weight: 400;
}

.shipping-option-price {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--checkout-primary);
    margin-left: auto;
}

/* ============================================
   PAYMENT OPTIONS (Section 5)
   ============================================ */
.payment-section h3 {
    margin-bottom: 14px !important;
}

/* Reset WC payment methods list */
.woocommerce-checkout .payment-section .wc_payment_methods {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
}

.woocommerce-checkout .payment-section .wc_payment_methods li {
    padding: 0 !important;
    margin: 0 !important;
    border-bottom: 1px solid var(--checkout-border) !important;
}

.woocommerce-checkout .payment-section .wc_payment_methods li:last-child {
    border-bottom: none !important;
}

/* Payment method label row */
.woocommerce-checkout .payment-section .wc_payment_methods li label {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 14px 0 !important;
    cursor: pointer !important;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    color: var(--checkout-primary) !important;
    width: 100% !important;
}

.woocommerce-checkout .payment-section .wc_payment_methods li label img {
    height: 22px !important;
    width: auto !important;
    margin-left: auto !important;
    object-fit: contain !important;
}

.woocommerce-checkout .payment-section .wc_payment_methods li input[type="radio"] {
    width: 18px !important;
    height: 18px !important;
    flex-shrink: 0 !important;
    accent-color: var(--checkout-button-bg) !important;
    cursor: pointer !important;
}

/* Payment method description (card form, etc) */
.woocommerce-checkout .payment-section .payment_box {
    background: #f9fafb !important;
    border-radius: 6px !important;
    padding: 14px !important;
    margin: 0 0 12px 0 !important;
    font-size: 0.8125rem !important;
    color: var(--checkout-secondary) !important;
    border: 1px solid var(--checkout-border) !important;
}

.woocommerce-checkout .payment-section .payment_box p {
    font-size: 0.8125rem !important;
    margin-bottom: 10px !important;
}

/* ============================================
   ORDER NOTES (Section 6 - top)
   ============================================ */
.order-notes-section {
    padding: 20px 28px !important;
}

.order-note-toggle-label {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-size: 0.875rem;
    color: var(--checkout-primary);
    font-weight: 400;
}

.order-note-toggle-label input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    accent-color: var(--checkout-button-bg) !important;
    flex-shrink: 0 !important;
}

#order-note-wrapper {
    margin-top: 14px;
}

#order-note-wrapper .form-row {
    margin: 0 !important;
}

#order-note-wrapper textarea {
    min-height: 90px !important;
    resize: vertical !important;
}

/* ============================================
   TERMS + PLACE ORDER (Section 6 - bottom)
   ============================================ */
.checkout-terms-section {
    padding: 20px 28px !important;
}

.checkout-terms-section .woocommerce-terms-and-conditions-wrapper p {
    font-size: 0.8125rem;
    color: var(--checkout-secondary);
    margin-bottom: 10px;
    line-height: 1.6;
}

.checkout-terms-section .woocommerce-terms-and-conditions-wrapper p a {
    color: var(--checkout-primary);
    text-decoration: underline;
}

.checkout-terms-section .woocommerce-form__label-for-checkbox {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    font-size: 0.8125rem !important;
    color: var(--checkout-secondary) !important;
    margin-bottom: 18px !important;
    line-height: 1.5 !important;
}

/* Place Order Button */
.place-order-btn,
.woocommerce-checkout #place_order {
    width: 100% !important;
    padding: 15px 20px !important;
    background: var(--checkout-button-bg) !important;
    color: white !important;
    border: none !important;
    border-radius: var(--checkout-radius-button) !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: opacity 0.2s !important;
    letter-spacing: 0.01em !important;
    display: block !important;
}

.place-order-btn:hover,
.woocommerce-checkout #place_order:hover {
    opacity: 0.85 !important;
}

.woocommerce-checkout .form-row.place-order {
    display: none !important;
    /* We use our custom place order in checkout-terms-section */
}

/* ============================================
   ORDER SUMMARY SIDEBAR
   ============================================ */
.order-summary {
    background: var(--checkout-box-bg) !important;
    border-radius: var(--checkout-radius-box) !important;
    padding: 24px !important;
    border: 1px solid var(--checkout-border) !important;
    margin-bottom: 0 !important;
}

.order-summary h3 {
    font-size: 1rem !important;
    font-weight: 600 !important;
    margin: 0 0 18px 0 !important;
    color: var(--checkout-primary) !important;
}

/* Product Items */
.checkout-items-list {
    border-bottom: 1px solid var(--checkout-border);
    margin-bottom: 18px;
    padding-bottom: 4px;
}

.checkout-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid #f3f4f6;
}

.checkout-item:last-child {
    border-bottom: none;
}

.checkout-item-image {
    width: 60px;
    height: 60px;
    border-radius: 6px;
    overflow: hidden;
    position: relative;
    flex-shrink: 0;
    background: #f3f4f6;
}

.checkout-item-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.item-qty-badge {
    position: absolute;
    top: -5px;
    right: -5px;
    background: var(--checkout-button-bg);
    color: white;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.6875rem;
    font-weight: 600;
    border: 2px solid white;
}

.checkout-item-details {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}

.checkout-item-name {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--checkout-primary);
    line-height: 1.4;
    display: block;
}

.checkout-item-meta {
    font-size: 0.75rem;
    color: var(--checkout-secondary);
}

.checkout-item-meta p,
.checkout-item-meta dl,
.checkout-item-meta dt,
.checkout-item-meta dd {
    margin: 1px 0 !important;
    font-size: 0.75rem !important;
    color: var(--checkout-secondary) !important;
}

.checkout-item-price {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--checkout-primary);
    flex-shrink: 0;
    white-space: nowrap;
}

/* Totals */
.checkout-totals-section {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.totals-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
    font-size: 0.875rem;
    border-bottom: 1px solid #f3f4f6;
}

.totals-row:last-child {
    border-bottom: none;
}

.totals-row span:first-child {
    color: var(--checkout-secondary);
}

.totals-row span:last-child {
    color: var(--checkout-primary);
    font-weight: 500;
}

/* Shipping row values */
.totals-row.shipping-row .woocommerce-shipping-totals td {
    font-size: 0.875rem !important;
}

/* Coupon toggle link */
.coupon-row {
    border-bottom: 1px solid #f3f4f6 !important;
}

.coupon-toggle-link {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--checkout-secondary);
    text-decoration: none;
    font-size: 0.8125rem;
    transition: color 0.2s;
}

.coupon-toggle-link:hover {
    color: var(--checkout-primary);
    text-decoration: none;
}

/* Coupon input row */
.coupon-input-row {
    display: flex;
    gap: 8px;
    padding: 10px 0;
    border-bottom: 1px solid #f3f4f6;
    align-items: center;
}

.coupon-input-row input[type="text"] {
    flex: 1;
    padding: 9px 12px;
    border: 1px solid var(--checkout-border);
    border-radius: 6px;
    font-size: 0.875rem;
    background: #ffffff;
}

.coupon-apply-btn {
    padding: 9px 16px !important;
    background: var(--checkout-button-bg) !important;
    color: white !important;
    border: none !important;
    border-radius: 6px !important;
    font-size: 0.875rem !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
}

/* Total row */
.order-total-row {
    margin-top: 6px !important;
    padding-top: 16px !important;
    border-top: 1px solid var(--checkout-border) !important;
    border-bottom: none !important;
}

.order-total-row span:first-child {
    font-size: 1rem !important;
    font-weight: 700 !important;
    color: var(--checkout-primary) !important;
}

.order-total-row span:last-child {
    font-size: 1.125rem !important;
    font-weight: 700 !important;
    color: var(--checkout-primary) !important;
}

/* Sidebar Place Order Button */
.sidebar-place-order {
    margin-top: 18px;
}

.sidebar-place-order-btn {
    width: 100% !important;
    padding: 15px 20px !important;
    background: var(--checkout-button-bg) !important;
    color: white !important;
    border: none !important;
    border-radius: var(--checkout-radius-button) !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: opacity 0.2s !important;
    display: block !important;
    text-align: center !important;
}

.sidebar-place-order-btn:hover {
    opacity: 0.85 !important;
}

/* Return to Cart */
.return-to-cart {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--checkout-secondary);
    font-size: 0.8125rem;
    text-decoration: none;
    transition: color 0.2s;
    padding: 4px 0;
}

.return-to-cart:hover {
    color: var(--checkout-primary);
    text-decoration: none;
}

/* ============================================
   WC SHIPPING TOTALS (inside review-order)
   ============================================ */
.shipping-row .woocommerce-shipping-totals {
    background: none !important;
    border: none !important;
}

.shipping-row .woocommerce-shipping-totals td,
.shipping-row .woocommerce-shipping-totals th {
    background: none !important;
    border: none !important;
    padding: 0 !important;
    font-size: 0.875rem !important;
}

/* ============================================
   WC NOTICES
   ============================================ */
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-info {
    border-radius: 8px !important;
    margin-bottom: 16px !important;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 900px) {
    .checkout-grid {
        grid-template-columns: 1fr;
    }

    .checkout-right {
        position: static;
        order: -1;
    }

    .delivery-options {
        grid-template-columns: 1fr 1fr;
    }

    .custom-shipping-fields .field-two-col {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .woocommerce-checkout {
        padding: 16px 12px 40px !important;
    }

    .checkout-box {
        padding: 20px 18px !important;
    }

    .delivery-options {
        grid-template-columns: 1fr;
    }
}