/* ===== STRUVEN — Dojo Console ===== */
.dash-body{background:var(--bg);min-height:100vh;overflow-x:hidden}

/* sidebar */
.side{position:fixed;top:0;left:0;bottom:0;width:232px;background:var(--bg2);border-right:1px solid var(--line);
  padding:22px 16px;display:flex;flex-direction:column;gap:6px;z-index:20}
.side .brand{margin:4px 6px 20px;font-size:18px}
.side-nav{display:flex;flex-direction:column;gap:4px}
.side-nav a{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:11px;font-weight:700;font-size:14px;color:#cfcdde;cursor:pointer;transition:background .15s,color .15s}
.side-nav a:hover{background:rgba(255,255,255,.04);color:#fff}
.side-nav a.active{background:rgba(108,76,255,.18);color:#fff;border:1px solid rgba(138,92,255,.35)}
.side-nav a .ic{font-size:16px;width:18px;text-align:center}
.side-back{margin-top:auto;font-size:13px;font-weight:700;color:var(--muted);padding:10px 14px;text-decoration:none}
.side-back:hover{color:#fff}
.side-beta{font-weight:800;font-size:11px;letter-spacing:.12em;color:var(--purple2);border:1px dashed rgba(138,92,255,.45);border-radius:11px;padding:9px;text-align:center}

/* main */
.main{margin-left:232px;padding:24px clamp(16px,3vw,38px) 60px}
.topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.topbar h1{font-weight:900;font-size:clamp(24px,3vw,32px);letter-spacing:-.02em}
.topbar p{color:var(--muted);font-size:14px;margin-top:2px}
.top-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.agent-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-weight:700;font-size:13px}
.agent-pill .bot-eyes i{width:15px;height:17px}
.agent-pill b{color:var(--mint)}
.btn-pill.run{font-size:14px}
.btn-pill.run:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}

/* grid */
.grid{display:grid;grid-template-columns:1.7fr 1fr;gap:18px;align-items:start}
.panel{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:18px;padding:20px;margin-bottom:18px}
.panel-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px}
.panel h3{font-size:16px;font-weight:800}

/* agent card */
.agent-card{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center}
.avatar{width:86px;height:80px;border-radius:18px;border:3px solid #0a0a0d;display:flex;align-items:center;justify-content:center;box-shadow:5px 6px 0 rgba(0,0,0,.5);flex:none}
.avatar .eyes{display:flex;gap:7px}
.avatar .eyes i{width:25px;height:29px;background:#fff;border-radius:50%;border:3px solid #0a0a0d;position:relative}
.avatar .eyes i::after{content:"";position:absolute;width:11px;height:11px;background:#0a0a0d;border-radius:50%;left:4px;top:12px}
.agent-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.agent-top h2{font-size:24px;font-weight:900}
.belt{font-size:10px;letter-spacing:.1em;font-weight:800;color:#0a0a0d;border-radius:6px;padding:4px 9px}
.lvl-row{display:flex;align-items:center;gap:12px;margin:13px 0 16px;font-size:13px;font-weight:700;flex-wrap:wrap}
.xpbar{flex:1;min-width:140px;max-width:240px;height:10px;background:rgba(255,255,255,.08);border-radius:6px;overflow:hidden}
.xpbar i{display:block;height:100%;background:linear-gradient(90deg,var(--purple2),var(--mint));border-radius:6px;transition:width .5s}
.xptext{color:var(--muted)}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:11px 24px}
.stat label{display:flex;justify-content:space-between;color:var(--muted);font-weight:700;font-size:12px;margin-bottom:5px}
.stat label b{color:#fff}
.statbar{height:7px;background:rgba(255,255,255,.08);border-radius:5px;overflow:hidden}
.statbar i{display:block;height:100%;background:var(--purple2);border-radius:5px;transition:width .6s}
.elo-box{text-align:center;padding-left:6px}
.elo-box span{font-family:'Baloo 2',sans-serif;font-weight:800;font-size:40px;color:#fff;line-height:1}
.elo-box label{display:block;font-size:11px;letter-spacing:.14em;color:var(--muted);margin:2px 0 4px}
.elo-box em{font-style:normal;font-size:12px;font-weight:800}
.up{color:var(--mint)}.dn{color:var(--pink)}

/* training loop */
.sel{background:rgba(255,255,255,.05);border:1px solid var(--line);color:#fff;border-radius:9px;padding:8px 12px;font-family:inherit;font-weight:700;font-size:13px;cursor:pointer}
.loop{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.lstep{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:13px;padding:14px;transition:border-color .3s,background .3s}
.lstep.active{border-color:var(--purple2);background:rgba(108,76,255,.12)}
.lstep.done{border-color:rgba(159,245,196,.45)}
.lstep .ln{display:flex;align-items:center;gap:8px;font-weight:800;font-size:13px;margin-bottom:7px}
.lstep .dot{width:9px;height:9px;border-radius:50%;background:var(--muted);flex:none}
.lstep.active .dot{background:var(--purple2);box-shadow:0 0 8px var(--purple2)}
.lstep.done .dot{background:var(--mint)}
.lstep p{font-size:11.5px;color:var(--muted);line-height:1.5;min-height:50px}
.console{background:#07060d;border:1px solid var(--line);border-radius:12px;padding:14px;font-family:ui-monospace,Menlo,monospace;font-size:12.5px;line-height:1.75;height:172px;overflow-y:auto;color:#b9b3d6}
.console .g{color:var(--mint)}.console .p{color:var(--purple2)}.console .k{color:var(--pink)}.console .d{color:#6a6486}

/* belts */
.belt-list{display:flex;flex-direction:column;gap:13px}
.belt-item .bt{display:flex;justify-content:space-between;font-size:13px;font-weight:700;margin-bottom:5px}
.belt-item .bt span{color:var(--muted)}
.belt-bar{height:7px;background:rgba(255,255,255,.08);border-radius:5px;overflow:hidden}
.belt-bar i{display:block;height:100%;border-radius:5px;transition:width .6s}

/* mini leaderboard */
.mini{display:flex;flex-direction:column;gap:2px}
.mrow{display:grid;grid-template-columns:22px 1fr auto auto;gap:9px;align-items:center;padding:9px 8px;border-radius:9px;font-size:13px;font-weight:700}
.mrow.you{background:rgba(108,76,255,.15);border:1px solid rgba(138,92,255,.35)}
.mrow .r{color:var(--purple2);font-weight:800}
.mrow .nm{display:flex;align-items:center;gap:8px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.mrow .dot{width:14px;height:14px;border-radius:4px;border:2px solid #0a0a0d;flex:none}
.mrow .e{font-family:'Baloo 2',sans-serif;font-weight:800}
.mrow .t{font-size:12px}

/* coach */
.coach-panel .bot-head{display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:1px solid var(--line);margin-bottom:12px}
.coach-panel .bot-head b{font-weight:900;letter-spacing:.05em;font-size:13px}
.coach-panel .bot-log{height:210px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:2px 2px 12px}

/* responsive */
@media(max-width:1040px){
  .grid{grid-template-columns:1fr}
  .agent-card{grid-template-columns:auto 1fr;gap:16px}
  .elo-box{grid-column:1/-1;display:flex;align-items:baseline;gap:10px;justify-content:flex-start;text-align:left;border-top:1px solid var(--line);padding-top:14px}
  .elo-box label{margin:0}
}
@media(max-width:820px){
  .side{position:static;width:auto;flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px;border-right:none;border-bottom:1px solid var(--line)}
  .side .brand{margin:0 12px 0 4px}
  .side-nav{flex-direction:row;flex-wrap:wrap}
  .side-nav a{padding:8px 11px;font-size:13px}
  .side-back,.side-beta{display:none}
  .main{margin-left:0}
  .loop{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){.loop{grid-template-columns:1fr}.stats{grid-template-columns:1fr}}
