:root{--bg: #f6f7fb;--surface: #ffffff;--text: #1b2237;--secondary: #626985;--accent: #4d8df7;--success: #2fa46a;--danger: #d64545;--border: #e3e7f0;--radius: 12px;--shadow: 0 1px 2px rgba(27, 34, 55, .04), 0 4px 14px rgba(27, 34, 55, .05);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{background:var(--bg);color:var(--text);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;font-size:14px;cursor:pointer}input,select{font-family:inherit;font-size:14px}.app-shell{display:flex;flex-direction:column;min-height:100%}.topbar{display:flex;align-items:center;gap:14px;padding:10px 20px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:15px}.topbar .brand img{width:26px;height:26px;border-radius:7px}.nav{display:flex;gap:4px;margin-left:8px}.nav a{padding:6px 12px;border-radius:8px;color:var(--secondary);font-weight:500}.nav a:hover{background:var(--bg);text-decoration:none}.nav a.active{background:#4d8df71f;color:var(--accent)}.topbar .spacer{flex:1}.signout{background:transparent;border:1px solid var(--border);color:var(--secondary);padding:6px 12px;border-radius:8px}.signout:hover{background:var(--bg)}.page{width:100%;max-width:1100px;margin:0 auto;padding:22px 20px 60px}.page h1{font-size:20px;margin:0 0 4px}.page .subtitle{color:var(--secondary);margin:0 0 20px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.grid{display:grid;gap:14px}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat{display:flex;flex-direction:column;gap:4px}.stat .label{color:var(--secondary);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.stat .value{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums}.stat .sub{color:var(--secondary);font-size:12px}.section-title{font-size:13px;font-weight:600;color:var(--secondary);text-transform:uppercase;letter-spacing:.04em;margin:0 0 10px}.pill{display:inline-flex;align-items:center;gap:6px;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid var(--border);background:var(--bg);color:var(--secondary)}.pill.plus{background:#4d8df71f;border-color:#4d8df74d;color:var(--accent)}.pill.free{background:var(--bg)}.pill.ok{background:#2fa46a1f;border-color:#2fa46a4d;color:var(--success)}.pill.bad{background:#d645451a;border-color:#d645454d;color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-weight:600}.btn:hover{background:var(--bg)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover{background:#3f7ce0}.btn.success{background:var(--success);border-color:var(--success);color:#fff}.btn.success:hover{background:#289059}.btn.danger{background:var(--surface);border-color:#d6454566;color:var(--danger)}.btn.danger:hover{background:#d6454514}.btn.small{padding:5px 10px;font-size:13px}.btn-row{display:flex;flex-wrap:wrap;gap:8px}.linkout{display:inline-flex;align-items:center;gap:6px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:13px;font-weight:600;color:var(--secondary)}.input,.select{padding:9px 11px;border:1px solid var(--border);border-radius:9px;background:var(--surface);color:var(--text);outline:none;width:100%}.input:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4d8df726}.alert{border-radius:10px;padding:10px 12px;font-size:13px;margin:10px 0;border:1px solid var(--border)}.alert.error{background:#d6454514;border-color:#d645454d;color:var(--danger)}.alert.success{background:#2fa46a1a;border-color:#2fa46a4d;color:var(--success)}.alert.info{background:#4d8df714;border-color:#4d8df74d;color:var(--accent)}.muted{color:var(--secondary)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.loading-block{display:flex;align-items:center;gap:10px;color:var(--secondary);padding:20px 0}table.data{width:100%;border-collapse:collapse;font-size:13px}table.data th{text-align:left;color:var(--secondary);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em;padding:8px 10px;border-bottom:1px solid var(--border)}table.data td{padding:9px 10px;border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums}table.data tr:last-child td{border-bottom:none}table.data tr.clickable{cursor:pointer}table.data tr.clickable:hover{background:var(--bg)}.login-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:28px}.login-card .logo{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:20px}.login-card .logo img{width:52px;height:52px;border-radius:13px}.login-card .logo .title{font-weight:700;font-size:17px}.login-card .logo .sub{color:var(--secondary);font-size:12px}.secret-box{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px;margin:10px 0;word-break:break-all}.secret-box .secret-code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:16px;font-weight:700;letter-spacing:.06em}.secret-box .otpauth{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;color:var(--secondary);margin-top:8px}.chart-wrap{width:100%;overflow-x:auto}.spark{display:block}.log-controls{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px}.chips{display:flex;gap:6px;flex-wrap:wrap}.chip{padding:5px 11px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--secondary);font-size:13px;font-weight:600}.chip.active{background:#4d8df71f;border-color:#4d8df74d;color:var(--accent)}.log-view{background:#11162a;color:#d7def0;border-radius:12px;border:1px solid #1d2440;padding:12px 14px;height:460px;overflow-y:auto;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px;line-height:1.55}.log-line{white-space:pre-wrap;word-break:break-word}.log-line .ts{color:#6f7aa3}.log-line .grp{color:#4d8df7;font-weight:600}.log-line.err .grp{color:#ff7b7b}.toggle{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--secondary);-webkit-user-select:none;user-select:none;cursor:pointer}.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}.flex{display:flex}.gap{gap:10px}.wrap{flex-wrap:wrap}.mt{margin-top:14px}.mb{margin-bottom:14px}.member-list{border-top:1px solid #e3e7f0}.member-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px 12px;padding:12px 0;border-bottom:1px solid #e3e7f0}.member-info{min-width:180px;flex:1}.member-email{font-weight:600;word-break:break-all}.member-meta{font-size:12px;margin-top:2px}.member-actions{flex-wrap:nowrap;justify-content:flex-end}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-scroll table.data{min-width:560px}
