:root{
  --bg:#0d1117; --card:#161b22; --line:#30363d; --txt:#e6edf3;
  --muted:#8b949e; --accent:#cc2936; --accent2:#1f6feb; --ok:#2ea043;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);
  font-family:system-ui,Segoe UI,Roboto,"Noto Sans Devanagari",sans-serif;line-height:1.5}
.wrap{max-width:760px;margin:0 auto;padding:24px 16px 80px}
header h1{margin:0 0 4px;font-size:28px}
.sub{color:var(--muted);margin:0 0 20px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:22px;margin-bottom:20px}
section{margin-bottom:22px;padding-bottom:18px;border-bottom:1px solid var(--line)}
section:last-of-type{border-bottom:none;margin-bottom:8px}
h2{font-size:16px;margin:0 0 14px;color:#fff}
label{display:block;margin-bottom:14px;font-size:14px;color:var(--muted)}
.req{color:var(--accent)}
input[type=text],textarea,select,input[type=file]{
  width:100%;margin-top:6px;padding:10px 12px;background:#0d1117;
  border:1px solid var(--line);border-radius:8px;color:var(--txt);font-size:14px;
  font-family:inherit}
textarea{resize:vertical}
small{display:block;color:var(--muted);margin-top:4px;font-size:12px}
.row{display:flex;gap:14px}
.row label{flex:1}
button,.btn{display:inline-block;cursor:pointer;border:none;border-radius:8px;
  padding:12px 20px;font-size:15px;font-weight:600;text-decoration:none;text-align:center}
#go,.btn:not(.ghost){background:var(--accent);color:#fff;width:100%}
#go:hover{background:#a8222e}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--txt)}
.hidden{display:none}
.bar{height:14px;background:#0d1117;border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));
  transition:width .4s ease}
.stats{display:flex;justify-content:space-between;margin-top:12px;font-size:14px}
#pct{font-weight:700;font-size:18px}
#stage{color:var(--accent2);font-weight:600}
#eta{color:var(--muted)}
.msg{color:var(--muted);font-size:13px;margin-top:6px}
video{width:100%;border-radius:10px;margin-bottom:14px;background:#000}
.err pre{white-space:pre-wrap;color:#ff7b72;font-size:12px;background:#0d1117;
  padding:12px;border-radius:8px;max-height:240px;overflow:auto}
.btn+.btn{margin-left:8px}

/* ---- login page ---- */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;margin:0}
.login-wrap{width:100%;max-width:380px;padding:20px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:34px 30px}
.login-brand{font-size:26px;font-weight:700;text-align:center}
.login-sub{color:var(--muted);text-align:center;margin:4px 0 24px}
.login-form label{display:block;margin-bottom:16px;font-size:13px;color:var(--muted)}
.login-form input{width:100%;margin-top:6px;padding:11px 12px;background:#0d1117;
  border:1px solid var(--line);border-radius:8px;color:var(--txt);font-size:15px}
.login-form button{width:100%;background:var(--accent);color:#fff;border:none;
  border-radius:8px;padding:12px;font-size:15px;font-weight:600;cursor:pointer;margin-top:6px}
.login-form button:hover{background:#a8222e}
.login-error{background:#3d1418;border:1px solid #a8222e;color:#ff9b9b;
  padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:18px;text-align:center}
.topbar{display:flex;justify-content:space-between;align-items:flex-start}
.logout-link{color:var(--muted);font-size:13px;text-decoration:none;border:1px solid var(--line);
  padding:6px 12px;border-radius:8px;white-space:nowrap}
.logout-link:hover{color:var(--txt);border-color:var(--muted)}

