/* Trading terminal (task-0132 hologram revamp). Bloomberg-style command surface
   with glass morphism panels, holographic glow, cyan data accents.
   Color discipline: green (--up) / red (--down) reserved for P&L only. */

.trading-main {
  --up:           #2ee6a8;
  --down:         #ff5c6c;
  --panel-bg:     rgba(8, 10, 20, 0.78);
  --panel-border: rgba(245, 158, 11, 0.20);
  --grid-line:    rgba(245, 158, 11, 0.09);

  max-width: 1640px;
  margin: 0 auto;
  padding: 1.1rem 1.25rem 2rem;
  width: 100%;
  overflow-x: hidden;
}

.mono {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

/* Grid: 4 tiles on top, full-width panels below */
.trading-grid {
  display: grid;
  gap: 0.85rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.tpanel.span { grid-column: 1 / -1; }

/* Panel frame: glass morphism */
.tpanel {
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: var(--panel-bg);
  backdrop-filter: blur(18px) saturate(1.3);
  -webkit-backdrop-filter: blur(18px) saturate(1.3);
  border: 1px solid var(--panel-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow), inset 0 1px 0 rgba(245,158,11,0.06);
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
.tpanel:hover {
  border-color: rgba(245,158,11,0.32);
  box-shadow: var(--shadow), 0 0 18px rgba(245,158,11,0.10), inset 0 1px 0 rgba(245,158,11,0.08);
}

.tpanel-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.55rem 0.75rem;
  border-bottom: 1px solid var(--grid-line);
  background: rgba(5,5,10,0.35);
}
.tpanel-head h2 {
  margin: 0;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #f6e7bd;
  text-shadow: 0 0 10px rgba(245,158,11,0.25);
}
.tpanel-meta {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
}
.tpanel-body {
  flex: 1;
  padding: 0.75rem;
  font-size: 0.82rem;
  color: var(--text);
  min-width: 0;
}
.tskel, .tempty {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--text-dim);
  opacity: 0.7;
  letter-spacing: 0.06em;
}
.tnote {
  margin-top: 0.5rem;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  color: var(--text-dim);
  opacity: 0.8;
}

/* Key/value rows */
.kv {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.6rem;
  padding: 0.18rem 0;
  border-bottom: 1px dotted var(--grid-line);
}
.kv:last-child { border-bottom: none; }
.kv > span:first-child {
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  color: var(--text-dim);
  text-transform: uppercase;
}
.kv > span:last-child { color: var(--text); }

.up   { color: var(--up);   text-shadow: 0 0 8px rgba(46,230,168,0.35); }
.down { color: var(--down); text-shadow: 0 0 8px rgba(255,92,108,0.35); }

.stop-badge {
  display: inline-block;
  font-size: 0.65rem;
  font-family: var(--font-mono, monospace);
  padding: 0 0.35em;
  border-radius: 3px;
  vertical-align: middle;
  margin-left: 0.3em;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.stop-hard       { background: rgba(220,50,50,0.18);  color: var(--down); }
.stop-breakeven  { background: rgba(180,140,0,0.22);  color: #f0b429; }
.stop-in_profit  { background: rgba(50,200,100,0.18); color: var(--up); }

/* 1. System status */
.statusbar {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.6rem;
}
.state-badge {
  font-family: var(--font-mono);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  padding: 0.25rem 0.6rem;
  border-radius: var(--radius);
  border: 1px solid transparent;
}
.state-badge.active {
  color: var(--accent-text);
  background: var(--grad-accent);
  box-shadow: var(--glow-soft);
}
.state-badge.paused {
  color: var(--warn);
  background: var(--warn-bg);
  border-color: rgba(255,200,87,0.4);
  box-shadow: 0 0 10px rgba(255,200,87,0.15);
}
.state-badge.shutdown {
  color: var(--down);
  background: var(--danger-bg);
  border-color: rgba(255,92,108,0.45);
  box-shadow: 0 0 10px rgba(255,92,108,0.15);
}
.state-badge.chop {
  color: var(--warn);
  background: var(--warn-bg);
  border-color: rgba(255,200,87,0.4);
}
.tbtn {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 0.74rem;
  padding: 0.3rem 0.7rem;
  border: 1px solid rgba(245,158,11,0.22);
  background: rgba(10,12,22,0.75);
  color: var(--text);
  border-radius: var(--radius);
  cursor: pointer;
  transition: all 0.18s ease;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}
.tbtn:hover {
  border-color: var(--accent);
  color: var(--accent);
  box-shadow: var(--glow-soft);
}
.tbtn:disabled { opacity: 0.5; cursor: default; }

.feeds { display: flex; flex-direction: column; gap: 0.15rem; }
.feed  { display: flex; justify-content: space-between; gap: 0.5rem; font-size: 0.72rem; }
.feed-label { color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.04em; }
.feed-val   { color: var(--text); }

/* 2. Position */
.flat {
  font-family: var(--font-mono);
  font-size: 0.9rem;
  letter-spacing: 0.08em;
  color: var(--text-dim);
  padding: 0.4rem 0;
}
.pos-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 0.4rem;
}
.pos-sym {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--accent);
  text-shadow: 0 0 10px rgba(245,158,11,0.35);
}
.pos-upl { font-size: 1.05rem; font-weight: 700; }
.pbar {
  position: relative;
  height: 6px;
  margin-top: 0.6rem;
  background: rgba(14,17,30,0.80);
  border-radius: 999px;
  overflow: visible;
  border: 1px solid rgba(245,158,11,0.10);
}
.pbar-fill {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  background: var(--grad-accent);
  border-radius: 999px;
  box-shadow: 0 0 8px rgba(245,158,11,0.35);
}
.pbar-mark {
  position: absolute;
  top: -3px;
  width: 2px; height: 12px;
  background: var(--text);
  transform: translateX(-1px);
}
.pbar-ends {
  display: flex;
  justify-content: space-between;
  font-size: 0.64rem;
  color: var(--text-dim);
  margin-top: 0.3rem;
}

/* 3. Performance */
.perf-pnl {
  font-size: 1.7rem;
  font-weight: 800;
  line-height: 1.1;
}
.perf-pct   { font-size: 0.95rem; font-weight: 600; }
.perf-grid  { margin: 0.5rem 0; }
.budget     { margin-top: 0.4rem; }
.budget-bar {
  height: 6px;
  background: rgba(14,17,30,0.80);
  border: 1px solid rgba(245,158,11,0.10);
  border-radius: 999px;
  overflow: hidden;
}
.budget-bar > span {
  display: block;
  height: 100%;
  background: var(--grad-accent);
  border-radius: 999px;
  transition: width 0.4s ease;
  box-shadow: 0 0 6px rgba(245,158,11,0.35);
}
.budget-bar > span.danger { background: var(--down); box-shadow: 0 0 6px rgba(255,92,108,0.35); }
.budget-label {
  margin-top: 0.25rem;
  font-family: var(--font-mono);
  font-size: 0.64rem;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* 4. GEX */
.gex-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 0.8rem; }
.gex-meta {
  margin-top: 0.5rem;
  font-family: var(--font-mono);
  font-size: 0.64rem;
  color: var(--text-dim);
}

/* Log tables */
.tlog-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.tlog {
  width: 100%;
  min-width: 480px;
  border-collapse: collapse;
  font-size: 0.76rem;
}
.tlog th {
  text-align: left;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-dim);
  padding: 0.25rem 0.5rem;
  border-bottom: 1px solid var(--panel-border);
  position: sticky;
  top: 0;
  background: rgba(5,5,10,0.90);
  backdrop-filter: blur(8px);
}
.tlog td {
  padding: 0.3rem 0.5rem;
  border-bottom: 1px solid var(--grid-line);
  vertical-align: top;
}
.tlog tbody tr.exp { cursor: pointer; }
.tlog tbody tr.exp:hover { background: rgba(245,158,11,0.05); }
.tlog tbody tr.exp.open  { background: rgba(245,158,11,0.07); }
.tlog .reason { color: var(--text-dim); max-width: 0; }
.tlog tr.detail td { background: var(--code-bg); }
.tlog tr.detail pre {
  margin: 0;
  padding: 0.5rem 0.6rem;
  font-size: 0.7rem;
  color: var(--text-dim);
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 320px;
  overflow: auto;
}

