/* assets/css/styles.css */
:root {
  --bg: #0b0f14;
  --panel: #0f1722;
  --panel2: #101c2b;
  --text: #e6eef7;
  --muted: #90a4b7;
  --grid: rgba(255, 255, 255, 0.06);
  --turq: #2de2e6;
  --coral: #ff6b6b;
  --green: #26d07c;
  --yellow: #ffc857;
  --red: #ff4d4d;
  --shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
  --radius: 16px;
  --container: 1600px;
  --gutter: 16px;
}

* {
  box-sizing: border-box;
}

html,
body {
  height: 100%;
  overflow-x: hidden;
}

html {
  color-scheme: dark;
}

body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:
    radial-gradient(1200px 800px at 20% -10%, rgba(45, 226, 230, 0.12), transparent 55%),
    radial-gradient(1000px 700px at 110% 0%, rgba(255, 107, 107, 0.1), transparent 60%),
    var(--bg);
  color: var(--text);
}

.app {
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(11, 15, 20, 0.85);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(10px);
}

.topbar-inner {
  width: min(var(--container), calc(100% - (var(--gutter) * 2)));
  margin: 0 auto;
  padding: 10px 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 12px 16px;
  align-items: end;
}

.brand {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 220px;
}

.brand__logo {
  width: 50px;
  height: 50px;
  object-fit: contain;
  flex: 0 0 auto;
  transform: translateX(10px) scale(1.28);
  transform-origin: left center;
  filter: drop-shadow(0 10px 18px rgba(0, 0, 0, 0.35));
  will-change: transform;
}

.brand__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1.05;
}

.brand__title {
  font-weight: 800;
  letter-spacing: 0.2px;
  font-size: 18px;
}

.brand__subtitle {
  font-size: 12px;
  color: var(--muted);
}

.topbar-center {
  justify-self: center;
  width: clamp(520px, 62vw, 980px);
  display: grid;
  grid-template-columns: 1.35fr 0.65fr;
  gap: 12px;
  align-items: end;
}

.topbar-right {
  justify-self: end;
  display: flex;
  gap: 12px;
  align-items: end;
}

#diagnostic {
  grid-column: 1 / -1;
  margin-top: 8px;
}

.control-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.label {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pair-controls {
  display: flex;
  gap: 8px;
}

.input,
.select,
select {
  width: 100%;
  height: 40px;
  padding: 0 12px;
  border-radius: 12px;
  outline: none;
  background: rgba(10, 14, 18, 0.88);
  color: rgba(230, 238, 247, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.14);
}

.input:focus,
.select:focus,
select:focus {
  border-color: rgba(34, 211, 238, 0.45);
  box-shadow: 0 0 0 3px rgba(34, 211, 238, 0.22);
}

select option {
  background: #0b0f14;
  color: rgba(255, 255, 255, 0.95);
}

.select {
  min-width: 170px;
}

.tf-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tf-btn {
  height: 40px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--text);
  cursor: pointer;
  font-weight: 600;
}

.tf-btn.active {
  border-color: rgba(45, 226, 230, 0.65);
  background: rgba(45, 226, 230, 0.1);
}

.tf-btn:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

.actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

.btn {
  height: 40px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.06);
  color: var(--text);
  cursor: pointer;
  font-weight: 700;
}

.btn--secondary {
  background: rgba(255, 255, 255, 0.03);
}

.btn:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

.icon-btn {
  height: 40px;
  width: 44px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.06);
  cursor: pointer;
  font-size: 16px;
}

.icon-btn.active {
  border-color: rgba(255, 107, 107, 0.6);
  background: rgba(255, 107, 107, 0.1);
}

.diagnostic {
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255, 77, 77, 0.35);
  background: rgba(255, 77, 77, 0.1);
  color: var(--text);
  font-size: 13px;
}

.hidden {
  display: none;
}

