/* Form Protection CSS - Visual feedback for form interactions */

/* Prevent accidental form submission visual cues */
.form-protection {
    position: relative;
}

.form-protection::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(255, 255, 255, 0.8);
    z-index: 1;
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
}

.form-protection.typing::before {
    opacity: 0.3;
}

/* Input field protection indicators */
input[type="text"]:not([name="q"]):not([data-search]),
input[type="number"]:not([name="q"]):not([data-search]),
input[type="email"]:not([name="q"]):not([data-search]),
input[type="password"]:not([name="q"]):not([data-search]),
textarea:not([name="q"]):not([data-search]) {
    transition: all 0.3s ease;
    border: 2px solid #dee2e6;
}

input[type="text"]:not([name="q"]):not([data-search]):focus,
input[type="number"]:not([name="q"]):not([data-search]):focus,
input[type="email"]:not([name="q"]):not([data-search]):focus,
input[type="password"]:not([name="q"]):not([data-search]):focus,
textarea:not([name="q"]):not([data-search]):focus {
    border-color: #0d6efd;
    box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
    background-color: #ffffff;
}

/* Typing indicator */
.typing-indicator {
    position: absolute;
    top: -25px;
    right: 10px;
    background: #0d6efd;
    color: white;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 10;
}

.typing-indicator.show {
    opacity: 1;
}

/* Form submission protection */
.form-submit-protection {
    position: relative;
}

.form-submit-protection button[type="submit"] {
    position: relative;
    z-index: 2;
}

.form-submit-protection::after {
    content: 'Form akan submit hanya saat tombol ditekan';
    position: absolute;
    top: -30px;
    left: 0;
    background: #28a745;
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 12px;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 10;
    white-space: nowrap;
}

.form-submit-protection:hover::after {
    opacity: 1;
}

/* Search form indicators */
form[data-search="true"] input[name="q"] {
    border-color: #28a745;
    background-color: #f8fff9;
}

form[data-search="true"] input[name="q"]:focus {
    border-color: #28a745;
    box-shadow: 0 0 0 0.25rem rgba(40, 167, 69, 0.25);
}

/* Auto-submit form indicators */
form[data-auto-submit="true"] {
    border: 2px dashed #ffc107;
    border-radius: 8px;
    padding: 10px;
    margin-bottom: 10px;
}

form[data-auto-submit="true"]::before {
    content: '⚠️ Form ini akan submit otomatis saat ada perubahan';
    display: block;
    background: #fff3cd;
    color: #856404;
    padding: 8px;
    border-radius: 4px;
    margin-bottom: 10px;
    font-size: 14px;
    font-weight: 500;
}

/* Mobile-specific protection */
@media (max-width: 768px) {
    .form-protection::before {
        background: rgba(0, 123, 255, 0.1);
    }
    
    .typing-indicator {
        top: -30px;
        font-size: 11px;
    }
    
    .form-submit-protection::after {
        top: -35px;
        font-size: 11px;
    }
}

/* High contrast mode */
@media (prefers-contrast: high) {
    input[type="text"]:not([name="q"]):not([data-search]),
    input[type="number"]:not([name="q"]):not([data-search]),
    input[type="email"]:not([name="q"]):not([data-search]),
    input[type="password"]:not([name="q"]):not([data-search]),
    textarea:not([name="q"]):not([data-search]) {
        border: 3px solid #000000;
    }
    
    input[type="text"]:not([name="q"]):not([data-search]):focus,
    input[type="number"]:not([name="q"]):not([data-search]):focus,
    input[type="email"]:not([name="q"]):not([data-search]):focus,
    input[type="password"]:not([name="q"]):not([data-search]):focus,
    textarea:not([name="q"]):not([data-search]):focus {
        border-color: #0000ff;
        box-shadow: 0 0 0 3px #0000ff;
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    .form-protection::before,
    .typing-indicator,
    .form-submit-protection::after,
    input[type="text"]:not([name="q"]):not([data-search]),
    input[type="number"]:not([name="q"]):not([data-search]),
    input[type="email"]:not([name="q"]):not([data-search]),
    input[type="password"]:not([name="q"]):not([data-search]),
    textarea:not([name="q"]):not([data-search]) {
        transition: none;
    }
}

/* Print styles */
@media print {
    .form-protection::before,
    .typing-indicator,
    .form-submit-protection::after {
        display: none !important;
    }
    
    form[data-auto-submit="true"]::before {
        display: none !important;
    }
}

