:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-width:320px;min-height:100vh}button,input{font-family:inherit}.drum-notation-container{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;padding:20px;margin:20px 0;box-shadow:0 8px 32px #0000004d}.notation-legend{margin-bottom:15px;padding:12px;background:#ffffff0d;border-radius:10px}.notation-legend h4{margin:0 0 10px;color:#fff;font-size:14px}.legend-items{display:flex;flex-wrap:wrap;gap:12px}.legend-item{display:flex;align-items:center;gap:6px;background:#ffffff14;padding:4px 10px;border-radius:20px;font-size:12px}.legend-symbol{font-size:16px;font-weight:700}.legend-name{color:#ccc}.notation-scroll{overflow-x:auto;overflow-y:hidden;padding:10px 0;-webkit-overflow-scrolling:touch}.drum-notation-svg{background:#0003;border-radius:8px}.time-signature{fill:#fff;font-size:24px;font-weight:700;font-family:serif}.beat-number{fill:#888;font-size:14px;text-anchor:middle;font-family:sans-serif}.measure-number{fill:#666;font-size:12px;text-anchor:middle;font-family:sans-serif}.drum-note{transition:transform .1s ease;transform-origin:0 0}.drum-note:hover .note-symbol{filter:brightness(1.3) drop-shadow(0 0 8px currentColor)}.drum-note.active .note-symbol{filter:brightness(1.5) drop-shadow(0 0 12px #00ff88);animation:pulse .15s ease-out}.drum-note.editable:hover{opacity:.7}.drum-note.editable:hover .note-symbol{filter:brightness(1.2) drop-shadow(0 0 8px #ff6b6b)}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.playhead{animation:playhead-glow .3s ease-in-out infinite alternate}@keyframes playhead-glow{0%{opacity:.5;filter:drop-shadow(0 0 5px #00ff88)}to{opacity:.9;filter:drop-shadow(0 0 15px #00ff88)}}.tooltip{position:fixed;transform:translate(-50%,-100%);background:linear-gradient(135deg,#2d2d44,#1a1a2e);border:2px solid #444;border-radius:12px;padding:10px 16px;z-index:1000;pointer-events:none;box-shadow:0 4px 20px #00000080;text-align:center;animation:tooltip-appear .15s ease-out}@keyframes tooltip-appear{0%{opacity:0;transform:translate(-50%,-90%)}to{opacity:1;transform:translate(-50%,-100%)}}.tooltip-name{color:#fff;font-size:14px;font-weight:700;margin-bottom:4px}.tooltip-symbol{font-size:24px}@media(max-width:768px){.drum-notation-container{padding:12px;margin:10px 0}.legend-items{gap:8px}.legend-item{padding:3px 8px;font-size:11px}.legend-symbol{font-size:14px}}.playback-controls{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:30px;padding:20px;background:linear-gradient(135deg,#2d2d44,#1a1a2e);border-radius:16px;margin:20px 0;box-shadow:0 8px 32px #0000004d}.control-group{display:flex;align-items:center;gap:12px}.transport{gap:8px}.control-btn{width:60px;height:60px;border-radius:50%;border:none;font-size:24px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.play-btn{background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff;box-shadow:0 4px 15px #4caf5066}.play-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #4caf5099}.play-btn.playing{background:linear-gradient(135deg,#ff9800,#f57c00);box-shadow:0 4px 15px #ff980066;animation:pulse-playing 1s infinite}@keyframes pulse-playing{0%,to{box-shadow:0 4px 15px #ff980066}50%{box-shadow:0 4px 25px #ff9800b3}}.stop-btn{background:linear-gradient(135deg,#f44336,#c62828);color:#fff;box-shadow:0 4px 15px #f4433666}.stop-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #f4433699}.restart-btn{background:linear-gradient(135deg,#2196f3,#1565c0);color:#fff;box-shadow:0 4px 15px #2196f366}.restart-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #2196f399}.bpm-control{flex-direction:column;gap:8px}.bpm-label{display:flex;align-items:center;gap:8px;color:#fff;font-size:16px;font-weight:700}.bpm-icon{font-size:24px}.bpm-slider-container{display:flex;align-items:center;gap:10px}.bpm-range-label{color:#888;font-size:12px;min-width:35px}.bpm-slider{width:180px;height:8px;border-radius:4px;background:linear-gradient(90deg,#4caf50,#ffeb3b,#f44336);appearance:none;outline:none;cursor:pointer}.bpm-slider::-webkit-slider-thumb{appearance:none;width:24px;height:24px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 10px #0000004d;transition:transform .15s ease}.bpm-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.bpm-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#fff;cursor:pointer;border:none;box-shadow:0 2px 10px #0000004d}.bpm-value-container{display:flex;align-items:center;gap:8px}.bpm-input{width:85px;padding:8px 12px;border-radius:8px;border:2px solid #444;background:#ffffff1a;color:#fff;font-size:18px;font-weight:700;text-align:center}.bpm-input:focus{outline:none;border-color:#4caf50}.bpm-unit{color:#888;font-size:14px}@media(max-width:768px){.playback-controls{flex-direction:column;gap:20px;padding:15px}.control-btn{width:50px;height:50px;font-size:20px}.bpm-slider{width:150px}}.song-manager{background:linear-gradient(135deg,#2d2d44,#1a1a2e);border-radius:16px;padding:20px;margin:20px 0;box-shadow:0 8px 32px #0000004d}.song-manager-title{display:flex;align-items:center;gap:10px;color:#fff;margin:0 0 16px;font-size:20px}.title-icon{font-size:24px}.create-song-btn{width:100%;padding:12px 16px;margin-bottom:16px;border-radius:12px;border:2px dashed rgba(76,175,80,.5);background:#4caf501a;color:#4caf50;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease}.create-song-btn:hover{background:#4caf5033;border-color:#4caf50}.create-song-btn .btn-icon{font-size:18px}.no-songs{text-align:center;padding:30px;color:#888}.no-songs p{margin:8px 0}.no-songs-hint{font-size:14px;color:#666}.songs-list{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto}.song-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#ffffff0d;border-radius:12px;border:2px solid transparent;transition:all .2s ease;cursor:pointer}.song-item:hover{background:#ffffff1a;border-color:#ffffff1a}.song-item.active{background:#4caf5033;border-color:#4caf50}.song-info{display:flex;flex-direction:column;gap:4px;flex:1}.song-name{color:#fff;font-size:16px;font-weight:600}.song-meta{color:#888;font-size:13px}.song-date{color:#666;font-size:12px}.song-actions{display:flex;gap:8px;opacity:0;transition:opacity .2s ease}.song-item:hover .song-actions{opacity:1}.action-btn{width:36px;height:36px;border-radius:8px;border:none;background:#ffffff1a;cursor:pointer;font-size:16px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.action-btn:hover{transform:scale(1.1)}.action-btn.edit:hover{background:#2196f34d}.action-btn.delete:hover{background:#f443364d}.song-edit{display:flex;align-items:center;gap:8px;width:100%}.song-name-input{flex:1;padding:8px 12px;border-radius:8px;border:2px solid #4caf50;background:#ffffff1a;color:#fff;font-size:16px;outline:none}.edit-btn{width:32px;height:32px;border-radius:8px;border:none;cursor:pointer;font-size:16px;transition:all .2s ease}.edit-btn.save{background:#4caf50;color:#fff}.edit-btn.save:hover{background:#66bb6a}.edit-btn.cancel{background:#666;color:#fff}.edit-btn.cancel:hover{background:#888}.songs-list::-webkit-scrollbar{width:8px}.songs-list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.songs-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.songs-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media(max-width:768px){.song-manager{padding:15px}.song-actions{opacity:1}.action-btn{width:32px;height:32px;font-size:14px}}.instrument-selector{background:linear-gradient(135deg,#2d2d44,#1a1a2e);border-radius:12px;padding:16px;margin-bottom:16px}.selector-title{margin:0 0 12px;color:#fff;font-size:14px;font-weight:600}.instrument-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.instrument-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;border-radius:10px;border:2px solid transparent;background:#ffffff0d;color:#ccc;cursor:pointer;transition:all .2s ease}.instrument-btn:hover{background:#ffffff1a;border-color:#fff3}.instrument-btn.selected{background:rgba(var(--instrument-color),.2);border-color:var(--instrument-color);color:#fff}.instrument-btn.selected .instrument-symbol{transform:scale(1.1)}.instrument-symbol{font-size:20px;color:var(--instrument-color);transition:transform .2s ease}.instrument-name{font-size:11px;text-align:center;line-height:1.2}@media(max-width:768px){.instrument-grid{grid-template-columns:repeat(3,1fr)}.instrument-btn{padding:8px 6px}.instrument-symbol{font-size:18px}.instrument-name{font-size:10px}}.measure-controls{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 16px;background:#ffffff0d;border-radius:10px;margin-bottom:16px;flex-wrap:wrap}.measure-count{color:#888;font-size:14px;font-weight:500}.measure-buttons{display:flex;gap:10px}.measure-btn{padding:8px 16px;border-radius:8px;border:none;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.measure-btn.add{background:#4caf5033;color:#4caf50;border:1px solid rgba(76,175,80,.4)}.measure-btn.add:hover{background:#4caf504d}.measure-btn.remove{background:#f4433633;color:#f44336;border:1px solid rgba(244,67,54,.4)}.measure-btn.remove:hover:not(:disabled){background:#f443364d}.measure-btn.remove:disabled{opacity:.4;cursor:not-allowed}@media(max-width:480px){.measure-controls{flex-direction:column;gap:10px}.measure-btn{padding:8px 12px;font-size:12px}}.tab-import-export-buttons{display:flex;gap:.5rem;margin-top:1rem}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;border:none;border-radius:8px;background:#3a3d56;color:#e0e0e0;font-size:.9rem;cursor:pointer;transition:all .2s ease}.tab-btn:hover:not(:disabled){background:#4a4d66}.tab-btn:disabled{opacity:.5;cursor:not-allowed}.tab-btn .btn-icon{font-size:1rem}.tab-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.tab-modal{background:#2a2d3e;border-radius:12px;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0006}.tab-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #3a3d56}.tab-modal-header h3{margin:0;font-size:1.1rem;color:#fff}.tab-modal-close{background:none;border:none;color:#888;font-size:1.5rem;cursor:pointer;line-height:1;padding:0}.tab-modal-close:hover{color:#fff}.tab-modal-content{padding:1.25rem;overflow-y:auto}.tab-preview{background:#1a1d2e;border-radius:8px;padding:1rem;font-family:Courier New,Courier,monospace;font-size:.85rem;line-height:1.5;color:#90ee90;overflow-x:auto;white-space:pre;margin:0 0 1rem}.tab-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.tab-action-btn{padding:.6rem 1.2rem;border:none;border-radius:8px;background:#3a3d56;color:#e0e0e0;font-size:.9rem;cursor:pointer;transition:all .2s ease}.tab-action-btn:hover:not(:disabled){background:#4a4d66}.tab-action-btn.primary{background:#4a90d9}.tab-action-btn.primary:hover:not(:disabled){background:#5aa0e9}.tab-action-btn:disabled{opacity:.5;cursor:not-allowed}.tab-import-help{margin:0 0 .75rem;color:#b0b0b0;font-size:.9rem}.tab-format-example{background:#1a1d2e;border-radius:8px;padding:.75rem 1rem;font-family:Courier New,Courier,monospace;font-size:.8rem;line-height:1.4;color:#888;margin:0 0 1rem;white-space:pre}.tab-import-textarea{width:100%;padding:1rem;border:1px solid #3a3d56;border-radius:8px;background:#1a1d2e;color:#e0e0e0;font-family:Courier New,Courier,monospace;font-size:.9rem;line-height:1.5;resize:vertical;margin-bottom:1rem}.tab-import-textarea:focus{outline:none;border-color:#4a90d9}.tab-import-textarea::placeholder{color:#666}.tab-import-errors{background:#ff64641a;border:1px solid rgba(255,100,100,.3);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem}.tab-import-errors p{margin:0;color:#ff6b6b;font-size:.85rem}.tab-import-errors p+p{margin-top:.25rem}@media(max-width:480px){.tab-import-export-buttons{flex-direction:column}.tab-modal{max-height:95vh}.tab-modal-actions{flex-direction:column}.tab-action-btn{width:100%}}*{box-sizing:border-box}body{margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);min-height:100vh;color:#fff}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{text-align:center;padding:30px 20px;background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 100%)}.app-header h1{margin:0;font-size:2.5rem;font-weight:800;display:flex;align-items:center;justify-content:center;gap:15px;background:linear-gradient(135deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}.header-icon{font-size:3rem;-webkit-text-fill-color:initial;animation:bounce 1s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.app-subtitle{margin:10px 0 0;font-size:1.2rem;color:#aaa}.app-main{flex:1;padding:0 20px 20px;max-width:1400px;margin:0 auto;width:100%}.current-song-header{text-align:center;margin-bottom:10px;display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.current-song-title{margin:0;font-size:1.5rem;color:#4caf50;font-weight:600}.edit-mode-btn{padding:10px 20px;border-radius:10px;border:2px solid #2196f3;background:#2196f31a;color:#2196f3;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.edit-mode-btn:hover{background:#2196f333}.edit-mode-btn.active{background:#4caf50;border-color:#4caf50;color:#fff}.no-song-selected{display:flex;align-items:center;justify-content:center;min-height:200px}.welcome-message{text-align:center;padding:40px;background:linear-gradient(135deg,#ffffff0d,#ffffff05);border-radius:20px;border:2px dashed #444}.welcome-icon{font-size:4rem;display:block;margin-bottom:16px;animation:wave 1.5s ease-in-out infinite}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}75%{transform:rotate(-20deg)}}.welcome-message h2{margin:0 0 10px;font-size:1.8rem;color:#fff}.welcome-message p{margin:0;color:#888;font-size:1.1rem}.app-panels{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}.panel{min-width:0}.sample-songs-section{margin-top:16px}.sample-songs-btn{width:100%;padding:14px 20px;border-radius:12px;border:none;background:linear-gradient(135deg,#ff6b6b,#ee5a5a);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 4px 15px #ff6b6b66}.sample-songs-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b6b99}.btn-icon{font-size:20px}.sample-songs-list{margin-top:12px;display:flex;flex-direction:column;gap:8px;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sample-song-item{width:100%;padding:12px 16px;border-radius:10px;border:2px solid transparent;background:#ffffff14;color:#fff;cursor:pointer;transition:all .2s ease;text-align:left;display:flex;flex-direction:column;gap:4px}.sample-song-item:hover{background:#ffffff26;border-color:#fff3}.sample-name{font-size:15px;font-weight:600}.sample-info{font-size:12px;color:#888}.app-footer{text-align:center;padding:20px;background:linear-gradient(0deg,rgba(0,0,0,.3) 0%,transparent 100%);color:#888}.app-footer p{margin:0;line-height:1.6}.footer-tip{color:#4caf50;font-weight:500}@media(max-width:900px){.app-panels{grid-template-columns:1fr}}@media(max-width:768px){.app-header h1{font-size:1.8rem}.header-icon{font-size:2.2rem}.app-subtitle{font-size:1rem}.welcome-message{padding:25px}.welcome-icon{font-size:3rem}.welcome-message h2{font-size:1.4rem}.current-song-title{font-size:1.2rem}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#ffffff0d;border-radius:5px}::-webkit-scrollbar-thumb{background:#fff3;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}::selection{background:#4caf5080;color:#fff}
