:root{--bg: #f6f6f4;--surface: #ffffff;--surface-soft: #fbfbfa;--border: #e5e5e1;--border-strong: #d4d4cf;--ink: #22252a;--ink-soft: #6b7078;--ink-faint: #9aa0a8;--accent: #2563eb;--accent-soft: #eff4ff;--danger: #dc2626;--radius: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(20, 22, 26, .06);--shadow-md: 0 6px 24px rgba(20, 22, 26, .12);--font: -apple-system, "Segoe UI", system-ui, Roboto, "Helvetica Neue", sans-serif}*{box-sizing:border-box}body{margin:0;font-family:var(--font);font-size:14px;color:var(--ink);background:var(--bg)}button{font-family:inherit;font-size:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit;color:var(--ink)}.app{display:flex;flex-direction:column;height:100vh}.boot-loading,.boot-error{padding:48px;color:var(--ink-soft)}.boot-error{color:var(--danger)}.topbar{display:flex;align-items:center;gap:24px;padding:10px 20px;background:var(--surface);border-bottom:1px solid var(--border)}.brand{display:flex;align-items:center;gap:10px;font-weight:650;font-size:15px}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;background:var(--accent);color:#fff;font-weight:700}.seg{display:flex;gap:2px;padding:3px;background:var(--bg);border-radius:var(--radius)}.seg-btn{border:none;background:transparent;padding:6px 16px;border-radius:6px;color:var(--ink-soft);font-weight:500}.seg-btn.is-active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.project-filter{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);max-width:220px}.btn{padding:7px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);font-weight:500}.btn:hover{border-color:var(--border-strong)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{filter:brightness(1.08);border-color:var(--accent)}.btn-danger{color:var(--danger);border-color:#f3caca}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.avatar{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;color:#fff;font-size:10px;font-weight:650;flex-shrink:0}.proj-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-soft);background:var(--surface-soft);border:1px solid var(--border);border-radius:99px;padding:2px 9px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prio{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px}.prio-high{background:#fde8e8;color:#b91c1c}.prio-normal{background:var(--surface-soft);color:var(--ink-soft);border:1px solid var(--border)}.prio-low{background:var(--surface-soft);color:var(--ink-faint);border:1px solid var(--border)}.content{flex:1;overflow:auto;padding:20px}.list-view{display:flex;flex-direction:column;gap:28px;max-width:1100px}.list-group-title{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:650;margin:0 0 10px}.list-group-count{font-size:12px;font-weight:500;color:var(--ink-faint);background:var(--surface);border:1px solid var(--border);border-radius:99px;padding:1px 8px}.list-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.list-table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);padding:9px 14px;border-bottom:1px solid var(--border);background:var(--surface-soft)}.list-table td{padding:9px 14px;border-bottom:1px solid var(--border)}.list-table tr:last-child td{border-bottom:none}.list-table tbody tr:hover{background:var(--surface-soft)}.list-title-cell{font-weight:500;cursor:pointer}.list-title-cell:hover{color:var(--accent)}.list-assignee{display:flex;align-items:center;gap:8px;color:var(--ink-soft)}.list-date{color:var(--ink-soft);white-space:nowrap;font-variant-numeric:tabular-nums}.status-select{border:1px solid transparent;background:transparent;border-radius:6px;padding:4px 6px;font-weight:600}.status-select:hover{border-color:var(--border);background:var(--surface)}.quick-add{margin-top:8px;width:100%;padding:8px 14px;border:1px dashed var(--border-strong);border-radius:var(--radius);background:transparent;color:var(--ink)}.quick-add::placeholder{color:var(--ink-faint)}.quick-add:focus{outline:none;border-color:var(--accent);background:var(--surface)}.board{display:flex;gap:16px;align-items:flex-start;min-height:100%}.board-col{width:300px;flex-shrink:0;background:#efefec;border-radius:var(--radius-lg);padding:10px;display:flex;flex-direction:column;gap:10px;border:1px solid transparent}.board-col.is-drag-over{border-color:var(--accent);background:var(--accent-soft)}.board-col-head{display:flex;align-items:center;gap:8px;padding:2px 6px}.board-col-title{font-weight:650}.board-col-count{font-size:12px;color:var(--ink-faint);background:var(--surface);border-radius:99px;padding:1px 8px}.board-col-body{display:flex;flex-direction:column;gap:8px;min-height:40px}.board-empty{color:var(--ink-soft);font-size:13px;line-height:1.45;text-align:center;padding:18px 14px;border:1.5px dashed var(--border-strong);border-radius:var(--radius)}.card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 26px 10px 12px;box-shadow:var(--shadow-sm);cursor:grab;display:flex;flex-direction:column;gap:8px;align-items:flex-start;transition:transform .08s ease,box-shadow .08s ease,border-color .08s ease}.card:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-md)}.card:active{cursor:grabbing;transform:none}.card-grip{position:absolute;top:7px;right:7px;color:var(--ink-faint);font-size:13px;line-height:1;opacity:.5;pointer-events:none}.card:hover .card-grip{opacity:1;color:var(--ink-soft)}.card-title{font-weight:550;line-height:1.35}.card-foot{display:flex;align-items:center;gap:8px;width:100%}.card-spacer{flex:1}.card-due{font-size:12px;color:var(--ink-soft);font-variant-numeric:tabular-nums}.card-due.is-overdue{color:var(--danger);font-weight:650}.board-add{border:none;background:transparent;color:var(--ink-soft);text-align:left;padding:6px;border-radius:6px;font-weight:500}.board-add:hover{background:var(--surface);color:var(--ink)}.gantt-wrap{display:flex;flex-direction:column;gap:14px}.gantt-scroll{overflow-x:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.gantt-header{display:flex;position:sticky;top:0;z-index:5;background:var(--surface-soft);border-bottom:1px solid var(--border)}.gantt-corner{position:sticky;left:0;z-index:6;flex-shrink:0;background:var(--surface-soft);border-right:1px solid var(--border)}.gantt-months{display:flex;border-bottom:1px solid var(--border)}.gantt-month{font-size:12px;font-weight:650;color:var(--ink-soft);padding:6px 0 4px 8px;border-right:1px solid var(--border);overflow:hidden;white-space:nowrap;flex-shrink:0}.gantt-days{display:flex}.gantt-day{width:26px;flex-shrink:0;text-align:center;font-size:10px;color:var(--ink-faint);padding:3px 0 5px;font-variant-numeric:tabular-nums}.gantt-day.is-weekend{background:#f1f1ee}.gantt-day.is-today{color:#fff;background:var(--accent);border-radius:4px;font-weight:700}.gantt-body{position:relative}.gantt-bg{position:absolute;top:0;bottom:0;z-index:0}.gantt-weekend{position:absolute;top:0;bottom:0;background:#f6f6f3}.gantt-today-line{position:absolute;top:0;bottom:0;width:2px;background:var(--accent);opacity:.55}.gantt-row{display:flex;position:relative;z-index:1;border-bottom:1px solid #f0f0ed}.gantt-row.is-task{cursor:pointer}.gantt-row.is-task:hover .gantt-label{color:var(--accent)}.gantt-label{position:sticky;left:0;z-index:2;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);padding:8px 12px;display:flex;align-items:center;gap:8px;overflow:hidden}.gantt-task-title{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-assignee{margin-left:auto;font-size:11px;color:var(--ink-faint);white-space:nowrap}.gantt-project-row{background:var(--surface-soft)}.gantt-project-label{font-weight:650;background:var(--surface-soft)}.gantt-track{position:relative;flex-shrink:0;height:36px}.gantt-project-row .gantt-track{height:32px}.gantt-bar{position:absolute;top:7px;height:22px;border-radius:6px;display:flex;align-items:center;padding:0 8px;cursor:grab}.gantt-bar:active{cursor:grabbing}.gantt-bar.is-done{opacity:.45}.gantt-bar-label{font-size:11px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}.gantt-unscheduled{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.gantt-unscheduled-title{font-size:13px;font-weight:600;color:var(--ink-soft)}.chip-task{border:1px dashed var(--border-strong);background:var(--surface);border-radius:99px;padding:4px 12px;color:var(--ink-soft)}.chip-task:hover{border-color:var(--accent);color:var(--accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#181a1e66;display:flex;align-items:flex-start;justify-content:center;padding-top:9vh;z-index:100}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:540px;max-width:calc(100vw - 32px);max-height:82vh;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:14px}.modal-sm{width:400px}.modal-title{margin:0;font-size:16px}.field{display:flex;flex-direction:column;gap:5px;flex:1}.field>span{font-size:12px;font-weight:600;color:var(--ink-soft)}.field input,.field select,.field textarea{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field-row{display:flex;gap:12px}.color-row{display:flex;gap:8px}.color-swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent}.color-swatch.is-active{border-color:var(--ink)}.modal-actions{display:flex;align-items:center;gap:8px;position:sticky;bottom:0;background:var(--surface);padding:12px 0 2px;margin-top:4px;border-top:1px solid var(--border)}.modal-spacer{flex:1}.field-check{display:flex;align-items:center;gap:8px;font-weight:550;cursor:pointer;-webkit-user-select:none;user-select:none}.field-check input{accent-color:var(--accent)}.ms-diamond{display:inline-block;width:9px;height:9px;border-radius:2px;transform:rotate(45deg);flex-shrink:0;margin:0 4px 0 1px;background:var(--ink-soft)}.gantt-milestone{position:absolute;top:10px;width:15px;height:15px;border-radius:3px;transform:translate(-50%) rotate(45deg);box-shadow:var(--shadow-sm)}.gantt-milestone.is-done{opacity:.45}.gantt-ms-label{position:absolute;top:10px;font-size:11px;font-weight:600;color:var(--ink-soft);white-space:nowrap}.file-badge{font-size:9px;font-weight:700;color:#fff;border-radius:4px;padding:2px 5px;letter-spacing:.02em;flex-shrink:0}.attach-list{display:flex;flex-direction:column;gap:6px;align-items:stretch}.attach-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-soft)}.attach-item.is-pending{border-style:dashed}.attach-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink);text-decoration:none}a.attach-name:hover{color:var(--accent)}.attach-size{font-size:11px;color:var(--ink-faint);flex-shrink:0;font-variant-numeric:tabular-nums}.attach-remove{border:none;background:none;color:var(--ink-faint);padding:0 2px;font-size:13px}.attach-remove:hover{color:var(--danger)}.attach-add{align-self:flex-start;margin-top:2px}.card-attach{font-size:12px;color:var(--ink-soft)}.list-attach{font-size:12px;color:var(--ink-faint);margin-left:8px}.polls-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;max-width:1100px}.poll-card{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:8px}.poll-card:hover{border-color:var(--border-strong)}.poll-card-new{align-items:center;justify-content:center;border-style:dashed;color:var(--ink-soft);font-weight:550;min-height:110px;background:transparent;box-shadow:none}.poll-card-new:hover{border-color:var(--accent);color:var(--accent)}.poll-card-head{display:flex;align-items:center;justify-content:space-between}.poll-status{font-size:11px;font-weight:700;padding:2px 9px;border-radius:99px;background:var(--surface-soft);border:1px solid var(--border);color:var(--ink-faint)}.poll-status.is-open{background:#e8f6ec;border-color:#bfe5c8;color:#15803d}.poll-participants{font-size:12px;color:var(--ink-faint)}.poll-card-title{font-weight:650;font-size:15px;line-height:1.35}.poll-card-desc{font-size:13px;color:var(--ink-soft);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.polls-empty{color:var(--ink-soft);margin-top:16px}.poll-modal-head{display:flex;flex-direction:column;gap:8px;align-items:flex-start}.poll-desc{margin:0;color:var(--ink-soft)}.poll-vote-box{display:flex;flex-direction:column;gap:8px;background:var(--surface-soft);border:1px solid var(--border);border-radius:var(--radius);padding:14px}.poll-option{display:flex;align-items:center;gap:10px;cursor:pointer;padding:4px 2px}.poll-option input{accent-color:var(--accent)}.poll-vote-row{display:flex;gap:10px;margin-top:6px}.poll-voter{flex:1;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius)}.poll-voted-note{margin:0;color:#15803d;font-weight:600}.poll-results{display:flex;flex-direction:column;gap:10px}.poll-results-title{margin:0;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-faint);display:flex;align-items:baseline;gap:10px}.poll-results-sub{text-transform:none;letter-spacing:0;font-weight:500;font-size:12px}.poll-result-row{display:flex;flex-direction:column;gap:4px}.poll-result-label{display:flex;justify-content:space-between;font-size:13px}.poll-result-nums{color:var(--ink-soft);font-variant-numeric:tabular-nums}.poll-result-track{height:10px;border-radius:99px;background:var(--surface-soft);border:1px solid var(--border);overflow:hidden}.poll-result-bar{height:100%;border-radius:99px;background:var(--ink-faint);transition:width .4s ease}.poll-result-bar.is-leading{background:var(--accent)}.poll-voters{margin:2px 0 0;font-size:12px;color:var(--ink-faint)}.btn-icon{padding:7px 11px}.btn-gear.is-active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.admin-view{display:flex;flex-direction:column;gap:24px;max-width:760px}.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px}.admin-title{margin:0;font-size:15px}.admin-hint{margin:-8px 0 0;font-size:13px;color:var(--ink-soft)}.admin-appname{max-width:320px}.admin-actions{display:flex;align-items:center;gap:10px}.status-editor{display:flex;flex-direction:column;gap:8px}.status-row{display:flex;align-items:center;gap:10px}.status-color{width:36px;height:34px;padding:2px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer}.status-label-input{flex:1;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius)}.status-done-check{font-size:12px;color:var(--ink-soft);white-space:nowrap;font-weight:500}.status-remove:hover{color:var(--danger);border-color:#f3caca}.wording-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 20px}.wording-row{display:flex;align-items:center;gap:10px}.wording-key{width:130px;flex-shrink:0;font-size:11px;color:var(--ink-faint);font-family:Consolas,monospace;overflow:hidden;text-overflow:ellipsis}.wording-row input{flex:1;min-width:0;padding:6px 9px;border:1px solid var(--border);border-radius:var(--radius)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:380px;max-width:100%;padding:28px;display:flex;flex-direction:column;gap:14px}.login-brand{justify-content:center;margin-bottom:4px}.login-title{margin:0;font-size:15px;font-weight:600;text-align:center;color:var(--ink-soft)}.login-error{margin:0;color:var(--danger);font-size:13px}.login-btn{margin-top:4px;padding:10px}.user-menu{position:relative}.user-menu summary{list-style:none;cursor:pointer;display:flex;border-radius:50%}.user-menu summary::-webkit-details-marker{display:none}.user-menu summary .avatar{width:32px;height:32px;font-size:12px}.user-menu[open] summary .avatar{outline:2px solid var(--accent);outline-offset:1px}.user-menu-panel{position:absolute;right:0;top:40px;z-index:60;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:200px;padding:6px;display:flex;flex-direction:column}.user-menu-name{padding:8px 10px;font-weight:650;border-bottom:1px solid var(--border);margin-bottom:4px;display:flex;flex-direction:column}.user-menu-role{font-size:11px;font-weight:500;color:var(--ink-faint)}.user-menu-item{text-align:left;border:none;background:transparent;padding:8px 10px;border-radius:6px;color:var(--ink)}.user-menu-item:hover{background:var(--surface-soft);color:var(--accent)}.user-list{display:flex;flex-direction:column;gap:8px}.user-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-soft)}.user-name{font-weight:600;min-width:140px}.user-self{font-weight:400;color:var(--ink-faint);font-size:12px}.user-username{color:var(--ink-faint);font-size:12px;font-family:Consolas,monospace;flex:1}.user-role{padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.user-reset{display:flex;align-items:center;gap:6px}.user-reset input{width:150px;padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius)}.user-reset-btn{font-size:12px;padding:5px 10px}.new-user-form{display:flex;gap:8px;flex-wrap:wrap;padding-top:10px;border-top:1px solid var(--border)}.new-user-form input,.new-user-form select{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);flex:1;min-width:130px}.poll-anon{font-size:13px;color:var(--ink-soft);font-weight:500}.notes-list{display:flex;flex-direction:column;gap:8px;max-width:860px}.note-row{display:flex;align-items:center;gap:14px;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;box-shadow:var(--shadow-sm)}.note-row:hover{border-color:var(--border-strong)}.note-row-new{justify-content:center;border-style:dashed;background:transparent;box-shadow:none;color:var(--ink-soft);font-weight:550}.note-row-new:hover{border-color:var(--accent);color:var(--accent)}.note-date{width:90px;flex-shrink:0;color:var(--ink-faint);font-variant-numeric:tabular-nums;font-size:13px}.note-title{font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.note-meta{display:flex;align-items:center;gap:10px;flex-shrink:0}.note-items{font-size:12px;color:var(--ink-faint)}.note-items.has-open{color:#b45309;font-weight:600}.modal-note{width:760px}.note-head{display:flex;flex-direction:column;gap:10px}.note-title-input{font-size:18px;font-weight:650;border:none;border-bottom:1px solid var(--border);padding:4px 2px;outline:none}.note-title-input:focus{border-color:var(--accent)}.note-head-row{display:flex;gap:10px}.note-head-row input,.note-head-row select{padding:6px 9px;border:1px solid var(--border);border-radius:var(--radius)}.note-participants{flex:1}.note-body-toolbar{display:flex;align-items:center;gap:4px;background:var(--bg);border-radius:var(--radius);padding:3px}.note-body{width:100%;padding:12px;border:1px solid var(--border);border-radius:var(--radius);font-family:Consolas,monospace;font-size:13px;line-height:1.55;resize:vertical}.note-body:focus{outline:none;border-color:var(--accent)}.note-preview{border:1px solid var(--border);border-radius:var(--radius);padding:4px 16px;min-height:180px;max-height:380px;overflow-y:auto;background:var(--surface-soft);line-height:1.55}.note-preview h1,.note-preview h2{font-size:16px;margin:14px 0 6px}.note-preview h3{font-size:14px;margin:12px 0 4px}.note-preview table{border-collapse:collapse}.note-preview th,.note-preview td{border:1px solid var(--border);padding:4px 10px}.note-ai-section{display:flex;flex-direction:column;gap:8px}.ai-row{display:flex;align-items:center;gap:10px;padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-soft)}.ai-title{flex:1;text-align:left;border:none;background:none;font-weight:500;padding:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-title:hover{color:var(--accent)}.ai-due{font-size:12px;color:var(--ink-soft);font-variant-numeric:tabular-nums}.ai-add{display:flex;gap:8px;align-items:center}.ai-add input,.ai-add select{padding:7px 9px;border:1px solid var(--border);border-radius:var(--radius)}.ai-add-title{flex:2;border-style:dashed!important}.ai-add-assignee{width:130px}.project-manage{border:none;background:none;color:var(--ink-faint);font-size:14px;padding:2px 6px;border-radius:6px}.project-manage:hover{color:var(--accent);background:var(--surface)}.member-list{display:flex;flex-direction:column;gap:6px;max-height:260px;overflow-y:auto}.member-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-soft)}.member-name{font-weight:500}.member-row select{padding:5px 8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.picker-list{display:flex;flex-direction:column;gap:6px}.picker-row{display:flex;align-items:center;gap:10px;text-align:left;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);font-weight:500}.picker-row:hover{border-color:var(--accent);color:var(--accent)}.seg-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:7px;border-radius:99px;background:var(--accent);color:#fff;font-size:11px;font-weight:700}.seg-badge.is-danger{background:var(--danger)}.focus-view{display:flex;flex-direction:column;gap:16px;max-width:760px}.focus-empty{color:var(--ink-soft);font-size:15px}.focus-group{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint);margin-top:8px}.focus-group.is-danger{color:var(--danger)}.focus-task{display:flex;align-items:center;gap:10px;padding:5px 4px;border:none;background:transparent;border-radius:var(--radius);text-align:left}button.focus-task:hover{background:var(--surface-soft)}.focus-task-title{flex:1;border:none;background:none;text-align:left;font-weight:500;padding:4px 6px;border-radius:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.focus-task-title:hover{color:var(--accent)}.focus-poll-icon{font-size:16px}.comment-list{display:flex;flex-direction:column;gap:10px}.comment{display:flex;gap:10px;align-items:flex-start}.comment-main{flex:1;background:var(--surface-soft);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px}.comment-head{display:flex;align-items:baseline;gap:10px}.comment-author{font-weight:650;font-size:13px}.comment-time{font-size:11px;color:var(--ink-faint);flex:1}.comment-body{margin-top:3px;white-space:pre-wrap;line-height:1.45}.comment-add{display:flex;gap:8px}.comment-add input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:99px}.comment-add input:focus{outline:none;border-color:var(--accent)}.focus-comment{display:flex;gap:10px;align-items:flex-start;text-align:left;border:none;background:transparent;padding:8px;border-radius:var(--radius)}.focus-comment:hover{background:var(--surface-soft)}.focus-comment-main{flex:1}.focus-comment-task{font-size:12px;color:var(--accent);margin-top:1px}.dashboard{display:flex;flex-direction:column;gap:22px;max-width:1100px}.dash-kpis{display:flex;gap:14px;flex-wrap:wrap}.kpi-card{flex:1;min-width:130px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-sm)}.kpi-num{font-size:30px;font-weight:700;line-height:1.1;font-variant-numeric:tabular-nums}.kpi-label{display:flex;align-items:center;gap:7px;margin-top:4px;font-size:12px;font-weight:600;color:var(--ink-soft)}.kpi-danger{border-color:#f3caca;background:#fdf4f4}.kpi-danger .kpi-num{color:var(--danger)}.dash-projects{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}.dash-project{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px}.dash-project-head{display:flex;align-items:center;gap:9px}.dash-project-name{font-weight:650;font-size:15px;flex:1}.dash-lead{font-size:13px;color:var(--ink-soft)}.dash-progress{display:flex;align-items:center;gap:10px}.dash-progress-track{flex:1;height:9px;border-radius:99px;background:var(--surface-soft);border:1px solid var(--border);overflow:hidden}.dash-progress-bar{height:100%;border-radius:99px;transition:width .4s ease}.dash-progress-text{font-size:12px;color:var(--ink-soft);white-space:nowrap;font-variant-numeric:tabular-nums}.dash-status-chips{display:flex;gap:10px;flex-wrap:wrap;font-size:12px;font-weight:600}.dash-members{display:flex;flex-wrap:wrap;gap:8px 14px;border-top:1px solid var(--border);padding-top:10px}.dash-member{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-soft)}.dash-member .avatar{width:20px;height:20px;font-size:9px}.dash-lists{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dash-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:6px}.dash-empty{margin:4px 0;color:var(--ink-faint);font-size:13px}.dash-task{display:flex;align-items:center;gap:10px;text-align:left;border:none;background:transparent;padding:7px 8px;border-radius:var(--radius)}.dash-task:hover{background:var(--surface-soft)}.dash-task-title{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-task-date{font-size:12px;color:var(--ink-soft);font-variant-numeric:tabular-nums}.dash-task-date.is-overdue{color:var(--danger);font-weight:700}.gantt-bar{cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.gantt-bar.is-dragging,.gantt-milestone.is-dragging{opacity:.75;cursor:grabbing;box-shadow:var(--shadow-md)}.gantt-milestone{cursor:grab;touch-action:none}.gantt-handle{position:absolute;top:0;bottom:0;width:7px;cursor:ew-resize;background:#ffffff40}.gantt-handle-l{left:0;border-radius:6px 0 0 6px}.gantt-handle-r{right:0;border-radius:0 6px 6px 0}.gantt-bar:hover .gantt-handle{background:#ffffff8c}.gantt-milestone{cursor:grab}.gantt-milestone:active{cursor:grabbing}.hint-chip{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding:8px 12px;background:var(--accent-soft);border:1px solid #d3e0fb;border-radius:var(--radius);color:var(--ink-soft);font-size:13px}.hint-chip-icon{font-size:14px}.hint-chip-text{flex:1}.hint-chip-dismiss{border:1px solid var(--border-strong);background:var(--surface);color:var(--ink-soft);border-radius:99px;padding:3px 12px;font-size:12px;font-weight:600;white-space:nowrap}.hint-chip-dismiss:hover{border-color:var(--accent);color:var(--accent)}.field-hint{margin:4px 0 0;color:var(--ink-soft);font-size:12px;line-height:1.4}.btn-link-danger{border:none;background:none;color:var(--danger);padding:8px 0;font-weight:500;text-decoration:underline;text-underline-offset:2px}.btn-link-danger:hover{color:#a81d1d}.gantt-legend{display:flex;flex-wrap:wrap;align-items:center;gap:6px 16px;margin-bottom:10px;font-size:12px;color:var(--ink-soft)}.gantt-legend-item{display:inline-flex;align-items:center;gap:6px}.gantt-legend-bar{width:18px;height:10px;border-radius:3px}.gantt-legend-ms{position:static;width:11px;height:11px;background:var(--ink-soft)}.gantt-legend-today{width:2px;height:14px;background:var(--accent)}.gantt-header-scale{position:relative}.gantt-today-label{position:absolute;top:0;transform:translate(-50%);background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:99px;white-space:nowrap;z-index:3;pointer-events:none}.poll-card-cta{margin-top:10px;font-size:13px;font-weight:600;color:var(--ink-soft)}.poll-card-cta.is-primary{color:var(--accent)}.focus-poll-cta{margin-left:auto;font-size:13px;font-weight:600;color:var(--accent);white-space:nowrap}.kpi-muted{background:var(--surface-soft)}.kpi-muted .kpi-num{color:var(--ink-soft)}.tasks-toolbar{display:flex;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap}.tasks-toolbar-label{color:var(--ink-faint);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.seg-views{background:#e9eaec;padding:4px;border-radius:10px}.seg-views .seg-btn{padding:7px 18px;font-weight:600}.seg-ico{font-size:12px;opacity:.7}.tasks-empty{color:var(--ink-soft);font-size:14px;padding:24px 4px}.board-wrap{display:flex;flex-direction:column;height:100%}.board-wrap .board{flex:1}.welcome-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px 26px;margin-bottom:22px}.welcome-title{font-size:22px;margin:0 0 6px}.welcome-lead{color:var(--ink-soft);font-size:15px;line-height:1.55;max-width:620px;margin:0}.welcome-steps{margin-top:18px}.welcome-step{display:flex;gap:16px;padding:14px 0;align-items:flex-start}.welcome-step+.welcome-step{border-top:1px solid var(--border)}.welcome-step-num{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;font-weight:700;font-size:13px;background:#f1f1ef;color:var(--ink-soft);margin-top:1px}.welcome-step-num.is-done{background:#dcfce7;color:#16a34a}.welcome-step-num.is-current{background:var(--accent);color:#fff}.welcome-step-body{flex:1}.welcome-step-title{font-weight:600;font-size:15px}.welcome-step-title.is-done{color:var(--ink-faint);text-decoration:line-through}.welcome-step-sub{color:var(--ink-soft);font-size:14px;margin-top:3px;line-height:1.45}.welcome-step .btn{margin-top:10px}.welcome-step-link{border:none;background:none;color:var(--accent);font-weight:600;font-size:14px;padding:10px 0 0;display:inline-block}.welcome-footer{border-top:1px solid var(--border);margin-top:6px;padding-top:14px;display:flex;justify-content:space-between;align-items:center}.welcome-footer span{color:var(--ink-faint);font-size:13px}.welcome-dismiss{border:none;background:none;color:var(--ink-soft);font-weight:600;font-size:14px}.welcome-dismiss:hover{color:var(--ink)}.kpi-clickable{text-align:left;font:inherit;cursor:pointer;transition:border-color .08s ease,box-shadow .08s ease,transform .08s ease}.kpi-clickable:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-1px)}.dash-empty-big{color:var(--ink-soft);font-size:15px;text-align:center;padding:30px 4px}.dash-project-hint{margin-top:10px;font-size:14px;color:var(--ink-soft)}.dash-hint-link{border:none;background:none;color:var(--accent);font-weight:600;font-size:14px;padding:0}.source-chip{align-self:flex-start;border:1px solid var(--border);background:var(--surface-soft);border-radius:99px;padding:4px 12px;font-size:12.5px;color:var(--ink-soft);margin-bottom:4px}.source-chip:hover{border-color:var(--accent);color:var(--accent)}.poll-results-locked{color:var(--ink-soft);font-size:14px;background:var(--surface-soft);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin:4px 0 0}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:#1f2937;color:#fff;font-size:13.5px;font-weight:500;padding:10px 18px;border-radius:99px;box-shadow:var(--shadow-md);z-index:200;animation:toast-in .18s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.gantt-bar:hover{box-shadow:0 4px 12px #0f172a40;outline:2px solid var(--accent);outline-offset:1px}.gantt-tooltip{position:absolute;bottom:calc(100% + 8px);left:0;background:#1f2937;color:#fff;font-size:12px;font-weight:500;padding:6px 10px;border-radius:7px;white-space:nowrap;z-index:5;box-shadow:0 6px 16px #0f172a4d;opacity:0;pointer-events:none;transition:opacity .1s ease}.gantt-bar:hover .gantt-tooltip{opacity:1}.gantt-body.is-drop-target{outline:2px dashed var(--accent);outline-offset:-2px;background:var(--accent-soft)}.gantt-tray{display:flex;align-items:center;flex-wrap:wrap;gap:12px;border:2px dashed var(--border-strong);border-radius:var(--radius);padding:14px 18px;background:var(--surface-soft)}.gantt-tray-label{font-weight:700;font-size:13px;color:var(--ink-soft)}.gantt-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:99px;padding:7px 14px;font-size:14px;font-weight:600;color:var(--ink);box-shadow:var(--shadow-sm);cursor:grab}.gantt-chip:active{cursor:grabbing}.gantt-chip:hover{border-color:var(--accent)}.gantt-chip-grip{color:var(--ink-faint);font-size:12px}.gantt-tray-hint{margin-left:auto;color:var(--ink-faint);font-size:13px}.card-status-chip{display:none;align-items:center;gap:6px;border:1px solid var(--border);background:var(--surface);border-radius:99px;padding:5px 10px;font-size:13px;font-weight:600;color:var(--ink)}.card-status-chip .chip-caret{color:var(--ink-faint);font-size:10px}.format-bar{display:flex;gap:6px;margin-bottom:8px}.format-bar button{border:1px solid var(--border);background:var(--surface);border-radius:7px;padding:6px 12px;font-size:13px;font-weight:600;color:var(--ink-soft)}.format-bar button:hover{border-color:var(--accent);color:var(--accent)}.task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px;margin-bottom:10px}.task-card-title{font-weight:600;font-size:15px;line-height:1.3}.task-card-foot{display:flex;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}.task-card-due{font-size:13px;color:var(--ink-soft)}.agenda-head{display:flex;align-items:baseline;gap:8px;margin:20px 2px 10px}.agenda-head-d{font-weight:700;font-size:15px}.agenda-head-c{font-size:12.5px;color:var(--ink-faint)}.agenda-head.is-today .agenda-head-d{color:var(--accent)}.agenda-row,.agenda-ms,.agenda-undated{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:14px;margin-bottom:10px}.agenda-row.is-danger{border-color:#f3caca;background:#fdf4f4}.agenda-undated{display:block;border-style:dashed;background:var(--surface-soft)}.agenda-body{flex:1;min-width:0}.agenda-title{font-weight:600;font-size:15px;line-height:1.3}.agenda-title.is-done{color:var(--ink-faint);text-decoration:line-through}.agenda-sub{font-size:13px;color:var(--ink-soft);margin-top:4px}.agenda-sub.is-danger{color:var(--danger);font-weight:600}.agenda-ms .ms-diamond{position:static;width:14px;height:14px}.fab{position:fixed;right:16px;bottom:calc(74px + env(safe-area-inset-bottom));z-index:60;height:54px;padding:0 22px 0 18px;border-radius:28px;border:none;background:var(--accent);color:#fff;font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px;box-shadow:0 8px 20px #2563eb5c}.fab-plus{font-size:22px;line-height:1;margin-top:-2px}.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:55;display:flex;background:var(--surface);border-top:1px solid var(--border);padding:6px 4px calc(6px + env(safe-area-inset-bottom))}.tabbar-item{flex:1;border:none;background:none;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--ink-faint);font-size:11px;font-weight:600;padding:6px 0 4px;min-height:50px;position:relative}.tabbar-item.is-active{color:var(--accent)}.tabbar-ico{font-size:20px;line-height:1}.tabbar-badge{position:absolute;top:0;left:50%;margin-left:6px;min-width:16px;height:16px;padding:0 4px;border-radius:9px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center}.tabbar-badge.is-danger{background:var(--danger)}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182757;z-index:210;display:flex;align-items:flex-end}.sheet{width:100%;background:var(--surface);border-radius:20px 20px 0 0;padding:10px 18px calc(22px + env(safe-area-inset-bottom));box-shadow:0 -8px 30px #0f172a2e;animation:sheet-up .18s ease}@keyframes sheet-up{0%{transform:translateY(12px);opacity:.6}to{transform:translateY(0);opacity:1}}.sheet-grab{width:40px;height:5px;border-radius:3px;background:var(--border-strong);margin:4px auto 14px}.sheet-title{font-weight:700;font-size:16px}.sheet-sub{font-size:13.5px;color:var(--ink-soft);margin:4px 0 14px}.sheet-opt{display:flex;align-items:center;gap:12px;width:100%;text-align:left;border:1px solid var(--border);background:var(--surface);border-radius:12px;padding:15px 16px;margin-bottom:10px;font-size:15px;font-weight:600;color:var(--ink);min-height:54px}.sheet-opt.is-sel{border-color:var(--accent);background:var(--accent-soft)}.sheet-check{margin-left:auto;color:var(--accent);font-weight:700}@media(max-width:600px){html,body,.app{overflow-x:hidden;max-width:100%}.topbar{padding:8px 12px;gap:8px}.topbar-nav{display:none}.content{padding:14px 12px calc(86px + env(safe-area-inset-bottom))}input,select,textarea,.quick-add,.note-title-input{font-size:16px}.status-select,.btn,.btn-icon,.card-status-chip,.seg-views .seg-btn{min-height:44px}.dash-kpis{display:grid;grid-template-columns:1fr 1fr;gap:10px}.kpi-card{min-width:0}.kpi-overdue{order:-1;grid-column:1 / -1}.dash-projects,.dash-lists{grid-template-columns:1fr}.card-status-chip{display:inline-flex}.board-wrap{height:auto}.board{overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.board-col{width:84vw;scroll-snap-align:start}.tasks-toolbar{gap:10px}.seg-views{width:100%}.project-filter{flex:1;min-width:0}.field-row{flex-direction:column;gap:0}.modal-overlay{align-items:flex-end;padding:0}.modal,.modal-sm,.modal-note{width:100%;max-width:none;margin:0;border-radius:18px 18px 0 0;max-height:92vh;overflow-y:auto}.welcome-card{padding:18px 16px}.welcome-title{font-size:19px}.gantt-tray-hint{margin-left:0;width:100%}.toast{bottom:calc(150px + env(safe-area-inset-bottom))}}
