/* FinSight Live — Bloomberg-style terminal theme
   Black canvas, amber primary, monospace, dense panels, sharp borders. */

:root, :root[data-theme="dark"] {
  --bg:         #000000;
  --bg-1:       #0a0a0a;
  --bg-2:       #111111;
  --bg-3:       #161616;
  --panel:      #0d0d0d;
  --panel-2:    #131313;
  --border:     #2a2a2a;
  --border-2:   #3a3a3a;
  --amber:      #ff9c00;
  --amber-dim:  #b86d00;
  --amber-soft: #5a3700;
  --green:      #00e676;
  --red:        #ff5252;
  --cyan:       #45d0ff;
  --magenta:    #ff5eae;
  --white:      #f0f0f0;
  --text:       #e8e8e8;
  --dim:        #888888;
  --dimmer:     #555555;
  --mono: "IBM Plex Mono", "JetBrains Mono", "Roboto Mono", "Consolas", "Cascadia Mono", "Courier New", monospace;
}

:root[data-theme="light"] {
  --bg:         #f4f1ea;
  --bg-1:       #ece7da;
  --bg-2:       #e2dcca;
  --bg-3:       #d8d0bb;
  --panel:      #fbf8f1;
  --panel-2:    #f0ebde;
  --border:     #c9c0a8;
  --border-2:   #b3a988;
  --amber:      #b35c00;
  --amber-dim:  #7a3f00;
  --amber-soft: #f1d8a8;
  --green:      #1f8a4d;
  --red:        #c0392b;
  --cyan:       #0078a8;
  --magenta:    #b8367a;
  --white:      #1a1a1a;
  --text:       #1f1f1f;
  --dim:        #5f5f5f;
  --dimmer:     #888888;
  --mono: "IBM Plex Mono", "JetBrains Mono", "Roboto Mono", "Consolas", "Cascadia Mono", "Courier New", monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); }
body {
  font-family: var(--mono);
  color: var(--text);
  font-size: 13px;
  line-height: 1.4;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  overflow-x: hidden;
}

a { color: var(--amber); text-decoration: none; }
a:hover { text-decoration: underline; }

.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--amber); color: var(--bg); padding: 6px 10px;
  font-weight: 700;
}
.skip-link:focus { left: 6px; top: 6px; z-index: 100; }

.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
.muted { color: var(--dim); }
.amber { color: var(--amber); }
.green { color: var(--green); }
.red   { color: var(--red); }
.cyan  { color: var(--cyan); }

/* ---------- TICKER TAPE ---------- */
.ticker {
  background: var(--bg-1);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
  height: 26px;
  position: relative;
}
.ticker-track {
  display: inline-flex;
  white-space: nowrap;
  animation: tickerScroll 60s linear infinite;
  line-height: 26px;
  font-size: 12px;
  padding-left: 100%;
}
.ticker-item { padding: 0 18px; color: var(--white); }
.ticker-item .sym { color: var(--amber); font-weight: 700; margin-right: 6px; }
.ticker-item .val { color: var(--white); margin-right: 4px; }
.ticker-item .chg.up   { color: var(--green); }
.ticker-item .chg.down { color: var(--red); }
.ticker-item .sep      { color: var(--dimmer); margin: 0 8px; }
@keyframes tickerScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}

/* ---------- TOP TERMINAL BAR ---------- */
.terminal-bar {
  background: var(--bg-1);
  border-bottom: 1px solid var(--border);
  padding: 6px 14px;
  display: flex; align-items: center; gap: 14px;
}
.terminal-bar .brand {
  display: flex; align-items: center; gap: 10px;
  color: var(--amber); font-weight: 700; letter-spacing: 1px;
}
.terminal-bar .brand .dot {
  width: 10px; height: 10px; background: var(--red);
  border-radius: 50%;
  display: inline-block; box-shadow: 0 0 8px var(--red);
  animation: livePulse 1.5s ease-in-out infinite;
  will-change: transform, opacity;
}
@keyframes livePulse {
  0%, 100% { transform: scale(1);   opacity: 1;   }
  50%      { transform: scale(1.4); opacity: 0.4; }
}
.terminal-bar .brand .sub {
  color: var(--dim); font-weight: 400; letter-spacing: 0;
  font-size: 11px; margin-left: 4px;
}
.terminal-bar .clock {
  margin-left: auto; color: var(--white); font-size: 12px;
}
.terminal-bar .clock .lbl { color: var(--dim); margin-right: 6px; }

