/* ── Auth pages layout ───────────────────────────────────── */
.auth-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-4);
    background: var(--bg-primary);
    background-image:
        radial-gradient(ellipse at 20% 50%, rgba(45, 127, 249, 0.06) 0%, transparent 60%),
        radial-gradient(ellipse at 80% 20%, rgba(0, 194, 255, 0.04) 0%, transparent 50%);
}

/* ── Auth card ───────────────────────────────────────────── */
.auth-card {
    width: 100%;
    max-width: 440px;
    background: var(--bg-card);
    border-radius: var(--border-radius-xl);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-xl);
    padding: var(--space-8);
    animation: fadeInUp 0.35s ease both;
}

/* ── Logo ────────────────────────────────────────────────── */
.auth-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
    margin-bottom: var(--space-6);
    text-decoration: none;
}

.auth-logo-icon {
    width: 44px;
    height: 44px;
    background: linear-gradient(135deg, var(--color-blue), var(--color-cyan));
    border-radius: var(--border-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    color: #fff;
    box-shadow: var(--shadow-blue);
    flex-shrink: 0;
}

.auth-logo-name {
    font-family: var(--font-primary);
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--text-primary);
    letter-spacing: -0.02em;
}

/* ── Auth header ─────────────────────────────────────────── */
.auth-header {
    text-align: center;
    margin-bottom: var(--space-6);
}

.auth-title {
    font-family: var(--font-primary);
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--text-primary);
    margin-bottom: var(--space-2);
}

.auth-subtitle {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    line-height: 1.6;
}

/* ── Auth form ───────────────────────────────────────────── */
.auth-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.auth-submit {
    margin-top: var(--space-2);
    position: relative;
}

/* ── Divider de texto ────────────────────────────────────── */
.auth-divider {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    color: var(--text-muted);
    font-size: var(--text-xs);
    margin: var(--space-2) 0;
}

.auth-divider::before,
.auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border-color);
}

/* ── Links de auth ───────────────────────────────────────── */
.auth-footer {
    margin-top: var(--space-5);
    text-align: center;
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.auth-footer a {
    color: var(--color-blue);
    font-weight: var(--font-medium);
}

.auth-footer a:hover {
    color: var(--color-cyan);
    text-decoration: underline;
}

.auth-link-top {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    margin-bottom: var(--space-6);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.auth-link-top:hover { color: var(--text-primary); }

/* ── Forgot password link ────────────────────────────────── */
.forgot-link {
    font-size: var(--text-xs);
    color: var(--text-secondary);
    text-align: right;
    margin-top: calc(-1 * var(--space-2));
}

.forgot-link a { color: var(--color-blue); }
.forgot-link a:hover { color: var(--color-cyan); }

/* ── Password strength ───────────────────────────────────── */
.password-strength {
    display: flex;
    gap: var(--space-1);
    margin-top: var(--space-1);
}

.strength-bar {
    flex: 1;
    height: 3px;
    background: var(--border-color);
    border-radius: var(--border-radius-full);
    transition: background var(--transition-fast);
}

.strength-bar.active-weak   { background: var(--color-red);    }
.strength-bar.active-medium { background: var(--color-yellow);  }
.strength-bar.active-strong { background: var(--color-green);   }

/* ── Success state ───────────────────────────────────────── */
.auth-success {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-4);
    text-align: center;
    padding: var(--space-4) 0;
}

.auth-success-icon {
    width: 64px;
    height: 64px;
    background: var(--color-green-soft);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    color: var(--color-green);
}

.auth-success-title {
    font-family: var(--font-primary);
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    color: var(--text-primary);
}

.auth-success-text {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    max-width: 300px;
    line-height: 1.6;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 480px) {
    .auth-card {
        padding: var(--space-6);
        border-radius: var(--border-radius-lg);
    }

    .auth-title { font-size: var(--text-xl); }
}
