*,: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.archived{opacity:.5}.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}.status-label{text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:600}.status-active{color:#22c55e;background:#22c55e26}.status-paused{color:#eab308;background:#eab30826}.status-completed{color:#6b7280;background:#6b728026}.project-folder{color:var(--text);font-size:10px;font-family:var(--mono);white-space:nowrap;text-overflow:ellipsis;opacity:.7;align-items:center;gap:4px;margin-bottom:6px;display:flex;overflow:hidden}.project-folder span{text-overflow:ellipsis;overflow:hidden}.spinning svg{animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.project-card-footer{justify-content:space-between;align-items:center;margin-top:8px;display:flex}.footer-badges{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.project-url{color:var(--accent);cursor:pointer;align-items:center;gap:4px;font-size:11px;display:flex}.project-url:hover{color:var(--accent-hover)}.priority-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.unread-badge{background:var(--accent);color:#fff;border-radius:10px;justify-content:center;align-items:center;gap:3px;min-width:20px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-flex}.project-card-wrapper{position:relative}.card-menu-btn{color:var(--text);cursor:pointer;opacity:.5;z-index:2;background:0 0;border:none;border-radius:4px;padding:4px;transition:opacity .2s;position:absolute;top:10px;right:10px}.card-menu-btn:hover{opacity:1;background:var(--bg-hover);color:var(--text-h)}.card-menu{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);z-index:20;min-width:160px;padding:4px;position:absolute;top:36px;right:10px;box-shadow:0 8px 24px #0000004d}.card-menu button{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:4px;align-items:center;gap:8px;padding:6px 10px;font-size:12px;display:flex}.card-menu button:hover{background:var(--bg-hover);color:var(--text-h)}.card-menu button.active{color:var(--accent);font-weight:600}.card-menu .menu-danger{color:var(--red)}.card-menu .menu-danger:hover{background:#ef44441a}.menu-section{flex-direction:column;display:flex}.menu-label{color:var(--text);text-transform:uppercase;letter-spacing:.5px;padding:4px 10px 2px;font-size:10px;font-weight:600}.menu-divider{background:var(--border);height:1px;margin:4px 0}.header-actions{align-items:center;gap:8px;display:flex}.filter-tabs{background:var(--bg-input);border-radius:var(--radius);gap:2px;padding:2px;display:flex}.filter-btn{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:500}.filter-btn:hover{color:var(--text-h)}.filter-btn.active{background:var(--accent);color:#fff}.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-toolbar{border-bottom:1px solid var(--border);background:var(--bg-card);justify-content:space-between;align-items:center;padding:6px 16px;display:flex}.chat-count{color:var(--text);font-size:11px}.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}.project-summary{color:var(--text-h);font-size:14px;line-height:1.6}.feature-list{flex-direction:column;gap:4px;padding:0;list-style:none;display:flex}.feature-list li{color:var(--text-h);padding:4px 0 4px 16px;font-size:13px;line-height:1.4;position:relative}.feature-list li:before{content:"•";color:var(--accent);font-weight:700;position:absolute;left:0}.tech-tags{flex-wrap:wrap;gap:6px;display:flex}.tech-tag{color:var(--text-h);background:var(--bg-input);border:1px solid var(--border);font-size:11px;font-family:var(--mono);border-radius:20px;padding:3px 10px}.empty-hint{color:var(--text);font-size:12px;font-style:italic}.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)}@media (width<=768px){.topbar{gap:8px;padding:10px 12px}.topbar-left h1{font-size:16px}.content{padding:12px}.section-header{flex-direction:column;align-items:flex-start;gap:10px}.header-actions{justify-content:space-between;width:100%}.project-grid{grid-template-columns:1fr!important}.project-card{padding:14px}.project-card-header h3{font-size:16px}.project-desc{font-size:13px}.priority-badge{font-size:11px}.tabs{gap:0}.tab{padding:10px 12px;font-size:13px}.notes-panel{flex-direction:column;height:auto;min-height:calc(100dvh - 110px)}.notes-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;max-height:150px;overflow-y:auto}.note-editor{min-height:300px}.chat-panel{height:calc(100dvh - 115px)}.chat-input input{font-size:16px}.add-task-form{flex-wrap:wrap}.add-task-form input{min-width:0}.settings-panel .info-row{flex-direction:column;gap:2px}.settings-panel .info-row code{word-break:break-all}}@media (width<=480px){.topbar{padding:8px 10px}.topbar-left h1{font-size:15px}.role-badge{padding:2px 5px;font-size:9px}.content{padding:8px}.section-header h2{font-size:16px}.filter-tabs{gap:1px}.filter-btn{padding:3px 7px;font-size:10px}.btn-sm{padding:5px 10px;font-size:12px}.project-card{padding:12px}.project-card-header h3{font-size:14px}.project-desc{font-size:12px}.unread-badge{padding:1px 5px;font-size:9px}.card-menu{min-width:140px}.card-menu button{padding:5px 8px;font-size:11px}.tab{gap:4px;padding:8px 10px;font-size:12px}.msg{padding:6px 10px}.msg-name{font-size:11px}.msg-body p{font-size:12px}.claude-output{padding:6px;font-size:11px}.chat-input{gap:6px;padding:8px 10px}.chat-input input{padding:8px 10px;font-size:16px}.chat-input button{padding:8px 12px}.task-item{padding:6px 8px}.task-title{font-size:13px}.task-meta{font-size:10px}.add-task-form input{padding:8px;font-size:14px}.add-task-form select{padding:6px;font-size:11px}.login-card{padding:24px 20px}.login-header h1{font-size:22px}.login-card input{padding:12px;font-size:16px}.login-card button{padding:12px;font-size:15px}.notes-sidebar{max-height:120px;padding:8px}.note-item{padding:5px 6px;font-size:11px}.note-title-input{font-size:16px}.note-content-input,.add-form input{font-size:14px}.project-link{display:none}}@media (hover:none){.btn-icon{justify-content:center;align-items:center;min-width:36px;min-height:36px;display:flex}.task-check{justify-content:center;align-items:center;min-width:32px;min-height:32px;display:flex}.card-menu-btn{opacity:.6;min-width:36px;min-height:36px}.tab{min-height:44px}.chat-input button{min-width:44px;min-height:44px}.filter-btn{min-height:32px}.password-toggle{min-width:36px;min-height:36px}}
