body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.ground-setup{margin:0 auto;max-width:600px;padding:20px}.demo-section{margin-bottom:20px}.demo-section h3{color:#2d3748;font-size:14px;letter-spacing:1px;margin-bottom:12px;text-transform:uppercase}.demo-card{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;gap:12px;padding:16px 20px;text-align:left;transition:all .2s;width:100%}.demo-card:hover{box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.demo-icon{font-size:28px}.demo-info{display:flex;flex:1 1;flex-direction:column}.demo-title{font-size:16px;font-weight:700}.demo-desc{font-size:13px;margin-top:2px;opacity:.9}.demo-arrow{font-size:20px;opacity:.8}.section-divider{align-items:center;display:flex;margin:24px 0}.section-divider:after,.section-divider:before{background:#e2e8f0;content:"";flex:1 1;height:1px}.section-divider span{color:#a0aec0;font-size:12px;font-weight:600;padding:0 16px}.ground-setup h2{color:#1a365d;margin-bottom:8px}.ground-setup .subtitle{color:#718096;margin-bottom:24px}.presets{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.preset-btn{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;min-width:140px;padding:12px 16px;text-align:left;transition:all .2s}.preset-btn.active,.preset-btn:hover{border-color:#3182ce}.preset-btn.active{background:#3182ce;color:#fff}.preset-name{font-size:14px;font-weight:600}.preset-desc{font-size:11px;margin-top:2px;opacity:.7}.platoon-info{background:#ebf8ff;border:1px solid #bee3f8;border-radius:8px;margin-bottom:24px;padding:16px}.platoon-info h4{color:#2b6cb0;font-size:14px;margin:0 0 8px}.platoon-info p{color:#4a5568;font-size:13px;line-height:1.5;margin:0}.inputs-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.input-group{display:flex;flex-direction:column}.input-group label{color:#2d3748;font-weight:500;margin-bottom:6px}.input-group input{border:2px solid #e2e8f0;border-radius:8px;font-size:16px;padding:12px}.input-group input:focus{border-color:#3182ce;outline:none}.input-group .hint{color:#a0aec0;font-size:12px;margin-top:4px}.ground-preview{background:#f7fafc;border-radius:12px;margin-bottom:24px;padding:20px}.ground-preview,.preview-rect{display:flex;justify-content:center}.preview-rect{align-items:center;background:linear-gradient(135deg,#48bb78,#38a169);border-radius:4px;box-shadow:0 4px 12px #48bb784d;color:#fff;flex-direction:column;font-weight:700;min-height:100px;min-width:100px}.preview-rect .musicians-badge{background:#fff3;border-radius:12px;font-size:14px;margin-top:8px;padding:4px 12px}.continue-btn{width:100%}@media (max-width:600px){.inputs-grid{grid-template-columns:1fr}}.sequence-builder{margin:0 auto;max-width:1200px;padding:20px}.builder-header h2{color:#1a365d;margin-bottom:8px}.builder-header .subtitle{color:#718096;margin-bottom:20px}.target-setting{align-items:center;background:#edf2f7;border-radius:8px;display:flex;gap:20px;margin-bottom:20px;padding:12px 16px}.target-setting label{align-items:center;color:#4a5568;display:flex;font-weight:500;gap:8px}.target-setting select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;padding:6px 12px}.current-total{color:#2d3748;font-weight:600}.timeline-track-container{background:#1a202c;border-radius:12px;margin-bottom:20px;padding:16px}.timeline-header{margin-bottom:12px}.timeline-title{color:#fff;font-size:16px;font-weight:600}.timeline-duration{color:#a0aec0;font-size:14px}.timeline-duration .over{color:#fc8181;font-weight:500}.timeline-duration .under{color:#90cdf4}.timeline-duration .good{color:#68d391}.timeline-track{background:#2d3748;border-radius:8px;height:80px;overflow:visible;position:relative}.time-ruler{border-bottom:1px solid #4a5568;height:20px;left:0;position:absolute;right:0;top:0}.time-mark{color:#718096;font-size:10px;position:absolute;top:4px;transform:translateX(-50%)}.track-items{bottom:4px;left:2px;position:absolute;right:2px;top:24px}.track-item{align-items:center;border-radius:6px;box-sizing:border-box;cursor:pointer;display:flex;height:100%;overflow:hidden;position:absolute;transition:all .2s}.track-item:hover{transform:scaleY(1.05);z-index:10}.track-item.entry{border:2px solid #68d391}.track-item.exit{border:2px solid #f6ad55}.track-item.march{border:2px solid #63b3ed}.track-item.transition{border:2px solid #b794f4}.item-content{align-items:center;display:flex;flex:1 1;gap:6px;min-width:0;padding:0 8px}.item-icon{flex-shrink:0;font-size:14px}.item-name{color:#fff;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-formations{color:#ffffffb3;flex-shrink:0;font-size:9px}.track-item .remove-btn{background:#0000004d;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:14px;height:20px;margin-right:4px;opacity:0;transition:opacity .2s;width:20px}.track-item:hover .remove-btn{opacity:1}.track-item .remove-btn:hover{background:#e53e3e}.target-marker{bottom:0;pointer-events:none;position:absolute;top:0;z-index:20}.marker-line{background:#48bb78;height:100%;width:2px}.marker-label{color:#48bb78;font-size:10px;left:50%;position:absolute;top:-18px;transform:translateX(-50%);white-space:nowrap}.builder-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 350px;margin-bottom:20px}.sequence-list{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:16px}.list-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.list-header h3{color:#2d3748;font-size:16px;margin:0}.list-header .hint{color:#a0aec0;font-size:12px}.sequence-items{display:flex;flex-direction:column;gap:8px}.sequence-card{align-items:center;background:#f7fafc;border-left:4px solid #e2e8f0;border-radius:8px;display:flex;gap:12px;padding:12px;transition:all .2s}.sequence-card:hover{background:#edf2f7}.sequence-card.entry{border-left-color:#48bb78}.sequence-card.exit{border-left-color:#ed8936}.sequence-card.march{border-left-color:#4299e1}.sequence-card.transition{border-left-color:#9f7aea}.card-order{align-items:center;background:#4a5568;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:28px;justify-content:center;width:28px}.card-icon{font-size:24px}.card-info{flex:1 1;min-width:0}.card-header{align-items:center;display:flex;gap:8px;margin-bottom:4px}.card-type{color:#718096;font-size:10px;font-weight:600;text-transform:uppercase}.card-name{font-size:14px}.card-details{color:#718096;display:flex;font-size:12px;gap:12px}.card-details .detail strong{color:#4a5568}.card-formations{color:#718096;font-size:11px;margin-top:6px}.formations-label{margin-right:4px}.formation-badge{color:#4a5568}.card-actions{align-items:center;display:flex;flex-shrink:0;gap:4px}.card-actions button{background:#fff;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;font-size:12px;padding:6px 10px;transition:all .2s}.card-actions .move-btn{color:#718096;padding:4px 8px}.card-actions .move-btn:hover:not(:disabled){background:#edf2f7;color:#4a5568}.card-actions .move-btn:disabled{cursor:not-allowed;opacity:.3}.card-actions .edit-btn{background:#ebf8ff;border-color:#bee3f8;color:#3182ce}.card-actions .edit-btn:hover{background:#3182ce;color:#fff}.card-actions .delete-btn{border-color:#feb2b2;color:#e53e3e}.card-actions .delete-btn:hover{background:#e53e3e;color:#fff}.add-between{display:flex;justify-content:center;padding:4px 0}.add-transition-btn{background:#0000;border:1px dashed #cbd5e0;border-radius:12px;color:#a0aec0;cursor:pointer;font-size:11px;padding:4px 12px;transition:all .2s}.add-transition-btn:hover{background:#f7fafc;border-color:#9f7aea;color:#9f7aea}.libraries-panel{display:flex;flex-direction:column;gap:16px}.march-library,.transition-library{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:16px}.march-library h3,.transition-library h3{color:#2d3748;font-size:15px;margin:0 0 12px}.march-list{max-height:300px;overflow-y:auto}.march-item{align-items:center;background:#f7fafc;border-radius:6px;display:flex;justify-content:space-between;padding:10px;transition:all .2s}.march-item:hover{background:#edf2f7}.march-info{display:flex;flex-direction:column}.march-name{color:#2d3748;font-size:13px;font-weight:600}.march-meta{color:#718096;font-size:11px}.add-march-btn{background:#4299e1;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s}.add-march-btn:hover{background:#3182ce}.transition-list{display:flex;flex-direction:column;gap:6px}.transition-item{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;padding:10px 12px;text-align:left;transition:all .2s}.transition-item:hover:not(:disabled){background:#9f7aea;border-color:#9f7aea;color:#fff}.transition-item:disabled{cursor:not-allowed;opacity:.5}.trans-name{font-size:13px;font-weight:500}.trans-bars{font-size:11px;opacity:.7}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:12px;max-width:400px;min-width:320px;padding:24px}.modal h3{color:#2d3748;margin:0 0 16px}.modal-content{gap:8px;margin-bottom:16px}.modal-content,.modal-option{display:flex;flex-direction:column}.modal-option{align-items:flex-start;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;padding:12px;text-align:left;transition:all .2s}.modal-option:hover{background:#faf5ff;border-color:#9f7aea}.option-name{color:#2d3748;font-weight:600}.option-desc{color:#718096;font-size:12px}.modal-cancel{background:#edf2f7;border:none;border-radius:6px;color:#4a5568;cursor:pointer;font-weight:500;padding:10px;width:100%}.modal-cancel:hover{background:#e2e8f0}.continue-btn:hover:not(:disabled){background:#2c5282}.continue-btn:disabled{background:#cbd5e0;cursor:not-allowed}@media (max-width:900px){.builder-content{grid-template-columns:1fr}.libraries-panel{flex-direction:row}.march-library,.transition-library{flex:1 1}}.loading{padding:20px;text-align:center}.formation-designer{margin:0 auto;max-width:1200px;padding:20px}.designer-header h2{color:#1a365d;margin-bottom:8px}.designer-header .subtitle{color:#718096;margin-bottom:12px}.progress-info{align-items:center;display:flex;gap:12px;margin-bottom:20px}.progress-text{color:#4a5568;font-size:14px}.progress-bar{background:#e2e8f0;border-radius:4px;flex:1 1;height:8px;max-width:300px;overflow:hidden}.progress-fill{transition:width .3s}.designer-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:280px 1fr;margin-bottom:20px}.march-list-sidebar{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:16px}.march-list-sidebar h3{color:#2d3748;font-size:15px;margin:0 0 12px}.march-list{display:flex;flex-direction:column;gap:8px}.march-card{align-items:center;background:#f7fafc;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:10px;transition:all .2s}.march-card:hover{background:#edf2f7}.march-card.active{background:#ebf8ff;border-color:#3182ce}.march-card.entry{border-left:4px solid #48bb78}.march-card.exit{border-left:4px solid #ed8936}.march-card.march{border-left:4px solid #4299e1}.march-card.transition{border-left:4px solid #9f7aea}.card-number{align-items:center;background:#4a5568;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:22px;justify-content:center;width:22px}.march-card.active .card-number{background:#3182ce}.card-icon{flex-shrink:0;font-size:18px}.card-content{flex:1 1;min-width:0}.card-name{color:#2d3748;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-meta{color:#718096;font-size:11px}.active-indicator{color:#3182ce;font-size:12px}.editing-area{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:20px}.march-header{align-items:flex-start;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.march-title{display:flex;flex-direction:column;gap:4px}.march-type{color:#718096;font-size:12px;font-weight:600;text-transform:uppercase}.march-title h3{color:#2d3748;font-size:20px;margin:0}.march-stats{display:flex;gap:16px}.march-stats span{background:#edf2f7;border-radius:4px;color:#4a5568;font-size:13px;padding:4px 10px}.formation-timeline{margin-bottom:20px}.formation-timeline .timeline-header{color:#4a5568;font-size:14px;font-weight:500;margin-bottom:8px}.formation-timeline .timeline-track{background:#1a202c;border-radius:8px;height:70px;padding:20px 8px 8px;position:relative}.bar-ruler{height:14px;left:8px;position:absolute;right:8px;top:4px}.bar-ruler span{color:#718096;font-size:9px;position:absolute;transform:translateX(-50%)}.formations-track{height:100%;position:relative}.formation-block{align-items:center;background:linear-gradient(135deg,#4299e1,#3182ce);border:2px solid #0000;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;gap:2px;height:100%;justify-content:center;min-width:50px;overflow:hidden;position:absolute;transition:all .2s}.formation-block:hover{transform:scaleY(1.05);z-index:10}.formation-block.selected{border-color:#48bb78;box-shadow:0 0 0 2px #48bb784d}.formation-block:nth-child(2n){background:linear-gradient(135deg,#48bb78,#38a169)}.formation-block:nth-child(3n){background:linear-gradient(135deg,#ed8936,#dd6b20)}.formation-block:nth-child(4n){background:linear-gradient(135deg,#9f7aea,#805ad5)}.formation-block .formation-icon{color:#fff;height:24px;width:24px}.formation-block .formation-name{color:#fff;font-size:10px;font-weight:600;max-width:100%;overflow:hidden;padding:0 4px;text-overflow:ellipsis;white-space:nowrap}.formation-block .transition-zone{background:repeating-linear-gradient(-45deg,#0000,#0000 2px,#ffffff26 0,#ffffff26 4px);bottom:0;position:absolute;right:0;top:0}.formation-editor{background:#f7fafc;border-radius:8px;padding:16px}.formation-editor h4{color:#2d3748;font-size:15px;margin:0 0 12px}.editor-form{margin-bottom:16px}.form-row{gap:16px;margin-bottom:12px}.form-row,.form-row label{align-items:center;display:flex}.form-row label{color:#4a5568;font-size:13px;gap:8px}.form-row input{border:1px solid #e2e8f0;border-radius:4px;font-size:13px;padding:6px 10px;text-align:center;width:70px}.form-row input:focus{border-color:#3182ce;outline:none}.form-row .hint{color:#a0aec0;font-size:12px}.form-actions{display:flex;gap:8px}.form-actions .save-btn{background:#3182ce;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s}.form-actions .save-btn:hover{background:#2c5282}.form-actions .remove-btn{background:#fff;border:1px solid #feb2b2;border-radius:6px;color:#e53e3e;cursor:pointer;font-size:13px;padding:8px 16px;transition:all .2s}.form-actions .remove-btn:hover{background:#fff5f5}.no-selection{color:#a0aec0;padding:20px;text-align:center}.add-formation-section{border-top:1px solid #e2e8f0;margin-top:16px;padding-top:16px}.add-formation-section h4{color:#2d3748;font-size:14px;margin:0 0 12px}.formation-palette{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.palette-item{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:10px 8px;transition:all .2s}.palette-item:hover{background:#ebf8ff;border-color:#3182ce}.palette-icon{color:#4a5568;height:32px;width:32px}.palette-item:hover .palette-icon{color:#3182ce}.palette-item span{color:#718096;font-size:10px;text-align:center}.palette-item:hover span{color:#3182ce}.no-march-selected{align-items:center;color:#a0aec0;display:flex;height:300px;justify-content:center}.nav-buttons{display:flex;gap:12px;justify-content:space-between}.back-btn{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:all .2s}.back-btn:hover{border-color:#4a5568}.continue-btn{background:#3182ce;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:14px 24px;transition:background .2s}.continue-btn:hover{background:#2c5282}@media (max-width:900px){.designer-content{grid-template-columns:1fr}.march-list-sidebar{order:-1}.march-list{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}.composing-progress{align-items:center;display:flex;justify-content:center;min-height:500px;padding:40px}.progress-content{max-width:500px;text-align:center}.progress-icon{animation:spin 2s linear infinite;color:#3182ce;height:80px;margin:0 auto 24px;width:80px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.progress-content h2{color:#1a365d;margin-bottom:20px}.progress-info{margin-bottom:24px}.info-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr);margin-bottom:16px}.info-item{background:#f7fafc;border-radius:8px;display:flex;flex-direction:column;padding:10px}.info-label{color:#718096;font-size:11px;margin-bottom:2px;text-transform:uppercase}.info-value{color:#2d3748;font-size:18px;font-weight:700}.current-item{align-items:center;background:#ebf8ff;border:2px solid #bee3f8;border-radius:8px;display:flex;gap:8px;justify-content:center;padding:12px 20px}.item-icon{font-size:24px}.item-name{color:#2b6cb0;font-size:16px;font-weight:600}.progress-bar-container{background:#e2e8f0;border-radius:6px;height:12px;margin-bottom:12px;overflow:hidden;width:100%}.progress-bar{background:linear-gradient(90deg,#3182ce,#63b3ed);border-radius:6px;height:100%;transition:width .3s ease-out}.progress-status{color:#718096;font-size:14px;margin-bottom:20px}.sequence-preview{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.seq-item{font-size:20px;opacity:.3;transition:all .3s}.seq-item.active{opacity:1;transform:scale(1.3)}.seq-item.done{opacity:.7}.error-state{text-align:center}.error-icon{align-items:center;background:#fed7d7;border-radius:50%;color:#c53030;display:flex;font-size:32px;font-weight:700;height:60px;justify-content:center;margin:0 auto 16px;width:60px}.error-state h3{color:#c53030;margin-bottom:8px}.error-state p{color:#718096;margin-bottom:16px}.error-state button{background:#3182ce;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px}.error-state button:hover{background:#2c5282}@media (max-width:500px){.info-grid{grid-template-columns:repeat(2,1fr)}}.viewer-3d{background:#1a202c;border-radius:12px;display:flex;flex-direction:column;height:calc(100vh - 200px);min-height:500px;overflow:hidden;position:relative}.viewer-header{align-items:center;background:#2d3748;border-bottom:1px solid #4a5568;display:flex;justify-content:space-between;padding:16px 20px}.viewer-header h2{color:#fff;font-size:18px;margin:0}.viewer-info{display:flex;gap:16px}.viewer-info span{background:#1a202c;border-radius:4px;color:#a0aec0;font-size:14px;padding:4px 12px}.viewer-info .playing-badge{animation:pulse-badge .5s ease-in-out infinite alternate;background:#48bb78;color:#fff;font-weight:700}@keyframes pulse-badge{0%{opacity:.8;transform:scale(1)}to{opacity:1;transform:scale(1.05)}}.canvas-container{flex:1 1;min-height:400px}.canvas-container canvas{height:100%!important;width:100%!important}.viewer-legend{background:#2d3748;border-top:1px solid #4a5568;display:flex;gap:24px;justify-content:center;padding:12px 20px}.legend-item{align-items:center;color:#e2e8f0;display:flex;font-size:13px;gap:8px}.color-dot{border-radius:50%;height:12px;width:12px}.color-dot.brass{background:#c53030}.color-dot.woodwind{background:#2b6cb0}.color-dot.percussion{background:#2f855a}.color-dot.leader{background:#d69e2e;box-shadow:0 0 4px #d69e2e}.viewer-3d:after{bottom:60px;color:#fff6;content:"Drag to rotate • Scroll to zoom • Right-drag to pan";font-size:12px;left:50%;pointer-events:none;position:absolute;transform:translateX(-50%)}.timeline{background:#2d3748;border-radius:12px;margin-top:16px;padding:16px}.timeline-header{align-items:center;border-bottom:1px solid #4a5568;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.timeline-header .back-btn{background:#0000;border:1px solid #4a5568;border-radius:6px;color:#a0aec0;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.timeline-header .back-btn:hover{background:#4a5568;color:#fff}.performance-info{align-items:center;display:flex;gap:16px}.perf-name{color:#fff;font-size:16px;font-weight:600}.perf-duration{background:#1a202c;border-radius:4px;color:#a0aec0;font-size:14px;padding:4px 10px}.sequence-track{margin-bottom:12px}.track-items{background:#1a202c;border-radius:8px;cursor:pointer;height:50px;overflow:hidden;position:relative}.track-items .track-item{align-items:center;border-radius:4px;display:flex;gap:6px;height:100%;overflow:hidden;padding:0 8px;position:absolute;transition:all .2s}.track-item.entry{background:linear-gradient(135deg,#48bb78,#38a169)}.track-item.exit{background:linear-gradient(135deg,#ed8936,#dd6b20)}.track-item.march{background:linear-gradient(135deg,#4299e1,#3182ce)}.track-item.transition{background:linear-gradient(135deg,#9f7aea,#805ad5)}.track-item.active{box-shadow:inset 0 0 0 2px #fff}.track-item .item-icon{flex-shrink:0;font-size:14px}.track-item .item-name{color:#fff;font-size:11px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playhead{bottom:0;box-shadow:0 0 6px #ffffff80;pointer-events:none;top:0;width:2px;z-index:10}.playhead,.playhead:before{background:#fff;position:absolute}.playhead:before{border-radius:50%;content:"";height:10px;left:-4px;top:-4px;width:10px}.current-info{align-items:center;background:#1a202c;border-radius:6px;display:flex;gap:12px;margin-bottom:16px;padding:10px 16px}.current-icon{font-size:20px}.current-name{color:#fff;flex:1 1;font-weight:600}.current-bar{background:#48bb7826;border-radius:4px;color:#48bb78;font-size:14px;padding:4px 10px}.current-tempo{color:#a0aec0;font-size:14px}.timeline-controls{gap:24px}.timeline-controls,.transport{align-items:center;display:flex}.transport{gap:8px}.transport-btn{align-items:center;background:#4a5568;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s;width:44px}.transport-btn:hover{background:#718096}.transport-btn.play-btn{background:#48bb78;height:56px;width:56px}.transport-btn.play-btn:hover{background:#38a169}.transport-btn.play-btn.playing{background:#ed8936}.transport-btn.play-btn.playing:hover{background:#dd6b20}.time-section{flex:1 1}.time-display{align-items:center;color:#e2e8f0;display:flex;font-family:monospace;font-size:14px;gap:4px;margin-bottom:8px}.time-display .separator{color:#718096}.time-display .total-time{color:#a0aec0}.progress-bar-wrapper{background:#1a202c;border-radius:4px;cursor:pointer;height:8px;position:relative}.progress-fill{background:linear-gradient(90deg,#48bb78,#38a169);border-radius:4px;height:100%;left:0;position:absolute;top:0;transition:width .05s linear}.options{align-items:center;display:flex;gap:16px}.speed-control label{color:#a0aec0;display:block;font-size:12px;margin-bottom:4px}.speed-buttons{display:flex;gap:4px}.speed-buttons button{background:#4a5568;border:none;border-radius:4px;color:#e2e8f0;cursor:pointer;font-size:12px;padding:6px 10px;transition:all .2s}.speed-buttons button:hover{background:#718096}.speed-buttons button.active{background:#3182ce}.metronome-btn{align-items:center;background:#4a5568;border:none;border-radius:6px;color:#e2e8f0;cursor:pointer;display:flex;font-size:13px;gap:6px;padding:8px 12px;transition:all .2s}.metronome-btn:hover{background:#718096}.metronome-btn.active{background:#3182ce}@media (max-width:900px){.timeline-controls{flex-wrap:wrap}.time-section{margin-top:12px;order:3;width:100%}}*{box-sizing:border-box}body{background:#f7fafc;color:#1a202c;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;margin:0}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:#1a365d;box-shadow:0 2px 8px #00000026;color:#fff;justify-content:space-between;padding:16px 24px}.app-header,.logo{align-items:center;display:flex}.logo{gap:12px}.logo svg{color:#63b3ed}.logo h1{font-size:20px;font-weight:600;margin:0}.header-info{align-items:center;display:flex;gap:16px}.march-count{background:#48bb78;border-radius:4px;font-size:13px;font-weight:600;padding:6px 12px}.new-btn{background:#3182ce;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background .2s}.new-btn:hover{background:#2c5282}.step-indicator{background:#fff;border-bottom:1px solid #e2e8f0;justify-content:center;padding:24px}.step,.step-indicator{align-items:center;display:flex}.step{flex-direction:column;gap:8px}.step-circle{align-items:center;background:#e2e8f0;border-radius:50%;color:#718096;display:flex;font-size:14px;font-weight:600;height:36px;justify-content:center;transition:all .3s;width:36px}.step.active .step-circle{background:#3182ce;color:#fff;transform:scale(1.1)}.step.completed .step-circle{background:#48bb78;color:#fff}.step-name{color:#718096;font-size:12px;font-weight:500}.step.active .step-name{color:#3182ce;font-weight:600}.step.completed .step-name{color:#48bb78}.step-connector{background:#e2e8f0;height:2px;margin:0 12px 24px;width:60px}.app-main{flex:1 1;padding:24px}.preview-container{margin:0 auto;max-width:1400px}.app-footer{background:#2d3748;color:#a0aec0;font-size:13px;padding:16px 24px;text-align:center}@media (max-width:768px){.app-header{flex-direction:column;gap:12px;text-align:center}.step-indicator{flex-wrap:wrap;gap:8px}.step-connector,.step-name{display:none}.app-main{padding:16px}}.loading{align-items:center;color:#718096;display:flex;justify-content:center;padding:40px}.error{background:#fed7d7;border-radius:8px;color:#c53030;padding:16px;text-align:center}
/*# sourceMappingURL=main.3eb2854f.css.map*/