:root{--vava-bg: #faf8f6;--vava-surface: #ffffff;--vava-tan: #bda793;--vava-tan-hover: #9c8574;--vava-tan-light: #d4c4b5;--vava-tan-tint: #bda7934d;--vava-text: #333333;--vava-text-muted: #777777;--vava-text-subtle: #9c8574;--vava-border: #e8e0d8;--vava-border-soft: #e8e0d880;--vava-red: #dd3327;--vava-red-bg: #ffe2e2;--vava-red-text: #9f0712;--vava-amber: #874b00;--vava-amber-bg: #fef9c2;--vava-amber-border: #fde68a;--vava-green: #3d8b5e;--vava-green-bg: #dcfce7;--vava-green-text: #016630}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--vava-bg);color:var(--vava-text);font-family:Inter,Geist,Geist Fallback,ui-sans-serif,system-ui,-apple-system,PingFang SC,Microsoft YaHei,Hiragino Sans GB,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.003em}.mono,.vava-mono{font-family:JetBrains Mono,Geist Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;letter-spacing:-.01em}.vava-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.vava-sidebar{background:var(--vava-surface);border-right:1px solid var(--vava-border);padding:20px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.vava-main{padding:32px;max-width:1280px;width:100%}.vava-brand{display:flex;align-items:center;gap:10px;padding:8px 10px 24px;border-bottom:1px solid var(--vava-border-soft);margin-bottom:16px}.vava-brand-logo{width:36px;height:36px;display:flex;align-items:center;justify-content:center}.vava-brand-word{font-weight:700;font-size:18px;letter-spacing:.02em;color:var(--vava-text)}.vava-brand-sub{font-size:9px;letter-spacing:.2em;color:var(--vava-text-subtle);text-transform:uppercase;margin-top:2px}.vava-nav{display:flex;flex-direction:column;gap:2px;flex:1}.vava-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:6px;color:var(--vava-text);cursor:pointer;font-size:14px;font-weight:500;transition:background .1s;border:none;background:transparent;text-align:left;width:100%}.vava-nav-item:hover{background:#bda7931a}.vava-nav-item.active{background:var(--vava-tan-tint);font-weight:600}.icon{width:18px;height:18px;flex-shrink:0;display:inline-block;vertical-align:middle}.vava-nav-item .icon{opacity:.7}.vava-nav-item.active .icon{opacity:1}.detail-back .icon,.vava-alert .icon{width:16px;height:16px}.btn .icon{width:15px;height:15px;margin-right:2px}.vava-nav-item.disabled{opacity:.4;cursor:not-allowed}.vava-sidebar-footer{padding:12px 10px;border-top:1px solid var(--vava-border-soft);font-size:12px;color:var(--vava-text-muted)}.vava-sidebar-footer .name{color:var(--vava-text);font-weight:600;margin-top:2px}.vava-sidebar-footer .logout{display:inline-block;margin-top:8px;color:var(--vava-text-muted);cursor:pointer;text-decoration:none}.vava-sidebar-footer .logout:hover{color:var(--vava-text)}.vava-page-title{font-size:32px;font-weight:700;letter-spacing:-.01em;color:var(--vava-text);margin:0 0 4px}.vava-page-meta{color:var(--vava-text-muted);font-size:13px}.vava-page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.vava-card{background:var(--vava-surface);border:1px solid var(--vava-border);border-radius:8px;padding:20px}.vava-card-title{font-size:14px;font-weight:600;color:var(--vava-text);margin:0 0 12px}.btn{display:inline-flex;align-items:center;gap:6px;font-family:inherit;font-size:14px;font-weight:500;padding:9px 18px;border-radius:6px;cursor:pointer;border:1px solid transparent;transition:background .1s,border-color .1s,color .1s;line-height:1;text-decoration:none;white-space:nowrap}.btn-primary{background:var(--vava-tan);color:#fff}.btn-primary:hover{background:var(--vava-tan-hover)}.btn-primary:disabled{background:var(--vava-tan-light);cursor:not-allowed}.btn-secondary{background:transparent;color:var(--vava-tan-hover);border-color:var(--vava-border)}.btn-secondary:hover{background:#bda79314;border-color:var(--vava-tan)}.btn-ghost{background:transparent;color:var(--vava-text);border-color:transparent}.btn-ghost:hover{background:#bda7931a}.btn-danger{background:var(--vava-red);color:#fff}.btn-sm{padding:6px 12px;font-size:13px}.vava-input,.vava-select,.vava-textarea{font-family:inherit;font-size:14px;width:100%;padding:10px 12px;background:#fff;border:1px solid var(--vava-border);border-radius:6px;color:var(--vava-text);transition:border-color .1s,box-shadow .1s}.vava-input:focus,.vava-select:focus,.vava-textarea:focus{outline:none;border-color:var(--vava-tan);box-shadow:0 0 0 3px var(--vava-tan-tint)}.vava-label{display:block;font-size:12px;font-weight:600;color:var(--vava-text-muted);margin-bottom:6px;letter-spacing:.02em;text-transform:uppercase}.vava-textarea{min-height:96px;resize:vertical;font-family:inherit}.vava-alert{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;border-radius:8px;margin-bottom:10px;font-size:14px;border:1px solid}.vava-alert.amber{background:var(--vava-amber-bg);border-color:var(--vava-amber-border);color:var(--vava-amber)}.vava-alert.red{background:var(--vava-red-bg);border-color:#ffd1d1;color:var(--vava-red-text)}.vava-alert.green{background:var(--vava-green-bg);border-color:#bbf7d0;color:var(--vava-green-text)}.vava-alert .left{display:flex;align-items:center;gap:10px}.vava-alert .action{color:inherit;font-weight:600;cursor:pointer;text-decoration:none;white-space:nowrap}.vava-alert .action:hover{text-decoration:underline}.prio{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px;letter-spacing:.03em;font-family:var(--vava-mono, inherit)}.prio-P0{background:var(--vava-red-bg);color:var(--vava-red-text)}.prio-P1{background:var(--vava-amber-bg);color:var(--vava-amber)}.prio-P2{background:#f5f5f5;color:var(--vava-text-muted)}.status{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:3px 10px;border-radius:999px;border:1px solid transparent;font-weight:500}.status .dot{width:6px;height:6px;border-radius:50%}.status-待开始{background:#f5f5f5;color:var(--vava-text-muted)}.status-待开始 .dot{background:#a1a1a1}.status-进行中{background:#dbeafe;color:#1c398e}.status-进行中 .dot{background:#3b82f6}.status-阻塞{background:var(--vava-red-bg);color:var(--vava-red-text)}.status-阻塞 .dot{background:var(--vava-red)}.status-已完成{background:var(--vava-green-bg);color:var(--vava-green-text)}.status-已完成 .dot{background:var(--vava-green)}.status-已取消{background:#f5f5f5;color:#a1a1a1;text-decoration:line-through}.status-已取消 .dot{background:#d4d4d4}.cat-tag{display:inline-block;font-size:11px;padding:2px 8px;background:#f5f5f5;color:var(--vava-text-muted);border-radius:4px;border:1px solid var(--vava-border)}.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;align-items:start}.kanban-col{background:#e8e0d859;border:1px solid var(--vava-border-soft);border-radius:8px;padding:12px;min-height:200px}.kanban-col-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:0 2px}.kanban-col-title{font-size:13px;font-weight:600;color:var(--vava-text);display:flex;align-items:center;gap:8px}.kanban-col-count{background:#fff;color:var(--vava-text-muted);font-size:11px;padding:1px 8px;border-radius:10px;border:1px solid var(--vava-border);font-weight:600}.kanban-cards{display:flex;flex-direction:column;gap:8px}.task-card{background:#fff;border:1px solid var(--vava-border);border-radius:7px;padding:12px;cursor:pointer;transition:border-color .1s,transform .05s;display:flex;flex-direction:column;gap:8px;position:relative}.task-card:hover{border-color:var(--vava-tan)}.task-card:active{transform:scale(.995)}.task-card.overdue{border-left:3px solid var(--vava-red)}.task-card.blocked{opacity:.6;background:repeating-linear-gradient(-45deg,var(--vava-surface),var(--vava-surface) 8px,var(--vava-border-soft) 8px,var(--vava-border-soft) 9px)}.task-card.blocked .task-card-title{color:var(--vava-text-muted)}.dep-hint-inline{font-size:11px;color:var(--vava-amber);font-style:italic;margin-top:2px;display:block;width:100%}.task-card-header{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.task-card-title{font-size:13px;font-weight:600;color:var(--vava-text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.task-card-meta{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--vava-text-muted);padding-top:6px;border-top:1px solid var(--vava-border-soft)}.task-card-meta .due{display:inline-flex;gap:4px;align-items:center}.task-card-meta .due.overdue-text{color:var(--vava-red);font-weight:600}.vava-table{width:100%;border-collapse:collapse;font-size:13px}.vava-table th,.vava-table td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--vava-border-soft)}.vava-table th{font-weight:600;color:var(--vava-text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--vava-border);background:#e8e0d833}.vava-table tr:hover td{background:#bda7930d;cursor:pointer}.vava-table tr.highlight td{background:#dd33270a}.kpi-strip{display:flex;gap:24px;padding:12px 0 20px;border-bottom:1px solid var(--vava-border-soft);margin-bottom:20px;flex-wrap:wrap}.kpi-item{display:flex;align-items:center;gap:8px;font-size:13px}.kpi-item .n{font-weight:700;color:var(--vava-text);font-size:16px}.kpi-item .l{color:var(--vava-text-muted)}.kpi-dot{width:8px;height:8px;border-radius:50%}.kpi-card{background:#fff;border:1px solid var(--vava-border);border-radius:8px;padding:20px 22px;display:flex;flex-direction:column;gap:4px}.kpi-card .label{color:var(--vava-text-muted);font-size:13px}.kpi-card .big{font-size:36px;font-weight:700;color:var(--vava-text);letter-spacing:-.02em;line-height:1.1}.kpi-card .sub{color:var(--vava-text-muted);font-size:12px;margin-top:6px;display:flex;gap:14px}.view-toggle{display:inline-flex;background:#fff;border:1px solid var(--vava-border);border-radius:7px;padding:3px;gap:2px}.view-toggle button{border:none;background:transparent;color:var(--vava-text-muted);padding:5px 12px;border-radius:5px;cursor:pointer;font-size:13px;font-weight:500;font-family:inherit}.view-toggle button.active{background:var(--vava-tan);color:#fff}.filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:16px}.chip{padding:5px 12px;background:#fff;border:1px solid var(--vava-border);border-radius:999px;font-size:12px;color:var(--vava-text);cursor:pointer;font-family:inherit}.chip:hover{border-color:var(--vava-tan)}.chip.active{background:var(--vava-tan);color:#fff;border-color:var(--vava-tan)}.progress-bar{width:80px;height:6px;background:#f5f5f5;border-radius:999px;overflow:hidden;display:inline-block;vertical-align:middle;margin-right:6px}.progress-bar .fill{height:100%;background:var(--vava-tan);border-radius:999px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--vava-bg)}.login-card{width:100%;max-width:420px}.login-logo{text-align:center;margin-bottom:32px}.login-logo .word{font-size:32px;font-weight:700;letter-spacing:.02em}.login-logo .sub{font-size:10px;letter-spacing:.3em;color:var(--vava-text-subtle);margin-top:4px;text-transform:uppercase}.login-logo .system{font-size:14px;color:var(--vava-text-muted);margin-top:18px}.login-form{background:#fff;border:1px solid var(--vava-border);border-radius:8px;padding:32px}.login-footer{text-align:center;margin-top:28px;color:var(--vava-text-subtle);font-size:12px}.login-error{color:var(--vava-red);font-size:12px;margin-top:8px;display:flex;align-items:center;gap:6px}.detail-back{display:inline-flex;align-items:center;gap:6px;color:var(--vava-text-muted);cursor:pointer;background:none;border:none;font-family:inherit;font-size:13px;padding:4px 0;margin-bottom:12px;white-space:nowrap;width:auto;max-width:max-content}.detail-back:hover{color:var(--vava-text)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:20px}.detail-row{display:flex;gap:12px;padding:8px 0;border-bottom:1px solid var(--vava-border-soft);font-size:13px}.detail-row .label{color:var(--vava-text-muted);width:80px;flex-shrink:0}.detail-row .value{color:var(--vava-text);font-weight:500}.update-list{display:flex;flex-direction:column;gap:14px;margin-top:16px}.update-item{border-left:2px solid var(--vava-tan);padding-left:12px}.update-item .time{font-size:11px;color:var(--vava-text-muted);font-family:var(--vava-mono, inherit);margin-bottom:4px}.update-item .text{font-size:13px;line-height:1.6;color:var(--vava-text)}.toast{position:fixed;bottom:24px;right:24px;background:var(--vava-text);color:#fff;padding:12px 18px;border-radius:8px;font-size:13px;box-shadow:0 8px 24px #0000002e;z-index:100;animation:toastIn .2s ease}.toast.success{background:var(--vava-green)}.toast.error{background:var(--vava-red)}@keyframes toastIn{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.empty-state{text-align:center;padding:48px 24px;color:var(--vava-text-muted)}.empty-state .emoji{font-size:40px;margin-bottom:12px}.empty-state .title{font-size:16px;font-weight:600;color:var(--vava-text);margin-bottom:6px}.empty-state .sub{font-size:13px;margin-bottom:16px}.skeleton{background:linear-gradient(90deg,#e8e0d866 25%,#e8e0d8b3,#e8e0d866 75%);background-size:200% 100%;animation:skeletonShimmer 1.4s infinite;border-radius:4px}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.modal-backdrop{position:fixed;inset:0;background:#33333380;display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal{background:#fff;border-radius:10px;padding:28px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 16px 40px #0003}.modal-title{font-size:20px;font-weight:700;margin:0 0 18px}@media(max-width:1024px){.vava-shell{grid-template-columns:56px 1fr}.vava-sidebar{padding:16px 8px}.vava-nav-item{justify-content:center;padding:10px 0}.vava-nav-item span:not(.icon-wrap){display:none}.vava-brand-word,.vava-brand-sub,.vava-sidebar-footer{display:none}.detail-grid{grid-template-columns:1fr}.kanban{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.vava-shell{grid-template-columns:1fr;grid-template-rows:1fr auto}.vava-sidebar{position:fixed;inset:auto 0 0;height:auto;flex-direction:row;padding:6px 4px;border-top:1px solid var(--vava-border);border-right:none;z-index:40;justify-content:space-around}.vava-brand{display:none}.vava-nav{flex-direction:row;justify-content:space-around;flex:1;gap:0}.vava-nav-item{padding:8px 6px;flex-direction:column;font-size:10px;gap:2px}.vava-nav-item .icon{width:20px;height:20px}.vava-nav-item span:not(.icon-wrap){display:block;font-size:10px}.vava-sidebar-footer{display:none}.vava-main{padding:16px 16px 80px;max-width:100%}.vava-page-title{font-size:24px}.kanban{grid-template-columns:1fr}.kpi-strip{gap:12px}.kpi-item .l{display:none}.detail-grid{grid-template-columns:1fr}.login-form{padding:24px}}.avatar{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--vava-tan);color:#fff;font-size:12px;font-weight:700;letter-spacing:-.01em;flex-shrink:0;font-family:Inter,sans-serif}.avatar-unknown{background:#d4d4d4;color:#777}.project-list{display:flex;flex-direction:column;gap:10px}.project-row{background:#fff;border:1px solid var(--vava-border);border-radius:8px;overflow:hidden}.project-header{display:flex;align-items:center;gap:12px;padding:14px 18px;cursor:pointer;user-select:none}.project-header:hover{background:#bda7930a}.project-chevron{color:var(--vava-text-muted);font-size:14px;width:16px;text-align:center;flex-shrink:0}.project-main{flex:1;min-width:0}.project-title-row{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}.project-title{font-size:15px;font-weight:600;margin:0;color:var(--vava-text)}.project-overdue-badge{font-size:11px;background:var(--vava-red-bg);color:var(--vava-red-text);padding:2px 8px;border-radius:4px;font-weight:600}.project-meta{font-size:12px;color:var(--vava-text-muted);display:flex;gap:10px;flex-wrap:wrap;align-items:center}.project-meta .avatar{width:18px;height:18px;font-size:10px;margin-left:2px;vertical-align:middle}.project-progress{display:flex;align-items:center;gap:10px;flex-shrink:0}.project-progress-text{font-weight:600;font-size:13px}.project-progress-pct{font-weight:600;font-size:13px;color:var(--vava-text-muted);min-width:38px;text-align:right}.project-subtasks{border-top:1px solid var(--vava-border-soft);background:#e8e0d826}.project-subtasks .vava-table th{background:transparent;border-bottom:1px solid var(--vava-border-soft)}.project-subtasks .vava-table tr:last-child td{border-bottom:none}.parent-link{background:#bda79314;border:1px solid var(--vava-border);border-radius:8px;padding:10px 14px;margin-bottom:14px;cursor:pointer;display:flex;flex-direction:column;gap:4px;transition:background .1s}.parent-link:hover{background:var(--vava-tan-tint);border-color:var(--vava-tan)}.parent-link-label{font-size:11px;color:var(--vava-text-muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase}.parent-link-main{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.parent-link-title{font-size:14px;font-weight:600;color:var(--vava-text)}.parent-link-owner{margin-left:auto;font-size:12px;color:var(--vava-text-muted);display:inline-flex;align-items:center;gap:4px}.raci-rail{display:flex;flex-direction:column;gap:12px}.raci-block{border-top:1px solid var(--vava-border-soft);padding-top:10px}.raci-block:first-child{border-top:none;padding-top:0}.raci-block-label{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--vava-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.raci-role-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;font-family:var(--vava-font-mono, monospace);font-size:10px;font-weight:700;letter-spacing:0}.raci-role-badge.role-R{background:#dd33271a;color:var(--vava-red)}.raci-role-badge.role-A{background:#874b001a;color:var(--vava-amber)}.raci-role-badge.role-C{background:var(--vava-tan-tint);color:var(--vava-tan-hover)}.raci-role-badge.role-I{background:var(--vava-border-soft);color:var(--vava-text-muted)}.raci-role-name{font-weight:600;color:var(--vava-text)}.raci-role-count{color:var(--vava-text-muted)}.raci-block-empty{font-size:12px;color:var(--vava-text-subtle);padding:4px 0}.raci-block-owners{display:flex;flex-direction:column;gap:6px}.multi-owner-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 6px;border-radius:6px;background:var(--vava-bg);font-size:12px}.multi-owner-name{flex:1;color:var(--vava-text);font-weight:500}.multi-owner-role{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:3px;font-family:var(--vava-font-mono, monospace);font-size:9px;font-weight:700}.multi-owner-role.role-R{background:#dd33271a;color:var(--vava-red)}.multi-owner-role.role-A{background:#874b001a;color:var(--vava-amber)}.multi-owner-role.role-C{background:var(--vava-tan-tint);color:var(--vava-tan-hover)}.multi-owner-role.role-I{background:var(--vava-border-soft);color:var(--vava-text-muted)}.raci-picker{display:flex;flex-direction:column;gap:12px}.raci-role-required{font-size:10px;color:var(--vava-red);background:var(--vava-red-bg);padding:1px 5px;border-radius:3px;text-transform:none;letter-spacing:0;font-weight:600}.multi-owner-pill-editable{background:var(--vava-surface);border:1px solid var(--vava-border)}.multi-owner-remove{background:none;border:none;color:var(--vava-text-muted);cursor:pointer;padding:2px;display:inline-flex;align-items:center;border-radius:3px}.multi-owner-remove:hover{color:var(--vava-red);background:var(--vava-red-bg)}.icon-sm{width:14px;height:14px}.raci-add-btn{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--vava-tan-hover);background:none;border:1px dashed var(--vava-border);border-radius:6px;padding:5px 10px;cursor:pointer;width:fit-content}.raci-add-btn:hover:not(:disabled){background:var(--vava-tan-tint);border-style:solid}.raci-add-btn:disabled{opacity:.5;cursor:not-allowed}.raci-add-select{max-width:100%;font-size:12px;padding:4px 8px}button:focus-visible,a:focus-visible,select:focus-visible,input:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--vava-tan);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