.content {
  width: min(var(--container), calc(100% - (var(--gutter) * 2)));
  margin: 18px auto 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.no-x {
  overflow-x: hidden;
}

.panel {
  background: linear-gradient(180deg, rgba(16, 28, 43, 0.85), rgba(15, 23, 34, 0.85));
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 14px;
}

.panel-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.panel h2 {
  margin: 0;
  font-size: 16px;
}

.panel h3 {
  margin: 0 0 10px;
  font-size: 14px;
}

.hint {
  font-size: 12px;
  color: var(--muted);
}

.hint.small {
  font-size: 12px;
  opacity: 0.75;
  margin-top: 2px;
}

.chart-head {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.signal-badge {
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: 0.02em;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.signal-badge.buy {
  border-color: rgba(38, 208, 124, 0.45);
  background: rgba(38, 208, 124, 0.1);
}

.signal-badge.sell {
  border-color: rgba(255, 77, 77, 0.45);
  background: rgba(255, 77, 77, 0.1);
}

.signal-badge.hold {
  border-color: rgba(255, 200, 87, 0.45);
  background: rgba(255, 200, 87, 0.1);
}

.meta {
  color: var(--muted);
  font-size: 12px;
  flex: 1;
}

.loading {
  margin-left: auto;
  font-size: 12px;
  color: var(--muted);
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
}

.loading.hidden {
  display: none;
}

.charts {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 12px;
}

.chart-wrap {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.chart-title {
  font-size: 12px;
  color: var(--muted);
}

.chart {
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(0, 0, 0, 0.25);
  overflow: hidden;
  position: relative;
  contain: layout paint;
  min-width: 0 !important;
  max-width: 100% !important;
}

#chartMain,
#chartVolume,
#chartRsi {
  min-width: 0 !important;
  max-width: 100% !important;
}

.chart--main {
  height: 420px;
}

.chart--mini {
  height: 160px;
}

.mini-charts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  align-items: stretch;
}

.mini-charts > .chart-wrap {
  min-width: 0 !important;
}

.chart-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.collapse-btn {
  border: 1px solid rgba(45, 226, 230, 0.25);
  background: rgba(10, 14, 18, 0.55);
  color: #e6eef7;
  padding: 6px 10px;
  border-radius: 10px;
  cursor: pointer;
  font-size: 12px;
}

.collapse-btn:hover {
  border-color: rgba(45, 226, 230, 0.55);
  box-shadow: 0 0 0 3px rgba(45, 226, 230, 0.1);
}

.chart-wrap.collapsed .chart {
  height: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  border: 0 !important;
}

.chart-wrap.collapsed {
  padding-bottom: 6px;
}

.settings-grid {
  display: grid;
  grid-template-columns: 1fr 1.35fr 1fr 1fr;
  gap: 12px;
  width: 100%;
}

.settings-block {
  padding: 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
}

.block-title {
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 10px;
}

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.chip {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  cursor: pointer;
  user-select: none;
  font-size: 12px;
  font-weight: 700;
}

.chip small {
  color: var(--muted);
  font-weight: 600;
}

.chip.active {
  border-color: rgba(45, 226, 230, 0.65);
  background: rgba(45, 226, 230, 0.1);
}

.chip-label small {
  opacity: 0.75;
  margin-left: 6px;
}

.chip-x {
  border: 0;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.85);
  width: 22px;
  height: 22px;
  border-radius: 999px;
  cursor: pointer;
}

.chip-x:hover {
  background: rgba(255, 107, 107, 0.18);
  color: #ff6b6b;
}

.check {
  display: flex;
  gap: 10px;
  align-items: center;
  font-size: 13px;
  color: var(--text);
  margin: 8px 0;
}

.check input {
  transform: scale(1.05);
}

.ema-command {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ema-command input {
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(45, 226, 230, 0.25);
  background: rgba(10, 14, 18, 0.65);
  color: #e6eef7;
  outline: none;
}

.ema-command input:focus {
  border-color: rgba(45, 226, 230, 0.55);
  box-shadow: 0 0 0 3px rgba(45, 226, 230, 0.12);
}

.ema-command-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
}

.cmd-msg {
  font-size: 12px;
  min-height: 16px;
  opacity: 0.95;
}

.cmd-msg.ok {
  color: #26d07c;
}

.cmd-msg.error {
  color: #ff4d4d;
}

.cmd-msg.info {
  color: rgba(255, 255, 255, 0.75);
}

.block-sep {
  height: 1px;
  background: rgba(255, 255, 255, 0.08);
  margin: 12px 0;
}

.rsi-row {
  display: flex;
  gap: 10px;
  align-items: center;
}

.rsi-row .input {
  max-width: 120px;
}

.btn--mini {
  height: 40px;
  padding: 0 12px;
  border-radius: 10px;
  font-size: 12px;
  white-space: nowrap;
}

.pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.pill {
  border-radius: 999px;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  cursor: pointer;
  font-weight: 700;
  font-size: 12px;
}

.pill:hover {
  border-color: rgba(255, 255, 255, 0.18);
}

.pill.active {
  border-color: rgba(45, 226, 230, 0.65);
  background: rgba(45, 226, 230, 0.1);
}

.analysis-box {
  display: block;
}



.profit-wrap {
  margin-top: 14px;
}

.table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.table th,
.table td {
  padding: 8px 6px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  text-align: left;
}

.table th {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.dict {
  display: grid;
  gap: 12px;
}

.dict-card {
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(10, 14, 18, 0.55);
  border-radius: 16px;
  padding: 14px;
}

.dict-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.dict-badge {
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(45, 226, 230, 0.25);
  color: #f09f9f;
  background: rgba(45, 226, 230, 0.08);
}

.dict-term {
  font-size: 20px;
  font-weight: 700;
  margin-top: 10px;
}

.dict-def {
  margin-top: 8px;
  opacity: 0.9;
  line-height: 1.35;
}

.dict-controls {
  display: grid;
  gap: 10px;
}

.dict-letters {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.dict-letter {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  color: #e6eef7;
  border-radius: 10px;
  padding: 6px 9px;
  font-size: 12px;
  cursor: pointer;
}

.dict-letter.on {
  border-color: rgba(45, 226, 230, 0.55);
  box-shadow: 0 0 0 3px rgba(45, 226, 230, 0.1);
}

.dict-list {
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(10, 14, 18, 0.35);
  border-radius: 16px;
  padding: 12px;
}

.dict-items {
  margin-top: 10px;
  display: grid;
  gap: 8px;
  max-height: 240px;
  overflow: auto;
  padding-right: 6px;
}

.dict-item {
  text-align: left;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.03);
  color: #e6eef7;
  border-radius: 12px;
  padding: 10px 12px;
  cursor: pointer;
}

.dict-item.active {
  border-color: rgba(255, 107, 107, 0.45);
  box-shadow: 0 0 0 3px rgba(255, 107, 107, 0.12);
}

.footer {
  text-align: center;
  color: var(--muted);
  font-size: 12px;
  padding: 12px 0 6px;
}

.fng {
  width: 240px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(10, 14, 18, 0.55);
}

.fng__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.fng__value {
  font-weight: 700;
  letter-spacing: 0.2px;
}

.fng__unit {
  opacity: 0.7;
  margin-left: 4px;
  font-weight: 600;
}

.fng__label {
  font-size: 12px;
  opacity: 0.9;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
}

.fng__bar {
  position: relative;
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(
    90deg,
    rgba(248, 113, 113, 0.95) 0%,
    rgba(251, 146, 60, 0.95) 25%,
    rgba(250, 204, 21, 0.95) 50%,
    rgba(34, 211, 238, 0.95) 75%,
    rgba(74, 222, 128, 0.95) 100%
  );
}

.fng__needle {
  position: absolute;
  top: 50%;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  transform: translate(-50%, -50%);
  background: rgba(230, 238, 247, 0.95);
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.35);
}

.fng__meta {
  margin-top: 8px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  font-size: 11px;
  opacity: 0.75;
}

/* FNG panel (debajo de Overlays) */
.fng-panel .fng {
  width: 100%;
  max-width: 560px;
}

.fng-panel .fng__meta {
  opacity: 0.8;
}

/* Colores por clasificación (label) */
.fng__label.na { opacity: 0.75; }

.fng__label.fear,
.fng__label.fear2 {
  border-color: rgba(255, 77, 77, 0.35);
  background: rgba(255, 77, 77, 0.10);
}

.fng__label.neutral {
  border-color: rgba(255, 200, 87, 0.35);
  background: rgba(255, 200, 87, 0.10);
}

.fng__label.greed,
.fng__label.greed2 {
  border-color: rgba(38, 208, 124, 0.35);
  background: rgba(38, 208, 124, 0.10);
}

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.68);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
  z-index: 9999;
}

