.app[data-v-7b2266df]{max-width:1200px;margin:0 auto;padding:20px;font-family:Arial,sans-serif}header[data-v-7b2266df]{margin-bottom:20px;text-align:center}h1[data-v-7b2266df]{color:#2c3e50}main[data-v-7b2266df]{margin-top:1rem}.notation-editor{max-width:100%;padding:10px;overflow-x:hidden;box-sizing:border-box}.controls{display:flex;flex-direction:column;gap:10px;margin-bottom:15px;width:100%}.controls-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;width:100%}.tempo-control{flex:1;min-width:120px;display:flex;align-items:center;flex-wrap:wrap;gap:5px}.tempo-control label{white-space:nowrap;font-size:14px}.tempo-slider{width:100%;max-width:200px}.clef-selector{display:flex;align-items:center;gap:10px}.clef-selector label{font-weight:500;white-space:nowrap}.custom-select{position:relative;min-width:120px}.playback-controls{display:flex;gap:12px;justify-content:center;margin:10px 0}.action-button{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 5px #00000026;position:relative;overflow:hidden}.action-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.action-button:after{content:"";position:absolute;top:50%;left:50%;width:120%;height:120%;background:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%) scale(0);opacity:0;transition:all .3s ease}.action-button:active:not(:disabled):after{transform:translate(-50%,-50%) scale(1.5);opacity:1;transition:all .2s ease}.button-icon{font-size:18px;line-height:1}.button-label{font-weight:500}.play-button{background-color:#4caf50;color:#fff}.play-button:hover:not(:disabled){background-color:#45a049;transform:translateY(-2px)}.stop-button{background-color:#f44336;color:#fff}.stop-button:hover:not(:disabled){background-color:#e53935;transform:translateY(-2px)}.clear-button{background-color:#757575;color:#fff}.clear-button:hover:not(:disabled){background-color:#616161;transform:translateY(-2px)}@keyframes buttonPress{0%{transform:scale(1)}50%{transform:scale(.95)}to{transform:scale(1)}}.button-press-animation{animation:buttonPress .3s ease}.tab-btn{flex:1;padding:10px 5px;background:#f0f0f0;border:none;border-bottom:2px solid #ddd;font-weight:700;font-size:14px;white-space:nowrap}.note-controls-container,.settings-container{background:#f5f5f5;border:1px solid #ddd;border-radius:4px;padding:10px;margin-bottom:10px;width:100%;box-sizing:border-box}.control-section{margin-bottom:15px;padding:10px;border:1px solid #ddd;border-radius:8px;background-color:#f9f9f9}.control-section h4{margin-top:0;margin-bottom:8px;color:#333;font-size:14px;text-align:center;border-bottom:1px solid #eee;padding-bottom:5px}.scrollable-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:5px}.note-btn{flex:0 0 auto;min-width:40px;height:40px;border:1px solid #ccc;border-radius:4px;background:#fff;font-size:18px;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.note-btn.active{background:#2196f3;color:#fff;border-color:#0d8aee;box-shadow:0 0 5px #2196f380}.dotted-note-toggle{margin-top:8px;display:flex;justify-content:center}.dotted-note-toggle button{width:100%;max-width:120px;height:36px;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}.dotted-note-toggle button.active{background:#2196f3;box-shadow:0 0 5px #2196f380}.button-group{display:flex;gap:5px;width:100%}.staff-scroll-controls{position:absolute;bottom:10px;right:10px;display:flex;gap:5px;z-index:10}.scroll-btn{width:36px;height:36px;background:#2196f3b3;color:#fff;border:none;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}.extend-btn{padding:0 10px;height:36px;background:#4caf50b3;color:#fff;border:none;border-radius:18px;font-size:12px;cursor:pointer;white-space:nowrap}@media (max-width: 360px){.notation-editor{padding:5px}.tempo-control label{font-size:12px}.tab-btn{padding:8px 5px;font-size:12px}.note-btn,.octave-btn,.chord-btn{padding:6px;font-size:12px;min-width:30px}.scroll-btn{width:30px;height:30px}.extend-btn{padding:0 8px;height:30px;font-size:11px}}@media (min-width: 768px){.notation-editor{padding:20px}.controls{flex-direction:row;align-items:center}.mobile-tabs{display:none}.note-controls-container,.settings-container{display:block!important}.note-controls{display:flex;flex-wrap:wrap;gap:15px}.control-section{flex:1;min-width:150px}.scrollable-buttons{flex-wrap:wrap}.staff-container{height:300px}.scroll-btn{width:40px;height:40px}.extend-btn{padding:0 15px;height:40px;font-size:14px}}.clef{width:60px;height:100%;display:flex;align-items:center;justify-content:center;border-right:1px solid #ddd}.clef img{height:150px;width:auto;margin-left:5px;margin-top:-10px;object-fit:contain}.staff-scroll-container{flex:1;position:relative;overflow:hidden;width:calc(100% - 60px)}.staff{position:absolute;height:100%;padding-top:60px;transition:transform .1s ease;min-width:100%;cursor:grab}.staff:active{cursor:grabbing;transition:none}.staff-lines{position:absolute;top:0;left:0;width:100%;height:60px;z-index:1}.staff-line{position:absolute;width:100%;height:1px;background-color:#000;left:0}.staff-line:nth-child(1){top:100px}.staff-line:nth-child(2){top:115px}.staff-line:nth-child(3){top:130px}.staff-line:nth-child(4){top:145px}.staff-line:nth-child(5){top:160px}.note-controls{display:flex;gap:5px;padding:10px;background:#f5f5f5;border:1px solid #ddd;border-radius:4px}.note-btn{padding:8px 12px;border:none;border-radius:4px;background:#4caf50;color:#fff;cursor:pointer}.note-btn.active{background:#2196f3}.octave-range{margin-top:10px;padding:10px;background:#f5f5f5;border:1px solid #ddd;border-radius:4px}.octave-buttons{display:flex;gap:5px;margin-top:5px}.octave-btn{padding:5px 10px;border:none;border-radius:4px;background:#4caf50;color:#fff;cursor:pointer}.octave-btn.active{background:#2196f3}.debug-panel{margin-top:20px;padding:15px;background:#e3f2fd;border:1px solid #2196F3;border-radius:4px}.debug-controls{display:flex;gap:20px;margin:10px 0}.debug-btn{padding:8px 12px;border:none;border-radius:4px;background:#ff5722;color:#fff;cursor:pointer;margin-top:5px}.debug-btn.active{background:#9c27b0}.debug-hint{font-style:italic;color:#666;margin-top:10px}button{transition:all .2s}button:hover{opacity:.9}.play-btn{background:#4caf50}.stop-btn{background:#f44336}.clear-btn{background:#ff9800}button:disabled{opacity:.5;cursor:not-allowed}.notes-container{position:absolute;top:0;left:0;width:100%;height:100%;z-index:3;overflow:visible}.note{position:absolute;font-family:Bravura,sans-serif;font-size:3.5em;cursor:pointer;-webkit-user-select:none;user-select:none;transition:transform .1s ease-out,background-color .2s;display:flex;align-items:center;justify-content:center;width:30px;height:20px;transform:translate(-50%,-50%);margin-bottom:0}.note.rest{font-size:4.5em}.note.playing{background-color:#ffff004d;transform:translate(-50%,-50%) scale(1.1)}.notehead{position:absolute;width:10px;height:8px;background:#000;border-radius:50%;left:5px;top:16px;transform:rotate(-20deg)}.notehead.whole,.notehead.half{background:#fff;border:1px solid black}.notehead.whole{width:12px;height:8px;left:4px}.note[data-duration=whole] .stem,.note[data-duration=whole] .flag{display:none}.note[data-duration=whole]{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.note[data-duration=whole] .dot{right:-12px;top:2px}.notehead.half{background:#fff;border:1px solid black;height:7px}.whole-note .notehead.whole{width:12px;height:8px;border:1px solid black;background:#fff;border-radius:50%;transform:rotate(-20deg);left:4px;top:6px}.whole-note .stem{display:none}.whole-note .dot{right:-12px;top:16px}.stem{position:absolute;width:1px;height:30px;background:#000}.stem.up{bottom:19px;right:5px}.stem.down{top:19px;left:5px}.flag{position:absolute;width:0;height:0;pointer-events:none}.flag.up{bottom:49px;right:5px}.flag.down{top:49px;left:5px}.flag:before{content:"";position:absolute;width:14px;height:8px;background-color:#000;border-radius:0 0 4px 4px;transform-origin:top left}.flag.sixteenth:after{content:"";position:absolute;width:14px;height:8px;background-color:#000;border-radius:0 0 4px 4px;transform-origin:top left}.flag.up:before{bottom:-4px;left:0;transform:skewY(35deg)}.flag.up.sixteenth:after{bottom:-11px;left:0;transform:skewY(35deg)}.flag.down:before,.flag.down.sixteenth:after{border-radius:4px 4px 0 0;transform-origin:bottom right}.flag.down:before{top:-4px;right:0;transform:skewY(-35deg)}.flag.down.sixteenth:after{top:-11px;right:0;transform:skewY(-35deg)}.accidental{position:absolute;left:-12px;top:8px;font-size:18px}.note[data-stem=up]{transform:translate(-50%,-50%)}.note[data-stem=down]{transform:translate(-50%,-50%) rotate(180deg)}.note[data-stem=up] .accidental{left:-12px;top:0;transform:none}.note[data-stem=down] .accidental{left:12px;top:0;transform:rotate(180deg)}.chord-symbol{position:absolute;font-family:Times New Roman,serif;font-size:16px;font-weight:700;transform:translate(-50%);z-index:4;color:#333}.chord-controls{margin:10px 0;display:flex;gap:10px}.chord-btn{background-color:#4a6da7;color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer}.chord-btn:hover{background-color:#3a5d97}.chord-input-modal{position:absolute;background:#fff;border:1px solid #ccc;border-radius:4px;padding:15px;box-shadow:0 2px 10px #0000001a;z-index:10}.modal-header{font-weight:700;margin-bottom:10px}.chord-input-modal input{width:100%;padding:8px;margin-bottom:10px;border:1px solid #ddd;border-radius:4px}.modal-buttons{display:flex;justify-content:flex-end;gap:10px}.add-btn{background-color:#4caf50;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer}.cancel-btn{background-color:#f44336;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer}.key-signature-control{display:flex;align-items:center;margin-left:20px}.key-signature-control label{margin-right:10px}.key-signature-control select{padding:5px;border-radius:4px;border:1px solid #ccc}.note.key-signature-affected{color:#2196f3}.staff-container{border:1px solid #ddd;background:#fff;display:flex;position:relative;overflow:hidden}.tab-btn.active{background:#fff;border-bottom:2px solid #2196F3;color:#2196f3}.note-btn.active,.octave-btn.active{background:#2196f3}.extend-btn:hover{background:#4caf50e6}.scroll-btn:hover{background:#2196f3e6}.measure-bar{position:absolute;top:100px;width:1px;height:60px;background:#000;z-index:2}.ledger-lines-container{position:absolute;z-index:2;pointer-events:none}.ledger-line{position:absolute;height:1px;background-color:#000;z-index:2;width:20px}.ledger-line.above,.ledger-line.below{display:block;width:20px;opacity:1;visibility:visible}.note[data-duration=whole]+.ledger-lines-container{transform:none}.note[data-duration=whole]~.ledger-lines-container .ledger-line{width:24px;left:-12px}.ledger-lines-container.above,.ledger-lines-container.below{transform:none}.bass-clef-ledger-line{position:absolute;height:1px;background-color:#000;z-index:2;width:20px}.clef img[alt="Bass Clef"]{height:100px;width:auto;margin-top:10px;margin-left:0;transform:scale(.7)}.dotted-note-toggle{display:flex;gap:5px}.dotted-note-toggle button{padding:6px 12px;border:none;border-radius:4px;background:#4caf50;color:#fff;cursor:pointer}.dotted-note-toggle button.active{background:#2196f3}.dot{font-size:12px;margin-left:5px}.dotted-note-toggle{margin-top:5px}.dot-btn{display:flex;align-items:center;gap:5px;padding:6px 12px}.dot-symbol{font-size:18px;font-weight:700;line-height:1}.dot-btn.active{background:#2196f3;box-shadow:0 0 5px #2196f380}.dot{position:absolute;font-size:16px;font-weight:700;right:-10px;top:8px}.note[data-stem=up] .dot{right:-10px;top:8px}.note[data-stem=down] .dot{left:-10px;bottom:8px}.ledger-lines-container{position:absolute;z-index:2;pointer-events:none;width:24px}.ledger-line{position:absolute;height:1px;background-color:#000;z-index:2;width:24px}.ledger-lines-container.above,.ledger-lines-container.below{left:-12px;transform:none}.ledger-line.above,.ledger-line.below{display:block!important;opacity:1;visibility:visible}.ledger-line:nth-child(1){top:0}.ledger-line:nth-child(2){top:15px}.ledger-line:nth-child(3){top:30px}.ledger-line:nth-child(4){top:45px}.ledger-line:nth-child(5){top:60px}.note~.ledger-lines-container{transform:none!important}.note{z-index:3}.ledger-lines-container{z-index:2}.ledger-line{min-width:24px;left:0}.note{position:absolute;transform:translate(-50%,-50%);z-index:3;cursor:pointer;transition:all .2s;width:20px;height:40px}.note:hover{filter:brightness(.9)}.note:hover:after{content:"×";position:absolute;top:-15px;right:-15px;color:#f44336;font-size:16px;font-weight:700;opacity:.7;pointer-events:none}@media (hover: hover){.note:hover:after{content:"×";position:absolute;top:-15px;right:-15px;color:#f44336;font-size:16px;font-weight:700;opacity:.7;pointer-events:none}}.note.touch-active{opacity:.7}.note-controls-container{padding:10px;background:#f5f5f5;border-top:1px solid #ddd}.note-controls-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.control-section{margin-bottom:10px;padding:8px;border:1px solid #ddd;border-radius:8px;background-color:#f9f9f9}.control-section h4{margin-top:0;margin-bottom:5px;font-size:12px;text-align:center;border-bottom:1px solid #eee;padding-bottom:3px}.note-btn,.octave-btn{flex:0 0 auto;min-width:36px;height:36px;border:1px solid #ccc;border-radius:4px;background:#fff;font-size:16px;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.scrollable-buttons{display:flex;flex-wrap:wrap;justify-content:center;gap:5px;max-height:none;overflow:visible}.button-group{display:flex;gap:5px;justify-content:center}.button-group button{flex:1}.octave-section .scrollable-buttons{display:flex;flex-wrap:wrap;justify-content:space-between}.octave-btn{flex:0 0 calc(20% - 5px);margin:0}.note-btn.active,.octave-btn.active{background:#2196f3;color:#fff;border-color:#0d8aee;box-shadow:0 0 5px #2196f380}@media (max-width: 480px){.note-controls-grid{grid-template-columns:1fr 1fr}.note-btn,.octave-btn{min-width:32px;height:32px;font-size:14px}.octave-btn{min-width:25px}}.note-btn,.octave-btn{flex:0 0 auto;min-width:36px;height:36px;border:1px solid #ccc;border-radius:4px;background:#fff;color:#333;font-size:16px;font-weight:700;line-height:1;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;text-shadow:none;box-shadow:0 1px 3px #0000001a}.note-btn:not(.active),.octave-btn:not(.active){color:#333;background:#f7f7f7;border-color:#ddd}.note-btn.active,.octave-btn.active{background:#2196f3;color:#fff;border-color:#0d8aee;box-shadow:0 0 5px #2196f380;font-weight:700}.duration-section .note-btn{font-family:Times New Roman,serif;font-size:20px;font-weight:400}.accidental-section .note-btn{font-size:18px;font-weight:400}.octave-section .octave-btn{font-weight:700;font-size:16px}.saved-compositions-container{margin-top:20px;padding:15px;background:#fff;border:1px solid #ddd;border-radius:4px}.save-composition-form{display:flex;gap:10px;margin-bottom:10px}.save-btn{background-color:#4caf50;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer}.no-saved-compositions{text-align:center;color:#666}.saved-composition-list{display:flex;flex-direction:column;gap:10px}.saved-composition-item{display:flex;justify-content:space-between;align-items:center;padding:5px;background:#f9f9f9;border:1px solid #ddd;border-radius:4px}.composition-name{font-weight:700}.composition-date{font-size:12px;color:#666}.load-btn,.delete-btn{background-color:#f44336;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer}.saved-compositions-container{padding:15px;background:#f5f5f5}.save-composition-form{display:flex;gap:10px;margin-bottom:15px}.composition-name-input{flex:1;padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px}.save-btn{background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer;font-weight:700}.save-btn:hover{background-color:#45a049}.no-saved-compositions{text-align:center;padding:20px;color:#666;font-style:italic}.saved-composition-list{max-height:300px;overflow-y:auto}.saved-composition-item{display:flex;justify-content:space-between;align-items:center;padding:10px;border-bottom:1px solid #ddd;background:#fff;margin-bottom:5px;border-radius:4px}.composition-info{display:flex;flex-direction:column}.composition-name{font-weight:700;color:#333}.composition-date{font-size:12px;color:#777}.composition-actions{display:flex;gap:5px}.load-btn{background-color:#2196f3;color:#fff;border:none;border-radius:4px;padding:5px 10px;cursor:pointer}.delete-btn{background-color:#f44336;color:#fff;border:none;border-radius:4px;padding:5px 10px;cursor:pointer}.mobile-tabs{display:flex}.mobile-tabs .tab-btn{flex:1;padding:10px;text-align:center;background:#f0f0f0;border:none;border-bottom:2px solid transparent;cursor:pointer}.mobile-tabs .tab-btn.active{background:#fff;border-bottom:2px solid #2196F3;font-weight:700}.force-redraw{animation:flash .1s}@keyframes flash{0%{opacity:.9}to{opacity:1}}.edit-name-form{display:flex;gap:5px;margin-top:5px}.rename-input{flex:1;padding:4px 8px;border:1px solid #2196F3;border-radius:4px;font-size:14px}.save-rename-btn,.cancel-rename-btn{padding:4px 8px;border:none;border-radius:4px;cursor:pointer;font-size:12px}.save-rename-btn{background-color:#4caf50;color:#fff}.cancel-rename-btn{background-color:#f44336;color:#fff}.update-btn{background-color:#ff9800;color:#fff;border:none;border-radius:4px;padding:5px 10px;cursor:pointer;margin-left:5px}.import-export-controls{display:flex;gap:10px;margin-top:15px;margin-bottom:15px;justify-content:center}.export-btn,.import-btn{background-color:#3f51b5;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer;font-size:14px;display:inline-block;text-align:center}.export-btn:hover,.import-btn:hover{background-color:#303f9f}.export-btn:disabled{background-color:#9e9e9e;cursor:not-allowed}.action-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border:none;border-radius:4px;background:#4caf50;color:#fff;cursor:pointer;transition:all .2s}.action-btn:hover{background-color:#45a049}.btn-icon{font-size:18px;font-weight:700}.btn-text{font-size:14px;font-weight:400}.btn-disabled{background-color:#9e9e9e;cursor:not-allowed}.custom-select{position:relative;display:inline-block}.select-icon{position:absolute;top:50%;right:10px;transform:translateY(-50%);pointer-events:none;color:#999}.select-icon:after{content:"▼";position:absolute;top:50%;right:10px;transform:translateY(-50%);pointer-events:none;color:#999}.select-icon:before{content:"▲";position:absolute;top:50%;right:10px;transform:translateY(-50%);pointer-events:none;color:#999}.select-icon:after,.select-icon:before{font-size:12px;line-height:1;pointer-events:none}.time-signature-selector{margin-top:10px;display:flex;align-items:center;gap:10px}.time-signature-selector label{font-weight:500;white-space:nowrap}.custom-select select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border:1px solid #ccc;border-radius:6px;padding:8px 30px 8px 10px;width:100%;font-size:15px;cursor:pointer;outline:none;transition:all .2s ease}.custom-select select:hover{border-color:#2196f3}.custom-select select:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.custom-select .select-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none;font-size:10px;color:#666}.custom-select select option{padding:10px;font-size:15px}@media (max-width: 600px){.custom-select{min-width:100px}.custom-select select{padding:6px 25px 6px 8px;font-size:14px}}.time-signature-display{position:absolute;top:100px;left:70px;display:flex;gap:5px;z-index:5}.time-signature-display .time-signature-numerator{font-size:16px;font-weight:700}.time-signature-display .time-signature-denominator{font-size:14px;color:#666}.barline-single,.barline-double,.barline-final,.barline-repeat-start,.barline-repeat-end{top:100px;height:60px}.repeat-dots{position:absolute;top:100px;left:70px;display:flex;gap:5px;z-index:5}.beat-marker{position:absolute;top:100px;width:1px;height:60px;background:#000;z-index:2}.barline-single{width:1px}.barline-double:before{content:"";position:absolute;left:0;top:0;width:1px;height:100%;background-color:#000}.barline-double:after{content:"";position:absolute;right:0;top:0;width:1px;height:100%;background-color:#000}.barline-final{width:6px;position:relative}.barline-final:before{content:"";position:absolute;left:0;top:0;width:1px;height:100%;background-color:#000}.barline-final:after{content:"";position:absolute;right:0;top:0;width:3px;height:100%;background-color:#000}.barline-repeat-start,.barline-repeat-end{width:10px;position:relative}.barline-repeat-start:before,.barline-repeat-end:before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background-color:#000}.barline-repeat-start:after,.barline-repeat-end:after{content:"";position:absolute;right:0;top:0;width:1px;height:100%;background-color:#000}.repeat-dots{position:absolute;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:10px}.time-signature-display{position:absolute;top:107px;display:flex;flex-direction:column;align-items:center;z-index:2}.time-signature-numerator,.time-signature-denominator{font-size:24px;font-weight:700;line-height:1}.time-signature-display{position:absolute;top:110px;left:70px;display:flex;flex-direction:column;align-items:center;z-index:3;width:20px;text-align:center}.time-signature-numerator,.time-signature-denominator{font-size:24px;font-weight:700;line-height:1;font-family:Times New Roman,serif}.time-signature-numerator{border-bottom:1px solid transparent;margin-bottom:2px}.key-signature{position:absolute;top:0;left:40px;height:100%;z-index:2}.key-signature-accidental{position:absolute;font-size:24px;line-height:0;transform:translate(-50%,-50%);font-family:Times New Roman,serif}.measure-number{position:absolute;top:-25px;left:-8px;font-size:12px;color:#666;font-weight:500}.measure-number[data-interval=true]{font-weight:700;color:#333}.playback-measure-controls{display:flex;flex-direction:column;gap:8px;margin-top:10px;padding:10px;background-color:#f5f5f5;border-radius:6px;border:1px solid #ddd}.control-label{font-weight:500;color:#333;margin-bottom:5px}.measure-range-inputs{display:flex;gap:15px;align-items:center}.auto-scroll-toggle{display:flex;align-items:center;gap:5px;margin-top:5px}.auto-scroll-toggle input[type=checkbox]{margin:0}@media (min-width: 768px){.playback-measure-controls{flex-direction:row;align-items:center;gap:20px}.control-label{margin-bottom:0;white-space:nowrap}.auto-scroll-toggle{margin-top:0;margin-left:auto}}.measure-visibility-toggle{display:flex;align-items:center;gap:5px;margin-top:10px;margin-bottom:10px}.measure-visibility-toggle input[type=checkbox]{margin:0}.measure-visibility-toggle label{font-size:14px;color:#333}.pause-button{background-color:#ff9800;color:#fff}.pause-button:hover:not(:disabled){background-color:#f57c00;transform:translateY(-2px)}.resume-button{background-color:#2196f3;color:#fff}.resume-button:hover:not(:disabled){background-color:#1976d2;transform:translateY(-2px)}.restart-button{background-color:#2196f3;color:#fff}.restart-button:hover:not(:disabled){background-color:#1976d2;transform:translateY(-2px)}.note-icon{width:20px;height:20px;display:inline-block;vertical-align:middle}.note-btn{display:flex;align-items:center;justify-content:center;min-width:40px;min-height:40px}.barline{position:absolute;top:100px;width:1px;height:60px;background-color:#000;z-index:2}.barline-double{width:5px;position:relative}.barline-double:before,.barline-double:after,.barline-final:before,.barline-final:after,.barline-repeat-start:before,.barline-repeat-start:after,.barline-repeat-end:before,.barline-repeat-end:after{top:0;height:100%}.lyrics-control-section{margin-top:15px;padding:10px;background-color:#f0f7ff;border:1px solid #cce5ff;border-radius:6px}.lyrics-input-container{display:flex;gap:10px;margin-bottom:8px}.lyric-input{flex:1;padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.add-lyric-btn{background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:8px 12px;cursor:pointer;font-weight:700}.add-lyric-btn:disabled{background-color:#ccc;cursor:not-allowed}.lyrics-help-text{font-size:12px;color:#666;font-style:italic;margin-top:5px}.lyric{position:absolute;left:50%;transform:translate(-50%);font-size:14px;color:#333;font-family:Times New Roman,serif;white-space:nowrap;text-align:center;pointer-events:none;line-height:1.2}.lyric.playing{color:#f44336;font-weight:700}.note{margin-bottom:0}.key-signature-selector{display:flex;align-items:center;margin-left:15px}.key-signature-selector label{margin-right:5px;font-weight:700}.key-signature-selector .custom-select{position:relative;display:inline-block}.key-signature-selector .custom-select select{padding:8px 25px 8px 10px;border:1px solid #ccc;border-radius:4px;background-color:#fff;cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none;min-width:120px}.key-signature-selector .custom-select .select-icon{position:absolute;top:50%;right:10px;transform:translateY(-50%);pointer-events:none}@media (max-width: 768px){.key-signature-selector{margin-left:10px;margin-top:5px}.key-signature-selector .custom-select select{min-width:100px;padding:6px 20px 6px 8px}}.note.selected{outline:2px solid #2196F3;outline-offset:3px;border-radius:50%;box-shadow:0 0 8px #2196f380}.note.rest.selected{outline:2px solid #2196F3;outline-offset:3px;border-radius:4px;box-shadow:0 0 8px #2196f380}.help-button-container{position:absolute;top:10px;right:10px;z-index:100}.help-button{display:flex;align-items:center;gap:8px;background-color:#2196f3;color:#fff;border:none;border-radius:50px;padding:8px 15px;cursor:pointer;font-weight:700;box-shadow:0 2px 5px #0003;transition:all .2s ease}.help-button:hover{background-color:#1976d2;transform:translateY(-2px)}.help-icon{font-size:18px;width:20px;height:20px;border-radius:50%;background:#fff;color:#2196f3;display:flex;align-items:center;justify-content:center;line-height:1}.help-text{font-size:14px}@media (max-width: 600px){.help-button{padding:6px;border-radius:50%}.help-text{display:none}}.logo-container{display:flex;align-items:center;justify-content:center;margin-bottom:15px;padding:10px;background:linear-gradient(135deg,#fff0f54d,#f0f8ff4d);border-radius:8px}.app-logo{max-width:120px;height:auto}@media (min-width: 768px){.logo-container{padding:12px}.app-logo{max-width:140px}}@media (max-width: 480px){.logo-container{padding:8px;margin-bottom:10px}.app-logo{max-width:100px}}.app-header{display:flex;align-items:center;justify-content:space-between;padding:8px;background:linear-gradient(135deg,#fff0f533,#f0f8ff33);border-radius:8px;margin-bottom:10px}.app-logo{height:45px;width:auto;margin-right:10px}.musical-settings{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.setting-item{display:flex;align-items:center;gap:5px}.tempo-container{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:8px;background-color:#f8f8f8;border-radius:8px}.tempo-slider{flex:1;min-width:120px}.playback-controls-container{margin:10px 0;display:flex;justify-content:center}.playback-controls{display:flex;gap:8px;justify-content:center;background-color:#f8f8f8cc;padding:8px;border-radius:8px;box-shadow:0 2px 5px #0000001a;z-index:50}@media (max-width: 600px){.app-header{flex-direction:column;align-items:center;gap:10px}.app-logo{margin-right:0;margin-bottom:8px}.musical-settings{justify-content:center;width:100%}.setting-item{min-width:45%;justify-content:center}.tempo-container{flex-direction:column;align-items:stretch}.tempo-container label{text-align:center;margin-bottom:5px}}.playback-settings{margin:10px 0 15px;padding:10px;background-color:#f5f5f5;border-radius:8px;border:1px solid #ddd}.playback-range{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px}.control-label{font-weight:500;color:#333;min-width:120px}.measure-range-inputs{display:flex;flex-wrap:wrap;gap:15px;align-items:center}.measure-input{display:flex;align-items:center;gap:5px}.measure-number-input{width:60px;padding:5px;border:1px solid #ccc;border-radius:4px;text-align:center}.measure-hint{font-size:12px;color:#666;font-style:italic}.playback-options{display:flex;flex-wrap:wrap;gap:20px}.auto-scroll-toggle,.measure-visibility-toggle{display:flex;align-items:center;gap:5px}@media (max-width: 600px){.playback-range{flex-direction:column;align-items:flex-start}.measure-range-inputs{width:100%}.playback-options{flex-direction:column;gap:10px}}.app-logo{height:100px;width:auto;margin-right:15px}@media (max-width: 600px){.app-header{flex-direction:column;align-items:center;gap:15px}.app-logo{height:100px;margin-right:0;margin-bottom:10px}}.toggle-debug-btn{display:none!important}.voice-layers-container{margin:15px 0;padding:10px;background-color:#f5f5f5;border-radius:8px}.voice-layers{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.voice-layer{background-color:#fff;border-radius:6px;padding:8px;box-shadow:0 1px 3px #0000001a;transition:all .2s ease}.voice-layer.active{box-shadow:0 2px 8px #0003;transform:translateY(-2px)}.voice-header{display:flex;align-items:center;border-left:4px solid;padding-left:8px}.voice-controls{display:flex;gap:5px;margin-right:10px}.voice-visibility-btn,.voice-select-btn{background:none;border:1px solid #ddd;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:14px}.voice-visibility-btn.visible{background-color:#e3f2fd}.voice-select-btn.active{background-color:#e8f5e9}.voice-name{flex-grow:1;font-weight:700;font-size:14px}.voice-playback-selection{display:flex;align-items:center;gap:5px}.voice-note-count{font-size:12px;color:#666;margin-top:5px;text-align:right}.voice-playback-options{margin-top:10px;padding-top:10px;border-top:1px solid #ddd}.playback-option{display:flex;align-items:center;gap:8px}.add-voice-container{margin-top:10px;text-align:center}.add-voice-btn{background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:8px 16px;cursor:pointer;font-size:14px;transition:background-color .2s}.add-voice-btn:hover{background-color:#388e3c}.mobile-tabs{display:flex;margin:10px 0;width:100%}.tab-btn{flex:1;padding:10px 5px;background:#f0f0f0;border:none;border-bottom:2px solid #ddd;font-weight:700;font-size:14px;white-space:nowrap;cursor:pointer;transition:background-color .2s,border-color .2s}.tab-btn.active{background:#e0e0e0;border-bottom-color:#2196f3}.tab-btn:hover:not(.active){background:#e9e9e9}.note .notehead.quarter,.note .notehead.eighth,.note .notehead.sixteenth{background-color:currentColor;border-color:currentColor}.note .stem,.note .flag{background-color:currentColor}.note .notehead.whole,.note .notehead.half{background-color:#fff;border:1px solid currentColor}.note .accidental-display,.note .dot{color:currentColor}.staves-container{display:flex;flex-direction:column;gap:40px;margin:10px 0;width:100%}.staff-wrapper{position:relative;width:100%}.staff-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.staff-title{font-weight:700;font-size:14px;color:#333}.staff-actions{display:flex;gap:5px}.staff-action-btn{background-color:#f0f0f0;border:1px solid #ddd;border-radius:4px;padding:3px 8px;font-size:12px;cursor:pointer;transition:background-color .2s}.staff-action-btn:hover{background-color:#e0e0e0}.staff-action-btn.remove{color:#f44336}.staff-connector{position:absolute;left:40px;width:3px;background-color:#000;z-index:10}.staff-connector-top{top:-20px;height:20px}.staff-connector-bottom{bottom:-20px;height:20px}.staff-container-multi{border:1px solid #ddd;background:#fff;margin:0;display:flex;height:300px;position:relative;overflow:hidden;padding-bottom:20px}.add-staff-button{display:block;width:100%;padding:10px;margin:10px 0;background-color:#4caf50;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s}.add-staff-button:hover{background-color:#45a049}.bracket-connector{position:absolute;left:20px;width:8px;border-left:3px solid #000;border-top:3px solid #000;border-bottom:3px solid #000;z-index:9}.staves-wrapper{display:flex;flex-direction:column;gap:20px;margin:10px 0;width:100%}.staff-outer-container{border:1px solid #ccc;border-radius:4px;padding:10px;background-color:#fdfdfd}.staff-header-controls{display:flex;align-items:center;gap:10px;margin-bottom:10px}.staff-header-controls .staff-name{font-weight:700;flex-grow:1}.remove-staff-btn{padding:5px 10px;background-color:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer}.remove-staff-btn:hover{background-color:#d32f2f}.add-staff-controls{margin-bottom:15px;text-align:center}.add-staff-btn{padding:10px 20px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1em}.add-staff-btn:hover{background-color:#45a049}.staff-scroll-controls-global{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:10px;padding:10px;background-color:#f0f0f0e6;border-radius:8px;position:sticky;bottom:10px;z-index:100}.staff-scroll-controls-global .scroll-btn,.staff-scroll-controls-global .extend-btn{background-color:#2196f3;color:#fff;border:none;border-radius:4px;padding:8px 12px;cursor:pointer}.staff-scroll-controls-global .extend-btn{background-color:#4caf50}.staff-scroll-controls-global .scroll-btn:disabled{background-color:#ccc;cursor:not-allowed}.staff-scroll-container{flex:1;position:relative;overflow-x:hidden;width:100%}.staff{position:relative;padding-top:0;transition:transform .1s ease-out;min-width:100%;cursor:grab;display:block}.note-btn,.octave-btn,.chord-btn,.extend-btn{padding:8px;border:none;border-radius:4px;background:#4caf50;color:#fff;cursor:pointer;white-space:nowrap;font-size:14px;min-width:40px;text-align:center}@media (max-width: 600px){.custom-select{min-width:100px}.custom-select select{padding:6px 25px 6px 8px;font-size:14px}.clef{width:45px;margin-top:67px}.clef img{height:110px;margin-top:30px;margin-left:3px}}.floating-help-btn{position:fixed;top:20px;right:20px;width:50px;height:50px;background-color:#2196f3;color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:24px;font-weight:700;cursor:pointer;box-shadow:0 4px 8px #0003;z-index:999;transition:background-color .3s ease,transform .2s ease-out}.floating-help-btn:hover{background-color:#1976d2;transform:scale(1.05)}@media (max-width: 768px){.floating-help-btn{top:15px;right:15px;width:45px;height:45px;font-size:20px}}@media (max-width: 480px){.floating-help-btn{top:10px;right:10px;width:40px;height:40px;font-size:18px}}.section-markers{position:relative;z-index:5}.section-marker{position:absolute;padding:3px 6px;background-color:#9c27b0cc;color:#fff;border-radius:4px;font-size:12px;font-weight:700;z-index:10;pointer-events:none}.section-start{transform:translate(-100%)}.section-end{transform:translate(0)}.section-background{position:absolute;top:0;height:100%;background-color:#9c27b0;opacity:.1;pointer-events:none;z-index:1}.playing-section .section-marker{background-color:#f44336;animation:pulse 1s infinite alternate}.playing-section .section-background{background-color:#f4433633;opacity:.3!important}@keyframes pulse{0%{opacity:.8}to{opacity:1}}.section-markers-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5}.staff-name-input{font-weight:700;flex-grow:1;padding:2px 5px;border:1px solid #ccc;border-radius:3px;font-size:inherit}.staff-name[title="Click to rename staff"]{cursor:pointer;border-bottom:1px dashed #ccc}.staff-header-controls select{padding:5px;border-radius:4px;border:1px solid #ccc}.collapse-staff-btn{padding:5px 10px;background-color:#607d8b;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9em}.collapse-staff-btn:hover{background-color:#546e7a}.remove-staff-btn{padding:5px 10px;background-color:#f44336}.read-only-toggle{display:flex;align-items:center;justify-content:center;margin:10px 0;gap:10px;padding:8px;background-color:#f8f8f8;border-radius:8px;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:100}.toggle-switch{position:relative;display:inline-block;width:46px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.toggle-slider{background-color:#f44336}input:checked+.toggle-slider:before{transform:translate(22px)}.toggle-label{font-size:14px;font-weight:500}.read-only-mode .staff-container{border:2px solid rgba(244,67,54,.3);box-shadow:inset 0 0 5px #f4433633}.read-only-mode .staff{cursor:default}.read-only-mode .note-btn,.read-only-mode .octave-btn,.read-only-mode .add-staff-btn,.read-only-mode .add-voice-btn,.read-only-mode .remove-staff-btn{opacity:.6;pointer-events:none}.read-only-mode .read-only-toggle{background-color:#f443361a;border:1px solid rgba(244,67,54,.3)}.read-only-mode .toggle-label{color:#f44336;font-weight:700}.read-only-mode .note-btn,.read-only-mode .octave-btn,.read-only-mode .add-staff-btn,.read-only-mode .add-voice-btn,.read-only-mode .remove-staff-btn,.read-only-mode .staff-header-controls select .read-only-mode .lyrics-control-section,.read-only-mode .section-add-controls,.read-only-mode .section-delete-btn,.read-only-mode .sequence-edit-controls,.read-only-mode .saved-composition-update-btn{display:none!important}.read-only-mode .active-tab-section{background-color:#f443361a;font-style:italic}.read-only-toggle{position:sticky;top:10px;z-index:50;margin:10px auto;max-width:250px}.tab-btn.disabled{opacity:.7;font-style:italic}.read-only-mode .note-btn,.read-only-mode .octave-btn,.read-only-mode .add-staff-btn,.read-only-mode .add-voice-btn,.read-only-mode .remove-staff-btn,.read-only-mode .staff-header-controls select,.read-only-mode .lyrics-control-section,.read-only-mode .section-add-controls,.read-only-mode .section-delete-btn,.read-only-mode .sequence-edit-controls,.read-only-mode .saved-composition-update-btn{display:none!important}.read-only-mode .add-section-form,.read-only-mode .section-delete-button,.read-only-mode .section-item-delete-btn,.read-only-mode .sequence-item-delete-btn,.read-only-mode .add-to-sequence-form,.read-only-mode .sequence-clear-btn,.read-only-mode .sections-clear-btn,.read-only-mode .sequence-item-controls button:not(.play-sequence-btn){display:none!important}.read-only-mode .play-section-btn,.read-only-mode .play-sequence-btn,.read-only-mode .jump-to-section-btn{opacity:1;pointer-events:auto;display:inline-block!important}.read-only-message-container{padding:10px;background-color:#f8f8f8;border:1px solid #ccc;border-radius:5px;margin-bottom:10px}.read-only-message{color:#333;font-style:italic}.read-only-detail{color:#666;font-size:.9em}.lock-icon{margin-right:5px}.read-only-message-container{padding:20px;display:flex;justify-content:center;align-items:center}.read-only-message{background-color:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:4px;padding:16px;color:#d32f2f;font-size:16px;font-weight:500;text-align:center;width:100%;max-width:500px}.lock-icon{margin-right:8px;font-size:18px}.read-only-detail{font-size:14px;color:#666;margin-top:8px}.read-only-mode .section-form,.read-only-mode .delete-section-btn,.read-only-mode .add-to-sequence-btn,.read-only-mode .remove-from-sequence-btn,.read-only-mode .clear-sequence-btn,.read-only-mode .voice-name-input,.read-only-mode .voice-color-picker,.read-only-mode .add-voice-section,.read-only-mode .delete-voice-btn,.read-only-mode .staff-select,.read-only-mode .voice-staff-assignment,.read-only-mode .is-active-btn{display:none!important}.read-only-mode .volume-slider{opacity:.8}.read-only-mode .voice-controls .control-btn.icon-btn:nth-child(1),.read-only-mode .voice-controls .control-btn.icon-btn:nth-child(2){opacity:1;pointer-events:auto}.read-only-mode .section-form,.read-only-mode .delete-section-btn,.read-only-mode .add-to-sequence-btn,.read-only-mode .remove-from-sequence-btn,.read-only-mode .clear-sequence-btn{display:none!important}.read-only-mode .delete-section-btn,.read-only-mode .add-to-sequence-btn,.read-only-mode .remove-from-sequence-btn,.read-only-mode .clear-sequence-btn,.read-only-mode .add-section-btn,.read-only-mode .section-form,.read-only-mode .saved-compositions-panel .update-btn,.read-only-mode button[title="Update current composition"],.read-only-mode button.update-composition-btn,.read-only-mode .add-staff-controls,.read-only-mode .add-staff-btn,.read-only-mode button[title*="Add New Staff"]{display:none!important;visibility:hidden!important;pointer-events:none!important;opacity:0!important}.read-only-mode .key-signature-select,.read-only-mode .time-signature-select,.read-only-mode select[title*="key signature"],.read-only-mode select[title*="time signature"],.read-only-mode .app-header select,.read-only-mode .app-header button:not(.help-button){pointer-events:none!important;opacity:.7!important;cursor:not-allowed!important;background-color:#f5f5f5!important}.read-only-mode .app-header:after{content:"🔒 Read-only mode active";display:block;text-align:center;color:#d32f2f;font-size:12px;font-style:italic;padding:3px 0;background-color:#f443361a;border-radius:4px;margin-top:5px}.read-only-mode button:not(.toggle-playback):not(.play-section-btn):not(.play-sequence-btn):not(.jump-to-section-btn):not(.help-button){display:none!important}.read-only-mode button.add-staff-btn,.read-only-mode div.add-staff-controls,.read-only-mode button:contains("Add New Staff"){display:none!important;visibility:hidden!important;opacity:0!important;position:absolute!important;z-index:-9999!important;pointer-events:none!important;height:0!important;width:0!important;overflow:hidden!important}.space-insertion-controls{display:flex;align-items:center;gap:10px;margin:10px 0;padding:10px;background-color:#f5f5f5;border-radius:4px}.insert-space-btn{padding:8px 16px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.insert-space-btn.active{background-color:#f44336}.insert-space-btn:hover{opacity:.9}.space-width-control{display:flex;align-items:center;gap:8px}.space-width-control input{width:60px;padding:4px;border:1px solid #ccc;border-radius:4px}.staff.inserting-space{cursor:col-resize}.staff.inserting-space:after{content:"";position:absolute;top:0;bottom:0;width:2px;background-color:#4caf50;pointer-events:none;transform:translate(-50%)}.space-controls{display:flex;flex-direction:column;gap:10px;margin:10px 0}.delete-space-btn{padding:8px 16px;background-color:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.delete-space-btn.active{background-color:#d32f2f}.delete-space-btn:hover{opacity:.9}.staff.deleting-space{cursor:col-resize}.staff.deleting-space:after{content:"";position:absolute;top:0;bottom:0;width:2px;background-color:#f44336;pointer-events:none;transform:translate(-50%)}.space-insertion-controls{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:10px;background-color:#f5f5f5;border-radius:4px}.select-range-btn{padding:8px 16px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.select-range-btn.active{background-color:#1976d2}.copy-btn{padding:8px 16px;background-color:#9c27b0;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.copy-btn:disabled{opacity:.5;cursor:not-allowed}.copy-info{padding:4px 8px;background-color:#f0f0f0;border-radius:4px;font-size:.9em}.staff.selecting-range{cursor:copy}.selection-highlight{position:absolute;top:0;height:100%;background-color:#2196f333;pointer-events:none;z-index:1}.cancel-paste-btn{padding:8px 16px;background-color:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.cancel-paste-btn:hover{opacity:.9}.paste-info{padding:4px 8px;background-color:#f0f0f0;border-radius:4px;font-size:.9em;color:#2196f3}.staff.pasting{cursor:cell}.copy-lyrics-btn{padding:8px 16px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.copy-controls{display:flex;gap:8px}.copy-lyrics-btn{padding:8px 16px;background-color:#009688;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s}.copy-lyrics-btn:hover{opacity:.9}.paste-info{padding:4px 8px;background-color:#f0f0f0;border-radius:4px;font-size:.9em;color:#2196f3;font-style:italic}.lyrics-control-section.draggable{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.lyrics-control-section.draggable .lyric-input{user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.note,.rest,.accidental,.clef,.time-signature,.key-signature{font-family:Noto Music,Noto Sans Symbols,Times New Roman,serif;font-feature-settings:"liga" 1,"dlig" 1;text-rendering:optimizeLegibility}.control-btn.icon-btn{font-family:"Noto Color Emoji","Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,Noto Sans Symbols,sans-serif;font-feature-settings:"liga" 1,"dlig" 1;text-rendering:optimizeLegibility}.device-ios .control-btn.icon-btn{font-family:"Apple Color Emoji","Noto Color Emoji",sans-serif}.device-android .control-btn.icon-btn{font-family:"Noto Color Emoji","Android Emoji",sans-serif}.browser-safari .control-btn.icon-btn{font-family:"Apple Color Emoji","Noto Color Emoji",sans-serif}.browser-chrome .control-btn.icon-btn{font-family:"Noto Color Emoji","Segoe UI Emoji",sans-serif}.browser-firefox .control-btn.icon-btn{font-family:"Noto Color Emoji",Twemoji Mozilla,sans-serif}.control-btn.icon-btn{min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;font-size:1.1em;line-height:1}.musical-symbol{font-family:Noto Music,Noto Sans Symbols,Times New Roman,serif;font-feature-settings:"liga" 1,"dlig" 1;text-rendering:optimizeLegibility}.fallback-text{font-family:Arial,Helvetica,sans-serif;font-weight:700;text-align:center;line-height:1}.control-btn.icon-btn .fallback-text{color:inherit;background:transparent}.help-overlay[data-v-413fab88]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;overflow:hidden}.help-container[data-v-413fab88]{background-color:#fff;border-radius:8px;width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 5px 20px #0000004d;animation:fadeIn-413fab88 .3s ease-out}@keyframes fadeIn-413fab88{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.help-header[data-v-413fab88]{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #eee}.help-header h1[data-v-413fab88]{margin:0;font-size:24px;color:#2196f3}.close-button[data-v-413fab88]{background:none;border:none;font-size:28px;cursor:pointer;color:#666;transition:color .2s}.close-button[data-v-413fab88]:hover{color:#f44336}.help-content[data-v-413fab88]{flex:1;overflow:hidden;display:flex;flex-direction:column}.help-tabs-container[data-v-413fab88]{position:relative;background-color:#f5f5f5;border-bottom:1px solid #ddd;overflow:hidden;flex-shrink:0}.help-tabs-scroll[data-v-413fab88]{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:0 5px;touch-action:pan-x;min-height:45px;align-items:center}.help-tabs-scroll[data-v-413fab88]::-webkit-scrollbar{display:none}.tab-item[data-v-413fab88]{padding:10px 16px;white-space:nowrap;cursor:pointer;color:#555;font-weight:500;font-size:14px;border:none;border-bottom:3px solid transparent;background-color:transparent;flex-shrink:0;text-align:center;transition:color .2s,border-color .2s,background-color .2s;position:relative;line-height:1.4}.tab-item[data-v-413fab88]:not(:last-child):after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);height:24px;width:1px;background-color:#ddd}.tab-item[data-v-413fab88]:hover{color:#2196f3;background-color:#2196f30d}.tab-item.active[data-v-413fab88]{color:#2196f3;border-bottom-color:#2196f3;font-weight:600}.tab-content[data-v-413fab88]{flex:1;overflow-y:auto;padding:20px}.tab-pane[data-v-413fab88]{animation:fadeIn-413fab88 .3s ease-out}.tab-pane h2[data-v-413fab88]{margin-top:0;color:#333;border-bottom:1px solid #eee;padding-bottom:10px}.help-section[data-v-413fab88]{margin-bottom:25px}.help-section h3[data-v-413fab88]{color:#2196f3;margin-bottom:10px}.help-section ul[data-v-413fab88],.help-section ol[data-v-413fab88]{padding-left:25px;margin-bottom:15px}.help-section li[data-v-413fab88]{margin-bottom:8px;line-height:1.5}.help-tip[data-v-413fab88]{background-color:#e3f2fd;border-left:4px solid #2196F3;padding:10px 15px;margin-top:10px;border-radius:4px}.help-footer[data-v-413fab88]{padding:15px 20px;border-top:1px solid #eee;text-align:right}.close-help-button[data-v-413fab88]{background-color:#2196f3;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s}.close-help-button[data-v-413fab88]:hover{background-color:#1976d2}@media (max-width: 768px){.help-container[data-v-413fab88]{width:95%;max-height:95vh}.help-header h1[data-v-413fab88]{font-size:20px}.help-tabs-scroll[data-v-413fab88]{min-height:42px}.tab-item[data-v-413fab88]{padding:8px 14px;font-size:13px}.tab-item[data-v-413fab88]:not(:last-child):after{height:20px}}@media (max-width: 480px){.help-container[data-v-413fab88]{width:95%;max-height:95vh}.help-header h1[data-v-413fab88]{font-size:18px}.help-tabs-scroll[data-v-413fab88]{min-height:40px}.tab-item[data-v-413fab88]{padding:8px 12px;font-size:12px}.tab-item[data-v-413fab88]:not(:last-child):after{height:18px}}.help-tabs-container[data-v-413fab88]:before,.help-tabs-container[data-v-413fab88]:after{content:"";position:absolute;top:0;bottom:0;width:35px;pointer-events:none;z-index:2;opacity:0;transition:opacity .2s ease-in-out}.help-tabs-container[data-v-413fab88]:before{left:0;background:linear-gradient(to right,#f5f5f5 20%,transparent)}.help-tabs-container[data-v-413fab88]:after{right:0;background:linear-gradient(to left,#f5f5f5 20%,transparent)}.help-tabs-container.scrollable-left[data-v-413fab88]:before{opacity:1}.help-tabs-container.scrollable-right[data-v-413fab88]:after{opacity:1}.user-menu[data-v-5359f3e3]{position:relative;z-index:1000}.avatar[data-v-5359f3e3]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:20px;background:#ffffff1a;transition:background-color .2s}.avatar[data-v-5359f3e3]:hover{background:#fff3}.avatar-image[data-v-5359f3e3]{width:32px;height:32px;border-radius:50%;object-fit:cover}.avatar-initials[data-v-5359f3e3]{width:32px;height:32px;border-radius:50%;background:#2196f3;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.user-name[data-v-5359f3e3]{color:#333;font-size:14px;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-dropdown[data-v-5359f3e3]{position:fixed;min-width:200px;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;z-index:1000}.menu-items[data-v-5359f3e3]{padding:8px 0}.menu-item[data-v-5359f3e3]{display:flex;align-items:center;gap:8px;width:100%;padding:8px 16px;border:none;background:none;color:#333;font-size:14px;text-align:left;cursor:pointer;transition:background-color .2s}.menu-item[data-v-5359f3e3]:hover{background:#f5f5f5}.menu-item i[data-v-5359f3e3]{width:16px;color:#666}.menu-divider[data-v-5359f3e3]{height:1px;background:#eee;margin:8px 0}.logout[data-v-5359f3e3],.logout i[data-v-5359f3e3]{color:#dc3545}.is-mobile .avatar[data-v-5359f3e3]{padding:4px}.is-mobile .user-name[data-v-5359f3e3]{display:none}.is-mobile .menu-dropdown[data-v-5359f3e3]{position:fixed;top:auto!important;bottom:0;left:0!important;right:0;width:100%;border-radius:16px 16px 0 0;box-shadow:0 -2px 10px #0000001a}.is-mobile .menu-items[data-v-5359f3e3]{padding:16px}.is-mobile .menu-item[data-v-5359f3e3]{padding:12px 16px;font-size:16px}@media (max-width: 768px){.user-menu:not(.is-mobile) .user-name[data-v-5359f3e3]{display:none}}.admin[data-v-5359f3e3]{color:#2196f3;text-decoration:none;display:flex;align-items:center;gap:8px}.admin[data-v-5359f3e3]:hover{background-color:#e3f2fd}.navbar[data-v-79f30bba]{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background-color:#fff;box-shadow:0 2px 4px #0000001a}.nav-brand[data-v-79f30bba]{display:flex;align-items:center;gap:.5rem}.nav-logo[data-v-79f30bba]{height:32px;width:auto}.nav-title[data-v-79f30bba]{font-size:1.25rem;font-weight:500;color:#2c3e50}.nav-auth[data-v-79f30bba]{display:flex;align-items:center}.google-signin-btn[data-v-79f30bba]{display:flex;align-items:center;gap:8px;padding:8px 16px;background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;color:#333;transition:background-color .2s}.google-signin-btn[data-v-79f30bba]:hover{background-color:#f8f9fa}.google-icon[data-v-79f30bba]{width:18px;height:18px}.signin-container[data-v-79f30bba]{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.error-message[data-v-79f30bba]{color:#dc3545;font-size:12px;margin:0;max-width:250px;text-align:right}@media (max-width: 768px){.nav-title[data-v-79f30bba]{display:none}.nav-logo[data-v-79f30bba]{height:28px}.google-signin-btn[data-v-79f30bba]{padding:6px 12px}}.app-header[data-v-f098c157]{display:flex;flex-direction:column;gap:1rem;padding:8px;background:linear-gradient(135deg,#fff0f533,#f0f8ff33);border-radius:8px;margin-bottom:10px}.header-main[data-v-f098c157]{display:flex;align-items:center;justify-content:space-between;width:100%}.composition-title[data-v-f098c157]{text-align:center;font-size:1.2em;font-weight:700;color:#333;margin:8px 0;padding:4px 8px;background:#fffc;border-radius:4px;border:1px solid rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center;gap:8px}.quick-save-btn[data-v-f098c157],.share-btn[data-v-f098c157],.reset-btn[data-v-f098c157]{background:#4caf50;color:#fff;border:none;border-radius:4px;padding:6px 8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.quick-save-btn[data-v-f098c157]:hover,.share-btn[data-v-f098c157]:hover,.reset-btn[data-v-f098c157]:hover{background:#45a049}.share-btn[data-v-f098c157]{background:#2196f3}.share-btn[data-v-f098c157]:hover{background:#1976d2}.reset-btn[data-v-f098c157]{background:#ff9800}.reset-btn[data-v-f098c157]:hover{background:#f57c00}.quick-save-btn[data-v-f098c157]{align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.quick-save-btn[data-v-f098c157]:hover{background:#45a049;transform:translateY(-1px);box-shadow:0 3px 6px #00000026}.quick-save-btn[data-v-f098c157]:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.quick-save-btn[data-v-f098c157]:disabled{opacity:.6;cursor:not-allowed;transform:none}.quick-save-btn[data-v-f098c157]:disabled:hover{background:#4caf50;transform:none;box-shadow:0 2px 4px #0000001a}.save-spinner[data-v-f098c157]{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin-f098c157 1s linear infinite}@keyframes spin-f098c157{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-logo[data-v-f098c157]{height:100px;width:auto}.musical-settings[data-v-f098c157]{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.setting-item[data-v-f098c157]{display:flex;align-items:center;gap:5px}.setting-item label[data-v-f098c157]{font-size:14px;white-space:nowrap}.custom-select[data-v-f098c157]{position:relative;min-width:120px}.custom-select.compact select[data-v-f098c157]{padding:6px 25px 6px 8px;font-size:14px}.custom-select select[data-v-f098c157]{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border:1px solid #ccc;border-radius:6px;padding:8px 30px 8px 10px;width:100%;font-size:15px;cursor:pointer;outline:none;transition:all .2s ease}.custom-select select[data-v-f098c157]:hover{border-color:#2196f3}.custom-select select[data-v-f098c157]:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.custom-select .select-icon[data-v-f098c157]{position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none;font-size:10px;color:#666}.tempo-input[data-v-f098c157]{display:flex;align-items:center;gap:4px}.tempo-input input[data-v-f098c157]{width:60px;padding:6px 8px;border:1px solid #ccc;border-radius:6px;font-size:14px;outline:none;transition:all .2s ease}.tempo-input input[data-v-f098c157]:hover{border-color:#2196f3}.tempo-input input[data-v-f098c157]:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.tempo-unit[data-v-f098c157]{font-size:14px;color:#666}@media (max-width: 600px){.header-main[data-v-f098c157]{flex-direction:column;align-items:center;gap:1rem}.app-logo[data-v-f098c157]{margin-bottom:0}.composition-title[data-v-f098c157]{font-size:1.1em;margin:4px 0}.musical-settings[data-v-f098c157]{justify-content:center;width:100%}.setting-item[data-v-f098c157]{min-width:45%;justify-content:center}.custom-select[data-v-f098c157]{min-width:100px}}.playback-controls-container[data-v-e2d56429]{margin:10px 0;display:flex;justify-content:center}.playback-controls[data-v-e2d56429]{display:flex;gap:8px;justify-content:center;background-color:#f8f8f8cc;padding:8px;border-radius:8px;box-shadow:0 2px 5px #0000001a}.action-button[data-v-e2d56429]{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 5px #00000026;position:relative;overflow:hidden}.action-button[data-v-e2d56429]:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.action-button[data-v-e2d56429]:after{content:"";position:absolute;top:50%;left:50%;width:120%;height:120%;background:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%) scale(0);opacity:0;transition:all .3s ease}.action-button[data-v-e2d56429]:active:not(:disabled):after{transform:translate(-50%,-50%) scale(1.5);opacity:1;transition:all .2s ease}.button-icon[data-v-e2d56429]{font-size:18px;line-height:1}.button-label[data-v-e2d56429]{font-weight:500}.play-button[data-v-e2d56429]{background-color:#4caf50;color:#fff}.play-button[data-v-e2d56429]:hover:not(:disabled){background-color:#45a049;transform:translateY(-2px)}.pause-button[data-v-e2d56429]{background-color:#ff9800;color:#fff}.pause-button[data-v-e2d56429]:hover:not(:disabled){background-color:#f57c00;transform:translateY(-2px)}.resume-button[data-v-e2d56429]{background-color:#2196f3;color:#fff}.resume-button[data-v-e2d56429]:hover:not(:disabled){background-color:#1976d2;transform:translateY(-2px)}.stop-button[data-v-e2d56429]{background-color:#f44336;color:#fff}.stop-button[data-v-e2d56429]:hover:not(:disabled){background-color:#e53935;transform:translateY(-2px)}.clear-button[data-v-e2d56429]{background-color:#757575;color:#fff}.clear-button[data-v-e2d56429]:hover:not(:disabled){background-color:#616161;transform:translateY(-2px)}.restart-button[data-v-e2d56429]{background-color:#2196f3;color:#fff}.restart-button[data-v-e2d56429]:hover:not(:disabled){background-color:#1976d2;transform:translateY(-2px)}.note-controls-container[data-v-d8b9788a]{background:#f5f5f5;border:1px solid #ddd;border-radius:4px;padding:10px;margin-bottom:10px;width:100%;box-sizing:border-box}.note-controls-grid[data-v-d8b9788a]{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;gap:12px;width:100%;height:100%;grid-template-areas:"duration type" "accidental octave"}.control-section[data-v-d8b9788a]{margin-bottom:0;padding:15px;border:1px solid #ddd;border-radius:8px;background-color:#f9f9f9;width:100%;box-sizing:border-box;display:flex;flex-direction:column;height:100%;min-height:140px}.duration-section[data-v-d8b9788a]{grid-area:duration}.type-section[data-v-d8b9788a]{grid-area:type}.accidental-section[data-v-d8b9788a]{grid-area:accidental}.octave-section[data-v-d8b9788a]{grid-area:octave}.control-section h4[data-v-d8b9788a]{margin-top:0;margin-bottom:12px;color:#333;font-size:14px;font-weight:600;text-align:center;border-bottom:1px solid #ddd;padding-bottom:8px}.scrollable-buttons[data-v-d8b9788a]{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;width:100%;flex:1;align-content:flex-start}.note-btn[data-v-d8b9788a],.octave-btn[data-v-d8b9788a]{flex:0 0 auto;min-width:48px;height:48px;border:2px solid #ddd;border-radius:8px;background:#fff;font-size:18px;line-height:1;padding:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#333;font-weight:500;box-shadow:0 2px 4px #0000001a}.note-btn[data-v-d8b9788a]:not(.active),.octave-btn[data-v-d8b9788a]:not(.active){color:#333;background:#f7f7f7;border-color:#ddd}.note-btn.active[data-v-d8b9788a],.octave-btn.active[data-v-d8b9788a]{background:#2196f3;color:#fff;border-color:#1976d2;box-shadow:0 4px 8px #2196f34d;font-weight:600;transform:translateY(-1px)}.note-modifiers[data-v-d8b9788a]{margin-top:12px;display:flex;justify-content:center;gap:12px;width:100%}.note-modifiers button[data-v-d8b9788a]{font-size:14px;flex:1;max-width:80px;height:36px;padding:8px 12px;border:2px solid #ddd;border-radius:6px;background:#fff;font-weight:500;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.note-modifiers button.active[data-v-d8b9788a]{background:#2196f3;color:#fff;border-color:#1976d2;transform:translateY(-1px)}.button-group[data-v-d8b9788a]{display:flex;gap:12px;width:100%;justify-content:center;flex:1;align-items:center}.button-group button[data-v-d8b9788a]{flex:1;height:50px;font-size:16px;font-weight:600;border:2px solid #ddd;border-radius:8px;background:#fff;transition:all .2s ease;box-shadow:0 2px 4px #0000001a;cursor:pointer;color:#333}.button-group button.active[data-v-d8b9788a]{background:#2196f3;color:#fff;border-color:#1976d2;transform:translateY(-1px);box-shadow:0 4px 8px #2196f34d}.duration-buttons-grid[data-v-d8b9788a]{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;margin-bottom:12px}.duration-btn[data-v-d8b9788a]{flex:0 0 auto;width:100%;height:50px;border:2px solid #ddd;border-radius:8px;background:#fff;font-size:16px;line-height:1;padding:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#333;font-weight:500;box-shadow:0 2px 4px #0000001a}.duration-btn.active[data-v-d8b9788a]{background:#2196f3;color:#fff;border-color:#1976d2;box-shadow:0 4px 8px #2196f34d;font-weight:600;transform:translateY(-1px)}.duration-section .note-btn[data-v-d8b9788a]{font-family:Times New Roman,serif;font-size:20px;font-weight:400}.accidental-section .note-btn[data-v-d8b9788a]{font-size:18px;font-weight:400}.octave-section .octave-btn[data-v-d8b9788a]{font-weight:700;font-size:16px}@media (min-width: 768px){.note-controls-grid[data-v-d8b9788a]{grid-template-columns:2fr 1fr;gap:20px}.control-section[data-v-d8b9788a]{min-height:160px}.duration-buttons-grid[data-v-d8b9788a]{grid-template-columns:repeat(5,1fr)}}@media (min-width: 1024px){.note-controls-container[data-v-d8b9788a]{padding:20px}.note-controls-grid[data-v-d8b9788a]{gap:25px}.control-section[data-v-d8b9788a]{padding:20px;min-height:180px}}@media (max-width: 767px){.note-controls-grid[data-v-d8b9788a]{grid-template-columns:1fr;grid-template-rows:auto auto auto auto;gap:15px;grid-template-areas:"duration" "type" "accidental" "octave"}.control-section[data-v-d8b9788a]{min-height:130px}.duration-buttons-grid[data-v-d8b9788a]{grid-template-columns:repeat(5,1fr);gap:6px}.duration-btn[data-v-d8b9788a]{height:45px;font-size:20px}}@media (max-width: 480px){.note-controls-container[data-v-d8b9788a]{padding:8px}.note-controls-grid[data-v-d8b9788a]{gap:12px}.control-section[data-v-d8b9788a]{padding:12px;min-height:120px}.control-section h4[data-v-d8b9788a]{font-size:13px;margin-bottom:10px}.duration-buttons-grid[data-v-d8b9788a]{grid-template-columns:repeat(5,1fr);gap:4px}.duration-btn[data-v-d8b9788a]{height:40px;font-size:20px;padding:4px}.note-btn[data-v-d8b9788a],.octave-btn[data-v-d8b9788a]{min-width:38px;height:40px;font-size:14px;padding:6px}.button-group button[data-v-d8b9788a]{height:45px;font-size:14px}.note-modifiers button[data-v-d8b9788a]{height:32px;font-size:12px;padding:6px 10px}}.floating-note-controls[data-v-00aa627e]{background:#f5f5f5;border:1px solid #ddd;border-radius:8px;padding:10px;margin-bottom:10px;width:100%;box-sizing:border-box;-webkit-user-select:none;user-select:none}.floating-note-controls.draggable[data-v-00aa627e]{position:fixed;width:400px;touch-action:none;box-shadow:0 4px 16px #0003}.drag-handle[data-v-00aa627e]{position:absolute;top:0;left:0;right:0;height:20px;display:flex;justify-content:center;align-items:center;cursor:move;background-color:#e0e0e0;border-top-left-radius:8px;border-top-right-radius:8px;border-bottom:1px solid #ccc}.close-btn[data-v-00aa627e]{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:16px;height:16px;border:none;background:#f44;color:#fff;border-radius:50%;cursor:pointer;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.close-btn[data-v-00aa627e]:hover{background:#c00}.drag-icon[data-v-00aa627e]{color:#666;font-size:14px;transform:rotate(90deg);-webkit-user-select:none;user-select:none}.floating-note-controls h4[data-v-00aa627e]{margin-top:15px;margin-bottom:10px;color:#333;font-size:16px;text-align:center;border-bottom:1px solid #ddd;padding-bottom:5px}.tab-navigation[data-v-00aa627e]{display:flex;gap:2px;margin-bottom:10px;border-bottom:1px solid #ddd}.tab-btn[data-v-00aa627e]{flex:1;padding:8px 12px;border:none;background:#e9e9e9;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease;border-radius:4px 4px 0 0}.tab-btn.active[data-v-00aa627e]{background:#2196f3;color:#fff}.tab-btn[data-v-00aa627e]:hover:not(.active){background:#d4d4d4}.tab-content[data-v-00aa627e]{min-height:200px}.tab-content.floating-mode[data-v-00aa627e]{min-height:180px}.tab-pane[data-v-00aa627e]{display:none}.tab-pane.active[data-v-00aa627e]{display:block}.tab-content:not(.floating-mode) .tab-pane[data-v-00aa627e]{display:block}.control-section[data-v-00aa627e]{margin-bottom:15px;padding:15px;border:1px solid #ddd;border-radius:8px;background-color:#f9f9f9;width:100%;box-sizing:border-box;display:flex;flex-direction:column;min-height:140px}.control-section h4[data-v-00aa627e]{margin-top:0;margin-bottom:12px;color:#333;font-size:14px;font-weight:600;text-align:center;border-bottom:1px solid #ddd;padding-bottom:8px}.duration-buttons-grid[data-v-00aa627e]{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;margin-bottom:12px}.duration-btn[data-v-00aa627e]{width:100%;height:45px;border:2px solid #ddd;border-radius:8px;background:#fff;font-size:16px;line-height:1;padding:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#333;font-weight:500;box-shadow:0 2px 4px #0000001a}.duration-btn.active[data-v-00aa627e]{background:#2196f3;color:#fff;border-color:#1976d2;box-shadow:0 4px 8px #2196f34d;font-weight:600;transform:translateY(-1px)}.note-modifiers[data-v-00aa627e]{display:flex;justify-content:center;gap:12px;width:100%}.note-modifiers button[data-v-00aa627e]{font-size:14px;flex:1;max-width:80px;height:36px;padding:8px 12px;border:2px solid #ddd;border-radius:6px;background:#fff;font-weight:500;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.note-modifiers button.active[data-v-00aa627e]{background:#2196f3;color:#fff;border-color:#1976d2;transform:translateY(-1px)}.button-group[data-v-00aa627e]{display:flex;gap:12px;width:100%;justify-content:center;flex:1;align-items:center}.button-group button[data-v-00aa627e]{flex:1;height:50px;font-size:16px;font-weight:600;border:2px solid #ddd;border-radius:8px;background:#fff;transition:all .2s ease;box-shadow:0 2px 4px #0000001a;cursor:pointer;color:#333}.button-group button.active[data-v-00aa627e]{background:#2196f3;color:#fff;border-color:#1976d2;transform:translateY(-1px);box-shadow:0 4px 8px #2196f34d}.scrollable-buttons[data-v-00aa627e]{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;width:100%;flex:1;align-content:flex-start}.note-btn[data-v-00aa627e],.octave-btn[data-v-00aa627e]{flex:0 0 auto;min-width:48px;height:48px;border:2px solid #ddd;border-radius:8px;background:#fff;font-size:18px;line-height:1;padding:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#333;font-weight:500;box-shadow:0 2px 4px #0000001a}.note-btn[data-v-00aa627e]:not(.active),.octave-btn[data-v-00aa627e]:not(.active){color:#333;background:#f7f7f7;border-color:#ddd}.note-btn.active[data-v-00aa627e],.octave-btn.active[data-v-00aa627e]{background:#2196f3;color:#fff;border-color:#1976d2;box-shadow:0 4px 8px #2196f34d;font-weight:600;transform:translateY(-1px)}@media (max-width: 480px){.floating-note-controls.draggable[data-v-00aa627e]{width:320px}.duration-buttons-grid[data-v-00aa627e]{grid-template-columns:repeat(2,1fr)}.tab-btn[data-v-00aa627e]{font-size:11px;padding:6px 8px}}.saved-compositions-container[data-v-1b899e25]{padding:15px;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;margin-top:20px}.control-section[data-v-1b899e25]{margin-bottom:15px;padding:10px;border:1px solid #ddd;border-radius:8px;background-color:#f9f9f9}.control-section h4[data-v-1b899e25]{margin-top:0;margin-bottom:8px;color:#333;font-size:14px;text-align:center;border-bottom:1px solid #eee;padding-bottom:5px}.save-composition-form[data-v-1b899e25]{display:flex;gap:10px;margin-bottom:10px}.composition-name-input[data-v-1b899e25]{flex:1;padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px}.save-btn[data-v-1b899e25]{background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer;font-weight:700}.save-btn[data-v-1b899e25]:hover{background-color:#45a049}.no-saved-compositions[data-v-1b899e25]{text-align:center;padding:20px;color:#666;font-style:italic}.saved-composition-list[data-v-1b899e25]{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:5px}.saved-composition-item[data-v-1b899e25]{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#fff;border:1px solid #ddd;border-radius:4px}.composition-info[data-v-1b899e25]{display:flex;flex-direction:column}.composition-name[data-v-1b899e25]{font-weight:700;color:#333}.composition-date[data-v-1b899e25]{font-size:12px;color:#777}.composition-actions[data-v-1b899e25]{display:flex;gap:5px}.load-btn[data-v-1b899e25],.delete-btn[data-v-1b899e25],.update-btn[data-v-1b899e25]{color:#fff;border:none;border-radius:4px;padding:5px 10px;cursor:pointer;font-size:13px}.load-btn[data-v-1b899e25]{background-color:#2196f3}.delete-btn[data-v-1b899e25]{background-color:#f44336}.update-btn[data-v-1b899e25]{background-color:#ff9800}.edit-name-form[data-v-1b899e25]{display:flex;gap:5px;align-items:center}.rename-input[data-v-1b899e25]{flex-grow:1;padding:6px 10px;border:1px solid #2196F3;border-radius:4px;font-size:14px}.save-rename-btn[data-v-1b899e25],.cancel-rename-btn[data-v-1b899e25]{padding:6px 10px;border:none;border-radius:4px;cursor:pointer;font-size:13px;color:#fff}.save-rename-btn[data-v-1b899e25]{background-color:#4caf50}.cancel-rename-btn[data-v-1b899e25]{background-color:#f44336}.import-export-controls[data-v-1b899e25]{display:flex;gap:10px;margin-top:15px;margin-bottom:15px;justify-content:center;flex-wrap:wrap}.export-btn[data-v-1b899e25],.import-btn[data-v-1b899e25]{background-color:#3f51b5;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer;font-size:14px;display:inline-block;text-align:center}.export-btn[data-v-1b899e25]:hover,.import-btn[data-v-1b899e25]:hover{background-color:#303f9f}.export-btn[data-v-1b899e25]:disabled{background-color:#9e9e9e;cursor:not-allowed}.export-options[data-v-1b899e25]{margin-top:10px;padding:10px;background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px}.composition-selection[data-v-1b899e25]{margin-right:10px;display:flex;align-items:center}.composition-selection input[type=checkbox][data-v-1b899e25]{width:16px;height:16px;cursor:pointer}.combine-controls[data-v-1b899e25]{margin-top:15px;display:flex;flex-direction:column;align-items:center;gap:10px;padding:10px;border-top:1px dashed #ccc}.combine-btn[data-v-1b899e25]{background-color:#673ab7;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer;font-weight:700}.combine-btn[data-v-1b899e25]:hover{background-color:#5e35b1}.combine-btn.active[data-v-1b899e25]{background-color:#f44336}.confirm-combine-btn[data-v-1b899e25]{background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer;font-weight:700}.confirm-combine-btn[data-v-1b899e25]:hover{background-color:#43a047}.combine-instructions[data-v-1b899e25]{font-size:12px;color:#666;text-align:center;margin:5px 0}.playback-settings[data-v-99da0046]{margin:10px 0 15px;padding:10px;background-color:#f5f5f5;border-radius:8px;border:1px solid #ddd}.playback-range[data-v-99da0046]{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:10px}.control-label[data-v-99da0046]{font-weight:500;color:#333;min-width:120px}.measure-range-inputs[data-v-99da0046]{display:flex;flex-wrap:wrap;gap:15px;align-items:center}.measure-input[data-v-99da0046]{display:flex;align-items:center;gap:5px}.measure-input label[data-v-99da0046]{font-size:14px}.measure-number-input[data-v-99da0046]{width:60px;padding:5px;border:1px solid #ccc;border-radius:4px;text-align:center;font-size:14px}.measure-hint[data-v-99da0046]{font-size:12px;color:#666;font-style:italic}.playback-options[data-v-99da0046]{display:flex;flex-wrap:wrap;gap:20px;align-items:center}.auto-scroll-toggle[data-v-99da0046],.measure-visibility-toggle[data-v-99da0046],.lyrics-edit-toggle[data-v-99da0046],.floating-note-controls-toggle[data-v-99da0046]{display:flex;align-items:center;gap:5px;font-size:14px}.auto-scroll-toggle input[type=checkbox][data-v-99da0046],.measure-visibility-toggle input[type=checkbox][data-v-99da0046],.lyrics-edit-toggle input[type=checkbox][data-v-99da0046],.floating-note-controls-toggle input[type=checkbox][data-v-99da0046]{margin:0;width:16px;height:16px;accent-color:#007bff}@media (max-width: 600px){.playback-range[data-v-99da0046]{flex-direction:column;align-items:flex-start}.control-label[data-v-99da0046]{min-width:auto;margin-bottom:5px}.measure-range-inputs[data-v-99da0046]{width:100%;gap:10px}.measure-input[data-v-99da0046]{width:calc(50% - 5px)}.measure-input label[data-v-99da0046]{font-size:13px}.measure-number-input[data-v-99da0046]{width:50px;font-size:13px}.playback-options[data-v-99da0046]{flex-direction:column;align-items:flex-start;gap:10px}}.lyrics-control-section[data-v-1653e017]{margin-top:15px;padding:10px;background-color:#f0f7ff;border:1px solid #cce5ff;border-radius:6px;box-shadow:0 2px 8px #0000001a;-webkit-user-select:none;user-select:none}.lyrics-control-section.draggable[data-v-1653e017]{position:fixed;width:300px;touch-action:none}.drag-handle[data-v-1653e017]{position:absolute;top:0;left:0;right:0;height:20px;display:flex;justify-content:center;align-items:center;cursor:move;background-color:#e0f0ff;border-top-left-radius:6px;border-top-right-radius:6px;border-bottom:1px solid #cce5ff}.close-btn[data-v-1653e017]{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:16px;height:16px;border:none;background:#f44;color:#fff;border-radius:50%;cursor:pointer;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.close-btn[data-v-1653e017]:hover{background:#c00}.drag-icon[data-v-1653e017]{color:#666;font-size:14px;transform:rotate(90deg);-webkit-user-select:none;user-select:none}.lyrics-control-section h4[data-v-1653e017]{margin-top:15px;margin-bottom:8px;color:#333;font-size:14px;text-align:center;border-bottom:1px solid #eee;padding-bottom:5px}.lyrics-input-container[data-v-1653e017]{display:flex;gap:10px;margin-bottom:8px}.lyric-input[data-v-1653e017]{flex:1;padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px}.add-lyric-btn[data-v-1653e017]{background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:8px 12px;cursor:pointer;font-weight:700;white-space:nowrap}.add-lyric-btn[data-v-1653e017]:disabled{background-color:#ccc;cursor:not-allowed}.lyrics-help-text[data-v-1653e017]{font-size:12px;color:#666;font-style:italic;margin-top:5px;margin-bottom:0}.voice-layers-panel-container[data-v-99afd126]{background-color:#f9f9f9;padding:15px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.voice-layers-panel-container h4[data-v-99afd126]{margin-top:0;margin-bottom:10px;color:#333;text-align:center;border-bottom:1px solid #eee;padding-bottom:5px}.voice-layers-list[data-v-99afd126]{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.voice-layer-item[data-v-99afd126]{background-color:#fff;border-radius:6px;padding:10px;border-left:5px solid transparent;display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;box-shadow:0 1px 3px #0000000d;transition:box-shadow .2s ease}.voice-layer-item[data-v-99afd126]:hover{box-shadow:0 2px 6px #0000001a}.voice-layer-item.active-voice[data-v-99afd126]{box-shadow:0 0 8px #2196f380}.voice-info[data-v-99afd126]{display:flex;align-items:center;gap:8px;grid-column:1 / 2}.voice-name-input[data-v-99afd126]{flex-grow:1;padding:2px;border:1px solid #ddd;border-radius:4px;font-size:14px}.voice-name-input[data-v-99afd126]:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f333;outline:none}.voice-color-picker[data-v-99afd126]{width:30px;height:30px;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:2px}.voice-controls[data-v-99afd126]{display:flex;flex-wrap:nowrap;gap:5px;align-items:center;grid-column:2 / 3;justify-self:start}.control-btn.icon-btn[data-v-99afd126]{background-color:#f0f0f0;border:1px solid #ccc;color:#333;padding:6px 8px;font-size:1.1em;border-radius:4px;cursor:pointer;transition:background-color .2s,border-color .2s;line-height:1;min-width:36px;text-align:right}.control-btn.icon-btn[data-v-99afd126]:hover{background-color:#e0e0e0;border-color:#bbb}.control-btn.icon-btn[data-v-99afd126]:disabled{background-color:#e9e9e9;color:#999;cursor:not-allowed;border-color:#ddd}.control-btn.icon-btn.is-active-btn[data-v-99afd126]:disabled{color:#ffc107;background-color:#f0f0f0;border-color:#ffc107}.voice-staff-assignment[data-v-99afd126]{grid-column:1 / -1;display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid #eee}.staff-assignment-label[data-v-99afd126]{font-size:13px;color:#555;white-space:nowrap}.staff-select[data-v-99afd126]{padding:6px 8px;border:1px solid #ddd;border-radius:4px;font-size:13px;background-color:#fff;flex-grow:1;min-width:120px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.voice-volume-control[data-v-99afd126]{grid-column:1 / -1;display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid #eee}.volume-label[data-v-99afd126]{font-size:13px;color:#555;white-space:nowrap}.volume-slider[data-v-99afd126]{flex-grow:1;cursor:pointer}.volume-value[data-v-99afd126]{font-size:12px;color:#333;min-width:40px;text-align:right}.delete-in-info-btn[data-v-99afd126]{margin-left:auto;background:none;border:none;color:#f44336;font-size:1.1em;padding:6px 8px;border-radius:4px;cursor:pointer;line-height:1}.delete-in-info-btn[data-v-99afd126]:hover{color:#c62828;background-color:#f0f0f0}.no-voices-message[data-v-99afd126]{text-align:center;color:#777;padding:10px;font-style:italic}.add-voice-section[data-v-99afd126]{margin-top:20px;padding-top:15px;border-top:1px solid #ddd}.add-voice-section h5[data-v-99afd126]{margin-top:0;margin-bottom:10px;color:#333}.add-voice-controls[data-v-99afd126]{display:flex;gap:10px;align-items:center}.staff-select-for-new-voice[data-v-99afd126]{padding:8px 10px;border:1px solid #ccc;border-radius:4px;font-size:14px;flex-grow:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.add-voice-btn-main[data-v-99afd126]{padding:8px 15px;font-size:14px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.add-voice-btn-main[data-v-99afd126]:hover{background-color:#45a049}.add-voice-btn-main[data-v-99afd126]:disabled{background-color:#ccc;cursor:not-allowed}.no-staves-warning[data-v-99afd126]{font-size:.9em;color:#c0392b;margin-top:5px}.playback-options-voices[data-v-99afd126]{margin-top:15px;padding-top:10px;border-top:1px solid #eee;font-size:14px}.playback-options-voices label[data-v-99afd126]{display:flex;align-items:center;gap:8px;cursor:pointer}@media (max-width: 700px){.voice-layer-item[data-v-99afd126]{grid-template-columns:1fr;row-gap:8px}.voice-info[data-v-99afd126]{grid-column:1 / -1}.voice-controls[data-v-99afd126]{grid-column:1 / -1;grid-row:2 / 3;flex-wrap:wrap;justify-content:flex-start}.voice-controls .control-btn.icon-btn[data-v-99afd126]{text-align:center}.voice-staff-assignment[data-v-99afd126]{grid-column:1 / -1;grid-row:3 / 4}.voice-volume-control[data-v-99afd126]{grid-column:1 / -1;grid-row:4 / 5}}@media (max-width: 480px){.voice-layers-panel-container[data-v-99afd126]{padding:10px;margin:10px auto}.voice-layer-item[data-v-99afd126]{grid-template-columns:1fr}.voice-info[data-v-99afd126],.voice-controls[data-v-99afd126],.voice-staff-assignment[data-v-99afd126],.voice-volume-control[data-v-99afd126]{grid-column:1 / -1;justify-self:stretch}.voice-controls[data-v-99afd126]{flex-wrap:wrap;justify-content:center}.add-voice-controls[data-v-99afd126]{flex-direction:column;align-items:stretch}}.read-only-banner[data-v-99afd126]{background-color:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:4px;padding:8px 12px;margin-bottom:12px;display:flex;align-items:center}.read-only-message[data-v-99afd126]{color:#d32f2f;font-size:14px;font-weight:500}.lock-icon[data-v-99afd126]{margin-right:6px;font-size:16px}.read-only-detail[data-v-99afd126]{font-size:12px;color:#666;margin-top:4px}.voice-layer-item.read-only[data-v-99afd126]{background-color:#f9f9f9}.voice-name-display[data-v-99afd126]{font-weight:700;padding:5px 0;font-size:14px}.voice-staff-display[data-v-99afd126]{grid-column:1 / -1;display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid #eee;font-size:13px;color:#666}.staff-label[data-v-99afd126]{font-weight:500}.staff-name[data-v-99afd126]{font-style:italic}.instruction-modal-overlay[data-v-172ec716]{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999}.instruction-modal[data-v-172ec716]{width:90%;max-width:800px;max-height:90vh;background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;overflow:hidden}.modal-header[data-v-172ec716]{padding:15px 20px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#9c27b0,#673ab7);color:#fff}.modal-header h2[data-v-172ec716]{margin:0;font-size:1.5rem}.close-btn[data-v-172ec716]{background:none;border:none;font-size:24px;color:#fff;cursor:pointer;outline:none}.modal-content[data-v-172ec716]{padding:20px;overflow-y:auto;flex-grow:1}.video-container[data-v-172ec716]{width:100%;margin:20px 0;border-radius:8px;overflow:hidden;position:relative;aspect-ratio:16 / 9;background-color:#000}.video-thumbnail[data-v-172ec716]{position:relative;width:100%;height:100%;cursor:pointer;display:flex;justify-content:center;align-items:center;overflow:hidden}.thumbnail-img[data-v-172ec716]{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.video-thumbnail:hover .thumbnail-img[data-v-172ec716]{transform:scale(1.05)}.play-button[data-v-172ec716]{position:absolute;width:70px;height:70px;background-color:#2196f3e6;border-radius:50%;display:flex;justify-content:center;align-items:center;z-index:2;box-shadow:0 4px 15px #0000004d;transition:all .3s ease}.play-icon[data-v-172ec716]{font-size:30px;color:#fff;margin-left:5px}.video-thumbnail:hover .play-button[data-v-172ec716]{transform:scale(1.1);background-color:#2196f3}.video-caption[data-v-172ec716]{position:absolute;bottom:10px;left:0;right:0;text-align:center;color:#fff;background-color:#000000b3;padding:8px;font-size:14px}.tutorial-video[data-v-172ec716]{width:100%;height:100%;object-fit:contain}.loading-indicator[data-v-172ec716]{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;justify-content:center;align-items:center;background-color:#000000b3;color:#fff;font-size:18px}.quick-tips[data-v-172ec716]{margin-top:20px;background-color:#f5f5f5;padding:15px;border-radius:8px;border-left:4px solid #2196F3}.quick-tips h3[data-v-172ec716]{margin-top:0;color:#2196f3}.quick-tips ul[data-v-172ec716]{margin-bottom:0;padding-left:20px}.quick-tips li[data-v-172ec716]{margin-bottom:8px}.modal-footer[data-v-172ec716]{padding:15px 20px;border-top:1px solid #eee;display:flex;justify-content:space-between;align-items:center}.dont-show-again[data-v-172ec716]{display:flex;align-items:center;gap:5px;cursor:pointer;-webkit-user-select:none;user-select:none}.start-btn[data-v-172ec716]{background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:10px 20px;font-size:16px;cursor:pointer;transition:background-color .2s}.start-btn[data-v-172ec716]:hover{background-color:#388e3c}@media (max-width: 600px){.instruction-modal[data-v-172ec716]{width:95%;max-height:95vh}.modal-header h2[data-v-172ec716]{font-size:1.2rem}.play-button[data-v-172ec716]{width:50px;height:50px}.play-icon[data-v-172ec716]{font-size:24px}.modal-footer[data-v-172ec716]{flex-direction:column;gap:15px}.start-btn[data-v-172ec716]{width:100%}}.login-prompt-overlay[data-v-94e3a78e]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.login-prompt-modal[data-v-94e3a78e]{background:#fff;border-radius:8px;padding:0;max-width:400px;width:90%;box-shadow:0 4px 20px #0000004d}.modal-header[data-v-94e3a78e]{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 0;border-bottom:1px solid #eee}.modal-header h2[data-v-94e3a78e]{margin:0;color:#333;font-size:1.5rem}.close-btn[data-v-94e3a78e]{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-btn[data-v-94e3a78e]:hover{background:#f0f0f0}.modal-body[data-v-94e3a78e]{padding:20px}.modal-body p[data-v-94e3a78e]{margin:0 0 10px;color:#666;line-height:1.5}.login-options[data-v-94e3a78e]{margin:20px 0}.google-signin-btn[data-v-94e3a78e]{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 20px;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:16px;color:#333;transition:all .2s}.google-signin-btn[data-v-94e3a78e]:hover{background:#f8f9fa;border-color:#c1c1c1;box-shadow:0 2px 4px #0000001a}.google-icon[data-v-94e3a78e]{width:18px;height:18px}.modal-footer[data-v-94e3a78e]{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:20px;border-top:1px solid #eee}.cancel-btn[data-v-94e3a78e]{padding:8px 16px;background:#f0f0f0;border:1px solid #ddd;border-radius:4px;cursor:pointer;color:#666;transition:all .2s}.cancel-btn[data-v-94e3a78e]:hover{background:#e0e0e0;border-color:#c1c1c1}.sections-panel[data-v-e31d0c72]{padding:15px;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;margin-top:20px}h4[data-v-e31d0c72]{margin-top:0;margin-bottom:10px;color:#333;font-size:14px;text-align:center;border-bottom:1px solid #eee;padding-bottom:5px}.section-form[data-v-e31d0c72]{display:flex;flex-direction:column;gap:10px;margin-bottom:15px;padding:10px;background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px}.section-name-input[data-v-e31d0c72]{padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px;width:100%}.measure-range[data-v-e31d0c72]{display:flex;gap:10px}.measure-input[data-v-e31d0c72]{display:flex;align-items:center;gap:5px;flex:1}.measure-input input[data-v-e31d0c72]{padding:8px;border:1px solid #ccc;border-radius:4px;font-size:14px;width:60px}.add-section-btn[data-v-e31d0c72]{background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer;font-weight:700}.add-section-btn[data-v-e31d0c72]:hover{background-color:#45a049}.no-sections[data-v-e31d0c72]{text-align:center;padding:20px;color:#666;font-style:italic}.sections-list[data-v-e31d0c72]{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:5px}.section-item[data-v-e31d0c72]{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#fff;border:1px solid #ddd;border-radius:4px}.section-info[data-v-e31d0c72]{display:flex;flex-direction:column}.section-name[data-v-e31d0c72]{font-weight:700;color:#333}.section-range[data-v-e31d0c72]{font-size:12px;color:#777}.section-actions[data-v-e31d0c72]{display:flex;gap:5px}.play-section-btn[data-v-e31d0c72],.jump-section-btn[data-v-e31d0c72],.delete-section-btn[data-v-e31d0c72]{color:#fff;border:none;border-radius:4px;padding:6px 10px;cursor:pointer;font-size:16px}.play-section-btn[data-v-e31d0c72]{background-color:#2196f3}.jump-section-btn[data-v-e31d0c72]{background-color:#9c27b0}.delete-section-btn[data-v-e31d0c72]{background-color:#f44336}.playback-sequence[data-v-e31d0c72]{margin-top:20px;padding-top:15px;border-top:1px dashed #ccc}.no-sequences[data-v-e31d0c72]{text-align:center;padding:15px;color:#666;font-style:italic;font-size:14px}.sequence-list[data-v-e31d0c72]{display:flex;flex-direction:column;gap:5px;margin-top:10px}.sequence-item[data-v-e31d0c72]{display:flex;align-items:center;padding:8px 10px;background:#fff;border:1px solid #ddd;border-radius:4px}.sequence-number[data-v-e31d0c72]{font-weight:700;margin-right:10px;color:#555;width:25px}.sequence-section-name[data-v-e31d0c72]{flex:1;font-weight:500}.remove-from-sequence-btn[data-v-e31d0c72]{color:#fff;background-color:#f44336;border:none;border-radius:4px;padding:4px 8px;cursor:pointer;font-size:14px}.sequence-controls[data-v-e31d0c72]{display:flex;gap:10px;margin-top:10px;justify-content:center}.play-sequence-btn[data-v-e31d0c72]{background-color:#4caf50;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer;font-weight:700}.clear-sequence-btn[data-v-e31d0c72]{background-color:#757575;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer}.add-to-sequence-btn[data-v-e31d0c72]{color:#fff;background-color:#ff9800;border:none;border-radius:4px;padding:6px 10px;cursor:pointer;font-size:16px;font-weight:700}.debug-btn[data-v-e31d0c72]{background-color:#757575;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer;margin-top:10px}.read-only-banner[data-v-e31d0c72]{background-color:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:4px;padding:8px 12px;margin-bottom:12px;display:flex;align-items:center}.read-only-message[data-v-e31d0c72]{color:#d32f2f;font-size:14px;font-weight:500}.lock-icon[data-v-e31d0c72]{margin-right:6px;font-size:16px}.read-only-detail[data-v-e31d0c72]{font-size:12px;color:#666;margin-top:4px}.modal-overlay[data-v-7da76bda]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content[data-v-7da76bda]{background-color:#fff;padding:20px;border-radius:8px;width:90%;max-width:500px}.form-group[data-v-7da76bda]{margin-bottom:15px}label[data-v-7da76bda]{display:block;margin-bottom:5px}input[type=text][data-v-7da76bda],input[type=email][data-v-7da76bda],select[data-v-7da76bda]{width:100%;padding:8px;border:1px solid #ccc;border-radius:4px}.radio-group label[data-v-7da76bda]{margin-right:15px}.share-entry[data-v-7da76bda]{display:flex;gap:10px;margin-bottom:10px}.modal-actions[data-v-7da76bda]{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal-overlay[data-v-b68a9a16]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content[data-v-b68a9a16]{background:#fff;border-radius:8px;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column}.modal-header[data-v-b68a9a16]{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #eee}.modal-header h2[data-v-b68a9a16]{margin:0;font-size:1.5rem;color:#333}.close-btn[data-v-b68a9a16]{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}.modal-body[data-v-b68a9a16]{padding:16px;overflow-y:auto}.tabs[data-v-b68a9a16]{display:flex;gap:8px;margin-bottom:16px;border-bottom:1px solid #eee;padding-bottom:8px}.tabs button[data-v-b68a9a16]{padding:8px 16px;border:none;background:none;cursor:pointer;color:#666;font-weight:500;border-radius:4px}.tabs button.active[data-v-b68a9a16]{background:#2196f3;color:#fff}.compositions-list[data-v-b68a9a16]{display:flex;flex-direction:column;gap:12px}.composition-item[data-v-b68a9a16]{display:flex;justify-content:space-between;align-items:flex-start;padding:14px;border:1px solid #e0e0e0;border-radius:8px;background:#fff;transition:all .2s ease;box-shadow:0 1px 3px #0000000d}.composition-item[data-v-b68a9a16]:hover{border-color:#d0d0d0;box-shadow:0 2px 6px #0000001a;background:#fafafa}.composition-info[data-v-b68a9a16]{flex:1}.comp-title[data-v-b68a9a16]{margin:0 0 6px;font-size:1.1rem;color:#333;line-height:1.3;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.access-tag[data-v-b68a9a16]{font-size:.6rem;font-weight:600;padding:2px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;display:inline-flex;align-items:center;gap:2px;cursor:default;pointer-events:none;vertical-align:middle;margin-left:4px}.access-tag i[data-v-b68a9a16]{font-size:.9em}.access-tag.access-owner[data-v-b68a9a16]{background:#e8f5e8;color:#2e7d32;border:1px solid #c8e6c9}.access-tag.access-write[data-v-b68a9a16]{background:#fff3e0;color:#e65100;border:1px solid #ffcc80}.access-tag.access-read[data-v-b68a9a16]{background:#f5f5f5;color:#424242;border:1px solid #e0e0e0}.author[data-v-b68a9a16]{margin:0 0 2px;font-size:.9rem;color:#666}.details[data-v-b68a9a16]{font-size:.85rem;color:#666;display:flex;gap:15px;margin:4px 0}.visibility[data-v-b68a9a16]{font-size:.85rem;color:#888}.composition-actions[data-v-b68a9a16]{display:flex;flex-direction:column;gap:6px}.load-btn[data-v-b68a9a16],.delete-btn[data-v-b68a9a16],.edit-btn[data-v-b68a9a16]{background:#2196f3;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.85rem}.delete-btn[data-v-b68a9a16]{background:#e53935}.edit-btn[data-v-b68a9a16]{background:#ff9800}.edit-form[data-v-b68a9a16]{flex:1;display:flex;flex-wrap:wrap;gap:10px}.form-group[data-v-b68a9a16]{flex:1 1 45%;display:flex;flex-direction:column}.form-group label[data-v-b68a9a16]{font-size:.8rem;margin-bottom:4px}.form-group input[data-v-b68a9a16],.form-group select[data-v-b68a9a16]{padding:6px 8px;border:1px solid #ccc;border-radius:4px}.edit-actions[data-v-b68a9a16]{display:flex;gap:8px;margin-top:10px}.save-edit-btn[data-v-b68a9a16]{background:#4caf50;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer}.cancel-edit-btn[data-v-b68a9a16]{background:#9e9e9e;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer}.current-composition-card[data-v-b68a9a16]{background:#f9f9f9;padding:15px 20px;border-bottom:1px solid #eee}.current-composition-card .title[data-v-b68a9a16]{font-weight:700;font-size:1.1rem;margin:4px 0}.sharing-section[data-v-b68a9a16]{width:100%;flex:1 1 100%}.share-entry[data-v-b68a9a16]{display:flex;gap:8px;margin-bottom:8px;align-items:center}.share-entry input[type=email][data-v-b68a9a16]{flex:2}.share-entry select[data-v-b68a9a16]{flex:1}.remove-share-btn[data-v-b68a9a16]{background:#e53935;color:#fff;border:none;padding:6px 10px;border-radius:4px;cursor:pointer;font-size:.8rem;white-space:nowrap}.add-share-btn[data-v-b68a9a16]{background:#4caf50;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.8rem;margin-top:4px}.checkbox-label[data-v-b68a9a16]{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox][data-v-b68a9a16]{width:auto;margin:0}.current-composition-card .meta[data-v-b68a9a16]{font-size:.9rem;color:#666;display:flex;gap:15px}.quick-save-btn[data-v-b68a9a16]{margin-top:10px;background:#4caf50;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer}.no-compositions[data-v-b68a9a16]{text-align:center;padding:24px;color:#666}.loading-compositions[data-v-b68a9a16]{text-align:center;padding:40px;color:#666}.loading-overlay[data-v-b68a9a16]{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.loading-spinner[data-v-b68a9a16]{width:32px;height:32px;border:3px solid #f3f3f3;border-top:3px solid #2196F3;border-radius:50%;animation:spin-b68a9a16 1s linear infinite;margin-bottom:12px}.button-spinner[data-v-b68a9a16]{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin-b68a9a16 1s linear infinite;display:inline-block;margin-right:6px}@keyframes spin-b68a9a16{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.load-btn[data-v-b68a9a16]:disabled,.edit-btn[data-v-b68a9a16]:disabled,.delete-btn[data-v-b68a9a16]:disabled,.save-edit-btn[data-v-b68a9a16]:disabled{opacity:.6;cursor:not-allowed}.load-btn:disabled .fas[data-v-b68a9a16],.edit-btn:disabled .fas[data-v-b68a9a16],.delete-btn:disabled .fas[data-v-b68a9a16]{opacity:.5}@media (max-width: 768px){.modal-content[data-v-b68a9a16]{width:95%;max-height:90vh}.composition-item[data-v-b68a9a16]{flex-direction:column;align-items:flex-start;gap:8px}.composition-actions[data-v-b68a9a16]{width:100%;justify-content:flex-end}.comp-title[data-v-b68a9a16]{flex-direction:column;align-items:flex-start;gap:4px}.access-tag[data-v-b68a9a16]{font-size:.55rem;padding:1px 4px;margin-left:0;align-self:flex-start}}.search-bar[data-v-b68a9a16]{margin:12px 0 8px;display:flex;justify-content:center}.search-bar input[data-v-b68a9a16]{width:100%;max-width:350px;padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:1rem}.ties-slurs-overlay[data-v-02d99d53]{position:absolute;top:0;left:0;pointer-events:none;z-index:10}.ties-slurs-overlay path[data-v-02d99d53]{pointer-events:auto}.tie-slur-path[data-v-02d99d53]{transition:stroke-width .2s ease}.tie-slur-path[data-v-02d99d53]:hover{stroke-width:3}.tie-slur-path.tie[data-v-02d99d53]{stroke-dasharray:none}.tie-slur-path.slur[data-v-02d99d53]{stroke-dasharray:3,2}.tie-slur-btn[data-v-02d99d53]{padding:8px 16px;background-color:#9c27b0;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:14px;font-weight:500}.tie-slur-btn.active[data-v-02d99d53]{background-color:#7b1fa2}.tie-slur-btn[data-v-02d99d53]:hover{opacity:.9}.tie-slur-info[data-v-02d99d53]{font-size:12px;color:#666;margin-top:5px}.note[data-v-02d99d53]:hover{transform:translate(-50%,-50%) scale(1.05)}.staff.tie-slur-mode[data-v-02d99d53]{cursor:crosshair}.staff.key-change-mode[data-v-02d99d53]{cursor:pointer}.key-change-btn[data-v-02d99d53]{padding:8px 16px;background-color:#ff5722;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:14px;font-weight:500}.key-change-btn.active[data-v-02d99d53]{background-color:#d84315}.key-change-btn[data-v-02d99d53]:hover{opacity:.9}.key-change-controls[data-v-02d99d53]{display:flex;align-items:center;gap:10px;margin-top:5px;font-size:12px}.key-change-controls select[data-v-02d99d53]{padding:4px 8px;border:1px solid #ccc;border-radius:4px}.key-change-info[data-v-02d99d53]{color:#666;font-style:italic}.time-change-btn[data-v-02d99d53]{padding:8px 16px;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:14px;font-weight:500;margin-left:8px}.time-change-btn.active[data-v-02d99d53]{background-color:#1976d2}.time-change-btn[data-v-02d99d53]:hover{opacity:.9}.time-change-controls[data-v-02d99d53]{display:flex;align-items:center;gap:10px;margin-top:5px;font-size:12px}.time-sig-select[data-v-02d99d53]{padding:4px 8px;border:1px solid #ccc;border-radius:4px;width:60px}.time-change-info[data-v-02d99d53]{color:#666;font-style:italic}.time-signature-change[data-v-02d99d53]{position:absolute;top:180px;left:0;z-index:15;pointer-events:all;min-width:60px}.time-signature-change.clickable[data-v-02d99d53]{cursor:pointer}.time-change-marker[data-v-02d99d53]{background:linear-gradient(135deg,#2196f3,#42a5f5);color:#fff;padding:4px 8px;border-radius:6px;font-size:10px;font-weight:700;text-align:center;box-shadow:0 2px 4px #0003;border:2px solid #2196F3;display:flex;flex-direction:column;align-items:center;min-width:50px}.time-change-icon[data-v-02d99d53]{font-size:12px;margin-bottom:2px}.time-change-text[data-v-02d99d53]{font-size:9px;line-height:1}.time-signature-change.clickable:hover .time-change-marker[data-v-02d99d53]{transform:scale(1.05);box-shadow:0 3px 6px #0000004d}.time-signature-change.clickable[data-v-02d99d53]:hover:after{content:"×";position:absolute;top:-8px;right:-8px;font-size:16px;color:#f44336;background:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000004d;pointer-events:none;font-weight:700}.key-signature-change[data-v-02d99d53]{position:absolute;top:20px;left:0;z-index:15;pointer-events:all;min-width:60px;transform:translate(70px)}.key-signature-change.clickable[data-v-02d99d53]{cursor:pointer}.key-change-marker[data-v-02d99d53]{background:linear-gradient(135deg,#ff5722,#ff7043);color:#fff;padding:4px 8px;border-radius:6px;font-size:10px;font-weight:700;text-align:center;box-shadow:0 2px 4px #0003;border:2px solid #FF5722;display:flex;flex-direction:column;align-items:center;min-width:50px}.key-change-icon[data-v-02d99d53]{font-size:12px;margin-bottom:2px}.key-change-text[data-v-02d99d53]{font-size:9px;line-height:1}.key-signature-change.clickable:hover .key-change-marker[data-v-02d99d53]{transform:scale(1.05);box-shadow:0 3px 6px #0000004d}.key-signature-change.clickable[data-v-02d99d53]:hover:after{content:"×";position:absolute;top:-8px;right:-8px;font-size:16px;color:#f44336;background:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000004d;pointer-events:none;font-weight:700}.triplet-brackets-overlay[data-v-02d99d53]{position:absolute;top:0;left:0;pointer-events:none;z-index:12}.triplet-bracket-line[data-v-02d99d53],.triplet-bracket-end[data-v-02d99d53]{stroke-linecap:round}.triplet-number[data-v-02d99d53]{pointer-events:none;-webkit-user-select:none;user-select:none}.note.triplet[data-v-02d99d53]{border-radius:3px}.triplet-brackets-overlay .triplet-bracket-line[data-v-02d99d53],.triplet-brackets-overlay .triplet-bracket-end[data-v-02d99d53],.triplet-brackets-overlay .triplet-number[data-v-02d99d53]{transition:none}.clef-change-btn[data-v-02d99d53]{padding:8px 16px;background-color:#9c27b0;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:14px;font-weight:500;margin-left:8px}.clef-change-btn.active[data-v-02d99d53]{background-color:#7b1fa2}.clef-change-btn[data-v-02d99d53]:hover{opacity:.9}.clef-change-controls[data-v-02d99d53]{display:flex;align-items:center;gap:10px;margin-top:5px;font-size:12px}.clef-change-controls select[data-v-02d99d53]{padding:4px 8px;border:1px solid #ccc;border-radius:4px}.clef-change-info[data-v-02d99d53]{color:#666;font-style:italic}.bpm-change-btn[data-v-02d99d53]{padding:8px 16px;background-color:#ff9800;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:14px;font-weight:500;margin-left:8px}.bpm-change-btn.active[data-v-02d99d53]{background-color:#f57c00}.bpm-change-btn[data-v-02d99d53]:hover{opacity:.9}.bpm-change-controls[data-v-02d99d53]{display:flex;align-items:center;gap:10px;margin-top:5px;font-size:12px}.bpm-change-controls .bpm-input[data-v-02d99d53]{padding:4px 8px;border:1px solid #ccc;border-radius:4px;width:80px}.bpm-change-info[data-v-02d99d53]{color:#666;font-style:italic}.bpm-change[data-v-02d99d53]{position:absolute;top:0;z-index:10;cursor:pointer}.bpm-change.clickable:hover .bpm-change-marker[data-v-02d99d53]{background-color:#ff980033}.bpm-change-marker[data-v-02d99d53]{display:flex;flex-direction:column;align-items:center;background-color:#ff98001a;border:2px solid #FF9800;border-radius:8px;padding:4px 8px;min-width:60px;font-size:12px;font-weight:700;color:#ff9800}.bpm-change-icon[data-v-02d99d53]{font-size:16px;margin-bottom:2px}.bpm-change-text[data-v-02d99d53]{font-size:10px;text-align:center}.clef-change[data-v-02d99d53]{position:absolute;top:20px;left:0;z-index:15;pointer-events:all;min-width:60px}.clef-change.clickable[data-v-02d99d53]{cursor:pointer}.clef-change-marker[data-v-02d99d53]{background:linear-gradient(135deg,#9c27b0,#ba68c8);color:#fff;padding:4px 8px;border-radius:6px;font-size:10px;font-weight:700;text-align:center;box-shadow:0 2px 4px #0003;border:2px solid #9C27B0;display:flex;flex-direction:column;align-items:center;min-width:50px}.clef-change-icon[data-v-02d99d53]{font-size:16px;margin-bottom:2px}.clef-change-text[data-v-02d99d53]{font-size:9px;line-height:1}.clef-change.clickable:hover .clef-change-marker[data-v-02d99d53]{transform:scale(1.05);box-shadow:0 3px 6px #0000004d}.clef-change.clickable[data-v-02d99d53]:hover:after{content:"×";position:absolute;top:-8px;right:-8px;font-size:16px;color:#f44336;background:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000004d;pointer-events:none;font-weight:700}.note.rest[data-v-02d99d53]{font-size:2.5em;transform:translate(-50%,-50%) scale(.6);transform-origin:center center;width:auto;height:auto;position:absolute}.note.rest[data-duration=whole][data-v-02d99d53],.note.rest[data-duration=half][data-v-02d99d53],.note.rest[data-duration=quarter][data-v-02d99d53],.note.rest[data-duration=eighth][data-v-02d99d53],.note.rest[data-duration=sixteenth][data-v-02d99d53]{transform:translate(-50%,-50%) scale(.6)}.note.rest[data-v-02d99d53]{color:currentColor}.note.rest.selected[data-v-02d99d53]{outline:2px solid #2196F3;outline-offset:3px;border-radius:4px;box-shadow:0 0 8px #2196f380}.duplicate-staff-btn[data-v-02d99d53]{background-color:#4a90e2;color:#fff;border:none;padding:5px 10px;border-radius:4px;cursor:pointer;margin-left:8px;font-size:.9em}.duplicate-staff-btn[data-v-02d99d53]:hover{background-color:#357abd}.save-cloud-btn[data-v-02d99d53]{margin-left:10px}.save-cloud-btn[data-v-02d99d53],.load-cloud-btn[data-v-02d99d53]{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;transition:background-color .3s;font-size:14px;font-weight:500;margin-left:8px;color:#fff}.save-cloud-btn[data-v-02d99d53]{background-color:#4caf50}.load-cloud-btn[data-v-02d99d53]{background-color:#2196f3}.save-cloud-btn[data-v-02d99d53]:hover,.load-cloud-btn[data-v-02d99d53]:hover{opacity:.9}.auth-container[data-v-02d99d53]{position:absolute;top:16px;right:16px;z-index:100}.google-signin-btn[data-v-02d99d53]{display:flex;align-items:center;gap:8px;padding:8px 16px;background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;color:#333;transition:background-color .2s}.google-signin-btn[data-v-02d99d53]:hover{background-color:#f8f9fa}.google-icon[data-v-02d99d53]{width:18px;height:18px}.staff-controls[data-v-02d99d53]{margin:16px;display:flex;gap:10px}.add-staff-btn[data-v-02d99d53]{padding:8px 16px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.add-staff-btn[data-v-02d99d53]:hover{background-color:#45a049}@media (max-width: 768px){.auth-container[data-v-02d99d53]{top:8px;right:8px}.google-signin-btn[data-v-02d99d53]{padding:6px 12px}.staff-controls[data-v-02d99d53]{margin:8px}.add-staff-btn[data-v-02d99d53]{padding:6px 12px;font-size:14px}}.loading-overlay[data-v-02d99d53]{position:fixed;top:0;left:0;width:100%;height:100%;background:#ffffffb3;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2000}.loading-overlay p[data-v-02d99d53]{margin-top:16px;font-size:16px;color:#333;font-weight:500}.spinner[data-v-02d99d53]{border:6px solid #f3f3f3;border-top:6px solid #3498db;border-radius:50%;width:60px;height:60px;animation:spin-02d99d53 1s linear infinite}@keyframes spin-02d99d53{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.partial-measure-btn[data-v-02d99d53]{background-color:#ff6b35;color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s}.partial-measure-btn[data-v-02d99d53]:hover{background-color:#e55a2b}.partial-measure-btn.active[data-v-02d99d53]{background-color:#d4481f}.partial-measure-controls[data-v-02d99d53]{display:flex;align-items:center;gap:8px;margin-top:4px;padding:8px;background-color:#fff3f0;border-radius:4px;font-size:12px}.partial-measure-controls label[data-v-02d99d53]{font-weight:700;color:#ff6b35}.partial-measure-controls select[data-v-02d99d53]{padding:4px;border:1px solid #ff6b35;border-radius:3px;background-color:#fff}.partial-measure-info[data-v-02d99d53]{color:#666;font-style:italic;margin-top:4px}.partial-measure[data-v-02d99d53]{position:absolute;top:100px;z-index:10;pointer-events:auto}.partial-measure-marker[data-v-02d99d53]{display:flex;flex-direction:column;align-items:center;background-color:#ff6b35e6;color:#fff;padding:4px 6px;border-radius:4px;font-size:10px;line-height:1.2;box-shadow:0 2px 4px #0003;cursor:pointer;transition:opacity .2s}.partial-measure-marker[data-v-02d99d53]:hover{opacity:.8}.partial-measure-icon[data-v-02d99d53]{font-size:12px;margin-bottom:2px}.partial-measure-text[data-v-02d99d53]{font-size:9px;font-weight:700}.staff.partial-measure-mode[data-v-02d99d53]{cursor:pointer}.staff.partial-measure-mode[data-v-02d99d53]:hover{background-color:#ff6b351a}.legal-page-container[data-v-a94ba7dd]{padding:20px;font-family:Arial,sans-serif;line-height:1.6;background-color:#f9f9f9;min-height:100vh;display:flex;justify-content:center}.legal-content[data-v-a94ba7dd]{background-color:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 10px #0000001a;max-width:800px;width:100%}.legal-content h1[data-v-a94ba7dd]{color:#333;border-bottom:2px solid #eee;padding-bottom:10px;margin-top:0}.legal-content h2[data-v-a94ba7dd]{color:#555;margin-top:30px;margin-bottom:10px;border-bottom:1px solid #eee;padding-bottom:5px}.legal-content p[data-v-a94ba7dd],.legal-content li[data-v-a94ba7dd]{color:#444;margin-bottom:10px}.legal-content ul[data-v-a94ba7dd]{padding-left:20px}.legal-content em[data-v-a94ba7dd]{color:#777;font-size:.9em}.back-button[data-v-a94ba7dd]{background-color:#007bff;color:#fff;border:none;padding:8px 15px;border-radius:4px;cursor:pointer;font-size:14px;margin-bottom:20px;transition:background-color .2s}.back-button[data-v-a94ba7dd]:hover{background-color:#0056b3}.contact-info[data-v-a94ba7dd]{margin-top:30px;font-style:italic;color:#666}.legal-page-container[data-v-ff74f2bf]{padding:20px;font-family:Arial,sans-serif;line-height:1.6;background-color:#f9f9f9;min-height:100vh;display:flex;justify-content:center}.legal-content[data-v-ff74f2bf]{background-color:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 10px #0000001a;max-width:800px;width:100%}.legal-content h1[data-v-ff74f2bf]{color:#333;border-bottom:2px solid #eee;padding-bottom:10px;margin-top:0}.legal-content h2[data-v-ff74f2bf]{color:#555;margin-top:30px;margin-bottom:10px;border-bottom:1px solid #eee;padding-bottom:5px}.legal-content p[data-v-ff74f2bf],.legal-content li[data-v-ff74f2bf]{color:#444;margin-bottom:10px}.legal-content ul[data-v-ff74f2bf]{padding-left:20px}.legal-content em[data-v-ff74f2bf]{color:#777;font-size:.9em}.back-button[data-v-ff74f2bf]{background-color:#007bff;color:#fff;border:none;padding:8px 15px;border-radius:4px;cursor:pointer;font-size:14px;margin-bottom:20px;transition:background-color .2s}.back-button[data-v-ff74f2bf]:hover{background-color:#0056b3}.legacy-migration[data-v-efc95c56]{padding:20px;max-width:800px;margin:0 auto}.stats[data-v-efc95c56]{margin:20px 0;padding:15px;background:#f5f5f5;border-radius:4px}.actions[data-v-efc95c56]{margin:20px 0;display:flex;gap:10px}button[data-v-efc95c56]{padding:8px 16px;border:none;border-radius:4px;background:#4caf50;color:#fff;cursor:pointer}button[data-v-efc95c56]:disabled{background:#ccc;cursor:not-allowed}.error[data-v-efc95c56]{color:#f44336;margin:10px 0}.compositions-list[data-v-efc95c56]{margin-top:20px}.compositions-list ul[data-v-efc95c56]{list-style:none;padding:0}.compositions-list li[data-v-efc95c56]{padding:8px;border-bottom:1px solid #eee}.success[data-v-efc95c56]{color:#4caf50;margin-left:10px}.error[data-v-efc95c56]{color:#f44336;margin-left:10px}.admin-view[data-v-88e167d2]{padding:20px;max-width:1200px;margin:0 auto}.unauthorized[data-v-88e167d2]{text-align:center;padding:40px;background:#f5f5f5;border-radius:4px}.admin-section[data-v-88e167d2]{margin:20px 0;padding:20px;background:#fff;border-radius:4px;box-shadow:0 2px 4px #0000001a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;color:#2c3e50;background:#f5f5f5;line-height:1.6;font-family:Arial,sans-serif;font-size:16px;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
