feat(ui): blackflame theming pass — edit toggle, md tables, back button, Little Blue action cards
- markdown_editor Edit toggle uses themed ghost button - .md-preview gets full blackflame styling incl. tables (migrated BookStack tables now render as tables) - reusable back button on page/reference/project/resource reading views - Little Blue actions regrouped into themed cards, pairing Start/Stop per guest Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
@@ -113,6 +113,47 @@ button.ghost {
|
||||
border-radius: 3px; cursor: pointer; font-size: 13px;
|
||||
}
|
||||
button.ghost:hover { color: var(--text); border-color: var(--accent-dim); }
|
||||
.back-btn { margin-bottom: 12px; }
|
||||
.back-btn:hover { color: var(--accent); border-color: var(--accent-dim); }
|
||||
|
||||
/* Rendered markdown (page preview, chat) — blackflame styling. */
|
||||
.md-preview { color: var(--text); line-height: 1.6; }
|
||||
.md-preview h1, .md-preview h2, .md-preview h3, .md-preview h4 {
|
||||
font-family: var(--font-display); color: var(--accent); letter-spacing: 0.03em; margin: 16px 0 8px;
|
||||
}
|
||||
.md-preview h1 { font-size: 20px; } .md-preview h2 { font-size: 16px; }
|
||||
.md-preview h3 { font-size: 14px; text-transform: uppercase; }
|
||||
.md-preview a { color: var(--accent); }
|
||||
.md-preview code { font-family: var(--font-mono); background: var(--panel-2); padding: 1px 5px; border: 1px solid var(--border); border-radius: 3px; font-size: 12px; }
|
||||
.md-preview pre { background: var(--panel-2); border: 1px solid var(--border); border-radius: 5px; padding: 12px; overflow-x: auto; }
|
||||
.md-preview pre code { border: none; background: none; padding: 0; }
|
||||
.md-preview blockquote { border-left: 2px solid var(--accent-dim); margin: 8px 0; padding: 2px 12px; color: var(--muted); }
|
||||
.md-preview table { border-collapse: collapse; width: 100%; margin: 12px 0; font-size: 13px; }
|
||||
.md-preview th, .md-preview td { border: 1px solid var(--border); padding: 6px 10px; text-align: left; vertical-align: top; }
|
||||
.md-preview th { background: var(--panel-2); color: var(--accent); font-weight: 600; letter-spacing: 0.02em; }
|
||||
.md-preview tbody tr:nth-child(even) td { background: rgba(255, 255, 255, 0.02); }
|
||||
|
||||
/* Little Blue caretaker view */
|
||||
.lb-grid { display: grid; grid-template-columns: 1fr 360px; gap: 14px; align-items: start; }
|
||||
.lb-chat { display: flex; flex-direction: column; height: 70vh; border: 1px solid var(--border); border-radius: 6px; background: var(--panel); overflow: hidden; }
|
||||
.lb-chat .lb-log { flex: 1; overflow-y: auto; padding: 14px; }
|
||||
.lb-actions { display: flex; flex-direction: column; gap: 8px; }
|
||||
.lb-sec { font-family: var(--font-display); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent); margin: 6px 0 2px; }
|
||||
.lb-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
|
||||
.lb-card { padding: 12px; margin: 0; }
|
||||
.lb-pending-card { padding: 12px; margin: 0; border-color: var(--accent-dim); }
|
||||
.lb-card-title { font-size: 12.5px; color: var(--text); margin-bottom: 10px; word-break: break-word; }
|
||||
.lb-btn-row { display: flex; gap: 8px; flex-wrap: wrap; }
|
||||
.lb-act { padding: 5px 12px; border-radius: 3px; cursor: pointer; font-size: 12px; font-family: var(--font-ui); border: 1px solid var(--border); background: transparent; color: var(--muted); }
|
||||
.lb-act.safe { color: var(--ok); }
|
||||
.lb-act.safe:hover { border-color: var(--ok); color: var(--ok); }
|
||||
.lb-act.risky { color: var(--accent); background: var(--accent-soft); border-color: var(--accent-dim); }
|
||||
.lb-act.risky:hover { background: var(--accent-dim); color: var(--text); }
|
||||
.lb-act:disabled { opacity: 0.5; cursor: default; }
|
||||
.lb-toasts { position: fixed; bottom: 16px; right: 16px; display: flex; flex-direction: column; gap: 6px; z-index: 60; }
|
||||
.lb-toast { background: var(--panel-2); border: 1px solid var(--accent-dim); color: var(--text); padding: 8px 12px; border-radius: 4px; font-size: 12px; box-shadow: 0 4px 16px rgba(0,0,0,0.45); }
|
||||
.lb-toast.err { border-color: var(--bad); color: var(--bad); }
|
||||
@media (max-width: 900px) { .lb-grid { grid-template-columns: 1fr; } }
|
||||
|
||||
/* modal */
|
||||
.modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.6); display: flex; align-items: center; justify-content: center; z-index: 100; }
|
||||
|
||||
Reference in New Issue
Block a user