:root{
  --bg:#0f1320; --panel:#171c2e; --panel2:#1d2440; --line:#252c4d;
  --text:#e6e8f2; --muted:#8a92b2; --accent:#6c8bff; --accent2:#7e6cff;
  --ok:#3ddc8c; --warn:#ffb74d; --err:#ff6b6b;
  --radius:10px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:14px;line-height:1.5}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:inherit;font-size:14px;padding:8px 14px;border-radius:var(--radius);border:1px solid var(--line);background:var(--panel2);color:var(--text);cursor:pointer;transition:all .15s}
button:hover{border-color:var(--accent)}
button.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;font-weight:600}
button.primary:hover{filter:brightness(1.1)}
button.danger{border-color:var(--err);color:var(--err)}
button.ghost{background:transparent}
button:disabled{opacity:.5;cursor:not-allowed}
input,textarea,select{font-family:inherit;font-size:14px;padding:9px 12px;border-radius:var(--radius);border:1px solid var(--line);background:var(--panel);color:var(--text);width:100%}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent)}
textarea{min-height:120px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Consolas,monospace}
label{display:block;margin:12px 0 6px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.hidden{display:none!important}

/* ---- login ---- */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 20% 0%,#1a2050 0%,var(--bg) 50%)}
.login-card{background:var(--panel);padding:32px;border-radius:14px;border:1px solid var(--line);width:380px;max-width:90vw}
.login-card h1{margin:0 0 6px;font-size:22px}
.login-card .sub{color:var(--muted);margin-bottom:24px;font-size:13px}

/* ---- layout ---- */
.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{background:var(--panel);border-right:1px solid var(--line);padding:20px 0;display:flex;flex-direction:column}
.brand{padding:0 20px 20px;border-bottom:1px solid var(--line);font-size:16px;font-weight:700}
.brand small{display:block;font-weight:400;color:var(--muted);font-size:11px;margin-top:4px}
.nav{flex:1;padding:12px 0}
.nav a{display:block;padding:10px 20px;color:var(--text);border-left:3px solid transparent}
.nav a.active{background:var(--panel2);border-left-color:var(--accent);font-weight:600;text-decoration:none}
.nav a:hover{background:var(--panel2);text-decoration:none}
.userbox{padding:16px 20px;border-top:1px solid var(--line);font-size:12px;color:var(--muted)}
.userbox b{display:block;color:var(--text);font-size:13px;font-weight:600}
.main{padding:32px 40px;overflow-x:auto}
.main h1{margin:0 0 6px;font-size:24px}
.main .greet{color:var(--muted);font-size:14px;margin-bottom:24px}

/* ---- panels ---- */
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.card h2{margin:0 0 12px;font-size:16px}
.card h3{margin:0 0 10px;font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}

/* ---- stat tiles ---- */
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.stat .n{font-size:28px;font-weight:700}
.stat .l{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}

/* ---- tables ---- */
table{width:100%;border-collapse:collapse}
th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);font-size:13px}
th{font-weight:600;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em}
tbody tr:hover{background:var(--panel2)}
.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.badge.draft{background:#2a3251;color:#9fb1ff}
.badge.sending{background:#3a2c5e;color:#cab1ff}
.badge.completed{background:#1f3b2c;color:#3ddc8c}
.badge.paused{background:#3b3325;color:#ffb74d}
.badge.failed{background:#3b1f1f;color:#ff6b6b}

/* ---- modal ---- */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:50}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px;max-width:720px;width:90%;max-height:90vh;overflow-y:auto}
.modal h2{margin:0 0 8px}
.modal .close{float:right;background:none;border:none;font-size:20px;color:var(--muted);cursor:pointer}

/* ---- toolbar ---- */
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* ---- toast ---- */
.toast{position:fixed;bottom:24px;right:24px;background:var(--panel);border:1px solid var(--line);padding:12px 18px;border-radius:var(--radius);z-index:99;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.toast.ok{border-color:var(--ok)}
.toast.err{border-color:var(--err)}

/* ---- progress ---- */
.bar{height:6px;background:var(--panel2);border-radius:3px;overflow:hidden}
.bar > div{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .3s}

/* ---- ai panel ---- */
.ai-box{background:linear-gradient(135deg,#1a1f3d,#2a1f3d);border:1px solid #3a3160;border-radius:var(--radius);padding:14px;margin-bottom:14px}
.ai-box h3{color:#cab1ff;margin:0 0 8px}
.muted{color:var(--muted);font-size:12px}
.pill{display:inline-block;padding:2px 8px;border-radius:8px;background:var(--panel2);font-size:11px;margin-right:4px}
.kbd{font-family:ui-monospace,monospace;background:var(--panel2);padding:1px 6px;border-radius:4px;font-size:12px}
hr{border:none;border-top:1px solid var(--line);margin:18px 0}
