:root{
  --bg:#0f1115; --panel:#171a21; --panel2:#1d2129; --line:#2a2f3a;
  --txt:#e6e9ef; --muted:#8b93a4; --accent:#5b8cff; --accent2:#3a6df0;
  --green:#3fb950; --amber:#d29922; --red:#f85149; --user:#243049;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{background:var(--bg);color:var(--txt);font:14px/1.5 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}
.hidden{display:none !important}
button{cursor:pointer;font:inherit}
a{color:var(--accent);text-decoration:none}
.btn{background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:7px;padding:6px 12px}
.btn:hover{border-color:var(--accent)}
.btn.primary{background:var(--accent2);border-color:var(--accent2)}
.btn.primary:disabled{opacity:.5;cursor:not-allowed}
.btn.danger:hover{border-color:var(--red);color:var(--red)}

/* login */
.login{position:fixed;inset:0;display:grid;place-items:center;background:var(--bg)}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:32px;width:340px;text-align:center}
.login-card h1{margin:0 0 6px;font-size:22px}
.login-card p{color:var(--muted);margin:0 0 18px}
.login-card input{width:100%;padding:10px;border-radius:8px;border:1px solid var(--line);background:var(--bg);color:var(--txt);margin-bottom:12px}
.login-card button{width:100%;padding:10px;background:var(--accent2);border:none;border-radius:8px;color:#fff}
.err{color:var(--red);margin-bottom:10px;min-height:18px;font-size:13px}

/* layout */
.app{display:grid;grid-template-columns:260px 1fr 320px;height:100vh;overflow:hidden}
.sidebar{background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;min-height:0}
.brand{font-weight:700;font-size:16px;padding:16px;border-bottom:1px solid var(--line)}
.sites-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px 6px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}
.sites-head button{background:none;border:none;color:var(--muted);font-size:16px;margin-left:6px}
.sites-head button:hover{color:var(--accent)}
.site-list{list-style:none;margin:0;padding:0;overflow:auto;flex:1}
.site-list li{padding:10px 16px;border-bottom:1px solid var(--line);cursor:pointer;display:flex;align-items:center;gap:8px}
.site-list li:hover{background:var(--panel2)}
.site-list li.active{background:var(--panel2);border-left:3px solid var(--accent)}
.dot{width:8px;height:8px;border-radius:50%;background:#555;flex:none}
.dot.running{background:var(--green)}
.dot.busy{background:var(--amber);animation:pulse 1s infinite}
@keyframes pulse{50%{opacity:.3}}
.site-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sidebar-foot{padding:12px 16px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px;font-size:13px}
.sidebar-foot .who{color:var(--muted);flex:1;overflow:hidden;text-overflow:ellipsis}
.sidebar-foot button{background:none;border:1px solid var(--line);color:var(--muted);border-radius:7px;padding:5px 9px}

/* main */
.main{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line)}
.site-title{display:flex;align-items:center;gap:10px;font-weight:600}
.badge{font-size:11px;padding:3px 9px;border-radius:20px;background:var(--panel2);color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.badge.running{color:var(--green)}
.badge.running.busy{color:var(--amber)}
.actions{display:flex;gap:8px}
.chat-wrap{flex:1;display:flex;flex-direction:column;min-height:0;position:relative}
.messages{flex:1;overflow:auto;padding:22px;display:flex;flex-direction:column;gap:14px}
.msg{max-width:80%;padding:11px 14px;border-radius:12px;white-space:pre-wrap;word-wrap:break-word}
.msg.user{align-self:flex-end;background:var(--user)}
.msg.assistant{align-self:flex-start;background:var(--panel2);border:1px solid var(--line)}
.msg.result{align-self:flex-start;background:#16241a;border:1px solid #1f4426}
.msg .who{font-size:11px;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}
.tool{align-self:flex-start;max-width:80%;font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--muted);background:#12151b;border:1px dashed var(--line);border-radius:8px;padding:7px 10px}
.tool b{color:var(--accent)}
.sys{align-self:center;color:var(--muted);font-size:12px;font-style:italic}
.cost{font-size:11px;color:var(--muted);margin-top:6px}
.composer{display:flex;gap:10px;padding:14px 18px;border-top:1px solid var(--line)}
.composer textarea{flex:1;resize:none;background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:10px;padding:11px 13px;max-height:160px}
.composer textarea:focus{outline:none;border-color:var(--accent)}

/* right bar */
.rightbar{background:var(--panel);border-left:1px solid var(--line);display:flex;flex-direction:column;min-width:0;min-height:0}
.tabs{display:flex;border-bottom:1px solid var(--line)}
.tab{flex:1;background:none;border:none;color:var(--muted);padding:13px;border-bottom:2px solid transparent}
.tab.active{color:var(--txt);border-bottom-color:var(--accent)}
.tabpane{flex:1;overflow:auto;padding:14px}
.task-add{display:flex;gap:8px;margin-bottom:12px}
.task-add input{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:7px;color:var(--txt);padding:8px}
.task-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.task-list li{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:9px 11px;display:flex;gap:9px;align-items:flex-start}
.task-list .st{cursor:pointer;flex:none;font-family:ui-monospace,monospace}
.task-list .st.todo{color:var(--muted)}
.task-list .st.doing{color:var(--amber)}
.task-list .st.done{color:var(--green)}
.task-list .ttl{flex:1}
.task-list .done .ttl{text-decoration:line-through;color:var(--muted)}
.task-list .del{background:none;border:none;color:var(--muted);font-size:14px}
.task-list .del:hover{color:var(--red)}
.context-view{white-space:pre-wrap;font-family:ui-monospace,Menlo,monospace;font-size:11.5px;color:var(--muted);margin:0}

/* modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:grid;place-items:center;z-index:50}
.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:26px;width:420px}
.modal-card h2{margin:0 0 4px}
.modal-card .hint{color:var(--muted);font-size:13px;margin:0 0 16px}
.modal-card label{display:block;font-size:13px;color:var(--muted);margin-bottom:12px}
.modal-card label.chk{display:flex;gap:8px;align-items:center}
.modal-card input[type=text],.modal-card input:not([type]){width:100%;margin-top:4px;padding:9px;border-radius:7px;border:1px solid var(--line);background:var(--bg);color:var(--txt)}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}
.ns-out{background:#12151b;border:1px solid var(--line);border-radius:7px;padding:10px;font-family:ui-monospace,monospace;font-size:11.5px;max-height:200px;overflow:auto;white-space:pre-wrap;margin-bottom:12px}

/* remote-site tag in the sidebar list */
.kind-tag {
  margin-left: auto;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--muted, #9aa);
  border: 1px solid currentColor;
  border-radius: 3px;
  padding: 0 4px;
  opacity: .8;
}

/* ---- files tab ---- */
.file-add { display:flex; gap:6px; align-items:center; margin:8px 0; }
.file-add input[type=file] { flex:1; font-size:12px; color:var(--muted,#9aa); }
.file-msg { font-size:12px; color:var(--muted,#9aa); min-height:16px; margin-bottom:6px; }
.file-list { list-style:none; padding:0; margin:0; }
.file-list li { display:flex; align-items:center; gap:8px; padding:5px 4px; border-bottom:1px solid rgba(128,128,128,.15); }
.file-list li.empty { color:var(--muted,#9aa); border:0; }
.file-list .fname { flex:1; text-decoration:none; color:inherit; word-break:break-all; }
.file-list .fname:hover { text-decoration:underline; }
.file-list .fmeta { font-size:11px; color:var(--muted,#9aa); white-space:nowrap; }
.file-list .del { background:none; border:0; color:#b32d2e; cursor:pointer; font-size:16px; line-height:1; }
.file-progress { width:100%; height:8px; margin:4px 0; }

/* jump-to-latest button (floats above the composer) */
.scroll-down{position:absolute;right:24px;bottom:90px;width:38px;height:38px;border-radius:50%;
  background:var(--accent2);color:#fff;border:1px solid var(--accent2);font-size:18px;line-height:1;
  display:flex;align-items:center;justify-content:center;z-index:5;box-shadow:0 2px 10px rgba(0,0,0,.45)}
.scroll-down:hover{background:var(--accent)}

/* ---- mobile responsive ---- */
.mobile-only{display:none}
.icon-btn{background:none;border:1px solid var(--line);color:var(--txt);border-radius:7px;padding:6px 10px;font-size:16px;line-height:1;flex:none}
.icon-btn:hover{border-color:var(--accent)}
#drawerBackdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55}

@media (max-width:820px){
  .app{grid-template-columns:1fr}             /* chat fills the screen */
  .mobile-only{display:inline-flex !important}
  /* side panels become slide-in drawers over the chat */
  .sidebar,.rightbar{position:fixed;top:0;bottom:0;z-index:60;width:84vw;max-width:330px;
    transition:transform .25s ease}
  .sidebar{left:0;transform:translateX(-100%)}
  .rightbar{right:0;transform:translateX(100%)}
  .sidebar.open,.rightbar.open{transform:translateX(0);box-shadow:0 0 40px rgba(0,0,0,.55)}
  .topbar{gap:8px;padding:10px 12px}
  .site-title{flex:1;min-width:0}
  #curSite{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .actions{flex-wrap:wrap;justify-content:flex-end;gap:6px}
  .actions .btn{padding:6px 9px;font-size:12.5px}
  .messages{padding:14px}
  .msg{max-width:92%}
  .composer{padding:10px 12px}
  .scroll-down{right:16px;bottom:84px}
}

/* ---- cases / bills ---- */
.case-list,.bill-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.case-card{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:10px 11px}
.case-card .ch{display:flex;justify-content:space-between;align-items:center;gap:8px}
.case-card .cn{font-family:ui-monospace,monospace;font-size:12px;word-break:break-all}
.case-card .st{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.case-card .exc{color:var(--red);font-weight:600}
.case-card .ok{color:var(--green)}
.case-card .links{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap}
.case-card .links a,.case-card .links button{font-size:12px;background:none;border:1px solid var(--line);border-radius:6px;padding:3px 8px;color:var(--txt)}
.case-card .links a:hover,.case-card .links button:hover{border-color:var(--accent)}
.bill-list li{display:flex;align-items:center;gap:8px;padding:6px 4px;border-bottom:1px solid rgba(128,128,128,.15)}
.bill-list .bn{flex:1;word-break:break-all}
.bill-list .proc{background:var(--accent2);border:none;color:#fff;border-radius:6px;padding:3px 9px;font-size:12px}
.flagpill{display:inline-block;font-size:10px;padding:1px 6px;border-radius:10px;border:1px solid var(--amber);color:var(--amber);margin-left:6px}
.recon{margin-top:6px;font-size:11.5px;border-radius:6px;padding:5px 8px;line-height:1.35}
.recon.ok{background:#16241a;border:1px solid #1f4426;color:var(--green)}
.recon.bad{background:#2a1416;border:1px solid #5a2326;color:var(--red)}

/* ---- settings page ---- */
.settings-wrap{max-width:1000px;margin:0 auto;padding:0 16px 60px}
.settings-top{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg);z-index:2}
.settings-top .back{font-weight:600}
.settings-main{display:flex;flex-direction:column;gap:18px;margin-top:18px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px 20px}
.card h2{margin:0 0 6px;font-size:16px}
.card .row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-top:10px}
.card label{display:flex;flex-direction:column;font-size:12px;color:var(--muted);gap:4px}
.card input,.card select{background:var(--panel2);border:1px solid var(--line);border-radius:7px;color:var(--txt);padding:8px}
.card code{background:var(--panel2);padding:1px 5px;border-radius:4px;font-size:12px}
.status-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-top:6px}
.kv{background:var(--panel2);border:1px solid var(--line);border-radius:8px;padding:9px 11px;display:flex;flex-direction:column;gap:3px}
.kv span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.kv b{font-size:15px}
table.grid{width:100%;border-collapse:collapse;margin-top:10px;font-size:13px}
table.grid th,table.grid td{text-align:left;padding:7px 9px;border-bottom:1px solid var(--line)}
table.grid th{color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em}
table.grid .muted{color:var(--muted)}
.btn.sm{padding:3px 9px;font-size:12px}
.out{margin-top:12px;background:#12151b;border:1px solid var(--line);border-radius:7px;padding:10px;font-family:ui-monospace,monospace;font-size:12px;white-space:pre-wrap}
.addrule{margin-top:12px}
