:root{--bg: #0f172a;--surface: #1e293b;--surface-2: #263449;--surface-3: #2f3e56;--border: #334155;--border-strong: #475569;--text: #e8edf5;--muted: #94a3b8;--primary: #3b82f6;--primary-hover: #60a5fa;--primary-soft: rgba(59, 130, 246, .14);--on-primary: #ffffff;--success: #22c55e;--warning: #f59e0b;--danger: #f87171;--todo: #94a3b8;--in_progress: #3b82f6;--review: #f59e0b;--done: #22c55e;--radius: 10px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 6px 16px rgba(0, 0, 0, .35);--shadow-lg: 0 16px 36px rgba(0, 0, 0, .5);--ring: 0 0 0 3px rgba(59, 130, 246, .3);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box}html,body,#app{height:100%;margin:0}body{background:var(--bg);color:var(--text)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:scale(.97) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}button{font:inherit;cursor:pointer;border:1px solid transparent;border-radius:8px;padding:8px 14px;background:var(--primary);color:var(--on-primary);font-weight:600;transition:background .16s ease,transform .1s ease,box-shadow .16s ease,border-color .16s ease}button:hover{background:var(--primary-hover);box-shadow:var(--shadow-sm)}button:active{transform:translateY(1px)}button.ghost{background:var(--surface-2);color:var(--text);border-color:var(--border-strong);font-weight:500}button.ghost:hover{background:var(--surface-3);box-shadow:none}button.danger{background:transparent;color:var(--danger);border-color:var(--danger)}button.danger:hover{background:var(--danger);color:#fff}button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}input,textarea,select{font:inherit;width:100%;padding:9px 11px;background:var(--surface-2);border:1px solid var(--border-strong);border-radius:8px;color:var(--text);transition:border-color .16s ease,box-shadow .16s ease}input::placeholder,textarea::placeholder{color:#64748b}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring)}label{display:block;font-size:13px;font-weight:500;color:var(--muted);margin:12px 0 5px}.login-wrap{height:100%;display:grid;place-items:center}.login-card{width:360px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:32px;box-shadow:var(--shadow-lg);animation:popIn .32s ease both}.brand{display:flex;align-items:center;gap:10px;margin-bottom:6px}.brand .logo{width:34px;height:34px;border-radius:8px;background:var(--primary);color:#fff;font-weight:800;display:grid;place-items:center;font-size:20px;box-shadow:0 4px 14px #3b82f666}.brand h1{font-size:22px;margin:0;letter-spacing:-.02em}.subtitle{color:var(--muted);font-size:13px;margin:0 0 20px}.error-msg{color:var(--danger);font-size:13px;margin-top:12px;min-height:18px}.remember{display:flex;align-items:center;gap:8px;margin:14px 0 0;font-size:13px;color:var(--text);font-weight:400;cursor:pointer}.remember input{width:16px;height:16px;margin:0;cursor:pointer;accent-color:var(--primary)}.remember span{user-select:none}.full-btn{width:100%;margin-top:20px;padding:10px}details.api-config{margin-top:16px}details.api-config summary{color:var(--muted);font-size:12px;cursor:pointer}.shell{display:grid;grid-template-columns:264px 1fr;height:100%}.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;min-height:0}.sidebar header{padding:18px 18px 12px;border-bottom:1px solid var(--border)}.sidebar .brand h1{font-size:18px}.project-list{flex:1;overflow-y:auto;padding:10px}.project-item{padding:9px 12px;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:8px;transition:background .14s ease}.project-item:hover{background:var(--surface-2)}.project-item.active{background:var(--primary-soft)}.project-item.active .name{color:var(--primary-hover);font-weight:600}.project-item .name{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-item .count{font-size:12px;color:var(--muted);background:var(--surface-2);min-width:22px;text-align:center;padding:1px 7px;border-radius:10px}.project-item.active .count{background:#3b82f640;color:var(--primary-hover)}.sidebar footer{padding:14px 18px;border-top:1px solid var(--border);font-size:13px;color:var(--muted);display:flex;justify-content:space-between;align-items:center;gap:8px}.sidebar footer .me{display:flex;align-items:center;gap:8px;min-width:0}.sidebar footer .me span{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar footer .avatar{border-color:var(--surface)}.sidebar footer a{color:var(--muted);cursor:pointer;text-decoration:none;font-weight:500}.sidebar footer a:hover{color:var(--primary-hover);text-decoration:underline}.main{min-width:0;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.main-header{padding:18px 24px;border-bottom:1px solid var(--border);background:var(--surface);display:flex;justify-content:space-between;align-items:center;gap:12px;animation:fadeIn .25s ease both}.main-header .row{display:flex;align-items:center;gap:8px}.main-header h2{margin:0;font-size:20px;letter-spacing:-.02em}.main-header .desc{color:var(--muted);font-size:13px;margin-top:3px}.board{flex:1;overflow:auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:20px 24px}.column{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;min-height:140px;transition:border-color .16s ease,box-shadow .18s ease,background .16s ease;animation:fadeInUp .3s ease both}.column:nth-child(1){animation-delay:.02s}.column:nth-child(2){animation-delay:.06s}.column:nth-child(3){animation-delay:.1s}.column:nth-child(4){animation-delay:.14s}.column.drag-over{border-color:var(--primary);border-style:dashed;background:var(--primary-soft);box-shadow:var(--ring)}.column-head{padding:12px 14px;font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border)}.dot{width:9px;height:9px;border-radius:50%}.column-head .n{margin-left:auto;color:var(--muted);font-weight:500;background:var(--surface-2);padding:0 8px;border-radius:10px}.cards{padding:10px;display:flex;flex-direction:column;gap:10px;flex:1}.card{position:relative;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:12px;cursor:grab;box-shadow:var(--shadow-sm);transition:transform .13s ease,box-shadow .18s ease,border-color .16s ease,opacity .16s ease;animation:fadeInUp .24s ease both}.card.selected{border-color:var(--primary);box-shadow:0 0 0 2px #3b82f666}.card.drop-before{box-shadow:0 -3px 0 -1px var(--primary)}.cards.drop-end{box-shadow:inset 0 -3px 0 -1px var(--primary)}.card-check{position:absolute;top:8px;right:8px;display:grid;place-items:center;padding:2px}.card-check input{width:16px;height:16px;cursor:pointer;accent-color:var(--primary);margin:0}.card .title{padding-right:22px}.bulk-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:14px 24px 0;padding:10px 14px;background:var(--surface);border:1px solid var(--primary);border-radius:8px;color:var(--text);font-size:14px;font-weight:500;animation:fadeInUp .2s ease both}.bulk-bar .row{display:flex;gap:8px}.card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.card:active{cursor:grabbing}.card.dragging{opacity:.5;transform:rotate(-1.5deg);box-shadow:var(--shadow-lg);border-color:var(--primary);cursor:grabbing}.card .title{font-size:14px;font-weight:500;margin-bottom:10px;line-height:1.35}.card .meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.avatars{display:flex}.avatar{width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;font-size:11px;font-weight:600;display:grid;place-items:center;margin-left:-6px;border:2px solid var(--surface-2);overflow:hidden;flex:none}.avatar:first-child{margin-left:0}.avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.empty-hint{color:var(--muted);font-size:12px;padding:10px 8px;text-align:center}.empty-state{flex:1;display:grid;place-items:center;color:var(--muted);text-align:center;padding:40px;animation:fadeIn .25s ease both}.modal-backdrop{position:fixed;inset:0;background:#0009;display:grid;place-items:center;z-index:50;animation:fadeIn .16s ease both;backdrop-filter:blur(2px)}.modal{width:520px;max-width:calc(100vw - 40px);max-height:calc(100vh - 60px);overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;box-shadow:var(--shadow-lg);animation:popIn .2s ease both}.modal h3{margin:0 0 4px;letter-spacing:-.01em}.modal .row{display:flex;gap:12px}.modal .row>div{flex:1}.assignee-grid{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:6px 12px;border-radius:20px;border:1px solid var(--border-strong);background:var(--surface-2);font-size:13px;cursor:pointer;user-select:none;transition:background .14s ease,border-color .14s ease,color .14s ease}.chip:hover{border-color:var(--primary);color:var(--primary-hover)}.chip.on{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.task-meta{margin-top:18px;padding-top:14px;border-top:1px solid var(--border);font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:4px}.task-meta .k{color:var(--text);font-weight:600}.modal-actions{display:flex;justify-content:space-between;gap:10px;margin-top:24px}.modal-actions .right{display:flex;gap:10px;margin-left:auto}.spacer{flex:1}