.dir   { font-family: var(--font-mono); font-weight: 700; }
.order { margin-left: 0.4rem; color: var(--text-dim); font-size: 0.7rem; }

/* Decision verdict badges */
.dbadge {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 0.08rem 0.4rem;
  border-radius: 4px;
  background: var(--chip-bg);
  color: var(--text-dim);
  border: 1px solid rgba(245,158,11,0.10);
}
.dbadge.take {
  color: var(--accent);
  background: rgba(245,158,11,0.12);
  border-color: rgba(245,158,11,0.40);
  box-shadow: 0 0 6px rgba(245,158,11,0.15);
}
.dbadge.wait {
  color: var(--warn);
  background: var(--warn-bg);
  border-color: rgba(255,200,87,0.35);
}
.dbadge.skip { color: var(--text-dim); }

.chip {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.04em;
  padding: 0.06rem 0.4rem;
  border-radius: 999px;
  background: var(--chip-bg);
  color: #f6e7bd;
  border: 1px solid rgba(245,158,11,0.14);
}
.chip.win  { color: var(--up);   border-color: rgba(46,230,168,0.4);  box-shadow: 0 0 6px rgba(46,230,168,0.18); }
.chip.loss { color: var(--down); border-color: rgba(255,92,108,0.4);  box-shadow: 0 0 6px rgba(255,92,108,0.18); }
.chip.open { color: var(--accent); border-color: rgba(245,158,11,0.4); box-shadow: 0 0 6px rgba(245,158,11,0.18); }

