/* ================================================
   auth.css — Login & Signup Page Styles
   ================================================ */
.auth-page { min-height: calc(100vh - 200px); display: flex; align-items: center; justify-content: center; padding: var(--space-8) var(--space-4); }
.auth-card { background: var(--color-white); border-radius: var(--radius-xl); padding: var(--space-8); width: 100%; max-width: 440px; box-shadow: var(--shadow-lg); }
.auth-logo { text-align: center; margin-bottom: var(--space-6); }
.auth-logo-text { font-family: var(--font-display); font-size: var(--text-2xl); color: var(--color-primary); }
.auth-tabs { display: flex; background: var(--color-bg); border-radius: var(--radius-md); padding: 4px; margin-bottom: var(--space-6); }
.auth-tab { flex: 1; padding: var(--space-2) var(--space-4); border-radius: var(--radius-sm); font-size: var(--text-sm); font-weight: 500; cursor: pointer; color: var(--color-text-muted); text-align: center; transition: all var(--transition-fast); background: none; border: none; }
.auth-tab.active { background: var(--color-white); color: var(--color-primary); box-shadow: var(--shadow-sm); }
.auth-form { display: flex; flex-direction: column; gap: var(--space-4); }
.auth-panel { display: none; }
.auth-panel.active { display: flex; flex-direction: column; gap: var(--space-4); }
.password-wrapper { position: relative; }
.password-wrapper .input { padding-right: 44px; }
.password-toggle { position: absolute; right: var(--space-3); top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; color: var(--color-text-muted); font-size: 1rem; }
.forgot-link { font-size: var(--text-xs); color: var(--color-primary); text-align: right; cursor: pointer; }
.forgot-link:hover { text-decoration: underline; }
.auth-divider { display: flex; align-items: center; gap: var(--space-3); margin: var(--space-2) 0; }
.auth-divider::before, .auth-divider::after { content: ''; flex: 1; border-top: 1px solid var(--color-border); }
.auth-divider span { font-size: var(--text-xs); color: var(--color-text-muted); white-space: nowrap; }
.social-btn { width: 100%; display: flex; align-items: center; justify-content: center; gap: var(--space-3); padding: var(--space-3); border: 1.5px solid var(--color-border); border-radius: var(--radius-md); font-size: var(--text-sm); font-weight: 500; cursor: pointer; transition: background var(--transition-fast); background: white; }
.social-btn:hover { background: var(--color-bg); }
.social-btn-icon { font-size: 1.2rem; }
.auth-switch { text-align: center; font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-2); }
.auth-switch a { color: var(--color-primary); font-weight: 500; cursor: pointer; }
.terms-row { display: flex; align-items: flex-start; gap: var(--space-2); font-size: var(--text-xs); color: var(--color-text-muted); }
.terms-row input { margin-top: 2px; accent-color: var(--color-primary); flex-shrink: 0; }
.terms-row a { color: var(--color-primary); }
