:root {
  color-scheme: dark;
  --bg: #070b0f;
  --panel: #101821;
  --panel-2: #14202b;
  --line: #263545;
  --text: #edf4f1;
  --muted: #9dacac;
  --green: #29f5b2;
  --red: #ff5277;
  --amber: #fbbf24;
  --blue: #60a5fa;
  --button: #29f5b2;
  --button-text: #06100d;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

a {
  color: inherit;
}

.lab-topbar {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--line);
  background: rgba(7, 11, 15, 0.94);
}

.back-link,
.subtext,
#status,
small {
  color: var(--muted);
}

.back-link {
  text-decoration: none;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
}

h1,
h2,
p {
  margin: 0;
}

h1 {
  margin-top: 4px;
  font-size: 26px;
}

h2 {
  font-size: 17px;
}

.controls,
.market-strip,
.section-head,
.actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
}

.check {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 38px;
}

input {
  height: 36px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #0d141b;
  color: var(--text);
  padding: 0 10px;
}

select {
  height: 36px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #0d141b;
  color: var(--text);
  padding: 0 10px;
}

input[type="number"] {
  width: 86px;
}

#access-token {
  width: 150px;
}

input[type="checkbox"] {
  width: 16px;
  height: 16px;
  padding: 0;
}

button,
.button-link {
  height: 36px;
  border: 0;
  border-radius: 6px;
  background: var(--button);
  color: var(--button-text);
  padding: 0 13px;
  font-weight: 800;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}

.mini-button {
  height: 30px;
  padding: 0 10px;
  border: 1px solid rgba(41, 245, 178, 0.34);
  background: rgba(41, 245, 178, 0.1);
  color: var(--green);
}

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

.ghost-button {
  border: 1px solid rgba(237, 244, 241, 0.18);
  background: rgba(237, 244, 241, 0.06);
  color: var(--text);
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}

.lab-shell {
  padding: 18px 22px 44px;
}

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

.metric,
.market-strip,
.clock-panel,
.strategy-panel,
.chart-panel,
.table-panel,
.paper-panel,
.trade-panel,
.auto-panel,
.panel {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel);
}

.metric {
  min-height: 88px;
  padding: 14px;
}

.metric span,
.market-strip span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
}

.metric strong {
  display: block;
  margin: 7px 0 5px;
  font-size: 24px;
}

.price-metric strong {
  color: var(--green);
  font-size: 32px;
  letter-spacing: 0;
}

.market-strip {
  display: grid;
  grid-template-columns: 1.2fr 1.2fr 1.4fr auto;
  gap: 10px;
  align-items: stretch;
  padding: 12px;
  margin-bottom: 14px;
}

.market-strip div {
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 8px;
  background: var(--panel-2);
}

.market-strip strong {
  display: block;
  margin: 5px 0 3px;
  overflow-wrap: anywhere;
}

.clock-panel {
  display: grid;
  grid-template-columns: minmax(180px, 260px) minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 14px;
  margin-bottom: 14px;
}

.clock-readout {
  padding: 14px;
  border: 1px solid rgba(41, 245, 178, 0.2);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(41, 245, 178, 0.12), rgba(96, 165, 250, 0.08));
}

.clock-readout span,
.clock-meta,
.clock-readout small {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
}

.clock-readout strong {
  display: block;
  margin: 5px 0 4px;
  color: var(--green);
  font-size: 42px;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
}

.clock-track-wrap {
  display: grid;
  gap: 8px;
}

.clock-track {
  position: relative;
  height: 18px;
  overflow: hidden;
  border: 1px solid rgba(237, 244, 241, 0.14);
  border-radius: 999px;
  background: #081017;
}

.clock-progress,
.settlement-progress {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 0%;
}

.clock-progress {
  background: linear-gradient(90deg, rgba(41, 245, 178, 0.95), rgba(96, 165, 250, 0.9));
}

.settlement-progress {
  left: auto;
  right: 0;
  background: rgba(251, 191, 36, 0.32);
  border-left: 1px solid rgba(251, 191, 36, 0.7);
}