.modal-card {
  width: min(720px, 100%);
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(180deg, rgba(16, 28, 43, 0.96), rgba(15, 23, 34, 0.96));
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.55);
  overflow: hidden;
}

.modal-head {
  padding: 16px 16px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.modal-head h2 {
  margin: 0;
  font-size: 18px;
}

.modal-sub {
  margin-top: 6px;
  color: var(--muted);
  font-size: 12px;
}

.modal-body {
  padding: 14px 16px 6px;
  display: grid;
  gap: 12px;
}

.modal-box {
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  border-radius: 14px;
  padding: 12px;
}

.modal-box-title {
  color: var(--muted);
  font-size: 12px;
  margin-bottom: 8px;
}

.modal-list {
  margin: 0;
  padding-left: 18px;
}

.modal-list li {
  margin: 6px 0;
  line-height: 1.25;
}

.modal-warn {
  border: 1px solid rgba(255, 77, 77, 0.3);
  background: rgba(255, 77, 77, 0.1);
  border-radius: 14px;
  padding: 12px;
}

.modal-warn-title {
  font-weight: 800;
  margin-bottom: 8px;
}

.modal-warn p {
  margin: 8px 0;
  line-height: 1.35;
  color: rgba(230, 238, 247, 0.95);
}

.modal-check {
  display: flex;
  gap: 10px;
  align-items: center;
  font-size: 13px;
  color: var(--text);
  padding: 4px 2px 10px;
}

.modal-check input {
  transform: scale(1.05);
}

.modal-actions {
  padding: 12px 16px 16px;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.btn--primary {
  border-color: rgba(45, 226, 230, 0.55);
  background: rgba(45, 226, 230, 0.14);
}

.btn--primary:hover {
  border-color: rgba(45, 226, 230, 0.75);
  box-shadow: 0 0 0 3px rgba(45, 226, 230, 0.12);
}

.modal-backdrop.hidden {
  display: none !important;
}

@media (max-width: 980px) {
  .topbar-inner {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .topbar-center {
    width: 100%;
    grid-template-columns: 1fr;
    justify-self: stretch;
  }

  .topbar-right {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .actions {
    justify-content: flex-start;
  }

  .analysis-box {
    grid-template-columns: 1fr;
  }

  .settings-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .chart--main {
    height: 380px;
  }

  .fng {
    width: 100%;
  }
}

@media (max-width: 720px) {
  .topbar {
    position: static !important;
  }

  .topbar-inner {
    padding: 10px 0 !important;
    gap: 10px !important;
  }

  .brand {
    justify-content: center;
    min-width: 0;
    gap: 10px;
  }

  .brand__subtitle {
    display: none;
  }

  .actions {
    display: grid;
    grid-template-columns: 52px 1fr 1fr;
    gap: 10px;
    justify-content: stretch;
  }

  #watchStar {
    width: 52px;
    justify-content: center;
  }

  .input,
  .select {
    height: 44px;
    font-size: 16px;
  }

  .mini-charts {
    grid-template-columns: 1fr;
  }

  .panel {
    padding: 10px;
  }

  .chart--main {
    height: 340px;
  }

  .chart--mini {
    height: 140px;
  }

  .settings-grid {
    grid-template-columns: 1fr;
  }

  .modal-actions {
    justify-content: stretch;
  }

  .modal-actions .btn {
    width: 100%;
  }

  .modal-body {
    padding: 12px 14px 6px;
  }
}

@media (max-width: 520px) {
  .content {
    width: calc(100% - 16px);
  }

  .pair-controls {
    flex-direction: column;
  }

  .select {
    min-width: unset;
  }

  .chart--main {
    height: 320px;
  }

  .chart--mini {
    height: 130px;
  }
}

@media (min-width: 721px) {
  #emaApplyBtn {
    display: none;
  }

  .ema-command-row {
    grid-template-columns: 1fr;
  }
}

/* Profit calc table: más legible y “pro” */
.pc-table { width: 100%; border-collapse: collapse; table-layout: fixed; }
.pc-table th, .pc-table td { padding: 8px 10px; border-bottom: 1px solid rgba(255,255,255,.08); }
.pc-table thead th { opacity: .85; font-weight: 600; }
.pc-table tbody tr:nth-child(even) { background: rgba(255,255,255,.03); }

.pc-table th:nth-child(1), .pc-table td:nth-child(1) { width: 56px; text-align: left; }
.pc-table th:nth-child(2), .pc-table td:nth-child(2),
.pc-table th:nth-child(3), .pc-table td:nth-child(3),
.pc-table th:nth-child(4), .pc-table td:nth-child(4),
.pc-table th:nth-child(5), .pc-table td:nth-child(5) {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.pc-tablewrap { overflow-x: auto; }


/* ===== Analysis Pro polish ===== */
.analysis-box {
  align-items: start;
}

.analysis-card {
  padding: 14px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.02));
  border: 1px solid rgba(255, 255, 255, 0.075);
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.22);
}

