﻿/* ============================================================================
   File: auth-modals.css
   Project: MyCaseHub.Web
   Path: Web/wwwroot/css/auth-modals.css
   Created: Batch 1.5 Extension - Modal Authentication
   Description: Custom styling for login and forgot password modals
   ============================================================================ */

/* ========== Modal Customization ========== */

/* Modal content shadow and border radius */
#loginModal .modal-content,
#forgotPasswordModal .modal-content {
    border: none;
    border-radius: 10px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
}

/* Modal header styling */
#loginModal .modal-header {
    background-color: #1e40af;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    border-bottom: none;
}

#forgotPasswordModal .modal-header {
    background-color: #1e40af;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    border-bottom: none;
}

/* Modal title */
.modal-title {
    font-weight: 600;
    font-size: 1.25rem;
}

/* Modal body padding */
#loginModal .modal-body,
#forgotPasswordModal .modal-body {
    padding: 2rem;
}

/* Modal footer */
#loginModal .modal-footer,
#forgotPasswordModal .modal-footer {
    border-top: 1px solid #e5e7eb;
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
    background-color: #f9fafb;
}

/* ========== Form Styling ========== */

/* Form labels */
#loginModal label,
#forgotPasswordModal label {
    font-weight: 500;
    color: #374151;
    margin-bottom: 0.5rem;
}

/* Form inputs */
#loginModal .form-control,
#forgotPasswordModal .form-control {
    border: 2px solid #e5e7eb;
    border-radius: 8px;
    padding: 0.75rem 1rem;
    font-size: 0.95rem;
    transition: all 0.3s ease;
}

    #loginModal .form-control:focus,
    #forgotPasswordModal .form-control:focus {
        border-color: #1e40af;
        box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.1);
        outline: none;
    }

    #forgotPasswordModal .form-control:focus {
        border-color: #1e40af;
        box-shadow: 0 0 0 3px rgba(30, 64, 175, 0.1);
    }

    /* Invalid input styling */
    #loginModal .form-control.is-invalid,
    #forgotPasswordModal .form-control.is-invalid {
        border-color: #ef4444;
        box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
    }

/* ========== Button Styling ========== */

/* Primary buttons */
#loginModal .btn-primary,
#forgotPasswordModal .btn-primary {
    padding: 0.75rem 1.5rem;
    font-weight: 600;
    border-radius: 8px;
    transition: all 0.3s ease;
    border: none;
    background-color: #1e40af;
}

    #loginModal .btn-primary:hover,
    #forgotPasswordModal .btn-primary:hover {
        background-color: #1e3a8a;
        transform: translateY(-1px);
        box-shadow: 0 4px 12px rgba(30, 64, 175, 0.3);
    }

    /* Disabled button state */
    #loginModal .btn-primary:disabled,
    #forgotPasswordModal .btn-primary:disabled {
        opacity: 0.6;
        cursor: not-allowed;
        transform: none;
    }

/* Password toggle button */
#toggleLoginPassword {
    border: 2px solid #e5e7eb;
    border-left: none;
    background-color: #f9fafb;
    color: #6b7280;
    transition: all 0.2s ease;
}

    #toggleLoginPassword:hover {
        background-color: #f3f4f6;
        color: #374151;
    }

    #toggleLoginPassword:focus {
        outline: none;
        box-shadow: none;
    }

/* ========== Alert Styling ========== */

#loginModal .alert,
#forgotPasswordModal .alert {
    border-radius: 8px;
    padding: 1rem;
    margin-bottom: 1.5rem;
    border: none;
}

#loginModal .alert-success,
#forgotPasswordModal .alert-success {
    background-color: #d1fae5;
    color: #065f46;
}

#loginModal .alert-danger,
#forgotPasswordModal .alert-danger {
    background-color: #fee2e2;
    color: #991b1b;
}

#loginModal .alert-info,
#forgotPasswordModal .alert-info {
    background-color: #dbeafe;
    color: #1e40af;
    border-left: 4px solid #1e40af;
}

/* ========== Link Styling ========== */

#loginModal a,
#forgotPasswordModal a {
    color: #1e40af;
    text-decoration: none;
    font-weight: 500;
    transition: color 0.2s ease;
}

    #loginModal a:hover,
    #forgotPasswordModal a:hover {
        color: #1e3a8a;
        text-decoration: underline;
    }

/* ========== Checkbox Styling ========== */

#loginRememberMe {
    width: 1.125rem;
    height: 1.125rem;
    border: 2px solid #d1d5db;
    border-radius: 4px;
    cursor: pointer;
}

    #loginRememberMe:checked {
        background-color: #1e40af;
        border-color: #1e40af;
    }

.form-check-label {
    margin-left: 0.5rem;
    cursor: pointer;
    user-select: none;
}

/* ========== Success State Styling ========== */

#forgotPasswordSuccessState {
    animation: fadeInUp 0.5s ease;
}

    #forgotPasswordSuccessState .fa-envelope-open-text {
        animation: bounce 1s ease;
    }

/* ========== Divider Styling ========== */

#loginModal hr,
#forgotPasswordModal hr {
    margin: 1.5rem 0;
    border-top: 2px solid #e5e7eb;
}

/* ========== Animations ========== */

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% {
        transform: translateY(0);
    }

    40% {
        transform: translateY(-10px);
    }

    60% {
        transform: translateY(-5px);
    }
}

/* ========== Responsive Design ========== */

@media (max-width: 576px) {
    #loginModal .modal-body,
    #forgotPasswordModal .modal-body {
        padding: 1.5rem;
    }

    #loginModal .modal-header,
    #forgotPasswordModal .modal-header {
        padding: 1rem 1.5rem;
    }

    .modal-title {
        font-size: 1.1rem;
    }

    #loginModal .btn-primary,
    #forgotPasswordModal .btn-primary {
        padding: 0.65rem 1.25rem;
    }
}

/* ========== Modal Backdrop ========== */

.modal-backdrop {
    background-color: rgba(0, 0, 0, 0.7);
}

    .modal-backdrop.show {
        opacity: 0.7;
    }

/* ========== Accessibility ========== */

/* Focus visible for keyboard navigation */
#loginModal .btn:focus,
#forgotPasswordModal .btn:focus,
#loginModal .form-control:focus,
#forgotPasswordModal .form-control:focus,
#loginModal a:focus,
#forgotPasswordModal a:focus {
    outline: 2px solid #1e40af;
    outline-offset: 2px;
}
