@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');
@import url('variables.css');

*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;overflow:hidden}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px}
a{color:var(--accent);text-decoration:none}

/* Layout */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--header-h) 1fr;height:100vh}

/* Header */
.header{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:var(--bg2);border-bottom:1px solid var(--border);z-index:10}
.header-left{display:flex;align-items:center;gap:12px}
.header-left h1{font-size:16px;font-weight:700;letter-spacing:-0.5px}
.header-left .logo{font-size:20px}
.header-right{display:flex;align-items:center;gap:16px;font-size:12px;color:var(--text2)}
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px}
.status-dot.live{background:var(--green);box-shadow:0 0 6px var(--green)}
.status-dot.dry{background:var(--yellow);box-shadow:0 0 6px var(--yellow)}
.status-dot.off{background:var(--red)}

/* Sidebar */
.sidebar{background:var(--bg2);border-right:1px solid var(--border);padding:12px 0;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;color:var(--text2);cursor:pointer;font-size:13px;font-weight:500;transition:all .15s;border-left:3px solid transparent}
.nav-item:hover{background:var(--bg3);color:var(--text)}
.nav-item.active{color:var(--accent);background:rgba(59,130,246,0.08);border-left-color:var(--accent)}
.nav-item .icon{font-size:16px;width:20px;text-align:center}
.nav-section{padding:12px 16px 6px;font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text3);font-weight:600}

/* Main */
.main{overflow-y:auto;padding:20px;background:var(--bg)}
.main::-webkit-scrollbar{width:6px}
.main::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* Cards */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:16px}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.card-title{font-size:13px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:0.5px}

/* Stats Grid */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.stat-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;font-weight:600}
.stat-value{font-size:24px;font-weight:700;font-family:var(--mono);letter-spacing:-1px}
.stat-value.positive{color:var(--green)}
.stat-value.negative{color:var(--red)}
.stat-sub{font-size:11px;color:var(--text2);margin-top:4px}

/* Price Cards */
.price-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-bottom:20px}
.price-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;cursor:pointer;transition:all .15s}
.price-card:hover{border-color:var(--accent);transform:translateY(-1px)}
.price-card.selected{border-color:var(--accent);background:rgba(59,130,246,0.06)}
.price-card .symbol{font-size:13px;font-weight:600;margin-bottom:2px}
.price-card .price{font-size:18px;font-weight:700;font-family:var(--mono)}
.price-card .change{font-size:12px;font-weight:600;margin-top:2px}
.price-card .change.up{color:var(--green)}
.price-card .change.down{color:var(--red)}
.price-card .sparkline{height:30px;margin-top:6px}

/* Chart Container */
.chart-container{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}
.chart-toolbar{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--border)}
.chart-toolbar .tf-btn{padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;background:transparent;color:var(--text2);border:1px solid transparent;cursor:pointer}
.chart-toolbar .tf-btn:hover{color:var(--text);background:var(--bg3)}
.chart-toolbar .tf-btn.active{color:var(--accent);background:rgba(59,130,246,0.1);border-color:var(--accent)}
.chart-toolbar .symbol-name{font-size:15px;font-weight:700;margin-right:auto}
#chart-area{height:420px}

/* Table */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:8px 12px;font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:0.5px;font-weight:600;border-bottom:1px solid var(--border)}
td{padding:8px 12px;font-size:13px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:12px}
tr:hover td{background:rgba(255,255,255,0.02)}
.pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}
.pill.buy{background:var(--green-bg);color:var(--green)}
.pill.sell{background:var(--red-bg);color:var(--red)}
.pill.profit{background:var(--green-bg);color:var(--green)}
.pill.loss{background:var(--red-bg);color:var(--red)}

/* Performance */
.perf-bar{height:6px;background:var(--bg3);border-radius:3px;overflow:hidden;margin-top:6px}
.perf-bar .fill{height:100%;border-radius:3px;transition:width .5s}
.perf-bar .fill.green{background:var(--green)}
.perf-bar .fill.red{background:var(--red)}

/* Loading */
.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text3)}
.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-right:10px}
@keyframes spin{to{transform:rotate(360deg)}}

/* Badge */
.badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600}
.badge.running{background:var(--green-bg);color:var(--green)}
.badge.stopped{background:var(--red-bg);color:var(--red)}
.badge.dry_run{background:var(--yellow-bg);color:var(--yellow)}

/* Bot Grid */
.bots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.bot-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;transition:all .15s}
.bot-card:hover{border-color:var(--accent);transform:translateY(-1px)}
.bot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.bot-name{font-size:13px;font-weight:600;color:var(--text)}
.bot-status{font-size:10px;font-weight:700;padding:2px 6px;border-radius:3px}
.bot-status.online{background:var(--green-bg);color:var(--green)}
.bot-status.offline{background:var(--red-bg);color:var(--red)}
.bot-meta{font-size:11px;color:var(--text3);margin-bottom:8px}
.bot-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.bot-stat{text-align:center}
.bot-stat-label{display:block;font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:0.5px}
.bot-stat-value{display:block;font-size:12px;font-weight:600;font-family:var(--mono)}
.bot-stat-value.up{color:var(--green)}
.bot-stat-value.down{color:var(--red)}

/* Responsive */
@media(max-width:768px){
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .price-grid{grid-template-columns:repeat(2,1fr)}
  #chart-area{height:300px}
}
