*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#4f46e5;--primary-hover:#4338ca;--primary-light:#eef2ff;--danger:#dc2626;--danger-hover:#b91c1c;--success:#059669;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--radius:8px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d}html{-webkit-text-size-adjust:100%}body{color:var(--gray-900);background:var(--gray-50);min-height:100vh;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.5}img,media{max-width:100%;height:auto}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.app-shell{flex-direction:column;min-height:100vh;display:flex}.navbar{border-bottom:1px solid var(--gray-200);z-index:50;background:#fff;padding:0 1rem;position:sticky;top:0}.navbar-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:1200px;height:56px;margin:0 auto;display:flex}.navbar-brand{color:var(--gray-900);white-space:nowrap;font-size:1.125rem;font-weight:700;text-decoration:none}.navbar-nav{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.page-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem 1rem}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:.375rem;min-height:36px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;line-height:1.25;transition:background .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.btn-ghost{color:var(--gray-600);background:0 0;border:1px solid #0000}.btn-ghost:hover:not(:disabled){background:var(--gray-100)}.btn-sm{min-height:28px;padding:.25rem .625rem;font-size:.8125rem}.form-field{flex-direction:column;gap:.375rem;display:flex}.form-label{color:var(--gray-700);font-size:.875rem;font-weight:500}.form-label-optional{color:var(--gray-400);font-size:.8125rem;font-weight:400}.form-input,.form-select{border:1px solid var(--gray-300);border-radius:var(--radius);width:100%;color:var(--gray-900);background:#fff;min-height:40px;padding:.5rem .75rem;font-size:.9375rem;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4f46e526}.form-error{color:var(--danger);font-size:.8125rem}.form-stack{flex-direction:column;gap:1rem;display:flex}.card{border-radius:var(--radius);border:1px solid var(--gray-200);box-shadow:var(--shadow);background:#fff;padding:1.5rem}.auth-page{background:var(--gray-50);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.auth-card{border:1px solid var(--gray-200);width:100%;max-width:400px;box-shadow:var(--shadow-md);background:#fff;border-radius:12px;padding:2rem}.auth-title{color:var(--gray-900);margin-bottom:.25rem;font-size:clamp(1.25rem,4vw,1.5rem);font-weight:700}.auth-subtitle{color:var(--gray-500);margin-bottom:1.5rem;font-size:.9375rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.page-title{color:var(--gray-900);font-size:clamp(1.125rem,3.5vw,1.5rem);font-weight:700}.alert{border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.alert-error{color:var(--danger);background:#fef2f2;border:1px solid #fecaca}.alert-success{color:var(--success);background:#ecfdf5;border:1px solid #a7f3d0}.modal-backdrop{z-index:100;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{box-shadow:var(--shadow-lg);background:#fff;border-radius:12px;width:100%;max-width:480px;max-height:calc(100vh - 2rem);padding:1.5rem;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;display:flex}.modal-title{color:var(--gray-900);font-size:1.125rem;font-weight:600}.modal-close{cursor:pointer;color:var(--gray-400);background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:.25rem;font-size:1.25rem;line-height:1}.modal-close:hover{color:var(--gray-700);background:var(--gray-100)}.modal-footer{flex-wrap:wrap;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.gantt-wrapper{-webkit-overflow-scrolling:touch;border:1px solid var(--gray-200);border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;overflow-x:auto}.gantt-table{width:100%;min-width:600px}.gantt-header{background:var(--gray-50);border-bottom:1px solid var(--gray-200);z-index:10;display:grid;position:sticky;top:0}.gantt-row{border-bottom:1px solid var(--gray-100);align-items:stretch;min-height:52px;display:grid}.gantt-row:last-child{border-bottom:none}.gantt-row:hover{background:var(--gray-50)}.gantt-cell-name{border-right:1px solid var(--gray-200);background:inherit;z-index:5;flex-direction:column;justify-content:center;padding:.625rem .75rem;font-size:.875rem;display:flex;position:sticky;left:0}.gantt-cell-name.header-cell{color:var(--gray-600);text-transform:uppercase;letter-spacing:.04em;font-size:.8125rem;font-weight:600}.gantt-task-name{color:var(--gray-800);text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.gantt-task-meta{color:var(--gray-400);margin-top:.125rem;font-size:.75rem}.gantt-actions{border-right:1px solid var(--gray-200);align-items:center;gap:.25rem;padding:.5rem;display:flex}.gantt-timeline{align-items:center;padding:.5rem .375rem;display:flex;position:relative;overflow:hidden}.day-header{text-align:center;width:48px;color:var(--gray-400);border-right:1px solid var(--gray-100);-webkit-user-select:none;user-select:none;white-space:nowrap;text-overflow:clip;flex:none;padding:.375rem 1px;font-size:.625rem;font-weight:500;line-height:1.3;overflow:hidden}.gantt-bar-container{align-items:center;height:32px;display:flex;position:relative}.gantt-bar{color:#fff;white-space:nowrap;text-overflow:ellipsis;background:var(--primary);border-radius:6px;align-items:center;height:28px;padding:0 .5rem;font-size:.75rem;font-weight:500;display:flex;position:absolute;overflow:hidden;box-shadow:0 1px 3px #4f46e54d}.dep-badge{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200);text-overflow:ellipsis;white-space:nowrap;border-radius:3px;align-items:center;gap:.25rem;max-width:100%;margin:.125rem .125rem 0 0;padding:1px 5px;font-size:.6875rem;display:inline-flex;overflow:hidden}.dep-remove{cursor:pointer;color:var(--gray-400);background:0 0;border:none;padding:0 2px;font-size:.75rem;line-height:1}.dep-remove:hover{color:var(--danger)}.start-date-bar{color:var(--gray-700);flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.875rem;display:flex}.start-date-label{flex-shrink:0;font-weight:500}.start-date-value{flex-wrap:wrap;align-items:center;gap:.25rem;display:flex}.start-date-edit{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.start-date-input{width:auto;min-width:140px;max-width:180px;min-height:32px;padding:.25rem .5rem;font-size:.875rem}.deps-checklist{border:1px solid var(--gray-200);border-radius:var(--radius);background:var(--gray-50);flex-direction:column;gap:.375rem;max-height:180px;padding:.5rem;display:flex;overflow-y:auto}.dep-check-item{cursor:pointer;border-radius:4px;align-items:center;gap:.5rem;padding:.25rem .375rem;font-size:.875rem;transition:background .1s;display:flex}.dep-check-item:hover{background:var(--gray-100)}.dep-check-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--primary);flex-shrink:0}.dep-check-item span:nth-child(2){color:var(--gray-800);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.dep-check-meta{color:var(--gray-400);flex-shrink:0;font-size:.75rem}.empty-state{text-align:center;color:var(--gray-400);padding:3rem 1rem}.empty-state h3{color:var(--gray-600);margin-bottom:.375rem;font-size:1rem}.users-table{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;min-width:480px}.data-table th{text-align:left;color:var(--gray-500);border-bottom:2px solid var(--gray-200);text-transform:uppercase;letter-spacing:.04em;padding:.625rem .75rem;font-size:.8125rem;font-weight:600}.data-table td{border-bottom:1px solid var(--gray-100);vertical-align:middle;padding:.75rem;font-size:.9375rem}.data-table tr:last-child td{border-bottom:none}.role-badge{text-transform:capitalize;border-radius:12px;align-items:center;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.role-admin{color:#5b21b6;background:#ede9fe}.role-editor{color:#1e40af;background:#dbeafe}.role-viewer{background:var(--gray-100);color:var(--gray-600)}.spinner{border:2px solid var(--gray-300);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{justify-content:center;padding:3rem;display:flex}.divider{background:var(--gray-200);height:1px;margin:1rem 0}.hint{color:var(--gray-500);font-size:.8125rem}@media (max-width:480px){.page-content{padding:1rem .75rem}.card,.modal{padding:1rem}.auth-card{padding:1.5rem}.page-header{gap:.625rem}.gantt-cell-name{min-width:100px}}
