/*
 * FifoZone — Order Flow Mobile-First Responsive CSS
 * File: CSS/fifozone-order-mobile.css
 * Covers: Checkout → Review → Payment → Order Success → Order Tracking → 
 *         Order Details → Order History → Cancel Order
 * Mobile-first: base styles target phones, media queries scale up
 */

/* ============================================================
   0. GLOBAL ORDER PAGE RESET
   ============================================================ */
*, *::before, *::after { box-sizing: border-box !important; }

html, body {
    overflow-x: hidden !important;
    max-width: 100vw !important;
}

/* ============================================================
   1. CHECKOUT SHELL & LAYOUT
   ============================================================ */
.fifozone-checkout-shell,
.fifozone-cart-shell {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 14px !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
}

/* Two-column grid → single column on mobile */
.fifo-checkout-layout {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
    width: 100% !important;
}

/* Summary sidebar: static and full-width on mobile */
.fifo-summary,
.fifo-order-summary-sidebar {
    position: static !important;
    width: 100% !important;
    order: -1 !important; /* Show summary at top on mobile */
}

/* ============================================================
   2. PREMIUM STEPPER — COMPACT ON MOBILE
   ============================================================ */
.fifo-premium-stepper {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 14px 16px !important;
    margin-bottom: 20px !important;
    border-radius: 16px !important;
    position: static !important; /* No sticky on mobile — wastes space */
    gap: 8px !important;
    overflow: hidden !important;
    width: 100% !important;
}

.fifo-step {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    flex-shrink: 0 !important;
}

/* Hide step label text on small phones to prevent overflow */
.fifo-step-label {
    display: none !important;
}

.fifo-step-icon {
    width: 32px !important;
    height: 32px !important;
    font-size: 14px !important;
    flex-shrink: 0 !important;
}

.fifo-stepper-line {
    flex: 1 !important;
    height: 3px !important;
    margin: 0 4px !important;
    min-width: 12px !important;
}

/* Show labels on tablet+ */
@media (min-width: 480px) {
    .fifo-step-label {
        display: inline !important;
        font-size: 13px !important;
    }
    .fifo-step-icon {
        width: 36px !important;
        height: 36px !important;
    }
    .fifo-stepper-line {
        margin: 0 10px !important;
    }
}

@media (min-width: 768px) {
    .fifo-premium-stepper {
        position: sticky !important;
        top: 16px !important;
        padding: 18px 32px !important;
        margin-bottom: 32px !important;
    }
    .fifo-step-label {
        font-size: 15px !important;
    }
    .fifo-step-icon {
        width: 40px !important;
        height: 40px !important;
    }
}

/* ============================================================
   3. GLASS CARDS — MOBILE PADDING
   ============================================================ */
.fifo-glass-card,
.fifo-card,
.fifo-form-card {
    padding: 18px 16px !important;
    border-radius: 16px !important;
    margin-bottom: 16px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

@media (min-width: 480px) {
    .fifo-glass-card,
    .fifo-card {
        padding: 24px 20px !important;
        border-radius: 20px !important;
    }
}

@media (min-width: 768px) {
    .fifo-glass-card,
    .fifo-card {
        padding: 32px !important;
        border-radius: 24px !important;
    }
}

/* ============================================================
   4. CHECKOUT FORM FIELDS — FULL WIDTH, NO FLOAT
   ============================================================ */

/* WooCommerce default form rows: kill floats */
.woocommerce-checkout .form-row,
.woocommerce form .form-row,
.woocommerce form .form-row-first,
.woocommerce form .form-row-last,
.woocommerce form .form-row-wide {
    float: none !important;
    width: 100% !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    clear: both !important;
    display: block !important;
    padding: 0 !important;
    margin-bottom: 16px !important;
    box-sizing: border-box !important;
}

.woocommerce-checkout .col2-set,
.woocommerce .col2-set {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
}

.woocommerce .col2-set .col-1,
.woocommerce .col2-set .col-2,
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
    float: none !important;
    width: 100% !important;
    margin: 0 0 24px 0 !important;
    padding: 0 !important;
}

/* Billing/shipping field wrappers */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper,
.woocommerce-additional-fields__field-wrapper {
    display: block !important;
    width: 100% !important;
}

/* Inputs: prevent iOS zoom + ensure full width */
.woocommerce form input[type="text"],
.woocommerce form input[type="email"],
.woocommerce form input[type="tel"],
.woocommerce form input[type="password"],
.woocommerce form input[type="number"],
.woocommerce form select,
.woocommerce form textarea,
.fifo-glass-card .input-text,
.fifo-glass-card select,
.fifo-glass-card textarea {
    font-size: 16px !important; /* Prevents iOS zoom */
    width: 100% !important;
    min-height: 48px !important;
    box-sizing: border-box !important;
    padding: 14px 16px !important;
    border-radius: 12px !important;
}

