*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f8fafc;--text-secondary: #94a3b8;--border-color: #475569;--accent: #3b82f6;--accent-hover: #2563eb;--error: #ef4444;--success: #10b981}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}.layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.header h1{font-size:18px;font-weight:600}.header-actions{display:flex;gap:8px;align-items:center}.header-separator{width:1px;height:20px;background:var(--border-color)}.header-btn{padding:6px 12px;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-size:13px;cursor:pointer;transition:background .15s,opacity .15s}.header-btn:hover:not(:disabled){background:var(--border-color)}.header-btn:disabled{opacity:.4;cursor:not-allowed}.header-btn-danger:hover:not(:disabled){background:var(--error);border-color:var(--error)}.day-view-controls{display:flex;align-items:center;gap:0}.day-view-btn{padding:6px 16px;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);font-size:13px;cursor:pointer;transition:background .15s;min-width:120px}.day-view-btn:hover{background:var(--border-color)}.day-view-btn.active{background:var(--accent);border-color:var(--accent)}.day-nav-btn{padding:6px 10px;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);font-size:13px;font-weight:700;cursor:pointer;transition:background .15s}.day-nav-btn:first-child{border-radius:6px 0 0 6px;border-right:none}.day-nav-btn:last-child{border-radius:0 6px 6px 0;border-left:none}.day-nav-btn:hover{background:var(--border-color)}.day-view-controls .day-view-btn{border-radius:0}.day-view-controls .day-view-btn:only-child{border-radius:6px}.header-user{display:flex;align-items:center;gap:12px;margin-left:auto}.user-avatar{width:32px;height:32px;border-radius:50%}.menu-toggle{display:none;background:none;border:none;color:var(--text-primary);font-size:20px;cursor:pointer;padding:4px 8px}.layout-body{display:flex;flex:1;overflow:hidden}.sidebar{width:320px;flex-shrink:0;background:var(--bg-secondary);border-right:1px solid var(--border-color);overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.sidebar::-webkit-scrollbar{display:none}.main{flex:1;overflow:hidden}@media(max-width:768px){.menu-toggle{display:block}.sidebar{position:fixed;top:49px;left:0;bottom:0;width:300px;transform:translate(-100%);transition:transform .2s ease;z-index:100}.sidebar.open{transform:translate(0)}}.sign-in-container{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary)}.sign-in-box{background:var(--bg-secondary);padding:48px;border-radius:12px;text-align:center;border:1px solid var(--border-color)}.sign-in-box h1{margin-bottom:24px;font-size:24px}.loading,.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px}.error-screen button{padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer}.ticket-list{padding:16px}.ticket-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.ticket-list h2{font-size:14px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);margin-bottom:0}.sync-btn{padding:6px 12px;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-size:12px;cursor:pointer;transition:background .15s}.sync-btn:hover:not(:disabled){background:var(--border-color)}.sync-btn:disabled{opacity:.5;cursor:not-allowed}.filter-input{width:100%;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;margin-bottom:12px}.filter-input:focus{outline:none;border-color:var(--accent)}.filter-input::placeholder{color:var(--text-secondary)}.customer-filter{width:100%;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;margin-bottom:12px}.customer-filter:focus{outline:none;border-color:var(--accent)}.ticket-customer{color:var(--accent);font-weight:400;font-size:11px}.ticket-section{margin-bottom:24px}.ticket-section h2{font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);margin:0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.refresh-btn{background:none;border:1px solid var(--border-color);color:var(--text-primary);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:14px}.refresh-btn:hover:not(:disabled){background:var(--bg-tertiary)}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.linear-ticket{border-left-color:var(--accent)!important;cursor:grab}.linear-ticket:active{cursor:grabbing}.ticket-state{font-size:10px;padding:2px 6px;background:var(--bg-primary);border-radius:4px;color:var(--text-secondary)}.drag-hint{font-size:11px;color:var(--text-secondary);margin-top:4px}.gantt-chart.drop-highlight{outline:2px dashed var(--accent);outline-offset:-2px}.ticket-list .empty{color:var(--text-secondary);font-size:14px;text-align:center;padding:32px 0}.tickets{display:flex;flex-direction:column;gap:8px}.ticket-item{background:var(--bg-tertiary);border-radius:10px;padding:16px;border-left:5px solid var(--accent);cursor:pointer;transition:background .15s}.ticket-item:hover{background:var(--border-color)}.ticket-item.selected{outline:2px solid var(--accent);outline-offset:2px}.ticket-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.ticket-id{font-weight:600;font-size:16px;color:var(--accent)}.delete-btn{background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:0 4px;line-height:1}.delete-btn:hover{color:var(--error)}.ticket-title{font-size:15px;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ticket-dates{font-size:13px;color:var(--text-secondary)}.ticket-actions{margin-top:10px}.add-btn{padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.add-btn:hover{background:var(--accent-hover)}.linear-link{display:inline-block;margin-top:8px;font-size:12px;color:var(--accent);text-decoration:none}.linear-link:hover{text-decoration:underline}.add-ticket-form{margin-bottom:16px}.add-ticket-form .form-row{display:flex;gap:8px;align-items:center}.add-ticket-form select{padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px}.add-ticket-form .separator{color:var(--text-secondary);font-weight:600}.add-ticket-form input{flex:1;padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;min-width:0}.add-ticket-form input:focus,.add-ticket-form select:focus{outline:none;border-color:var(--accent)}.add-ticket-form button{padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.add-ticket-form button:hover:not(:disabled){background:var(--accent-hover)}.add-ticket-form button:disabled{opacity:.5;cursor:not-allowed}.add-ticket-form .error{margin-top:8px;padding:8px 12px;background:#ef44441a;border-radius:6px;color:var(--error);font-size:13px}.gantt-chart{height:100%;overflow:hidden;background:var(--bg-primary)}.gantt-scroll{height:100%;overflow:auto;-webkit-overflow-scrolling:touch}.gantt-content{position:relative;min-width:100%;min-height:100%}.gantt-header{position:sticky;top:0;z-index:10;display:flex;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.gantt-day-header{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid var(--border-color);padding:8px 4px}.gantt-day-header.weekend{background:#ffffff05}.gantt-day-header.today{background:#3b82f61a}.gantt-day-header .day-name{font-size:11px;color:var(--text-secondary);text-transform:uppercase}.gantt-day-header .day-date{font-size:16px;font-weight:600}.gantt-grid{position:absolute;left:0;right:0;bottom:0;display:flex}.gantt-grid-line{position:absolute;top:0;bottom:0;border-right:1px solid var(--border-color)}.gantt-grid-line.weekend{background:#ffffff05}.gantt-today-line{position:absolute;bottom:0;width:2px;background:var(--error);z-index:5}.gantt-bars{position:absolute;left:0;right:0;z-index:6}.gantt-bar{position:absolute;height:56px;border-radius:10px;display:flex;align-items:center;cursor:grab;transition:box-shadow .15s,transform .15s;box-shadow:0 2px 4px #0003;overflow:visible;user-select:none;-webkit-user-select:none}.gantt-bar:hover{box-shadow:0 4px 8px #0000004d;transform:translateY(-1px)}.gantt-bar.selected{outline:2px solid white;outline-offset:2px}.gantt-bar.dragging{cursor:grabbing;opacity:.9;box-shadow:0 8px 16px #0006}.gantt-bar .bar-content{flex:1;padding:0 20px;overflow:visible;display:flex;gap:8px;align-items:center;touch-action:none;white-space:nowrap;min-width:0}.gantt-bar .bar-id{font-size:14px;font-weight:700;flex-shrink:0;pointer-events:none;background:#0009;padding:5px 10px;border-radius:5px}.gantt-bar .bar-title{font-size:15px;font-weight:600;white-space:nowrap;pointer-events:none;background:#0009;padding:5px 10px;border-radius:5px}.gantt-bar .resize-handle{width:16px;height:100%;cursor:ew-resize;flex-shrink:0;touch-action:none;position:absolute;top:0;z-index:20;pointer-events:auto}.gantt-bar .bar-content{pointer-events:auto}.gantt-bar .resize-handle.left{left:0;border-radius:10px 0 0 10px}.gantt-bar .resize-handle.right{right:0;border-radius:0 10px 10px 0}.gantt-bar .resize-handle:hover{background:#fff3}
