*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app.dark{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-tertiary: #252542;--text-primary: #ffffff;--text-secondary: #a0a0b0;--text-muted: #6b6b80;--border-color: #333355;--accent-color: #6366f1;--success-color: #22c55e;--warning-color: #eab308;--error-color: #ef4444}.app.light{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #e2e8f0;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border-color: #cbd5e1;--accent-color: #4f46e5;--success-color: #16a34a;--warning-color: #ca8a04;--error-color: #dc2626}.app{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);display:flex;flex-direction:column}.app-header{background:var(--bg-secondary);padding:1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:.5rem}.app-header h1{font-size:1.25rem;font-weight:600;white-space:nowrap}.header-controls{display:flex;align-items:center;gap:.75rem}.tuning-selector{display:flex;align-items:center;gap:.5rem}.tuning-selector label{font-size:.875rem;color:var(--text-secondary)}.tuning-selector select{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:.5rem;padding:.5rem .75rem;font-size:.875rem;cursor:pointer;outline:none}.tuning-selector select:focus{border-color:var(--accent-color)}.theme-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:.5rem;padding:.5rem;font-size:1.25rem;cursor:pointer;transition:transform .2s}.theme-toggle:hover{transform:scale(1.1)}.app-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:1.5rem 1rem;gap:1.5rem;max-width:500px;margin:0 auto;width:100%}.error-message,.permission-message{background:#ef44441a;border:1px solid var(--error-color);border-radius:.75rem;padding:1rem;text-align:center;width:100%}.error-message{color:var(--error-color);display:flex;align-items:center;justify-content:center;gap:.5rem}.permission-message{color:var(--text-secondary)}.permission-hint{font-size:.875rem;color:var(--text-muted);margin-top:.5rem}.tuner-display{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:1rem;padding:1.5rem;width:100%;min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.note-display{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.25rem}.note-display .string-number{font-size:.875rem;color:var(--text-muted)}.note-display .note-letter{font-size:5rem;font-weight:700;line-height:1;transition:color .2s}.note-display.waiting .note-letter{color:var(--text-muted)}.note-display .note-info{font-size:1.25rem;font-weight:500;transition:color .2s}.note-display.perfect .note-letter{animation:pulse 1s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.needle-container{width:100%;max-width:280px;display:flex;flex-direction:column;align-items:center}.needle-labels{display:flex;justify-content:space-between;width:100%;padding:0 .5rem;margin-bottom:.25rem}.needle-labels .label-left{font-size:.75rem;font-weight:600;color:#3b82f6}.needle-labels .label-right{font-size:.75rem;font-weight:600;color:#ef4444}.needle-svg{width:100%;height:auto}.cent-display{font-size:1rem;font-weight:500;margin-top:.5rem}.frequency-display{display:flex;flex-direction:column;align-items:center;gap:.25rem}.frequency-display .frequency{font-size:1.5rem;font-weight:600;font-variant-numeric:tabular-nums}.frequency-display .target-frequency{font-size:.875rem;color:var(--text-muted)}.volume-meter{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.volume-bar{height:100%;background:var(--accent-color);border-radius:3px;transition:width .05s linear}.mic-button{display:flex;align-items:center;justify-content:center;gap:.75rem;background:var(--accent-color);color:#fff;border:none;border-radius:9999px;padding:1rem 2rem;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px #6366f166}.mic-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f180}.mic-button:active{transform:translateY(0)}.mic-button.listening{background:var(--error-color);box-shadow:0 4px 14px #ef444466;animation:listening-pulse 2s infinite}@keyframes listening-pulse{0%,to{box-shadow:0 4px 14px #ef444466}50%{box-shadow:0 4px 30px #ef444499}}.mic-icon{font-size:1.5rem}.string-selector{width:100%;display:flex;flex-direction:column;align-items:center;gap:.75rem}.strings-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;width:100%}.string-btn{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:1rem;padding:.75rem .25rem;display:flex;flex-direction:column;align-items:center;gap:.25rem;cursor:pointer;transition:all .2s}.string-btn:hover{border-color:var(--accent-color);background:#6366f11a}.string-btn.selected{background:var(--accent-color);border-color:var(--accent-color);color:#fff;transform:scale(1.05);box-shadow:0 4px 12px #6366f166}.string-btn .string-num{font-size:.625rem;color:var(--text-muted)}.string-btn.selected .string-num{color:#fffc}.string-btn .string-note{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.string-btn.selected .string-note{color:#fff}.selected-hint{font-size:.75rem;color:var(--accent-color);text-align:center}.string-buttons{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:1rem;padding:1rem;width:100%}.string-buttons h3{font-size:.875rem;color:var(--text-secondary);text-align:center;margin-bottom:.75rem}.buttons-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}.string-button{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:.75rem;padding:.75rem .25rem;display:flex;flex-direction:column;align-items:center;gap:.25rem;cursor:pointer;transition:all .2s}.string-button:hover{border-color:var(--accent-color);background:#6366f11a}.string-button.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.string-button .string-number{font-size:.625rem;color:var(--text-muted)}.string-button.active .string-number{color:#fffc}.string-button .string-note{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.string-button.active .string-note{color:#fff}.string-button .string-freq{font-size:.625rem;color:var(--text-muted)}.string-button.active .string-freq{color:#fffc}.listening-hint{font-size:.875rem;color:var(--text-muted);text-align:center}@media (min-width: 640px){.app-header h1{font-size:1.5rem}.note-display .note-letter{font-size:7rem}.note-display .note-info{font-size:1.5rem}.needle-container{max-width:320px}.mic-button{padding:1.25rem 2.5rem;font-size:1.25rem}.string-button{padding:1rem .5rem}.string-button .string-note{font-size:1.5rem}.string-button .string-number,.string-button .string-freq{font-size:.75rem}}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}button:focus-visible,select:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}
