/* ══════════════════════════════════════════════════════════
   Azamind Auth — uses tokens from App.Shared/css/tokens.css
   Fonts loaded from App.Shared/app.css
   ══════════════════════════════════════════════════════════ */

/* ── Base ────────────────────────────────────────────── */

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--az-font-family);
    background: var(--az-surface-900);
    color: var(--az-on-surface);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    transition: background 0.3s, color 0.3s;
}

/* ── Container ───────────────────────────────────────── */

.auth-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 2rem 1rem;
}

/* ── Brand ───────────────────────────────────────────── */

.auth-logo {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    margin-bottom: 2rem;
}

.auth-brand-name {
    font-size: 1.35rem;
    font-weight: 700;
    background: var(--az-gold-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    letter-spacing: 0.12em;
}

.auth-brand-tagline {
    font-size: var(--az-text-overline);
    color: var(--az-surface-200);
    letter-spacing: 0.12em;
    text-transform: lowercase;
}

/* ── Card ────────────────────────────────────────────── */

.auth-card {
    width: 100%;
    max-width: 420px;
    background: var(--az-glass-bg);
    border: var(--az-glass-border);
    border-radius: var(--az-radius-lg);
    padding: 2rem;
    backdrop-filter: blur(var(--az-glass-blur));
    box-shadow: var(--az-glass-shadow);
    transition: background 0.3s, border-color 0.3s, box-shadow 0.3s;
}

.auth-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--az-on-surface);
    margin-bottom: 0.25rem;
}

.auth-subtitle {
    font-size: var(--az-text-body);
    color: var(--az-on-surface-secondary);
    margin-bottom: 1.5rem;
    line-height: 1.5;
}

/* ── Form ────────────────────────────────────────────── */

.form-group {
    margin-bottom: 1rem;
}

.form-group label {
    display: block;
    font-size: var(--az-text-body-sm);
    font-weight: 500;
    color: var(--az-on-surface-secondary);
    margin-bottom: 0.375rem;
}

.form-input {
    width: 100%;
    padding: 0.7rem 0.875rem;
    background: rgba(var(--az-gold-rgb), 0.04);
    border: 1px solid var(--az-surface-400);
    border-radius: var(--az-radius-md);
    color: var(--az-on-surface);
    font-family: inherit;
    font-size: 0.95rem;
    transition: border-color var(--az-transition-fast), box-shadow var(--az-transition-fast);
    outline: none;
}

.form-input::placeholder {
    color: var(--az-surface-200);
}

.form-input:focus {
    border-color: var(--az-gold);
    box-shadow: 0 0 0 3px rgba(var(--az-gold-rgb), 0.3);
}

/* ── Form row (remember me + forgot) ─────────────────── */

.form-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.25rem;
    font-size: var(--az-text-body-sm);
}

.checkbox-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--az-on-surface-secondary);
    cursor: pointer;
}

.checkbox-label input[type="checkbox"] {
    accent-color: var(--az-gold);
    width: 16px;
    height: 16px;
}

/* ── Buttons ─────────────────────────────────────────── */

.btn-primary,
a.btn-primary,
a.btn-primary:visited {
    display: block;
    width: 100%;
    padding: 0.75rem;
    background: var(--az-gold);
    color: var(--az-on-primary);
    border: none;
    border-radius: var(--az-radius-md);
    font-family: inherit;
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--az-transition-fast), transform 0.1s;
}

.btn-primary:hover,
a.btn-primary:hover,
a.btn-primary:focus {
    background: var(--az-gold-light);
    color: var(--az-on-primary);
}

.btn-primary:active {
    transform: scale(0.98);
}

.btn-google {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.625rem;
    width: 100%;
    padding: 0.7rem;
    background: transparent;
    color: var(--az-on-surface);
    border: 1px solid var(--az-surface-400);
    border-radius: var(--az-radius-md);
    font-family: inherit;
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: border-color var(--az-transition-fast), background var(--az-transition-fast);
}