/* Order review / customer details containers */
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #order_review,
.woocommerce-checkout #customer_details {
    float: none !important;
    width: 100% !important;
}

@media (min-width: 768px) {
    .woocommerce .col2-set {
        flex-direction: row !important;
        gap: 24px !important;
    }
    .woocommerce .col2-set .col-1,
    .woocommerce .col2-set .col-2 {
        flex: 1 !important;
        width: auto !important;
        margin: 0 !important;
    }
}

/* ============================================================
   5. CHECKOUT REVIEW ORDER TABLE — RESPONSIVE
   ============================================================ */
.woocommerce-checkout-review-order-table,
.shop_table,
.woocommerce-table--order-details {
    width: 100% !important;
    table-layout: auto !important;
    border-collapse: collapse !important;
}

.woocommerce-checkout-review-order-table thead,
.woocommerce-checkout-review-order-table tfoot tr:first-child {
    display: none !important; /* Hide on tiny screens */
}

/* Stack table rows as card-style on mobile */
@media (max-width: 480px) {
    .woocommerce-checkout-review-order-table tbody tr {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 12px 0 !important;
        border-bottom: 1px solid #f3f4f6 !important;
    }
    .woocommerce-checkout-review-order-table tbody td {
        display: block !important;
        padding: 4px 8px !important;
        font-size: 14px !important;
    }
    .woocommerce-checkout-review-order-table tfoot tr {
        display: flex !important;
        justify-content: space-between !important;
        padding: 10px 8px !important;
    }
    .woocommerce-checkout-review-order-table tfoot td,
    .woocommerce-checkout-review-order-table tfoot th {
        display: block !important;
        font-size: 14px !important;
        white-space: nowrap !important;
    }
}

@media (min-width: 481px) {
    .woocommerce-checkout-review-order-table thead {
        display: table-header-group !important;
    }
    .woocommerce-checkout-review-order-table th,
    .woocommerce-checkout-review-order-table td {
        padding: 12px 10px !important;
        font-size: 14px !important;
    }
    .woocommerce-checkout-review-order-table .product-total {
        text-align: right !important;
        white-space: nowrap !important;
    }
}

/* ============================================================
   6. REVIEW ITEM CARDS (fifo-review-item)
   ============================================================ */
.fifo-review-item {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    padding: 16px !important;
    border-radius: 14px !important;
    margin-bottom: 12px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.fifo-review-img {
    width: 80px !important;
    height: 80px !important;
    border-radius: 10px !important;
    object-fit: contain !important;
    flex-shrink: 0 !important;
}

/* Row layout for the product line inside card */
.fifo-review-item-inner,
.fifo-product-line {
    display: flex !important;
    flex-direction: row !important;
    gap: 12px !important;
    align-items: flex-start !important;
    width: 100% !important;
}

.fifo-review-details {
    flex: 1 !important;
    min-width: 0 !important;
}

.fifo-review-title {
    font-size: 15px !important;
    line-height: 1.4 !important;
    word-break: break-word !important;
    margin-bottom: 6px !important;
}

.fifo-review-pricing {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-items: center !important;
}

.fifo-price-offer {
    font-size: 16px !important;
}

@media (min-width: 480px) {
    .fifo-review-item {
        flex-direction: row !important;
        padding: 20px !important;
    }
    .fifo-review-img {
        width: 100px !important;
        height: 100px !important;
    }
}

/* ============================================================
   7. DELIVERY ADDRESS DISPLAY
   ============================================================ */
.fifo-address-display {
    width: 100% !important;
    padding: 16px !important;
    border-radius: 14px !important;
    box-sizing: border-box !important;
    word-break: break-word !important;
}

.fifo-address-display p,
.fifo-address-display address {
    font-size: 14px !important;
    line-height: 1.7 !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    white-space: normal !important;
    max-width: 100% !important;
}

.fifo-btn-change {
    position: static !important;
    display: inline-block !important;
    margin-top: 12px !important;
    font-size: 14px !important;
}

.fifo-delivery-estimate {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 14px 16px !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    align-items: center !important;
    word-break: break-word !important;
}

@media (min-width: 480px) {
    .fifo-btn-change {
        position: absolute !important;
        top: 16px !important;
        right: 16px !important;
        margin: 0 !important;
    }
    .fifo-address-display {
        position: relative !important;
    }
}

/* ============================================================
   8. PAYMENT SECTION
   ============================================================ */
#payment,
.woocommerce-checkout #payment {
    background: transparent !important;
    border-radius: 0 !important;
    padding: 0 !important;
    width: 100% !important;
}

#payment ul.payment_methods {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 16px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
}

