:root{--color-bg-dark: #090d16;--color-bg-light: #0d1527;--color-card-bg: rgba(20, 27, 45, .65);--color-card-border: rgba(255, 255, 255, .07);--color-text-primary: #f8fafc;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-accent: #5ec8c0;--color-accent-glow: rgba(94, 200, 192, .3);--color-in-tune: #10b981;--color-in-tune-glow: rgba(16, 185, 129, .35);--color-flat: #f59e0b;--color-flat-glow: rgba(245, 158, 11, .3);--color-sharp: #ef4444;--color-sharp-glow: rgba(239, 68, 68, .3);--transition-fast: .15s ease;--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0;user-select:none;-webkit-user-select:none}.icon-svg{width:1.15em;height:1.15em;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:middle;transition:transform var(--transition-normal)}.btn-icon{display:flex;align-items:center;justify-content:center}.spinner-svg{width:1.1em;height:1.1em;stroke:currentColor;stroke-width:3;fill:none;animation:spin 1s linear infinite;display:inline-block;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}button,select,input,label,a,.control-btn,.action-btn,.string-btn,.timer-preset-btn{touch-action:manipulation}body{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--color-bg-dark);color:var(--color-text-primary);min-height:100vh;min-height:100dvh;display:flex;justify-content:center;align-items:center;overflow:hidden;padding:1rem;position:relative;box-sizing:border-box}.app-background-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:radial-gradient(circle,#06b6d414,#10b9810a 40%,#0000 70%);z-index:0;pointer-events:none}.app-container{width:100%;max-width:500px;height:100%;max-height:860px;display:flex;flex-direction:column;justify-content:center;z-index:1}.app-card{background:var(--color-card-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--color-card-border);border-radius:28px;box-shadow:0 24px 64px -12px #0009,inset 0 1px 1px #ffffff14;overflow:hidden;transition:box-shadow var(--transition-slow);display:flex;flex-direction:column;max-height:100%}.app-card:hover{box-shadow:0 28px 72px -8px #000000b3,inset 0 1px 1px #ffffff1f}.app-header{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:2rem 2rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.04)}.header-top-row{display:flex;justify-content:space-between;align-items:center;width:100%}.app-logo{display:flex;align-items:center;gap:.5rem}.app-logo .logo-icon{display:flex;align-items:center;justify-content:center}.app-logo .logo-icon .logo-svg{width:1.65rem;height:1.65rem;color:var(--color-accent);filter:drop-shadow(0 2px 8px var(--color-accent-glow));transition:color .3s ease,filter .3s ease}.theme-switcher{display:flex;gap:6px;align-items:center;background:#0003;padding:4px 6px;border-radius:20px;border:1px solid rgba(255,255,255,.03)}.theme-swatch{width:14px;height:14px;border-radius:50%;border:1.5px solid transparent;cursor:pointer;padding:0;transition:transform .2s ease,border-color .2s ease;position:relative;box-sizing:border-box}.theme-swatch:hover{transform:scale(1.25)}.theme-swatch.active{transform:scale(1.25);border-color:#fff;box-shadow:0 0 8px currentColor}.app-logo h1{font-size:1.5rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;background:linear-gradient(135deg,#f8fafc 30%,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.tab-selectors{display:flex;background:#0b1324cc;border-radius:16px;padding:.25rem;width:100%;border:1px solid rgba(255,255,255,.05);box-shadow:inset 0 2px 4px #00000080,0 8px 24px -4px #0009;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.tab-btn{flex:1;display:flex;justify-content:center;align-items:center;gap:.5rem;background:none;border:1px solid transparent;color:var(--color-text-secondary);padding:.75rem 1rem;font-family:inherit;font-size:.95rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all var(--transition-normal);opacity:.7}.tab-btn:hover{color:var(--color-text-primary);opacity:.95;background:#ffffff08}.tab-btn:active{transform:scale(.97)}.tab-btn.active{color:var(--color-text-primary);opacity:1;background:linear-gradient(135deg,#ffffff1a,#ffffff05);border:1px solid rgba(255,255,255,.14);box-shadow:0 6px 20px -5px #06b6d433,0 4px 12px #00000073,inset 0 1px 1px #ffffff26;transform:translateY(-.5px)}.tab-btn.active:active{transform:translateY(-.5px) scale(.98)}.tab-icon{font-size:1.05rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.35));transition:transform var(--transition-normal),filter var(--transition-normal)}.tab-btn.active .tab-icon{transform:scale(1.12);filter:drop-shadow(0 2px 8px var(--color-accent-glow))}.card-content{position:relative;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.tab-panel{display:none;padding:2rem;opacity:0;transform:translateY(10px);transition:opacity var(--transition-normal),transform var(--transition-normal)}.tab-panel.active{display:block;opacity:1;transform:translateY(0)}.control-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:var(--color-text-primary);padding:.75rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all var(--transition-fast)}.control-btn:hover{background:#ffffff14;border-color:#ffffff1f}.control-btn:active{transform:scale(.97)}.control-btn.active{background:var(--color-accent-glow);border-color:var(--color-accent);color:var(--color-text-primary);box-shadow:0 0 12px var(--color-accent-glow)}.action-btn{background:var(--color-text-primary);border:none;color:var(--color-bg-dark);padding:1rem 2rem;font-family:inherit;font-size:1.05rem;font-weight:700;border-radius:14px;cursor:pointer;display:flex;justify-content:center;align-items:center;gap:.5rem;transition:all var(--transition-normal);box-shadow:0 4px 20px #00000040}.action-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #ffffff26}.action-btn:active{transform:translateY(1px) scale(.98)}.tuner-layout{display:flex;flex-direction:column;gap:1rem}.tuner-display-section{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:#00000026;border-radius:20px;padding:1.5rem 1rem;border:1px solid rgba(255,255,255,.02)}.gauge-container{position:relative;width:100%;max-width:280px;margin-bottom:.75rem}.gauge{width:100%;height:auto}.gauge-track{stroke:#ffffff14}.gauge-center-zone{stroke:var(--color-in-tune);opacity:.4;transition:opacity var(--transition-normal)}.gauge-ticks line{stroke:var(--color-text-muted);stroke-width:1.5;opacity:.5}.gauge-needle{stroke:var(--color-text-secondary);fill:var(--color-text-secondary);transform-origin:100px 110px;transition:transform .25s cubic-bezier(.175,.885,.32,1.275),stroke var(--transition-fast),fill var(--transition-fast)}.gauge-labels{position:absolute;bottom:-15px;left:0;right:0;display:flex;justify-content:space-between;padding:0 1rem;font-size:.75rem;font-weight:800;letter-spacing:.05em;color:var(--color-text-muted)}.label-intune{text-align:center}.state-flat .gauge-needle{stroke:var(--color-flat);fill:var(--color-flat);filter:drop-shadow(0 0 4px var(--color-flat-glow))}.state-flat .gauge-center-zone{opacity:.4}.state-sharp .gauge-needle{stroke:var(--color-sharp);fill:var(--color-sharp);filter:drop-shadow(0 0 4px var(--color-sharp-glow))}.state-sharp .gauge-center-zone{opacity:.4}.state-intune .gauge-needle{stroke:var(--color-in-tune);fill:var(--color-in-tune);filter:drop-shadow(0 0 8px var(--color-in-tune-glow))}.state-intune .gauge-center-zone{opacity:1;stroke-width:10}.note-display-wrapper{display:flex;flex-direction:column;align-items:center;margin-top:-.5rem}.note-letter{font-size:4rem;font-weight:800;line-height:1;color:var(--color-text-primary);text-shadow:0 0 20px rgba(255,255,255,.05);transition:color var(--transition-fast),text-shadow var(--transition-fast)}.state-intune .note-letter{color:var(--color-in-tune);text-shadow:0 0 30px var(--color-in-tune-glow)}.state-flat .note-letter{color:var(--color-flat);text-shadow:0 0 30px var(--color-flat-glow)}.state-sharp .note-letter{color:var(--color-sharp);text-shadow:0 0 30px var(--color-sharp-glow)}.note-cents{font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:700;color:var(--color-text-secondary)}.state-intune .note-cents{color:var(--color-in-tune)}.tuner-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.info-card{background:#0003;border-radius:12px;padding:.75rem 1rem;border:1px solid rgba(255,255,255,.02);display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.info-value{font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:700;color:var(--color-text-primary)}.visualizer-container{width:100%;height:48px;background:#00000040;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.02)}#tuner-canvas{width:100%;height:100%;display:block}.tuner-controls{display:grid;grid-template-columns:1fr 1.1fr;gap:.75rem;align-items:center}.mode-toggles{display:grid;grid-template-columns:1fr 1fr;gap:.2rem;background:#0003;padding:.2rem;border-radius:12px;height:100%}.mode-toggles .control-btn{padding:.5rem .25rem;font-size:.8rem;height:100%;border-radius:10px;border:none;background:transparent}.mode-toggles .control-btn.active{background:#ffffff14;color:var(--color-text-primary);box-shadow:inset 0 1px #ffffff0d}.tuner-controls .action-btn{width:100%;padding:.65rem 1rem;font-size:.95rem;border-radius:12px;background:var(--color-accent);color:var(--color-bg-dark);transition:background-color .3s ease,color .3s ease,box-shadow var(--transition-fast)}.tuner-controls .action-btn:hover{box-shadow:0 0 16px var(--color-accent-glow)}.tuner-controls .action-btn.active{background:var(--color-sharp);color:var(--color-text-primary);box-shadow:0 0 16px var(--color-sharp-glow)}.guitar-neck-container{display:flex;flex-direction:column;gap:.75rem;background:#00000026;padding:1.25rem 1rem;border-radius:20px;border:1px solid rgba(255,255,255,.02)}.neck-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);text-align:center}.guitar-strings{display:flex;justify-content:space-between;align-items:stretch;height:90px;background:#1e1b18;border-radius:10px;position:relative;padding:0 .5rem;box-shadow:inset 0 2px 8px #000c,0 4px 12px #00000026;border:1px solid rgba(255,255,255,.03)}.guitar-strings:before{content:"";position:absolute;top:0;bottom:0;left:0;right:0;background:repeating-linear-gradient(90deg,transparent,transparent 15%,rgba(0,0,0,.1) 15%,rgba(0,0,0,.1) 16%);pointer-events:none;opacity:.4}.string-btn{position:relative;flex:1;background:none;border:none;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:.5rem 0;z-index:1;transition:background-color var(--transition-fast)}.string-btn:hover{background-color:#ffffff05}.string-btn.active{background-color:#ffffff0d}.string-wire{position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%);background:linear-gradient(90deg,#94a3b8,#cbd5e1,#64748b);box-shadow:0 0 2px #00000080;pointer-events:none;width:2px}.string-wire.size-e2{width:3.5px}.string-wire.size-a2{width:3px}.string-wire.size-d3{width:2.5px}.string-wire.size-g3{width:2px}.string-wire.size-b3{width:1.5px}.string-wire.size-e4{width:1px}@keyframes string-vibrate{0%{transform:translate(-50%) skew(0)}10%{transform:translate(-50%) skew(2deg) scaleX(1.3)}20%{transform:translate(-50%) skew(-2deg) scaleX(1.3)}30%{transform:translate(-50%) skew(1.5deg) scaleX(1.2)}40%{transform:translate(-50%) skew(-1.5deg) scaleX(1.2)}55%{transform:translate(-50%) skew(.8deg) scaleX(1.1)}70%{transform:translate(-50%) skew(-.8deg) scaleX(1.1)}85%{transform:translate(-50%) skew(.4deg) scaleX(1.05)}to{transform:translate(-50%) skew(0) scaleX(1)}}.string-btn.plucked .string-wire{animation:string-vibrate .6s ease-out}.string-note-name{font-size:.95rem;font-weight:800;color:var(--color-text-secondary);background:#14110f;border-radius:50%;width:24px;height:24px;display:flex;justify-content:center;align-items:center;border:1px solid rgba(255,255,255,.1);box-shadow:0 2px 4px #00000080;z-index:2;transition:all var(--transition-fast)}.string-btn:hover .string-note-name,.string-btn.active .string-note-name{color:var(--color-text-primary);border-color:var(--color-accent);box-shadow:0 0 8px var(--color-accent-glow)}.string-freq{font-size:.6rem;font-weight:700;color:var(--color-text-muted);z-index:2}.metronome-layout{display:flex;flex-direction:column;gap:1.75rem}.beat-bar-wrapper{display:flex;flex-direction:column;gap:.75rem;background:#00000026;padding:1.25rem;border-radius:16px;border:1px solid rgba(255,255,255,.02)}.beat-dots{display:flex;justify-content:center;gap:.75rem}.beat-dot{width:14px;height:14px;border-radius:50%;background:#ffffff14;border:1.5px solid rgba(255,255,255,.03);box-shadow:inset 0 1px 2px #0009;transition:all var(--transition-fast)}.beat-dot.active{background:var(--color-accent);box-shadow:0 0 12px var(--color-accent),inset 0 1px 1px #fff6}.beat-dot.accent.active{background:var(--color-sharp);box-shadow:0 0 14px var(--color-sharp),inset 0 1px 1px #fff6}.visual-flash-bar{width:100%;height:4px;background:#ffffff0a;border-radius:2px;position:relative;overflow:hidden}.visual-flash-bar:after{content:"";position:absolute;top:0;bottom:0;left:0;width:100%;background:linear-gradient(90deg,transparent,var(--color-accent),transparent);opacity:0;transform:translate(-100%)}.visual-flash-bar.flash:after{animation:flash-sweep .15s ease-out}.visual-flash-bar.flash-accent:after{background:linear-gradient(90deg,transparent,var(--color-sharp),transparent);animation:flash-sweep .15s ease-out}@keyframes flash-sweep{0%{opacity:0;transform:translate(-100%)}50%{opacity:1}to{opacity:0;transform:translate(100%)}}.bpm-display-section{display:flex;flex-direction:column;align-items:center;gap:.75rem}.bpm-text-wrapper{display:flex;align-items:baseline;gap:.25rem}.bpm-number{font-family:JetBrains Mono,monospace;font-size:5rem;font-weight:800;line-height:.9;color:var(--color-text-primary);letter-spacing:-.05em;text-shadow:0 4px 24px rgba(0,0,0,.3)}.bpm-unit{font-size:1.1rem;font-weight:700;color:var(--color-text-muted);letter-spacing:.05em}.bpm-fine-adjust{display:flex;gap:.5rem}.bpm-fine-adjust .adjust-btn{background:#ffffff08;border:1px solid rgba(255,255,255,.05);color:var(--color-text-secondary);padding:.5rem .8rem;font-family:JetBrains Mono,monospace;font-weight:700;font-size:.8rem;border-radius:8px;cursor:pointer;transition:all var(--transition-fast)}.bpm-fine-adjust .adjust-btn:hover{background:#ffffff14;border-color:#ffffff1a;color:var(--color-text-primary)}.bpm-fine-adjust .adjust-btn:active{transform:scale(.93)}.slider-wrapper{padding:0 .5rem}input[type=range]{-webkit-appearance:none;width:100%;background:transparent}input[type=range]:focus{outline:none}input[type=range]::-webkit-slider-runnable-track{width:100%;height:8px;cursor:pointer;background:#ffffff0f;border-radius:4px;border:1px solid rgba(255,255,255,.02)}input[type=range]::-webkit-slider-thumb{height:20px;width:20px;border-radius:50%;background:var(--color-text-primary);cursor:pointer;-webkit-appearance:none;margin-top:-6px;box-shadow:0 2px 10px #00000080,0 0 0 0 var(--color-accent-glow);transition:background-color var(--transition-fast),box-shadow var(--transition-fast)}input[type=range]:hover::-webkit-slider-thumb,input[type=range]:focus::-webkit-slider-thumb{background:var(--color-accent);box-shadow:0 2px 12px var(--color-accent-glow),0 0 0 6px var(--color-accent-glow)}input[type=range]::-moz-range-track{width:100%;height:8px;background:#ffffff0f;border-radius:4px}input[type=range]::-moz-range-thumb{height:20px;width:20px;border:none;border-radius:50%;background:var(--color-text-primary);cursor:pointer;box-shadow:0 2px 10px #00000080;transition:background-color var(--transition-fast),box-shadow var(--transition-fast)}input[type=range]:hover::-moz-range-thumb{background:var(--color-accent);box-shadow:0 2px 12px var(--color-accent-glow),0 0 0 6px var(--color-accent-glow)}.metronome-settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.setting-card{background:#00000026;border-radius:12px;padding:.75rem 1rem;border:1px solid rgba(255,255,255,.02);display:flex;flex-direction:column;gap:.4rem}.setting-card label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.setting-card select{background:transparent;border:none;color:var(--color-text-primary);font-family:inherit;font-size:.95rem;font-weight:600;outline:none;cursor:pointer;padding-right:1.5rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right center;background-size:1rem;-webkit-appearance:none;-moz-appearance:none}.setting-card select option{background-color:var(--color-bg-dark);color:var(--color-text-primary);font-family:inherit;padding:10px}.accent-card{justify-content:center}.checkbox-container{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.9rem!important;color:var(--color-text-secondary)!important;text-transform:none!important;letter-spacing:0!important}.checkbox-container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.custom-checkbox{height:20px;width:36px;background-color:#ffffff0f;border-radius:10px;position:relative;transition:background-color var(--transition-normal);border:1px solid rgba(255,255,255,.04)}.custom-checkbox:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background-color:var(--color-text-secondary);transition:transform var(--transition-normal),background-color var(--transition-normal)}.checkbox-container input:checked~.custom-checkbox{background-color:var(--color-accent-glow);border-color:var(--color-accent)}.checkbox-container input:checked~.custom-checkbox:after{transform:translate(16px);background-color:var(--color-accent)}.metronome-controls{display:grid;grid-template-columns:1fr 1.2fr;gap:1rem}.tap-btn{background:#ffffff08;border-color:#ffffff0f}.tap-btn:active{background:#ffffff14}.play-btn{background:var(--color-accent);color:var(--color-bg-dark)}.play-btn:hover{box-shadow:0 0 16px var(--color-accent-glow)}.play-btn.active{background:var(--color-sharp);color:var(--color-text-primary)}.play-btn.active:hover{box-shadow:0 0 16px var(--color-sharp-glow)}html,body{overflow:hidden;max-width:100%;height:100%}@media (max-width: 480px){body{padding:.25rem}.app-container{height:100dvh;padding:.25rem}.app-card{border-radius:20px;max-width:100%;height:100%}.tab-panel{padding:.75rem}.tab-btn{padding:.55rem .35rem;font-size:.8rem;gap:.2rem}.app-header{padding:.75rem .75rem .5rem;gap:.5rem}.app-logo h1,.app-logo .logo-icon{font-size:1.2rem}.tuner-layout{gap:.6rem}.tuner-display-section{padding:.5rem;gap:.15rem;border-radius:16px}.gauge-container{max-width:210px;margin-bottom:.6rem}.note-letter{font-size:2.6rem}.visualizer-container{height:32px}.guitar-neck-container{padding:.5rem;border-radius:16px;gap:.4rem}.neck-title{font-size:.62rem}.guitar-strings{height:65px}.metronome-layout{gap:.75rem}.bpm-display-section{gap:.4rem}.bpm-number{font-size:3.4rem}.bpm-fine-adjust .adjust-btn{padding:.4rem .6rem;font-size:.75rem}.beat-bar-wrapper{margin-bottom:.1rem}.metronome-settings-grid{gap:.45rem}.setting-card{padding:.45rem .6rem;gap:.25rem;border-radius:10px}.setting-card label{font-size:.62rem}.setting-card select{font-size:.85rem}.metronome-controls{gap:.6rem}.trainer-settings-grid{gap:.5rem;margin-top:.5rem}.sub-setting input{padding:.3rem;font-size:.8rem}.practice-timer-card{padding:.75rem;gap:.75rem;border-radius:16px}.timer-display-circle{width:160px;height:160px}.timer-text{font-size:2.1rem}.timer-presets{gap:.4rem}.timer-preset-btn{padding:.35rem;font-size:.75rem}}.tuner-stats-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;width:100%}.tuner-stats-bar .info-card{background:#00000026;border-radius:12px;padding:.5rem .75rem;border:1px solid rgba(255,255,255,.02);display:flex;flex-direction:column;justify-content:center;gap:.15rem}.tuner-stats-bar .select-card{position:relative;cursor:pointer}.tuner-stats-bar .select-card select{background:transparent;border:none;color:var(--color-text-primary);font-family:inherit;font-size:.85rem;font-weight:700;outline:none;cursor:pointer;width:100%;padding-right:1rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right center;background-size:.7rem;-webkit-appearance:none;-moz-appearance:none;text-overflow:ellipsis}.tuner-stats-bar .select-card select option{background-color:var(--color-bg-dark);color:var(--color-text-primary);font-family:inherit}.tuning-selector-card{display:flex;justify-content:space-between;align-items:center;background:#00000040;padding:.6rem 1rem;border-radius:12px;margin-bottom:.75rem;border:1px solid rgba(255,255,255,.02)}.tuning-selector-card label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.tuning-selector-card select{background:transparent;border:none;color:var(--color-text-primary);font-family:inherit;font-size:.9rem;font-weight:600;outline:none;cursor:pointer;padding-right:1.25rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right center;background-size:.8rem;-webkit-appearance:none}.tuning-selector-card select option{background-color:var(--color-bg-dark);color:var(--color-text-primary);font-family:inherit}.trainer-card{transition:all var(--transition-normal)}.trainer-settings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:.75rem}.sub-setting{display:flex;flex-direction:column;gap:.25rem}.sub-setting label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.sub-setting input{background:#0003;border:1px solid rgba(255,255,255,.06);color:var(--color-text-primary);border-radius:8px;padding:.4rem;font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:600;outline:none;text-align:center}.sub-setting input:focus{border-color:var(--color-accent);box-shadow:0 0 6px var(--color-accent-glow)}.practice-timer-card{background:#00000026;border-radius:20px;padding:1.25rem;border:1px solid rgba(255,255,255,.02);display:flex;flex-direction:column;align-items:center;gap:1rem}.timer-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);text-align:center}.timer-display-wrapper{display:flex;justify-content:center;margin:.25rem 0}.timer-display-circle{position:relative;width:200px;height:200px;display:flex;justify-content:center;align-items:center}.timer-svg{position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(-90deg)}.timer-circle-bg{fill:none;stroke:#ffffff0a;stroke-width:5}.timer-circle-progress{fill:none;stroke:var(--color-accent);stroke-dasharray:339.29;stroke-dashoffset:0;stroke-linecap:round;stroke-width:5;transition:stroke-dashoffset 1s linear,stroke var(--transition-normal)}.timer-text{font-family:JetBrains Mono,monospace;font-size:2.6rem;font-weight:700;color:var(--color-text-primary);z-index:1;text-shadow:0 2px 8px rgba(0,0,0,.4)}.timer-presets{display:flex;gap:.5rem;width:100%}.timer-preset-btn{flex:1;background:#ffffff08;border:1px solid rgba(255,255,255,.05);color:var(--color-text-secondary);padding:.45rem;font-family:inherit;font-size:.8rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all var(--transition-fast)}.timer-preset-btn:hover{background:#ffffff0f;color:var(--color-text-primary)}.timer-preset-btn.active{background:var(--color-accent-glow);border-color:var(--color-accent);color:var(--color-text-primary);box-shadow:0 0 8px var(--color-accent-glow)}.timer-action-controls{display:grid;grid-template-columns:1.2fr 1fr;gap:.5rem;width:100%}.timer-action-controls button{padding:.6rem;font-size:.85rem}@keyframes pulse-green{0%{stroke:var(--color-accent)}50%{stroke:var(--color-in-tune);filter:drop-shadow(0 0 6px var(--color-in-tune-glow))}to{stroke:var(--color-accent)}}.timer-circle-progress.complete{stroke:var(--color-in-tune);animation:pulse-green 1.5s infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}#trainer-settings{animation:fadeIn var(--transition-normal) forwards}@keyframes tab-beat-pulse{0%{background:var(--color-accent-glow);border-color:var(--color-accent);box-shadow:0 0 14px var(--color-accent-glow)}to{background:none;border-color:transparent;box-shadow:none}}@keyframes tab-beat-pulse-accent{0%{background:#f59e0b40;border-color:var(--color-flat);box-shadow:0 0 14px #f59e0b66}to{background:none;border-color:transparent;box-shadow:none}}.tab-btn.beat-flash{animation:tab-beat-pulse .22s cubic-bezier(.1,.8,.3,1) forwards}.tab-btn.beat-flash-accent{animation:tab-beat-pulse-accent .22s cubic-bezier(.1,.8,.3,1) forwards}.app-swipe-hint{display:flex;justify-content:center;align-items:center;padding:.5rem 0 1.25rem;border-top:1px solid rgba(255,255,255,.02);background:#00000014;font-family:JetBrains Mono,monospace;font-size:.62rem;font-style:italic;font-weight:400;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);opacity:.25;pointer-events:none;user-select:none;-webkit-user-select:none;animation:swipe-hint-pulse 4s ease-in-out infinite}@keyframes swipe-hint-pulse{0%,to{opacity:.22}50%{opacity:.45}}@media (max-width: 480px){.app-swipe-hint{padding:.4rem 0 .85rem;font-size:.58rem}}.practice-layout{display:flex;flex-direction:column;gap:1.25rem}.practice-sub-selectors{display:flex;background:#00000040;border-radius:12px;padding:.2rem;border:1px solid rgba(255,255,255,.03);box-shadow:inset 0 1px 3px #00000080;margin:0 .75rem}.sub-tab-btn{flex:1;background:none;border:none;color:var(--color-text-secondary);padding:.5rem;font-family:inherit;font-size:.85rem;font-weight:600;border-radius:9px;cursor:pointer;transition:all var(--transition-normal)}.sub-tab-btn:hover{color:var(--color-text-primary)}.sub-tab-btn.active{background:#ffffff0f;color:var(--color-text-primary);border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px #ffffff0d,0 2px 8px #0000004d}.practice-sub-panel{display:none}.practice-sub-panel.active{display:block;animation:fadeIn var(--transition-normal) forwards}.chord-trainer-card{background:#00000026;border-radius:20px;padding:1.25rem;border:1px solid rgba(255,255,255,.02);display:flex;flex-direction:column;gap:1.25rem}.chord-trainer-config{display:grid;grid-template-columns:1.3fr 1fr;gap:.75rem}#custom-progression-builder{display:flex;flex-direction:column;gap:.6rem;background:#0003;padding:.75rem;border-radius:12px;border:1px solid rgba(255,255,255,.03);animation:fadeIn var(--transition-normal) forwards}.custom-chord-chips{display:flex;flex-wrap:wrap;gap:.4rem;min-height:32px;align-items:center;background:#00000026;padding:.4rem;border-radius:8px;border:1px dashed rgba(255,255,255,.1)}.chord-chip{background:var(--color-accent-glow);border:1px solid var(--color-accent);color:var(--color-text-primary);padding:.25rem .5rem;border-radius:6px;font-size:.8rem;font-family:JetBrains Mono,monospace;font-weight:700;display:flex;align-items:center;gap:.25rem;cursor:pointer;animation:fadeIn var(--transition-fast) forwards}.chord-chip:hover{background:#ef444433;border-color:var(--color-sharp)}.chord-chip:after{content:"×";font-size:.75rem;opacity:.7}.chord-pool{display:flex;flex-wrap:wrap;gap:.35rem}.chord-pool-btn{background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:var(--color-text-secondary);padding:.25rem .6rem;font-size:.75rem;font-family:JetBrains Mono,monospace;font-weight:700;border-radius:6px;cursor:pointer;transition:all var(--transition-fast)}.chord-pool-btn:hover{background:#ffffff14;color:var(--color-text-primary);border-color:#ffffff1a}.chord-pool-btn:active{transform:scale(.95)}.clear-custom-btn{background:transparent;border:1px solid rgba(239,68,68,.3);color:var(--color-sharp);padding:.25rem .6rem;font-size:.75rem;font-weight:600;border-radius:6px;cursor:pointer;margin-left:auto;transition:all var(--transition-fast)}.clear-custom-btn:hover{background:#ef44441a}.chord-diagrams-container{display:grid;grid-template-columns:1.2fr .8fr;gap:1.25rem;align-items:center;background:#00000026;padding:1rem;border-radius:16px;border:1px solid rgba(255,255,255,.01)}.chord-active-box,.chord-next-box{display:flex;flex-direction:column;align-items:center;gap:.4rem}.chord-box-title{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.chord-name{font-size:2.2rem;font-weight:800;color:var(--color-text-primary);line-height:1;font-family:JetBrains Mono,monospace;text-shadow:0 0 15px rgba(255,255,255,.05)}.chord-name.next{font-size:1.6rem;color:var(--color-text-secondary)}.chord-diagram-wrapper{width:90px;height:110px;background:#00000040;border-radius:10px;padding:.35rem;border:1px solid rgba(255,255,255,.03);box-shadow:inset 0 2px 6px #00000080;display:flex;justify-content:center;align-items:center;transition:transform var(--transition-normal)}.chord-diagram-wrapper.mini{width:65px;height:80px;padding:.25rem;opacity:.7}.chord-svg{width:100%;height:100%}.chord-trainer-footer{display:flex;flex-direction:column;gap:.85rem;align-items:center;width:100%}.chord-beat-progress{display:flex;justify-content:center;gap:.6rem;height:12px}.chord-beat-progress .beat-dot{width:10px;height:10px;background:#ffffff0f;border-radius:50%;transition:all var(--transition-fast)}.chord-beat-progress .beat-dot.active{background:var(--color-accent);box-shadow:0 0 10px var(--color-accent-glow)}.chord-beat-progress .beat-dot.prepare.active{background:var(--color-flat);box-shadow:0 0 12px var(--color-flat-glow);animation:prepare-flash .5s ease infinite alternate}@keyframes prepare-flash{0%{transform:scale(1)}to{transform:scale(1.25)}}@media (max-width: 480px){.practice-sub-selectors{margin:0 .25rem}.chord-trainer-card{padding:.75rem;gap:.75rem}.chord-trainer-config{gap:.5rem}.chord-diagrams-container{padding:.65rem;gap:.75rem}.chord-name{font-size:1.8rem}.chord-name.next{font-size:1.3rem}.chord-diagram-wrapper{width:75px;height:95px}.chord-diagram-wrapper.mini{width:55px;height:70px}}
