:root{
  --bg:#08090d;
  --bg2:#0d0f16;
  --panel:rgba(20,22,32,.62);
  --panel-solid:#12141d;
  --border:rgba(255,255,255,.08);
  --border-hi:rgba(255,255,255,.18);
  --text:#e7e9f2;
  --text-dim:#8891a6;
  --text-dim2:#5c6478;
  --violet:#8b6bff;
  --violet-glow:rgba(139,107,255,.45);
  --teal:#00e2c3;
  --teal-glow:rgba(0,226,195,.4);
  --amber:#ffb020;
  --danger:#ff4d6d;
  --danger-glow:rgba(255,77,109,.4);
  --ok:#3ddc84;
  --radius:14px;
  --mono:'JetBrains Mono', ui-monospace, monospace;
  --disp:'Rajdhani', sans-serif;
}
*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  background:
    radial-gradient(circle at 15% -10%, rgba(139,107,255,.12), transparent 40%),
    radial-gradient(circle at 90% 0%, rgba(0,226,195,.08), transparent 45%),
    var(--bg);
  color:var(--text);
  font-family:var(--mono);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--violet-glow);}
::-webkit-scrollbar{width:9px;height:9px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:#2a2d3d;border-radius:8px;}
::-webkit-scrollbar-thumb:hover{background:#3a3e55;}

a{color:var(--teal);}

.perf-mode .brand-core .dot{animation:none;opacity:1;}
.perf-mode .iconbtn.primary{box-shadow:none;}
.perf-mode .screen-shell.mouse-captured{box-shadow:inset 0 0 0 2px var(--teal);}
.perf-mode *{transition-duration:0s !important;}

/* ---------- top bar ---------- */
.topbar{
  display:flex;align-items:center;gap:18px;
  padding:14px 22px;
  border-bottom:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.03), transparent);
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(14px);
}
.brand{display:flex;align-items:center;gap:12px;}
.brand-core{
  width:34px;height:34px;border-radius:9px;
  background:conic-gradient(from 200deg, var(--violet), var(--teal), var(--violet));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 22px var(--violet-glow);
  position:relative;
  flex:none;
}
.brand-core::after{
  content:"";position:absolute;inset:3px;border-radius:7px;background:var(--bg2);
}
.brand-core .dot{
  width:8px;height:8px;border-radius:50%;background:var(--teal);z-index:1;
  box-shadow:0 0 10px var(--teal-glow);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}
.brand h1{
  font-family:var(--disp);font-weight:700;font-size:21px;letter-spacing:.5px;margin:0;
  background:linear-gradient(90deg,#fff,#c9c2ff 60%,var(--teal));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.brand small{display:block;color:var(--text-dim2);font-size:10.5px;letter-spacing:1.6px;text-transform:uppercase;margin-top:-2px;}
.topbar-spacer{flex:1;}
.status-pill{
  display:flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:999px;
  border:1px solid var(--border);background:rgba(255,255,255,.02);
  font-size:12px;color:var(--text-dim);
}
.status-pill .led{width:8px;height:8px;border-radius:50%;background:var(--text-dim2);transition:.25s;}
.status-pill.boot .led{background:var(--amber);box-shadow:0 0 8px var(--amber);animation:blink 1s infinite;}
.status-pill.run .led{background:var(--ok);box-shadow:0 0 8px var(--ok);}
.status-pill.err .led{background:var(--danger);box-shadow:0 0 8px var(--danger);}
@keyframes blink{50%{opacity:.25}}
.top-btn{
  border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text);
  border-radius:9px;padding:8px 13px;font-family:var(--mono);font-size:12px;cursor:pointer;
  display:flex;align-items:center;gap:6px;transition:.15s;
}
.top-btn:hover{border-color:var(--border-hi);background:rgba(255,255,255,.07);}
.top-btn.danger:hover{border-color:var(--danger);color:var(--danger);}

/* ---------- layout ---------- */
.app{
  display:grid;
  grid-template-columns:1fr 400px;
  gap:18px;
  padding:20px;
  max-width:1680px;margin:0 auto;
  align-items:start;
}
@media(max-width:1080px){.app{grid-template-columns:1fr;}}

.panel{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius);
  backdrop-filter:blur(16px);
  overflow:hidden;
}
.panel-screen{background:var(--panel-solid);backdrop-filter:none;}
.panel-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 16px;border-bottom:1px solid var(--border);
}
.panel-head h2{
  font-family:var(--disp);font-size:15px;font-weight:600;letter-spacing:.4px;margin:0;
  color:var(--text);text-transform:uppercase;
}
.panel-head h2 span{color:var(--text-dim2);font-weight:500;}
.panel-body{padding:16px;}