/* theme toggle button */
.theme-toggle {
  background: transparent; border: 1px solid var(--border-2);
  color: var(--amber); padding: 2px 8px;
  font-family: var(--mono); font-size: 11px;
  cursor: pointer; letter-spacing: 1px; font-weight: 500;
}
.theme-toggle:hover { background: var(--amber-soft); border-color: var(--amber); }
.theme-toggle:focus-visible { outline: 1px solid var(--amber); outline-offset: 1px; }

/* function key row */
.fkeys {
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
  display: flex; flex-wrap: wrap; gap: 0;
}
.fkey {
  background: transparent; border: none;
  border-right: 1px solid var(--border);
  color: var(--text);
  padding: 7px 14px;
  font-family: var(--mono); font-size: 12px; cursor: pointer;
  display: flex; align-items: center; gap: 6px;
  text-decoration: none;
}
.fkey .k { color: var(--amber); font-weight: 700; }
.fkey:hover { background: var(--amber-soft); color: var(--amber); }
.fkey.active { background: var(--amber); color: var(--bg); font-weight: 700; }
.fkey.active .k { color: var(--bg); }
.fkey:focus-visible { outline: 1px solid var(--amber); outline-offset: -1px; }
.fkey.primary {
  margin-left: auto;
  background: var(--amber); color: var(--bg); font-weight: 700;
}
.fkey.primary .k { color: var(--bg); }
.fkey.primary:hover { background: var(--white); }

/* command bar */
.cmd-bar {
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  padding: 6px 14px;
  display: flex; align-items: center; gap: 10px;
}
.cmd-bar .prompt { color: var(--amber); font-weight: 700; }
.cmd-bar input {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--white);
  font-family: var(--mono); font-size: 13px;
  outline: none;
  caret-color: var(--amber);
}
.cmd-bar input::placeholder { color: var(--dimmer); }
.cmd-bar .hint { color: var(--dim); font-size: 11px; }
.cursor {
  display: inline-block; width: 8px; height: 14px;
  background: var(--amber); vertical-align: middle;
  animation: blink 1s steps(2, end) infinite;
}
@keyframes blink { 0%, 50% { opacity: 1; } 50.01%, 100% { opacity: 0; } }

/* ---------- MAIN ---------- */
main {
  padding: 10px 12px 50px;
  max-width: 1600px;
  margin: 0 auto;
}

/* PANEL */
.panel {
  background: var(--panel);
  border: 1px solid var(--border);
  margin-bottom: 10px;
}
.panel-head {
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
  padding: 6px 12px;
  display: flex; align-items: center; gap: 12px;
  font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase;
}
.panel-head .title { color: var(--amber); font-weight: 700; }
.panel-head .sub   { color: var(--dim); font-weight: 400; }
.panel-head .right { margin-left: auto; display: flex; gap: 8px; align-items: center; }
.panel-body { padding: 12px; }
.panel-body.tight { padding: 0; }

/* GRID HELPERS */
.row-grid { display: grid; gap: 10px; }
.cols-2 { grid-template-columns: 1.4fr 1fr; }
.cols-3 { grid-template-columns: 2fr 1fr 1fr; }
@media (max-width: 900px) {
  .cols-2, .cols-3 { grid-template-columns: 1fr; }
}

/* HERO STRIP */
.hero {
  background: linear-gradient(90deg, var(--panel) 0%, var(--bg-2) 100%);
  border: 1px solid var(--border);
  padding: 12px 14px;
  margin-bottom: 10px;
  display: flex; gap: 18px; align-items: center; flex-wrap: wrap;
}
.hero .label {
  color: var(--amber); font-weight: 700; letter-spacing: 1.5px;
  font-size: 11px; text-transform: uppercase;
  padding: 4px 8px; border: 1px solid var(--amber-dim);
}
.hero .summary {
  color: var(--white); font-size: 14px; flex: 1; min-width: 280px;
}
.hero .chips { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 8px;
  font-size: 11px; font-weight: 700;
  border: 1px solid var(--border-2);
  background: var(--bg-1);
  letter-spacing: 0.5px;
}
.chip.good { color: var(--green); border-color: rgba(0,230,118,0.4); }
.chip.warn { color: var(--amber); border-color: var(--amber-dim); }
.chip.info { color: var(--cyan);  border-color: rgba(69,208,255,0.4); }
.chip.bad  { color: var(--red);   border-color: rgba(255,82,82,0.4); }

/* KPI TILES */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}
@media (max-width: 1200px) { .kpi-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px)  { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }

.kpi {
  background: var(--panel);
  padding: 10px 12px;
  border-left: 2px solid var(--amber-dim);
}
.kpi.good { border-left-color: var(--green); }
.kpi.warn { border-left-color: var(--amber); }
.kpi.bad  { border-left-color: var(--red); }
.kpi.info { border-left-color: var(--cyan); }

.kpi .k-label {
  color: var(--dim);
  font-size: 10px;
  letter-spacing: 1.5px; text-transform: uppercase;
  display: flex; justify-content: space-between; align-items: center;
}
.kpi .k-label .badge {
  color: var(--amber); font-size: 9px;
}
.kpi .k-value {
  color: var(--white); font-size: 22px; font-weight: 700;
  margin: 4px 0 2px;
  font-variant-numeric: tabular-nums;
}
.kpi .k-delta {
  font-size: 12px; font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.kpi .k-delta.up   { color: var(--green); }
.kpi .k-delta.down { color: var(--red); }
.kpi .k-delta.flat { color: var(--dim); }
.kpi .k-note { color: var(--dim); font-size: 11px; margin-top: 4px; }

/* CHART (SVG line) */
.chart-wrap { position: relative; height: 240px; padding: 6px 6px 0; }
.chart-svg { width: 100%; height: 100%; display: block; }
.chart-grid line { stroke: var(--border); stroke-width: 1; }
.chart-axis text { fill: var(--dim); font-family: var(--mono); font-size: 10px; }
.chart-area  { fill: rgba(255,156,0,0.10); }
.chart-line  { fill: none; stroke: var(--amber); stroke-width: 2; }
.chart-line.green  { stroke: var(--green); }
.chart-line.cyan   { stroke: var(--cyan); }
.chart-area.green { fill: rgba(0,230,118,0.10); }
.chart-area.cyan  { fill: rgba(69,208,255,0.10); }
.chart-dot   { fill: var(--amber); }
.chart-dot.green { fill: var(--green); }
.chart-dot.cyan  { fill: var(--cyan); }
.chart-stat {
  position: absolute; top: 8px; right: 12px;
  display: flex; gap: 14px;
  font-size: 11px;
}
.chart-stat span { color: var(--dim); }
.chart-stat b { color: var(--white); font-weight: 700; margin-left: 4px; }

/* TOGGLE GROUP */
.toggle-group { display: inline-flex; border: 1px solid var(--border-2); }
.toggle {
  background: var(--bg-1); border: none; color: var(--dim);
  padding: 4px 10px; font-family: var(--mono); font-size: 11px;
  cursor: pointer; letter-spacing: 1px; text-transform: uppercase;
  border-right: 1px solid var(--border-2);
}
.toggle:last-child { border-right: none; }
.toggle:hover { color: var(--amber); }
.toggle.active { background: var(--amber); color: var(--bg); font-weight: 700; }
.toggle:focus-visible { outline: 1px solid var(--amber); outline-offset: -1px; }

/* INPUTS */
.input, select, textarea {
  background: var(--bg);
  border: 1px solid var(--border-2);
  color: var(--white);
  font-family: var(--mono); font-size: 12px;
  padding: 6px 10px;
  min-width: 160px;
}
.input:focus, select:focus, textarea:focus {
  outline: none; border-color: var(--amber);
}
.input::placeholder { color: var(--dimmer); }
select option { background: var(--bg); color: var(--white); }

/* BUTTONS */
.btn {
  background: var(--bg-1);
  border: 1px solid var(--border-2);
  color: var(--text);
  padding: 6px 12px;
  font-family: var(--mono); font-size: 12px;
  cursor: pointer;
  letter-spacing: 0.5px;
  display: inline-flex; align-items: center; gap: 6px;
}
.btn:hover { border-color: var(--amber); color: var(--amber); }
.btn:focus-visible { outline: 1px solid var(--amber); outline-offset: 1px; }
.btn.primary {
  background: var(--amber); color: var(--bg); border-color: var(--amber); font-weight: 700;
}
.btn.primary:hover { background: var(--white); border-color: var(--white); color: var(--bg); }
.btn.danger { border-color: rgba(255,82,82,0.4); color: var(--red); }
.btn.danger:hover { background: rgba(255,82,82,0.1); color: var(--red); border-color: var(--red); }
.btn.sm { padding: 3px 8px; font-size: 11px; }
.btn.success { background: var(--green); color: var(--bg); border-color: var(--green); font-weight: 700; }

/* CONTROLS */
.controls { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }

/* TABLE (DATA DESK) */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--mono); font-size: 12px;
}
.data-table th, .data-table td {
  padding: 7px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  font-variant-numeric: tabular-nums;
}
.data-table th {
  background: var(--bg-2);
  color: var(--amber); font-weight: 700;
  font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase;
}
.data-table tbody tr:hover { background: var(--bg-2); }
.data-table td.num { text-align: right; }

.status-pill {
  display: inline-block; padding: 1px 7px; font-size: 10px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  border: 1px solid;
}
.status-pill.on-track { color: var(--green); border-color: var(--green); }
.status-pill.watch    { color: var(--amber); border-color: var(--amber); }
.status-pill.at-risk  { color: var(--red);   border-color: var(--red); }

/* PRODUCT TILES */
.prod-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
}
@media (max-width: 900px) { .prod-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .prod-grid { grid-template-columns: 1fr; } }
.prod {
  background: var(--panel);
  padding: 12px;
}
.prod h4 {
  margin: 0 0 8px; font-size: 12px; color: var(--amber);
  letter-spacing: 1px; text-transform: uppercase;
}
.prod .row { display: flex; justify-content: space-between; font-size: 12px; margin-bottom: 4px; }
.prod .row .l { color: var(--dim); }
.prod .row .v { color: var(--white); font-variant-numeric: tabular-nums; }
.prod .bar {
  margin-top: 8px; height: 6px; background: var(--bg);
  border: 1px solid var(--border);
}
.prod .bar > span {
  display: block; height: 100%;
  background: var(--amber);
}

/* RISK LIST */
.risk-list { list-style: none; margin: 0; padding: 0; }
.risk-item {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 0;
  border-bottom: 1px dashed var(--border);
  font-size: 12px;
}
.risk-item:last-child { border-bottom: none; }
.risk-item .risk-text { flex: 1; color: var(--white); }
.risk-item.reviewed .risk-text { color: var(--dimmer); text-decoration: line-through; }
.sev {
  display: inline-flex; padding: 2px 8px; font-size: 10px; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
  border: 1px solid; min-width: 70px; justify-content: center;
}
.sev.low    { color: var(--cyan);  border-color: var(--cyan); }
.sev.medium { color: var(--amber); border-color: var(--amber); }
.sev.high   { color: var(--red);   border-color: var(--red); }

/* INSIGHTS */
.insight-list { margin: 0; padding-left: 18px; }
.insight-list li { margin-bottom: 8px; line-height: 1.6; color: var(--text); }
.insight-list li::marker { color: var(--amber); }

/* RELEASE NOTES */
.rel-list { list-style: none; margin: 0; padding: 0; font-size: 12px; }
.rel-list li {
  padding: 6px 0; border-bottom: 1px dashed var(--border);
  display: flex; gap: 12px; align-items: center;
}
.rel-list li:last-child { border-bottom: none; }
.rel-list .ver {
  color: var(--amber); font-weight: 700; min-width: 50px;
  border: 1px solid var(--amber-dim); text-align: center;
  padding: 1px 4px; font-size: 11px;
}

/* STATUS BAR */
.status-bar {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--amber);
  color: var(--bg);
  font-family: var(--mono); font-size: 11px; font-weight: 700;
  padding: 4px 14px;
  display: flex; gap: 18px; align-items: center;
  border-top: 1px solid var(--bg);
  letter-spacing: 1px;
  z-index: 60;
}
.status-bar .seg { display: flex; gap: 6px; align-items: center; }
.status-bar .seg .l { opacity: 0.7; }
.status-bar .seg.right { margin-left: auto; }

/* REQUESTS PAGE */
.page-head {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-1);
}
.page-head h2 {
  margin: 0; color: var(--amber);
  font-size: 14px; letter-spacing: 1.5px; text-transform: uppercase;
}
.page-head p { margin: 4px 0 0; color: var(--dim); font-size: 12px; }
.page-wrap { padding: 10px 12px 60px; max-width: 1600px; margin: 0 auto; }

.notice {
  border: 1px solid var(--cyan); color: var(--cyan);
  background: rgba(69,208,255,0.06);
  padding: 8px 12px;
  font-size: 12px; margin-bottom: 10px;
}
.notice.warn { border-color: var(--amber); color: var(--amber); background: rgba(255,156,0,0.06); }
.notice.good { border-color: var(--green); color: var(--green); background: rgba(0,230,118,0.06); }
.notice.err  { border-color: var(--red);   color: var(--red);   background: rgba(255,82,82,0.06); }

.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.form-row  { display: flex; flex-direction: column; gap: 4px; }
.form-row.full { grid-column: 1 / -1; }
.form-row label {
  font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--amber);
}
.form-row .input, .form-row select, .form-row textarea {
  width: 100%;
  background: var(--bg);
  border: 1px solid var(--border-2);
  color: var(--white);
  padding: 7px 10px;
  font-family: var(--mono); font-size: 13px;
}
.form-row textarea { resize: vertical; min-height: 70px; }
.form-row .input:focus, .form-row select:focus, .form-row textarea:focus {
  outline: none; border-color: var(--amber);
}

.checkbox-row {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--text);
  border: 1px solid var(--border); padding: 8px 10px; background: var(--bg-1);
}
.checkbox-row input[type="checkbox"] {
  width: 16px; height: 16px; accent-color: var(--amber);
}

.form-actions {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px;
  padding-top: 12px; border-top: 1px dashed var(--border);
}
.error-msg { color: var(--red); font-size: 12px; margin-top: 8px; min-height: 16px; }

.issue-output { margin-top: 14px; display: none; }
.issue-output.visible { display: block; }
.issue-output textarea {
  width: 100%; min-height: 220px;
  background: var(--bg);
  border: 1px solid var(--border-2);
  color: var(--green);
  padding: 10px;
  font-family: var(--mono); font-size: 12px;
}

/* QUEUE */
.queue-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1px;
  background: var(--border); border: 1px solid var(--border);
}
.queue-card {
  background: var(--panel);
  padding: 12px;
  display: flex; flex-direction: column; gap: 6px;
}
.queue-card.sample {
  background: var(--bg-1);
  border-left: 2px dashed var(--amber-dim);
}
.queue-card .qhead {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 6px;
}
.queue-card h4 {
  margin: 0; font-size: 13px; color: var(--white); flex: 1;
}
.queue-card .qmeta {
  font-size: 11px; color: var(--dim);
  display: flex; flex-wrap: wrap; gap: 8px;
}
.queue-card .qactions { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 4px; }
.tag {
  display: inline-flex; padding: 1px 6px;
  font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  border: 1px solid var(--border-2); color: var(--dim);
}
.tag.priority-Low    { color: var(--cyan);  border-color: var(--cyan); }
.tag.priority-Medium { color: var(--amber); border-color: var(--amber); }
.tag.priority-High   { color: var(--red);   border-color: var(--red); }
.tag.type-Feature       { color: var(--amber);   border-color: var(--amber); }
.tag.type-Bug           { color: var(--red);     border-color: var(--red); }
.tag.type-Performance   { color: var(--green);   border-color: var(--green); }
.tag.type-Accessibility { color: var(--cyan);    border-color: var(--cyan); }
.tag.gh-synced { color: var(--green); border-color: var(--green); }

.queue-empty {
  text-align: center; padding: 22px; color: var(--dim); font-size: 12px;
  background: var(--panel);
}

/* token panel */
.token-panel {
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 12px;
  margin-bottom: 10px;
}
.token-panel summary {
  cursor: pointer;
  color: var(--amber);
  font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase;
  font-weight: 700;
  outline: none;
}
.token-panel summary::-webkit-details-marker { color: var(--amber); }
.token-panel .body { margin-top: 10px; display: flex; flex-direction: column; gap: 8px; font-size: 12px; }
.token-panel .row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.token-panel .row .input { flex: 1; min-width: 200px; }
.token-panel .status {
  font-size: 11px; padding: 4px 8px; border: 1px solid;
  letter-spacing: 1px; text-transform: uppercase; font-weight: 700;
}
.token-panel .status.connected { color: var(--green); border-color: var(--green); }
.token-panel .status.disconnected { color: var(--dim); border-color: var(--border-2); }
.token-panel .help {
  color: var(--dim); font-size: 11px; line-height: 1.5;
}
.token-panel .help code {
  color: var(--amber); background: var(--bg); padding: 1px 5px; border: 1px solid var(--border);
}

/* TOAST */
.toast {
  position: fixed; bottom: 30px; right: 14px; z-index: 80;
  background: var(--bg-1); color: var(--white);
  border: 1px solid var(--amber);
  padding: 10px 14px; font-size: 12px;
  font-family: var(--mono);
  max-width: 360px;
  box-shadow: 0 0 0 1px var(--bg);
}
.toast.good { border-color: var(--green); }
.toast.err  { border-color: var(--red); }

/* ---------- LIVE SIMULATION (issue #10) ---------- */
.ticker-item .val {
  display: inline-block;
  padding: 0 2px;
  border-radius: 2px;
  transition: background 200ms ease-out, color 200ms ease-out;
}
.ticker-item.flash .val {
  animation: tickerValueFlash 220ms ease-out;
}
@keyframes tickerValueFlash {
  0%   { background: rgba(255, 156, 0, 0.55); color: var(--amber); }
  100% { background: rgba(255, 156, 0, 0);    color: var(--white); }
}
.kpi .k-label .badge.flash {
  background: var(--amber); color: var(--bg);
  padding: 0 4px; border-radius: 2px;
  animation: kpiBadgeFlash 420ms ease-out;
}
@keyframes kpiBadgeFlash {
  0%   { background: var(--amber); color: var(--bg);    box-shadow: 0 0 6px var(--amber); }
  100% { background: transparent;  color: var(--amber); box-shadow: none;                 }
}

/* KPI SPARKLINES */
.kpi-spark {
  display: block;
  width: 100%;
  height: 28px;
  margin-top: 8px;
  overflow: visible;
}
.kpi-spark .spark-area {
  stroke: none;
}
.kpi-spark .spark-line {
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  animation: kpiSparkDraw 400ms ease-out forwards;
}
.kpi-spark .spark-dot {
  stroke: var(--panel);
  stroke-width: 1;
}
.kpi-spark.good .spark-line { stroke: var(--green); }
.kpi-spark.warn .spark-line { stroke: var(--amber); }
.kpi-spark.info .spark-line { stroke: var(--cyan); }
.kpi-spark.bad .spark-line  { stroke: var(--red); }
.kpi-spark.good .spark-dot { fill: var(--green); }
.kpi-spark.warn .spark-dot { fill: var(--amber); }
.kpi-spark.info .spark-dot { fill: var(--cyan); }
.kpi-spark.bad .spark-dot  { fill: var(--red); }
.kpi-spark.good .spark-area { fill: rgba(0,230,118,0.10); }
.kpi-spark.warn .spark-area { fill: rgba(255,156,0,0.10); }
.kpi-spark.info .spark-area { fill: rgba(69,208,255,0.10); }
.kpi-spark.bad .spark-area  { fill: rgba(255,82,82,0.10); }
@keyframes kpiSparkDraw {
  to { stroke-dashoffset: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .terminal-bar .brand .dot,
  .ticker-track,
  .ticker-item.flash .val,
  .kpi .k-label .badge.flash,
  .kpi-spark .spark-line {
    animation: none !important;
  }
  .kpi-spark .spark-line { stroke-dashoffset: 0 !important; }
  .ticker-item.flash .val { background: transparent; }
  .kpi .k-label .badge.flash { background: transparent; color: var(--amber); box-shadow: none; }
}

/* RESPONSIVE TWEAKS */
@media (max-width: 720px) {
  .terminal-bar .brand .sub { display: none; }
  .terminal-bar { padding: 6px 10px; gap: 8px; }
  .fkeys { overflow-x: auto; flex-wrap: nowrap; }
  .fkey { padding: 7px 10px; flex-shrink: 0; }
  .fkey.primary { margin-left: 0; }
  .hero { flex-direction: column; align-items: flex-start; }
  .form-grid { grid-template-columns: 1fr; }
  .status-bar { font-size: 10px; gap: 10px; padding: 4px 8px; overflow-x: auto; }
}
