:root{--bg: #f5f6f8;--surface: #ffffff;--border: #e3e6ea;--text: #1a1d21;--muted: #6b7280;--primary: #4f46e5;--primary-d: #4338ca;--danger: #dc2626;--ok: #16a34a;--radius: 10px;--shadow: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .1);font-synthesis:none}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}.app{min-height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:24px;padding:0 20px;height:56px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.brand{font-weight:700;font-size:16px;white-space:nowrap}.tabs{display:flex;gap:4px;flex:1;overflow-x:auto}.tab{padding:8px 14px;border-radius:8px;text-decoration:none;color:var(--muted);font-weight:500;white-space:nowrap}.tab:hover{background:#f0f1f4;color:var(--text)}.tab.active{background:#eef2ff;color:var(--primary-d)}.user{display:flex;align-items:center;gap:12px}.role-badge{text-transform:uppercase;font-size:11px;font-weight:700;letter-spacing:.04em;padding:3px 8px;border-radius:999px;background:#eef2ff;color:var(--primary-d)}.role-badge.admin{background:#fef3c7;color:#92400e}.content{padding:24px;max-width:1200px;width:100%;margin:0 auto}.page-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}.page-head h1{font-size:20px;margin:0}.pill{font-size:11px;font-weight:700;color:var(--muted);background:#eceef1;padding:3px 8px;border-radius:999px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.muted{color:var(--muted)}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);padding:8px 14px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer}.btn:hover{background:#f0f1f4}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-d)}.btn.ghost{background:transparent;border-color:transparent;color:var(--muted)}.btn.ghost:hover{background:#f0f1f4;color:var(--text)}input,select{width:100%;padding:9px 11px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:#fff;color:var(--text)}input:focus,select:focus{outline:2px solid #c7d2fe;border-color:var(--primary)}.error{color:var(--danger);font-size:13px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#eef2ff,#f5f6f8 60%);padding:20px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:32px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:14px}.login-brand{font-size:22px;font-weight:700}.login-card .muted{margin:-8px 0 8px}.splash{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--muted)}.page{display:flex;flex-direction:column;gap:16px}.filterbar{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end}.filterbar label{display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:600;color:var(--muted);min-width:150px}.filterbar label input,.filterbar label select{font-weight:400;color:var(--text)}.filterbar .btn{height:38px}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.toolbar-actions{display:flex;gap:8px}.table-wrap{padding:0;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th,.data-table td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.data-table th{font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);background:#fafbfc;position:sticky;top:0}.data-table td.num,.data-table th.num{text-align:right;font-variant-numeric:tabular-nums}.data-table tr:hover td{background:#fafbfe}.row-excluded td{color:var(--muted);background:#fbfbfc}.badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:#eceef1;color:var(--muted)}.badge.ok{background:#dcfce7;color:#166534}.lang{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--primary-d);background:#eef2ff;padding:1px 6px;border-radius:6px}.error-card{border-color:#fecaca;background:#fef2f2;color:#991b1b}.success-card{border-color:#bbf7d0;background:#f0fdf4;color:#166534}.kv-card{display:grid;gap:8px}.kv{display:flex;gap:12px;font-size:13px}.kv>span:first-child{width:100px;color:var(--muted);font-weight:600}.kv code{font-size:12px;color:var(--text)}.spinner-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--primary);margin-right:8px;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3}50%{opacity:1}}.subtabs{display:flex;gap:6px;border-bottom:1px solid var(--border)}.subtab{border:none;background:none;padding:8px 14px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.subtab:hover{color:var(--text)}.subtab.active{color:var(--primary-d);border-bottom-color:var(--primary)}.conds{display:flex;flex-direction:column;gap:8px;margin-top:8px}.cond-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.cond-row select,.cond-row input{width:auto;min-width:140px;flex:0 1 auto}.data-table code{font-size:11px;color:var(--muted)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;display:flex;justify-content:flex-end;z-index:50}.drawer{width:min(560px,100%);background:var(--surface);height:100%;overflow-y:auto;padding:20px 24px;box-shadow:-4px 0 24px #10182826}.drawer-head{display:flex;align-items:center;justify-content:space-between}.drawer-head h2{margin:0;font-size:18px}.drawer h3{font-size:13px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);margin:18px 0 6px}.transcript{white-space:pre-wrap;word-break:break-word;background:#f7f8fa;border:1px solid var(--border);border-radius:8px;padding:12px;font-size:12px;max-height:320px;overflow-y:auto}
