@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Prompt:wght@300;400;500;600;700&display=swap";:root{--font-sans:"Plus Jakarta Sans", "Prompt", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px -2px #0000000d;--shadow-md:0 4px 20px -4px #00000014, 0 2px 8px -2px #0000000a;--shadow-lg:0 10px 32px -4px #0000001f, 0 4px 16px -4px #00000014;--shadow-glow:0 0 20px 0px #6366f133}:root,.light{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--bg-glass:#ffffffb3;--border-color:#e2e8f0cc;--border-glass:#fff9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--primary:#4f46e5;--primary-hover:#4338ca;--primary-light:#4f46e51a;--success:#10b981;--success-light:#10b9811a;--warning:#f59e0b;--warning-light:#f59e0b1a;--danger:#ef4444;--danger-light:#ef44441a;--info:#06b6d4;--info-light:#06b6d41a;--card-shadow:var(--shadow-md);--card-hover-shadow:var(--shadow-lg);--backdrop-blur:blur(12px)}.dark{--bg-primary:#0b0f19;--bg-secondary:#131b2e;--bg-tertiary:#1e293b;--bg-glass:#131b2eb3;--border-color:#1e293bcc;--border-glass:#ffffff0d;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--primary:#6366f1;--primary-hover:#4f46e5;--primary-light:#6366f126;--success:#10b981;--success-light:#10b98126;--warning:#fbbf24;--warning-light:#fbbf2426;--danger:#f87171;--danger-light:#f8717126;--info:#22d3ee;--info-light:#22d3ee26;--card-shadow:0 4px 30px #0006;--card-hover-shadow:0 10px 40px #0009, 0 0 25px #6366f126}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background-color var(--transition-normal), color var(--transition-normal);line-height:1.5;overflow-x:hidden}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-container{flex-direction:column;min-height:100vh;display:flex}.navbar{z-index:100;background:var(--bg-glass);-webkit-backdrop-filter:var(--backdrop-blur);border-bottom:1px solid var(--border-glass);transition:background var(--transition-normal), border var(--transition-normal);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.logo-section{align-items:center;gap:.75rem;display:flex}.logo-icon{background:linear-gradient(135deg, var(--primary), #ec4899);color:#fff;border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;font-weight:800;display:flex;box-shadow:0 4px 12px #6366f14d}.logo-text{background:linear-gradient(135deg, var(--text-primary), var(--text-secondary));-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;font-size:1.25rem;font-weight:700}.logo-tagline{color:var(--text-muted);font-size:.75rem;font-weight:500;display:block}.nav-controls{align-items:center;gap:1.5rem;display:flex}.role-switcher-container{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);align-items:center;padding:.25rem;display:flex}.role-tab{color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;display:flex}.role-tab:hover{color:var(--text-primary)}.role-tab.active{background:var(--bg-secondary);color:var(--primary);box-shadow:var(--shadow-sm)}.dark .role-tab.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-glow)}.theme-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-full);cursor:pointer;width:40px;height:40px;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.theme-btn:hover{background:var(--bg-secondary);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.main-content{width:100%;max-width:1600px;animation:fadeIn var(--transition-normal);flex:1;margin:0 auto;padding:2rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.kpi-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--card-shadow);transition:all var(--transition-normal);align-items:center;gap:1.25rem;padding:1.5rem;display:flex;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--card-hover-shadow);transform:translateY(-4px)}.kpi-card:before{content:"";background:var(--card-accent,var(--primary));width:4px;height:100%;position:absolute;top:0;left:0}.kpi-icon-wrapper{border-radius:var(--radius-md);background:var(--card-accent-light,var(--primary-light));width:54px;height:54px;color:var(--card-accent,var(--primary));justify-content:center;align-items:center;font-size:1.5rem;display:flex}.kpi-info h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem;font-size:.875rem;font-weight:600}.kpi-value{color:var(--text-primary);font-size:1.75rem;font-weight:800;line-height:1.2}.dashboard-panel-grid{grid-template-columns:2fr 1fr;gap:2rem;margin-bottom:2rem;display:grid}@media (width<=1024px){.dashboard-panel-grid{grid-template-columns:1fr}}.panel-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--card-shadow);padding:1.75rem}.panel-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.panel-title{align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;display:flex}.team-progress-list{flex-direction:column;gap:1.25rem;display:flex}.team-progress-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem}.team-progress-info{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.team-member-name{align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;display:flex}.team-member-avatar{border-radius:var(--radius-full);background:var(--primary-light);width:28px;height:28px;color:var(--primary);border:1px solid var(--border-color);justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.team-progress-stats{color:var(--text-muted);font-size:.8rem}.progress-bar-container{background:var(--bg-secondary);border-radius:var(--radius-full);border:1px solid var(--border-color);height:8px;position:relative;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--primary), var(--info));border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow) ease-out}.task-form{flex-direction:column;gap:1.25rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.form-control{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast);padding:.75rem 1rem;font-size:.9rem}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);background:var(--bg-secondary);outline:none}textarea.form-control{resize:vertical;min-height:90px}.btn{background:var(--primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:600;display:inline-flex}.btn:hover{background:var(--primary-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-secondary)}.btn-danger{background:var(--danger)}.btn-danger:hover{background:#dc2626;box-shadow:0 0 15px #ef44444d}.task-table-wrapper{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);overflow-x:auto}.task-table{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.task-table th{background:var(--bg-tertiary);color:var(--text-secondary);border-bottom:1px solid var(--border-color);white-space:nowrap;padding:1rem;font-weight:600}.task-table td{border-bottom:1px solid var(--border-color);color:var(--text-primary);padding:1rem}.task-table tr:last-child td{border-bottom:none}.task-table tr:hover td{background:var(--bg-tertiary)}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.3px;align-items:center;gap:.35rem;padding:.25rem .65rem;font-size:.75rem;font-weight:700;display:inline-flex}.badge-status-todo{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.badge-status-in_progress{background:var(--info-light);color:var(--info);border:1px solid #06b6d433}.badge-status-review{background:var(--warning-light);color:var(--warning);border:1px solid #f59e0b33}.badge-status-done{background:var(--success-light);color:var(--success);border:1px solid #10b98133}.badge-priority-high{background:var(--danger-light);color:var(--danger);border:1px solid #ef444433}.badge-priority-medium{background:var(--warning-light);color:var(--warning);border:1px solid #f59e0b33}.badge-priority-low{background:var(--success-light);color:var(--success);border:1px solid #10b98133}.badge-overdue{background:var(--danger);color:#fff;animation:2s infinite pulse}.badge-near-deadline{background:var(--warning);color:#fff}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05);box-shadow:0 0 10px #ef444466}to{transform:scale(1)}}.action-btn-group{gap:.5rem;display:flex}.action-icon-btn{border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.action-icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.action-icon-btn.edit:hover{color:var(--primary);background:var(--primary-light)}.action-icon-btn.delete:hover{color:var(--danger);background:var(--danger-light)}.kanban-header-section{background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--card-shadow);justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem;display:flex}.kanban-user-info{align-items:center;gap:1rem;display:flex}.kanban-user-avatar{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--primary), var(--info));color:#fff;width:48px;height:48px;box-shadow:var(--shadow-sm);justify-content:center;align-items:center;font-size:1.25rem;font-weight:800;display:flex}.kanban-user-details h2{font-size:1.25rem;font-weight:700}.kanban-user-details p{color:var(--text-muted);font-size:.85rem}.kanban-container{grid-template-columns:repeat(4,1fr);align-items:start;gap:1.25rem;display:grid}@media (width<=1200px){.kanban-container{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.kanban-container{grid-template-columns:1fr}}.kanban-column{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);min-height:550px;box-shadow:var(--card-shadow);transition:all var(--transition-normal);flex-direction:column;gap:1rem;padding:1.25rem 1rem;display:flex}.kanban-column.dragover{border-color:var(--primary);background:var(--bg-tertiary);box-shadow:var(--shadow-glow)}.column-header{border-bottom:2px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:0 .5rem .75rem;display:flex}.column-header-title{align-items:center;gap:.5rem;font-size:.95rem;font-weight:700;display:flex}.column-header-dot{border-radius:var(--radius-full);background:var(--dot-color,var(--text-muted));width:8px;height:8px}.column-count{background:var(--bg-tertiary);border-radius:var(--radius-full);color:var(--text-secondary);border:1px solid var(--border-color);padding:.2rem .5rem;font-size:.75rem;font-weight:700}.column-cards-area{flex-direction:column;gap:1rem;min-height:480px;display:flex}.task-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:grab;transition:all var(--transition-normal);flex-direction:column;gap:.75rem;padding:1rem;display:flex;position:relative}.task-card:active{cursor:grabbing}.task-card:hover{box-shadow:var(--shadow-md);border-color:var(--text-muted);transform:translateY(-2px)}.task-card.dragging{opacity:.5;border:2px dashed var(--primary)}.task-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.task-card-title{color:var(--text-primary);font-size:.95rem;font-weight:700;line-height:1.4}.task-card-desc{color:var(--text-secondary);-webkit-line-clamp:2;text-overflow:ellipsis;-webkit-box-orient:vertical;font-size:.825rem;line-height:1.4;display:-webkit-box;overflow:hidden}.task-card-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-top:.25rem;padding-top:.75rem;display:flex}.task-card-date{color:var(--text-muted);align-items:center;gap:.25rem;font-size:.75rem;display:flex}.task-card-assignee{color:var(--text-secondary);background:var(--bg-tertiary);border-radius:var(--radius-full);border:1px solid var(--border-color);align-items:center;gap:.35rem;padding:.15rem .5rem;font-size:.75rem;font-weight:600;display:flex}.task-card-controls{gap:.25rem;display:flex}.column-add-btn{border:1px dashed var(--border-color);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;gap:.5rem;padding:.75rem;font-size:.85rem;font-weight:600;display:flex}.column-add-btn:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;animation:fadeIn var(--transition-fast);background:#0009;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-lg);animation:scaleIn var(--transition-normal);padding:2rem;position:relative}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-close-btn{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;font-size:1.25rem;position:absolute;top:1.25rem;right:1.25rem}.modal-close-btn:hover{color:var(--text-primary)}.modal-title{align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.25rem;font-weight:800;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.25rem;display:flex}.footer{background:var(--bg-glass);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);border-top:1px solid var(--border-glass);text-align:center;color:var(--text-muted);margin-top:auto;padding:1.5rem;font-size:.8rem}.footer a{color:var(--primary);text-decoration:none}.footer a:hover{text-decoration:underline}.filter-bar{background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:.75rem 1.25rem;display:flex}.filter-group{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.filter-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:700}.filter-select{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;padding:.4rem .75rem;font-size:.85rem}.filter-select:focus{border-color:var(--primary)}.empty-state{color:var(--text-muted);text-align:center;border:1px dashed var(--border-color);border-radius:var(--radius-md);background:#00000005;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:3rem 1.5rem;display:flex}.dark .empty-state{background:#ffffff03}.empty-state-icon{color:var(--text-muted);opacity:.5;font-size:2.5rem}.empty-state-text{font-size:.9rem;font-weight:500}
