html{box-sizing:border-box}*,*:before,*:after{box-sizing:inherit}:root{--font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;--line-height: 1.6;--font-weight: 400;--color-bg-app: #f8fafc;--color-bg-panel: #ffffff;--color-text-primary: #1e293b;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-accent: #3b82f6;--color-accent-hover: #2563eb;--color-border: #e2e8f0;--color-interval-root-rgb: 16, 185, 129;--color-interval-root: rgba(var(--color-interval-root-rgb), .85);--color-interval-root-glow: rgba(var(--color-interval-root-rgb), .4);--color-interval-3-rgb: 245, 158, 11;--color-interval-3: rgba(var(--color-interval-3-rgb), .85);--color-interval-3-glow: rgba(var(--color-interval-3-rgb), .4);--color-interval-5-rgb: 59, 130, 246;--color-interval-5: rgba(var(--color-interval-5-rgb), .85);--color-interval-5-glow: rgba(var(--color-interval-5-rgb), .4);--color-interval-default: #f1f5f9;--color-interval-ghost: #cbd5e1;--fretboard-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--layout-max-width: 1600px;--header-height: 80px}body{margin:0;min-width:320px;min-height:100vh;font-family:var(--font-family);background-color:var(--color-bg-app);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{max-width:100%;margin:0 auto;padding:0;text-align:center;width:100%}h1{font-size:3.2em;line-height:1.1;margin-bottom:2rem}.card{padding:0 1rem}.page-container{width:100%;max-width:1000px;margin:0 auto;padding:0}.main-header{background:linear-gradient(to right,#1e293b,#475569);color:#fff;width:100%;padding:.75rem 0;box-shadow:0 4px 6px -1px #0000001a;position:fixed;top:0;left:0;z-index:50}.header-inner{width:95%;max-width:var(--layout-max-width);margin:0 auto;display:flex;align-items:center;padding:0 1rem}.main-header h1{font-size:1.25rem;margin:0;font-weight:700;color:#f8fafc;background:none;-webkit-text-fill-color:initial;line-height:1}.header-title-group{display:flex;flex-direction:column;align-items:center}.header-copyright{font-size:.5rem;color:#94a3b8;margin-top:2px;width:100%;text-align:left;line-height:1;text-transform:uppercase;letter-spacing:0px}.header-title-group{width:max-content}.app-container{width:95%;max-width:var(--layout-max-width);margin:0 auto;padding:calc(var(--header-height) + 1.5rem) 1rem 6rem;display:flex;flex-direction:column;gap:1.5rem}.controls{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;gap:1rem;background:var(--color-bg-panel);padding:1rem;border-radius:12px;box-shadow:0 2px 4px #0000000d;border:1px solid var(--color-border);margin-bottom:1.5rem}.control-group{display:flex;align-items:center;gap:.75rem;flex-wrap:nowrap}.control-group label{font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;font-size:.85rem;letter-spacing:.05em;margin-right:.5rem}.note-selector{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.note-selector button{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:8px;font-weight:600;background:#f1f5f9;border:1px solid var(--color-border);color:var(--color-text-primary);transition:all .2s}.note-selector button:hover{background:#e2e8f0;border-color:#cbd5e1}.note-selector button.active{background:var(--color-interval-root);color:#fff;border-color:var(--color-interval-root);box-shadow:0 4px 6px -1px #34d3994d}.scale-selector{display:flex;background:#f1f5f9;padding:4px;border-radius:8px;border:1px solid var(--color-border)}.scale-selector button{background:transparent;border:none;color:var(--color-text-secondary);padding:.5rem 1.5rem;border-radius:6px;font-weight:500}.scale-selector button:hover{color:var(--color-text-primary)}.scale-selector button.active{background:#fff;color:var(--color-text-primary);box-shadow:0 1px 3px #0000001a;font-weight:600}select{padding:.75rem 2rem .75rem 1rem;background-color:#f1f5f9;color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%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 .75rem center;background-size:1.25em;min-width:250px}select:hover{border-color:#cbd5e1;background-color:#e2e8f0}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;color:var(--color-text-primary);background:#fff;padding:.5rem 1rem;border-radius:8px;border:1px solid var(--color-border);transition:all .2s;font-weight:500;box-shadow:0 1px 2px #0000000d}.checkbox-label:hover{border-color:var(--color-accent);color:var(--color-accent);background:#eff6ff}.checkbox-label input[type=checkbox]{accent-color:var(--color-accent);width:1.2em;height:1.2em}.fretboard-wrapper{display:flex;justify-content:center;width:100%;margin-top:2rem;padding:0}.mini-legend{display:flex;align-items:center;gap:1rem;margin-left:auto;padding-left:1rem;font-size:.8rem;color:var(--color-text-secondary)}.mini-legend .legend-item{display:flex;align-items:center;gap:.25rem}.note-marker.small{width:20px;height:20px;font-size:.7rem}.schema-container{display:flex;align-items:center;color:var(--color-text-secondary);font-family:Inter,sans-serif;font-size:.9rem;font-weight:500;margin-left:auto;padding:.5rem 1rem;background:#fff;border-radius:8px;border:1px solid var(--color-border)}.schema-node{display:flex;align-items:center;justify-content:center;min-width:48px;height:48px;padding:0 8px;background:#fff;border-radius:24px;font-size:1rem;font-weight:700;color:var(--color-text-primary);box-shadow:0 2px 4px #00000014;border:1px solid #94a3b8}.schema-node.root{background-color:rgba(var(--color-interval-root-rgb),.15);border-color:var(--color-interval-root);color:var(--color-text-primary)}.schema-node.third{background-color:rgba(var(--color-interval-3-rgb),.15);border-color:var(--color-interval-3);color:var(--color-text-primary)}.schema-node.fifth{background-color:rgba(var(--color-interval-5-rgb),.15);border-color:var(--color-interval-5);color:var(--color-text-primary)}.schema-connector{height:2px;background-color:#cbd5e1;margin:0 12px;position:relative;width:40px}.schema-connector.whole{width:40px}.schema-connector.half{width:40px;background-color:var(--color-accent);height:3px}.schema-connector.half:after{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid var(--color-accent)}.schema-connector.whole:after{content:"GT";position:absolute;top:-10px;left:50%;transform:translate(-50%);font-size:.55rem;color:#94a3b8;font-weight:600;pointer-events:none}.schema-connector.half:before{content:"HT";position:absolute;top:-16px;left:50%;transform:translate(-50%);font-size:.55rem;color:var(--color-accent);font-weight:700;pointer-events:none}.fretboard-controls{flex-direction:column;align-items:normal;gap:0;padding-bottom:1rem}.settings-header-title{width:100%;font-size:.9rem;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;cursor:pointer;display:flex}.settings-content{display:flex;flex-direction:column;gap:1rem;transition:all .3s ease-in-out;max-height:1000px;opacity:1;overflow:hidden}.settings-content.collapsed{max-height:0;opacity:0;margin:0}.control-row-top,.control-row-mid,.control-row-bottom{display:flex;align-items:center;flex-wrap:wrap;gap:1.5rem}.control-row-top{justify-content:flex-start;gap:1rem}.settings-toggle-handle{display:flex;justify-content:center;align-items:center;width:calc(100% + 2rem);margin:.5rem -1rem -1rem;padding:.5rem 0;cursor:pointer;border-top:1px solid var(--color-border);border-radius:0 0 12px 12px;color:var(--color-text-muted);transition:all .2s;background-color:transparent}@media(hover:hover){.settings-toggle-handle:hover{background-color:#f1f5f9;color:var(--color-accent)}}.settings-toggle-handle svg{width:20px;height:20px;stroke-width:2.5px}@media(max-width:768px){.settings-toggle-handle{width:calc(100% + 1.5rem);margin:.5rem -.75rem -.75rem}}@media(max-width:768px){.app-container{padding:calc(var(--header-height) + 1rem) .5rem 6rem;width:100%;max-width:100vw;overflow-x:hidden}.main-header h1{font-size:1.1rem}.controls.fretboard-controls.settings-closed{gap:0!important;padding-bottom:0!important}.controls.fretboard-controls.settings-closed .settings-header-title{margin-bottom:0!important}.controls.fretboard-controls.settings-closed .settings-toggle-handle{margin-top:0!important;margin-bottom:0!important}.controls{flex-direction:column;align-items:stretch;padding:.75rem;gap:1.25rem}.control-group{flex-direction:column;align-items:flex-start;width:100%;gap:.5rem}.control-group label{margin-bottom:.25rem;font-size:.8rem}select{width:100%;min-width:0}.custom-select-container{min-width:0!important;width:100%!important}.scale-selector{width:100%;max-width:100%;box-sizing:border-box;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.scale-selector button{flex:1 1 auto;min-width:0;text-align:center;padding:.5rem;font-size:.9rem;white-space:normal;overflow-wrap:break-word}.note-selector{justify-content:space-between;gap:.25rem}.note-selector button{width:calc((100% / 6) - .5rem);height:36px;font-size:.9rem}.mini-legend{margin-left:0;width:100%;justify-content:space-around;padding-top:.5rem;border-top:1px solid var(--color-border);margin-top:.5rem}.schema-container{display:none}.action-bar-row{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;-ms-overflow-style:none;margin-left:-.75rem;width:calc(100% + 1.5rem);padding-left:.75rem;padding-right:.75rem;-webkit-overflow-scrolling:touch;gap:.75rem}.action-bar-row::-webkit-scrollbar{display:none}.toggle-chip{flex-shrink:0;white-space:nowrap}}.circle-of-fifths-view{display:flex;flex-direction:column;align-items:center;width:100%;max-width:1200px;margin:0 auto;padding:2rem 1rem}.circle-of-fifths-view h2{font-size:2rem;margin-bottom:2rem;color:var(--color-text-primary)}.cof-wrapper{width:100%;max-width:600px;margin-bottom:2rem}.schema-wrapper-full{width:100%;overflow-x:auto;display:flex;justify-content:center}.scale-schema-container{display:flex;flex-direction:row;align-items:flex-start;gap:2px;margin-left:0;overflow-x:auto;padding:10px;background:#fff;border-radius:8px;border:1px solid var(--color-border)}.schema-node-wrapper{display:flex;flex-direction:column;align-items:center;gap:4px}.schema-numeral{font-size:1rem;color:var(--color-text-secondary);font-weight:500}.schema-connector{margin-top:23px}@media(max-width:1024px)and (min-width:769px){.controls{justify-content:space-between}}@media(max-width:768px){.scale-schema-container{padding:5px;gap:0;justify-content:space-between;width:100%;overflow-x:hidden}.schema-node-wrapper{flex:1;min-width:0}.schema-node{min-width:28px;height:28px;font-size:.75rem;padding:0}.schema-connector{display:block;margin:14px 2px 0;width:12px}.schema-connector.whole,.schema-connector.half{width:12px}.schema-connector.whole:after{font-size:.45rem;top:-10px}.schema-connector.half:before{font-size:.45rem;top:-16px}.schema-connector.half:after{top:-6px;border-left-width:3px;border-right-width:3px;border-top-width:3px}.schema-numeral{font-size:.7rem}.quality-suffix.dim:after{content:"°";font-size:.75rem}}.action-bar-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-top:.5rem;width:100%}.toggle-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:9999px;border:1px solid #cbd5e1;background-color:#fff;color:#64748b;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;box-shadow:0 1px 2px #0000000d}.toggle-chip:hover{background-color:#f1f5f9;border-color:#94a3b8}.toggle-chip.active{background-color:#334155;border-color:#334155;color:#fff}.toggle-chip svg{width:18px;height:18px;stroke-width:2px}.donation-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000}.donation-modal-content{background:#fff;width:90%;max-width:400px;height:600px;max-height:80vh;border-radius:12px;position:relative;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;overflow:hidden;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.donation-close-btn{position:absolute;top:10px;right:10px;background:#ffffffe6;border:1px solid #e2e8f0;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;line-height:1;color:#334155;cursor:pointer;z-index:20;box-shadow:0 2px 4px #0000001a;transition:all .2s}.donation-close-btn:hover{background:#fff;color:#0f172a;transform:scale(1.1)}.donation-iframe-wrapper{flex:1;width:100%;background:#fff;position:relative;z-index:1}.donation-fallback{padding:.5rem;display:flex;justify-content:center;background:#f8fafc;border-top:1px solid #e2e8f0}.bmc-button{text-decoration:none;color:#5f7fff;font-weight:600;font-size:.9rem}.header-actions{margin-left:auto;display:flex;gap:.75rem;align-items:center}.header-icon-btn{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:.8rem;font-weight:700;padding:0}.header-icon-btn svg{width:20px;height:20px}.header-icon-btn:hover{background:#ffffff26;border-color:#fff9;transform:translateY(-1px)}.header-icon-btn:active{transform:translateY(0);background:#ffffff1a}.contact-modal{max-width:500px;height:auto;max-height:90vh;padding:0;overflow-y:auto}.contact-form-container{padding:2rem;height:100%;display:flex;flex-direction:column}.contact-form{display:flex;flex-direction:column;gap:1rem;height:100%}.contact-form h3{margin:0 0 1rem;color:#334155;text-align:center}.contact-info-box{background:#eff6ff;border:1px solid #dbeafe;border-radius:8px;padding:1rem;font-size:.9rem;color:#1e3a8a;line-height:1.5;margin-bottom:1.5rem;text-align:left}.form-row{display:flex;gap:1rem}.form-group{flex:1;display:flex;flex-direction:column;gap:.25rem}.form-group label{font-size:.85rem;font-weight:600;color:#64748b;width:100%;text-align:left}.form-group input,.form-group textarea{padding:.75rem;border:1px solid #cbd5e1;border-radius:8px;font-family:inherit;font-size:.95rem;color:#0f172a;transition:border-color .2s;background:#f8fafc;width:100%}.form-group textarea{min-height:150px}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 2px #3b82f61a}.form-submit-btn{margin-top:1rem;padding:.75rem;background:#334155;color:#fff;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:background .2s}.form-submit-btn:hover:not(:disabled){background:#1e293b}.form-submit-btn:disabled{opacity:.7;cursor:not-allowed}.form-error{color:#ef4444;font-size:.9rem;text-align:center;background:#fef2f2;padding:.5rem;border-radius:6px}.contact-success-message{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#334155;padding:2rem 0}.success-icon{width:60px;height:60px;background:#22c55e;color:#fff;font-size:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}@media(max-width:768px){.settings-content,.control-row-top,.control-row-mid,.control-row-bottom{width:100%!important;min-width:0!important;max-width:100%!important;box-sizing:border-box!important}.header-icon-btn{width:28px!important;height:28px!important;padding:0!important}.header-icon-btn svg{width:18px;height:18px}.action-bar-row{display:flex!important;flex-wrap:nowrap!important;overflow-x:auto!important;padding-bottom:4px;gap:.75rem;scrollbar-width:none;-ms-overflow-style:none;margin-left:-.75rem;width:calc(100% + 1.5rem);max-width:calc(100% + 1.5rem)!important;padding-left:.75rem;padding-right:.75rem;-webkit-overflow-scrolling:touch;box-sizing:border-box!important}.action-bar-row::-webkit-scrollbar{display:none}.toggle-chip{flex-shrink:0;white-space:nowrap}.settings-toggle-handle{background-color:#fff!important;width:calc(100% + 1.5rem);max-width:calc(100% + 1.5rem)!important;margin:.5rem -.75rem -.75rem;border-top:1px solid var(--color-border);box-sizing:border-box!important}}@media(max-width:768px){.action-bar-row{flex-wrap:nowrap!important;overflow-x:auto!important;padding-bottom:4px;gap:.75rem;scrollbar-width:none;-ms-overflow-style:none;margin-left:-.75rem;width:calc(100% + 1.5rem);padding-left:.75rem;padding-right:.75rem;-webkit-overflow-scrolling:touch}.action-bar-row::-webkit-scrollbar{display:none}.toggle-chip{flex-shrink:0;white-space:nowrap}.settings-toggle-handle{background-color:#fff!important;width:calc(100% + 1.5rem);margin:.5rem -.75rem -.75rem;border-top:1px solid var(--color-border)}}.modal-header h3{text-align:center;width:100%}.fretboard-container{width:100%;display:flex;justify-content:center;padding:0}.fretboard{display:flex;flex-direction:column;background-color:#fff;width:100%;max-width:100%;border:1px solid #cbd5e1;padding:0;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;overflow:hidden}.fretboard-scroll-content{width:100%;overflow-x:auto;display:flex;flex-direction:column;padding:1rem;scroll-behavior:smooth;min-width:0}.fret-markers{display:flex;flex-direction:row;height:30px;margin-bottom:5px;margin-top:5px}.fret-number{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;color:#888;font-size:.8rem;min-width:55px}.dot{font-size:1.5rem;line-height:.5;color:#ccc;margin-bottom:4px}.fretboard-header{padding:.5rem 1.5rem;min-height:60px;font-size:1.1rem;font-weight:600;color:#334155;border-bottom:1px solid #f1f5f9;text-align:left;display:grid;grid-template-columns:1fr auto;align-items:center;gap:1rem}.header-title{justify-self:start;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;min-width:0;font-size:clamp(.75rem,3.5vw,1.1rem)}.header-nav-controls{justify-self:end;display:flex;gap:.5rem;align-items:center}.nav-arrow-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;border:1px solid transparent;background-color:transparent;color:#475569;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.nav-arrow-btn:hover{background-color:#f1f5f9;border-color:#cbd5e1;color:#0f172a;transform:scale(1.05)}.nav-arrow-btn:active{background-color:#e2e8f0;transform:scale(.95)}.nav-arrow-btn svg{width:28px;height:28px;stroke-width:2.5px}.fretboard-bottom-legend{display:flex;justify-content:flex-end;align-items:center;padding:.25rem 1rem .5rem;font-size:.75rem;color:#64748b;background-color:#fff;border-top:1px solid #f1f5f9}.fretboard-bottom-legend .note-marker{width:16px;height:16px;font-size:.65rem;margin-right:4px;display:inline-flex;align-items:center;justify-content:center}.fretboard-bottom-legend .legend-item{margin-left:1rem}.fretboard-bottom-legend .note-marker.root{transform:none;font-size:.65rem;box-shadow:none}.guitar-string{display:flex;flex-direction:row;width:100%}.fret{position:relative;display:flex;align-items:center;justify-content:center;height:50px;flex:1;min-width:55px;border-right:2px solid #cbd5e1}.fret:first-child{border-right:6px solid #64748b}.fret:last-child{border-right:none}.string-line{position:absolute;width:100%;height:2px;background-color:#94a3b8;z-index:1}.note-container{z-index:10;position:relative}.fret.highlighted:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;z-index:5;pointer-events:none}.fret.highlighted.pattern-1:before{background-color:#9333ea1a}.fret.highlighted.pattern-2:before{background-color:#ec48991a}.pattern-label{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:.75rem;font-weight:600;color:#6b21a8;background-color:#ffffffe6;padding:1px 6px;border-radius:4px;z-index:100;white-space:nowrap;border:1px solid #e9d5ff}.fret.highlighted.pattern-2 .pattern-label{top:-70px}.note-marker{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-family:Inter,sans-serif;font-size:1rem;background-color:#fdfdfde6;border:2px solid #a1a1aa;color:#333;box-shadow:0 2px 4px #0003;z-index:10}.note-marker.root{background-color:var(--color-interval-root);color:#fff;border:2px solid var(--color-interval-root);transform:scale(1.15);box-shadow:0 4px 6px #0000004d;font-size:1.2rem}.note-marker.third{background-color:var(--color-interval-3);color:#000;border:2px solid var(--color-interval-3)}.note-marker.fifth{background-color:var(--color-interval-5);color:#fff;border:2px solid var(--color-interval-5)}.note-marker.ghost{opacity:.3;background-color:#ffffff80;border:1px dashed #777;color:#555;box-shadow:none;transform:scale(.9)}.note-marker.rectangle{border-radius:6px;width:42px;height:32px;font-size:.9rem;font-weight:700}.custom-select-container{position:relative;-webkit-user-select:none;user-select:none;min-width:250px}.custom-select-trigger{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;font-size:1rem;font-weight:500;color:var(--color-text-primary, #334155);background:#f1f5f9;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;cursor:pointer;transition:all .2s;text-align:left}.custom-select-trigger:hover{background:#e2e8f0;border-color:#cbd5e1}.custom-select-trigger.active{background:#fff;border-color:var(--color-accent, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.arrow-icon{display:flex;align-items:center;color:#64748b;transition:transform .2s}.custom-select-trigger.active .arrow-icon{transform:rotate(180deg)}.custom-select-options{position:absolute;top:calc(100% + 4px);left:0;width:100%;max-height:250px;overflow-y:auto;background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:100;text-align:left}.custom-option{padding:.75rem 1rem;font-size:.95rem;color:var(--color-text-primary, #334155);cursor:pointer;transition:background .1s;text-align:left}.custom-option:hover{background:#f1f5f9}.custom-option.selected{background:#eff6ff;color:var(--color-accent, #2563eb);font-weight:600}.trainer-view-container{padding:0;max-width:1000px;margin:0 auto}.trainer-menu header{text-align:center;margin-bottom:3rem}.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.menu-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px -1px #0000000d;display:flex;flex-direction:column;align-items:center;gap:1rem}.menu-card:hover:not(.disabled){transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a;border-color:#3b82f6}.menu-card .icon{font-size:3rem;margin-bottom:.5rem}.menu-card h3{margin:0;font-size:1.25rem;color:#1e293b}.menu-card p{margin:0;color:#64748b;font-size:.95rem}.menu-card.disabled{opacity:.6;cursor:not-allowed;background:#f9fafb;border-style:dashed}@media(max-width:768px){.trainer-view-container{padding:0;width:100%}.trainer-menu header{margin-bottom:2rem}.menu-grid{gap:1rem;grid-template-columns:1fr}.menu-card{padding:1.5rem;flex-direction:row;align-items:center;gap:1rem;display:grid;grid-template-columns:auto 1fr;text-align:left}.menu-card .icon{font-size:2.5rem;margin-bottom:0;grid-row:span 2}.menu-card h3{font-size:1.1rem;align-self:end}.menu-card p{font-size:.9rem;align-self:start;grid-column:2}}.t-container{padding:0;width:100%;max-width:900px;margin:0 auto;font-family:Inter,system-ui,-apple-system,sans-serif;color:#1e293b;display:flex;flex-direction:column;align-items:flex-start}.t-container h2{font-size:1.875rem;font-weight:700;margin-bottom:2rem;color:#0f172a;text-align:left;letter-spacing:-.025em}.t-container h3{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:.75rem;text-align:left}.t-back-button{background:transparent;border:none;color:#64748b;cursor:pointer;font-size:.95rem;padding:.5rem 0;margin-bottom:1.5rem;display:inline-flex;align-items:center;gap:.5rem;font-weight:500;transition:color .2s ease}.t-back-button:hover{color:#2563eb}.t-back-button svg{transition:transform .2s ease}.t-back-button:hover svg{transform:translate(-4px)}.t-panel{background-color:#fff;padding:2.5rem;border-radius:1rem;box-shadow:0 10px 15px -3px #0000000d,0 4px 6px -2px #00000006;border:1px solid #f1f5f9;width:100%;box-sizing:border-box}.t-tonality-display{display:flex;align-items:center;background:linear-gradient(to right,#eff6ff,#f8fafc);border-left:4px solid #3b82f6;padding:1.5rem;border-radius:.75rem;margin-bottom:2rem;box-shadow:0 2px 4px #00000005}.t-tonality-icon{margin-right:1.25rem;color:#3b82f6;width:2.5rem;height:2.5rem}.t-tonality-info{display:flex;flex-direction:column}.t-tonality-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#3b82f6;margin-bottom:.25rem;font-family:inherit}.t-tonality-value{font-size:1.75rem;font-weight:800;color:#1e3a8a;line-height:1;font-family:inherit}.t-split-container{display:flex;flex-direction:column;gap:2rem;align-items:flex-start;width:100%}.t-split-col{width:100%;flex:auto;min-width:0;display:flex;flex-direction:column;box-sizing:border-box}.t-progression-display,.t-resolution-display{margin-bottom:0;width:100%}.t-cards-container{display:flex;flex-wrap:wrap;gap:1rem;background-color:#f8fafc;padding:1.5rem;border-radius:.75rem;min-height:5rem;align-items:center;border:1px solid #e2e8f0;width:100%;box-sizing:border-box;justify-content:flex-start}.t-card{font-size:1.5rem;font-weight:600;color:#0f172a;background:#fff;padding:.75rem 1.5rem;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;min-width:3.5rem;text-align:center;transition:all .2s ease}.t-card-target{background-color:#dcfce7;color:#15803d;border-color:#86efac}.t-toggle-wrapper{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.t-toggle-input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.t-toggle-slider{position:relative;display:inline-block;width:44px;height:24px;background-color:#cbd5e1;border-radius:9999px;transition:.3s cubic-bezier(.4,0,.2,1)}.t-toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:2px;bottom:2px;background-color:#fff;border-radius:50%;transition:.3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 2px #0003}.t-toggle-input:checked+.t-toggle-slider{background-color:#3b82f6}.t-toggle-input:checked+.t-toggle-slider:before{transform:translate(20px)}.t-toggle-label{font-size:.95rem;font-weight:500;color:#334155}.t-input{appearance:none;background-color:#fff;border:1px solid #cbd5e1;border-radius:.375rem;padding:.5rem .75rem;font-size:1rem;line-height:1.5;color:#0f172a;width:80px;text-align:center;transition:border-color .2s,box-shadow .2s}.t-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.t-timer-group{display:flex;align-items:center;gap:.5rem}.t-timer-unit{color:#64748b;font-size:.9rem;font-weight:500}.t-btn-primary{background-color:#2563eb;color:#fff;padding:.75rem 1.5rem;border-radius:.5rem;border:none;font-weight:600;font-size:.95rem;cursor:pointer;box-shadow:0 1px 2px #0000000d;transition:all .2s}.t-btn-primary:hover{background-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.t-btn-primary:active{transform:translateY(0)}.t-btn-secondary{background-color:#fff;color:#0f172a;padding:.75rem 1.5rem;border-radius:.5rem;border:1px solid #e2e8f0;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s}.t-btn-secondary:hover{background-color:#f8fafc;border-color:#cbd5e1;color:#1e293b}.t-btn-resolve{background-color:#16a34a;color:#fff;padding:.75rem 1.5rem;border-radius:.5rem;border:none;font-weight:600;font-size:.95rem;cursor:pointer;box-shadow:0 1px 2px #0000000d;transition:all .2s}.t-btn-resolve:hover{background-color:#15803d;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.t-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-top:2.5rem;width:100%;padding-top:1.5rem;border-top:1px solid #f1f5f9}.t-actions-left{display:flex;align-items:center;gap:1rem}.t-actions-right{display:flex;align-items:center;gap:2rem;justify-content:flex-end}.t-fixed-key-control,.t-control-group,.t-toggle-wrapper{flex-shrink:0}.t-control-group{display:flex;align-items:center;gap:1rem}.t-info-container{margin-top:2rem}.t-info-content-box{border-left:4px solid #3b82f6;padding-left:1.5rem;margin-top:.75rem;display:flex;flex-direction:column;gap:1.25rem}.t-info-section{display:flex;flex-direction:column}.t-info-header{display:flex;align-items:center;font-weight:600;color:#0f172a;margin-bottom:.25rem}.t-info-icon{width:1.25rem;height:1.25rem;margin-right:.5rem;color:#3b82f6}.t-info-text{padding-left:1.75rem;color:#475569;line-height:1.6;text-align:left}.t-timer-bar-container{background:#e2e8f0;height:6px;border-radius:99px;overflow:hidden;margin-bottom:2rem;width:100%}.t-timer-bar{background:#3b82f6;height:100%;transition:width 1s linear}.t-fade-in{animation:tFadeIn .5s ease-in}@keyframes tFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.t-flex{display:flex}.t-items-center{align-items:center}.t-justify-start{justify-content:flex-start}.t-mr-1{margin-right:.25rem}.t-mr-4{margin-right:1rem}.t-mb-4{margin-bottom:1rem}.t-h-5{height:1.25rem}@media(max-width:768px){.t-container{padding:0 0 .5rem;width:100%}.t-container h2{font-size:1.5rem;margin-bottom:1.5rem}.t-panel{padding:1.5rem}.t-tonality-display{padding:1rem;margin-bottom:1.5rem}.t-tonality-icon{width:2rem;height:2rem;margin-right:1rem}.t-tonality-value{font-size:1.5rem}.t-cards-container{padding:1rem;gap:.75rem;justify-content:center}.t-card{font-size:1.25rem;padding:.5rem 1rem;min-width:3rem}.t-actions{flex-direction:column;align-items:stretch;gap:1.5rem}.t-actions-left,.t-actions-right{width:100%;flex-direction:column;gap:1rem;align-items:flex-start}.t-actions-right{align-items:flex-start}.t-btn-primary,.t-btn-secondary,.t-btn-resolve{width:100%}.t-timer-group{width:auto;justify-content:flex-start}.t-control-group,.t-fixed-key-control{display:flex;align-items:center;gap:1rem;width:100%;justify-content:flex-start}.t-control-group .t-toggle-wrapper,.t-fixed-key-control .t-toggle-wrapper{width:auto;justify-content:flex-start;background:transparent;padding:0;border-radius:0}.t-toggle-wrapper:not(.t-control-group .t-toggle-wrapper):not(.t-fixed-key-control .t-toggle-wrapper){width:100%;justify-content:space-between;background:#f8fafc;padding:.75rem;border-radius:.5rem}.t-btn-primary,.t-btn-secondary,.t-btn-resolve{width:100%;text-align:center;padding:1rem}}.metronome-container{padding:0;max-width:500px;margin:0 auto;display:flex;flex-direction:column;gap:0;font-family:Inter,system-ui,-apple-system,sans-serif}.metronome-container .t-back-button{margin-bottom:1.5rem}.metronome-card{background:var(--color-bg-panel);border-radius:24px;padding:2.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:2.5rem;box-shadow:0 10px 40px -10px #0000001a;border:1px solid rgba(0,0,0,.05);background:linear-gradient(to bottom,#fff,#f9fafb)}@media(prefers-color-scheme:dark){.metronome-card{background:var(--color-bg-panel)}}.metronome-card h2{margin:0;color:var(--color-text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:2px;font-weight:600;opacity:.7}.bpm-display-container{position:relative;display:flex;justify-content:center;align-items:center;padding:1rem 0}.bpm-value-wrapper{display:flex;flex-direction:column;align-items:center}.bpm-value{font-size:5rem;font-weight:800;line-height:1;color:var(--color-text-primary);font-variant-numeric:tabular-nums;letter-spacing:-2px;text-shadow:0 2px 10px rgba(0,0,0,.05)}.bpm-label{font-size:1rem;font-weight:600;color:var(--color-accent);margin-top:.5rem;text-transform:uppercase;letter-spacing:1px}.beat-indicators{display:flex;gap:1rem;margin-bottom:-1rem;padding:.5rem}.beat-dot{width:16px;height:16px;border-radius:50%;background-color:#e2e8f0;transition:all .1s ease-in-out;border:2px solid transparent}.beat-dot.beat-one.active{background-color:var(--color-accent, #3b82f6);box-shadow:0 0 15px var(--color-accent, rgba(59, 130, 246, .5));transform:scale(1.3)}.beat-dot.beat-other.active{background-color:#94a3b8;box-shadow:0 0 10px #94a3b880;transform:scale(1.2)}.controls-container{width:100%;display:flex;flex-direction:column;gap:1.5rem}.slider-container{display:flex;align-items:center;gap:1rem;background:#f1f5f9;padding:.5rem 1rem;border-radius:16px;box-shadow:inset 0 2px 4px #0000000d}.bpm-slider{flex:1;height:6px;border-radius:4px;appearance:none;-webkit-appearance:none;background:transparent;cursor:pointer}.bpm-slider::-webkit-slider-runnable-track{width:100%;height:6px;background:#cbd5e1;border-radius:4px}.bpm-slider::-webkit-slider-thumb{-webkit-appearance:none;height:24px;width:24px;border-radius:50%;background:#fff;border:2px solid var(--color-accent);box-shadow:0 2px 6px #00000026;margin-top:-9px;transition:transform .1s}.bpm-slider::-webkit-slider-thumb:active{transform:scale(.95)}.control-btn{background:#fff;border:none;color:var(--color-text-primary);width:32px;height:32px;border-radius:50%;font-weight:700;font-size:1.2rem;cursor:pointer;box-shadow:0 2px 5px #0000001a;display:flex;align-items:center;justify-content:center;transition:all .2s}.control-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0000001f;color:var(--color-accent)}.control-btn:active{transform:translateY(1px);box-shadow:0 1px 2px #0000001a}.presets-container{display:flex;justify-content:center;gap:1rem}.preset-btn{background:transparent;border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.preset-btn:hover{background:var(--color-bg-main);color:var(--color-text-primary);border-color:var(--color-text-secondary)}.sound-toggle-container{display:flex;align-items:center;gap:1.5rem;padding:.5rem}.sound-label{font-size:.9rem;font-weight:600;color:var(--color-text-secondary);transition:color .3s}.sound-label.active{color:var(--color-accent)}.toggle-switch{width:60px;height:32px;background:#cbd5e1;border-radius:100px;position:relative;cursor:pointer;transition:background .3s ease;box-shadow:inset 0 2px 4px #0000001a}.toggle-switch.on{background:var(--color-accent)}.toggle-thumb{width:26px;height:26px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0003}.toggle-switch.on .toggle-thumb{transform:translate(28px)}.play-btn-container{margin-top:1rem}.play-button-modern{background:var(--color-accent);border:none;width:120px;height:120px;border-radius:50%;cursor:pointer;box-shadow:0 10px 25px #3b82f666;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;position:relative;overflow:visible}.play-button-modern:hover{transform:scale(1.05);box-shadow:0 15px 35px #3b82f680}.play-button-modern:active{transform:scale(.95);box-shadow:0 5px 15px #3b82f64d}.play-text{font-size:1.5rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:2px;position:relative;z-index:2}.play-button-modern.playing{background:#ef4444;box-shadow:0 10px 25px #ef444466}.play-button-modern.playing:hover{box-shadow:0 15px 35px #ef444480;transform:scale(1.05)}.pulse-effect{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;pointer-events:none;z-index:1}.pulse-effect.pulse-beat{width:100%;height:100%;background:#ffffff4d;animation:beat-pulse .4s ease-out forwards}@keyframes beat-pulse{0%{transform:translate(-50%,-50%) scale(1);opacity:.5}to{transform:translate(-50%,-50%) scale(1.4);opacity:0}}.pulse-effect.pulse-measure{width:100%;height:100%;background:transparent;border:4px solid rgba(255,255,255,.8);box-shadow:0 0 20px 10px #fff6;animation:aura-pulse .6s ease-out forwards}@keyframes aura-pulse{0%{transform:translate(-50%,-50%) scale(1);opacity:1;box-shadow:0 0 #ffffffb3}to{transform:translate(-50%,-50%) scale(2.5);opacity:0;box-shadow:0 0 40px 20px #fff0}}@media(max-width:768px){.metronome-container{padding:0;max-width:100%}.metronome-card{padding:1.5rem 1rem;background:#fff;gap:1.5rem;border-radius:16px}.bpm-value{font-size:3.5rem}.bpm-label{font-size:.9rem}.controls-container{gap:1.25rem}.slider-container{padding:.75rem}.play-button-modern{width:90px;height:90px}.play-text{font-size:1.2rem}.presets-container{flex-wrap:wrap;gap:.5rem}.preset-btn{flex:1;min-width:60px;text-align:center}.sound-toggle-container{width:100%;justify-content:center}}.key-finder-container{display:flex;flex-direction:column;gap:32px;width:100%;max-width:1000px;margin:0 auto;font-family:Inter,sans-serif;color:var(--text-color);--primary-color: #3b82f6;--primary-color-rgb: 59, 130, 246}.kf-actions-bar{display:flex;flex-direction:column;align-items:flex-start;gap:0;margin-bottom:24px;background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:20px 24px;border-radius:16px;border:1px solid rgba(255,255,255,.5);box-shadow:0 4px 20px #0000000d}.kf-actions-header{width:100%;display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.kf-selection-label{font-size:1.1rem;font-weight:700;color:var(--text-color);letter-spacing:-.02em}.kf-selected-chords-list{display:flex;flex-wrap:wrap;gap:8px;width:100%;margin-bottom:8px}.kf-selected-chord-chip{background:var(--surface-color);border:1px solid rgba(0,0,0,.1);border-radius:99px;padding:6px 12px;display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-color);font-size:.95rem;cursor:pointer;transition:all .2s}.kf-selected-chord-chip:hover{background:#fee2e2;border-color:#fecaca;color:#ef4444}.kf-chip-remove{font-size:1.1em;font-weight:700;line-height:1;opacity:.5}.kf-selected-chord-chip:hover .kf-chip-remove{opacity:1}.kf-btn-text{background:rgba(var(--primary-color-rgb),.08);border:1px solid rgba(var(--primary-color-rgb),.15);color:var(--primary-color);font-weight:600;cursor:pointer;font-size:.85rem;padding:6px 16px;border-radius:20px;transition:all .3s cubic-bezier(.4,0,.2,1);text-transform:uppercase;letter-spacing:.05em}.kf-btn-text:hover{background:var(--primary-color);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--primary-color-rgb),.2);text-decoration:none}.kf-categories{display:flex;flex-direction:column;gap:16px}.kf-category{background:var(--surface-color);border-radius:16px;overflow:hidden;border:1px solid rgba(0,0,0,.05);box-shadow:0 2px 8px #0000000a;transition:border-color .3s,box-shadow .3s}.kf-category:hover{border-color:rgba(var(--primary-color-rgb),.3);box-shadow:0 4px 12px #0000000f}.kf-category-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:transparent;border:none;color:var(--text-color);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.kf-category-header:hover{background:#00000005}.kf-cat-title{display:flex;align-items:center;gap:12px}.kf-cat-title:before{content:"";display:block;width:4px;height:16px;background:var(--primary-color);border-radius:2px;opacity:.5;transition:opacity .3s}.kf-category-header:hover .kf-cat-title:before,.kf-category-header.open .kf-cat-title:before{opacity:1}.kf-cat-icon{font-size:.8rem;opacity:.4;transition:transform .4s cubic-bezier(.68,-.55,.265,1.55);color:var(--text-color)}.kf-category-header.open .kf-cat-icon{transform:rotate(180deg);color:var(--primary-color);opacity:1}.kf-category-content{padding:0 24px 24px;border-top:1px solid rgba(0,0,0,.05);animation:slideDown .4s cubic-bezier(.16,1,.3,1)}.kf-quality-row{margin-top:20px}.kf-quality-label{display:block;font-size:.8rem;color:var(--text-color-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.1em;font-weight:600}.kf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:10px}.kf-grid-btn{aspect-ratio:1;background:#fff;border:1px solid rgba(0,0,0,.08);color:var(--text-color);border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.25,.46,.45,.94);display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;overflow:hidden;box-shadow:0 2px 4px #00000005}.kf-grid-btn:hover{background:#f8f9fa;transform:translateY(-2px);border-color:#00000026;box-shadow:0 4px 8px #0000000d}.kf-grid-btn.selected{background:var(--primary-color);border-color:var(--primary-color);color:#fff;font-weight:800;box-shadow:0 4px 15px rgba(var(--primary-color-rgb),.4);animation:popIn .3s cubic-bezier(.175,.885,.32,1.275)}.kf-grid-btn.selected:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.3) 0%,transparent 100%)}.kf-results-section{display:flex;flex-direction:column;gap:24px;animation:fadeIn .5s ease-out}.kf-result-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 8px 30px #00000014;border:1px solid rgba(0,0,0,.03);transition:transform .3s ease}.kf-result-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px #0000001f}.kf-result-header{padding:20px 24px;background:#fafafa;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(0,0,0,.05)}.kf-result-title{font-size:1.4rem;font-weight:800;color:#000;background:none;-webkit-background-clip:border-box;background-clip:border-box;-webkit-text-fill-color:currentColor}.kf-score-badge{padding:6px 14px;border-radius:20px;font-size:.9rem;font-weight:700;border:1px solid transparent}.kf-score-badge.score-green{background:#2ecc7126;color:#27ae60;border-color:#2ecc714d}.kf-score-badge.score-blue{background:#3498db26;color:#2980b9;border-color:#3498db4d}.kf-score-badge.score-yellow{background:#f39c1226;color:#d35400;border-color:#f39c124d}.kf-score-badge.score-red{background:#e74c3c26;color:#c0392b;border-color:#e74c3c4d}.kf-result-actions{display:flex;flex-direction:row;align-items:center;gap:12px;margin-left:auto}.kf-btn-jump{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border-radius:50%;background:transparent;border:1px solid transparent;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.kf-btn-jump:hover{background:rgba(var(--primary-color-rgb),.08);transform:scale(1.1);box-shadow:0 4px 12px rgba(var(--primary-color-rgb),.15)}.kf-btn-jump:active{transform:scale(.95)}.kf-analysis-grid{padding:24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.kf-analysis-item{background:#f8f9fa;padding:16px;border-radius:12px;border-left:4px solid transparent;border:1px solid rgba(0,0,0,.03);border-left-width:4px;display:flex;flex-direction:column;justify-content:center;transition:background-color .2s}.kf-analysis-item:hover{background:#f1f3f5}.kf-analysis-item.Diatonic{border-left-color:#2ecc71;background:linear-gradient(90deg,#2ecc710d,#fff)}.kf-analysis-item.SecondaryDominant{border-left-color:#3498db;background:linear-gradient(90deg,#3498db0d,#fff)}.kf-analysis-item.Borrowed{border-left-color:#f1c40f;background:linear-gradient(90deg,#f1c40f0d,#fff)}.kf-analysis-item.Neapolitan{border-left-color:#f39c12;background:linear-gradient(90deg,#f39c120d,#fff)}.kf-analysis-item.Unknown{border-left-color:#e74c3c;background:linear-gradient(90deg,#e74c3c0d,#fff);opacity:1}.kf-chord-name{font-size:1.1rem;font-weight:700;display:block;margin-bottom:6px;color:var(--text-color)}.kf-chord-desc{font-size:.85rem;color:var(--text-color-secondary);display:block;line-height:1.4}.kf-empty-state{text-align:center;padding:60px 20px;color:var(--text-color-secondary);background:#00000005;border-radius:16px;border:2px dashed rgba(0,0,0,.06)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{transform:scale(.9)}50%{transform:scale(1.05)}to{transform:scale(1)}}.kf-separator{height:1px;background:#0000001a;margin:8px 0;width:100%}.kf-perfect-matches-container{margin-bottom:0;padding:0;width:100%;animation:fadeIn .4s ease-out;display:flex;flex-direction:column;align-items:flex-start}.kf-perfect-matches-label{font-size:1.1rem;font-weight:700;color:var(--text-color);letter-spacing:-.02em;margin-bottom:12px;display:block;text-transform:none;text-align:left;width:100%}.kf-perfect-matches-list{display:flex;flex-wrap:wrap;gap:12px}.kf-perfect-match-btn{background:rgba(var(--primary-color-rgb),.1);border:1px solid rgba(var(--primary-color-rgb),.2);color:var(--primary-color);padding:8px 16px;border-radius:99px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.kf-perfect-match-btn:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px rgba(var(--primary-color-rgb),.25)}.kf-perfect-match-score{font-size:.85em;opacity:.9;font-weight:400}.chord-finder-container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:900px;margin:0 auto}.section-header h2{margin-top:0;font-size:1.875rem;color:#0f172a;font-weight:700}.chord-result-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:1.5rem;width:100%;max-width:320px;height:140px;margin-bottom:.5rem;box-shadow:0 10px 15px -3px #0000000d,0 4px 6px -2px #00000006;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all .3s ease;overflow:hidden}.chord-result-card.active{border-color:#3b82f6;box-shadow:0 20px 25px -5px #3b82f61a,0 10px 10px -5px #3b82f60a}.chord-main-display{text-align:center;display:flex;flex-direction:column;justify-content:center;flex-grow:1}.chord-symbol{font-size:3rem;font-weight:800;color:#1e293b;line-height:1.1;letter-spacing:-.02em;background:linear-gradient(135deg,#1e293b,#334155);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;display:inline-block}.chord-alternatives{margin-top:auto;padding-top:.5rem;border-top:1px solid #f1f5f9;font-size:.75rem;color:#94a3b8;width:100%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;height:2rem;display:flex;align-items:center;justify-content:center}.chord-alternatives span{color:#64748b;font-weight:500}.chord-placeholder{color:#cbd5e1;font-size:1rem;font-weight:500;display:flex;flex-direction:column;align-items:center;gap:.5rem}.chord-placeholder svg{width:32px;height:32px;opacity:.5}.cf-reset-btn{appearance:none;background-color:#f8fafc;border:1px solid #cbd5e1;color:#64748b;border-radius:999px;padding:.75rem 2rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;margin-top:1.5rem}.cf-reset-btn:hover:not(:disabled){background-color:#f1f5f9;border-color:#94a3b8;color:#475569;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000000d}.cf-reset-btn:active:not(:disabled){transform:translateY(0);background-color:#e2e8f0}.cf-reset-btn:disabled{opacity:.5;cursor:not-allowed;background-color:#f8fafc;border-color:#e2e8f0;color:#cbd5e1}.fretboard-wrapper{width:100%;display:flex;justify-content:center;padding:0 0 1rem}@media(max-width:600px){.chord-result-card{padding:1rem;height:auto;min-height:100px;margin-bottom:.5rem;max-width:100%}.chord-symbol{font-size:2.2rem}.chord-alternatives{font-size:.7rem;padding-top:.25rem}.section-header{margin-bottom:1rem!important}.section-header h2{font-size:1.5rem;margin-bottom:.25rem}.cf-reset-btn{margin-top:1rem;padding:.6rem 1.5rem;font-size:.9rem}}.tuner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem;gap:.5rem;max-width:800px;margin:0 auto;margin-top:-1rem;color:var(--text-primary);background:var(--surface-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.tuner-header{text-align:center}.tuner-header h2{font-size:2rem;font-weight:700;margin-top:0;margin-bottom:0;background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.tuner-display{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;width:100%}.note-display{font-size:8rem;font-weight:800;line-height:.8;margin-top:-.5rem;color:var(--text-primary);transition:color .1s ease;min-height:9rem}.octave-sub{font-size:3rem;vertical-align:sub;opacity:.6;margin-left:.2rem}.note-display.in-tune{color:#10b981;text-shadow:0 0 30px rgba(16,185,129,.6)}.tuner-target-zone{position:absolute;top:0;bottom:0;left:45%;width:10%;background:#10b9811a;border-left:1px solid rgba(16,185,129,.3);border-right:1px solid rgba(16,185,129,.3);z-index:0}.frequency-display{font-family:monospace;font-size:1.25rem;color:var(--text-secondary)}.tuner-gauge-linear{position:relative;width:100%;max-width:600px;height:80px;margin-bottom:1rem;background:var(--surface);border-radius:8px;border:1px solid var(--border-color);box-sizing:border-box;padding:0;display:flex;overflow:hidden}.tuner-shoulder{width:40px;height:100%;background:#ef4444;opacity:.1;flex-shrink:0}.tuner-gauge-inner{display:none}.tuner-play-area{position:relative;flex-grow:1;height:100%;margin:0;inset:auto}.tuner-track-gradient{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:0;opacity:.1;background:linear-gradient(90deg,#ef4444,#eab308 30%,#10b981 45% 55%,#eab308 70%,#ef4444)}.tuner-fill-bar{position:absolute;top:0;bottom:0;opacity:.3;transition:width .1s linear,left .1s linear,background-color .2s;border-radius:4px}.scale-marks{position:relative;width:100%;height:100%;display:flex;justify-content:space-between;align-items:flex-end}.tick{position:absolute;bottom:0;width:2px;background:var(--text-secondary);opacity:.5;transform:translate(-50%)}.tick.major{height:25px;width:3px;opacity:.8}.tick.center{height:40px;width:4px;background:#10b981;opacity:1;z-index:2;left:50%}.tick.sub{height:15px;width:1px;opacity:.3}.tick-label{position:absolute;left:50%;transform:translate(-50%);font-size:.75rem;color:var(--text-secondary);font-weight:700;bottom:auto;top:-20px;white-space:nowrap}.tuner-needle-linear{position:absolute;bottom:0;top:0;width:4px;background:var(--text-primary);transform:translate(-50%);border-radius:2px;z-index:10;transition:left .1s linear,background-color .2s ease}.tuner-needle-linear:after{display:none}.tuner-needle-linear.in-tune{background:#10b981;box-shadow:0 0 10px #10b981}.tuner-status-text{font-size:1.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;min-height:2rem}.tuner-controls{display:flex;gap:1rem}.tuner-btn{display:none;padding:.75rem 2rem;font-size:1.1rem;font-weight:600;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all .2s ease}.tuner-btn.visible{display:block}.tuner-btn.stop{background:var(--surface-hover);color:var(--text-primary);border:1px solid var(--border-color)}.tuner-btn.stop:hover{background:var(--surface-active)}.mic-error{color:#ef4444;background:#ef44441a;padding:1rem;border-radius:var(--radius-md);text-align:center;margin-top:1rem}@media(max-width:600px){.tuner-container{padding:.5rem;gap:.5rem;width:100%;border:none;box-shadow:none;background:transparent}.tuner-gauge-linear{max-width:100%}.note-display{font-size:5rem}.tuner-display{gap:.5rem}.tuner-status-text{font-size:1rem}}.circle-of-fifths-container{width:100%;display:flex;justify-content:center;position:relative;max-width:100%;overflow:hidden}.cof-svg{width:100%;height:auto;max-width:500px;max-height:500px;display:block;filter:drop-shadow(0 10px 15px rgba(0,0,0,.05))}.cof-segment{transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;stroke:#fff;stroke-width:2px;transform-origin:center;-webkit-tap-highlight-color:transparent;outline:none;-webkit-touch-callout:none}.cof-segment-major{fill:#e2e8f0}.cof-segment-minor{fill:#cbd5e1}.cof-segment:hover{filter:brightness(.95)}.cof-label{text-anchor:middle;dominant-baseline:central;pointer-events:none;transition:all .2s ease;stroke:none!important;stroke-width:0!important}.cof-label.major{font-size:14px;font-weight:700;fill:#000;opacity:1}.cof-label.minor{font-size:11px;font-weight:600;fill:#000}.cof-center-circle{fill:#fff;stroke:#fff;stroke-width:2px}.cof-center-text{font-size:36px;font-weight:700;fill:#000;text-anchor:middle;padding:0}.cof-segment.active-center{fill:#3b82f6!important;stroke:#fff;stroke-width:2px}.cof-label.active-center{fill:#fff!important;text-shadow:none;font-weight:800}.cof-segment.active-neighbor{fill:#dbeafe!important;stroke:#fff;stroke-width:2px}.cof-label.active-neighbor{fill:#000!important;font-weight:700;stroke:none!important}.cof-segment.inactive{fill:#f8fafc;opacity:.8}.cof-label.inactive{opacity:.3;fill:#000}.bottom-nav{position:fixed;bottom:0;left:0;width:100%;background-color:var(--color-bg-panel);border-top:1px solid var(--color-border);display:flex;justify-content:center;gap:3rem;padding:.5rem 0;box-shadow:0 -4px 6px -1px #0000000d;z-index:1000}.copyright-info{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:.6rem;color:var(--color-text-secondary);opacity:.6;white-space:nowrap;pointer-events:none}.nav-item{background:transparent;border:none;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem 1rem;color:var(--color-text-secondary);cursor:pointer;border-radius:8px;width:100px;transition:all .2s}.nav-item:hover{background-color:var(--color-interval-default);color:var(--color-text-primary)}.nav-item.active{color:var(--color-accent)}.nav-item.active .icon{transform:scale(1.1)}.nav-item .icon{font-size:1.5rem;transition:transform .2s}.nav-item span{font-size:.8rem;font-weight:600}.content-wrapper{padding-bottom:80px}@media(max-width:480px){.bottom-nav{gap:0;justify-content:space-around;padding:.5rem .25rem}.nav-item{width:auto;flex:1;padding:.5rem .25rem;gap:.1rem}.nav-item span{font-size:.65rem}.nav-item .icon{font-size:1.25rem}}.modal-overlay{position:fixed;inset:0;background-color:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:10000;animation:fadeIn .2s ease-out}.modal-content{background:var(--color-bg-panel, #ffffff);padding:2rem;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;max-width:90%;width:400px;position:relative;animation:slideUp .3s cubic-bezier(.16,1,.3,1);border:1px solid var(--color-border, #e2e8f0)}.modal-header{margin-bottom:1rem;display:flex;justify-content:center;align-items:center;text-align:center}.modal-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary, #1e293b);line-height:1.4;text-align:center;width:100%}.modal-body{margin-bottom:1.5rem;color:var(--color-text-secondary, #64748b);font-size:1rem;line-height:1.5}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.release-notes-modal{width:600px;max-width:95%}.release-notes-scroll-wrapper{max-height:55vh;overflow-y:auto;padding-right:.5rem;text-align:left;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.release-notes-scroll-wrapper::-webkit-scrollbar{width:6px}.release-notes-scroll-wrapper::-webkit-scrollbar-track{background:transparent}.release-notes-scroll-wrapper::-webkit-scrollbar-thumb{background-color:var(--color-border);border-radius:3px}.release-notes-timeline{display:flex;flex-direction:column;padding:1.5rem 1rem;position:relative;font-family:var(--font-family);min-height:100%}.release-notes-timeline:before{content:"";position:absolute;top:1.5rem;bottom:1.5rem;left:2rem;width:2px;background:linear-gradient(to bottom,var(--color-accent) 0%,var(--color-border) 100%);border-radius:1px;z-index:0}.version-block{position:relative;margin-bottom:2rem;padding-left:3.5rem}.version-block:last-child{margin-bottom:0}.version-marker{position:absolute;left:1.5rem;top:0;width:1rem;height:1rem;background-color:var(--color-bg-panel);border:2px solid var(--color-text-muted);border-radius:50%;z-index:2;transition:all .3s ease}.version-block:hover .version-marker{transform:scale(1.2);border-color:var(--color-accent)}.version-block.latest .version-marker{background-color:var(--color-accent);border-color:var(--color-accent);box-shadow:0 0 0 4px #3b82f633}.version-content{background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;box-shadow:0 2px 4px #0000000d;transition:transform .2s,box-shadow .2s}.version-block:hover .version-content{transform:translateY(-2px);box-shadow:0 8px 16px #00000014;border-color:#cbd5e1}.version-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;border-bottom:1px solid var(--color-bg-app);padding-bottom:.75rem}.version-title{font-size:1.25rem;font-weight:800;color:var(--color-text-primary);margin:0;line-height:1;text-align:left}.version-block.latest .version-title{color:var(--color-accent)}.new-badge{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-hover));color:#fff;font-size:.65rem;font-weight:700;text-transform:uppercase;padding:.25rem .6rem;border-radius:999px;letter-spacing:.05em;box-shadow:0 2px 4px #3b82f64d;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.version-changes{margin:0;padding:0;list-style:none;text-align:left}.version-changes li{position:relative;padding-left:1.5rem;margin-bottom:.5rem;color:var(--color-text-secondary);line-height:1.5;font-weight:500}.version-changes li:before{content:"•";position:absolute;left:.25rem;color:var(--color-accent);font-weight:700;font-size:1.25em;line-height:1;top:.1em}.version-changes li:last-child{margin-bottom:0}@media(max-width:600px){.release-notes-timeline:before{left:1rem}.version-marker{left:.5rem}.version-block{padding-left:2.5rem}}
