:root{--font-display: "Space Grotesk", system-ui, -apple-system, sans-serif;--font-ui: "Manrope", system-ui, -apple-system, sans-serif;--font-mono: "DM Mono", ui-monospace, "SF Mono", monospace}*{box-sizing:border-box}html,body{margin:0;height:100%}body{background:#131416;font-family:var(--font-ui);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;display:grid;place-items:center;overflow:hidden}[data-theme=ember]{--bg: oklch(.19 .013 60);--bg2: oklch(.165 .012 58);--surface: oklch(.24 .015 60);--surface2: oklch(.28 .016 60);--text: oklch(.95 .012 75);--dim: oklch(.68 .014 72);--faint: oklch(.5 .012 65);--line: oklch(.34 .013 60);--accent: oklch(.8 .12 62);--good: oklch(.83 .16 152);--warn: oklch(.76 .16 55);--shadow: 0 30px 80px rgba(0,0,0,.55)}[data-theme=midnight]{--bg: oklch(.17 .022 256);--bg2: oklch(.145 .02 256);--surface: oklch(.23 .026 256);--surface2: oklch(.28 .03 256);--text: oklch(.96 .012 250);--dim: oklch(.68 .025 250);--faint: oklch(.5 .02 252);--line: oklch(.32 .025 256);--accent: oklch(.78 .12 215);--good: oklch(.83 .15 162);--warn: oklch(.78 .15 50);--shadow: 0 30px 80px rgba(0,0,0,.6)}[data-theme=paper]{--bg: oklch(.975 .008 85);--bg2: oklch(.95 .009 85);--surface: oklch(.995 .005 85);--surface2: oklch(.93 .01 85);--text: oklch(.27 .014 65);--dim: oklch(.52 .014 68);--faint: oklch(.68 .012 72);--line: oklch(.88 .009 85);--accent: oklch(.6 .13 48);--good: oklch(.58 .15 152);--warn: oklch(.6 .18 45);--shadow: 0 30px 80px rgba(0,0,0,.4)}[data-theme=studio]{--bg: oklch(.92 .022 88);--bg2: oklch(.88 .024 86);--surface: oklch(.96 .018 88);--surface2: oklch(.85 .026 86);--text: oklch(.24 .022 58);--dim: oklch(.46 .024 56);--faint: oklch(.6 .02 60);--line: oklch(.78 .026 86);--accent: oklch(.55 .18 30);--good: oklch(.5 .14 150);--warn: oklch(.52 .19 32);--shadow: 0 30px 80px rgba(0,0,0,.4)}.app{position:relative;width:min(100vw,440px);height:100dvh;display:flex;flex-direction:column;background:radial-gradient(120% 80% at 50% -10%,var(--bg2),var(--bg) 60%);color:var(--text);overflow:hidden;padding:calc(env(safe-area-inset-top) + 8px) 20px calc(env(safe-area-inset-bottom) + 18px);transition:background .4s ease,color .4s ease}@media(min-width:480px){body{padding:24px}.app{height:min(calc(100dvh - 48px),900px);border-radius:40px;box-shadow:var(--shadow);border:1px solid color-mix(in oklab,var(--line),transparent 30%)}}.start{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:38px;text-align:center;animation:view-enter .38s cubic-bezier(.3,.8,.3,1)}.tuner-view{flex:1;min-height:0;display:flex;flex-direction:column;animation:view-enter .38s cubic-bezier(.3,.8,.3,1)}@keyframes view-enter{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}.brand{display:flex;flex-direction:column;align-items:center;gap:14px}.brand-mark{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:var(--surface);color:var(--accent);border:1px solid var(--line)}.brand h1{font-family:var(--font-display);font-size:46px;font-weight:600;letter-spacing:-.02em;margin:0;line-height:1}.brand p{margin:0;color:var(--dim);font-size:15px}.start-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:18px;color:var(--text)}.start-ring{position:relative;width:168px;height:168px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle at 50% 38%,color-mix(in oklab,var(--accent),transparent 78%),transparent 70%),var(--surface);border:1px solid var(--line);transition:transform .25s cubic-bezier(.3,.7,.4,1),box-shadow .25s}.start-ring:before,.start-ring:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:1.5px solid color-mix(in oklab,var(--accent),transparent 55%);animation:pulse-ring 2.8s ease-out infinite}.start-ring:after{animation-delay:1.4s}.start-ico{position:relative;z-index:1;width:92px;height:92px;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:var(--bg);box-shadow:0 10px 30px color-mix(in oklab,var(--accent),transparent 60%)}.start-btn:hover .start-ring{transform:scale(1.03)}.start-btn:active .start-ring{transform:scale(.97)}.start-btn.busy .start-ico{animation:breathe 1.4s ease-in-out infinite}.start-lbl{font-family:var(--font-display);font-size:19px;font-weight:500;letter-spacing:-.01em}.start-meta{display:flex;align-items:center;gap:10px}.pill{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:999px;background:var(--surface);border:1px solid var(--line);color:var(--text);font-family:var(--font-ui);font-size:14px;font-weight:600}.pill-sub{color:var(--dim);font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;font-weight:400;white-space:nowrap}.mic-blocked{display:flex;flex-direction:column;gap:6px;max-width:260px;text-align:center;padding:14px 18px;border-radius:14px;background:color-mix(in oklab,var(--warn),transparent 88%);border:1px solid color-mix(in oklab,var(--warn),transparent 60%);color:var(--dim);font-size:13px;line-height:1.4;animation:view-enter .3s cubic-bezier(.3,.8,.3,1)}.mic-blocked strong{color:var(--warn);font-weight:600;font-size:13px}.guitar-seg{display:flex;border-radius:999px;background:var(--surface);border:1px solid var(--line);overflow:hidden}.guitar-seg-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;border:0;background:transparent;padding:8px 14px;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--dim);text-transform:capitalize;transition:background .2s,color .2s}.guitar-seg-btn.on{background:var(--surface2);color:var(--text)}.install-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;border:0;background:transparent;display:inline-flex;align-items:center;gap:6px;color:var(--faint);font-family:var(--font-ui);font-size:13px;text-decoration:underline;text-underline-offset:3px;padding:0;animation:view-enter .5s .3s cubic-bezier(.3,.8,.3,1) both}.install-btn:hover{color:var(--dim)}.topbar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 2px 4px}.tb-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;border:1px solid transparent;background:transparent;color:var(--text);font-family:var(--font-ui)}.tb-tuning{display:flex;flex-direction:column;align-items:flex-start;gap:1px;padding:7px 12px;border-radius:12px;background:var(--surface);border:1px solid var(--line)}.tb-name{font-size:14px;font-weight:600}.tb-short{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--dim);white-space:nowrap}.tb-right{display:flex;align-items:center;gap:10px}.tb-btn.icon{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--line);color:var(--dim)}.tb-btn.icon:hover{color:var(--text)}.capo-badge{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--accent);margin-left:6px;font-weight:400}.stage{flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.meter{--off: 0;--live: color-mix(in oklab, var(--good), var(--warn) calc(var(--off, 0) * 1%));position:relative;width:min(78vw,320px);display:grid;place-items:center;transition:transform .35s cubic-bezier(.34,1.56,.5,1);transform-origin:center}.meter.intune{transform:scale(1.035)}.meter-ring{aspect-ratio:1;width:min(76vw,44vh,320px)}.ring-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible}.ring-track{fill:none;stroke:var(--line);stroke-width:5}.ring-glow{fill:none;stroke:var(--good);stroke-width:6;opacity:0;transition:opacity .35s ease;filter:drop-shadow(0 0 10px var(--good))}.meter.intune .ring-glow{opacity:.95}.ring-arc{fill:none;stroke:var(--live);stroke-width:7;stroke-linecap:round;transition:stroke .18s ease;filter:drop-shadow(0 0 6px color-mix(in oklab,var(--live),transparent 45%))}.ring-dot circle{fill:var(--live);transition:fill .18s ease,opacity .2s ease;filter:drop-shadow(0 0 8px color-mix(in oklab,var(--live),transparent 35%))}.tick{stroke:var(--line);stroke-width:2;stroke-linecap:round}.tick-mid{stroke:var(--dim);stroke-width:2.5}.meter.intune .tick-mid{stroke:var(--good)}.ring-side{position:absolute;top:8%;font-family:var(--font-display);font-size:18px;color:var(--faint)}.ring-flat{left:10%}.ring-sharp{right:10%}.note-block{display:flex;flex-direction:column;align-items:center;gap:2px;transition:opacity .3s ease}.meter.nosignal .note-block{opacity:.55}.note-main{display:flex;align-items:flex-start;line-height:.9}.note-letter{font-family:var(--font-display);font-weight:600;font-size:92px;letter-spacing:-.03em;color:var(--text);transition:color .3s ease}.meter.intune .note-letter{color:var(--good)}.note-marks{display:flex;flex-direction:column;align-items:flex-start;margin-left:4px;padding-top:12px}.note-acc{font-family:var(--font-display);font-size:30px;color:var(--dim);line-height:1;min-height:8px}.note-oct{font-family:var(--font-mono);font-size:18px;color:var(--faint);margin-top:auto}.note-cents{font-family:var(--font-mono);font-size:15px;letter-spacing:.04em;color:var(--live);transition:color .2s ease;min-height:18px;font-variant-numeric:tabular-nums;white-space:nowrap}.meter.intune .note-cents{color:var(--good)}.meter.nosignal .note-cents{color:var(--faint)}.note-hz{font-family:var(--font-mono);font-size:11px;color:var(--faint);letter-spacing:.05em;white-space:nowrap}.meter-linear{gap:26px;padding-top:8px}.bar-wrap{display:flex;align-items:center;gap:14px;width:min(82vw,340px)}.bar-side{font-family:var(--font-display);font-size:18px;color:var(--faint)}.bar-track{position:relative;flex:1;height:58px}.bar-ticks{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:space-between}.btick{width:2px;height:12px;background:var(--line);border-radius:2px}.btick-mid{height:26px;width:2.5px;background:var(--dim)}.meter.intune .btick-mid{background:var(--good)}.bar-fill{position:absolute;left:50%;top:50%;height:4px;width:0;background:var(--live);border-radius:4px;transform-origin:left center;transition:background .18s ease;filter:drop-shadow(0 0 6px color-mix(in oklab,var(--live),transparent 50%))}.bar-dot{position:absolute;left:50%;top:50%;width:16px;height:38px;margin:-19px 0 0 -8px;border-radius:8px;background:var(--live);transition:background .18s ease,opacity .2s ease;box-shadow:0 0 14px color-mix(in oklab,var(--live),transparent 35%)}.status{font-size:15px;color:var(--dim);text-align:center;min-height:20px;transition:color .3s ease}.status b{color:var(--text);font-weight:600}.status b sub{font-family:var(--font-mono);font-size:.62em;color:var(--dim)}.status.done{color:var(--good);font-weight:500}.strings{display:flex;gap:8px;justify-content:center;padding:6px 0 2px}.str{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;position:relative;flex:1;max-width:60px;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:15px;border:1px solid var(--line);background:var(--surface);color:var(--dim);font-family:var(--font-display);transition:transform .18s cubic-bezier(.3,.7,.4,1),background .25s,color .25s,border-color .25s,box-shadow .25s}.str:hover{transform:translateY(-2px)}.str-note{font-size:21px;font-weight:600;display:flex;align-items:flex-start}.str-acc{font-size:12px;margin-top:1px}.str-oct{font-family:var(--font-mono);font-size:10px;color:var(--faint);margin-top:1px}.str-check{position:absolute;top:6px;right:6px;opacity:0;transform:scale(.4);color:var(--good);transition:opacity .2s,transform .25s cubic-bezier(.34,1.56,.5,1)}.str.active{color:var(--text);border-color:color-mix(in oklab,var(--accent),transparent 30%);box-shadow:0 0 0 1.5px color-mix(in oklab,var(--accent),transparent 45%)}.str.active:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:18px;border:1.5px solid color-mix(in oklab,var(--accent),transparent 25%);animation:active-pulse 1.5s ease-in-out infinite alternate;pointer-events:none}.str.detected{color:var(--text);background:var(--surface2)}.str.tuned{color:var(--good);background:color-mix(in oklab,var(--good),transparent 86%);border-color:color-mix(in oklab,var(--good),transparent 55%)}.str.tuned:after{display:none}.str.tuned .str-oct{color:color-mix(in oklab,var(--good),transparent 30%)}.str.tuned .str-check{opacity:1;transform:scale(1)}.str.tuned.active{box-shadow:none}.retune{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;margin:14px auto 2px;display:block;padding:11px 22px;border-radius:999px;background:var(--accent);color:var(--bg);border:0;font-family:var(--font-ui);font-size:14px;font-weight:600;transition:opacity .2s}.retune:hover{opacity:.85}.sheet-scrim{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;background:color-mix(in oklab,#000,transparent 50%);opacity:0;pointer-events:none;transition:opacity .3s ease;display:flex;align-items:flex-end}.sheet-scrim.open{opacity:1;pointer-events:auto}.sheet{width:100%;background:var(--bg2);border-top-left-radius:26px;border-top-right-radius:26px;border-top:1px solid var(--line);max-height:82dvh;overflow-y:auto;overscroll-behavior:contain;padding:12px 20px calc(env(safe-area-inset-bottom) + 24px);transform:translateY(100%);transition:transform .34s cubic-bezier(.3,.8,.3,1);box-shadow:0 -20px 50px #00000059}.sheet-scrim.open .sheet{transform:translateY(0)}.sheet-grip{width:38px;height:4px;border-radius:4px;background:var(--line);margin:2px auto 14px}.sheet-title{font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);margin-bottom:12px}.tlist{display:flex;flex-direction:column;gap:6px}.trow{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;position:relative;text-align:left;display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;background:var(--surface);border:1px solid var(--line);color:var(--text);transition:background .2s,border-color .2s}.trow:hover{background:var(--surface2)}.trow.on{border-color:color-mix(in oklab,var(--accent),transparent 40%);background:color-mix(in oklab,var(--accent),transparent 90%)}.trow-name{font-family:var(--font-display);font-size:16px;font-weight:500}.trow-notes{font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;color:var(--dim);margin-left:auto}.trow-dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}.cust-editor{margin-top:14px;display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--line);padding-top:14px}.cust-header{display:flex;gap:10px;padding:0 2px 4px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}.cust-header span:first-child{width:16px;text-align:center;flex-shrink:0}.cust-header span:not(:first-child){flex:1;text-align:center}.cust-row{display:flex;align-items:center;gap:10px}.cust-str-lbl{font-family:var(--font-mono);font-size:12px;color:var(--faint);width:16px;text-align:center;flex-shrink:0}.cust-ctrl{flex:1;display:flex;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:10px;overflow:hidden}.cust-arrow{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;cursor:pointer;color:var(--dim);font-size:18px;padding:8px 12px;line-height:1;transition:color .15s,background .15s}.cust-arrow:hover{color:var(--text);background:var(--surface2)}.cust-val{flex:1;text-align:center;font-family:var(--font-display);font-size:15px;font-weight:600;color:var(--text)}.cust-oct{font-family:var(--font-mono);font-size:14px;font-weight:400;color:var(--dim)}.set-grp{padding:6px 0 16px;border-bottom:1px solid var(--line)}.set-grp--last,.set-grp:last-of-type{border-bottom:0}.set-lbl{font-size:14px;font-weight:600;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.set-val{font-family:var(--font-mono);color:var(--accent);font-weight:400}.set-hint{font-size:12px;color:var(--faint);margin-top:9px}.seg{display:flex;gap:4px;padding:4px;background:var(--surface);border-radius:12px;border:1px solid var(--line)}.seg-b{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;flex:1;padding:9px;border:0;border-radius:9px;background:transparent;color:var(--dim);font-family:var(--font-ui);font-size:14px;font-weight:600;text-transform:capitalize;transition:background .2s,color .2s}.seg-b.on{background:var(--surface2);color:var(--text);box-shadow:0 1px 3px #0000002e}.chips{display:flex;gap:7px;flex-wrap:wrap}.chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;padding:9px 14px;border-radius:10px;background:var(--surface);border:1px solid var(--line);color:var(--dim);font-family:var(--font-mono);font-size:13px;transition:all .2s}.chip.on{background:color-mix(in oklab,var(--accent),transparent 86%);color:var(--accent);border-color:color-mix(in oklab,var(--accent),transparent 50%)}.toggle{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;border:0;padding:0;width:44px;height:26px;border-radius:999px;background:var(--line);position:relative;transition:background .2s}.toggle.on{background:var(--accent)}.toggle-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:var(--bg);box-shadow:0 1px 3px #0000004d;transition:transform .2s cubic-bezier(.34,1.56,.5,1)}.toggle.on .toggle-thumb{transform:translate(18px)}.set-action{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;width:100%;margin-top:16px;padding:13px;border-radius:13px;border:0;background:var(--accent);color:var(--bg);font-family:var(--font-ui);font-size:15px;font-weight:600}.toast{position:absolute;left:50%;bottom:calc(env(safe-area-inset-bottom) + 96px);transform:translate(-50%);z-index:40;background:var(--surface2);color:var(--text);border:1px solid var(--line);border-radius:999px;padding:10px 18px;font-size:13px;white-space:nowrap;box-shadow:0 10px 30px #0000004d;animation:toast-in .3s cubic-bezier(.3,.8,.3,1)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}@keyframes pulse-ring{0%{transform:scale(1);opacity:.6}to{transform:scale(1.28);opacity:0}}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}@keyframes active-pulse{0%{opacity:.7;transform:scale(1)}to{opacity:0;transform:scale(1.22)}}@media(prefers-reduced-motion:reduce){.start-ring:before,.start-ring:after,.str.active:after,.start-btn.busy .start-ico{animation:none}}
