:root{interpolate-size:allow-keywords}:root,[data-theme=light]{--bg-primary: #f5f5f7;--bg-secondary: #ffffff;--bg-tertiary: #f0f0f2;--bg-hover: #e5e5ea;--bg-overlay: rgba(0, 0, 0, .4);--text-primary: #1d1d1f;--text-secondary: #6e6e73;--text-tertiary: #aeaeb2;--border-color: #d2d2d7;--border-hover: #c7c7cc;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .12);--shadow-drag: 0 16px 48px rgba(0, 0, 0, .18);--accent: #6d28d9;--accent-hover: #5b21b6;--accent-light: #ede9fe;--accent-glow: rgba(109, 40, 217, .12);--danger: #ef4444;--danger-hover: #dc2626;--priority-low-bg: #dcfce7;--priority-low-text: #166534;--priority-med-bg: #fef3c7;--priority-med-text: #92400e;--priority-high-bg: #fee2e2;--priority-high-text: #991b1b;--tag-bg: #ede9fe;--tag-text: #5b21b6;--column-bg: #f0f0f2;--card-bg: #f7f7f8;--scrollbar-thumb: #c7c7cc;--scrollbar-track: transparent;--bg-dot: rgba(0, 0, 0, .1)}[data-theme=dark]{--bg-primary: #050505;--bg-secondary: #0e0e10;--bg-tertiary: #0e0e10;--bg-hover: #1a1a1e;--bg-overlay: rgba(0, 0, 0, .75);--text-primary: #ececee;--text-secondary: #8e8e93;--text-tertiary: #48484a;--border-color: #1c1c1e;--border-hover: #2c2c2e;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .5);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .6);--shadow-drag: 0 16px 48px rgba(0, 0, 0, .7);--accent: #8b5cf6;--accent-hover: #6d28d9;--accent-light: #1a1233;--accent-glow: rgba(167, 139, 250, .1);--danger: #f87171;--danger-hover: #ef4444;--priority-low-bg: #052e16;--priority-low-text: #6ee7b7;--priority-med-bg: #451a03;--priority-med-text: #fbbf24;--priority-high-bg: #450a0a;--priority-high-text: #fca5a5;--tag-bg: #1e1b4b;--tag-text: #a5b4fc;--column-bg: #0a0a0c;--card-bg: #111113;--scrollbar-thumb: #2c2c2e;--scrollbar-track: transparent;--date-icon-filter: invert(1);--bg-dot: rgba(255, 255, 255, .08)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box;--ease: cubic-bezier(.25, .1, .25, 1);--ease-out: cubic-bezier(.22, .68, 0, 1);transition:background-color .25s var(--ease),border-color .25s var(--ease)}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;accent-color:var(--accent);color-scheme:dark}[data-theme=light]{color-scheme:light}::selection{background:var(--accent);color:#fff}::placeholder{color:var(--text-tertiary);opacity:1;font-size:.85rem;font-weight:400;font-family:inherit;letter-spacing:normal}input,textarea,select,button{color:inherit;font:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input:focus-visible,textarea:focus-visible{outline:none}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background-color .25s var(--ease)}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--scrollbar-track);border-radius:3px}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}::-webkit-scrollbar-corner{background:transparent}.app{position:relative;display:flex;flex-direction:column;height:100vh;overflow:hidden;padding-bottom:16px;box-sizing:border-box}.app:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle,var(--bg-dot) 1px,transparent 1px);background-size:28px 28px;opacity:0;transition:opacity 2s cubic-bezier(.25,.1,.25,1) .5s}body.board-drag-scrolling .app:before{opacity:1}.app>.app-header{position:relative;z-index:100}.app>.board-container{position:relative;z-index:1}.app-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 28px;background:var(--column-bg);border:1px solid var(--border-color);border-radius:14px;margin:12px 16px 0;flex-shrink:0;z-index:10;overflow:visible;transition:background-color .25s var(--ease),border-color .25s var(--ease)}.header-left{display:flex;align-items:center;gap:10px;color:var(--accent)}.header-left h1{font-size:1.2rem;font-weight:700;letter-spacing:-.03em;color:var(--text-primary)}.header-right{display:flex;align-items:center;gap:12px}.header-right .btn-primary.btn-sm{padding:7px 14px}.header-right .btn-sm,.header-right .search-toggle{height:32px;min-height:32px}.theme-toggle{width:36px;height:36px;min-width:36px;min-height:36px;padding:0}.task-count{font-size:.75rem;color:var(--text-secondary);font-weight:500;padding:5px 12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:20px;white-space:nowrap;transition:background-color .25s var(--ease),border-color .25s var(--ease)}.search-popover-anchor{position:relative;z-index:9999}.search-toggle,.theme-toggle{display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color);border-radius:10px;background:var(--card-bg);color:var(--text-secondary);cursor:pointer;position:relative;transition:background-color .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease),transform .15s var(--ease)}.search-toggle{padding:7px 14px;box-sizing:border-box}.theme-toggle{box-sizing:border-box;border:none;background:transparent}.header-right .search-toggle,.header-right .theme-toggle{flex-shrink:0}.header-right .btn-group{height:32px}.header-right .btn-group .btn{height:32px;min-height:32px}.header-columns-wrap,.header-transfer-wrap,.header-analytics-wrap{position:relative;display:flex;align-items:center}.header-columns-wrap .btn{display:inline-flex;align-items:center;gap:6px}.columns-chevron{opacity:.7;transition:transform .2s ease}.columns-chevron.open{transform:rotate(180deg)}.columns-dropdown{position:absolute;top:calc(100% + 6px);right:0;width:max-content;min-width:140px;padding:6px;background:var(--column-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #00000040;z-index:1000;animation:popover-in .15s var(--ease-out)}.header-analytics-wrap .columns-dropdown,.header-transfer-wrap .columns-dropdown{top:calc(100% + 6px);left:0;right:auto}.columns-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;border-radius:6px;background:none;color:var(--text-primary);font-size:.875rem;cursor:pointer;text-align:left;white-space:nowrap;transition:background .15s ease}.columns-dropdown-item:hover{background:var(--bg-hover)}.search-toggle:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent)}.theme-toggle:hover{background:var(--bg-hover);border:none;color:var(--accent)}.search-toggle:active,.theme-toggle:active{transform:scale(.92)}.search-toggle.has-filter{border-color:var(--accent);color:var(--accent)}.search-toggle.has-filter:before{content:"";position:absolute;top:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:var(--accent);border:2px solid var(--card-bg)}.search-popover{position:absolute;top:calc(100% + 8px);left:0;width:280px;padding:12px;background:var(--column-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #00000040;z-index:9999;display:flex;flex-direction:column;gap:10px;animation:popover-in .15s var(--ease-out)}@keyframes popover-in{0%{opacity:0;transform:translateY(-4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes date-picker-popover-in{0%{opacity:0}to{opacity:1}}.search-popover-input-wrap{position:relative}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.search-input{width:100%;padding:7px 32px;font-size:.85rem;font-weight:400;font-family:inherit;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);outline:none;box-sizing:border-box;transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background-color .25s var(--ease)}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.search-clear{position:absolute;right:6px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;background:var(--bg-hover);border-radius:50%;color:var(--text-tertiary);cursor:pointer;transition:all .2s var(--ease)}.search-clear:hover{background:var(--border-color);color:var(--text-primary)}.search-popover-filters{display:flex;gap:4px}.search-popover-result-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:6px;border-top:1px solid var(--border-color);margin-top:2px}.search-popover-task-count{font-size:.72rem;color:var(--text-tertiary);font-weight:500}.search-popover-clear-all{font-size:.72rem;font-weight:600;font-family:inherit;padding:4px 10px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:background-color .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease)}.search-popover-clear-all:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent)}.filter-pill{display:inline-flex;align-items:center;justify-content:center;padding:5px 10px;font-size:.72rem;font-weight:600;font-family:inherit;border:1px solid var(--border-color);border-radius:6px;background:var(--card-bg);color:var(--text-tertiary);cursor:pointer;flex:1;transition:background-color .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease),transform .15s var(--ease)}.filter-pill:hover{border-color:var(--border-hover);color:var(--text-secondary)}.filter-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.filter-pill:active{transform:scale(.95)}.board-container{flex:1;min-height:0;min-width:0;overflow-x:auto;overflow-y:auto;padding:24px 16px}.board-container.board-container-drag-scroll{-webkit-user-select:none;user-select:none}.board{display:flex;gap:16px;align-items:flex-start;width:fit-content;margin:0 auto}.board-column-wrap{flex-shrink:0}.empty-board{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;flex:1;text-align:center;padding:40px}.empty-board-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:20px;background:var(--bg-hover);color:var(--text-tertiary);margin-bottom:8px}.empty-board h2{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.empty-board p{font-size:.88rem;color:var(--text-secondary);max-width:300px;line-height:1.5;margin-bottom:8px}.empty-board .btn{display:flex;align-items:center;gap:6px;padding:10px 22px;font-size:.88rem}.kanban-column{display:flex;flex-direction:column;width:300px;min-width:300px;max-height:100%;background:var(--column-bg);border-radius:14px;border:1px solid var(--border-color);transition:opacity .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease),background-color .25s var(--ease)}.kanban-column.column-dragging{opacity:.4;will-change:transform}.kanban-column.column-overlay{box-shadow:var(--shadow-drag);border-color:var(--accent);min-height:120px;will-change:transform}.kanban-column.column-overlay.column-overlay-collapsed{min-height:0;height:fit-content}.kanban-column.column-overlay .column-header{padding:12px}.column-header{display:flex;align-items:center;justify-content:space-between;padding:12px;flex-shrink:0}.column-header-actions{display:flex;align-items:center;gap:2px}.column-drag-handle{display:flex;align-items:center;justify-content:center;padding:3px;cursor:grab;color:var(--text-tertiary);background:none;border:none;border-radius:4px;transition:color .2s var(--ease),background .2s var(--ease);opacity:.4}.kanban-column:hover .column-drag-handle{opacity:1}.column-drag-handle:hover{color:var(--text-secondary)}.column-drag-handle:active{cursor:grabbing}.column-title-group{display:flex;align-items:center;gap:8px;min-width:0}.column-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.column-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);min-width:0;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2}.column-count{font-size:.7rem;font-weight:600;color:var(--text-tertiary);background:var(--bg-hover);padding:2px 7px;border-radius:8px;min-width:20px;text-align:center;transition:background-color .25s var(--ease)}.column-collapse-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;background:transparent;border-radius:4px;color:var(--text-tertiary);cursor:pointer;transition:transform .2s var(--ease),color .2s var(--ease)}.column-collapse-btn:hover{color:var(--text-secondary)}.column-collapse-btn.collapsed{transform:rotate(-90deg)}.column-body{flex:1 1 auto;min-height:0;overflow:hidden;transition:height .3s var(--ease-out),opacity .25s var(--ease),flex .3s var(--ease-out),min-height .3s var(--ease-out)}.column-body.collapsed{flex:0 0 0px;height:0;min-height:0;opacity:0;pointer-events:none}.column-tasks{overflow-y:auto;overflow-x:hidden;padding:12px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px;min-height:60px}.column-empty{display:flex;align-items:center;justify-content:center;padding:28px 16px;color:var(--text-secondary);font-size:.78rem;font-weight:500;border-radius:10px;background:var(--bg-hover);margin-top:2px;transition:background-color .25s var(--ease)}.task-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;padding:12px 14px;cursor:default;box-shadow:var(--shadow-sm);position:relative;transition:opacity .25s var(--ease),border-color .2s ease,background-color .2s ease,translate .2s cubic-bezier(.22,.68,0,1)}.task-card:after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:var(--shadow-md);opacity:0;transition:opacity .2s var(--ease);pointer-events:none}.task-card:hover{border-color:var(--border-hover);background:var(--bg-hover);translate:0 -2px;z-index:1;box-shadow:0 0 0 1px color-mix(in srgb,var(--border-hover) 55% transparent),var(--shadow-sm)}.task-card:hover:after{opacity:1;box-shadow:0 2px 8px #0000000f}[data-theme=dark] .task-card:hover:after{box-shadow:0 2px 8px #00000038}.board-dragging .task-card:hover{border-color:var(--border-color);background:var(--card-bg);translate:none;box-shadow:var(--shadow-sm)}.board-dragging .task-card:hover:after{opacity:0}.task-card.dragging{border-color:var(--accent);translate:none}.task-card.dragging:after{box-shadow:var(--shadow-drag);opacity:1}.task-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.drag-handle{display:flex;align-items:center;justify-content:center;padding:2px;cursor:grab;color:var(--text-tertiary);background:none;border:none;border-radius:4px;transition:color .2s var(--ease),background .2s var(--ease);opacity:.5}.task-card:hover .drag-handle{opacity:1}.drag-handle:hover{color:var(--text-secondary);background:var(--bg-hover)}.drag-handle:active{cursor:grabbing}.task-card-actions{display:flex;gap:1px;opacity:0;transition:opacity .2s var(--ease)}.task-card:hover .task-card-actions{opacity:1}.task-card-actions .icon-btn:hover{background:var(--card-bg);color:var(--text-primary)}.task-card-actions .icon-btn.danger:hover{background:var(--priority-high-bg);color:var(--danger)}.task-title{font-size:.85rem;font-weight:600;line-height:1.4;color:var(--text-primary);margin-bottom:3px;word-break:break-word;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden}.task-description{font-size:.78rem;line-height:1.5;color:var(--text-secondary);margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;white-space:pre-line}.task-description code{font-family:SF Mono,Fira Code,monospace;font-size:.75rem;background:var(--bg-hover);padding:1px 4px;border-radius:3px;color:var(--accent)}.task-description a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.task-description del{opacity:.5}.task-card-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.task-card-footer{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:8px;transition:gap .2s var(--ease),margin .2s var(--ease)}.task-time{display:flex;align-items:center;gap:4px;font-size:.68rem;font-weight:500;line-height:1.2;color:var(--text-tertiary);margin-left:auto}.priority-badge{display:inline-flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;padding:2px 7px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em;line-height:1.4}.priority-low{background:var(--priority-low-bg);color:var(--priority-low-text)}.priority-medium{background:var(--priority-med-bg);color:var(--priority-med-text)}.priority-high{background:var(--priority-high-bg);color:var(--priority-high-text)}.tag{display:inline-flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:500;padding:2px 7px;border-radius:4px;background:var(--tag-bg);color:var(--tag-text);line-height:1.4}.tag.removable{cursor:pointer;display:flex;align-items:center;gap:3px;font-size:.72rem;padding:3px 9px;background:var(--accent);color:#fff;border-radius:5px;transition:opacity .2s var(--ease)}.tag.removable:hover{opacity:.8}.icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:background .2s var(--ease),color .2s var(--ease)}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.icon-btn:active{transform:scale(.9)}.icon-btn.danger:hover{background:var(--priority-high-bg);color:var(--danger)}.icon-btn.add-btn{color:var(--text-secondary);border:1px solid transparent;border-radius:8px;background:var(--bg-hover);width:28px;height:28px;aspect-ratio:1;transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease)}.icon-btn.add-btn:hover,.icon-btn.add-btn:focus-visible{color:var(--accent);border-color:var(--accent)}.modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:fadeIn .2s var(--ease);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-sizing:border-box}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:24px;width:100%;max-width:660px;min-height:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .25s var(--ease-out)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:1.05rem;font-weight:700;letter-spacing:-.02em}.modal-header-title-group{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.modal-header-subtitle{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.column-modal-section{margin-bottom:16px}.column-modal-section:last-of-type{margin-bottom:0}.column-modal-section-title{font-size:.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.form-group{margin-bottom:14px;position:relative}.form-group label:not(.checkbox-row):not(.attachment-drop-zone){display:block;font-size:.72rem;font-weight:600;color:var(--text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group textarea:not(.subtask-edit-input),.form-group select{width:100%;padding:9px 12px;font-size:.85rem;font-weight:400;font-family:inherit;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background-color .25s var(--ease);outline:none}.form-group input:focus,.form-group textarea:not(.subtask-edit-input):focus,.form-group select:focus{border-color:transparent;background-image:linear-gradient(var(--bg-primary),var(--bg-primary)),linear-gradient(135deg,#d8b4fe,#9333ea,#581c87);background-origin:border-box;background-clip:padding-box,border-box;box-shadow:0 0 8px #7c3aed4d}.form-group.has-error input,.form-group.has-error textarea{border-color:var(--danger);box-shadow:0 0 0 1px var(--danger)}.form-group.has-error input:focus,.form-group.has-error textarea:focus{background-image:none;border-color:var(--danger);box-shadow:0 0 8px #ef444440}.field-error{display:block;font-size:.74rem;font-weight:500;color:var(--danger);margin-top:5px}.field-hint{display:block;font-size:.72rem;color:var(--text-tertiary);margin-top:4px}.checkbox-row{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--text-primary);margin-bottom:0;line-height:1.2}.checkbox-row input[type=checkbox]{width:16px;height:16px;margin:0;flex-shrink:0;accent-color:var(--accent);cursor:pointer;vertical-align:middle}.form-group textarea:not(.subtask-edit-input){field-sizing:content;resize:none;line-height:1.5;min-height:calc(4.5em + 22px);max-height:calc(9em + 22px);overflow-y:auto}.form-group input[type=date]{appearance:none;-webkit-appearance:none;position:relative;cursor:pointer}.form-group input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;border-radius:4px;padding:4px;opacity:.5;filter:var(--date-icon-filter, none);transition:opacity .2s var(--ease);color-scheme:light}.form-group input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.form-group input[type=date]::-webkit-datetime-edit{color:var(--text-primary)}.form-group input[type=date]::-webkit-datetime-edit-fields-wrapper{padding:0}.form-group input[type=date]::-webkit-datetime-edit-text,.form-group input[type=date]::-webkit-datetime-edit-month-field,.form-group input[type=date]::-webkit-datetime-edit-day-field,.form-group input[type=date]::-webkit-datetime-edit-year-field{color:var(--text-primary);padding:0 2px}.date-picker-wrap{position:relative;width:100%}.date-picker-wrap label{display:block;font-size:.72rem;font-weight:600;color:var(--text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}.date-picker-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;font-size:.85rem;font-weight:400;font-family:inherit;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;text-align:left;transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background-color .25s var(--ease);outline:none}.date-picker-trigger:hover{border-color:var(--border-hover);background:var(--bg-hover)}.date-picker-trigger[aria-expanded=true]{border-color:transparent;background-image:linear-gradient(var(--bg-primary),var(--bg-primary)),linear-gradient(135deg,#d8b4fe,#9333ea,#581c87);background-origin:border-box;background-clip:padding-box,border-box;box-shadow:0 0 8px #7c3aed4d}.date-picker-icon{color:var(--text-tertiary);flex-shrink:0}.date-picker-value{flex:1;min-width:0}.date-picker-value.placeholder{color:var(--text-tertiary);opacity:1;font-size:.85rem;font-weight:400;font-family:inherit;letter-spacing:normal}.date-picker-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:1000;min-width:260px;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #00000040;animation:popover-in .15s var(--ease-out)}.date-picker-popover-fixed{position:fixed;right:auto;width:min-content;animation:date-picker-popover-in .15s var(--ease-out)}.date-picker-popover-above{transform:translateY(-100%)}.date-picker-popover-title{font-size:.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.date-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.date-picker-month-label{font-size:.9rem;font-weight:600;color:var(--text-primary)}.date-picker-nav{display:flex;gap:2px}.date-picker-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s ease,color .15s ease}.date-picker-nav-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.date-picker-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:6px}.date-picker-weekday{font-size:.68rem;font-weight:600;color:var(--text-tertiary);text-align:center;padding:4px 0}.date-picker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.date-picker-day{display:flex;align-items:center;justify-content:center;width:32px;height:32px;margin:0 auto;border:none;border-radius:8px;background:transparent;color:var(--text-primary);font-size:.82rem;font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease}.date-picker-day:hover{background:var(--bg-hover)}.date-picker-day.other-month{color:var(--text-tertiary)}.date-picker-day.today{background:var(--accent-light);color:var(--accent);font-weight:600}.date-picker-day.today:hover{background:var(--accent-light);color:var(--accent)}.date-picker-day.selected,.date-picker-day.selected:hover{background:var(--accent);color:#fff}.date-picker-footer{display:flex;justify-content:space-between;gap:8px;margin-top:12px;padding-top:10px;border-top:1px solid var(--border-color)}.date-picker-footer-btn{font-size:.8rem;font-weight:600;font-family:inherit;padding:6px 12px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s ease,color .15s ease}.date-picker-footer-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.date-picker-footer-btn.primary{background:var(--accent);color:#fff}.date-picker-footer-btn.primary:hover{background:var(--accent);color:#fff;opacity:.9}.form-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}.form-row .form-group{min-width:0}.tag-input-row{display:flex;gap:8px}.tag-input-row input{flex:1}.tags-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.advanced-toggle{display:flex;align-items:center;gap:6px;padding:10px 0 8px;margin-top:4px;border:none;border-radius:10px;outline-offset:2px;font-size:.78rem;font-weight:600;font-family:inherit;color:var(--text-tertiary);background:none;width:100%;cursor:pointer;transition:color .2s var(--ease)}.advanced-toggle:hover,.advanced-toggle.open{color:var(--text-secondary)}.advanced-chevron{transition:transform .2s var(--ease)}.advanced-chevron.rotated{transform:rotate(180deg)}.advanced-section{height:0;overflow:hidden;opacity:0;transition:height .3s var(--ease-out),opacity .25s var(--ease)}.advanced-section.open{height:auto;overflow:visible;opacity:1;margin-top:12px}.advanced-section-inner{padding-top:4px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:9px 18px;font-size:.82rem;font-weight:600;font-family:inherit;border:none;border-radius:8px;cursor:pointer;transition:background .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease),opacity .2s var(--ease),border-color .2s var(--ease),transform .2s var(--ease)}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 2px #0003}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0) scale(.97)}.btn-secondary{background:var(--card-bg);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent)}.btn-secondary:active{transform:translateY(0) scale(.97)}.btn-group{display:flex}.btn-group .btn{border-radius:0}.btn-group .btn+.btn{margin-left:-1px}.btn-group .btn:hover{z-index:1}.btn-group .btn:first-child{border-radius:8px 0 0 8px}.btn-group .btn:last-child{border-radius:0 8px 8px 0}.btn-sm{padding:7px 14px;font-size:.78rem;display:flex;align-items:center;gap:5px;border-radius:8px;white-space:nowrap}.color-picker{display:flex;flex-wrap:wrap;gap:8px}.color-swatch{width:28px;height:28px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:border-color .2s var(--ease),transform .2s var(--ease-out)}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--text-tertiary)}.custom-color-swatch{display:flex;align-items:center;justify-content:center;color:#ffffffd9;position:relative;cursor:pointer}.custom-color-swatch svg{fill:var(--bg-secondary)}.color-input-hidden{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;padding:0}.color-picker-wrap{position:relative}.color-picker-wrap label{display:block;font-size:.72rem;font-weight:600;color:var(--text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}.color-picker-trigger{display:flex;align-items:center;justify-content:center;width:44px;height:40px;padding:0;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-primary);cursor:pointer;transition:border-color .2s var(--ease),box-shadow .2s var(--ease);outline:none}.color-picker-trigger:hover{border-color:var(--border-hover)}.color-picker-trigger[aria-expanded=true]{border-color:var(--accent);box-shadow:0 0 8px #7c3aed4d}.color-picker-trigger-swatch{display:block;width:24px;height:24px;border-radius:6px;box-shadow:0 0 0 1px #00000026}.color-picker-popover{position:absolute;z-index:1000;min-width:220px;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #00000040;animation:date-picker-popover-in .15s var(--ease-out)}.color-picker-popover-fixed{position:fixed;right:auto;width:min-content}.color-picker-popover-above{transform:translateY(-100%)}.color-picker-popover-title{font-size:.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.color-picker-presets{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-bottom:12px}.color-picker-preset-swatch{width:28px;height:28px;margin:0 auto;padding:0;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:border-color .2s var(--ease),transform .2s var(--ease-out);display:block}.color-picker-preset-swatch:hover{transform:scale(1.08)}.color-picker-preset-swatch.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-secondary)}.color-picker-preset-custom{width:28px;height:28px;margin:0 auto;padding:0;border-radius:8px;border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease,border-color .15s ease,transform .2s var(--ease-out)}.color-picker-preset-custom:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover);transform:scale(1.08)}.color-picker-modal-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.color-picker-modal-swatch,.color-picker-modal-custom{width:28px;height:28px;min-width:28px;min-height:28px;margin:0;padding:0;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:border-color .2s var(--ease),transform .2s var(--ease-out),box-shadow .2s var(--ease);display:flex;align-items:center;justify-content:center;box-sizing:border-box;flex-shrink:0}.color-picker-modal-swatch{background-color:var(--bg-primary)}.color-picker-modal-swatch:hover,.color-picker-modal-custom:hover{transform:scale(1.08)}.color-picker-modal-swatch.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-primary)}.color-picker-modal-custom{border:2px solid var(--border-color);box-shadow:var(--custom-picker-shadow, 0 2px 10px rgba(0, 0, 0, .25))}.color-picker-modal-custom:hover{border-color:var(--border-hover);box-shadow:var(--custom-picker-shadow-hover, 0 2px 14px rgba(0, 0, 0, .35))}.color-picker-modal-custom-icon{color:#fffffff2;filter:drop-shadow(0 0 1px rgba(0,0,0,.9)) drop-shadow(0 1px 1px rgba(0,0,0,.5))}.color-picker-sl-box{position:relative;width:200px;height:140px;border-radius:8px;cursor:crosshair;overflow:hidden;margin-bottom:10px;border:1px solid var(--border-color);user-select:none;-webkit-user-select:none}.color-picker-sl-handle{position:absolute;width:16px;height:16px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px #0006;pointer-events:none;top:0}.color-picker-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}.color-picker-eyedropper-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.color-picker-eyedropper-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.color-picker-preview-swatch{width:28px;height:28px;border-radius:8px;flex-shrink:0;border:1px solid var(--border-color);box-shadow:inset 0 0 0 1px #0000001a}.color-picker-hue-bar{position:relative;flex:1;height:12px;border-radius:6px;cursor:pointer;overflow:hidden;border:1px solid var(--border-color);user-select:none;-webkit-user-select:none}.color-picker-hue-handle{position:absolute;top:0;bottom:0;width:14px;margin-left:-7px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px #0000004d;pointer-events:none}.color-picker-rgb-row{display:flex;gap:8px;padding-top:8px;border-top:1px solid var(--border-color)}.color-picker-rgb-field{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.color-picker-rgb-input{width:100%;padding:9px 8px;font-size:.85rem;font-weight:400;font-family:inherit;text-align:center;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary)}.color-picker-rgb-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #7c3aed33}.color-picker-rgb-label{font-size:.65rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase}.modal.modal-sm{max-width:420px;min-height:auto}.modal.modal-presets{max-width:480px;min-height:auto}.presets-hint{font-size:.84rem;color:var(--text-secondary);margin-bottom:16px;line-height:1.4}.presets-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}.preset-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .2s var(--ease);font-family:inherit;font-size:.84rem;font-weight:500;text-align:left}.preset-card:hover{border-color:var(--border-hover);background:var(--bg-hover)}.preset-card.selected{border-color:var(--accent);background:var(--accent-light);outline:2px solid var(--accent);outline-offset:-2px}.preset-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.preset-label{flex:1}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.header-settings-wrap{position:relative}.settings-popup{position:absolute;top:calc(100% + 6px);right:0;min-width:260px;padding:12px;background:var(--column-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #00000040;z-index:1000;display:flex;flex-direction:column;gap:10px;animation:popover-in .15s var(--ease-out)}.settings-popup-title{font-size:.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;padding-bottom:4px;border-bottom:1px solid var(--border-color)}.settings-popup-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.settings-popup-label{font-size:.84rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.settings-lang-group{display:flex;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;width:120px;flex-shrink:0}.settings-lang-btn{flex:1;min-width:0;padding:5px 8px;font-size:.75rem;font-weight:600;font-family:inherit;border:none;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:background .15s ease,color .15s ease}.settings-lang-btn+.settings-lang-btn{border-left:1px solid var(--border-color)}.settings-lang-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-lang-btn.active{background:var(--accent);color:#fff}.no-animations,.no-animations *,.no-animations *:before,.no-animations *:after{animation-duration:0s!important;animation-delay:0s!important;transition-duration:0s!important;transition-delay:0s!important}.empty-board-actions{display:flex;gap:10px}.empty-board-actions .btn{display:flex;align-items:center;gap:6px}.modal.modal-confirm{max-width:380px;min-height:auto;text-align:center;padding:32px 28px 24px}.confirm-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:var(--priority-high-bg);color:var(--danger);margin-bottom:16px}.confirm-title{font-size:1.05rem;font-weight:700;margin-bottom:8px}.confirm-message{font-size:.85rem;color:var(--text-secondary);line-height:1.5;margin-bottom:24px}.confirm-actions{display:flex;gap:10px;justify-content:center}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 1px 2px #0003}.btn-danger:hover{background:var(--danger-hover);box-shadow:0 4px 16px #ef444440;transform:translateY(-1px)}.file-input-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;padding:0;margin:-1px}label.attachment-drop-zone{display:flex;justify-content:start;align-items:center;gap:8px;width:100%;padding:18px 14px;border:2px dashed var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-tertiary);opacity:1;font-size:.85rem;font-weight:400;font-family:inherit;letter-spacing:normal;text-transform:none;cursor:pointer;transition:all .2s var(--ease);margin-bottom:0}label.attachment-drop-zone:hover,label.attachment-drop-zone.drag-over{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}label.attachment-drop-zone.drag-over{border-style:solid;box-shadow:0 0 0 1px var(--accent),0 0 12px var(--accent-glow)}.attachment-list{display:flex;flex-direction:column;gap:4px;margin-top:8px}.attachment-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:8px;background:var(--bg-primary);border:1px solid var(--border-color);font-size:.8rem;transition:background .2s var(--ease)}.attachment-item:hover{background:var(--bg-hover)}.attachment-item.pending{border-style:dashed;opacity:.75}.attachment-icon{color:var(--accent);flex-shrink:0}.attachment-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary);font-weight:500}.attachment-size{font-size:.7rem;color:var(--text-tertiary);flex-shrink:0}.task-attachment-count{display:flex;align-items:center;gap:4px;font-size:.68rem;font-weight:500;line-height:1.2;color:var(--text-tertiary)}.task-due-badge{display:flex;align-items:center;gap:4px;font-size:.68rem;font-weight:600;line-height:1.2;padding:2px 6px;border-radius:4px}.task-due-badge.upcoming{background:var(--priority-low-bg);color:var(--priority-low-text)}.task-due-badge.soon{background:var(--priority-med-bg);color:var(--priority-med-text)}.task-due-badge.overdue{background:var(--priority-high-bg);color:var(--priority-high-text)}.task-estimate{display:flex;align-items:center;gap:4px;font-size:.68rem;font-weight:600;line-height:1.2;padding:2px 6px;border-radius:4px;background:var(--tag-bg);color:var(--tag-text)}.task-subtask-count{display:flex;align-items:center;gap:4px;font-size:.68rem;font-weight:500;line-height:1.2;color:var(--text-tertiary)}.task-subtask-count.all-done{color:var(--priority-low-text)}.subtask-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}.subtask-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;background:var(--bg-primary);border:1px solid var(--border-color);font-size:.84rem;touch-action:none;transition:transform .2s cubic-bezier(.22,.68,0,1),border-color .2s ease,box-shadow .2s ease,opacity .2s ease,background-color .2s ease}.subtask-item:hover{border-color:color-mix(in srgb,var(--accent) 30%,var(--border-color))}.subtask-item.dragging{box-shadow:var(--shadow-drag);border-color:var(--accent);background:var(--bg-secondary);z-index:10;will-change:transform}.subtask-drag-handle{display:flex;align-items:center;justify-content:center;cursor:grab;color:var(--text-tertiary);background:none;border:none;padding:2px;flex-shrink:0;border-radius:4px;transition:color .2s var(--ease),background .2s var(--ease)}.subtask-drag-handle:hover{color:var(--text-primary);background:color-mix(in srgb,var(--text-tertiary) 10%,transparent)}.subtask-drag-handle:active{cursor:grabbing}.subtask-item.done .subtask-title{text-decoration:line-through;opacity:.45}.subtask-check{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:6px;border:2px solid var(--border-color);background:transparent;cursor:pointer;flex-shrink:0;color:transparent;transition:background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease)}.subtask-check:hover{border-color:var(--accent)}.subtask-check.checked{background:var(--accent);border-color:var(--accent);color:#fff}.subtask-title{flex:1;min-width:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-break:break-word;color:var(--text-primary)}.subtask-title-wrap{flex:1;min-width:0;display:flex}.subtask-item .subtask-title-tooltip{display:block!important;min-width:0;width:100%}.subtask-edit-input{flex:1;min-width:0;background:var(--bg-secondary);border:2px solid var(--accent);border-radius:8px;padding:6px 10px;font-size:.85rem;font-weight:400;font-family:inherit;color:var(--text-primary);outline:none;box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 25%,transparent)}.subtask-actions{display:flex;align-items:center;gap:2px;flex-shrink:0;opacity:0;transition:opacity .2s var(--ease)}.subtask-item:hover .subtask-actions,.subtask-item:has(.subtask-edit-input:focus) .subtask-actions{opacity:1}.subtask-action-btn{padding:4px;border-radius:5px;color:var(--text-tertiary);transition:color .2s var(--ease),background .2s var(--ease)}.subtask-action-btn:hover{color:var(--text-primary);background:color-mix(in srgb,var(--text-tertiary) 12%,transparent)}.subtask-action-btn.danger:hover{color:var(--priority-high-text);background:color-mix(in srgb,var(--priority-high-text) 12%,transparent)}.modal.modal-analytics{max-width:720px;width:100%;min-height:auto;max-height:90vh;overflow-x:hidden;overflow-y:auto;min-width:0}.modal.modal-analytics-advanced{max-width:860px}.analytics-stats-6{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))!important}.analytics-content{display:flex;flex-direction:column;gap:20px;min-width:0;overflow-wrap:break-word}.analytics-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.stat-card{display:flex;align-items:center;gap:10px;padding:14px 12px;border-radius:10px;background:var(--bg-primary);border:1px solid var(--border-color);min-width:0;transition:transform .2s var(--ease-out),box-shadow .2s var(--ease)}.stat-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.stat-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:9px;flex-shrink:0}.stat-info{display:flex;flex-direction:column;gap:2px;min-width:0}.stat-value{font-size:1.15rem;font-weight:700;line-height:1.2;color:var(--text-primary)}.stat-label{font-size:.68rem;font-weight:500;color:var(--text-tertiary);white-space:normal;word-break:break-word;line-height:1.2}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));gap:12px;min-width:0}.analytics-card{display:flex;flex-direction:column;padding:16px;border-radius:10px;background:var(--bg-primary);border:1px solid var(--border-color);min-width:0;overflow:hidden}.analytics-card-wide{grid-column:1 / -1}.analytics-card-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:14px}.analytics-card-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}.analytics-card-header-row .analytics-card-title{margin-bottom:0}.analytics-view-toggle{display:flex;gap:4px}.analytics-toggle-btn{padding:6px 12px;font-size:.75rem;font-weight:600;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.analytics-toggle-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.analytics-toggle-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.tag-details-stats{display:flex;flex-direction:column;gap:10px}.tag-detail-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.tag-detail-label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.tag-detail-value{font-size:.95rem;font-weight:700;color:var(--text-primary)}.analytics-empty{font-size:.82rem;color:var(--text-tertiary);text-align:center;padding:20px 0}.bar-chart{display:flex;flex-direction:column;gap:8px;min-width:0}.bar-row{display:flex;align-items:center;gap:10px;min-width:0}.bar-label{font-size:.76rem;font-weight:500;color:var(--text-secondary);width:80px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-track{flex:1;min-width:0;height:8px;background:var(--bg-hover);border-radius:4px;overflow:hidden}.bar-fill{height:100%;border-radius:4px;min-width:4px;transition:width .4s var(--ease-out)}.bar-value{font-size:.72rem;font-weight:700;color:var(--text-primary);width:24px;text-align:right;flex-shrink:0}.donut-chart-wrap{display:flex;align-items:center;justify-content:center;gap:20px}.donut-chart{width:110px;height:110px;flex-shrink:0}.donut-center-value{font-size:18px;font-weight:700;fill:var(--text-primary)}.donut-center-label{font-size:.8rem;font-weight:500;fill:var(--text-tertiary)}.donut-legend{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.8rem}.legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.legend-label{flex:1;color:var(--text-secondary);font-weight:500}.legend-count{font-weight:700;color:var(--text-primary)}.stacked-bar-wrap{display:flex;flex-direction:column;gap:12px}.stacked-bar{display:flex;height:18px;border-radius:9px;overflow:hidden;background:var(--bg-hover)}.stacked-bar-segment{height:100%;min-width:3px;transition:width .4s var(--ease-out)}.stacked-bar-legend{display:flex;flex-wrap:wrap;gap:10px 18px}.stacked-bar-legend-item{display:flex;align-items:center;gap:6px;font-size:.78rem}.stacked-bar-legend-dot{width:9px;height:9px;border-radius:3px;flex-shrink:0}.stacked-bar-legend-label{color:var(--text-secondary);font-weight:500}.stacked-bar-legend-count{font-weight:700;color:var(--text-primary)}.gauge-wrap{display:flex;flex-direction:column;align-items:center;gap:4px}.gauge-svg{width:160px;height:90px}.gauge-bg{fill:none;stroke:var(--bg-hover);stroke-width:14;stroke-linecap:round}.gauge-fill{fill:none;stroke-width:14;stroke-linecap:round;transition:stroke-dashoffset .6s var(--ease-out)}.gauge-value-text{font-size:26px;font-weight:700;fill:var(--text-primary);text-anchor:middle}.gauge-label-text{font-size:10px;font-weight:500;fill:var(--text-tertiary);text-anchor:middle}.composition-chart{display:flex;flex:1;flex-direction:column;justify-content:center;gap:10px}.composition-row{display:flex;align-items:center;gap:10px}.composition-label{font-size:.74rem;font-weight:500;color:var(--text-secondary);width:80px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.composition-track{flex:1;height:8px;background:var(--bg-hover);border-radius:4px;overflow:hidden;min-width:0}.composition-fill{height:100%;border-radius:4px;min-width:3px;background:var(--accent);transition:width .4s var(--ease-out)}.composition-value{font-size:.72rem;font-weight:700;color:var(--text-primary);width:32px;text-align:right;flex-shrink:0}.timeline-chart{display:flex;flex-direction:column;gap:6px;min-width:0}.timeline-svg{width:100%;height:80px;min-width:0}.timeline-labels{display:flex;justify-content:space-around;flex-wrap:wrap;gap:4px}.timeline-label{font-size:.62rem;color:var(--text-tertiary);font-weight:500}.age-chart{display:flex;align-items:flex-end;gap:6px;height:120px;padding-top:8px;min-width:0}.age-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.age-bar-value{font-size:.68rem;font-weight:700;color:var(--text-primary);line-height:1}.age-bar-track{flex:1;width:100%;max-width:28px;background:var(--bg-hover);border-radius:4px;display:flex;align-items:flex-end;overflow:hidden}.age-bar-fill{width:100%;border-radius:4px;background:var(--accent);min-height:3px;transition:height .4s var(--ease-out)}.age-bar-fill-alt{background:#3b82f6}.age-bar-label{font-size:.62rem;font-weight:600;color:var(--text-tertiary);white-space:nowrap}@media(max-width:768px){.analytics-stats,.analytics-stats-6{grid-template-columns:repeat(2,1fr)!important}.analytics-grid{grid-template-columns:1fr}.modal.modal-analytics{max-width:100%}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.custom-select{position:relative}.custom-select-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:9px 12px;font-size:.85rem;font-weight:400;font-family:inherit;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background-color .25s var(--ease);outline:none;text-align:left}.custom-select-trigger>span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:10px}.custom-select-trigger:hover{border-color:var(--border-hover)}.custom-select-trigger.open{border-color:transparent;background-image:linear-gradient(var(--bg-primary),var(--bg-primary)),linear-gradient(135deg,#d8b4fe,#9333ea,#581c87);background-origin:border-box;background-clip:padding-box,border-box;box-shadow:0 0 8px #7c3aed4d}.custom-select-trigger .chevron{color:var(--text-tertiary);transition:transform .2s var(--ease-out);flex-shrink:0}.custom-select-trigger .chevron.rotated{transform:rotate(180deg)}.custom-select-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:220px;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:4px;list-style:none;z-index:50;box-shadow:var(--shadow-lg);animation:fadeIn .2s var(--ease)}.custom-select-option{padding:8px 10px;font-size:.85rem;border-radius:6px;cursor:pointer;color:var(--text-secondary);transition:background .2s var(--ease),color .2s var(--ease);min-width:0}.custom-select-option>span{display:block;width:100%;min-width:0}.custom-select-option-label{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden;min-width:0}.custom-select-option:hover{background:var(--accent-glow);color:var(--accent)}.custom-select-option.selected{background:var(--accent-light);color:var(--accent);font-weight:600}.has-tooltip{position:relative}.has-tooltip:after{content:attr(data-tooltip);position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%) translateY(-4px);padding:5px 10px;font-size:.68rem;font-weight:600;white-space:nowrap;color:#f0f0f0;background:#1a1a1e;border:1px solid #2c2c2e;border-radius:6px;pointer-events:none;opacity:0;transition:opacity .2s var(--ease),transform .2s var(--ease);transition-delay:0s;z-index:200;box-shadow:0 4px 12px #0006}.has-tooltip:hover:after{opacity:1;transform:translate(-50%) translateY(0);transition-delay:.4s}.tooltip-portal{padding:5px 10px;font-size:.68rem;font-weight:600;white-space:normal;max-width:220px;text-align:center;color:#f0f0f0;background:#1a1a1e;border:1px solid #2c2c2e;border-radius:6px;pointer-events:none;z-index:10000;box-shadow:0 4px 12px #0006;animation:tooltipFadeIn .15s ease-out}@keyframes tooltipFadeIn{0%{opacity:0}to{opacity:1}}.toast-container{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:9999}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:10px;background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);font-size:.82rem;font-weight:500;color:var(--text-primary);min-width:240px;max-width:380px;animation:toastIn .25s var(--ease-out)}.toast-error .toast-icon{color:var(--danger)}.toast-success .toast-icon{color:#10b981}.toast-info .toast-icon{color:var(--accent)}.toast-icon{flex-shrink:0;display:flex}.toast-message{flex:1;line-height:1.4}.toast-close{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:transparent;border-radius:4px;color:var(--text-tertiary);cursor:pointer;flex-shrink:0;transition:all .2s var(--ease)}.toast-close:hover{background:var(--bg-hover);color:var(--text-primary)}@keyframes toastIn{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:1024px){.app-header{padding:10px 16px}.header-right{gap:6px}.header-right .btn-sm{padding:7px 14px;font-size:0;gap:0;white-space:nowrap}.header-right .btn-sm svg{width:16px;height:16px}.header-right .btn-primary.btn-sm{width:36px;height:36px;min-width:36px;min-height:36px;padding:0}.header-right .btn-primary.btn-sm .btn-label{display:none}.task-count{font-size:.7rem;padding:4px 10px}}@media(max-width:768px){.app-header{flex-wrap:wrap;padding:12px 16px;margin:10px 12px 0;border-radius:14px}.header-left h1{font-size:1.1rem}.header-right{gap:6px;flex-wrap:wrap;min-width:0}.btn-group{align-items:stretch}.has-tooltip:after{display:none}.board-container{padding:16px 12px;overflow-x:auto;overflow-y:auto}.board{flex-direction:column;width:100%;align-items:stretch}.board-column-wrap{width:100%!important}.kanban-column{width:100%;min-width:unset;max-height:none}.column-header{flex-wrap:wrap;gap:8px}.column-title-group{min-width:0}.modal{margin:12px;padding:20px;border-radius:14px;max-width:100%;min-height:auto}.form-row{grid-template-columns:1fr}.toast-container{left:12px;right:12px;bottom:12px}.toast{min-width:unset;max-width:100%}}@media(max-width:480px){.app-header{padding:10px 12px;margin:8px 8px 0;border-radius:12px}.modal{padding:16px}.board-container{padding:12px 8px}.board{gap:12px}.analytics-stats{grid-template-columns:1fr 1fr}.stat-card{padding:10px}.stat-value{font-size:1rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.2s!important}}
