/* ── Suan Finance 2 — Dark Glass UI ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --accent:   #59c3ff;
  --green:    #2ed573;
  --red:      #ff4d68;
  --yellow:   #ffc107;
  --purple:   #9b5de5;
  --blue:     #4361ee;
  --white:    #ffffff;
  --muted:    rgba(255,255,255,0.65);
  --muted2:   rgba(255,255,255,0.38);

  --bg:       #060d1f;
  --panel:    rgba(255,255,255,0.055);
  --panel-h:  rgba(255,255,255,0.09);
  --border:   rgba(255,255,255,0.10);
  --border2:  rgba(255,255,255,0.06);

  --font:     'Segoe UI', Arial, sans-serif;
  --r:        14px;
  --r-sm:     9px;
  --nav-h:    64px;
}

html, body {
  min-height: 100vh;
  font-family: var(--font);
  font-size: 14px;
  color: var(--white);
  background: var(--bg);
  overflow-x: hidden;
}

/* ── FON ORNAMENTLARI ─────────────────────────────────────────────── */
.bg-orbs {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}
.orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
  opacity: 0.18;
}
.orb-a { width: 600px; height: 600px; background: #4361ee; top: -150px; left: -100px; }
.orb-b { width: 500px; height: 500px; background: #59c3ff; top: 40%; right: -80px; }
.orb-c { width: 400px; height: 400px; background: #9b5de5; bottom: -100px; left: 35%; }

.bg-grid {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 48px 48px;
}

/* ── NAVBAR ─────────────────────────────────────────────────────── */
.navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-h);
  display: flex;
  align-items: center;
  gap: 0;
  padding: 0 24px;
  background: rgba(6,13,31,0.80);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border);
  z-index: 100;
}

.nav-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 210px;
}
.nav-brand-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  background: rgba(89,195,255,0.10);
  border: 1px solid rgba(89,195,255,0.20);
  border-radius: 10px;
}
.nav-brand-text {
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 3px;
  color: var(--white);
}
.nav-brand-text .s { color: var(--accent); }
.nav-brand-text .f { color: var(--blue); }
.nav-brand-text .v {
  font-size: 11px;
  color: var(--muted2);
  vertical-align: super;
  letter-spacing: 0;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 1;
  padding: 0 16px;
}
.nav-btn {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 14px;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--r-sm);
  color: var(--muted);
  font-family: var(--font);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  cursor: pointer;
  transition: all 0.18s;
  white-space: nowrap;
}
.nav-btn svg { width: 15px; height: 15px; fill: currentColor; flex-shrink: 0; }
.nav-btn:hover {
  background: var(--panel-h);
  border-color: var(--border);
  color: var(--white);
}
.nav-btn.active {
  background: rgba(89,195,255,0.12);
  border-color: rgba(89,195,255,0.28);
  color: var(--accent);
}

.nav-right {
  display: flex;
  align-items: center;
  gap: 0;
  margin-left: auto;
}
.nav-info-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 16px;
}
.nav-info-val {
  font-size: 15px;
  font-weight: 700;
  color: var(--white);
  line-height: 1;
}
.nav-info-lbl {
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--muted2);
  margin-top: 3px;
}
.nav-divider {
  width: 1px;
  height: 32px;
  background: var(--border);
}
.nav-clock-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 16px;
}
.nav-clock-time {
  font-size: 16px;
  font-weight: 700;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.nav-clock-lbl {
  font-size: 9px;
  letter-spacing: 2px;
  margin-top: 3px;
}
.nav-clock-lbl.open  { color: var(--green); }
.nav-clock-lbl.closed { color: var(--red); }

.nav-market-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 14px;
}
.nav-market-label {
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--muted2);
  margin-bottom: 3px;
}
.nav-countdown {
  font-size: 13px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.nav-countdown.open   { color: var(--green); }
.nav-countdown.closed { color: var(--red); }

.nav-logout {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-left: 12px;
  padding: 9px 16px;
  background: rgba(255,77,104,0.10);
  border: 1px solid rgba(255,77,104,0.22);
  border-radius: var(--r-sm);
  color: #ff6b6b;
  font-family: var(--font);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.18s;
}
.nav-logout svg { flex-shrink: 0; }
.nav-logout:hover {
  background: rgba(255,77,104,0.22);
  border-color: rgba(255,77,104,0.45);
  color: #ff9090;
  box-shadow: 0 0 18px rgba(255,77,104,0.20);
  transform: translateY(-1px);
}

/* ── PAGE LAYOUT ─────────────────────────────────────────────────── */
.page {
  display: none;
  padding: calc(var(--nav-h) + 24px) 24px 100px;
  max-width: 1400px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.page.active { display: block; }

/* ── PANEL ───────────────────────────────────────────────────────── */
.panel {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 20px;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  margin-bottom: 20px;
}
.panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.panel-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--muted2);
}

.btn-refresh {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: var(--panel-h);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--muted);
  font-family: var(--font);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
}
.btn-refresh svg { width: 13px; height: 13px; fill: currentColor; }
.btn-refresh:hover { background: var(--panel-h); color: var(--white); border-color: var(--border2); }

/* ── SUMMARY GRID ─────────────────────────────────────────────────── */
.summary-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
  margin-bottom: 20px;
}
.sum-card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 16px;
  display: flex;
  align-items: center;
  gap: 14px;
  backdrop-filter: blur(16px);
  transition: all 0.18s;
}
.sum-card:hover {
  background: var(--panel-h);
  border-color: rgba(255,255,255,0.16);
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.25);
}
.sum-icon {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.sum-icon svg { width: 20px; height: 20px; fill: currentColor; }
.sum-icon.blue   { background: rgba(67,97,238,0.18); color: #4361ee; }
.sum-icon.green  { background: rgba(46,213,115,0.15); color: var(--green); }
.sum-icon.yellow { background: rgba(255,193,7,0.15);  color: var(--yellow); }
.sum-icon.purple { background: rgba(155,93,229,0.15); color: var(--purple); }
.sum-icon.accent { background: rgba(89,195,255,0.12); color: var(--accent); }
.sum-icon.red    { background: rgba(255,77,104,0.15); color: var(--red); }

.sum-val {
  font-size: 20px;
  font-weight: 800;
  color: var(--white);
  line-height: 1;
}
.sum-lbl {
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--muted2);
  margin-top: 5px;
}

/* ── AKKAUNTLAR OVERVIEW ─────────────────────────────────────────── */
.accounts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}
.acc-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 18px;
  transition: all 0.18s;
}
.acc-card:hover {
  background: var(--panel-h);
  border-color: rgba(255,255,255,0.16);
}
.acc-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.acc-name {
  font-size: 14px;
  font-weight: 700;
}
.acc-broker {
  font-size: 11px;
  color: var(--muted2);
  margin-top: 2px;
}
.acc-status {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 4px 10px;
  border-radius: 20px;
}
.acc-status.online  { background: rgba(46,213,115,0.15); color: var(--green); }
.acc-status.offline { background: rgba(255,77,104,0.12); color: var(--red); }
.acc-status .dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.acc-status.online .dot { animation: pulse 1.5s infinite; }
@keyframes pulse {
  0%,100% { opacity: 1; } 50% { opacity: 0.3; }
}

