:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%}.control-panel{background:linear-gradient(135deg,#fff,#f8f9fa);padding:24px;border-radius:12px;box-shadow:0 4px 16px #0000001a;margin-bottom:24px}.control-header{text-align:center;margin-bottom:24px}.control-header h1{margin:0 0 8px;color:#2d2d44;font-size:32px;font-weight:700}.control-header p{margin:0;color:#666;font-size:14px}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:24px}.control-group{display:flex;flex-direction:column;gap:8px}.control-group label{font-size:14px;font-weight:600;color:#2d2d44;text-transform:uppercase;letter-spacing:.5px}.control-select{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;background:#fff;color:#2d2d44;cursor:pointer;transition:all .2s ease;font-family:inherit}.control-select:hover{border-color:#ff6b6b}.control-select:focus{outline:none;border-color:#ff6b6b;box-shadow:0 0 0 3px #ff6b6b1a}.checkbox-group{justify-content:center;padding-top:8px}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:#2d2d44;font-weight:600}.control-checkbox{width:20px;height:20px;cursor:pointer;accent-color:#ff6b6b}.info-panel{display:flex;justify-content:space-between;align-items:center;padding:16px;background:linear-gradient(135deg,#f0f0f5,#e8e8f0);border-radius:8px;border-left:4px solid #ff6b6b}.info-item{display:flex;gap:8px;align-items:center}.info-label{font-size:14px;color:#666;font-weight:500}.info-value{font-size:18px;color:#2d2d44;font-weight:700}.legend{display:flex;gap:20px}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#666}.legend-dot{width:16px;height:16px;border-radius:50%;box-shadow:0 2px 4px #0003}.legend-dot.root{background:linear-gradient(135deg,#ff6b6b,#ee5a6f)}.legend-dot.scale{background:linear-gradient(135deg,#a0a0a0,gray)}@media(max-width:768px){.controls-grid{grid-template-columns:1fr}.info-panel{flex-direction:column;gap:16px;align-items:flex-start}.legend{width:100%;justify-content:space-around}}.fretboard-container{width:100%;overflow-x:auto;padding:20px;background:linear-gradient(135deg,#1e1e2e,#2d2d44);border-radius:12px;box-shadow:0 8px 32px #0000004d}.fretboard{min-width:1200px;position:relative}.fret-markers{display:flex;margin-bottom:10px;padding-left:60px}.fret-marker-space{flex:1;display:flex;justify-content:center;align-items:center;min-width:45px;height:30px}.fret-marker{display:flex;flex-direction:column;gap:4px;align-items:center}.fret-marker.double{gap:8px}.marker-dot{width:8px;height:8px;background:#fff3;border-radius:50%}.strings{display:flex;flex-direction:column;gap:2px}.string-row{display:flex;align-items:center;position:relative}.string-label{width:50px;text-align:right;padding-right:10px;font-weight:700;color:#e0e0e0;font-size:14px}.frets{display:flex;flex:1;position:relative;border-bottom:2px solid #888}.fret{flex:1;min-width:45px;height:40px;border-right:2px solid #666;display:flex;align-items:center;justify-content:center;position:relative}.fret:first-child{border-left:4px solid #444;background:#ffffff0d}.note-marker{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;transition:all .2s ease;cursor:pointer;box-shadow:0 2px 8px #0000004d}.note-marker:hover{transform:scale(1.15)}.note-marker.root{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;width:28px;height:28px;box-shadow:0 4px 12px #ff6b6b66}.note-marker.scale{background:linear-gradient(135deg,#a0a0a0,gray);color:#2d2d44;width:20px;height:20px}.note-name{font-size:10px;-webkit-user-select:none;user-select:none}.note-marker.root .note-name{font-size:11px;font-weight:700}.fret-numbers{display:flex;margin-top:8px;padding-left:60px}.fret-number{flex:1;min-width:45px;text-align:center;font-size:12px;color:#ffffff80;font-weight:500}@media(max-width:1024px){.fretboard-container{padding:10px}.fretboard{min-width:900px}.fret,.fret-marker-space,.fret-number{min-width:35px}}*{box-sizing:border-box}.app{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}#root{max-width:1600px;margin:0 auto}@media(max-width:768px){.app{padding:10px}}