.analysis-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  letter-spacing: 0.02em;
  margin: 0 0 8px;
}

.analysis-title b {
  font-weight: 900;
}

.analysis-card .hint {
  line-height: 1.35;
}

.analysis-card .hint + .hint {
  margin-top: 6px;
}

.analysis-lines {
  margin: 10px 0 0;
  padding-left: 18px;
}

.analysis-lines li {
  margin: 7px 0;
  color: rgba(230, 238, 247, 0.95);
  line-height: 1.25;
}

.analysis-lines li::marker {
  color: rgba(45, 226, 230, 0.65);
}

/* Badge más “pro” */
.badge {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
  padding: 6px 10px;
  border-radius: 999px;
  backdrop-filter: blur(6px);
}

.badge.green { box-shadow: 0 0 0 3px rgba(38, 208, 124, 0.08); }
.badge.yellow { box-shadow: 0 0 0 3px rgba(255, 200, 87, 0.08); }
.badge.red { box-shadow: 0 0 0 3px rgba(255, 77, 77, 0.08); }

/* “Tarjetas” dentro del análisis (cuando hay grids) */
.analysis-card > div[style*="display:grid"] {
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(0, 0, 0, 0.18);
}

/* Títulos de subtarjeta (Fibonacci / Niveles) */
.analysis-card .analysis-title + .hint {
  opacity: 0.92;
}

