/* ==========================================================================
   Mobile Forms Enhancement for SOMASUQ
   ========================================================================== */

/* Form Container Mobile */
@media (max-width: 768px) {
    
    /* Form Layout */
    .form-container-mobile {
        background: white !important;
        border-radius: 12px !important;
        padding: 1.5rem !important;
        margin: 1rem 0 !important;
        box-shadow: 0 2px 10px rgba(0,0,0,0.1) !important;
    }
    
    .form-header-mobile {
        text-align: center !important;
        margin-bottom: 2rem !important;
        padding-bottom: 1rem !important;
        border-bottom: 1px solid #e9ecef !important;
    }
    
    .form-header-mobile h4 {
        color: #495057 !important;
        font-weight: 600 !important;
        margin-bottom: 0.5rem !important;
    }
    
    .form-header-mobile p {
        color: #6c757d !important;
        font-size: 0.9rem !important;
        margin: 0 !important;
    }
    
    /* Form Groups */
    .form-group-mobile {
        margin-bottom: 1.5rem !important;
        position: relative !important;
    }
    
    .form-label-mobile {
        font-weight: 600 !important;
        color: #495057 !important;
        margin-bottom: 0.75rem !important;
        display: block !important;
        font-size: 0.9rem !important;
    }
    
    .form-label-mobile.required::after {
        content: " *" !important;
        color: #dc3545 !important;
    }
    
    /* Form Controls */
    .form-control-mobile {
        width: 100% !important;
        padding: 0.875rem 1rem !important;
        font-size: 16px !important; /* Prevent zoom on iOS */
        border: 2px solid #e9ecef !important;
        border-radius: 10px !important;
        background: #f8f9fa !important;
        transition: all 0.3s ease !important;
        min-height: 50px !important; /* Touch-friendly */
    }
    
    .form-control-mobile:focus {
        border-color: #007bff !important;
        background: white !important;
        box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25) !important;
        outline: none !important;
    }
    
    .form-control-mobile.is-invalid {
        border-color: #dc3545 !important;
        background: #fff5f5 !important;
    }
    
    .form-control-mobile.is-valid {
        border-color: #28a745 !important;
        background: #f8fff9 !important;
    }
    
    /* Select Dropdowns */
    .form-select-mobile {
        width: 100% !important;
        padding: 0.875rem 1rem !important;
        font-size: 16px !important;
        border: 2px solid #e9ecef !important;
        border-radius: 10px !important;
        background: #f8f9fa !important;
        background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m1 6 7 7 7-7'/%3e%3c/svg%3e") !important;
        background-repeat: no-repeat !important;
        background-position: left 0.75rem center !important;
        background-size: 16px 12px !important;
        appearance: none !important;
        -webkit-appearance: none !important;
        -moz-appearance: none !important;
        min-height: 50px !important;
        transition: all 0.3s ease !important;
    }
    
    .form-select-mobile:focus {
        border-color: #007bff !important;
        background-color: white !important;
        box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25) !important;
        outline: none !important;
    }
    
    /* Textarea */
    .form-textarea-mobile {
        width: 100% !important;
        padding: 0.875rem 1rem !important;
        font-size: 16px !important;
        border: 2px solid #e9ecef !important;
        border-radius: 10px !important;
        background: #f8f9fa !important;
        resize: vertical !important;
        min-height: 120px !important;
        transition: all 0.3s ease !important;
    }
    
    .form-textarea-mobile:focus {
        border-color: #007bff !important;
        background: white !important;
        box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25) !important;
        outline: none !important;
    }
    
    /* Input Groups */
    .input-group-mobile {
        display: flex !important;
        width: 100% !important;
        margin-bottom: 1.5rem !important;
    }
    
    .input-group-mobile .form-control-mobile {
        border-top-left-radius: 0 !important;
        border-bottom-left-radius: 0 !important;
        margin-bottom: 0 !important;
    }
    
    .input-group-text-mobile {
        display: flex !important;
        align-items: center !important;
        padding: 0.875rem 1rem !important;
        font-size: 0.9rem !important;
        font-weight: 500 !important;
        color: #495057 !important;
        background: #e9ecef !important;
        border: 2px solid #e9ecef !important;
        border-left: none !important;
        border-top-right-radius: 10px !important;
        border-bottom-right-radius: 10px !important;
        white-space: nowrap !important;
    }
    
    /* Checkboxes and Radios */
    .form-check-mobile {
        display: flex !important;
        align-items: flex-start !important;
        margin-bottom: 1rem !important;
        padding: 0 !important;
    }
    
    .form-check-input-mobile {
        width: 20px !important;
        height: 20px !important;
        margin-top: 0.125rem !important;
        margin-left: 0.75rem !important;
        border: 2px solid #dee2e6 !important;
        border-radius: 4px !important;
        background-color: white !important;
        transition: all 0.2s ease !important;
        cursor: pointer !important;
    }
    
    .form-check-input-mobile:checked {
        background-color: #007bff !important;
        border-color: #007bff !important;
    }
    
    .form-check-input-mobile[type="radio"] {
        border-radius: 50% !important;
    }
    
    .form-check-label-mobile {
        font-size: 0.9rem !important;
        color: #495057 !important;
        cursor: pointer !important;
        line-height: 1.4 !important;
        flex: 1 !important;
    }
    
    /* File Upload */
    .form-file-mobile {
        position: relative !important;
        margin-bottom: 1.5rem !important;
    }
    
    .form-file-input-mobile {
        position: absolute !important;
        opacity: 0 !important;
        width: 100% !important;
        height: 100% !important;
        cursor: pointer !important;
    }
    
    .form-file-label-mobile {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 2rem 1rem !important;
        border: 2px dashed #dee2e6 !important;
        border-radius: 10px !important;
        background: #f8f9fa !important;
        color: #6c757d !important;
        font-size: 0.9rem !important;
        text-align: center !important;
        cursor: pointer !important;
        transition: all 0.3s ease !important;
        min-height: 120px !important;
        flex-direction: column !important;
        gap: 0.5rem !important;
    }
    
    .form-file-label-mobile:hover {
        border-color: #007bff !important;
        background: #f0f8ff !important;
        color: #007bff !important;
    }
    
    .form-file-label-mobile i {
        font-size: 2rem !important;
        margin-bottom: 0.5rem !important;
    }
    
    .form-file-preview-mobile {
        display: none !important;
        margin-top: 1rem !important;
        padding: 1rem !important;
        border: 1px solid #dee2e6 !important;
        border-radius: 8px !important;
        background: white !important;
    }
    
    .form-file-preview-mobile.show {
        display: block !important;
    }
    
    .form-file-preview-item-mobile {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        padding: 0.5rem 0 !important;
        border-bottom: 1px solid #e9ecef !important;
    }
    
    .form-file-preview-item-mobile:last-child {
        border-bottom: none !important;
    }
    
    .form-file-preview-info-mobile {
        display: flex !important;
        align-items: center !important;
        gap: 0.75rem !important;
    }
    
    .form-file-preview-icon-mobile {
        width: 40px !important;
        height: 40px !important;
        border-radius: 8px !important;
        background: #f8f9fa !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        color: #6c757d !important;
    }
    
    .form-file-preview-details-mobile {
        flex: 1 !important;
    }
    
    .form-file-preview-name-mobile {
        font-size: 0.85rem !important;
        font-weight: 500 !important;
        color: #495057 !important;
        margin-bottom: 0.25rem !important;
    }
    
    .form-file-preview-size-mobile {
        font-size: 0.75rem !important;
        color: #6c757d !important;
    }
    
    .form-file-preview-remove-mobile {
        background: none !important;
        border: none !important;
        color: #dc3545 !important;
        font-size: 1.2rem !important;
        cursor: pointer !important;
        padding: 0.25rem !important;
        border-radius: 4px !important;
        transition: all 0.2s ease !important;
    }
    
    .form-file-preview-remove-mobile:hover {
        background: #f8d7da !important;
    }
    
    /* Form Validation */
    .form-feedback-mobile {
        font-size: 0.8rem !important;
        margin-top: 0.5rem !important;
        display: block !important;
    }
    
    .form-feedback-mobile.invalid {
        color: #dc3545 !important;
    }
    
    .form-feedback-mobile.valid {
        color: #28a745 !important;
    }
    
    .form-help-mobile {
        font-size: 0.8rem !important;
        color: #6c757d !important;
        margin-top: 0.25rem !important;
        display: block !important;
    }
    
    /* Form Buttons */
    .form-buttons-mobile {
        display: flex !important;
        gap: 1rem !important;
        margin-top: 2rem !important;
        padding-top: 1.5rem !important;
        border-top: 1px solid #e9ecef !important;
    }
    
    .form-btn-mobile {
        flex: 1 !important;
        padding: 0.875rem 1.5rem !important;
        font-size: 0.9rem !important;
        font-weight: 600 !important;
        border-radius: 10px !important;
        border: none !important;
        transition: all 0.3s ease !important;
        text-decoration: none !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 0.5rem !important;
        min-height: 50px !important;
        cursor: pointer !important;
    }
    
    .form-btn-mobile.primary {
        background: linear-gradient(135deg, #007bff, #0056b3) !important;
        color: white !important;
    }
    
    .form-btn-mobile.secondary {
        background: #6c757d !important;
        color: white !important;
    }
    
    .form-btn-mobile.success {
        background: linear-gradient(135deg, #28a745, #1e7e34) !important;
        color: white !important;
    }
    
    .form-btn-mobile.danger {
        background: linear-gradient(135deg, #dc3545, #c82333) !important;
        color: white !important;
    }
    
    .form-btn-mobile:hover {
        transform: translateY(-2px) !important;
        box-shadow: 0 4px 12px rgba(0,0,0,0.2) !important;
    }
    
    .form-btn-mobile:disabled {
        opacity: 0.6 !important;
        cursor: not-allowed !important;
        transform: none !important;
        box-shadow: none !important;
    }
    
    /* Loading States */
    .form-loading-mobile {
        display: none !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 2rem !important;
        color: #6c757d !important;
    }
    
    .form-loading-mobile.show {
        display: flex !important;
    }
    
    .form-loading-mobile i {
        font-size: 2rem !important;
        margin-left: 1rem !important;
        animation: spin 1s linear infinite !important;
    }
    
    @keyframes spin {
        0% { transform: rotate(0deg); }
        100% { transform: rotate(360deg); }
    }
    
    /* Form Steps */
    .form-steps-mobile {
        display: flex !important;
        justify-content: space-between !important;
        margin-bottom: 2rem !important;
        padding: 1rem 0 !important;
        border-bottom: 1px solid #e9ecef !important;
    }
    
    .form-step-mobile {
        flex: 1 !important;
        text-align: center !important;
        position: relative !important;
    }
    
    .form-step-mobile::after {
        content: '' !important;
        position: absolute !important;
        top: 15px !important;
        right: -50% !important;
        width: 100% !important;
        height: 2px !important;
        background: #e9ecef !important;
        z-index: 1 !important;
    }
    
    .form-step-mobile:last-child::after {
        display: none !important;
    }
    
    .form-step-number-mobile {
        width: 30px !important;
        height: 30px !important;
        border-radius: 50% !important;
        background: #e9ecef !important;
        color: #6c757d !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 0.8rem !important;
        font-weight: 600 !important;
        margin: 0 auto 0.5rem !important;
        position: relative !important;
        z-index: 2 !important;
        transition: all 0.3s ease !important;
    }
    
    .form-step-mobile.active .form-step-number-mobile {
        background: #007bff !important;
        color: white !important;
    }
    
    .form-step-mobile.completed .form-step-number-mobile {
        background: #28a745 !important;
        color: white !important;
    }
    
    .form-step-mobile.completed::after {
        background: #28a745 !important;
    }
    
    .form-step-title-mobile {
        font-size: 0.75rem !important;
        color: #6c757d !important;
        font-weight: 500 !important;
    }
    
    .form-step-mobile.active .form-step-title-mobile {
        color: #007bff !important;
        font-weight: 600 !important;
    }
    
    .form-step-mobile.completed .form-step-title-mobile {
        color: #28a745 !important;
    }
    
    /* Form Sections */
    .form-section-mobile {
        background: white !important;
        border-radius: 12px !important;
        padding: 1.5rem !important;
        margin-bottom: 1rem !important;
        box-shadow: 0 2px 10px rgba(0,0,0,0.1) !important;
    }
    
    .form-section-header-mobile {
        display: flex !important;
        align-items: center !important;
        margin-bottom: 1.5rem !important;
        padding-bottom: 1rem !important;
        border-bottom: 1px solid #e9ecef !important;
    }
    
    .form-section-icon-mobile {
        width: 40px !important;
        height: 40px !important;
        border-radius: 50% !important;
        background: linear-gradient(135deg, #007bff, #0056b3) !important;
        color: white !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        margin-left: 1rem !important;
        font-size: 1.1rem !important;
    }
    
    .form-section-title-mobile {
        flex: 1 !important;
    }
    
    .form-section-title-mobile h5 {
        margin: 0 0 0.25rem 0 !important;
        font-size: 1.1rem !important;
        font-weight: 600 !important;
        color: #495057 !important;
    }
    
    .form-section-title-mobile p {
        margin: 0 !important;
        font-size: 0.85rem !important;
        color: #6c757d !important;
    }
}

/* Extra Small Devices */
@media (max-width: 575.98px) {
    
    .form-container-mobile {
        padding: 1rem !important;
        margin: 0.5rem 0 !important;
        border-radius: 8px !important;
    }
    
    .form-control-mobile,
    .form-select-mobile,
    .form-textarea-mobile {
        padding: 0.75rem !important;
        font-size: 16px !important;
        min-height: 48px !important;
    }
    
    .form-buttons-mobile {
        flex-direction: column !important;
        gap: 0.75rem !important;
    }
    
    .form-btn-mobile {
        min-height: 48px !important;
        padding: 0.75rem 1.25rem !important;
    }
    
    .form-steps-mobile {
        padding: 0.75rem 0 !important;
    }
    
    .form-step-number-mobile {
        width: 28px !important;
        height: 28px !important;
        font-size: 0.75rem !important;
    }
    
    .form-step-title-mobile {
        font-size: 0.7rem !important;
    }
    
    .form-section-mobile {
        padding: 1rem !important;
    }
    
    .form-section-icon-mobile {
        width: 36px !important;
        height: 36px !important;
        font-size: 1rem !important;
    }
    
    .form-file-label-mobile {
        padding: 1.5rem 1rem !important;
        min-height: 100px !important;
    }
    
    .form-file-label-mobile i {
        font-size: 1.5rem !important;
    }
}

/* Dark Mode Support */
@media (max-width: 768px) and (prefers-color-scheme: dark) {
    
    .form-container-mobile,
    .form-section-mobile {
        background: #2d3748 !important;
        color: #e2e8f0 !important;
    }
    
    .form-control-mobile,
    .form-select-mobile,
    .form-textarea-mobile {
        background: #4a5568 !important;
        border-color: #718096 !important;
        color: #e2e8f0 !important;
    }
    
    .form-control-mobile:focus,
    .form-select-mobile:focus,
    .form-textarea-mobile:focus {
        background: #4a5568 !important;
        border-color: #63b3ed !important;
        color: #e2e8f0 !important;
    }
    
    .form-label-mobile {
        color: #e2e8f0 !important;
    }
    
    .form-help-mobile {
        color: #a0aec0 !important;
    }
    
    .input-group-text-mobile {
        background: #4a5568 !important;
        border-color: #718096 !important;
        color: #e2e8f0 !important;
    }
    
    .form-file-label-mobile {
        background: #4a5568 !important;
        border-color: #718096 !important;
        color: #a0aec0 !important;
    }
    
    .form-file-label-mobile:hover {
        background: #2d3748 !important;
        border-color: #63b3ed !important;
        color: #63b3ed !important;
    }
}