:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color-scheme:dark;--bg: #070b10;--bg-elevated: #0f1724;--bg-soft: #111827;--accent: #3b82f6;--accent-soft: rgba(59,130,246,.12);--border-subtle: rgba(148,163,184,.35);--text: #e5e7eb;--text-soft: #9ca3af;--danger: #ef4444;--success: #22c55e;--radius-lg: 18px;--radius-xl: 26px;--shadow-soft: 0 18px 45px rgba(15,23,42,.9);--blur: 26px}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;background:radial-gradient(circle at top,#0b1120,#020617 60%);color:var(--text)}#root{min-height:100vh;display:flex;align-items:stretch;justify-content:center;padding:16px}.app-shell{width:100%;max-width:1120px;display:flex;flex-direction:column;gap:16px}header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.brand{display:flex;align-items:center;gap:10px}.brand-mark{width:32px;height:32px;border-radius:999px;background:conic-gradient(from 210deg,#22c55e,#3b82f6,#a855f7,#22c55e);padding:2px;box-shadow:0 0 0 1px #0f172acc,0 0 40px #38bdf859}.brand-mark-inner{width:100%;height:100%;border-radius:inherit;background:radial-gradient(circle at 30% 20%,#0f172a,#020617);display:flex;align-items:center;justify-content:center;color:#e5e7eb;font-size:14px;font-weight:600}.brand-text{display:flex;flex-direction:column;gap:2px}.brand-title{font-size:18px;font-weight:600;letter-spacing:.02em}.brand-subtitle{font-size:12px;color:var(--text-soft)}.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.pill{border-radius:999px;padding:4px 10px;font-size:11px;border:1px solid rgba(148,163,184,.35);color:var(--text-soft);display:inline-flex;align-items:center;gap:6px;background:#0f172ad9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.pill-dot{width:7px;height:7px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 4px #22c55e2e}.pill-dot.disconnected{background:var(--danger);box-shadow:0 0 0 4px #ef44442e}.tag{border-radius:999px;border:1px solid rgba(148,163,184,.35);font-size:11px;padding:3px 8px;color:var(--text-soft);background:#0f172ab3;display:inline-flex;align-items:center;gap:5px}.tag-dot{width:6px;height:6px;border-radius:999px;background:#94a3b8cc}.tag-dot.accent{background:#3b82f6}.tag-dot.green{background:#22c55e}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.btn{border-radius:999px;border:1px solid rgba(148,163,184,.4);padding:7px 14px;font-size:13px;background:#0f172af2;color:var(--text);display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease;box-shadow:0 0 #0000}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,#2563eb,#4f46e5);border-color:#818cf8b3;box-shadow:0 14px 35px #2563eb66}.btn-primary:hover:not(:disabled){box-shadow:0 18px 40px #2563eb8c}.btn-ghost{background:#0f172ad9}.btn-ghost:hover:not(:disabled){background:#0f172af2;box-shadow:0 12px 30px #0f172ab3}.btn-mini{border-radius:999px;border:1px solid rgba(148,163,184,.45);padding:3px 8px;font-size:11px;background:#0f172af2;color:var(--text);display:inline-flex;align-items:center;gap:5px;cursor:pointer;transition:background .12s ease,transform .12s ease}.btn-mini.primary{border-color:#60a5facc;background:radial-gradient(circle at top left,#2563eb80,#1d4ed8)}.btn-mini:hover{transform:translateY(-1px);background:#0f172afa}.btn-mini.primary:hover{background:radial-gradient(circle at top left,#3b82f6e6,#1d4ed8)}main{display:grid;grid-template-columns:minmax(0,3fr) minmax(0,2.5fr);gap:16px;align-items:stretch;flex:1}@media (max-width: 900px){main{grid-template-columns:minmax(0,1fr)}}.panel{background:radial-gradient(circle at top left,rgba(148,163,184,.08),transparent 55%),radial-gradient(circle at bottom right,rgba(59,130,246,.06),transparent 60%),#0f172af5;border-radius:var(--radius-xl);padding:16px 16px 14px;border:1px solid rgba(148,163,184,.4);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(var(--blur));backdrop-filter:blur(var(--blur));display:flex;flex-direction:column;min-height:0}.panel-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:10px}.panel-header-left{display:flex;flex-direction:column;gap:1px}.panel-title{font-size:14px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--text-soft)}.panel-subtitle{font-size:12px;color:var(--text-soft);margin-top:2px}.project-list{margin-top:2px;border-radius:var(--radius-lg);border:1px solid rgba(51,65,85,.9);background:radial-gradient(circle at top,#0f172ae6,#0f172afa);padding:6px;display:flex;flex-direction:column;gap:6px;overflow:hidden;max-height:300px;overflow-y:auto}.project-row{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(0,1.1fr) auto;gap:8px;align-items:center;padding:7px 9px;border-radius:999px;transition:background .12s ease,transform .12s ease;cursor:pointer}.project-row:hover{background:#0f172af2;transform:translateY(-1px)}.project-row.selected{background:#3b82f626;border:1px solid rgba(59,130,246,.4)}.project-main{display:flex;align-items:center;gap:8px;min-width:0}.project-icon{width:24px;height:24px;border-radius:7px;border:1px solid rgba(148,163,184,.55);display:flex;align-items:center;justify-content:center;font-size:11px;background:#0f172ae6;flex-shrink:0}.project-text{min-width:0}.project-name{font-size:13px;font-weight:500;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.project-meta,.project-time{font-size:11px;color:var(--text-soft)}.project-actions{display:flex;align-items:center;gap:6px}.chip{border-radius:999px;padding:4px 8px;font-size:11px;border:1px solid rgba(51,65,85,.9);background:#0f172ae6;color:var(--text-soft);display:inline-flex;align-items:center;gap:5px}.status-dot{width:7px;height:7px;border-radius:999px;background:#22c55e;box-shadow:0 0 0 3px #22c55e4d}.drag-area{margin-top:10px;border-radius:var(--radius-lg);border:1px dashed rgba(148,163,184,.55);background:radial-gradient(circle at top,#0f172af0,#0f172afa);padding:16px 14px;display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;text-align:center;transition:border-color .2s,background .2s}.drag-area.dragging{border-color:var(--accent);background:#3b82f61a}.drag-area.disabled{opacity:.5;pointer-events:none}.drag-title{font-size:13px;font-weight:500}.drag-subtitle{font-size:12px;color:var(--text-soft)}.drag-badge-row{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:6px}.drag-badge{border-radius:999px;border:1px solid rgba(51,65,85,.9);padding:3px 7px;font-size:11px;color:var(--text-soft);background:#0f172ae6}.drag-cta{margin-top:10px;display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--accent);cursor:pointer}.chat-panel{display:flex;flex-direction:column;gap:10px;flex:1;min-height:0}.chat-stream{flex:1;border-radius:var(--radius-lg);border:1px solid rgba(51,65,85,.9);background:radial-gradient(circle at top,#0f172af2,#0f172a);padding:10px 10px 8px;overflow:hidden;display:flex;flex-direction:column;gap:8px;min-height:200px;max-height:500px}.chat-scroll{overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:3px;flex:1}.chat-bubble{max-width:100%;border-radius:14px;padding:7px 9px;font-size:12px;line-height:1.4;border:1px solid rgba(51,65,85,.95);background:#0f172af2;color:var(--text)}.chat-bubble.assistant{border-radius:14px 14px 14px 4px;border-color:#3b82f6e6;background:radial-gradient(circle at top left,#2563eb47,#0f172afa)}.chat-bubble.user{margin-left:auto;border-radius:14px 14px 4px;border-color:#94a3b8cc;background:radial-gradient(circle at top right,#94a3b852,#0f172afa)}.chat-meta{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--text-soft);margin-bottom:3px}.chat-meta .role-dot{width:7px;height:7px;border-radius:999px;background:#3b82f6;box-shadow:0 0 0 3px #3b82f666}.chat-meta .role-dot.user{background:#e5e7eb;box-shadow:0 0 0 3px #94a3b866}.chat-input-row{margin-top:8px;display:flex;gap:8px;align-items:center}.chat-input-wrapper{flex:1;border-radius:999px;border:1px solid rgba(51,65,85,.9);background:#0f172af5;display:flex;align-items:center;padding:4px 8px;gap:6px}.chat-input-wrapper input{border:none;background:transparent;outline:none;color:var(--text);font-size:12px;flex:1}.chat-input-wrapper input::placeholder{color:var(--text-soft)}.chat-input-wrapper input:disabled{opacity:.5}.chat-input-icon{font-size:14px;color:#94a3b8e6}.chat-hint{font-size:10px;color:var(--text-soft);text-align:right;margin-top:2px}.badge-inline{border-radius:999px;border:1px solid rgba(55,65,81,.9);font-size:10px;padding:2px 7px;display:inline-flex;align-items:center;gap:5px;color:var(--text-soft);background:#111827f5}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;color:var(--text-soft);text-align:center;gap:8px}.empty-state-icon{font-size:32px;opacity:.5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-soft);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:20px;min-width:320px;max-width:90%;box-shadow:var(--shadow-soft)}.modal-title{font-size:16px;font-weight:600;margin-bottom:16px}.modal-input{width:100%;padding:10px 14px;border-radius:12px;border:1px solid var(--border-subtle);background:var(--bg);color:var(--text);font-size:14px;outline:none;margin-bottom:16px}.modal-input:focus{border-color:var(--accent)}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.loading{display:flex;align-items:center;justify-content:center;padding:20px;color:var(--text-soft)}.spinner{width:20px;height:20px;border:2px solid var(--border-subtle);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{background:radial-gradient(circle at top left,rgba(148,163,184,.08),transparent 55%),radial-gradient(circle at bottom right,rgba(59,130,246,.06),transparent 60%),#0f172af5;border-radius:var(--radius-xl);padding:32px;border:1px solid rgba(148,163,184,.4);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(var(--blur));backdrop-filter:blur(var(--blur));width:100%;max-width:380px}.login-header{text-align:center;margin-bottom:24px}.login-header .brand-mark{margin:0 auto 16px;width:48px;height:48px}.login-header .brand-mark-inner{font-size:18px}.login-header h1{font-size:22px;font-weight:600;margin-bottom:8px}.login-header p{font-size:13px;color:var(--text-soft)}.login-input-wrapper{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;border:1px solid var(--border-subtle);background:var(--bg);margin-bottom:16px}.login-input-wrapper:focus-within{border-color:var(--accent)}.login-input-icon{font-size:16px}.login-input-wrapper input{flex:1;border:none;background:transparent;outline:none;color:var(--text);font-size:14px}.login-input-wrapper input::placeholder{color:var(--text-soft)}.login-error{color:var(--danger);font-size:12px;margin-bottom:16px;padding:8px 12px;border-radius:8px;background:#ef44441a;border:1px solid rgba(239,68,68,.3)}.login-btn{width:100%;justify-content:center;padding:12px;font-size:14px}.login-footer{margin-top:24px;display:flex;justify-content:center}.chat-bubble.thinking{animation:pulse 1.5s ease-in-out infinite}.thinking-dots{display:flex;gap:4px;padding:4px 0}.thinking-dots span{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:bounce 1.4s ease-in-out infinite}.thinking-dots span:nth-child(1){animation-delay:0s}.thinking-dots span:nth-child(2){animation-delay:.2s}.thinking-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-6px);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.chat-content{white-space:pre-wrap;word-break:break-word}.code-block{background:#0006;border-radius:8px;padding:10px;margin:8px 0;overflow-x:auto;font-family:Consolas,Monaco,monospace;font-size:12px;line-height:1.5;border:1px solid rgba(51,65,85,.8)}.code-block code{color:#e5e7eb}.code-lang{font-size:10px;color:var(--text-soft);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.inline-code{background:#0000004d;padding:2px 6px;border-radius:4px;font-family:Consolas,Monaco,monospace;font-size:11px;color:#93c5fd}.token-usage{margin-left:auto;font-size:9px;color:var(--text-soft);opacity:.7}.panel-header-right{display:flex;align-items:center;gap:8px}.model-select{padding:5px 10px;border-radius:999px;border:1px solid rgba(148,163,184,.45);background:#0f172af2;color:var(--text);font-size:11px;cursor:pointer;outline:none;transition:border-color .2s,background .2s}.model-select:hover{border-color:var(--accent)}.model-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #3b82f633}.model-select option{background:var(--bg-soft);color:var(--text)}.chat-bubble.progress{animation:pulse 1.5s ease-in-out infinite}.progress-content{margin:8px 0;display:flex;flex-direction:column;gap:6px}.progress-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;background:#0003;font-size:11px}.progress-icon{font-size:14px;flex-shrink:0}.tool-name{font-family:Consolas,Monaco,monospace;color:#93c5fd;font-weight:500}.tool-input{color:var(--text-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-result.success{background:#22c55e26;border:1px solid rgba(34,197,94,.3)}.tool-result.error{background:#ef444426;border:1px solid rgba(239,68,68,.3)}.result-status{margin-left:auto;font-size:10px;text-transform:uppercase}.iteration-badge{margin-left:auto;font-size:9px;padding:2px 6px;border-radius:4px;background:#3b82f64d;color:#93c5fd}.thinking-item{color:var(--text-soft)}.text-item{color:var(--text);background:#3b82f61a}.token-live{margin-left:auto;font-size:10px;padding:2px 8px;border-radius:4px;background:#22c55e33;color:#4ade80;font-family:Consolas,Monaco,monospace}.token-item{background:#22c55e26;border:1px solid rgba(34,197,94,.3)}.cost-badge{margin-left:auto;padding:2px 6px;border-radius:4px;background:#fbbf2433;color:#fbbf24;font-size:10px;font-family:Consolas,Monaco,monospace}.project-cost{color:#4ade80;font-family:Consolas,Monaco,monospace}