/* Resalta números tipo precios */
.analysis-card b {
  color: rgba(230, 238, 247, 0.98);
}

/* Mejor separación vertical entre cards dentro del mismo panel */
.analysis-card + .analysis-card {
  margin-top: 12px;
}

/* Compactar y alinear el bloque F/FS */
.analysis-card .analysis-title:has(+ .hint) {
  padding-bottom: 4px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

/* Fibo card: hacer el texto más legible */
.analysis-card .hint b {
  color: rgba(45, 226, 230, 0.9);
}

/* Responsivo: más aire en móvil */
@media (max-width: 720px) {
  .analysis-card { padding: 12px; }
  .analysis-title { font-size: 12px; }
  .analysis-lines { padding-left: 16px; }
}

/* FNG: centrar panel */
.fng-panel .panel-head{
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.fng-panel .fng{
  margin: 0 auto;
  text-align: left;
}

/* === FNG GRID (2 widgets lado a lado) === */
.fng-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: stretch;
}

@media (max-width: 900px){
  .fng-grid{ grid-template-columns: 1fr; }
}

.fng-card{
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 14px;
  padding: 12px 12px 10px;
  background: rgba(0,0,0,.10);
}

.fng-card__head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.fng-card__title{
  font-weight: 700;
  letter-spacing: .2px;
}

.fng-card__tag{
  font-size: 12px;
  opacity: .8;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.16);
}


