.glow{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 20%,rgba(232,169,62,.04) 0%,transparent 70%);pointer-events:none;z-index:0}.layout{position:relative;z-index:1;min-height:100vh}.top-nav{display:flex;justify-content:center;padding:16px 20px 0;position:relative;z-index:10}.top-nav-inner{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:4px}.nav-tab{background:none;border:none;color:var(--text-dim);padding:8px 24px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;letter-spacing:.3px;text-transform:uppercase;border-radius:8px}.nav-tab:hover{color:var(--text)}.nav-tab.active{background:var(--accent);color:#1a1a10;font-weight:700}.page-content{max-width:900px;margin:0 auto;padding:20px;animation:fadeIn .3s ease}.page-header{text-align:center;padding:32px 0 28px;display:flex;flex-direction:column;align-items:center;gap:10px}.page-header .logo{font-size:36px;line-height:1;opacity:.9;animation:pulse 3s ease-in-out infinite;color:var(--accent-light)}.page-header .logo svg{width:36px;height:36px}.page-header h1{font-family:Playfair Display,serif;font-size:clamp(32px,8vw,48px);font-weight:900;letter-spacing:-1px;line-height:.95;background:linear-gradient(135deg,var(--text) 30%,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header .subtitle{color:var(--text-dim);font-size:16px;font-weight:300;margin-bottom:12px}@media(max-width:600px){.page-content{padding:12px}.page-header h1{font-size:32px}}.piano-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px 12px 12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.piano{position:relative;height:160px;margin:0 auto;user-select:none;-webkit-user-select:none}.key{position:absolute;top:0;border-radius:0 0 5px 5px;cursor:pointer;display:flex;align-items:flex-end;justify-content:center;transition:background .08s,box-shadow .08s}.key .label{font-size:9px;padding-bottom:4px;opacity:.5;pointer-events:none;font-weight:500}.key.white{width:34px;height:150px;background:var(--white-key);border:1px solid #c0bfb6;z-index:1}.key.white .label{color:#666}.key.white:active{background:#e0dfd6}.key.white.active{background:var(--white-key-active);box-shadow:0 0 12px var(--accent-glow)}.key.white.bass{background:var(--accent-light);box-shadow:0 0 16px var(--accent-glow)}.key.black{width:22px;height:95px;background:var(--black-key);border:1px solid #3a3a50;z-index:2}.key.black .label{color:#777;font-size:8px}.key.black:active{background:#2a2a40}.key.black.active{background:var(--black-key-active);box-shadow:0 0 10px var(--accent-glow)}.key.black.bass{background:var(--accent);box-shadow:0 0 12px var(--accent-glow)}@media(max-width:600px){.key.white{width:24px;height:130px}.key.black{width:16px;height:80px}.piano{height:135px}}.chord-pill{position:relative;background:var(--surface);border:2px solid var(--border);border-radius:10px;padding:10px 18px;cursor:pointer;font-size:20px;font-weight:700;transition:all .15s;-webkit-user-select:none;user-select:none}.chord-pill:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.chord-pill.dragging{opacity:.4;transform:scale(.95)}.chord-pill[draggable]{cursor:grab}.chord-pill[draggable]:active{cursor:grabbing}.chord-pill.active{background:var(--accent);color:#1a1a10;border-color:var(--accent);box-shadow:0 0 16px var(--accent-glow)}.chord-pill .bar-num{display:block;font-family:DM Sans,sans-serif;font-size:10px;font-weight:400;color:var(--text-dim);text-align:center;margin-top:2px}.chord-pill.active .bar-num{color:var(--bg);opacity:.7}.pill-remove{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:var(--bg);font-size:14px;line-height:22px;text-align:center;cursor:pointer;font-weight:700;transition:all .15s}.pill-remove:hover{background:var(--error);color:#fff;transform:scale(1.15)}.pill-insert{width:28px;height:28px;border-radius:50%;background:none;border:2px dashed var(--text-dim);color:var(--text-dim);font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;-webkit-user-select:none;user-select:none;flex-shrink:0;opacity:.4}.pill-insert:hover{border-color:var(--success);color:var(--success);opacity:1;transform:scale(1.15);box-shadow:0 0 10px var(--success-glow)}.pill-add{background:none;border:2px dashed var(--success);border-radius:10px;padding:10px 18px;cursor:pointer;font-size:24px;font-weight:700;color:var(--success);transition:all .15s;-webkit-user-select:none;user-select:none;min-width:50px;display:flex;align-items:center;justify-content:center}.pill-add:hover{background:var(--success);color:var(--bg);box-shadow:0 0 16px var(--success-glow);transform:translateY(-2px)}.song-library{margin-top:32px}.library-title{font-size:18px;font-weight:700;margin-bottom:14px}.lib-section{border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:10px;background:var(--surface);transition:border-color .2s}.lib-section:hover{border-color:color-mix(in srgb,var(--sec-color) 40%,var(--border))}.lib-section-header{display:flex;align-items:center;gap:8px;width:100%;padding:11px 14px;background:none;border:none;color:var(--text);cursor:pointer;font-family:inherit;font-size:13px;font-weight:700;text-align:left;transition:background .12s}.lib-section-header:hover{background:var(--surface-2)}.lib-section-dot{width:8px;height:8px;border-radius:50%;background:var(--sec-color);flex-shrink:0;box-shadow:0 0 6px var(--sec-color)}.lib-section-label{flex:1;letter-spacing:.2px}.lib-section-count{font-size:11px;font-weight:600;color:var(--text-dim);background:var(--surface-3);padding:1px 7px;border-radius:8px}.lib-section-chevron{color:var(--text-dim);display:flex;align-items:center}.lib-section-body{border-top:1px solid var(--border);padding:10px 12px;animation:fadeIn .15s ease}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px}.song-card{position:relative;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:10px 12px;cursor:pointer;transition:all .15s}.song-card:hover{border-color:var(--card-accent, var(--accent));transform:translateY(-2px);box-shadow:0 4px 16px #0000004d}.song-name{font-weight:700;font-size:13px;margin-bottom:2px}.song-detail{font-size:11px;color:var(--text-dim);margin-bottom:4px}.song-chords{font-size:12px;font-weight:600;color:var(--card-accent, var(--accent-light));word-break:break-word}.song-delete{position:absolute;top:6px;right:6px;background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px;border-radius:6px;opacity:0;transition:all .12s;display:flex;align-items:center}.song-card:hover .song-delete{opacity:1}.song-delete:hover{color:var(--error);background:#f871711f}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease}.modal{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px 32px 24px;width:340px;max-width:90vw;text-align:center;animation:popIn .2s ease}.modal-close{position:absolute;top:10px;right:10px;background:none;border:none;color:var(--text-dim);cursor:pointer;padding:4px;border-radius:6px;display:flex}.modal-close:hover{color:var(--text);background:var(--surface-2)}.modal-icon{color:var(--error);margin-bottom:12px}.modal-title{font-size:16px;font-weight:700;margin-bottom:6px}.modal-text{font-size:13px;color:var(--text-dim);margin-bottom:20px;line-height:1.4}.modal-text strong{color:var(--text)}.modal-actions{display:flex;gap:8px;justify-content:center}.modal-btn{border:none;border-radius:10px;padding:9px 22px;font-family:inherit;font-size:13px;font-weight:700;cursor:pointer;transition:all .12s}.modal-btn--cancel{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border)}.modal-btn--cancel:hover{background:var(--surface-3);color:var(--text)}.modal-btn--delete{background:var(--error);color:#fff}.modal-btn--delete:hover{background:#ef4444;box-shadow:0 4px 12px var(--error-glow)}@media(max-width:600px){.library-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:6px}.lib-section-header{padding:10px 12px;font-size:12px}.lib-section-body{padding:8px}}.chord-builder{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:center;margin-bottom:28px}.chord-builder select{background:var(--surface-2);color:var(--text);border:1px solid var(--surface-3);border-radius:10px;padding:10px 30px 10px 14px;font-family:inherit;font-size:16px;font-weight:600;cursor:pointer;transition:border-color .15s;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2375758a' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.chord-builder select:hover,.chord-builder select:focus{border-color:var(--accent);outline:none}.chord-builder .sep{width:1px;height:32px;background:var(--border);margin:0 4px}.add-btn{background:var(--accent);color:#1a1a10;border:none;border-radius:10px;padding:10px 18px;font-weight:700;font-family:inherit;font-size:15px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.add-btn:hover{background:var(--accent-light);box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}.add-btn svg{width:16px;height:16px}.clear-btn{background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:10px;padding:10px 14px;font-family:inherit;font-size:13px;cursor:pointer;transition:all .15s}.clear-btn:hover{border-color:var(--error);color:var(--error)}.progression{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:28px;justify-content:center;align-items:center}.controls{display:flex;flex-direction:column;gap:12px;align-items:center;margin-bottom:24px}.tempo-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-dim)}.tempo-row input[type=range]{width:120px;accent-color:var(--accent)}.tempo-val{font-weight:700;color:var(--text);min-width:70px}.control-btns{display:flex;gap:8px;align-items:center}.nav-btn,.save-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 14px;font-size:14px;cursor:pointer;transition:all .15s}.nav-btn:hover,.save-btn:hover{border-color:var(--accent);background:var(--surface-2)}.play-btn{background:var(--accent);color:#1a1a10;border:none;border-radius:8px;padding:8px 20px;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s}.play-btn:hover{background:var(--accent-light)}.play-btn.playing{background:var(--error);color:#fff}.inversion-bar{display:flex;justify-content:center;gap:8px;margin-bottom:16px}.inv-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);border-radius:8px;padding:6px 16px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.inv-btn:hover{border-color:var(--accent);color:var(--text)}.inv-btn.active{background:var(--accent);color:#1a1a10;border-color:var(--accent)}.piano-section{margin-bottom:32px}.piano-header{display:flex;align-items:baseline;gap:12px;margin-bottom:10px}.piano-header h2{font-size:24px}.chord-notes{font-size:14px;color:var(--text-dim)}.inversion-detail{text-align:center;font-size:12px;color:var(--text-dim);margin-top:8px}.triads-home{display:flex;flex-direction:column;align-items:center;gap:24px;max-width:500px;margin:0 auto}.mode-cards{display:flex;flex-direction:column;gap:14px;width:100%}.mode-card{display:flex;align-items:center;gap:16px;padding:18px 20px;background:var(--surface);border:1px solid var(--surface-3);border-radius:14px;cursor:pointer;text-align:left;color:var(--text);font-family:inherit;font-size:14px;transition:all .2s}.mode-card:hover{border-color:var(--accent);background:var(--surface-2);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.mode-card:active{transform:translateY(0)}.mode-icon{font-size:28px;flex-shrink:0;display:inline-flex}.mode-info{display:flex;flex-direction:column;gap:2px}.mode-title{font-weight:700;font-size:16px}.mode-desc{font-size:13px;color:var(--text-dim);font-weight:300}.sound-toggle{background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:20px;padding:6px 16px;font-family:inherit;font-size:13px;cursor:pointer;transition:all .15s;margin-top:8px}.sound-toggle:hover{border-color:var(--accent);color:var(--text)}.triads-screen{animation:fadeIn .3s ease}.top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.back-btn{background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:8px;padding:6px 12px;font-family:inherit;font-size:13px;cursor:pointer;transition:all .15s}.back-btn:hover{border-color:var(--accent);color:var(--text)}.stats{display:flex;gap:20px}.stat-item{text-align:center}.stat-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:20px;font-weight:700}.chord-display{text-align:center;margin-bottom:28px}.chord-name{font-family:Playfair Display,serif;font-size:48px;font-weight:700;color:var(--accent-light)}.chord-sub{font-size:14px;color:var(--text-dim);margin-top:4px}.answer-slots{display:flex;justify-content:center;gap:12px;margin-bottom:24px}.slot{width:60px;height:50px;border-radius:10px;border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;transition:all .15s}.slot.filled{border-style:solid;border-color:var(--accent);background:var(--surface-2);color:var(--accent-light)}.slot.correct{border-color:var(--success);background:#34d3991a;color:var(--success)}.slot.wrong{border-color:var(--error);background:#f871711a;color:var(--error)}.quiz-actions{display:flex;justify-content:center;gap:10px;margin-top:24px}.action-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);border-radius:8px;padding:8px 16px;font-family:inherit;font-size:13px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px}.action-btn:hover{border-color:var(--accent);color:var(--text)}.start-btn{background:var(--accent);color:#1a1a10;border:none;border-radius:10px;padding:12px 28px;font-family:inherit;font-size:15px;font-weight:700;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:8px}.start-btn:hover{background:var(--accent-light);transform:translateY(-1px)}.answer-reveal{margin-top:12px;padding:12px;background:var(--surface);border-radius:10px;text-align:center}.answer-phrase{font-family:Playfair Display,serif;font-size:28px;font-weight:700;color:var(--accent-light);animation:phraseReveal .4s ease}.answer-notes{font-size:16px;color:var(--text);margin-top:4px;font-weight:600}.note-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;max-width:500px;margin:0 auto}.note-btn{padding:14px 4px;border-radius:10px;border:2px solid var(--border);background:var(--surface);color:var(--text);font-family:DM Sans,sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.note-btn.black{grid-column:span 1;background:var(--surface-2);border-color:var(--surface-3)}.note-btn:hover:not(:disabled){border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.note-btn:active:not(:disabled){transform:translateY(0)}.note-btn.selected{background:var(--accent);border-color:var(--accent);color:#1a1a10;box-shadow:0 0 12px var(--accent-glow)}.note-btn.correct{background:var(--success);border-color:var(--success);color:#0b1a10;box-shadow:0 0 12px var(--success-glow)}.note-btn.wrong{background:var(--error);border-color:var(--error);color:#fff;box-shadow:0 0 12px var(--error-glow);animation:shake .3s}.note-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:480px){.note-grid{grid-template-columns:repeat(4,1fr);gap:6px}.note-btn{padding:12px 4px;font-size:14px}}.ref-grid{display:flex;flex-direction:column;gap:10px;max-width:500px;margin:0 auto}.ref-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all .15s}.ref-card:hover{border-color:var(--accent);transform:translateY(-1px)}.ref-card.expanded{border-color:var(--accent);box-shadow:0 4px 16px #0000004d}.ref-header{display:flex;align-items:baseline;gap:12px}.ref-name{font-family:Playfair Display,serif;font-size:22px;font-weight:700;color:var(--accent-light);min-width:50px}.ref-notes{font-size:14px;color:var(--text);font-weight:500}.ref-phrase{font-size:13px;color:var(--text-dim);font-style:italic;margin-left:auto}.ref-inversions{margin-top:12px;display:flex;flex-direction:column;gap:6px;animation:slideUp .2s ease}.ref-inv-row{display:flex;align-items:center;gap:10px;padding:6px 8px;background:var(--surface-2);border-radius:8px}.ref-inv-label{font-size:12px;font-weight:600;color:var(--text-dim);min-width:55px}.ref-inv-notes{font-size:14px;font-weight:500;flex:1}.ref-play{background:none;border:1px solid var(--border);color:var(--accent);border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:12px;transition:all .15s;display:flex;align-items:center;justify-content:center}.ref-play:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.progress-dots{display:flex;justify-content:center;gap:6px;margin-bottom:16px}.dot{width:12px;height:12px;border-radius:50%;background:var(--surface-3);transition:all .2s}.dot.current{background:var(--accent);box-shadow:0 0 8px var(--accent-glow);animation:glow 1.5s ease-in-out infinite}.dot.done{background:var(--success)}.dot.error{background:var(--error)}.flash-card{max-width:450px;margin:24px auto 32px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px 28px;text-align:center;animation:fadeIn .3s ease}.flash-label{font-size:14px;color:var(--text-dim);margin-bottom:8px}.flash-think{font-size:13px;color:var(--text-dim);font-style:italic;margin:12px 0}.flash-rating{margin-top:16px}.rating-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.rating-btn{padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.rating-btn:hover{transform:translateY(-2px)}.rating-no:hover{border-color:var(--error);color:var(--error)}.rating-slow:hover{border-color:var(--accent);color:var(--accent)}.rating-yes:hover{border-color:var(--success);color:var(--success)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px;margin:16px 0}.summary-item{display:flex;justify-content:space-between;padding:6px 10px;border-radius:6px;background:var(--surface-2);font-size:13px;font-weight:600}.summary-item.easy{color:var(--success)}.summary-item.slow{color:var(--accent)}.summary-item.hard{color:var(--error)}@font-face{font-family:Playfair Display;src:url(/fonts/playfair-700.woff2) format("woff2");font-weight:700;font-display:swap}@font-face{font-family:Playfair Display;src:url(/fonts/playfair-900.woff2) format("woff2");font-weight:900;font-display:swap}@font-face{font-family:DM Sans;src:url(/fonts/dmsans-400.woff2) format("woff2");font-weight:400;font-display:swap}@font-face{font-family:DM Sans;src:url(/fonts/dmsans-700.woff2) format("woff2");font-weight:700;font-display:swap}:root{--bg: #0b0b12;--surface: #13131e;--surface-2: #1b1b2a;--surface-3: #252538;--border: #252538;--text: #e4e4ee;--text-dim: #75758a;--accent: #e8a93e;--accent-light: #f4c96a;--accent-glow: rgba(232, 169, 62, .25);--success: #34d399;--success-glow: rgba(52, 211, 153, .3);--error: #f87171;--error-glow: rgba(248, 113, 113, .3);--white-key: #f0efe6;--white-key-active: #e8a93e;--black-key: #1e1e30;--black-key-active: #f4c96a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}@keyframes glow{0%,to{box-shadow:0 0 8px var(--accent-glow)}50%{box-shadow:0 0 20px var(--accent-glow)}}@keyframes phraseReveal{0%{transform:scale(.7);opacity:0;filter:blur(8px)}to{transform:scale(1);opacity:1;filter:blur(0)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:3px}
