:root{                      /* thème clair (par défaut) */
  --bg:#f4f6f9; --card:#ffffff; --ink:#1b2330; --muted:#647084; --line:#e3e8ef;
  --accent:#2f6df6; --ok:#1f9d55; --err:#d64545; --warn:#b9892f;
  --console-bg:#f6f8fa; --console-ink:#1b2330; --input-bg:#ffffff;
}
[data-theme="dark"]{        /* thème sombre (activation manuelle, mémorisé) */
  --bg:#0f1216; --card:#181d24; --ink:#e8ecf1; --muted:#8b96a5; --line:#2a313b;
  --accent:#4f87ff; --ok:#2bbd6e; --err:#e06b6b; --warn:#caa23a;
  --console-bg:#0a0e12; --console-ink:#e8ecf1; --input-bg:#0f141a;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font:15px/1.5 system-ui,Segoe UI,Roboto,sans-serif}
header{display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;border-bottom:1px solid var(--line)}
header h1{margin:0;font-size:18px;letter-spacing:.3px}
.theme-btn{background:none;border:1px solid var(--line);border-radius:8px;
  font-size:16px;line-height:1;padding:6px 9px;cursor:pointer;color:var(--ink)}
main,section{max-width:880px;margin:18px auto;padding:0 16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:20px;margin:18px auto}
h2{font-size:16px;margin:0 0 12px}
.muted{color:var(--muted);font-size:13px}
.hidden{display:none!important}
.error{color:var(--err);min-height:18px;margin:8px 0 0}
label{display:block;margin:12px 0}
input:not([type="checkbox"]),select{width:100%;padding:10px 12px;margin-top:6px;background:var(--input-bg);color:var(--ink);
  border:1px solid var(--line);border-radius:8px;font-size:15px}
.row{display:flex;gap:8px;align-items:stretch;margin-top:6px}
.row input{margin-top:0}
.row button{margin-top:0;white-space:nowrap}
small{display:block;margin-top:4px}
button{background:var(--accent);color:#fff;border:0;border-radius:8px;padding:10px 16px;
  font-size:15px;cursor:pointer;margin-top:8px}
button:hover{filter:brightness(1.06)}
button:disabled{opacity:.6;cursor:default}
.link{background:none;border:0;color:var(--accent);cursor:pointer;text-decoration:none;font-size:14px;padding:0;margin:0}
.topbar{display:flex;justify-content:space-between;align-items:center;max-width:880px;margin:8px auto;padding:0 16px}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:8px 6px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:600}
.badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;border:1px solid var(--line)}
.badge-queued{color:var(--muted)} .badge-running{color:var(--accent);border-color:var(--accent)}
.badge-success{color:var(--ok);border-color:var(--ok)} .badge-error{color:var(--err);border-color:var(--err)}
.badge-canceled{color:var(--warn);border-color:var(--warn)}
.docs-head{display:flex;justify-content:space-between;align-items:center;margin:10px 0 6px}
.docs-list{border:1px solid var(--line);border-radius:8px;max-height:240px;overflow:auto;padding:6px 10px}
.doc-item{display:flex;align-items:center;gap:8px;margin:4px 0;font-size:14px}
.doc-item input{flex:0 0 auto;width:16px;height:16px;margin:0;padding:0}
.doc-item span{flex:1 1 auto}
.job-actions{display:flex;gap:16px;align-items:center;margin:12px 0;flex-wrap:wrap}
.console{background:var(--console-bg);color:var(--console-ink);border:1px solid var(--line);border-radius:8px;
  padding:14px;height:48vh;overflow:auto;white-space:pre-wrap;word-break:break-word;
  font:13px/1.45 ui-monospace,Menlo,Consolas,monospace}

/* Vrais boutons (CTA), bandeau de résultat */
.btn{display:inline-block;background:var(--accent);color:#fff;border:0;border-radius:8px;
  padding:10px 16px;font-size:15px;cursor:pointer;text-decoration:none;line-height:1.25;margin:0}
.btn:hover{filter:brightness(1.06)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-big{font-size:16px;padding:13px 22px;margin-top:12px}
.job-top{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.log-label{margin:16px 0 6px;text-transform:uppercase;letter-spacing:.5px;font-size:12px}
.banner{margin:16px 0;padding:18px 20px;border-radius:12px;border:1px solid var(--line)}
.banner-title{font-size:17px;font-weight:700;margin-bottom:4px}
.banner.ok{border-color:var(--ok);background:color-mix(in srgb,var(--ok) 12%,var(--card))}
.banner.err{border-color:var(--err);background:color-mix(in srgb,var(--err) 12%,var(--card))}
.banner.warn{border-color:var(--warn);background:color-mix(in srgb,var(--warn) 12%,var(--card))}
