/* Auth Styles with Retro Vibes */
.auth-container {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: calc(100vh - calc(2 * var(--spacing-lg)));
    padding: var(--spacing-lg);
    background: linear-gradient(45deg, var(--color-background), var(--color-gray-dark));
}

.auth-box {
    background: var(--color-surface);
    padding: var(--spacing-lg);
    border: var(--border-width-thick) solid var(--color-primary);
    box-shadow: 8px 8px 0 var(--color-accent);
    max-width: 400px;
    width: 100%;
    position: relative;
    animation: float 6s ease-in-out infinite;
}

@keyframes float {
    0% { transform: translateY(0px); }
    50% { transform: translateY(-10px); }
    100% { transform: translateY(0px); }
}

.auth-box h2 {
    font-family: var(--font-display);
    font-size: var(--font-size-large);
    text-align: center;
    margin-bottom: var(--spacing-lg);
    color: var(--color-text);
    text-shadow: 2px 2px var(--color-accent);
}

.auth-form .form-group {
    margin-bottom: var(--spacing-md);
}

.auth-form label {
    display: block;
    margin-bottom: var(--spacing-xs);
    font-family: var(--font-display);
    font-size: var(--font-size-small);
    color: var(--color-text);
}

.auth-form input[type="email"],
.auth-form input[type="password"],
.auth-form input[type="text"] {
    width: 100%;
    padding: var(--spacing-sm);
    border: var(--border-width) solid var(--color-gray-light);
    background: var(--color-background);
    color: var(--color-text);
    font-family: var(--font-primary);
    font-size: var(--font-size-base);
    transition: all var(--transition-speed) var(--transition-timing);
}

.auth-form input:focus {
    border-color: var(--color-primary);
    outline: none;
    box-shadow: var(--shadow-small);
}

.auth-form input:valid {
    border-color: var(--color-success-dark);
}

/* Checkbox styling */
.checkbox-container {
    display: flex;
    align-items: center;
    cursor: pointer;
}

.checkbox-container input[type="checkbox"] {
    margin-right: var(--spacing-xs);
    width: 1.2rem;
    height: 1.2rem;
    background: var(--color-background);
    border: var(--border-width) solid var(--color-gray-light);
}

.checkbox-label {
    font-family: var(--font-primary);
    font-size: var(--font-size-base);
    color: var(--color-text);
}

/* Form actions */
.form-actions {
    text-align: center;
    margin-top: var(--spacing-lg);
}

.form-actions .btn {
    margin: var(--spacing-xs);
    background: var(--color-primary);
    color: var(--color-text);
    border: var(--border-width) solid var(--color-black);
    transition: all var(--transition-speed) var(--transition-timing);
}

.form-actions .btn:hover {
    background: var(--color-accent);
    transform: translateY(-2px);
    box-shadow: var(--shadow-small);
}

/* Auth links */
.auth-links {
    text-align: center;
    margin-top: var(--spacing-lg);
    font-family: var(--font-primary);
    font-size: var(--font-size-base);
}

.auth-links a {
    color: var(--color-accent);
    text-decoration: none;
    border-bottom: var(--border-width) dotted var(--color-accent);
    transition: all var(--transition-speed) var(--transition-timing);
}

.auth-links a:hover {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

/* 2FA specific styles */
.setup-2fa-instructions {
    margin-bottom: var(--spacing-lg);
    font-family: var(--font-primary);
    font-size: var(--font-size-base);
    color: var(--color-text);
}

.setup-2fa-instructions ol {
    padding-left: var(--spacing-md);
}

.setup-2fa-instructions li {
    margin-bottom: var(--spacing-xs);
}

.qr-code-container {
    text-align: center;
    margin: var(--spacing-lg) 0;
    padding: var(--spacing-sm);
    background: var(--color-white);
    border: var(--border-width) solid var(--color-text);
}

.qr-code-container img {
    max-width: 200px;
    height: auto;
}

.setup-2fa-warning {
    margin-top: var(--spacing-lg);
    padding: var(--spacing-sm);
    background: var(--color-accent);
    border: var(--border-width) solid var(--color-primary);
    color: var(--color-text);
}

/* Responsive design */
@media (max-width: 480px) {
    .auth-box {
        padding: var(--spacing-md);
    }
    
    .auth-box h2 {
        font-size: var(--font-size-base);
    }
    
    .auth-form label {
        font-size: var(--font-size-small);
    }
}
