: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;
}

body.simple-mode .professional-only,
body.simple-mode .professional-link {
  display: none;
}

body.simple-mode #accountPerformancePanel,
body.simple-mode .market-scan-panel,
body.simple-mode #connectionsGrid,
body.simple-mode #exchangeReadOnlyPanel,
body.simple-mode #connections .api-access-guide,
body.simple-mode #connections .api-checklist {
  display: none;
}

body.professional-mode .simple-home {
  display: none;
}

[data-owner-only][hidden] {
  display: none !important;
}

.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;
}

.mode-toggle {
  grid-column: 1 / -1;
  justify-self: end;
}

.simple-badge {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgb(51 214 159 / 13%);
  color: var(--green);
  font-size: 13px;
}

.simple-home {
  display: grid;
  gap: 14px;
  border-color: rgb(102 217 239 / 24%);
  background: #11171a;
}

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

.simple-home-card {
  min-height: 132px;
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.simple-home-card span {
  font-size: 12px;
}

.simple-home-card strong {
  font-size: 20px;
  color: var(--text);
  line-height: 1.2;
}

.simple-home-card small {
  line-height: 1.45;
}

.simple-home-card a {
  width: fit-content;
  margin-top: auto;
  color: var(--green);
  text-decoration: none;
  font-weight: 700;
}

.simple-home-card.good {
  border-color: rgb(51 214 159 / 34%);
}

.simple-home-card.warn {
  border-color: rgb(242 191 94 / 40%);
}

.simple-home-card.bad {
  border-color: rgb(255 107 122 / 42%);
}

.simple-setup-progress {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.simple-progress-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.simple-progress-head strong {
  color: var(--text);
}

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

.simple-step {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-height: 86px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #12171a;
  text-decoration: none;
}

.simple-step > span {
  display: grid;
  width: 30px;
  height: 30px;
  place-items: center;
  border-radius: 50%;
  background: var(--panel-2);
  color: var(--text);
  font-weight: 800;
}

.simple-step strong {
  color: var(--text);
}

.simple-step small {
  display: block;
  margin-top: 3px;
  line-height: 1.35;
}

.simple-step em {
  grid-column: 1 / -1;
  width: fit-content;
  padding: 3px 8px;
  border-radius: 999px;
  color: var(--muted);
  background: var(--panel-2);
  font-style: normal;
  font-size: 12px;
}

.simple-step.done {
  border-color: rgb(51 214 159 / 32%);
}

.simple-step.done > span,
.simple-step.done em {
  color: #07100d;
  background: var(--green);
}

.simple-step.active {
  border-color: rgb(242 191 94 / 42%);
  background: rgb(242 191 94 / 7%);
}

.simple-step.active em {
  color: var(--gold);
}

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;
}

.quick-start {
  display: grid;
  gap: 16px;
}

.quick-steps,
.quick-bot-options,
.quick-start-form {
  display: grid;
  gap: 12px;
}

.quick-steps {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.quick-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 5px 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #13171a;
}

.quick-step span {
  grid-row: span 2;
  display: grid;
  width: 30px;
  height: 30px;
  place-items: center;
  border-radius: 50%;
  background: var(--panel-2);
  color: var(--text);
  font-weight: 800;
}

.quick-step strong,
.quick-step small {
  min-width: 0;
}

.quick-bot-options {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.quick-option {
  min-height: 112px;
  display: grid;
  align-content: center;
  justify-items: start;
  gap: 8px;
  padding: 18px;
  border: 1px solid var(--line);
  background: #11161a;
  color: var(--text);
  text-align: left;
}

.quick-option.active {
  border-color: var(--green);
  background: rgb(51 214 159 / 12%);
  box-shadow: inset 0 0 0 1px rgb(51 214 159 / 20%);
}

.quick-api-readiness {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgb(102 217 239 / 24%);
  border-radius: 8px;
  background: #10171b;
}

.quick-api-readiness:empty {
  display: none;
}

.quick-api-readiness-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.quick-api-readiness-head strong {
  color: var(--text);
}

.quick-api-readiness-head a {
  color: var(--green);
  text-decoration: none;
}

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

.quick-api-items article {
  display: grid;
  gap: 5px;
  min-height: 96px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #13181b;
}

.quick-api-items article.ok {
  border-color: rgb(51 214 159 / 30%);
}

.quick-api-items article.warn {
  border-color: rgb(242 191 94 / 40%);
}

.quick-api-items span {
  width: fit-content;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--panel-2);
  font-size: 12px;
}

.quick-api-items .ok span {
  color: var(--green);
}

.quick-api-items .warn span {
  color: var(--gold);
}

.quick-option strong {
  font-size: 18px;
}

.quick-option span {
  line-height: 1.45;
}

.quick-start-form {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: end;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #14181c;
}

.quick-auto-run {
  grid-column: 1 / -1;
  padding: 10px 12px;
  border: 1px solid rgb(51 214 159 / 22%);
  border-radius: 8px;
  background: rgb(51 214 159 / 8%);
}

.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 article.market-metric {
  border-color: rgb(102 217 239 / 35%);
}

.metrics article.market-metric.market-trusted {
  border-color: rgb(51 214 159 / 55%);
}

.metrics article.market-metric.market-untrusted {
  border-color: rgb(255 183 77 / 70%);
  box-shadow: inset 3px 0 0 rgb(255 183 77 / 85%);
}

.market-quality-warning {
  margin: 0;
  padding: 10px 12px;
  border: 1px solid rgb(255 183 77 / 45%);
  background: rgb(255 183 77 / 8%);
  color: var(--muted);
  border-radius: 6px;
}

.metrics article.account-metric {
  border-color: rgb(51 214 159 / 35%);
}

.alert-center {
  margin: 0 0 18px;
  padding: 14px;
  border: 1px solid rgb(255 95 109 / 45%);
  background: rgb(255 95 109 / 5%);
  border-radius: 8px;
}

.alert-center-head,
.alert-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.alert-center h2,
.alert-center p {
  margin: 0;
}

.alert-center-head span,
.runtime-alert small {
  color: var(--muted);
}

.alert-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.runtime-alert {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-left: 3px solid var(--gold);
  background: var(--panel);
  border-radius: 6px;
}

.runtime-alert.critical {
  border-left-color: var(--red);
}

.runtime-alert.read {
  opacity: 0.62;
}

@media (max-width: 720px) {
  .alert-center-head,
  .alert-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .runtime-alert {
    grid-template-columns: 1fr auto;
  }
}

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

.panel {
  padding: 18px;
}

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

.market-scan-panel {
  display: grid;
  gap: 12px;
  margin-top: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #14181c;
}

.compact-head {
  align-items: center;
}

.scan-controls {
  display: grid;
  grid-template-columns: 110px 110px auto;
  gap: 8px;
}

.scan-result,
.scan-list {
  display: grid;
  gap: 10px;
}

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

.scan-summary article,
.scan-row {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.scan-summary article {
  display: grid;
  gap: 6px;
  padding: 12px;
}

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

.scan-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 70px 90px minmax(180px, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
}

.scan-row button {
  min-height: 36px;
}

.scan-note,
.empty-state {
  color: var(--muted);
  margin: 0;
}

.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);
}