#payment ul.payment_methods li {
    background: #ffffff !important;
    border: 2px solid #f3f4f6 !important;
    border-radius: 14px !important;
    padding: 16px !important;
    cursor: pointer !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

#payment ul.payment_methods li label {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    width: 100% !important;
    flex-wrap: wrap !important;
}

#payment ul.payment_methods li .payment_box {
    margin-top: 12px !important;
    padding: 12px !important;
    background: #f8fafc !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    word-break: break-word !important;
}

.woocommerce-checkout #payment .place-order {
    padding: 16px 0 0 !important;
}

/* ============================================================
   9. ACTION BUTTONS — FULL WIDTH, TOUCH-FRIENDLY
   ============================================================ */

/* Place Order button */
#place_order,
.woocommerce-checkout #payment .place-order button,
.fifo-btn-primary,
.fifo-btn-secondary,
.fifo-btn-place,
button.button.alt,
input[type="submit"].button {
    width: 100% !important;
    min-height: 52px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    border-radius: 14px !important;
    padding: 14px 20px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-sizing: border-box !important;
    cursor: pointer !important;
    text-align: center !important;
    text-decoration: none !important;
}

/* Step navigation: stack on mobile */
.fifo-step-nav {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    margin-top: 24px !important;
    padding-top: 20px !important;
    border-top: 1px solid rgba(0,0,0,0.06) !important;
    width: 100% !important;
}

.fifo-step-nav button,
.fifo-step-nav a {
    width: 100% !important;
    min-height: 52px !important;
    font-size: 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

@media (min-width: 480px) {
    .fifo-step-nav {
        flex-direction: row !important;
        justify-content: space-between !important;
    }
    .fifo-step-nav button,
    .fifo-step-nav a {
        width: auto !important;
        min-width: 160px !important;
    }
}

/* ============================================================
   10. CHECKOUT LAYOUT: TWO COLUMNS ON TABLET+
   ============================================================ */
@media (min-width: 768px) {
    .fifozone-checkout-shell,
    .fifozone-cart-shell {
        padding: 0 24px !important;
        margin: 24px auto !important;
        max-width: 1200px !important;
    }
    .fifo-checkout-layout {
        display: grid !important;
        grid-template-columns: 1fr 360px !important;
        gap: 28px !important;
        align-items: start !important;
    }
    .fifo-summary,
    .fifo-order-summary-sidebar {
        position: sticky !important;
        top: 100px !important;
        order: 0 !important;
    }
}

@media (min-width: 1024px) {
    .fifo-checkout-layout {
        grid-template-columns: 1fr 400px !important;
        gap: 36px !important;
    }
    .fifozone-checkout-shell {
        padding: 0 32px !important;
        margin: 40px auto !important;
    }
}

/* ============================================================
   11. ORDER SUCCESS (THANK YOU PAGE)
   ============================================================ */

/* Success hero section */
.fifo-success-hero {
    text-align: center !important;
    padding: 40px 16px !important;
    border-radius: 16px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

.fifo-success-hero h1 {
    font-size: clamp(22px, 5vw, 36px) !important;
    line-height: 1.3 !important;
    margin-bottom: 12px !important;
    word-break: break-word !important;
}

.fifo-success-hero p {
    font-size: 15px !important;
    line-height: 1.6 !important;
    margin-bottom: 24px !important;
}

.fifo-check-anim {
    width: 72px !important;
    height: 72px !important;
    margin: 0 auto 24px !important;
}

/* Meta grid: 2 columns on mobile, 4 on desktop */
.fifo-thanks-meta-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
    margin: 0 auto 28px !important;
    width: 100% !important;
    max-width: 600px !important;
}

.fifo-thanks-meta-card {
    background: #f8fafc !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    padding: 14px 12px !important;
    text-align: left !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

.fifo-thanks-meta-label {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    color: #9ca3af !important;
    margin-bottom: 4px !important;
}

.fifo-thanks-meta-value {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #111827 !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
}

.fifo-thanks-meta-value.highlight {
    color: #7c3aed !important;
    font-size: 16px !important;
}

/* Address card inside success hero */
.fifo-thanks-address-card {
    text-align: left !important;
    padding: 16px !important;
    border-radius: 14px !important;
    margin: 0 auto 28px !important;
    width: 100% !important;
    max-width: 600px !important;
    box-sizing: border-box !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
}

/* Thank you action buttons: stack on mobile */
.fifo-thanks-actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    max-width: 480px !important;
    margin: 0 auto !important;
    width: 100% !important;
}

.fifo-thanks-actions a,
.fifo-thanks-actions .fifo-btn-primary,
.fifo-thanks-actions .fifo-btn-secondary {
    width: 100% !important;
    min-height: 52px !important;
    font-size: 15px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 12px !important;
    text-decoration: none !important;
    box-sizing: border-box !important;
}

@media (min-width: 480px) {
    .fifo-success-hero {
        padding: 60px 24px !important;
    }
    .fifo-check-anim {
        width: 90px !important;
        height: 90px !important;
    }
    .fifo-thanks-meta-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }
    .fifo-thanks-actions {
        flex-direction: row !important;
        flex-wrap: wrap !important;
        justify-content: center !important;
    }
    .fifo-thanks-actions a {
        width: auto !important;
        min-width: 160px !important;
        flex: 1 1 auto !important;
    }
}