.acc-stats {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 10px;
}
.acc-stat-cell {
  text-align: center;
}
.acc-stat-val {
  font-size: 16px;
  font-weight: 700;
}
.acc-stat-lbl {
  font-size: 9px;
  letter-spacing: 1.5px;
  color: var(--muted2);
  margin-top: 3px;
}

/* ── TABLE ───────────────────────────────────────────────────────── */
.table-wrap {
  overflow-x: auto;
}
table {
  width: 100%;
  border-collapse: collapse;
}
thead th {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--muted2);
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
tbody td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border2);
  font-size: 13px;
  white-space: nowrap;
}
tbody tr:last-child td { border-bottom: none; }
tbody tr:hover td { background: rgba(255,255,255,0.03); }
.empty-td {
  text-align: center;
  color: var(--muted2);
  padding: 32px !important;
  font-size: 13px;
}

/* ── BADGES ──────────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
}
.badge-buy  { background: rgba(46,213,115,0.15); color: var(--green); }
.badge-sell { background: rgba(255,77,104,0.15); color: var(--red); }

/* ── BITIMLAR / TARIX SAHIFASI ──────────────────────────────────── */
.trades-page-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px 12px;
}
.trades-acc-panel  { margin-bottom: 16px; }
.trades-acc-meta   { font-size: 11px; color: var(--muted2); margin-top: 2px; }
.acc-login-tag     { font-size: 12px; font-weight: 400; color: var(--muted2); }

/* Robot / MT5 badge */
.src-badge {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 10px; font-weight: 700; padding: 2px 7px;
  border-radius: 20px; white-space: nowrap;
}
.src-robot { background: rgba(67,97,238,.15); color: #818cf8; }
.src-mt5   { background: rgba(255,255,255,.07); color: var(--muted2); }

/* Tarix — kun bo'limi */
.hist-day-block  { border-top: 1px solid var(--border); }
.hist-day-header {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 20px;
  background: rgba(255,255,255,.025);
}
.hist-day-label  { font-size: 12px; font-weight: 700; color: var(--muted2); flex: 1; letter-spacing: .5px; }
.hist-day-count  { font-size: 11px; color: var(--muted2); }
.hist-day-profit { font-size: 13px; font-weight: 800; }

/* ── COLORS ──────────────────────────────────────────────────────── */
.green  { color: var(--green)  !important; }
.red    { color: var(--red)    !important; }
.yellow { color: var(--yellow) !important; }
.purple { color: var(--purple) !important; }
.blue   { color: var(--blue)   !important; }
.accent { color: var(--accent) !important; }

/* ── EMPTY STATE ─────────────────────────────────────────────────── */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px;
  gap: 12px;
  color: var(--muted2);
}
.empty-state svg {
  width: 48px; height: 48px;
  opacity: 0.3;
}
.empty-state p {
  font-size: 14px;
  letter-spacing: 1px;
}

/* ── PAPKALAR ────────────────────────────────────────────────────── */
.folders-wrap { display: flex; flex-wrap: wrap; gap: 14px; }
.folder-card {
  display: flex; align-items: center; gap: 16px;
  background: var(--panel); border: 1px solid var(--border);
  border-radius: var(--r); padding: 18px 22px;
  cursor: pointer; transition: all 0.18s; min-width: 280px;
  backdrop-filter: blur(16px);
}
.folder-card:hover {
  background: var(--panel-h); border-color: rgba(89,195,255,0.3);
  transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}
.folder-icon {
  width: 44px; height: 44px; border-radius: 10px;
  background: rgba(89,195,255,0.12); border: 1px solid rgba(89,195,255,0.2);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent); flex-shrink: 0;
}
.folder-icon svg { width: 22px; height: 22px; }
.folder-icon.purple {
  background: rgba(155,93,229,0.12); border-color: rgba(155,93,229,0.2); color: var(--purple);
}
.folder-icon-nvda {
  background: rgba(118,185,0,0.14); border-color: rgba(118,185,0,0.3);
}
.folder-icon-aapl {
  background: rgba(210,210,210,0.10); border-color: rgba(210,210,210,0.22);
}
.folder-icon-amd {
  background: rgba(237,28,36,0.10); border-color: rgba(237,28,36,0.28);
}
.folder-logo { width: 30px; height: 30px; object-fit: contain; display: block; }
.folder-logo-aapl { filter: brightness(0) invert(1); width: 24px; height: 24px; }
.folder-name { font-size: 16px; font-weight: 700; }
.folder-sub  { font-size: 11px; color: var(--muted2); margin-top: 3px; }
.folder-arrow { margin-left: auto; font-size: 22px; color: var(--muted2); }

.folder-breadcrumb {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 16px; padding: 10px 0;
}
.breadcrumb-back {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: var(--r-sm); padding: 7px 14px;
  color: var(--muted); font-family: var(--font);
  font-size: 12px; cursor: pointer; transition: all 0.15s;
}
.breadcrumb-back:hover { background: var(--panel-h); color: var(--white); }
.breadcrumb-sep { color: var(--muted2); }
.breadcrumb-cur { font-size: 13px; font-weight: 600; }

/* ── ANALIZ ──────────────────────────────────────────────────────── */
.overall-signal-wrap {
  display: flex; align-items: center; gap: 32px; flex-wrap: wrap;
}
.overall-dir-lbl { font-size: 9px; letter-spacing: 2px; color: var(--muted2); }
.overall-dir {
  font-size: 36px; font-weight: 900; letter-spacing: 4px;
  margin-top: 4px;
}
.overall-dir.BUY  { color: var(--green); }
.overall-dir.SELL { color: var(--red); }
.overall-dir.HOLD { color: var(--yellow); }

.overall-bars { flex: 1; min-width: 200px; display: flex; flex-direction: column; gap: 8px; }
.overall-bar-row { display: flex; align-items: center; gap: 10px; }
.overall-bar-track {
  flex: 1; height: 8px; background: rgba(255,255,255,0.07);
  border-radius: 4px; overflow: hidden;
}
.overall-bar-fill { height: 100%; border-radius: 4px; transition: width 0.4s ease; }
.green-bg { background: var(--green); }
.red-bg   { background: var(--red); }

