*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--bg-card:#1a1b23;--bg-input:#22232d;--bg-hover:#2a2b37;--border:#2e303a;--text:#9ca3af;--text-h:#f3f4f6;--accent:#6366f1;--accent-hover:#818cf8;--green:#22c55e;--red:#ef4444;--orange:#f97316;--yellow:#eab308;--blue:#3b82f6;--purple:#a855f7;--font:"Inter", system-ui, -apple-system, sans-serif;--mono:"JetBrains Mono", "Fira Code", monospace;--radius:8px;--radius-lg:12px}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100dvh;font-size:14px;line-height:1.5}#root{flex-direction:column;min-height:100dvh;display:flex}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.loading{height:100dvh;color:var(--text);justify-content:center;align-items:center;font-size:16px;display:flex}.login-page{justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:380px;padding:32px}.login-header{text-align:center;margin-bottom:24px}.login-header h1{color:var(--text-h);margin-bottom:4px;font-size:24px;font-weight:600}.login-header p{color:var(--text);font-size:13px}.login-card form{flex-direction:column;gap:12px;display:flex}.login-card input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-h);outline:none;padding:10px 12px;font-size:14px;transition:border-color .2s}.login-card input:focus{border-color:var(--accent)}.password-field{align-items:center;display:flex;position:relative}.password-field input{width:100%;padding-right:40px}.password-toggle{color:var(--text);cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;right:8px}.password-toggle:hover{color:var(--text-h)}.login-card button{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:14px;font-weight:500;transition:background .2s;display:flex}.login-card button:hover{background:var(--accent-hover)}.login-card button:disabled{opacity:.5;cursor:not-allowed}.error-msg{color:var(--red);text-align:center;font-size:13px}.page{flex-direction:column;min-height:100dvh;display:flex}.topbar{background:var(--bg-card);border-bottom:1px solid var(--border);z-index:10;align-items:center;gap:12px;padding:12px 16px;display:flex;position:sticky;top:0}.topbar-left{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.topbar-left h1{color:var(--text-h);white-space:nowrap;font-size:18px;font-weight:600}.topbar-right{align-items:center;gap:8px;display:flex}.user-email{color:var(--text);font-size:12px;display:none}@media (width>=640px){.user-email{display:block}}.role-badge{background:var(--accent);color:#fff;text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.project-link{color:var(--text);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:4px;font-size:12px;display:flex;overflow:hidden}.content{flex:1;padding:16px}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-header h2{color:var(--text-h);font-size:18px;font-weight:600}.btn-sm{background:var(--accent);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:4px;padding:6px 12px;font-size:13px;font-weight:500;transition:background .2s;display:inline-flex}.btn-sm:hover{background:var(--accent-hover)}.btn-sm:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{color:var(--text);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-h)}.btn-icon{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.btn-icon:hover{color:var(--text-h);background:var(--bg-hover)}.btn-icon-sm{color:var(--text);cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;transition:opacity .2s;display:flex}.btn-icon-sm:hover{opacity:1;color:var(--red)}.add-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;margin-bottom:16px;padding:12px;display:flex}.add-form input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-h);outline:none;padding:8px 10px;font-size:13px}.add-form input:focus{border-color:var(--accent)}.form-actions{gap:8px;display:flex}.project-grid{grid-template-columns:1fr;gap:8px;display:grid}@media (width>=640px){.project-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=960px){.project-grid{grid-template-columns:repeat(3,1fr)}}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:14px;transition:border-color .2s,background .2s;display:block}.project-card:hover{border-color:var(--accent);background:var(--bg-hover);color:var(--text)}.project-card-header{align-items:center;gap:8px;margin-bottom:6px;display:flex}.project-card-header h3{color:var(--text-h);flex:1;font-size:15px;font-weight:600}.project-desc{color:var(--text);margin-bottom:8px;font-size:12px;line-height:1.4}.project-url{color:var(--accent);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:4px;font-size:11px;display:flex;overflow:hidden}.tabs{border-bottom:1px solid var(--border);background:var(--bg-card);display:flex;overflow-x:auto}.tab{color:var(--text);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:500;transition:color .2s,border-color .2s;display:flex}.tab:hover{color:var(--text-h)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.chat-panel{flex-direction:column;flex:1;height:calc(100dvh - 110px);display:flex}.chat-messages{flex-direction:column;flex:1;gap:8px;padding:12px 16px;display:flex;overflow-y:auto}.chat-empty{color:var(--text);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;display:flex}.chat-empty .hint{color:var(--text);font-size:12px}.chat-empty code{background:var(--bg-input);color:var(--accent);border-radius:4px;padding:2px 6px;font-size:12px}.msg{border-radius:var(--radius);padding:8px 12px}.msg-djoko{border-left:3px solid var(--accent);background:#6366f11a}.msg-tester{border-left:3px solid var(--green);background:#22c55e1a}.msg-claude{border-left:3px solid var(--purple);background:#a855f71a}.msg-header{align-items:center;gap:6px;margin-bottom:4px;display:flex}.msg-name{color:var(--text-h);font-size:12px;font-weight:600}.msg-time{color:var(--text);margin-left:auto;font-size:10px}.msg-badge{background:var(--purple);color:#fff;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:500}.msg-body p{color:var(--text-h);white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.5}.claude-output{font-family:var(--mono);color:var(--text-h);white-space:pre-wrap;word-break:break-word;background:var(--bg);border-radius:4px;max-height:400px;padding:8px;font-size:12px;line-height:1.6;overflow-y:auto}.claude-working{color:var(--purple);font-size:11px;animation:1.5s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.typing-dots{gap:4px;padding:4px 0;display:flex}.typing-dots span{background:var(--purple);border-radius:50%;width:6px;height:6px;animation:1.4s infinite bounce}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}.chat-input{background:var(--bg-card);border-top:1px solid var(--border);gap:8px;padding:12px 16px;display:flex}.chat-input input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-h);outline:none;flex:1;padding:10px 12px;font-size:14px}.chat-input input:focus{border-color:var(--accent)}.chat-input button{background:var(--accent);border-radius:var(--radius);color:#fff;cursor:pointer;border:none;align-items:center;padding:10px 14px;transition:background .2s;display:flex}.chat-input button:hover{background:var(--accent-hover)}.chat-input button:disabled{opacity:.4;cursor:not-allowed}.tasks-panel{flex:1;padding:16px;overflow-y:auto}.add-task-form{gap:8px;margin-bottom:16px;display:flex}.add-task-form input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-h);outline:none;flex:1;padding:8px 10px;font-size:13px}.add-task-form input:focus{border-color:var(--accent)}.add-task-form select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-h);outline:none;padding:8px;font-size:12px}.add-task-form button{background:var(--accent);border-radius:var(--radius);color:#fff;cursor:pointer;border:none;align-items:center;padding:8px 10px;display:flex}.add-task-form button:disabled{opacity:.4}.task-list{flex-direction:column;gap:4px;display:flex}.task-item{border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);align-items:flex-start;gap:8px;padding:8px 10px;transition:background .2s;display:flex}.task-item:hover{background:var(--bg-hover)}.task-done{opacity:.5}.task-done .task-title{text-decoration:line-through}.task-check{color:var(--text);cursor:pointer;background:0 0;border:none;margin-top:1px;padding:0;display:flex}.task-check:hover{color:var(--green)}.task-content{flex:1;min-width:0}.task-title{color:var(--text-h);word-break:break-word;font-size:13px}.task-meta{color:var(--text);flex-wrap:wrap;align-items:center;gap:4px;margin-top:2px;font-size:11px;display:flex}.priority-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.notes-panel{flex:1;height:calc(100dvh - 110px);display:flex;overflow:hidden}.notes-sidebar{border-right:1px solid var(--border);flex-shrink:0;width:200px;padding:12px;overflow-y:auto}@media (width<=640px){.notes-sidebar{width:140px}}.note-item{border-radius:var(--radius);color:var(--text);cursor:pointer;align-items:center;gap:6px;padding:6px 8px;font-size:12px;transition:background .2s;display:flex}.note-item:hover{background:var(--bg-hover);color:var(--text-h)}.note-item.active{background:var(--accent);color:#fff}.note-item span{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.note-editor{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow:hidden}.note-title-input{color:var(--text-h);border:none;border-bottom:1px solid var(--border);background:0 0;outline:none;padding:4px 0;font-size:18px;font-weight:600}.note-content-input{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-h);font-size:13px;font-family:var(--mono);resize:none;background:0 0;outline:none;flex:1;padding:12px;line-height:1.6}.note-content-input:focus{border-color:var(--accent)}.settings-panel{padding:16px;overflow-y:auto}.info-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;padding:16px}.info-section h3{color:var(--text-h);align-items:center;gap:6px;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.info-row{flex-wrap:wrap;gap:8px;padding:4px 0;font-size:13px;display:flex}.info-row strong{color:var(--text-h);min-width:60px}.info-row code{font-family:var(--mono);background:var(--bg-input);border-radius:4px;padding:2px 6px;font-size:11px}.info-row a{font-size:13px}.cred-row{align-items:center;gap:8px;padding:4px 0;font-size:12px;display:flex}.cred-key{color:var(--text-h);min-width:80px;font-weight:500}.cred-val{font-family:var(--mono);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11px;overflow:hidden}.add-cred-form{gap:6px;margin-top:8px;display:flex}.add-cred-form input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-h);outline:none;flex:1;padding:6px 8px;font-size:12px}.add-cred-form button{background:var(--accent);border-radius:var(--radius);color:#fff;cursor:pointer;border:none;align-items:center;padding:6px 8px;display:flex}.empty-state{color:var(--text);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:40px 20px;display:flex}.empty-state.small{padding:20px}.empty-state p{font-size:13px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text)}
