#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}.app-container{position:relative;width:1152px;height:1000px;margin:auto}.panel{width:1152px;position:absolute;background-color:#ecf0f4;height:317px;margin:auto;border-radius:5px;-webkit-box-shadow:0px 0px 5px 0px rgba(0,0,0,.75);z-index:3}.panel-bottom{position:absolute;background:rgb(236,240,244);background:linear-gradient(180deg,rgba(236,240,244,1) 0%,rgba(27,32,53,1) 100%);width:1152px;height:8px;top:314px;border-radius:5px}.play-button.panel-button-binary{left:540px;top:242px;height:63px;width:54px;padding-left:7px;line-height:60px;font-size:35px;text-align:center;border-radius:50%}.bar-button-increment.panel-button{left:635px;top:250px;border-radius:10px;width:300px;height:45px;line-height:43px;text-align:center;font-size:30px;letter-spacing:3px}.bar-button-decrement.panel-button{left:214px;top:250px;border-radius:10px;width:300px;height:45px;line-height:43px;text-align:center;font-size:30px;letter-spacing:3px}.audio-header{position:absolute;left:25px;top:10px;width:175px;height:50px;line-height:50px;letter-spacing:7px;text-align:center;font-size:30px;color:#838383}.timing-header{position:absolute;left:25px;top:90px;width:175px;height:50px;line-height:50px;letter-spacing:7px;text-align:center;font-size:30px;color:#838383}.timing-slider{position:absolute;left:23px;top:147px;width:175px;height:10px;color:#0d79a3;-webkit-box-shadow:-5px -5px 6px -4px rgb(255,255,255),4px 4px 6px -4px rgb(13,121,163),4px 4px 6px -4px rgb(13,121,163)}.audio-slider{position:absolute;left:23px;top:65px;width:175px;height:10px;color:#0d79a3;-webkit-box-shadow:-5px -5px 6px -4px rgb(255,255,255),4px 4px 6px -4px rgb(13,121,163),4px 4px 6px -4px rgb(13,121,163)}.reset-button{left:25px;top:248px;border-radius:10px;width:175px;height:50px;text-align:center;font-size:30px;letter-spacing:3px;line-height:50px}.playing-mode-button{left:25px;top:182px;border-radius:10px;width:175px;height:50px;text-align:center;font-size:30px;letter-spacing:0px;line-height:50px}.key-mode-button{left:950px;top:25px;border-radius:10px;width:175px;height:50px;text-align:center;font-size:27px;letter-spacing:0px;line-height:50px}.accidental-button{left:950px;top:104px;border-radius:10px;width:175px;height:50px;text-align:center;font-size:27px;letter-spacing:0px;line-height:50px}.key-button{position:absolute;left:950px;top:175px;border-radius:10px;width:175px;height:50px;line-height:50px;text-align:center;font-size:30px;cursor:pointer}.key-assist-button{left:950px;top:248px;border-radius:10px;width:175px;height:50px;text-align:center;font-size:30px;letter-spacing:0px;line-height:50px}.panel-button-binary{transition:-webkit-box-shadow .3s,color .2s,transform .3s cubic-bezier(.2,2,1,3);cursor:pointer;color:#838383;transform:scale(1);font-weight:500;-webkit-box-shadow:-10px -10px 6px -4px rgba(252,252,252,1),10px 10px 6px -4px rgba(210,218,230,1),-4px -4px 10px 0px rgba(210,218,230,0) inset,4px 4px 10px 0px rgba(252,252,252,0) inset;background-color:#e8e8e8;position:absolute;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.panel-button-binary:hover{color:#0d79a3}.panel-button-binary-pressed{-webkit-box-shadow:0px 0px 6px -4px rgba(252,252,252,1),0px 0px 6px -4px rgba(210,218,230,1),10px 12px 15px -5px rgba(210,218,230,1) inset,-10px -12px 15px -5px rgba(252,252,252,1) inset;transform:scale(.99,.97);color:#0d79a3}.panel-button{transition:-webkit-box-shadow .3s,color .2s,transform .3s cubic-bezier(.2,2,1,3);cursor:pointer;color:#838383;transform:scale(1);font-weight:500;-webkit-box-shadow:-10px -10px 6px -4px rgba(252,252,252,1),10px 10px 6px -4px rgba(210,218,230,1),-4px -4px 10px 0px rgba(210,218,230,0) inset,4px 4px 10px 0px rgba(252,252,252,0) inset;background-color:#e8e8e8;position:absolute;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.panel-button:hover:not(.deactivated-button){color:#0d79a3}.panel-button:active:not(.deactivated-button){-webkit-box-shadow:0px 0px 6px -4px rgba(252,252,252,1),0px 0px 6px -4px rgba(210,218,230,1),10px 12px 15px -5px rgba(210,218,230,1) inset,-10px -12px 15px -5px rgba(252,252,252,1) inset;transform:scale(.99,.97)}.deactivated-button{color:silver;cursor:default}.staff-container{display:inline-block;background-color:#fff;position:relative;padding:10px;border:1px solid rgb(170,170,170);border-radius:10px;box-shadow:0 0 5px 10px #000000bf inset;-webkit-box-shadow:0px 0px 5px 0px rgb(0,0,0,1) inset,0px 0px 15px 1px rgb(136,221,255,0);-moz-box-shadow:0px 0px 5px 10px rgba(0,0,0,.75) inset;width:700px;height:185px;margin:25px auto 0;z-index:55}.chord-reel{display:inline-block;width:700px;height:35px;background-color:#fbfdff;margin:0 auto;line-height:0px;font-size:0px;border-bottom:1px solid grey;vertical-align:top}.symbol{position:absolute;color:#000;font-size:18px;font-weight:300;top:-5px;height:40px;width:80px;text-align:center;line-height:3;transition:left .5s}.staff{display:inline-block;position:relative;background-color:#fff;width:700px;height:115px;font-size:0;background-image:linear-gradient(180deg,#000 0,#000 1px,transparent 1px,transparent 8px,#000 8px,#000 9px,transparent 9px,transparent 16px,#000 16px,#000 17px,transparent 17px,transparent 24px,#000 24px,#000 25px,transparent 25px,transparent 32px,#000 32px,#000 33px,transparent 33px),linear-gradient(180deg,#000 0,#000 1px,transparent 1px,transparent 8px,#000 8px,#000 9px,transparent 9px,transparent 16px,#000 16px,#000 17px,transparent 17px,transparent 24px,#000 24px,#000 25px,transparent 25px,transparent 32px,#000 32px,#000 33px,transparent 33px);background-size:100% 48px;background-position:right 10px top 16px,right 10px top 64px;background-repeat:no-repeat;line-height:0px;font-size:0px;vertical-align:top}.bar{position:absolute;width:75px;height:117px;top:47px;transition:left .5s}.bar-container{position:absolute;width:75px;top:-47px;height:207px;transition:left .5s;cursor:pointer;z-index:6}.treble-clef{position:absolute;background-image:url(/Pianosition/assets/TrebleClef-c1086928.png);background-repeat:no-repeat;height:60px;background-size:contain;width:80px;left:5px;top:4px}.bass-clef{position:absolute;background-image:url(/Pianosition/assets/BassClef-516d085e.png);background-repeat:no-repeat;background-size:contain;height:30px;width:80px;left:10px;top:64px}.signature-accidental{font-size:20px;height:20px;width:20px;color:#000;position:absolute;font-weight:700;transform:scaleY(1.5)}.accidental{font-size:20px;height:0px;width:0px;color:#000;position:absolute;font-weight:700;transform:scaleY(1.5);top:1px}.analysis-reel{position:relative;display:inline-block;width:700px;height:35px;background-color:#fbfdff;margin:0 auto;line-height:0px;border-top:1px solid grey;vertical-align:top}.analysis{position:absolute;color:#000;font-size:18px;font-weight:300;top:-10px;height:40px;width:80px;text-align:center;line-height:3;transition:left .5s}.interval-container{display:inline-block;position:relative;height:30px;width:0px;margin-left:2px;margin-right:2px;top:3px}.upper-interval{position:absolute;font-size:11px;top:-2px}.lower-interval{position:absolute;font-size:11px;top:8px}.note{position:absolute;height:8px;width:12px;-webkit-animation:fadein .5s;-moz-animation:fadein .5s;-ms-animation:fadein .5s;-o-animation:fadein .5s;animation:fadein .5s;transition:left .25s ease,box-shadow .2s ease;box-shadow:none}.terminated-note{-webkit-animation:fadeOut .5s;-moz-animation:fadeOut .5s;-ms-animation:fadeOut .5s;-o-animation:fadeOut .5s;animation:fadeOut .5s}@keyframes fadein{0%{opacity:0}to{opacity:1}}@-moz-keyframes fadein{0%{opacity:0}to{opacity:1}}@-webkit-keyframes fadein{0%{opacity:0}to{opacity:1}}@-ms-keyframes fadein{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@-moz-keyframes fadeOut{0%{opacity:1}to{opacity:0}}@-webkit-keyframes fadeOut{0%{opacity:1}to{opacity:0}}@-ms-keyframes fadeOut{0%{opacity:1}to{opacity:0}}.note:before{position:absolute;height:8px;width:12px;content:"";box-sizing:border-box;border:1px solid black;border-left-width:4px;border-right-width:4px;border-radius:50%;z-index:5}.note.current-bar:after{position:absolute;height:8px;width:12px;content:"";box-sizing:border-box;border:1px solid rgba(0,0,0,0);border-left-width:4px;border-right-width:4px;border-radius:50%;box-shadow:0 0 5px #3bc1ff,0 0 2px #3df9ff80;z-index:0}.keyboard-shadow{position:absolute;top:-100px;left:2px;width:1148px;height:100px;z-index:5;box-shadow:0 23px 15px -10px #1b2035e6}.keyboard-bottom{position:absolute;top:319px;left:40px;width:1100px;height:100px;margin:auto;z-index:1;background-color:#000}.keyboard{top:319px;width:1148px;left:2px;height:400px;margin:auto;position:absolute;z-index:2}.keyboard-animation-layer{width:1000px;height:222px;margin:auto;z-index:0;display:block;position:absolute;overflow:hidden}.animation-circle{position:absolute;height:5px;width:5px;border-radius:50%;border:1px solid #6faeffd5;transform:scale(1);transition:0s;opacity:0;top:183px;box-shadow:0 3px 6px #000000bf,;-webkit-box-shadow:0px 3px 6px 0px #6faeffd5;-moz-box-shadow:0px 3px 6px 0px rgba(0,0,0,.75)}.circle-activated{transform:scale(300);opacity:1;transition:transform 1s ease-out,opacity .01s}.keyboard-animation-layer-activated{z-index:4}.key-container-white{width:40px;height:220px;position:absolute;top:0;transition:top .2s ease-in}.key-container-black{width:20px;height:140px;position:absolute;top:0;transition:top .2s ease-in}.key{border:1px solid black;position:absolute;cursor:pointer;transition:background-color .1s ease-out,box-shadow .2s,-webkit-box-shadow .2s,-moz-box-shadow .2s;top:0;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.white{width:40px;height:220px;background-color:#fff;border-radius:10px;z-index:2}.white-adjacent{background-color:#e1fffa}.white:hover:not(.white-pressed){background-color:#d1f2ff;transition:.1s ease-in}.white-label{position:relative;text-align:center;margin-top:180px;color:#1a1a1a;display:inline-block;transition:transform .1s ease-out,color .2s,font-weight .2s;transform-origin:0 0}.black{width:20px;height:140px;background-color:#1a1a1a;color:#fff;border-radius:7px;z-index:6}.black:hover:not(.black-pressed){background-color:#dff6ff;transition:.1s ease-in;color:#000}.black-label{position:relative;text-align:center;margin-top:100px;color:inherit;display:inline-block;transition:transform .1s ease-out,color .2s,font-weight .2s;transform-origin:0 0}.key-shadow-white{position:absolute;width:40px;height:220px;border-radius:10px;box-shadow:0 5px 4px #000000bf;-webkit-box-shadow:0px 4px 6px 0px rgba(0,0,0,.75);-moz-box-shadow:0px 5px 4px 0px rgba(0,0,0,.75);z-index:1;transition:.1s ease-out}.key-shadow-black{position:absolute;width:20px;height:140px;border-radius:7px;box-shadow:0 6px 8px -2px #000000bf;-webkit-box-shadow:0px 6px 8px -2px rgba(0,0,0,.75);-moz-box-shadow:0px 6px 8px -2px rgba(0,0,0,.75);z-index:5;transition:.1s ease-out}.label-shadow-diatonic-white{font-weight:600;color:#1b8ab6}.label-shadow-diatonic-black{font-weight:600;color:#000}.key-shadow-diatonic-white{box-shadow:0 0 2 10px #184eff80 inset;-webkit-box-shadow:0px 0px 10px 0px rgba(36,156,255,.5) inset;-moz-box-shadow:0px 0px 2px 10px rgba(24,78,255,.5) inset;border-color:#249cff80;z-index:3}.key-shadow-diatonic-black{box-shadow:0 0 2 10px #184eff;-webkit-box-shadow:0px 0px 3px 0px rgba(36,156,255,1) inset;-moz-box-shadow:0px 0px 2px 10px rgba(24,78,255,1);background-color:#fff}.white-pressed{background-color:#8df;box-shadow:0 0 5px 10px #000000bf inset;-webkit-box-shadow:0px 0px 4px 0px rgba(0,0,0,.75) inset;-moz-box-shadow:0px 0px 5px 10px rgba(0,0,0,.75) inset;color:#000;z-index:4;border:1px solid black;transition:.2s ease-in}.black-pressed{background-color:#c7efff;color:#000;box-shadow:0 0 5px 10px #000000bf inset;-webkit-box-shadow:0px 0px 4px 0px rgba(0,0,0,.75) inset;-moz-box-shadow:0px 0px 5px 10px rgba(0,0,0,.75) inset;transition:.2s ease-in}.black-adjacent{background-color:#11584a}.key-shadow-diatonic-black.black-adjacent{background-color:#d5fff7}.key-depressed{box-shadow:0 4px 4px -2px #00000080;-webkit-box-shadow:0px 4px 4px -2px rgba(0,0,0,.5);-moz-box-shadow:0px 4px 4px -2px rgba(0,0,0,.5);transition:.2s ease-in}.label-pressed{transform:scaleY(.95);-webkit-transform:scale(1,.95);-moz-transform:scale(1,.95);-ms-transform:scale(1,.95);-o-transform:scale(1,.95);color:#000;transition:transform .2s ease-in,color .2s ease-in}.key-container-white.free-mode{transition:background-color .1s ease-out,box-shadow .2s,-webkit-box-shadow .2s,-moz-box-shadow .2s,transform .1s cubic-bezier(1,1,1,1);transform-origin:top}.key-container-white.free-mode:active{transform:scaleY(.985)}.key-container-black.free-mode{transition:background-color .1s ease-out,box-shadow .2s,-webkit-box-shadow .2s,-moz-box-shadow .2s,transform .1s cubic-bezier(1,1,1,1);z-index:5;transform-origin:top}.key-container-black.free-mode:active{transform:scaleY(.98)}.key-jump{top:-30px;transition:top .1s ease-out}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}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;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;width:175px;height:10px;background-image:linear-gradient(rgb(13,121,163),rgb(13,121,163));background-repeat:no-repeat;border-radius:5px}input[type=range]:focus{outline:none}input[type=range]::-webkit-slider-runnable-track{-webkit-appearance:none;box-shadow:none;border:none;background:transparent}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:50%;background-color:#e8e8e8;height:25px;width:25px;-webkit-box-shadow:-5px -5px 6px -4px rgb(255,255,255),4px 4px 6px -4px rgb(13,121,163),4px 4px 6px -4px rgb(13,121,163);transition:background-color .2s}input[type=range]:hover::-webkit-slider-thumb{background-color:#0d79a3}input[type=range]::-moz-range-track{-webkit-appearance:none;border:none;background:transparent}input[type=range]::-moz-range-thumb{border:none;border-radius:50%;background-color:#e8e8e8;height:25px;width:25px;-webkit-box-shadow:0px 4px 6px -4px rgb(13,121,163),0px 4px 6px -4px rgb(13,121,163);transition:background-color .2s}input[type=range]:hover::-moz-range-thumb{background-color:#0d79a3}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
