/* tiny_vllm demo — visual language matched to surajsharan.github.io * * Tokens lifted from the portfolio CSS: * bg: #0a0e14 (215 30% 5%) foreground: #fafafa * accent: #c6ff3e (lime) accent-dim: #8ac91f * card: #0f131a border: #212833 * muted text: ~hsl(215 12% 60%) * fonts: Inter (sans), JetBrains Mono (mono) * radius: 0.5rem */ :root { --bg: #0a0e14; --bg-elev: #0f131a; --bg-elev2: #141926; --fg: #fafafa; --muted: #8d96a3; --accent: #c6ff3e; --accent-dim: #8ac91f; --accent-bg: rgba(198, 255, 62, 0.08); --green: #c6ff3e; /* reuse lime for success */ --purple: #b78cff; --orange: #f0a23e; --red: #ff6b6b; --border: #212833; --border-strong: #2d3645; --radius: 0.5rem; --sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif; --mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace; --grid: rgba(255, 255, 255, 0.045); } * { box-sizing: border-box; } html, body { background: var(--bg); color: var(--fg); } body { margin: 0; font-family: var(--sans); font-size: 14px; line-height: 1.5; background-image: linear-gradient(var(--grid) 1px, transparent 1px), linear-gradient(90deg, var(--grid) 1px, transparent 1px); background-size: 48px 48px; background-position: -1px -1px; background-attachment: fixed; } /* ---------- topbar ---------- */ .topbar { display: flex; align-items: center; justify-content: space-between; padding: 10px 24px; border-bottom: 1px solid var(--border); background: rgba(10, 14, 20, 0.85); backdrop-filter: blur(8px); font-family: var(--mono); font-size: 12px; position: sticky; top: 0; z-index: 10; } .topbar a { color: var(--fg); text-decoration: none; } .topbar a:hover { color: var(--accent); } .topbar .crumb { color: var(--muted); } .topbar .crumb .sep { margin: 0 6px; } .topbar .right { display: flex; gap: 16px; align-items: center; } .topbar .right a { color: var(--muted); } .topbar .right a:hover { color: var(--accent); } header.hero { padding: 28px 24px 20px; border-bottom: 1px solid var(--border); } header.hero h1 { margin: 0 0 4px; font-family: var(--mono); font-size: 22px; font-weight: 600; letter-spacing: -0.01em; } header.hero h1::before { content: "$ "; color: var(--accent); margin-right: 4px; } header.hero .subtitle { color: var(--muted); font-size: 13px; margin: 0; max-width: 760px; } header.hero .status { display: flex; gap: 10px; align-items: center; margin-top: 10px; font-family: var(--mono); font-size: 11px; } .badge { display: inline-flex; align-items: center; gap: 6px; padding: 3px 10px; border-radius: 999px; font-family: var(--mono); font-size: 11px; border: 1px solid var(--border-strong); background: var(--bg-elev); } .badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--muted); } .badge.online { color: var(--accent); border-color: var(--accent); } .badge.online::before { background: var(--accent); box-shadow: 0 0 8px var(--accent); } .badge.offline { color: var(--red); border-color: rgba(255, 107, 107, 0.4); } .badge.offline::before { background: var(--red); } .badge.replay { color: var(--purple); border-color: rgba(183, 140, 255, 0.4); } .badge.replay::before { background: var(--purple); } .muted { color: var(--muted); font-weight: 400; } /* ---------- banner ---------- */ .banner { padding: 10px 24px; font-family: var(--mono); font-size: 12px; background: rgba(183, 140, 255, 0.08); color: var(--purple); border-bottom: 1px solid rgba(183, 140, 255, 0.25); } .banner.error, .banner.replay-banner.error { background: rgba(255, 107, 107, 0.08); color: var(--red); border-bottom-color: rgba(255, 107, 107, 0.3); } /* ---------- prompt box ---------- */ .prompt-box { padding: 14px 24px; border-bottom: 1px solid var(--border); background: var(--bg-elev); display: flex; flex-direction: column; gap: 10px; } .prompt-box textarea { width: 100%; background: var(--bg); color: var(--fg); border: 1px solid var(--border); border-radius: var(--radius); padding: 10px 12px; font-family: var(--mono); font-size: 13px; resize: vertical; } .prompt-box textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-bg); } .controls { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; } .controls label { display: flex; gap: 6px; align-items: center; font-family: var(--mono); font-size: 11px; color: var(--muted); text-transform: lowercase; } .controls input { width: 70px; background: var(--bg); color: var(--fg); border: 1px solid var(--border); border-radius: var(--radius); padding: 4px 8px; font-family: var(--mono); font-size: 12px; } .controls input:focus { outline: none; border-color: var(--accent); } button { background: var(--accent); color: var(--bg); border: 1px solid var(--accent); border-radius: var(--radius); padding: 6px 14px; font-family: var(--mono); font-size: 12px; font-weight: 600; cursor: pointer; transition: all 0.12s ease; } button:hover { background: var(--accent-dim); border-color: var(--accent-dim); } button:disabled { opacity: 0.35; cursor: not-allowed; background: var(--bg-elev); color: var(--muted); border-color: var(--border); } button.ghost { background: transparent; border: 1px solid var(--border-strong); color: var(--fg); } button.ghost:hover { border-color: var(--accent); color: var(--accent); } #send-twice { background: transparent; color: var(--accent); border: 1px solid var(--accent); } #send-twice:hover { background: var(--accent-bg); } textarea:disabled { opacity: 0.5; } .replay-controls { margin-left: auto; display: flex; gap: 6px; align-items: center; } .replay-controls select { background: var(--bg); color: var(--fg); border: 1px solid var(--border); border-radius: var(--radius); padding: 4px 8px; font-family: var(--mono); font-size: 12px; } /* ---------- layout ---------- */ main { display: grid; grid-template-columns: 1fr 1fr; grid-template-areas: "pool sched" "seqs seqs"; gap: 16px; padding: 16px 24px; } .card { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; position: relative; } .card::before { content: ""; position: absolute; top: -1px; bottom: -1px; left: -1px; width: 2px; background: var(--accent); border-top-left-radius: var(--radius); border-bottom-left-radius: var(--radius); opacity: 0; transition: opacity 0.18s ease; } .card:hover::before { opacity: 1; } .card h2 { font-family: var(--mono); font-size: 12px; font-weight: 600; margin: 0 0 12px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg); } .card h2 .muted { font-weight: 400; text-transform: none; letter-spacing: 0; } .card h3 { font-family: var(--mono); font-size: 10px; margin: 14px 0 6px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.1em; } .card.grow { grid-area: seqs; } .card:nth-of-type(1) { grid-area: pool; } .card:nth-of-type(2) { grid-area: sched; } /* ---------- block pool ---------- */ .block-pool { display: grid; grid-template-columns: repeat(auto-fill, 16px); gap: 3px; padding: 10px; background: var(--bg); border-radius: var(--radius); border: 1px solid var(--border); max-height: 320px; overflow-y: auto; } .block { width: 16px; height: 16px; border-radius: 2px; background: var(--bg-elev2); cursor: help; border: 1px solid transparent; transition: transform 0.1s ease; } .block:hover { transform: scale(1.25); z-index: 2; position: relative; } .block.free { background: #1a2030; } .block.cached { background: #2a3d2a; } .block.used { background: var(--accent); } .block.shared { background: var(--purple); } .block.hashed { border-color: var(--accent); } .legend { display: flex; gap: 14px; margin-top: 10px; font-family: var(--mono); font-size: 10px; color: var(--muted); flex-wrap: wrap; } .legend-item { display: flex; align-items: center; gap: 5px; } .swatch { width: 12px; height: 12px; border-radius: 2px; display: inline-block; } .swatch-free { background: #1a2030; } .swatch-cached { background: #2a3d2a; } .swatch-used { background: var(--accent); } .swatch-shared { background: var(--purple); } .swatch-hashed-edge { background: var(--bg-elev2); border: 1px solid var(--accent); } /* ---------- stats ---------- */ .stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; } .stat { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius); padding: 10px; } .stat-label { font-family: var(--mono); font-size: 9px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.1em; } .stat-value { font-family: var(--mono); font-size: 20px; margin-top: 4px; color: var(--fg); font-weight: 500; } /* ---------- log ---------- */ .log { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius); padding: 10px; height: 160px; overflow-y: auto; font-family: var(--mono); font-size: 11px; margin: 0; white-space: pre-wrap; word-break: break-word; color: var(--muted); } .log .ev-step { color: var(--muted); } .log .ev-admit { color: var(--accent); } .log .ev-finish { color: var(--accent-dim); } .log .ev-preempt { color: var(--orange); } /* ---------- sequences ---------- */ #seqs { display: flex; flex-direction: column; gap: 10px; } .seq { background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px; } .seq-header { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; } .seq-id { font-family: var(--mono); color: var(--muted); font-size: 11px; } .seq-status { font-family: var(--mono); font-size: 9px; text-transform: uppercase; padding: 2px 8px; border-radius: 999px; letter-spacing: 0.08em; border: 1px solid; } .seq-status.waiting { color: var(--muted); border-color: var(--border-strong); } .seq-status.prefilling { color: var(--accent); border-color: var(--accent); background: var(--accent-bg); } .seq-status.running { color: var(--accent); border-color: var(--accent); } .seq-status.finished { color: var(--purple); border-color: var(--purple); } .seq-status.preempted { color: var(--orange); border-color: var(--orange); } .seq-meta { color: var(--muted); font-size: 11px; font-family: var(--mono); margin-left: auto; } .seq-blocks { margin-top: 10px; display: flex; gap: 3px; flex-wrap: wrap; } .seq-block { width: 26px; height: 16px; background: var(--bg-elev2); font-family: var(--mono); font-size: 9px; line-height: 16px; text-align: center; border-radius: 2px; color: var(--muted); border: 1px solid var(--border); } .seq-block.cached-hit { background: rgba(198, 255, 62, 0.12); color: var(--accent); border-color: var(--accent); } .seq-block.shared { background: rgba(183, 140, 255, 0.18); color: var(--purple); border-color: var(--purple); } .seq-text { margin-top: 10px; font-family: var(--mono); font-size: 12px; background: var(--bg-elev2); border: 1px solid var(--border); border-radius: var(--radius); padding: 10px 12px; min-height: 28px; max-height: 200px; overflow-y: auto; white-space: pre-wrap; word-break: break-word; line-height: 1.55; } .seq-text .prompt { color: var(--muted); } .seq-text .gen { color: var(--fg); } .seq-text .cursor { display: inline-block; width: 7px; height: 14px; background: var(--accent); vertical-align: text-bottom; margin-left: 1px; animation: blink 1s steps(2, start) infinite; } @keyframes blink { to { opacity: 0; } } footer { padding: 14px 24px; border-top: 1px solid var(--border); color: var(--muted); font-family: var(--mono); font-size: 11px; } footer a { color: var(--accent); text-decoration: none; } footer a:hover { text-decoration: underline; } /* ---------- scrollbar ---------- */ ::-webkit-scrollbar { width: 8px; height: 8px; } ::-webkit-scrollbar-track { background: transparent; } ::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 4px; } ::-webkit-scrollbar-thumb:hover { background: var(--muted); } @media (max-width: 900px) { main { grid-template-columns: 1fr; grid-template-areas: "pool" "sched" "seqs"; } .stats { grid-template-columns: repeat(2, 1fr); } .topbar { padding: 8px 16px; font-size: 11px; } header.hero, .prompt-box, main, footer { padding-left: 16px; padding-right: 16px; } }