.trade-totals {
  display: flex;
  gap: 1.2rem;
  padding: 0.5rem 0.5rem 0;
  margin-top: 0.4rem;
  border-top: 1px solid var(--panel-border);
  font-family: var(--font-mono);
  font-size: 0.74rem;
  color: var(--text-dim);
}
.trade-totals b { color: var(--text); }

/* Toast */
.ttoast {
  position: fixed;
  bottom: 1.25rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  padding: 0.5rem 1rem;
  background: rgba(8,10,20,0.92);
  backdrop-filter: blur(16px);
  color: var(--text);
  border: 1px solid rgba(245,158,11,0.40);
  border-radius: var(--radius);
  box-shadow: var(--glow-soft), var(--shadow);
}

/* Market briefing */
.tdim { color: var(--text-dim); }
.brief-summary {
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--text);
  border-left: 2px solid var(--accent);
  padding: 0.2rem 0 0.2rem 0.7rem;
  margin-bottom: 0.7rem;
  box-shadow: -4px 0 12px rgba(245,158,11,0.10);
}
.brief-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin-bottom: 0.6rem;
}
.brief-grid .kv > span:last-child { text-align: right; max-width: 70%; }
.brief-label {
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin: 0.2rem 0 0.4rem;
}
.brief-setups {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 0.7rem;
}
.brief-toggle { font-size: 0.72rem; }
.brief-full {
  margin-top: 0.6rem;
  max-height: 320px;
  overflow: auto;
  padding: 0.7rem;
  font-size: 0.72rem;
  line-height: 1.45;
  color: var(--text-dim);
  background: var(--code-bg);
  border: 1px solid var(--grid-line);
  border-radius: var(--radius);
  white-space: pre-wrap;
  word-break: break-word;
}

/* Strategy control bar */
.strategy-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.85rem;
  padding: 0.55rem 0.9rem;
  background: rgba(8,10,20,0.78);
  backdrop-filter: blur(14px);
  border: 1px solid var(--panel-border);
  border-radius: var(--radius);
  flex-wrap: wrap;
  box-shadow: inset 0 1px 0 rgba(245,158,11,0.06);
}
.strategy-bar-left,
.strategy-bar-right { display: flex; align-items: center; gap: 0.55rem; flex-wrap: wrap; }
.strategy-bar-label {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-dim);
}
.mode-pills { display: flex; gap: 0.25rem; }
.mode-pill {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.22rem 0.7rem;
  border-radius: 999px;
  border: 1px solid rgba(245,158,11,0.18);
  background: rgba(10,12,22,0.75);
  color: var(--text-dim);
  cursor: pointer;
  transition: all 0.18s ease;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}