.clock-meta {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.section-head {
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
}

.strategy-panel {
  margin-bottom: 14px;
}

.strategy-action {
  padding: 8px 10px;
  border-radius: 6px;
  background: rgba(251, 191, 36, 0.12);
  color: var(--amber);
  font-size: 13px;
}

.strategy-action.buy {
  background: rgba(41, 245, 178, 0.14);
  color: var(--green);
}

.strategy-action.sell {
  background: rgba(255, 82, 119, 0.14);
  color: var(--red);
}

.strategy-controls {
  display: grid;
  grid-template-columns: repeat(8, minmax(92px, 1fr));
  gap: 10px;
  padding: 14px;
  border-bottom: 1px solid rgba(237, 244, 241, 0.08);
}

.strategy-controls input,
.strategy-controls select {
  width: 100%;
}

.strategy-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(150px, 1fr));
  gap: 10px;
  padding: 14px;
}

.strategy-card {
  display: grid;
  gap: 7px;
  min-height: 112px;
  padding: 12px;
  border: 1px solid rgba(237, 244, 241, 0.1);
  border-radius: 8px;
  background: #0d141b;
}

.strategy-card span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.strategy-card strong {
  color: var(--amber);
  font-size: 18px;
}

.strategy-card.pos strong {
  color: var(--green);
}

.strategy-card.sell strong,
.strategy-card.neg strong {
  color: var(--red);
}

.strategy-card small {
  line-height: 1.45;
}

.strategy-rules {
  display: grid;
  gap: 8px;
  padding: 0 14px 14px;
}

.strategy-rules p {
  padding: 10px 12px;
  border: 1px solid rgba(237, 244, 241, 0.08);
  border-radius: 8px;
  background: var(--panel-2);
  color: var(--muted);
  line-height: 1.45;
}

.paper-panel {
  position: relative;
  margin-bottom: 14px;
}

.paper-panel.paper-floating {
  position: fixed;
  z-index: 80;
  top: 86px;
  right: 22px;
  width: min(720px, calc(100vw - 32px));
  max-height: calc(100vh - 104px);
  overflow: auto;
  resize: both;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.55);
}

.paper-panel.paper-floating .paper-drag-handle {
  cursor: move;
  user-select: none;
}

.paper-panel:not(.paper-floating) #paper-dock,
.paper-panel.paper-floating #paper-float {
  display: none;
}

.paper-window-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

#paper-status {
  padding: 8px 10px;
  border-radius: 6px;
  background: rgba(96, 165, 250, 0.12);
  color: var(--blue);
  font-size: 13px;
}

#paper-status.pos {
  background: rgba(41, 245, 178, 0.14);
  color: var(--green);
}

#paper-status.neg {
  background: rgba(255, 82, 119, 0.14);
  color: var(--red);
}

.paper-collapse-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  min-height: 42px;
  padding: 10px 14px;
  border: 0;
  border-top: 1px solid rgba(237, 244, 241, 0.08);
  border-bottom: 1px solid rgba(237, 244, 241, 0.08);
  border-radius: 0;
  background: #0a1118;
  color: var(--text);
  text-align: left;
}

.paper-collapse-toggle:hover,
.paper-collapse-toggle:focus-visible {
  background: #101923;
}

