*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #3b82f6;--primary-light: #dbeafe;--primary-dark: #1d4ed8;--critical: #ef4444;--critical-light: #fee2e2;--bar-normal: #60a5fa;--bar-critical: #ef4444;--bar-summary: #334155;--bar-done: #94a3b8;--milestone-color: #f59e0b;--bg: #f8fafc;--surface: #ffffff;--header-bg: #0f172a;--border: #e2e8f0;--text: #1e293b;--muted: #64748b;--hover: #f1f5f9;--selected: #eff6ff;--success: #22c55e;--radius: 6px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 10px 25px rgba(0,0,0,.12)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:13px;color:var(--text);background:var(--bg);height:100vh;overflow:hidden;display:flex;flex-direction:column}#root{flex:1;display:flex;flex-direction:column;min-height:0}.app-header{height:50px;background:var(--header-bg);display:flex;align-items:center;padding:0 16px;gap:0;flex-shrink:0;z-index:100}.app-logo{color:#fff;font-weight:700;font-size:15px;letter-spacing:-.3px;display:flex;align-items:center;gap:7px;padding-right:20px;border-right:1px solid rgba(255,255,255,.1);margin-right:4px;white-space:nowrap}.logo-mark{width:26px;height:26px;background:var(--primary);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff}.app-nav{display:flex;gap:2px;padding:0 8px}.app-nav button{background:none;border:none;color:#ffffff8c;padding:5px 11px;border-radius:5px;cursor:pointer;font-size:13px;transition:all .15s;display:flex;align-items:center;gap:5px}.app-nav button:hover{background:#ffffff14;color:#fff}.app-nav button.active{background:#ffffff1f;color:#fff}.nav-dot{width:6px;height:6px;border-radius:50%;background:var(--primary)}.header-spacer{flex:1}.header-actions{display:flex;align-items:center;gap:10px}.header-user{display:flex;align-items:center;gap:8px;color:#ffffffb3;font-size:12px;cursor:pointer;padding:4px 8px;border-radius:5px;transition:background .15s}.header-user:hover{background:#ffffff14}.avatar{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.view{display:none;flex:1;overflow:hidden;flex-direction:column}.view.active{display:flex}.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:var(--radius);border:none;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s;white-space:nowrap;text-decoration:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--text)}.btn-secondary:hover{background:var(--hover)}.btn-danger{background:#fff;border:1px solid #fca5a5;color:var(--critical)}.btn-danger:hover{background:var(--critical-light)}.btn-sm{padding:5px 9px;font-size:12px}#view-dashboard{overflow-y:auto;padding:32px;gap:0}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.dashboard-header h1{font-size:20px;font-weight:700}.dashboard-header p{font-size:13px;color:var(--muted);margin-top:2px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px;cursor:pointer;transition:all .18s;box-shadow:var(--shadow);display:flex;flex-direction:column}.project-card:hover{border-color:var(--primary);box-shadow:0 4px 16px #3b82f61f;transform:translateY(-1px)}.project-card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.project-name{font-weight:700;font-size:15px;margin-bottom:3px}.project-meta{font-size:11px;color:var(--muted)}.project-status{padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600;flex-shrink:0}.s-active{background:#dcfce7;color:#16a34a}.s-planning{background:#fef9c3;color:#a16207}.s-done{background:#f1f5f9;color:var(--muted)}.project-progress-wrap{margin-bottom:14px}.progress-label{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-bottom:5px}.progress-track{height:5px;background:var(--border);border-radius:3px;overflow:hidden}.progress-bar{height:100%;border-radius:3px;background:var(--primary)}.project-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--border);font-size:11px;color:var(--muted)}.card-stat{display:flex;align-items:center;gap:4px}.card-open-btn{font-size:12px;color:var(--primary);font-weight:500;background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .12s}.card-open-btn:hover{background:var(--primary-light)}.new-project-card{background:var(--surface);border:2px dashed var(--border);border-radius:10px;padding:20px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);min-height:160px;transition:all .18s}.new-project-card:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.new-project-card .plus{font-size:30px;font-weight:300;line-height:1}.new-project-card span{font-size:13px;font-weight:500}.gantt-toolbar{height:42px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 10px;gap:2px;flex-shrink:0}.tbtn{height:28px;padding:0 7px;border:none;background:none;border-radius:4px;cursor:pointer;color:var(--text);font-size:12px;display:flex;align-items:center;gap:4px;transition:background .1s;white-space:nowrap;font-family:inherit}.tbtn:hover{background:var(--hover)}.tbtn.active{background:var(--primary-light);color:var(--primary)}.tbtn:disabled{opacity:.4;cursor:default}.tbtn svg{width:13px;height:13px;flex-shrink:0}.tsep{width:1px;height:18px;background:var(--border);margin:0 3px}.tbreadcrumb{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:4px;margin-right:6px}.tbreadcrumb .current{color:var(--text);font-weight:600}.tsep-big{flex:1}.zoom-label{font-size:11px;color:var(--muted);padding:0 2px}.gantt-workspace{flex:1;display:flex;overflow:hidden}.task-list-panel{width:420px;min-width:420px;border-right:2px solid var(--border);overflow:hidden;display:flex;flex-direction:column;background:var(--surface);position:relative;z-index:5}.task-table-header{display:grid;grid-template-columns:44px 1fr 42px 52px 52px 42px;height:56px;border-bottom:2px solid var(--border);background:var(--surface);flex-shrink:0}.th{display:flex;align-items:flex-end;padding:0 6px 10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}.th:first-child{padding-left:10px}.task-table-body{overflow-y:auto;flex:1}.task-row{display:grid;grid-template-columns:44px 1fr 42px 52px 52px 42px;height:36px;cursor:pointer;border-bottom:1px solid rgba(226,232,240,.5);transition:background .1s}.task-row:hover .tc{background:var(--hover)}.task-row.selected .tc{background:var(--selected)}.task-row.summary .tc{background:#f8fafc}.task-row.summary:hover .tc{background:var(--hover)}.tc{display:flex;align-items:center;padding:0 6px;overflow:hidden;font-size:12px;color:var(--text);transition:background .1s}.tc:first-child{padding-left:10px}.tc-wbs{font-size:10px;color:var(--muted);font-weight:500}.tc-name{font-weight:400}.tc-num{justify-content:center;color:var(--muted);font-size:11px}.tc-date{font-size:10px;color:var(--muted);white-space:nowrap}.summary .tc-name{font-weight:700}.summary .tc-num{color:var(--muted)}.task-indent{flex-shrink:0}.expand-btn{width:14px;height:14px;flex-shrink:0;border:none;background:none;cursor:pointer;font-size:9px;color:var(--muted);display:flex;align-items:center;justify-content:center;border-radius:2px}.expand-btn:hover{background:var(--border)}.milestone-sym{color:var(--milestone-color);font-size:10px;flex-shrink:0}.name-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.critical-flag{color:var(--critical);font-size:9px;flex-shrink:0;margin-left:3px}.gantt-chart-panel{flex:1;overflow:auto;position:relative;background:var(--surface);scroll-behavior:smooth}#gantt-svg{display:block;cursor:default}.gantt-bar{cursor:pointer}.gantt-bar:hover{filter:brightness(1.08)}.page-body{flex:1;overflow-y:auto;padding:32px}.page-inner{max-width:680px}.page-title{font-size:18px;font-weight:700;margin-bottom:3px}.page-sub{font-size:13px;color:var(--muted);margin-bottom:28px}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:20px;box-shadow:var(--shadow)}.section-title{font-size:13px;font-weight:700;margin-bottom:14px;color:var(--text)}.field-row{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.field-row:last-child{margin-bottom:0}.field-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.field-input,.field-select{height:36px;border:1px solid var(--border);border-radius:var(--radius);padding:0 10px;font-size:13px;color:var(--text);background:var(--surface);outline:none;width:100%;font-family:inherit}.field-input:focus,.field-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.field-textarea{border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;font-size:13px;color:var(--text);background:var(--surface);outline:none;width:100%;resize:vertical;min-height:80px;font-family:inherit}.field-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.days-grid{display:flex;gap:8px;flex-wrap:wrap}.day-chip{width:48px;height:48px;border:1.5px solid var(--border);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;font-size:11px;font-weight:600;color:var(--muted);transition:all .15s;-webkit-user-select:none;user-select:none}.day-chip.on{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.day-chip:hover:not(.on){border-color:var(--primary);background:#f0f7ff}.day-chip .day-abbr{font-size:12px;font-weight:700}.day-chip .day-letter{font-size:9px;font-weight:500;color:inherit}.holiday-list{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.holiday-header{display:grid;grid-template-columns:120px 1fr 80px;background:var(--bg);padding:7px 12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:1px solid var(--border)}.holiday-row{display:grid;grid-template-columns:120px 1fr 80px;padding:9px 12px;border-bottom:1px solid var(--border);font-size:12px;align-items:center}.holiday-row:last-child{border-bottom:none}.holiday-row:hover{background:var(--hover)}.remove-holiday{background:none;border:none;cursor:pointer;color:var(--muted);font-size:15px;line-height:1;display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;transition:all .12s}.remove-holiday:hover{background:var(--critical-light);color:var(--critical)}.add-row{display:flex;gap:8px;margin-top:12px;align-items:flex-end}.add-row .field-input{flex:1}.helper{font-size:11px;color:var(--muted);margin-top:4px}.danger-zone{border:1px solid #fca5a5;border-radius:10px;padding:20px;margin-bottom:20px}.danger-zone .section-title{color:var(--critical)}.danger-desc{font-size:12px;color:var(--muted);margin-bottom:12px}.overlay{position:fixed;right:0;bottom:0;left:0;top:50px;background:#0f172a40;z-index:200;opacity:0;pointer-events:none;transition:opacity .2s}.overlay.open{opacity:1;pointer-events:auto}.task-panel{position:fixed;top:50px;right:0;bottom:0;width:340px;background:var(--surface);border-left:1px solid var(--border);z-index:201;transform:translate(100%);transition:transform .22s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-6px 0 20px #00000017}.task-panel.open{transform:translate(0)}.panel-hdr{padding:14px 14px 10px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:8px;flex-shrink:0}.panel-hdr-title{flex:1}.panel-task-name{font-weight:700;font-size:14px;line-height:1.3}.panel-wbs{font-size:11px;color:var(--muted);margin-top:2px}.panel-close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:18px;line-height:1;padding:2px 4px;border-radius:4px;flex-shrink:0}.panel-close:hover{background:var(--hover);color:var(--text)}.panel-body{overflow-y:auto;flex:1;padding:14px}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}.info-cell{background:var(--surface);padding:10px 12px}.info-cell .lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:3px}.info-cell .val{font-size:13px;font-weight:600}.badge-critical{color:var(--critical)}.badge-ok{color:#16a34a}.panel-field{margin-bottom:14px}.panel-field .lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:5px}.panel-field .field-select,.panel-field .field-input{width:100%}.constraint-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.conflict-box{background:#fffbeb;border:1px solid #fcd34d;border-radius:var(--radius);padding:10px 12px;font-size:11px;color:#78350f;margin-bottom:14px;display:none;gap:7px;align-items:flex-start}.conflict-box.show{display:flex}.conflict-icon{flex-shrink:0;font-size:14px}.float-bar-wrap{height:6px;background:var(--border);border-radius:3px;margin-top:6px;overflow:hidden}.float-bar{height:100%;border-radius:3px;background:var(--success)}.float-bar.warn{background:var(--milestone-color)}.float-bar.critical{background:var(--critical)}.panel-ftr{padding:12px 14px;border-top:1px solid var(--border);display:flex;gap:7px;flex-shrink:0}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.page-actions{display:flex;gap:8px;padding-top:16px;border-top:1px solid var(--border);margin-top:8px}.tag{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:20px;font-size:11px;font-weight:500}.tag-blue{background:var(--primary-light);color:var(--primary)}.tag-red{background:var(--critical-light);color:var(--critical)}.tag-green{background:#dcfce7;color:#16a34a}.tag-gray{background:#f1f5f9;color:var(--muted)}.sub-nav{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 32px;background:var(--surface);flex-shrink:0}.sub-nav button{background:none;border:none;border-bottom:2px solid transparent;padding:10px 14px;font-size:13px;color:var(--muted);cursor:pointer;font-family:inherit;transition:all .15s;margin-bottom:-1px;font-weight:500}.sub-nav button:hover{color:var(--text)}.sub-nav button.active{color:var(--primary);border-bottom-color:var(--primary)}
