@keyframes bv-cardEntrance{0%{opacity:0;transform:translateY(6px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes bv-fadeIn{0%{opacity:0}to{opacity:1}}.board-web-root{flex:1;align-items:flex-start;gap:16px;padding:16px;display:flex;overflow:auto hidden}.board-web-column{background:var(--wh-bg,#f5f5f7);border:1px solid var(--wh-border-light,#f0f0f0);border-radius:12px;flex-direction:column;flex-shrink:0;width:300px;min-width:300px;max-height:calc(100vh - 240px);display:flex}.board-web-col-header{z-index:2;background:var(--wh-bg,#f5f5f7);border-radius:12px 12px 0 0;align-items:center;gap:8px;padding:14px 16px 10px;display:flex;position:sticky;top:0}.board-web-col-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.board-web-col-title{color:var(--wh-heading,#09090b);font-size:14px;font-weight:600;font-family:var(--wh-font);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.board-web-col-count{background:var(--wh-surface,#fff);border:1px solid var(--wh-border,#e4e4e7);color:var(--wh-text-secondary,#52525b);font-size:12px;font-weight:600;font-family:var(--wh-font);border-radius:99px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;display:inline-flex}.board-web-col-add{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s;display:flex}.board-web-col-add:hover{background:var(--wh-surface,#fff)}.board-web-col-menu{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s;display:flex}.board-web-col-menu:hover{background:var(--wh-surface,#fff)}.board-web-progress{align-items:center;gap:8px;padding:0 16px 8px;display:flex}.board-web-progress-track{background:var(--wh-border,#e4e4e7);border-radius:2px;flex:1;height:3px;overflow:hidden}.board-web-progress-fill{border-radius:2px;height:100%;transition:width .3s}.board-web-progress-text{color:var(--wh-text-muted);font-size:11px;font-weight:500;font-family:var(--wh-font);font-variant-numeric:tabular-nums;flex-shrink:0}.board-web-cards{flex-direction:column;flex:1;gap:8px;min-height:60px;padding:4px 10px 10px;display:flex;overflow-y:auto}.board-card{background:var(--wh-surface,#fff);border:1px solid var(--wh-border-light,#f0f0f0);cursor:pointer;border-radius:12px;flex-direction:column;gap:10px;padding:16px 18px 14px;transition:box-shadow .2s,border-color .2s,transform .15s;animation:.3s cubic-bezier(.16,1,.3,1) both bv-cardEntrance;display:flex;position:relative;box-shadow:0 1px 2px #00000005}.board-card:hover{border-color:var(--wh-border,#e4e4e7);box-shadow:0 4px 16px #0000000f}.board-card:active{transform:scale(.99)}.board-card-priority{display:none}.board-card-header{align-items:center;gap:6px;display:flex}.board-card-status-badge{font-size:11px;font-weight:600;font-family:var(--wh-font);white-space:nowrap;letter-spacing:.01em;border-radius:99px;align-items:center;gap:5px;padding:3px 10px;display:inline-flex}.board-card-status-badge--todo{color:#5b5bd6;background:#eef0ff}.board-card-status-badge--in_progress{color:#db2777;background:#ffecf2}.board-card-status-badge--review{color:#c2781c;background:#fff3df}.board-card-status-badge--done{color:#15803d;background:#e8f7ed}.board-card-status-badge--overdue{color:#b91c1c;background:#fef2f2}.board-card-status-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.board-card-menu{cursor:pointer;opacity:1;color:var(--wh-text-muted);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;margin-left:auto;transition:background .15s;display:flex}.board-card-menu:hover{background:var(--wh-canvas-subtle,#f4f4f5)}.board-card-drag{cursor:grab;opacity:0;justify-content:center;align-items:center;width:16px;height:16px;transition:opacity .15s;display:flex;position:absolute;top:8px;left:4px}.board-card:hover .board-card-drag{opacity:.5}.board-card-drag:active{cursor:grabbing}.board-card-title{color:var(--wh-heading,#09090b);font-size:14px;font-weight:600;line-height:1.4;font-family:var(--wh-font);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.board-card-title--done{color:var(--wh-text-muted);text-decoration:line-through}.board-card-desc{color:var(--wh-text-secondary,#64748b);font-size:12px;line-height:1.5;font-family:var(--wh-font);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.board-card-assignee-row{align-items:center;gap:8px;margin-top:2px;display:flex}.board-card-assignee-label{color:var(--wh-text-muted);font-size:12px;font-family:var(--wh-font);flex-shrink:0}.board-card-assignee-avatars{align-items:center;margin-left:auto;display:flex}.board-card-meta-row{justify-content:space-between;align-items:center;gap:8px;margin-top:2px;display:flex}.board-card-date{font-size:11px;font-weight:500;font-family:var(--wh-font);color:var(--wh-text-muted);align-items:center;gap:4px;padding:2px 0;display:inline-flex}.board-card-date--overdue{color:#ef4444}.board-card-priority-pill{font-size:11px;font-weight:600;font-family:var(--wh-font);border-radius:99px;align-items:center;padding:3px 12px;display:inline-flex}.board-card-priority-pill--Low{color:#5b5bd6;background:#eef0ff}.board-card-priority-pill--Medium{color:#c2781c;background:#fff3df}.board-card-priority-pill--High{color:#e11d48;background:#ffe6e6}.board-card-priority-pill--Urgent{color:#b91c1c;background:#ffd6d6}.board-card-footer{border-top:1px solid var(--wh-border-light,#f4f4f5);align-items:center;gap:12px;margin-top:4px;padding-top:8px;display:flex}.board-card-footer-item{color:var(--wh-text-muted);font-size:11px;font-weight:500;font-family:var(--wh-font);align-items:center;gap:4px;display:inline-flex}.board-card-labels{flex-wrap:wrap;gap:4px;display:flex}.board-card-label-chip{font-size:10px;font-weight:600;font-family:var(--wh-font);letter-spacing:.02em;border-radius:6px;align-items:center;gap:4px;padding:2px 8px;display:inline-flex}.board-card-checkbox{border:1.5px solid var(--wh-border,#e4e4e7);cursor:pointer;background:0 0;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;padding:0;transition:background .15s,border-color .15s;display:flex}.board-card-checkbox:hover{border-color:var(--wh-border-strong,#a1a1aa)}.board-card-checkbox--checked{background:var(--wh-success,#22c55e);border-color:var(--wh-success,#22c55e)}.board-card-priority-badge{border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.board-web-add-card{border:1px dashed var(--wh-border,#e4e4e7);color:var(--wh-text-muted);font-size:13px;font-weight:500;font-family:var(--wh-font);cursor:pointer;background:0 0;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;padding:10px;transition:background .15s,border-color .15s;display:flex}.board-web-add-card:hover{background:var(--wh-surface,#fff);border-color:var(--wh-border-strong,#a1a1aa)}.board-web-add-column{border:1px dashed var(--wh-border,#e4e4e7);color:var(--wh-text-muted);font-size:13px;font-weight:500;font-family:var(--wh-font);cursor:pointer;background:0 0;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;gap:6px;min-width:280px;height:48px;margin-top:48px;transition:background .15s,border-color .15s;display:flex}.board-web-add-column:hover{background:var(--wh-bg,#f5f5f7);border-color:var(--wh-border-strong,#a1a1aa)}[data-theme=dark] .board-web-column{background:var(--wh-surface);border-color:var(--wh-border)}[data-theme=dark] .board-web-col-header{background:var(--wh-surface)}[data-theme=dark] .board-card{background:var(--wh-bg);border-color:var(--wh-border)}[data-theme=dark] .board-card:hover{box-shadow:0 4px 16px #0003}[data-theme=dark] .board-card-status-badge--todo{color:#94a3b8;background:#64748b26}[data-theme=dark] .board-card-status-badge--in_progress{color:#60a5fa;background:#3b82f61f}[data-theme=dark] .board-card-status-badge--review{color:#fbbf24;background:#f59e0b1f}[data-theme=dark] .board-card-status-badge--done{color:#4ade80;background:#22c55e1f}[data-theme=dark] .board-card-status-badge--overdue{color:#f87171;background:#ef44441f}[data-theme=dark] .board-card-footer{border-top-color:var(--wh-border)}[data-theme=dark] .board-web-add-card{border-color:var(--wh-border)}[data-theme=dark] .board-web-add-card:hover{background:var(--wh-surface-hover)}@media (prefers-reduced-motion:reduce){.board-card{transition-duration:.01ms!important;animation:none!important}}