.exchange-rule-hint {
  padding: 10px 12px;
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--muted);
  border-radius: 6px;
  font-size: 13px;
}

.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;
}

.api-access-panel {
  display: grid;
  gap: 14px;
}

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

.api-access-guide article,
.api-card {
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #11171a;
}

.api-access-guide strong {
  color: var(--text);
}

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

.api-checklist section {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #12181c;
}

.api-checklist h3,
.api-checklist ul {
  margin: 0;
}

.api-checklist ul {
  display: grid;
  gap: 7px;
  padding-left: 18px;
  color: var(--muted);
}

.api-checklist button {
  justify-self: start;
}

.exchange-api-helper {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgb(102 217 239 / 25%);
  border-radius: 8px;
  background: #10171b;
}

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

.api-helper-grid article {
  display: grid;
  gap: 6px;
  min-height: 92px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #12181c;
}

.api-helper-grid strong {
  color: var(--text);
}

.api-helper-grid small,
.exchange-api-helper p {
  line-height: 1.45;
}

.exchange-api-helper p {
  margin: 0;
  padding: 10px 12px;
  border: 1px solid rgb(242 191 94 / 28%);
  border-radius: 8px;
  background: rgb(242 191 94 / 7%);
}

.copy-result {
  min-height: 20px;
}

.member-admin-panel {
  display: grid;
  gap: 14px;
}

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

.member-admin-summary article,
.member-admin-card {
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #12181c;
}

