.roadmap-wrapper{position:relative;min-height:100vh;padding:4rem 0}.timeline-container{position:relative;max-width:1200px;margin:0 auto;padding:2rem 0}.timeline-container:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent 0%,rgba(156,163,175,.3) 10%,rgba(156,163,175,.5) 50%,rgba(156,163,175,.3) 90%,transparent 100%);transform:translate(-50%);z-index:0}.timeline-item{position:relative;margin-bottom:4rem;display:flex;justify-content:center;align-items:flex-start;z-index:1;min-height:100px}.node-wrapper{position:relative;width:100%;display:flex;justify-content:center;align-items:center}.node-content{position:absolute;display:flex;flex-direction:column;align-items:center;z-index:2;transition:transform .3s ease}.timeline-main .node-content{position:relative;transform:translate(0)}.timeline-left .node-content{transform:translate(calc(var(--custom-offset, -120px)))}.timeline-right .node-content{transform:translate(calc(var(--custom-offset, 120px)))}.connector-line{position:absolute;z-index:1;opacity:0;transition:opacity .5s ease;pointer-events:none}.timeline-item.visible .connector-line{opacity:.6}.timeline-main .connector-line{left:50%;top:2rem;width:2px;height:30px;background:linear-gradient(to bottom,currentColor 0%,currentColor 100%);transform:translate(-50%);filter:drop-shadow(0 0 2px currentColor)}.timeline-left .connector-line{left:calc(50% + var(--custom-offset, -120px));top:2rem;width:2px;height:40px;background:linear-gradient(to bottom,currentColor 0%,currentColor 100%);filter:drop-shadow(0 0 2px currentColor)}.timeline-left .connector-line:after{content:"";position:absolute;bottom:0;left:0;width:calc(var(--custom-offset, -120px) * -1);height:2px;background:linear-gradient(to right,currentColor 0%,currentColor 100%);filter:drop-shadow(0 0 2px currentColor)}.timeline-right .connector-line{left:calc(50% + var(--custom-offset, 120px));top:2rem;width:2px;height:40px;background:linear-gradient(to bottom,currentColor 0%,currentColor 100%);filter:drop-shadow(0 0 2px currentColor)}.timeline-right .connector-line:after{content:"";position:absolute;bottom:0;right:0;width:calc(var(--custom-offset, 120px));height:2px;background:linear-gradient(to left,currentColor 0%,currentColor 100%);filter:drop-shadow(0 0 2px currentColor)}.node-circle{width:4rem;height:4rem;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;border:3px solid currentColor;box-shadow:0 0 8px 0 currentColor,0 2px 8px #0006,inset 0 2px 4px #0000004d;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;z-index:3}.node-circle:hover{transform:scale(1.1);border-width:4px;box-shadow:0 0 12px 1px currentColor,0 4px 12px #00000080,inset 0 2px 4px #0000004d}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px 0 currentColor,0 2px 8px #0006,inset 0 2px 4px #0000004d}50%{box-shadow:0 0 12px 2px currentColor,0 4px 12px #00000080,inset 0 2px 4px #0000004d}}.node-circle.in-progress{animation:pulse-glow 2.5s ease-in-out infinite}.node-status{position:absolute;top:-6px;right:-6px;width:1.5rem;height:1.5rem;border-radius:50%;background:#111827f2;border:2px solid currentColor;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0006;z-index:4}.node-info{text-align:center;margin-top:1rem;max-width:200px;opacity:0;animation:fadeInUp .5s forwards;animation-delay:.2s}.node-title{font-size:.9rem;font-weight:700;line-height:1.3;margin-bottom:.25rem;text-shadow:0 2px 4px rgba(0,0,0,.5)}.node-date{font-size:.75rem;color:#9ca3af;font-weight:500}.info-card-container{position:fixed;top:auto;left:50%;transform:translate(-50%);margin-top:1rem;z-index:9999;pointer-events:none}.info-card-container.active,.info-card-portal{pointer-events:auto}.info-card{width:320px;max-width:90vw;padding:1.5rem;border-radius:12px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 10px 30px #00000080,0 1px 2px #0003;border:1px solid rgba(255,255,255,.1);position:relative;background:linear-gradient(135deg,#111827f2,#1f2937f2)}.card-pointer{position:absolute;top:-8px;left:50%;transform:translate(-50%) rotate(45deg);width:16px;height:16px;border-top:2px solid;border-left:2px solid;border-color:inherit;background:linear-gradient(135deg,#111827f2,#1f2937f2 50%)}.card-badges{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:.5rem}.badge{font-size:.7rem;font-weight:700;padding:.25rem .75rem;border-radius:20px;color:#fff;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 1px 3px #0003}.badge-status{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.card-desc-short{color:#e5e7eb;font-size:.9rem;font-weight:600;margin-bottom:.75rem;line-height:1.4}.card-desc-full{color:#9ca3af;font-size:.8rem;line-height:1.6}.legend-container{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem;margin-top:6rem;padding:2rem;background:#11182780;border-radius:12px;backdrop-filter:blur(10px);position:relative;z-index:5}.legend-entry{display:flex;align-items:center;gap:.5rem;opacity:0;animation:fadeIn .5s forwards}.legend-entry:nth-child(1){animation-delay:.1s}.legend-entry:nth-child(2){animation-delay:.2s}.legend-entry:nth-child(3){animation-delay:.3s}.legend-entry:nth-child(4){animation-delay:.4s}.legend-entry:nth-child(5){animation-delay:.5s}.legend-circle{width:12px;height:12px;border-radius:50%;box-shadow:0 0 6px currentColor}.legend-text{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}@keyframes fadeIn{to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin-slow{animation:spin-slow 3s linear infinite}@media(max-width:768px){.roadmap-wrapper{padding:2rem 0}.timeline-container{padding:1rem .5rem}.timeline-item{margin-bottom:3.5rem;min-height:60px}.timeline-left .node-content,.timeline-right .node-content,.timeline-center .node-content{transform:translate(0)!important}.timeline-left .connector-line,.timeline-right .connector-line{display:none}.timeline-main .connector-line{height:15px}.node-circle{width:2.75rem;height:2.75rem}.large-task .node-circle.large-node{width:3.25rem;height:3.25rem}.node-status{top:-2px;right:-2px;width:1.1rem;height:1.1rem}.node-info{max-width:140px;margin-top:.5rem}.node-title{font-size:.75rem;line-height:1.1;margin-bottom:.125rem}.node-date{font-size:.65rem}.info-card{width:90vw;max-width:340px;padding:1rem}.card-desc-short{font-size:.85rem}.card-desc-full{font-size:.75rem}.legend-container{gap:.75rem;padding:1rem;margin-top:3rem}.legend-text{font-size:.7rem}.subtask-indicators{display:none}.roadmap-wrapper .text-center.mb-20{margin-bottom:3rem}}html{scroll-behavior:smooth}.node-circle:focus-visible{outline:2px solid rgba(249,115,22,.8);outline-offset:4px}body{overflow-x:hidden}
