phase-4: scss upgrade

This commit is contained in:
Kazuma
2026-06-04 15:49:49 -04:00
parent 0a0a368b87
commit 104ed81b9f
18 changed files with 1275 additions and 819 deletions
+72 -311
View File
@@ -370,116 +370,53 @@
{/if}
<style>
/* ── Page ──────────────────────────────────────────────────────── */
/* ── Page ── unique to this route ──────────────────────────────── */
.page { max-width: 1400px; padding-bottom: 60px; }
/* ── Toolbar ────────────────────────────────────────────────────── */
.toolbar { margin-bottom: 20px; display: flex; flex-direction: column; gap: 10px; }
.toolbar-top {
display: flex;
align-items: center;
gap: 8px;
}
.search-row {
display: flex;
gap: 8px;
align-items: center;
}
.toolbar-top { display: flex; align-items: center; gap: 8px; }
.search-row { display: flex; gap: 8px; align-items: center; }
input {
flex: 1;
min-width: 0;
background: #1e293b;
border: 1px solid #2d3f55;
border-radius: 8px;
color: #e2e8f0;
padding: 10px 14px;
font-size: 13px;
background: var(--bg-card);
border: 1px solid var(--border-input);
border-radius: var(--radius-md);
color: var(--text-secondary);
padding: 10px var(--space-lg);
font-size: var(--fs-md);
font-family: 'SF Mono', 'Fira Code', monospace;
letter-spacing: 0.02em;
outline: none;
transition: border-color 0.15s;
transition: border-color var(--transition);
}
input:focus { border-color: #3b82f6; box-shadow: 0 0 0 2px #3b82f620; }
input:focus { border-color: var(--blue); box-shadow: 0 0 0 2px #3b82f620; }
button {
padding: 10px 18px;
border-radius: 8px;
font-size: 13px;
font-weight: 600;
cursor: pointer;
border: none;
white-space: nowrap;
transition: background 0.15s, opacity 0.15s;
}
button:disabled { opacity: 0.45; cursor: default; }
/* Primary catalyst button */
.btn-catalyst {
background: #2563eb;
color: #fff;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 6px;
padding: 10px 20px;
}
.btn-catalyst:hover:not(:disabled) { background: #1d4ed8; }
/* Secondary search toggle */
/* btn-search-toggle — page-specific ghost variant */
.btn-search-toggle {
background: #1e293b;
color: #64748b;
border: 1px solid #2d3f55;
background: var(--bg-card);
color: var(--text-dim);
border: 1px solid var(--border-input);
font-size: 12px;
padding: 8px 14px;
padding: 8px var(--space-lg);
}
.btn-search-toggle:hover { background: #263347; color: #94a3b8; }
/* Screen button inside the expanded search row */
.btn-screen {
background: #1e3a5f;
color: #60a5fa;
border: 1px solid #1e3a5f;
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 80px;
}
.btn-screen:hover:not(:disabled) { background: #163356; }
.btn-search-toggle:hover { background: #263347; color: var(--text-muted); }
.screened-at {
margin-left: auto;
font-size: 11px;
color: #475569;
}
.loading-area {
display: flex;
justify-content: center;
align-items: center;
padding: 80px 0;
}
.error-banner {
background: #450a0a55;
border: 1px solid #7f1d1d;
border-radius: 8px;
color: #f87171;
padding: 10px 14px;
margin-bottom: 16px;
font-size: 13px;
font-size: var(--fs-sm);
color: var(--text-dimmer);
}
/* ── Market Context Strip ───────────────────────────────────────── */
.ctx-strip {
display: flex;
gap: 1px;
background: #1e293b;
border: 1px solid #1e293b;
border-radius: 10px;
background: var(--border);
border: 1px solid var(--border);
border-radius: var(--radius-lg);
overflow: hidden;
margin-bottom: 20px;
}
@@ -487,210 +424,49 @@
.ctx-chip {
flex: 1;
min-width: 70px;
background: #0f1117;
padding: 10px 14px;
background: var(--bg-base);
padding: 10px var(--space-lg);
display: flex;
flex-direction: column;
gap: 3px;
}
.ctx-label {
font-size: 9px;
font-size: var(--fs-2xs);
font-weight: 700;
letter-spacing: 0.08em;
text-transform: uppercase;
color: #475569;
color: var(--text-dimmer);
}
.ctx-val {
font-size: 15px;
font-size: var(--fs-lg);
font-weight: 700;
color: #f1f5f9;
color: var(--text-primary);
font-variant-numeric: tabular-nums;
}
.ctx-regime[data-regime="HIGH"] { color: #f87171; }
.ctx-regime[data-regime="NORMAL"] { color: #94a3b8; }
.ctx-regime[data-regime="LOW"] { color: #4ade80; }
.ctx-regime[data-regime="HIGH"] { color: var(--red); }
.ctx-regime[data-regime="NORMAL"] { color: var(--text-muted); }
.ctx-regime[data-regime="LOW"] { color: var(--green); }
/* ── Section ────────────────────────────────────────────────────── */
.section {
background: #0d1117;
border: 1px solid #1e293b;
border-radius: 10px;
margin-bottom: 16px;
overflow: hidden;
}
.section-header {
display: flex;
align-items: center;
gap: 10px;
padding: 14px 18px 12px;
border-bottom: 1px solid #1e293b;
background: #111827;
}
h2 {
font-size: 11px;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.08em;
color: #64748b;
margin: 0;
}
.count {
font-size: 10px;
font-weight: 600;
color: #334155;
background: #1e293b;
padding: 2px 7px;
border-radius: 20px;
}
/* ── Mode Tabs ──────────────────────────────────────────────────── */
.mode-tabs {
display: flex;
gap: 4px;
margin-left: auto;
}
.mode-tabs button {
background: transparent;
color: #475569;
border: 1px solid #1e293b;
font-size: 11px;
padding: 4px 12px;
border-radius: 6px;
}
.mode-tabs button.active {
background: #1e3a5f;
color: #60a5fa;
border-color: #1e3a5f;
}
/* ── Table ──────────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
table { width: max-content; min-width: 100%; border-collapse: collapse; }
thead th {
text-align: left;
padding: 8px 14px;
font-size: 10px;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.06em;
color: #334155;
border-bottom: 1px solid #1e293b;
white-space: nowrap;
background: #111827;
}
tbody tr { border-bottom: 1px solid #161f2e; }
tbody tr:hover { background: #131c2b; }
tbody td {
padding: 10px 14px;
vertical-align: middle;
white-space: nowrap;
font-size: 13px;
}
/* Sticky ticker column */
.col-ticker,
tbody td:first-child {
position: sticky;
left: 0;
background: inherit;
z-index: 1;
}
thead .col-ticker { background: #111827; }
tbody td:first-child { background: #0d1117; }
tbody tr:hover td:first-child { background: #131c2b; }
.ticker {
font-weight: 700;
font-size: 13px;
color: #f1f5f9;
letter-spacing: 0.02em;
}
.num {
color: #64748b;
font-variant-numeric: tabular-nums;
font-size: 12px;
}
/* Score cell: truncates gate failure text, shown in full via title tooltip */
/* ── Score cell ─────────────────────────────────────────────────── */
.score-cell {
color: #64748b;
font-size: 11px;
color: var(--text-dim);
font-size: var(--fs-sm);
max-width: 140px;
overflow: hidden;
text-overflow: ellipsis;
}
/* ── Verdict Pill ───────────────────────────────────────────────── */
.verdict-pill {
display: inline-block;
padding: 3px 10px;
border-radius: 20px;
font-size: 11px;
font-weight: 700;
letter-spacing: 0.02em;
}
.verdict-pill.green { background: #14532d33; color: #4ade80; }
.verdict-pill.yellow { background: #71350033; color: #facc15; }
.verdict-pill.red { background: #450a0a33; color: #f87171; }
/* ── Tags ───────────────────────────────────────────────────────── */
.tag {
display: inline-block;
background: #1e293b;
color: #64748b;
padding: 2px 8px;
border-radius: 4px;
font-size: 10px;
font-weight: 600;
letter-spacing: 0.04em;
text-transform: uppercase;
}
.tag.sm { font-size: 10px; padding: 1px 6px; }
/* ── Risk Flags ─────────────────────────────────────────────────── */
/* ── Risk flags ─────────────────────────────────────────────────── */
.flags { display: flex; flex-direction: column; gap: 2px; }
.flag { color: #fb923c; font-size: 11px; }
.flag { color: var(--orange); font-size: var(--fs-sm); }
/* ── Errors ─────────────────────────────────────────────────────── */
.error-list { padding: 12px 18px; display: flex; flex-direction: column; gap: 6px; }
.error-item { color: #64748b; font-size: 12px; }
.error-item .ticker { color: #f87171; font-weight: 700; margin-right: 8px; }
/* ── Analyze button ─────────────────────────────────────────────── */
.btn-analyze {
background: transparent;
color: #7c93b0;
border: 1px solid #1e293b;
font-size: 11px;
font-weight: 600;
letter-spacing: 0.04em;
padding: 4px 12px;
border-radius: 6px;
display: inline-flex;
align-items: center;
gap: 5px;
margin-left: 8px;
white-space: nowrap;
transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.btn-analyze:hover:not(:disabled) {
background: #0f2240;
color: #93c5fd;
border-color: #1e3a5f;
}
.btn-analyze:disabled { opacity: 0.4; cursor: default; }
/* ── Error list ─────────────────────────────────────────────────── */
.error-list { padding: 12px var(--space-xl); display: flex; flex-direction: column; gap: 6px; }
.error-item { color: var(--text-dim); font-size: 12px; }
.error-item :global(.ticker) { color: var(--red); font-weight: 700; margin-right: 8px; }
/* ── LLM Sidebar ────────────────────────────────────────────────── */
.sidebar-backdrop {
@@ -702,12 +478,10 @@
.sidebar {
position: fixed;
top: 0;
right: 0;
bottom: 0;
top: 0; right: 0; bottom: 0;
width: 380px;
background: #0d1117;
border-left: 1px solid #1e3a5f;
background: var(--bg-surface);
border-left: 1px solid var(--blue-surface);
z-index: 101;
display: flex;
flex-direction: column;
@@ -718,9 +492,9 @@
display: flex;
align-items: center;
justify-content: space-between;
padding: 16px 18px;
border-bottom: 1px solid #1e293b;
background: #0d1e30;
padding: 16px var(--space-xl);
border-bottom: 1px solid var(--border);
background: var(--blue-badge);
flex-shrink: 0;
}
@@ -728,36 +502,36 @@
display: flex;
align-items: center;
gap: 8px;
font-size: 13px;
font-size: var(--fs-md);
font-weight: 700;
color: #e2e8f0;
color: var(--text-secondary);
}
.sidebar-type {
font-size: 10px;
font-size: var(--fs-xs);
font-weight: 700;
letter-spacing: 0.06em;
background: #1e3a5f;
color: #60a5fa;
background: var(--blue-surface);
color: var(--blue-muted);
padding: 2px 8px;
border-radius: 20px;
border-radius: var(--radius-pill);
}
.sidebar-close {
background: none;
border: none;
color: #475569;
color: var(--text-dimmer);
font-size: 14px;
padding: 4px 8px;
cursor: pointer;
border-radius: 4px;
border-radius: var(--radius-xs);
}
.sidebar-close:hover { color: #94a3b8; background: #1e293b; }
.sidebar-close:hover { color: var(--text-muted); background: var(--bg-card); }
.sidebar-body {
flex: 1;
overflow-y: auto;
padding: 18px;
padding: var(--space-xl);
display: flex;
flex-direction: column;
gap: 16px;
@@ -772,30 +546,30 @@
}
.sidebar-error {
color: #f87171;
background: #450a0a33;
border-radius: 8px;
padding: 12px 14px;
font-size: 13px;
color: var(--red);
background: var(--red-bg);
border-radius: var(--radius-md);
padding: 12px var(--space-lg);
font-size: var(--fs-md);
}
.sb-sentiment-row { display: flex; align-items: center; gap: 8px; }
.sb-summary {
font-size: 13px;
color: #94a3b8;
font-size: var(--fs-md);
color: var(--text-muted);
line-height: 1.6;
border-left: 3px solid #1e3a5f;
border-left: 3px solid var(--blue-surface);
padding-left: 12px;
margin: 0;
}
.sb-sub {
font-size: 10px;
font-size: var(--fs-xs);
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.08em;
color: #475569;
color: var(--text-dimmer);
margin: 0;
}
@@ -806,33 +580,20 @@
flex-direction: column;
gap: 3px;
padding: 10px 12px;
background: #111827;
border-radius: 6px;
border: 1px solid #1e293b;
background: var(--bg-elevated);
border-radius: var(--radius-sm);
border: 1px solid var(--border);
}
.sb-name {
font-size: 12px;
font-weight: 600;
color: #e2e8f0;
color: var(--text-secondary);
}
.sb-reason {
font-size: 11px;
color: #64748b;
font-size: var(--fs-sm);
color: var(--text-dim);
line-height: 1.4;
}
/* ── Sidebar sentiment pill ─────────────────────────────────────── */
.sentiment-pill {
font-size: 10px;
font-weight: 700;
letter-spacing: 0.06em;
padding: 3px 10px;
border-radius: 20px;
}
.sentiment-pill[data-sentiment="BULLISH"] { background: #14532d33; color: #4ade80; }
.sentiment-pill[data-sentiment="BEARISH"] { background: #450a0a33; color: #f87171; }
.sentiment-pill[data-sentiment="NEUTRAL"] { background: #1e293b; color: #94a3b8; }
</style>