/* ---------- screen ---------- */
.screen-wrap{position:relative;}
.screen-shell{
  position:relative;
  background:#000;
  border-radius:10px;
  overflow:hidden;
  aspect-ratio:4/3;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.02), 0 0 60px rgba(0,0,0,.5);
  cursor:none;
  transition:box-shadow .2s;
}
.screen-shell.mouse-captured{
  box-shadow:inset 0 0 0 2px var(--teal), 0 0 30px var(--teal-glow);
}
.capture-hint{
  position:absolute;bottom:10px;left:50%;transform:translateX(-50%);
  font-size:11px;color:var(--text-dim);background:rgba(0,0,0,.55);border:1px solid var(--border);
  padding:5px 10px;border-radius:999px;pointer-events:none;opacity:0;transition:opacity .2s;
  font-family:var(--mono);
}
.screen-shell:hover .capture-hint{opacity:1;}
.screen-shell.mouse-captured .capture-hint{opacity:0;}
#screen_container{
  width:100%;height:100%;color:#c6ffe0;
  white-space:pre;font-family:'JetBrains Mono',monospace;font-size:14px;line-height:14px;
  overflow:hidden;position:relative;
  display:flex;align-items:center;justify-content:center;
}
#screen_container canvas{max-width:100%;max-height:100%;image-rendering:pixelated;}
.stretch-mode #screen_container canvas{
  width:100% !important;height:100% !important;max-width:none !important;max-height:none !important;
  object-fit:fill;image-rendering:pixelated;
}
.stretch-mode #screen_container{align-items:stretch;justify-content:stretch;}
.idle-screen{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;color:var(--text-dim2);text-align:center;padding:30px;
}
.idle-screen .glyph{font-size:34px;filter:grayscale(1) opacity(.5);}
.idle-screen b{color:var(--text-dim);font-family:var(--disp);font-size:15px;font-weight:600;letter-spacing:.4px;}
.idle-screen span{font-size:12px;max-width:320px;line-height:1.5;}

.screen-toolbar{
  display:flex;flex-wrap:wrap;gap:8px;align-items:center;
  padding:12px 4px 2px;
}
.iconbtn{
  border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text-dim);
  border-radius:8px;padding:8px 12px;font-family:var(--mono);font-size:11.5px;cursor:pointer;
  display:flex;align-items:center;gap:6px;transition:.15s;white-space:nowrap;
}
.iconbtn:hover:not(:disabled){color:var(--text);border-color:var(--border-hi);background:rgba(255,255,255,.07);}
.iconbtn:disabled{opacity:.35;cursor:not-allowed;}
.iconbtn.primary{background:linear-gradient(135deg,var(--violet),#6a4bff);border-color:transparent;color:#fff;box-shadow:0 4px 18px var(--violet-glow);}
.iconbtn.primary:hover:not(:disabled){filter:brightness(1.12);}
.iconbtn.stop{border-color:var(--danger);color:var(--danger);}
.iconbtn.stop:hover:not(:disabled){background:rgba(255,77,109,.12);}
.iconbtn.teal{border-color:var(--teal);color:var(--teal);}
.spacer-flex{flex:1;}

/* ---------- tabs ---------- */
.tabs{display:flex;flex-wrap:wrap;gap:2px;padding:8px 8px 0;border-bottom:1px solid var(--border);}
.tab{
  padding:9px 12px;font-size:11.5px;color:var(--text-dim2);cursor:pointer;
  border-bottom:2px solid transparent;font-family:var(--disp);font-weight:600;letter-spacing:.4px;text-transform:uppercase;
}
.tab:hover{color:var(--text-dim);}
.tab.active{color:var(--teal);border-color:var(--teal);}
.tabpage{display:none;padding:16px;}
.tabpage.active{display:block;}

.field{margin-bottom:15px;}
.field label{display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:var(--text-dim);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;}
.field label .val{color:var(--teal);font-weight:600;text-transform:none;letter-spacing:0;}
.hint{font-size:11px;color:var(--text-dim2);margin-top:5px;line-height:1.5;}
input[type=range]{
  width:100%;accent-color:var(--violet);height:4px;
}
input[type=text],input[type=number],select,textarea{
  width:100%;background:rgba(0,0,0,.3);border:1px solid var(--border);color:var(--text);
  border-radius:8px;padding:9px 10px;font-family:var(--mono);font-size:12.5px;outline:none;
  transition:.15s;
}
input[type=text]:focus,input[type=number]:focus,select:focus,textarea:focus{border-color:var(--violet);box-shadow:0 0 0 3px var(--violet-glow);}
textarea{resize:vertical;min-height:70px;}
select{cursor:pointer;}
.row{display:flex;gap:10px;}
.row > *{flex:1;}
.switch-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);}
.switch-row:last-child{border-bottom:none;}
.switch-row .lbl{font-size:12.5px;color:var(--text);}
.switch-row .sub{font-size:10.5px;color:var(--text-dim2);margin-top:2px;}
.switch{position:relative;width:38px;height:21px;flex:none;}
.switch input{opacity:0;width:0;height:0;}
.switch .track{position:absolute;inset:0;background:rgba(255,255,255,.12);border-radius:999px;transition:.2s;cursor:pointer;}
.switch .track::before{content:"";position:absolute;width:15px;height:15px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;}
.switch input:checked + .track{background:var(--violet);}
.switch input:checked + .track::before{transform:translateX(17px);}

