.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:52px;border-radius:6px;box-sizing:border-box;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;padding-bottom:1em;position:sticky;top:0;background:#fff;z-index:10}.timeline-container .timeline .timeline-head .timeline-month{width:240px;border-left:1px solid var(--gray);padding-left:10px;padding-top:4px}.timeline-container .timeline .timeline-head .timeline-month .month-label{font-size:.75em;color:var(--gray);text-transform:uppercase;letter-spacing:.5px}.timeline-container .timeline .timeline-head .timeline-month .day-label{font-size:.9em}.timeline-container .timeline .timeline-head .timeline-month.weekend{background:#f5f5f5;border-left-color:#e0e0e0}.timeline-container .timeline .timeline-head .timeline-month.weekend .day-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:420px;z-index:10;position:sticky;left:0;background:rgb(255 255 255/86%);padding-left:calc(var(--bs-gutter-x)/2);margin-bottom:-4px}.timeline-container .timeline .timeline-name{font-size:1.2em;font-weight:500;margin-left:4px}.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}.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}.characteristic-tag{display:inline-block;background:#e3f2fd;color:#1565c0;font-size:.75em;padding:1px 6px;border-radius:3px;margin-right:4px;margin-top:2px}.characteristics-row{margin-top:2px;line-height:1.4}