@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&display=swap";:root{color-scheme:light;--tg-bg: #f6f7fb;--tg-surface: #ffffff;--tg-surface-2: #f1f4f9;--tg-stroke: #e2e7ef;--tg-text: #1c1f24;--tg-muted: #7b8499;--tg-accent: #2aabee;--tg-accent-text: #ffffff;--tg-danger: #e04b4b;--tg-success: #2f8f5b;--radius-lg: 16px;--radius-md: 12px;--radius-sm: 10px;--shadow-soft: 0 8px 24px rgba(20, 28, 46, .08);--shadow-strong: 0 16px 40px rgba(20, 28, 46, .14);--tg-safe-top: 0px;--tg-safe-bottom: 0px;--font-base: 15px;--font-sm: 13px;--font-xs: 12px;--font-md: 16px;--font-lg: 18px;--font-xl: 20px;--tg-mobile-top-extra: 0px}*{box-sizing:border-box}html,body,#app{height:100%;min-height:var(--tg-viewport-height, 100vh);overscroll-behavior:none;touch-action:pan-x pan-y}body{margin:0;font-family:Manrope,sans-serif;background:radial-gradient(circle at top right,rgba(42,171,238,.08),transparent 45%),var(--tg-bg);color:var(--tg-text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-size:var(--font-base);padding-top:0;overscroll-behavior:none;touch-action:pan-x pan-y;-webkit-text-size-adjust:100%}a{color:var(--tg-accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{font-weight:600}audio{width:100%}.hidden{display:none}.app-shell{min-height:var(--tg-viewport-height, 100vh);display:flex;flex-direction:column;padding-top:calc(var(--tg-safe-top, 0px) + var(--tg-mobile-top-extra, 0px));overscroll-behavior:none}.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:#fffc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--tg-stroke);position:sticky;top:0;z-index:10}.brand{font-weight:700;font-size:var(--font-lg);letter-spacing:.2px}.user{display:flex;align-items:center;gap:10px;font-size:var(--font-sm);color:var(--tg-muted)}main{flex:1;padding:8px 16px 28px;padding-bottom:calc(28px + var(--tg-safe-bottom, env(safe-area-inset-bottom)));overscroll-behavior:contain}.page{display:flex;flex-direction:column;gap:18px}.page.has-bottom-cta{padding-bottom:96px}.page-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:6px}.page-header h1{margin:0;font-size:var(--font-xl);font-weight:700}.page-header p{margin:6px 0 0;color:var(--tg-muted);font-size:var(--font-sm)}.header-actions{display:flex;gap:8px;flex-wrap:wrap}.primary{background:var(--tg-accent);color:var(--tg-accent-text);border:none;border-radius:var(--radius-sm);padding:8px 14px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 6px 16px #2aabee47;min-height:40px;font-size:var(--font-base)}.primary:hover{transform:translateY(-1px)}.ghost{background:var(--tg-surface-2);border:1px solid var(--tg-stroke);border-radius:var(--radius-sm);padding:8px 12px;font-weight:500;cursor:pointer;color:var(--tg-text);min-height:40px}.ghost.small{padding:6px 10px;font-size:var(--font-xs);min-height:30px}.ghost.danger{border-color:#e04b4b80;color:var(--tg-danger);background:#e04b4b14}.input{width:100%;border:1px solid var(--tg-stroke);border-radius:var(--radius-sm);padding:10px 12px;font-family:inherit;background:var(--tg-surface);font-size:var(--font-base)}.input.tall{min-height:44px;padding:12px}.input:focus{outline:2px solid rgba(42,171,238,.2);border-color:#2aabee80}textarea.input{resize:vertical}.form-grid{display:grid;gap:12px}.form-grid label{display:flex;flex-direction:column;gap:6px;font-size:var(--font-sm);color:var(--tg-muted)}.checkbox{display:flex;align-items:center;gap:8px;font-size:var(--font-sm);color:var(--tg-muted)}.project-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.project-card{background:var(--tg-surface);border:1px solid var(--tg-stroke);border-radius:var(--radius-lg);padding:16px;text-align:left;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:6px}.project-card h3{margin:0;font-size:var(--font-lg);overflow-wrap:anywhere;word-break:break-word}.project-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-strong)}.project-stats{display:flex;gap:12px;font-size:var(--font-sm);color:var(--tg-muted)}.bottom-cta{position:fixed;left:16px;right:16px;bottom:calc(12px + var(--tg-safe-bottom, env(safe-area-inset-bottom)));z-index:20}.bottom-cta .primary{width:100%;padding:14px 16px;font-size:var(--font-md);border-radius:14px}.filters{display:flex;flex-direction:column;gap:10px;background:var(--tg-surface);padding:12px;border-radius:var(--radius-lg);border:1px solid var(--tg-stroke);box-shadow:var(--shadow-soft)}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.filter-bar .input{flex:1}.filters-panel{display:flex;flex-direction:column;gap:12px;padding:12px;background:var(--tg-surface-2);border:1px solid var(--tg-stroke);border-radius:14px}.filter-group{display:flex;flex-wrap:wrap;gap:10px 16px}.filter-row{display:flex;flex-direction:column;gap:6px}.filter-label{font-size:var(--font-sm);color:var(--tg-muted)}.date-range{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.range-field{display:flex;align-items:center;gap:6px;background:var(--tg-surface);border:1px solid var(--tg-stroke);border-radius:12px;padding:8px 10px}.range-field span{font-size:var(--font-xs);color:var(--tg-muted);min-width:14px}.range-field .input{border:none;padding:4px 0;background:transparent}.range-field .input:focus{outline:none}.filter-actions{display:flex;justify-content:flex-end}.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.kanban-column{flex:0 0 min(320px,84vw);background:var(--tg-surface);border-radius:var(--radius-lg);border:1px solid var(--tg-stroke);padding:12px;box-shadow:var(--shadow-soft);scroll-snap-align:start;display:flex;flex-direction:column;gap:12px;transition:max-height .2s ease,opacity .2s ease;min-width:0}.kanban-column header{display:flex;justify-content:space-between;align-items:center;gap:8px}.column-title{display:flex;align-items:center;gap:8px}.column-title h3{margin:0;font-size:15px}.column-title .count{font-size:12px;color:var(--tg-muted);background:var(--tg-surface-2);padding:2px 8px;border-radius:999px}.kanban-list{display:flex;flex-direction:column;gap:12px}.kanban-column.collapsed{max-height:120px;overflow:hidden}.collapsed-hint{color:var(--tg-muted);font-size:12px}.task-card{background:var(--tg-surface);border-radius:var(--radius-md);padding:14px;border:1px solid var(--tg-stroke);cursor:pointer;display:flex;flex-direction:column;gap:10px;box-shadow:0 8px 18px #141c2e0f;transition:transform .15s ease,box-shadow .15s ease;min-width:0}.task-card:hover{transform:translateY(-1px);box-shadow:0 12px 22px #141c2e1a}.task-card.overdue{border-color:#e04b4b80;box-shadow:0 0 #e04b4b4d;animation:pulse 1.6s infinite}.task-card.important{border-color:#ff8c0073;box-shadow:0 8px 20px #ff8c0033;position:relative}.task-card.important:after{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:inherit;box-shadow:0 0 18px #ff8c0059;opacity:.6;pointer-events:none;animation:flicker 1.6s infinite}.task-header{display:flex;justify-content:space-between;gap:8px;align-items:center}.task-header h4{margin:0;font-size:var(--font-md);font-weight:600}.task-title{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.task-number{font-size:var(--font-xs);font-weight:700;color:var(--tg-accent);background:#2aabee1f;padding:2px 6px;border-radius:999px}.flame-icon{font-size:14px;animation:flicker 1.6s infinite}.task-name{font-size:var(--font-md);overflow-wrap:anywhere;word-break:break-word}.status-badge{font-size:var(--font-xs);padding:4px 8px;border-radius:999px;background:var(--tg-surface-2);color:var(--tg-muted)}.status-badge.done{background:#2f8f5b1f;color:var(--tg-success)}.status-badge.waiting_review{background:#2aabee1f;color:var(--tg-accent)}.status-badge.needs_work{background:#e04b4b1f;color:var(--tg-danger)}.task-desc{margin:0;color:var(--tg-muted);font-size:var(--font-sm);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-width:100%;overflow-wrap:anywhere;word-break:break-word}.task-info{display:flex;flex-direction:column;gap:4px}.info-block{display:flex;flex-direction:column;gap:2px}.task-meta .label{font-size:var(--font-xs)}.task-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.task-actions button:disabled{opacity:.6;cursor:not-allowed}.assignee-row{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.assignee{display:flex;align-items:center;gap:6px}.assignee .avatar{width:24px;height:24px}.assignee-name{font-size:var(--font-sm);color:var(--tg-muted)}.overdue-label{font-size:var(--font-xs);color:var(--tg-danger);margin-top:2px}.overdue-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:#e04b4b1a;color:var(--tg-danger);font-size:var(--font-xs);width:fit-content}.avatar{width:34px;height:34px;border-radius:50%;background:var(--tg-surface-2);display:grid;place-items:center;font-weight:600;overflow:hidden;border:1px solid var(--tg-stroke);color:var(--tg-muted)}.avatar img{width:100%;height:100%;object-fit:cover}.detail-card{background:var(--tg-surface);padding:14px;border-radius:var(--radius-lg);border:1px solid var(--tg-stroke);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:12px;overflow-wrap:anywhere;word-break:break-word}.attachment-actions{display:flex;gap:8px;align-items:center}.detail-card h3{margin:0;font-size:var(--font-lg)}.task-detail{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.meta-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.meta-person{display:flex;align-items:center;gap:10px}.meta-person .avatar{width:32px;height:32px}.detail-list{display:flex;flex-direction:column;gap:12px;border-top:1px solid var(--tg-stroke);padding-top:12px}.detail-row{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:center;padding:4px 0}.detail-label{font-size:var(--font-sm);color:var(--tg-muted)}.detail-value{display:flex;align-items:center;gap:8px;font-size:var(--font-sm)}.detail-value .avatar{width:28px;height:28px}.detail-value.column{flex-direction:column;align-items:flex-start;gap:4px}.label{display:block;font-size:var(--font-xs);color:var(--tg-muted)}.value{font-weight:600;font-size:var(--font-md)}.hint{color:var(--tg-muted);font-size:var(--font-xs)}.comment-composer{display:flex;flex-direction:column;gap:10px;background:var(--tg-surface);padding:12px;border-radius:var(--radius-lg);border:1px solid var(--tg-stroke)}.composer-actions{display:flex;justify-content:space-between;align-items:center;gap:10px}.composer-left{display:flex;align-items:center;gap:8px}.send-btn{height:40px;padding:0 16px}.comment-list{display:flex;flex-direction:column;gap:12px}.comment-item{display:flex;gap:10px;align-items:flex-start;max-width:88%}.comment-item.mine{align-self:flex-end;flex-direction:row-reverse}.comment-item.mine .comment-avatar{display:none}.comment-avatar{flex:0 0 auto}.comment-bubble{background:var(--tg-surface);border-radius:14px;padding:10px 12px;border:1px solid var(--tg-stroke);display:flex;flex-direction:column;gap:6px;box-shadow:0 6px 14px #141c2e0d}.comment-item.mine .comment-bubble{background:#2aabee1f;border-color:#2aabee33}.comment-header{display:flex;justify-content:space-between;align-items:center;gap:10px}.author-name{font-weight:600;font-size:var(--font-sm)}.meta{font-size:var(--font-xs);color:var(--tg-muted)}.comment-body{line-height:1.45;font-size:var(--font-base);overflow-wrap:anywhere;word-break:break-word}.comment-body a{overflow-wrap:anywhere;word-break:break-word}.reply-preview{font-size:var(--font-xs);color:var(--tg-muted);background:#0000000a;padding:6px 8px;border-radius:10px}.mention-chip{display:inline-flex;align-items:center;padding:2px 6px;border-radius:10px;background:#2aabee2e;color:var(--tg-accent);font-weight:600;font-size:var(--font-xs)}.mention-suggestions{display:flex;flex-direction:column;gap:6px;background:var(--tg-surface);border-radius:12px;padding:8px;border:1px solid var(--tg-stroke);box-shadow:var(--shadow-soft)}.mention-suggestions button{display:flex;align-items:center;gap:8px;border:none;background:transparent;cursor:pointer;padding:6px;border-radius:8px}.mention-suggestions button.active{background:var(--tg-surface-2)}.comment-reactions{display:flex;flex-direction:column;gap:6px}.reaction-row{display:flex;flex-wrap:wrap;gap:6px}.reaction-chip{background:var(--tg-surface-2);border-radius:999px;padding:4px 10px;font-size:var(--font-xs);border:1px solid var(--tg-stroke);display:inline-flex;align-items:center;gap:4px;cursor:pointer}.reaction-chip.active{background:#2aabee26;border-color:#2aabee66;color:var(--tg-accent)}.reaction-chip.add{font-weight:600}.reaction-picker{display:flex;gap:6px;flex-wrap:wrap}.reaction-btn{border:1px solid var(--tg-stroke);background:var(--tg-surface);cursor:pointer;font-size:18px;border-radius:10px;padding:4px 6px}.comment-actions{display:flex;gap:8px;justify-content:flex-end}.comment-files{display:flex;flex-direction:column;gap:8px}.comment-file{display:flex;align-items:center;gap:8px}.comment-file a{font-size:var(--font-xs);overflow-wrap:anywhere;word-break:break-word}.comment-file img{max-width:220px;border-radius:10px;border:1px solid var(--tg-stroke)}.voice-recorder{display:flex;flex-direction:column;gap:6px}.voice-actions{display:flex;gap:8px;flex-wrap:wrap}.icon-action{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;border:1px solid var(--tg-stroke);background:var(--tg-surface-2);cursor:pointer}.icon-action.active{border-color:#ff8c0080;background:#ff8c001f}.icon-action.recording{border-color:#e04b4b80;background:#e04b4b1f}.icon-action.recording svg{stroke:var(--tg-danger)}.icon-action svg{width:20px;height:20px;stroke:var(--tg-muted);fill:none;stroke-width:1.8}.important-toggle{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--tg-muted)}.voice-hint{font-size:var(--font-xs);color:var(--tg-muted)}.voice-error{font-size:var(--font-xs);color:var(--tg-danger)}.record-indicator{display:inline-flex;align-items:center;gap:6px;font-size:var(--font-xs);color:var(--tg-danger)}.record-dot{width:8px;height:8px;border-radius:50%;background:var(--tg-danger);animation:pulse-dot 1.2s infinite}.voice-indicator{font-size:var(--font-xs);color:var(--tg-success)}.attachment-list{display:flex;flex-direction:column;gap:6px;font-size:var(--font-xs);color:var(--tg-muted)}.attachment-item{display:flex;justify-content:space-between;gap:8px;align-items:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#10142159;display:grid;place-items:center;z-index:50;padding:16px}.modal-card{background:var(--tg-surface);padding:18px;border-radius:var(--radius-lg);width:min(520px,100%);max-height:90vh;overflow-y:auto;border:1px solid var(--tg-stroke);box-shadow:var(--shadow-strong)}.modal-card.image-preview{width:min(640px,100%);display:flex;flex-direction:column;gap:12px;align-items:center}.modal-card.image-preview img{max-width:100%;max-height:60vh;border-radius:12px}.preview-actions{display:flex;gap:10px}.settings-section{display:flex;flex-direction:column;gap:10px;padding:12px 0;border-bottom:1px solid var(--tg-stroke)}.settings-section:last-child{border-bottom:none}.settings-row{display:flex;justify-content:space-between;gap:12px;align-items:center}.settings-label{font-size:var(--font-xs);color:var(--tg-muted)}.settings-value{font-size:var(--font-sm);font-weight:600;word-break:break-all}.icon-btn{border:1px solid var(--tg-stroke);background:var(--tg-surface-2);border-radius:10px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;line-height:0}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn svg{width:18px;height:18px;stroke:var(--tg-muted);fill:none;stroke-width:1.6;display:block;stroke-linecap:round;stroke-linejoin:round}.icon-btn.danger{border-color:#e04b4b66;background:#e04b4b14}.icon-btn.danger svg{stroke:var(--tg-danger)}.member-list{display:flex;flex-direction:column;gap:10px}.member-item{display:flex;align-items:center;gap:10px;justify-content:space-between}.member-info{flex:1}.member-name{font-weight:600;font-size:13px}.member-id{font-size:11px;color:var(--tg-muted)}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.modal-body{margin-top:12px}.modal-footer{margin-top:18px;display:flex;justify-content:flex-end;gap:10px}.notice{padding:14px;border-radius:var(--radius-md);background:var(--tg-surface);border:1px solid var(--tg-stroke);box-shadow:var(--shadow-soft)}.notice.danger{border-color:#e04b4b66}.loading{padding:14px;color:var(--tg-muted)}.empty{color:var(--tg-muted);text-align:center}.file-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.file-sections{display:flex;flex-direction:column;gap:12px}.file-section h4{margin:0 0 8px;font-size:var(--font-sm);color:var(--tg-muted);font-weight:600}.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(74px,1fr));gap:8px}.file-thumb{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:10px;border:1px solid var(--tg-stroke);cursor:pointer}.audio-list{display:flex;flex-direction:column;gap:8px}.file-list li{display:flex;justify-content:space-between;gap:8px;font-size:var(--font-sm);align-items:center;flex-wrap:wrap}.file-list a{overflow-wrap:anywhere;word-break:break-word}.file-list img{max-width:220px;border-radius:10px;border:1px solid var(--tg-stroke);cursor:pointer}@media (max-width: 720px){.task-detail{grid-template-columns:1fr}}@media (max-width: 520px){.detail-row{grid-template-columns:1fr;gap:6px;align-items:flex-start}}@keyframes pulse{0%{box-shadow:0 0 #e04b4b4d}70%{box-shadow:0 0 0 10px #e04b4b00}to{box-shadow:0 0 #e04b4b00}}@keyframes flicker{0%,to{opacity:.6;transform:translateY(0)}50%{opacity:1;transform:translateY(-1px)}}@keyframes pulse-dot{0%{transform:scale(.9);opacity:.6}50%{transform:scale(1.2);opacity:1}to{transform:scale(.9);opacity:.6}}@media (max-width: 768px){main{padding:12px 14px 14px;padding-bottom:calc(24px + var(--tg-safe-bottom, env(safe-area-inset-bottom)))}.topbar{padding:12px 14px}.kanban-column{flex:0 0 86vw}.task-detail,.detail-row{grid-template-columns:1fr}}
