.timeline-container{height:calc(100vh - 230px);overflow-x:scroll;margin-left:calc(var(--bs-gutter-x)/-2);position:relative}.timeline-container .timeline{width:-moz-max-content;width:max-content;position:relative;margin-left:calc(var(--bs-gutter-x)/2);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.timeline-container .timeline .timeline-line{position:absolute;height:54px;border-radius:6px;box-sizing:border-box;border:3px solid #fff;padding:4px 8px;background:#f7f8ff;margin:2px 0 0;box-shadow:0 0 2px 1px hsla(0,0%,79.2%,.6);transition:all .3s ease;cursor:pointer;display:flex;align-items:center;gap:6px;overflow:hidden}.timeline-container .timeline .timeline-line:hover{box-shadow:0 0 6px 2px rgba(113,58,232,.4);transform:translateY(-1px)}.timeline-container .timeline .timeline-line.highlighted{background:#fff9c4;box-shadow:0 0 8px 2px rgba(255,235,59,.8);z-index:5}.tl-bar{display:flex;flex-wrap:wrap;align-items:baseline;gap:2px 6px;flex:1;line-height:1.35;max-height:2.7em}.tl-bar,.tl-name{min-width:0;overflow:hidden}.tl-name{font-weight:500;font-size:.85em;color:var(--gray-dark);pointer-events:none}.tl-serial{font-size:.75em;color:var(--gray);pointer-events:none;flex-shrink:0}.tl-chars{display:inline-flex;gap:3px;flex-shrink:0}.tl-char{font-size:.7em;padding:1px 5px;border-radius:3px;background:hsla(0,0%,100%,.7);color:var(--gray-dark);pointer-events:none}.tl-end{font-size:.75em;color:var(--gray);pointer-events:none;flex-shrink:0;white-space:nowrap}.timeline-container .timeline .timeline-line .timeline-color{width:8px;height:8px;border-radius:50%;flex-shrink:0;pointer-events:none}.timeline-line .tl-end,.timeline-line .tl-serial{display:none}.timeline-line.bar-lg .tl-end,.timeline-line.bar-lg .tl-serial,.timeline-line.bar-md .tl-end,.timeline-line.bar-md .tl-serial,.timeline-line.bar-sm .tl-serial{display:inline}.timeline-line.bar-lg .tl-chars{display:inline-flex}.timeline-line.bar-xl .tl-end,.timeline-line.bar-xl .tl-serial{display:inline}.timeline-line.bar-xl .tl-chars{display:inline-flex}.timeline-container .timeline .timeline-line.bar-xs{min-width:12px;padding:4px}.timeline-row{position:relative;width:100%;height:56px}.timeline-container .timeline .timeline-head{display:flex;position:sticky;top:0;background:#fff;z-index:20}.timeline-container .timeline .timeline-head .timeline-title{position:sticky;left:0;z-index:25;background:#fff}.timeline-container .timeline .timeline-head .timeline-month{width:240px;border-left:1px solid var(--gray);padding:2px 6px;position:sticky;background:#fff;left:220px}.timeline-container .timeline .timeline-head .timeline-month .month-label{font-size:.6em;color:var(--gray);text-transform:uppercase;letter-spacing:.3px;line-height:1.3}.timeline-container .timeline .timeline-head .timeline-month .day-row{display:flex;align-items:baseline;gap:4px;line-height:1.2}.timeline-container .timeline .timeline-head .timeline-month .day-label{font-size:.95em;font-weight:700}.timeline-container .timeline .timeline-head .timeline-month .weekday-label{font-size:.65em;color:var(--gray);text-transform:lowercase;font-weight:500}.timeline-container .timeline .timeline-head .timeline-month.weekend{background:#f5f5f5;border-left-color:#e0e0e0}.timeline-container .timeline .timeline-head .timeline-month.weekend .day-label,.timeline-container .timeline .timeline-head .timeline-month.weekend .weekday-label{color:#bdbdbd}.timeline-container .timeline .timeline-head .timeline-month.year:before{content:"";width:1px;height:100%;border-left:4px solid #713ae8;position:absolute;margin-left:-13px;border-radius:6px}.timeline-container .timeline .timeline-item{display:flex;gap:0;margin-bottom:.5em;padding-bottom:4px}.timeline-container .timeline .timeline-title{width:220px;z-index:10;position:sticky;left:0;background:rgb(255 255 255/86%);padding:6px 0 6px 8px;margin-bottom:-4px;display:flex;gap:8px;align-items:stretch}.tl-title-accent{width:3px;border-radius:3px;flex-shrink:0}.tl-title-accent.accent-product{background:#1976d2}.tl-title-accent.accent-user,.tl-title-accent.accent-worker{background:#388e3c}.tl-title-accent.accent-machine{background:#f57c00}.tl-title-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.tl-title-row{display:flex;align-items:center;gap:6px;min-width:0}.tl-type-badge{font-size:.6em;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:1px 6px;border-radius:3px;flex-shrink:0}.tl-type-badge.type-product{background:#e3f2fd;color:#1565c0}.tl-type-badge.type-user,.tl-type-badge.type-worker{background:#e8f5e9;color:#2e7d32}.tl-type-badge.type-machine{background:#fff3e0;color:#e65100}.timeline-container .timeline .timeline-name{font-size:1em;font-weight:600;color:var(--gray-dark);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tl-title-meta{gap:4px 8px;flex-wrap:wrap}.tl-serial-label{font-size:.75em;color:var(--gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-char-pills{display:inline-flex;gap:3px;flex-wrap:wrap}.tl-char-pill{font-size:.65em;padding:1px 5px;border-radius:3px;background:#f3e5f5;color:#7b1fa2}.dragscroll{cursor:all-scroll}.now-line{bottom:0;width:2px;z-index:9;pointer-events:none}.now-line,.now-line:before{position:absolute;top:0;background:#e53935}.now-line:before{content:"";left:-4px;width:10px;height:10px;border-radius:50%}.stats-bar{border:1px solid #e9ecef}.stats-item{white-space:nowrap}.stats-label{font-size:.85em;color:var(--gray);margin-right:4px}.stats-value{font-weight:600;font-size:.95em}.zoom-slider{width:100px;height:4px;cursor:pointer;accent-color:#713ae8}.zoom-value{min-width:50px;text-align:right}.timeline-body{position:relative}.current-view-badge .badge{font-size:.8em;text-transform:uppercase;letter-spacing:.5px}.op-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#4caf50;margin-left:4px;vertical-align:super}.characteristics-badge{display:inline-block;background:#e8f5e9;color:#2e7d32;font-size:.8em;padding:2px 8px;border-radius:4px;white-space:nowrap}.timeline-container .timeline .timeline-item:nth-child(2n),.timeline-container .timeline .timeline-item:nth-child(2n) .timeline-title{background:#f6f3ff;border-radius:8px}.step-item{background:var(--bg);border:1px solid transparent;transition:all .15s}.step-item:hover{border-color:var(--default)}.step-active{background:var(--default);border:1px solid var(--default)}.step-active .btn-light{border-color:hsla(0,0%,100%,.3);color:var(--default)}.step-active .btn-light:hover{background:hsla(0,0%,100%,.9)}.text-white-50{color:hsla(0,0%,100%,.6)}.cursor-pointer{cursor:pointer}