.member-admin-summary article {
  display: grid;
  gap: 5px;
}

.member-admin-summary strong {
  font-size: 28px;
}

.member-admin-list {
  display: grid;
  gap: 10px;
}

.member-admin-card {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(280px, 2fr) auto;
  gap: 12px;
  align-items: center;
}

.member-admin-card.owner {
  border-color: rgb(51 214 159 / 30%);
}

.member-admin-card p {
  margin: 4px 0 0;
}

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

.member-admin-card dl div {
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #101417;
}

.member-admin-card dt,
.member-admin-card dd {
  margin: 0;
}

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

.api-key-fields {
  display: grid;
  grid-template-columns: 180px minmax(240px, 1fr);
  gap: 10px;
}

.exchange-read-only-panel {
  display: grid;
  gap: 12px;
  margin-top: 14px;
  padding: 14px;
  border: 1px solid rgb(102 217 239 / 30%);
  border-radius: 8px;
  background: #10161a;
}

.exchange-key-form {
  display: grid;
  gap: 12px;
  margin-top: 14px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #11171a;
}

.exchange-key-fields {
  display: grid;
  grid-template-columns: 130px repeat(3, minmax(160px, 1fr));
  gap: 10px;
}

.api-key-fields small,
.exchange-key-fields small {
  line-height: 1.45;
}

.read-only-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.read-only-head p,
.exchange-read-only-panel p {
  margin: 3px 0 0;
  color: var(--muted);
}

.read-only-warning {
  padding: 9px 10px;
  border-left: 3px solid var(--gold);
  background: rgb(255 204 102 / 7%);
  color: var(--muted);
  font-size: 13px;
}

.read-only-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.read-only-grid h3 {
  margin: 0 0 8px;
  font-size: 15px;
}

.read-only-list {
  display: grid;
  gap: 7px;
}

.read-only-list article {
  display: grid;
  grid-template-columns: minmax(80px, 1fr) repeat(3, auto);
  gap: 10px;
  align-items: center;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0e1317;
}

.read-only-list span {
  color: var(--muted);
  font-size: 12px;
}

.read-only-list b {
  color: var(--text);
}

.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,
  .simple-home-grid,
  .simple-steps,
  .bots-grid,
  .scan-summary,
  .scan-row,
  .scan-controls {
    grid-template-columns: 1fr;
  }
}


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

.topbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
}

.topbar > div:first-child {
  min-width: 0;
}

.auth-gate {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  place-items: center;
  padding: 24px;
  background: #0d1013;
}

.auth-gate[hidden] {
  display: none;
}

.auth-card {
  width: min(420px, 100%);
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
  box-shadow: 0 24px 70px rgb(0 0 0 / 35%);
}

.auth-heading {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
}

.auth-heading > div {
  display: grid;
  gap: 4px;
}

.auth-heading strong {
  font-size: 20px;
}

.auth-heading small,
.auth-inline label {
  color: var(--muted);
}

.auth-inline {
  display: grid;
  gap: 14px;
}

.auth-inline label {
  display: grid;
  gap: 7px;
  font-size: 13px;
}

.auth-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.auth-actions button {
  min-height: 42px;
}

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

.account-avatar {
  display: grid;
  width: 30px;
  height: 30px;
  place-items: center;
  flex: 0 0 30px;
  border-radius: 50%;
  background: var(--green);
  color: #07100d;
  font-weight: 800;
}

