*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1e1b4b;--bg2: #312e81;--card: #faf5ff;--ink: #1e1b4b;--accent: #7c3aed;--accent2: #f59e0b;--ok: #16a34a}body{font-family:Comic Sans MS,Trebuchet MS,-apple-system,BlinkMacSystemFont,sans-serif;background:linear-gradient(160deg,var(--bg),var(--bg2));color:#f3f4f6;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}#app{width:100%;display:flex;justify-content:center}.screen{display:none;width:100%;max-width:min(600px,100%);flex-direction:column;align-items:center;gap:18px}.screen.active{display:flex}h1{font-size:1.8rem;text-align:center}.subtitle{font-size:.92rem;color:#c7d2fe;text-align:center}.topbar{width:100%;display:flex;justify-content:space-between;font-size:1.1rem;font-weight:700}.stars-box{color:#fde047}.score-row{display:flex;gap:14px;align-items:center}.daily{color:#fca5a5}.wrong-box{color:#f87171;font-size:1.05rem;font-weight:700}.string-dots{display:flex;gap:12px}.sdot{width:46px;height:46px;border-radius:50%;border:3px solid #6366f1;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:700;color:#c7d2fe;transition:all .3s ease}.sdot.current{border-color:#fde047;color:#fde047;transform:scale(1.08)}.sdot.done{border-color:var(--ok);background:var(--ok);color:#fff}.card,.note-card{width:100%;background:#ffffff14;border-radius:20px;padding:22px;display:flex;flex-direction:column;align-items:center;gap:14px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.string-name{font-size:2.3rem;font-weight:800;color:#fde047}.string-target{font-size:.85rem;color:#c7d2fe}.needle-wrap{width:100%;position:relative;height:56px}.needle-track{position:absolute;width:100%;height:8px;top:50%;transform:translateY(-50%);background:#4338ca;border-radius:4px}.needle-center{position:absolute;width:3px;height:26px;background:#c7d2fe;left:50%;top:50%;transform:translate(-50%,-50%);border-radius:2px}.needle{position:absolute;width:20px;height:20px;border-radius:50%;background:#9ca3af;top:50%;left:50%;transform:translate(-50%,-50%);transition:left .08s linear,background .15s ease;box-shadow:0 0 8px #0006}.needle-labels{display:flex;justify-content:space-between;width:100%;font-size:.75rem;color:#a5b4fc}.tuner-status{font-size:1.15rem;font-weight:700;min-height:1.6rem;text-align:center}.tuner-hz{font-size:.85rem;color:#a5b4fc;min-height:1.2rem}.gauge-wrap{width:100%;background:#efe6c9;border:6px solid #2a2a2a;border-radius:14px;padding:6px;box-sizing:border-box}.gauge-wrap svg{display:block;width:100%;height:auto}.gauge-needle{transition:transform .22s cubic-bezier(.25,.8,.4,1);transform-box:fill-box}.mic-level{width:70%;max-width:220px;height:12px;border-radius:6px;background:#ffffff1f;overflow:hidden;margin:2px auto 0}.mic-level-fill{height:100%;width:0%;border-radius:6px;background:#34d399;transition:width .08s linear,background .15s ease}.mic-level-label{font-size:.72rem;color:#a5b4fc;text-align:center}.series-line{font-size:.95rem;color:#fde047;font-weight:800;text-align:center;min-height:1.2rem;letter-spacing:.5px}.btn{border:none;border-radius:16px;font-size:1.05rem;font-weight:700;cursor:pointer;transition:transform .1s ease,opacity .2s;padding:15px 34px;font-family:inherit}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent2);color:#1e1b4b}.btn-primary:hover:not(:disabled){filter:brightness(1.08)}.btn-skip{background:transparent;border:2px solid #6366f1;color:#c7d2fe;padding:9px 22px;font-size:.9rem}.mic-btn{width:80px;height:80px;border-radius:50%;border:none;font-size:1.8rem;cursor:pointer;transition:all .2s ease;background:#6366f1;color:#fff}.mic-btn.listening{background:#dc2626;color:#fff;animation:pulse 1.4s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #dc262673}50%{box-shadow:0 0 0 16px #dc262600}}.warning{background:#451a03;border:1px solid #92400e;border-radius:12px;padding:12px 16px;font-size:.88rem;color:#fbbf24;text-align:center;width:100%}.mode-toggle{display:flex;background:#ffffff14;border-radius:14px;padding:5px;gap:5px}.mode-btn{padding:9px 22px;border:none;border-radius:10px;font-size:.92rem;font-weight:700;cursor:pointer;color:#c7d2fe;background:transparent;font-family:inherit;transition:all .2s}.mode-btn.active{background:var(--accent2);color:#1e1b4b}.acc-toggle{font-size:.85rem;color:#c7d2fe;display:block;cursor:pointer}.acc-toggle input{vertical-align:middle;margin-right:6px}.level-line{font-size:.85rem;color:#fde047;font-weight:700;min-height:1rem}#vf,#rh-vf,#r-vf{background:#fff;border-radius:12px;width:100%;overflow:hidden}#vf svg,#rh-vf svg,#r-vf svg{display:block;width:100%!important}#vf.vf-fit,#r-vf.vf-fit{display:flex;justify-content:center}#vf.vf-fit svg,#r-vf.vf-fit svg{width:auto!important;max-width:100%;margin:0 auto}.note-label{font-size:1.9rem;font-weight:800;color:#fde047;letter-spacing:1px}.mascot{font-size:1rem;color:#e0e7ff;text-align:center;background:#ffffff12;border-radius:14px;padding:10px 16px;width:100%}.mascot span{font-weight:600}.feedback{font-size:1.4rem;font-weight:800;min-height:2rem;text-align:center}.feedback.correct{color:#4ade80}.feedback.too-high{color:#fbbf24}.feedback.too-low{color:#60a5fa}.mic-area{display:flex;flex-direction:column;align-items:center;gap:8px}.mic-hint{font-size:.85rem;color:#c7d2fe}.detected-freq{font-size:.8rem;color:#a5b4fc;min-height:1.1rem}.streak{font-size:1.15rem;font-weight:800;color:#fb923c;animation:bob .8s ease-in-out infinite alternate}@keyframes bob{0%{transform:scale(1)}to{transform:scale(1.12)}}.progress-bar-wrap{width:100%;height:10px;background:#ffffff1f;border-radius:5px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:5px;transition:width .4s ease}.menu-grid{display:flex;flex-direction:column;gap:14px;width:100%}.menu-card{width:100%;background:#ffffff14;border:2px solid transparent;border-radius:18px;padding:18px 20px;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .2s;color:#f3f4f6}.menu-card:hover{border-color:var(--accent2);background:#ffffff21}.menu-card:active{transform:scale(.97)}.menu-icon{font-size:2.4rem}.menu-label{font-size:1.15rem;font-weight:800}.menu-sub{font-size:.82rem;color:#a5b4fc}.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%}.choice-btn{padding:16px 8px;border:2px solid #6366f1;border-radius:14px;background:#ffffff12;color:#f3f4f6;font-size:1.4rem;font-weight:800;cursor:pointer;font-family:inherit;transition:all .15s}.choice-btn:hover{background:#6366f140}.choice-btn:active{transform:scale(.95)}.choice-correct{background:#16a34a!important;border-color:#16a34a!important;color:#fff!important}.choice-wrong{background:#dc2626!important;border-color:#dc2626!important;color:#fff!important}.tap-zone{width:100%;min-height:110px;border-radius:20px;background:#6366f133;border:3px dashed #6366f1;color:#c7d2fe;font-size:1.5rem;font-weight:800;cursor:pointer;font-family:inherit;transition:all .1s;display:flex;align-items:center;justify-content:center}.tap-zone.tapped{background:#fde04740;border-color:#fde047;transform:scale(.97)}.result-box{width:100%;background:#ffffff12;border-radius:18px;padding:20px;display:flex;flex-direction:column;align-items:center;gap:10px}.result-beats{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.beat-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700}.beat-dot.ok{background:#16a34a;color:#fff}.beat-dot.miss{background:#dc2626;color:#fff}.feedback.wrong{color:#f87171}.icon-btn{background:#ffffff1a;border:none;border-radius:10px;font-size:1.1rem;cursor:pointer;padding:6px 10px;transition:background .2s}.icon-btn:hover{background:#fff3}.login-box{width:100%;max-width:340px;display:flex;flex-direction:column;align-items:center;gap:16px}.login-logo{font-size:3.5rem}.login-form{width:100%;display:flex;flex-direction:column;gap:10px}.login-input{width:100%;padding:12px 14px;border-radius:12px;border:2px solid #6366f1;background:#ffffff14;color:#f3f4f6;font-size:1rem;font-family:inherit;outline:none}.login-input:focus{border-color:var(--accent2)}.login-input::placeholder{color:#9ca3af}.login-submit{width:100%;margin-top:4px}.login-error{background:#450a0a;border:1px solid #dc2626;border-radius:8px;padding:8px 12px;font-size:.9rem;color:#fca5a5}.login-hint{font-size:.8rem;color:#a5b4fc;text-align:center}.admin-header{width:100%;display:flex;justify-content:space-between;align-items:center;font-size:1.1rem;font-weight:700}.admin-action-btn{padding:8px 14px;font-size:.88rem}.tab-bar{display:flex;gap:4px;width:100%}.tab-btn{flex:1;padding:9px 6px;border:none;border-radius:10px;font-size:.85rem;font-weight:700;cursor:pointer;background:#ffffff14;color:#c7d2fe;font-family:inherit;transition:all .2s}.tab-btn.active{background:var(--accent2);color:#1e1b4b}.tab-content{width:100%}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th{padding:6px 8px;text-align:left;color:#a5b4fc;border-bottom:1px solid rgba(255,255,255,.12)}.admin-table td{padding:7px 8px;border-bottom:1px solid rgba(255,255,255,.06)}.admin-table tr:last-child td{border-bottom:none}.admin-row td{color:#fde047}.btn-tiny{border:none;border-radius:6px;padding:4px 10px;font-size:.78rem;cursor:pointer;background:#ffffff1f;color:#e0e7ff;font-family:inherit}.btn-tiny.danger{background:#dc262640;color:#fca5a5}.btn-tiny:hover{filter:brightness(1.2)}.add-user-form{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.add-user-form .login-input{flex:1;min-width:120px}.empty-msg{color:#9ca3af;font-size:.9rem;padding:8px 0}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.overlay-box{background:var(--bg2);border-radius:20px;padding:24px;width:min(94vw,380px);display:flex;flex-direction:column;align-items:center;gap:14px}.celebrate-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:50}.confetti{position:absolute;top:-8vh;animation-name:fall;animation-timing-function:linear}@keyframes fall{to{transform:translateY(115vh) rotate(540deg);opacity:.9}}.preset-btn{padding:10px 16px;border:2px solid #6366f1;border-radius:12px;background:#ffffff12;color:#f3f4f6;font-size:.9rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s}.preset-btn.active{background:var(--accent2);border-color:var(--accent2);color:#1e1b4b}.preset-btn:hover:not(.active){background:#6366f140}@media (min-width: 600px){.screen{max-width:580px}.note-card{padding:28px}#vf,#rh-vf,#r-vf{min-height:160px}.choice-btn{font-size:1.6rem;padding:20px 8px}.btn{font-size:1.15rem;padding:17px 38px}h1{font-size:2.1rem}}.badge-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(80px);background:#1e1b4b;border:2px solid #6366f1;border-radius:16px;padding:14px 20px;display:flex;align-items:center;gap:14px;color:#f3f4f6;font-size:.9rem;z-index:100;box-shadow:0 8px 32px #00000080;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .35s;opacity:0;pointer-events:none}.badge-toast--show{transform:translate(-50%) translateY(0);opacity:1}.badge-emoji{font-size:2rem}.topbar-actions{display:flex;gap:8px;align-items:center}.hint-text{font-size:.78rem;color:#a5b4fc}.icon-btn.danger:hover{background:#ef444433;color:#f87171}
