*{box-sizing:border-box;margin:0;padding:0}:root{--dalu-primary:#f59e0b;--dalu-secondary:#3b82f6;--dalu-dark:#1f2937;--dalu-light:#f3f4f6;--dalu-border:#e5e7eb;--dalu-text:#374151;--dalu-text-light:#6b7280;--header-height:60px;--sidebar-width:300px;--task-height:40px;--row-gap:8px;--color-fve-residential:#f59e0b;--color-fve-commercial:#f97316;--color-service:#3b82f6;--color-wind:#06b6d4;--color-battery:#8b5cf6}body{color:var(--dalu-text);background-color:#f9fafb;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;overflow:hidden}#app{flex-direction:column;width:100vw;height:100vh;display:flex}.app-header{height:var(--header-height);color:#fff;z-index:100;background:linear-gradient(135deg,#1f2937 0%,#374151 100%);justify-content:space-between;align-items:center;padding:0 24px;display:flex;box-shadow:0 2px 4px #0000001a}.app-header-left{align-items:center;gap:16px;display:flex}.app-logo{color:var(--dalu-primary);align-items:center;gap:8px;font-size:24px;font-weight:700;display:flex}.app-logo span{color:#fff}.app-subtitle{color:#9ca3af;border-left:1px solid #4b5563;padding-left:16px;font-size:14px}.app-header-right{align-items:center;gap:12px;display:flex}.btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-primary{background-color:var(--dalu-primary);color:#fff}.btn-primary:hover{background-color:#d97706}.btn-secondary{color:#fff;background-color:#4b5563}.btn-secondary:hover{background-color:#374151}.btn-icon{justify-content:center;min-width:36px;padding:8px}.main-content{flex:1;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--dalu-border);background:#fff;flex-direction:column;display:flex;overflow:hidden}.sidebar-header{border-bottom:1px solid var(--dalu-border);background:#fafafa;padding:16px}.sidebar-header h3{color:var(--dalu-text);text-transform:uppercase;letter-spacing:.5px;font-size:14px;font-weight:600}.project-list{flex:1;padding:8px;overflow-y:auto}.project-item{cursor:pointer;border-left:4px solid #0000;border-radius:8px;margin-bottom:8px;padding:12px;transition:all .2s}.project-item:hover{background-color:#f3f4f6}.project-item.active{border-left-color:var(--dalu-secondary);background-color:#eff6ff}.project-item-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.project-icon{font-size:18px}.project-name{color:var(--dalu-dark);font-size:14px;font-weight:600}.project-meta{color:var(--dalu-text-light);margin-left:26px;font-size:12px}.project-type-badge{border-radius:12px;margin-top:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.gantt-container{background:#fff;flex-direction:column;flex:1;display:flex;overflow:hidden}.timeline-header{border-bottom:1px solid var(--dalu-border);background:#fafafa;align-items:center;gap:16px;height:50px;padding:0 16px;display:flex}.timeline-controls{align-items:center;gap:8px;display:flex}.timeline-title{color:var(--dalu-dark);flex:1;font-weight:600}.zoom-control{align-items:center;gap:8px;display:flex}.zoom-label{color:var(--dalu-text-light);font-size:12px}.link-mode-pill{color:#1e3a8a;background:#e0ecff;border:1px solid #bfdbfe;border-radius:999px;align-items:center;gap:8px;padding:4px 8px;font-size:12px;display:inline-flex}.link-mode-pill .btn{min-width:auto;padding:2px 6px}.timeline-scale{border-bottom:1px solid var(--dalu-border);background:#fff;height:40px;display:flex;position:relative;overflow:hidden}.timeline-scale-inner{height:100%;display:flex}.timeline-month{border-right:1px solid var(--dalu-border);background:#f9fafb;flex-direction:column;justify-content:center;padding:0 8px;display:flex}.timeline-month-name{color:var(--dalu-dark);font-size:13px;font-weight:600}.timeline-month-year{color:var(--dalu-text-light);font-size:11px}.timeline-day{color:var(--dalu-text-light);border-right:1px solid #f0f0f0;justify-content:center;align-items:center;font-size:11px;display:flex}.timeline-day.weekend{color:#ef4444;background:#fef2f2}.timeline-body{background:#fafafa;flex:1;position:relative;overflow:auto}.timeline-grid{min-height:100%;position:relative}.timeline-grid-lines{pointer-events:none;position:absolute;inset:0}.grid-line{border-right:1px dashed #e5e7eb;position:absolute;top:0;bottom:0}.task-row{height:calc(var(--task-height) + var(--row-gap));align-items:center;display:flex;position:relative}.task-row:nth-child(2n){background:#00000003}.task-row:hover{background:#3b82f60d}.task-bar{color:#fff;cursor:grab;white-space:nowrap;text-overflow:ellipsis;-webkit-user-select:none;user-select:none;z-index:5;border-radius:6px;align-items:center;height:32px;padding:0 12px;font-size:12px;font-weight:500;transition:box-shadow .2s,transform .1s;display:flex;position:absolute;overflow:visible;box-shadow:0 1px 3px #0000001a}.task-bar.milestone{border-radius:8px;min-width:36px;height:36px;padding:0;overflow:visible;box-shadow:0 0 0 2px #1f2937,0 6px 10px #11182747;background:#111827!important;border-left:none!important}.milestone-label{color:#1f2937;white-space:nowrap;pointer-events:none;background:#ffffffe6;border:1px solid #e5e7eb;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:600;position:absolute;top:50%;left:44px;transform:translateY(-50%)}.task-bar.link-source{box-shadow:0 0 0 3px #3b82f673,0 4px 6px #00000026}.task-bar:hover{z-index:10;box-shadow:0 4px 6px #00000026}.task-bar:active{cursor:grabbing;transform:scale(1.02)}.task-bar.dragging{opacity:.8;z-index:100;box-shadow:0 8px 16px #0003}.task-bar.milestone:active{transform:none}.task-bar-content{text-overflow:ellipsis;flex:1;overflow:hidden}.task-resize-handle{cursor:col-resize;background:#ffffff4d;width:8px;transition:background .2s;position:absolute;top:0;bottom:0;right:0}.task-resize-handle:hover{background:#fff9}.task-link-handle{color:#0f172a;cursor:pointer;opacity:1;pointer-events:auto;z-index:30;background:#fff;border:1px solid #cbd5e1;border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;font-weight:700;transition:opacity .15s,transform .15s,box-shadow .15s;display:flex;position:absolute;top:-9px;right:-9px;transform:scale(1)}.task-add-handle{color:#0f172a;cursor:pointer;opacity:1;pointer-events:auto;z-index:30;background:#fff;border:1px solid #cbd5e1;border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;font-weight:700;transition:box-shadow .15s;display:flex;position:absolute;top:-9px;left:-9px;transform:none}.task-add-handle:focus{outline:none;box-shadow:0 0 0 2px #f59e0b73}.task-link-handle:focus,.task-link-handle.active{opacity:1;pointer-events:auto;outline:none;transform:scale(1);box-shadow:0 0 0 2px #3b82f673}.task-bar.milestone .task-link-handle{top:-6px;right:-22px}.task-bar.milestone .task-add-handle{top:-6px;left:-22px}.quick-add-backdrop{z-index:1200;background:#0f172a66;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.quick-add-dialog{border:1px solid var(--dalu-border);background:#fff;border-radius:10px;flex-direction:column;gap:12px;width:min(92vw,360px);padding:16px;display:flex;box-shadow:0 20px 40px #0f172a3d}.quick-add-dialog h4{color:var(--dalu-dark);font-size:16px;font-weight:600}.quick-add-input{border:1px solid #cbd5e1;border-radius:8px;width:100%;padding:10px 12px;font-size:14px}.quick-add-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f629}.quick-add-actions{justify-content:flex-end;gap:8px;display:flex}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.dependency-lines-svg{pointer-events:auto;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.dependency-line-path{fill:none;stroke:#9ca3af;stroke-width:2px;stroke-dasharray:5 5}.dependency-line-path.interactive{pointer-events:stroke;cursor:pointer}.dependency-line-path.highlighted{stroke:#3b82f6;stroke-width:3px;stroke-dasharray:none}.task-info-panel{border:1px solid var(--dalu-border);z-index:1000;background:#fff;border-radius:8px;min-width:280px;max-width:350px;padding:16px;position:absolute;box-shadow:0 10px 15px #0000001a}.task-info-panel h4{color:var(--dalu-dark);margin-bottom:12px;font-size:16px;font-weight:600}.task-info-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;padding:6px 0;font-size:13px;display:flex}.task-info-row:last-child{border-bottom:none}.task-info-label{color:var(--dalu-text-light)}.task-info-value{color:var(--dalu-text);font-weight:500}.legend{border-top:1px solid var(--dalu-border);background:#fff;flex-wrap:wrap;gap:16px;padding:12px 16px;display:flex}.legend-item{color:var(--dalu-text-light);align-items:center;gap:6px;font-size:12px;display:flex}.legend-color{border-radius:3px;width:12px;height:12px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (width<=1024px){.sidebar{width:260px}}@media (width<=768px){.sidebar{display:none}.app-header{padding:0 12px}.app-subtitle{display:none}}
