.app-loader {
    position: fixed;
    inset: 0;
    z-index: 999;
    display: grid;
    place-items: center;
    padding: var(--space-4);
    background: rgba(16, 20, 34, 0.48);
    backdrop-filter: blur(6px);
}

.app-loader-card {
    width: min(100%, 420px);
    display: grid;
    justify-items: center;
    gap: var(--space-3);
    padding: var(--space-5) var(--space-4);
    background: rgba(255, 255, 255, 0.96);
    text-align: center;
}

.app-loader-card strong {
    font-family: var(--font-heading);
    font-size: var(--fs-h3);
    font-weight: var(--fw-bold);
}

.app-loader-card p {
    margin: 0;
    color: var(--text-muted);
    font-size: var(--fs-body-sm);
    line-height: var(--lh-normal);
}

.app-loader-progress {
    display: grid;
    gap: var(--space-2);
    width: min(100%, 420px);
}

.app-loader-progress-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--space-3);
    font-family: var(--font-heading);
    font-size: var(--fs-meta);
    font-weight: var(--fw-bold);
    color: var(--text-muted);
}

.app-loader-progress-track {
    width: 100%;
    height: 10px;
    border-radius: var(--radius-pill);
    background: rgba(70, 72, 212, 0.12);
    overflow: hidden;
}

.app-loader-progress-bar {
    width: 0;
    height: 100%;
    border-radius: var(--radius-pill);
    background: linear-gradient(135deg, var(--accent), var(--accent-bright));
    transition: width 0.35s ease;
}

.app-loader-steps {
    width: min(100%, 420px);
    display: grid;
    gap: var(--space-2);
}

.app-loader-step {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr);
    gap: var(--space-2);
    align-items: start;
    text-align: left;
    color: var(--text-muted);
    font-size: var(--fs-body-sm);
}

.app-loader-step-badge {
    width: 22px;
    height: 22px;
    border-radius: var(--radius-pill);
    display: grid;
    place-items: center;
    background: rgba(70, 72, 212, 0.08);
    color: var(--text-soft);
    font-family: var(--font-heading);
    font-size: var(--fs-caption);
    font-weight: var(--fw-extrabold);
}

.app-loader-step-copy {
    display: grid;
    gap: var(--space-1);
}

.app-loader-step-copy strong {
    font-family: var(--font-heading);
    font-size: var(--fs-body-sm);
    font-weight: var(--fw-bold);
    color: var(--text-main);
}

.app-loader-step-copy span {
    color: var(--text-muted);
    font-size: var(--fs-meta);
    line-height: var(--lh-normal);
}

.app-loader-step.active .app-loader-step-badge {
    background: var(--accent-bright);
    color: #fff;
}

.app-loader-step.active .app-loader-step-copy strong {
    color: var(--accent);
}

.app-loader-step.done .app-loader-step-badge {
    background: var(--success-soft);
    color: var(--success);
}

.app-loader-step.done .app-loader-step-copy strong {
    color: var(--text-main);
}

.app-loader-spinner {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    border: 4px solid rgba(70, 72, 212, 0.16);
    border-top-color: var(--accent);
    animation: app-loader-spin 0.9s linear infinite;
}

.topbar-user-chip {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2);
    border-radius: var(--radius-lg);
    border: 1px solid var(--panel-border);
    background: #ffffff;
}