/* ============================================================
   12. ORDERED PRODUCT CARDS
   ============================================================ */
.fifo-ordered-product-card {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    gap: 16px !important;
    padding: 20px 16px !important;
    border-radius: 16px !important;
    margin-bottom: 16px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    position: relative !important;
}

.fifo-ordered-badge {
    position: static !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    margin-bottom: 4px !important;
    font-size: 13px !important;
    padding: 6px 12px !important;
    border-radius: 8px !important;
    background: #dcfce7 !important;
    color: #16a34a !important;
    font-weight: 800 !important;
}

.fifo-ordered-img {
    width: 120px !important;
    height: 120px !important;
    object-fit: contain !important;
    border-radius: 14px !important;
    padding: 8px !important;
    background: #f8fafc !important;
}

.fifo-ordered-details {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    width: 100% !important;
    min-width: 0 !important;
}

.fifo-ordered-title {
    font-size: 17px !important;
    font-weight: 800 !important;
    line-height: 1.4 !important;
    margin-bottom: 10px !important;
    word-break: break-word !important;
}

.fifo-ordered-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 10px !important;
    font-size: 14px !important;
    margin-bottom: 14px !important;
}

.fifo-ordered-price-wrap {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
}

.fifo-ordered-price {
    font-size: 22px !important;
    font-weight: 800 !important;
}

@media (min-width: 540px) {
    .fifo-ordered-product-card {
        flex-direction: row !important;
        text-align: left !important;
        padding: 24px 20px !important;
        gap: 24px !important;
    }
    .fifo-ordered-badge {
        position: absolute !important;
        top: 20px !important;
        right: 20px !important;
        margin: 0 !important;
    }
    .fifo-ordered-img {
        width: 130px !important;
        height: 130px !important;
        flex-shrink: 0 !important;
    }
    .fifo-ordered-details {
        align-items: flex-start !important;
    }
    .fifo-ordered-meta {
        justify-content: flex-start !important;
    }
    .fifo-ordered-price-wrap {
        flex-direction: row !important;
        align-items: center !important;
    }
}

@media (min-width: 768px) {
    .fifo-ordered-img {
        width: 160px !important;
        height: 160px !important;
    }
    .fifo-ordered-title {
        font-size: 20px !important;
    }
    .fifo-ordered-price {
        font-size: 26px !important;
    }
}

/* ============================================================
   13. ORDER TRACKING TIMELINE — VERTICAL (MOBILE-FIRST)
   ============================================================ */

/* HORIZONTAL timeline → VERTICAL on all screens */
.fifo-timeline {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 0 !important;
    margin: 20px 0 !important;
    position: relative !important;
    padding-left: 0 !important;
    width: 100% !important;
}

/* Remove old horizontal ::before pseudo-line */
.fifo-timeline::before {
    display: none !important;
}

.fifo-time-step {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    gap: 16px !important;
    width: 100% !important;
    text-align: left !important;
    position: relative !important;
    padding-bottom: 28px !important;
    z-index: 2 !important;
}

/* Vertical connector line between steps */
.fifo-time-step::after {
    content: '' !important;
    position: absolute !important;
    left: 20px !important;
    top: 44px !important;
    width: 4px !important;
    bottom: 0 !important;
    background: #e2e8f0 !important;
    border-radius: 2px !important;
    z-index: 1 !important;
}

.fifo-time-step.done::after {
    background: #10b981 !important;
}

.fifo-time-step:last-child {
    padding-bottom: 0 !important;
}

.fifo-time-step:last-child::after {
    display: none !important;
}

.fifo-time-dot {
    width: 44px !important;
    height: 44px !important;
    border-radius: 50% !important;
    background: #f1f5f9 !important;
    border: 3px solid #fff !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    flex-shrink: 0 !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08) !important;
    position: relative !important;
    z-index: 2 !important;
}

.fifo-time-step.done .fifo-time-dot {
    background: #10b981 !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(16,185,129,0.3) !important;
}

.fifo-time-step.current .fifo-time-dot {
    background: #d946ef !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(217,70,239,0.3) !important;
}

.fifo-time-label {
    flex: 1 !important;
    padding-top: 10px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #374151 !important;
    line-height: 1.4 !important;
}

