@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600&display=swap";:root{font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;--bg-dark: #0f1214;--bg-panel: #1a1d21;--bg-card: #202428;--primary: #3b82f6;--primary-hover: #2563eb;--accent: #ef4444;--text-main: #f3f4f6;--text-muted: #9ca3af;--border-color: #374151;--glass-bg: rgba(26, 29, 33, .95);--glass-border: rgba(255, 255, 255, .1);--fret-wire: #525252;--string-color: #6b7280}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top center,#1f2937,#0f1214);color:var(--text-main);overflow:hidden}#app{max-width:100%;margin:0;height:100vh;height:100dvh;display:flex;flex-direction:column}.layout-container{display:flex;flex:1;overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#4b5563;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6b7280}#scale-list{flex:1;padding:.4rem 1rem;overflow-y:auto;display:flex;flex-direction:column;gap:.4rem;align-items:center;background:transparent}.empty-state{color:var(--text-muted);font-size:1.1rem;margin-top:20vh;font-weight:300;letter-spacing:.5px;opacity:.7}#sidebar{width:320px;background:var(--glass-bg);border-left:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem 1rem;display:flex;flex-direction:column;gap:.5rem;z-index:10;box-shadow:-4px 0 20px #0000004d;overflow:hidden}#sidebar h2{margin:0;font-size:1.05rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);border-bottom:1px solid var(--border-color);padding-bottom:.3rem;font-weight:600}#controls{flex:0 1 auto;min-height:0;overflow-y:auto}.controls-bar{display:flex;flex-direction:column;gap:.6rem}.control-section{background:#00000026;border:1px solid var(--border-color);border-radius:6px;padding:.4rem;box-shadow:inset 0 2px 4px #0000001a}.section-title{margin:0 0 .3rem;font-size:.85rem;color:var(--primary);font-weight:600;letter-spacing:.3px}.section-content{display:flex;flex-direction:column;gap:.3rem}.control-group{display:flex;flex-direction:column;gap:.1rem}.control-group label{font-size:.8rem;color:var(--text-muted);font-weight:500}select{width:100%;padding:.4rem .6rem;border-radius:4px;border:1px solid var(--border-color);background:#25292e;color:var(--text-main);font-size:.9rem;cursor:pointer;outline:none;transition:all .2s}select:hover{border-color:#4b5563;background:#2a2e33}select:focus{border-color:var(--primary);box-shadow:0 0 0 2px #3b82f633}.btn-primary{background:linear-gradient(135deg,var(--primary),#2563eb);color:#fff;border:none;padding:.8rem;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px -1px #0003;text-align:center}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 10px 15px -3px #0000004d;filter:brightness(1.1)}.btn-primary:active{transform:translateY(0)}.btn-primary.update-mode{background:linear-gradient(135deg,#10b981,#059669)}.btn-danger{background:linear-gradient(135deg,var(--accent),#dc2626);color:#fff;border:none;padding:.8rem;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px -1px #0003;text-align:center}.btn-danger:hover{transform:translateY(-1px);box-shadow:0 10px 15px -3px #0000004d;filter:brightness(1.1)}.btn-danger:active{transform:translateY(0)}.fretboard-container{width:100%;max-width:820px;background:var(--bg-card);padding:.5rem 1rem;border-radius:12px;border:1px solid var(--border-color);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;position:relative;transition:transform .2s,box-shadow .2s,border-color .2s,background-color .2s}.fretboard-container:nth-child(2n){background:#151a21}.fretboard-container:hover{border-color:#4b5563;box-shadow:0 10px 15px -3px #0003}.fretboard-container.dragging{opacity:.5;transform:scale(.98);border:2px dashed var(--primary)}.fretboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0;padding-bottom:.2rem;border-bottom:1px solid rgba(255,255,255,.05)}.fretboard-header h3{font-size:.9rem;font-weight:600;margin:0;color:var(--text-main);letter-spacing:.3px;flex-grow:1}.header-actions{display:flex;align-items:center;gap:4px}.edit-btn,.delete-btn{background:transparent;border:1px solid transparent;cursor:pointer;font-size:1.1rem;padding:2px 6px;border-radius:4px;color:var(--text-muted);transition:all .2s;line-height:1}.edit-btn:hover{background:#3b82f61a;color:var(--primary);border-color:#3b82f633}.delete-btn:hover{background:#ef44441a;color:var(--accent);border-color:#ef444433}.fretboard{display:grid;background:#111;border-radius:6px;padding:6px 0;overflow-x:auto;position:relative;border:1px solid #333;box-shadow:inset 0 0 20px #00000080}.fretboard.lefty{direction:rtl}.fretboard.lefty .fret-cell.open-string{border-left:4px solid #777;border-right:1px solid var(--fret-wire)}.fretboard.lefty .note-marker{direction:ltr}.fret-cell{position:relative;height:28px;border-right:1px solid var(--fret-wire);display:flex;align-items:center;justify-content:center}.fret-cell.open-string{background:#ffffff08;border-right:4px solid #777}.string-line{position:absolute;width:100%;background:linear-gradient(to bottom,#9ca3af,#4b5563);z-index:1;box-shadow:0 1px 2px #00000080;pointer-events:none}.note-marker{width:24px;height:24px;border-radius:50%;background:linear-gradient(145deg,var(--primary),#2563eb);color:#fff;z-index:2;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;box-shadow:0 2px 4px #0006,inset 0 1px #ffffff4d;text-shadow:0 1px 1px rgba(0,0,0,.3)}.note-marker.root{background:linear-gradient(145deg,var(--accent),#dc2626);box-shadow:0 0 0 2px #ef44444d,0 2px 4px #0006;border:1px solid rgba(255,255,255,.8);z-index:3}.note-marker.secondary{background:linear-gradient(145deg,#d97706,#b45309);box-shadow:0 2px 4px #0006,inset 0 1px #ffffff4d}.note-marker.secondary.root{background:linear-gradient(145deg,#ea580c,#c2410c);border:1px solid rgba(255,255,255,.8)}.note-marker.shared{background:linear-gradient(145deg,#ec4899,#db2777);box-shadow:0 0 0 2px #ec489966,0 2px 4px #0006;z-index:4}.note-marker.shared.root{border:2px solid white}.fret-number-cell{color:#525252;font-size:.7rem;font-family:monospace;display:flex;justify-content:center;padding-top:4px}.fret-number-cell.has-dot{color:#9ca3af;font-weight:700}.checkbox-group{margin-top:.5rem}.checkbox-group label{cursor:pointer;display:flex;align-items:center;gap:.8rem;background:#ffffff0d;padding:.6rem;border-radius:6px;transition:background .2s}.checkbox-group label:hover{background:#ffffff1a}.checkbox-group input{height:1.1rem;width:1.1rem;accent-color:var(--primary)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;opacity:1;transition:opacity .3s ease}.modal-overlay.hidden{opacity:0;pointer-events:none}.modal{background:var(--bg-card);border:1px solid var(--border-color);padding:2rem;border-radius:12px;box-shadow:0 20px 25px -5px #0000004d;max-width:400px;width:90%;text-align:center;transform:scale(1);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.modal-overlay.hidden .modal{transform:scale(.9)}.modal-title{margin-top:0;color:var(--text-main);font-size:1.25rem}.modal-text{color:var(--text-muted);margin-bottom:2rem}.modal-buttons{display:flex;gap:1rem;justify-content:center}.btn-secondary{background:transparent;border:1px solid var(--border-color);color:var(--text-main);padding:.8rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s}.btn-secondary:hover{background:#ffffff0d}.fab{display:none;position:fixed;bottom:1.5rem;right:1.5rem;width:3.5rem;height:3.5rem;border-radius:50%;background:linear-gradient(135deg,var(--primary),#2563eb);color:#fff;border:none;box-shadow:0 4px 10px #0006;z-index:999;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s,background .2s}.fab:active{transform:scale(.95)}@media (max-width: 768px){.layout-container{flex-direction:column}#scale-list{flex:1;width:100%;padding:1rem .5rem 6rem}.fab{display:flex}#sidebar{position:fixed;top:0;right:-450px;width:320px;height:100vh;max-height:none;background:var(--glass-bg);border-left:1px solid var(--glass-border);border-top:none;transition:right .3s cubic-bezier(.4,0,.2,1);z-index:1001;box-shadow:-8px 0 30px #00000080}#sidebar.mobile-open{right:0}.controls-bar{display:flex;flex-direction:column;gap:.8rem;margin-bottom:0}.section-content{display:flex;flex-direction:column;gap:.5rem}#sidebar h2{display:block}#controls{overflow-y:auto}.modal{width:90%;padding:1.5rem}.edit-btn,.delete-btn{padding:8px 12px;margin-left:4px}}@media print{body{background:#fff;color:#000;overflow:visible}#app{height:auto;display:block}.layout-container{display:block}#sidebar,.header-actions,.modal-overlay{display:none!important}#scale-list{padding:0;overflow:visible;display:block}.fretboard-container{break-inside:avoid;border:1px solid #ccc;box-shadow:none;background:#fff;margin-bottom:1rem;page-break-inside:avoid;max-width:100%}.fretboard-header{border-bottom:2px solid #333}.fretboard-header h3{color:#000;font-size:1.2rem}.fretboard-header span{color:#333!important}.fretboard-header div{color:#555!important}.fretboard{border:1px solid #333;background:#fff;box-shadow:none;color:#000}.string-line{background:#999;box-shadow:none}.fret-cell{border-right:1px solid #999}.fret-cell.open-string{background:none;border-right:4px solid #555}.fret-number-cell{color:#000}.note-marker{box-shadow:none;-webkit-print-color-adjust:exact;print-color-adjust:exact;border:1px solid #000;color:#fff}}.keyboard-container{background:#111;border-radius:4px;box-shadow:inset 0 2px 5px #00000080}.piano-key{position:absolute;top:0;border-radius:0 0 4px 4px;box-sizing:border-box;transition:background .1s}.piano-key.white{width:40px;height:140px;background:linear-gradient(to bottom,#fff,#eee);border:1px solid #999;z-index:1}.piano-key.black{width:24px;height:90px;background:linear-gradient(to bottom,#333,#000);border:1px solid #000;border-top:none;z-index:2}.key-marker{position:absolute;bottom:15px;left:50%;transform:translate(-50%);width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:5;box-shadow:0 2px 4px #0000004d}.piano-key.black .key-marker{bottom:10px;width:18px;height:18px;font-size:.6rem}.key-marker.root{background:var(--accent);box-shadow:0 0 0 2px #ef444466}.key-marker.secondary{background:#d97706}.key-marker.secondary.root{background:#ea580c}.key-marker.shared{background:#db2777}.key-marker.shared.root{border:1px solid white}
