:root{--bg:#0f1117;--bg2:#1a1d27;--bg3:#242736;--border:#2e3247;--text:#e2e8f0;--text2:#94a3b8;--text3:#64748b;--accent:#6366f1;--hover:#252840;--row-h:36px;--hdr-h:56px;--label-w:240px;--today:#f43f5e;--toolbar:48px;--app-hdr:56px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);flex-direction:column;height:100vh;font-family:Inter,Segoe UI,system-ui,sans-serif;font-size:13px;display:flex;overflow:hidden}button{font-family:inherit}.app-header{height:var(--app-hdr);background:var(--bg2);border-bottom:1px solid var(--border);z-index:50;flex-shrink:0;align-items:center;gap:16px;padding:0 20px;display:flex}.app-header h1{white-space:nowrap;font-size:14px;font-weight:700}.app-header .sub{color:var(--text3);margin-top:1px;font-size:11px}.spacer{flex:1}.btn-sm{border:1px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;border-radius:6px;padding:5px 12px;font-size:11px;font-weight:500;transition:all .15s}.btn-sm:hover{border-color:var(--accent);color:var(--text)}.btn-primary{background:var(--accent);border:1px solid var(--accent);color:#fff;cursor:pointer;border-radius:6px;padding:8px 16px;font-size:12px;font-weight:600;transition:all .15s}.btn-primary:hover{filter:brightness(1.1)}.btn-primary:disabled{opacity:.5;cursor:default}.auth-screen{flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.auth-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;width:100%;max-width:380px;padding:32px}.auth-card h2{margin-bottom:6px;font-size:18px}.auth-card .sub{color:var(--text3);margin-bottom:20px;font-size:12px}.auth-card label{color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.auth-card input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);border-radius:6px;outline:none;margin-bottom:14px;padding:10px 12px;font-size:13px}.auth-card input:focus{border-color:var(--accent)}.auth-card button{width:100%}.auth-msg{border-radius:6px;margin-top:14px;padding:10px;font-size:12px}.auth-msg.info{color:#93c5fd;background:#1e3a5f33;border:1px solid #3b82f6}.auth-msg.error{color:#f87171;background:#7f1d1d33;border:1px solid #ef4444}.picker-screen{flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.picker-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;width:100%;max-width:480px;padding:32px}.picker-card h2{margin-bottom:16px;font-size:18px}.plan-list{flex-direction:column;gap:8px;max-height:320px;margin-bottom:16px;display:flex;overflow-y:auto}.plan-item{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:6px;justify-content:space-between;align-items:center;padding:12px 14px;transition:all .15s;display:flex}.plan-item:hover{border-color:var(--accent);background:var(--hover)}.plan-item .name{font-weight:600}.plan-item .meta{color:var(--text3);font-size:11px}.plan-empty{text-align:center;color:var(--text3);padding:20px;font-size:12px}.new-plan-row{border-top:1px solid var(--border);gap:8px;padding-top:16px;display:flex}.new-plan-row input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;outline:none;flex:1;padding:8px 10px;font-size:12px}.new-plan-row input:focus{border-color:var(--accent)}.app-screen{flex-direction:column;flex:1;display:flex;overflow:hidden}.app-placeholder{color:var(--text3);flex:1;justify-content:center;align-items:center;font-size:13px;display:flex}.hidden{display:none!important}.gantt-toolbar{height:var(--toolbar);background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:0 16px;display:flex}.btn-add{color:#93c5fd;cursor:pointer;background:#1e3a5f;border:1px solid #3b82f6;border-radius:6px;padding:5px 12px;font-size:11px;font-weight:700;transition:all .15s}.btn-add:hover{color:#fff;background:#2563eb}.filter-sep{background:var(--border);width:1px;height:20px;margin:0 4px}.filter-label{color:var(--text3);text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:700}.zoom-btn{border:1px solid var(--border);width:24px;height:24px;color:var(--text2);cursor:pointer;background:0 0;border-radius:5px;justify-content:center;align-items:center;font-size:15px;font-weight:700;transition:all .15s;display:flex}.zoom-btn:hover{background:var(--bg3);color:var(--text)}.zoom-btn:disabled{opacity:.3;cursor:default}.gantt-outer{flex:1;position:relative;overflow:auto}.gantt-content{flex-direction:column;min-width:max-content;display:flex}.g-hdr{z-index:30;height:var(--hdr-h);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;position:sticky;top:0}.g-hdr .col-label{width:var(--label-w);z-index:50;background:var(--bg2);border-right:1px solid var(--border);color:var(--text3);text-transform:uppercase;letter-spacing:.07em;flex-shrink:0;align-items:flex-end;padding:0 12px 8px;font-size:10px;font-weight:700;display:flex;position:sticky;left:0}.g-hdr .col-timeline{flex-shrink:0;position:relative}.tl-quarter{height:20px;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;border-left:1px solid var(--border);align-items:center;padding-left:6px;font-size:9px;font-weight:700;display:flex;position:absolute;top:0}.tl-month{min-height:18px;color:var(--text2);border-left:1px solid var(--border);align-items:center;padding-left:5px;font-size:10px;font-weight:500;display:flex;position:absolute;top:20px;bottom:0}.tl-month.minor{border-left-color:#2e324766}.tl-week{height:18px;color:var(--text3);border-left:1px solid #2e324780;align-items:center;padding-left:4px;font-size:9px;display:flex;position:absolute}.tl-day{height:18px;color:var(--text3);pointer-events:none;border-left:1px solid #2e324759;justify-content:center;align-items:center;font-size:9px;display:flex;position:absolute}.tl-day.weekend{color:#6366f1;background:#6366f112}.g-hdr.weeks-visible{height:74px}.weeks-visible .tl-month{height:18px;top:20px;bottom:auto}.weeks-visible .tl-week{height:auto;min-height:18px;top:38px;bottom:0}.g-hdr.days-visible{height:92px}.days-visible .tl-month{height:18px;top:20px;bottom:auto}.days-visible .tl-week{height:18px;top:38px;bottom:auto}.days-visible .tl-day{height:18px;top:56px}.vline{pointer-events:none;background:#2e324766;width:1px;position:absolute;top:0;bottom:0}.vline.major{background:#2e3247cc}.vline.week{background:#2e32478c}.vline.day{background:#2e324738}.vline.wknd{background:#6366f12e}.today-line{background:var(--today);z-index:4;pointer-events:none;width:2px;position:absolute;top:0;bottom:0}.g-row{display:flex}.g-row:nth-child(2n) .col-label,.g-row:nth-child(2n) .col-chart{background:#1e2130}.g-row:nth-child(odd) .col-label,.g-row:nth-child(odd) .col-chart{background:var(--bg2)}.g-row:hover .col-label,.g-row:hover .col-chart{background:var(--hover)}.g-row .col-label{width:var(--label-w);z-index:40;background:var(--bg2);border-right:1px solid var(--border);border-bottom:1px solid var(--border);height:var(--row-h);flex-shrink:0;align-items:center;padding:0 12px;display:flex;position:sticky;left:0}.res-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:600;overflow:hidden}.res-role{color:var(--text3);white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.g-row .col-chart{height:var(--row-h);border-bottom:1px solid var(--border);flex-shrink:0;position:relative}.gbar{height:calc(var(--row-h) - 8px);cursor:grab;color:#ffffffeb;white-space:nowrap;-webkit-user-select:none;user-select:none;z-index:3;border-radius:4px;align-items:center;padding:0 6px;font-size:10px;font-weight:700;transition:filter .1s;display:flex;position:absolute;top:4px;overflow:hidden;box-shadow:inset 0 1px #ffffff26}.gbar:hover{filter:brightness(1.15);z-index:6}.gbar.gbar-status-not_started{opacity:.55;outline-offset:-2px;outline:1.5px dashed #ffffff8c}.gbar.gbar-status-closed{opacity:.35}.gbar.gbar-status-closed .gbar-label{text-decoration:line-through}.gbar.dragging{opacity:.85;z-index:20;cursor:grabbing;transition:none}.gbar .resize-l,.gbar .resize-r{cursor:ew-resize;width:7px;position:absolute;top:0;bottom:0}.gbar .resize-l{left:0}.gbar .resize-r{right:0}.g-row.drop-target .col-label,.g-row.drop-target .col-chart{outline-offset:-1px;outline:1px solid #6366f180;background:#6366f12e!important}.cust-window{pointer-events:none;z-index:1;border-left:1px dashed;border-right:1px dashed;position:absolute;top:0;bottom:0}.modal-backdrop{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:14px;width:100%;max-width:440px;padding:24px;display:flex}.modal-title{font-size:16px;font-weight:700}.modal-body{flex-direction:column;gap:12px;display:flex}.modal-body label{color:var(--text3);text-transform:uppercase;letter-spacing:.05em;flex-direction:column;gap:4px;font-size:11px;font-weight:600;display:flex}.modal-body input,.modal-body select,.modal-body textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);text-transform:none;letter-spacing:0;border-radius:6px;outline:none;padding:8px 10px;font-family:inherit;font-size:13px}.modal-body input:focus,.modal-body select:focus,.modal-body textarea:focus{border-color:var(--accent)}.modal-body textarea{resize:vertical;min-height:80px;line-height:1.45}.modal-body textarea.modal-textarea-lg{min-height:180px}.modal-card{max-width:600px}.status{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700}.status-not_started{color:#94a3b8;background:#1e293b}.status-ongoing{color:#93c5fd;background:#1e3a5f}.status-closed{color:#6ee7b7;background:#064e3b}.members-list{flex-direction:column;gap:8px;max-height:320px;display:flex;overflow-y:auto}.members-section-title{color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-top:8px;font-size:11px;font-weight:700}.member-row{background:var(--bg);border:1px solid var(--border);border-radius:6px;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.member-email{font-size:13px;font-weight:600}.member-role{color:var(--text3);margin-top:2px;font-size:11px}.invite-row{border-top:1px solid var(--border);gap:8px;padding-top:12px;display:flex}.invite-row input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:6px;outline:none;flex:1;padding:8px 10px;font-size:12px}.invite-row input:focus{border-color:var(--accent)}.modal-actions{align-items:center;gap:8px;display:flex}.btn-danger{color:#f87171!important;border-color:#7f1d1d!important}.btn-danger:hover{background:#7f1d1d33;border-color:#ef4444!important}.tab-nav{gap:2px;display:flex}.tab-btn{border:1px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;border-radius:6px;padding:5px 14px;font-size:12px;font-weight:500;transition:all .15s}.tab-btn:hover{background:var(--bg3);color:var(--text)}.tab-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.tab-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.tab-content.hidden{display:none!important}.table-toolbar{height:var(--toolbar);background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:0 20px;display:flex}.count-lbl{color:var(--text3);font-size:11px}.table-outer{flex:1;padding:12px 20px 40px;overflow:auto}table{border-collapse:collapse;width:100%}thead th{background:var(--bg2);color:var(--text3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);z-index:10;text-align:left;white-space:nowrap;padding:7px 8px;font-size:10px;font-weight:700;position:sticky;top:0}tbody tr{cursor:pointer;border-bottom:1px solid #2e324780;transition:background .1s}tbody tr:hover{background:#ffffff0a}td{vertical-align:middle;padding:8px;font-size:12px}.tickets-table tr.ticket-row td{background:#6366f10d;padding:10px 8px}.tickets-table tr.task-row td:first-child{width:24px}.dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.prio{text-transform:uppercase;letter-spacing:.04em;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700}.prio-low{color:#94a3b8;background:#1e293b}.prio-medium{color:#93c5fd;background:#1e3a5f}.prio-high{color:#fdba74;background:#5b2818}.prio-critical{color:#fca5a5;background:#7f1d1d}