.robot-rec {
  padding: 10px 20px; border-radius: var(--r-sm);
  font-size: 13px; font-weight: 700; letter-spacing: 1px;
  white-space: nowrap;
}
.robot-rec.buy  { background: rgba(46,213,115,0.12); border: 1px solid rgba(46,213,115,0.25); color: var(--green); }
.robot-rec.sell { background: rgba(255,77,104,0.12); border: 1px solid rgba(255,77,104,0.25); color: var(--red); }
.robot-rec.hold { background: rgba(255,193,7,0.10);  border: 1px solid rgba(255,193,7,0.25);  color: var(--yellow); }

/* ── STRATEGIYALAR ───────────────────────────────────────────────── */
.strat-grid { display: flex; flex-direction: column; gap: 10px; }
.strat-card {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: var(--r); padding: 16px 20px;
  display: flex; align-items: center; gap: 16px;
  transition: all 0.18s; backdrop-filter: blur(12px);
}
.strat-card:hover { background: var(--panel-h); border-color: rgba(255,255,255,0.16); }
.strat-card.disabled { opacity: 0.45; }

.strat-num {
  width: 32px; height: 32px; border-radius: 8px;
  background: rgba(89,195,255,0.10); border: 1px solid rgba(89,195,255,0.18);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; color: var(--accent); flex-shrink: 0;
}
.strat-info { flex: 1; min-width: 0; }
.strat-name { font-size: 14px; font-weight: 700; }
.strat-meta { display: flex; gap: 8px; margin-top: 5px; }

.tag {
  font-size: 9px; font-weight: 700; letter-spacing: 1.5px;
  padding: 2px 8px; border-radius: 20px;
}
.tag-tf   { background: rgba(89,195,255,0.12); color: var(--accent); border: 1px solid rgba(89,195,255,0.2); }
.tag-risk-LOW    { background: rgba(46,213,115,0.12); color: var(--green);  border: 1px solid rgba(46,213,115,0.2); }
.tag-risk-MEDIUM { background: rgba(255,193,7,0.10);  color: var(--yellow); border: 1px solid rgba(255,193,7,0.2);  }
.tag-risk-HIGH   { background: rgba(255,77,104,0.12); color: var(--red);    border: 1px solid rgba(255,77,104,0.2); }

.strat-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.btn-strat-info {
  padding: 6px 12px; background: rgba(255,255,255,0.06);
  border: 1px solid var(--border); border-radius: var(--r-sm);
  color: var(--muted); font-family: var(--font); font-size: 11px;
  cursor: pointer; transition: all 0.15s;
}
.btn-strat-info:hover { background: var(--panel-h); color: var(--white); }

.toggle-wrap { display: flex; align-items: center; gap: 8px; }
.toggle-label { font-size: 10px; color: var(--muted2); letter-spacing: 1px; }
.toggle {
  position: relative; width: 40px; height: 22px; cursor: pointer;
}
.toggle input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; inset: 0;
  background: #e53e3e; border-radius: 22px;
  transition: all 0.2s;
}
.toggle-slider::before {
  content: ''; position: absolute;
  width: 16px; height: 16px; border-radius: 50%;
  background: white; top: 3px; left: 3px; transition: all 0.2s;
}
input:checked + .toggle-slider { background: var(--green); }
input:checked + .toggle-slider::before { transform: translateX(18px); }

/* ── STRATEGIYA MODAL ────────────────────────────────────────────── */
.modal-bg {
  position: fixed; inset: 0; background: rgba(0,0,0,0.6);
  backdrop-filter: blur(4px); z-index: 300;
}
.strat-modal {
  position: fixed; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(8,14,36,0.95);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 18px; padding: 28px;
  z-index: 301; width: 90%; max-width: 760px;
  max-height: 85vh; overflow-y: auto;
  backdrop-filter: blur(32px);
}
.strat-modal-header {
  display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 20px;
}
.strat-modal-name { font-size: 20px; font-weight: 800; }
.btn-close {
  background: rgba(255,255,255,0.08); border: 1px solid var(--border);
  border-radius: 8px; padding: 6px 12px; color: var(--muted);
  cursor: pointer; font-size: 14px; transition: all 0.15s;
}
.btn-close:hover { background: rgba(255,77,104,0.15); color: var(--red); }
.strat-modal-body { display: flex; flex-direction: column; gap: 16px; }
.sm-section { background: rgba(255,255,255,0.04); border-radius: 10px; padding: 14px; }
.sm-title {
  font-size: 9px; font-weight: 700; letter-spacing: 2px;
  color: var(--muted2); margin-bottom: 8px;
}
.sm-text { font-size: 13px; color: var(--muted); line-height: 1.6; }
.sm-text.pre { white-space: pre-line; }

/* ── ROBOT SAHIFASI ──────────────────────────────────────────────── */
.install-steps { display: flex; flex-direction: column; gap: 12px; margin-top: 4px; }
.install-step {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 14px; background: rgba(255,255,255,0.04); border-radius: 10px;
}
.step-num {
  width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
  background: rgba(89,195,255,0.15); border: 1px solid rgba(89,195,255,0.3);
  color: var(--accent); font-weight: 800; font-size: 13px;
  display: flex; align-items: center; justify-content: center;
}
.step-title { font-size: 13px; font-weight: 700; margin-bottom: 4px; }
.step-desc  { font-size: 12px; color: var(--muted); line-height: 1.5; }
code {
  background: rgba(89,195,255,0.10); border: 1px solid rgba(89,195,255,0.2);
  border-radius: 4px; padding: 1px 6px; font-size: 11px; color: var(--accent);
}
.btn-download {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 18px; background: linear-gradient(135deg, rgba(46,213,115,0.15), rgba(46,213,115,0.08));
  border: 1px solid rgba(46,213,115,0.35); border-radius: var(--r-sm);
  color: var(--green); font-family: var(--font); font-size: 12px;
  font-weight: 700; letter-spacing: 1px; text-decoration: none;
  transition: all 0.18s; white-space: nowrap;
}
.btn-download:hover {
  background: linear-gradient(135deg, rgba(46,213,115,0.25), rgba(46,213,115,0.15));
  border-color: rgba(46,213,115,0.6);
  box-shadow: 0 0 16px rgba(46,213,115,0.2);
}

