:root{--bg-root: #0a0a0f;--bg-sidebar: #0f0f17;--bg-board: #12121c;--bg-column: rgba(18, 18, 30, .7);--bg-column-hover: rgba(24, 24, 42, .8);--bg-card: rgba(22, 22, 38, .85);--bg-card-hover: rgba(30, 30, 52, .95);--bg-modal: rgba(14, 14, 24, .97);--bg-input: rgba(255, 255, 255, .04);--bg-input-focus: rgba(255, 255, 255, .07);--border-subtle: rgba(255, 255, 255, .06);--border-medium: rgba(255, 255, 255, .1);--border-accent: rgba(124, 92, 252, .4);--text-primary: #e8e8f0;--text-secondary: #8888a0;--text-muted: #55556a;--text-accent: #a78bfa;--accent-primary: #7c5cfc;--accent-primary-soft: rgba(124, 92, 252, .15);--accent-secondary: #06d6a0;--accent-danger: #ef476f;--accent-danger-soft: rgba(239, 71, 111, .15);--accent-warning: #ffd166;--color-code: #60a5fa;--color-art2d: #f472b6;--color-art3d: #c084fc;--color-animation: #34d399;--color-vfx: #fb923c;--color-audio: #22d3ee;--color-design: #fbbf24;--color-placeholder: #6b7280;--color-wip: #f59e0b;--color-review: #3b82f6;--color-final: #10b981;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--shadow-card: 0 2px 8px rgba(0, 0, 0, .3), 0 0 0 1px rgba(255, 255, 255, .04);--shadow-card-hover: 0 8px 24px rgba(0, 0, 0, .4), 0 0 0 1px rgba(124, 92, 252, .2);--shadow-column: 0 1px 4px rgba(0, 0, 0, .2);--shadow-modal: 0 24px 80px rgba(0, 0, 0, .6);--shadow-glow: 0 0 20px rgba(124, 92, 252, .15);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-root);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-layout{display:flex;height:100vh;width:100vw}.sidebar{width:260px;min-width:260px;background:var(--bg-sidebar);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;transition:width var(--transition-base);overflow:hidden}.sidebar-header{padding:20px 18px 16px;border-bottom:1px solid var(--border-subtle)}.sidebar-logo{display:flex;align-items:center;gap:10px;margin-bottom:2px}.sidebar-logo h1{font-size:16px;font-weight:700;letter-spacing:-.3px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-logo-icon{color:var(--accent-primary);opacity:.9}.sidebar-subtitle{font-size:11px;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;margin-top:4px}.sidebar-section{padding:12px 12px 8px;flex:1;overflow-y:auto}.sidebar-section-label{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);padding:0 6px 8px}.board-list{list-style:none;display:flex;flex-direction:column;gap:2px}.board-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:13px;font-weight:500;color:var(--text-secondary);position:relative}.board-item:hover{background:#ffffff0a;color:var(--text-primary)}.board-item.is-dragging{background:var(--accent-primary-soft);border:1px solid var(--border-accent);box-shadow:var(--shadow-card-hover);z-index:10}.board-item-grip{display:flex;align-items:center;color:var(--text-muted);opacity:0;cursor:grab;flex-shrink:0;transition:opacity var(--transition-fast)}.board-item:hover .board-item-grip{opacity:.5}.board-item-grip:hover{opacity:1!important;color:var(--text-secondary)}.board-item.active{background:var(--accent-primary-soft);color:var(--text-accent)}.board-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--accent-primary);border-radius:0 3px 3px 0}.board-item-icon{flex-shrink:0;opacity:.6}.board-item.active .board-item-icon{opacity:1}.board-item-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.board-item-delete{opacity:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center}.board-item:hover .board-item-delete{opacity:1}.board-item-delete:hover{color:var(--accent-danger);background:var(--accent-danger-soft)}.sidebar-add-btn{display:flex;align-items:center;gap:8px;width:100%;padding:10px;margin-top:4px;border:1px dashed var(--border-medium);background:transparent;color:var(--text-muted);border-radius:var(--radius-md);cursor:pointer;font-size:13px;font-weight:500;transition:all var(--transition-fast)}.sidebar-add-btn:hover{border-color:var(--accent-primary);color:var(--text-accent);background:var(--accent-primary-soft)}.board-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-board)}.board-header{padding:16px 24px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;background:#0f0f1780;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.board-title-input{background:transparent;border:1px solid transparent;color:var(--text-primary);font-size:20px;font-weight:700;font-family:inherit;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast);letter-spacing:-.3px;width:auto;min-width:200px}.board-title-input:hover{border-color:var(--border-medium)}.board-title-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-input-focus)}.board-content{flex:1;overflow-x:auto;overflow-y:hidden;padding:20px}.board-content.is-panning{cursor:grabbing;-webkit-user-select:none;user-select:none}.board-content::-webkit-scrollbar{height:8px}.board-content::-webkit-scrollbar-track{background:transparent}.board-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.board-content::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.board-columns{display:flex;gap:16px;height:100%;align-items:flex-start}.empty-board{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:var(--text-muted)}.empty-board-icon{opacity:.3}.empty-board h2{font-size:20px;font-weight:600;color:var(--text-secondary)}.empty-board p{font-size:14px;max-width:400px;text-align:center;line-height:1.6}.column{width:300px;min-width:300px;background:var(--bg-column);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);display:flex;flex-direction:column;max-height:calc(100vh - 120px);transition:all var(--transition-fast);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.column.dragging-over{border-color:var(--border-accent);box-shadow:var(--shadow-glow)}.column-header{padding:12px 10px 10px;display:flex;align-items:center;gap:6px;border-bottom:1px solid var(--border-subtle);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.column-title-input{flex:1;min-width:0;background:transparent;border:1px solid transparent;color:var(--text-primary);font-size:14px;font-weight:600;font-family:inherit;padding:4px 6px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.column-title-input:hover{border-color:var(--border-medium)}.column-title-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-input-focus)}.column-count{background:#ffffff0f;color:var(--text-muted);font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px;min-width:22px;text-align:center}.column-actions{display:flex;gap:2px;flex-shrink:0}.column-action-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all var(--transition-fast);opacity:0}.column-header:hover .column-action-btn{opacity:1}.column-action-btn:hover{color:var(--accent-danger);background:var(--accent-danger-soft)}.column-color-btn:hover,.column-copy-btn:hover{color:var(--text-accent)!important;background:var(--accent-primary-soft)!important}.column-cards{flex:1;overflow-y:auto;padding:8px;min-height:60px}.column-cards::-webkit-scrollbar{width:4px}.column-cards::-webkit-scrollbar-track{background:transparent}.column-cards::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}.column-footer{padding:8px;border-top:1px solid var(--border-subtle)}.add-card-btn{display:flex;align-items:center;gap:6px;width:100%;padding:8px 10px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;border-radius:var(--radius-md);transition:all var(--transition-fast)}.add-card-btn:hover{background:#ffffff0a;color:var(--text-secondary)}.add-card-input-wrap{padding:8px}.add-card-input{width:100%;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border-medium);color:var(--text-primary);font-size:13px;font-family:inherit;border-radius:var(--radius-md);transition:all var(--transition-fast);resize:none}.add-card-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-input-focus);box-shadow:0 0 0 3px #7c5cfc1a}.add-card-actions{display:flex;gap:6px;margin-top:6px;padding:0 8px 4px}.btn-primary{padding:6px 14px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.btn-primary:hover{filter:brightness(1.15);transform:translateY(-1px)}.btn-ghost{padding:6px 14px;background:transparent;color:var(--text-muted);border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.btn-ghost:hover{color:var(--text-secondary);background:#ffffff0a}.add-column-btn{width:300px;min-width:300px;padding:14px;background:#ffffff05;border:1px dashed var(--border-medium);border-radius:var(--radius-lg);color:var(--text-muted);cursor:pointer;font-size:14px;font-weight:500;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--transition-fast);align-self:flex-start;height:fit-content}.add-column-btn:hover{border-color:var(--accent-primary);color:var(--text-accent);background:var(--accent-primary-soft)}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px;margin-bottom:8px;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-card);position:relative}.card:hover{background:var(--bg-card-hover);border-color:var(--border-medium);box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.card.is-dragging{box-shadow:var(--shadow-card-hover),var(--shadow-glow);border-color:var(--border-accent);opacity:.95}.card-priority-stripe{position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-md) var(--radius-md) 0 0}.priority-stripe-critical{background:var(--accent-danger)}.priority-stripe-high{background:var(--color-vfx)}.priority-stripe-medium{background:var(--color-design)}.priority-stripe-low{background:var(--color-final)}.card-title{font-size:13px;font-weight:500;color:var(--text-primary);line-height:1.45;margin-bottom:8px}.card-badges{display:flex;flex-wrap:wrap;gap:5px}.badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:6px;letter-spacing:.3px;text-transform:uppercase;line-height:1.5}.badge-discipline,.badge-discipline[data-discipline=Code]{background:#60a5fa1f;color:var(--color-code)}.badge-discipline[data-discipline=Art2D]{background:#f472b61f;color:var(--color-art2d)}.badge-discipline[data-discipline=Art3D]{background:#c084fc1f;color:var(--color-art3d)}.badge-discipline[data-discipline=Animation]{background:#34d3991f;color:var(--color-animation)}.badge-discipline[data-discipline=VFX]{background:#fb923c1f;color:var(--color-vfx)}.badge-discipline[data-discipline=Audio]{background:#22d3ee1f;color:var(--color-audio)}.badge-discipline[data-discipline=Design]{background:#fbbf241f;color:var(--color-design)}.badge-status,.badge-status[data-status=Placeholder]{background:#6b728026;color:var(--color-placeholder)}.badge-status[data-status=WIP]{background:#f59e0b26;color:var(--color-wip)}.badge-status[data-status=Review]{background:#3b82f626;color:var(--color-review)}.badge-status[data-status=Final]{background:#10b98126;color:var(--color-final)}.badge-priority{font-weight:700}.badge-priority.priority-critical{background:#ef476f33;color:var(--accent-danger)}.badge-priority.priority-high{background:#fb923c26;color:var(--color-vfx)}.badge-priority.priority-medium{background:#fbbf2426;color:var(--color-design)}.badge-priority.priority-low{background:#10b98126;color:var(--color-final)}.badge-points{background:#7c5cfc1f;color:var(--text-accent)}.card-has-desc{position:absolute;top:10px;right:10px;color:var(--text-muted);opacity:.4}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-fast) ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-modal);border:1px solid var(--border-medium);border-radius:var(--radius-xl);width:640px;max-width:90vw;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-modal);animation:slideUp var(--transition-base) ease-out}.modal::-webkit-scrollbar{width:6px}.modal::-webkit-scrollbar-track{background:transparent}.modal::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.modal-title-input{flex:1;background:transparent;border:1px solid transparent;color:var(--text-primary);font-size:18px;font-weight:700;font-family:inherit;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast);letter-spacing:-.2px}.modal-title-input:hover{border-color:var(--border-medium)}.modal-title-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-input-focus)}.modal-close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:all var(--transition-fast);display:flex;align-items:center}.modal-close-btn:hover{color:var(--text-primary);background:#ffffff0f}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:20px}.modal-section{display:flex;flex-direction:column;gap:8px}.modal-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.description-editor{display:flex;flex-direction:column;gap:8px}.description-tabs{display:flex;gap:2px;background:#ffffff08;border-radius:var(--radius-sm);padding:2px;width:fit-content}.desc-tab{padding:5px 12px;background:transparent;border:none;color:var(--text-muted);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;border-radius:4px;transition:all var(--transition-fast)}.desc-tab.active{background:var(--accent-primary-soft);color:var(--text-accent)}.desc-tab:hover:not(.active){color:var(--text-secondary)}.description-textarea{width:100%;min-height:140px;padding:12px;background:var(--bg-input);border:1px solid var(--border-medium);color:var(--text-primary);font-size:13px;font-family:Inter,monospace;line-height:1.6;border-radius:var(--radius-md);resize:vertical;transition:all var(--transition-fast)}.description-textarea:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-input-focus);box-shadow:0 0 0 3px #7c5cfc1a}.markdown-preview{padding:12px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);min-height:140px;font-size:13px;line-height:1.7;color:var(--text-primary)}.markdown-preview h1,.markdown-preview h2,.markdown-preview h3{color:var(--text-primary);margin:12px 0 6px;font-weight:700}.markdown-preview h1{font-size:18px}.markdown-preview h2{font-size:16px}.markdown-preview h3{font-size:14px}.markdown-preview p{margin:6px 0}.markdown-preview code{background:#7c5cfc1a;color:var(--text-accent);padding:2px 5px;border-radius:4px;font-size:12px}.markdown-preview pre{background:#0006;padding:12px;border-radius:var(--radius-md);overflow-x:auto;margin:8px 0}.markdown-preview pre code{background:none;padding:0;color:var(--text-primary)}.markdown-preview ul,.markdown-preview ol{padding-left:20px;margin:6px 0}.markdown-preview li{margin:3px 0}.markdown-preview a{color:var(--text-accent);text-decoration:underline}.markdown-preview blockquote{border-left:3px solid var(--accent-primary);padding-left:12px;color:var(--text-secondary);margin:8px 0}.markdown-preview table{width:100%;border-collapse:collapse;margin:8px 0}.markdown-preview th,.markdown-preview td{border:1px solid var(--border-medium);padding:6px 10px;text-align:left;font-size:12px}.markdown-preview th{background:#ffffff0a;font-weight:600}.metadata-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.meta-field{display:flex;flex-direction:column;gap:5px}.meta-field label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted)}.meta-select,.meta-input{padding:8px 10px;background:var(--bg-input);border:1px solid var(--border-medium);color:var(--text-primary);font-size:13px;font-family:inherit;border-radius:var(--radius-sm);transition:all var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.meta-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238888a0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}.meta-select:focus,.meta-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #7c5cfc1a}.meta-select option{background:var(--bg-modal);color:var(--text-primary)}.priority-calculator{display:flex;flex-direction:column;gap:8px}.priority-sliders{display:grid;grid-template-columns:1fr 1fr;gap:10px}.priority-slider-group{display:flex;flex-direction:column;gap:4px}.priority-slider-group label{font-size:11px;color:var(--text-muted)}.priority-slider-group input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:var(--border-medium);border-radius:3px;outline:none}.priority-slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-primary);cursor:pointer;border:2px solid var(--bg-modal);box-shadow:0 0 6px #7c5cfc66}.priority-result{text-align:center;font-size:22px;font-weight:800;padding:6px;border-radius:var(--radius-sm)}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center}.btn-danger{padding:7px 14px;background:var(--accent-danger-soft);color:var(--accent-danger);border:1px solid rgba(239,71,111,.2);border-radius:var(--radius-sm);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all var(--transition-fast)}.btn-danger:hover{background:#ef476f40;border-color:var(--accent-danger)}.btn-save{padding:8px 20px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all var(--transition-fast)}.btn-save:hover{filter:brightness(1.15);transform:translateY(-1px);box-shadow:0 4px 12px #7c5cfc4d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.no-board-selected{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;color:var(--text-muted)}.no-board-selected h2{font-size:22px;font-weight:700;color:var(--text-secondary);letter-spacing:-.3px}.no-board-selected p{font-size:14px;line-height:1.6;max-width:380px;text-align:center}.no-board-icon{opacity:.15;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.color-picker-dropdown{display:flex;gap:4px;padding:8px 12px;border-bottom:1px solid var(--border-subtle);flex-wrap:wrap}.color-swatch{width:22px;height:22px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-swatch:hover{transform:scale(1.15);border-color:#ffffff4d}.color-swatch.active{border-color:var(--accent-primary);box-shadow:0 0 0 2px #7c5cfc4d}.card-color-picker{display:flex;gap:6px;flex-wrap:wrap}.color-swatch-lg{width:28px;height:28px;border-radius:8px;border:2px solid var(--border-medium);cursor:pointer;transition:all var(--transition-fast)}.color-swatch-lg:hover{transform:scale(1.1);border-color:#ffffff4d}.color-swatch-lg.active{border-color:var(--accent-primary);box-shadow:0 0 0 2px #7c5cfc4d}.board-header-right{display:flex;align-items:center;gap:8px}.btn-icon{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all var(--transition-fast)}.btn-icon:hover{color:var(--text-primary);background:#ffffff0f}.board-zoom-controls{display:flex;align-items:center;gap:4px;background:#ffffff08;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:2px}.zoom-label{font-size:11px;font-weight:600;color:var(--text-secondary);min-width:36px;text-align:center}.board-progress{display:flex;align-items:center;gap:8px}.board-progress-bar{width:80px;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden}.board-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));border-radius:3px;transition:width var(--transition-base)}.board-progress-text{font-size:11px;font-weight:600;color:var(--text-secondary);min-width:28px}.column-collapsed{min-width:200px;width:200px}.column-collapsed .column-cards,.column-collapsed .column-footer,.column-collapsed .add-card-input-wrap,.column-collapsed .add-card-actions{display:none}.column-collapse-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:var(--radius-sm);display:flex;align-items:center;flex-shrink:0;transition:color var(--transition-fast)}.column-collapse-btn:hover{color:var(--text-primary)}.checklist{list-style:none;display:flex;flex-direction:column;gap:2px}.checklist-item{display:flex;align-items:center;gap:8px;padding:5px 4px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.checklist-item:hover{background:#ffffff08}.checklist-item.completed .checklist-text{text-decoration:line-through;color:var(--text-muted)}.checklist-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;display:flex;align-items:center;flex-shrink:0;transition:color var(--transition-fast)}.checklist-item.completed .checklist-toggle{color:var(--accent-secondary)}.checklist-text{flex:1;font-size:13px;color:var(--text-primary)}.checklist-delete{opacity:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all var(--transition-fast)}.checklist-item:hover .checklist-delete{opacity:1}.checklist-delete:hover{color:var(--accent-danger)}.checklist-progress-label{font-size:11px;font-weight:600;color:var(--text-secondary);margin-left:4px}.checklist-progress-bar{height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden}.checklist-progress-fill{height:100%;background:var(--accent-secondary);border-radius:2px;transition:width var(--transition-base)}.checklist-add-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:12px;font-family:inherit;padding:6px 4px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.checklist-add-btn:hover{color:var(--text-secondary);background:#ffffff08}.checklist-add-row{display:flex;gap:6px;align-items:center}.checklist-add-input{flex:1;padding:6px 10px;background:var(--bg-input);border:1px solid var(--border-medium);color:var(--text-primary);font-size:13px;font-family:inherit;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.checklist-add-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-input-focus)}.btn-sm{padding:4px 10px!important;font-size:11px!important}.link-list{list-style:none;display:flex;flex-direction:column;gap:4px}.link-item{display:flex;align-items:center;gap:8px;padding:5px 8px;background:#ffffff05;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:12px}.link-type-badge{font-size:10px;font-weight:600;text-transform:uppercase;color:var(--text-accent);background:var(--accent-primary-soft);padding:1px 6px;border-radius:4px;flex-shrink:0}.link-target-title{flex:1;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.link-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;transition:color var(--transition-fast)}.link-delete:hover{color:var(--accent-danger)}.link-add-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.link-card-select{flex:1;min-width:200px}.shortcuts-panel{background:var(--bg-modal);border:1px solid var(--border-medium);border-radius:var(--radius-xl);width:380px;max-width:90vw;box-shadow:var(--shadow-modal);animation:slideUp var(--transition-base) ease-out}.shortcuts-header{padding:16px 20px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.shortcuts-header h3{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}.shortcuts-body{padding:16px 20px;display:flex;flex-direction:column;gap:8px}.shortcut-row{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--text-secondary)}.shortcut-row kbd{background:#ffffff0f;border:1px solid var(--border-medium);border-radius:4px;padding:2px 8px;font-size:11px;font-family:inherit;font-weight:600;color:var(--text-primary)}.shortcut-section-title{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted);margin-top:8px;padding-bottom:2px;border-bottom:1px solid var(--border-subtle)}.shortcut-section-title:first-child{margin-top:0}.archive-panel{background:var(--bg-modal);border:1px solid var(--border-medium);border-radius:var(--radius-xl);width:420px;max-width:90vw;max-height:70vh;overflow-y:auto;box-shadow:var(--shadow-modal);animation:slideUp var(--transition-base) ease-out}.archive-header{padding:16px 20px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg-modal);z-index:1}.archive-header h3{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}.archive-body{padding:12px 20px}.archive-empty{color:var(--text-muted);font-size:13px;text-align:center;padding:20px 0}.archive-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-subtle)}.archive-card:last-child{border-bottom:none}.archive-card-title{font-size:13px;font-weight:500;color:var(--text-primary)}.archive-card-list{font-size:11px;color:var(--text-muted);margin-top:2px}.milestone-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0;font-size:13px;color:var(--text-secondary)}.milestone-add-row{display:flex;gap:6px;align-items:center;margin-top:4px}.modal-footer-left{display:flex;gap:6px;align-items:center}.btn-icon-secondary{background:#ffffff0a;border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all var(--transition-fast)}.btn-icon-secondary:hover{color:var(--text-primary);border-color:var(--border-medium);background:#ffffff14}.btn-icon-danger{background:none;border:1px solid var(--border-subtle);color:var(--text-muted);cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all var(--transition-fast)}.btn-icon-danger:hover{color:var(--accent-danger);border-color:var(--accent-danger);background:var(--accent-danger-soft)}.badge-milestone{background:#7c5cfc1f;color:var(--text-accent)}.badge-checklist{background:#ffffff0f;color:var(--text-secondary)}.badge-checklist-done{background:#06d6a026;color:var(--accent-secondary)}.badge-links{background:#60a5fa1f;color:var(--color-code)}.notes-add-row{display:flex;gap:6px;align-items:center;margin-bottom:8px}.notes-list{list-style:none;display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto}.note-item{padding:8px 10px;background:#ffffff05;border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.note-text{font-size:13px;color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.note-meta{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.note-time{font-size:10px;color:var(--text-muted)}.note-empty{font-size:12px;color:var(--text-muted);text-align:center;padding:10px 0}.badge-notes{background:#ffffff0f;color:var(--text-secondary)}.board-description-section{padding:0 24px 12px;border-bottom:1px solid var(--border-subtle)}.board-description-input{width:100%;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border-medium);color:var(--text-primary);font-size:13px;font-family:JetBrains Mono,Fira Code,monospace;border-radius:var(--radius-sm);resize:vertical;min-height:60px;transition:all var(--transition-fast)}.board-description-input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-input-focus)}.board-description-preview{padding:8px 12px;min-height:40px}.board-sub-bar{display:flex;align-items:center;gap:8px;padding:6px 24px;border-bottom:1px solid var(--border-subtle)}.board-sub-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-right:4px}.bulk-action-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;padding:10px 20px;background:var(--bg-modal);border:1px solid var(--border-accent);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal),var(--shadow-glow);z-index:1000;animation:slideUp var(--transition-base) ease-out}.bulk-count{font-size:13px;font-weight:600;color:var(--text-accent);white-space:nowrap}.bulk-select{min-width:120px}.card-selected{outline:2px solid var(--accent-primary)!important;outline-offset:-2px}.card-select-checkbox{position:absolute;top:6px;right:6px;color:var(--text-accent);z-index:1}.card{position:relative}.btn-icon-active{color:var(--text-accent)!important;background:var(--accent-primary-soft)!important}.column-footer-buttons{display:flex;align-items:center;gap:4px}.template-menu-wrap{position:relative}.template-btn{padding:6px 8px!important;min-width:auto}.template-dropdown{position:absolute;bottom:100%;left:0;margin-bottom:6px;min-width:180px;background:var(--bg-modal);border:1px solid var(--border-medium);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);padding:4px;z-index:50;animation:slideUp .15s ease-out}.template-dropdown-item{display:block;width:100%;text-align:left;padding:8px 12px;background:none;border:none;color:var(--text-primary);font-size:13px;font-family:inherit;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.template-dropdown-item:hover{background:#ffffff0f}.template-editor-modal{display:flex;width:820px;max-width:95vw;max-height:85vh;background:var(--bg-modal);border:1px solid var(--border-medium);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);overflow:hidden;animation:slideUp var(--transition-base) ease-out}.template-sidebar{width:220px;min-width:220px;border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;background:#00000026}.template-sidebar-header{padding:14px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.template-sidebar-header h3{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;color:var(--text-secondary)}.template-sidebar-list{flex:1;overflow-y:auto;padding:6px}.template-sidebar-item{display:flex;align-items:center;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.template-sidebar-item:hover{background:#ffffff0a}.template-sidebar-item.active{background:var(--accent-primary-soft)}.template-sidebar-btn{flex:1;text-align:left;padding:8px 10px;background:none;border:none;color:var(--text-primary);font-size:12px;font-family:inherit;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-sidebar-delete{opacity:0;padding:4px;background:none;border:none;color:var(--text-muted);cursor:pointer;flex-shrink:0;display:flex;align-items:center;transition:all var(--transition-fast)}.template-sidebar-item:hover .template-sidebar-delete{opacity:1}.template-sidebar-delete:hover{color:var(--accent-danger)}.template-sidebar-empty{font-size:11px;color:var(--text-muted);text-align:center;padding:20px 10px;line-height:1.6}.template-editor-content{flex:1;display:flex;flex-direction:column;overflow-y:auto}.template-import-picker{display:flex;flex-direction:column;gap:4px}.template-import-empty{font-size:12px;color:var(--text-muted);padding:8px 0;line-height:1.5}.template-import-item{display:flex;flex-direction:column;gap:2px;padding:8px 12px;background:#ffffff05;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.template-import-item:hover{background:#ffffff0f;border-color:var(--border-medium)}.template-import-name{font-size:13px;font-weight:500;color:var(--text-primary)}.template-import-meta{font-size:11px;color:var(--text-muted)}.timeline-modal{width:700px;max-width:95vw;max-height:85vh;background:var(--bg-modal);border:1px solid var(--border-medium);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);display:flex;flex-direction:column;animation:slideUp var(--transition-base) ease-out}.timeline-modal-body{flex:1;display:flex;flex-direction:column;overflow:hidden}.timeline-add-section{padding:16px 24px;background:#0003;border-bottom:1px solid var(--border-subtle)}.timeline-add-section h4{font-size:13px;color:var(--text-secondary);margin-bottom:12px;font-weight:600}.timeline-input-row{display:flex;gap:12px;margin-bottom:8px}.timeline-input-row:last-child{margin-bottom:0}.timeline-input{background:var(--bg-input);border:1px solid var(--border-medium);color:var(--text-primary);font-size:13px;padding:8px 12px;border-radius:var(--radius-sm);outline:none;font-family:inherit}.timeline-input:focus{border-color:var(--accent-primary)}.flex-1{flex:1}.flex-2{flex:2}.timeline-container{flex:1;overflow-y:auto;padding:40px 24px;position:relative}.timeline-line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:repeating-linear-gradient(to bottom,var(--border-medium) 0,var(--border-medium) 6px,transparent 6px,transparent 12px);transform:translate(-50%);z-index:0}.timeline-empty{text-align:center;color:var(--text-muted);font-size:14px;padding:40px;position:relative;z-index:1;background:var(--bg-modal);margin:0 auto;width:fit-content;border-radius:var(--radius-md)}.timeline-entry{position:relative;width:50%;margin-bottom:30px;z-index:1}.timeline-entry.timeline-left{left:0;padding-right:30px}.timeline-entry.timeline-right{left:50%;padding-left:30px}.timeline-node{position:absolute;top:14px;width:14px;height:14px;background:var(--accent-primary);border:3px solid var(--bg-modal);border-radius:50%;box-shadow:0 0 0 2px var(--border-medium)}.timeline-left .timeline-node{right:-7px}.timeline-right .timeline-node{left:-7px}.timeline-content{background:#ffffff08;border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:14px 16px;position:relative;transition:transform var(--transition-fast),border-color var(--transition-fast)}.timeline-content:hover{transform:translateY(-2px);border-color:var(--border-accent)}.timeline-content:before{content:"";position:absolute;top:14px;width:10px;height:10px;background:var(--bg-modal);border-top:1px solid var(--border-subtle);border-right:1px solid var(--border-subtle)}.timeline-left .timeline-content:before{right:-6px;transform:rotate(45deg);background:#191919}.timeline-right .timeline-content:before{left:-6px;transform:rotate(-135deg);background:#191919}.timeline-content:hover:before{border-color:var(--border-accent)}.timeline-content-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.timeline-title{font-size:14px;font-weight:600;color:var(--text-primary)}.timeline-date{font-size:11px;color:var(--text-accent);display:flex;align-items:center;gap:4px;background:var(--accent-primary-soft);padding:2px 8px;border-radius:var(--radius-sm);font-family:JetBrains Mono,monospace}.timeline-desc{font-size:13px;color:var(--text-secondary);line-height:1.5}.timeline-delete{position:absolute;top:-10px;right:-10px;opacity:0;background:var(--bg-hover)!important;border:1px solid var(--border-medium)!important;box-shadow:var(--shadow-sm);padding:6px!important}.timeline-left .timeline-delete{right:auto;left:-10px}.timeline-content:hover .timeline-delete{opacity:1}.icon-picker-popover{position:absolute;top:100%;left:0;z-index:50;width:280px;max-height:340px;background:var(--bg-modal);border:1px solid var(--border-medium);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);display:flex;flex-direction:column;overflow:hidden;margin-top:4px}.icon-picker-header{display:flex;align-items:center;gap:6px;padding:8px 10px;border-bottom:1px solid var(--border-subtle)}.icon-picker-search-wrap{flex:1;display:flex;align-items:center;gap:6px;background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:4px 8px}.icon-picker-search-wrap:focus-within{border-color:var(--accent-primary);background:var(--bg-input-focus)}.icon-picker-search-icon{color:var(--text-muted);flex-shrink:0}.icon-picker-search{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:12px;font-family:inherit;outline:none;min-width:0}.icon-picker-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all var(--transition-fast)}.icon-picker-close:hover{color:var(--text-primary);background:#ffffff0f}.icon-picker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:8px;overflow-y:auto;flex:1}.icon-picker-grid::-webkit-scrollbar{width:4px}.icon-picker-grid::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}.icon-picker-item{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.icon-picker-item:hover{background:#ffffff0f;color:var(--text-primary)}.icon-picker-item.active{background:var(--accent-primary-soft);color:var(--text-accent);box-shadow:inset 0 0 0 1px var(--border-accent)}.icon-picker-clear{color:var(--text-muted)}.icon-picker-empty{padding:16px;text-align:center;color:var(--text-muted);font-size:12px}.column-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-accent);opacity:.8}.column-icon-btn:hover{color:var(--text-accent)!important;background:var(--accent-primary-soft)!important}.attachment-upload-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.attachment-upload-btn{white-space:nowrap}.attachment-hint{font-size:11px;color:var(--text-muted)}.attachment-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-top:4px}.attachment-thumb{position:relative;border-radius:var(--radius-md);overflow:hidden;background:#0000004d;border:1px solid var(--border-subtle);transition:all var(--transition-fast)}.attachment-thumb:hover{border-color:var(--border-medium);box-shadow:var(--shadow-card-hover)}.attachment-media{width:100%;height:100px;object-fit:cover;display:block;cursor:pointer;transition:opacity var(--transition-fast)}.attachment-media:hover{opacity:.85}.attachment-info{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;background:#0006}.attachment-name{font-size:10px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.attachment-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all var(--transition-fast);flex-shrink:0;opacity:0}.attachment-thumb:hover .attachment-delete{opacity:1}.attachment-delete:hover{color:var(--accent-danger);background:var(--accent-danger-soft)}.attachment-empty{color:var(--text-muted);font-size:12px;padding:8px 0}.badge-attachments{background:#a8a29e1f;color:var(--text-secondary)}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:#000000e6;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lightbox-close{position:absolute;top:16px;right:16px;background:#ffffff1a;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:2001}.lightbox-close:hover{background:#fff3;transform:scale(1.1)}.lightbox-content{max-width:90vw;max-height:90vh;border-radius:var(--radius-md);box-shadow:0 0 60px #00000080;cursor:default}img.lightbox-content{object-fit:contain}video.lightbox-content{outline:none}.login-screen{height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg-root)}.login-card{display:flex;flex-direction:column;align-items:center;gap:24px;padding:48px 40px;background:var(--bg-sidebar);border:1px solid var(--border-medium);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal);width:360px}.login-logo{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-accent)}.login-logo h1{font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.login-subtitle{color:var(--text-secondary);font-size:.875rem;text-align:center}.user-bar{position:fixed;bottom:16px;right:16px;display:flex;align-items:center;gap:8px;padding:6px 10px 6px 8px;background:var(--bg-column);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100}.user-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.user-name{font-size:.75rem;color:var(--text-secondary);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:none;border:none;cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast)}.logout-btn:hover{color:var(--accent-danger);background:var(--accent-danger-soft)}
