/**
 * Cuttalo WooCommerce Mobile Optimized Styles
 * Version: 1.0.0
 */

/* Fix Cart Page Layout Issues */
.woocommerce-cart-form .shop_table {
    display: none !important;
}

.woocommerce-cart .cart-collaterals .cart_totals {
    width: 100% !important;
    float: none !important;
}

/* Hide duplicate empty cart buttons from imorder plugin */
.woocommerce button[name="empty_cart"],
.woocommerce .actions button[name="empty_cart"],
.woocommerce-cart-form .actions .empty-cart,
.woocommerce .empty-cart,
a.empty-cart,
button.empty-cart:not(.empty-cart-btn),
.cart-actions .empty-cart,
#empty-cart-button {
    display: none !important;
}

/* General Mobile Optimizations */
@media (max-width: 768px) {
    .woocommerce .col2-set .col-1,
    .woocommerce .col2-set .col-2 {
        float: none;
        width: 100%;
    }
    
    .woocommerce table.shop_table_responsive tr,
    .woocommerce-page table.shop_table_responsive tr {
        display: block;
        border: 1px solid #ddd;
        margin-bottom: 10px;
        padding: 10px;
        border-radius: 4px;
    }
}

/* Invoice Info Box Styling */
.invoice-info-box {
    background: #f0f8ff;
    border: 1px solid #0066cc;
    border-radius: 8px;
    padding: 20px;
    margin: 20px 0;
}

.invoice-info-box h3 {
    color: #0066cc;
    margin: 0 0 15px 0;
    font-size: 18px;
}

.invoice-info-box p {
    margin: 5px 0;
    line-height: 1.6;
}

/* Empty Cart Button */
.empty-cart-btn {
    background-color: #dc3545 !important;
    color: white !important;
    margin-left: 10px;
}

.empty-cart-btn:hover {
    background-color: #c82333 !important;
}

/* Cart Count Badge */
.cart-count {
    background: #ff5722;
    color: white;
    border-radius: 50%;
    padding: 2px 6px;
    font-size: 12px;
    position: absolute;
    top: -8px;
    right: -8px;
}

/* Checkout Field Improvements */
.woocommerce-checkout .form-row {
    margin-bottom: 15px;
}

.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 {
    height: 45px;
    font-size: 16px;
}

.woocommerce-checkout .form-row label {
    font-weight: 600;
    margin-bottom: 5px;
    display: block;
}

/* Validation States */
.woocommerce-validated input {
    border-color: #28a745 !important;
}

.woocommerce-invalid input {
    border-color: #dc3545 !important;
}

/* Loading Overlay Improvements */
.blockUI.blockOverlay {
    background-color: rgba(255, 255, 255, 0.9) !important;
}

.blockUI.blockOverlay:before {
    content: '';
    display: inline-block;
    width: 40px;
    height: 40px;
    border: 3px solid #f3f3f3;
    border-top: 3px solid #ff5722;
    border-radius: 50%;
    animation: spin 1s linear infinite;
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -20px;
    margin-left: -20px;
}

/* Copied Message */
.copied-message {
    position: absolute;
    background: #4CAF50;
    color: white;
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 12px;
    margin-left: 10px;
    z-index: 1000;
}

/* Responsive Tables */
@media (max-width: 480px) {
    .woocommerce table.shop_table,
    .woocommerce-page table.shop_table {
        font-size: 14px;
    }
    
    .woocommerce table.shop_table th,
    .woocommerce table.shop_table td {
        padding: 8px;
    }
}

/* Touch-friendly buttons */
@media (max-width: 768px) {
    .woocommerce a.button,
    .woocommerce button.button,
    .woocommerce input.button {
        min-height: 44px;
        line-height: 44px;
        padding: 0 20px;
    }
}

/* Sticky Order Review on Desktop */
@media (min-width: 769px) {
    .woocommerce-checkout .order-review-wrapper {
        position: sticky;
        top: 20px;
        max-height: calc(100vh - 40px);
        overflow-y: auto;
    }
}

/* Improved Error Messages */
.woocommerce-error li,
.woocommerce-message,
.woocommerce-info {
    list-style: none;
    padding-left: 40px;
    position: relative;
    width: 100% !important;
}

