:root{
  --bg:#0d0e12; --bg2:#14161c; --panel:#181b23; --panel2:#1f232d;
  --border:#272c38; --text:#e7e9ee; --muted:#8b93a7; --muted2:#5d6577;
  --accent:#c13584; --accent2:#f56040; --accent3:#833ab4;
  --grad:linear-gradient(45deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);
  --ok:#2ecc71; --warn:#f1c40f; --err:#e74c3c; --info:#3aa3ff; --dry:#7a8296;
  --radius:14px; --shadow:0 8px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--text);
  font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;}
a{color:inherit;text-decoration:none;cursor:pointer}
b{color:#fff}
.muted{color:var(--muted)} .tiny{font-size:11px} .mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}

#app{display:grid;grid-template-columns:236px 1fr;min-height:100vh}

/* sidebar */
.sidebar{background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:18px 14px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:600;padding:6px 8px 18px}
.brand-logo{font-size:26px;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.brand-name b{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nav{display:flex;flex-direction:column;gap:4px;margin-top:6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--muted);font-weight:500;transition:.15s}
.nav-item .ic{width:18px;text-align:center;opacity:.8}
.nav-item:hover{background:var(--panel);color:var(--text)}
.nav-item.active{background:var(--panel2);color:#fff;box-shadow:inset 3px 0 0 var(--accent)}
.sidebar-foot{margin-top:auto;display:flex;flex-direction:column;gap:8px;padding:8px}
.mode-pill{font-size:12px;font-weight:700;letter-spacing:.04em;padding:6px 10px;border-radius:8px;text-align:center;border:1px solid var(--border)}
.mode-pill.dry{color:var(--dry);background:#1a1d25}
.mode-pill.live{color:#fff;background:linear-gradient(45deg,#d62976,#962fbf)}

/* main */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--border);position:sticky;top:0;background:rgba(13,14,18,.85);backdrop-filter:blur(8px);z-index:5}
.topbar h1{font-size:20px;font-weight:600}
.view{padding:24px 28px;max-width:1180px;width:100%}

/* switch */
.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.switch input{display:none}
.slider{width:42px;height:24px;border-radius:20px;background:#2a2f3b;position:relative;transition:.2s}
.slider::before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.2s}
.switch input:checked + .slider{background:#3a4150}
.switch input:checked + .slider::before{transform:translateX(18px)}
.switch-label{font-size:12px;font-weight:700;letter-spacing:.03em;color:var(--dry)}
.switch.live .switch-label{color:var(--accent2)}

/* cards / grid */
.grid{display:grid;gap:16px}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.card h3{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em}
.stat{display:flex;flex-direction:column;gap:6px}
.stat .num{font-size:34px;font-weight:700;line-height:1}
.stat .lbl{color:var(--muted);font-size:13px}
.stat .accent{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* section header */
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.section-head h2{font-size:16px;font-weight:600}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:10px;border:1px solid var(--border);background:var(--panel2);color:var(--text);font-weight:600;font-size:13px;cursor:pointer;transition:.15s}
.btn:hover{border-color:#3a4150;background:#252a36}
.btn.primary{background:linear-gradient(45deg,#d62976,#962fbf);border:none;color:#fff}
.btn.primary:hover{filter:brightness(1.08)}
.btn.ghost{background:transparent}
.btn.danger{color:#ff8a80;border-color:#43292b}
.btn.danger:hover{background:#2a1c1d}
.btn.ok{color:#0d0e12;background:var(--ok);border:none}
.btn.sm{padding:6px 11px;font-size:12px}
.btn:disabled{opacity:.45;cursor:not-allowed}
.row-actions{display:flex;gap:8px;flex-wrap:wrap}

/* table */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:10px 12px;border-bottom:1px solid var(--border)}
td{padding:12px;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.015)}

/* badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.02em}
.badge .dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.badge.running{color:var(--ok);background:rgba(46,204,113,.12)}
.badge.stopped{color:var(--muted);background:rgba(139,147,167,.1)}
.badge.ok{color:var(--ok);background:rgba(46,204,113,.12)}
.badge.error,.badge.err,.badge.blocked{color:var(--err);background:rgba(231,76,60,.12)}
.badge.new{color:var(--info);background:rgba(58,163,255,.12)}
.badge.dry{color:var(--dry);background:rgba(122,130,150,.14)}
.badge.live{color:#fff;background:linear-gradient(45deg,#d62976,#962fbf)}
.badge.success{color:var(--ok);background:rgba(46,204,113,.12)}
.badge.skipped{color:var(--warn);background:rgba(241,196,15,.12)}
.badge.dry_run{color:var(--dry);background:rgba(122,130,150,.14)}

.chip{display:inline-block;padding:2px 8px;border-radius:6px;background:var(--panel2);border:1px solid var(--border);font-size:11px;margin:2px 3px 2px 0}

/* empty state */
.empty{text-align:center;padding:54px 20px;color:var(--muted)}
.empty .big{font-size:40px;margin-bottom:10px;opacity:.5}

/* forms / modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:50;overflow:auto}
.modal{background:var(--panel);border:1px solid var(--border);border-radius:18px;width:100%;max-width:620px;box-shadow:var(--shadow)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}
.modal-head h2{font-size:17px}
.modal-body{padding:20px 22px;max-height:66vh;overflow:auto}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border)}
.x{cursor:pointer;color:var(--muted);font-size:22px;line-height:1}
.x:hover{color:#fff}

.field{margin-bottom:15px}
.field > label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px}
.field .hint{font-size:11px;color:var(--muted2);margin-top:4px}
input[type=text],input[type=number],input[type=password],select,textarea{
  width:100%;background:var(--bg2);border:1px solid var(--border);border-radius:10px;color:var(--text);padding:10px 12px;font:inherit;outline:none;transition:.15s}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
textarea{resize:vertical;min-height:62px;font-family:ui-monospace,Menlo,monospace;font-size:12px}
.checks{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.check{display:flex;align-items:center;gap:9px;padding:9px 11px;border:1px solid var(--border);border-radius:10px;background:var(--bg2);cursor:pointer}
.check input{width:16px;height:16px;accent-color:var(--accent)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.three{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.sub{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:18px 0 10px;padding-top:14px;border-top:1px dashed var(--border)}

/* segmented (auth method) */
.seg{display:flex;gap:6px;background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:4px}
.seg button{flex:1;padding:8px;border:none;background:transparent;color:var(--muted);font-weight:600;border-radius:7px;cursor:pointer}
.seg button.on{background:var(--panel2);color:#fff}

/* activity log */
.log{font-family:ui-monospace,Menlo,monospace;font-size:12.5px}
.log .ts{color:var(--muted2)}
.log td{padding:9px 12px}
.filters{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.filters select,.filters input{width:auto;min-width:130px}

.feed{display:flex;flex-direction:column;gap:1px}
.feed-row{display:flex;align-items:center;gap:12px;padding:9px 4px;border-bottom:1px solid var(--border);font-size:13px}
.feed-row:last-child{border:none}
.feed-row .when{color:var(--muted2);font-size:11px;width:62px;flex:none;font-family:ui-monospace,Menlo,monospace}
.feed-row .act{flex:none;width:84px;font-weight:700}
.feed-row .tgt{color:var(--muted);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.spin{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:sp .7s linear infinite;vertical-align:middle}
@keyframes sp{to{transform:rotate(360deg)}}

/* toast */
.toast-root{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:10px;z-index:100}
.toast{background:var(--panel2);border:1px solid var(--border);border-left:3px solid var(--info);border-radius:10px;padding:12px 16px;min-width:240px;box-shadow:var(--shadow);animation:slide .25s ease}
.toast.ok{border-left-color:var(--ok)} .toast.err{border-left-color:var(--err)} .toast.warn{border-left-color:var(--warn)}
@keyframes slide{from{transform:translateX(40px);opacity:0}}

@media(max-width:860px){#app{grid-template-columns:1fr}.sidebar{display:none}.grid.cols-4{grid-template-columns:repeat(2,1fr)}.grid.cols-3,.grid.cols-2{grid-template-columns:1fr}}