.paper-collapse-title {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.paper-collapse-title strong {
  font-size: 13px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.paper-collapse-title small {
  overflow: hidden;
  color: var(--muted);
  font-size: 11px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.paper-collapse-state {
  flex: 0 0 auto;
  border: 1px solid rgba(237, 244, 241, 0.13);
  border-radius: 999px;
  padding: 5px 9px;
  color: var(--green);
  font-size: 11px;
  font-weight: 800;
}

.paper-collapse-toggle.is-collapsed .paper-collapse-state {
  color: var(--blue);
}

.paper-collapsible-body[hidden],
.paper-bot-controls[hidden] {
  display: none !important;
}

.paper-desks {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(360px, 0.95fr);
  gap: 12px;
  align-items: end;
  padding: 14px;
  border-bottom: 1px solid rgba(237, 244, 241, 0.08);
  background: #071017;
}

.desk-label {
  display: block;
  margin-bottom: 8px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.paper-account-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.paper-account-tab {
  display: grid;
  gap: 2px;
  min-width: 150px;
  padding: 10px 12px;
  border: 1px solid rgba(237, 244, 241, 0.14);
  border-radius: 8px;
  background: #0d141b;
  color: var(--text);
  text-align: left;
}

.paper-account-tab strong,
.paper-account-tab span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.paper-account-tab span {
  color: var(--muted);
  font-size: 11px;
}

.paper-account-tab.active {
  border-color: rgba(41, 245, 178, 0.48);
  background: linear-gradient(135deg, rgba(41, 245, 178, 0.13), rgba(96, 165, 250, 0.08));
}

.paper-account-actions {
  display: grid;
  grid-template-columns: minmax(140px, 1fr) repeat(3, max-content);
  gap: 10px;
  align-items: end;
}

.paper-account-actions input {
  width: 100%;
}

.paper-account-comparison {
  display: grid;
  gap: 8px;
  padding: 14px;
  border-bottom: 1px solid rgba(237, 244, 241, 0.08);
  background: #050b10;
}

.paper-account-comparison h3 {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.paper-desk-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 8px;
}

.paper-desk-card {
  display: grid;
  gap: 5px;
  padding: 10px;
  border: 1px solid rgba(237, 244, 241, 0.1);
  border-radius: 8px;
  background: #0d141b;
}

.paper-desk-card.active {
  border-color: rgba(41, 245, 178, 0.34);
}

.paper-desk-card strong {
  color: var(--text);
  font-size: 14px;
}

.paper-desk-card span {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.35;
}

.paper-headline {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(136px, 1fr));
  gap: 10px;
  padding: 14px;
  border-bottom: 1px solid rgba(237, 244, 241, 0.08);
  background: radial-gradient(circle at top left, rgba(41, 245, 178, 0.12), transparent 48%), #071017;
}

.paper-headline-card {
  display: grid;
  gap: 4px;
  min-height: 82px;
  padding: 12px;
  border: 1px solid rgba(237, 244, 241, 0.12);
  border-radius: 8px;
  background: rgba(13, 20, 27, 0.92);
}

.paper-headline-card.primary {
  border-color: rgba(41, 245, 178, 0.36);
  background: linear-gradient(135deg, rgba(41, 245, 178, 0.14), rgba(96, 165, 250, 0.08));
}

.paper-headline-card span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.paper-headline-card strong {
  color: var(--text);
  font-size: 26px;
  line-height: 1.05;
  font-variant-numeric: tabular-nums;
}

.paper-headline-card.primary strong {
  color: var(--green);
  font-size: 32px;
}

.paper-headline-card small {
  color: var(--muted);
  line-height: 1.35;
}

.paper-headline-card.pos strong {
  color: var(--green);
}

.paper-headline-card.neg strong {
  color: var(--red);
}

.paper-bots {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
  align-items: stretch;
  padding: 14px;
  border-bottom: 1px solid rgba(237, 244, 241, 0.08);
  background: #071017;
}

.paper-bot-card {
  display: grid;
  gap: 8px;
  min-height: 86px;
  padding: 12px;
  border: 1px solid rgba(237, 244, 241, 0.12);
  border-radius: 8px;
  background: #0d141b;
  cursor: pointer;
}

.paper-sim-bot-card {
  grid-column: 1 / -1;
  cursor: default;
}

.paper-bot-card span:last-child {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.paper-sim-bot-card > span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.paper-sim-bot-collapse {
  justify-self: start;
  min-height: 32px;
  padding: 7px 10px;
  border: 1px solid rgba(96, 165, 250, 0.25);
  border-radius: 6px;
  background: rgba(96, 165, 250, 0.1);
  color: var(--blue);
  font-size: 12px;
  font-weight: 800;
}

.paper-sim-bot-collapse:hover,
.paper-sim-bot-collapse:focus-visible {
  background: rgba(96, 165, 250, 0.18);
}

.paper-sim-bot-card.is-sim-bot-compact {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  min-height: 0;
}

.paper-sim-bot-card.is-sim-bot-compact > span {
  display: none;
}

.paper-sim-bot-card.is-sim-bot-compact .paper-sim-bot-collapse {
  justify-self: end;
}

.paper-bot-toggle {
  display: flex;
  align-items: center;
  gap: 9px;
}

.paper-bot-toggle input {
  width: 18px;
  height: 18px;
  accent-color: var(--green);
}

.paper-bot-toggle strong {
  font-size: 15px;
}

.paper-bot-controls {
  display: grid;
  grid-template-columns: repeat(3, minmax(88px, 1fr));
  gap: 8px;
}

.paper-bot-controls label {
  color: var(--muted);
  font-size: 11px;
}

.paper-bot-controls input,
.paper-bot-controls select {
  width: 100%;
  min-height: 34px;
  margin-top: 4px;
  padding: 7px 8px;
  border: 1px solid rgba(237, 244, 241, 0.12);
  border-radius: 6px;
  background: #070b10;
  color: var(--text);
}

.paper-bot-controls .danger-button {
  align-self: end;
  min-height: 34px;
  padding: 7px 10px;
}

.paper-server-bot-status {
  padding: 10px;
  border: 1px solid rgba(41, 245, 178, 0.18);
  border-radius: 8px;
  background: rgba(41, 245, 178, 0.06);
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.paper-server-bot-status.pos {
  border-color: rgba(41, 245, 178, 0.34);
  color: var(--green);
}

.paper-server-bot-status.neg {
  border-color: rgba(255, 82, 119, 0.34);
  background: rgba(255, 82, 119, 0.08);
  color: var(--red);
}

.paper-auto-status {
  display: grid;
  align-content: center;
  min-height: 86px;
  padding: 12px;
  border: 1px solid rgba(96, 165, 250, 0.22);
  border-radius: 8px;
  background: rgba(96, 165, 250, 0.08);
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.paper-auto-status.pos {
  border-color: rgba(41, 245, 178, 0.34);
  background: rgba(41, 245, 178, 0.1);
  color: var(--green);
}

.paper-auto-status.neg {
  border-color: rgba(255, 82, 119, 0.34);
  background: rgba(255, 82, 119, 0.1);
  color: var(--red);
}

.paper-settings-row {
  display: grid;
  grid-template-columns: minmax(110px, 150px) minmax(130px, 170px) max-content max-content;
  gap: 10px;
  align-items: end;
  padding: 14px;
  border-bottom: 1px solid rgba(237, 244, 241, 0.08);
}

.paper-settings-row input,
.paper-settings-row select {
  width: 100%;
}

.paper-settings-row input[readonly] {
  border-color: rgba(41, 245, 178, 0.24);
  background: rgba(41, 245, 178, 0.08);
  color: var(--green);
}

.paper-ticket {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-bottom: 1px solid rgba(237, 244, 241, 0.08);
  background: linear-gradient(180deg, rgba(13, 20, 27, 0.82), rgba(8, 15, 22, 0.96));
}

.paper-hidden-selects {
  display: none;
}

.paper-action-tabs,
.paper-ticket-actions,
.paper-ticket-fields {
  display: grid;
  gap: 10px;
}

.paper-action-tabs {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: 4px;
  border: 1px solid rgba(237, 244, 241, 0.12);
  border-radius: 8px;
  background: #050b10;
}

.paper-tab {
  min-height: 38px;
  border-color: transparent;
  background: transparent;
  color: var(--muted);
}

.paper-tab.active {
  background: rgba(41, 245, 178, 0.16);
  color: var(--green);
}

.paper-tab.sell.active {
  background: rgba(255, 82, 119, 0.14);
  color: var(--red);
}

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

.paper-side-button {
  display: grid;
  gap: 4px;
  min-height: 86px;
  padding: 12px;
  text-align: left;
  border: 1px solid rgba(237, 244, 241, 0.12);
  border-radius: 8px;
  background: #0a1118;
}

.paper-side-button span,
.paper-ticket-preview span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.paper-side-button strong {
  font-size: 28px;
}

.paper-side-button.yes strong {
  color: var(--green);
}

.paper-side-button.no strong {
  color: var(--red);
}

.paper-side-button.active {
  border-color: rgba(41, 245, 178, 0.62);
  box-shadow: inset 0 0 0 1px rgba(41, 245, 178, 0.22);
}

.paper-side-button.no.active {
  border-color: rgba(255, 82, 119, 0.54);
  box-shadow: inset 0 0 0 1px rgba(255, 82, 119, 0.18);
}

.paper-ticket-fields {
  grid-template-columns: minmax(110px, 1fr) minmax(150px, 1.2fr);
}

.paper-ticket-fields input {
  width: 100%;
}

.paper-price-input {
  display: grid;
  grid-template-columns: minmax(0, 1fr) max-content;
  gap: 8px;
}

.paper-ticket-preview {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(237, 244, 241, 0.1);
  border-radius: 8px;
  background: #050b10;
}

.paper-ticket-preview div {
  display: grid;
  gap: 4px;
}

.paper-ticket-preview strong {
  font-size: 16px;
  font-variant-numeric: tabular-nums;
}

.paper-ticket-preview .pos strong {
  color: var(--green);
}

.paper-ticket-preview .wait strong {
  color: var(--amber);
}

.paper-ticket-actions {
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
}

.paper-ticket-actions #paper-buy-best {
  position: relative;
  justify-content: center;
  min-height: 42px;
  overflow: hidden;
  border: 1px solid rgba(41, 245, 178, 0.5);
  background: linear-gradient(180deg, #45ffd0 0%, #21d99e 100%);
  box-shadow:
    0 10px 22px rgba(41, 245, 178, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.26),
    inset 0 -3px 0 rgba(0, 0, 0, 0.22);
  transform: translateY(0) scale(1);
  transition:
    background 150ms ease,
    border-color 150ms ease,
    box-shadow 150ms ease,
    transform 90ms ease;
}

.paper-ticket-actions #paper-buy-best.sell {
  border-color: rgba(255, 82, 119, 0.5);
  background: linear-gradient(180deg, #ff7a98 0%, #ff5277 100%);
  box-shadow:
    0 10px 22px rgba(255, 82, 119, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.24),
    inset 0 -3px 0 rgba(0, 0, 0, 0.22);
  color: #18060b;
}

.paper-ticket-actions #paper-buy-best:hover,
.paper-ticket-actions #paper-buy-best:focus-visible {
  box-shadow:
    0 14px 28px rgba(41, 245, 178, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.3),
    inset 0 -3px 0 rgba(0, 0, 0, 0.24);
  transform: translateY(-1px);
}

.paper-ticket-actions #paper-buy-best.sell:hover,
.paper-ticket-actions #paper-buy-best.sell:focus-visible {
  box-shadow:
    0 14px 28px rgba(255, 82, 119, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.3),
    inset 0 -3px 0 rgba(0, 0, 0, 0.24);
}

.paper-ticket-actions #paper-buy-best:active,
.paper-ticket-actions #paper-buy-best.is-pressing {
  box-shadow:
    0 4px 10px rgba(41, 245, 178, 0.14),
    inset 0 2px 7px rgba(0, 0, 0, 0.28);
  transform: translateY(2px) scale(0.985);
}

.paper-ticket-actions #paper-buy-best.sell:active,
.paper-ticket-actions #paper-buy-best.sell.is-pressing {
  box-shadow:
    0 4px 10px rgba(255, 82, 119, 0.14),
    inset 0 2px 7px rgba(0, 0, 0, 0.28);
}

.paper-ticket-actions #paper-buy-best::after {
  position: absolute;
  inset: 50% auto auto 50%;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.58);
  content: "";
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, -50%) scale(0);
}

