*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0;width:100%;max-width:100vw;overflow-x:hidden}:root{--bg:#020617;--bg-alt:#020617;--panel-bg:#020617;--panel-inner-bg:#020617;--border:#1e293b;--shadow:#000;--accent:#3b82f6;--accent-soft:rgba(59,130,246,.14);--accent-warn:#eab308;--accent-error:#ef4444;--text:#f9fafb;--muted:#9ca3af}body{min-height:100vh;background:radial-gradient(circle at top left,#020617 0,#020617 45%,#020617 100%);color:var(--text);font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif}a{color:inherit}a,a.tag-link{text-decoration:none}.app-root{min-height:100vh;display:flex;flex-direction:column;width:100%;max-width:100vw;overflow-x:hidden}.app-header{padding:1.1rem 1.5rem;border-bottom:1px solid var(--border);background:#020617;justify-content:space-between;gap:1rem;flex-wrap:wrap}.app-header,.app-header-main{display:flex;align-items:center}.app-header-main{gap:.9rem;min-width:0}.app-header-logo{display:flex;align-items:center;justify-content:center}.app-header-logo img{display:block}.app-header-titles{display:flex;flex-direction:column;gap:2px;min-width:0}.app-header-title{font-size:1.2rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em}.app-header-subtitle{font-size:.75rem;color:var(--muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.app-header-side{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}.tag-row{display:flex;flex-wrap:wrap;gap:.4rem}.tag-pill{padding:2px 8px;border-radius:999px;border:1px solid var(--border);font-size:.65rem;text-transform:uppercase;background:rgba(15,23,42,.9);color:var(--muted)}.tag-link{cursor:pointer}.status-badge{padding:2px 7px;border-radius:999px;border:1px solid var(--border);font-size:.68rem;text-transform:uppercase;letter-spacing:.08em}.status-idle{background:rgba(15,23,42,.9);color:var(--muted)}.status-busy{background:rgba(234,179,8,.15);color:#eab308}.status-error{background:rgba(239,68,68,.16);color:#fecaca}.header-status{margin-top:4px}.app-main{flex:1 1;padding:1.1rem 1.5rem 1.4rem;display:flex;gap:1rem;align-items:stretch;width:100%;max-width:100vw;overflow-x:hidden}.panel{border:1px solid var(--border);background:#020617;box-shadow:0 0 0 1px #020617;display:flex;flex-direction:column;min-height:0;border-radius:12px}.panel-left{flex:0 0 300px;max-width:360px}.panel-center{flex:1 1 auto;min-width:0}.panel-right{flex:0 0 260px;max-width:320px}.panel-header{padding:.7rem .9rem;border-bottom:1px solid var(--border);background:#020617;display:flex;justify-content:space-between;align-items:center}.panel-title{font-size:.7rem;text-transform:uppercase;font-weight:700;letter-spacing:.12em;color:var(--muted)}.panel-subtitle{font-size:.68rem;color:var(--muted)}.panel-body{padding:.8rem .9rem .9rem;gap:.75rem}.panel-body,.subpanel{display:flex;flex-direction:column}.subpanel{border:1px solid var(--border);background:#020617;border-radius:10px;padding:.6rem .7rem;gap:.45rem}.subpanel-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.3rem}.subpanel-title{font-size:.72rem;text-transform:uppercase;font-weight:700;color:var(--muted)}.field-label,.subpanel-caption{font-size:.65rem;color:var(--muted)}.field-label{text-transform:uppercase;margin-bottom:2px}.field-note{color:var(--muted)}.field-note,.key-display{font-size:.62rem;margin-top:3px}.key-display{border-radius:6px;border:1px dashed var(--border);background:#020617;padding:4px 6px;word-break:break-all}.input-brutal,.textarea-brutal{width:100%;border-radius:6px;border:1px solid var(--border);padding:6px 8px;font-size:.72rem;background:#020617;color:var(--text);outline:none}.input-brutal::placeholder,.textarea-brutal::placeholder{color:#4b5563}.input-brutal:focus,.textarea-brutal:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-soft);background:#020617}.textarea-brutal{resize:vertical;min-height:70px}.btn-row{display:flex;flex-wrap:wrap;gap:.4rem}.btn-brutal{border-radius:999px;border:1px solid var(--border);padding:5px 10px;font-size:.68rem;text-transform:uppercase;background:#020617;color:var(--text);cursor:pointer;transition:transform 80ms ease-out,box-shadow 80ms ease-out,background 80ms ease-out,border-color 80ms ease-out}.btn-primary{background:#3b82f6;border-color:#3b82f6;color:#020617}.btn-ghost{background:#020617}.btn-brutal:hover:not(:disabled){transform:translateY(1px);box-shadow:0 0 0 1px #111827;background:#020617}.btn-brutal:disabled{opacity:.55;cursor:default}.debug-list{display:flex;flex-direction:column;gap:.5rem}.debug-item-label{font-size:.65rem;text-transform:uppercase;color:var(--muted);margin-bottom:2px}.debug-item-value{font-size:.65rem;border-radius:6px;border:1px dashed var(--border);background:#020617;padding:4px 6px;word-break:break-all}.chat-shell{display:grid;grid-template-columns:320px minmax(0,1fr);grid-gap:16px;gap:16px;padding:16px;height:calc(100vh - 96px);box-sizing:border-box;width:100%;max-width:100vw;overflow-x:hidden}.chat-sidebar{display:flex;flex-direction:column;gap:12px;border-radius:16px;border:1px solid var(--border);background:#020617;padding:12px;overflow:hidden}.chat-sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.chat-new-btn{padding:4px 10px;font-size:11px}.chat-search{font-size:12px;padding:6px 8px}.chat-list{flex:1 1 auto;overflow-y:auto;margin-top:6px;padding-right:4px;display:flex;flex-direction:column;gap:4px}.chat-list-empty{font-size:12px;opacity:.7}.chat-list-item{text-align:left;width:100%;border-radius:12px;border:1px solid var(--border);background:#020617;padding:8px 10px;display:grid;grid-template-columns:32px 1fr auto;grid-column-gap:8px;column-gap:8px;align-items:center;cursor:pointer}.chat-list-item-active{border-color:var(--accent);background:#020617}.chat-avatar{width:28px;height:28px;border-radius:9999px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;background:#020617;color:var(--muted)}.chat-list-main{overflow:hidden}.chat-list-title{font-size:13px;font-weight:600;color:var(--text)}.chat-list-snippet,.chat-list-title{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.chat-list-snippet{font-size:11px;opacity:.7;color:var(--muted)}.chat-list-time{font-size:10px;opacity:.6;white-space:nowrap;margin-left:4px;color:var(--muted)}.chat-details{border-top:1px solid var(--border);padding-top:8px;margin-top:8px;font-size:11px}.field-label-spaced{margin-top:6px}.textarea-compact{min-height:48px;font-size:12px}.chat-details-actions{margin-top:6px}.chat-main{border-radius:16px;border:1px solid var(--border);flex-direction:column;overflow:hidden}.chat-main,.chat-main-header{background:#020617;display:flex}.chat-main-header{padding:10px 14px;border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px}.chat-main-title{display:flex;flex-direction:column}.chat-main-peer{font-size:14px;font-weight:600}.chat-main-sub{font-size:11px;opacity:.7;color:var(--muted)}.chat-main-actions{display:flex;gap:6px}.chat-main-body{flex:1 1 auto;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px;background:#020617}.messages-empty{font-size:13px;opacity:.7;color:var(--muted)}.chat-bubble{max-width:70%;border-radius:16px;padding:8px 10px;box-shadow:0 1px 2px rgba(15,23,42,.9);font-size:13px}.chat-bubble-in{align-self:flex-start;background:#16a34a;border:1px solid #15803d;color:#ecfdf3}.chat-bubble-pending{opacity:.8;border-style:dashed}.chat-bubble-out{align-self:flex-end;background:#1d4ed8;border:1px solid #1d4ed8;color:#e5e7eb}.chat-bubble-meta{display:flex;justify-content:space-between;gap:.5rem;font-size:.6rem;color:#fff;margin-bottom:3px}.chat-bubble-body{white-space:pre-wrap}.chat-composer{border-top:1px solid var(--border);padding:8px 10px;display:flex;gap:8px;align-items:flex-end;background:#020617}.chat-composer-input{flex:1 1 auto;resize:none;max-height:120px;min-height:38px;font-size:13px}.chat-composer-send{padding:8px 18px;font-size:12px}.chat-list::-webkit-scrollbar,.chat-main-body::-webkit-scrollbar{width:6px}.chat-list::-webkit-scrollbar-track,.chat-main-body::-webkit-scrollbar-track{background:#020617}.chat-list::-webkit-scrollbar-thumb,.chat-main-body::-webkit-scrollbar-thumb{background:#3b82f6}@media (max-width:960px){.app-main{flex-direction:column}.panel{width:100%;max-width:100%;box-shadow:none}.panel-center,.panel-left,.panel-right{flex:1 1 auto}}@media (max-width:900px){.chat-shell{grid-template-columns:1fr;grid-template-rows:auto auto;height:auto}.chat-main{order:1;min-height:50vh}.chat-sidebar{order:2;max-height:40vh}}@media (max-width:640px){.app-header{flex-direction:column}.app-header,.app-header-side,.chat-main-header{align-items:flex-start}.chat-main-header{flex-direction:column}.chat-bubble{max-width:90%}.app-main,.chat-shell{padding-inline:.75rem}}@keyframes spinner-rotate{to{transform:rotate(1turn)}}.spinner{border-radius:999px;border:2px solid rgba(148,163,184,.4);border-top-color:#38bdf8;animation:spinner-rotate .75s linear infinite}.spinner-xs{width:12px;height:12px}.spinner-sm{width:16px;height:16px}.spinner-dark{border-color:#38bdf8 rgba(148,163,184,.6) rgba(148,163,184,.6)}.inline-loader{display:inline-flex;align-items:center;gap:.35rem;font-size:.7rem;opacity:.9}