@import "https://fonts.googleapis.com/css2?family=Caveat:wght@500;600;700&family=Shantell+Sans:wght@400;500;600&display=swap";.home-entry{background:var(--paper);border:var(--stroke);border-radius:var(--wonky-card);cursor:pointer;text-align:left;align-items:center;gap:14px;width:100%;padding:14px 16px;transition:transform .12s,background .12s;display:flex}.home-entry:hover{background:#fff7e6;transform:rotate(-.8deg)}.home-entry:active{transform:scale(.98)}.home-entry__icon{width:44px;height:44px;color:var(--tomato);border:var(--stroke);background:var(--paper);border-radius:50% 45% 55% 48%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.home-entry__icon svg{width:26px;height:26px}.home-entry__text{flex-direction:column;flex:1;gap:2px;display:flex}.home-entry__text strong{font-size:17px;font-weight:600}.home-entry__text small{color:var(--soft);font-size:12px}.home-entry__arrow{font-family:var(--font-hand);color:var(--soft);font-size:24px}.ui-screen .ui-card+.ui-card{margin-top:var(--gap,14px)}.sc-field{margin-bottom:12px}.sc-label{font-family:var(--font-ui);color:var(--soft);margin-bottom:6px;font-size:13px;display:block}.sc-notes{border-top:1.5px dashed var(--soft);flex-wrap:wrap;gap:6px;margin-top:10px;padding-top:12px;display:flex}.sc-note{font-family:var(--font-hand);color:var(--ink);border:1.5px solid #0000;border-radius:10px 6px;padding:1px 8px;font-size:20px;font-weight:600;transition:transform .12s,background .12s,color .12s,border-color .12s}.sc-note.playing{background:var(--tomato);color:var(--paper);border-color:var(--ink);transform:scale(1.18)rotate(-2deg)}.sc-note.following{background:var(--teal);color:var(--paper);border-color:var(--ink);transform:scale(1.1)}.sc-hint{font-family:var(--font-ui);color:var(--soft);margin:0 0 12px;font-size:14px;line-height:1.6}.sc-btn-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.sc-target{font-family:var(--font-ui);color:var(--ink);justify-content:space-between;align-items:baseline;margin-bottom:6px;font-size:16px;display:flex}.sc-target strong{font-family:var(--font-hand);color:var(--teal);margin-left:4px;font-size:30px;font-weight:700}.sc-target__progress{font-family:var(--font-hand);color:var(--soft);font-size:18px}.sc-meter{margin:8px 0 14px}.sc-meter__svg{width:100%;height:auto;display:block}.sc-meter__tick{font-family:var(--font-hand);fill:var(--soft);font-size:13px}.sc-meter__needle{transition:transform 80ms linear,opacity .25s}.sc-meter__readout{text-align:center;font-family:var(--font-hand);margin-top:2px;font-size:28px;font-weight:700}.sc-meter__dir{font-family:var(--font-ui);color:var(--soft);margin-top:2px;font-size:13px;font-weight:500;display:block}.sc-meter[data-active=off]{opacity:.6}.sc-error{font-family:var(--font-ui);color:var(--paper);background:var(--tomato);border:var(--stroke);border-radius:var(--wonky-card);margin-top:12px;padding:10px 12px;font-size:14px}.sc-result{text-align:center;border:2px dashed var(--ink);border-radius:var(--wonky-card);background:var(--paper2);margin-top:14px;padding:12px}.sc-result__num{font-family:var(--font-hand);color:var(--tomato);font-size:52px;font-weight:700;line-height:1}.sc-result__unit{font-family:var(--font-ui);color:var(--soft);margin-top:4px;font-size:13px}.sc-chart{font-family:var(--font-ui);margin:0 -4px}.lt-timer-card,.lt-live{margin-bottom:var(--gap)}.lt-timer-card{text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.lt-timer{font-family:var(--font-hand);letter-spacing:.02em;font-size:64px;font-weight:700;line-height:1;transition:color .2s;transform:rotate(-1.5deg)}.lt-error{color:var(--bad);margin:0;font-size:13px;line-height:1.5}.lt-howto{color:var(--ink);margin:0;padding-left:20px;font-size:14px;line-height:1.7}.lt-howto li{margin-bottom:4px}.lt-live{flex-direction:column;align-items:stretch;gap:14px;display:flex}.lt-ring{justify-content:center;align-items:center;width:168px;height:168px;margin:4px auto 0;display:flex;position:relative}.lt-ring__pulse{border:5px solid var(--soft);border-radius:var(--wonky-circle,50%);opacity:.5;position:absolute;inset:0;transform:scale(.92)}.lt-ring__pulse.is-active{animation-name:lt-pulse;animation-timing-function:ease-in-out;animation-iteration-count:infinite}@keyframes lt-pulse{0%{opacity:.35;transform:scale(.86)}50%{opacity:.9;transform:scale(1.04)}to{opacity:.35;transform:scale(.86)}}.lt-ring__core{flex-direction:column;align-items:center;gap:2px;display:flex}.lt-ring__label{font-family:var(--font-hand);font-size:38px;font-weight:700;line-height:1;transform:rotate(-2deg)}.lt-ring__hz{font-family:var(--font-hand);opacity:.8;font-size:20px;font-weight:600}.lt-gauge{flex-direction:column;align-items:center;gap:2px;display:flex}.lt-gauge__svg{width:240px;max-width:100%;height:auto}.lt-gauge__tick{fill:var(--soft);font-family:var(--font-hand);font-size:13px;font-weight:600}.lt-gauge__read{font-family:var(--font-hand);font-size:22px;font-weight:700;transform:rotate(-1deg)}.lt-spark-wrap{flex-direction:column;gap:4px;display:flex}.lt-spark-label{color:var(--soft);font-size:12px}.lt-spark{border:var(--stroke);background:#fff7e6;border-radius:12px 6px;width:100%;height:48px;display:block}.lt-meter{flex-direction:column;gap:4px;display:flex}.lt-meter__head{color:var(--ink);justify-content:space-between;font-size:13px;display:flex}.lt-meter__val{font-family:var(--font-hand);color:var(--soft);font-size:16px;font-weight:600}.lt-meter__track{border:var(--stroke);background:var(--paper2);border-radius:8px;height:12px;overflow:hidden}.lt-meter__fill{border-radius:6px;height:100%;transition:width .15s,background .2s}.lt-advice{text-align:center;margin:2px 0 0;font-size:14px;font-weight:500;line-height:1.6}.lt-empty{color:var(--soft);margin:0;font-size:14px;line-height:1.6}.lt-trend{margin:4px 0 14px}.lt-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.lt-item{border:var(--stroke);border-radius:var(--wonky-card);background:#fff7e6;align-items:center;gap:12px;padding:10px 12px;display:flex}.lt-item__score{text-align:center;width:46px;font-family:var(--font-hand);flex-shrink:0;font-size:32px;font-weight:700;line-height:1}.lt-item__body{flex:1;min-width:0}.lt-item__meta{flex-direction:column;gap:1px;display:flex}.lt-item__meta strong{color:var(--ink);font-size:14px;font-weight:600}.lt-item__meta span{color:var(--soft);font-size:12px}.lt-item__advice{color:var(--soft);margin:4px 0 0;font-size:12px;line-height:1.5}.lt-item__del{border:var(--stroke);background:var(--paper);width:28px;height:28px;color:var(--ink);cursor:pointer;border-radius:50%;flex-shrink:0;font-size:13px;line-height:1;transition:transform .12s,background .12s,color .12s}.lt-item__del:hover{background:var(--tomato);color:var(--paper);transform:rotate(8deg)}.bz-form{flex-direction:column;gap:18px;display:flex}.bz-trend{margin-top:16px}.bz-metric__head{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.bz-metric__label{font-family:var(--font-ui);color:var(--ink);font-size:16px;font-weight:600}.bz-metric__score{font-family:var(--font-hand);font-size:22px;font-weight:700}.bz-metric__hint{color:var(--soft);margin:2px 0 8px;font-size:12px}.bz-dots{gap:10px;display:flex}.bz-dot{border:var(--stroke);border-radius:var(--wonky-circle);background:var(--paper);width:40px;height:40px;color:var(--ink);font-family:var(--font-hand);cursor:pointer;flex:none;font-size:20px;font-weight:700;transition:transform .12s,background .12s,color .12s}.bz-dot:hover{transform:rotate(-4deg)scale(1.05)}.bz-dot:active{transform:scale(.94)}.bz-dot.on{color:var(--paper)}.bz-note{flex-direction:column;gap:6px;display:flex}.bz-note__label{font-family:var(--font-ui);color:var(--ink);font-size:14px;font-weight:600}.bz-note__input{box-sizing:border-box;border:var(--stroke);width:100%;color:var(--ink);font-family:var(--font-ui);border-radius:var(--wonky-card);resize:vertical;background:#fff7e6;padding:10px 12px;font-size:15px;line-height:1.5}.bz-note__input::placeholder{color:var(--soft);opacity:.8}.bz-note__input:focus{border-color:var(--tomato);outline:none}.bz-error{border:2px dashed var(--bad);border-radius:var(--wonky-card);color:var(--bad);margin:0;padding:8px 12px;font-size:14px;font-weight:600}.bz-ok{color:var(--good);font-family:var(--font-hand);margin:0;font-size:20px;font-weight:700}.bz-legend{flex-wrap:wrap;gap:14px;margin-bottom:10px;display:flex}.bz-legend__item{color:var(--soft);align-items:center;gap:6px;font-size:13px;display:inline-flex}.bz-legend__swatch{border:2px solid var(--ink);border-radius:6px 3px;flex:none;width:16px;height:8px}.bz-empty{color:var(--soft);margin:8px 0;font-size:14px}.bz-chart{font-family:var(--font-ui)}.bz-tooltip{background:var(--paper-hi);border:var(--stroke);font-family:var(--font-ui);border-radius:12px 6px;padding:8px 10px;box-shadow:2px 2px #43352a40}.bz-tooltip__day{font-family:var(--font-hand);color:var(--ink);margin-bottom:2px;font-size:18px;font-weight:700}.bz-tooltip__row{font-size:13px;font-weight:600}.ui-screen>.ui-card+.ui-card{margin-top:var(--gap)}.sg-empty,.sg-status{font-family:var(--font-ui);color:var(--soft);margin:12px 0 0;font-size:14px}.sg-status{color:var(--ink)}.sg-error{font-family:var(--font-ui);color:var(--bad);border:2px dashed var(--tomato);background:#fff3ee;border-radius:12px 6px;margin:12px 0 0;padding:8px 12px;font-size:13.5px}.sg-song-list,.sg-rec-list{flex-direction:column;gap:10px;margin:14px 0 0;padding:0;list-style:none;display:flex}.sg-song{align-items:stretch;gap:8px;display:flex}.sg-song__pick{text-align:left;border:var(--stroke);background:var(--paper);color:var(--ink);cursor:pointer;border-radius:var(--wonky-card);flex-direction:column;flex:1;gap:2px;padding:10px 14px;transition:transform .12s,background .12s;display:flex}.sg-song__pick:hover{background:#fff7e6;transform:rotate(-.6deg)}.sg-song__pick:active{transform:scale(.985)}.sg-song__pick:disabled{opacity:.6;cursor:not-allowed;transform:none}.sg-song.is-active .sg-song__pick{background:var(--teal);color:var(--paper)}.sg-song__name{font-family:var(--font-ui);word-break:break-all;font-size:15px;font-weight:600}.sg-song__meta{font-family:var(--font-ui);opacity:.85;font-size:12px}.sg-song__del{border:var(--stroke);background:var(--paper);width:44px;color:var(--ink);cursor:pointer;border-radius:12px 6px;flex-shrink:0;font-size:17px;transition:transform .12s,background .12s}.sg-song__del:hover{background:#fff3ee;transform:rotate(2deg)}.sg-song__del:disabled{opacity:.4;cursor:not-allowed;transform:none}.sg-headphone{font-family:var(--font-ui);color:var(--ink);background:var(--mustard);border:var(--stroke);border-radius:var(--wonky-chip);margin-bottom:14px;padding:9px 14px;font-size:13.5px;font-weight:600;transform:rotate(-.8deg)}.sg-current{font-family:var(--font-ui);color:var(--ink);margin:0 0 14px;font-size:14px}.sg-current strong{word-break:break-all;font-weight:700}.sg-rec{align-items:center;gap:10px;margin:0 0 14px;display:flex}.sg-rec__dot{background:var(--tomato);border:2px solid var(--ink);border-radius:50%;width:14px;height:14px;animation:1s ease-in-out infinite sg-pulse}@keyframes sg-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.sg-rec__time{font-family:var(--font-hand);color:var(--tomato);font-size:28px;font-weight:700;line-height:1}.sg-rec__hint{font-family:var(--font-ui);color:var(--soft);font-size:12px}.sg-rec-item{border:var(--stroke);background:var(--paper);border-radius:var(--wonky-card);padding:12px 14px}.sg-rec-item__head{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px;display:flex}.sg-rec-item__info{flex-direction:column;gap:2px;min-width:0;display:flex}.sg-rec-item__name{font-family:var(--font-ui);color:var(--ink);word-break:break-all;font-size:15px;font-weight:600}.sg-rec-item__meta{font-family:var(--font-ui);color:var(--soft);font-size:12px}.sg-audio{width:100%;height:38px}.ui-btn{border:var(--stroke);background:var(--paper);color:var(--ink);font-family:var(--font-ui);cursor:pointer;border-radius:var(--wonky-btn);justify-content:center;align-items:center;gap:8px;padding:11px 20px;font-size:16px;font-weight:500;transition:transform .12s,background .12s,color .12s;display:inline-flex}.ui-btn:hover{transform:rotate(-1.5deg)}.ui-btn:active{transform:scale(.97)}.ui-btn--primary{background:var(--mustard)}.ui-btn--accent{background:var(--tomato);color:var(--paper)}.ui-btn--ghost{font-family:var(--font-hand);background:0 0;border-style:dashed;font-size:19px;font-weight:600}.ui-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.ui-btn--block{width:100%}.ui-toggle{border:var(--stroke);background:var(--paper);cursor:pointer;border-radius:16px;flex-shrink:0;width:50px;height:27px;padding:0;transition:background .2s;position:relative}.ui-toggle.on{background:var(--teal)}.ui-toggle__knob{background:var(--ink);border-radius:50%;width:19px;height:19px;transition:left .2s,background .2s;position:absolute;top:2px;left:2px}.ui-toggle.on .ui-toggle__knob{background:var(--paper);left:25px}.ui-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.ui-row>span{font-size:15px}.ui-chip{border:var(--stroke);background:var(--paper);color:var(--ink);cursor:pointer;font-size:14px;font-family:var(--font-ui);border-radius:var(--wonky-chip);padding:7px 14px;transition:transform .12s,background .12s,color .12s}.ui-chip:hover{transform:rotate(-1.5deg)}.ui-chip.active{background:var(--teal);color:var(--paper)}.ui-chip.active.mustard{background:var(--mustard);color:var(--ink)}.ui-chips{flex-wrap:wrap;gap:8px;display:flex}.ui-card{background:var(--paper);border:var(--stroke);border-radius:var(--wonky-card);padding:16px}.ui-card__title{font-family:var(--font-hand);margin:0 0 8px;font-size:22px;font-weight:700;transform:rotate(-1deg)}.ui-num{border:var(--stroke);width:62px;color:var(--ink);font-family:var(--font-hand);text-align:center;background:#fff7e6;border-radius:12px 6px;padding:5px 8px;font-size:20px;font-weight:600}.ui-num::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ui-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.ui-num[type=number]{-moz-appearance:textfield}.ui-num-row{flex-wrap:wrap;align-items:center;gap:8px;font-size:14px;display:flex}.ui-tabbar{height:calc(var(--tabbar-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--paper);border-top:var(--stroke);z-index:50;display:flex;position:fixed;bottom:0;left:0;right:0}.ui-tab{color:var(--soft);cursor:pointer;font-family:var(--font-ui);background:0 0;border:none;flex-direction:column;flex:1 1 0;justify-content:center;align-items:center;gap:2px;padding:6px 2px;font-size:11px;transition:color .15s,transform .15s;display:flex}.ui-tab svg{width:24px;height:24px}.ui-tab.active{color:var(--ink);transform:translateY(-1px)}.ui-tab.active svg{color:var(--tomato)}.ui-screen{width:100%;max-width:480px;padding:calc(var(--safe-top) + 14px) 18px calc(var(--tabbar-h) + 28px);box-sizing:border-box;flex:auto;margin:0 auto}.ui-screen__title{font-family:var(--font-hand);color:var(--ink);margin:0 0 2px;font-size:30px;font-weight:700;transform:rotate(-2deg)}.ui-screen__sub{color:var(--soft);letter-spacing:.1em;margin:0 0 16px;font-size:12px}.app-main{flex-direction:column;flex:auto;width:100%;display:flex}:root{--paper:#f5e9ce;--paper2:#eeddb8;--paper-hi:#fbf3de;--ink:#43352a;--tomato:#d8543f;--mustard:#e6a52e;--teal:#3b8c7b;--soft:#8a765f;--good:var(--teal);--warn:var(--mustard);--bad:var(--tomato);--font-hand:"Caveat", cursive;--font-ui:"Shantell Sans", system-ui, sans-serif;--wonky-chip:225px 15px 200px 15px / 15px 200px 15px 225px;--wonky-btn:255px 18px 225px 18px / 18px 225px 18px 255px;--wonky-card:18px 8px 18px 8px / 8px 18px 8px 18px;--wonky-circle:52% 48% 51% 49% / 49% 51% 49% 51%;--stroke-w:2.5px;--stroke:var(--stroke-w) solid var(--ink);--gap:14px;--pad:18px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--tabbar-h:66px}*{box-sizing:border-box}html,body,#root{height:100%}body{color:var(--ink);font-family:var(--font-ui);background:radial-gradient(130% 90% at 50% -10%, var(--paper-hi) 0%, var(--paper) 55%, var(--paper2) 100%), repeating-linear-gradient(transparent, transparent 31px, #43352a0f 31px, #43352a0f 32px);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;-webkit-tap-highlight-color:transparent;overscroll-behavior-y:none;background-attachment:fixed;margin:0}#root{flex-direction:column;min-height:100%;display:flex}:focus-visible{outline:3px solid var(--tomato);outline-offset:2px}button{color:inherit;font-family:inherit}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}