.paper-ticket-actions #paper-buy-best.is-order-placed::after {
  animation: paperLimitRipple 620ms ease-out;
}

.paper-ticket-actions #paper-buy-best.is-order-placed {
  animation: paperLimitPlaced 620ms ease-out;
}

.paper-ticket-actions #paper-buy-best.is-order-placed.is-order-sell {
  animation-name: paperLimitSellPlaced;
}

@keyframes paperLimitRipple {
  0% {
    opacity: 0.8;
    transform: translate(-50%, -50%) scale(0);
  }
  100% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(42);
  }
}

@keyframes paperLimitPlaced {
  0% {
    box-shadow:
      0 4px 10px rgba(41, 245, 178, 0.14),
      inset 0 2px 7px rgba(0, 0, 0, 0.28);
    transform: translateY(2px) scale(0.985);
  }
  38% {
    box-shadow:
      0 0 0 4px rgba(41, 245, 178, 0.16),
      0 16px 30px rgba(41, 245, 178, 0.24),
      inset 0 1px 0 rgba(255, 255, 255, 0.34);
    transform: translateY(-1px) scale(1.018);
  }
  100% {
    transform: translateY(0) scale(1);
  }
}

@keyframes paperLimitSellPlaced {
  0% {
    box-shadow:
      0 4px 10px rgba(255, 82, 119, 0.14),
      inset 0 2px 7px rgba(0, 0, 0, 0.28);
    transform: translateY(2px) scale(0.985);
  }
  38% {
    box-shadow:
      0 0 0 4px rgba(255, 82, 119, 0.16),
      0 16px 30px rgba(255, 82, 119, 0.24),
      inset 0 1px 0 rgba(255, 255, 255, 0.34);
    transform: translateY(-1px) scale(1.018);
  }
  100% {
    transform: translateY(0) scale(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .paper-ticket-actions #paper-buy-best {
    transition: none;
  }

  .paper-ticket-actions #paper-buy-best.is-order-placed,
  .paper-ticket-actions #paper-buy-best.is-order-placed::after {
    animation: none;
  }
}

