
    /* Login Page Styles */
    .login-page {
        background: linear-gradient(135deg, var(--primary-50) 0%, var(--bg-primary) 100%);
        font-family: var(--font-primary);
        position: relative;
        overflow-x: hidden;
    }
    
    .bg-pattern {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23e2e8f0' fill-opacity='0.3'%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
        z-index: -1;
    }
    
    .login-container {
        background: var(--bg-primary);
        border-radius: var(--radius-2xl);
        box-shadow: var(--shadow-2xl);
        padding: 2rem;
        position: relative;
        z-index: 1;
    }
    
    .home-icon-mobile {
        position: absolute;
        top: 1rem;
        left: 1rem;
        z-index: 10;
    }
    
    .home-link {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 40px;
        background: var(--bg-secondary);
        border-radius: 50%;
        color: var(--text-secondary);
        text-decoration: none;
        transition: all 0.3s ease;
        box-shadow: var(--shadow-sm);
    }
    
    .home-link:hover {
        background: var(--color-primary);
        color: var(--text-inverse);
        transform: scale(1.1);
    }
    
    .home-link i {
        font-size: 1.1rem;
    }
    
    .logo-link {
        text-decoration: none;
        transition: transform 0.3s ease;
    }
    
    .logo-link:hover {
        transform: scale(1.05);
    }
    
    .brand-name {
        font-size: 2rem;
        font-weight: 700;
        margin: 0;
    }
    
    .welcome-title {
        font-size: 2rem;
        font-weight: 700;
        color: var(--text-primary);
        font-family: var(--font-heading);
    }
    
    .welcome-subtitle {
        font-size: 1rem;
        line-height: 1.5;
    }
    
    .form-label {
        font-weight: 600;
        color: var(--text-primary);
        margin-bottom: 0.5rem;
    }
    
    .form-control {
        border: 2px solid var(--border-light);
        border-radius: var(--radius-lg);
        padding: 0.6rem 0.875rem;
        font-size: 0.95rem;
        transition: all 0.3s ease;
    }
    
    .form-control:focus {
        border-color: var(--color-primary);
        box-shadow: 0 0 0 3px var(--primary-100);
    }
    
    .input-group-text {
        background: var(--bg-secondary);
        border: 2px solid var(--border-light);
        border-right: none;
        color: var(--text-secondary);
    }
    
    .input-group .form-control {
        border-left: none;
    }
    
    .input-group .form-control:focus + .input-group-text {
        border-color: var(--color-primary);
    }
    
    /* Toggle password button styling */
    #togglePassword {
        border: 2px solid var(--border-light);
        border-left: none;
        border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
        transition: all 0.3s ease;
        width: 30px;
        min-width: 30px;
    }
    
    #togglePassword:hover {
        border-color: var(--color-primary);
        background: var(--primary-50);
        color: var(--color-primary);
    }
    
    .input-group .form-control:focus ~ #togglePassword {
        border-color: var(--color-primary);
    }
    
    .forgot-link {
        color: var(--color-primary);
        text-decoration: none;
        font-weight: 500;
        transition: color 0.3s ease;
    }
    
    .forgot-link:hover {
        color: var(--color-primary-dark);
    }
    
    .btn-primary {
        background: var(--color-primary);
        border: none;
        font-weight: 600;
        padding: 0.75rem 1.5rem;
        border-radius: var(--radius-lg);
        transition: all 0.3s ease;
    }
    
    .btn-primary:hover {
        background: var(--color-primary-dark);
        transform: translateY(-2px);
        box-shadow: var(--shadow-lg);
    }
    
    .divider {
        position: relative;
        text-align: center;
    }
    
    .divider::before {
        content: '';
        position: absolute;
        top: 50%;
        left: 0;
        right: 0;
        height: 1px;
        background: var(--border-light);
    }
    
    .divider span {
        background: var(--bg-primary);
        padding: 0 1rem;
        color: var(--text-secondary);
        font-size: 0.9rem;
    }
    
    .social-login .btn {
        border: 2px solid var(--border-light);
        border-radius: var(--radius-lg);
        padding: 0.75rem 1rem;
        font-weight: 500;
        transition: all 0.3s ease;
    }
    
    .social-login .btn:hover {
        border-color: var(--color-primary);
        background: var(--primary-50);
        color: var(--color-primary);
    }
    
    .signup-cta {
        border-top: 1px solid var(--border-light);
        padding-top: 2rem;
    }
    
    .signup-cta .btn {
        border: 2px solid var(--color-primary);
        border-radius: var(--radius-lg);
        font-weight: 600;
        transition: all 0.3s ease;
    }
    
    .signup-cta .btn:hover {
        background: var(--color-primary);
        color: var(--text-inverse);
        transform: translateY(-2px);
    }
    
    /* Hero Content Styles */
    .hero-content {
        max-width: 500px;
    }
    
    .hero-title {
        font-size: 1.5rem;
        font-weight: 700;
        font-family: var(--font-heading);
        color: #ffffff;
    }
    
    .hero-subtitle {
        font-size: 1.2rem;
        line-height: 1.6;
        opacity: 0.9;
    }
    
    .features-list {
        text-align: left;
    }
    
    .feature-item {
        font-size: 1.1rem;
        opacity: 0.9;
        color: white;
    }
    
    .feature-item i {
        color: var(--success-500);
    }
    
    .testimonial {
        background: rgba(255, 255, 255, 0.1);
        border-radius: var(--radius-xl);
        padding: 2rem;
        backdrop-filter: blur(10px);
    }
    
    .testimonial-content p {
        font-style: italic;
        font-size: 1.1rem;
        line-height: 1.6;
    }
    
    .testimonial-author {
        display: flex;
        align-items: center;
    }
    
    /* Responsive Design */
    @media (max-width: 1200px) {
        .login-container {
            max-width: 400px !important;
        }
        
        .hero-content {
            padding: 2rem;
        }
    }
    
    @media (max-width: 992px) {
        .login-container {
            max-width: 100% !important;
            margin: 1rem;
        }
        
        .welcome-title {
            font-size: 2.2rem;
        }
        
        .hero-title {
            font-size: 2.8rem;
        }
        
        .hero-subtitle {
            font-size: 1.1rem;
        }
    }
    
    @media (max-width: 768px) {
        .login-page {
            min-height: 100vh;
            padding: 1rem 0;
        }
        
        .login-container {
            padding: 2rem 1.5rem;
            margin: 0.5rem;
            border-radius: var(--radius-xl);
            box-shadow: var(--shadow-lg);
        }
        
        .welcome-title {
            font-size: 1.8rem;
            margin-bottom: 0.5rem;
        }
        
        .welcome-subtitle {
            font-size: 1rem;
        }
        
        .brand-name {
            font-size: 1.5rem;
        }
        
        .logo-img {
            height: 50px !important;
        }
        
        .form-group {
            margin-bottom: 1.5rem;
        }
        
        .form-control {
            padding: 0.875rem 1rem;
            font-size: 1rem;
        }
        
        .btn {
            padding: 0.875rem 1.5rem;
            font-size: 1rem;
        }
        
        .btn-lg {
            padding: 1rem 1.5rem;
        }
        
        .divider {
            margin: 1.5rem 0;
        }
        
        .social-login .btn {
            margin-bottom: 0.75rem;
        }
        
        .signup-cta {
            margin-top: 1.5rem;
        }
        
        .signup-cta p {
            font-size: 0.9rem;
        }
    }
    
    @media (max-width: 576px) {
        .login-container {
            padding: 1.5rem 1rem;
            margin: 0.25rem;
        }
        
        .welcome-title {
            font-size: 1.6rem;
        }
        
        .welcome-subtitle {
            font-size: 0.9rem;
        }
        
        .brand-name {
            font-size: 1.3rem;
        }
        
        .logo-img {
            height: 45px !important;
        }
        
        .form-control {
            padding: 0.75rem 0.875rem;
            font-size: 0.95rem;
        }
        
        .btn {
            padding: 0.75rem 1.25rem;
            font-size: 0.95rem;
        }
        
        .btn-lg {
            padding: 0.875rem 1.25rem;
        }
        
        .input-group-text {
            padding: 0.75rem 0.875rem;
        }
        
        .form-check-label {
            font-size: 0.9rem;
        }
        
        .forgot-link {
            font-size: 0.9rem;
        }
        
        .divider span {
            font-size: 0.9rem;
            padding: 0 1rem;
        }
        
        .social-login .btn {
            font-size: 0.9rem;
            padding: 0.75rem 1rem;
        }
        
        .signup-cta p {
            font-size: 0.85rem;
        }
        
        .signup-cta .btn {
            font-size: 0.9rem;
            padding: 0.875rem 1rem;
        }
    }
    
    @media (max-width: 480px) {
        .login-container {
            padding: 1.25rem 0.75rem;
        }
        
        .welcome-title {
            font-size: 1.5rem;
        }
        
        .welcome-subtitle {
            font-size: 0.85rem;
        }
        
        .form-control {
            padding: 0.7rem 0.75rem;
            font-size: 0.9rem;
        }
        
        .btn {
            padding: 0.7rem 1rem;
            font-size: 0.9rem;
        }
        
        .btn-lg {
            padding: 0.8rem 1rem;
        }
        
        .input-group-text {
            padding: 0.7rem 0.75rem;
        }
        
        /* Mobile touch improvements */
        .form-control, .btn, .input-group-text {
            -webkit-tap-highlight-color: transparent;
            touch-action: manipulation;
        }
        
        .form-control:focus {
            font-size: 16px !important; /* Prevents zoom on iOS */
        }
        
        .btn:active {
            transform: scale(0.98);
        }
    }
    
    /* Additional mobile improvements */
    @media (max-width: 480px) {
        .form-control, .btn {
            min-height: 44px; /* Minimum touch target size */
        }
        
        .input-group-text {
            min-height: 44px;
        }
        
        .btn-close {
            min-width: 44px;
            min-height: 44px;
        }
    }
   