.account-chip strong {
  max-width: 110px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-chip small {
  display: none;
}

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

.market-picker {
  grid-column: 1 / -1;
  justify-self: end;
}

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

.auth-card .result {
  max-width: none;
  margin-top: 12px;
  text-align: left;
}

@media (max-width: 980px) {
  .topbar {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .account-panel {
    grid-column: 1;
    justify-items: stretch;
  }

  .market-picker {
    grid-column: 1;
    justify-self: stretch;
  }

  .mode-toggle {
    grid-column: 1;
    justify-self: stretch;
  }

  .auth-card {
    padding: 22px;
  }

  .quick-steps,
  .quick-bot-options,
  .quick-start-form {
    grid-template-columns: 1fr;
  }

  .api-access-guide,
  .api-helper-grid,
  .api-checklist,
  .member-admin-summary,
  .member-admin-card,
  .member-admin-card dl,
  .api-key-fields,
  .exchange-key-fields {
    grid-template-columns: 1fr;
  }
}


.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;
}

.form-actions {
  grid-column: 1 / -1;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.form-actions button {
  min-width: 132px;
}

.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-explain-mini {
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.bot-explain-mini strong {
  color: var(--text);
}

.bot-explain-mini span {
  font-size: 13px;
  line-height: 1.45;
}

.bot-explain-mini.good {
  border-color: rgb(51 214 159 / 34%);
}

.bot-explain-mini.warn {
  border-color: rgb(242 191 94 / 38%);
}

.bot-explain-mini.bad {
  border-color: rgb(255 107 122 / 42%);
}

.bot-explain-panel {
  display: grid;
  gap: 12px;
}

.bot-explain-panel.good {
  border-color: rgb(51 214 159 / 34%);
}

.bot-explain-panel.warn {
  border-color: rgb(242 191 94 / 38%);
}

.bot-explain-panel.bad {
  border-color: rgb(255 107 122 / 42%);
}

.bot-explain-decision {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #12191d;
}

.bot-explain-decision span {
  width: fit-content;
  padding: 4px 8px;
  border-radius: 6px;
  background: var(--panel-2);
  color: var(--text);
  font-weight: 700;
}

.bot-explain-decision p {
  margin: 0;
  line-height: 1.55;
}

.bot-explain-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.bot-explain-steps > div {
  display: grid;
  gap: 6px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0f1418;
}

.bot-explain-steps strong {
  color: var(--text);
}

.bot-explain-steps small {
  line-height: 1.45;
}

.bot-explain-steps .good {
  border-color: rgb(51 214 159 / 32%);
}

.bot-explain-steps .warn {
  border-color: rgb(242 191 94 / 36%);
}

.bot-explain-steps .bad {
  border-color: rgb(255 107 122 / 40%);
}

.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;
}

.enable-confirm-panel {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgb(51 214 159 / 38%);
  border-radius: 8px;
  background: rgb(51 214 159 / 7%);
}

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

.enable-confirm-grid > div {
  display: grid;
  gap: 5px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.enable-confirm-grid span {
  color: var(--muted);
  font-size: 12px;
}

.enable-readiness-list {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.enable-readiness-list > div {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 2px 8px;
  align-items: center;
  padding: 9px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.trade-confirm-dialog {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: 20px;
  background: rgb(4 8 12 / 76%);
  backdrop-filter: blur(10px);
}

.trade-confirm-dialog[hidden] {
  display: none;
}

.confirm-dialog-open {
  overflow: hidden;
}

.trade-confirm-card {
  width: min(980px, 100%);
  max-height: min(86vh, 860px);
  overflow: auto;
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid rgb(51 214 159 / 34%);
  border-radius: 8px;
  background: #0e1418;
  box-shadow: 0 24px 80px rgb(0 0 0 / 45%);
}

.trade-confirm-content {
  display: grid;
  gap: 12px;
}

.trade-confirm-alert,
.trade-confirm-rules {
  display: grid;
  gap: 6px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.trade-confirm-alert.live {
  border-color: rgb(255 91 91 / 38%);
  background: rgb(255 91 91 / 8%);
}

.trade-confirm-alert.paper {
  border-color: rgb(255 203 107 / 35%);
  background: rgb(255 203 107 / 8%);
}

.trade-confirm-alert span,
.trade-confirm-rules p {
  margin: 0;
  color: var(--muted);
}

.trade-confirm-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.trade-confirm-readiness {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.trade-confirm-check {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #101519;
}

.enable-readiness-list > div > span {
  display: grid;
  width: 22px;
  height: 22px;
  grid-row: 1 / 3;
  place-items: center;
  border-radius: 50%;
  font-weight: 900;
}

.enable-readiness-list .passed > span {
  background: rgb(51 214 159 / 18%);
  color: var(--green);
}

.enable-readiness-list .blocked > span {
  background: rgb(255 107 107 / 18%);
  color: var(--red);
}

.enable-readiness-list small {
  color: var(--muted);
  overflow-wrap: anywhere;
}

.enable-confirm-panel textarea {
  width: 100%;
  resize: vertical;
}

.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;
}

.bot-timeline-block {
  gap: 10px;
}

.bot-timeline-block .detail-block-head span {
  color: var(--muted);
  font-size: 12px;
}

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

.bot-timeline-item {
  display: grid;
  grid-template-columns: 150px 48px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 10px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--line);
  border-radius: 8px;
  background: #0f1417;
}

.bot-timeline-item.scan {
  border-left-color: var(--green);
}

.bot-timeline-item.signal,
.bot-timeline-item.ai {
  border-left-color: var(--cyan);
}

.bot-timeline-item.risk {
  border-left-color: var(--gold);
}

.bot-timeline-item.risk.danger {
  border-left-color: var(--red);
}

.bot-timeline-item.order {
  border-left-color: var(--green);
}

.bot-timeline-item.config {
  border-left-color: var(--muted);
}

.bot-timeline-item time,
.bot-timeline-item span {
  color: var(--muted);
  font-size: 12px;
}

.bot-timeline-item span {
  justify-self: start;
  min-width: 42px;
  padding: 3px 7px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #12191d;
  color: var(--text);
  text-align: center;
  font-weight: 700;
}

.bot-timeline-item div {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.bot-timeline-item strong,
.bot-timeline-item p,
.bot-timeline-item small {
  overflow-wrap: anywhere;
}

.bot-timeline-item p,
.bot-timeline-item small {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
}

.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,
  .bot-explain-steps,
  .enable-confirm-grid,
  .enable-readiness-list,
  .trade-confirm-grid,
  .trade-confirm-readiness,
  .detail-edit-form {
    grid-template-columns: 1fr;
  }

  .trade-confirm-dialog {
    padding: 10px;
    align-items: end;
  }

  .trade-confirm-card {
    max-height: 92vh;
    padding: 14px;
  }

  .bot-timeline-item {
    grid-template-columns: 1fr;
  }

  .bot-timeline-item span {
    justify-self: start;
  }
}


.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;
}

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

.performance-window-head,
.performance-window-head > div,
.performance-window-grid article,
.performance-window-grid dl {
  display: grid;
  gap: 8px;
}

.performance-window-head {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.performance-window-head h3,
.performance-window-head p,
.performance-window-verdict {
  margin: 0;
}

.performance-window-head p,
.performance-window-verdict,
.performance-window-grid dt {
  color: var(--muted);
}

.performance-window-head > span {
  padding: 6px 9px;
  border: 1px solid currentColor;
  border-radius: 6px;
  font-weight: 700;
}

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

.performance-window-grid article {
  padding: 12px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 6px;
}

.performance-window-grid header,
.performance-window-grid dl div {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

.performance-window-grid header span,
.performance-window-grid dt {
  font-size: 12px;
}

.performance-window-grid dd {
  margin: 0;
  font-weight: 700;
}

.performance-window-verdict {
  margin-top: 10px;
}

.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;
}

@media (max-width: 920px) {
  .performance-window-grid,
  .performance-window-head {
    grid-template-columns: 1fr;
  }
}

.runtime-status-center {
  display: grid;
  gap: 12px;
  margin: 0 0 18px;
  padding: 14px;
  border: 1px solid rgb(51 214 159 / 30%);
  border-radius: 8px;
  background: #11171a;
}

.runtime-quality-center {
  display: grid;
  gap: 12px;
  margin: 0 0 18px;
  padding: 14px;
  border: 1px solid rgb(255 204 102 / 28%);
  border-radius: 8px;
  background: #121619;
}

.health-report-panel {
  display: grid;
  gap: 12px;
  margin: 0 0 18px;
  padding: 14px;
  border: 1px solid rgb(102 217 239 / 34%);
  border-radius: 8px;
  background: #10161a;
}

.health-report-panel[hidden] {
  display: none;
}

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

.health-verdict {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--green);
  border-radius: 8px;
  background: #0e1317;
}

.health-verdict.warn {
  border-left-color: var(--gold);
}

.health-verdict.bad {
  border-left-color: var(--red);
}

.health-verdict span,
.health-verdict p {
  display: block;
  margin: 3px 0 0;
  color: var(--muted);
}

.health-verdict strong {
  display: block;
  margin-top: 4px;
  font-size: 20px;
}

.health-verdict b {
  padding: 7px 10px;
  border-radius: 6px;
  background: var(--panel-2);
}

.health-report-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

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

.health-report-grid article.bad {
  border-color: rgb(255 107 107 / 45%);
}

.health-report-grid article.warn {
  border-color: rgb(255 204 102 / 45%);
}

.health-report-grid strong,
.health-report-grid span {
  display: block;
}

.health-report-grid strong {
  font-size: 18px;
}

.health-report-grid span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

.health-report-bots {
  display: grid;
  gap: 8px;
}

.health-report-bots > article {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--green);
  border-radius: 8px;
  background: #0e1317;
}

.health-report-bots > article.warn {
  border-left-color: var(--gold);
}

.health-report-bots > article.bad {
  border-left-color: var(--red);
}

.health-report-bots header {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.health-report-bots header p,
.health-report-bots > article > p {
  margin: 3px 0 0;
  color: var(--muted);
}

.health-report-bots header span {
  font-weight: 800;
}

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

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

.health-report-bots dd {
  margin: 3px 0 0;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.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;
}

.runtime-head-actions,
.runtime-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.runtime-head-actions button,
.runtime-actions button {
  min-height: 34px;
  padding: 7px 10px;
}

.runtime-safety-state {
  padding: 6px 9px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--text);
  font-size: 12px;
  font-weight: 800;
}

.runtime-safety-state.good {
  border-color: rgb(51 214 159 / 50%);
  color: var(--green);
}

.runtime-safety-state.warn,
.runtime-safety-state.watch {
  border-color: rgb(255 204 102 / 55%);
  color: var(--gold);
}

.runtime-safety-state.bad {
  border-color: rgb(255 107 107 / 60%);
  color: var(--red);
}

.runtime-safety-note {
  margin: 0;
  padding: 9px 10px;
  border-left: 3px solid var(--gold);
  background: rgb(255 204 102 / 7%);
  color: var(--muted);
  font-size: 13px;
}

.runtime-readiness-list {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}

.runtime-readiness-list article {
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #0e1317;
}

.runtime-readiness-list article.passed {
  border-color: rgb(51 214 159 / 40%);
}

.runtime-readiness-list article.blocked {
  border-color: rgb(255 107 107 / 45%);
}

.runtime-readiness-list span {
  color: var(--muted);
  font-size: 11px;
}

.runtime-readiness-list .passed span {
  color: var(--green);
}

.runtime-readiness-list .blocked span {
  color: var(--red);
}

.runtime-readiness-list small {
  color: var(--muted);
  overflow-wrap: anywhere;
}

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

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

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

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

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

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

.runtime-summary .good,
.quality-summary .good {
  border-color: rgb(51 214 159 / 40%);
}

.runtime-summary .watch,
.runtime-summary .warn,
.quality-summary .warn {
  border-color: rgb(255 204 102 / 45%);
}

.runtime-summary .bad,
.quality-summary .bad {
  border-color: rgb(255 107 107 / 45%);
}

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

.decision-card,
.runtime-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;
}

.runtime-card {
  grid-template-columns: minmax(0, 1fr) 110px minmax(180px, 1fr) auto;
}

.quality-card {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) 64px minmax(220px, 1.5fr) auto;
  gap: 10px;
  align-items: start;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--line);
  border-radius: 8px;
  background: #0e1317;
}

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

