*,*:before,*:after{box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;background:#0a0a0a;color:#fff}#root{min-height:100vh;display:flex;flex-direction:column}.viz-canvas{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;display:block}.app{position:relative;z-index:1;display:flex;flex-direction:column;min-height:100vh}.setup-sidebar{position:fixed;top:0;left:0;bottom:0;width:340px;z-index:10;display:flex;flex-direction:column;gap:.75rem;background:#0a0a0cd9;border-right:1px solid rgba(255,255,255,.06);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);overflow:hidden}.sidebar-panels{flex:1 1 0;min-height:0;display:flex;flex-direction:column;gap:.5rem;overflow:hidden}.sidebar-brand{flex-shrink:0;padding:1.25rem 1.25rem 0;display:flex;flex-direction:column;gap:.3rem}.header-logo{width:100%;height:auto}.header-tagline{font-size:8px;font-weight:500;letter-spacing:.1em;color:#ffffff59;white-space:nowrap;text-align:center}.install-pwa-wrap{padding:.5rem 1.25rem 0}.install-pwa-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;background:#ff520014;border:1px solid rgba(255,82,0,.35);border-radius:8px;color:#ff5200;font-family:inherit;font-size:.65rem;font-weight:700;letter-spacing:.12em;padding:.6rem 1rem;cursor:pointer;transition:background .15s,border-color .15s}.install-pwa-btn:hover{background:#ff520026;border-color:#ff5200}.install-pwa-btn:active{transform:scale(.97)}.install-ios-hint{margin:.4rem 0 0;font-size:.7rem;color:#ffffff8c;line-height:1.5;text-align:center}.install-ios-hint strong{color:#fff}.drop-zone{width:calc(100% - 2.5rem);max-width:100%;margin:0 1.25rem;box-sizing:border-box;background:#111;border:1.5px dashed #252525;border-radius:16px;padding:2.5rem 1.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s,background .2s,padding .3s ease;-webkit-user-select:none;user-select:none;flex-shrink:0}.drop-zone:hover,.drop-zone.dragging{border-color:#ff5200;background:#130a00}.drop-zone.compact{padding:.875rem 1.25rem;border-style:solid;border-color:#1e1e1e}.drop-zone.compact .drop-content{flex-direction:row;gap:.5rem}.drop-zone.compact .drop-icon{width:16px;height:16px;color:#333}.drop-zone.compact .drop-label{font-size:.75rem;color:#444}.drop-zone.compact .drop-sub{display:none}.drop-zone.welcome{padding:3rem 1.5rem;border-style:dashed;border-color:#ff520033;background:#ff520008}.drop-welcome{display:flex;flex-direction:column;align-items:center;gap:.75rem;pointer-events:none}.drop-wheel-icon{width:48px;height:48px}.drop-welcome-title{margin:0;font-size:18px;font-weight:600;color:#fff;text-align:center}.drop-welcome-sub{margin:0;font-size:13px;color:#fff6}.drop-content{display:flex;flex-direction:column;align-items:center;gap:.75rem;pointer-events:none}.drop-icon{width:40px;height:40px;color:#333}.drop-label{margin:0;font-size:.95rem;font-weight:500;color:#ccc}.drop-sub{margin:0;font-size:.75rem;color:#444;letter-spacing:.03em}@keyframes spin{to{transform:rotate(360deg)}}.ride-timeline{width:calc(100% - 2.5rem);max-width:100%;margin:0 1.25rem;background:#040404d1;border:1px solid rgba(255,255,255,.04);border-radius:14px;padding:1.5rem 1.25rem 0;flex:1 1 0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-shrink:0}.timeline-content{flex:1;min-height:0;overflow-y:auto;padding-bottom:1.25rem;scrollbar-width:thin;scrollbar-color:#1e1e1e transparent}.timeline-heading{font-size:.6rem;letter-spacing:.18em;color:#444;font-weight:700}.timeline-total{font-size:.7rem;color:#333;font-weight:600;font-variant-numeric:tabular-nums}.tl-row{display:grid;grid-template-columns:3rem 20px 1fr 3rem;gap:0 .75rem}.tl-time{font-size:.65rem;font-weight:600;color:#555;text-align:right;padding-top:1px;font-variant-numeric:tabular-nums;align-self:start}.tl-track{display:flex;flex-direction:column;align-items:center;align-self:stretch}.tl-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.tl-dot.i1{background:#4a5568}.tl-dot.i2{background:#38a169}.tl-dot.i3{background:#d69e2e}.tl-dot.i4{background:#dd6b20}.tl-dot.i5{background:#ff5200}.tl-line{flex:1;width:2px;background:#1e1e1e;margin-top:4px}.tl-body{display:flex;flex-direction:column;gap:.25rem;padding-bottom:1.5rem;align-self:start}.tl-top{display:flex;align-items:center;gap:.6rem}.tl-cue{font-size:.875rem;font-weight:600;color:#ddd}.tl-pips{display:flex;gap:3px;flex-shrink:0}.tl-pip{width:5px;height:5px;border-radius:1px;background:#222}.tl-pip.on{background:#ff5200}.tl-meta{font-size:.68rem;color:#444;line-height:1.5}.meta-sep{color:#282828}.tl-dur{font-size:.65rem;color:#444;font-weight:600;text-align:right;padding-top:2px;font-variant-numeric:tabular-nums;align-self:start}.player-bar{width:calc(100% - 2.5rem);max-width:100%;margin:0 1.25rem;background:#111;border:1px solid #1e1e1e;border-radius:12px;padding:.875rem 1.25rem;display:flex;align-items:center;gap:.875rem;flex-shrink:0}.play-btn{background:none;border:none;color:#ff5200;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;transition:background .15s}.play-btn:hover{background:#ff52001f}.progress-track{flex:1;height:4px;background:#1e1e1e;border-radius:2px;cursor:pointer;position:relative}.progress-fill{height:100%;background:#ff5200;border-radius:2px;pointer-events:none}.progress-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:50%;background:#ff5200;pointer-events:none;opacity:0;transition:opacity .15s}.progress-track:hover .progress-thumb{opacity:1}.player-time{font-size:.65rem;color:#555;font-variant-numeric:tabular-nums;font-weight:600;flex-shrink:0;white-space:nowrap;letter-spacing:.03em}.time-sep{color:#2a2a2a}.tl-row.active .tl-cue{color:#fff}.tl-row.active .tl-time{color:#888}.tl-row.active .tl-dur,.tl-row.active .tl-meta{color:#666}.tl-row.active .tl-dot{box-shadow:0 0 0 3px #ff520026,0 0 10px #ff52008c}.pl-tab-spinner{width:8px;height:8px;border:1.5px solid #222;border-top-color:#ff5200;border-radius:50%;animation:spin .75s linear infinite;flex-shrink:0}.pl-panel{flex:1 1 0;min-height:0;display:flex;flex-direction:column;background:#040404d1;border:1px solid rgba(255,255,255,.04);border-radius:14px;margin:0 1.25rem;width:calc(100% - 2.5rem);max-width:100%;overflow:hidden}.pl-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.25rem .75rem;border-bottom:1px solid #141414;flex-shrink:0}.pl-heading{font-size:.6rem;font-weight:800;letter-spacing:.18em;color:#444}.pl-track-count{font-size:.65rem;color:#333;font-weight:600}.pl-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.pl-empty p{font-size:.75rem;color:#333;text-align:center;line-height:1.6}.pl-list{list-style:none;margin:0;padding:.5rem 0;flex:1;min-height:0;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#1e1e1e transparent}.pl-list::-webkit-scrollbar{width:4px}.pl-list::-webkit-scrollbar-track{background:transparent}.pl-list::-webkit-scrollbar-thumb{background:#1e1e1e;border-radius:2px}.pl-row{display:flex;flex-direction:column;border-left:2px solid transparent;transition:background .1s}.pl-row-main{display:flex;align-items:center;gap:.5rem;padding:.6rem .875rem;cursor:pointer}.pl-row.expanded{background:#ffffff05}.pl-row:hover{background:#ffffff08}.pl-row.active{background:#ff52000f;border-left-color:#ff5200}.pl-row.no-audio{opacity:.45;cursor:default}.pl-drag-handle{color:#2a2a2a;cursor:grab;flex-shrink:0;display:flex;align-items:center;padding:2px;transition:color .1s}.pl-row:hover .pl-drag-handle{color:#444}.pl-num{font-size:.6rem;color:#333;font-weight:600;font-variant-numeric:tabular-nums;min-width:18px;text-align:right;flex-shrink:0}.pl-row.active .pl-num{color:#ff5200}.pl-playing-icon{display:flex;align-items:flex-end;gap:2px;height:12px}.pl-playing-icon span{width:3px;background:#ff5200;border-radius:1px;animation:pl-bar .8s ease-in-out infinite alternate}.pl-playing-icon span:nth-child(1){height:6px;animation-delay:0s}.pl-playing-icon span:nth-child(2){height:12px;animation-delay:.2s}.pl-playing-icon span:nth-child(3){height:8px;animation-delay:.4s}@keyframes pl-bar{0%{transform:scaleY(.4)}to{transform:scaleY(1)}}.pl-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.pl-title{font-size:.75rem;font-weight:600;color:#bbb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.pl-row.active .pl-title{color:#fff}.pl-meta{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.pl-dur,.pl-bpm{font-size:.6rem;color:#333;font-weight:600;font-variant-numeric:tabular-nums}.pl-mood-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.pl-badge-analysing{font-size:.55rem;color:#444;font-weight:600;letter-spacing:.05em;animation:pulse-opacity 1.2s ease-in-out infinite}@keyframes pulse-opacity{0%,to{opacity:.5}50%{opacity:1}}.pl-badge-error{font-size:.55rem;color:#f44;font-weight:600}.pl-no-audio{font-size:.55rem;color:#333;font-style:italic}.pl-remove{background:none;border:none;color:#2a2a2a;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;flex-shrink:0;transition:color .1s,background .1s;opacity:0}.pl-row:hover .pl-remove{opacity:1}.pl-remove:hover{color:#f44;background:#ff44441a}.pl-clear-btn{flex:1;background:#111;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffa6;font-size:.7rem;font-weight:700;letter-spacing:.1em;padding:0;min-height:48px;cursor:pointer;transition:background .15s,color .15s}.pl-clear-btn:hover{background:#1a1a1a;color:#fff}.pl-row-expanded{padding:0 .875rem .75rem 2.75rem;display:flex;flex-direction:column;gap:.5rem}.pl-song-controls{display:flex;gap:.5rem}.pl-song-field{flex:1;display:flex;flex-direction:column;gap:.2rem}.pl-song-field-label{font-size:.5rem;letter-spacing:.15em;color:#444;font-weight:700}.pl-song-select{appearance:none;-webkit-appearance:none;background:#0a0a0a;border:1px solid #1e1e1e;border-radius:4px;color:#aaa;font-family:inherit;font-size:.65rem;font-weight:600;padding:.35rem 1.5rem .35rem .5rem;cursor:pointer;width:100%;transition:border-color .15s;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23555' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .4rem center}.pl-song-select:hover{border-color:#333;color:#ccc}.pl-song-select:focus{outline:none;border-color:#ff5200;color:#fff}.pl-song-select option{background:#111;color:#ccc}.pl-song-stats{display:flex;gap:.75rem}.pl-song-stat{font-size:.6rem;color:#444;font-weight:600}.pl-song-viz,.pl-song-pal{font-size:.55rem;color:#444;font-weight:600}.pl-song-sep{font-size:.55rem;color:#282828}.start-ride-btn{flex:1;background:#ff5200;color:#fff;border:none;border-radius:8px;padding:0;min-height:48px;font-size:.8rem;font-weight:800;letter-spacing:.15em;cursor:pointer;transition:background .15s,transform .1s}.start-ride-btn:hover{background:#e64800}.start-ride-btn:active{transform:scale(.97)}.install-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;background:#ff52001a;color:#ff5200;border:1px solid rgba(255,82,0,.25);border-radius:8px;padding:.6rem 1rem;font-size:.75rem;font-weight:700;letter-spacing:.1em;cursor:pointer;transition:background .15s;font-family:inherit;margin-bottom:.5rem}.install-btn:hover{background:#ff52002e}.install-btn svg{flex-shrink:0}.ios-install-hint{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:.75rem 1rem;margin-bottom:.5rem;font-size:.8rem;color:#ffffffb3;line-height:1.5}.ios-install-hint strong{color:#ff5200}.ios-install-dismiss{background:none;border:none;color:#fff6;cursor:pointer;font-size:.7rem;font-family:inherit;padding:.3rem 0 0;text-decoration:underline}.ride-summary-overlay{position:fixed;inset:0;z-index:110;background:#000000d9;display:flex;align-items:center;justify-content:center;animation:summary-fade-in .5s ease-out}@keyframes summary-fade-in{0%{opacity:0}to{opacity:1}}.ride-summary-card{background:#111114;border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:2.5rem 2rem;max-width:420px;width:90%;text-align:center;animation:summary-card-in .5s ease-out .1s both}@keyframes summary-card-in{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.summary-template{font-size:.7rem;font-weight:700;letter-spacing:.15em;color:#ff5200;text-transform:uppercase;margin-bottom:.5rem}.summary-heading{font-size:clamp(1.5rem,5vw,2rem);font-weight:800;color:#fff;letter-spacing:-.02em;margin:0 0 1.5rem}.summary-stats{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:2rem}.summary-stat{display:flex;flex-direction:column;gap:.2rem}.stat-value{font-size:1.6rem;font-weight:800;color:#fff}.stat-label{font-size:.65rem;font-weight:600;letter-spacing:.1em;color:#fff6;text-transform:uppercase}.summary-actions{display:flex;flex-direction:column;gap:.6rem}.summary-btn{display:block;width:100%;padding:.75rem 1rem;border-radius:10px;font-size:.8rem;font-weight:700;letter-spacing:.1em;cursor:pointer;transition:background .15s;font-family:inherit;text-align:center;text-decoration:none}.summary-btn.primary{background:#ff5200;color:#fff;border:none}.summary-btn.primary:hover{background:#e64800}.summary-btn.secondary{background:none;color:#ffffff80;border:1px solid rgba(255,255,255,.1)}.summary-btn.secondary:hover{background:#ffffff0a;color:#ffffffb3}.countdown-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#0009;pointer-events:none}.countdown-num{font-size:120px;font-weight:800;color:#fff;animation:countdown-pulse 1s ease-out forwards;-webkit-user-select:none;user-select:none}.countdown-num.go{color:#ff5200;animation:countdown-pulse .5s ease-out forwards}@keyframes countdown-pulse{0%{transform:scale(1.3);opacity:.8}to{transform:scale(1);opacity:1}}.app.ride-active{display:none}.ride-hud{position:fixed;inset:0;z-index:50;pointer-events:none;animation:ride-fade-in .5s ease forwards}.ride-watermark{position:fixed;bottom:12px;right:14px;height:22px;width:auto;opacity:.08;pointer-events:none;z-index:51}.ride-hud>*{pointer-events:auto}@keyframes ride-fade-in{0%{opacity:0}to{opacity:1}}.cue-flash{position:fixed;inset:0;background:#fff;opacity:.5;animation:cue-flash-out .4s ease-out forwards;pointer-events:none;z-index:60}@keyframes cue-flash-out{0%{opacity:.5}to{opacity:0}}.cue-countdown{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:120px;font-weight:800;color:#fff;pointer-events:none;z-index:55;animation:cue-cd-pulse .3s ease-out forwards;text-shadow:0 0 40px rgba(0,0,0,.5)}.cue-countdown.final{color:#ff5200}@keyframes cue-cd-pulse{0%{transform:translate(-50%,-50%) scale(1.4);opacity:.9}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.ride-hud-top{position:absolute;top:0;left:0;right:0;padding-top:calc(16px + env(safe-area-inset-top));z-index:20;pointer-events:none}.ride-hud-top>*{pointer-events:auto}.ride-hud-row1{display:flex;justify-content:space-between;align-items:center;padding:0 16px;margin-bottom:8px}.ride-exit{background:#00000059;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.08);border-radius:8px;color:#ffffff80;font-size:.55rem;font-weight:700;letter-spacing:.15em;padding:.35rem .7rem;cursor:pointer;transition:color .15s,background .15s}.ride-exit:hover{color:#fff;background:#000000b3}.ride-playpause{background:#00000059;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.08);border-radius:50%;color:#ffffff80;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.ride-playpause:hover{color:#fff;background:#000000b3}.ride-paused{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:48px;font-weight:700;letter-spacing:.25em;color:#ffffff26;pointer-events:none}.ride-timer-row{display:flex;align-items:center;justify-content:center;gap:.75rem}.ride-skip-btn{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.08);background:#00000059;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);color:#ffffff73;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s,opacity .15s}.ride-skip-btn:hover{background:#000000b3;color:#fff}.ride-skip-btn.disabled{opacity:.25;cursor:default;pointer-events:none}.ride-timer-panel{background:#00000073;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:.6rem 1.5rem .5rem;display:flex;flex-direction:column;align-items:center;pointer-events:none}.timer-cols{display:flex;align-items:center;gap:1.5rem}.timer-col{display:flex;flex-direction:column;align-items:center}.timer-col-label{font-size:11px;font-weight:700;letter-spacing:.15em;color:#ffffff4d;text-transform:uppercase}.timer-col-value{font-size:56px;font-weight:700;color:#fff;line-height:1;font-variant-numeric:tabular-nums;transition:color .3s ease}.timer-col-value.intensity{color:#ff5200}.timer-col-label.intensity-label{color:#ff5200;font-size:13px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:120px}.timer-col-value.warn{color:#ff5200}.timer-col-value.pulse{color:#ff5200;animation:timer-pulse 1s ease-in-out infinite}@keyframes timer-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.timer-col-divider{width:1px;height:48px;background:#ffffff1a;flex-shrink:0}.ride-timer-song{font-size:13px;font-weight:600;color:#ffffff4d;white-space:nowrap;margin-top:.2rem;margin-bottom:.35rem}.seg-bar{position:relative;width:100%;height:6px;cursor:pointer;pointer-events:auto;padding:20px 0;margin:-20px 0;box-sizing:content-box}.seg-bar-track{position:absolute;top:20px;left:0;right:0;height:6px;background:#ffffff26;border-radius:3px}.seg-bar-played{position:absolute;top:20px;left:0;height:6px;background:#fff;border-radius:3px 0 0 3px;pointer-events:none}.seg-bar-active{position:absolute;top:20px;height:6px;background:#ff5200;pointer-events:none}.seg-bar-zone{position:absolute;top:0;height:100%;cursor:pointer}.seg-bar-zone:hover{background:#ffffff14}.seg-bar-zone.current:hover{background:#ff520026}.seg-bar-hash{position:absolute;top:17px;width:2px;height:12px;background:#fff9;transform:translate(-1px);pointer-events:none}.seg-bar-hash.current{background:#ff5200}.seg-bar-head{position:absolute;top:19px;width:8px;height:8px;border-radius:50%;background:#fff;transform:translate(-4px);pointer-events:none;box-shadow:0 0 4px #00000080}.ride-motivation{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:72px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.08em;text-shadow:0 0 40px rgba(255,82,0,.4),0 2px 12px rgba(0,0,0,.6);pointer-events:none;animation:motivation-in .2s ease-out forwards;white-space:nowrap}@keyframes motivation-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.ride-next-cue{position:absolute;bottom:170px;left:50%;transform:translate(-50%);background:#0006;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.06);border-radius:20px;padding:.4rem 1.25rem;font-size:.65rem;font-weight:600;color:#ffffff80;letter-spacing:.08em;white-space:nowrap;pointer-events:none;transition:opacity .3s ease}.ride-cue-card{position:absolute;bottom:28px;left:50%;transform:translate(-50%);background:#00000073;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:.6rem 1.5rem .5rem;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:1rem;text-align:center;min-width:280px;max-width:620px;animation:cue-slide-in .35s ease-out forwards;pointer-events:none}.cue-video{width:100px;height:100px;object-fit:cover;border-radius:10px;flex-shrink:0}.cue-text{display:flex;flex-direction:column;align-items:center;gap:.3rem}@keyframes cue-slide-in{0%{transform:translate(-50%) translateY(30px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.cue-name{font-size:clamp(24px,4vw,52px);font-weight:700;color:#fff;line-height:1.1;white-space:nowrap}.cue-cadence{font-size:clamp(12px,1.5vw,18px);font-weight:600;color:#ffffff73;letter-spacing:.1em;text-transform:uppercase}.cue-desc{font-size:clamp(13px,1.8vw,22px);color:#ffffffb3;line-height:1.4;max-width:480px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ride-style-section{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.ride-style-dropdown{position:relative}.ride-style-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;background:#ffffff08;border:1px solid rgba(255,255,255,.09);color:#fff;font-family:inherit;font-size:.65rem;font-weight:600;border-radius:8px;padding:.55rem;cursor:pointer;transition:border-color .15s,background .15s}.ride-style-trigger:hover{background:#ffffff12;border-color:#ffffff2e}.ride-style-chevron{transition:transform .2s;flex-shrink:0}.ride-style-chevron.open{transform:rotate(180deg)}.ride-style-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:50;background:#1a1a1a;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:.25rem;overflow:hidden;box-shadow:0 8px 24px #00000080}.ride-style-option{display:flex;align-items:flex-start;gap:.45rem;width:100%;background:none;border:1px solid transparent;border-radius:6px;padding:.45rem .5rem;cursor:pointer;text-align:left;font-family:inherit;color:#fff;transition:background .12s,border-color .12s}.ride-style-option:hover{background:#ff520014;border-color:#ff520033}.ride-style-option.active{border-color:#ff520059;background:#ff52001a}.ride-style-option-check{width:.7rem;flex-shrink:0;color:#ff5200;font-size:.45rem;line-height:1.1rem;text-align:center}.ride-style-option-text{display:flex;flex-direction:column;gap:.1rem;min-width:0}.ride-style-option-label{font-size:.6rem;font-weight:700;letter-spacing:.03em}.ride-style-option.active .ride-style-option-label{color:#ff5200}.ride-style-option-desc{font-size:.48rem;color:#ffffff59;line-height:1.3}.difficulty-label{font-size:.5rem;letter-spacing:.15em;color:#ffffff59;font-weight:700}.difficulty-section{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.difficulty-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem}.difficulty-card{display:flex;flex-direction:column;gap:.25rem;padding:.55rem .5rem .5rem;border-radius:8px;border:1px solid rgba(255,255,255,.09);background:#ffffff08;color:#ffffff80;font-family:inherit;text-align:left;cursor:pointer;transition:border-color .15s,background .15s}.difficulty-card:hover:not(:disabled){background:#ffffff12;border-color:#ffffff2e}.difficulty-card.active{border-color:#ff5200;background:#ff52001a;color:#fff}.difficulty-card:disabled,.difficulty-card.disabled{opacity:.35;cursor:not-allowed}.diff-card-name{font-size:.6rem;font-weight:800;letter-spacing:.1em}.difficulty-card.active .diff-card-name{color:#ff5200}.diff-card-meta{font-size:.5rem;color:#fff6;display:flex;flex-direction:column;gap:.08rem;line-height:1.4}.difficulty-card.active .diff-card-meta{color:#ffffffa6}.diff-card-bar{height:3px;background:#ffffff12;border-radius:2px;overflow:hidden;margin-top:.2rem}.diff-card-bar-fill{height:100%;background:#ffffff40;border-radius:2px;transition:width .4s ease}.difficulty-card.active .diff-card-bar-fill{background:#ff5200}.diff-card-loading{font-size:.48rem;color:#fff3;font-style:italic;margin-top:.15rem}.sidebar-controls{flex-shrink:0;padding:0 1.25rem}.sidebar-divider{flex-shrink:0;height:1px;background:#ffffff0d;margin:0 1.25rem}.sidebar-btn-row{flex-shrink:0;display:flex;gap:.5rem;padding:0 1.25rem 1.25rem}.voice-toggle-control{display:flex;flex-direction:column;gap:.5rem}.voice-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .55rem;background:#ffffff08;border:1px solid rgba(255,255,255,.09);border-radius:8px;cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s}.voice-toggle:hover{background:#ffffff12;border-color:#ffffff2e}.voice-toggle-knob{position:relative;width:32px;height:18px;flex-shrink:0;border-radius:9px;background:#ffffff26;transition:background .2s}.voice-toggle-knob:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#ffffff80;transition:transform .2s,background .2s}.voice-toggle.on .voice-toggle-knob{background:#ff5200}.voice-toggle.on .voice-toggle-knob:after{transform:translate(14px);background:#fff}.voice-toggle-label{font-size:.55rem;font-weight:700;letter-spacing:.1em;color:#ffffff59;transition:color .2s}.voice-toggle.on .voice-toggle-label{color:#ff5200}button,a,input,select,[role=button]{touch-action:manipulation;-webkit-tap-highlight-color:transparent}@media(max-width:1023px){.setup-sidebar{width:300px}.ride-timer-panel{padding:.5rem 1.25rem .4rem}.timer-col-value{font-size:44px}.timer-col-divider{height:36px}.ride-timer-song{font-size:12px}}@media(max-width:767px){.setup-sidebar{position:relative;width:100%;border-right:none;overflow:visible}.sidebar-brand{padding:.75rem .75rem 0}.header-logo{width:100%;height:auto}.header-tagline{font-size:7px;letter-spacing:.08em}.drop-zone{margin:0 .75rem;width:calc(100% - 1.5rem);padding:2rem 1.25rem}.drop-zone.compact{padding:.6rem 1rem}.drop-icon{width:28px;height:28px}.drop-label{font-size:.82rem}.player-bar{margin:0 .75rem;width:calc(100% - 1.5rem)}.play-btn{padding:10px;min-width:44px;min-height:44px}.progress-track{height:8px}.progress-thumb{width:20px;height:20px;opacity:1}.sidebar-panels{flex:none}.ride-timeline{margin:0 .75rem;width:calc(100% - 1.5rem);padding:1rem .75rem;flex:none;overflow:visible}.timeline-content{overflow:visible;padding-bottom:0}.pl-panel{margin:0 .75rem;width:calc(100% - 1.5rem);flex:none;overflow:visible}.tl-row{grid-template-columns:2.5rem 16px 1fr 2.5rem;gap:0 .5rem}.tl-cue{font-size:.8rem}.tl-body{padding-bottom:1rem}.pl-header{padding:.75rem .75rem .5rem}.pl-row-main{padding:.65rem .75rem;min-height:48px}.pl-remove{opacity:1;min-width:44px;min-height:44px;padding:10px}.pl-drag-handle{padding:6px;color:#444}.sidebar-btn-row{padding:0 .75rem 1rem}.pl-clear-btn{min-height:48px;font-size:.7rem}.pl-row-expanded{padding:0 .75rem .75rem 1.5rem}.pl-song-controls{flex-direction:column}.pl-song-select{font-size:.75rem;padding:.5rem 1.5rem .5rem .5rem;min-height:44px}.pl-actions{padding:.75rem}.difficulty-cards{gap:.3rem}.difficulty-card{padding:.5rem .4rem}.voice-toggle-knob{width:40px;height:22px;border-radius:11px}.voice-toggle-knob:after{width:18px;height:18px}.voice-toggle.on .voice-toggle-knob:after{transform:translate(18px)}.start-ride-btn{min-height:52px;font-size:.9rem}.countdown-num,.cue-countdown{font-size:80px}.ride-hud-top{padding-top:calc(8px + env(safe-area-inset-top))}.ride-hud-row1{padding:0 10px;margin-bottom:4px}.ride-exit{padding:.6rem 1rem;font-size:.7rem;min-width:44px;min-height:44px}.ride-playpause{width:44px;height:44px}.ride-paused{font-size:36px}.ride-timer-row{gap:.4rem}.ride-skip-btn{width:44px;height:44px}.ride-timer-panel{padding:.4rem 1rem .3rem;border-radius:10px}.timer-cols{gap:1rem}.timer-col-label{font-size:9px}.timer-col-value{font-size:36px}.timer-col-divider{height:30px}.ride-timer-song{font-size:11px;margin-bottom:.2rem;overflow:hidden;text-overflow:ellipsis;max-width:220px}.ride-motivation{font-size:48px}.ride-next-cue{bottom:130px;font-size:.6rem;padding:.35rem .9rem}.ride-cue-card{bottom:calc(12px + env(safe-area-inset-bottom));padding:.5rem 1rem calc(.4rem + env(safe-area-inset-bottom));flex-direction:row;width:calc(100vw - 24px);max-width:none;min-width:0;height:auto;overflow:visible;gap:.75rem}.cue-text{align-items:flex-start;text-align:left}.cue-video{width:80px;height:80px}.cue-name{font-size:clamp(18px,5vw,36px)}.cue-cadence{font-size:clamp(10px,2.8vw,14px)}.cue-desc{font-size:clamp(12px,3.2vw,18px);line-height:1.35;-webkit-line-clamp:3;overflow:visible}@keyframes cue-slide-in{0%{transform:translate(-50%) translateY(30px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}}@media(max-height:500px)and (orientation:landscape){.setup-sidebar{width:280px}.sidebar-brand{padding:.5rem .75rem 0}.drop-zone{padding:1rem}.drop-icon{width:20px;height:20px}.drop-label{font-size:.75rem}.drop-sub{display:none}.start-ride-btn{min-height:44px;font-size:.75rem}.ride-hud-top{padding-top:calc(4px + env(safe-area-inset-top))}.ride-hud-row1{padding:0 8px;margin-bottom:2px}.ride-timer-row{gap:.3rem}.ride-skip-btn{width:36px;height:36px}.ride-skip-btn svg{width:16px;height:16px}.ride-timer-panel{padding:.3rem 1rem .25rem;min-width:140px;border-radius:10px}.timer-cols{gap:.75rem}.timer-col-label{font-size:8px}.timer-col-value{font-size:28px}.timer-col-divider{height:24px}.ride-timer-song{font-size:10px;margin-bottom:.2rem;max-width:150px;overflow:hidden;text-overflow:ellipsis}.seg-bar,.seg-bar-track,.seg-bar-played,.seg-bar-active{height:4px}.seg-bar-hash{height:10px}.seg-bar-head{width:6px;height:6px;transform:translate(-3px)}.ride-exit{padding:.35rem .65rem;font-size:.55rem;min-height:36px}.ride-playpause{width:32px;height:32px}.ride-paused{font-size:28px}.ride-motivation{font-size:36px}.ride-next-cue{bottom:auto;top:50px;font-size:.55rem}.ride-cue-card{bottom:8px;padding:.3rem 1rem .25rem;min-width:160px;max-width:60vw;height:auto;overflow:visible}.cue-video{width:56px;height:56px;border-radius:8px}.cue-name{font-size:clamp(16px,3vw,24px)}.cue-cadence{font-size:clamp(9px,2vw,12px)}.cue-desc{font-size:clamp(11px,2vw,15px);line-height:1.35;-webkit-line-clamp:3;overflow:visible}@keyframes cue-slide-in{0%{transform:translate(-50%) translateY(30px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.countdown-num,.cue-countdown{font-size:60px}}@media(hover:none){.pl-remove,.progress-thumb{opacity:1}.pl-drag-handle{color:#444}.start-ride-btn:active{background:#e64800}.difficulty-card:active:not(:disabled){background:#ffffff1a}.difficulty-card.active:active{background:#ff52002e}.ride-skip-btn:active{background:#000000b3;color:#fff}.ride-exit:active,.ride-playpause:active{color:#fff;background:#000000b3}.pl-row:active{background:#ffffff0a}.play-btn:active{background:#ff520026}}
