:root{--bg-primary: #ffffff;--bg-secondary: #f9f9f9;--bg-tertiary: #f8f8f8;--text-primary: #213547;--text-secondary: #666;--text-tertiary: #999;--border-color: #ddd;--border-color-light: #e0e0e0;--button-bg: #007bff;--button-bg-hover: #0056b3;--button-bg-secondary: #6c757d;--button-bg-secondary-hover: #545b62;--button-bg-danger: #d32f2f;--button-bg-danger-hover: #b71c1c;--navbar-bg: #f8f8f8;--navbar-text: #666;--navbar-active: #007bff;--input-bg: #ffffff;--input-border: #ddd;--input-text: #333;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root.dark{--bg-primary: #1a1a1a;--bg-secondary: #242424;--bg-tertiary: #2d2d2d;--text-primary: #ffffff;--text-secondary: #b0b0b0;--text-tertiary: #808080;--border-color: #444;--border-color-light: #555;--button-bg: #0d6efd;--button-bg-hover: #0a58ca;--button-bg-secondary: #6c757d;--button-bg-secondary-hover: #5a6268;--button-bg-danger: #e74c3c;--button-bg-danger-hover: #c0392b;--navbar-bg: #2d2d2d;--navbar-text: #b0b0b0;--navbar-active: #0d6efd;--input-bg: #2a2a2a;--input-border: #444;--input-text: #ffffff}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s,color .3s;height:100vh;width:100vw}a{font-weight:500;color:var(--button-bg);text-decoration:inherit}a:hover{color:var(--button-bg-hover)}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .25s,background-color .3s,color .3s}button:hover{border-color:var(--button-bg)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.card{padding:2em}#app{width:inherit;height:inherit;min-height:100vh;background-color:var(--bg-primary);transition:background-color .3s}.dark-mode-toggle{position:fixed;top:1rem;right:1rem;z-index:1000;background-color:var(--button-bg);color:#fff;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:1.2rem;box-shadow:0 2px 8px #00000026}.dark-mode-toggle:hover{background-color:var(--button-bg-hover);transform:scale(1.1);box-shadow:0 4px 12px #00000040}.dark-mode-toggle:active{transform:scale(.95)}.btn{padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;font-weight:500;min-width:120px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--button-bg);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--button-bg-hover);transform:translateY(-2px);box-shadow:0 4px 8px #007bff4d}.btn-secondary{background-color:var(--button-bg-secondary);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--button-bg-secondary-hover);transform:translateY(-2px);box-shadow:0 4px 8px #6c757d4d}.btn-danger{background-color:var(--button-bg-danger);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--button-bg-danger-hover);transform:translateY(-2px);box-shadow:0 4px 8px #d32f2f4d}@media(max-width:768px){h1{font-size:2em}.dark-mode-toggle{top:.75rem;right:.75rem;width:40px;height:40px;font-size:1rem}}.app-container[data-v-28f4e0f5]{display:flex;flex-direction:column;width:inherit;margin:0;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s,color .3s}.navbar[data-v-28f4e0f5]{display:flex;justify-content:center;width:100%;padding:1rem 0;background-color:var(--navbar-bg);border-bottom:1px solid var(--border-color);transition:background-color .3s,border-color .3s}.nav-link[data-v-28f4e0f5]{padding:.5rem 1.5rem;font-size:1.2rem;border:none;background-color:transparent;cursor:pointer;transition:color .3s,border-bottom .3s;color:var(--navbar-text);border-bottom:2px solid transparent;text-decoration:none;display:inline-block}.nav-link[data-v-28f4e0f5]:hover{color:var(--navbar-active)}.nav-link.active[data-v-28f4e0f5]{color:var(--navbar-active);border-bottom:2px solid var(--navbar-active)}main[data-v-28f4e0f5]{width:100%;padding:1rem;flex:1;background-color:var(--bg-primary);transition:background-color .3s}@media(max-width:768px){.navbar[data-v-28f4e0f5]{padding:.75rem 0}.nav-link[data-v-28f4e0f5]{padding:.4rem 1rem;font-size:1rem}main[data-v-28f4e0f5]{padding:.5rem}}.container[data-v-12ed6d2e]{display:flex;flex-direction:column;align-items:center;margin-top:2rem;padding:2rem}.container h1[data-v-12ed6d2e]{color:var(--text-primary);margin-bottom:1.5rem}.btn[data-v-12ed6d2e]{margin-bottom:1.5rem}.note-display[data-v-12ed6d2e]{text-align:center;background-color:var(--bg-secondary);border-radius:8px;padding:1.5rem;margin-top:1rem;border:1px solid var(--border-color-light);color:var(--text-primary)}.note-display h2[data-v-12ed6d2e]{margin-top:0;color:var(--text-primary);font-size:1.5rem}.note-display p[data-v-12ed6d2e]{margin:.5rem 0;color:var(--text-secondary);font-family:monospace}canvas[data-v-12ed6d2e]{border:2px solid var(--border-color);border-radius:6px;margin:1rem 0;background-color:var(--bg-secondary)}.chord-mode-container[data-v-95a1aa2a]{display:flex;flex-direction:column;align-items:center}.controls[data-v-95a1aa2a]{margin-bottom:2rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.neck-container[data-v-95a1aa2a]{display:flex;align-items:center;margin:2rem auto;width:95%;max-width:1100px}.string-names[data-v-95a1aa2a]{display:flex;flex-direction:column;justify-content:space-around;height:240px;padding-right:10px;font-family:monospace;font-size:1.2rem;color:#333}.string-name[data-v-95a1aa2a]{text-align:center;cursor:pointer;padding:.25rem;border-radius:4px}.string-name[data-v-95a1aa2a]:hover{background-color:#f0f0f0}.string-name.muted[data-v-95a1aa2a]{color:#ccc;text-decoration:line-through;background-color:#fafafa}.guitar-neck[data-v-95a1aa2a]{display:flex;flex-direction:column;border:2px solid #000;border-radius:5px;width:100%;background-color:#6b4226}.string[data-v-95a1aa2a]{display:flex;position:relative}.string.muted[data-v-95a1aa2a]{opacity:.5}.string[data-v-95a1aa2a]:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:#d3d3d3;transform:translateY(-50%);z-index:0;pointer-events:none}.fret[data-v-95a1aa2a]{height:40px;flex-grow:1;border-right:2px solid #aaa;box-sizing:border-box;cursor:pointer;position:relative;z-index:1}.fret[data-v-95a1aa2a]:first-child{border-left:5px solid #000}.fret[data-v-95a1aa2a]:hover{background-color:#fff3}.fret.selected[data-v-95a1aa2a]{background-color:#007bff80;outline:2px solid #007bff;outline-offset:-2px}.fret-marker[data-v-95a1aa2a]{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background-color:#ddd;border-radius:50%;z-index:0}.fret-marker.double[data-v-95a1aa2a]{top:25%}.fret-marker.double[data-v-95a1aa2a]:after{content:"";position:absolute;top:20px;left:0;width:10px;height:10px;background-color:#ddd;border-radius:50%}.recorder-container[data-v-9a479a86]{display:flex;flex-direction:column;width:100%;padding:2rem;max-width:1200px;margin:0 auto}.recorder-header[data-v-9a479a86]{margin-bottom:2rem;text-align:center}.recorder-header h1[data-v-9a479a86]{margin:0;font-size:2rem;color:var(--text-primary)}.recording-section[data-v-9a479a86]{background-color:var(--bg-secondary);border-radius:8px;padding:2rem;margin-bottom:2rem;border:1px solid var(--border-color-light);transition:background-color .3s,border-color .3s}.recording-controls[data-v-9a479a86]{display:flex;flex-direction:column;gap:1rem;align-items:center}.recording-status[data-v-9a479a86]{display:flex;align-items:center;gap:.75rem;font-size:1.2rem;font-weight:600;color:#d32f2f}.recording-indicator[data-v-9a479a86]{width:12px;height:12px;border-radius:50%;background-color:#d32f2f;animation:pulse-9a479a86 1s infinite}@keyframes pulse-9a479a86{0%,to{opacity:1}50%{opacity:.5}}.duration[data-v-9a479a86]{font-family:monospace;font-size:1.1rem;color:var(--text-secondary)}.button-group[data-v-9a479a86]{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.error-message[data-v-9a479a86]{padding:.75rem 1rem;background-color:#ffebee;color:#c62828;border-radius:4px;border-left:4px solid var(--button-bg-danger)}:root.dark .error-message[data-v-9a479a86]{background-color:#3e2a2a;color:#ff6b6b}:root.dark .btn-playback[data-v-9a479a86]{background-color:#1e90ff;box-shadow:0 2px 8px #1e90ff33}:root.dark .btn-playback[data-v-9a479a86]:hover:not(:disabled){background-color:#0078ff;box-shadow:0 4px 12px #1e90ff4d}:root.dark .btn-playback.active[data-v-9a479a86]{background-color:#ff9800;box-shadow:0 2px 8px #ff980033}:root.dark .btn-playback.active[data-v-9a479a86]:hover:not(:disabled){background-color:#fa3;box-shadow:0 4px 12px #ff98004d}.recordings-section[data-v-9a479a86]{background-color:var(--bg-primary);border-radius:8px;padding:2rem;border:1px solid var(--border-color-light)}.recordings-section h2[data-v-9a479a86]{margin-top:0;color:var(--text-primary);font-size:1.5rem}.storage-info[data-v-9a479a86]{margin:1.5rem 0;padding:1rem;background-color:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-color-light)}.storage-usage[data-v-9a479a86]{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.95rem}.storage-usage .label[data-v-9a479a86]{color:var(--text-secondary);font-weight:500}.storage-usage .value[data-v-9a479a86]{color:var(--text-primary);font-weight:600;font-family:monospace}.storage-bar[data-v-9a479a86]{height:8px;background-color:var(--bg-primary);border-radius:4px;overflow:hidden;border:1px solid var(--border-color-light)}.storage-fill[data-v-9a479a86]{height:100%;background-color:#4caf50;transition:width .3s ease,background-color .3s ease}.storage-fill.storage-warning[data-v-9a479a86]{background-color:#ff9800}.empty-state[data-v-9a479a86]{text-align:center;padding:2rem;color:var(--text-secondary)}.recordings-list[data-v-9a479a86]{display:flex;flex-direction:column;gap:1rem}.recording-item[data-v-9a479a86]{display:flex;align-items:center;justify-content:space-between;padding:1rem;background-color:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-color-light);transition:all .3s ease;gap:1rem}.recording-item[data-v-9a479a86]:hover{background-color:var(--bg-tertiary);box-shadow:0 2px 8px #0000001a}.recording-info[data-v-9a479a86]{flex:1;min-width:0;overflow:hidden}.recording-name[data-v-9a479a86]{font-weight:600;color:var(--text-primary);margin-bottom:.25rem;word-break:break-word;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recording-meta[data-v-9a479a86]{display:flex;gap:1rem;font-size:.875rem;color:var(--text-secondary);align-items:center;flex-wrap:nowrap}.recording-meta .duration[data-v-9a479a86]{font-family:monospace;font-weight:500;white-space:nowrap;min-width:max-content}.recording-meta .timestamp[data-v-9a479a86]{white-space:nowrap}.playback-controls[data-v-9a479a86]{flex-shrink:0;display:flex;align-items:center;justify-content:center}.btn-playback[data-v-9a479a86]{width:48px;height:48px;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background-color:#007bff;color:#fff;min-width:48px;flex-shrink:0;line-height:1;font-family:Arial,sans-serif;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #007bff4d;font-weight:600}.btn-playback[data-v-9a479a86]:hover:not(:disabled){background-color:#0056b3;transform:scale(1.08);box-shadow:0 4px 12px #007bff66}.btn-playback[data-v-9a479a86]:active:not(:disabled){transform:scale(.95);box-shadow:0 1px 4px #007bff4d}.btn-playback[data-v-9a479a86]:disabled{opacity:.5;cursor:not-allowed}.btn-playback.active[data-v-9a479a86]{background-color:#ff9800;box-shadow:0 2px 8px #ff98004d}.btn-playback.active[data-v-9a479a86]:hover:not(:disabled){background-color:#e68900;box-shadow:0 4px 12px #ff980066}.btn-playback .icon[data-v-9a479a86]{display:flex;align-items:center;justify-content:center;width:100%;height:100%;line-height:1}.recording-actions[data-v-9a479a86]{display:flex;gap:.5rem;flex-shrink:0}.btn-small[data-v-9a479a86]{padding:.5rem .75rem;font-size:.875rem;min-width:auto;background-color:var(--border-color-light);color:var(--text-primary)}.btn-small[data-v-9a479a86]:hover:not(:disabled){background-color:#d0d0d0}.btn-small.btn-danger[data-v-9a479a86]{background-color:#ffebee;color:#c62828}.btn-small.btn-danger[data-v-9a479a86]:hover:not(:disabled){background-color:#ffcdd2}@media(max-width:768px){.recorder-container[data-v-9a479a86]{padding:1rem}.recording-section[data-v-9a479a86],.recordings-section[data-v-9a479a86]{padding:1.5rem}.recording-item[data-v-9a479a86]{flex-direction:column;align-items:center;gap:1rem;text-align:center}.recording-info[data-v-9a479a86]{width:100%}.playback-controls[data-v-9a479a86]{margin:0;width:100%;display:flex;justify-content:center}.btn-playback[data-v-9a479a86]{width:56px;height:56px;min-width:56px;font-size:1.5rem}.recording-actions[data-v-9a479a86]{width:100%;justify-content:center}.button-group[data-v-9a479a86]{width:100%;flex-direction:column}.btn[data-v-9a479a86]{width:100%}.recorder-header h1[data-v-9a479a86]{font-size:1.5rem}}@media(max-width:480px){.recorder-container[data-v-9a479a86]{padding:.5rem}.recording-section[data-v-9a479a86],.recordings-section[data-v-9a479a86]{padding:1rem}.recording-item[data-v-9a479a86]{flex-direction:column;align-items:center;gap:.75rem;text-align:center}.recording-info[data-v-9a479a86]{width:100%}.playback-controls[data-v-9a479a86]{width:100%;display:flex;justify-content:center}.btn-playback[data-v-9a479a86]{width:52px;height:52px;min-width:52px;font-size:1.3rem}.recording-meta[data-v-9a479a86]{flex-direction:column;gap:.25rem;justify-content:center}.btn-small[data-v-9a479a86]{font-size:.75rem;padding:.4rem .6rem}.recording-actions[data-v-9a479a86]{width:100%;gap:.4rem;justify-content:center}}
