:root{--brand: #0d0d0d;--brand-50: #f4f4f5;--brand-100: #e5e5e5;--brand-700: #2d2d2d;--accent: #10a37f;--accent-tint: #e6f6f1;--accent-text: #0c7a5e;--success: #15803d;--success-tint: #e7f6ec;--danger: #dc2626;--danger-tint: #fdeaea;--warning: #b45309;--warning-tint: #fdf1dd;--bg: #f7f7f8;--surface: #ffffff;--border: #e5e5e5;--text: #0d0d0d;--text-muted: #6e6e80;--radius: 12px;--sidebar-w: 240px;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);-webkit-font-smoothing:antialiased}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 14px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:14px;font-weight:500;cursor:pointer}.btn:hover{background:#f7f7f8}.btn--primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn--primary:hover{background:var(--brand-700);border-color:var(--brand-700)}.btn:disabled{background:#fff;border-color:var(--border);color:var(--text-muted);cursor:not-allowed}.input{width:100%;height:40px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);font-size:14px;outline:none}.input:focus{border-color:var(--accent)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.auth-card{width:100%;max-width:380px;background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px;box-shadow:0 8px 30px #0000000a}.auth-title{font-size:22px;font-weight:700;margin:0 0 4px}.auth-sub{color:var(--text-muted);font-size:14px;margin:0 0 20px}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-form .btn{width:100%}.auth-error{color:var(--danger);font-size:14px}.shell{display:flex;min-height:100vh}.shell-side{width:var(--sidebar-w);flex-shrink:0;border-right:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;padding:18px 14px}.shell-brand{font-size:16px;font-weight:700;padding:0 8px 16px}.shell-nav{display:flex;flex-direction:column;gap:2px;flex:1}.shell-link{display:block;padding:9px 10px;border-radius:8px;font-size:14px;color:var(--text);text-decoration:none}.shell-link:hover{background:var(--brand-50)}.shell-link.active{background:var(--accent-tint);color:var(--accent-text);font-weight:600}.shell-foot{border-top:1px solid var(--border);padding-top:12px;display:flex;flex-direction:column;gap:8px}.shell-email{font-size:13px;color:var(--text-muted);padding:0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shell-main{flex:1;min-width:0;padding:28px 32px}.page-title{font-size:24px;font-weight:700;margin:0 0 20px}.placeholder-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:28px;color:var(--text-muted);font-size:14px}.page-sub{font-size:14px;color:var(--text-muted);margin:-10px 0 20px}.mdl-name{flex:1;font-size:14px;font-weight:600;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mdl-prov{width:110px;flex-shrink:0;color:var(--text-muted);font-size:13px}.mdl-price{width:130px;flex-shrink:0;display:flex;align-items:center;gap:4px}.mdl-cur{color:var(--text-muted);font-size:13px}.mdl-input{height:34px;padding:0 8px;width:100%}.mdl-action{width:120px;flex-shrink:0;display:flex;justify-content:flex-end}.users-search{max-width:360px;margin-bottom:16px}.pager{display:flex;align-items:center;gap:14px;margin-top:16px}.pager-info{font-size:13px;color:var(--text-muted)}.tbl{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden}.tbl-head,.tbl-row{display:flex;align-items:center;gap:16px;padding:12px 18px}.tbl-head{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;border-bottom:1px solid var(--border)}.tbl-row+.tbl-row{border-top:1px solid var(--border)}.tbl-cell{min-width:0}.tbl-user{flex:1;display:flex;align-items:center;gap:12px}.tbl-prov{width:90px;flex-shrink:0;color:var(--text-muted);font-size:13px}.tbl-status{width:120px;flex-shrink:0}.tbl-date{width:110px;flex-shrink:0;color:var(--text-muted);font-size:13px}.tbl-action{width:120px;flex-shrink:0;display:flex;justify-content:flex-end}.tbl-empty{padding:28px 18px;color:var(--text-muted);font-size:14px}.u-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.u-avatar--initial{background:var(--accent-tint);color:var(--accent-text);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.u-meta{min-width:0}.u-name{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.u-email{font-size:13px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-block;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px}.badge--on{color:var(--success);background:var(--success-tint)}.badge--off{color:var(--text-muted);background:var(--brand-50)}
