*{margin:0;padding:0;box-sizing:border-box}:root{--vida-50: #f3faeb;--vida-100: #e5f2d5;--vida-200: #cde7af;--vida-300: #acd680;--vida-400: #8dc457;--vida-500: #669c35;--vida-600: #54862a;--vida-700: #416724;--vida-800: #375222;--vida-900: #304720;--vida-950: #17260d;--primary-color: var(--vida-600);--primary-light: var(--vida-500);--primary-dark: var(--vida-700);--bg-dark: #0f172a;--bg-light: #f8fafc;--bg-white: #ffffff;--text-dark: #0f172a;--text-light: #f1f5f9;--border-color: #e2e8f0;--border-dark: #334155;--hover-color: #f1f5f9;--hover-dark: #1e293b}html,body,#root{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-light);color:var(--text-dark);overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}.app-container{display:flex;height:100vh;overflow:hidden;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.sidebar{width:280px;background-color:var(--bg-white);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden;transition:width .3s ease-in-out;box-shadow:0 2px 8px #0000000a}.sidebar.collapsed{width:0;border-right:none}.sidebar-header{padding:1.5rem;background:linear-gradient(135deg,var(--primary-dark),var(--primary-color));display:flex;justify-content:space-between;align-items:flex-start;border-bottom:none}.sidebar-header-content{display:flex;flex-direction:column;gap:.25rem}.sidebar-header h1{color:#fff;font-size:1.25rem;font-weight:700;line-height:1.2;font-family:Playfair Display,serif}.sidebar-attribution{color:#ffffffd9;font-size:.75rem;text-decoration:none;transition:all .2s;font-weight:500}.sidebar-attribution:hover{color:#fff}.sidebar-header-buttons{display:flex;gap:.5rem;align-items:center}.sidebar-collapse{display:flex;background:#fff3;border:none;color:#fff;cursor:pointer;padding:.5rem;width:32px;height:32px;border-radius:.375rem;transition:all .2s;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.sidebar-collapse:active{transform:scale(.95)}.sidebar-collapse:hover{background:#ffffff4d}.sidebar-close{display:none;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0;width:28px;height:28px;line-height:1;opacity:.8;transition:opacity .2s;-webkit-tap-highlight-color:transparent}.sidebar-close:active{transform:scale(.9)}.sidebar-close:hover{opacity:1}.sidebar-toggle{display:flex;align-items:center;justify-content:center;position:fixed;top:1rem;left:1rem;z-index:1001;background-color:var(--primary-color);border:none;border-radius:.5rem;padding:.5rem;cursor:pointer;box-shadow:0 2px 8px #00000026;transition:all .3s;color:#fff;min-width:44px;min-height:44px;-webkit-tap-highlight-color:transparent}.sidebar-toggle:hover{background-color:var(--primary-dark)}.sidebar-toggle:active{transform:scale(.95)}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:999}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-light);position:relative}.score-section{flex:0 0 66.666%;overflow-x:hidden;overflow-y:auto;background-color:var(--bg-white);padding:.5rem;position:relative;border-bottom:1px solid var(--border-color)}.resize-divider{flex:0 0 6px;background-color:var(--border-color);cursor:row-resize;transition:background-color .2s;position:relative;z-index:50}.resize-divider:hover{background-color:var(--primary-color)}.exercise-list{flex:1;overflow-y:auto;padding:1rem;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.exercise-list::-webkit-scrollbar{width:6px}.exercise-list::-webkit-scrollbar-track{background:transparent}.exercise-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.exercise-filters{padding:0 0 1rem;margin-bottom:1rem;border-bottom:1px solid var(--border-color)}.filter-label{display:block;font-size:.75rem;font-weight:700;margin-bottom:.5rem;color:var(--text-dark);text-transform:uppercase;letter-spacing:.5px}.filter-select{width:100%;padding:.625rem .75rem;border:1px solid var(--border-color);border-radius:.375rem;font-size:.875rem;background-color:#fff;cursor:pointer;transition:all .2s;color:var(--text-dark);-webkit-tap-highlight-color:transparent;min-height:44px}.filter-select:hover{border-color:var(--primary-color)}.filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #54862a1a}.exercise-item{padding:1rem;margin-bottom:.75rem;border:1px solid var(--border-color);border-radius:.5rem;cursor:pointer;transition:all .2s;background-color:#fff;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}.exercise-item:hover{background-color:var(--vida-50);border-color:var(--primary-color)}.exercise-item.selected{background-color:var(--vida-100);border-color:var(--primary-color);box-shadow:0 0 0 2px #54862a1a}.exercise-title{font-weight:600;font-size:.95rem;margin-bottom:.25rem;color:var(--text-dark)}.exercise-level{display:inline-block;padding:.25rem .5rem;border-radius:.25rem;font-size:.7rem;font-weight:700;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.3px}.exercise-level.beginner{background-color:#dcfce7;color:#166534}.exercise-level.intermediate{background-color:#fef3c7;color:#92400e}.exercise-level.advanced{background-color:#fee2e2;color:#991b1b}.exercise-description{font-size:.8rem;color:#64748b;line-height:1.4}.exercise-snapshot{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color);pointer-events:none;display:none}@media (min-width: 769px){.exercise-snapshot{display:block}}.snapshot-container{max-width:100%;overflow:hidden;border-radius:.25rem;background-color:#f8fafc;padding:.5rem;display:flex;justify-content:center;align-items:center;white-space:nowrap}.snapshot-container svg{max-width:100%;height:auto;display:inline-block;flex-shrink:0}.snapshot-loading,.snapshot-error{font-size:.7rem;color:#94a3b8;text-align:center;padding:.5rem;font-style:italic}.snapshot-error{color:#cbd5e1}.exercise-category{margin-bottom:.5rem}.category-header{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#54862a14;border-radius:8px;cursor:pointer;transition:all .2s;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.category-header:hover{background:#54862a26}.category-header:active{transform:scale(.99)}.category-toggle{font-size:.75rem;flex-shrink:0;transition:transform .2s}.category-toggle.expanded{transform:rotate(90deg)}.category-info{flex:1;min-width:0}.category-name{margin:0;font-size:.9rem;font-weight:700;color:var(--text-dark);display:flex;align-items:center;gap:.5rem}.exercise-count{background:var(--primary-color);color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.7rem;font-weight:700;flex-shrink:0}.category-exercises{margin-left:1.25rem;margin-top:.5rem;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.category-exercises .exercise-item{margin-bottom:.5rem}.exercise-main{cursor:pointer}.exercise-title-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.variations-badge{background:#54862a1f;color:var(--primary-dark);padding:.15rem .45rem;border-radius:10px;font-size:.7rem;font-weight:700;cursor:pointer;transition:all .2s;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;flex-shrink:0;line-height:1;display:inline-flex;align-items:center;gap:.2rem}.variations-badge:hover{background:#54862a33;transform:scale(1.05)}.variations-list{margin-left:1rem;margin-top:.25rem;margin-bottom:.5rem;padding-left:.5rem;border-left:2px solid rgba(84,134,42,.2);animation:slideDown .2s ease-out}.variation-item{background:#00000005;border-left:2px solid rgba(84,134,42,.3);margin-bottom:.375rem}.variation-item:hover{background:#54862a0d;border-left-color:var(--primary-color)}.variation-item.selected{background:#54862a1a;border-left-color:var(--primary-color)}.variation-arrow{color:var(--primary-color);font-weight:700;margin-right:.25rem}.loading-state,.empty-state{text-align:center;padding:2rem;color:#64748b}.score-viewer{display:flex;flex-direction:column;height:100%}.score-header{margin-bottom:.375rem;padding:.5rem .625rem;background:var(--bg-light);border:1px solid var(--border-color);border-radius:.375rem}.score-title{font-size:1.125rem;font-weight:700;color:var(--text-dark);margin-bottom:.375rem}.score-meta{display:flex;gap:1rem;font-size:.75rem;color:#64748b;margin-bottom:.375rem;flex-wrap:wrap}.score-meta-item{display:flex;gap:.25rem;align-items:center}.score-meta-label{font-weight:600;color:var(--text-dark)}.score-notes{padding:.375rem .5rem;background-color:var(--vida-50);border-left:2px solid var(--primary-color);border-radius:.25rem;font-size:.75rem;color:var(--primary-dark);line-height:1.3}.score-controls{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem;align-items:center}.control-group{display:flex;gap:.375rem;align-items:center;padding:.375rem .5rem;background-color:var(--bg-light);border-radius:.25rem;border:1px solid var(--border-color);transition:all .2s}.control-group:hover{border-color:var(--primary-color)}.controls-spacer{flex:1}.zoom-controls{flex-shrink:0}.zoom-controls button{min-width:32px;padding:.375rem .5rem}.control-group label{font-size:.75rem;font-weight:600;color:var(--text-dark);margin:0;white-space:nowrap}.playback-controls{background-color:var(--vida-50);border-color:var(--vida-200);flex-shrink:0}.playback-controls button{min-width:70px}.tempo-control{flex:1;min-width:140px;max-width:240px;flex-direction:column;align-items:stretch}.tempo-control label{margin-bottom:.25rem}.tempo-control input[type=range]{width:100%;height:5px;background:var(--vida-200);border-radius:2.5px;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.tempo-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:var(--primary-color);cursor:pointer;border-radius:50%;transition:all .2s}.tempo-control input[type=range]::-webkit-slider-thumb:hover{background:var(--primary-dark);transform:scale(1.1)}.tempo-control input[type=range]::-moz-range-thumb{width:14px;height:14px;background:var(--primary-color);cursor:pointer;border-radius:50%;border:none;transition:all .2s}.score-controls button{padding:.375rem .75rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.25rem;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}.score-controls button:active:not(:disabled){transform:scale(.98)}.score-controls button:hover:not(:disabled){background-color:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #54862a33}.score-controls button:disabled{opacity:.5;cursor:not-allowed}.score-controls button.active{background-color:#10b981}.score-controls button.active:hover{background-color:#059669}.score-container{flex:1;border:1px solid var(--border-color);border-radius:.375rem;padding:.375rem;background-color:#fff;overflow-x:hidden;overflow-y:auto;min-height:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.score-container::-webkit-scrollbar{width:8px;height:0}.score-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.score-container>div{width:100%;max-width:100%}.score-container svg{max-width:100%;height:auto}.score-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:#cbd5e1;font-size:1.125rem;text-align:center}.score-error{color:#ef4444}.tools-workspace{flex:1;background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:1rem;overflow:auto;position:relative;display:flex;flex-wrap:wrap;align-items:flex-start;gap:1rem;align-content:flex-start}.tools-workspace::-webkit-scrollbar{width:6px;height:6px}.tools-workspace::-webkit-scrollbar-track{background:transparent}.tools-workspace::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.tools-panel{position:absolute;background:#fff;border:1px solid var(--border-color);border-radius:.75rem;box-shadow:0 2px 8px #0000000f;display:flex;flex-direction:column;transition:box-shadow .2s;-webkit-user-select:none;user-select:none;min-width:300px;min-height:200px}.tools-panel:hover{box-shadow:0 4px 12px #0000001a}.tools-panel.dragging{opacity:.95;box-shadow:0 8px 20px #00000026;z-index:100}.tools-panel-header{padding:1rem;background:linear-gradient(135deg,var(--primary-dark),var(--primary-color));color:#fff;cursor:grab;border-radius:.75rem .75rem 0 0;display:flex;justify-content:space-between;align-items:center;gap:.75rem;font-weight:600}.tools-panel-header:active{cursor:grabbing}.tools-panel-title{font-size:.95rem;font-weight:600}.tools-panel-close{background:#fff3;border:none;color:#fff;cursor:pointer;padding:.375rem;border-radius:.25rem;transition:all .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.tools-panel-close:hover{background:#ffffff4d}.tools-panel-close svg{width:18px;height:18px;stroke:#fff;stroke-width:2}.tools-panel-content{flex:1;padding:1.5rem;overflow:auto;color:var(--text-light)}.tools-panel-content::-webkit-scrollbar{width:6px}.tools-panel-content::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:3px}.tools-add-button{position:fixed;bottom:1.5rem;right:1.5rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:50%;width:56px;height:56px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #54862a4d;transition:all .2s;z-index:50;padding:0}.tools-add-button:hover{background-color:var(--primary-dark);transform:scale(1.1);box-shadow:0 6px 16px #54862a66}.tools-add-button svg{width:28px;height:28px}.tools-menu{position:fixed;bottom:80px;right:20px;background:#fff;border:1px solid var(--border-color);border-radius:.75rem;box-shadow:0 4px 16px #0000001f;z-index:150;display:flex;flex-direction:column;gap:.5rem;padding:.75rem}.tools-menu-item{padding:.75rem;border:none;background:none;cursor:pointer;width:auto;height:48px;display:flex;align-items:center;justify-content:center;color:var(--text-dark);transition:all .2s;border-radius:.5rem;position:relative}.tools-menu-item:hover{background-color:var(--vida-50);color:var(--primary-dark)}.tools-menu-item svg{width:32px;height:32px;stroke:currentColor}.metronome{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.bpm-display{font-size:3rem;font-weight:700;margin:0}.bpm-label{font-size:.75rem;color:#94a3b8;margin:0;text-transform:uppercase;letter-spacing:.5px}.bpm-slider{width:100%;min-height:80px;display:flex;flex-direction:column;align-items:center;gap:.75rem}.bpm-slider input[type=range]{width:100%;height:6px;background:#334155;border-radius:3px;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none}.bpm-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:var(--vida-400);cursor:pointer;border-radius:50%;transition:all .2s}.bpm-slider input[type=range]::-webkit-slider-thumb:hover{background:var(--vida-500);transform:scale(1.15)}.bpm-slider input[type=range]::-moz-range-thumb{width:18px;height:18px;background:var(--vida-400);cursor:pointer;border-radius:50%;border:none}.metronome-controls{display:flex;gap:1rem;align-items:center;width:100%;justify-content:center}.metronome-controls button{padding:.75rem 1.5rem;background-color:var(--vida-400);color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s}.metronome-controls button:hover{background-color:var(--vida-500);transform:translateY(-2px)}.metronome-controls button.playing{background-color:#ef4444}.metronome-controls button.playing:hover{background-color:#dc2626}.time-signature-select{padding:.5rem .75rem;background-color:#334155;color:#fff;border:1px solid #475569;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:all .2s}.time-signature-select:hover{border-color:var(--vida-400)}.beat-indicator{width:60px;height:60px;border-radius:50%;background-color:#334155;transition:all .1s;display:flex;align-items:center;justify-content:center}.beat-indicator.active{background-color:var(--vida-400);transform:scale(1.15);box-shadow:0 0 20px #8dc45799}.tuner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.tuner-display{text-align:center}.detected-note{font-size:3.5rem;font-weight:700;margin-bottom:.5rem}.frequency-display{font-size:1.125rem;color:#94a3b8}.tuner-gauge{width:100%;height:80px;background:linear-gradient(to right,#ef4444,#f97316,#fbbf24 40%,#22c55e 48%,#22c55e 52%,#fbbf24 60%,#f97316,#ef4444);border-radius:.5rem;position:relative;margin-bottom:1.5rem;overflow:visible;box-shadow:inset 0 2px 8px #0000004d}.gauge-marks{position:absolute;top:100%;left:0;right:0;height:20px;margin-top:.5rem}.gauge-mark{position:absolute;transform:translate(-50%);font-size:.7rem;color:#94a3b8;font-weight:500}.gauge-mark.center{color:#22c55e;font-weight:700}.gauge-center{position:absolute;left:50%;top:0;bottom:0;width:3px;background-color:#fff;transform:translate(-50%);box-shadow:0 0 8px #fff9;z-index:1}.gauge-center:before,.gauge-center:after{content:"";position:absolute;left:50%;transform:translate(-50%);width:2px;height:12px;background-color:#fff6}.gauge-center:before{top:-12px}.gauge-center:after{bottom:-12px}.gauge-needle{position:absolute;top:50%;left:50%;width:0;height:0;transform:translate(-50%) translateY(-50%);transition:left .15s ease-out;z-index:2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.gauge-needle:before{content:"";position:absolute;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:50px solid #fff;top:-45px}.gauge-needle:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;background-color:#fff;border-radius:50%;border:2px solid #1e293b}.tuner-status{font-size:1.125rem;font-weight:600}.tuner-status.in-tune{color:#22c55e}.tuner-status.out-of-tune{color:#fbbf24}.tuner-controls{width:100%;display:flex;justify-content:center}.tuner-controls button{padding:.75rem 1.5rem;background-color:var(--vida-400);color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s}.tuner-controls button:hover{background-color:var(--vida-500)}.tuner-controls button.active{background-color:#ef4444}.tuner-controls button.active:hover{background-color:#dc2626}.tuner-error{color:#f87171;text-align:center}.drone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.drone-header{text-align:center}.drone-header h3{font-size:1.25rem;font-weight:700;margin:0}.drone-subtitle{font-size:.75rem;color:#94a3b8;margin:.5rem 0 0}.drone-display{display:flex;flex-direction:column;align-items:center}.drone-indicator{width:80px;height:80px;border-radius:50%;background-color:#334155;display:flex;align-items:center;justify-content:center;gap:.4rem;margin-bottom:1rem;position:relative;transition:all .3s}.drone-indicator.playing{background-color:var(--vida-400);box-shadow:0 0 30px #8dc45780}.drone-wave{width:6px;height:30px;background-color:#ffffff4d;border-radius:3px;transition:all .3s}.drone-indicator.playing .drone-wave{background-color:#fff;animation:wave .8s ease-in-out infinite}.drone-indicator.playing .drone-wave:nth-child(1){animation-delay:0s}.drone-indicator.playing .drone-wave:nth-child(2){animation-delay:.2s}.drone-indicator.playing .drone-wave:nth-child(3){animation-delay:.4s}@keyframes wave{0%,to{height:30px}50%{height:60px}}.selected-note{font-size:1.75rem;font-weight:700}.drone-mode-toggle{display:flex;gap:.5rem;width:100%}.mode-toggle-btn{flex:1;padding:.5rem 1rem;background-color:#1e293b;border:2px solid #334155;border-radius:.375rem;color:#94a3b8;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.mode-toggle-btn:hover:not(:disabled){border-color:var(--vida-400);color:var(--text-light)}.mode-toggle-btn.active{background-color:var(--vida-400);border-color:var(--vida-400);color:#fff}.mode-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.drone-main-controls{display:flex;flex-direction:column;gap:.75rem;width:100%}.drone-control-row{display:flex;align-items:center;gap:.75rem}.drone-label{font-size:.8rem;font-weight:600;color:#94a3b8;min-width:60px;text-align:right}.note-select-large{flex:1;padding:.625rem .75rem;background-color:#1e293b;border:2px solid #334155;border-radius:.375rem;color:var(--text-light);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.note-select-large:hover:not(:disabled){border-color:var(--vida-400)}.note-select-large:focus{outline:none;border-color:var(--vida-400);box-shadow:0 0 0 3px #8dc45726}.note-select-large:disabled{opacity:.5;cursor:not-allowed}.note-select-large option{background-color:#1e293b;color:#fff}.drone-controls{display:flex;justify-content:center;width:100%}.drone-play-btn{padding:.75rem 1.5rem;background-color:var(--vida-400);color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s}.drone-play-btn:hover{background-color:var(--vida-500);transform:translateY(-2px)}.drone-play-btn.playing{background-color:#ef4444}.drone-play-btn.playing:hover{background-color:#dc2626}.drone-info-compact{text-align:center;font-size:.75rem;color:#94a3b8;padding:.75rem 1rem;background-color:#8dc4571a;border-radius:.375rem;border:1px solid rgba(141,196,87,.2);width:100%}.app-container.focus-mode .sidebar,.app-container.focus-mode .tools-workspace{display:none}.focus-controls{display:flex;gap:.5rem;position:absolute;top:1rem;right:1rem;z-index:10;background-color:#fffffff2;padding:.75rem;border-radius:.5rem;box-shadow:0 2px 8px #0000001a}.focus-control-group{display:flex;gap:.375rem;align-items:center;padding:.25rem;background-color:#f8fafc;border-radius:.375rem;border:1px solid var(--border-color)}.tempo-display{font-size:.75rem;font-weight:600;color:#475569;padding:0 .5rem}.focus-controls button{padding:.5rem 1rem;background-color:#fff;color:var(--text-dark);border:1px solid var(--border-color);border-radius:.375rem;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .2s}.focus-controls button:hover:not(:disabled){background-color:var(--hover-color);border-color:var(--primary-color)}.focus-controls button:disabled{opacity:.5;cursor:not-allowed}.focus-controls button.active{background-color:#10b981;color:#fff;border-color:#10b981}.focus-controls button.active:hover{background-color:#059669;border-color:#059669}.focus-button{background-color:var(--primary-color)!important;color:#fff!important;border:none!important;flex-shrink:0;white-space:nowrap}.focus-button:hover{background-color:var(--primary-dark)!important}.focus-button.active{background-color:var(--primary-color)!important}.focus-button.active:hover{background-color:var(--primary-dark)!important}.score-viewer.focus-mode{height:100%}.score-viewer.focus-mode .score-container{height:100%;border:none;border-radius:0;padding:2rem}.ios-audio-notice{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 12px #00000026;animation:slideDown .4s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.ios-audio-notice-content{display:flex;align-items:center;gap:1rem;padding:.875rem 1.25rem;max-width:1200px;margin:0 auto}.ios-audio-notice-icon{font-size:1.5rem;flex-shrink:0;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.ios-audio-notice-text{flex:1;color:#fff;font-size:.9rem;line-height:1.4;text-shadow:0 1px 2px rgba(0,0,0,.2)}.ios-audio-notice-text strong{font-weight:700}.ios-audio-notice-dismiss{background:#fff3;border:none;color:#fff;font-size:1.25rem;font-weight:600;cursor:pointer;padding:.25rem .625rem;border-radius:.375rem;transition:all .2s;flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;line-height:1;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none}.ios-audio-notice-dismiss:hover{background:#ffffff4d}.ios-audio-notice-dismiss:active{transform:scale(.95)}.app-container.with-ios-notice{padding-top:60px}@media (max-width: 768px){.ios-audio-notice-content{padding:.75rem 1rem;gap:.75rem}.ios-audio-notice-icon{font-size:1.25rem}.ios-audio-notice-text{font-size:.8rem}.ios-audio-notice-dismiss{width:28px;height:28px;font-size:1.125rem}.ios-audio-notice{padding-top:env(safe-area-inset-top)}}@media (max-width: 480px){.ios-audio-notice-content{padding:.625rem .875rem;gap:.625rem}.ios-audio-notice-icon{font-size:1.125rem}.ios-audio-notice-text{font-size:.75rem;line-height:1.3}.ios-audio-notice-dismiss{width:24px;height:24px;font-size:1rem;padding:.125rem .5rem}}@media (max-width: 768px){.app-container{flex-direction:column}.sidebar{position:fixed;top:0;left:0;height:100vh;height:100dvh;width:85%;max-width:320px;transform:translate(-100%);transition:transform .3s ease-in-out;z-index:1000;box-shadow:2px 0 8px #00000026;opacity:1;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.sidebar.open{transform:translate(0)}.sidebar-overlay,.sidebar-close{display:block}.sidebar-header{padding:1.25rem}.sidebar-header h1{font-size:1.125rem;font-family:Playfair Display,serif}.main-content{height:100vh;height:100dvh;width:100%}.score-section{padding:.25rem;padding-top:calc(3.25rem + env(safe-area-inset-top))}.sidebar-toggle{top:calc(.5rem + env(safe-area-inset-top));left:calc(.5rem + env(safe-area-inset-left));padding:.5rem;box-shadow:0 2px 12px #0003;min-width:40px;min-height:40px}.score-header{padding:.375rem .5rem;margin-bottom:.25rem;border-radius:.25rem}.score-title{font-size:.95rem;margin-bottom:.125rem;line-height:1.3}.score-meta{flex-direction:row;gap:.5rem;font-size:.65rem;margin-bottom:.125rem}.score-notes{padding:.375rem .5rem;font-size:.65rem;line-height:1.2}.score-controls{flex-direction:row;gap:.25rem;margin-bottom:.25rem;flex-wrap:wrap}.control-group{padding:.25rem .375rem;flex:0 1 auto;min-width:auto}.control-group label{font-size:.65rem;margin:0}.playback-controls{flex:0 0 auto;gap:.25rem}.playback-controls button{padding:.375rem .5rem;font-size:.7rem;min-width:50px;min-height:36px}.tempo-control{flex:1 1 120px;min-width:120px;max-width:160px;padding:.25rem .375rem}.tempo-control label{font-size:.65rem;margin-bottom:.125rem}.zoom-controls{flex:0 0 auto;gap:.25rem;padding:.25rem}.zoom-controls label{display:none}.zoom-controls button{padding:.375rem .5rem;min-width:32px;min-height:36px;font-size:.75rem}.controls-spacer{display:none}.focus-button{flex:0 0 auto;padding:.375rem .625rem!important;font-size:.7rem!important;min-height:36px!important;white-space:nowrap}.focus-controls{top:calc(.5rem + env(safe-area-inset-top));right:calc(.5rem + env(safe-area-inset-right));left:auto;padding:.25rem;flex-direction:row;gap:.25rem;align-items:center;flex-wrap:wrap}.focus-control-group{gap:.25rem;padding:.125rem}.focus-controls button{padding:.375rem .5rem;font-size:.7rem;min-height:36px;min-width:32px}.focus-controls button:active:not(:disabled){transform:scale(.97)}.tempo-display{font-size:.65rem;padding:0 .375rem;white-space:nowrap}.score-container{padding:.25rem;border-radius:.25rem;flex:1;min-height:0}.score-viewer{height:100%;display:flex;flex-direction:column}.exercise-list{padding:.75rem}.exercise-category{margin-bottom:.625rem}.category-header{padding:.625rem;gap:.5rem}.category-name{font-size:.85rem}.exercise-count{font-size:.65rem;padding:.2rem .4rem}.category-exercises{margin-left:.75rem;margin-top:.375rem}.exercise-item{padding:.875rem;margin-bottom:.625rem}.exercise-title{font-size:.9rem}.exercise-description{font-size:.75rem}.variations-badge{font-size:.6rem;padding:.125rem .35rem}.variations-list{margin-left:.5rem;padding-left:.375rem}.variation-item{padding:.75rem}.exercise-filters{padding:0 0 .75rem;margin-bottom:.75rem}.filter-label{font-size:.7rem}.filter-select{padding:.625rem;font-size:.8rem;min-height:44px}.tools-panel{min-width:280px;min-height:200px}.tools-add-button{width:48px;height:48px;font-size:1.25rem}.score-viewer.focus-mode .score-container{padding:.5rem}}@media (max-width: 480px){.sidebar{width:90%;max-width:100%}.sidebar-header{padding:1rem}.sidebar-header h1{font-size:1rem;font-family:Playfair Display,serif}.sidebar-attribution{font-size:.7rem}.score-section{padding:.25rem;padding-top:calc(3rem + env(safe-area-inset-top))}.score-title{font-size:.9rem}.score-meta{font-size:.6rem}.score-notes{font-size:.6rem;padding:.25rem .375rem}.score-header{padding:.25rem .375rem;margin-bottom:.25rem}.playback-controls button{font-size:.65rem;padding:.25rem .375rem;min-width:45px;min-height:32px}.tempo-control{min-width:100px}.tempo-control label{font-size:.6rem}.zoom-controls button{padding:.25rem .375rem;min-width:28px;min-height:32px;font-size:.7rem}.focus-button{padding:.25rem .5rem!important;font-size:.65rem!important;min-height:32px!important}.focus-controls{padding:.25rem;gap:.25rem}.focus-controls button{padding:.25rem .375rem;font-size:.65rem;min-height:32px;min-width:28px}.tempo-display{font-size:.6rem;padding:0 .25rem}.category-header{padding:.5rem;gap:.375rem}.category-name{font-size:.8rem}.category-toggle{font-size:.7rem}.exercise-count{font-size:.6rem;padding:.2rem .375rem}.category-exercises{margin-left:.5rem}.exercise-item{padding:.75rem}.exercise-title{font-size:.85rem}.exercise-level{font-size:.65rem;padding:.2rem .4rem}.exercise-description{font-size:.7rem}.variations-badge{font-size:.55rem;padding:.1rem .3rem}.variations-list{margin-left:.375rem;padding-left:.25rem}}@media (max-width: 768px) and (orientation: landscape){.score-section{padding:.25rem;padding-left:calc(3rem + env(safe-area-inset-left));padding-right:env(safe-area-inset-right)}.sidebar-toggle{top:calc(.375rem + env(safe-area-inset-top));left:calc(.375rem + env(safe-area-inset-left));padding:.375rem;min-width:36px;min-height:36px}.focus-controls{flex-direction:row;top:calc(.25rem + env(safe-area-inset-top));right:calc(.25rem + env(safe-area-inset-right));left:auto;padding:.25rem;gap:.25rem}.focus-control-group{width:auto;padding:.125rem;gap:.25rem}.focus-controls button{padding:.25rem .375rem;font-size:.65rem;min-height:32px;min-width:28px}.score-controls{flex-direction:row;flex-wrap:wrap;gap:.25rem;margin-bottom:.25rem}.control-group{width:auto;flex:0 1 auto;padding:.25rem .375rem}.playback-controls{flex:0 0 auto;gap:.25rem}.playback-controls button{padding:.25rem .375rem;font-size:.65rem;min-width:45px;min-height:32px}.tempo-control{flex:1 1 120px;min-width:100px;max-width:160px;padding:.25rem .375rem}.tempo-control label{font-size:.6rem}.zoom-controls{flex:0 0 auto;gap:.25rem;padding:.25rem}.zoom-controls label{display:none}.zoom-controls button{padding:.25rem .375rem;min-width:28px;min-height:32px;font-size:.7rem}.controls-spacer{display:none}.focus-button{flex:0 0 auto;width:auto!important;padding:.25rem .5rem!important;font-size:.65rem!important;min-height:32px!important}.score-header{padding:.25rem .375rem;margin-bottom:.25rem}.score-title{font-size:.85rem;margin-bottom:.125rem}.score-meta{font-size:.6rem;flex-direction:row;gap:.5rem}.score-notes{font-size:.6rem;padding:.25rem .375rem}.tempo-display{font-size:.6rem}}@media (min-width: 769px) and (max-width: 1024px) and (orientation: portrait){.sidebar{position:fixed;top:0;left:0;height:100vh;height:100dvh;width:320px;transform:translate(-100%);transition:transform .3s ease-in-out;z-index:1000;box-shadow:2px 0 8px #00000026;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.sidebar.open{transform:translate(0)}.sidebar-overlay,.sidebar-close{display:block}.main-content{width:100%;height:100vh;height:100dvh}.score-section{padding:1rem;padding-top:calc(4rem + env(safe-area-inset-top));padding-left:1rem}.sidebar-toggle{top:calc(1rem + env(safe-area-inset-top));left:calc(1rem + env(safe-area-inset-left))}.score-controls{flex-wrap:wrap}.control-group{min-width:200px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:#fff;border-radius:1rem;box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{background:linear-gradient(135deg,var(--primary-dark),var(--primary-color));padding:2rem;text-align:center}.modal-header h2{color:#fff;font-size:1.75rem;font-weight:700;margin:0}.modal-body{padding:2rem;color:var(--text-dark)}.modal-body p{margin:0 0 1rem;line-height:1.6;font-size:1rem}.modal-body p:last-child{margin-bottom:0}.modal-footer{padding:1.5rem 2rem;background-color:var(--bg-light);display:flex;justify-content:center}.modal-button{padding:.75rem 2rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 2px 8px #54862a4d;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;min-height:44px}.modal-button:active{transform:scale(.98)}.modal-button:hover{background-color:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #54862a66}.modal-button:active{transform:translateY(0)}@media (max-width: 768px){.modal-content{width:95%;max-width:none;margin:1rem}.modal-header{padding:1.5rem}.modal-header h2{font-size:1.5rem}.modal-body{padding:1.5rem}.modal-body p{font-size:.95rem}.modal-footer{padding:1rem 1.5rem}.modal-button{width:100%;padding:.875rem 1.5rem}}@media (max-width: 480px){.modal-content{width:calc(100% - 2rem);margin:1rem}.modal-header{padding:1.25rem}.modal-header h2{font-size:1.375rem}.modal-body{padding:1.25rem}.modal-body p{font-size:.9rem}.modal-footer{padding:1rem 1.25rem}}.homepage{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:2rem;display:flex;flex-direction:column;align-items:center}.homepage-header{text-align:center;margin-bottom:3rem;max-width:800px}.homepage-header h1{font-size:3rem;font-weight:900;color:var(--text-dark);margin-bottom:.5rem;background:linear-gradient(135deg,var(--primary-dark),var(--primary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-family:Playfair Display,serif;letter-spacing:-.02em}.homepage-subtitle{font-size:1.25rem;color:#64748b;margin:0}.notebooks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;width:100%;max-width:1200px;padding:1rem}.notebook{position:relative;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;perspective:1000px;height:320px}.notebook:hover{transform:translateY(-8px) rotateY(-5deg)}.notebook:active{transform:translateY(-4px) rotateY(-2deg)}.notebook-coming-soon{cursor:not-allowed;opacity:.7}.notebook-coming-soon:hover{transform:translateY(-4px) rotateY(-2deg)}.notebook-coming-soon:active{transform:translateY(-2px) rotateY(-1deg)}.notebook-cover{width:100%;height:100%;background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid var(--border-color);border-radius:8px;padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;box-shadow:0 4px 12px #0000001a;transition:all .3s ease;position:relative;overflow:hidden}.notebook-cover:before{content:"";position:absolute;left:0;top:0;bottom:0;width:8px;background:var(--notebook-color, var(--primary-color));border-radius:8px 0 0 8px}.notebook:hover .notebook-cover{box-shadow:0 8px 24px #00000026;border-color:var(--notebook-color, var(--primary-color))}.notebook-spine{position:absolute;left:-12px;top:20px;bottom:20px;width:12px;background:linear-gradient(180deg,var(--notebook-color, var(--primary-color)) 0%,rgba(0,0,0,.3) 100%);border-radius:4px 0 0 4px;box-shadow:-2px 0 8px #0003;z-index:-1}.notebook-icon{font-size:4rem;margin-bottom:.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.notebook-title{font-size:1.25rem;font-weight:700;color:var(--text-dark);text-align:center;margin-bottom:.5rem}.notebook-count{font-size:.875rem;color:#64748b;text-align:center}.coming-soon-badge{position:absolute;top:1rem;right:1rem;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:.375rem .75rem;border-radius:1rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #f59e0b66;z-index:10;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.homepage-empty{text-align:center;padding:3rem;color:#64748b;font-size:1.125rem}.homepage-footer{margin-top:auto;padding:2rem 1rem;text-align:center;border-top:1px solid var(--border-color);width:100%;max-width:1200px}.homepage-footer p{margin:0;color:#64748b;font-size:.875rem}.homepage-footer a{color:var(--primary-color);text-decoration:none;font-weight:600;transition:color .2s}.homepage-footer a:hover{color:var(--primary-dark);text-decoration:underline}.home-button{background:#fff3;border:none;color:#fff;cursor:pointer;padding:.5rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:600;transition:all .2s;margin-bottom:.5rem;-webkit-tap-highlight-color:transparent;text-decoration:none;display:inline-block}.home-button:hover{background:#ffffff4d;transform:translate(-2px)}.home-button:active{transform:translate(0)}@media (max-width: 768px){.homepage{padding:1.5rem 1rem}.homepage-header h1{font-size:2rem;font-family:Playfair Display,serif}.homepage-subtitle{font-size:1rem}.notebooks-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem;padding:.5rem}.notebook{height:280px}.notebook-cover{padding:1.5rem}.notebook-icon{font-size:3rem}.notebook-title{font-size:1.125rem}.homepage-footer{padding:1.5rem 1rem;margin-top:2rem}.homepage-footer p{font-size:.8rem}}@media (max-width: 480px){.homepage-header h1{font-size:1.75rem;font-family:Playfair Display,serif}.notebooks-grid{grid-template-columns:1fr;gap:1rem}.notebook{height:260px}.notebook-cover{padding:1.25rem}.notebook-icon{font-size:2.5rem}.homepage-footer{padding:1.25rem .875rem;margin-top:1.5rem}.homepage-footer p{font-size:.75rem}}