.robot-account-card {
  background: rgba(255,255,255,0.04); border: 1px solid var(--border);
  border-radius: var(--r); padding: 20px; margin-bottom: 14px;
}
.robot-acc-header {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px;
}
.robot-acc-name { font-size: 15px; font-weight: 700; }
.robot-acc-broker { font-size: 11px; color: var(--muted2); margin-top: 2px; }
.robot-acc-actions { display: flex; gap: 10px; align-items: center; }
.robot-stats { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 14px; }
.robot-stat { text-align: center; }
.robot-stat-val { font-size: 18px; font-weight: 700; }
.robot-stat-lbl { font-size: 9px; letter-spacing: 1.5px; color: var(--muted2); margin-top: 3px; }
.robot-cmds { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border2); }
.robot-cmds-title { font-size: 9px; letter-spacing: 2px; color: var(--muted2); margin-bottom: 8px; }
.robot-cmd-row { display: flex; gap: 8px; align-items: center; font-size: 11px; padding: 3px 0; }
.cmd-badge {
  padding: 1px 7px; border-radius: 10px; font-size: 9px; font-weight: 700;
}
.cmd-PENDING { background: rgba(255,193,7,0.15); color: var(--yellow); }
.cmd-SENT    { background: rgba(89,195,255,0.12); color: var(--accent); }
.cmd-DONE    { background: rgba(46,213,115,0.12); color: var(--green); }
.btn-toggle-robot {
  padding: 8px 16px; border-radius: var(--r-sm);
  font-family: var(--font); font-size: 11px; font-weight: 700;
  letter-spacing: 1px; cursor: pointer; transition: all 0.18s; border: 1px solid;
}
.btn-toggle-robot.on {
  background: rgba(255,77,104,0.12); border-color: rgba(255,77,104,0.3); color: var(--red);
}
.btn-toggle-robot.on:hover { background: rgba(255,77,104,0.25); }
.btn-toggle-robot.off {
  background: rgba(46,213,115,0.12); border-color: rgba(46,213,115,0.3); color: var(--green);
}
.btn-toggle-robot.off:hover { background: rgba(46,213,115,0.25); }

/* ── TOAST ───────────────────────────────────────────────────────── */
.toast {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%) translateY(80px);
  background: rgba(20,30,60,0.92);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 12px 22px;
  font-size: 13px;
  color: var(--white);
  backdrop-filter: blur(16px);
  transition: transform 0.3s ease;
  z-index: 200;
  white-space: nowrap;
}
.toast.show { transform: translateX(-50%) translateY(0); }

/* ── LOGIN ───────────────────────────────────────────────────────── */
.login-body {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.login-bg {
  position: fixed;
  inset: 0;
  pointer-events: none;
}
.login-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0.20;
}
.orb1 { width: 500px; height: 500px; background: #4361ee; top: -100px; left: -100px; }
.orb2 { width: 400px; height: 400px; background: #59c3ff; bottom: -80px; right: -80px; }
.orb3 { width: 300px; height: 300px; background: #9b5de5; top: 40%; left: 40%; }

.login-wrap {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 420px;
  padding: 20px;
}
.login-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 20px;
  padding: 40px 36px;
  backdrop-filter: blur(32px);
  -webkit-backdrop-filter: blur(32px);
  box-shadow: 0 32px 80px rgba(0,0,0,0.40);
}
.login-logo {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 36px;
}
.login-logo-icon {
  width: 52px; height: 52px;
  background: rgba(89,195,255,0.10);
  border: 1px solid rgba(89,195,255,0.22);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.login-title {
  font-size: 18px;
  font-weight: 800;
  letter-spacing: 3px;
}
.login-title .s { color: var(--accent); }
.login-title .f { color: var(--blue); }
.login-title .v { font-size: 12px; color: var(--muted2); vertical-align: super; letter-spacing: 0; }
.login-sub {
  font-size: 11px;
  color: var(--muted2);
  letter-spacing: 1.5px;
  margin-top: 4px;
}

.login-field { margin-bottom: 18px; }
.login-field label {
  display: block;
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--muted2);
  margin-bottom: 8px;
  font-weight: 700;
}
.login-input-wrap {
  position: relative;
}
.login-icon {
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
  width: 17px; height: 17px;
  fill: var(--muted2);
  pointer-events: none;
}
.login-input-wrap input {
  width: 100%;
  padding: 12px 14px 12px 40px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--white);
  font-family: var(--font);
  font-size: 14px;
  outline: none;
  transition: all 0.18s;
}
.login-input-wrap input:focus {
  border-color: rgba(89,195,255,0.45);
  background: rgba(89,195,255,0.06);
  box-shadow: 0 0 0 3px rgba(89,195,255,0.10);
}
.login-input-wrap input::placeholder { color: var(--muted2); }

.login-error {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,77,104,0.12);
  border: 1px solid rgba(255,77,104,0.25);
  border-radius: var(--r-sm);
  padding: 10px 14px;
  color: #ff6b6b;
  font-size: 12px;
  margin-bottom: 16px;
}

.login-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 13px;
  background: linear-gradient(135deg, #4361ee, #59c3ff);
  border: none;
  border-radius: var(--r-sm);
  color: white;
  font-family: var(--font);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 2px;
  cursor: pointer;
  transition: all 0.22s;
  margin-top: 8px;
}
.login-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(67,97,238,0.45);
}
.login-footer {
  text-align: center;
  font-size: 11px;
  color: var(--muted2);
  margin-top: 24px;
  letter-spacing: 1px;
}

/* ── RESPONSIVE ──────────────────────────────────────────────────── */
@media (max-width: 1200px) {
  .summary-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .summary-grid { grid-template-columns: repeat(2, 1fr); }
  .nav-links { display: none; }
  .nav-brand-text { font-size: 13px; letter-spacing: 2px; }
  .nav-info-block { display: none; }
  .nav-clock-wrap { padding: 0 10px; }
  .page { padding: calc(var(--nav-h) + 16px) 12px 80px; }
}
@media (max-width: 480px) {
  .summary-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .nav-logout span { display: none; }
}

/* ── TF KARD TIZIMI (ANALIZ SAXIFASI) ───────────────────────────── */
.tf-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
  gap: 16px;
  margin-top: 16px;
}

