/* MGM Client API Portal — minimal, vanilla CSS */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif; color: #1a1d24; background: #f6f7fa; }
a { color: #1f6feb; text-decoration: none; }
a:hover { text-decoration: underline; }
code { font-family: "SF Mono", Menlo, Consolas, monospace; background: #eef0f4; padding: 2px 6px; border-radius: 4px; font-size: 13px; word-break: break-all; }
pre { font-family: "SF Mono", Menlo, Consolas, monospace; background: #0b1221; color: #d6e1ff; padding: 16px; border-radius: 6px; overflow-x: auto; font-size: 13px; }
pre.code { background: #0b1221; color: #d6e1ff; }

.wrap { max-width: 960px; margin: 0 auto; padding: 0 20px; }

.hdr { background: linear-gradient(135deg, #0b1221 0%, #122348 100%); color: #fff; padding: 22px 0; border-bottom: 3px solid #f5b800; box-shadow: 0 2px 8px rgba(0,0,0,0.15); }
.hdr .wrap { display: flex; align-items: center; gap: 22px; }
.hdr-logo { height: 32px; width: auto; filter: brightness(0) invert(1); }
.hdr-title { flex: 1; }
.hdr h1 { margin: 0; font-size: 20px; font-weight: 600; color: #fff; letter-spacing: 0.3px; }
.hdr-subtitle { font-size: 11px; color: #9bb4e0; margin-top: 2px; letter-spacing: 0.5px; text-transform: uppercase; }
.hdr .badge { background: #1c2840; color: #d6e1ff; padding: 5px 12px; border-radius: 12px; font-size: 12px; border: 1px solid #2a3e66; }
.hdr .btn-ghost { background: transparent; color: #d6e1ff; border: 1px solid #2a3e66; }
.hdr .btn-ghost:hover { background: #1c2840; }
.ftr { background: #f6f7fa; border-top: 1px solid #e5e7eb; padding: 22px 0; text-align: center; }
.ftr .muted { font-size: 12px; color: #6c7280; }

main { padding: 30px 0 60px; }
.ftr { padding: 18px 0; font-size: 12px; color: #6c7280; border-top: 1px solid #e5e7eb; }
.ftr a { color: #6c7280; }

.card { background: #fff; border: 1px solid #e5e7eb; border-radius: 8px; padding: 24px; margin-bottom: 20px; box-shadow: 0 1px 2px rgba(0,0,0,0.04); }
.login-card { max-width: 440px; margin: 60px auto; text-align: center; padding: 40px 30px; }
.login-card .row { text-align: left; }
.login-card .actions { justify-content: center; }
.login-logo { height: 36px; margin-bottom: 18px; }
.card h2 { margin: 0 0 6px; font-size: 20px; }
.card h3 { margin: 0 0 6px; font-size: 16px; }
.card h4 { margin: 18px 0 6px; font-size: 14px; }

.muted { color: #6c7280; font-size: 13px; line-height: 1.5; margin: 4px 0 14px; }
.warn { color: #a94400; background: #fff4e3; padding: 10px 14px; border-radius: 6px; font-size: 13px; border-left: 3px solid #ff9a40; }
.err { color: #b00020; font-size: 13px; min-height: 16px; margin: 6px 0; }
.ok  { color: #0a7; font-size: 13px; min-height: 16px; margin: 6px 0; }

.row { display: flex; flex-direction: column; gap: 4px; margin: 10px 0; }
.row label { font-size: 12px; font-weight: 600; color: #4a5260; text-transform: uppercase; letter-spacing: 0.4px; }
.row input { padding: 10px 12px; border: 1px solid #d0d5dd; border-radius: 6px; font-size: 14px; font-family: inherit; }
.row input:focus { outline: none; border-color: #1f6feb; box-shadow: 0 0 0 3px rgba(31,111,235,0.15); }

.actions { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }
.btn { cursor: pointer; padding: 10px 18px; font-size: 14px; font-family: inherit; border-radius: 6px; border: 0; font-weight: 500; }
.btn-primary { background: #1f6feb; color: #fff; }
.btn-primary:hover { background: #1858c4; }
.btn-ghost { background: #fff; color: #1a1d24; border: 1px solid #d0d5dd; }
.btn-ghost:hover { background: #f6f7fa; }

.tabs { display: flex; gap: 4px; border-bottom: 1px solid #e5e7eb; margin: 0 0 20px; }
.tab { background: transparent; border: 0; padding: 10px 16px; font-size: 14px; font-family: inherit; cursor: pointer; color: #6c7280; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.tab:hover { color: #1a1d24; }
.tab-active { color: #1f6feb; border-bottom-color: #1f6feb; font-weight: 600; }

.keys-list { margin: 14px 0; }
.key-row { display: grid; grid-template-columns: auto 1fr auto auto; gap: 12px; align-items: center; padding: 12px; border: 1px solid #e5e7eb; border-radius: 6px; margin-bottom: 8px; font-size: 13px; }
.key-row .prefix { font-family: "SF Mono", Menlo, Consolas, monospace; background: #eef0f4; padding: 3px 8px; border-radius: 4px; }
.key-row .name { color: #4a5260; }
.key-row .exp { color: #6c7280; font-size: 12px; }
.key-row .kbtn { display: flex; gap: 6px; }
.key-row .kbtn button { padding: 6px 12px; font-size: 12px; }

.reveal { border: 2px solid #ff9a40; background: #fffaf3; }
.reveal code { display: block; padding: 12px; background: #0b1221; color: #6be6b4; font-size: 14px; margin: 12px 0; }

#mfaOtpauth { display: block; padding: 10px; margin: 8px 0 4px; word-break: break-all; font-size: 12px; }
#mfaSecret { font-size: 14px; letter-spacing: 2px; }

/* Global loading overlay + spinner */
.global-loader { position: fixed; top: 0; left: 0; right: 0; height: 3px; z-index: 9999; background: rgba(31, 111, 235, 0.15); overflow: hidden; pointer-events: none; }
.global-loader::before { content: ""; position: absolute; top: 0; left: -40%; height: 100%; width: 40%; background: #1f6feb; animation: loader-bar 1s linear infinite; }
@keyframes loader-bar { from { left: -40%; } to { left: 100%; } }
.btn-busy { opacity: 0.7; cursor: progress; }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Users tab */
.users-list { margin: 14px 0; }
.user-row { display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: center; padding: 14px; border: 1px solid #e5e7eb; border-radius: 6px; margin-bottom: 10px; }
.user-email { font-weight: 600; font-size: 14px; color: #1a1d24; }
.user-meta { font-size: 12px; color: #6c7280; margin-top: 2px; }
.user-badges { margin-top: 6px; display: flex; gap: 5px; flex-wrap: wrap; }
.user-badges .badge { padding: 2px 8px; border-radius: 10px; font-size: 11px; font-weight: 500; background: #eef0f4; color: #4a5260; }
.badge-owner { background: #fce7f3; color: #7a1948; }
.badge-admin { background: #dbeafe; color: #1e4785; }
.badge-read_only { background: #f3f4f6; color: #4a5260; }
.badge-ok { background: #d1fae5; color: #065f46; }
.badge-warn { background: #fff4e3; color: #a94400; }
.badge-off { background: #fee2e2; color: #b91c1c; }
.badge-self { background: #1f6feb; color: #fff; }
.user-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.user-actions button { padding: 6px 12px; font-size: 12px; }
.select { padding: 10px 12px; border: 1px solid #d0d5dd; border-radius: 6px; font-size: 14px; font-family: inherit; background: #fff; }

/* Modal dialogs (replaces native prompt/confirm) */
.modal { border: 0; border-radius: 10px; padding: 0; max-width: 480px; width: calc(100% - 40px); box-shadow: 0 20px 60px rgba(0,0,0,0.3); }
.modal::backdrop { background: rgba(11, 18, 33, 0.7); }
.modal-form { padding: 24px; font-family: inherit; }
.modal-form h3 { margin: 0 0 8px; font-size: 18px; }
.modal-form p { margin: 0 0 14px; color: #6c7280; font-size: 14px; line-height: 1.5; }
.modal-form input { width: 100%; padding: 10px 12px; border: 1px solid #d0d5dd; border-radius: 6px; font-size: 14px; box-sizing: border-box; font-family: inherit; }
.modal-form input:focus { outline: none; border-color: #1f6feb; box-shadow: 0 0 0 3px rgba(31,111,235,0.15); }
.modal-form .actions { margin-top: 16px; }