.fifo-time-step.done .fifo-time-label {
    color: #111827 !important;
    font-weight: 700 !important;
}

/* Delivery estimate banner */
.fifo-delivery-estimate {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    padding: 16px !important;
    border-radius: 14px !important;
    align-items: center !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    margin-top: 24px !important;
    justify-content: center !important;
    text-align: center !important;
    width: 100% !important;
    box-sizing: border-box !important;
    word-break: break-word !important;
}

/* ============================================================
   14. TRACKING TIMELINE — VERTICAL VARIANT (fifo-timeline-vertical)
   ============================================================ */
.fifo-timeline-vertical {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    width: 100% !important;
    position: relative !important;
    margin: 20px 0 !important;
}

.fifo-timeline-vertical .fifo-time-step {
    display: flex !important;
    align-items: flex-start !important;
    gap: 16px !important;
    position: relative !important;
    z-index: 2 !important;
    padding-bottom: 28px !important;
}

.fifo-timeline-vertical .fifo-time-step::after {
    content: '' !important;
    position: absolute !important;
    top: 40px !important;
    left: 20px !important;
    width: 4px !important;
    height: calc(100% - 36px) !important;
    background: #e2e8f0 !important;
    z-index: 1 !important;
    border-radius: 2px !important;
}

.fifo-timeline-vertical .fifo-time-step.done::after {
    background: #10b981 !important;
}

.fifo-timeline-vertical .fifo-time-step:last-child {
    padding-bottom: 0 !important;
}

.fifo-timeline-vertical .fifo-time-step:last-child::after {
    display: none !important;
}

.fifo-timeline-vertical .fifo-time-dot {
    width: 44px !important;
    height: 44px !important;
    flex-shrink: 0 !important;
    position: relative !important;
    z-index: 2 !important;
}

.fifo-timeline-vertical .fifo-time-label {
    padding-top: 10px !important;
    flex: 1 !important;
    min-width: 0 !important;
    word-break: break-word !important;
}

/* ============================================================
   15. ORDER HISTORY PAGE
   ============================================================ */
.fifo-orders-wrap {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto 40px !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

.fifo-orders-header {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 12px !important;
    margin-bottom: 20px !important;
}

.fifo-orders-header h2 {
    font-size: clamp(22px, 5vw, 28px) !important;
    margin: 0 !important;
}

.fifo-orders-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    width: 100% !important;
}

.fifo-order-card {
    width: 100% !important;
    padding: 18px 16px !important;
    border-radius: 16px !important;
    box-sizing: border-box !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    overflow: hidden !important;
}

/* Order meta: 2-column grid on mobile */
.fifo-order-meta {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px 16px !important;
    padding-bottom: 14px !important;
    border-bottom: 1px solid #f3f4f6 !important;
    align-items: start !important;
}

.fifo-meta-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

.fifo-meta-label {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    color: #9ca3af !important;
    white-space: nowrap !important;
}

.fifo-meta-value {
    font-size: 14px !important;
    font-weight: 600 !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
}

/* Status badge: right-aligned on mobile */
.fifo-order-meta .fifo-meta-group:last-child,
.fifo-order-meta > *:last-child {
    align-items: flex-end !important;
    text-align: right !important;
}

.fifo-order-status {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 6px 12px !important;
    border-radius: 50px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
    text-transform: uppercase !important;
}

/* Product preview row */
.fifo-order-products {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    width: 100% !important;
    overflow: hidden !important;
}