.btn-google:hover {
    border-color: var(--az-surface-300);
    background: rgba(var(--az-gold-rgb), 0.04);
}

.google-icon {
    flex-shrink: 0;
}

/* ── Divider ─────────────────────────────────────────── */

.divider {
    display: flex;
    align-items: center;
    margin: 1.25rem 0;
    color: var(--az-on-surface-secondary);
    font-size: 0.8rem;
}

.divider::before,
.divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--az-surface-400);
}

.divider span {
    padding: 0 0.75rem;
}

/* ── Links ───────────────────────────────────────────── */

.link-gold {
    color: var(--az-gold);
    text-decoration: none;
    font-weight: 500;
    transition: color var(--az-transition-fast);
}

.link-gold:hover {
    color: var(--az-gold-light);
}

/* ── Footer text ─────────────────────────────────────── */

.auth-footer {
    text-align: center;
    margin-top: 1.25rem;
    font-size: var(--az-text-body-sm);
    color: var(--az-on-surface-secondary);
}

/* ── Errors ──────────────────────────────────────────── */

.auth-error {
    background: var(--az-danger-lighter);
    border: 1px solid rgba(255, 59, 48, 0.25);
    border-radius: var(--az-radius-md);
    padding: 0.75rem;
    margin-bottom: 1rem;
    color: var(--az-danger);
    font-size: var(--az-text-body-sm);
    line-height: 1.5;
}

.auth-error:empty {
    display: none;
}

.field-error {
    display: block;
    color: var(--az-danger);
    font-size: var(--az-text-overline);
    margin-top: 0.25rem;
}

.auth-error ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.auth-error ul li + li {
    margin-top: 0.25rem;
}

/* ── Info grid (user profile) ─────────────────────────── */

.info-grid {
    display: flex;
    flex-direction: column;
    gap: 0.625rem;
}

.info-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--az-surface-600);
}

.info-row:last-child {
    border-bottom: none;
}

.info-label {
    font-size: var(--az-text-body-sm);
    color: var(--az-on-surface-secondary);
    white-space: nowrap;
    flex-shrink: 0;
}

.info-value {
    font-size: var(--az-text-body-sm);
    color: var(--az-on-surface);
    text-align: right;
    word-break: break-all;
}

.info-mono {
    font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
    font-size: var(--az-text-overline);
    opacity: 0.8;
}

.info-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    border-radius: var(--az-radius-full);
    font-size: var(--az-text-overline);
    font-weight: 600;
    letter-spacing: 0.03em;
    background: rgba(var(--az-gold-rgb), 0.12);
    color: var(--az-gold);
    border: 1px solid rgba(var(--az-gold-rgb), 0.2);
}

.info-badge + .info-badge {
    margin-left: 0.375rem;
}

.info-badge-success {
    background: var(--az-success-lighter);
    color: var(--az-success);
    border-color: transparent;
}

.info-badge-danger {
    background: var(--az-danger-lighter);
    color: var(--az-danger);
    border-color: transparent;
}

/* ── Nav sections (Index page) ────────────────────────── */

.nav-section {
    margin-bottom: 1.5rem;
}

.nav-section:last-child {
    margin-bottom: 0;
}

.nav-section-title {
    font-size: var(--az-text-overline);
    color: var(--az-on-surface-secondary);
    margin-bottom: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 600;
}

.nav-section-links {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

/* ── Nav links ───────────────────────────────────────── */

.nav-link {
    display: block;
    padding: 0.6rem 0.875rem;
    background: rgba(var(--az-gold-rgb), 0.04);
    border: 1px solid var(--az-surface-400);
    border-radius: var(--az-radius-md);
    color: var(--az-on-surface);
    text-decoration: none;
    font-size: 0.9rem;
    transition: border-color var(--az-transition-fast), background var(--az-transition-fast), color var(--az-transition-fast);
}

.nav-link:hover {
    border-color: var(--az-gold);
    background: rgba(var(--az-gold-rgb), 0.08);
    color: var(--az-gold);
}