.tf-card {
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.tf-card:hover {
  border-color: rgba(67,97,238,.4);
  box-shadow: 0 4px 24px rgba(67,97,238,.1);
}

/* Kard tepasi */
.tf-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,.02);
}
.tf-card-label {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--text);
  min-width: 90px;
}
.tf-card-sublabel {
  font-size: 11px;
  color: var(--muted2);
  letter-spacing: .5px;
}
.tf-card-vote {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
}
.vote-badge {
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .5px;
}
.vote-badge.BUY  { background: rgba(34,197,94,.18); color: #22c55e; border: 1px solid rgba(34,197,94,.3); }
.vote-badge.SELL { background: rgba(239,68,68,.18);  color: #ef4444; border: 1px solid rgba(239,68,68,.3); }
.vote-badge.HOLD { background: rgba(234,179,8,.15);  color: #eab308; border: 1px solid rgba(234,179,8,.25); }
.vote-badge.none { background: rgba(255,255,255,.06); color: var(--muted2); border: 1px solid var(--border); }

/* Mini bar */
.tf-mini-bars {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px 10px;
  border-bottom: 1px solid var(--border);
}
.tf-mini-bar-track {
  flex: 1;
  height: 5px;
  background: rgba(255,255,255,.06);
  border-radius: 3px;
  overflow: hidden;
  display: flex;
}
.tf-mini-bar-buy  { height: 100%; background: #22c55e; border-radius: 3px 0 0 3px; transition: width .5s; }
.tf-mini-bar-sell { height: 100%; background: #ef4444; border-radius: 0 3px 3px 0; transition: width .5s; }
.tf-mini-pct-buy  { font-size: 11px; font-weight: 700; color: #22c55e; min-width: 32px; }
.tf-mini-pct-sell { font-size: 11px; font-weight: 700; color: #ef4444; min-width: 32px; text-align: right; }

/* Strategiya qatorlari */
.tf-strategies { padding: 6px 0 8px; }
.strat-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 18px;
  border-bottom: 1px solid rgba(255,255,255,.03);
  transition: background .15s;
}
.strat-row:last-child { border-bottom: none; }
.strat-row:hover { background: rgba(255,255,255,.03); }

.strat-row-num {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(255,255,255,.07);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  color: var(--muted2);
  flex-shrink: 0;
}
.strat-row-name {
  font-size: 12px;
  color: var(--muted);
  flex: 1;
  letter-spacing: .3px;
}
.strat-row-pct {
  font-size: 11px;
  font-weight: 600;
  min-width: 36px;
  text-align: right;
}
.strat-row-badge {
  padding: 3px 9px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 700;
  min-width: 44px;
  text-align: center;
  letter-spacing: .3px;
}
.strat-row-badge.BUY  { background: rgba(34,197,94,.15); color: #22c55e; }
.strat-row-badge.SELL { background: rgba(239,68,68,.15);  color: #ef4444; }
.strat-row-badge.HOLD { background: rgba(234,179,8,.12);  color: #eab308; }
.strat-row-badge.none { background: rgba(255,255,255,.05); color: var(--muted2); }

.strat-row-bar {
  width: 60px;
  height: 4px;
  background: rgba(255,255,255,.06);
  border-radius: 2px;
  overflow: hidden;
}
.strat-row-bar-fill {
  height: 100%;
  border-radius: 2px;
  transition: width .5s;
}
.strat-row-bar-fill.buy  { background: #22c55e; }
.strat-row-bar-fill.sell { background: #ef4444; }
.strat-row-bar-fill.hold { background: #eab308; }

/* Signal kutilmoqda holati */
.tf-card-pending { opacity: 0.6; }
.strat-row-muted { opacity: 0.55; }
.analysis-no-signal-banner {
  display: flex; align-items: center; gap: 8px;
  background: rgba(89,195,255,.08);
  border: 1px solid rgba(89,195,255,.2);
  border-radius: var(--r-sm);
  padding: 10px 16px;
  font-size: 12px; color: var(--accent);
  margin-bottom: 14px;
  grid-column: 1 / -1;
}

/* TF kard pastki qismi */
.tf-card-footer {
  padding: 8px 18px;
  border-top: 1px solid var(--border);
  background: rgba(255,255,255,.02);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.tf-card-price { font-size: 12px; color: var(--accent); font-weight: 600; }
.tf-card-time  { font-size: 10px; color: var(--muted2); }

/* ── STRATEGIYALAR TF GURUHLASH ─────────────────────────────────── */
.strat-tf-group {
  margin-bottom: 20px;
}
.strat-tf-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 10px;
}
.strat-tf-badge {
  background: rgba(67,97,238,.18);
  color: var(--accent);
  border: 1px solid rgba(67,97,238,.3);
  padding: 3px 10px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
}
.strat-tf-label {
  font-size: 13px;
  color: var(--muted);
  letter-spacing: .5px;
}
.strat-tf-count {
  margin-left: auto;
  font-size: 11px;
  color: var(--muted2);
}
.strat-tf-cards {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* ── 3 GURUH KARD (QISQA / O'RTA / UZOQ) ───────────────────────── */
.group-cards-wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 12px;
}
@media (max-width: 900px) {
  .group-cards-wrap { grid-template-columns: 1fr; }
}

.group-card {
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 20px;
  position: relative;
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.group-card::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .3s;
  border-radius: 16px;
}
.group-card.BUY  { border-color: rgba(34,197,94,.3); }
.group-card.BUY::before  { background: radial-gradient(ellipse at top left, rgba(34,197,94,.08), transparent 65%); opacity: 1; }
.group-card.SELL { border-color: rgba(239,68,68,.3); }
.group-card.SELL::before { background: radial-gradient(ellipse at top left, rgba(239,68,68,.08), transparent 65%); opacity: 1; }
.group-card.HOLD { border-color: rgba(234,179,8,.25); }
.group-card.HOLD::before { background: radial-gradient(ellipse at top left, rgba(234,179,8,.06), transparent 65%); opacity: 1; }

.gc-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 16px;
}
.gc-label-wrap {}
.gc-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  color: var(--muted2);
  margin-bottom: 4px;
}
.gc-tfs {
  font-size: 11px;
  color: var(--muted2);
  letter-spacing: .5px;
}
.gc-dir {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 2px;
  padding: 6px 16px;
  border-radius: 10px;
}
.gc-dir.BUY  { color: #22c55e; background: rgba(34,197,94,.12); }
.gc-dir.SELL { color: #ef4444; background: rgba(239,68,68,.12); }
.gc-dir.HOLD { color: #eab308; background: rgba(234,179,8,.10); }
.gc-dir.none { color: var(--muted2); background: rgba(255,255,255,.05); font-size: 16px; }

/* Bar */
.gc-bars { margin-bottom: 16px; }
.gc-bar-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 5px;
}
.gc-bar-lbl { font-size: 11px; font-weight: 700; width: 32px; }
.gc-bar-track {
  flex: 1;
  height: 6px;
  background: rgba(255,255,255,.06);
  border-radius: 3px;
  overflow: hidden;
}
.gc-bar-fill { height: 100%; border-radius: 3px; transition: width .6s cubic-bezier(.4,0,.2,1); }
.gc-bar-pct { font-size: 12px; font-weight: 700; width: 36px; text-align: right; }

/* Narx va TP */
.gc-price-tp {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px;
}
.gc-price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.gc-price-lbl { font-size: 10px; color: var(--muted2); letter-spacing: 1px; font-weight: 600; }
.gc-price-val { font-size: 15px; font-weight: 700; color: var(--text); font-family: monospace; }
.gc-divider { height: 1px; background: var(--border); margin: 8px 0; }
.gc-tp-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.gc-tp-lbl { font-size: 10px; color: var(--muted2); letter-spacing: 1px; font-weight: 600; }
.gc-tp-wrap { display: flex; align-items: center; gap: 8px; }
.gc-tp-val { font-size: 15px; font-weight: 700; font-family: monospace; }
.gc-tp-val.BUY  { color: #22c55e; }
.gc-tp-val.SELL { color: #ef4444; }
.gc-tp-badge {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 6px;
  letter-spacing: .5px;
}
.gc-tp-badge.BUY  { background: rgba(34,197,94,.15); color: #22c55e; }
.gc-tp-badge.SELL { background: rgba(239,68,68,.15);  color: #ef4444; }

/* Umumiy xulosa satri */
.overall-summary-bar {
  display: flex;
  align-items: center;
  gap: 16px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 20px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.osb-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: var(--muted2);
  white-space: nowrap;
}
.osb-dir {
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 2px;
  min-width: 60px;
}
.osb-dir.BUY  { color: #22c55e; }
.osb-dir.SELL { color: #ef4444; }
.osb-dir.HOLD { color: #eab308; }
.osb-bars {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 200px;
}
.osb-bar-track {
  flex: 1;
  height: 5px;
  background: rgba(255,255,255,.06);
  border-radius: 3px;
  overflow: hidden;
  display: flex;
}
.osb-bar-fill { height: 100%; transition: width .5s; }
.robot-rec { font-size: 12px; color: var(--muted); white-space: nowrap; }
.robot-rec.buy  { color: #22c55e; }
.robot-rec.sell { color: #ef4444; }

/* ── ROBOT AKKAUNT KARTALARI (yangi) ────────────────────────────── */
.robot-acc-wrap { display: flex; flex-direction: column; gap: 16px; padding: 4px; }

.robot-acc-card2 {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 20px;
}
.robot-acc-top {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
}
.robot-acc-info { flex: 1; }
.robot-acc-name2 { font-size: 15px; font-weight: 700; color: var(--text); }
.robot-acc-meta  { font-size: 12px; color: var(--muted2); margin-top: 2px; }
.robot-acc-stats2 {
  display: flex; gap: 20px; flex-wrap: wrap;
  padding: 12px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}
.robot-stat2 { text-align: center; min-width: 70px; }
.robot-stat2-val { font-size: 14px; font-weight: 700; color: var(--text); }
.robot-stat2-lbl { font-size: 10px; color: var(--muted2); letter-spacing: .8px; margin-top: 2px; }

/* Symbol tugmalari */
.robot-symbols-title { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; color: var(--muted2); margin-bottom: 10px; }
.robot-symbols-wrap  { display: flex; gap: 10px; flex-wrap: wrap; }

.robot-symbol-btn {
  display: flex; align-items: center; gap: 10px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 18px;
  cursor: pointer;
  transition: border-color .2s, background .2s;
  color: var(--text);
}
.robot-symbol-btn:hover {
  border-color: rgba(67,97,238,.5);
  background: rgba(67,97,238,.08);
}
.rsb-ticker { font-size: 16px; font-weight: 800; letter-spacing: 1px; }
.rsb-status { font-size: 11px; color: var(--muted2); }
.rsb-terms  { display: flex; gap: 4px; }
.rsb-term   { font-size: 10px; padding: 2px 6px; border-radius: 5px; font-weight: 600; }
.rsb-term.on  { background: rgba(34,197,94,.15); color: #22c55e; }
.rsb-term.off { background: rgba(255,255,255,.06); color: var(--muted2); }
.rsb-arrow  { font-size: 18px; color: var(--muted2); margin-left: 4px; }

/* Robot ON/OFF tugmasi */
.robot-power-btn {
  padding: 8px 18px; border-radius: 10px; font-size: 13px; font-weight: 700;
  cursor: pointer; letter-spacing: .5px; transition: all .2s;
  border: 1px solid;
}
.robot-power-btn.on  { background: rgba(239,68,68,.15);  color: #ef4444; border-color: rgba(239,68,68,.35); }
.robot-power-btn.off { background: rgba(34,197,94,.13);  color: #22c55e; border-color: rgba(34,197,94,.3); }
.robot-power-btn:hover { filter: brightness(1.2); }

.robot-delete-btn {
  padding: 8px 14px; border-radius: 10px; font-size: 12px; font-weight: 700;
  cursor: pointer; letter-spacing: .3px; transition: all .2s;
  background: rgba(239,68,68,.08); color: #f87171;
  border: 1px solid rgba(239,68,68,.22);
}
.robot-delete-btn:hover { background: rgba(239,68,68,.22); border-color: rgba(239,68,68,.5); }

/* O'chirish tasdiq modali */
.del-bg {
  position: fixed; inset: 0; background: rgba(0,0,0,.65);
  z-index: 1100; backdrop-filter: blur(4px);
}
.del-modal {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%);
  z-index: 1101;
  background: var(--card); border: 1px solid rgba(239,68,68,.45);
  border-radius: 20px; padding: 36px 32px 28px; width: 360px;
  text-align: center; box-shadow: 0 24px 64px rgba(0,0,0,.55);
}
.del-modal-icon  { font-size: 44px; margin-bottom: 14px; }
.del-modal-title { font-size: 18px; font-weight: 800; color: var(--text); margin-bottom: 10px; }
.del-modal-msg   { font-size: 13px; color: var(--muted2); line-height: 1.6; margin-bottom: 26px; }
.del-modal-btns  { display: flex; gap: 10px; }
.del-modal-cancel {
  flex: 1; padding: 11px; border-radius: 10px; font-size: 13px; font-weight: 700;
  cursor: pointer; background: var(--glass); color: var(--muted2);
  border: 1px solid var(--border); transition: all .2s;
}
.del-modal-cancel:hover { color: var(--text); border-color: var(--muted2); }
.del-modal-ok {
  flex: 1; padding: 11px; border-radius: 10px; font-size: 13px; font-weight: 700;
  cursor: pointer; background: rgba(239,68,68,.15); color: #ef4444;
  border: 1px solid rgba(239,68,68,.4); transition: all .2s;
}
.del-modal-ok:hover { background: rgba(239,68,68,.32); }

/* ── MODAL OVERLAY ───────────────────────────────────────────────── */
.rsm-bg {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 1000;
}

/* ── ROBOT SOZLAMALAR MODALI ─────────────────────────────────────── */
.rsm-modal {
  position: fixed;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1001;
  width: min(720px, 96vw);
  max-height: 90vh;
  overflow-y: auto;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 20px;
  box-shadow: 0 24px 80px rgba(0,0,0,.6);
}
.rsm-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border);
}
.rsm-symbol   { font-size: 20px; font-weight: 900; letter-spacing: 2px; color: var(--text); }
.rsm-subtitle { font-size: 12px; color: var(--muted2); margin-top: 2px; letter-spacing: .5px; }
.rsm-close    { background: rgba(255,255,255,.07); border: 1px solid var(--border); color: var(--muted); width: 32px; height: 32px; border-radius: 8px; cursor: pointer; font-size: 14px; }
.rsm-close:hover { background: rgba(255,0,0,.15); color: #ef4444; }

.rsm-body { padding: 16px 24px; display: flex; flex-direction: column; gap: 12px; }

.rsm-term {
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
}
.rsm-term-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px;
  background: rgba(255,255,255,.02);
}
.rsm-term-label { font-size: 13px; font-weight: 700; letter-spacing: .5px; color: var(--text); }
.rsm-term-tfs   { font-size: 11px; color: var(--muted2); margin-top: 2px; }
.rsm-term-body  { padding: 14px 16px; display: flex; flex-direction: column; gap: 14px; }

.rsm-field {}
.rsm-field-label { font-size: 11px; color: var(--muted2); letter-spacing: .5px; font-weight: 600; display: block; margin-bottom: 8px; }

/* Counter */
.rsm-dir-row {
  display: flex;
  gap: 20px;
  padding-top: 4px;
  border-top: 1px solid var(--border2);
}
.rsm-dir-item {
  display: flex;
  align-items: center;
  gap: 8px;
}
.rsm-dir-lbl {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1px;
}
.rsm-dir-lbl.buy  { color: #2ed573; }
.rsm-dir-lbl.sell { color: #ff4757; }

.rsm-shares-input {
  width: 120px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--text);
  font-size: 18px;
  font-weight: 700;
  padding: 8px 14px;
  outline: none;
  transition: border-color .2s;
  text-align: center;
}
.rsm-shares-input:focus { border-color: var(--accent); }

/* Slider */
.rsm-slider {
  width: 100%;
  -webkit-appearance: none;
  height: 6px;
  border-radius: 3px;
  background: rgba(255,255,255,.1);
  outline: none;
  margin-bottom: 6px;
}
.rsm-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--accent);
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(67,97,238,.4);
}
.rsm-slider-labels {
  display: flex; justify-content: space-between;
  font-size: 10px; color: var(--muted2);
}

.rsm-footer {
  display: flex; gap: 10px; justify-content: flex-end;
  padding: 16px 24px 20px;
  border-top: 1px solid var(--border);
}
.rsm-btn-cancel {
  padding: 10px 20px; border-radius: 10px; border: 1px solid var(--border);
  background: transparent; color: var(--muted); cursor: pointer; font-size: 13px;
}
.rsm-btn-save {
  padding: 10px 28px; border-radius: 10px; border: none;
  background: var(--accent); color: #fff; cursor: pointer;
  font-size: 13px; font-weight: 700; letter-spacing: .5px;
}
.rsm-btn-save:hover { filter: brightness(1.1); }

/* ── RSM KENGAYTMALAR ────────────────────────────────────────────── */
.rsm-body-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.rsm-body-grid .rsm-term:last-child {
  grid-column: 1 / -1;  /* UZOQ — to'liq kenglikda */
}
@media (max-width: 600px) {
  .rsm-body-grid { grid-template-columns: 1fr; }
  .rsm-body-grid .rsm-term:last-child { grid-column: auto; }
}

/* Akkaunt nomi maydoni */
.rsm-name-row {
  padding: 14px 24px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 16px;
}
.rsm-name-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--muted2);
  white-space: nowrap;
  min-width: 110px;
}
.rsm-name-wrap { flex: 1; }
.rsm-name-input {
  width: 100%;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 14px;
  color: var(--text);
  font-size: 14px;
  font-weight: 600;
  outline: none;
  transition: border-color .2s;
  box-sizing: border-box;
}
.rsm-name-input:focus { border-color: var(--accent); }
.rsm-name-hint {
  display: block;
  font-size: 10px;
  color: var(--muted2);
  margin-top: 5px;
  letter-spacing: .3px;
}

/* ── EA CARD ─────────────────────────────────────────────────────── */
.ea-card { padding: 20px 24px; }
.ea-card-top {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 18px;
}
.ea-card-icon {
  width: 52px; height: 52px;
  background: rgba(89,195,255,.1);
  border: 1px solid rgba(89,195,255,.2);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
  flex-shrink: 0;
}
.ea-card-info { flex: 1; }
.ea-card-name {
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 1px;
  color: var(--text);
}
.ea-ver {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  background: rgba(89,195,255,.12);
  border: 1px solid rgba(89,195,255,.2);
  border-radius: 5px;
  padding: 1px 7px;
  margin-left: 6px;
  vertical-align: middle;
  letter-spacing: .5px;
}
.ea-card-desc {
  font-size: 12px;
  color: var(--muted2);
  margin-top: 3px;
  letter-spacing: .5px;
}
.btn-install-guide {
  display: flex; align-items: center; gap: 7px;
  padding: 9px 16px;
  background: rgba(155,93,229,.12);
  border: 1px solid rgba(155,93,229,.28);
  border-radius: 10px;
  color: #b47ef9;
  font-family: var(--font);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  cursor: pointer;
  white-space: nowrap;
  transition: all .18s;
}
.btn-install-guide:hover {
  background: rgba(155,93,229,.22);
  border-color: rgba(155,93,229,.5);
}
.ea-downloads {
  display: flex; gap: 10px; flex-wrap: wrap;
}
.btn-dl {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  background: rgba(89,195,255,.1);
  border: 1px solid rgba(89,195,255,.25);
  border-radius: 10px;
  color: var(--accent);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  letter-spacing: .5px;
  transition: all .18s;
}
.btn-dl:hover {
  background: rgba(89,195,255,.2);
  border-color: rgba(89,195,255,.5);
}
.btn-dl-tpl {
  background: rgba(46,213,115,.1);
  border-color: rgba(46,213,115,.25);
  color: var(--green);
}
.btn-dl-tpl:hover {
  background: rgba(46,213,115,.2);
  border-color: rgba(46,213,115,.5);
}
.btn-dl-macos {
  background: rgba(255,179,71,.1);
  border-color: rgba(255,179,71,.25);
  color: #ffb347;
}
.btn-dl-macos:hover {
  background: rgba(255,179,71,.2);
  border-color: rgba(255,179,71,.5);
}

/* ── O'RNATISH QO'LLANMASI QADAMLARI ────────────────────────────── */
/* ── O'RNATISH TABLARI ───────────────────────────────────────────── */
.ig-tabs {
  display: flex;
  gap: 4px;
  padding: 0 24px;
  border-bottom: 1px solid var(--border);
}
.ig-tab {
  display: inline-flex;
  align-items: center;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--muted2);
  font-size: 12px;
  font-weight: 700;
  padding: 12px 16px;
  cursor: pointer;
  letter-spacing: .4px;
  margin-bottom: -1px;
  transition: color .15s, border-color .15s;
}
.ig-tab:hover { color: var(--text); }
.ig-tab.ig-tab-active { color: var(--accent); border-bottom-color: var(--accent); }
#ig-tab-mac.ig-tab-active { color: #ffb347; border-bottom-color: #ffb347; }

/* macOS eslatma banner */
.ig-mac-note {
  margin: 12px 24px 0;
  padding: 10px 14px;
  background: rgba(255,179,71,.07);
  border: 1px solid rgba(255,179,71,.2);
  border-radius: 10px;
  font-size: 11px;
  color: rgba(255,179,71,.85);
  line-height: 1.6;
}
/* Terminal buyruq qutisi */
.ig-cmd-wrap {
  display: flex;
  align-items: stretch;
  gap: 0;
  margin-top: 10px;
  border: 1px solid rgba(255,179,71,.25);
  border-radius: 8px;
  overflow: hidden;
}
.ig-cmd {
  flex: 1;
  display: block;
  padding: 10px 12px;
  background: rgba(0,0,0,.35);
  color: #ffb347;
  font-size: 10.5px;
  font-family: 'SFMono-Regular', 'Consolas', monospace;
  line-height: 1.55;
  word-break: break-all;
  white-space: pre-wrap;
  border-radius: 0;
}
.ig-cmd-copy {
  flex-shrink: 0;
  padding: 0 14px;
  background: rgba(255,179,71,.12);
  border: none;
  border-left: 1px solid rgba(255,179,71,.2);
  color: #ffb347;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
}
.ig-cmd-copy:hover { background: rgba(255,179,71,.22); }

/* ── O'RNATISH QADAMLARI ─────────────────────────────────────────── */
.ig-step {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
}
.ig-step-mac {
  border-color: rgba(255,179,71,.15);
}
.ig-step-mac:hover {
  background: rgba(255,179,71,.04);
}
.ig-num {
  width: 26px; height: 26px;
  background: rgba(89,195,255,.15);
  border: 1px solid rgba(89,195,255,.3);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px;
  font-weight: 800;
  color: var(--accent);
  flex-shrink: 0;
  margin-top: 1px;
}
.ig-num-mac {
  background: rgba(255,179,71,.15);
  border-color: rgba(255,179,71,.3);
  color: #ffb347;
}
.ig-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 5px;
  letter-spacing: .3px;
}
.ig-desc {
  font-size: 11px;
  color: var(--muted2);
  line-height: 1.6;
}
.ig-desc code {
  background: rgba(89,195,255,.1);
  color: var(--accent);
  padding: 1px 5px;
  border-radius: 4px;
  font-size: 10.5px;
}
.ig-step-mac .ig-desc code {
  background: rgba(255,179,71,.1);
  color: #ffb347;
}
.ig-desc em {
  color: var(--text);
  font-style: normal;
  font-weight: 600;
}
.ig-desc kbd {
  background: rgba(255,255,255,.1);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 1px 6px;
  font-size: 10.5px;
  color: var(--text);
}
.ig-url {
  display: inline-block;
  margin-top: 4px;
  background: rgba(89,195,255,.1) !important;
  color: var(--accent) !important;
  padding: 3px 8px !important;
  border-radius: 6px;
}

/* ── YANGILIKLAR SAHIFASI ────────────────────────────────────────── */
.news-source-badge {
  display: flex; align-items: center; gap: 5px;
  font-size: 10px; color: var(--muted2); letter-spacing: .5px;
}

/* Voqealar grid */
.news-events-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
.news-event-card {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px 18px;
  display: flex; flex-direction: column; gap: 8px;
  transition: border-color .2s;
}
.news-event-card:hover { border-color: rgba(255,255,255,.2); }
.nec-top { display: flex; align-items: center; gap: 8px; }
.nec-icon { display: flex; align-items: center; }
.nec-type { font-size: 10px; font-weight: 800; letter-spacing: 1.5px; flex: 1; }
.nec-impact { font-size: 9px; font-weight: 700; letter-spacing: 1px;
  background: rgba(255,255,255,.06); border-radius: 4px; padding: 2px 6px; }
.nec-title { font-size: 13px; font-weight: 700; color: var(--text); line-height: 1.4; }
.nec-note { font-size: 11px; color: var(--muted2); }
.nec-source { font-size: 10px; color: var(--muted2); display: flex; align-items: center; gap: 4px; }
.nec-countdown {
  font-size: 20px; font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--accent); letter-spacing: 1px;
  background: rgba(89,195,255,.08);
  border: 1px solid rgba(89,195,255,.15);
  border-radius: 10px; padding: 8px 12px;
  text-align: center; margin-top: 4px;
}
.nec-countdown.passed { color: var(--muted2); background: rgba(255,255,255,.04); border-color: var(--border); font-size: 13px; }

/* Yangiliklar ro'yxati */
.news-list { display: flex; flex-direction: column; gap: 2px; }
.news-item {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 12px 14px; border-radius: 10px;
  text-decoration: none; color: inherit;
  transition: background .15s;
  border-bottom: 1px solid var(--border2);
}
.news-item:hover { background: rgba(255,255,255,.05); }
.news-item:last-child { border-bottom: none; }
.ni-sent { font-size: 14px; margin-top: 2px; flex-shrink: 0; width: 16px; text-align: center; }
.ni-body { flex: 1; min-width: 0; }
.ni-title { font-size: 13px; font-weight: 600; color: var(--text); line-height: 1.45;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.news-item:hover .ni-title { white-space: normal; }
.ni-meta { display: flex; align-items: center; gap: 10px; margin-top: 4px; }
.ni-source { font-size: 10px; font-weight: 700; color: var(--accent); letter-spacing: .5px; }
.ni-time { font-size: 10px; color: var(--muted2); }
.news-empty { color: var(--muted2); font-size: 13px; padding: 20px 0; text-align: center; }
.news-loading { color: var(--muted2); font-size: 13px; padding: 20px 0; text-align: center; }

/* ── FOREX FOLDER ICON ─────────────────────────────────────────── */
.folder-icon-forex {
  background: linear-gradient(135deg, rgba(99,102,241,.25), rgba(139,92,246,.25));
  border: 1px solid rgba(99,102,241,.3);
}
.folder-icon-forex img {
  width: 36px; height: 36px;
}

/* ── FOREX ROBOT SOZLAMALAR MODALI ──────────────────────────────── */
.rsm-modal-wide { max-width: 760px; }

.frsm-cards-wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 16px 24px;
  max-height: 55vh;
  overflow-y: auto;
}
.frsm-tf-card {
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .2s;
}
.frsm-card-on {
  border-color: rgba(46,213,115,0.45);
}
.frsm-tf-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 16px;
  background: rgba(255,255,255,.02);
  border-bottom: 1px solid var(--border);
}
.frsm-tf-card-body {
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.frsm-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.frsm-input {
  width: 100%;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  font-size: 13px;
  padding: 7px 10px;
  outline: none;
  transition: border-color .2s;
  box-sizing: border-box;
}
.frsm-input:focus { border-color: var(--accent); }
.frsm-loading {
  grid-column: 1 / -1;
  text-align: center;
  padding: 24px;
  color: var(--muted2);
  font-size: 13px;
}
@media (max-width: 600px) {
  .frsm-cards-wrap { grid-template-columns: repeat(2, 1fr); }
}
