:root{--bg: #0b1929;--bg-surface: #0f2035;--bg-hover: #142a42;--bg-input: #0d1f33;--text: #e2e8f0;--text-soft: #8899aa;--text-muted: #556677;--accent: #1a8fcf;--accent-bright: #38bdf8;--green: #22c55e;--yellow: #eab308;--red: #ef4444;--line: rgba(255,255,255,.08);--radius: 10px;--radius-sm: 6px;--font: "Inter", -apple-system, sans-serif;--mono: "JetBrains Mono", monospace;--sidebar-w: 300px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.6}#app,.view{height:100%}.login-view{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0b1929,#0d2240)}.login-card{background:var(--bg-surface);border:1px solid var(--line);border-radius:16px;padding:40px;width:100%;max-width:380px;box-shadow:0 20px 60px #0006}.login-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:32px}.login-mark{font-size:28px;font-weight:700;color:#fff;letter-spacing:.04em}.login-sub{font-family:var(--mono);font-size:12px;color:var(--accent-bright);letter-spacing:.1em;text-transform:uppercase;margin-top:4px}.field{margin-bottom:16px}.field label{display:block;font-size:12px;font-weight:600;color:var(--text-soft);margin-bottom:6px;letter-spacing:.04em;text-transform:uppercase}.field input{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:14px;outline:none;transition:border-color .2s}.field input:focus{border-color:var(--accent)}.field input::placeholder{color:var(--text-muted)}.error-msg{margin-top:12px;padding:8px 12px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);color:var(--red);font-size:13px}.success-msg{margin-top:12px;padding:8px 12px;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-sm);color:#4ade80;font-size:13px}.login-hint{margin:4px 0 16px;font-size:12px;line-height:1.5;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#1f9fdf;transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:default;transform:none}.btn-accent{background:var(--green);color:#fff}.btn-accent:hover{background:#16a34a}.btn-ghost:hover{color:var(--text);border-color:var(--text-soft)}.btn-sm{padding:5px 10px;font-size:12px}.btn-full{width:100%;padding:11px}.btn-send{padding:8px 12px;border-radius:8px}#main-view{display:flex}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--line);display:flex;flex-direction:column}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--line)}.sidebar-logo{font-weight:700;font-size:16px;color:#fff}.sidebar-budget{padding:10px 16px;font-family:var(--mono);color:var(--text-muted);border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:2px}.sidebar-budget .budget-main{font-size:14px;font-weight:600;color:var(--text-soft);letter-spacing:.2px}.sidebar-budget .budget-sub{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.sidebar-list{flex:1;overflow-y:auto;padding:8px}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-soft)}.thread-item{position:relative;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s;margin-bottom:2px}.thread-item:hover{background:var(--bg-hover)}.thread-item.active{background:var(--bg-hover);border-left:2px solid var(--accent-bright)}.thread-item.archived .thread-item-title{color:var(--text-soft)}.thread-item-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.thread-item-time{font-size:11px;color:var(--text-muted);font-family:var(--mono);white-space:nowrap}.thread-item-actions{display:none;align-items:center;gap:2px}.thread-item:hover .thread-item-actions,.thread-item.active .thread-item-actions{display:inline-flex}.thread-item:hover .thread-item-time,.thread-item.active .thread-item-time{display:none}.thread-action-btn{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:5px;color:var(--text-soft);cursor:pointer;transition:all .15s;padding:0}.thread-action-btn:hover{background:#ffffff14;color:var(--text)}.thread-action-btn.danger:hover{background:#ef44442e;color:#fca5a5}.thread-action-btn svg{width:13px;height:13px;pointer-events:none}.sidebar-tabs{display:flex;gap:4px;padding:6px 12px 8px;border-bottom:1px solid var(--line)}.sidebar-tab{flex:1;padding:6px 10px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-soft);font-family:var(--font);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.sidebar-tab:hover{background:var(--bg-hover);color:var(--text)}.sidebar-tab.active{background:var(--bg-hover);color:var(--accent-bright);border-color:#38bdf840}.sidebar-tab .tab-count{display:inline-block;margin-left:6px;padding:0 5px;font-size:10px;font-family:var(--mono);background:#ffffff14;border-radius:8px;color:var(--text-muted)}.sidebar-tab.active .tab-count{background:#38bdf82e;color:var(--accent-bright)}.thread-list-empty{padding:24px 16px;text-align:center;font-size:12px;color:var(--text-muted)}.badge{display:inline-block;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600;font-family:var(--mono);text-transform:uppercase;letter-spacing:.05em}.badge-open{background:#eab30826;color:var(--yellow)}.badge-on_test{background:#38bdf826;color:var(--accent-bright)}.badge-on_main{background:#22c55e26;color:var(--green)}.badge-closed{background:#55667726;color:var(--text-muted)}.badge-sm{padding:2px 6px;font-size:9px;border-radius:8px}.content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-soft);text-align:center;padding:40px}.empty-state h2{color:var(--text);font-size:22px}.empty-state p{max-width:400px}#thread-view{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.thread-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--line);gap:16px}.thread-header h1{font-size:16px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.thread-actions{display:flex;gap:8px;align-items:center}.model-picker{display:inline-flex;align-items:center;gap:6px;background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);padding:2px 6px 2px 10px;color:var(--text-soft);font-size:12px;transition:border-color .15s,color .15s}.model-picker:hover{border-color:var(--text-soft);color:var(--text)}.model-icon{opacity:.7;flex-shrink:0}.model-picker select{background:transparent;border:0;color:inherit;font-family:var(--font);font-size:12px;font-weight:600;padding:5px 18px 5px 0;cursor:pointer;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%238899aa' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 2px center}.model-picker select option{background:var(--bg-surface);color:var(--text)}.messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px;display:flex;flex-direction:column;gap:16px;min-height:0}.msg{max-width:80%;padding:12px 16px;border-radius:var(--radius);line-height:1.6;font-size:14px}.msg-user{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:2px}.msg-assistant{align-self:flex-start;background:var(--bg-surface);border:1px solid var(--line);border-bottom-left-radius:2px}.msg-system{align-self:center;background:#eab3081a;border:1px solid rgba(234,179,8,.2);color:var(--yellow);font-size:12px;font-family:var(--mono);max-width:90%;text-align:center}.msg-diff{margin-top:8px;padding:8px;background:#0000004d;border-radius:var(--radius-sm);font-family:var(--mono);font-size:11px}.msg-diff-head{color:var(--accent-bright);font-size:12px;margin-bottom:6px;padding:0 2px}.diff-add{color:var(--green)}.diff-del{color:var(--red)}.diff-file-btn{display:flex;align-items:center;gap:8px;flex-wrap:wrap;width:100%;margin:4px 0;padding:8px 10px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-sm);font-family:var(--mono);font-size:11px;color:var(--text);text-align:left;cursor:pointer;transition:background .12s ease,border-color .12s ease}.diff-file-btn:hover{background:#66aaff14;border-color:#66aaff4d}.diff-file-btn:focus-visible{outline:2px solid var(--accent-bright);outline-offset:1px}.diff-kind-icon{width:14px;height:14px;flex-shrink:0;background-repeat:no-repeat;background-position:center;background-size:contain;opacity:.75}.diff-kind-text{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e6edf7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'/%3E%3Cpolyline points='14 2 14 8 20 8'/%3E%3Cline x1='16' y1='13' x2='8' y2='13'/%3E%3Cline x1='16' y1='17' x2='8' y2='17'/%3E%3Cpolyline points='10 9 9 9 8 9'/%3E%3C/svg%3E")}.diff-kind-image{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e6edf7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='18' height='18' rx='2' ry='2'/%3E%3Ccircle cx='8.5' cy='8.5' r='1.5'/%3E%3Cpolyline points='21 15 16 10 5 21'/%3E%3C/svg%3E")}.diff-kind-video{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e6edf7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolygon points='23 7 16 12 23 17 23 7'/%3E%3Crect x='1' y='5' width='15' height='14' rx='2' ry='2'/%3E%3C/svg%3E")}.diff-kind-binary{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e6edf7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='4' width='16' height='16' rx='2'/%3E%3Cpath d='M8 10h2v4H8zM14 10h2v4h-2z'/%3E%3C/svg%3E")}.diff-path{color:var(--accent-bright);font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.diff-file-btn:hover .diff-path{text-decoration:underline;text-decoration-color:#66aaff80;text-underline-offset:3px}.diff-counts{margin-left:auto;flex-shrink:0}.diff-badge.new{background:#22c55e2e;color:var(--green);font-size:10px;padding:1px 6px;border-radius:999px;font-family:var(--mono);letter-spacing:.04em}.diff-empty{padding:16px;color:var(--text-muted);font-style:italic;text-align:center}.diff-code{background:#00000073}.diff-code table.code{border-collapse:collapse;width:100%;font-family:var(--mono);font-size:12px;line-height:1.5}.diff-code td.ln{-webkit-user-select:none;user-select:none;text-align:right;color:var(--text-muted);padding:0 8px;border-right:1px solid rgba(255,255,255,.06);white-space:pre;vertical-align:top}.diff-code td.cd{padding:0 8px;white-space:pre;color:var(--text);vertical-align:top}.diff-code.side{height:100%}.diff-warn{padding:8px 12px;background:#fbbf241a;color:#fcd34d;font-family:var(--mono);font-size:11px;border-bottom:1px solid rgba(251,191,36,.2)}table.code.side{table-layout:fixed;width:100%}table.code.side col.col-ln{width:52px}table.code.side col.col-cd{width:calc((100% - 104px)/2)}table.code.side thead th{position:sticky;top:0;z-index:1;background:#ffffff0f;text-align:left;padding:6px 10px;font-family:var(--mono);font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:500;border-bottom:1px solid rgba(255,255,255,.08)}table.code.side td.cd{word-break:break-all;white-space:pre-wrap}table.code.side td.cd.del{background:#ef444426;border-left:2px solid rgba(239,68,68,.6)}table.code.side td.cd.add{background:#22c55e26;border-left:2px solid rgba(34,197,94,.6)}table.code.side td.cd.gap{background:#ffffff05}table.code.side tr.gap-row td.gap-cell{text-align:center;color:var(--text-muted);font-style:italic;padding:4px 8px;background:#ffffff05;border-top:1px dashed rgba(255,255,255,.08);border-bottom:1px dashed rgba(255,255,255,.08)}.diff-media{display:grid;gap:12px;padding:12px;background:#0000004d;border-top:1px solid rgba(255,255,255,.06)}.diff-media.pair{grid-template-columns:1fr 1fr}.diff-media.single{grid-template-columns:1fr;justify-items:center}.diff-media.single figure{max-width:min(720px,100%);width:100%}.diff-media figure{display:flex;flex-direction:column;gap:8px;background:#ffffff05;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-sm);padding:10px}.diff-media figcaption{font-family:var(--mono);font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.diff-media img,.diff-media video{max-width:100%;max-height:75vh;width:auto;height:auto;object-fit:contain;background:linear-gradient(45deg,rgba(255,255,255,.04) 25%,transparent 25%) 0 0/16px 16px,linear-gradient(-45deg,rgba(255,255,255,.04) 25%,transparent 25%) 0 8px/16px 16px,linear-gradient(45deg,transparent 75%,rgba(255,255,255,.04) 75%) 8px -8px/16px 16px,linear-gradient(-45deg,transparent 75%,rgba(255,255,255,.04) 75%) -8px 0/16px 16px,#0006;border-radius:4px;display:block;margin:0 auto}.msg-cost{font-size:10px;color:var(--text-muted);font-family:var(--mono);margin-top:4px;text-align:right}.msg-model{display:inline-block;font-size:10px;font-family:var(--mono);color:var(--accent-bright);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;padding:2px 8px;background:#38bdf814;border:1px solid rgba(56,189,248,.2);border-radius:999px}.phase-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;margin-bottom:8px;background:#1a8fcf14;border:1px solid rgba(26,143,207,.25);border-radius:999px;font-size:12px;color:var(--accent-bright);font-family:var(--mono)}.phase-pill .phase-label{color:var(--text-soft)}.msg.streaming .msg-body:after{content:"▍";display:inline-block;margin-left:2px;color:var(--accent-bright);animation:blink 1s steps(1) infinite;font-weight:100}@keyframes blink{50%{opacity:0}}.msg-error{border-color:#ef444466!important;background:#ef444414!important}.msg-error .msg-body{color:#fecaca}.uploads-bar{padding:8px 24px;border-top:1px solid var(--line);display:flex;align-items:center;gap:8px}.uploads-label{font-size:11px;color:var(--text-muted);font-family:var(--mono)}.uploads-chips{display:flex;gap:6px;flex-wrap:wrap}.upload-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--bg-hover);border-radius:12px;font-size:11px;color:var(--text-soft)}.chat-input{padding:16px 24px;border-top:1px solid var(--line);position:relative}.drop-zone{position:absolute;top:0;right:0;bottom:0;left:0;display:none;align-items:center;justify-content:center;background:#1a8fcf1a;border:2px dashed var(--accent);border-radius:var(--radius);z-index:10}.drop-zone.active{display:flex}.drop-hint{color:var(--accent-bright);font-weight:600}.input-row{display:flex;gap:8px;align-items:flex-end}.upload-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-soft);transition:color .15s,background .15s}.upload-btn:hover{color:var(--text);background:var(--bg-hover)}#chat-input{flex:1;padding:10px 14px;background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:14px;resize:none;min-height:40px;max-height:200px;outline:none;transition:border-color .2s}#chat-input:focus{border-color:var(--accent)}#chat-input::placeholder{color:var(--text-muted)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--line);border-top-color:var(--accent-bright);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.btn-xs{padding:4px 8px;font-size:11px;border-radius:5px}.btn-danger{background:#ef44441f;color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.btn-danger:hover:not(:disabled){background:#ef444433;color:#fecaca}.btn-ghost{background:transparent;color:var(--text-soft);border:1px solid var(--line)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.btn:disabled{opacity:.4;cursor:not-allowed}[hidden]{display:none!important}.modal{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:100}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);cursor:pointer;pointer-events:auto}.modal-card{position:relative;background:var(--bg-surface);border:1px solid var(--line);border-radius:var(--radius);width:min(820px,calc(100vw - 32px));max-height:calc(100vh - 64px);display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;overflow:hidden}.modal.modal-wide .modal-card{width:min(1400px,calc(100vw - 32px));height:calc(100vh - 48px);max-height:calc(100vh - 48px)}.modal-body{flex:1;overflow:auto;min-height:0;background:#0000004d}.diff-modal-title-wrap{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.diff-modal-title-wrap h2{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.diff-modal-kind{background:#66aaff26;color:var(--accent-bright);font-family:var(--mono);font-size:10px;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0}.diff-modal-kind[data-kind=image]{background:#a855f726;color:#c4b5fd}.pipeline-status{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:var(--bg-input);border:1px solid var(--line);color:var(--text-soft);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s;max-width:320px}.pipeline-status:hover{background:var(--bg-hover);color:var(--text)}.pipeline-status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.pipeline-status-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pipeline-state-idle .pipeline-status-dot{background:var(--text-muted)}.pipeline-state-running{border-color:#38bdf866;color:var(--accent-bright)}.pipeline-state-running .pipeline-status-dot{background:var(--accent-bright);box-shadow:0 0 #38bdf899;animation:pipelinePulse 1.6s ease-out infinite}.pipeline-state-success{border-color:#22c55e66;color:var(--green)}.pipeline-state-success .pipeline-status-dot{background:var(--green)}.pipeline-state-failed{border-color:#ef444473;color:var(--red)}.pipeline-state-failed .pipeline-status-dot{background:var(--red)}@keyframes pipelinePulse{0%{box-shadow:0 0 #38bdf899}70%{box-shadow:0 0 0 7px #38bdf800}to{box-shadow:0 0 #38bdf800}}.pipeline-modal-summary{padding:16px 20px;background:var(--bg-input);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;flex-wrap:wrap}.pipeline-modal-summary .pipeline-status{cursor:default}.pipeline-modal-summary .pipeline-summary-link{color:var(--accent-bright);font-size:12px;text-decoration:none;border-bottom:1px dashed transparent}.pipeline-modal-summary .pipeline-summary-link:hover{border-bottom-color:var(--accent-bright)}.pipeline-event-list{list-style:none;margin:0;padding:0}.pipeline-event{padding:12px 20px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:24px 1fr;gap:10px;align-items:start}.pipeline-event:last-child{border-bottom:none}.pipeline-event-icon{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;margin-top:1px}.pipeline-event[data-status=success] .pipeline-event-icon{background:#22c55e26;color:var(--green)}.pipeline-event[data-status=failed] .pipeline-event-icon{background:#ef444426;color:var(--red)}.pipeline-event[data-status=running] .pipeline-event-icon{background:#38bdf826;color:var(--accent-bright)}.pipeline-event-body{min-width:0}.pipeline-event-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px}.pipeline-event-job{font-weight:600;color:var(--text)}.pipeline-event-job-key{font-family:var(--mono);font-size:11px;color:var(--text-muted);background:#ffffff0a;padding:1px 6px;border-radius:4px}.pipeline-event-time{margin-left:auto;font-size:11px;color:var(--text-muted);font-family:var(--mono)}.pipeline-event-detail{margin-top:4px;font-size:12px;color:var(--text-soft);white-space:pre-wrap}.pipeline-event-next{margin-top:4px;font-size:12px;color:var(--accent-bright);font-style:italic}.pipeline-event-links{margin-top:6px;display:flex;gap:12px;font-size:11px}.pipeline-event-links a{color:var(--accent-bright);text-decoration:none;border-bottom:1px dashed transparent}.pipeline-event-links a:hover{border-bottom-color:var(--accent-bright)}.pipeline-empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:13px}.diff-modal-kind[data-kind=video]{background:#fb923c26;color:#fdba74}.diff-modal-kind[data-kind=binary]{background:#ffffff14;color:var(--text-muted)}.diff-modal-counts{font-family:var(--mono);font-size:11px;flex-shrink:0}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}.modal-header h2{font-size:16px;font-weight:600}.modal-close{background:transparent;border:0;color:var(--text-soft);font-size:24px;line-height:1;padding:4px 10px;cursor:pointer;pointer-events:auto;z-index:2}.modal-close:hover{color:var(--text)}.users-add{padding:16px 20px;border-bottom:1px solid var(--line);background:#ffffff04}.users-add-row{display:grid;grid-template-columns:minmax(180px,1.4fr) minmax(120px,1fr) auto auto;gap:8px;align-items:center}.users-add-row input[type=email],.users-add-row input[type=text]{background:var(--bg-input);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--text);padding:8px 10px;font-size:13px}.users-add-row input:focus{outline:none;border-color:var(--accent)}.users-add-admin{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-soft);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.users-add-admin input{accent-color:var(--accent-bright)}.users-list-wrap{overflow:auto}.users-table{width:100%;border-collapse:collapse;font-size:13px}.users-table th,.users-table td{padding:10px 16px;text-align:left;border-bottom:1px solid var(--line)}.users-table th{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;background:#ffffff05;position:sticky;top:0;z-index:1}.users-table tbody tr:hover{background:var(--bg-hover)}.users-time{color:var(--text-soft);white-space:nowrap}.users-actions{display:flex;gap:6px;justify-content:flex-end;white-space:nowrap}.users-empty{padding:24px;text-align:center;color:var(--text-muted)}.role-badge{display:inline-block;padding:2px 8px;font-size:11px;font-weight:600;border-radius:999px;letter-spacing:.02em}.role-admin{background:#38bdf826;color:var(--accent-bright);border:1px solid rgba(56,189,248,.3)}.role-user{background:#ffffff0f;color:var(--text-soft);border:1px solid var(--line)}.badge-self{display:inline-block;margin-left:4px;padding:1px 6px;font-size:10px;border-radius:999px;background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.3)}.thread-item-owner{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#38bdf81f;color:var(--accent-bright);font-size:10px;font-weight:600;font-family:var(--font);flex-shrink:0;border:1px solid rgba(56,189,248,.25);text-transform:uppercase;letter-spacing:0}.thread-item-owner.is-self{background:#22c55e26;color:#4ade80;border-color:#22c55e4d}.thread-item.thread-edit-active{border-left:2px solid var(--green);background:#22c55e0f}.thread-item.thread-edit-active .thread-item-title:before{content:"🔒 ";color:var(--green);font-size:11px;margin-right:2px}.thread-item.thread-locked .thread-item-title{color:var(--text-soft)}.thread-item.thread-locked{opacity:.85}.thread-item.thread-locked.active{opacity:1}.lock-banner{display:flex;align-items:center;gap:10px;margin:12px 24px 0;padding:10px 14px;background:#eab3081a;border:1px solid rgba(234,179,8,.3);border-radius:var(--radius-sm);font-size:13px;color:var(--yellow)}.lock-banner-icon{font-size:16px;line-height:1}.lock-banner-text{flex:1;line-height:1.4;color:var(--text)}.lock-banner-text strong{color:var(--yellow);font-weight:600}.lock-banner-jump{background:#eab30833;border:1px solid rgba(234,179,8,.4);color:var(--yellow);padding:4px 10px;font-size:12px;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.lock-banner-jump:hover{background:#eab3084d}.btn[disabled],.btn:disabled{opacity:.55;cursor:not-allowed}.chat-input.readonly textarea,.chat-input.readonly .upload-btn{opacity:.5;pointer-events:none}.toast-container{position:fixed;right:20px;bottom:20px;z-index:1000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{pointer-events:auto;min-width:280px;max-width:420px;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--radius-sm);color:var(--text);font-size:13px;line-height:1.45;box-shadow:0 8px 24px #00000073;animation:toast-slide-in .18s ease-out}.toast.toast-warn{border-left-color:var(--yellow)}.toast.toast-error{border-left-color:var(--red)}.toast.toast-info{border-left-color:var(--accent-bright)}.toast strong{color:var(--accent-bright);font-weight:600}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){:root{--sidebar-w: 100%}#main-view{flex-direction:column}.sidebar{max-height:50vh}.msg{max-width:95%}.users-add-row{grid-template-columns:1fr}.modal-card{max-height:calc(100vh - 16px)}.toast-container{left:12px;right:12px;bottom:12px}.toast{min-width:0;max-width:none}}