.woocommerce-error li:before,
.woocommerce-message:before,
.woocommerce-info:before {
    position: absolute;
    left: 15px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 20px;
}

.woocommerce-error li:before {
    content: '⚠️';
}

.woocommerce-message:before {
    content: '✅';
}

.woocommerce-info:before {
    content: 'ℹ️';
}

/* Fatture in Cloud Fields Enhancement */
#woorichiestafattura_field {
    border: 2px solid #0066cc;
    animation: highlight 0.5s ease-in-out;
}

@keyframes highlight {
    0% { border-color: #0066cc; }
    50% { border-color: #ff5722; }
    100% { border-color: #0066cc; }
}

.billing_cod_fisc_field.hidden,
.billing_partita_iva_field.hidden,
.billing_pec_email_field.hidden,
.billing_codice_destinatario_field.hidden {
    display: none !important;
}

/* Mobile Cart Improvements */
@media (max-width: 768px) {
    .woocommerce table.cart td.actions {
        text-align: center;
    }
    
    .woocommerce table.cart td.actions .coupon {
        float: none;
        margin-bottom: 10px;
    }
    
    .woocommerce table.cart td.actions .button {
        width: 100%;
        margin-bottom: 5px;
    }
}

/* Accessibility Improvements */
.woocommerce-checkout label {
    cursor: pointer;
}

.woocommerce-checkout input:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout textarea:focus {
    outline: 2px solid #ff5722;
    outline-offset: 2px;
}

/* Fix Duplicate Buttons */
.woocommerce-cart .actions .button:not(.update-cart):not(.empty-cart-btn) {
    display: none !important;
}

.woocommerce-cart .cart-collaterals .wc-proceed-to-checkout a.checkout-button:not(:first-child) {
    display: none !important;
}

/* Print Styles */
@media print {
    .checkout-progress,
    .thankyou-actions,
    .empty-cart-btn,
    .woocommerce-form-coupon-toggle,
    .woocommerce-form-login-toggle {
        display: none !important;
    }
    
    .invoice-info-box {
        border: 1px solid #000;
        page-break-inside: avoid;
    }
}

/* Ultra Compact Mobile Optimizations */
@media (max-width: 480px) {
    /* Checkout Mobile */
    .cuttalo-checkout-ultra .checkout-step {
        padding: 16px;
        margin-bottom: 12px;
    }
    
    .cuttalo-checkout-ultra .step-title {
        font-size: 18px;
        margin-bottom: 16px;
    }
    
    .cuttalo-checkout-ultra .form-grid {
        gap: 8px;
    }
    
    .cuttalo-checkout-ultra .form-field-compact input,
    .cuttalo-checkout-ultra .form-field-compact select {
        padding: 10px 12px;
        font-size: 16px; /* Prevent zoom on iOS */
    }
    
    /* Cart Mobile */
    .cuttalo-cart-ultra .cart-item {
        padding: 12px;
        gap: 12px;
    }
    
    .cuttalo-cart-ultra .item-image img {
        width: 50px;
        height: 50px;
    }
    
    .cuttalo-cart-ultra .summary-box {
        padding: 16px;
    }
    
    /* Fixed bottom summary on mobile */
    .cuttalo-cart-ultra .summary-box.mobile-fixed {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        border-radius: 16px 16px 0 0;
        box-shadow: 0 -4px 20px rgba(0,0,0,0.1);
        z-index: 999;
        max-height: 50vh;
        overflow-y: auto;
    }
    
    /* Checkout progress mobile */
    .checkout-progress .step-text {
        font-size: 12px;
    }
    
    .checkout-progress .step-num {
        width: 32px;
        height: 32px;
        line-height: 32px;
        font-size: 14px;
    }
}

/* Touch-friendly elements */
@media (hover: none) and (pointer: coarse) {
    .qty-btn,
    .remove-btn,
    button,
    .button,
    input[type="submit"] {
        min-height: 44px;
        min-width: 44px;
    }
    
    .wc_payment_method {
        padding: 20px;
    }
    
    .ship-different input[type="checkbox"] {
        width: 24px;
        height: 24px;
    }
}