Redesign UI: neo-brutalist retro-futuristic aesthetic
- New color palette: amber/gold accent, deep black backgrounds - JetBrains Mono for headings, labels, and system text - 2px borders, 2px border-radius (brutalist) - Animated dot-grid background canvas with random scanline artifacts - CRT scanline overlay + vignette effect - Backdrop-filter blur on panels for glass depth - Pulsing status dot, amber glow effects - Login page: full retro treatment with sys-tag footer - All functional elements preserved Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
parent
d651c52a59
commit
8cbc2bec84
266
llm_team_ui.py
266
llm_team_ui.py
@ -274,24 +274,33 @@ LOGIN_HTML = """
|
||||
<!DOCTYPE html>
|
||||
<html><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width,initial-scale=1.0">
|
||||
<title>LLM Team - Login</title>
|
||||
<link href="https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600;700&family=Inter:wght@400;500;600;700&display=swap" rel="stylesheet">
|
||||
<style>
|
||||
:root{--bg:#0a0c10;--surface:#151820;--border:#272d3f;--text:#e4e4e7;--text2:#a1a1aa;--accent:#6366f1;--accent2:#818cf8;--red:#ef4444;--green:#22c55e}
|
||||
:root{--bg:#08090c;--surface:rgba(14,16,22,0.85);--border:#2a2d35;--text:#e8e6e3;--text2:#7a7872;--accent:#e2b55a;--accent2:#f0cc74;--red:#e05252;--green:#4ade80;--glow:rgba(226,181,90,0.06)}
|
||||
*{box-sizing:border-box;margin:0;padding:0}
|
||||
body{font-family:'Inter',-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;align-items:center;justify-content:center}
|
||||
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:36px;width:380px;box-shadow:0 0 40px rgba(99,102,241,0.06),0 8px 32px rgba(0,0,0,0.3)}
|
||||
.login-box h1{font-size:22px;margin-bottom:6px;font-weight:700}
|
||||
.login-box h1 span{background:linear-gradient(135deg,var(--accent2),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
|
||||
.login-box .sub{color:var(--text2);font-size:13px;margin-bottom:24px}
|
||||
.field{margin-bottom:14px}
|
||||
.field label{display:block;font-size:12px;color:var(--text2);margin-bottom:4px;font-weight:500}
|
||||
.field input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:10px 12px;font-size:14px}
|
||||
.field input:focus{outline:none;border-color:var(--accent)}
|
||||
.btn{width:100%;padding:11px;background:linear-gradient(135deg,var(--accent),#7c3aed);color:white;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}
|
||||
.btn:hover{filter:brightness(1.15)}
|
||||
.error{color:var(--red);font-size:12px;margin-bottom:12px;display:none}
|
||||
.setup-note{color:var(--green);font-size:12px;margin-bottom:12px;display:none}
|
||||
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}
|
||||
canvas#bg-grid{position:fixed;inset:0;z-index:0;pointer-events:none}
|
||||
.scanlines{position:fixed;inset:0;z-index:1;pointer-events:none;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.03) 2px,rgba(0,0,0,0.03) 4px)}
|
||||
.vignette{position:fixed;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,0.6) 100%)}
|
||||
.login-box{background:var(--surface);border:2px solid var(--border);border-radius:2px;padding:40px;width:400px;position:relative;z-index:10;backdrop-filter:blur(20px);box-shadow:0 0 60px rgba(226,181,90,0.04),0 1px 0 rgba(226,181,90,0.1) inset}
|
||||
.login-box::before{content:'';position:absolute;top:-1px;left:20px;right:20px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0.4}
|
||||
.login-box h1{font-family:'JetBrains Mono',monospace;font-size:20px;margin-bottom:4px;font-weight:700;letter-spacing:-0.5px}
|
||||
.login-box h1 span{color:var(--accent)}
|
||||
.login-box .sub{color:var(--text2);font-size:12px;margin-bottom:28px;font-family:'JetBrains Mono',monospace;letter-spacing:0.5px;text-transform:uppercase}
|
||||
.field{margin-bottom:16px}
|
||||
.field label{display:block;font-size:10px;color:var(--text2);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;font-family:'JetBrains Mono',monospace}
|
||||
.field input{width:100%;background:rgba(0,0,0,0.4);border:2px solid var(--border);color:var(--text);border-radius:2px;padding:11px 14px;font-size:14px;font-family:'JetBrains Mono',monospace;transition:border-color 0.15s}
|
||||
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
|
||||
.btn{width:100%;padding:12px;background:var(--accent);color:#08090c;border:none;border-radius:2px;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:1px}
|
||||
.btn:hover{background:var(--accent2);box-shadow:0 0 20px rgba(226,181,90,0.2)}
|
||||
.error{color:var(--red);font-size:11px;margin-bottom:12px;display:none;font-family:'JetBrains Mono',monospace;border-left:2px solid var(--red);padding-left:8px}
|
||||
.setup-note{color:var(--green);font-size:11px;margin-bottom:12px;display:none;font-family:'JetBrains Mono',monospace;border-left:2px solid var(--green);padding-left:8px}
|
||||
.sys-tag{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--text2);text-transform:uppercase;letter-spacing:2px;margin-top:20px;text-align:center;opacity:0.4}
|
||||
</style>
|
||||
</head><body>
|
||||
<canvas id="bg-grid"></canvas>
|
||||
<div class="scanlines"></div>
|
||||
<div class="vignette"></div>
|
||||
<div class="login-box">
|
||||
<h1><span>LLM</span> Team</h1>
|
||||
<p class="sub" id="subtitle">Sign in to continue</p>
|
||||
@ -303,8 +312,12 @@ LOGIN_HTML = """
|
||||
<div class="field" id="confirm-field" style="display:none"><label>Confirm Password</label><input id="confirm" type="password"></div>
|
||||
<button class="btn" type="submit" id="submit-btn">Sign In</button>
|
||||
</form>
|
||||
<div class="sys-tag">SYS.AUTH // v3.2</div>
|
||||
</div>
|
||||
<script>
|
||||
!function(){const c=document.getElementById('bg-grid'),x=c.getContext('2d');function resize(){c.width=window.innerWidth;c.height=window.innerHeight}resize();window.addEventListener('resize',resize);let t=0;function draw(){x.clearRect(0,0,c.width,c.height);const s=40,ox=(t*0.3)%s,oy=(t*0.15)%s;x.fillStyle='rgba(226,181,90,0.03)';for(let gx=-s+ox;gx<c.width+s;gx+=s){for(let gy=-s+oy;gy<c.height+s;gy+=s){x.beginPath();x.arc(gx,gy,0.8,0,Math.PI*2);x.fill()}}if(Math.random()>0.97){const ly=Math.random()*c.height;x.strokeStyle='rgba(226,181,90,0.015)';x.lineWidth=1;x.beginPath();x.moveTo(0,ly);x.lineTo(c.width,ly);x.stroke()}t++;requestAnimationFrame(draw)}draw()}();
|
||||
</script>
|
||||
<script>
|
||||
let isSetup = false;
|
||||
async function checkSetup() {
|
||||
const r = await fetch('/api/auth/setup');
|
||||
@ -552,154 +565,161 @@ HTML = r"""
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>LLM Team</title>
|
||||
<link href="https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap" rel="stylesheet">
|
||||
<style>
|
||||
:root {
|
||||
--bg: #0a0c10; --surface: #151820; --surface2: #1c2030; --border: #272d3f;
|
||||
--text: #e4e4e7; --text2: #a1a1aa; --accent: #6366f1; --accent2: #818cf8;
|
||||
--green: #22c55e; --orange: #f59e0b; --red: #ef4444; --blue: #3b82f6;
|
||||
--glow: rgba(99,102,241,0.12);
|
||||
--bg: #08090c; --surface: rgba(14,16,22,0.82); --surface2: rgba(20,22,30,0.7); --border: #2a2d35;
|
||||
--text: #e8e6e3; --text2: #7a7872; --accent: #e2b55a; --accent2: #f0cc74;
|
||||
--green: #4ade80; --orange: #f59e0b; --red: #e05252; --blue: #5b9cf5;
|
||||
--glow: rgba(226,181,90,0.06);
|
||||
}
|
||||
* { box-sizing: border-box; margin: 0; padding: 0; }
|
||||
body { font-family: 'Inter', -apple-system, sans-serif; background: var(--bg); color: var(--text); min-height: 100vh; }
|
||||
.container { max-width: 1440px; margin: 0 auto; padding: 16px 24px; }
|
||||
header { display: flex; align-items: center; gap: 14px; padding: 16px 0; border-bottom: 1px solid var(--border); margin-bottom: 20px; }
|
||||
header h1 { font-size: 22px; font-weight: 700; letter-spacing: -0.5px; }
|
||||
header h1 span { background: linear-gradient(135deg, var(--accent2), #a78bfa); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
|
||||
header .badge { background: var(--surface2); border: 1px solid var(--border); padding: 4px 12px; border-radius: 20px; font-size: 11px; color: var(--text2); font-weight: 500; }
|
||||
header .badge .dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--green); margin-right: 6px; vertical-align: middle; }
|
||||
.grid { display: grid; grid-template-columns: 420px 1fr; gap: 16px; align-items: start; }
|
||||
.panel { background: var(--surface); border: 1px solid var(--border); border-radius: 10px; padding: 18px; }
|
||||
.panel h2 { font-size: 11px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--text2); margin-bottom: 14px; font-weight: 600; }
|
||||
body { font-family: 'Inter', -apple-system, sans-serif; background: var(--bg); color: var(--text); min-height: 100vh; overflow-x: hidden; }
|
||||
canvas#bg-grid { position: fixed; inset: 0; z-index: 0; pointer-events: none; }
|
||||
.scanlines { position: fixed; inset: 0; z-index: 1; pointer-events: none; background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,0,0,0.02) 2px, rgba(0,0,0,0.02) 4px); }
|
||||
.vignette { position: fixed; inset: 0; z-index: 1; pointer-events: none; background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.5) 100%); }
|
||||
.container { max-width: 1440px; margin: 0 auto; padding: 16px 28px; position: relative; z-index: 10; }
|
||||
header { display: flex; align-items: center; gap: 14px; padding: 18px 0; border-bottom: 2px solid var(--border); margin-bottom: 22px; }
|
||||
header h1 { font-family: 'JetBrains Mono', monospace; font-size: 20px; font-weight: 700; letter-spacing: -0.5px; }
|
||||
header h1 span { color: var(--accent); }
|
||||
header .badge { background: rgba(0,0,0,0.3); border: 2px solid var(--border); padding: 4px 12px; border-radius: 2px; font-size: 10px; color: var(--text2); font-weight: 600; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 0.5px; backdrop-filter: blur(10px); }
|
||||
header .badge .dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--green); margin-right: 6px; vertical-align: middle; box-shadow: 0 0 8px var(--green); animation: pulse-dot 2s ease-in-out infinite; }
|
||||
@keyframes pulse-dot { 0%,100% { opacity: 1; } 50% { opacity: 0.5; } }
|
||||
.grid { display: grid; grid-template-columns: 420px 1fr; gap: 18px; align-items: start; }
|
||||
.panel { background: var(--surface); border: 2px solid var(--border); border-radius: 2px; padding: 20px; backdrop-filter: blur(16px); position: relative; }
|
||||
.panel::before { content: ''; position: absolute; top: -1px; left: 16px; right: 16px; height: 1px; background: linear-gradient(90deg, transparent, rgba(226,181,90,0.15), transparent); }
|
||||
.panel h2 { font-family: 'JetBrains Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 2px; color: var(--text2); margin-bottom: 14px; font-weight: 600; }
|
||||
.mode-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 5px; margin-bottom: 16px; }
|
||||
.mode-tab { padding: 8px 6px; background: var(--surface2); border: 1.5px solid transparent; border-radius: 6px; color: var(--text2); cursor: pointer; text-align: center; font-size: 11px; font-weight: 600; transition: all 0.15s; }
|
||||
.mode-tab:hover { border-color: var(--accent); color: var(--text); background: rgba(99,102,241,0.06); }
|
||||
.mode-tab.active { border-color: var(--accent); background: var(--glow); color: var(--accent2); box-shadow: 0 0 12px rgba(99,102,241,0.1); }
|
||||
.mode-tab small { display: block; font-weight: 400; font-size: 9px; margin-top: 2px; opacity: 0.6; }
|
||||
.mode-tab.crazy { background: linear-gradient(135deg, #1a0a2e, #2d1045); }
|
||||
.mode-tab { padding: 8px 6px; background: rgba(0,0,0,0.3); border: 2px solid transparent; border-radius: 2px; color: var(--text2); cursor: pointer; text-align: center; font-size: 11px; font-weight: 600; transition: all 0.15s; font-family: 'Inter', sans-serif; }
|
||||
.mode-tab:hover { border-color: var(--accent); color: var(--text); background: var(--glow); }
|
||||
.mode-tab.active { border-color: var(--accent); background: var(--glow); color: var(--accent); box-shadow: 0 0 16px rgba(226,181,90,0.08), inset 0 1px 0 rgba(226,181,90,0.1); }
|
||||
.mode-tab small { display: block; font-weight: 400; font-size: 9px; margin-top: 2px; opacity: 0.5; font-family: 'JetBrains Mono', monospace; }
|
||||
.mode-tab.crazy { background: linear-gradient(135deg, rgba(20,5,35,0.8), rgba(40,15,60,0.8)); border-color: rgba(168,85,247,0.2); }
|
||||
.mode-tab.crazy:hover { border-color: #a855f7; }
|
||||
.mode-tab.crazy.active { background: linear-gradient(135deg, #2d1045, #4a1a6b); border-color: #a855f7; color: #c084fc; box-shadow: 0 0 12px rgba(168,85,247,0.15); }
|
||||
.mode-tab.crazy.active { background: linear-gradient(135deg, rgba(40,15,60,0.9), rgba(65,25,95,0.9)); border-color: #a855f7; color: #c084fc; box-shadow: 0 0 16px rgba(168,85,247,0.12); }
|
||||
.model-list { display: flex; flex-direction: column; gap: 4px; margin-bottom: 14px; }
|
||||
.model-card { display: flex; align-items: center; gap: 10px; padding: 7px 10px; background: var(--surface2); border: 1px solid var(--border); border-radius: 6px; cursor: pointer; transition: all 0.15s; user-select: none; }
|
||||
.model-card:hover { border-color: rgba(99,102,241,0.4); }
|
||||
.model-card { display: flex; align-items: center; gap: 10px; padding: 7px 10px; background: rgba(0,0,0,0.25); border: 2px solid var(--border); border-radius: 2px; cursor: pointer; transition: all 0.15s; user-select: none; }
|
||||
.model-card:hover { border-color: rgba(226,181,90,0.3); }
|
||||
.model-card.selected { border-color: var(--accent); background: var(--glow); }
|
||||
.model-card .check { width: 16px; height: 16px; border: 1.5px solid var(--border); border-radius: 3px; display: flex; align-items: center; justify-content: center; font-size: 10px; flex-shrink: 0; transition: all 0.15s; }
|
||||
.model-card.selected .check { background: var(--accent); border-color: var(--accent); color: white; }
|
||||
.model-card .check { width: 16px; height: 16px; border: 2px solid var(--border); border-radius: 1px; display: flex; align-items: center; justify-content: center; font-size: 10px; flex-shrink: 0; transition: all 0.15s; }
|
||||
.model-card.selected .check { background: var(--accent); border-color: var(--accent); color: #08090c; }
|
||||
.model-card .info { flex: 1; min-width: 0; }
|
||||
.model-card .name { font-weight: 600; font-size: 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
|
||||
.model-card .meta { font-size: 10px; color: var(--text2); }
|
||||
.prov-badge { font-size: 8px; padding: 1px 6px; border-radius: 8px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; }
|
||||
.prov-badge.ollama { background: rgba(34,197,94,0.12); color: var(--green); }
|
||||
.prov-badge.openrouter { background: rgba(59,130,246,0.12); color: var(--blue); }
|
||||
.prov-badge.openai { background: rgba(129,140,248,0.12); color: var(--accent2); }
|
||||
.prov-badge.anthropic { background: rgba(236,72,153,0.12); color: #ec4899; }
|
||||
.model-card .meta { font-size: 10px; color: var(--text2); font-family: 'JetBrains Mono', monospace; }
|
||||
.prov-badge { font-size: 8px; padding: 2px 6px; border-radius: 1px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; font-family: 'JetBrains Mono', monospace; border: 1px solid; }
|
||||
.prov-badge.ollama { background: rgba(74,222,128,0.08); color: var(--green); border-color: rgba(74,222,128,0.2); }
|
||||
.prov-badge.openrouter { background: rgba(91,156,245,0.08); color: var(--blue); border-color: rgba(91,156,245,0.2); }
|
||||
.prov-badge.openai { background: rgba(226,181,90,0.08); color: var(--accent2); border-color: rgba(226,181,90,0.2); }
|
||||
.prov-badge.anthropic { background: rgba(236,72,153,0.08); color: #ec4899; border-color: rgba(236,72,153,0.2); }
|
||||
.config-section { margin-bottom: 10px; }
|
||||
.config-row { display: flex; gap: 8px; align-items: center; margin-bottom: 6px; font-size: 12px; }
|
||||
.config-row label { width: 90px; color: var(--text2); flex-shrink: 0; font-weight: 500; }
|
||||
.config-row select, .config-row input { flex: 1; background: var(--bg); border: 1px solid var(--border); color: var(--text); border-radius: 5px; padding: 6px 8px; font-size: 12px; }
|
||||
.config-row select:focus, .config-row input:focus { outline: none; border-color: var(--accent); }
|
||||
.pipeline-step { display: flex; align-items: center; gap: 8px; padding: 7px; margin-bottom: 4px; background: var(--surface2); border-radius: 6px; font-size: 12px; }
|
||||
.pipeline-step .step-num { width: 22px; height: 22px; background: var(--accent); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 11px; flex-shrink: 0; }
|
||||
.pipeline-step select, .pipeline-step input { background: var(--bg); border: 1px solid var(--border); color: var(--text); border-radius: 4px; padding: 4px 6px; font-size: 11px; }
|
||||
.config-row label { width: 90px; color: var(--text2); flex-shrink: 0; font-weight: 600; font-family: 'JetBrains Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; }
|
||||
.config-row select, .config-row input { flex: 1; background: rgba(0,0,0,0.4); border: 2px solid var(--border); color: var(--text); border-radius: 2px; padding: 6px 8px; font-size: 12px; }
|
||||
.config-row select:focus, .config-row input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent); }
|
||||
.pipeline-step { display: flex; align-items: center; gap: 8px; padding: 7px; margin-bottom: 4px; background: rgba(0,0,0,0.25); border: 1px solid var(--border); border-radius: 2px; font-size: 12px; }
|
||||
.pipeline-step .step-num { width: 22px; height: 22px; background: var(--accent); color: #08090c; border-radius: 2px; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 11px; flex-shrink: 0; font-family: 'JetBrains Mono', monospace; }
|
||||
.pipeline-step select, .pipeline-step input { background: rgba(0,0,0,0.4); border: 2px solid var(--border); color: var(--text); border-radius: 2px; padding: 4px 6px; font-size: 11px; }
|
||||
.pipeline-step input { flex: 1; }
|
||||
.pipeline-step .remove-step { background: none; border: none; color: var(--red); cursor: pointer; font-size: 14px; padding: 0 4px; opacity: 0.6; transition: opacity 0.15s; }
|
||||
.pipeline-step .remove-step:hover { opacity: 1; }
|
||||
.add-step-btn { width: 100%; padding: 7px; background: var(--surface2); border: 1px dashed var(--border); border-radius: 6px; color: var(--text2); cursor: pointer; font-size: 12px; margin-bottom: 14px; transition: all 0.15s; }
|
||||
.add-step-btn:hover { border-color: var(--accent); color: var(--accent2); }
|
||||
.prompt-area { width: 100%; min-height: 90px; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; color: var(--text); padding: 12px; font-size: 13px; font-family: inherit; resize: vertical; margin-bottom: 10px; line-height: 1.5; }
|
||||
.prompt-area:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(99,102,241,0.1); }
|
||||
.prompt-area::placeholder { color: var(--text2); opacity: 0.5; }
|
||||
.run-btn { width: 100%; padding: 11px; background: linear-gradient(135deg, var(--accent), #7c3aed); color: white; border: none; border-radius: 8px; font-size: 14px; font-weight: 600; cursor: pointer; transition: all 0.2s; letter-spacing: 0.3px; }
|
||||
.run-btn:hover { filter: brightness(1.15); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(99,102,241,0.3); }
|
||||
.add-step-btn { width: 100%; padding: 7px; background: transparent; border: 2px dashed var(--border); border-radius: 2px; color: var(--text2); cursor: pointer; font-size: 11px; margin-bottom: 14px; transition: all 0.15s; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 0.5px; }
|
||||
.add-step-btn:hover { border-color: var(--accent); color: var(--accent); }
|
||||
.prompt-area { width: 100%; min-height: 90px; background: rgba(0,0,0,0.4); border: 2px solid var(--border); border-radius: 2px; color: var(--text); padding: 14px; font-size: 13px; font-family: 'Inter', sans-serif; resize: vertical; margin-bottom: 10px; line-height: 1.5; }
|
||||
.prompt-area:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 0 20px rgba(226,181,90,0.06); }
|
||||
.prompt-area::placeholder { color: var(--text2); opacity: 0.5; font-family: 'JetBrains Mono', monospace; font-size: 12px; }
|
||||
.run-btn { width: 100%; padding: 12px; background: var(--accent); color: #08090c; border: none; border-radius: 2px; font-size: 13px; font-weight: 700; cursor: pointer; transition: all 0.15s; letter-spacing: 1px; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; }
|
||||
.run-btn:hover { background: var(--accent2); box-shadow: 0 0 24px rgba(226,181,90,0.2), 0 0 60px rgba(226,181,90,0.06); transform: translateY(-1px); }
|
||||
.run-btn:active { transform: translateY(0); }
|
||||
.run-btn:disabled { opacity: 0.4; cursor: not-allowed; filter: none; transform: none; box-shadow: none; }
|
||||
.run-btn:disabled { opacity: 0.3; cursor: not-allowed; filter: none; transform: none; box-shadow: none; }
|
||||
.output-area { display: flex; flex-direction: column; gap: 10px; }
|
||||
.output-card { background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
|
||||
.output-card .card-header { display: flex; align-items: center; gap: 8px; padding: 8px 12px; border-bottom: 1px solid var(--border); font-size: 12px; font-weight: 600; }
|
||||
.output-card .card-header .dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
|
||||
.output-card .card-header .role-tag { margin-left: auto; font-size: 10px; font-weight: 500; color: var(--text2); background: var(--bg); padding: 2px 8px; border-radius: 10px; }
|
||||
.output-card .card-body { padding: 12px; font-size: 13px; line-height: 1.65; white-space: pre-wrap; max-height: 500px; overflow-y: auto; }
|
||||
.output-card { background: rgba(0,0,0,0.25); border: 2px solid var(--border); border-radius: 2px; overflow: hidden; backdrop-filter: blur(8px); }
|
||||
.output-card .card-header { display: flex; align-items: center; gap: 8px; padding: 10px 14px; border-bottom: 2px solid var(--border); font-size: 12px; font-weight: 600; font-family: 'JetBrains Mono', monospace; }
|
||||
.output-card .card-header .dot { width: 8px; height: 8px; border-radius: 1px; flex-shrink: 0; }
|
||||
.output-card .card-header .role-tag { margin-left: auto; font-size: 9px; font-weight: 600; color: var(--text2); background: rgba(0,0,0,0.4); padding: 2px 8px; border-radius: 1px; border: 1px solid var(--border); text-transform: uppercase; letter-spacing: 1px; font-family: 'JetBrains Mono', monospace; }
|
||||
.output-card .card-body { padding: 14px; font-size: 13px; line-height: 1.7; white-space: pre-wrap; max-height: 500px; overflow-y: auto; }
|
||||
.synthesis-card { border-color: var(--accent); }
|
||||
.synthesis-card .card-header { background: var(--glow); }
|
||||
.synthesis-card::before { content: ''; position: absolute; top: -1px; left: 0; right: 0; height: 1px; background: var(--accent); opacity: 0.3; }
|
||||
.crazy-card { border-color: #a855f7; }
|
||||
.crazy-card .card-header { background: rgba(168,85,247,0.1); }
|
||||
.status-bar { display: flex; align-items: center; gap: 8px; padding: 10px 12px; background: var(--surface2); border-radius: 8px; font-size: 12px; color: var(--text2); }
|
||||
.crazy-card .card-header { background: rgba(168,85,247,0.08); }
|
||||
.status-bar { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: rgba(0,0,0,0.3); border: 2px solid var(--border); border-radius: 2px; font-size: 11px; color: var(--text2); font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 0.5px; }
|
||||
.spinner { width: 14px; height: 14px; border: 2px solid var(--border); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.7s linear infinite; }
|
||||
@keyframes spin { to { transform: rotate(360deg); } }
|
||||
.sample-prompts { display: flex; flex-wrap: wrap; gap: 6px; margin: 8px 0; }
|
||||
.sample-chip { background: var(--surface2); border: 1px solid var(--border); border-radius: 16px; padding: 5px 12px; font-size: 11px; color: var(--text2); cursor: pointer; transition: all 0.15s; line-height: 1.4; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
|
||||
.sample-chip:hover { border-color: var(--accent); color: var(--accent2); background: var(--glow); }
|
||||
.sample-chip .chip-level { font-size: 9px; font-weight: 600; text-transform: uppercase; margin-right: 4px; opacity: 0.6; }
|
||||
.sample-chip { background: rgba(0,0,0,0.3); border: 1px solid var(--border); border-radius: 2px; padding: 6px 12px; font-size: 11px; color: var(--text2); cursor: pointer; transition: all 0.15s; line-height: 1.4; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
|
||||
.sample-chip:hover { border-color: var(--accent); color: var(--accent); background: var(--glow); }
|
||||
.sample-chip .chip-level { font-size: 8px; font-weight: 700; text-transform: uppercase; margin-right: 6px; opacity: 0.5; font-family: 'JetBrains Mono', monospace; letter-spacing: 1px; }
|
||||
.empty-state { text-align: center; padding: 80px 20px; color: var(--text2); }
|
||||
.empty-state .icon { font-size: 32px; margin-bottom: 16px; opacity: 0.3; }
|
||||
.empty-state p { font-size: 13px; line-height: 1.6; max-width: 280px; margin: 0 auto; }
|
||||
.empty-state p strong { color: var(--text); font-weight: 600; }
|
||||
.mode-desc { background: var(--surface2); border-left: 2px solid var(--accent); border-radius: 0 6px 6px 0; padding: 8px 12px; font-size: 11px; color: var(--text2); margin-bottom: 14px; line-height: 1.5; }
|
||||
.empty-state .icon { font-size: 32px; margin-bottom: 16px; opacity: 0.2; }
|
||||
.empty-state p { font-size: 12px; line-height: 1.6; max-width: 280px; margin: 0 auto; font-family: 'JetBrains Mono', monospace; }
|
||||
.empty-state p strong { color: var(--accent); font-weight: 600; }
|
||||
.mode-desc { background: rgba(0,0,0,0.25); border-left: 2px solid var(--accent); border-radius: 0; padding: 10px 14px; font-size: 11px; color: var(--text2); margin-bottom: 14px; line-height: 1.5; font-family: 'JetBrains Mono', monospace; }
|
||||
.left-scroll { max-height: calc(100vh - 72px); overflow-y: auto; display: flex; flex-direction: column; gap: 12px; }
|
||||
.left-scroll::-webkit-scrollbar { width: 4px; }
|
||||
.left-scroll::-webkit-scrollbar { width: 3px; }
|
||||
.left-scroll::-webkit-scrollbar-track { background: transparent; }
|
||||
.left-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
|
||||
.left-scroll::-webkit-scrollbar-thumb:hover { background: var(--text2); }
|
||||
.output-card .card-body::-webkit-scrollbar { width: 4px; }
|
||||
.left-scroll::-webkit-scrollbar-thumb { background: rgba(226,181,90,0.15); border-radius: 0; }
|
||||
.left-scroll::-webkit-scrollbar-thumb:hover { background: rgba(226,181,90,0.3); }
|
||||
.output-card .card-body::-webkit-scrollbar { width: 3px; }
|
||||
.output-card .card-body::-webkit-scrollbar-track { background: transparent; }
|
||||
.output-card .card-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
|
||||
.output-card .card-body::-webkit-scrollbar-thumb { background: rgba(226,181,90,0.15); border-radius: 0; }
|
||||
.m-toggle { display: none; }
|
||||
.m-collapse { display: block !important; }
|
||||
@media (max-width: 900px) { .grid { grid-template-columns: 1fr; } }
|
||||
@media (max-width: 768px) { .m-toggle { display: flex; } .m-collapse { display: none !important; } .m-collapse.open { display: block !important; } }
|
||||
.card-actions { display: flex; gap: 4px; padding: 4px 12px 8px; }
|
||||
.card-act { background: none; border: 1px solid var(--border); border-radius: 4px; color: var(--text2); font-size: 10px; padding: 3px 8px; cursor: pointer; transition: all 0.15s; }
|
||||
.card-act:hover { border-color: var(--accent); color: var(--accent2); }
|
||||
.card-actions { display: flex; gap: 4px; padding: 6px 14px 10px; }
|
||||
.card-act { background: none; border: 2px solid var(--border); border-radius: 2px; color: var(--text2); font-size: 9px; padding: 3px 10px; cursor: pointer; transition: all 0.15s; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 0.5px; }
|
||||
.card-act:hover { border-color: var(--accent); color: var(--accent); }
|
||||
.card-act.copied { border-color: var(--green); color: var(--green); }
|
||||
.repipe-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 200; display: none; align-items: center; justify-content: center; }
|
||||
.repipe-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.75); z-index: 200; display: none; align-items: center; justify-content: center; backdrop-filter: blur(4px); }
|
||||
.repipe-overlay.open { display: flex; }
|
||||
.repipe-modal { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; width: 700px; max-width: 90vw; max-height: 85vh; display: flex; flex-direction: column; overflow: hidden; }
|
||||
.repipe-header { padding: 14px 18px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; }
|
||||
.repipe-header h3 { font-size: 14px; flex: 1; }
|
||||
.repipe-modal { background: rgba(14,16,22,0.95); border: 2px solid var(--border); border-radius: 2px; width: 700px; max-width: 90vw; max-height: 85vh; display: flex; flex-direction: column; overflow: hidden; backdrop-filter: blur(20px); }
|
||||
.repipe-header { padding: 14px 18px; border-bottom: 2px solid var(--border); display: flex; align-items: center; gap: 10px; }
|
||||
.repipe-header h3 { font-size: 14px; flex: 1; font-family: 'JetBrains Mono', monospace; }
|
||||
.repipe-header .repipe-close { background: none; border: none; color: var(--text2); font-size: 18px; cursor: pointer; }
|
||||
.repipe-body { padding: 14px 18px; overflow-y: auto; flex: 1; }
|
||||
.repipe-text { background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 12px; font-size: 12px; line-height: 1.6; white-space: pre-wrap; max-height: 300px; overflow-y: auto; margin-bottom: 14px; color: var(--text); }
|
||||
.repipe-text::-webkit-scrollbar { width: 4px; }
|
||||
.repipe-text::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
|
||||
.repipe-text { background: rgba(0,0,0,0.4); border: 2px solid var(--border); border-radius: 2px; padding: 12px; font-size: 12px; line-height: 1.6; white-space: pre-wrap; max-height: 300px; overflow-y: auto; margin-bottom: 14px; color: var(--text); }
|
||||
.repipe-text::-webkit-scrollbar { width: 3px; }
|
||||
.repipe-text::-webkit-scrollbar-thumb { background: rgba(226,181,90,0.15); border-radius: 0; }
|
||||
.repipe-actions { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
|
||||
.repipe-btn { padding: 7px 14px; border: 1px solid var(--border); border-radius: 6px; background: var(--surface2); color: var(--text); cursor: pointer; font-size: 12px; font-weight: 500; transition: all 0.15s; }
|
||||
.repipe-btn:hover { border-color: var(--accent); color: var(--accent2); }
|
||||
.repipe-btn.primary { background: var(--accent); border-color: var(--accent); color: white; }
|
||||
.repipe-btn.primary:hover { filter: brightness(1.15); }
|
||||
.repipe-section { font-size: 10px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--text2); margin: 12px 0 6px; font-weight: 600; }
|
||||
.repipe-btn { padding: 7px 14px; border: 2px solid var(--border); border-radius: 2px; background: transparent; color: var(--text); cursor: pointer; font-size: 11px; font-weight: 600; transition: all 0.15s; font-family: 'JetBrains Mono', monospace; }
|
||||
.repipe-btn:hover { border-color: var(--accent); color: var(--accent); }
|
||||
.repipe-btn.primary { background: var(--accent); border-color: var(--accent); color: #08090c; }
|
||||
.repipe-btn.primary:hover { background: var(--accent2); }
|
||||
.repipe-section { font-size: 9px; text-transform: uppercase; letter-spacing: 2px; color: var(--text2); margin: 12px 0 6px; font-weight: 600; font-family: 'JetBrains Mono', monospace; }
|
||||
.repipe-modes { display: flex; flex-wrap: wrap; gap: 4px; }
|
||||
.repipe-mode { padding: 5px 10px; border: 1px solid var(--border); border-radius: 5px; background: var(--surface2); color: var(--text2); cursor: pointer; font-size: 11px; transition: all 0.15s; }
|
||||
.repipe-mode { padding: 5px 10px; border: 2px solid var(--border); border-radius: 2px; background: transparent; color: var(--text2); cursor: pointer; font-size: 11px; transition: all 0.15s; }
|
||||
.repipe-mode:hover { border-color: var(--accent); color: var(--text); }
|
||||
.repipe-mode.sel { border-color: var(--accent); background: var(--glow); color: var(--accent2); }
|
||||
.history-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 90; display: none; }
|
||||
.repipe-mode.sel { border-color: var(--accent); background: var(--glow); color: var(--accent); }
|
||||
.history-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 90; display: none; backdrop-filter: blur(2px); }
|
||||
.history-overlay.open { display: block; }
|
||||
.history-panel { position: fixed; top: 0; right: 0; width: 480px; height: 100vh; background: var(--surface); border-left: 1px solid var(--border); z-index: 100; transform: translateX(100%); transition: transform 0.25s; overflow-y: auto; display: flex; flex-direction: column; }
|
||||
.history-panel { position: fixed; top: 0; right: 0; width: 480px; height: 100vh; background: rgba(14,16,22,0.95); border-left: 2px solid var(--border); z-index: 100; transform: translateX(100%); transition: transform 0.25s; overflow-y: auto; display: flex; flex-direction: column; backdrop-filter: blur(20px); }
|
||||
.history-panel.open { transform: translateX(0); }
|
||||
.history-panel::-webkit-scrollbar { width: 4px; }
|
||||
.history-panel::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
|
||||
.hp-header { padding: 16px 18px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
|
||||
.hp-header h2 { font-size: 16px; font-weight: 600; flex: 1; }
|
||||
.history-panel::-webkit-scrollbar { width: 3px; }
|
||||
.history-panel::-webkit-scrollbar-thumb { background: rgba(226,181,90,0.15); border-radius: 0; }
|
||||
.hp-header { padding: 16px 18px; border-bottom: 2px solid var(--border); display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
|
||||
.hp-header h2 { font-size: 14px; font-weight: 700; flex: 1; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 1px; }
|
||||
.hp-close { background: none; border: none; color: var(--text2); font-size: 20px; cursor: pointer; padding: 4px; }
|
||||
.hp-close:hover { color: var(--text); }
|
||||
.hp-list { flex: 1; overflow-y: auto; padding: 8px; }
|
||||
.hp-item { background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; padding: 12px; margin-bottom: 6px; cursor: pointer; transition: border-color 0.15s; }
|
||||
.hp-item { background: rgba(0,0,0,0.25); border: 2px solid var(--border); border-radius: 2px; padding: 12px; margin-bottom: 6px; cursor: pointer; transition: border-color 0.15s; }
|
||||
.hp-item:hover { border-color: var(--accent); }
|
||||
.hp-item .hp-mode { font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--accent2); font-weight: 600; }
|
||||
.hp-item .hp-mode { font-size: 9px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--accent); font-weight: 700; font-family: 'JetBrains Mono', monospace; }
|
||||
.hp-item .hp-prompt { font-size: 13px; margin: 4px 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
|
||||
.hp-item .hp-meta { font-size: 10px; color: var(--text2); display: flex; gap: 10px; }
|
||||
.hp-item .hp-meta { font-size: 10px; color: var(--text2); display: flex; gap: 10px; font-family: 'JetBrains Mono', monospace; }
|
||||
.hp-detail { padding: 12px 18px; }
|
||||
.hp-detail .hp-back { background: none; border: none; color: var(--accent2); cursor: pointer; font-size: 12px; margin-bottom: 10px; }
|
||||
.hp-detail .hp-back { background: none; border: none; color: var(--accent); cursor: pointer; font-size: 11px; margin-bottom: 10px; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 1px; }
|
||||
.hp-detail .hp-actions { display: flex; gap: 6px; margin-bottom: 12px; }
|
||||
.hp-detail .hp-btn { padding: 5px 12px; border: 1px solid var(--border); border-radius: 5px; background: var(--surface2); color: var(--text); cursor: pointer; font-size: 11px; }
|
||||
.hp-detail .hp-btn { padding: 5px 12px; border: 2px solid var(--border); border-radius: 2px; background: transparent; color: var(--text); cursor: pointer; font-size: 10px; font-family: 'JetBrains Mono', monospace; text-transform: uppercase; }
|
||||
.hp-detail .hp-btn:hover { border-color: var(--accent); }
|
||||
.hp-detail .hp-btn-del { border-color: var(--red); color: var(--red); }
|
||||
.hp-resp { background: var(--surface2); border: 1px solid var(--border); border-radius: 6px; margin-bottom: 6px; overflow: hidden; }
|
||||
.hp-resp-header { padding: 6px 10px; border-bottom: 1px solid var(--border); font-size: 11px; font-weight: 600; display: flex; gap: 6px; align-items: center; }
|
||||
.hp-resp-body { padding: 8px 10px; font-size: 12px; line-height: 1.5; white-space: pre-wrap; max-height: 200px; overflow-y: auto; }
|
||||
.hp-resp { background: rgba(0,0,0,0.25); border: 2px solid var(--border); border-radius: 2px; margin-bottom: 6px; overflow: hidden; }
|
||||
.hp-resp-header { padding: 8px 12px; border-bottom: 2px solid var(--border); font-size: 11px; font-weight: 600; display: flex; gap: 6px; align-items: center; font-family: 'JetBrains Mono', monospace; }
|
||||
.hp-resp-body { padding: 10px 12px; font-size: 12px; line-height: 1.6; white-space: pre-wrap; max-height: 200px; overflow-y: auto; }
|
||||
@media (max-width: 768px) {
|
||||
.container { padding: 10px; }
|
||||
header { padding: 10px 0; margin-bottom: 10px; flex-wrap: wrap; gap: 8px; }
|
||||
header h1 { font-size: 18px; }
|
||||
header .badge { font-size: 10px; padding: 3px 8px; }
|
||||
header h1 { font-size: 16px; }
|
||||
header .badge { font-size: 9px; padding: 3px 8px; }
|
||||
header nav { gap: 3px; }
|
||||
header nav a, header nav button, header nav span { font-size: 10px !important; padding: 3px 6px !important; }
|
||||
.grid { grid-template-columns: 1fr; }
|
||||
@ -708,7 +728,7 @@ HTML = r"""
|
||||
.left-scroll { display: flex; flex-direction: column; gap: 8px; }
|
||||
.left-scroll > .panel:first-child { order: 2; }
|
||||
.left-scroll > .panel:last-child { order: 1; }
|
||||
.m-toggle { display: flex; align-items: center; gap: 8px; padding: 10px; background: var(--surface); border: 1px solid var(--border); border-radius: 8px; cursor: pointer; margin-bottom: 8px; font-size: 13px; font-weight: 600; color: var(--accent2); }
|
||||
.m-toggle { display: flex; align-items: center; gap: 8px; padding: 10px; background: var(--surface); border: 2px solid var(--border); border-radius: 2px; cursor: pointer; margin-bottom: 8px; font-size: 12px; font-weight: 700; color: var(--accent); font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 0.5px; backdrop-filter: blur(16px); }
|
||||
.m-toggle::after { content: ''; margin-left: auto; width: 0; height: 0; border-left: 5px solid transparent; border-right: 5px solid transparent; border-top: 6px solid var(--text2); transition: transform 0.2s; }
|
||||
.m-toggle.open::after { transform: rotate(180deg); }
|
||||
.m-collapse { display: none; }
|
||||
@ -719,11 +739,11 @@ HTML = r"""
|
||||
.model-card { padding: 6px 8px; }
|
||||
.model-card .name { font-size: 11px; }
|
||||
.prompt-area { min-height: 60px; font-size: 14px; }
|
||||
.run-btn { padding: 14px; font-size: 16px; }
|
||||
.run-btn { padding: 14px; font-size: 14px; }
|
||||
.output-card .card-body { font-size: 13px; max-height: 600px; }
|
||||
.card-actions { flex-wrap: wrap; }
|
||||
.panel { padding: 12px; }
|
||||
.panel h2 { font-size: 10px; margin-bottom: 10px; }
|
||||
.panel h2 { font-size: 9px; margin-bottom: 10px; }
|
||||
.config-row { font-size: 11px; }
|
||||
.config-row label { width: 70px; }
|
||||
.mode-desc { font-size: 10px; padding: 6px 10px; }
|
||||
@ -735,17 +755,20 @@ HTML = r"""
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<canvas id="bg-grid"></canvas>
|
||||
<div class="scanlines"></div>
|
||||
<div class="vignette"></div>
|
||||
<div class="container">
|
||||
<header>
|
||||
<h1><span>LLM</span> Team</h1>
|
||||
<div class="badge" id="model-count"><span class="dot"></span>0 models</div>
|
||||
<nav style="margin-left:auto;display:flex;align-items:center;gap:4px">
|
||||
<button onclick="toggleHistory()" style="color:var(--text2);background:none;font-size:11px;padding:5px 10px;border:1px solid var(--border);border-radius:6px;cursor:pointer">History</button>
|
||||
<a href="/lab" style="color:var(--green);text-decoration:none;font-size:11px;padding:5px 10px;border:1px solid rgba(34,197,94,0.2);border-radius:6px">Lab</a>
|
||||
<a href="/admin" style="color:var(--text2);text-decoration:none;font-size:11px;padding:5px 10px;border:1px solid var(--border);border-radius:6px">Admin</a>
|
||||
<span style="width:1px;height:16px;background:var(--border);margin:0 2px"></span>
|
||||
<button id="demo-toggle" onclick="toggleDemo()" style="display:none;color:var(--orange);background:none;font-size:10px;padding:4px 8px;border:1px solid rgba(245,158,11,0.3);border-radius:6px;cursor:pointer">Demo</button>
|
||||
<a href="/logout" style="color:var(--text2);text-decoration:none;font-size:10px;padding:4px 8px;opacity:0.5">Logout</a>
|
||||
<button onclick="toggleHistory()" style="color:var(--text2);background:none;font-size:10px;padding:5px 10px;border:2px solid var(--border);border-radius:2px;cursor:pointer;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:0.5px">History</button>
|
||||
<a href="/lab" style="color:var(--green);text-decoration:none;font-size:10px;padding:5px 10px;border:2px solid rgba(74,222,128,0.2);border-radius:2px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:0.5px">Lab</a>
|
||||
<a href="/admin" style="color:var(--text2);text-decoration:none;font-size:10px;padding:5px 10px;border:2px solid var(--border);border-radius:2px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:0.5px">Admin</a>
|
||||
<span style="width:2px;height:16px;background:var(--border);margin:0 4px"></span>
|
||||
<button id="demo-toggle" onclick="toggleDemo()" style="display:none;color:var(--orange);background:none;font-size:9px;padding:4px 8px;border:2px solid rgba(245,158,11,0.3);border-radius:2px;cursor:pointer;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:0.5px">Demo</button>
|
||||
<a href="/logout" style="color:var(--text2);text-decoration:none;font-size:9px;padding:4px 8px;opacity:0.4;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:0.5px">Logout</a>
|
||||
</nav>
|
||||
</header>
|
||||
<div class="grid">
|
||||
@ -773,7 +796,7 @@ HTML = r"""
|
||||
<div class="mode-tab" data-mode="hallucination" onclick="setMode('hallucination')">Hallucinate?<small>Claim verify</small></div>
|
||||
<div class="mode-tab crazy" data-mode="timeloop" onclick="setMode('timeloop')">Time Loop<small>Catastrophe fix!</small></div>
|
||||
</div>
|
||||
<div style="font-size:9px;text-transform:uppercase;letter-spacing:2px;color:var(--text2);margin:-8px 0 8px;opacity:0.5">Autonomous Pipelines</div>
|
||||
<div style="font-size:8px;text-transform:uppercase;letter-spacing:3px;color:var(--accent);margin:-8px 0 8px;opacity:0.5;font-family:'JetBrains Mono',monospace;font-weight:600">Autonomous Pipelines</div>
|
||||
<div class="mode-grid" style="grid-template-columns:repeat(3,1fr);margin-bottom:16px">
|
||||
<div class="mode-tab" data-mode="research" onclick="setMode('research')" style="border-color:var(--green);border-width:1px">Research<small>Auto brief</small></div>
|
||||
<div class="mode-tab" data-mode="eval" onclick="setMode('eval')" style="border-color:var(--orange);border-width:1px">Model Eval<small>Benchmark</small></div>
|
||||
@ -1509,6 +1532,9 @@ async function toggleDemo() {
|
||||
loadModels();
|
||||
renderSamplePrompts();
|
||||
checkDemo();
|
||||
|
||||
// Background grid animation
|
||||
!function(){const c=document.getElementById('bg-grid');if(!c)return;const x=c.getContext('2d');function resize(){c.width=window.innerWidth;c.height=window.innerHeight}resize();window.addEventListener('resize',resize);let t=0;function draw(){x.clearRect(0,0,c.width,c.height);const s=50,ox=(t*0.2)%s,oy=(t*0.1)%s;x.fillStyle='rgba(226,181,90,0.025)';for(let gx=-s+ox;gx<c.width+s;gx+=s){for(let gy=-s+oy;gy<c.height+s;gy+=s){x.beginPath();x.arc(gx,gy,0.7,0,Math.PI*2);x.fill()}}if(Math.random()>0.985){const ly=Math.random()*c.height;x.strokeStyle='rgba(226,181,90,0.012)';x.lineWidth=1;x.beginPath();x.moveTo(0,ly);x.lineTo(c.width,ly);x.stroke()}if(Math.random()>0.995){const lx=Math.random()*c.width;x.strokeStyle='rgba(226,181,90,0.008)';x.lineWidth=40;x.beginPath();x.moveTo(lx,0);x.lineTo(lx,c.height);x.stroke()}t++;requestAnimationFrame(draw)}draw()}();
|
||||
</script>
|
||||
<div id="repipe-overlay" class="repipe-overlay" onclick="if(event.target===this)closeRepipe()">
|
||||
<div class="repipe-modal">
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user