/* ═══════════════════════════════════════════════════════
   AUTH PAGES — Login, Register styles
   ═══════════════════════════════════════════════════════ */

.auth-body {
    min-height: 100vh;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--teal-50) 0%, var(--bg-body) 50%, var(--teal-50) 100%);
    padding: var(--space-lg);
}

.auth-container {
    width: 100%; max-width: 460px;
    animation: fadeInUp .5s ease;
}

.auth-card {
    background: var(--bg-card);
    border-radius: var(--radius-2xl);
    padding: var(--space-2xl);
    box-shadow: var(--shadow-xl);
}

.auth-logo {
    display: flex; align-items: center; justify-content: center;
    gap: 12px; margin-bottom: var(--space-xl);
}
.auth-logo-icon {
    width: 48px; height: 48px;
    background: linear-gradient(135deg, var(--teal-400), var(--teal-600));
    border-radius: var(--radius-lg);
    display: flex; align-items: center; justify-content: center;
    font-size: 24px;
}
.auth-logo-text {
    font-size: var(--font-2xl); font-weight: var(--fw-bold);
    color: var(--text-primary);
}
.auth-logo-text span { color: var(--color-primary); }

.auth-title {
    font-size: var(--font-xl); font-weight: var(--fw-bold);
    text-align: center; margin-bottom: 4px;
}
.auth-subtitle {
    font-size: var(--font-sm); color: var(--text-secondary);
    text-align: center; margin-bottom: var(--space-xl);
}

.auth-footer {
    text-align: center; margin-top: var(--space-xl);
    font-size: var(--font-sm); color: var(--text-secondary);
}
.auth-footer a { font-weight: var(--fw-semibold); }

.auth-divider {
    display: flex; align-items: center; gap: 16px;
    margin: var(--space-lg) 0;
    color: var(--text-muted); font-size: var(--font-xs);
}
.auth-divider::before, .auth-divider::after {
    content: ''; flex: 1; height: 1px; background: var(--gray-200);
}

/* ─── Register Type Selection ─── */
.register-options {
    display: grid; gap: var(--space-lg);
}
.register-option {
    display: flex; align-items: center; gap: 16px;
    padding: var(--space-lg);
    border: 2px solid var(--gray-200);
    border-radius: var(--radius-xl);
    cursor: pointer;
    transition: all var(--transition-base);
    color: var(--text-primary);
}
.register-option:hover {
    border-color: var(--color-primary);
    background: var(--color-primary-bg);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
.register-option-icon {
    width: 56px; height: 56px;
    border-radius: var(--radius-lg);
    display: flex; align-items: center; justify-content: center;
    font-size: 28px; flex-shrink: 0;
}
.register-option-icon.paciente { background: var(--color-info-bg); }
.register-option-icon.psicologo { background: var(--color-success-bg); }
.register-option-title { font-weight: var(--fw-bold); font-size: var(--font-md); }
.register-option-desc { font-size: var(--font-xs); color: var(--text-secondary); margin-top: 2px; }

/* ─── Password Toggle ─── */
.password-wrapper { position: relative; }
.password-toggle {
    position: absolute; right: 14px; top: 50%; transform: translateY(-50%);
    color: var(--text-muted); cursor: pointer;
    padding: 4px;
}
