.color-picker-container{position:relative;display:inline-flex;width:40px;height:40px;z-index:2}.color-picker-display{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px}.color-picker-preview-button{all:unset;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;flex:0 0 auto;border:none;background:transparent;cursor:pointer}.color-picker-preview-button:hover,.color-picker-preview-button:focus-visible{background:transparent!important;border-color:transparent!important;outline:none}.color-picker-preview-button.is-empty{opacity:.85}.color-picker-preview{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:2px solid #d1d5db;cursor:pointer;box-sizing:border-box;transition:transform .2s,box-shadow .2s}.color-picker-preview:hover{transform:scale(1.1);box-shadow:0 0 8px #0003}.color-picker-preview-empty{background-color:#f8fafc;background-image:linear-gradient(45deg,#e5e7eb 25%,transparent 25%),linear-gradient(-45deg,#e5e7eb 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e5e7eb 75%),linear-gradient(-45deg,transparent 75%,#e5e7eb 75%);background-size:12px 12px;background-position:0 0,0 6px,6px -6px,-6px 0}.color-picker-popup{position:absolute;top:calc(100% + 8px);left:0;min-width:220px;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:12px;box-shadow:0 4px 12px #00000026;margin-top:0;z-index:3000}.color-picker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:8px}.color-picker-option{width:36px;height:36px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .2s,box-shadow .2s}.color-picker-option:hover{transform:scale(1.15);box-shadow:0 0 8px #0000004d}.color-picker-option.selected{border-color:#000;box-shadow:0 0 0 2px #0000001a}.color-picker-divider{height:1px;background-color:#e5e7eb;margin:8px 0}.color-picker-custom{margin-bottom:8px}.color-picker-custom label{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:#6b7280}.color-picker-custom input[type=color]{width:36px;height:36px;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;padding:2px}.color-picker-actions{display:flex;gap:4px;justify-content:flex-end}.color-picker-actions button{flex:1;font-size:12px}.gantt-container,.gantt-container *{box-sizing:border-box}.gantt-container{display:flex;height:100%;width:100%;background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.gantt-task-list-wrapper{width:280px;height:100%;border-right:1px solid #e5e7eb;background-color:#fafafa;overflow:hidden;position:relative}.gantt-task-row{display:flex;align-items:center;padding:0 8px;border-bottom:1px solid #e5e7eb;-webkit-user-select:none;user-select:none;transition:background-color .15s ease-out}.gantt-task-row:hover{background-color:#3b82f60d}.gantt-task-row.is-selected{background-color:#3b82f61a;border-left:3px solid #3b82f6}.gantt-expand-button{width:20px;height:20px;padding:0;margin-right:4px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;font-size:14px;transition:transform .2s ease-out}.gantt-expand-button:hover{color:#4b5563}.gantt-chart-wrapper{flex:1;display:flex;flex-direction:column;overflow:auto;position:relative;min-width:0}.gantt-chart-wrapper::-webkit-scrollbar{width:8px;height:8px}.gantt-chart-wrapper::-webkit-scrollbar-track{background:transparent}.gantt-chart-wrapper::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.gantt-chart-wrapper::-webkit-scrollbar-thumb:hover{background:#9ca3af}.gantt-chart-header{position:sticky;top:0;z-index:10;background:#f3f4f6;border-bottom:1px solid #d1d5db;display:flex;align-items:stretch;-webkit-user-select:none;user-select:none;box-sizing:border-box}.gantt-chart-header>div{min-width:max-content}.gantt-header-cell{display:flex;align-items:center;padding:0 8px;font-size:12px;font-weight:500;color:#4b5563;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background-color .15s ease-out}.gantt-header-cell:nth-child(odd){background-color:#f9fafb}.gantt-header-cell:nth-child(2n){background-color:#f3f4f6}.gantt-grid{position:absolute;top:0;left:0;z-index:1;pointer-events:none}.gantt-bars-container{position:relative;width:100%;background:transparent}.gantt-bar-item{position:absolute;top:0;left:0;border-radius:4px;color:#fff;display:flex;align-items:center;padding:0 8px;font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:grab;-webkit-user-select:none;user-select:none;transform:translateZ(0);backface-visibility:hidden;perspective:1000px;transition:box-shadow .15s ease-out,opacity .15s ease-out}.gantt-bar-item:active{cursor:grabbing}.gantt-bar-item:hover{opacity:1!important;box-shadow:0 2px 8px #00000026;z-index:12}.gantt-bar-item.is-selected{opacity:1;box-shadow:0 2px 8px #00000026;z-index:12}.gantt-bar-item.is-dragging{opacity:.7;z-index:15}.gantt-bar-progress{position:absolute;left:0;top:0;bottom:0;background-color:#00000026;border-radius:4px 0 0 4px;z-index:1;transition:width .3s ease-out}.gantt-bar-resize-handle{position:absolute;right:0;top:0;bottom:0;width:6px;cursor:col-resize;background-color:transparent;z-index:10}.gantt-bar-resize-handle:hover{background-color:#3b82f64d}.gantt-dependency-layer{position:absolute;top:0;left:0;pointer-events:none;z-index:5}.gantt-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:#9ca3af;font-size:14px;text-align:center;padding:20px}.gantt-chart-content{flex:1;position:relative;overflow:hidden}.gantt-bar-item.type-epic{background-color:#8b5cf6d9}.gantt-bar-item.type-phase{background-color:#3b82f6cc}.gantt-bar-item.type-task{background-color:#06b6d4bf}.gantt-bar-item.type-milestone{background-color:#f97316cc}.gantt-task-badge{width:8px;height:8px;border-radius:50%;margin-right:8px;flex-shrink:0}.gantt-task-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px;color:#1f2937}@media (max-width: 768px){.gantt-task-list-wrapper{width:150px}.gantt-bar-item,.gantt-header-cell{font-size:11px;padding:0 4px}}.gantt-bar-item:focus{outline:2px solid #2563eb;outline-offset:2px}@media print{.gantt-chart-wrapper{overflow:visible}.gantt-bar-item{break-inside:avoid}}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1f2937;background:#f3f4f6}body{margin:0}.layout{display:flex;flex-direction:column;height:100vh}.layout-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000000f}.header-left{display:flex;gap:20px;align-items:center}.header-left h1{margin:0;font-size:24px;font-weight:700}.header-right{display:flex;gap:12px;align-items:center}.user-info{font-size:14px;color:#6b7280}.logout-btn{background:#111827;color:#fff;border-color:#111827}.logout-btn:hover{background:#0f172a;border-color:#0f172a}.layout-main{flex:1;overflow:auto;padding:24px}.page{max-width:100%;margin:0 auto}.login-page{display:flex;align-items:center;justify-content:center;height:100vh;padding:0}.login-card{width:100%;max-width:400px}.login-card h1{text-align:center;margin-bottom:24px}.projects-page{display:grid;gap:24px}.projects-header{display:flex;justify-content:space-between;align-items:center}.projects-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.projects-table{width:100%;border-collapse:collapse}.projects-list-table{table-layout:fixed}.projects-list-table th:nth-child(1),.projects-list-table td:nth-child(1){width:36%}.projects-list-table th:nth-child(2),.projects-list-table td:nth-child(2){width:20%}.projects-table th,.projects-table td{padding:10px 8px;border-bottom:1px solid #e5e7eb;text-align:left;font-size:14px}.projects-table th{color:#6b7280;font-weight:600}.project-name-link{color:#1f2937;text-decoration:none;font-weight:600;font-size:14px;line-height:1.2;display:inline-block;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transform-origin:left center;transition:text-shadow .15s ease,transform .15s ease}.project-name-link:hover{color:#111827;text-shadow:0 1px 2px rgba(17,24,39,.18);transform:scale(1.03)}.project-name-link:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}.table-action-link{color:#2563eb;text-decoration:none;font-weight:500}.table-action-link:hover{color:#1d4ed8;text-decoration:underline}.button-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:10px 8px;border-bottom:1px solid #e5e7eb;text-align:left;font-size:14px}.users-table th{color:#6b7280;font-weight:600}.project-card{background:#fff;border-radius:12px;padding:20px;cursor:pointer;box-shadow:0 2px 8px #0000000f;transition:all .2s}.project-card:hover{box-shadow:0 4px 12px #0000001f;transform:translateY(-2px)}.project-card h3{margin:0 0 8px;color:#111827}.project-card .client{margin:4px 0;font-size:14px;color:#6b7280}.project-card .type{margin:8px 0 0;font-size:12px;background:#f3f4f6;padding:4px 8px;border-radius:4px;display:inline-block;color:#4b5563}.delete-project-btn{margin-top:0;background:#ef4444;color:#fff;border-color:#ef4444}.delete-project-btn:hover{background:#dc2626}.project-detail{display:grid;gap:16px;min-width:0}.project-detail-page-fit{width:100%;overflow-x:hidden}.detail-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.detail-title{display:flex;align-items:center;gap:12px}.detail-title-wrap{flex:1;min-width:0;flex-wrap:wrap;align-items:center;row-gap:8px}.detail-title-main{display:flex;align-items:center;gap:12px;min-width:0}.detail-title-main h2{margin:0}.detail-version-readonly-note{display:inline-flex;align-items:center;min-height:32px;padding:6px 10px;border:1px solid #fde68a;border-radius:8px;background:#fffbeb;color:#92400e;font-size:13px;line-height:1.35;max-width:720px}.back-icon-btn{background:transparent;border:none;padding:0;cursor:pointer;color:#111827;font-size:20px;line-height:1;filter:none;transition:filter .15s ease}.back-icon-btn:hover,.back-icon-btn:focus-visible{background:transparent;border-color:transparent;color:#111827;filter:drop-shadow(0 1px 3px rgba(17,24,39,.35))}.detail-actions{display:flex;gap:8px}.detail-header-wrap{flex-wrap:wrap}.detail-actions-wrap{flex-wrap:wrap;justify-content:flex-end}.detail-actions input{flex:1;padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;max-width:300px}.detail-actions button{background:inherit;color:inherit;border-color:inherit}.detail-actions button:hover:not(:disabled){background:inherit}.detail-actions button:disabled{opacity:.6;cursor:not-allowed}.versions-selector{display:flex;gap:8px;align-items:center}.versions-selector select{padding:10px;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;flex:1}.detail-content{display:grid;grid-template-columns:400px 1fr;gap:16px;height:600px}.gantt-editor-card{padding:0;overflow:hidden}.gantt-editor-header,.gantt-editor-row{display:grid;grid-template-columns:260px 180px 100px 120px 1fr 120px}.gantt-editor-header.compact,.gantt-editor-row.compact{grid-template-columns:320px 220px 120px 120px 120px}.gantt-editor-header{background:#f3f4f6;border-bottom:1px solid #d1d5db;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase}.gantt-editor-header>div,.gantt-editor-row .cell{padding:10px 12px;border-right:1px solid #f3f4f6}.gantt-editor-body{max-height:620px;overflow:auto}.gantt-editor-dates-row{display:grid;grid-template-columns:260px 180px 100px 120px 1fr 120px;background:#fafafa;border-bottom:1px solid #e5e7eb}.timeline-dates-cell{overflow-x:auto;padding-top:0;padding-bottom:0}.timeline-date-track{display:flex}.timeline-date-cell{min-width:28px;width:28px;border-right:1px solid #f3f4f6;text-align:center;font-size:9px;color:#6b7280;padding:4px 0}.gantt-editor-row{align-items:center}.gantt-editor-row .cell{min-height:42px;display:flex;align-items:center}.gantt-editor-row.compact{border-bottom:none}.gantt-editor-body.compact{padding:2px 0 8px}.task-name-cell.is-subtask{padding-left:24px}.task-link{color:#111827;font-weight:500}.progress-cell{color:#374151;font-size:13px}.progress-cell input{width:64px}.color-cell input[type=color]{width:48px;height:28px;border:none;padding:0;background:transparent}.timeline-cell{overflow:auto}.timeline-grid{position:relative;height:26px;background-image:repeating-linear-gradient(to right,#f3f4f6 0,#f3f4f6 1px,transparent 1px,transparent 28px)}.timeline-bar{position:absolute;top:3px;height:20px;border-radius:6px;display:flex;align-items:center;justify-content:space-between;color:#fff;font-size:11px;padding:0 2px}.timeline-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 16px)}.resize-handle{width:6px;height:14px;background:#ffffffd9;border-radius:2px;cursor:ew-resize}.timeline-bar-epic{background:#7c3aed}.timeline-bar-phase{background:#0284c7}.timeline-bar-task{background:#059669}.timeline-bar-milestone{background:#d97706}.new-task-row{background:#fafafa}.inline-subtask-row{background:#fcfcfc}.gantt-library-card{padding:8px;overflow:hidden}.gantt-library-card .gantt-container{border:1px solid #e5e7eb;border-radius:8px}.gantt-width-boundary{max-width:100%}.gantt-scroll-shell{width:100%;overflow-x:auto;overflow-y:hidden}.quick-actions-card{padding:12px}.quick-actions-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.quick-actions-row+.quick-actions-row{margin-top:10px}.selected-task-info{font-size:13px;color:#4b5563}.color-inline-label{display:inline-flex;align-items:center;gap:8px;font-size:13px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:24px;z-index:1000}.modal-card{width:min(720px,100%);background:#fff;border-radius:12px;padding:20px;box-shadow:0 18px 48px #0f172a3d}.modal-card h3{margin:0 0 16px}.modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.gantt-placeholder{min-height:220px;display:flex;align-items:center;justify-content:center;color:#6b7280;font-size:14px;border:1px dashed #d1d5db;border-radius:8px;background:#fafafa}.actions-cell{justify-content:flex-start}.tiny-button{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border:1px solid;border-radius:6px;padding:6px 10px;font-size:13px;line-height:1.2;font-weight:500;cursor:pointer;background:#111827;color:#fff;border-color:#111827}.tiny-button-secondary,.tiny-button-primary{background:#111827;border-color:#111827}.tiny-button-edit{background:#2563eb;border-color:#2563eb}.tiny-button-edit:hover:not(:disabled){background:#1d4ed8;border-color:#1d4ed8}.tiny-button-success{background:#059669;border-color:#059669}.tiny-button-success:hover:not(:disabled){background:#047857;border-color:#047857}.tiny-button-danger{background:#dc2626;border-color:#dc2626}.tiny-button-danger:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.tasks-side,.gantt-side{background:#fff;border-radius:12px;padding:16px;overflow:auto;box-shadow:0 2px 8px #0000000f}.tasks-side h3,.gantt-side h3{margin:0 0 16px;font-size:16px}.tasks-grid{display:flex;flex-direction:column;height:100%}.tasks-header{display:grid;grid-template-columns:150px 80px 140px 70px 120px;gap:8px;padding:8px 0;border-bottom:2px solid #e5e7eb;font-weight:600;font-size:12px;color:#6b7280;text-transform:uppercase;sticky:top}.tasks-list{flex:1;overflow:auto}.task-row{display:grid;grid-template-columns:150px 80px 140px 70px 120px;gap:8px;padding:8px 0;border-bottom:1px solid #f3f4f6;font-size:14px;align-items:center}.task-row.depth-0{background:#f9fafb;font-weight:600}.task-row.depth-1{padding-left:16px}.task-row.depth-2{padding-left:32px;font-size:13px}.task-row.depth-3{padding-left:48px;font-size:12px}.empty-state{padding:20px;text-align:center;color:#9ca3af}.gantt-container{height:100%;overflow:auto}.gantt-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#9ca3af}.gantt-timeline{height:100%;display:flex;flex-direction:column}.gantt-axis{display:flex;height:100%;gap:1px;background:#e5e7eb}.gantt-labels{flex:0 0 280px;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;background:#f9fafb}.gantt-label{padding:12px;border-bottom:1px solid #e5e7eb;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:40px;display:flex;align-items:center}.gantt-bars{flex:1;display:flex;flex-direction:column;overflow-x:auto}.gantt-header{display:flex;background:#f3f4f6;border-bottom:2px solid #d1d5db;font-size:12px;font-weight:600;color:#6b7280}.gantt-week{padding:8px 4px;text-align:center;border-right:1px solid #d1d5db;min-width:70px}.gantt-row{display:flex;align-items:center;min-height:40px;border-bottom:1px solid #e5e7eb;position:relative;gap:1px;flex:1}.gantt-bar{height:24px;border-radius:4px;transition:opacity .2s;cursor:pointer}.gantt-bar:hover{filter:brightness(.9)}.gantt-bar-epic{background:#7c3aed}.gantt-bar-phase{background:#0ea5e9}.gantt-bar-task{background:#10b981}.gantt-bar-milestone{background:#f59e0b;min-width:12px}.card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000000f}.stack{display:grid;gap:10px}.row{display:flex;gap:8px;align-items:center;justify-content:space-between}label{display:grid;gap:6px;font-size:14px;font-weight:500}input,select,button{font:inherit;padding:6px 10px;border-radius:6px;border:1px solid #d1d5db}input,select{background:#fff}button{background:#111827;color:#fff;border-color:#111827;cursor:pointer;font-weight:500;font-size:13px;line-height:1.2;transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease}button:hover:not(:disabled){background:#0f172a;border-color:#0f172a}button:disabled{opacity:1;cursor:not-allowed;background:#9ca3af;border-color:#9ca3af;color:#f9fafb}button.back-icon-btn:hover,button.back-icon-btn:focus-visible{background:transparent!important;border-color:transparent!important;color:#111827!important}button.back-icon-btn:active{background:transparent!important;border-color:transparent!important;color:#111827!important}.login-submit-btn{padding:8px 12px;font-size:14px;border-radius:8px}.error{color:#b91c1c}.error-box{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}pre{background:#111827;color:#e5e7eb;padding:12px;border-radius:8px;overflow-x:auto}@media (max-width: 1200px){.detail-content{grid-template-columns:1fr;height:auto}.tasks-side,.gantt-side{min-height:400px}}@media (max-width: 768px){.layout-header{flex-direction:column;gap:12px;align-items:flex-start}.projects-list,.gantt-editor-header,.gantt-editor-dates-row,.gantt-editor-row{grid-template-columns:1fr}.detail-header{flex-direction:column;align-items:stretch}.detail-actions{flex-direction:column}.modal-grid,.task-row,.tasks-header{grid-template-columns:1fr}.task-row.depth-1{padding-left:8px}.task-row.depth-2{padding-left:16px}.task-row.depth-3{padding-left:24px}}input[type=range]{width:100%;max-width:100%;height:18px;margin:0;padding:0;border:none;border-radius:0;box-sizing:border-box;background:transparent;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}input[type=range]::-webkit-slider-runnable-track{height:4px;background:#d1d5db;border-radius:999px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#3b82f6;cursor:pointer;border:none;box-shadow:none;margin-top:-5px}input[type=range]::-moz-range-track{height:4px;background:#d1d5db;border-radius:999px}input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#3b82f6;cursor:pointer;border:none;box-shadow:none}
