/* ============================================================ Components — Shared UI elements ============================================================ */ /* ---------- Card ---------- */ .card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--sp-6); margin-bottom: var(--sp-6); } .card-accent { border-left: 3px solid var(--accent); } /* ---------- Pill / Badge ---------- */ .pill { font-family: var(--font-mono); font-size: 0.7rem; padding: 2px 10px; border-radius: var(--radius-pill); display: inline-flex; align-items: center; gap: var(--sp-1); white-space: nowrap; } .pill-amber { background: var(--accent-bg); color: var(--accent); border: 1px solid var(--accent-border); } .pill-cyan { background: var(--cyan-bg); color: var(--cyan); border: 1px solid rgba(34,211,238,0.25); } .pill-green { background: var(--green-bg); color: var(--green); border: 1px solid rgba(34,197,94,0.25); } .pill-red { background: var(--red-bg); color: var(--red); border: 1px solid rgba(239,68,68,0.25); } .pill-purple { background: var(--purple-bg); color: var(--purple); border: 1px solid rgba(167,139,250,0.25); } /* ---------- Data Table ---------- */ .data-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; } .data-table th { font-family: var(--font-mono); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); text-align: left; padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border); white-space: nowrap; } .data-table td { padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--border); color: var(--fg); font-family: var(--font-mono); font-size: 0.8rem; } .data-table tr:hover td { background: var(--surface-raised); } .data-table .mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; } /* ---------- Code Block ---------- */ .code-block { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-md); padding: var(--sp-4) var(--sp-5); overflow-x: auto; margin-bottom: var(--sp-5); } .code-block code { font-family: var(--font-mono); font-size: 0.82rem; line-height: 1.6; color: var(--fg-dim); background: none; padding: 0; } .code-block .kw { color: var(--purple); } .code-block .str { color: var(--green); } .code-block .cm { color: var(--muted); font-style: italic; } .code-block .type { color: var(--cyan); } .code-block .fn { color: var(--accent); } /* ---------- Stat Grid ---------- */ .stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--sp-4); margin-bottom: var(--sp-6); } .stat-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--sp-5); } .stat-value { font-family: var(--font-mono); font-size: 1.6rem; font-weight: 700; color: var(--fg-bright); font-variant-numeric: tabular-nums; } .stat-label { font-size: 0.75rem; color: var(--muted); margin-top: var(--sp-1); text-transform: uppercase; letter-spacing: 0.05em; } /* ---------- Section Header ---------- */ .section-header { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-5); padding-bottom: var(--sp-3); border-bottom: 1px solid var(--border); } .section-header .section-num { font-family: var(--font-mono); font-size: 0.7rem; color: var(--accent); background: var(--accent-bg); padding: 2px 8px; border-radius: var(--radius-pill); } /* ---------- Roadmap Phase ---------- */ .phase-item { display: flex; gap: var(--sp-4); margin-bottom: var(--sp-5); } .phase-marker { display: flex; flex-direction: column; align-items: center; min-width: 40px; } .phase-dot { width: 12px; height: 12px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px rgba(240, 160, 48, 0.3); } .phase-dot.future { background: var(--border-light); box-shadow: none; } .phase-line { flex: 1; width: 2px; background: var(--border); margin-top: var(--sp-1); } .phase-content { flex: 1; } /* ---------- Demo Container ---------- */ .demo-container { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; margin-bottom: var(--sp-6); } /* Inner panels inside demos that need independent scrolling */ .demo-scroll-panel { overflow-y: auto; overscroll-behavior: contain; flex-shrink: 0; } .demo-toolbar { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-3) var(--sp-4); background: var(--surface-raised); border-bottom: 1px solid var(--border); font-size: 0.8rem; } .demo-toolbar .demo-title { font-family: var(--font-mono); font-size: 0.75rem; color: var(--accent); text-transform: uppercase; letter-spacing: 0.05em; } .demo-canvas-wrap { position: relative; background: var(--bg); min-height: 400px; } .demo-canvas-wrap canvas { display: block; width: 100%; height: 100%; } .demo-sidebar { width: 280px; background: var(--surface); border-left: 1px solid var(--border); padding: var(--sp-4); overflow-y: auto; font-size: 0.8rem; } /* ---------- Button ---------- */ .btn { font-family: var(--font-body); font-size: 0.8rem; font-weight: 500; padding: var(--sp-2) var(--sp-4); border-radius: var(--radius-md); border: 1px solid var(--border); background: var(--surface-raised); color: var(--fg); cursor: pointer; transition: all var(--transition-fast); display: inline-flex; align-items: center; gap: var(--sp-2); } .btn:hover { border-color: var(--border-light); background: var(--surface-hover); } .btn-primary { background: var(--accent); color: var(--bg); border-color: var(--accent); font-weight: 600; } .btn-primary:hover { background: var(--accent-hover); } .btn-sm { padding: var(--sp-1) var(--sp-3); font-size: 0.75rem; } .btn-danger { border-color: var(--red-dim); color: var(--red); } .btn-danger:hover { background: var(--red-bg); } /* ---------- Tags / Keywords ---------- */ .tag-list { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-bottom: var(--sp-4); } /* ---------- Alert / Callout ---------- */ .callout { padding: var(--sp-4) var(--sp-5); border-radius: var(--radius-md); margin-bottom: var(--sp-5); font-size: 0.85rem; line-height: 1.5; } .callout-info { background: var(--cyan-bg); border: 1px solid rgba(34,211,238,0.2); color: var(--cyan); } .callout-warn { background: var(--accent-bg); border: 1px solid var(--accent-border); color: var(--accent); } .callout-danger { background: var(--red-bg); border: 1px solid rgba(239,68,68,0.2); color: var(--red); } /* ---------- Grid Layouts ---------- */ .grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); } .grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-5); } @media (max-width: 900px) { .grid-2, .grid-3 { grid-template-columns: 1fr; } } /* ---------- Animations ---------- */ @keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } } /* ---------- Progress Bar ---------- */ .progress-bar { height: 4px; background: var(--border); border-radius: var(--radius-pill); overflow: hidden; } .progress-bar .fill { height: 100%; border-radius: var(--radius-pill); transition: width var(--transition-base); }