.paper-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(138px, 1fr));
  gap: 10px;
  padding: 14px;
}

.paper-metric {
  display: grid;
  gap: 5px;
  min-height: 84px;
  padding: 12px;
  border: 1px solid rgba(237, 244, 241, 0.1);
  border-radius: 8px;
  background: #0d141b;
}

.paper-metric span,
.paper-history h3 {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.paper-metric strong {
  font-size: 22px;
}

.paper-metric small {
  line-height: 1.35;
}

.paper-table-wrap {
  overflow: auto;
  border-top: 1px solid rgba(237, 244, 241, 0.08);
}

.paper-table-wrap table {
  min-width: 920px;
}

.paper-orders {
  display: grid;
  gap: 8px;
  padding: 14px;
  border-top: 1px solid rgba(237, 244, 241, 0.08);
}

.paper-orders h3,
.paper-history h3 {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

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

.paper-order-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid rgba(237, 244, 241, 0.1);
  border-radius: 8px;
  background: #0d141b;
}

.paper-order-item strong {
  display: block;
  margin-bottom: 4px;
}

.paper-history {
  display: grid;
  gap: 8px;
  padding: 14px;
  border-top: 1px solid rgba(237, 244, 241, 0.08);
}

.paper-history-list {
  display: grid;
  gap: 8px;
  max-height: 220px;
  overflow: auto;
}

.paper-history-item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px;
  border: 1px solid rgba(237, 244, 241, 0.1);
  border-radius: 8px;
  background: #0d141b;
}