.dropzone{
  border:1.5px dashed var(--border-hi);border-radius:10px;padding:16px;text-align:center;
  cursor:pointer;transition:.15s;background:rgba(255,255,255,.015);
}
.dropzone:hover{border-color:var(--violet);background:rgba(139,107,255,.06);}
.dropzone.filled{border-style:solid;border-color:var(--teal);background:rgba(0,226,195,.06);}
.dropzone .dz-icon{font-size:20px;margin-bottom:4px;}
.dropzone .dz-title{font-size:12px;color:var(--text);font-weight:600;}
.dropzone .dz-sub{font-size:10.5px;color:var(--text-dim2);margin-top:3px;}
.dropzone .dz-file{font-size:11px;color:var(--teal);margin-top:6px;word-break:break-all;}
.media-slot{margin-bottom:14px;}
.media-slot-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.media-slot-head span.tag{font-size:10px;padding:2px 7px;border-radius:5px;background:rgba(255,255,255,.06);color:var(--text-dim);}
.clear-x{background:none;border:none;color:var(--text-dim2);cursor:pointer;font-size:11px;text-decoration:underline;}
.clear-x:hover{color:var(--danger);}

.badge-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;}
.badge-list .b{font-size:10px;padding:3px 8px;border-radius:6px;background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--text-dim);}

pre.console{
  background:#000;border:1px solid var(--border);border-radius:8px;
  padding:10px;height:220px;overflow-y:auto;font-size:11.5px;line-height:1.5;
  color:#8dffc0;white-space:pre-wrap;word-break:break-all;margin:0 0 10px;
}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.stat-card{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:10px;padding:12px;}
.stat-card .k{font-size:10px;color:var(--text-dim2);text-transform:uppercase;letter-spacing:.5px;}
.stat-card .v{font-family:var(--disp);font-size:21px;font-weight:700;color:var(--teal);margin-top:4px;}
.stat-card .v small{font-size:11px;color:var(--text-dim);font-family:var(--mono);font-weight:500;}

.log-line{font-size:11px;color:var(--text-dim);padding:3px 0;border-bottom:1px dashed var(--border);display:flex;gap:8px;}
.log-line .t{color:var(--text-dim2);flex:none;}
.log-line.err{color:var(--danger);}
.log-line.ok{color:var(--ok);}
.log-line.warn{color:var(--amber);}

.footer-note{padding:16px 22px;color:var(--text-dim2);font-size:11px;text-align:center;line-height:1.7;}
.footer-note a{color:var(--text-dim);}
kbd{background:rgba(255,255,255,.08);border:1px solid var(--border-hi);border-radius:4px;padding:1px 6px;font-size:11px;}