.decision-card.watch,
.runtime-card.watch,
.runtime-card.warn,
.runtime-card.neutral,
.quality-card.warn {
  border-left-color: var(--gold);
}

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

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

.quality-card > span {
  color: var(--text);
  font-weight: 800;
  text-align: center;
}

.quality-card ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.quality-card li {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.quality-card b,
.quality-card small {
  overflow-wrap: anywhere;
}

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

.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,
  .runtime-card,
  .quality-card {
    grid-template-columns: 1fr;
  }

  .decision-summary,
  .runtime-summary,
  .runtime-readiness-list,
  .quality-summary,
  .health-report-grid,
  .health-report-bots dl {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .health-verdict {
    grid-template-columns: 1fr;
  }

  .read-only-grid,
  .read-only-list article,
  .exchange-key-fields {
    grid-template-columns: 1fr;
  }

  .read-only-head {
    align-items: flex-start;
  }

  .health-report-bots header {
    display: grid;
  }

  .decision-score,
  .decision-state,
  .quality-card > span,
  .runtime-head-actions,
  .runtime-actions {
    text-align: left;
    justify-content: flex-start;
  }
}

.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;
}
.config-section {
  margin-top: 10px;
  padding: 0 12px 12px;
  border-top: 1px solid var(--line);
}
.config-section > summary {
  padding: 12px 0 2px;
  color: var(--text);
  font-size: 13px;
}
.config-section[open] > summary {
  color: var(--green);
}
.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;
  }
}