/* ===== Dictionary v2 additions (append at end) ===== */

.muted { color: var(--muted); }

.dict-short{
  margin-top: 8px;
  opacity: .92;
  line-height: 1.35;
}

.dict-metaRow{
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.07);
}

@media (min-width: 900px){
  .dict-metaRow{ grid-template-columns: 1fr 1fr; }
}

.dict-meta{
  font-size: 12px;
  color: rgba(230,238,247,.92);
  opacity: .95;
}

.dict-long{
  margin-top: 12px;
  line-height: 1.45;
  opacity: .92;
}

.dict-section{
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.06);
}

.dict-section__title{
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 8px;
}

.dict-example{
  opacity: .92;
  line-height: 1.35;
  background: rgba(0,0,0,.14);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 12px;
  padding: 10px 12px;
}

.dict-controls__row{
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

@media (min-width: 820px){
  .dict-controls__row{ grid-template-columns: 1.2fr .8fr; }
}

/* list items with meta */
.dict-item__term{
  font-weight: 800;
  letter-spacing: .1px;
}

.dict-item__meta{
  margin-top: 4px;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.2;
}

/* chips (re-using your .chip base) */
.chip--link{
  cursor: pointer;
  border-color: rgba(45, 226, 230, 0.28);
  background: rgba(45, 226, 230, 0.08);
}

.chip--link:hover{
  border-color: rgba(45, 226, 230, 0.55);
  box-shadow: 0 0 0 3px rgba(45, 226, 230, 0.10);
}

.dict-chips{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dict-suggest{
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.empty{
  border: 1px dashed rgba(255,255,255,.16);
  background: rgba(0,0,0,.10);
  border-radius: 14px;
  padding: 12px;
}

.empty__title{
  font-weight: 900;
  margin-bottom: 4px;
}

.empty__text{
  color: var(--muted);
  margin-bottom: 10px;
  font-size: 12px;
}


/* Profit calc – forzar inputs a look del sistema */
#profitCalc input[type="text"],
#profitCalc input[type="number"],
#profitCalc select {
  width: 100%;
  height: 36px;
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.28);
  color: var(--text);
  outline: none;
}

#profitCalc input[type="text"]:focus,
#profitCalc input[type="number"]:focus,
#profitCalc select:focus {
  border-color: rgba(45, 226, 230, 0.55);
  box-shadow: 0 0 0 3px rgba(45, 226, 230, 0.10);
}

/* ===== Analysis layout v2 (grid-areas, sin huecos ni vacío) ===== */
.analysis-layout{
  display: grid;
  grid-template-columns: 1.35fr 1fr;
  gap: 12px;
  align-items: start;
  grid-template-areas:
    "signal fng"
    "levels fng"
    "levels fib";
}

@media (max-width: 980px){
  .analysis-layout{
    grid-template-columns: 1fr;
    grid-template-areas:
      "signal"
      "fng"
      "levels"
      "fib";
  }
}

.analysis-area-signal{ grid-area: signal; }
.analysis-area-fng{ grid-area: fng; }
.analysis-area-levels{ grid-area: levels; }
.analysis-area-fib{ grid-area: fib; }