/**
 * Trading Manager — Design system (interface-design skill)
 * Dominio: cockpit de trading — precisión, contexto, riesgo.
 * Paleta: base slate oscuro, acento teal, semántica verde/rojo/ámbar.
 * Firma: estado y contexto siempre visible (nav + indicador testnet/prod).
 */

:root {
  /* ---- Superficies (elevación sutil) ---- */
  --tm-bg-base: #0d1117;
  --tm-bg-elevated: #161b22;
  --tm-bg-surface: #21262d;
  --tm-bg-surface-hover: #30363d;
  --tm-bg-inset: #0d1117;

  /* ---- Texto (jerarquía, contraste tipo Binance) ---- */
  --tm-fg-primary: #f0f6fc;
  --tm-fg-secondary: #b1bac4;
  --tm-fg-tertiary: #8b949e;
  --tm-fg-muted: #6e7681;

  /* ---- Bordes (progresión) ---- */
  --tm-border-subtle: rgba(48, 54, 61, 0.8);
  --tm-border-default: rgba(56, 63, 71, 0.9);
  --tm-border-strong: rgba(139, 148, 158, 0.4);
  --tm-border-focus: rgba(45, 212, 191, 0.6);

  /* ---- Acento y semántica ---- */
  --tm-accent: #2dd4bf;
  --tm-accent-dim: rgba(45, 212, 191, 0.15);
  --tm-success: #3fb950;
  --tm-success-dim: rgba(63, 185, 80, 0.12);
  --tm-danger: #f85149;
  --tm-danger-dim: rgba(248, 81, 73, 0.12);
  --tm-warning: #d29922;
  --tm-warning-dim: rgba(210, 153, 34, 0.15);
  --tm-info-dim: rgba(56, 139, 253, 0.12);

  /* ---- Espaciado (sistema 4px) ---- */
  --tm-space-1: 4px;
  --tm-space-2: 8px;
  --tm-space-3: 12px;
  --tm-space-4: 16px;
  --tm-space-5: 24px;
  --tm-space-6: 32px;

  /* ---- Tipografía (tamaños legibles, jerarquía clara) ---- */
  --tm-font-sans: "JetBrains Mono", "SF Mono", "Consolas", "Liberation Mono", monospace;
  --tm-font-size-xs: 0.8125rem;
  --tm-font-size-sm: 0.9375rem;
  --tm-font-size-base: 1rem;
  --tm-font-size-lg: 1.125rem;
  --tm-font-size-xl: 1.25rem;
  --tm-font-weight-normal: 400;
  --tm-font-weight-medium: 500;
  --tm-font-weight-semibold: 600;
}

/* ---- Base ---- */
body.tm-theme {
  background: var(--tm-bg-base);
  color: var(--tm-fg-primary);
  font-family: var(--tm-font-sans);
  font-size: var(--tm-font-size-base);
  line-height: 1.5;
  min-height: 100vh;
}

