:root{--bg:#0b0e14;--panel:#141925;--panel-2:#1b2233;--border:#273043;--text:#e6e9ef;--muted:#9aa4b8;--accent:#5b8cff;--green:#34d399;--amber:#fbbf24;--red:#f87171;--violet:#a78bfa;--cyan:#22d3ee;--blue:#60a5fa;--slate:#94a3b8;--radius:10px}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.sidebar{background:var(--panel);border-right:1px solid var(--border);padding:18px 12px;position:-webkit-sticky;position:sticky;top:0;height:100vh}.brand{font-weight:700;font-size:16px;padding:6px 10px 16px;letter-spacing:.2px}.brand span{color:var(--accent)}.nav{display:flex;flex-direction:column;gap:2px}.nav a{padding:8px 10px;border-radius:8px;color:var(--muted);font-weight:500}.nav a.active,.nav a:hover{background:var(--panel-2);color:var(--text)}.main{padding:24px 28px;max-width:1200px}.page-title{font-size:22px;font-weight:700;margin:0 0 4px}.page-sub{color:var(--muted);margin:0 0 22px}.grid{display:grid;grid-gap:14px;gap:14px}.grid.cols-2{grid-template-columns:repeat(2,1fr)}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-4{grid-template-columns:repeat(4,1fr)}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.card h3{margin:0 0 12px;font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.stat{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.stat .value{font-size:26px;font-weight:700}.stat .label{color:var(--muted);font-size:13px;margin-top:2px}table{width:100%;border-collapse:collapse}td,th{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px}tr:hover td{background:var(--panel-2)}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid transparent}.badge.green{color:var(--green);background:rgba(52,211,153,.12)}.badge.amber{color:var(--amber);background:rgba(251,191,36,.12)}.badge.red{color:var(--red);background:rgba(248,113,113,.12)}.badge.violet{color:var(--violet);background:rgba(167,139,250,.12)}.badge.cyan{color:var(--cyan);background:rgba(34,211,238,.12)}.badge.blue{color:var(--blue);background:rgba(96,165,250,.12)}.badge.slate{color:var(--slate);background:rgba(148,163,184,.12)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-weight:600;font-size:13px;cursor:pointer}.btn.primary,.btn:hover{border-color:var(--accent)}.btn.primary{background:var(--accent);color:#0b0e14}.btn.ghost{background:transparent}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.sm{padding:4px 9px;font-size:12px}input,select,textarea{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 10px;font:inherit;width:100%}label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}.field{margin-bottom:12px}.field .field-label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}.field .field-label .muted{font-weight:400}.field input,.field select{font-size:14px}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.spacer{flex:1 1}.muted{color:var(--muted)}.error{color:var(--red);font-size:13px}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:600;padding:6px 10px}.table td,.table th{border-bottom:1px solid var(--border)}.table td{padding:8px 10px;vertical-align:top}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:var(--panel-2)}.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.kanban{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(220px,1fr);grid-gap:12px;gap:12px;overflow-x:auto}.kanban .col{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:10px;min-height:120px}.kanban .col h4{margin:0 0 10px;font-size:13px;display:flex;justify-content:space-between}.kanban .ticket{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:9px;margin-bottom:8px}.kanban .ticket .name{font-weight:600}.list-item{padding:12px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;background:var(--panel)}.list-item.unread{border-left:3px solid var(--accent)}.step{border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:10px;background:var(--panel)}.step .head{display:flex;align-items:center;gap:8px;margin-bottom:8px}.step .subject{font-weight:600}.step pre{white-space:pre-wrap;padding:10px;border-radius:8px;margin:8px 0 0;font-family:inherit}.node,.step pre{background:var(--panel-2)}.node{display:inline-block;padding:6px 10px;border:1px solid var(--border);border-radius:8px;margin:0 4px 4px 0;font-size:12px}.banner{background:rgba(248,113,113,.12);border:1px solid var(--red);color:var(--red);padding:10px 14px;border-radius:8px;margin-bottom:16px}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.session{display:flex;align-items:center;justify-content:space-between;gap:8px}.session-user{display:flex;flex-direction:column;line-height:1.2}.session-role{font-size:11px;color:var(--muted);text-transform:capitalize}.session-link{background:none;border:none;color:var(--accent);cursor:pointer;font:inherit;padding:0;text-decoration:none}.session-link:hover{text-decoration:underline}.theme-toggle{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;padding:6px 10px;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font:inherit;font-size:13px;cursor:pointer;transition:border-color .15s ease,color .15s ease}.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.theme-toggle-icon{display:inline-flex}.theme-toggle-label{line-height:1}.login-wrap{min-height:70vh;display:flex;align-items:center;justify-content:center}.login-card{width:320px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:28px}.login-card h1{margin:0;font-size:26px}.login-card h1 span{color:var(--accent)}.login-sub{color:var(--muted);margin:4px 0 20px}.login-card .field{display:block;margin-bottom:14px}.login-card .field span{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}.login-card .field .field-hint{margin-top:5px;margin-bottom:0;color:var(--accent);font-family:var(--mono,monospace)}.login-card input{width:100%;padding:9px 11px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;color:var(--text);font:inherit;box-sizing:border-box}.login-card .btn-primary{width:100%;margin-top:6px;padding:10px;background:var(--accent);color:#04121f;border:none;border-radius:8px;font-weight:600;cursor:pointer}.login-card .btn-primary:disabled{opacity:.6;cursor:default}.login-error{background:rgba(248,113,113,.12);border:1px solid var(--red);color:var(--red);padding:8px 10px;border-radius:8px;font-size:13px;margin-bottom:12px}.login-hint{color:var(--muted);font-size:12px;margin:14px 0 0}.sidebar{display:flex;flex-direction:column}