.paper-history-item strong {
  font-size: 13px;
}

.paper-history-item small {
  text-align: right;
}

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

.paper-panel.paper-floating .paper-headline {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.paper-panel.paper-floating .paper-bots {
  grid-template-columns: 1fr;
}

.paper-panel.paper-floating .paper-desks,
.paper-panel.paper-floating .paper-account-actions,
.paper-panel.paper-floating .paper-desk-grid {
  grid-template-columns: 1fr;
}

.paper-panel.paper-floating .paper-settings-row,
.paper-panel.paper-floating .paper-ticket-fields,
.paper-panel.paper-floating .paper-ticket-preview,
.paper-panel.paper-floating .paper-ticket-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.paper-panel.paper-floating .paper-settings-row button,
.paper-panel.paper-floating .paper-ticket-actions button {
  width: 100%;
}

.chart-stage {
  position: relative;
  min-height: 430px;
  padding: 14px;
}

.live-price-card {
  position: absolute;
  top: 26px;
  right: 28px;
  z-index: 2;
  min-width: 218px;
  padding: 13px 14px;
  border: 1px solid rgba(41, 245, 178, 0.34);
  border-radius: 8px;
  background: rgba(6, 16, 20, 0.92);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.28);
}

.chart-decision-card,
.chart-hover-card {
  position: absolute;
  z-index: 3;
  border: 1px solid rgba(237, 244, 241, 0.14);
  border-radius: 8px;
  background: rgba(6, 16, 20, 0.94);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.28);
}

