*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0;width:100%;overflow:hidden;touch-action:manipulation;-webkit-text-size-adjust:100%}.app-root{font-family:system-ui,-apple-system,BlinkMacSystemFont,sans-serif;height:100%;min-height:0;display:flex;flex-direction:column;background:#111;color:#f5f5f5;overflow:hidden}.app-root--joined{flex:1 1 auto;display:flex;flex-direction:column;padding:.75rem 1.25rem 0;padding-top:calc(.75rem + env(safe-area-inset-top));padding-bottom:calc(3.5rem + env(safe-area-inset-bottom))}.app-main{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;overflow-y:auto}.tab-bar{display:flex;border-top:1px solid #333;background:#000;padding:.4rem .6rem;padding-bottom:calc(.4rem + env(safe-area-inset-bottom));position:fixed;bottom:0;left:0;right:0;z-index:50}.tab-bar__button{flex:1;padding:.6rem .4rem;margin:0 .3rem;border-radius:999px;border:none;font-size:.95rem;font-weight:600;background:#333;color:#ddd}.tab-bar__button--active{background:#f5f5f5;color:#111}.instrument-picker{display:flex;padding:0 .75rem;margin-bottom:.5rem;gap:.5rem}.instrument-picker__button{flex:1 1 0;min-width:0;padding:.55rem .35rem;border-radius:1rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#333;color:#ddd;border:1px solid rgba(255,255,255,.2)}.instrument-picker__button--active{background:#ffd86b;color:#111;border-color:#ffd86b}.scale-badge{display:flex;align-items:center;justify-content:space-between;padding:0 .75rem;margin-bottom:.5rem;gap:.75rem}.scale-badge__left{display:flex;align-items:center;gap:.6rem}.scale-badge__info{display:flex;flex-direction:column;gap:.1rem}.scale-badge__scale{font-size:1rem;font-weight:600}.scale-badge__chord{font-size:.85rem;opacity:.8}.scale-badge__logo{flex:0 0 auto;max-width:280px}.home-splash,.home-splash-logo{align-self:center;display:block;width:130%}.screen-instrument{flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.instrument-view{flex:1 1 auto;min-height:0;display:flex;overflow:hidden;width:100%;min-width:0;align-items:stretch}.instrument-view>*{flex:1 1 auto;width:100%;height:100%;min-height:0;min-width:0}.screen-ensemble,.screen-account{flex:1 1 auto;display:flex;flex-direction:column;padding:0 .75rem .75rem}.instrument-placeholder{flex:1;display:flex;align-items:center;justify-content:center;font-size:1rem;opacity:.6}.ensemble-card{margin:.9rem;padding:.9rem 1.1rem;border-radius:.9rem;background:#222;font-size:1rem}.harp-string{width:100%;height:1px;border-radius:0;background:#ffffffe6;transform-origin:center;transition:background-color .2s ease-out,transform .2s ease-out}.harp-string--ringing{animation:harp-vibrate .22s ease-out}@keyframes harp-vibrate{0%{transform:translateY(0)}25%{transform:translateY(-3px)}50%{transform:translateY(2px)}75%{transform:translateY(-1px)}to{transform:translateY(0)}}button{padding:.7rem 1.1rem;border-radius:.9rem;border:none;font-size:1rem;font-weight:600;background:#ffd86b;color:#000}@media(max-width:768px){html,body,#root{font-size:18px}.tab-bar{padding:.5rem .75rem}.tab-bar__button{flex:1;padding:.6rem .4rem;margin:0 .3rem;border-radius:999px;border:1px solid rgba(255,255,255,.25);font-size:.95rem;font-weight:600;background:#333;color:#f5f5f5;box-shadow:0 1px 2px #0000004d}.instrument-picker{padding:0 .5rem}.instrument-picker__button{flex:1 1 0;min-width:0;padding:.55rem .35rem;border-radius:1rem;text-align:center;background:#333;color:#f5f5f5;border:1px solid rgba(255,255,255,.25);box-shadow:0 1px 2px #0000004d;transition:background .15s ease,color .15s ease,border-color .15s ease}.scale-badge__scale{font-size:1.1rem}.scale-badge__chord{font-size:.9rem}.scale-badge__logo{flex:0 0 auto;max-width:240px;overflow:hidden}.scale-badge__logo svg{transform:scale(.45);transform-origin:left center;width:100%;height:30%;height:auto}.ensemble-card{margin:.9rem .75rem;font-size:1.05rem}.ensemble-page-scroll{flex:1 1 auto;overflow-y:auto;-webkit-overflow-scrolling:touch}button{font-size:1.05rem;padding:.8rem 1.2rem;background-color:#fafad2}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}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}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
