:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.track-node{width:280px;background:linear-gradient(135deg,#0f172a,#1e293b);border-radius:12px;border:1px solid rgba(120,119,198,.2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff1a;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.track-node:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 16px 64px #0006,inset 0 1px #fff3}.track-node.start-node{border-color:#3b82f6;background:linear-gradient(135deg,#1e40af20,#3b82f620);box-shadow:0 8px 32px #3b82f64d,inset 0 1px #ffffff1a}.track-node.suggestion{background:linear-gradient(135deg,#0f172a,#1e293b);animation:floatGlow 3s ease-in-out infinite}@keyframes floatGlow{0%,to{transform:translateY(0);box-shadow:0 8px 32px #0000004d}50%{transform:translateY(-4px);box-shadow:0 16px 48px #0006}}.track-node.selected{border-color:#f80;background:#1a1a1a}.track-node.selected:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#f80;border-radius:8px 8px 0 0}.track-node.clicked{border-color:#85f;background:#1a1a1a}.track-node.clicked:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#85f;border-radius:8px 8px 0 0}.track-node.clicked.selected{border-color:#85f;background:#1a1a1a}.track-content{display:flex;padding:16px;gap:14px;align-items:center}.key-indicator{position:absolute;top:0;left:0;right:0;height:3px;border-radius:12px 12px 0 0;opacity:.8}.recommendation-marker{position:absolute;top:-8px;right:-8px;display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:12px;font-size:10px;font-weight:600;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px #0000004d,inset 0 1px #fff3;z-index:10;animation:markerPulse 2s infinite;cursor:help}.rec-icon{font-size:12px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.rec-label{font-family:Inter,sans-serif;letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.3);white-space:nowrap}@keyframes markerPulse{0%,to{transform:scale(1);box-shadow:0 4px 16px #0000004d,inset 0 1px #fff3}50%{transform:scale(1.05);box-shadow:0 6px 24px #0006,inset 0 1px #ffffff4d}}.recommendation-marker:hover{transform:scale(1.1);animation:none}.album-art{width:50px;height:50px;border-radius:8px;background-size:cover;background-position:center;background-color:#1a1a2e;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.1);position:relative;overflow:hidden}.bpm-badge{position:absolute;top:2px;right:2px;background:#000c;color:#fff;font-size:9px;font-weight:700;padding:2px 4px;border-radius:4px;font-family:SF Mono,Monaco,monospace}.placeholder-icon{font-size:20px;opacity:.3;color:#666}.track-info{flex:1;min-width:0}.track-title{font-weight:600;font-size:15px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.track-artist{font-size:13px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:6px}.track-metadata{display:flex;gap:8px;align-items:center;margin-bottom:6px}.key-display{font-size:10px;padding:3px 6px;border-radius:4px;font-weight:700;font-family:SF Mono,Monaco,monospace;min-width:24px;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.3)}.energy-bar{height:4px;width:40px;background:#ffffff1a;border-radius:2px;overflow:hidden;position:relative}.energy-fill{height:100%;border-radius:2px;transition:width .3s ease;position:relative}.energy-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.track-genre{font-size:9px;text-transform:uppercase;letter-spacing:1px;font-weight:600;padding:2px 6px;border-radius:4px;border:1px solid currentColor;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.handle-left,.handle-right{width:8px;height:8px;background:#555;border:1px solid #333;border-radius:2px}.handle-left:hover,.handle-right:hover{background:#777}.track-node.suggestion{animation:fadeSlideIn .3s ease-out forwards}.track-node.clicked{animation:none}@keyframes fadeSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.current-track-display{position:fixed;top:20px;left:50%;transform:translate(-50%);width:800px;height:70px;background:linear-gradient(135deg,#0a0a0af2,#1a1a2ef2);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:2px solid;border-radius:35px;box-shadow:0 8px 32px #0006,inset 0 1px #ffffff1a;z-index:1000;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden;display:flex;align-items:center;padding:0 24px}.current-track-header{display:none}.now-playing-label{font-size:9px;font-weight:700;letter-spacing:1px;color:#fff;opacity:.7;margin-right:16px;writing-mode:vertical-lr;text-orientation:mixed}.remaining-time{font-size:11px;font-weight:600;font-family:SF Mono,Monaco,monospace;letter-spacing:.5px;margin-left:auto;display:flex;align-items:center;gap:8px}.current-track-content{display:flex;gap:16px;align-items:center;flex:1;padding:0}.current-album-art{width:50px;height:50px;border-radius:25px;background-size:cover;background-position:center;background-color:#1a1a2e;border:2px solid;position:relative;flex-shrink:0;overflow:hidden}.current-placeholder-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:20px;opacity:.3;color:#666}.current-key-overlay{position:absolute;bottom:2px;right:2px;padding:2px 4px;border-radius:3px;font-size:8px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);font-family:SF Mono,Monaco,monospace}.current-track-info{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:2px}.current-track-title{font-size:16px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.current-track-artist{font-size:13px;color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.current-track-params{display:flex;gap:16px;align-items:center;margin-left:auto;margin-right:16px}.param-group{display:flex;align-items:center;gap:6px}.param-label{font-size:8px;font-weight:600;letter-spacing:1px;color:#ffffff80;text-transform:uppercase}.param-value{font-weight:700;font-family:SF Mono,Monaco,monospace}.bpm-value{font-size:14px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.key-value{font-size:12px;padding:3px 6px;border-radius:4px;text-shadow:0 1px 2px rgba(0,0,0,.5)}.current-energy-bar{width:40px;height:4px;background:#ffffff1a;border-radius:2px;position:relative;overflow:hidden}.current-energy-fill{height:100%;border-radius:3px;position:relative;transition:width .5s cubic-bezier(.4,0,.2,1)}.energy-percentage{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:10px;font-weight:600;color:#fffc;font-family:SF Mono,Monaco,monospace}.current-genre-tag{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;padding:4px 8px;border:1px solid;border-radius:6px;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-block}@media (max-width: 640px){.current-track-display{width:calc(100vw - 40px);left:20px;transform:none;bottom:20px}.current-track-content{gap:16px;padding:16px}.current-album-art{width:60px;height:60px}.current-track-params{gap:12px}.current-energy-bar{width:40px}}.current-track-display{animation:fadeInUp .5s cubic-bezier(.4,0,.2,1)}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.crowd-metrics{position:fixed;top:20px;right:20px;width:280px;background:linear-gradient(135deg,#0a0a0af2,#1a1a2ef2);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid rgba(120,119,198,.3);border-radius:16px;padding:20px;box-shadow:0 16px 64px #0006,inset 0 1px #ffffff1a;z-index:1000;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.crowd-metrics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.crowd-metrics-header h3{margin:0;font-size:12px;font-weight:700;letter-spacing:1.2px;color:#fff;opacity:.9}.live-indicator{display:flex;align-items:center;gap:6px;font-size:9px;font-weight:600;letter-spacing:1px;color:#10b981}.live-dot{width:6px;height:6px;background:#10b981;border-radius:50%;animation:livePulse 2s infinite}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.3}}.metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.metric-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px;text-align:center;position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.4,0,.2,1)}.metric-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.metric-icon{font-size:20px;margin-bottom:6px;opacity:.8}.metric-value{font-size:18px;font-weight:700;color:#fff;margin-bottom:4px;font-family:SF Mono,Monaco,monospace}.metric-label{font-size:9px;font-weight:600;letter-spacing:1px;color:#fff9;text-transform:uppercase}.mood-text{font-size:14px;font-weight:600;font-family:Inter,sans-serif}.movement-text{font-size:14px;font-weight:600;color:#fff;font-family:Inter,sans-serif}.energy-bar-mini{width:100%;height:3px;background:#ffffff1a;border-radius:2px;margin-top:6px;overflow:hidden}.energy-fill-mini{height:100%;border-radius:2px;transition:width .5s cubic-bezier(.4,0,.2,1)}.engagement-ring{position:absolute;top:8px;right:8px;width:24px;height:24px}.engagement-circle{width:100%;height:100%;transform:rotate(-90deg)}.movement-bars{display:flex;gap:2px;justify-content:center;margin-top:6px}.movement-bar{width:4px;height:16px;border-radius:2px;transition:all .3s cubic-bezier(.4,0,.2,1)}.movement-bar:nth-child(1){height:8px}.movement-bar:nth-child(2){height:12px}.movement-bar:nth-child(3){height:16px}.movement-bar:nth-child(4){height:20px}.movement-bar.active{animation:movementPulse 1.5s ease-in-out infinite}@keyframes movementPulse{0%,to{opacity:1}50%{opacity:.6}}.people-count .metric-value{color:#3b82f6}.feedback-indicator{display:flex;align-items:center;gap:8px;font-size:10px;color:#ffffffb3;padding:8px 12px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.feedback-pulse{width:6px;height:6px;border-radius:50%;animation:feedbackPulse 3s infinite}@keyframes feedbackPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}@media (max-width: 768px){.crowd-metrics{width:240px;top:10px;right:10px;padding:16px}.metrics-grid{grid-template-columns:1fr;gap:8px}.metric-card{padding:12px}.metric-value{font-size:16px}}.crowd-metrics{animation:slideInRight .5s cubic-bezier(.4,0,.2,1)}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.playlist-analytics{position:fixed;left:50%;transform:translate(-50%);bottom:20px;width:800px;height:180px;background:linear-gradient(135deg,#0a0a0af2,#1a1a2ef2);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid rgba(120,119,198,.3);border-radius:16px;box-shadow:0 16px 64px #0006,inset 0 1px #ffffff1a;z-index:999;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}.analytics-header{padding:12px 20px 8px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.analytics-header h3{margin:0;font-size:11px;font-weight:700;letter-spacing:1.2px;color:#fff;opacity:.9}.metric-selector{display:flex;gap:6px}.metric-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;background:transparent;border:1px solid;border-radius:8px;font-size:10px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.metric-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.metric-btn.active{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);box-shadow:0 4px 16px #0000004d,inset 0 1px #fff3}.metric-btn-icon{font-size:12px}.metric-btn-label{text-transform:uppercase;letter-spacing:.5px}.chart-container{padding:12px 20px;height:calc(100% - 100px);position:relative}.chart-background{position:relative;height:80px;background:#ffffff05;border-radius:8px;overflow:hidden}.grid-line{position:absolute;left:0;right:0;height:1px;background:#ffffff0d;display:flex;align-items:center}.grid-label{font-size:9px;color:#fff6;background:#0a0a0acc;padding:1px 4px;border-radius:3px;font-family:SF Mono,Monaco,monospace}.chart-area{position:absolute;inset:0;padding:10px;display:flex;align-items:center;justify-content:center}.empty-chart-message{display:flex;flex-direction:column;align-items:center;gap:8px;color:#fff6}.empty-icon{font-size:32px;opacity:.5}.empty-text{font-size:11px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.chart-svg{width:100%;height:100%}.chart-line{stroke-linecap:round;stroke-linejoin:round;animation:drawLine 1s ease-out}@keyframes drawLine{0%{stroke-dasharray:1000;stroke-dashoffset:1000}to{stroke-dasharray:1000;stroke-dashoffset:0}}.chart-point{animation:pointAppear .5s ease-out;cursor:pointer}.chart-point:hover{r:6;transition:r .2s ease}.chart-point-hover{cursor:pointer}.chart-point-hover:hover+.chart-point{r:6}@keyframes pointAppear{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.chart-area-fill{opacity:.6;animation:fillAppear 1s ease-out .5s both}@keyframes fillAppear{0%{opacity:0}to{opacity:.6}}.track-labels{display:flex;position:relative;margin-top:8px;height:35px}.track-label{position:absolute;transform:translate(-50%);text-align:center;min-width:80px}.track-position{width:20px;height:20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff;margin:0 auto 4px;font-family:SF Mono,Monaco,monospace}.track-name{font-size:9px;color:#ffffffb3;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-value{font-size:10px;font-weight:700;font-family:SF Mono,Monaco,monospace}.analytics-stats{display:flex;gap:12px;padding:8px 20px 12px;border-top:1px solid rgba(255,255,255,.1)}.stat-card{flex:1;text-align:center;background:#ffffff0d;border-radius:8px;padding:8px;border:1px solid rgba(255,255,255,.1)}.stat-label{font-size:9px;font-weight:600;letter-spacing:1px;color:#fff9;text-transform:uppercase;margin-bottom:4px}.stat-value{font-size:12px;font-weight:700;font-family:SF Mono,Monaco,monospace}.trend-indicator{font-size:16px}@media (max-width: 1200px){.playlist-analytics{width:350px;height:240px}.chart-container{height:calc(100% - 120px)}.chart-background{height:100px}}@media (max-width: 900px){.playlist-analytics{position:relative;left:0;bottom:0;width:100%;margin:20px 0}}.playlist-analytics{animation:slideInLeft .5s cubic-bezier(.4,0,.2,1)}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100px)}to{opacity:1;transform:translate(0)}}.playlist-builder{width:100vw;height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a1a2e,#16213e);color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;position:relative;overflow:hidden}.playlist-builder:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(120,119,198,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,119,198,.1) 0%,transparent 50%),radial-gradient(circle at 40% 40%,rgba(120,219,255,.1) 0%,transparent 50%);animation:float 20s ease-in-out infinite;pointer-events:none}@keyframes float{0%,to{opacity:.4}50%{opacity:.8}}.playlist-header{position:absolute;top:20px;left:20px;z-index:10;background:#0a0a0af2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:16px 24px;border-radius:12px;border:1px solid rgba(120,119,198,.3);box-shadow:0 8px 32px #0006}.playlist-header h1{margin:0 0 4px;font-size:20px;font-weight:600;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.playlist-header p{margin:0;font-size:12px;color:#999}.flow-container{width:100%;height:100%}.react-flow__node{cursor:pointer}.react-flow__edge{cursor:default}.react-flow__controls{bottom:20px;left:20px}.react-flow__minimap{bottom:20px;right:20px;border:1px solid rgba(255,255,255,.1);border-radius:8px}.react-flow__background{background-color:#0f172a;background-image:linear-gradient(90deg,rgba(120,119,198,.03) 1px,transparent 1px),linear-gradient(0deg,rgba(120,119,198,.03) 1px,transparent 1px);background-size:80px 80px;animation:backgroundShift 30s linear infinite}@keyframes backgroundShift{0%{background-position:0px 0px,0px 0px}to{background-position:80px 80px,80px 80px}}.playlist-builder:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(120,219,255,.02) 2px,rgba(120,219,255,.02) 4px);animation:energyPulse 8s ease-in-out infinite;pointer-events:none;z-index:1}@keyframes energyPulse{0%,to{opacity:.3;transform:translateY(0)}50%{opacity:.7;transform:translateY(-2px)}}.react-flow__edge.react-flow__edge-smoothstep path{stroke:#7877c699;stroke-width:3px;opacity:.8;transition:all .3s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 0 4px rgba(120,119,198,.3))}.react-flow__edge:hover path{stroke:#7877c6e6;opacity:1;stroke-width:4px;filter:drop-shadow(0 0 8px rgba(120,119,198,.5))}.react-flow__edge.react-flow__edge-smoothstep path{stroke-dasharray:8,4;animation:flowAnimation 3s linear infinite}@keyframes flowAnimation{0%{stroke-dashoffset:0}to{stroke-dashoffset:12}}*{margin:0;padding:0;box-sizing:border-box}#root{width:100vw;height:100vh;overflow:hidden}