.chart-decision-card {
  top: 128px;
  right: 28px;
  display: grid;
  gap: 5px;
  min-width: 218px;
  padding: 12px 14px;
}

.chart-decision-card span,
.chart-hover-card span,
.chart-hover-card small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
}

.chart-decision-card strong {
  color: var(--amber);
  font-size: 16px;
}

.chart-decision-card.buy strong,
.chart-decision-card.buy span {
  color: var(--green);
}

.chart-decision-card.sell strong,
.chart-decision-card.sell span {
  color: var(--red);
}

.chart-decision-card small {
  line-height: 1.35;
}

.chart-hover-card {
  pointer-events: none;
  width: 224px;
  padding: 10px 12px;
}

.chart-hover-card strong {
  display: block;
  margin-bottom: 4px;
  color: var(--green);
  font-size: 14px;
}

.live-price-card span,
.live-price-card small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
}

.live-price-card strong {
  display: block;
  margin: 5px 0;
  color: var(--green);
  font-size: 32px;
  line-height: 1;
}

.chart-svg {
  display: block;
  width: 100%;
  height: auto;
  min-height: 390px;
}

.chart-bg {
  fill: #0a1118;
}

.grid {
  stroke: rgba(157, 172, 172, 0.18);
}

.grid.major {
  stroke: rgba(237, 244, 241, 0.26);
}

.axis-label,
.line-label {
  fill: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.axis-left,
.axis-right {
  fill: rgba(237, 244, 241, 0.86);
}

.price-line {
  fill: none;
  stroke: var(--blue);
  stroke-width: 3;
}

.target-line {
  stroke: var(--amber);
  stroke-width: 2.5;
  stroke-dasharray: 8 6;
}

.current-line {
  stroke: rgba(41, 245, 178, 0.36);
  stroke-width: 1.5;
  stroke-dasharray: 4 6;
}

.current-plane {
  filter: drop-shadow(0 0 8px rgba(41, 245, 178, 0.52));
}

.plane-shadow {
  fill: rgba(0, 0, 0, 0.34);
  transform: translate(2px, 2px);
}

.plane-body {
  fill: var(--green);
  stroke: #06221a;
  stroke-width: 1.7;
  stroke-linejoin: round;
}

.plane-wing {
  fill: rgba(237, 244, 241, 0.72);
  stroke: rgba(6, 34, 26, 0.65);
  stroke-width: 0.8;
  stroke-linejoin: round;
}

.price-label-bg {
  stroke-width: 1;
}

.current-bg {
  fill: rgba(41, 245, 178, 0.16);
  stroke: rgba(41, 245, 178, 0.5);
}

.target-bg {
  fill: rgba(251, 191, 36, 0.14);
  stroke: rgba(251, 191, 36, 0.48);
}

.current-label {
  fill: var(--green);
  font-size: 14px;
  font-weight: 900;
}

.target-label {
  fill: var(--amber);
  font-size: 13px;
  font-weight: 900;
}

.last-price-tag {
  fill: var(--green);
  font-size: 13px;
  font-weight: 900;
  paint-order: stroke;
  stroke: rgba(7, 11, 15, 0.9);
  stroke-width: 5px;
  stroke-linejoin: round;
}

.settle-band {
  fill: rgba(251, 191, 36, 0.13);
}

.open-band {
  fill: rgba(96, 165, 250, 0.08);
}

.entry-band {
  fill: rgba(41, 245, 178, 0.08);
  stroke: rgba(41, 245, 178, 0.16);
}

.win-zone {
  opacity: 0.28;
}

.yes-zone {
  fill: rgba(41, 245, 178, 0.12);
}

.no-zone {
  fill: rgba(255, 82, 119, 0.12);
}

.now-line {
  stroke: rgba(237, 244, 241, 0.72);
  stroke-width: 1.5;
  stroke-dasharray: 2 6;
}

.entry-label {
  fill: var(--green);
}

.now-label {
  fill: var(--text);
}

.table-wrap {
  overflow: auto;
}

.trade-panel {
  margin-top: 14px;
}

.auto-panel {
  margin-top: 14px;
}

.trade-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 260px);
  gap: 14px;
  padding: 14px;
}

