/* Shared Login Page Styles */ .login-container { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: linear-gradient( 135deg, var(--color-primary-light) 0%, var(--color-primary) 100% ); padding: 1rem; } .login-wrapper { width: 100%; max-width: 400px; } .login-card { box-shadow: 0 25px 50px rgba(0, 0, 0, 0.15); border-radius: 16px; overflow: hidden; border: 1px solid rgba(255, 255, 255, 0.1); background: var(--surface-card); } .login-header { text-align: center; padding: 2rem 2rem 1rem 2rem; background: var(--surface-card); } .login-title { margin: 1rem 0 0.5rem 0; color: var(--primary-color); font-size: 2rem; font-weight: 700; } .login-subtitle { margin: 0; color: var(--text-color-secondary); font-size: 0.95rem; } .login-form { padding: 0 2rem 2rem 2rem; background: var(--surface-card); } .login-button { margin-top: 1rem; padding: 0.75rem; font-size: 1.1rem; font-weight: 600; background: var(--color-primary-light) !important; color: white !important; border: none !important; box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); transition: all 0.3s ease; } .login-button:hover { background: var(--color-primary) !important; box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15); transform: translateY(-2px); } .login-button:active { transform: translateY(0); box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); } .login-error-message { display: flex; align-items: center; gap: 0.5rem; padding: 0.75rem; margin-bottom: 1rem; background-color: var(--red-50); color: var(--red-800); border: 1px solid var(--red-200); border-radius: 6px; font-size: 0.9rem; } .login-footer { text-align: center; padding: 1rem 2rem; background-color: var(--surface-ground); border-top: 1px solid var(--surface-border); } .login-footer small { color: var(--text-color-secondary); } /* Dark mode support */ [data-theme="dark"] .login-footer { background-color: var(--surface-ground); } [data-theme="dark"] .login-error-message { background-color: rgba(239, 68, 68, 0.15); color: var(--red-300); border-color: var(--red-800); } /* Responsive design */ @media (max-width: 768px) { .login-container { padding: 0.5rem; } .login-wrapper { max-width: 100%; padding: 0 1rem; } .login-card { border-radius: 8px; } .login-header { padding: 1.5rem 1rem; } .login-title { font-size: 1.5rem; } .login-form { padding: 0 1rem 1.5rem 1rem; } /* Ensure inputs are touch-friendly */ .login-container .p-inputtext, .login-container .p-password input { min-height: 44px; font-size: 16px; /* Prevents zoom on iOS */ } .login-footer { padding: 1rem; } } @media (max-width: 480px) { .login-container { padding: 0.25rem; } .login-card { margin: 0; } .login-header { padding: 1rem 0.5rem; } .login-title { font-size: 1.25rem; } .login-subtitle { font-size: 0.875rem; } .login-form { padding: 0 0.5rem 1rem 0.5rem; } .login-footer { padding: 0.75rem 0.5rem; } } /* Animation for smooth transitions */ .login-card { animation: loginFadeInUp 0.6s ease-out; } @keyframes loginFadeInUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }