:root {
  color-scheme: dark;
  --bg: #101214;
  --panel: #191d21;
  --panel-2: #20262b;
  --line: #303840;
  --text: #f3f6f8;
  --muted: #9faab5;
  --green: #33d69f;
  --red: #ff6b7a;
  --gold: #f2bf5e;
  --cyan: #66d9ef;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--bg);
  color: var(--text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  display: grid;
  grid-template-columns: 260px 1fr;
}

.sidebar {
  border-right: 1px solid var(--line);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  background: #15181b;
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
}

.mark {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  background: var(--green);
  color: #07100d;
  font-weight: 800;
  border-radius: 8px;
}

small,
p,
span {
  color: var(--muted);
}

nav {
  display: grid;
  gap: 8px;
}

nav a {
  color: var(--muted);
  text-decoration: none;
  padding: 10px 12px;
  border-radius: 6px;
}

nav a.active,
nav a:hover {
  color: var(--text);
  background: var(--panel-2);
}

.safety {
  margin-top: auto;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
}

#liveBadge {
  display: inline-flex;
  color: #07100d;
  background: var(--gold);
  padding: 5px 8px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}

main {
  padding: 28px;
  display: grid;
  gap: 22px;
}

.topbar,
.section-head,
.row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

h1,
h2,
p {
  margin: 0;
}

h1 {
  font-size: 30px;
}

h2 {
  font-size: 18px;
}

.market-picker,
.row {
  display: flex;
}

button,
input,
select {
  border: 1px solid var(--line);
  background: #111417;
  color: var(--text);
  border-radius: 6px;
  padding: 10px 12px;
  font: inherit;
}

button {
  cursor: pointer;
  background: var(--green);
  color: #06100d;
  border-color: transparent;
  font-weight: 700;
}

.metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.metrics article,
.panel,
.bot-card {
  border: 1px solid var(--line);
  background: var(--panel);
  border-radius: 8px;
}

.metrics article {
  padding: 18px;
  display: grid;
  gap: 7px;
}

.metrics strong {
  font-size: 28px;
}

.panel {
  padding: 18px;
}

.bots-grid {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.bot-card {
  padding: 16px;
  display: grid;
  gap: 10px;
}

.bot-card header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.bot-card strong {
  font-size: 16px;
}

.tag {
  color: #06100d;
  background: var(--cyan);
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 12px;
  font-weight: 700;
}

.bot-card dl,
.connection-card dl {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 0;
}

.bot-card dd,
.bot-card dt,
.connection-card dd,
.connection-card dt {
  margin: 0;
}

.bot-card dt,
.connection-card dt {
  color: var(--muted);
  font-size: 12px;
}

.positive {
  color: var(--green);
}

.negative {
  color: var(--red);
}

.split {
  display: grid;
  grid-template-columns: minmax(320px, 0.85fr) 1.15fr;
  gap: 14px;
}

form {
  display: grid;
  gap: 14px;
}

label {
  display: grid;
  gap: 7px;
  color: var(--muted);
}

label > input,
label > select,
.row > label {
  width: 100%;
}

.checkline {
  display: flex;
  align-items: center;
  gap: 10px;
}

.checkline input {
  width: 18px;
  height: 18px;
}

.result {
  min-height: 42px;
  color: var(--muted);
}

.table-list {
  display: grid;
  gap: 8px;
  max-height: 300px;
  overflow: auto;
}

.table-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}

.table-row:last-child {
  border-bottom: 0;
}

.connection-card {
  padding: 16px;
  display: grid;
  gap: 12px;
}

.status-ok {
  color: var(--green);
}

.status-warn {
  color: var(--gold);
}

.backtest-result {
  display: grid;
  gap: 12px;
  min-height: 70px;
}

.backtest-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.backtest-metrics span {
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #11161a;
  color: var(--muted);
  font-size: 13px;
}

.backtest-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.curve {
  height: 86px;
  display: flex;
  align-items: end;
  gap: 3px;
  border-bottom: 1px solid var(--line);
}

.curve span {
  flex: 1;
  min-width: 3px;
  background: var(--cyan);
  border-radius: 2px 2px 0 0;
}

.risk-trigger-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.risk-trigger-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-left: 3px solid var(--gold);
  border-radius: 8px;
  background: #13171a;
}

.risk-trigger-card.high {
  border-left-color: var(--red);
}

.risk-trigger-card header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.risk-trigger-card p {
  margin: 0;
  color: var(--muted);
}

.trigger-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.trigger-tags span {
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--panel-2);
  color: var(--muted);
  font-size: 12px;
}

.events {
  display: grid;
  gap: 10px;
  max-height: 340px;
  overflow: auto;
  padding-right: 4px;
}

.event {
  display: grid;
  gap: 4px;
  padding: 12px;
  background: #13171a;
  border-left: 3px solid var(--cyan);
  border-radius: 6px;
}

.event.risk {
  border-left-color: var(--red);
}

.event.trade {
  border-left-color: var(--green);
}

@media (max-width: 920px) {
  body {
    grid-template-columns: 1fr;
  }

  .sidebar {
    position: static;
  }

  .topbar,
  .market-picker,
  .split {
    display: grid;
  }

  .metrics,
  .bots-grid {
    grid-template-columns: 1fr;
  }
}


.account-panel {
  display: grid;
  gap: 8px;
  justify-items: end;
}

.auth-inline {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.auth-inline input {
  width: 130px;
}

.account-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
}

.account-chip button {
  padding: 7px 9px;
  background: var(--panel-2);
  color: var(--text);
  border-color: var(--line);
}

.account-panel .result {
  max-width: 420px;
  text-align: right;
}

@media (max-width: 980px) {
  .topbar {
    align-items: stretch;
    flex-direction: column;
  }

  .account-panel,
  .auth-inline {
    justify-items: stretch;
    justify-content: stretch;
  }

  .auth-inline input,
  .auth-inline button {
    width: 100%;
  }
}


.bot-create-form {
  margin-top: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #14181c;
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: 12px;
}

.bot-create-form button,
.bot-create-form .result {
  align-self: end;
}

.template-hint {
  grid-column: 1 / -1;
  padding: 10px 12px;
  border: 1px solid rgba(51, 214, 159, 0.28);
  border-radius: 8px;
  background: rgba(51, 214, 159, 0.08);
  color: var(--muted);
  font-size: 13px;
}

.bot-detail-panel {
  margin-top: 14px;
  padding: 14px;
  border: 1px solid rgba(51, 214, 159, 0.35);
  border-radius: 8px;
  background: #12171a;
  display: grid;
  gap: 12px;
}

.bot-detail-panel[hidden] {
  display: none;
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.detail-grid > div,
.detail-block {
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.detail-grid dt {
  color: var(--muted);
  font-size: 12px;
}

.detail-grid dd {
  margin: 4px 0 0;
  font-weight: 700;
}

.detail-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.detail-edit-form {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.detail-edit-form button {
  align-self: end;
}

.detail-block {
  display: grid;
  gap: 6px;
}

.detail-block-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}

.detail-block p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}

.risk-pause-note {
  border-left: 3px solid var(--red);
}

.bot-card.customer-owned {
  border-color: rgba(51, 214, 159, 0.55);
}

.mini-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

button.danger {
  background: var(--red);
  color: #160407;
}

@media (max-width: 1100px) {
  .bot-create-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .bot-create-form,
  .detail-grid,
  .detail-edit-form {
    grid-template-columns: 1fr;
  }
}


.ai-key-form {
  margin-top: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #11161a;
  display: grid;
  grid-template-columns: 180px minmax(220px, 1fr) 140px minmax(180px, 1fr);
  gap: 12px;
  align-items: end;
}

@media (max-width: 900px) {
  .ai-key-form {
    grid-template-columns: 1fr;
  }
}


.secondary {
  background: var(--panel-2);
  color: var(--text);
  border-color: var(--line);
}

.switch-line {
  min-height: 42px;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
}

.switch-line input {
  width: auto;
  accent-color: var(--green);
}


.audit-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.audit-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #13171a;
}

.audit-card header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.audit-card dl {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

.audit-card dt {
  color: var(--muted);
  font-size: 12px;
}

.audit-card dd {
  margin: 3px 0 0;
  font-weight: 700;
}

.status-neutral {
  background: var(--panel-2);
  color: var(--text);
}

@media (max-width: 920px) {
  .audit-list,
  .audit-card dl {
    grid-template-columns: 1fr;
  }
}


.risk-audit-card {
  border-left: 3px solid var(--gold);
}

.risk-audit-card .status-warn {
  background: var(--gold);
  color: #171207;
}


.performance-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.performance-summary article,
.asset-row,
.performance-card {
  border: 1px solid var(--line);
  background: #13171a;
  border-radius: 8px;
}

.performance-summary article {
  padding: 14px;
  display: grid;
  gap: 6px;
}

.performance-summary strong {
  font-size: 24px;
}

.personal-decision-panel {
  display: grid;
  gap: 12px;
  margin: 14px 0 18px;
  padding: 14px;
  border: 1px solid rgba(102, 217, 239, 0.32);
  border-radius: 8px;
  background: #12171b;
}

.personal-decision-head,
.decision-card {
  display: grid;
  align-items: center;
  gap: 10px;
}

.personal-decision-head {
  grid-template-columns: 1fr auto;
}

.personal-decision-head h3,
.personal-decision-head p {
  margin: 0;
}

.personal-mode-badge {
  padding: 6px 9px;
  border-radius: 6px;
  color: #07100d;
  background: var(--gold);
  font-size: 12px;
  font-weight: 800;
}

.decision-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.decision-summary article {
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0e1317;
}

.decision-summary strong,
.decision-summary span {
  display: block;
}

.decision-summary strong {
  font-size: 20px;
}

.decision-list {
  display: grid;
  gap: 8px;
}

.decision-card {
  grid-template-columns: minmax(0, 1fr) 72px 86px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-left-width: 4px;
  border-radius: 8px;
  background: #0e1317;
}

.decision-card.good {
  border-left-color: var(--green);
}

.decision-card.watch {
  border-left-color: var(--gold);
}

.decision-card.bad {
  border-left-color: var(--red);
}

.decision-card p,
.decision-card small {
  margin: 3px 0 0;
}

.decision-card small {
  grid-column: 1 / -1;
}

.decision-score {
  text-align: center;
}

.decision-score strong,
.decision-score span {
  display: block;
}

.decision-score strong {
  font-size: 22px;
}

.decision-state {
  text-align: center;
  color: var(--text);
  font-weight: 700;
}

.decision-disclaimer {
  font-size: 12px;
}

@media (max-width: 720px) {
  .personal-decision-head,
  .decision-card {
    grid-template-columns: 1fr;
  }

  .decision-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .decision-score,
  .decision-state {
    text-align: left;
  }
}

.performance-split {
  display: grid;
  grid-template-columns: minmax(220px, 0.75fr) 1.5fr;
  gap: 14px;
  margin-top: 14px;
}

.performance-split h3 {
  margin: 0 0 10px;
  font-size: 15px;
}

.asset-list,
.performance-list {
  display: grid;
  gap: 10px;
}

.asset-row {
  display: grid;
  grid-template-columns: 80px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 12px;
}

.performance-card {
  display: grid;
  gap: 10px;
  padding: 14px;
}

.performance-card header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.performance-card dl {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
}

.performance-card dt {
  color: var(--muted);
  font-size: 12px;
}

.performance-card dd {
  margin: 3px 0 0;
  font-weight: 700;
}

@media (max-width: 920px) {
  .risk-trigger-list,
  .performance-summary,
  .performance-split,
  .performance-card dl,
  .asset-row {
    grid-template-columns: 1fr;
  }
}


.advanced-config {
  grid-column: 1 / -1;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #13171a;
}
.advanced-config summary {
  cursor: pointer;
  font-weight: 700;
}
.advanced-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
@media (max-width: 920px) {
  .advanced-grid,
  .backtest-metrics {
    grid-template-columns: 1fr;
  }
}


.risk-review-queue {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.risk-review-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(242, 191, 94, 0.45);
  border-left: 3px solid var(--gold);
  border-radius: 8px;
  background: #13171a;
}

.risk-review-card header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.risk-review-card dl {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
}

.risk-review-card dt,
.risk-review-card dd {
  margin: 0;
}

.risk-review-card dt {
  color: var(--muted);
  font-size: 12px;
}

@media (max-width: 920px) {
  .risk-trigger-list,
  .risk-review-queue {
    grid-template-columns: 1fr;
  }
}


.risk-review-history {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #11161a;
}

.risk-review-history summary {
  cursor: pointer;
  font-weight: 700;
}

.risk-review-history summary span {
  margin-left: 6px;
  color: var(--gold);
}

.risk-review-history-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.risk-review-history-item {
  display: grid;
  grid-template-columns: minmax(180px, 0.8fr) 1fr auto;
  gap: 12px;
  align-items: start;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.risk-review-history-item p {
  margin: 0;
}

@media (max-width: 920px) {
  .risk-review-history-item {
    grid-template-columns: 1fr;
  }
}


.risk-review-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.risk-review-filters button {
  padding: 8px 10px;
  background: var(--panel-2);
  color: var(--muted);
  border: 1px solid var(--line);
}

.risk-review-filters button.active {
  background: var(--green);
  color: #06100d;
  border-color: transparent;
}

.risk-review-card.high,
.manual-review-card.high {
  border-left-color: var(--red);
}

.manual-review-card {
  border-left-color: var(--cyan);
}


.review-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.review-actions button {
  padding: 8px 10px;
}


.risk-ticket-drawer {
  margin-top: 14px;
  padding: 14px;
  border: 1px solid rgba(102, 217, 239, 0.4);
  border-radius: 8px;
  background: #101519;
  display: grid;
  gap: 12px;
}

.risk-ticket-drawer[hidden] {
  display: none;
}

.ticket-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.ticket-grid article {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #13171a;
  display: grid;
  gap: 8px;
}

.ticket-grid p {
  margin: 0;
}

.ticket-link {
  padding: 0;
  background: transparent;
  border: 0;
  color: var(--cyan);
  text-align: left;
  font-weight: 800;
}

@media (max-width: 920px) {
  .ticket-grid {
    grid-template-columns: 1fr;
  }
}


.risk-ticket-search {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 8px;
  margin-top: 12px;
}

.risk-ticket-search input {
  width: 100%;
}

@media (max-width: 720px) {
  .risk-ticket-search {
    grid-template-columns: 1fr;
  }
}


.risk-sla-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.risk-sla-summary article {
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.risk-sla-summary strong {
  display: block;
  font-size: 20px;
  color: var(--gold);
}

.risk-sla-summary span {
  color: var(--muted);
  font-size: 12px;
}

.risk-card-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

.risk-priority-badge,
.risk-sla-badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid var(--line);
}

.risk-priority-badge.high,
.risk-sla-badge.overdue {
  color: #ffd8d8;
  border-color: rgba(255, 107, 107, 0.55);
  background: rgba(255, 107, 107, 0.12);
}

.risk-priority-badge.medium,
.risk-sla-badge.soon {
  color: #ffe2aa;
  border-color: rgba(242, 191, 94, 0.5);
  background: rgba(242, 191, 94, 0.12);
}

.risk-priority-badge.low,
.risk-sla-badge.normal {
  color: #c6f6e4;
  border-color: rgba(53, 208, 127, 0.42);
  background: rgba(53, 208, 127, 0.1);
}

.risk-review-card.overdue {
  box-shadow: inset 0 0 0 1px rgba(255, 107, 107, 0.25);
}

@media (max-width: 920px) {
  .risk-sla-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .risk-review-card header {
    flex-direction: column;
  }

  .risk-card-badges {
    justify-content: flex-start;
  }
}


.workflow-badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid var(--line);
}

.workflow-badge.pending {
  color: #ffe2aa;
  border-color: rgba(242, 191, 94, 0.5);
  background: rgba(242, 191, 94, 0.12);
}

.workflow-badge.paused {
  color: #d8e2ff;
  border-color: rgba(126, 153, 255, 0.45);
  background: rgba(126, 153, 255, 0.12);
}

.workflow-badge.adjusted,
.workflow-badge.watching {
  color: #bff7ff;
  border-color: rgba(102, 217, 239, 0.45);
  background: rgba(102, 217, 239, 0.1);
}

.workflow-badge.closed {
  color: #c6f6e4;
  border-color: rgba(53, 208, 127, 0.42);
  background: rgba(53, 208, 127, 0.1);
}


.risk-workflow-board {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.workflow-board-card {
  min-height: 86px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
  display: grid;
  gap: 4px;
}

.workflow-board-card strong {
  font-size: 24px;
  color: var(--text);
}

.workflow-board-card span {
  font-weight: 700;
}

.workflow-board-card small {
  color: var(--muted);
}

.workflow-board-card.pending {
  border-color: rgba(242, 191, 94, 0.4);
}

.workflow-board-card.adjusted,
.workflow-board-card.watching {
  border-color: rgba(102, 217, 239, 0.35);
}

.workflow-board-card.closed {
  border-color: rgba(53, 208, 127, 0.35);
}

@media (max-width: 920px) {
  .risk-workflow-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .risk-workflow-board,
  .risk-sla-summary {
    grid-template-columns: 1fr;
  }
}


.workflow-board-card {
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.workflow-board-card:hover,
.workflow-board-card.active {
  border-color: var(--gold);
  box-shadow: inset 0 0 0 1px rgba(242, 191, 94, 0.28);
}

.workflow-board-card.active strong {
  color: var(--gold);
}


.risk-bulk-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.risk-bulk-toolbar strong {
  color: var(--gold);
}

.risk-bulk-toolbar small {
  color: var(--muted);
}

.bulk-select {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
}

.bulk-select input {
  width: auto;
}

.risk-review-card.selected {
  box-shadow: inset 0 0 0 1px rgba(102, 217, 239, 0.35);
}


.risk-bulk-result-panel {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.risk-bulk-result-panel[hidden] {
  display: none;
}

.risk-bulk-result-panel h3 {
  margin: 0;
}

.risk-bulk-result-list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.bulk-result-item {
  display: grid;
  grid-template-columns: minmax(160px, 0.8fr) 1fr;
  gap: 10px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0e1317;
}

.bulk-result-item strong,
.bulk-result-item span,
.bulk-result-item small {
  display: block;
}

.bulk-result-item small {
  color: var(--muted);
}

.bulk-result-item p {
  margin: 0;
}

.bulk-result-item.success {
  border-color: rgba(53, 208, 127, 0.35);
}

.bulk-result-item.skipped {
  border-color: rgba(242, 191, 94, 0.35);
}

.bulk-result-item.failed {
  border-color: rgba(255, 107, 107, 0.42);
}

@media (max-width: 720px) {
  .bulk-result-item {
    grid-template-columns: 1fr;
  }
}


.risk-note-template-bar {
  display: grid;
  grid-template-columns: minmax(220px, 320px) auto minmax(220px, 1fr);
  align-items: end;
  gap: 8px;
  margin-top: 10px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.risk-note-template-bar label {
  display: grid;
  gap: 6px;
}

.risk-note-template-bar small {
  color: var(--muted);
}

@media (max-width: 920px) {
  .risk-note-template-bar {
    grid-template-columns: 1fr;
  }
}


.risk-note-template-bar input {
  width: 100%;
}

.risk-note-template-bar button:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}


.risk-operation-timeline {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #11161a;
}

.risk-operation-timeline summary {
  cursor: pointer;
  font-weight: 700;
}

.risk-operation-timeline summary span {
  margin-left: 6px;
  color: var(--gold);
}

.risk-operation-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.risk-operation-item {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 12px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.risk-operation-item time,
.risk-operation-item small {
  color: var(--muted);
}

.risk-operation-item p {
  margin: 4px 0;
}

.risk-operation-item.bulk,
.risk-operation-item.export,
.risk-operation-item.template {
  border-color: rgba(102, 217, 239, 0.32);
}

@media (max-width: 720px) {
  .risk-operation-item {
    grid-template-columns: 1fr;
  }
}


.timeline-actions {
  margin-top: 10px;
}


.risk-report-preview {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(102, 217, 239, 0.35);
  border-radius: 8px;
  background: #101519;
}

.risk-report-preview[hidden] {
  display: none;
}

.risk-report-preview h3 {
  margin: 0;
}

.report-preview-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.report-preview-grid article,
.report-preview-list article {
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0e1317;
}

.report-preview-grid strong {
  display: block;
  font-size: 22px;
  color: var(--gold);
}

.report-preview-grid span,
.report-preview-list small {
  color: var(--muted);
}

.report-preview-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 12px 0;
}

.report-preview-meta dt,
.report-preview-meta dd {
  margin: 0;
}

.report-preview-meta dt {
  color: var(--muted);
  font-size: 12px;
}

.report-preview-list {
  display: grid;
  gap: 8px;
}

.report-preview-list p {
  margin: 4px 0;
}

@media (max-width: 720px) {
  .report-preview-grid,
  .report-preview-meta {
    grid-template-columns: 1fr;
  }
}


.printable-risk-report {
  display: grid;
  gap: 14px;
}

.print-report-header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line);
}

.print-report-header h2,
.print-report-header p {
  margin: 0;
}

.print-report-header p {
  color: var(--muted);
  font-size: 12px;
}

.print-report-section {
  display: grid;
  gap: 10px;
}

.print-report-section h3 {
  margin: 0;
}

.print-report-timeline {
  display: grid;
  gap: 8px;
}

.print-report-timeline article {
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0e1317;
}

.print-report-timeline time,
.print-report-timeline small {
  color: var(--muted);
}

.print-report-timeline p {
  margin: 4px 0;
}

.print-report-footer {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  color: var(--muted);
}

@media print {
  body.print-report-mode > *:not(.app-shell) {
    display: none !important;
  }

  body.print-report-mode .app-shell > *:not(main),
  body.print-report-mode main > *:not(#riskReviewCenter),
  body.print-report-mode #riskReviewCenter > *:not(#riskReportPreviewPanel),
  body.print-report-mode #riskReportPreviewPanel > .section-head {
    display: none !important;
  }

  body.print-report-mode,
  body.print-report-mode .app-shell,
  body.print-report-mode main,
  body.print-report-mode #riskReviewCenter,
  body.print-report-mode #riskReportPreviewPanel {
    background: #fff !important;
    color: #111 !important;
  }

  body.print-report-mode #riskReportPreviewPanel {
    border: 0;
    padding: 0;
  }

  body.print-report-mode .printable-risk-report article,
  body.print-report-mode .print-report-timeline article {
    background: #fff !important;
    color: #111 !important;
    border-color: #ccc !important;
  }

  body.print-report-mode small,
  body.print-report-mode dt,
  body.print-report-mode time {
    color: #555 !important;
  }
}
