body { background: #f6f7fb; }
.login-wrap { max-width: 420px; margin: 8vh auto; }
.kpi { background: #fff; border: 1px solid #e7e9f0; border-radius: 14px; padding: 18px; min-height: 110px; box-shadow: 0 1px 2px rgba(0,0,0,.03); }
.kpi span { display:block; color:#6b7280; font-size:.9rem; margin-bottom:.5rem; }
.kpi strong { font-size:1.8rem; color:#111827; }
.card { border: 1px solid #e7e9f0; border-radius: 14px; box-shadow: 0 1px 2px rgba(0,0,0,.03); }
.card-header { background: #fff; font-weight: 600; border-bottom: 1px solid #e7e9f0; }
.path-cell { max-width: 460px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.badge.status-active { background:#16a34a; }
.badge.status-planned { background:#64748b; }
.badge.status-paused { background:#ca8a04; }
.badge.status-error { background:#dc2626; }
.source-box { border-bottom: 1px solid #eef0f5; padding: .7rem 0; }
.source-box:last-child { border-bottom: 0; }
.otp-qr { width: 180px; height: 180px; background: #fff; border: 1px solid #e5e7eb; border-radius: 8px; padding: 8px; margin: 6px 0; }
table { font-size: .92rem; }
