@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Sans:wght@300;400;500;600;700&display=swap";[data-theme=dark]{--bg: #0d0f14;--surface: #13161e;--surface2: #1a1e28;--surface3: #222736;--border: #2a3040;--border2: #363d52;--text: #e8eaf0;--text2: #8b90a0;--text3: #545a6e;--card-bg: #13161e;--input-bg: #1a1e28;--shadow: 0 2px 12px rgba(0,0,0,.4)}[data-theme=light]{--bg: #f0f2f7;--surface: #ffffff;--surface2: #f5f6fa;--surface3: #eceef5;--border: #dde1ec;--border2: #c8ccdb;--text: #1a1d2e;--text2: #5a5f7a;--text3: #9096b0;--card-bg: #ffffff;--input-bg: #f5f6fa;--shadow: 0 2px 12px rgba(0,0,0,.08)}:root{--accent: #4f7cff;--accent2: #7c5cff;--green: #3dd68c;--yellow: #e8b800;--red: #ff5c5c;--orange: #ff8c42;--cyan: #3dd6d6;--pink: #ff6eb4;--mono: "IBM Plex Mono", monospace;--sans: "IBM Plex Sans", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--sans);background:var(--bg);color:var(--text);height:100vh;display:flex;flex-direction:column;overflow:hidden;font-size:13px;transition:background .2s,color .2s}.topbar{background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;height:48px;gap:14px;flex-shrink:0;z-index:100;box-shadow:var(--shadow)}.logo{font-family:var(--mono);font-weight:600;font-size:15px;color:var(--accent);letter-spacing:-.5px;white-space:nowrap}.logo span{color:var(--text2);font-weight:400}.logo sup{font-size:9px;color:var(--accent2);vertical-align:super}.project-selector{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font-size:12px;min-width:180px}.project-selector select{background:none;border:none;color:var(--text);font-family:var(--sans);font-size:12px;cursor:pointer;width:100%;outline:none}.project-selector select option{background:var(--surface2);color:var(--text)}.topbar-actions{display:flex;gap:8px;margin-left:auto;align-items:center}.autosave-indicator{font-family:var(--mono);font-size:10px;color:var(--text3);display:flex;align-items:center;gap:5px}.autosave-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}.autosave-dot.saving{background:var(--yellow);animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.theme-toggle{display:flex;align-items:center;background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:3px;gap:2px;cursor:pointer}.theme-btn{width:26px;height:22px;border-radius:16px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s;background:transparent;color:var(--text3)}.theme-btn.active{background:var(--accent);color:#fff}.app-body{display:flex;flex:1;overflow:hidden}.sidebar{width:204px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;font-size:12px;color:var(--text2);border-left:2px solid transparent;transition:all .1s}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--surface2);color:var(--accent);border-left-color:var(--accent)}.sidebar-section{padding:12px 16px 4px;font-size:10px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;font-weight:600}.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.view-panel{display:none;flex:1;overflow:hidden;flex-direction:column}.view-panel.active{display:flex}.btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:5px;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;font-weight:500;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#6b91ff}.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.btn-danger{background:var(--red);color:#fff}.btn-success{background:var(--green);color:#000}.btn-sm{padding:4px 8px;font-size:11px}.field-group{display:flex;flex-direction:column;gap:5px}.field-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.field-input,.field-textarea,.field-select{background:var(--input-bg);border:1px solid var(--border);border-radius:5px;padding:7px 10px;color:var(--text);font-family:var(--sans);font-size:13px;outline:none;width:100%;transition:border-color .15s}.field-input:focus,.field-textarea:focus,.field-select:focus{border-color:var(--accent)}.field-textarea{resize:vertical;min-height:72px}.field-select option{background:var(--surface2);color:var(--text)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;background:var(--surface3);color:var(--text2);border:1px solid var(--border)}.tag-remove{cursor:pointer;opacity:.6}.tag-remove:hover{opacity:1;color:var(--red)}.tags-container{display:flex;flex-wrap:wrap;gap:5px;align-items:center}.tag-input-wrap{display:flex;gap:6px;align-items:center}.status-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;white-space:nowrap}.s-backlog{background:#8b90a026;color:var(--text2)}.s-todo{background:#4f7cff26;color:var(--accent)}.s-inprogress{background:#e8b80026;color:var(--yellow)}.s-review{background:#3dd6d626;color:var(--cyan)}.s-done{background:#3dd68c26;color:var(--green)}.s-blocked{background:#ff5c5c26;color:var(--red)}.p-critical{background:var(--red)}.p-high{background:var(--orange)}.p-medium{background:var(--yellow)}.p-low{background:var(--green)}.assignee-avatar{width:22px;height:22px;border-radius:50%;background:var(--accent2);display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;flex-shrink:0}.priority-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.bell-badge{position:relative;display:inline-flex}.bell-count{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:9px;font-weight:700;min-width:14px;height:14px;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:50px;color:var(--text3);gap:10px;text-align:center}.empty-state h3{font-size:15px;color:var(--text2)}.empty-state p{font-size:12px;max-width:300px}.toast{position:fixed;bottom:20px;right:20px;background:var(--surface);border:1px solid var(--border2);border-radius:6px;padding:10px 16px;font-size:12px;color:var(--text);z-index:500;display:none;align-items:center;gap:8px;box-shadow:var(--shadow);animation:toastIn .2s ease}.toast.show{display:flex}@keyframes toastIn{0%{transform:translateY(10px);opacity:0}}.reminder-popup{position:fixed;bottom:20px;left:20px;background:var(--surface);border:1px solid var(--yellow);border-radius:8px;padding:14px 18px;font-size:12px;color:var(--text);z-index:500;display:none;flex-direction:column;gap:6px;box-shadow:0 4px 20px #0000004d;max-width:320px}.reminder-popup.show{display:flex}.reminder-popup-title{font-weight:600;color:var(--yellow);display:flex;align-items:center;gap:6px}.projects-grid{padding:18px;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;overflow-y:auto;align-content:start}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px;cursor:pointer;transition:border-color .15s,box-shadow .15s}.project-card:hover{border-color:var(--accent);box-shadow:0 0 0 3px #4f7cff1a}.project-card.active-proj{border-color:var(--accent);background:#4f7cff0a}.project-card h3{font-size:14px;margin-bottom:4px}.project-card p{font-size:11px;color:var(--text3)}.project-card-meta{display:flex;gap:10px;margin-top:12px;font-size:10px;color:var(--text3)}.project-progress{height:3px;background:var(--surface3);border-radius:2px;margin-top:10px;overflow:hidden}.project-progress-bar{height:100%;background:var(--accent);border-radius:2px;transition:width .4s}.divider{border:none;border-top:1px solid var(--border);margin:4px 0}.badge-count{font-family:var(--mono);font-size:9px;background:var(--surface3);padding:1px 5px;border-radius:8px;color:var(--text3);margin-left:auto}.dashboard-grid{padding:18px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}.stats-row{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:14px 16px}.stat-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.stat-value{font-family:var(--mono);font-size:26px;font-weight:600}.stat-sub{font-size:10px;color:var(--text3);margin-top:3px}.dash-row2{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.status-col{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.status-col-header{padding:9px 12px;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.status-badge{font-family:var(--mono);font-size:10px;padding:2px 7px;border-radius:10px;font-weight:600}.status-col-tickets{padding:8px;display:flex;flex-direction:column;gap:5px;min-height:80px}.mini-ticket{background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:7px 9px;cursor:pointer;transition:border-color .1s}.mini-ticket:hover{border-color:var(--accent)}.mini-ticket-id{font-family:var(--mono);font-size:9px;color:var(--text3)}.mini-ticket-title{font-size:11px;margin-top:2px}.mini-ticket-meta{display:flex;gap:6px;margin-top:5px;align-items:center;flex-wrap:wrap}.list-toolbar{padding:9px 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;flex-wrap:wrap}.search-input{flex:1;min-width:140px;background:var(--input-bg);border:1px solid var(--border);border-radius:5px;padding:6px 10px;color:var(--text);font-family:var(--sans);font-size:12px;outline:none}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text3)}select.filter-select{background:var(--input-bg);border:1px solid var(--border);border-radius:5px;padding:6px 9px;color:var(--text);font-family:var(--sans);font-size:12px;outline:none;cursor:pointer}select.filter-select option{background:var(--surface2);color:var(--text)}.tickets-table-wrap{flex:1;overflow-y:auto}table.tickets-table{width:100%;border-collapse:collapse;font-size:12px}.tickets-table th{background:var(--surface);padding:7px 11px;text-align:left;font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;font-weight:600;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10;white-space:nowrap}.tickets-table td{padding:7px 11px;border-bottom:1px solid var(--border);vertical-align:middle}.tickets-table tr:hover td{background:var(--surface2)}.level-1-row td{background:#4f7cff0a}.level-2-row td{background:#7c5cff08}.indent-1{padding-left:12px!important}.indent-2{padding-left:28px!important}.indent-3{padding-left:44px!important}.group-toggle{cursor:pointer;display:inline-flex;align-items:center;gap:6px;font-weight:600}.group-toggle .chevron{transition:transform .15s;color:var(--text3)}.group-toggle.collapsed .chevron{transform:rotate(-90deg)}.ticket-id-cell{font-family:var(--mono);font-size:10px;color:var(--text3);white-space:nowrap}.ticket-title-cell{cursor:pointer}.ticket-title-cell:hover{color:var(--accent)}.ticket-detail-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;align-items:flex-start;justify-content:flex-end}.ticket-detail-overlay.open{display:flex}.ticket-detail-panel{width:620px;height:100%;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;animation:slideIn .2s ease;box-shadow:-4px 0 24px #0003}@keyframes slideIn{0%{transform:translate(40px);opacity:0}}.detail-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.detail-id{font-family:var(--mono);font-size:11px;color:var(--text3)}.detail-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}.detail-tab{padding:10px 18px;font-size:12px;cursor:pointer;color:var(--text2);border-bottom:2px solid transparent;transition:all .15s;font-weight:500}.detail-tab:hover{color:var(--text)}.detail-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.detail-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:16px}.detail-tab-panel{display:none;flex-direction:column;gap:16px}.detail-tab-panel.active{display:flex}.comment-list{display:flex;flex-direction:column;gap:12px}.comment-item{display:flex;gap:10px}.comment-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}.comment-bubble{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;flex:1}.comment-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.comment-author{font-size:11px;font-weight:600}.comment-time{font-size:10px;color:var(--text3);font-family:var(--mono)}.comment-text{font-size:12px;color:var(--text);line-height:1.5;white-space:pre-wrap}.comment-add{display:flex;gap:8px;align-items:flex-end}.comment-input{flex:1;background:var(--input-bg);border:1px solid var(--border);border-radius:6px;padding:8px 10px;color:var(--text);font-family:var(--sans);font-size:12px;outline:none;resize:none;min-height:60px}.comment-input:focus{border-color:var(--accent)}.activity-item{display:flex;gap:10px;align-items:flex-start;font-size:11px}.activity-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);flex-shrink:0;margin-top:3px}.activity-dot.create{background:var(--green)}.activity-dot.update{background:var(--accent)}.activity-dot.comment{background:var(--cyan)}.activity-dot.status{background:var(--yellow)}.activity-line{flex:1}.activity-time{color:var(--text3);font-family:var(--mono);font-size:10px}.attach-list{display:flex;flex-direction:column;gap:8px}.attach-item{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:9px 12px}.attach-icon{font-size:18px;flex-shrink:0}.attach-info{flex:1;overflow:hidden}.attach-name{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attach-meta{font-size:10px;color:var(--text3);margin-top:2px}.attach-link{color:var(--accent);text-decoration:none;font-size:11px}.attach-link:hover{text-decoration:underline}.attach-remove{cursor:pointer;color:var(--text3);font-size:14px;padding:2px}.attach-remove:hover{color:var(--red)}#attDropZone:hover{border-color:var(--accent);background:#4f7cff0a}#attDropZone.dragover{border-color:var(--accent);background:#4f7cff14}.gantt-container{flex:1;overflow:hidden;display:flex;flex-direction:column}.gantt-toolbar{padding:9px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;background:var(--surface);flex-shrink:0}.gantt-scroll-wrap{flex:1;overflow:auto}.gantt-inner{display:flex;flex-direction:column}.gantt-row{display:flex;align-items:center;height:32px;border-bottom:1px solid var(--border)}.gantt-row:hover{background:var(--surface2)}.gantt-row-label{width:280px;flex-shrink:0;padding:0 12px;font-size:11px;display:flex;align-items:center;gap:6px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;border-right:1px solid var(--border);cursor:pointer;position:sticky;left:0;background:var(--bg);z-index:4;height:32px}.gantt-row-label:hover{background:var(--surface2)}.gantt-cells{display:flex;position:relative}.gantt-cell{width:30px;height:32px;flex-shrink:0;border-right:1px solid var(--border)}.gantt-cell.weekend{background:#8080800f}.gantt-cell.today{background:#4f7cff14}.gantt-day-col{width:30px;flex-shrink:0;text-align:center;font-size:9px;color:var(--text3);border-right:1px solid var(--border);padding:2px 0;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1.2}.gantt-day-col.weekend{background:#8080800f}.gantt-day-col.today{background:#4f7cff1a;color:var(--accent);font-weight:700}.gantt-bar{position:absolute;height:18px;top:7px;border-radius:3px;display:flex;align-items:center;padding:0 6px;font-size:9px;font-weight:600;overflow:hidden;white-space:nowrap;color:#fff;cursor:pointer;z-index:3;transition:opacity .15s}.gantt-bar:hover{opacity:.8}.analytics-grid{padding:18px;overflow-y:auto;flex:1;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-content:start}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px}.chart-card.wide{grid-column:span 2}.chart-card.full{grid-column:1 / -1}.chart-title{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px}.chart-wrap{position:relative}.reminder-item{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:8px 12px}.reminder-bell{font-size:16px;flex-shrink:0}.reminder-info{flex:1}.reminder-msg{font-size:12px;font-weight:500}.reminder-time{font-size:10px;color:var(--text3);font-family:var(--mono)}.reminder-done{width:16px;height:16px;border-radius:3px;border:1px solid var(--border2);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;flex-shrink:0}.reminder-done:checked{background:var(--green);border-color:var(--green)}.dep-list{display:flex;flex-direction:column;gap:6px}.dep-item{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:6px 10px;font-size:11px}.dep-type{font-family:var(--mono);font-size:9px;color:var(--accent);background:#4f7cff1a;padding:2px 6px;border-radius:3px}.dep-remove{margin-left:auto;cursor:pointer;color:var(--text3)}.dep-remove:hover{color:var(--red)}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:300;align-items:center;justify-content:center}.modal-overlay.open{display:flex}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:10px;padding:22px;width:480px;max-height:86vh;overflow-y:auto;display:flex;flex-direction:column;gap:14px;box-shadow:0 8px 40px #0000004d;animation:modalIn .15s ease}@keyframes modalIn{0%{transform:scale(.97);opacity:0}}.modal h2{font-size:16px;font-weight:600}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.modal-wide{width:560px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text3)}.auth-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--bg)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px 28px 24px;width:360px;max-width:92vw}.auth-card h2{font-size:18px;margin:0 0 4px;color:var(--text)}.auth-card .auth-subtitle{font-size:12px;color:var(--text3);margin-bottom:18px}.auth-card .field-group{margin-bottom:12px}.auth-error{background:#ff50501a;border:1px solid rgba(255,80,80,.25);color:var(--red);font-size:12px;padding:8px 12px;border-radius:6px;margin-bottom:12px;display:none}.auth-toggle{text-align:center;font-size:12px;color:var(--text3);margin-top:14px}.auth-toggle a{color:var(--accent);cursor:pointer;text-decoration:none}.auth-toggle a:hover{text-decoration:underline}
