*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0b1120;--surface: #131f35;--surface2: #0f1929;--border: #1e3251;--border2: #2a4270;--text: #e2e8f0;--text2: #7a90aa;--text3: #3d5270;--header-bg: #0d1729;--sidebar-bg: #0d1729;--radius: 10px;--radius-sm: 7px;--sh-sm: 0 1px 4px rgba(0,0,0,.4);--sh: 0 4px 12px rgba(0,0,0,.5)}:root[data-theme=light]{--bg: #f1f5f9;--surface: #ffffff;--surface2: #f8fafc;--border: #e2e8f0;--border2: #cbd5e1;--text: #0f172a;--text2: #475569;--text3: #94a3b8;--header-bg: #1e293b;--sidebar-bg: #ffffff;--sh-sm: 0 1px 3px rgba(0,0,0,.08);--sh: 0 4px 12px rgba(0,0,0,.12)}:root[data-theme=green]{--bg: #050d06;--surface: #0c1a0d;--surface2: #091409;--border: #193d1e;--border2: #235829;--text: #c8e6c9;--text2: #6ea870;--text3: #385a3a;--header-bg: #040b05;--sidebar-bg: #040b05;--sh-sm: 0 1px 4px rgba(0,0,0,.5);--sh: 0 4px 14px rgba(0,0,0,.6)}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Pretendard,sans-serif;background:var(--bg);color:var(--text);height:100dvh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;font-size:14px}.header{background:var(--header-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:10px;flex-shrink:0;z-index:100;padding-top:env(safe-area-inset-top);min-height:calc(52px + env(safe-area-inset-top))}.header-icon{width:28px;height:28px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;box-shadow:0 0 12px #6366f166}.header-title{font-size:14px;font-weight:700;color:#e2e8f0;letter-spacing:-.02em}.header-sep{color:var(--border2);font-size:16px}.header-sub{font-size:12px;color:var(--text2)}.header-spacer{flex:1}.header-badge{font-size:11px;font-weight:500;color:var(--text2);background:var(--surface);border:1px solid var(--border);padding:3px 10px;border-radius:20px}.layout{display:flex;flex:1;overflow:hidden}.sidebar{width:210px;flex-shrink:0;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}.sidebar-section{padding:14px 10px 8px}.sidebar-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;padding:0 6px;margin-bottom:4px}.cat-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background .12s;user-select:none;position:relative}.cat-item:hover{background:var(--surface)}.cat-item.active{background:#6366f126}.cat-item.active .cat-name{color:#a5b4fc;font-weight:600}.cat-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.cat-name{font-size:13px;color:var(--text2);flex:1;line-height:1}.cat-count{font-size:11px;font-weight:500;color:var(--text3);background:var(--bg);padding:1px 7px;border-radius:10px}.cat-item.active .cat-count{background:#6366f133;color:#a5b4fc}.cat-del{display:none;position:absolute;right:8px;background:none;border:none;cursor:pointer;color:var(--text3);font-size:14px;padding:0 2px;border-radius:4px}.cat-del:hover{color:#f87171}.cat-item:hover .cat-del{display:flex;align-items:center}.cat-item:hover .cat-count{display:none}.sidebar-divider{height:1px;background:var(--border);margin:6px 10px}.btn-add-cat{display:flex;align-items:center;gap:8px;width:100%;background:none;border:none;padding:7px 14px;font-size:13px;color:var(--text3);cursor:pointer;font-family:inherit;transition:color .12s}.btn-add-cat:hover{color:#a5b4fc}.cat-add-form{margin:4px 10px 8px;border:1.5px solid #4f46e5;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface)}.cat-add-input{width:100%;padding:8px 10px;font-size:13px;font-family:inherit;border:none;outline:none;background:none;color:var(--text)}.cat-color-picker{display:flex;gap:5px;padding:6px 10px;border-top:1px solid var(--border);background:var(--surface2)}.color-swatch{width:17px;height:17px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .1s}.color-swatch:hover{transform:scale(1.2)}.color-swatch.selected{border-color:#fff}.cat-add-actions{display:flex;gap:5px;padding:7px 8px;background:var(--surface2);border-top:1px solid var(--border)}.content{flex:1;overflow-y:auto;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom)}.wip-strip{display:flex;align-items:center;gap:10px;padding:9px 20px;background:#f59e0b14;border-bottom:1px solid rgba(245,158,11,.2);overflow-x:auto;flex-shrink:0}.wip-strip::-webkit-scrollbar{display:none}.wip-label{font-size:11px;font-weight:700;color:#f59e0b;white-space:nowrap;display:flex;align-items:center;gap:5px}.wip-chip{background:#f59e0b1f;border:1px solid rgba(245,158,11,.25);border-radius:20px;padding:3px 11px;font-size:12px;font-weight:500;color:#fbbf24;white-space:nowrap;flex-shrink:0;max-width:180px;overflow:hidden;text-overflow:ellipsis}.cat-bar{padding:14px 20px 0;display:flex;align-items:baseline;gap:10px}.cat-bar-title{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.03em}.cat-bar-count{font-size:13px;color:var(--text3)}.view-toggle{display:flex;gap:3px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:3px;margin-left:auto}.view-btn{background:none;border:none;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:500;color:var(--text3);cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}.view-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--sh-sm)}.board{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:14px 20px 24px;align-items:start}.column{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--sh-sm)}.col-header{padding:12px 14px 10px;display:flex;align-items:center;gap:9px;border-bottom:1px solid var(--border)}.col-header.todo{background:#3b82f612}.col-header.wip{background:#f59e0b12}.col-header.done{background:#10b98112}.col-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.col-dot.todo{background:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.col-dot.wip{background:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}.col-dot.done{background:#10b981;box-shadow:0 0 0 3px #10b98133}.col-title{font-size:12.5px;font-weight:600;flex:1}.col-header.todo .col-title{color:#60a5fa}.col-header.wip .col-title{color:#fbbf24}.col-header.done .col-title{color:#34d399}.col-count{font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px}.col-header.todo .col-count{background:#3b82f626;color:#60a5fa}.col-header.wip .col-count{background:#f59e0b26;color:#fbbf24}.col-header.done .col-count{background:#10b98126;color:#34d399}.cards{padding:9px 9px 3px;display:flex;flex-direction:column;gap:7px;min-height:40px}.card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:box-shadow .2s,transform .15s}.card:hover{box-shadow:var(--sh);transform:translateY(-1px);border-color:var(--border2)}.drag-handle{display:flex;align-items:center;justify-content:center;width:18px;flex-shrink:0;cursor:grab;color:var(--text3);font-size:14px;line-height:1;opacity:0;transition:opacity .15s;user-select:none;-webkit-user-select:none}.card:hover .drag-handle{opacity:1}.drag-handle:active{cursor:grabbing}@media (max-width: 700px){.drag-handle{opacity:.5}}.card.sortable-ghost{opacity:0!important}.card.sortable-chosen{box-shadow:0 0 0 2px #6366f1,var(--sh)}.card.sortable-drag{opacity:.95!important;transform:rotate(1.5deg) scale(1.02)!important;box-shadow:0 20px 50px #000000a6!important}.cards.sortable-over{outline:2px dashed rgba(99,102,241,.45);outline-offset:-2px;border-radius:8px;background:#6366f10d}.card-top{padding:10px 9px 10px 8px;display:flex;align-items:flex-start;gap:6px;cursor:pointer}.card-top .card-title-text{cursor:pointer}.card-title-text{flex:1;font-size:13px;font-weight:500;color:var(--text);line-height:1.5;cursor:pointer;word-break:break-word}.card-title-input{flex:1;font-size:13px;font-weight:500;color:var(--text);background:#6366f10f;border:1px solid #6366f1;border-radius:5px;padding:2px 6px;outline:none;font-family:inherit;line-height:1.5;resize:none;overflow:hidden;min-height:20px;width:100%}.card-toggle{width:22px;height:22px;background:none;border:1px solid var(--border);cursor:pointer;color:var(--text3);font-size:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:5px;transition:all .15s}.card-toggle:hover{background:var(--surface);color:var(--text2)}.card-toggle.open{transform:rotate(180deg);background:var(--surface)}.card-meta{padding:0 12px 8px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}.card-date{font-size:11px;color:var(--text3)}.card-done-date{font-size:11px;font-weight:500;color:#34d399}.card-cat-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:10px;font-size:11px;font-weight:500}.card-cat-badge-dot{width:5px;height:5px;border-radius:50%}.card-progress{padding:0 12px 9px;display:flex;align-items:center;gap:8px}.progress-track{flex:1;height:3px;background:var(--border);border-radius:10px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:10px;transition:width .3s ease}.progress-fill.complete{background:linear-gradient(90deg,#10b981,#059669)}.progress-text{font-size:11px;font-weight:600;color:var(--text3);white-space:nowrap;min-width:52px;text-align:right}.progress-text.complete{color:#34d399}.card-body{display:none}.card-body.open{display:block}.checklist{padding:8px 12px 4px}.check-row{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:6px;transition:background .1s;cursor:pointer}.check-row:hover{background:#ffffff0a}.check-row input[type=checkbox]{appearance:none;-webkit-appearance:none;width:16px;height:16px;flex-shrink:0;border-radius:5px;border:1.5px solid var(--border2);background:var(--surface2);cursor:pointer;display:grid;place-content:center;transition:background .15s,border-color .15s,box-shadow .15s}.check-row input[type=checkbox]:before{content:"";width:9px;height:9px;clip-path:polygon(14% 44%,0 65%,50% 100%,100% 16%,80% 0%,43% 62%);background:#fff;transform:scale(0) rotate(-10deg);transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.check-row input[type=checkbox]:hover:not(:checked){border-color:#6366f1;background:#6366f112}.check-row input[type=checkbox]:checked{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-color:transparent;box-shadow:0 0 0 3px #6366f133}.check-row input[type=checkbox]:checked:before{transform:scale(1) rotate(0)}:root[data-theme=green] .check-row input[type=checkbox]:checked{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 0 0 3px #22c55e33}.check-text{flex:1;font-size:12.5px;color:var(--text2);line-height:1.5}.check-text.done{text-decoration:line-through;color:var(--text3)}.check-edit-input{flex:1;font-size:12.5px;color:var(--text);background:var(--bg);border:1px solid var(--border2);border-radius:5px;padding:3px 7px;outline:none;font-family:inherit}.check-edit-input:focus{border-color:#6366f1}.btn-pencil,.btn-trash{width:22px;height:22px;background:none;border:none;cursor:pointer;color:var(--text3);font-size:12px;display:flex;align-items:center;justify-content:center;border-radius:5px;opacity:0;transition:opacity .15s,background .15s;flex-shrink:0}.check-row:hover .btn-pencil,.check-row:hover .btn-trash{opacity:1}.btn-pencil:hover{background:var(--surface);color:var(--text2)}.btn-trash:hover{background:#f871711a;color:#f87171}.btn-pencil-confirm{background:#6366f126;color:#a5b4fc;border:none;border-radius:5px;padding:2px 7px;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;flex-shrink:0}.btn-pencil-cancel{background:none;color:var(--text3);border:none;border-radius:5px;padding:2px 5px;font-size:11px;cursor:pointer;font-family:inherit;flex-shrink:0}.btn-add-item{display:flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;color:var(--text3);font-size:12px;font-family:inherit;padding:6px 6px 4px;margin:2px 6px 4px;border-radius:6px;transition:all .15s;width:calc(100% - 12px)}.btn-add-item:hover{color:#a5b4fc;background:#6366f114}.add-item-row{display:flex;align-items:center;gap:7px;padding:4px 6px 6px}.add-item-input{flex:1;font-size:12.5px;color:var(--text);background:var(--bg);border:1px solid var(--border2);border-radius:6px;padding:5px 9px;outline:none;font-family:inherit}.add-item-input:focus{border-color:#6366f1}.btn-item-ok{background:#6366f1;color:#fff;border:none;border-radius:6px;padding:5px 11px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;flex-shrink:0}.btn-item-cancel{background:none;color:var(--text3);border:none;cursor:pointer;font-size:16px;line-height:1;flex-shrink:0}.checklist-divider{height:1px;background:var(--border);margin:6px 12px}.card-memo{width:100%;padding:9px 12px;font-size:12.5px;font-family:inherit;color:var(--text2);background:transparent;border:none;border-top:1px solid var(--border);outline:none;resize:vertical;min-height:60px;line-height:1.7}.card-memo::placeholder{color:var(--text3)}.card-memo:focus{background:#ffffff05}.card-footer{display:flex;align-items:center;padding:7px 9px;gap:5px;border-top:1px solid var(--border);background:var(--surface2)}.card-footer-spacer{flex:1}.btn-chip{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:11.5px;font-weight:500;cursor:pointer;color:var(--text2);transition:all .15s;white-space:nowrap;font-family:inherit}.btn-chip:hover{border-color:var(--border2);color:var(--text)}.btn-chip.danger:hover{background:#f871711a;color:#f87171;border-color:#f871714d}.add-form{margin:3px 9px 9px;border:1.5px solid #6366f1;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface2);box-shadow:0 0 0 3px #6366f11a}.add-form-title{width:100%;padding:10px 12px;font-size:13px;font-family:inherit;border:none;outline:none;background:none;color:var(--text);resize:none;overflow:hidden;min-height:40px;font-weight:500}.add-form-title::placeholder{color:var(--text3);font-weight:400}.add-form-checklist{padding:6px 8px 2px;border-top:1px solid var(--border)}.add-form-check-row{display:flex;align-items:center;gap:7px;padding:4px;border-radius:5px}.add-form-check-row-text{flex:1;font-size:12.5px;color:var(--text2)}.btn-remove-sub{background:none;border:none;cursor:pointer;color:var(--text3);font-size:15px;line-height:1;padding:0 2px;border-radius:4px;flex-shrink:0;opacity:0;transition:opacity .15s,color .15s}.add-form-check-row:hover .btn-remove-sub{opacity:1}.btn-remove-sub:hover{color:#f87171}.btn-add-sub{display:flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;color:var(--text3);font-size:12px;font-family:inherit;padding:5px 4px;border-radius:5px;transition:color .15s;width:100%}.btn-add-sub:hover{color:#a5b4fc}.add-sub-input-row{display:flex;align-items:center;gap:6px;padding:4px 4px 6px}.add-sub-input{flex:1;font-size:12.5px;color:var(--text);background:var(--bg);border:1px solid var(--border2);border-radius:5px;padding:4px 8px;outline:none;font-family:inherit}.add-sub-input:focus{border-color:#6366f1}.add-form-cat-row{display:flex;align-items:center;gap:8px;padding:7px 12px;border-top:1px solid var(--border);background:var(--surface2)}.add-form-cat-label{font-size:11px;color:var(--text3);white-space:nowrap}.add-form-cat-select{flex:1;font-size:12.5px;font-family:inherit;background:var(--bg);border:1px solid var(--border2);border-radius:6px;padding:5px 8px;color:var(--text);outline:none;cursor:pointer}.add-form-cat-select:focus{border-color:#6366f1}.add-form-actions{display:flex;gap:6px;padding:7px 9px;background:var(--surface2);border-top:1px solid var(--border)}.btn-primary{background:#6366f1;color:#fff;border:none;border-radius:6px;padding:5px 14px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.btn-primary:hover{background:#4f46e5}.btn-secondary{background:none;color:var(--text3);border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:12px;font-family:inherit;cursor:pointer;transition:all .15s}.btn-secondary:hover{background:var(--surface);color:var(--text2)}.col-footer{padding:7px 9px 11px}.btn-add-col{width:100%;background:none;border:1.5px dashed var(--border2);border-radius:var(--radius-sm);padding:8px;font-size:12px;font-weight:500;color:var(--text3);cursor:pointer;transition:all .15s;font-family:inherit}.btn-add-col:hover{color:#a5b4fc;border-color:#6366f1;background:#6366f10f}.col-empty{padding:20px 14px;text-align:center;color:var(--text3);font-size:12px;line-height:1.8}.calendar-wrap{padding:14px 20px 24px}.cal-nav{display:flex;align-items:center;gap:12px;margin-bottom:14px}.cal-title{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.02em;flex:1}.cal-nav-btn{background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:6px 12px;font-size:13px;color:var(--text2);cursor:pointer;font-family:inherit;transition:all .15s}.cal-nav-btn:hover{border-color:var(--border2);color:var(--text)}.cal-today-btn{background:none;border:1px solid var(--border);border-radius:7px;padding:6px 12px;font-size:12px;font-weight:500;color:var(--text3);cursor:pointer;font-family:inherit;transition:all .15s}.cal-today-btn:hover{border-color:#6366f1;color:#a5b4fc}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:16px}.cal-dow{text-align:center;font-size:11px;font-weight:600;color:var(--text3);padding:6px 0;text-transform:uppercase;letter-spacing:.06em}.cal-dow:first-child{color:#f87171}.cal-dow:last-child{color:#60a5fa}.cal-day{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:7px 8px;min-height:62px;cursor:pointer;transition:all .15s;position:relative}.cal-day:hover{border-color:var(--border2);background:var(--surface2)}.cal-day.other-month{opacity:.3;cursor:default}.cal-day.today{border-color:#6366f1;background:#6366f114}.cal-day.selected{border-color:#6366f1;box-shadow:0 0 0 2px #6366f14d}.cal-day-num{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:5px;line-height:1}.cal-day.today .cal-day-num{color:#a5b4fc}.cal-day-dots{display:flex;gap:3px;flex-wrap:wrap}.cal-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.cal-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--sh-sm)}.cal-panel-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:12px;letter-spacing:-.02em}.cal-task-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:7px;border:1px solid var(--border);margin-bottom:6px;background:var(--surface2)}.cal-task-status{display:flex;align-items:center;gap:5px;flex-shrink:0;min-width:60px}.cal-dot-sm{width:7px;height:7px;border-radius:50%}.cal-dot-sm.todo{background:#3b82f6}.cal-dot-sm.wip{background:#f59e0b}.cal-dot-sm.done{background:#10b981}.cal-status-lbl{font-size:11px;font-weight:500;color:var(--text3)}.cal-task-title{font-size:13px;color:var(--text);flex:1;font-weight:500}.cal-task-cat{font-size:11px;font-weight:500;padding:2px 8px;border-radius:10px;flex-shrink:0}.cal-task-prog{font-size:11px;color:var(--text3);font-weight:600;flex-shrink:0}.cal-panel-empty{font-size:13px;color:var(--text3);padding:12px 0}.comments-section{border-top:1px solid var(--border);padding:10px 12px}.comments-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.comment-item{display:flex;align-items:flex-start;gap:8px;padding:6px 8px;border-radius:6px;margin-bottom:3px;background:#ffffff05}.comment-item:hover{background:#ffffff0a}.comment-body{flex:1;min-width:0}.comment-text{font-size:12.5px;color:var(--text2);line-height:1.6;word-break:break-word;white-space:pre-wrap}.comment-time{font-size:10.5px;color:var(--text3);margin-top:2px}.btn-comment-del{background:none;border:none;cursor:pointer;color:var(--text3);font-size:14px;padding:0 2px;border-radius:4px;opacity:0;transition:opacity .15s,color .15s;flex-shrink:0;line-height:1.2}.comment-item:hover .btn-comment-del{opacity:1}.btn-comment-del:hover{color:#f87171}.comment-input-row{display:flex;gap:7px;margin-top:10px;align-items:flex-end}.comment-input{flex:1;font-size:12.5px;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:7px 10px;outline:none;font-family:inherit;resize:none;min-height:36px;line-height:1.5;transition:border-color .15s}.comment-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11f}.comment-input::placeholder{color:var(--text3)}.btn-comment-add{background:#6366f126;color:#a5b4fc;border:1px solid rgba(99,102,241,.3);border-radius:7px;padding:7px 13px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;flex-shrink:0;transition:background .15s;line-height:1.5}.btn-comment-add:hover{background:#6366f147}.loading{grid-column:1/-1;display:flex;align-items:center;justify-content:center;gap:8px;padding:80px 20px;color:var(--text3);font-size:13px}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:#6366f1;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.theme-switcher{display:flex;gap:5px;align-items:center;margin-right:2px}.theme-dot{width:15px;height:15px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;padding:0;transition:transform .15s,border-color .15s;flex-shrink:0}.theme-dot:hover{transform:scale(1.2)}.theme-dot.active{border-color:#ffffffbf}:root[data-theme=light] .theme-dot.active{border-color:#0006}.modal-overlay{position:fixed;inset:0;z-index:500;background:#000000a6;backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .18s}.modal-overlay.show{opacity:1;pointer-events:all}.modal-window{width:70%;max-width:860px;max-height:85vh;background:var(--surface);border:1px solid var(--border2);border-radius:14px;box-shadow:0 24px 80px #000000bf;display:flex;flex-direction:column;transform:scale(.96) translateY(10px);transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.modal-overlay.show .modal-window{transform:scale(1) translateY(0)}.modal-header{padding:18px 20px 14px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:12px;flex-shrink:0}.modal-title-input{flex:1;font-size:17px;font-weight:700;color:var(--text);background:none;border:none;outline:none;font-family:inherit;resize:none;line-height:1.4;letter-spacing:-.02em;padding:2px 6px;border-radius:6px;transition:background .15s}.modal-title-input:focus{background:#6366f10f}.modal-close{background:none;border:none;cursor:pointer;color:var(--text3);font-size:16px;padding:4px 8px;border-radius:6px;transition:all .15s;flex-shrink:0;line-height:1;margin-top:2px}.modal-close:hover{background:#f871711f;color:#f87171}.modal-body{flex:1;overflow-y:auto;padding:20px 22px;display:flex;flex-direction:column;gap:22px}.modal-section-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.modal-status-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.modal-status-chip{padding:5px 16px;border-radius:20px;font-size:12px;font-weight:600;border:1.5px solid transparent;cursor:pointer;transition:all .15s;font-family:inherit}.modal-status-chip.todo{color:#60a5fa;border-color:#3b82f640;background:#3b82f612}.modal-status-chip.todo.active{border-color:#3b82f6;background:#3b82f62e}.modal-status-chip.wip{color:#fbbf24;border-color:#f59e0b40;background:#f59e0b12}.modal-status-chip.wip.active{border-color:#f59e0b;background:#f59e0b2e}.modal-status-chip.done{color:#34d399;border-color:#10b98140;background:#10b98112}.modal-status-chip.done.active{border-color:#10b981;background:#10b9812e}.modal-cat-chip{font-size:11px;font-weight:600;padding:4px 12px;border-radius:20px;margin-left:4px}.modal-memo{width:100%;font-size:13.5px;font-family:inherit;color:var(--text2);background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;outline:none;resize:vertical;min-height:80px;line-height:1.7;transition:border-color .15s}.modal-memo:focus{border-color:#6366f1}.modal-memo::placeholder{color:var(--text3)}.modal-section-box{background:var(--surface2);border:1px solid var(--border);border-radius:8px;overflow:hidden}.modal-footer{padding:11px 20px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0;background:var(--surface2);border-radius:0 0 14px 14px}.modal-meta-info{font-size:11px;color:var(--text3);flex:1}@media (max-width: 700px){.modal-window{width:95%;max-height:92vh;border-radius:12px}.modal-body{padding:14px;gap:16px}.modal-header{padding:14px 14px 12px}.modal-footer{padding:10px 14px}}.toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%) translateY(70px);background:#1e293b;color:#e2e8f0;border:1px solid var(--border2);padding:9px 18px;border-radius:22px;font-size:12.5px;font-weight:500;z-index:200;transition:transform .22s cubic-bezier(.34,1.56,.64,1);pointer-events:none;white-space:nowrap;box-shadow:var(--sh)}.toast.show{transform:translate(-50%) translateY(0)}@media (max-width: 900px){.sidebar{width:180px}}@media (max-width: 700px){.sidebar{width:100%;height:auto;flex-direction:row;border-right:none;border-bottom:1px solid var(--border);overflow-x:auto;overflow-y:hidden;flex-shrink:0;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);-webkit-overflow-scrolling:touch}.sidebar::-webkit-scrollbar{display:none}.layout{flex-direction:column}.sidebar-section{padding:8px 6px;display:flex;gap:4px;align-items:center;white-space:nowrap;flex-shrink:0}.sidebar-label,.sidebar-divider{display:none}.cat-item{padding:7px 12px;flex-shrink:0;border-radius:20px}.cat-del{display:none!important}.btn-add-cat{padding:7px 12px;flex-shrink:0}.btn-add-cat span:last-child{display:none}.content{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.board{grid-template-columns:1fr;padding:10px 14px}.cat-bar{padding:12px 14px 0}.calendar-wrap{padding:12px 14px}.btn-chip{padding:6px 12px;font-size:12px}.card-footer{padding:9px 11px}.wip-strip{padding:9px 14px}.cal-day{min-height:48px;padding:5px}.cal-day-num{font-size:11px}.toast{bottom:calc(20px + env(safe-area-inset-bottom))}}
