/**
* Daem0n MCP Apps - Shared Aesthetic Theme
*
* This CSS defines the daemon visual identity used across all MCP Apps.
* The dark theme with purple accents reflects the daemon's nature as
* a background intelligence that emerges when needed.
*
* Usage: Include in all MCP Apps templates as <link rel="stylesheet" href="daemon.css">
*/
/* ==========================================================================
CSS Custom Properties - Daemon Theme
========================================================================== */
:root {
/* Core colors - daemon theme */
--daemon-bg: #0a0a0f;
--daemon-bg-alt: #12121a;
--daemon-surface: #1a1a24;
--daemon-text: #e0e0e0;
--daemon-text-muted: #888888;
--daemon-accent: #8b5cf6; /* Purple - primary actions */
--daemon-accent-hover: #a78bfa;
--daemon-warning: #f59e0b; /* Amber - warnings */
--daemon-error: #ef4444; /* Red - errors */
--daemon-success: #22c55e; /* Green - success */
--daemon-decision: #3b82f6; /* Blue - decisions */
--daemon-pattern: #8b5cf6; /* Purple - patterns */
--daemon-learning: #22c55e; /* Green - learnings */
/* Typography */
--daemon-font: 'Segoe UI', system-ui, -apple-system, sans-serif;
--daemon-font-mono: 'Cascadia Code', 'Fira Code', monospace;
/* Spacing */
--daemon-space-xs: 4px;
--daemon-space-sm: 8px;
--daemon-space-md: 16px;
--daemon-space-lg: 24px;
--daemon-space-xl: 32px;
/* Borders */
--daemon-radius: 6px;
--daemon-border: 1px solid rgba(139, 92, 246, 0.2);
/* Shadows */
--daemon-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3);
--daemon-glow: 0 0 20px rgba(139, 92, 246, 0.15);
}
/* ==========================================================================
Base Element Styles
========================================================================== */
*,
*::before,
*::after {
box-sizing: border-box;
}
html {
font-size: 16px;
line-height: 1.5;
}
body {
margin: 0;
padding: 0;
background-color: var(--daemon-bg);
color: var(--daemon-text);
font-family: var(--daemon-font);
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
/* Headings */
h1, h2, h3, h4, h5, h6 {
margin: 0 0 var(--daemon-space-md) 0;
color: var(--daemon-text);
font-weight: 600;
line-height: 1.25;
}
h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.125rem; }
h5 { font-size: 1rem; }
h6 { font-size: 0.875rem; color: var(--daemon-text-muted); }
/* Paragraphs */
p {
margin: 0 0 var(--daemon-space-md) 0;
}
/* Links */
a {
color: var(--daemon-accent);
text-decoration: none;
transition: color 0.15s ease;
}
a:hover {
color: var(--daemon-accent-hover);
text-decoration: underline;
}
a:focus-visible {
outline: 2px solid var(--daemon-accent);
outline-offset: 2px;
}
/* Code */
code, pre {
font-family: var(--daemon-font-mono);
}
code {
padding: 2px 6px;
background-color: var(--daemon-surface);
border-radius: 3px;
font-size: 0.875em;
}
pre {
margin: 0 0 var(--daemon-space-md) 0;
padding: var(--daemon-space-md);
background-color: var(--daemon-surface);
border-radius: var(--daemon-radius);
overflow-x: auto;
}
pre code {
padding: 0;
background-color: transparent;
}
/* ==========================================================================
Form Elements
========================================================================== */
button {
cursor: pointer;
font-family: inherit;
font-size: inherit;
}
input, textarea, select {
font-family: inherit;
font-size: inherit;
}
/* ==========================================================================
Scrollbar Styling
========================================================================== */
::-webkit-scrollbar {
width: 8px;
height: 8px;
}
::-webkit-scrollbar-track {
background: var(--daemon-bg-alt);
}
::-webkit-scrollbar-thumb {
background: var(--daemon-surface);
border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
background: var(--daemon-text-muted);
}
/* Firefox scrollbar */
* {
scrollbar-width: thin;
scrollbar-color: var(--daemon-surface) var(--daemon-bg-alt);
}
/* ==========================================================================
Utility Classes - Cards
========================================================================== */
.daemon-card {
background-color: var(--daemon-surface);
border: var(--daemon-border);
border-radius: var(--daemon-radius);
padding: var(--daemon-space-lg);
box-shadow: var(--daemon-shadow);
}
.daemon-card:hover {
box-shadow: var(--daemon-shadow), var(--daemon-glow);
}
/* ==========================================================================
Utility Classes - Buttons
========================================================================== */
.daemon-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: var(--daemon-space-sm);
padding: var(--daemon-space-sm) var(--daemon-space-md);
background-color: var(--daemon-accent);
color: white;
border: none;
border-radius: var(--daemon-radius);
font-weight: 500;
text-decoration: none;
transition: background-color 0.15s ease, transform 0.1s ease;
}
.daemon-btn:hover {
background-color: var(--daemon-accent-hover);
color: white;
text-decoration: none;
transform: translateY(-1px);
}
.daemon-btn:active {
transform: translateY(0);
}
.daemon-btn:focus-visible {
outline: 2px solid var(--daemon-accent-hover);
outline-offset: 2px;
}
.daemon-btn--secondary {
background-color: transparent;
border: var(--daemon-border);
color: var(--daemon-text);
}
.daemon-btn--secondary:hover {
background-color: var(--daemon-surface);
border-color: var(--daemon-accent);
}
.daemon-btn--small {
padding: var(--daemon-space-xs) var(--daemon-space-sm);
font-size: 0.875rem;
}
/* ==========================================================================
Utility Classes - Inputs
========================================================================== */
.daemon-input {
width: 100%;
padding: var(--daemon-space-sm) var(--daemon-space-md);
background-color: var(--daemon-surface);
color: var(--daemon-text);
border: var(--daemon-border);
border-radius: var(--daemon-radius);
transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.daemon-input::placeholder {
color: var(--daemon-text-muted);
}
.daemon-input:focus {
outline: none;
border-color: var(--daemon-accent);
box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.2);
}
.daemon-input:disabled {
opacity: 0.5;
cursor: not-allowed;
}
/* Textarea variant */
textarea.daemon-input {
min-height: 100px;
resize: vertical;
}
/* Select variant */
select.daemon-input {
cursor: pointer;
appearance: none;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888888' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right var(--daemon-space-sm) center;
padding-right: var(--daemon-space-xl);
}
/* ==========================================================================
Utility Classes - Badges
========================================================================== */
.daemon-badge {
display: inline-flex;
align-items: center;
gap: var(--daemon-space-xs);
padding: 2px var(--daemon-space-sm);
background-color: var(--daemon-surface);
border: 1px solid var(--daemon-text-muted);
border-radius: 999px;
font-size: 0.75rem;
font-weight: 500;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.daemon-badge--decision {
background-color: rgba(59, 130, 246, 0.1);
border-color: var(--daemon-decision);
color: var(--daemon-decision);
}
.daemon-badge--pattern {
background-color: rgba(139, 92, 246, 0.1);
border-color: var(--daemon-pattern);
color: var(--daemon-pattern);
}
.daemon-badge--learning {
background-color: rgba(34, 197, 94, 0.1);
border-color: var(--daemon-learning);
color: var(--daemon-learning);
}
.daemon-badge--warning {
background-color: rgba(245, 158, 11, 0.1);
border-color: var(--daemon-warning);
color: var(--daemon-warning);
}
.daemon-badge--error {
background-color: rgba(239, 68, 68, 0.1);
border-color: var(--daemon-error);
color: var(--daemon-error);
}
.daemon-badge--success {
background-color: rgba(34, 197, 94, 0.1);
border-color: var(--daemon-success);
color: var(--daemon-success);
}
/* ==========================================================================
Utility Classes - Score Display
========================================================================== */
.daemon-score {
display: inline-flex;
align-items: center;
gap: var(--daemon-space-xs);
font-family: var(--daemon-font-mono);
font-size: 0.875rem;
font-weight: 600;
}
.daemon-score__value {
color: var(--daemon-accent);
}
.daemon-score__label {
color: var(--daemon-text-muted);
font-weight: 400;
font-size: 0.75rem;
}
/* Score bar visualization */
.daemon-score-bar {
display: flex;
align-items: center;
gap: var(--daemon-space-sm);
width: 100%;
}
.daemon-score-bar__track {
flex: 1;
height: 6px;
background-color: var(--daemon-bg-alt);
border-radius: 3px;
overflow: hidden;
}
.daemon-score-bar__fill {
height: 100%;
background: linear-gradient(90deg, var(--daemon-accent), var(--daemon-accent-hover));
border-radius: 3px;
transition: width 0.3s ease;
}
/* ==========================================================================
Status Colors - Standalone Classes
========================================================================== */
.daemon-warning {
color: var(--daemon-warning);
}
.daemon-error {
color: var(--daemon-error);
}
.daemon-success {
color: var(--daemon-success);
}
.daemon-muted {
color: var(--daemon-text-muted);
}
/* Background variants */
.daemon-warning-bg {
background-color: rgba(245, 158, 11, 0.1);
border-left: 3px solid var(--daemon-warning);
padding: var(--daemon-space-sm) var(--daemon-space-md);
}
.daemon-error-bg {
background-color: rgba(239, 68, 68, 0.1);
border-left: 3px solid var(--daemon-error);
padding: var(--daemon-space-sm) var(--daemon-space-md);
}
.daemon-success-bg {
background-color: rgba(34, 197, 94, 0.1);
border-left: 3px solid var(--daemon-success);
padding: var(--daemon-space-sm) var(--daemon-space-md);
}
/* ==========================================================================
Layout Utilities
========================================================================== */
.daemon-container {
max-width: 1200px;
margin: 0 auto;
padding: 0 var(--daemon-space-md);
}
.daemon-flex {
display: flex;
}
.daemon-flex--column {
flex-direction: column;
}
.daemon-flex--center {
align-items: center;
justify-content: center;
}
.daemon-flex--between {
justify-content: space-between;
}
.daemon-flex--gap-sm {
gap: var(--daemon-space-sm);
}
.daemon-flex--gap-md {
gap: var(--daemon-space-md);
}
.daemon-flex--gap-lg {
gap: var(--daemon-space-lg);
}
.daemon-grid {
display: grid;
gap: var(--daemon-space-md);
}
.daemon-grid--2 {
grid-template-columns: repeat(2, 1fr);
}
.daemon-grid--3 {
grid-template-columns: repeat(3, 1fr);
}
.daemon-grid--auto {
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
/* ==========================================================================
Loading States
========================================================================== */
.daemon-loading {
display: flex;
align-items: center;
justify-content: center;
gap: var(--daemon-space-sm);
padding: var(--daemon-space-lg);
color: var(--daemon-text-muted);
}
.daemon-spinner {
width: 20px;
height: 20px;
border: 2px solid var(--daemon-surface);
border-top-color: var(--daemon-accent);
border-radius: 50%;
animation: daemon-spin 0.8s linear infinite;
}
@keyframes daemon-spin {
to {
transform: rotate(360deg);
}
}
/* ==========================================================================
Empty States
========================================================================== */
.daemon-empty {
text-align: center;
padding: var(--daemon-space-xl);
color: var(--daemon-text-muted);
}
.daemon-empty__icon {
font-size: 3rem;
margin-bottom: var(--daemon-space-md);
opacity: 0.5;
}
.daemon-empty__title {
font-size: 1.125rem;
font-weight: 500;
color: var(--daemon-text);
margin-bottom: var(--daemon-space-sm);
}
.daemon-empty__description {
font-size: 0.875rem;
max-width: 400px;
margin: 0 auto;
}
/* ==========================================================================
Pagination
========================================================================== */
.daemon-pagination {
display: flex;
align-items: center;
justify-content: center;
gap: var(--daemon-space-md);
padding: var(--daemon-space-md) 0;
margin-top: var(--daemon-space-lg);
border-top: var(--daemon-border);
}
.daemon-pagination__info {
color: var(--daemon-text-muted);
font-size: 0.875rem;
}
.daemon-pagination__btn {
padding: var(--daemon-space-xs) var(--daemon-space-md);
background-color: var(--daemon-surface);
color: var(--daemon-text);
border: var(--daemon-border);
border-radius: var(--daemon-radius);
cursor: pointer;
transition: background-color 0.15s ease;
}
.daemon-pagination__btn:hover:not(:disabled) {
background-color: var(--daemon-bg-alt);
border-color: var(--daemon-accent);
}
.daemon-pagination__btn:disabled {
opacity: 0.5;
cursor: not-allowed;
}
/* ==========================================================================
Accordion
========================================================================== */
.daemon-accordion {
display: flex;
flex-direction: column;
gap: var(--daemon-space-sm);
}
.daemon-accordion__item {
background-color: var(--daemon-surface);
border: var(--daemon-border);
border-radius: var(--daemon-radius);
overflow: hidden;
}
.daemon-accordion__header {
display: flex;
align-items: center;
justify-content: space-between;
padding: var(--daemon-space-md);
background-color: transparent;
border: none;
width: 100%;
cursor: pointer;
color: var(--daemon-text);
font-size: 1rem;
font-weight: 500;
text-align: left;
transition: background-color 0.15s ease;
}
.daemon-accordion__header:hover {
background-color: var(--daemon-bg-alt);
}
.daemon-accordion__header:focus-visible {
outline: 2px solid var(--daemon-accent);
outline-offset: -2px;
}
.daemon-accordion__title {
display: flex;
align-items: center;
gap: var(--daemon-space-sm);
}
.daemon-accordion__count {
font-size: 0.75rem;
color: var(--daemon-text-muted);
font-weight: 400;
}
.daemon-accordion__icon {
font-size: 0.75rem;
color: var(--daemon-text-muted);
transition: transform 0.2s ease;
}
.daemon-accordion__item[open] .daemon-accordion__icon {
transform: rotate(90deg);
}
.daemon-accordion__content {
padding: 0 var(--daemon-space-md) var(--daemon-space-md);
}
/* Statistics Panel */
.daemon-stats {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
gap: var(--daemon-space-md);
padding: var(--daemon-space-md);
background-color: var(--daemon-surface);
border: var(--daemon-border);
border-radius: var(--daemon-radius);
margin-bottom: var(--daemon-space-lg);
}
.daemon-stat {
text-align: center;
}
.daemon-stat__value {
font-size: 1.75rem;
font-weight: 600;
color: var(--daemon-accent);
font-family: var(--daemon-font-mono);
}
.daemon-stat__label {
font-size: 0.75rem;
color: var(--daemon-text-muted);
text-transform: uppercase;
letter-spacing: 0.05em;
margin-top: var(--daemon-space-xs);
}
.daemon-stat--success .daemon-stat__value {
color: var(--daemon-success);
}
.daemon-stat--warning .daemon-stat__value {
color: var(--daemon-warning);
}
.daemon-stat--error .daemon-stat__value {
color: var(--daemon-error);
}
/* ==========================================================================
Responsive Breakpoints
========================================================================== */
@media (max-width: 768px) {
.daemon-grid--2,
.daemon-grid--3 {
grid-template-columns: 1fr;
}
.daemon-container {
padding: 0 var(--daemon-space-sm);
}
.daemon-card {
padding: var(--daemon-space-md);
}
}
/* ==========================================================================
Covenant State Machine Visualization
========================================================================== */
.covenant-diagram {
width: 100%;
max-width: 720px;
height: auto;
display: block;
margin: 0 auto;
}
.covenant-state circle {
fill: var(--daemon-surface);
stroke: var(--daemon-text-muted);
stroke-width: 2;
transition: fill 0.3s ease, stroke 0.3s ease;
transform-origin: center;
}
.covenant-state text {
fill: var(--daemon-text);
font-size: 12px;
font-weight: 500;
text-anchor: middle;
}
.covenant-state--active circle {
fill: var(--daemon-accent);
stroke: var(--daemon-accent-hover);
animation: covenant-pulse 2s ease-in-out infinite;
}
.covenant-state--active text {
fill: white;
}
.covenant-state--completed circle {
fill: var(--daemon-success);
stroke: var(--daemon-success);
}
.covenant-transition {
stroke: var(--daemon-text-muted);
stroke-width: 2;
fill: none;
}
@keyframes covenant-pulse {
0%, 100% {
filter: drop-shadow(0 0 4px var(--daemon-accent));
}
50% {
filter: drop-shadow(0 0 12px var(--daemon-accent));
}
}
/* ==========================================================================
Token Status Panel
========================================================================== */
.token-status {
padding: var(--daemon-space-md);
background: var(--daemon-surface);
border: var(--daemon-border);
border-radius: var(--daemon-radius);
margin-bottom: var(--daemon-space-lg);
}
.token-status__header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: var(--daemon-space-md);
}
.token-status__label {
font-weight: 500;
color: var(--daemon-text);
}
.token-status__badge {
padding: 2px var(--daemon-space-sm);
border-radius: 999px;
font-size: 0.75rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
}
.token-status__badge--valid {
background-color: var(--daemon-success);
color: white;
}
.token-status__badge--expired {
background-color: var(--daemon-error);
color: white;
}
.token-status__badge--none {
background-color: var(--daemon-text-muted);
color: var(--daemon-surface);
}
.token-status__countdown {
display: flex;
align-items: center;
gap: var(--daemon-space-sm);
margin-bottom: var(--daemon-space-md);
}
.token-status__icon {
font-size: 1.25rem;
color: var(--daemon-text-muted);
}
.token-status__time {
font-family: var(--daemon-font-mono);
font-size: 1.5rem;
font-weight: 600;
color: var(--daemon-accent);
}
.token-status__time--warning {
color: var(--daemon-warning);
}
.token-status__unit {
font-size: 0.875rem;
color: var(--daemon-text-muted);
}
/* ==========================================================================
Treemap - Community Cluster Map (Phase 10)
========================================================================== */
.treemap-container {
width: 100%;
height: 500px;
background-color: var(--daemon-surface);
border: var(--daemon-border);
border-radius: var(--daemon-radius);
position: relative;
overflow: hidden;
}
.treemap-cell {
position: absolute;
border: 1px solid var(--daemon-bg);
overflow: hidden;
cursor: pointer;
transition: filter 0.2s ease;
}
.treemap-cell:hover {
filter: brightness(1.15);
}
.treemap-cell__label {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
color: var(--daemon-text);
font-size: 0.75rem;
font-weight: 600;
text-shadow: 0 1px 2px rgba(0, 0, 0, 0.8);
pointer-events: none;
text-align: center;
max-width: 90%;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.treemap-cell__count {
position: absolute;
bottom: var(--daemon-space-xs);
right: var(--daemon-space-xs);
font-size: 0.625rem;
color: rgba(255, 255, 255, 0.7);
font-family: var(--daemon-font-mono);
text-shadow: 0 1px 2px rgba(0, 0, 0, 0.8);
pointer-events: none;
}
/* Treemap hierarchy colors (6 levels) */
.treemap-cell--level-0 { background-color: #6366f1; } /* Indigo - root */
.treemap-cell--level-1 { background-color: #8b5cf6; } /* Purple - level 1 */
.treemap-cell--level-2 { background-color: #a855f7; } /* Violet - level 2 */
.treemap-cell--level-3 { background-color: #d946ef; } /* Fuchsia - level 3 */
.treemap-cell--level-4 { background-color: #ec4899; } /* Pink - level 4 */
.treemap-cell--level-5 { background-color: #f43f5e; } /* Rose - level 5+ */
/* Leaf cells (no drill-down available) */
.treemap-cell--leaf {
cursor: default;
}
.treemap-cell--leaf:hover {
filter: brightness(1.1); /* Reduced hover effect for leaf nodes */
}
/* Treemap tooltip */
.treemap-tooltip {
position: fixed;
z-index: 1000;
max-width: 300px;
padding: var(--daemon-space-sm) var(--daemon-space-md);
background-color: var(--daemon-surface);
border: var(--daemon-border);
border-radius: var(--daemon-radius);
box-shadow: var(--daemon-shadow);
font-size: 0.875rem;
pointer-events: none;
opacity: 0;
transition: opacity 0.15s ease;
}
.treemap-tooltip--visible {
opacity: 1;
}
.treemap-tooltip__title {
font-weight: 600;
color: var(--daemon-text);
margin-bottom: var(--daemon-space-xs);
}
.treemap-tooltip__summary {
color: var(--daemon-text-muted);
line-height: 1.4;
}
.treemap-tooltip__meta {
display: flex;
gap: var(--daemon-space-md);
margin-top: var(--daemon-space-sm);
padding-top: var(--daemon-space-sm);
border-top: var(--daemon-border);
font-size: 0.75rem;
color: var(--daemon-text-muted);
}
/* Treemap breadcrumb navigation */
.treemap-breadcrumb {
display: flex;
align-items: center;
gap: var(--daemon-space-xs);
padding: var(--daemon-space-sm) 0;
font-size: 0.875rem;
flex-wrap: wrap;
}
.treemap-breadcrumb__item {
color: var(--daemon-text-muted);
cursor: pointer;
transition: color 0.15s ease;
}
.treemap-breadcrumb__item:hover {
color: var(--daemon-accent);
}
.treemap-breadcrumb__item--current {
color: var(--daemon-text);
cursor: default;
}
.treemap-breadcrumb__item--current:hover {
color: var(--daemon-text);
}
.treemap-breadcrumb__separator {
color: var(--daemon-text-muted);
}
/* ============================================
MEMORY GRAPH VIEWER (Phase 11)
============================================ */
/* Graph container - full viewport canvas */
.graph-container {
position: relative;
width: 100%;
height: calc(100vh - 120px);
background: var(--daemon-bg);
border-radius: var(--daemon-radius);
overflow: hidden;
}
.graph-canvas {
display: block;
cursor: grab;
}
.graph-canvas:active {
cursor: grabbing;
}
/* Node category colors (match existing badge colors) */
.graph-node--decision { fill: var(--daemon-decision, #3b82f6); }
.graph-node--warning { fill: var(--daemon-warning, #f59e0b); }
.graph-node--pattern { fill: var(--daemon-pattern, #8b5cf6); }
.graph-node--learning { fill: var(--daemon-learning, #22c55e); }
/* Details panel (slides in from right) */
.graph-details {
position: absolute;
top: 0;
right: 0;
width: 320px;
height: 100%;
background: var(--daemon-surface);
border-left: 1px solid var(--daemon-border);
padding: var(--daemon-space-md);
transform: translateX(100%);
transition: transform 0.2s ease-out;
overflow-y: auto;
z-index: 10;
}
.graph-details--visible {
transform: translateX(0);
}
.graph-details__close {
position: absolute;
top: var(--daemon-space-sm);
right: var(--daemon-space-sm);
background: none;
border: none;
color: var(--daemon-text-muted);
font-size: 1.5rem;
cursor: pointer;
line-height: 1;
}
.graph-details__close:hover {
color: var(--daemon-text);
}
/* Graph header with controls */
.graph-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--daemon-space-md);
}
.graph-header__title {
display: flex;
align-items: center;
gap: var(--daemon-space-sm);
}
.graph-header__count {
color: var(--daemon-text-muted);
font-size: 0.875rem;
}
/* Legend for node categories */
.graph-legend {
display: flex;
gap: var(--daemon-space-md);
flex-wrap: wrap;
margin-bottom: var(--daemon-space-md);
}
.graph-legend__item {
display: flex;
align-items: center;
gap: var(--daemon-space-xs);
font-size: 0.75rem;
color: var(--daemon-text-muted);
}
.graph-legend__color {
width: 12px;
height: 12px;
border-radius: 50%;
}
.graph-legend__color--decision { background: var(--daemon-decision, #3b82f6); }
.graph-legend__color--warning { background: var(--daemon-warning, #f59e0b); }
.graph-legend__color--pattern { background: var(--daemon-pattern, #8b5cf6); }
.graph-legend__color--learning { background: var(--daemon-learning, #22c55e); }
/* Zoom controls */
.graph-controls {
position: absolute;
bottom: var(--daemon-space-md);
right: var(--daemon-space-md);
display: flex;
flex-direction: column;
gap: var(--daemon-space-xs);
z-index: 5;
}
.graph-controls__btn {
width: 36px;
height: 36px;
display: flex;
align-items: center;
justify-content: center;
background: var(--daemon-surface);
border: 1px solid var(--daemon-border);
border-radius: var(--daemon-radius);
color: var(--daemon-text);
font-size: 1.25rem;
cursor: pointer;
transition: background 0.15s;
}
.graph-controls__btn:hover {
background: var(--daemon-bg-alt);
}
/* Loading indicator */
.graph-loading {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
display: flex;
flex-direction: column;
align-items: center;
gap: var(--daemon-space-sm);
color: var(--daemon-text-muted);
}
.graph-loading__spinner {
width: 32px;
height: 32px;
border: 3px solid var(--daemon-border);
border-top-color: var(--daemon-accent);
border-radius: 50%;
animation: graph-spin 0.8s linear infinite;
}
@keyframes graph-spin {
to { transform: rotate(360deg); }
}
.graph-loading--hidden {
display: none;
}
/* Empty state */
.graph-empty {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
text-align: center;
color: var(--daemon-text-muted);
}
/* ==========================================================================
Path Animation Controls (Phase 11 - trace_chain visualization)
========================================================================== */
/* Path animation overlay controls */
.graph-path-controls {
position: absolute;
top: var(--daemon-space-md);
left: var(--daemon-space-md);
display: flex;
gap: var(--daemon-space-sm);
z-index: 5;
}
.graph-path-info {
background: var(--daemon-surface);
border: 1px solid var(--daemon-border);
border-radius: var(--daemon-radius);
padding: var(--daemon-space-xs) var(--daemon-space-sm);
font-size: 0.75rem;
color: var(--daemon-text-muted);
}
.graph-path-info--visible {
display: block;
}
.graph-path-info--hidden {
display: none;
}
/* Path clear button */
.graph-path-clear {
background: var(--daemon-surface);
border: 1px solid var(--daemon-border);
border-radius: var(--daemon-radius);
padding: var(--daemon-space-xs) var(--daemon-space-sm);
font-size: 0.75rem;
color: var(--daemon-text-muted);
cursor: pointer;
transition: background 0.15s, color 0.15s;
}
.graph-path-clear:hover {
background: var(--daemon-bg-alt);
color: var(--daemon-text);
}
/* Top-positioned graph controls for community toggle */
.graph-controls--top {
position: absolute;
top: var(--daemon-space-md);
right: var(--daemon-space-md);
bottom: auto;
flex-direction: row;
}
.graph-controls__toggle {
display: flex;
align-items: center;
gap: var(--daemon-space-xs);
background: var(--daemon-surface);
border: 1px solid var(--daemon-border);
border-radius: var(--daemon-radius);
padding: var(--daemon-space-xs) var(--daemon-space-sm);
font-size: 0.75rem;
color: var(--daemon-text-muted);
cursor: pointer;
}
.graph-controls__toggle:hover {
background: var(--daemon-bg-alt);
}
.graph-controls__toggle input[type="checkbox"] {
margin: 0;
cursor: pointer;
}
/* ==========================================================================
Temporal Slider (Phase 11 - bi-temporal filtering)
========================================================================== */
/* Temporal slider container */
.graph-temporal {
position: absolute;
bottom: var(--daemon-space-md);
left: var(--daemon-space-md);
right: 80px; /* Leave room for zoom controls */
height: 50px;
background: var(--daemon-surface);
border: 1px solid var(--daemon-border);
border-radius: var(--daemon-radius);
padding: var(--daemon-space-xs);
z-index: 5;
}
.graph-temporal__label {
font-size: 0.7rem;
color: var(--daemon-text-muted);
margin-bottom: var(--daemon-space-xs);
}
.graph-temporal svg {
overflow: visible;
}
.graph-temporal .selection {
fill: var(--daemon-accent);
fill-opacity: 0.3;
stroke: var(--daemon-accent);
}
.graph-temporal .handle {
fill: var(--daemon-accent);
}
.graph-temporal .tick text {
fill: var(--daemon-text-muted);
font-size: 0.65rem;
}
.graph-temporal .domain {
stroke: var(--daemon-border);
}
/* ==========================================================================
Real-Time Update Indicators
========================================================================== */
.daemon-update-badge {
position: fixed;
top: var(--daemon-space-md);
right: var(--daemon-space-md);
display: flex;
align-items: center;
gap: var(--daemon-space-sm);
background: var(--daemon-surface);
border: 1px solid var(--daemon-accent);
border-radius: var(--daemon-radius);
padding: var(--daemon-space-sm) var(--daemon-space-md);
color: var(--daemon-text);
font-size: 0.875rem;
opacity: 0;
transform: translateY(-10px);
transition: opacity 0.2s ease, transform 0.2s ease;
z-index: 100;
}
.daemon-update-badge--visible {
opacity: 1;
transform: translateY(0);
}
.daemon-update-badge__dot {
width: 8px;
height: 8px;
background: var(--daemon-accent);
border-radius: 50%;
}
.daemon-update-badge--visible .daemon-update-badge__dot {
animation: daemon-badge-pulse 2s ease-in-out infinite;
}
@keyframes daemon-badge-pulse {
0%, 100% {
transform: scale(1);
box-shadow: 0 0 0 0 rgba(139, 92, 246, 0.4);
}
50% {
transform: scale(1.1);
box-shadow: 0 0 0 4px rgba(139, 92, 246, 0);
}
}
.daemon-btn--highlight {
animation: daemon-btn-attention 1s ease-in-out 3;
}
@keyframes daemon-btn-attention {
0%, 100% {
box-shadow: none;
}
50% {
box-shadow: 0 0 12px var(--daemon-accent);
}
}
/* Accessibility: Respect reduced motion preference */
@media (prefers-reduced-motion: reduce) {
.daemon-update-badge--visible .daemon-update-badge__dot {
animation: none;
box-shadow: 0 0 8px var(--daemon-accent);
}
.daemon-btn--highlight {
animation: none;
border-color: var(--daemon-accent);
}
}