.fifo-order-img-wrap {
    width: 72px !important;
    height: 72px !important;
    border-radius: 10px !important;
    flex-shrink: 0 !important;
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.fifo-order-img-wrap img {
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
}

.fifo-order-details {
    flex: 1 !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

.fifo-order-details h3 {
    font-size: 15px !important;
    font-weight: 700 !important;
    line-height: 1.4 !important;
    margin: 0 0 4px !important;
    overflow: hidden !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    word-break: break-word !important;
}

.fifo-order-details p {
    font-size: 13px !important;
    color: #6b7280 !important;
    margin: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

/* Order actions: full-width stacked on mobile */
.fifo-order-actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    padding-top: 14px !important;
    border-top: 1px solid #f3f4f6 !important;
    width: 100% !important;
}

.fifo-action-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-height: 48px !important;
    padding: 12px 20px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    text-align: center !important;
    box-sizing: border-box !important;
    cursor: pointer !important;
}

/* On phones ≥380px, put 2 buttons side by side */
@media (min-width: 380px) {
    .fifo-order-actions {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 10px !important;
    }
    /* "View" button: spans full width */
    .fifo-order-actions .fifo-btn-primary {
        grid-column: 1 / -1 !important;
    }
}

@media (min-width: 600px) {
    .fifo-order-card {
        padding: 24px !important;
        border-radius: 20px !important;
    }
    .fifo-order-meta {
        grid-template-columns: repeat(4, 1fr) !important;
    }
    .fifo-order-img-wrap {
        width: 80px !important;
        height: 80px !important;
    }
    .fifo-order-details h3 {
        font-size: 16px !important;
    }
    .fifo-order-actions {
        flex-direction: row !important;
        display: flex !important;
        flex-wrap: wrap !important;
        justify-content: flex-end !important;
    }
    .fifo-action-btn {
        width: auto !important;
        min-width: 140px !important;
        flex: 0 0 auto !important;
    }
    .fifo-order-actions .fifo-btn-primary {
        grid-column: auto !important;
    }
}

/* ============================================================
   16. PRICE SUMMARY / ORDER TOTAL TABLES
   ============================================================ */
.summary-totals,
.fifo-price-summary,
.cart_totals,
.woocommerce-order-details {
    width: 100% !important;
    overflow-x: hidden !important;
    box-sizing: border-box !important;
}

.summary-totals table,
.fifo-price-summary table,
.cart_totals table,
.woocommerce-table--order-details {
    width: 100% !important;
    table-layout: fixed !important;
    border-collapse: collapse !important;
}

.summary-totals table th,
.summary-totals table td,
.cart_totals table th,
.cart_totals table td {
    font-size: 14px !important;
    padding: 10px 8px !important;
    vertical-align: top !important;
    word-break: break-word !important;
}

.summary-totals table th,
.cart_totals table th {
    width: 50% !important;
    font-weight: 600 !important;
    color: #6b7280 !important;
    text-align: left !important;
}

.summary-totals table td,
.cart_totals table td {
    width: 50% !important;
    font-weight: 700 !important;
    color: #111827 !important;
    text-align: right !important;
    white-space: nowrap !important;
}

/* Order details table */
.woocommerce-table--order-details th,
.woocommerce-table--order-details td {
    font-size: 14px !important;
    padding: 12px 8px !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
}

.woocommerce-table--order-details .product-name {
    width: 65% !important;
}

.woocommerce-table--order-details .product-total {
    width: 35% !important;
    text-align: right !important;
    white-space: nowrap !important;
}

/* ============================================================
   17. PRICE DETAILS TABLE (CHECKOUT REVIEW)
   ============================================================ */
.fifo-price-table {
    width: 100% !important;
    border-collapse: collapse !important;
}

.fifo-price-table tr {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 10px 0 !important;
    border-bottom: 1px solid #f3f4f6 !important;
    gap: 12px !important;
}

.fifo-price-table td {
    font-size: 14px !important;
    flex: 1 !important;
    min-width: 0 !important;
    word-break: break-word !important;
}

.fifo-price-table td:last-child {
    text-align: right !important;
    flex-shrink: 0 !important;
    white-space: nowrap !important;
    font-weight: 700 !important;
}

/* ============================================================
   18. CANCEL ORDER MODAL
   ============================================================ */
.fifo-cancel-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 99999 !important;
    display: flex !important;
    align-items: flex-end !important; /* Slide up from bottom on mobile */
    justify-content: center !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

.fifo-cancel-modal {
    background: white !important;
    border-radius: 24px 24px 0 0 !important; /* Bottom sheet style */
    width: 100% !important;
    max-width: 100% !important;
    padding: 28px 20px 32px !important;
    box-sizing: border-box !important;
    overflow-y: auto !important;
    max-height: 90vh !important;
}

.fifo-cancel-modal h3 {
    font-size: 20px !important;
    margin: 0 0 12px !important;
}

.fifo-cancel-modal p {
    font-size: 14px !important;
    margin-bottom: 20px !important;
    line-height: 1.6 !important;
}

.fifo-cancel-modal select,
.fifo-cancel-modal textarea {
    width: 100% !important;
    padding: 14px 16px !important;
    border-radius: 12px !important;
    font-size: 16px !important; /* Prevent iOS zoom */
    margin-bottom: 16px !important;
    box-sizing: border-box !important;
    border: 1px solid #d1d5db !important;
}

.fifo-cancel-btn-group {
    display: flex !important;
    gap: 12px !important;
    width: 100% !important;
}

.fifo-cancel-btn-group button {
    flex: 1 !important;
    min-height: 52px !important;
    border-radius: 14px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    border: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

@media (min-width: 480px) {
    .fifo-cancel-overlay {
        align-items: center !important;
        padding: 20px !important;
    }
    .fifo-cancel-modal {
        border-radius: 24px !important;
        max-width: 460px !important;
        padding: 32px !important;
    }
}

/* Sad / Success modal */
.fifo-sad-modal {
    text-align: center !important;
}

.fifo-sad-icon {
    font-size: 60px !important;
    margin-bottom: 16px !important;
    display: block !important;
}

.fifo-btn-shop {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 52px !important;
    padding: 14px 28px !important;
    border-radius: 50px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    margin-top: 16px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

@media (min-width: 480px) {
    .fifo-btn-shop {
        width: auto !important;
    }
}

/* ============================================================
   19. WC ORDER OVERVIEW (ORDER NUMBER, DATE, ETC.)
   ============================================================ */
ul.woocommerce-order-overview,
.woocommerce-order-overview {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 24px !important;
    width: 100% !important;
}

.woocommerce-order-overview li {
    background: #f8fafc !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    padding: 12px 14px !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
    overflow-wrap: break-word !important;
    word-break: break-word !important;
    min-width: 0 !important;
}

.woocommerce-order-overview li strong {
    display: block !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    margin-top: 2px !important;
    word-break: break-word !important;
}

@media (min-width: 480px) {
    ul.woocommerce-order-overview {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (min-width: 768px) {
    ul.woocommerce-order-overview {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

/* ============================================================
   20. CUSTOMER ADDRESS DETAILS (ORDER CONFIRMATION)
   ============================================================ */
.woocommerce-customer-details {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
    margin-bottom: 24px !important;
}

.woocommerce-customer-details section,
.woocommerce-column--billing-address,
.woocommerce-column--shipping-address {
    width: 100% !important;
    padding: 18px 16px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 14px !important;
    background: #f8fafc !important;
    box-sizing: border-box !important;
    overflow-wrap: break-word !important;
    word-break: break-word !important;
}

.woocommerce-column--billing-address h2,
.woocommerce-column--shipping-address h2,
.woocommerce-customer-details h2,
.woocommerce-customer-details h3 {
    font-size: clamp(15px, 3.5vw, 18px) !important;
    font-weight: 700 !important;
    margin: 0 0 10px !important;
    word-break: break-word !important;
}

.woocommerce-customer-details address {
    font-size: 14px !important;
    line-height: 1.7 !important;
    word-break: break-word !important;
    overflow-wrap: break-word !important;
    white-space: normal !important;
}

@media (min-width: 600px) {
    .woocommerce-customer-details {
        flex-direction: row !important;
    }
    .woocommerce-customer-details section,
    .woocommerce-column--billing-address,
    .woocommerce-column--shipping-address {
        flex: 1 !important;
    }
}

/* ============================================================
   21. TRUST BADGES
   ============================================================ */
.fifo-trust-badges {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
    margin-top: 24px !important;
    width: 100% !important;
}

.fifo-trust-badge {
    padding: 14px 12px !important;
    border-radius: 12px !important;
    font-size: 13px !important;
    text-align: center !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
}

/* ============================================================
   22. PET TIPS & SUPPORT SECTIONS
   ============================================================ */
.fifo-pet-tips {
    padding: 20px 16px !important;
    border-radius: 16px !important;
    margin-top: 28px !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.fifo-pet-tips h3 {
    font-size: 18px !important;
    margin-bottom: 14px !important;
    word-break: break-word !important;
}

.fifo-pet-tips li {
    font-size: 14px !important;
    line-height: 1.7 !important;
    margin-bottom: 8px !important;
}

.fifo-support-block {
    padding: 24px 16px !important;
    border-radius: 16px !important;
    margin-top: 24px !important;
    text-align: center !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.fifo-support-links {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    align-items: stretch !important;
}

.fifo-support-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-height: 52px !important;
    padding: 14px 20px !important;
    border-radius: 12px !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    text-decoration: none !important;
    box-sizing: border-box !important;
    width: 100% !important;
}

@media (min-width: 480px) {
    .fifo-support-links {
        flex-direction: row !important;
        flex-wrap: wrap !important;
        justify-content: center !important;
    }
    .fifo-support-btn {
        width: auto !important;
        min-width: 160px !important;
        flex: 1 1 auto !important;
    }
}

@media (min-width: 768px) {
    .fifo-pet-tips {
        padding: 32px !important;
    }
    .fifo-support-block {
        padding: 32px !important;
    }
}

/* ============================================================
   23. RECOMMENDED PRODUCTS CAROUSEL
   ============================================================ */
.fifo-smart-recs {
    margin-top: 40px !important;
    width: 100% !important;
    overflow: hidden !important;
}

.fifo-smart-recs h3 {
    font-size: clamp(18px, 4vw, 24px) !important;
    font-weight: 800 !important;
    margin-bottom: 16px !important;
}

.fifo-rec-carousel {
    display: flex !important;
    gap: 14px !important;
    overflow-x: auto !important;
    padding-bottom: 12px !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    width: 100% !important;
}

.fifo-rec-carousel::-webkit-scrollbar {
    height: 4px !important;
}

.fifo-rec-card {
    min-width: 160px !important;
    flex-shrink: 0 !important;
    scroll-snap-align: start !important;
    border-radius: 14px !important;
    padding: 12px !important;
    display: flex !important;
    flex-direction: column !important;
}

.fifo-rec-card img {
    width: 100% !important;
    height: 120px !important;
    object-fit: contain !important;
    border-radius: 10px !important;
    margin-bottom: 10px !important;
}

.fifo-rec-title {
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1.4 !important;
    margin-bottom: 8px !important;
}

@media (min-width: 480px) {
    .fifo-rec-card {
        min-width: 200px !important;
    }
    .fifo-rec-card img {
        height: 140px !important;
    }
}

/* ============================================================
   24. COUPON / ZONE MESSAGE
   ============================================================ */
.woocommerce-checkout .woocommerce-NoticeGroup,
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message {
    width: 100% !important;
    box-sizing: border-box !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    padding: 14px 16px !important;
    overflow-wrap: break-word !important;
    word-break: break-word !important;
}

/* Coupon row */
.checkout_coupon,
.woocommerce-checkout .coupon {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    width: 100% !important;
}

.checkout_coupon input,
.woocommerce-checkout .coupon input {
    flex: 1 !important;
    min-width: 120px !important;
}

.checkout_coupon button,
.woocommerce-checkout .coupon button {
    flex-shrink: 0 !important;
}

/* ============================================================
   25. ORDER TRACKING PAGE (CUSTOM TRACK ORDER)
   ============================================================ */
.fifo-track-shell,
.fifozone-checkout-shell .fifo-track-form {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    box-sizing: border-box !important;
}

/* Track order form inputs */
.fifo-track-form input,
.fifo-track-form select {
    width: 100% !important;
    min-height: 52px !important;
    font-size: 16px !important;
    padding: 14px 16px !important;
    border-radius: 12px !important;
    box-sizing: border-box !important;
    margin-bottom: 14px !important;
}

.fifo-track-form button,
.fifo-track-form input[type="submit"] {
    width: 100% !important;
    min-height: 52px !important;
}

/* Tracking timeline displayed on track page */
.fifo-tracking-result {
    width: 100% !important;
    box-sizing: border-box !important;
}

/* ============================================================
   26. GLOBAL MY ACCOUNT WRAPPER
   ============================================================ */
.woocommerce-MyAccount-content {
    float: none !important;
    width: 100% !important;
    padding: 0 !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
}

/* ============================================================
   27. PROCEED TO CHECKOUT / CART BUTTONS
   ============================================================ */
.wc-proceed-to-checkout,
.wc-proceed-to-checkout a.checkout-button,
.wc-proceed-to-checkout .checkout-button {
    display: block !important;
    width: 100% !important;
}

.wc-proceed-to-checkout a.checkout-button {
    min-height: 56px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    border-radius: 14px !important;
    text-align: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* ============================================================
   28. TABLET & DESKTOP ENHANCEMENTS
   ============================================================ */
@media (min-width: 768px) {
    .fifo-orders-wrap {
        max-width: 900px !important;
    }
    .fifo-order-card {
        padding: 24px !important;
    }
    .fifo-success-hero {
        padding: 80px 40px !important;
    }
    .fifo-check-anim {
        width: 100px !important;
        height: 100px !important;
    }
    .fifo-timeline .fifo-time-dot,
    .fifo-timeline-vertical .fifo-time-dot {
        width: 48px !important;
        height: 48px !important;
        font-size: 16px !important;
    }
    .fifo-timeline .fifo-time-step::after {
        left: 24px !important;
        top: 48px !important;
    }
    .fifo-time-label {
        font-size: 16px !important;
        padding-top: 12px !important;
    }
    .fifo-cancel-modal {
        border-radius: 24px !important;
    }
    .fifo-rec-card {
        min-width: 220px !important;
    }
    .fifo-rec-card img {
        height: 160px !important;
    }
}

@media (min-width: 1024px) {
    .fifo-orders-wrap {
        max-width: 1000px !important;
    }
    .fifo-pet-tips h3 {
        font-size: 22px !important;
    }
    .fifo-support-block h3 {
        font-size: 22px !important;
    }
}

/* ============================================================
   29. CRITICAL OVERFLOW PREVENTION
   ============================================================ */
.woocommerce-order,
.woocommerce-order-received,
.woocommerce-checkout,
.woocommerce-account {
    overflow-x: hidden !important;
    max-width: 100% !important;
}

/* Images never overflow */
img, svg, video, iframe {
    max-width: 100% !important;
    height: auto !important;
}

/* Address text never overflows */
address,
.woocommerce-customer-details address {
    overflow-wrap: break-word !important;
    word-break: break-word !important;
    word-wrap: break-word !important;
    hyphens: auto !important;
    white-space: normal !important;
    max-width: 100% !important;
}
