*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh}body.overlay-open{overflow:hidden}header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:16px 24px;border-bottom:1px solid #1e293b;background:#1e293b}.header-left{display:flex;align-items:center;gap:16px;min-width:0}header h1{font-size:1.15rem;font-weight:700;color:#f8fafc}.header-tabs{display:flex;gap:2px;background:#0f172a;border-radius:6px;padding:2px;flex:1 1 280px;justify-content:center}.tab-btn{background:none;border:none;color:#64748b;font-size:.78rem;font-weight:600;padding:5px 14px;border-radius:4px;cursor:pointer;transition:all .15s}.tab-btn:hover{color:#94a3b8}.tab-btn.active{background:#334155;color:#f1f5f9}.header-meta{display:flex;align-items:center;gap:12px;margin-left:auto}#count-summary{font-size:.8rem;color:#94a3b8}#refresh-btn{background:#334155;border:1px solid #475569;color:#e2e8f0;font-size:1.1rem;width:32px;height:32px;border-radius:6px;cursor:pointer;transition:background .15s}#refresh-btn:hover{background:#475569}.project-label{font-size:.8rem;color:#94a3b8;background:#334155;padding:4px 10px;border-radius:6px}#project-select{background:#334155;border:1px solid #475569;color:#e2e8f0;font-size:.8rem;padding:4px 8px;border-radius:6px;cursor:pointer}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px 14px;flex-wrap:wrap;padding:7px 24px;background:#1e293b;border-bottom:1px solid #0f172a;flex-shrink:0}.toolbar-primary,.toolbar-secondary{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.toolbar-primary{flex:1 1 320px}.toolbar-secondary{flex:1 1 320px;justify-content:flex-end}.toolbar-mobile-toggle{display:none}#search-input{background:#0f172a;border:1px solid #334155;color:#e2e8f0;font-size:.82rem;padding:5px 10px 5px 28px;border-radius:6px;width:220px;outline:none;transition:border-color .15s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='M21 21l-4.35-4.35'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:8px center;flex:1 1 220px}#search-input:focus{border-color:#60a5fa}#search-input::placeholder{color:#475569}#sort-select{background:#334155;border:1px solid #475569;color:#e2e8f0;font-size:.8rem;padding:5px 8px;border-radius:6px;cursor:pointer}#category-filter{display:flex;align-items:center;gap:4px}.cat-chip{background:#1e293b;border:1px solid #334155;color:#64748b;font-size:.74rem;padding:3px 8px;border-radius:5px;cursor:pointer;transition:all .15s;white-space:nowrap}.cat-chip:hover{border-color:#475569;color:#94a3b8}.cat-chip.active{background:#172554;border-color:#3b82f6;color:#93c5fd}#project-filter{display:flex;align-items:center;min-width:0}.toolbar-toggle-btn{background:#1e293b;border:1px solid #334155;color:#64748b;font-size:.78rem;padding:5px 10px;border-radius:6px;cursor:pointer;transition:all .15s;white-space:nowrap}.toolbar-toggle-btn:hover{border-color:#475569;color:#94a3b8}.toolbar-toggle-btn.active{background:#172554;border-color:#3b82f6;color:#93c5fd}main#board{display:grid;grid-template-columns:repeat(7,minmax(180px,1fr));gap:0;height:calc(100vh - 101px);overflow-x:auto}main#board.hidden{display:none}.column{display:flex;flex-direction:column;border-right:1px solid #1e293b;overflow:hidden;min-width:0}.column:last-child{border-right:none}.column-header{display:flex;align-items:center;justify-content:space-between;padding:12px;font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid transparent;flex-shrink:0}.column-toggle-btn{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:0;border:none;background:transparent;color:inherit;font:inherit;text-transform:inherit;letter-spacing:inherit;cursor:pointer}.column-toggle-label{min-width:0}.column-toggle-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}.column-toggle-icon{font-size:.95rem;line-height:1;display:none}.column-header-right{display:flex;align-items:center;gap:6px}.column-header .count{font-size:.7rem;font-weight:500;background:#334155;padding:2px 7px;border-radius:10px;color:#94a3b8}.add-card-btn{width:22px;height:22px;border-radius:6px;border:1px solid #334155;background:#1e293b;color:#60a5fa;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;line-height:1}.add-card-btn:hover{background:#334155;border-color:#60a5fa}.column.todo .column-header{color:#60a5fa;border-bottom-color:#3b82f6}.column.plan .column-header{color:#fbbf24;border-bottom-color:#f59e0b}.column.plan_review .column-header{color:#fb923c;border-bottom-color:#f97316}.column.impl .column-header{color:#f472b6;border-bottom-color:#ec4899}.column.impl_review .column-header{color:#a78bfa;border-bottom-color:#8b5cf6}.column.test .column-header{color:#2dd4bf;border-bottom-color:#14b8a6}.column.done .column-header{color:#34d399;border-bottom-color:#10b981}.column-body{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:6px;transition:background .15s}.column-body.drag-over{background:#3b82f614}.empty{color:#475569;font-size:.75rem;text-align:center;padding:20px 8px}.card{background:#1e293b;border:1px solid #334155;border-radius:8px;padding:10px 12px;cursor:pointer;transition:border-color .15s,transform .1s,opacity .15s}.card{content-visibility:auto;contain-intrinsic-size:auto 80px}.card:hover{border-color:#475569;transform:translateY(-1px)}.card.dragging{opacity:.4}.column.plan_review .card{border-left:3px solid #f97316}.column.impl_review .card{border-left:3px solid #8b5cf6}.column.test .card{border-left:3px solid #14b8a6}.drop-indicator{height:3px;background:#3b82f6;border-radius:2px;margin:2px 0;flex-shrink:0}.card-header{display:flex;align-items:center;gap:4px;margin-bottom:4px;flex-wrap:wrap}.card-copy-btn{margin-left:auto;background:none;border:none;color:#64748b;cursor:pointer;font-size:.8rem;padding:1px 4px;border-radius:3px;opacity:0;transition:opacity .15s,color .15s,background .15s;flex-shrink:0;line-height:1}.card:hover .card-copy-btn{opacity:1}.card-copy-btn:hover{color:#94a3b8;background:#ffffff1a}.card-id{font-size:.65rem;color:#64748b;font-weight:500}.card-title{font-size:.8rem;font-weight:600;color:#f1f5f9;margin-bottom:4px;line-height:1.3}.card-desc{font-size:.7rem;color:#94a3b8;line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-footer{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.mobile-card-move{display:none}.mobile-status-select{background:#0f172a;border:1px solid #334155;color:#e2e8f0;border-radius:8px;padding:6px 8px;font-size:.78rem;width:100%}.card-tags{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}.badge{font-size:.6rem;font-weight:600;padding:1px 6px;border-radius:4px;text-transform:uppercase;white-space:nowrap}.badge.high{background:#991b1b;color:#fca5a5}.badge.medium{background:#92400e;color:#fde68a}.badge.low{background:#1e3a5f;color:#93c5fd}.badge.date{background:#064e3b;color:#6ee7b7;text-transform:none}.badge.created{background:#1e293b;color:#64748b;border:1px solid #334155;text-transform:none}.badge.project{background:#312e81;color:#a5b4fc;text-transform:none}.badge.review-pending{background:#4c1d95;color:#c4b5fd;text-transform:none}.badge.review-approved{background:#064e3b;color:#6ee7b7;text-transform:none}.badge.review-changes{background:#7c2d12;color:#fdba74;text-transform:none}.badge.status-plan{background:#78350f;color:#fbbf24;text-transform:none}.badge.status-plan_review{background:#7c2d12;color:#fb923c;text-transform:none}.badge.status-impl{background:#831843;color:#f472b6;text-transform:none}.badge.status-impl_review{background:#4c1d95;color:#a78bfa;text-transform:none}.badge.status-test{background:#134e4a;color:#2dd4bf;text-transform:none}.badge.level-1{background:#064e3b;color:#6ee7b7;text-transform:none;font-size:.55rem}.badge.level-2{background:#78350f;color:#fde68a;text-transform:none;font-size:.55rem}.badge.level-3{background:#4c1d95;color:#c4b5fd;text-transform:none;font-size:.55rem}.level-indicator{font-size:.6rem;font-weight:700;color:#64748b;background:#1e293b;border:1px solid #334155;padding:2px 6px;border-radius:4px;margin-right:8px}.badge.agent-tag{background:#1e3a5f;color:#7dd3fc;text-transform:none;font-size:.55rem;padding:1px 5px}.tag{font-size:.6rem;color:#64748b;background:#0f172a;padding:1px 5px;border-radius:3px}.column.done .card{opacity:.7}.column.done .card:hover{opacity:1}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#7c2d12;color:#fdba74;padding:10px 20px;border-radius:8px;font-size:.8rem;font-weight:500;z-index:200;animation:toast-fade 3s ease-in-out}@keyframes toast-fade{0%{opacity:0;transform:translate(-50%) translateY(10px)}10%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1}to{opacity:0}}.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-overlay.hidden{display:none}.modal{background:#1e293b;border:1px solid #334155;border-radius:12px;width:90%;max-width:700px;max-height:85vh;overflow-y:auto;padding:24px;position:relative;box-shadow:0 24px 60px #0f172a73}.detail-modal{max-width:780px}.add-card-modal{max-width:480px}.auth-modal{max-width:420px}.sheet-handle{display:none;width:44px;height:5px;border-radius:999px;background:#94a3b873;margin:0 auto 12px}.modal-sheet-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.modal-sheet-copy{display:grid;gap:4px;min-width:0}.modal-sheet-kicker{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#94a3b8}.modal-sheet-title{font-size:1.1rem;color:#f8fafc}.auth-title{font-size:1.15rem;color:#f8fafc;margin-bottom:0}.auth-copy{font-size:.84rem;color:#94a3b8;line-height:1.55;margin-bottom:16px}.auth-message{min-height:18px;font-size:.78rem;color:#64748b;margin-bottom:12px}.auth-message.error{color:#fca5a5}.auth-message.success{color:#6ee7b7}.auth-actions{display:flex;gap:10px;align-items:center}.auth-secondary-btn{padding:10px 12px;background:transparent;color:#94a3b8;border:1px solid #334155;border-radius:6px;font-size:.8rem;cursor:pointer;white-space:nowrap}.auth-secondary-btn:hover{border-color:#475569;color:#e2e8f0}.modal-close{position:relative;top:auto;right:auto;background:#0f172aeb;border:1px solid #334155;color:#cbd5e1;font-size:1.35rem;width:36px;height:36px;border-radius:999px;cursor:pointer;flex-shrink:0}.modal-close:hover{color:#f1f5f9;border-color:#475569}.modal-meta{font-size:.7rem;color:#94a3b8;margin-bottom:12px;line-height:1.8}.modal-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.modal-body{margin-top:12px}#modal-content h1{font-size:1.1rem;color:#f8fafc;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #334155}#modal-content h2{font-size:.9rem;color:#e2e8f0;margin-top:.6em;margin-bottom:.2em}#modal-content h3{font-size:.85rem;color:#cbd5e1;margin-top:.5em;margin-bottom:.15em}#modal-content ul,#modal-content ol{padding-left:1.5em;margin:.2em 0 .4em}#modal-content li{margin:0;line-height:1.5}#modal-content code{background:#0f172a;padding:1px 6px;border-radius:3px;font-size:.8rem;color:#93c5fd}#modal-content pre{background:#0f172a;padding:12px;border-radius:6px;overflow-x:auto;margin:8px 0}#modal-content pre code{background:none;padding:0}.lifecycle-progress{display:flex;align-items:center;justify-content:center;gap:0;margin:16px 0 20px;padding:12px 0}.progress-step{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}.step-dot{width:10px;height:10px;border-radius:50%;background:#334155;border:2px solid #475569;transition:all .2s}.progress-step.completed .step-dot{background:#10b981;border-color:#10b981}.progress-step.current .step-dot{background:#3b82f6;border-color:#60a5fa;box-shadow:0 0 8px #3b82f680}.step-label{font-size:.55rem;color:#64748b;white-space:nowrap}.progress-step.completed .step-label{color:#10b981}.progress-step.current .step-label{color:#60a5fa;font-weight:600}.progress-line{width:20px;height:2px;background:#334155;margin-bottom:18px}.lifecycle-sections{display:flex;flex-direction:column;gap:10px}.lifecycle-phase{border:1px solid #334155;border-radius:8px;overflow:hidden}.lifecycle-phase.active{border-color:#475569}.phase-header{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#0f172a;font-size:.78rem;font-weight:600;color:#94a3b8;position:relative}.phase-icon{font-size:.85rem}.phase-label{text-transform:uppercase;letter-spacing:.03em}.phase-requirement .phase-header{color:#60a5fa}.phase-plan .phase-header{color:#fbbf24}.phase-decision-log .phase-header{color:#34d399}.phase-plan-review .phase-header{color:#fb923c}.phase-impl .phase-header{color:#f472b6}.phase-review .phase-header{color:#a78bfa}.phase-test .phase-header{color:#2dd4bf}.phase-agent-log .phase-header{color:#94a3b8}.review-count{margin-left:auto;font-size:.65rem;font-weight:400;color:#64748b}.phase-edit-btn{margin-left:auto;background:none;border:1px solid #334155;color:#64748b;font-size:.8rem;width:26px;height:26px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}.phase-edit-btn:hover{color:#e2e8f0;border-color:#60a5fa}.phase-expand-btn{background:none;border:1px solid #334155;color:#64748b;font-size:.75rem;width:26px;height:26px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s;flex-shrink:0}.phase-label+.phase-expand-btn{margin-left:auto}.phase-expand-btn:hover{color:#e2e8f0;border-color:#60a5fa}.lifecycle-phase:fullscreen,.lifecycle-phase:-webkit-full-screen{background:#1e293b;overflow-y:auto;border:none;border-radius:0;display:flex;flex-direction:column}.lifecycle-phase:fullscreen .phase-header,.lifecycle-phase:-webkit-full-screen .phase-header{position:sticky;top:0;z-index:1;padding:16px 32px;background:#0f172a;border-bottom:1px solid #334155}.lifecycle-phase:fullscreen .phase-body,.lifecycle-phase:-webkit-full-screen .phase-body{font-size:1rem;line-height:1.75;padding:32px;max-width:960px;margin:0 auto;width:100%;box-sizing:border-box}.lifecycle-phase:fullscreen .phase-body pre,.lifecycle-phase:-webkit-full-screen .phase-body pre{font-size:.875rem}.lifecycle-phase:fullscreen .phase-body svg,.lifecycle-phase:-webkit-full-screen .phase-body svg{max-width:100%;height:auto}.phase-body.hidden{display:none}.phase-body textarea{width:100%;background:#0f172a;border:1px solid #334155;border-radius:6px;padding:8px 10px;font-size:.8rem;font-family:ui-monospace,Cascadia Code,Fira Code,monospace;color:#e2e8f0;line-height:1.5;resize:vertical;min-height:80px}.phase-body textarea:focus{outline:none;border-color:#3b82f6}.phase-edit-actions{display:flex;gap:8px;margin-top:8px;justify-content:flex-end}.phase-save-btn,.phase-cancel-btn{padding:5px 14px;font-size:.75rem;font-weight:600;border-radius:4px;cursor:pointer;border:none}.phase-save-btn{background:#3b82f6;color:#fff}.phase-save-btn:hover{background:#2563eb}.phase-cancel-btn{background:#334155;color:#94a3b8}.phase-cancel-btn:hover{background:#475569}.phase-body{padding:10px 14px;font-size:.78rem;color:#cbd5e1;line-height:1.5}.phase-body p{margin:0 0 .4em}.phase-body p:last-child{margin-bottom:0}.phase-body ul,.phase-body ol{margin:.2em 0 .4em;padding-left:1.5em}.phase-body li{margin:0;padding:0;line-height:1.5}.phase-body h1,.phase-body h2,.phase-body h3{margin:.6em 0 .2em}.phase-body h1:first-child,.phase-body h2:first-child,.phase-body h3:first-child{margin-top:0}.phase-body pre{margin:.4em 0}.phase-empty{color:#475569;font-style:italic}.review-entry{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:10px;margin-bottom:8px}.review-entry.approved{border-left:3px solid #10b981}.review-entry.changes_requested{border-left:3px solid #f97316}.review-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.review-meta{font-size:.65rem;color:#64748b}.review-comment{font-size:.78rem;color:#cbd5e1;line-height:1.5}.review-comment p{margin:0 0 .4em}.review-comment p:last-child{margin-bottom:0}.review-comment ul,.review-comment ol{margin:.2em 0 .4em;padding-left:1.5em}.review-comment li{margin:0;line-height:1.5}.test-output{font-size:.75rem;margin-bottom:6px}.test-output pre{background:#1e293b;padding:6px 10px;border-radius:4px;font-size:.7rem;color:#94a3b8;margin-top:2px;overflow-x:auto;max-height:120px;overflow-y:auto}.agent-log-body{display:flex;flex-direction:column;gap:4px}.agent-log-entry{display:flex;align-items:center;gap:8px;font-size:.72rem;padding:4px 0;border-bottom:1px solid #1e293b}.agent-log-entry:last-child{border-bottom:none}.agent-log-time{font-size:.65rem;color:#64748b;font-family:ui-monospace,monospace;white-space:nowrap}.agent-log-msg{color:#cbd5e1;flex:1}.badge.model-tag{font-size:.58rem;padding:1px 5px;border-radius:3px;font-weight:600;letter-spacing:.02em;white-space:nowrap}.badge.model-opus{background:#7c3aed20;color:#a78bfa;border:1px solid #7c3aed40}.badge.model-sonnet{background:#3b82f620;color:#60a5fa;border:1px solid #3b82f640}.badge.model-haiku{background:#10b98120;color:#34d399;border:1px solid #10b98140}.badge.model-gemini{background:#f59e0b20;color:#fbbf24;border:1px solid #f59e0b40}.badge.model-copilot{background:#64748b20;color:#94a3b8;border:1px solid #64748b40}.level-select{margin-left:auto;background:#1e293b;border:1px solid #334155;color:#94a3b8;font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:4px;cursor:pointer}.level-select:hover{border-color:#60a5fa;color:#e2e8f0}.level-select:focus{outline:none;border-color:#3b82f6}.attachment-drop-zone{border:2px dashed #334155;border-radius:8px;padding:16px;text-align:center;cursor:pointer;color:#64748b;font-size:.78rem;margin:8px 0;transition:border-color .15s,background .15s}.attachment-drop-zone:hover,.attachment-drop-zone.drop-active{border-color:#3b82f6;background:#3b82f60d;color:#94a3b8}.attachments-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.attachment-thumb{position:relative;width:100px;height:100px;border-radius:6px;overflow:hidden;border:1px solid #334155;background:#0f172a}.attachment-thumb img{width:100%;height:100%;object-fit:cover;cursor:pointer}.attachment-thumb img:hover{opacity:.8}.attachment-thumb .attachment-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:#000000b3;color:#ef4444;border:none;font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.attachment-thumb:hover .attachment-remove{opacity:1}.attachment-name{position:absolute;bottom:0;left:0;right:0;background:#000000b3;color:#94a3b8;font-size:.55rem;padding:2px 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-danger-zone{margin-top:16px;padding-top:12px;border-top:1px solid #334155;display:flex;justify-content:flex-end}.delete-task-btn{background:none;border:1px solid #334155;color:#64748b;font-size:.72rem;padding:5px 12px;border-radius:4px;cursor:pointer;transition:all .15s}.delete-task-btn:hover{background:#991b1b;border-color:#991b1b;color:#fca5a5}details.phase-agent-log>summary{cursor:pointer;list-style:none}details.phase-agent-log>summary::-webkit-details-marker{display:none}details.phase-agent-log>summary:before{content:"u25B6";font-size:.6rem;margin-right:4px;transition:transform .15s;display:inline-block}details.phase-agent-log[open]>summary:before{transform:rotate(90deg)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#475569}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.75rem;font-weight:600;color:#94a3b8;margin-bottom:4px;text-transform:uppercase;letter-spacing:.03em}.form-group input[type=text],.form-group textarea,.form-group select{width:100%;background:#0f172a;border:1px solid #334155;border-radius:6px;padding:8px 12px;font-size:.85rem;color:#e2e8f0;font-family:inherit;transition:border-color .15s}.form-group input[type=text]:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#3b82f6}.form-group textarea{resize:vertical}.form-row{display:flex;gap:12px}.form-row .form-col{flex:1}.form-submit{width:100%;padding:10px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.form-submit:hover{background:#2563eb}@media(max-width:1400px){main#board{grid-template-columns:repeat(7,minmax(160px,1fr))}.column-header{padding:10px;font-size:.72rem}.card{padding:8px 10px}.card-title{font-size:.75rem}.card-desc{font-size:.65rem}.badge{font-size:.55rem;padding:1px 5px}}@media(max-width:1200px){main#board{grid-template-columns:repeat(7,minmax(140px,1fr))}.column-header{padding:8px;font-size:.68rem}.column-body{padding:6px;gap:4px}.card{padding:6px 8px}.card-title{font-size:.72rem}.card-desc,.card-tags{display:none}}@media(max-width:1024px){main#board{grid-template-columns:repeat(4,1fr);height:auto;overflow-x:visible}.column{border-bottom:1px solid #1e293b}.card-desc{display:block}}@media(max-width:768px){.modal-overlay{align-items:flex-end;justify-content:stretch;padding:0;background:linear-gradient(180deg,#0206173d,#020617c2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal{width:100%;max-width:none;max-height:min(92vh,100dvh);min-height:54vh;border-radius:22px 22px 0 0;border-left:none;border-right:none;border-bottom:none;padding:14px 16px calc(22px + env(safe-area-inset-bottom))}.detail-modal{min-height:72vh}.add-card-modal,.auth-modal{min-height:68vh}.sheet-handle{display:block}.modal-sheet-header{position:sticky;top:-14px;z-index:2;margin:0 -16px 14px;padding:0 16px 12px;background:linear-gradient(180deg,#1e293bfa,#1e293be6);border-bottom:1px solid rgba(51,65,85,.9);align-items:center}.auth-sheet-header{margin-bottom:12px}.modal-sheet-title,.auth-title{font-size:1.02rem}.auth-copy{font-size:.8rem;line-height:1.6}.form-group input[type=text],.form-group textarea,.form-group select{font-size:16px}.form-row{flex-direction:column;gap:10px}.attachment-drop-zone{overflow-wrap:anywhere}.auth-actions{flex-direction:column;align-items:stretch}.auth-secondary-btn,.auth-actions .form-submit{width:100%}.modal-body{margin-top:8px}#modal-content{padding-bottom:8px}header{align-items:stretch;gap:12px;padding:14px 16px}.header-left,.header-meta{width:100%}.header-left{justify-content:space-between}.header-tabs{width:100%;justify-content:flex-start;overflow-x:auto;padding:3px}.tab-btn{flex:1 0 auto;text-align:center;white-space:nowrap}.header-meta{justify-content:space-between;gap:8px;margin-left:0}#count-summary{order:-1;width:100%;font-size:.75rem}.toolbar{align-items:stretch;padding:10px 16px 14px}.toolbar-primary,.toolbar-secondary{width:100%;justify-content:flex-start}.toolbar-primary{flex-direction:column;align-items:stretch}.toolbar-mobile-toggle{display:inline-flex;align-items:center;justify-content:center;width:100%}.toolbar-secondary{display:none;flex-direction:column;align-items:stretch}body.mobile-toolbar-open .toolbar-secondary{display:flex}#search-input,#sort-select,#project-filter,#project-select,.toolbar .toolbar-toggle-btn,.toolbar-secondary>*{width:100%}#search-input,#sort-select,#project-filter{flex:0 0 auto}#category-filter{flex-wrap:wrap}.cat-chip{flex:1 1 auto;text-align:center}.toolbar-secondary .toolbar-toggle-btn{justify-content:center}main#board{grid-template-columns:1fr;height:auto;gap:10px;padding:12px 16px 18px}.column{border:1px solid #1e293b;border-radius:14px;background:#111827;max-height:none}.column-header{padding:0;border-bottom:none}.column-toggle-btn{padding:14px}.column-toggle-label{font-size:.76rem}.column-toggle-icon{display:inline-block}.column[data-mobile-expanded=false] .column-body{display:none}.column-body{padding:10px;border-top:1px solid #1e293b}body.mobile-board-search main#board .column .column-body{display:flex}body.mobile-board-search main#board .column .column-toggle-icon{opacity:.5}.add-card-btn{width:28px;height:28px}.mobile-card{padding:10px;border-radius:10px}.mobile-card .card-copy-btn{opacity:1}.mobile-card .card-desc,.mobile-card .card-tags{display:none}.mobile-card .card-header{gap:5px;margin-bottom:6px}.mobile-card .card-title{font-size:.84rem;margin-bottom:6px}.mobile-card .card-footer{gap:5px}.mobile-card-move{display:grid;gap:6px;margin-top:8px;color:#94a3b8;font-size:.68rem;text-transform:uppercase;letter-spacing:.04em}}@media(max-width:640px){header h1{font-size:1rem}.tab-btn{font-size:.72rem;padding:7px 10px}.toolbar{gap:8px}#refresh-btn{width:36px;height:36px}.toolbar-toggle-btn,#sort-select,#search-input,#project-select{font-size:.82rem}}#list-view{padding:16px 24px;height:calc(100vh - 57px);overflow-y:auto}#list-view.hidden{display:none}.list-view-shell{display:flex;flex-direction:column;gap:16px}.list-cards{display:none}.list-card{border:1px solid #1e293b;border-radius:16px;background:linear-gradient(180deg,#0f172af5,#0f172ad1);padding:14px;display:grid;gap:12px;box-shadow:0 18px 40px #0f172a2e}.list-card-top,.list-card-meta,.list-card-dates,.list-card-tags{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.list-card-top{justify-content:space-between}.list-card-id{color:#94a3b8;font-size:.74rem;font-weight:700}.list-card-title{background:none;border:none;padding:0;color:#f8fafc;font-size:.94rem;font-weight:700;text-align:left;line-height:1.45;cursor:pointer}.list-card-title:hover{color:#60a5fa}.list-card-dates{color:#94a3b8;font-size:.74rem;justify-content:space-between}.list-card-controls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.list-card-controls label{display:grid;gap:6px;font-size:.68rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.list-card-controls select{width:100%}.list-table{width:100%;border-collapse:collapse;font-size:.78rem}.list-table th{text-align:left;padding:8px 10px;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid #334155;white-space:nowrap;position:sticky;top:0;background:#0f172a;z-index:1}.list-table td{padding:6px 10px;border-bottom:1px solid #1e293b;color:#cbd5e1;vertical-align:middle}.list-table tr:hover td{background:#1e293b}.list-table tr.status-done td{opacity:.5}.list-table tr:hover.status-done td{opacity:.8}.list-table .col-id{color:#64748b;font-weight:500;width:50px}.list-table .col-title{font-weight:600;color:#f1f5f9;cursor:pointer;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-table .col-title:hover{color:#60a5fa}.list-status-select,.list-level-select,.list-priority-select{background:#0f172a;border:1px solid #334155;color:#cbd5e1;font-size:.72rem;padding:3px 6px;border-radius:4px;cursor:pointer}.list-status-select:hover,.list-level-select:hover,.list-priority-select:hover{border-color:#60a5fa}.list-status-select:focus,.list-level-select:focus,.list-priority-select:focus{outline:none;border-color:#3b82f6}.list-date{font-size:.68rem;color:#64748b;white-space:nowrap}.md-table{width:100%;border-collapse:collapse;font-size:.8rem;margin:10px 0;border:1px solid #334155;border-radius:6px;overflow:hidden}.md-table th{background:#1e293b;color:#94a3b8;font-weight:600;text-align:left;padding:6px 10px;border-bottom:2px solid #334155;font-size:.72rem;text-transform:uppercase;letter-spacing:.03em}.md-table td{padding:5px 10px;border-bottom:1px solid #1e293b;color:#cbd5e1}.md-table tr:last-child td{border-bottom:none}.md-table tr:hover td{background:#1e293b40}pre.mermaid{background:#0f172a;border:1px solid #334155;border-radius:8px;padding:16px;margin:10px 0;overflow-x:auto;text-align:center}pre.mermaid svg{max-width:100%;height:auto}.notes-section{margin-top:20px;border-top:1px solid #1e293b;padding-top:16px}.notes-header{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;color:#94a3b8;margin-bottom:12px}.notes-count{background:#334155;color:#94a3b8;font-size:.65rem;padding:1px 6px;border-radius:8px;font-weight:500}.notes-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.note-entry{background:#1e293b;border-radius:6px;padding:10px 12px;border-left:3px solid #3b82f6}.note-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.note-author{font-size:.72rem;font-weight:600;color:#60a5fa}.note-time{font-size:.65rem;color:#475569}.note-delete{margin-left:auto;background:none;border:none;color:#475569;cursor:pointer;font-size:.9rem;padding:0 4px;line-height:1;border-radius:3px}.note-delete:hover{color:#ef4444;background:#1e293b}.note-text{font-size:.78rem;color:#cbd5e1;line-height:1.5}.note-text p{margin:0 0 4px}.note-text p:last-child{margin-bottom:0}.note-form{display:flex;gap:8px;align-items:flex-start}.note-form textarea{flex:1;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#e2e8f0;padding:8px 10px;font-size:.78rem;font-family:inherit;resize:vertical;min-height:36px}.note-form textarea:focus{outline:none;border-color:#3b82f6}.note-form textarea::placeholder{color:#475569}.note-submit{background:#3b82f6;color:#fff;border:none;border-radius:6px;padding:8px 14px;font-size:.75rem;font-weight:500;cursor:pointer;white-space:nowrap}.note-submit:hover{background:#2563eb}.badge.notes-count{background:#1e3a5f;color:#60a5fa;font-size:.6rem}#chronicle-view{height:calc(100vh - 112px);overflow-y:auto;padding:32px 24px}.chronicle-timeline{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:32px}.chronicle-week-header{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#475569;border-bottom:1px solid #1e293b;padding-bottom:6px;margin-bottom:12px}.chronicle-events{position:relative;display:flex;flex-direction:column;gap:10px;padding-left:28px}.chronicle-events:before{content:"";position:absolute;left:5px;top:0;bottom:0;width:2px;background:#1e293b;border-radius:1px}.chronicle-event{display:flex;align-items:flex-start;gap:10px;position:relative}.chronicle-dot{position:absolute;left:-23px;top:3px;width:12px;height:12px;border-radius:50%;border:2px solid #0f172a;flex-shrink:0}.ev-completed{background:#2a8860}.chronicle-event-time{width:52px;flex-shrink:0;font-size:.68rem;color:#4e6070;font-variant-numeric:tabular-nums;padding-top:1px;line-height:1.5;white-space:pre-line}.chronicle-event-body{display:flex;flex-wrap:wrap;align-items:center;gap:6px;min-width:0}.chronicle-task-link{background:none;border:none;color:#cbd5e1;font-size:.8rem;font-weight:600;cursor:pointer;padding:0;text-align:left;white-space:normal;word-break:break-word}.chronicle-task-link:hover{color:#60a5fa;text-decoration:underline}@media(max-width:768px){#list-view{padding:12px 16px 22px;height:calc(100vh - 112px)}.list-cards{display:grid;gap:12px}.list-table{display:none}.list-card-controls{grid-template-columns:1fr}.list-card-dates{gap:6px 12px;justify-content:flex-start}#chronicle-view{height:calc(100vh - 112px);padding:16px 16px 24px}.chronicle-timeline{gap:18px}.chronicle-week-header{font-size:.72rem;margin-bottom:10px}.chronicle-events{padding-left:20px;gap:12px}.chronicle-events:before{left:2px}.chronicle-dot{left:-18px;top:6px}.chronicle-event{gap:12px;padding:12px 12px 12px 10px;border:1px solid #1e293b;border-radius:14px;background:#0f172ab8}.chronicle-event-time{width:64px;font-size:.72rem}.chronicle-event-body{gap:8px}.chronicle-task-link{font-size:.9rem;line-height:1.45}}#graph-view{position:relative;overflow:hidden;padding:0}#graph-view.hidden{display:none}.graph-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:320px;color:#94a3b8;font-size:.9rem}.graph-spinner{width:32px;height:32px;border:3px solid #334155;border-top-color:#60a5fa;border-radius:50%;animation:graph-spin .8s linear infinite}@keyframes graph-spin{to{transform:rotate(360deg)}}.graph-tooltip{display:none;position:absolute;z-index:20;pointer-events:none;background:#1e293b;border:1px solid #334155;border-radius:8px;padding:8px 12px;max-width:280px;font-size:.78rem;color:#e2e8f0;box-shadow:0 4px 12px #0006}.graph-tooltip-title{font-weight:600;margin-bottom:4px;line-height:1.3;color:#f1f5f9}.graph-tooltip-meta{color:#94a3b8;font-size:.72rem;margin-bottom:4px}.graph-tooltip-tags{display:flex;flex-wrap:wrap;gap:4px}.graph-tooltip-tags span{background:#334155;color:#cbd5e1;padding:1px 6px;border-radius:4px;font-size:.68rem}.graph-legend{position:absolute;bottom:16px;right:16px;background:#1e293b;border:1px solid #334155;border-radius:8px;padding:8px 12px;display:flex;flex-direction:column;gap:4px;z-index:10;pointer-events:none}.graph-legend-item{display:flex;align-items:center;gap:6px;font-size:.72rem;color:#94a3b8;text-transform:capitalize}.graph-legend-item span{width:10px;height:10px;border-radius:50%;flex-shrink:0}@media(max-width:600px){#tab-graph{display:none}}
