/**
 * WAPF Stepper Field Styles
 * Styling for the new stepper field type
 */

/* Stepper wrapper */
.wapf-stepper-wrapper {
    display: inline-flex;
    align-items: center;
    border: 1px solid #ddd;
    border-radius: 4px;
    overflow: hidden;
    background: #fff;
    max-width: 150px;
}

/* Stepper input field */
.wapf-stepper-wrapper input[type="number"] {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    text-align: center;
    width: 60px;
    padding: 8px 4px;
    margin: 0;
    background: #09cc09!important;
    -moz-appearance: textfield; /* Firefox */
    pointer-events: none; /* Prevent manual editing - only buttons work */
    user-select: none; /* Prevent text selection */
}

/* Hide number input spinners */
.wapf-stepper-wrapper input[type="number"]::-webkit-outer-spin-button,
.wapf-stepper-wrapper input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Stepper buttons */
.wapf-stepper-btn {
    background: #f7f7f7;
    border: none;
    width: 32px;
    height: 36px;
    cursor: pointer;
    font-size: 16px;
    font-weight: bold;
    color: #3bf159;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s ease;
    user-select: none;
}

.wapf-stepper-btn:hover:not(:disabled) {
    background: #e7e7e7;
}

.wapf-stepper-btn:active:not(:disabled) {
    background: #ddd;
}

.wapf-stepper-btn:disabled,
.wapf-stepper-btn.wapf-stepper-disabled {
    background: #f9f9f9;
    color: #ccc;
    cursor: not-allowed;
}

/* Minus button */
.wapf-stepper-minus {
    border-right: 1px solid #ddd;
}

/* Plus button */
.wapf-stepper-plus {
    border-left: 1px solid #ddd;
}

/* Error states */
.wapf-stepper-wrapper input.wapf-stepper-error {
    border-color: #dc3232 !important;
    background-color: #ffeaea;
}

.wapf-stepper-error-message {
    color: #dc3232;
    font-size: 0.85em;
    margin-top: 4px;
    display: block;
}

/* Info states (for auto-correction) */
.wapf-stepper-wrapper input.wapf-stepper-info {
    border-color: #00a0d2 !important;
    background-color: #e7f7ff;
}

.wapf-stepper-info-message {
    color: #00a0d2;
    font-size: 0.85em;
    margin-top: 4px;
    display: block;
    animation: wapf-stepper-fade-in 0.3s ease-in;
}

/* Animations */
@keyframes wapf-stepper-fade-in {
    from {
        opacity: 0;
        transform: translateY(-5px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Focus states */
.wapf-stepper-wrapper:focus-within {
    border-color: #0073aa;
    box-shadow: 0 0 0 1px #0073aa;
}

/* Field container integration */
.wapf-field-container.wapf-field-stepper {
    margin-bottom: 15px;
}

.wapf-field-container.wapf-field-stepper .wapf-field-label {
    margin-bottom: 5px;
    display: block;
    font-weight: 500;
}

/* WooCommerce theme integration */
.woocommerce .wapf-stepper-wrapper,
.woocommerce-page .wapf-stepper-wrapper {
    border-color: #09cc09;
}

.woocommerce .wapf-stepper-btn,
.woocommerce-page .wapf-stepper-btn {
    background: #09cc09;
}

.woocommerce .wapf-stepper-btn:hover:not(:disabled),
.woocommerce-page .wapf-stepper-btn:hover:not(:disabled) {
    background: #067906;
}

/* Responsive design */
@media (max-width: 768px) {
    .wapf-stepper-wrapper {
        max-width: 120px;
    }
    
    .wapf-stepper-wrapper input[type="number"] {
        width: 50px;
        padding: 6px 2px;
    }
    
    .wapf-stepper-btn {
        width: 28px;
        height: 32px;
        font-size: 14px;
    }
    
    .wapf-stepper-error-message,
    .wapf-stepper-info-message {
        font-size: 0.8em;
    }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .wapf-stepper-wrapper {
        border-width: 2px;
        border-color: #000;
    }
    
    .wapf-stepper-btn {
        border-width: 2px;
        color: #000;
    }
    
    .wapf-stepper-error-message {
        color: #d63638;
        font-weight: bold;
    }
    
    .wapf-stepper-info-message {
        color: #135e96;
        font-weight: bold;
    }
}

/* Dark mode support */
@media (prefers-color-scheme: dark) {
    .wapf-stepper-wrapper {
        background: #2c2c2c;
        border-color: #555;
    }
    
    .wapf-stepper-wrapper input[type="number"] {
        background: transparent;
        color: #fff;
    }
    
    .wapf-stepper-btn {
        background: #3c3c3c;
        color: #fff;
        border-color: #555;
    }
    
    .wapf-stepper-btn:hover:not(:disabled) {
        background: #4c4c4c;
    }
    
    .wapf-stepper-btn:disabled,
    .wapf-stepper-btn.wapf-stepper-disabled {
        background: #2c2c2c;
        color: #666;
    }
    
    .wapf-stepper-error-message {
        color: #ff6b6b;
    }
    
    .wapf-stepper-info-message {
        color: #4ecdc4;
    }
}

/* Print styles */
@media print {
    .wapf-stepper-btn {
        display: none;
    }
    
    .wapf-stepper-wrapper {
        border: 1px solid #000;
    }
    
    .wapf-stepper-wrapper input[type="number"] {
        border: none;
        background: transparent;
    }
}

/* RTL support */
.rtl .wapf-stepper-minus {
    border-right: none;
    border-left: 1px solid #ddd;
}

.rtl .wapf-stepper-plus {
    border-left: none;
    border-right: 1px solid #ddd;
}

/* PRIO-2: Enhanced price display styling (SAFE - no breaking changes) */
.wapf-stepper-price-display {
    margin-top: 10px !important;
    padding: 12px !important;
    background: #f8f9fa !important;
    border: 1px solid #e9ecef !important;
    border-radius: 6px !important;
    font-family: inherit !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1) !important;
    transition: all 0.2s ease !important;
}

.wapf-stepper-price-display:hover {
    box-shadow: 0 2px 6px rgba(0,0,0,0.15) !important;
}

/* Enhanced cap warning styling */
.wapf-stepper-price-display div[style*="color: #d63638"] {
    background: #fff2f2 !important;
    border: 1px solid #ffccd5 !important;
    border-radius: 4px !important;
    padding: 8px 10px !important;
    margin-top: 8px !important;
    font-weight: 500 !important;
    animation: wapf-price-warning-pulse 2s ease-in-out !important;
}

@keyframes wapf-price-warning-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.8; }
}

/* OPTION 2: Live-Preisberechnung - Clean approach without hiding elements */
/* All problematic CSS selectors removed - back to stable solution */