/* Respaldo: Bootstrap dentro del tema (páginas no migradas totalmente) */
.tm-theme .card {
  background: var(--tm-bg-elevated);
  border: 1px solid var(--tm-border-subtle);
  border-radius: 8px;
  color: var(--tm-fg-primary);
}
.tm-theme .card-header {
  background: var(--tm-bg-surface);
  border-bottom: 1px solid var(--tm-border-subtle);
  color: var(--tm-fg-primary);
}
.tm-theme .card-body { color: var(--tm-fg-primary); }
.tm-theme .form-control, .tm-theme .form-select {
  background: var(--tm-bg-inset);
  border: 1px solid var(--tm-border-default);
  color: var(--tm-fg-primary);
}
.tm-theme .form-control:focus, .tm-theme .form-select:focus {
  border-color: var(--tm-accent);
  box-shadow: 0 0 0 3px var(--tm-accent-dim);
}
.tm-theme .form-label, .tm-theme label { color: var(--tm-fg-secondary); }
.tm-theme .btn-primary { background: var(--tm-accent); border-color: var(--tm-accent); color: var(--tm-bg-base); }
.tm-theme .btn-outline-primary { color: var(--tm-accent); border-color: var(--tm-border-strong); }
.tm-theme .btn-outline-primary:hover { background: var(--tm-accent-dim); }
.tm-theme .table { color: var(--tm-fg-primary); }
.tm-theme .table-light { background: var(--tm-bg-surface); color: var(--tm-fg-secondary); }
.tm-theme .text-muted { color: var(--tm-fg-tertiary); }
.tm-theme .text-success { color: #56d364; }
.tm-theme .text-danger { color: #ff7b72; }
.tm-theme .alert { border-radius: 8px; border: 1px solid var(--tm-border-subtle); color: var(--tm-fg-primary); }
.tm-theme .alert-success { background: var(--tm-success-dim); border-left: 4px solid var(--tm-success); color: var(--tm-fg-primary); }
.tm-theme .alert-danger  { background: var(--tm-danger-dim);  border-left: 4px solid var(--tm-danger);  color: var(--tm-fg-primary); }
.tm-theme .alert-info    { background: var(--tm-info-dim);    border-left: 4px solid var(--tm-accent);  color: var(--tm-fg-primary); }
/* Advertencias: prominente, siempre legible */
.tm-theme .alert-warning {
  background: rgba(210, 153, 34, 0.18) !important;
  border: 1px solid rgba(210, 153, 34, 0.45) !important;
  border-left: 4px solid var(--tm-warning) !important;
  color: var(--tm-fg-primary) !important;
}
.tm-theme .alert-warning strong {
  color: #f0c060;
  font-size: 0.95rem;
  letter-spacing: 0.02em;
}
.tm-theme .alert-warning ul {
  color: var(--tm-fg-primary);
  margin-top: 0.4rem;
  padding-left: 1.2rem;
}
.tm-theme .alert-warning ul li {
  color: var(--tm-fg-primary);
  margin-bottom: 0.25rem;
  line-height: 1.55;
}

/* Cards con fondos Bootstrap: convertir a dark-theme con borde semántico */
.tm-theme .card.bg-primary,
.tm-theme .card.bg-secondary,
.tm-theme .card.bg-danger,
.tm-theme .card.bg-warning,
.tm-theme .card.bg-info,
.tm-theme .card.bg-success {
  background: var(--tm-bg-elevated) !important;
  color: var(--tm-fg-primary) !important;
}
.tm-theme .card.bg-primary { border-left: 3px solid var(--tm-accent); }
.tm-theme .card.bg-secondary { border-left: 3px solid var(--tm-border-strong); }
.tm-theme .card.bg-danger { border-left: 3px solid var(--tm-danger); }
.tm-theme .card.bg-warning { border-left: 3px solid var(--tm-warning); }
.tm-theme .card.bg-info { border-left: 3px solid #0dcaf0; }
.tm-theme .card.bg-success { border-left: 3px solid var(--tm-success); }
.tm-theme .card.bg-primary .card-body,
.tm-theme .card.bg-secondary .card-body,
.tm-theme .card.bg-danger .card-body,
.tm-theme .card.bg-warning .card-body,
.tm-theme .card.bg-info .card-body,
.tm-theme .card.bg-success .card-body { color: var(--tm-fg-primary) !important; }

/* Card headers con colores Bootstrap: forzar tema oscuro coherente */
.tm-theme .card-header.bg-primary,
.tm-theme .card-header.bg-warning,
.tm-theme .card-header.text-white,
.tm-theme .card-header.text-dark {
  background: var(--tm-bg-surface) !important;
  color: var(--tm-fg-primary) !important;
  border-bottom: 1px solid var(--tm-border-subtle);
}
.tm-theme .card-header.bg-primary { border-left: 3px solid var(--tm-accent); }
.tm-theme .card-header.bg-warning { border-left: 3px solid var(--tm-warning); }
.tm-theme .card-header.bg-danger { border-left: 3px solid var(--tm-danger); }
.tm-theme .card-header.bg-success { border-left: 3px solid var(--tm-success); }
.tm-theme .card-header.bg-secondary { border-left: 3px solid var(--tm-border-strong); }

/* Modales: cabecera nunca amarilla/azul; cuerpo coherente con tema */
.tm-theme .modal-header.bg-warning,
.tm-theme .modal-header.bg-primary,
.tm-theme .modal-header.text-white,
.tm-theme .modal-header.text-dark {
  background: var(--tm-bg-surface) !important;
  color: var(--tm-fg-primary) !important;
  border-bottom: 1px solid var(--tm-border-subtle);
}
.tm-theme .modal-header.bg-warning { border-left: 3px solid var(--tm-warning); }
.tm-theme .modal-header .modal-title { font-size: var(--tm-font-size-lg); font-weight: var(--tm-font-weight-semibold); }
.tm-theme .modal-header .btn-close { filter: invert(1); opacity: 0.8; }
.tm-theme .modal-body { font-size: var(--tm-font-size-sm); color: var(--tm-fg-primary); }
.tm-theme .modal-body .small { font-size: var(--tm-font-size-sm); color: var(--tm-fg-secondary); }
/* Bloques de contenido en modal (resumen JSON, detalle orden): fondo oscuro, no blanco */
.tm-theme .modal-body .bg-light,
.tm-theme .modal-body pre.bg-light,
.tm-theme .modal-body .p-3.bg-light,
.tm-theme .bg-light.rounded {
  background: var(--tm-bg-inset) !important;
  color: var(--tm-fg-primary) !important;
  border: 1px solid var(--tm-border-subtle);
  font-size: var(--tm-font-size-sm);
}

/* Tablas genéricas: tamaño mínimo legible y espaciado */
.tm-theme .table { font-size: var(--tm-font-size-sm); color: var(--tm-fg-primary); }
.tm-theme .table td, .tm-theme .table th { padding: var(--tm-space-2) var(--tm-space-3); }
.tm-theme .table-sm td, .tm-theme .table-sm th { padding: var(--tm-space-1) var(--tm-space-2); font-size: var(--tm-font-size-sm); }
.tm-theme .table .text-success { color: #56d364; }
.tm-theme .table .text-danger { color: #ff7b72; }
.tm-theme .table-warning { background: var(--tm-warning-dim) !important; color: var(--tm-fg-primary); }
.tm-theme .small { font-size: var(--tm-font-size-sm); color: var(--tm-fg-secondary); }
.tm-theme .text-info { color: var(--tm-accent); }
.tm-theme .btn-success { background: var(--tm-success); border-color: var(--tm-success); color: var(--tm-bg-base); }
.tm-theme .btn-secondary { background: var(--tm-bg-surface); border-color: var(--tm-border-default); color: var(--tm-fg-primary); }

.tm-theme .container {
  max-width: 1200px;
  padding-left: var(--tm-space-4);
  padding-right: var(--tm-space-4);
  padding-bottom: var(--tm-space-6);
}

/* ---- Navegación (mismo plano que contenido, borde sutil) ---- */
.tm-nav-wrap {
  background: var(--tm-bg-base);
  border-bottom: 1px solid var(--tm-border-subtle);
  margin-bottom: var(--tm-space-5);
  position: sticky;
  top: 0;
  z-index: 100;
}

.tm-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--tm-space-1);
  list-style: none;
  margin: 0;
  padding: var(--tm-space-2) 0;
}

.tm-nav-item {
  display: inline-flex;
}

.tm-nav-link {
  display: inline-block;
  padding: var(--tm-space-2) var(--tm-space-3);
  color: var(--tm-fg-secondary);
  text-decoration: none;
  font-size: var(--tm-font-size-base);
  font-weight: var(--tm-font-weight-medium);
  border-radius: 6px;
  border: 1px solid transparent;
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}

.tm-nav-link:hover {
  color: var(--tm-fg-primary);
  background: var(--tm-bg-surface);
}

.tm-nav-link.active {
  color: var(--tm-accent);
  background: var(--tm-accent-dim);
  border-color: var(--tm-border-strong);
}

.tm-nav-link.text-danger {
  color: var(--tm-danger);
}

.tm-nav-link.text-danger:hover {
  color: #ff7b72;
  background: var(--tm-danger-dim);
}

.tm-nav-ms-auto {
  margin-left: auto;
}

/* ---- Contenido: títulos ---- */
.tm-theme .tm-page-title {
  font-size: var(--tm-font-size-xl);
  font-weight: var(--tm-font-weight-semibold);
  color: var(--tm-fg-primary);
  margin-bottom: var(--tm-space-4);
  letter-spacing: -0.02em;
}

.tm-theme .tm-section-title {
  font-size: var(--tm-font-size-lg);
  font-weight: var(--tm-font-weight-semibold);
  color: var(--tm-fg-primary);
  margin-bottom: var(--tm-space-3);
}

/* ---- Cards / superficies elevadas ---- */
.tm-card {
  background: var(--tm-bg-elevated);
  border: 1px solid var(--tm-border-subtle);
  border-radius: 8px;
  overflow: hidden;
}

.tm-card-current {
  border-color: var(--tm-accent);
  box-shadow: 0 0 0 1px var(--tm-accent);
}

.tm-card-body {
  padding: var(--tm-space-4);
}

.tm-card-header {
  padding: var(--tm-space-3) var(--tm-space-4);
  background: var(--tm-bg-surface);
  border-bottom: 1px solid var(--tm-border-subtle);
  font-weight: var(--tm-font-weight-semibold);
  font-size: var(--tm-font-size-sm);
  color: var(--tm-fg-primary);
}

/* ---- Alertas (semántica) ---- */
.tm-alert {
  padding: var(--tm-space-3) var(--tm-space-4);
  border-radius: 8px;
  border: 1px solid var(--tm-border-subtle);
  margin-bottom: var(--tm-space-4);
  font-size: var(--tm-font-size-sm);
}

.tm-alert-success {
  background: var(--tm-success-dim);
  border-color: rgba(63, 185, 80, 0.35);
  color: var(--tm-fg-primary);
}

.tm-alert-warning {
  background: var(--tm-warning-dim);
  border-color: rgba(210, 153, 34, 0.4);
  color: var(--tm-fg-primary);
}

.tm-alert-danger {
  background: var(--tm-danger-dim);
  border-color: rgba(248, 81, 73, 0.4);
  color: var(--tm-fg-primary);
}

.tm-alert-info {
  background: var(--tm-info-dim);
  border-color: rgba(56, 139, 253, 0.4);
  color: var(--tm-fg-primary);
}

.tm-alert-secondary {
  background: var(--tm-bg-surface);
  border-color: var(--tm-border-subtle);
  color: var(--tm-fg-secondary);
}

/* ---- Badges (estado testnet/prod, LONG/SHORT) ---- */
.tm-badge {
  display: inline-block;
  padding: var(--tm-space-1) var(--tm-space-2);
  font-size: var(--tm-font-size-xs);
  font-weight: var(--tm-font-weight-semibold);
  border-radius: 4px;
}

.tm-badge-warning {
  background: var(--tm-warning-dim);
  color: #e3b341;
  border: 1px solid rgba(210, 153, 34, 0.4);
}

.tm-badge-danger {
  background: var(--tm-danger-dim);
  color: #ff7b72;
  border: 1px solid rgba(248, 81, 73, 0.4);
}

.tm-badge-success {
  background: var(--tm-success-dim);
  color: #56d364;
  border: 1px solid rgba(63, 185, 80, 0.35);
}

.tm-badge-info {
  background: var(--tm-info-dim);
  color: #79c0ff;
  border: 1px solid rgba(56, 139, 253, 0.4);
}

/* ---- Tablas ---- */
.tm-table-wrap {
  overflow-x: auto;
  border-radius: 8px;
  border: 1px solid var(--tm-border-subtle);
}

.tm-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--tm-font-size-sm);
}

.tm-table th,
.tm-table td {
  padding: var(--tm-space-2) var(--tm-space-3);
  text-align: left;
  border-bottom: 1px solid var(--tm-border-subtle);
}

.tm-table th {
  background: var(--tm-bg-surface);
  color: var(--tm-fg-secondary);
  font-weight: var(--tm-font-weight-semibold);
}

.tm-table tbody tr:hover {
  background: var(--tm-bg-surface);
}

.tm-table tbody tr:last-child td {
  border-bottom: none;
}

.tm-table .text-success { color: #56d364; }
.tm-table .text-danger { color: #ff7b72; }

/* ---- Formularios (inputs inset) ---- */
.tm-theme .tm-form-label {
  display: block;
  font-size: var(--tm-font-size-sm);
  font-weight: var(--tm-font-weight-medium);
  color: var(--tm-fg-secondary);
  margin-bottom: var(--tm-space-1);
}

.tm-theme .tm-form-control {
  display: block;
  width: 100%;
  padding: var(--tm-space-2) var(--tm-space-3);
  background: var(--tm-bg-inset);
  border: 1px solid var(--tm-border-default);
  border-radius: 6px;
  color: var(--tm-fg-primary);
  font-size: var(--tm-font-size-sm);
  font-family: inherit;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.tm-theme .tm-form-control::placeholder {
  color: var(--tm-fg-muted);
}

.tm-theme .tm-form-control:focus {
  outline: none;
  border-color: var(--tm-accent);
  box-shadow: 0 0 0 3px var(--tm-accent-dim);
}

.tm-theme select.tm-form-control {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238b949e' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
}

/* ---- Botones ---- */
.tm-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--tm-space-2);
  padding: var(--tm-space-2) var(--tm-space-3);
  font-size: var(--tm-font-size-sm);
  font-weight: var(--tm-font-weight-medium);
  font-family: inherit;
  border-radius: 6px;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.tm-btn-primary {
  background: var(--tm-accent);
  color: var(--tm-bg-base);
  border-color: var(--tm-accent);
}

.tm-btn-primary:hover {
  background: #2ee0c5;
  border-color: #2ee0c5;
}

.tm-btn-outline-primary {
  background: transparent;
  color: var(--tm-accent);
  border-color: var(--tm-border-strong);
}

.tm-btn-outline-primary:hover {
  background: var(--tm-accent-dim);
  border-color: var(--tm-accent);
}

.tm-btn-outline-secondary {
  background: transparent;
  color: var(--tm-fg-secondary);
  border-color: var(--tm-border-default);
}

.tm-btn-outline-secondary:hover {
  background: var(--tm-bg-surface);
  color: var(--tm-fg-primary);
}

.tm-btn-success {
  background: var(--tm-success);
  color: var(--tm-bg-base);
  border-color: var(--tm-success);
}

.tm-btn-success:hover {
  background: #56d364;
  border-color: #56d364;
}

.tm-btn-sm {
  padding: var(--tm-space-1) var(--tm-space-2);
  font-size: var(--tm-font-size-xs);
}

/* ---- Listas ---- */
.tm-list-unstyled {
  list-style: none;
  padding: 0;
  margin: 0;
}

.tm-list-unstyled li {
  padding: var(--tm-space-1) 0;
  color: var(--tm-fg-secondary);
  font-size: var(--tm-font-size-sm);
}

.tm-list-unstyled li::before {
  content: "✓ ";
  color: var(--tm-success);
  font-weight: var(--tm-font-weight-semibold);
}

.tm-list-plain {
  list-style: none;
  padding: 0;
  margin: 0;
}

.tm-list-plain li {
  padding: var(--tm-space-1) 0;
  color: var(--tm-fg-secondary);
  font-size: var(--tm-font-size-sm);
}

/* ---- Utilidades ---- */
.tm-text-muted { color: var(--tm-fg-tertiary); }
.tm-text-success { color: #56d364; }
.tm-text-danger { color: #ff7b72; }
.tm-text-accent { color: var(--tm-accent); }
.tm-small { font-size: var(--tm-font-size-xs); color: var(--tm-fg-tertiary); }

/* ---- Modal (overlay oscuro) ---- */
.tm-theme .modal-content {
  background: var(--tm-bg-elevated);
  border: 1px solid var(--tm-border-subtle);
  border-radius: 8px;
  color: var(--tm-fg-primary);
}

.tm-theme .modal-header {
  background: var(--tm-bg-surface);
  border-bottom: 1px solid var(--tm-border-subtle);
}

.tm-theme .modal-footer {
  border-top: 1px solid var(--tm-border-subtle);
}

.tm-theme .modal-backdrop {
  background: rgba(0, 0, 0, 0.7);
}

/* ---- Descripción pestañas (contenido Markdown) ---- */
.tm-descripcion-content { font-size: var(--tm-font-size-sm); }
.tm-descripcion-content h1 { font-size: var(--tm-font-size-lg); margin-bottom: var(--tm-space-3); padding-bottom: var(--tm-space-2); border-bottom: 2px solid var(--tm-accent); color: var(--tm-accent); }
.tm-descripcion-content h2 { font-size: var(--tm-font-size-base); margin-top: var(--tm-space-5); margin-bottom: var(--tm-space-2); color: var(--tm-fg-primary); }
.tm-descripcion-content h3 { font-size: var(--tm-font-size-sm); margin-top: var(--tm-space-3); margin-bottom: var(--tm-space-1); color: var(--tm-fg-secondary); }
.tm-descripcion-content p { margin-bottom: var(--tm-space-2); }
.tm-descripcion-content ul { margin-bottom: var(--tm-space-3); padding-left: var(--tm-space-5); }
.tm-descripcion-content li { margin-bottom: var(--tm-space-1); }
.tm-descripcion-content hr { margin: var(--tm-space-4) 0; border-color: var(--tm-border-subtle); }
.tm-descripcion-content table { width: 100%; margin-bottom: var(--tm-space-3); border-collapse: collapse; font-size: var(--tm-font-size-sm); }
.tm-descripcion-content table th,
.tm-descripcion-content table td { border: 1px solid var(--tm-border-subtle); padding: var(--tm-space-2) var(--tm-space-3); text-align: left; }
.tm-descripcion-content table th { background: var(--tm-bg-surface); font-weight: var(--tm-font-weight-semibold); color: var(--tm-fg-secondary); }
.tm-descripcion-content table tr:nth-child(even) { background: var(--tm-bg-surface); }
.tm-descripcion-content strong { font-weight: var(--tm-font-weight-semibold); color: var(--tm-fg-primary); }

.tm-feature-pill {
  border-radius: 8px;
  border: 1px solid var(--tm-border-subtle);
  padding: var(--tm-space-2) var(--tm-space-3);
  background: var(--tm-bg-surface);
  height: 100%;
}
.tm-feature-pill .tm-feature-title { font-weight: var(--tm-font-weight-semibold); font-size: var(--tm-font-size-sm); color: var(--tm-fg-primary); }
.tm-feature-pill .tm-feature-sub { font-size: var(--tm-font-size-xs); color: var(--tm-fg-tertiary); }
