*{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)}.header-actions .customer-filter{padding:6px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:13px;cursor:pointer;min-width:140px}.header-actions .customer-filter:focus{outline:none;border-color:var(--accent)}.header-actions .customer-filter:hover{background:var(--border-color)}.ticket-list .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}.ticket-list .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-group-header{position:absolute;left:0;display:flex;align-items:center;gap:8px;padding:0 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);z-index:5}.gantt-group-header .group-name{color:var(--accent)}.gantt-group-header .group-count{background:var(--bg-tertiary);padding:2px 8px;border-radius:10px;font-size:11px}.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}.gantt-bar .bar-notes{background:#0006;border:1px solid transparent;border-radius:4px;color:var(--text-primary);font-size:12px;padding:4px 8px;min-width:100px;max-width:200px;cursor:text}.gantt-bar .bar-notes:focus{outline:none;border-color:#fff6;background:#0009}.gantt-bar .bar-notes::placeholder{color:#fff6}.gantt-bar .bar-notes-readonly{font-size:12px;color:#ffffffb3;background:#0000004d;padding:4px 8px;border-radius:4px}.focus-btn{background:var(--accent)!important;border-color:var(--accent)!important}.focus-btn:hover{background:var(--accent-hover)!important;border-color:var(--accent-hover)!important}.focus-view-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.focus-view{background:var(--bg-secondary);border-radius:16px;padding:24px;min-width:480px;max-width:90vw;max-height:90vh;overflow-y:auto;border:1px solid var(--border-color);box-shadow:0 20px 40px #0006}.focus-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.focus-header h2{font-size:20px;font-weight:600}.focus-close{background:none;border:none;color:var(--text-secondary);font-size:28px;cursor:pointer;padding:0;line-height:1;order:1}.focus-close:hover{color:var(--text-primary)}.focus-date-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:24px}.focus-date-label{font-size:16px;font-weight:500;min-width:240px;text-align:center}.focus-nav-btn{padding:8px 14px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;font-weight:700;cursor:pointer;transition:background .15s}.focus-nav-btn:hover{background:var(--border-color)}.focus-counter{text-align:center;color:var(--text-secondary);font-size:14px;margin-bottom:16px}.focus-empty{text-align:center;padding:48px 0;color:var(--text-secondary)}.focus-ticket-nav{display:flex;align-items:center;gap:16px;margin-bottom:24px}.focus-arrow{padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:18px;cursor:pointer;transition:background .15s}.focus-arrow:hover:not(:disabled){background:var(--border-color)}.focus-arrow:disabled{opacity:.3;cursor:not-allowed}.focus-ticket-card{flex:1;background:var(--bg-tertiary);border-radius:12px;padding:20px;border-left:5px solid var(--accent);cursor:pointer;transition:background .15s,transform .15s}.focus-ticket-card:hover{background:var(--border-color);transform:translateY(-2px)}.focus-status{display:inline-block;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;margin-bottom:12px}.focus-status.status-starting{background:#10b98133;color:var(--success)}.focus-status.status-flight{background:#3b82f633;color:var(--accent)}.focus-status.status-ending{background:#ef444433;color:var(--error)}.focus-ticket-id{font-size:18px;font-weight:700;color:var(--accent);margin-bottom:8px}.focus-ticket-title{font-size:16px;margin-bottom:8px;line-height:1.4}.focus-ticket-customer{font-size:13px;color:var(--accent);margin-bottom:8px}.focus-ticket-dates{font-size:13px;color:var(--text-secondary)}.focus-summary{display:flex;justify-content:center;gap:24px;padding-top:16px;border-top:1px solid var(--border-color)}.focus-summary-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.focus-summary-dot{width:10px;height:10px;border-radius:50%}.focus-summary-dot.starting{background:var(--success)}.focus-summary-dot.flight{background:var(--accent)}.focus-summary-dot.ending{background:var(--error)}
