:root{--font-sans:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono:ui-monospace, "SF Mono", Menlo, monospace;--text-xs:11px;--text-sm:12px;--text-base:13px;--text-md:14px;--text-lg:16px;--text-xl:20px;--text-2xl:22px;--leading-tight:1.25;--leading-normal:1.5;--color-bg:#f6f7f9;--color-surface:#fff;--color-surface-2:#f9fafb;--color-surface-hover:#f3f4f6;--color-border:#e5e7eb;--color-border-strong:#d1d5db;--color-divider:#f3f4f6;--color-text:#111827;--color-text-secondary:#374151;--color-text-muted:#6b7280;--color-text-subtle:#9ca3af;--color-text-inverse:#fff;--color-primary:#1d4ed8;--color-primary-hover:#1e40af;--color-primary-active:#1e3a8a;--color-primary-soft:#eff6ff;--color-primary-soft-border:#bfdbfe;--color-focus-ring:#1d4ed859;--color-success:#047857;--color-success-soft:#d1fae5;--color-warning:#b45309;--color-warning-soft:#fed7aa;--color-danger:#b91c1c;--color-danger-soft:#fee2e2;--color-danger-strong:#dc2626;--color-info:#0369a1;--color-info-soft:#e0f2fe;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-pill:999px;--shadow-xs:0 1px 2px #0f172a0a;--shadow-sm:0 1px 3px #0f172a0f, 0 1px 2px #0f172a0a;--shadow-md:0 4px 12px #0f172a14;--shadow-lg:0 10px 25px #0f172a1f;--topbar-h:56px;--sidebar-w:220px;--motion-fast:.12s ease;--motion-base:.18s ease;color:var(--color-text);background:var(--color-bg);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{flex-direction:column;min-height:100vh;margin:0;display:flex}.center-page{flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);width:100%;max-width:420px;box-shadow:var(--shadow-sm)}.card h1{margin:0 0 var(--space-4) 0;font-size:var(--text-xl);letter-spacing:-.01em;font-weight:700}label{font-size:var(--text-base);margin-bottom:var(--space-1);color:var(--color-text-secondary);font-weight:500;display:block}input,select,textarea{width:100%;padding:8px var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);font-size:var(--text-md);margin-bottom:var(--space-3);background:var(--color-surface);color:var(--color-text);font-family:inherit;line-height:var(--leading-normal);transition:border-color var(--motion-fast), box-shadow var(--motion-fast);display:block}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring);outline:none}input[aria-invalid=true],input.invalid,select.invalid,textarea.invalid{border-color:var(--color-danger)}input[aria-invalid=true]:focus,input.invalid:focus{box-shadow:0 0 0 3px #dc262633}button{padding:8px var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-primary);background:var(--color-primary);color:var(--color-text-inverse);font-size:var(--text-md);cursor:pointer;transition:background var(--motion-fast), border-color var(--motion-fast), box-shadow var(--motion-fast);justify-content:center;align-items:center;gap:6px;font-family:inherit;font-weight:500;display:inline-flex}button:hover:not([disabled]){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}button:focus-visible{box-shadow:0 0 0 3px var(--color-focus-ring);outline:none}button[disabled]{opacity:.55;cursor:not-allowed}button.secondary{background:var(--color-surface);color:var(--color-primary);border-color:var(--color-border-strong)}button.secondary:hover:not([disabled]){background:var(--color-primary-soft);border-color:var(--color-primary)}button.danger,.btn-danger{background:var(--color-danger-strong);border-color:var(--color-danger-strong);color:var(--color-text-inverse)}button.danger:hover:not([disabled]),.btn-danger:hover:not([disabled]){background:#b91c1c;border-color:#b91c1c}button.ghost,.btn-ghost{color:var(--color-text-secondary);background:0 0;border-color:#0000}button.ghost:hover:not([disabled]),.btn-ghost:hover:not([disabled]){background:var(--color-surface-hover);color:var(--color-text)}.btn-loading:before{content:"";border:2px solid;border-right-color:#0000;border-radius:50%;width:12px;height:12px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.error{color:var(--color-danger);background:var(--color-danger-soft);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-base);margin-bottom:var(--space-3);border:1px solid #fecaca}.muted{color:var(--color-text-muted);font-size:var(--text-base)}.row{gap:var(--space-3);justify-content:space-between;align-items:center;display:flex}.app-shell{min-height:100vh}.topbar{height:var(--topbar-h);background:var(--color-surface);border-bottom:1px solid var(--color-border);align-items:center;gap:var(--space-4);padding:0 var(--space-5);z-index:10;box-shadow:var(--shadow-xs);display:flex;position:fixed;top:0;left:0;right:0}.topbar-brand{align-items:center;gap:var(--space-2);color:var(--color-text);font-weight:700;font-size:var(--text-lg);letter-spacing:-.01em;flex-shrink:0;text-decoration:none;display:inline-flex}.topbar-brand-mark{background:var(--color-primary);width:28px;height:28px;color:var(--color-text-inverse);border-radius:var(--radius-md);font-weight:700;font-size:var(--text-sm);letter-spacing:0;justify-content:center;align-items:center;display:inline-flex}.topbar-brand-text{line-height:1}.topbar-title{font-weight:600;font-size:var(--text-lg);color:var(--color-text)}.topbar-spacer{flex:1}.topbar-user{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.topbar-user .muted{color:var(--color-text-muted);font-size:var(--text-base)}.role-pill{border-radius:var(--radius-pill);background:var(--color-primary-soft);color:var(--color-primary-active);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;margin-left:6px;padding:2px 8px;font-weight:600;display:inline-block}.sidebar{top:var(--topbar-h);width:var(--sidebar-w);background:var(--color-surface);border-right:1px solid var(--color-border);padding:var(--space-3) 0;position:fixed;bottom:0;left:0;overflow-y:auto}.sidebar nav{padding:0 var(--space-2);flex-direction:column;gap:2px;display:flex}.nav-link{align-items:center;gap:var(--space-2);padding:9px var(--space-3);color:var(--color-text-secondary);font-size:var(--text-md);border-radius:var(--radius-md);transition:background var(--motion-fast), color var(--motion-fast);border-left:3px solid #0000;text-decoration:none;display:flex}.nav-link:hover{background:var(--color-surface-hover);color:var(--color-text)}.nav-link.active{background:var(--color-primary-soft);color:var(--color-primary);border-left-color:var(--color-primary);font-weight:600}.nav-link.active:hover{background:var(--color-primary-soft);color:var(--color-primary-active)}.nav-link.disabled{color:var(--color-text-subtle);cursor:not-allowed}.nav-link.disabled:hover{color:var(--color-text-subtle);background:0 0}.wip{font-size:var(--text-xs);background:var(--color-surface-hover);color:var(--color-text-muted);border-radius:var(--radius-pill);margin-left:auto;padding:1px 6px;font-weight:500;display:inline-block}.content{margin-left:var(--sidebar-w);margin-top:var(--topbar-h);padding:var(--space-6);min-height:calc(100vh - var(--topbar-h))}.page-header{align-items:center;gap:var(--space-4);margin-bottom:var(--space-5);flex-wrap:wrap;display:flex}.page-header h1{font-size:var(--text-2xl);letter-spacing:-.01em;margin:0;font-weight:700}.page-header .muted{font-size:var(--text-md)}.page-header-actions{gap:var(--space-2);flex-wrap:wrap;margin-left:auto;display:flex}.filters-row{gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap;align-items:center;display:flex}.filter-input,.filter-select{padding:7px var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);font-size:var(--text-md);background:var(--color-surface);width:auto;min-width:200px;transition:border-color var(--motion-fast), box-shadow var(--motion-fast);margin-bottom:0}.filter-input:focus,.filter-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring);outline:none}.filter-select{min-width:160px}.table-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:var(--text-base)}.data-table th,.data-table td{text-align:left;padding:11px var(--space-3);border-bottom:1px solid var(--color-divider);white-space:nowrap}.data-table thead th{background:var(--color-surface-2);color:var(--color-text-secondary);font-weight:600;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border);z-index:1;position:sticky;top:0}.data-table tbody tr{transition:background var(--motion-fast)}.data-table tbody tr:hover{background:var(--color-surface-2)}.data-table tbody tr:last-child td{border-bottom:0}.data-table a{color:var(--color-primary);text-decoration:none}.data-table a:hover{text-decoration:underline}.cell-truncate{text-overflow:ellipsis;max-width:220px;overflow:hidden}.cell-num{text-align:right;font-variant-numeric:tabular-nums}.pagination{justify-content:center;align-items:center;gap:var(--space-4);margin-top:var(--space-4);font-size:var(--text-base);color:var(--color-text-muted);display:flex}.pagination button{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border-strong)}.pagination button:hover:not([disabled]){background:var(--color-surface-hover)}.badge{border-radius:var(--radius-pill);font-size:var(--text-sm);white-space:nowrap;letter-spacing:.01em;padding:2px 9px;font-weight:600;line-height:1.4;display:inline-block}.badge-green{color:#065f46;background:#d1fae5}.badge-blue{color:#1e3a8a;background:#dbeafe}.badge-orange{color:#7c2d12;background:#fed7aa}.badge-red{color:#991b1b;background:#fee2e2}.badge-gray{color:#1f2937;background:#e5e7eb}.kanban-row{gap:var(--space-4);padding:var(--space-4) 0;display:flex;overflow-x:auto}.kanban-column{background:var(--color-surface-2);border-radius:var(--radius-lg);min-width:290px;padding:var(--space-2);border:1px solid var(--color-border);flex:0 0 290px;max-height:calc(100vh - 240px);overflow-y:auto}.kanban-column-header{font-weight:600;font-size:var(--text-md);padding:var(--space-2);border-bottom:1px solid var(--color-border);background:var(--color-surface-2);z-index:1;color:var(--color-text-secondary);position:sticky;top:0}.kanban-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);margin-bottom:var(--space-2);cursor:grab;transition:box-shadow var(--motion-fast), transform var(--motion-fast);box-shadow:var(--shadow-xs)}.kanban-card:hover{box-shadow:var(--shadow-sm)}.kanban-card:active{cursor:grabbing}.kanban-card-title{font-weight:600;font-size:var(--text-base);line-height:var(--leading-tight);word-break:break-word;color:var(--color-text);margin-bottom:6px}.kanban-card-labels{flex-wrap:wrap;gap:4px;margin-bottom:6px;display:flex}.kanban-card-meta{align-items:center;gap:var(--space-2);margin-top:6px;display:flex}.kanban-card-checklist{font-size:var(--text-xs);color:var(--color-text-muted);flex:1;align-items:center;gap:4px;display:flex}.kanban-progress{background:var(--color-border);border-radius:2px;flex:1;min-width:40px;height:4px;overflow:hidden}.kanban-progress-bar{background:var(--color-primary);height:100%;transition:width var(--motion-base)}.kanban-due{font-size:var(--text-xs);color:var(--color-text-muted)}.kanban-due.past{color:var(--color-danger);font-weight:600}.kanban-card-members{gap:4px;margin-top:6px;display:flex}.member-avatar{background:var(--color-primary-soft);width:22px;height:22px;color:var(--color-primary-active);font-size:var(--text-xs);border:1px solid var(--color-primary-soft-border);border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.modal-overlay{z-index:100;padding:var(--space-6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);width:100%;max-width:640px;max-height:calc(100vh - 48px);box-shadow:var(--shadow-lg);flex-direction:column;display:flex;position:relative;overflow:hidden}.modal-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.modal-header h2,.modal-header h3{font-size:var(--text-lg);margin:0;font-weight:600}.modal-body{padding:var(--space-4) var(--space-5);overflow-y:auto}.modal-footer{justify-content:flex-end;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-top:1px solid var(--color-border);background:var(--color-surface-2);display:flex}.modal-description{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:var(--text-base);white-space:pre-wrap;word-break:break-word;color:var(--color-text-secondary)}.trello-link{padding:6px var(--space-3);border-radius:var(--radius-md);background:var(--color-primary);color:var(--color-text-inverse);font-size:var(--text-md);text-decoration:none;display:inline-block}.trello-link:hover{background:var(--color-primary-hover)}.match-link,.short-code-chip{border-radius:var(--radius-pill);background:var(--color-primary-soft);color:var(--color-primary);font-size:var(--text-sm);border:1px solid var(--color-primary-soft-border);font-weight:600;font-family:var(--font-mono);letter-spacing:.02em;transition:background var(--motion-fast);padding:2px 9px;text-decoration:none;display:inline-block}.match-link:hover,.short-code-chip:hover{background:#dbeafe;text-decoration:none}.short-code-chip.muted{background:var(--color-surface-hover);color:var(--color-text-muted);border-color:var(--color-border)}.detail-grid{gap:var(--space-4);margin-bottom:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));display:grid}.detail-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);margin-bottom:var(--space-4);box-shadow:var(--shadow-xs)}.detail-section-title{margin:0 0 var(--space-3) 0;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:1px solid var(--color-divider);padding-bottom:var(--space-2);font-weight:700}.detail-section-body{gap:var(--space-2);flex-direction:column;display:flex}.detail-field{gap:var(--space-3);font-size:var(--text-base);flex-direction:row;align-items:baseline;padding:3px 0;display:flex}.detail-field-label{color:var(--color-text-muted);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.03em;flex:0 0 140px;font-weight:500}.detail-field-value{color:var(--color-text);word-break:break-word;line-height:var(--leading-normal);flex:1}.chip-row{flex-wrap:wrap;gap:6px;display:flex}.chip{border-radius:var(--radius-pill);background:var(--color-surface-hover);color:var(--color-text-secondary);font-size:var(--text-sm);border:1px solid var(--color-border);padding:2px 10px;font-weight:500;display:inline-block}.detail-pre{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);font-size:var(--text-base);white-space:pre-wrap;word-break:break-word;font-family:var(--font-mono);color:var(--color-text-secondary);line-height:var(--leading-normal);margin:0}.action-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin:.75rem 0;display:flex}.checklist-list{margin:0;padding:0;list-style:none}.checklist-item{border-bottom:1px solid #f3f4f6;align-items:center;gap:.5rem;padding:.4rem 0;display:flex}.checklist-item.done{opacity:.6}.checklist-item.done span{text-decoration:line-through}.vault-secret{background:#fef3c7;border-radius:4px;margin-top:.25rem;padding:.5rem;font-family:ui-monospace,SF Mono,Menlo,monospace;display:inline-block}.vault-countdown{color:#92400e;margin-left:.5rem;font-size:.75rem}.activity-list{margin:0;padding:0;list-style:none}.activity-list li{border-bottom:1px solid #f3f4f6;align-items:baseline;gap:1rem;padding:.4rem 0;font-size:.9rem;display:flex}.activity-list time{color:#6b7280;flex-shrink:0;min-width:8rem}.activity-list .user{color:#4b5563;flex-shrink:0;min-width:6rem}.modal-close{top:var(--space-3);right:var(--space-3);cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-md);transition:background var(--motion-fast), color var(--motion-fast);background:0 0;border:0;padding:4px 8px;font-size:22px;line-height:1;position:absolute}.modal-close:hover{background:var(--color-surface-hover);color:var(--color-text)}.autocomplete{position:relative}.autocomplete-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:10;max-height:220px;box-shadow:var(--shadow-md);margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.autocomplete-option{padding:var(--space-2) var(--space-3);cursor:pointer;border-bottom:1px solid var(--color-divider);font-size:var(--text-base)}.autocomplete-option:last-child{border-bottom:none}.autocomplete-option:hover{background:var(--color-surface-hover)}.selected-pill{align-items:center;gap:var(--space-2);background:var(--color-primary-soft);color:var(--color-primary-active);padding:3px var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-base);margin-bottom:var(--space-2);border:1px solid var(--color-primary-soft-border);font-weight:500;display:inline-flex}.selected-pill button{cursor:pointer;color:inherit;font-size:var(--text-lg);background:0 0;border:none;padding:0;line-height:1}.form-field{margin-bottom:var(--space-4)}.form-field label{font-size:var(--text-base);margin-bottom:var(--space-1);color:var(--color-text-secondary);font-weight:500;display:block}.banner-success{background:var(--color-success-soft);color:var(--color-success);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin:var(--space-4) 0;font-size:var(--text-md);border:1px solid #a7f3d0}.banner-error{background:var(--color-danger-soft);color:var(--color-danger);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin:var(--space-4) 0;font-size:var(--text-md);border:1px solid #fecaca}.scrape-actions{flex-wrap:wrap;gap:.5rem;margin:1rem 0;display:flex}.scrape-actions button{padding:.5rem 1rem}.error-list{color:#991b1b;margin:.25rem 0 0;padding-left:1.25rem;font-size:.85rem}@keyframes pulse-blue{0%,to{opacity:1}50%{opacity:.6}}.badge-blue.pulse{animation:1.5s ease-in-out infinite pulse-blue}.map-embed{border:1px solid #e5e7eb;border-radius:6px;margin-top:.75rem;overflow:hidden}.map-embed iframe{border:0;width:100%;display:block}.search-bar{flex:0 360px;margin:0;position:relative}.search-bar input{width:100%;padding:7px var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);font-size:var(--text-md);background:var(--color-surface-2);transition:border-color var(--motion-fast), background var(--motion-fast), box-shadow var(--motion-fast);margin-bottom:0}.search-bar input:focus{border-color:var(--color-primary);background:var(--color-surface);box-shadow:0 0 0 3px var(--color-focus-ring);outline:none}.search-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);z-index:50;max-height:420px;box-shadow:var(--shadow-md);position:absolute;top:calc(100% + 6px);left:0;right:0;overflow-y:auto}.search-section{padding:var(--space-2) 0;border-bottom:1px solid var(--color-divider)}.search-section:last-child{border-bottom:0}.search-section-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);padding:0 var(--space-3) 4px var(--space-3);font-weight:700}.search-hit{padding:6px var(--space-3);cursor:pointer;font-size:var(--text-md);color:var(--color-text);transition:background var(--motion-fast)}.search-hit:hover{background:var(--color-surface-hover)}.search-empty{padding:var(--space-4);text-align:center;color:var(--color-text-muted);font-size:var(--text-md)}.hamburger{cursor:pointer;color:#374151;background:0 0;border:0;padding:0 .75rem;font-size:1.5rem;line-height:1;display:none}.sidebar-backdrop{display:none}@media (width<=768px){.hamburger{justify-content:center;align-items:center;height:40px;display:inline-flex}.topbar{padding:0 var(--space-2);gap:var(--space-2);height:auto;min-height:var(--topbar-h);flex-wrap:wrap;position:sticky;top:0;left:auto;right:auto}.topbar-brand-text{display:none}.topbar-user{gap:var(--space-2)}.topbar-user .role-pill{display:none}.topbar-user .muted{font-size:var(--text-base)}.topbar-spacer{display:none}.search-bar{max-width:none;margin:0 0 var(--space-2) 0;flex-basis:100%;order:99}.sidebar{height:100vh;transition:transform var(--motion-base);z-index:60;box-shadow:var(--shadow-lg);top:0;transform:translate(-100%)}.app-shell[data-mobile-nav=open] .sidebar{transform:translate(0)}.sidebar-backdrop{z-index:50;opacity:0;pointer-events:none;transition:opacity var(--motion-base);background:#0f172a66;display:block;position:fixed;inset:0}.app-shell[data-mobile-nav=open] .sidebar-backdrop{opacity:1;pointer-events:auto}.content{padding:var(--space-4) var(--space-3);margin-top:0;margin-left:0}.page-header{gap:var(--space-2);flex-wrap:wrap}.page-header h1{font-size:var(--text-xl)}.page-header-actions{width:100%;margin-left:0}.filters-row{gap:6px}.filters-row .filter-input,.filters-row .filter-select{flex:calc(50% - 6px);min-width:0}.modal-overlay{padding:var(--space-2)}.modal-content{max-width:100%}.modal-header,.modal-body{padding:var(--space-3) var(--space-4)}.modal-footer{padding:var(--space-2) var(--space-4)}.detail-grid{grid-template-columns:1fr}.detail-field{flex-direction:column;align-items:flex-start;gap:2px}.detail-field-label{flex:none}.activity-list li{gap:4px var(--space-2);flex-wrap:wrap}.activity-list time{min-width:auto;font-size:var(--text-sm)}.activity-list .user{min-width:auto}.detail-section{padding:var(--space-3) var(--space-3)}.notif-dropdown{width:calc(100vw - var(--space-4));right:var(--space-2)}.data-table{font-size:var(--text-sm)}.data-table th,.data-table td{padding:8px var(--space-2)}.kpi-table{font-size:var(--text-sm)}}.kpi-table th,.kpi-table td{vertical-align:top}.kpi-cell{min-width:140px;padding:6px var(--space-2)}.kpi-cell-inner{align-items:flex-start;gap:4px;display:flex}.kpi-cell-btn{text-align:left;cursor:pointer;border-radius:var(--radius-sm);color:inherit;font-size:inherit;background:0 0;border:0;flex:1;padding:4px}.kpi-cell-btn:hover{background:var(--color-surface-hover)}.kpi-cell-text{font-size:var(--text-base);color:var(--color-text);margin-bottom:4px;font-weight:500}.kpi-bar-track{background:var(--color-border);border-radius:3px;width:100%;height:6px;overflow:hidden}.kpi-bar-fill{height:100%;transition:width var(--motion-base)}.kpi-bar-green{background:#10b981}.kpi-bar-blue{background:#3b82f6}.kpi-bar-orange{background:#f59e0b}.kpi-bar-red{background:#ef4444}.kpi-bar-gray{background:var(--color-text-subtle)}.kpi-edit-btn{cursor:pointer;font-size:var(--text-md);color:var(--color-text-muted);background:0 0;border:0;padding:2px 4px}.kpi-edit-btn:hover{color:var(--color-text);background:var(--color-surface-hover);border-radius:var(--radius-sm)}.kpi-edit-form{align-items:center;gap:4px;display:flex}.kpi-edit-form input{width:60px;font-size:var(--text-sm);margin-bottom:0;padding:2px 4px}.kpi-edit-save{font-size:var(--text-sm);cursor:pointer;padding:2px 6px}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg, var(--color-border) 0%, var(--color-divider) 50%, var(--color-border) 100%);border-radius:var(--radius-sm);background-size:200% 100%;height:12px;animation:1.4s ease-in-out infinite skeleton-shimmer;display:inline-block}.skeleton-table{gap:var(--space-2);padding:var(--space-3);flex-direction:column;display:flex}.skeleton-row{gap:var(--space-3);align-items:center;padding:6px 0;display:flex}.skeleton-row .skeleton:first-child{flex:0 0 18%;height:14px}.skeleton-row .skeleton:nth-child(2){flex:0 0 32%;height:14px}.skeleton-row .skeleton:nth-child(3){flex:0 0 18%;height:14px}.skeleton-row .skeleton:nth-child(4){flex:1;height:14px}.skeleton-card{padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-2)}.empty-state{text-align:center;padding:var(--space-10) var(--space-4);color:var(--color-text-muted);background:var(--color-surface);border:1px dashed var(--color-border);border-radius:var(--radius-lg)}.empty-state-compact{padding:var(--space-3) var(--space-2);background:0 0;border:0}.empty-state-compact .empty-icon{margin-bottom:4px;font-size:20px}.empty-state-compact .empty-title{font-size:var(--text-md);margin-bottom:0}.empty-state-compact .empty-body{font-size:var(--text-base);margin:4px auto 0}.empty-icon{margin-bottom:var(--space-3);opacity:.7;font-size:40px}.empty-title{font-size:var(--text-lg);color:var(--color-text-secondary);margin-bottom:6px;font-weight:600}.empty-body{font-size:var(--text-md);max-width:420px;margin:0 auto var(--space-4);line-height:var(--leading-normal)}.empty-action{background:var(--color-primary);color:var(--color-text-inverse);padding:8px var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-primary);cursor:pointer;font-size:var(--text-md);font-weight:500}.empty-action:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.error-boundary{max-width:520px;margin:var(--space-10) auto;padding:var(--space-8);text-align:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.error-boundary h2{color:var(--color-danger);margin:0 0 var(--space-2) 0;font-size:var(--text-xl)}.error-boundary p{color:var(--color-text-muted);margin:0 0 var(--space-4) 0;font-size:var(--text-md)}.error-boundary button{margin-top:var(--space-3);background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-inverse);padding:8px var(--space-5);border-radius:var(--radius-md);cursor:pointer}.error-boundary button:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.dashboard-grid{gap:var(--space-4);margin-top:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.dashboard-tile{padding:var(--space-5);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:inherit;box-shadow:var(--shadow-xs);transition:box-shadow var(--motion-base), transform var(--motion-base), border-color var(--motion-base);text-decoration:none;display:block}.dashboard-tile:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-soft-border);transform:translateY(-1px)}.dashboard-tile-icon{margin-bottom:var(--space-2);font-size:28px}.dashboard-tile-title{font-weight:600;font-size:var(--text-md);margin-bottom:4px}.dashboard-tile-body{font-size:var(--text-base);color:var(--color-text-muted);line-height:var(--leading-normal)}.bell-wrap{position:relative}.bell-btn{font-size:var(--text-lg);cursor:pointer;padding:6px var(--space-2);color:var(--color-text-secondary);border-radius:var(--radius-md);transition:background var(--motion-fast), color var(--motion-fast);background:0 0;border:0;position:relative}.bell-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.bell-badge{background:var(--color-danger-strong);color:var(--color-text-inverse);border-radius:var(--radius-pill);text-align:center;border:2px solid var(--color-surface);min-width:16px;padding:1px 5px;font-size:10px;font-weight:700;line-height:1.2;position:absolute;top:2px;right:2px}.notif-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:360px;box-shadow:var(--shadow-md);z-index:50;max-height:420px;position:absolute;top:calc(100% + 6px);right:0;overflow-y:auto}.notif-empty{padding:var(--space-5);text-align:center;color:var(--color-text-muted);font-size:var(--text-md)}.notif-item{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-divider);cursor:pointer;gap:var(--space-2);transition:background var(--motion-fast);display:flex}.notif-item:hover{background:var(--color-surface-2)}.notif-item.unread{background:var(--color-primary-soft)}.notif-item.unread:hover{background:#dbeafe}.notif-item:last-child{border-bottom:0}.notif-icon{flex-shrink:0;font-size:16px;line-height:1.4}.notif-content{flex:1;min-width:0}.notif-title{font-weight:600;font-size:var(--text-md);color:var(--color-text)}.notif-body{font-size:var(--text-base);color:var(--color-text-muted);line-height:var(--leading-normal);margin-top:2px}.notif-time{font-size:var(--text-xs);color:var(--color-text-subtle);margin-top:4px}.notif-footer{padding:var(--space-2) var(--space-3);border-top:1px solid var(--color-border);text-align:center;background:var(--color-surface-2)}.link-btn{color:var(--color-primary);cursor:pointer;font-size:var(--text-base);border-radius:var(--radius-sm);background:0 0;border:0;padding:4px 8px;font-weight:500}.link-btn:hover{background:var(--color-primary-soft);text-decoration:none}.link-btn:disabled{opacity:.5;cursor:not-allowed;background:0 0}.kpi-table{width:100%;min-width:800px}.kpi-table thead th{z-index:5;background:#f9fafb;position:sticky;top:0;box-shadow:inset 0 -1px #e5e7eb}.kpi-table tbody th{z-index:4;white-space:nowrap;background:#fff;position:sticky;left:0;box-shadow:inset -1px 0 #e5e7eb}.kpi-table tbody tr:hover th{background:#f9fafb}.kanban-column.drag-over{background:var(--color-primary-soft);outline:2px dashed var(--color-primary);outline-offset:-4px}