.mode-pill.active-pill {
  background: var(--grad-accent);
  color: var(--accent-text);
  border-color: transparent;
  box-shadow: var(--glow-soft);
}
.mode-pill.live-pill.active-pill {
  background: rgba(255,92,108,0.18);
  color: var(--down);
  border-color: rgba(255,92,108,0.4);
  box-shadow: 0 0 10px rgba(255,92,108,0.18);
}
.mode-pill:hover:not(.active-pill) {
  border-color: var(--accent);
  color: var(--accent);
  box-shadow: var(--glow-soft);
}
.live-warn {
  font-family: var(--font-mono);
  font-size: 0.64rem;
  font-weight: 600;
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  background: rgba(255,92,108,0.14);
  color: var(--down);
  border: 1px solid rgba(255,92,108,0.3);
  letter-spacing: 0.04em;
}
.strategy-select {
  font-family: var(--font-mono);
  font-size: 0.74rem;
  padding: 0.25rem 0.55rem;
  border: 1px solid rgba(245,158,11,0.22);
  border-radius: var(--radius);
  background: rgba(10,12,22,0.75);
  color: var(--text);
  cursor: pointer;
}
.strategy-select:focus { outline: 1px solid var(--accent); outline-offset: 1px; }
.strategy-info {
  margin-bottom: 0.7rem;
  padding: 0.4rem 0.9rem;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--text-dim);
  border-left: 2px solid var(--accent);
  background: rgba(245,158,11,0.04);
  border-radius: 0 var(--radius) var(--radius) 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0 1.2rem;
  align-items: baseline;
  box-shadow: -4px 0 10px rgba(245,158,11,0.08);
}
.strategy-info-name   { font-weight: 700; color: var(--accent); font-size: 0.74rem; letter-spacing: 0.04em; }
.strategy-info-param  { color: var(--text-dim); }

/* Day navigation */
.tpanel-nav { margin-left: auto; display: flex; align-items: center; gap: 0.3rem; }
.tnav-btn {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  line-height: 1;
  padding: 0.22rem 0.4rem;
  border: 1px solid rgba(245,158,11,0.20);
  background: rgba(10,12,22,0.75);
  color: var(--text);
  border-radius: var(--radius);
  cursor: pointer;
  transition: all 0.18s ease;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
}
.tnav-btn:hover:not(:disabled) { border-color: var(--accent); color: var(--accent); box-shadow: var(--glow-soft); }
.tnav-btn:disabled { opacity: 0.4; cursor: default; }
.tnav-today { letter-spacing: 0.06em; text-transform: uppercase; }
.tnav-today.is-live { color: var(--up); border-color: rgba(46,230,168,0.4); box-shadow: 0 0 8px rgba(46,230,168,0.18); }
.tnav-date {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  padding: 0.18rem 0.3rem;
  border: 1px solid rgba(245,158,11,0.20);
  background: rgba(10,12,22,0.75);
  color: var(--text);
  border-radius: var(--radius);
  color-scheme: dark;
}
.hist-note {
  margin-top: 0.45rem;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* All-time P&L */
.alltime-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.6rem;
}
.stat {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.55rem 0.65rem;
  background: rgba(10,12,22,0.78);
  border: 1px solid var(--grid-line);
  border-radius: var(--radius);
  min-width: 0;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}
.stat:hover {
  border-color: rgba(245,158,11,0.25);
  box-shadow: 0 0 12px rgba(245,158,11,0.08);
}
.stat-label {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.stat-val {
  font-size: 1rem;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.alltime-days {
  margin-top: 0.6rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 1.2rem;
}

/* Responsive */
@media (max-width: 1100px) {
  .trading-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .alltime-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .trading-grid { grid-template-columns: 1fr; }
  .alltime-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .perf-pnl { font-size: 1.4rem; }
  .tlog .col-dur, .tlog .col-setup { display: none; }
}