.ticket-card {
  min-height: 126px;
  padding: 14px;
  border: 1px solid rgba(237, 244, 241, 0.12);
  border-radius: 8px;
  background: var(--panel-2);
}

.ticket-main {
  display: grid;
  gap: 7px;
}

.ticket-main strong {
  font-size: 24px;
}

.ticket-facts {
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: 8px;
  margin-top: 14px;
}

.ticket-facts p {
  display: grid;
  gap: 4px;
  padding: 10px;
  border: 1px solid rgba(237, 244, 241, 0.09);
  border-radius: 8px;
  background: #0d141b;
}

.ticket-facts span,
.ticket-actions small {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
}

.ticket-list {
  display: grid;
  gap: 6px;
  margin-top: 12px;
}

.ticket-list p {
  padding: 8px 10px;
  border-radius: 6px;
}

.bad-list p {
  background: rgba(255, 82, 119, 0.12);
  color: var(--red);
}

.warn-list p {
  background: rgba(251, 191, 36, 0.12);
  color: var(--amber);
}

.ticket-actions {
  display: grid;
  align-content: start;
  gap: 10px;
}

.auto-grid {
  display: grid;
  grid-template-columns: minmax(140px, 180px) repeat(3, minmax(110px, 140px)) minmax(180px, 1fr);
  gap: 12px;
  align-items: end;
  padding: 14px;
}

.auto-log {
  display: grid;
  gap: 8px;
  max-height: 220px;
  overflow: auto;
  padding: 0 14px 14px;
}

.auto-entry {
  display: grid;
  gap: 5px;
  padding: 10px;
  border: 1px solid rgba(237, 244, 241, 0.1);
  border-radius: 8px;
  background: #0d141b;
}

.auto-entry strong {
  font-size: 13px;
}

.auto-entry small {
  line-height: 1.4;
}

table {
  width: 100%;
  min-width: 1080px;
  border-collapse: collapse;
}

th,
td {
  padding: 11px 13px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}

th {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  background: #111922;
}

.side-pill,
.call-pill {
  display: inline-flex;
  min-width: 46px;
  justify-content: center;
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
}

.side-pill.yes,
.call-pill.good {
  background: rgba(41, 245, 178, 0.13);
  color: var(--green);
}

.side-pill.no,
.call-pill.bad {
  background: rgba(255, 82, 119, 0.13);
  color: var(--red);
}

.call-pill.watch {
  background: rgba(251, 191, 36, 0.13);
  color: var(--amber);
}

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

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

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

.reason-list {
  display: grid;
  gap: 8px;
  padding: 14px;
}

.reason-list p {
  color: var(--muted);
  line-height: 1.5;
}

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

  .summary-grid,
  .market-strip,
  .clock-panel,
  .strategy-controls,
  .strategy-grid,
  .paper-desks,
  .paper-account-actions,
  .paper-settings-row,
  .paper-headline,
  .paper-bots,
  .paper-ticket-fields,
  .paper-ticket-preview,
  .paper-ticket-actions,
  .paper-summary,
  .paper-bot-controls,
  .trade-grid,
  .auto-grid,
  .split {
    grid-template-columns: 1fr;
  }

  .ticket-facts {
    grid-template-columns: 1fr;
  }

  .paper-history-item,
  .paper-order-item {
    align-items: flex-start;
  }

  .paper-history-item {
    flex-direction: column;
  }

  .paper-order-item {
    grid-template-columns: 1fr;
  }

  .paper-history-item small {
    text-align: left;
  }

  input,
  select,
  #access-token,
  button,
  .button-link {
    width: 100%;
  }

  .live-price-card {
    position: static;
    margin-bottom: 10px;
  }

  .chart-decision-card {
    position: static;
    margin-bottom: 10px;
  }
}
