html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}html{height:100%;margin:0;padding:0}body,#root{min-height:100%;margin:0;padding:0;min-width:320px}body{background:url(/assets/Highlands.png) no-repeat center center;background-size:cover;padding-top:.5rem}: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;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:none}a:hover{color:#535bf2}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}}input[type=range]{-webkit-touch-action:none;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;-webkit-appearance:none;width:1rem}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;background:#fffc;border-radius:50%}@keyframes direction-feedback-fade-in{0%{opacity:0}to{opacity:1}}.direction-feedback-controls{animation:direction-feedback-fade-in .5s ease-out}.direction-feedback-result{opacity:1;transition:opacity .9s ease-out}.direction-feedback-result--fading{opacity:0}@media (prefers-reduced-motion: reduce){.direction-feedback-result{transition-duration:1ms}}.app-page{display:flex;flex-direction:column;align-items:center;width:100%;min-height:100vh;padding:.75rem 1rem 2rem;box-sizing:border-box}.app-shell{display:flex;justify-content:flex-end;width:100%;min-height:3.35rem;margin-bottom:.75rem}.app-content{display:flex;flex-direction:column;align-items:center;width:100%}.app-auth-screen{display:flex;align-items:center;justify-content:center;width:100%;min-height:100vh;padding:1.5rem;box-sizing:border-box}.auth-card{width:min(100%,26rem);padding:clamp(1.25rem,4vw,2rem);color:#fff;text-align:left;border:1px solid rgba(255,255,255,.22);border-radius:1.25rem;background:linear-gradient(180deg,#05080cdb,#05080cb8);box-shadow:0 24px 60px #00000061;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.auth-card--status{text-align:center;font-weight:700}.auth-card__title{margin:0 0 .5rem;color:#fff6d1;font-size:clamp(1.6rem,5vw,2.25rem);line-height:1.1}.auth-card__intro,.auth-card__note{margin:0 0 1rem;color:#ffffffd6}.auth-card__strong{color:#fff;font-weight:700}.auth-card__dev-code{margin:0;padding:.65rem .75rem;color:#ffe28a;border:1px solid rgba(255,226,138,.3);border-radius:.75rem;background:#ffe28a17;font-size:.95rem}.auth-card__error{margin:1rem 0 0;color:#fecaca;font-size:.95rem}.auth-form{display:grid;gap:.85rem;width:100%}.auth-input{width:100%;min-height:3rem;padding:.8rem .9rem;color:#fff;border:1px solid rgba(255,255,255,.28);border-radius:.85rem;background:#00000057;font:inherit}.auth-input::placeholder{color:#fff9}.auth-input:focus{outline:2px solid rgba(255,224,130,.82);outline-offset:2px}.auth-button{min-height:3rem;color:#1f1600;border-color:#ffe18a59;background:#f4c24f;font-weight:800}.auth-button:hover:not(:disabled){border-color:#ffffff73;background:#ffd56c}.auth-button:disabled,.auth-link-button:disabled{cursor:not-allowed;opacity:.72}.auth-link-button{justify-self:center;padding:.25rem .35rem;color:#ffffffc7;border:0;background:transparent;text-decoration:underline;box-shadow:none}.auth-link-button:hover:not(:disabled){color:#fff;border-color:transparent;background:transparent}.app-controls{position:relative;z-index:50;display:flex;justify-content:flex-end;width:100%}.app-controls__desktop,.app-controls__mobile,.app-mobile-menu{pointer-events:auto}.app-controls__desktop{display:flex;align-items:center;gap:.35rem;padding:.25rem;border:1px solid rgba(255,255,255,.16);border-radius:999px;background:#05080c94;box-shadow:0 10px 28px #00000038;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-controls__mobile{display:none}.app-menu-button,.app-control-item{color:#ffffffe0;border:1px solid transparent;background:transparent;box-shadow:none}.app-menu-button:hover,.app-control-item:hover{color:#fff;border-color:#ffffff29;background:#ffffff17}.app-menu-button:focus-visible,.app-control-item:focus-visible{outline:2px solid rgba(255,224,130,.8);outline-offset:2px}.app-menu-button{min-width:2.75rem;min-height:2.75rem;padding:.55rem .75rem;border-color:#ffffff38;border-radius:.85rem;background:#05080cad;box-shadow:0 10px 26px #00000042;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-control-item{display:inline-flex;align-items:center;gap:.38rem;min-height:2.15rem;padding:.42rem .72rem;border-radius:999px;font-size:.88rem;line-height:1.1;letter-spacing:.01em;transition:color .16s ease,background .16s ease,border-color .16s ease}.app-control-item--active{color:#fff3c4;background:#ffe18a1c;border-color:#ffe18a38}.app-control-item--quiet{color:#ffffffb8}.app-control-item__check{display:inline-flex;justify-content:center;width:1rem;color:#ffe28a;font-weight:700}.app-mobile-menu{display:grid;min-width:12.75rem;gap:.2rem;margin-top:.5rem;padding:.38rem;border:1px solid rgba(255,255,255,.16);border-radius:1rem;background:#05080ce6;box-shadow:0 18px 36px #00000057;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-mobile-menu .app-control-item{justify-content:flex-start;width:100%;min-height:2.75rem;padding:.7rem .78rem;border-radius:.75rem;text-align:left}@media (max-width: 699px){.app-page{padding:.75rem .75rem 1.5rem}.app-shell,.app-controls{justify-content:flex-start}.app-controls__desktop{display:none}.app-controls__mobile{display:block}}.instructions-modal{color:#fff;box-shadow:0 28px 70px #0000006b}.instructions-panel{display:grid;gap:1rem;max-height:88vh;padding:clamp(1rem,3vw,1.35rem);overflow-y:auto;text-align:left;border-radius:18px;background:linear-gradient(180deg,#05080cf0,#05080cdb);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.instructions-panel__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding-bottom:.85rem;border-bottom:1px solid rgba(255,255,255,.14)}.instructions-panel__header h2{margin:0;color:#fff6d1;font-size:clamp(1.6rem,4vw,2.15rem);line-height:1.08}.instructions-panel__eyebrow{margin:0 0 .25rem;color:#ffe28a;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.instructions-panel__close{min-width:2.25rem;min-height:2.25rem;padding:.15rem .55rem;color:#ffffffd6;border-color:#ffffff1f;background:#ffffff0f;font-size:1.35rem;line-height:1}.instructions-panel__body{display:grid;gap:1rem}.instructions-panel__section{display:grid;gap:.55rem;padding:.95rem;border:1px solid rgba(255,255,255,.12);border-radius:1rem;background:#ffffff0e}.instructions-panel__section h3,.instructions-panel__section p{margin:0}.instructions-panel__section h3{color:#fff6d1;font-size:1rem}.instructions-panel__section p{color:#ffffffd6;line-height:1.45}.instructions-panel__audio{justify-self:center;display:inline-flex;align-items:center;gap:.65rem;color:#1f1600;border-color:#ffe18a59;background:#f4c24f;font-weight:800}.instructions-panel__audio img{width:1.5rem;height:1.5rem}.analytics-modal{color:#fff;box-shadow:0 28px 70px #0000006b}.analytics-panel{display:flex;flex:1 1 auto;flex-direction:column;gap:1rem;max-height:88vh;min-height:0;padding:clamp(1rem,3vw,1.35rem);overflow:hidden;text-align:left;border-radius:18px;background:linear-gradient(180deg,#05080cf0,#05080cdb);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.analytics-panel__header{display:flex;flex:0 0 auto;align-items:flex-start;justify-content:space-between;gap:1rem;padding-bottom:.85rem;border-bottom:1px solid rgba(255,255,255,.14)}.analytics-panel__header h2{margin:0;color:#fff6d1;font-size:clamp(1.6rem,4vw,2.15rem);line-height:1.08}.analytics-panel__header p{max-width:40rem;margin:.45rem 0 0;color:#ffffffc7;font-size:.95rem}.analytics-panel__eyebrow{margin:0 0 .25rem!important;color:#ffe28ac7!important;font-size:.78rem!important;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.analytics-panel__close{flex:0 0 auto;width:2.35rem;height:2.35rem;padding:0;color:#ffffffc7;border-color:#ffffff29;border-radius:999px;background:#ffffff0f;font-size:1.45rem;line-height:1;box-shadow:none}.analytics-panel__close:hover{color:#fff;border-color:#ffffff42;background:#ffffff1c}.analytics-panel__body{display:grid;flex:1 1 auto;gap:.9rem;min-height:0;overflow-y:auto;padding-right:.2rem}.analytics-section{display:grid;gap:.75rem;padding:.9rem;border:1px solid rgba(255,255,255,.13);border-radius:1rem;background:#ffffff0e}.analytics-section__header h3{margin:0;color:#fffffff5;font-size:1rem;line-height:1.2}.analytics-section__header p{margin:.25rem 0 0;color:#ffffffad;font-size:.86rem;line-height:1.4}.analytics-section__header--accordion h3{margin:0}.analytics-section__toggle{display:flex;width:100%;align-items:center;justify-content:space-between;gap:.75rem;padding:0;color:#fffffff5;border:0;background:transparent;box-shadow:none;font:inherit;text-align:left}.analytics-section__toggle:hover{color:#fff6d1;border:0;background:transparent}.analytics-section__toggle:focus-visible{outline:2px solid rgba(255,224,130,.8);outline-offset:.25rem}.analytics-section__chevron{flex:0 0 auto;color:#ffe28ac7;font-size:1.05rem;line-height:1}.analytics-section__accordion-panel{display:grid;gap:.75rem}.analytics-section__accordion-panel[hidden]{display:none}.analytics-metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(9.5rem,1fr));gap:.55rem;margin:0}.analytics-metric{min-width:0;margin:0;padding:.7rem;border:1px solid rgba(255,255,255,.1);border-radius:.8rem;background:#00000029}.analytics-metric__label,.analytics-attempt dt{margin:0;color:#ffffff9e;font-size:.75rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase}.analytics-metric__value{margin:.2rem 0 0;color:#fffffff0;font-size:1rem;font-weight:750}.analytics-metric__note{margin:.2rem 0 0;color:#ffffff94;font-size:.78rem}.analytics-state,.analytics-empty-row{padding:1rem;color:#ffffffc2;border:1px solid rgba(255,255,255,.12);border-radius:1rem;background:#ffffff0e;font-size:.95rem}.analytics-state--error{color:#fecaca;border-color:#fecaca38;background:#7f1d1d29}.analytics-attempt-list{display:grid;gap:.55rem}.analytics-attempt{display:grid;gap:.55rem;padding:.75rem;border:1px solid rgba(255,255,255,.1);border-radius:.85rem;background:#00000024}.analytics-attempt__main{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.analytics-attempt__main time{color:#fffffff0;font-weight:750}.analytics-attempt__main span{color:#ffe28ad1;font-size:.85rem}.analytics-attempt__details{display:grid;grid-template-columns:repeat(auto-fit,minmax(7rem,1fr));gap:.4rem .75rem;margin:0}.analytics-attempt__details div{min-width:0}.analytics-attempt dd{margin:.1rem 0 0;color:#ffffffe0;font-size:.9rem}@media (max-width: 699px){.analytics-panel__header{align-items:flex-start}.analytics-metric-grid,.analytics-attempt__details{grid-template-columns:1fr}}.app-language-selector select{color:#ffffffdb;border:1px solid rgba(255,255,255,.16);border-radius:999px;background:#05080c6b;padding:.2rem .55rem;font:inherit}.app-language-selector select:focus-visible{outline:2px solid rgba(255,224,130,.8);outline-offset:2px}.headphone-instruction{display:grid;justify-items:center;gap:.45rem;width:min(100%,28rem);margin:.5rem auto .75rem;text-align:center}.headphone-instruction__icon{display:block;width:clamp(9rem,30vw,250px);max-width:100%;height:auto;object-fit:contain}@media (max-width: 699px){.headphone-instruction{width:min(100%,22rem);gap:.35rem;margin-top:.25rem}.headphone-instruction__icon{width:clamp(7rem,38vw,9.5rem)}}.headphone-instruction__text{max-width:26rem;margin:0;color:#fff6d1;font-size:clamp(.95rem,2.5vw,1.1rem);font-weight:700;line-height:1.35;text-wrap:balance}.tuning-surface{width:100%;max-width:48rem;padding:0 .5rem;overflow-x:clip}.tuning-control-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(8.5rem,100%),1fr));align-items:stretch;justify-items:center;gap:clamp(.75rem,2.5vw,1rem);width:100%}.tuning-control-column{display:flex;justify-content:center;width:100%;min-width:0}.tuning-channel-control{display:flex;flex-direction:column;align-items:center;width:min(100%,8.5rem);min-width:0;height:100%}.tuning-channel-control--chanter{display:grid;grid-template-rows:auto auto 1fr auto;row-gap:.5rem;align-items:start;justify-items:center}.tuning-channel-title{display:flex;align-items:center;justify-content:center;min-height:2.6rem;width:100%;padding:0 .25rem;color:#fff;font-size:clamp(.8rem,1.15vw,1.15rem);font-weight:700;line-height:1.15;overflow-wrap:anywhere;text-align:center;white-space:normal}.tuning-channel-mute-row{display:flex;align-items:center;justify-content:center;min-height:2.3rem;width:100%}.tuning-channel-mute{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;max-width:100%;color:#fff;font-size:.875rem;line-height:1.15;overflow-wrap:anywhere;text-align:center;white-space:normal}.tuning-channel-title__compact,.tuning-channel-mute__compact{display:none}@media (max-width: 560px){.tuning-surface{padding:0 .25rem}.tuning-control-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.35rem}.tuning-channel-control{width:100%}.tuning-channel-control--chanter{row-gap:.35rem}.tuning-channel-title{min-height:2.15rem;padding:0 .125rem;font-size:clamp(.64rem,2.65vw,.74rem);line-height:1.08;overflow-wrap:normal;text-align:center;word-break:normal}.tuning-channel-title__full,.tuning-channel-mute__full{display:none}.tuning-channel-title__compact,.tuning-channel-mute__compact{display:inline}.tuning-channel-title__compact{display:inline-block;max-width:100%;text-wrap:balance;white-space:normal}.tuning-channel-mute-row{min-height:1.65rem}.tuning-channel-mute{gap:.15rem;font-size:.68rem;line-height:1;white-space:nowrap}.tuning-channel-mute input{width:.85rem;height:.85rem}.tuning-channel-control--chanter label{gap:2px!important}.tuning-channel-control--chanter input[type=radio]{width:.8rem;height:.8rem;margin:0}.tuning-channel-control--chanter span{font-size:.68rem!important;line-height:1.05}}.leaderboard-modal{color:#fff;box-shadow:0 28px 70px #0000006b}.leaderboard-panel{display:grid;gap:1rem;max-height:88vh;padding:clamp(1rem,3vw,1.35rem);overflow:hidden;border-radius:18px;background:linear-gradient(180deg,#05080cf0,#05080cdb);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.leaderboard-panel__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding-bottom:.85rem;border-bottom:1px solid rgba(255,255,255,.14)}.leaderboard-panel__header h2{margin:0;color:#fff6d1;font-size:clamp(1.6rem,4vw,2.15rem);line-height:1.08}.leaderboard-panel__close{flex:0 0 auto;width:2.35rem;height:2.35rem;padding:0;color:#ffffffc7;border-color:#ffffff29;border-radius:999px;background:#ffffff0f;font-size:1.45rem;line-height:1;box-shadow:none}.leaderboard-panel__close:hover{color:#fff;border-color:#ffffff42;background:#ffffff1c}@media (max-width: 899px){.app-controls__desktop{flex-wrap:wrap;justify-content:flex-end;max-width:min(100%,42rem);border-radius:1.25rem}}
