/* ComfyCool Configurator — admin (framework-vrij, professioneel) */
:root{
  --bg:#eef1f6; --panel:#fff; --ink:#1f2430; --soft:#6b7280;
  --line:#e6e9f0; --primary:#357659; --accent:#345C82;
  --primary-d:#2b6049; --danger:#c0392b; --ok:#1f8a55; --warn:#b9791b;
  --radius:12px; --shadow:0 1px 2px rgba(16,24,40,.04),0 8px 24px rgba(16,24,40,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"Plus Jakarta Sans",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
h1{font-size:1.55rem;font-weight:800;letter-spacing:-.02em}
h2{font-size:1.1rem;font-weight:700;margin-bottom:12px}
code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#f1f3f8;
  padding:2px 6px;border-radius:5px;font-size:.86em}
.muted{color:var(--soft)}.hint{font-size:.85rem;color:var(--soft);margin:4px 0 10px}
.lead{color:var(--soft);margin:8px 0 24px;max-width:70ch}

/* ── Auth (login/setup) ── */
body.auth{display:flex;min-height:100vh;align-items:center;justify-content:center;
  background:radial-gradient(circle at 30% 20%,#2f6b51,#244e3c 60%,#1d2b3a)}
.auth-card{background:#fff;padding:38px 34px;border-radius:16px;
  box-shadow:0 24px 60px rgba(0,0,0,.28);width:380px;max-width:92vw}
.auth-brand{font-weight:800;font-size:1.15rem;margin-bottom:20px;color:var(--primary)}
.auth-brand span{color:var(--accent);font-weight:600}

/* ── Topbar ── */
.topbar{display:flex;justify-content:space-between;align-items:center;
  background:var(--panel);border-bottom:1px solid var(--line);padding:0 24px;height:60px;
  position:sticky;top:0;z-index:20}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{height:26px;width:auto}
.brand-sub{font-size:.82rem;color:var(--soft);font-weight:600;border-left:1px solid var(--line);padding-left:12px}
.topbar-right{display:flex;align-items:center;gap:16px}
.who{display:flex;align-items:center;gap:9px;font-size:.9rem;font-weight:600}
.avatar{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;
  display:grid;place-items:center;font-size:.8rem;font-weight:700}
.btn-ghost{border:1px solid var(--line);padding:7px 14px;border-radius:8px;
  font-size:.88rem;font-weight:600;color:var(--ink);background:#fff;cursor:pointer}
.btn-ghost:hover{background:#f6f7fb;text-decoration:none}

/* ── Shell + sidebar ── */
.shell{display:flex;min-height:calc(100vh - 60px)}
.sidebar{width:236px;background:var(--panel);border-right:1px solid var(--line);
  padding:18px 14px;display:flex;flex-direction:column;flex-shrink:0}
.sidebar ul{list-style:none;flex:1;display:flex;flex-direction:column;gap:3px}
.sidebar a,.sidebar .disabled{display:flex;align-items:center;gap:11px;padding:10px 12px;
  border-radius:9px;font-size:.93rem;font-weight:600;color:#3b4252}
.sidebar a:hover{background:#f4f6fa;text-decoration:none}
.sidebar a.active{background:color-mix(in srgb,var(--primary) 12%,#fff);color:var(--primary-d)}
.sidebar .ni{width:20px;text-align:center;opacity:.7;font-size:1rem}
.sidebar a.active .ni{opacity:1}
.sidebar .disabled{color:#aeb4c0;cursor:not-allowed}
.sidebar .disabled em{font-size:.68rem;font-style:normal;background:#f1f3f8;color:#9aa1ad;
  padding:1px 7px;border-radius:999px;margin-left:auto}
.sb-foot{padding:14px 12px 4px;color:#aeb4c0;font-size:.78rem;font-weight:600}
.sb-foot span{color:#c4c9d2;font-weight:500}
.content{flex:1;overflow:auto}
.content-in{max-width:1080px;padding:32px 40px}

/* ── Page head ── */
.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:6px}
.page-head .back{display:inline-block;font-size:.85rem;font-weight:600;color:var(--soft);margin-bottom:6px}
.fb-actions{display:flex;gap:10px}

/* ── Panels & cards ── */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;margin-top:20px;box-shadow:var(--shadow)}
.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.panel-head h2{margin:0}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-top:6px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow)}
.card-num{font-size:2rem;font-weight:800;color:var(--primary)}
.card-lbl{color:var(--soft);font-size:.86rem;margin-top:2px;font-weight:600}
.card.ok{border-color:#bfe3cf}.card.warn{border-color:#f0d9ad}

/* ── Tables ── */
table.data{width:100%;border-collapse:collapse;font-size:.92rem}
table.data th{text-align:left;padding:13px 16px;background:#f7f9fc;color:var(--soft);
  font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}
table.data td{padding:13px 16px;border-top:1px solid var(--line)}
table.data tr:hover td{background:#fafbfe}

/* ── Pills / alerts ── */
.pill{font-size:.7rem;padding:3px 10px;border-radius:999px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.pill.ok{background:#e7f5ee;color:var(--ok)}
.pill.warn{background:#fcf2dd;color:var(--warn)}
.pill:not(.ok):not(.warn){background:#eef0f4;color:#6b7280}
.alert{padding:12px 16px;border-radius:9px;margin:14px 0;font-size:.92rem}
.alert-ok{background:#e9f6ef;color:#1c6b45;border:1px solid #b9ddc8}
.alert-error{background:#fdeceb;color:#9e2b22;border:1px solid #f2bdb8}
.alert ul{margin:6px 0 0 18px}

/* ── Buttons ── */
button{font:inherit;cursor:pointer}
.btn-primary{background:var(--primary);color:#fff;border:0;padding:10px 20px;border-radius:9px;
  font-weight:700;font-size:.92rem}
.btn-primary:hover{background:var(--primary-d)}
.btn-ghost-sm{display:inline-block;border:1px solid var(--line);background:#fff;color:#3b4252;
  padding:5px 11px;border-radius:7px;font-size:.82rem;font-weight:600;margin-left:4px}
.btn-ghost-sm:hover{background:#f4f6fa;text-decoration:none}
.btn-ghost-sm.danger,.btn-ghost.danger{color:var(--danger);border-color:#f0c8c4}
.btn-ghost-sm.danger:hover{background:#fdeceb}

/* ── Forms ── */
form{max-width:620px}
fieldset{border:1px solid var(--line);border-radius:10px;padding:18px;margin-bottom:18px}
legend{padding:0 8px;font-weight:700;color:var(--primary)}
label{display:block;margin:12px 0;font-size:.88rem;font-weight:600}
input,select,textarea{width:100%;padding:10px 12px;margin-top:5px;border:1px solid #d6dae3;
  border-radius:8px;font:inherit;font-weight:400;background:#fff}
input:focus,select:focus,textarea:focus{outline:2px solid color-mix(in srgb,var(--accent) 50%,#fff);
  border-color:var(--accent)}
textarea.code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;line-height:1.5}

/* ── Modal (<dialog>) ── */
dialog.modal{border:0;border-radius:14px;padding:0;box-shadow:0 24px 60px rgba(0,0,0,.3);max-width:440px;width:92vw}
dialog.modal::backdrop{background:rgba(20,24,33,.45)}
dialog.modal form{padding:26px;max-width:none}
dialog.modal h2{margin-bottom:14px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}

/* ── Flow builder ── */
.fb-grid{display:grid;grid-template-columns:1fr 280px;gap:20px;align-items:start}
.fb-side .panel:first-child{margin-top:20px}
dl.meta{display:grid;grid-template-columns:auto 1fr;gap:6px 14px;font-size:.88rem}
dl.meta dt{color:var(--soft);font-weight:600}
.versions{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:.88rem}
.versions li{display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:8px 10px;border:1px solid var(--line);border-radius:8px}
.fb-steps{display:flex;flex-direction:column;gap:10px}
.fb-step{border:1px solid var(--line);border-radius:10px;background:#fcfcfe}
.fb-step-head{display:flex;align-items:center;gap:10px;padding:11px 14px}
.fb-grip{color:#c4c9d2;cursor:grab}
.fb-step-title{font-weight:700}
.fb-step-type{font-size:.72rem;background:#eef0f4;color:#6b7280;padding:2px 9px;
  border-radius:999px;font-weight:700}
.fb-step-head .spacer{flex:1}
.fb-step-body{padding:6px 16px 18px;border-top:1px dashed var(--line);display:flex;
  flex-direction:column;gap:6px}
.fb-f{display:block;font-size:.85rem;font-weight:600}
.fb-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.fb-check{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.88rem;margin:8px 0}
.fb-check input{width:auto;margin:0}
.fb-opts,.fb-cond{border:1px dashed var(--line);border-radius:8px;padding:12px;background:#fff}
.fb-opt-row,.fb-cond-row{display:flex;gap:8px;margin-bottom:8px}
.fb-opt-row input,.fb-cond-row input,.fb-cond-row select{margin-top:0}
.fb-sub{border-left:3px solid var(--accent);padding:10px 0 10px 14px;margin:8px 0}
.fb-sub-h{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--soft);
  font-weight:700;margin-bottom:8px}
.fb-advanced summary{cursor:pointer;list-style:none}
.fb-advanced summary::-webkit-details-marker{display:none}
.fb-advanced summary h2::before{content:'▸ ';color:var(--soft)}
.fb-advanced[open] summary h2::before{content:'▾ '}

@media(max-width:880px){.fb-grid{grid-template-columns:1fr}.content-in{padding:22px}
  .sidebar{width:64px}.sidebar a span:not(.ni),.sidebar .disabled em,.sb-foot{display:none}}
