:root{
  --bg:#f4f1ec; --card:#fffdfa; --ink:#2b2622; --muted:#8a8178;
  --line:#e7e0d6; --accent:#7a1f2b; --accent-ink:#fff; --ok:#2f6b3a; --err:#a3322b;
  --radius:14px; --shadow:0 8px 30px rgba(40,30,20,.08);
}
*{box-sizing:border-box}
body{margin:0;font:15px/1.5 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--ink);min-height:100vh}
a{color:var(--accent)}
.wrap{max-width:920px;margin:0 auto;padding:28px 20px}
.center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:28px}
.card.narrow{max-width:400px;width:100%}
h1{font-size:22px;margin:0 0 4px}
.sub{color:var(--muted);margin:0 0 22px;font-size:14px}
label{display:block;font-size:13px;color:var(--muted);margin:14px 0 6px}
input[type=text],input[type=password]{width:100%;padding:11px 12px;border:1px solid var(--line);
  border-radius:10px;background:#fff;font:inherit;color:var(--ink)}
input:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}
button{font:inherit;cursor:pointer;border:0;border-radius:10px;padding:11px 18px;
  background:var(--accent);color:var(--accent-ink);font-weight:600}
button:hover{filter:brightness(1.08)}
button.ghost{background:transparent;color:var(--muted);font-weight:500;padding:8px 10px}
button[disabled]{opacity:.5;cursor:not-allowed}
.full{width:100%}
.row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.alert{padding:10px 12px;border-radius:10px;font-size:14px;margin:0 0 16px}
.alert.err{background:#faecea;color:var(--err);border:1px solid #efcfca}
.alert.warn{background:#fdf6e7;color:#8a6d1f;border:1px solid #efe2bc}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.brand{font-weight:700;letter-spacing:.3px}
.brand small{color:var(--muted);font-weight:500}
.drop{border:2px dashed var(--line);border-radius:var(--radius);background:var(--card);
  padding:46px 20px;text-align:center;transition:.15s;cursor:pointer}
.drop.over{border-color:var(--accent);background:#fff}
.drop strong{display:block;font-size:17px;margin-bottom:4px}
.hint{color:var(--muted);font-size:13px}
.list{margin:18px 0 0;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-top:1px solid var(--line);font-size:14px}
.item:first-child{border-top:0}
.item .nm{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.badge{font-size:12px;padding:2px 8px;border-radius:99px;font-weight:600}
.badge.ok{background:#e7f1e9;color:var(--ok)}
.badge.err{background:#faecea;color:var(--err)}
.badge.wait{background:#eee9e1;color:var(--muted)}
.actions{display:flex;gap:10px;margin-top:18px}
.muted{color:var(--muted);font-size:13px}
.spin{display:inline-block;width:14px;height:14px;border:2px solid var(--line);
  border-top-color:var(--accent);border-radius:50%;animation:s .7s linear infinite;vertical-align:-2px}
@keyframes s{to{transform:rotate(360deg)}}
