:root{--fret-color: #ddd;--string-color: #aaa;--note-scale: #1f7ae0;--note-gold: #ffd700;--fretboard-bg: #3e2723;--bili-pink: #fb7299;--root-note: #ff7043;--control-bg: #ffffff;--page-bg: #f2f2f2}*{box-sizing:border-box}body{font-family:Inter,Noto Sans SC,PingFang SC,Microsoft YaHei,system-ui,sans-serif;font-weight:400;display:flex;flex-direction:column;align-items:center;background:var(--page-bg);padding:16px;margin:0;color:#222}.control-panel{display:flex;flex-direction:column;gap:16px;padding:16px;background:var(--control-bg);border-radius:12px;box-shadow:0 6px 18px #00000014;margin-bottom:24px;width:min(1200px,100%)}.control-row{display:flex;flex-wrap:wrap;gap:16px;align-items:center}.control-label{font-size:14px;font-weight:700;color:#333;min-width:72px}.btn-group{display:flex;flex-wrap:wrap;gap:8px}button{padding:9px 12px;cursor:pointer;border:1px solid #ccc;background:#fff;border-radius:6px;font-weight:600;transition:.2s}button.active{background:var(--note-scale);color:#fff;border-color:var(--note-scale)}select,input[type=range]{padding:6px 8px;border:1px solid #ccc;border-radius:6px;background:#fff}.control-row select{appearance:none;padding:8px 34px 8px 12px;border-radius:10px;border:1px solid #d0d7de;background-color:#fff;color:#111;font-weight:700;letter-spacing:.2px;box-shadow:0 1px #1b1f240a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23111211' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 10px center;background-size:12px 8px;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease,transform .1s ease}.control-row select:hover{background-color:#f6f8fa;border-color:#d0d7de;box-shadow:0 2px 6px #1f23281f}.control-row select:focus{outline:none;border-color:#0969da;box-shadow:0 0 0 3px #0969da33}.control-row select:active{transform:translateY(1px)}.switch-box{display:flex;align-items:center;gap:12px;border-left:1px solid #eee;padding-left:16px}.switch{position:relative;width:50px;height:26px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.3s;border-radius:34px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.slider{background-color:var(--note-gold)}input:checked+.slider:before{transform:translate(24px)}.fretboard-wrapper{position:relative;width:min(1200px,100%);overflow-x:auto;padding-bottom:8px}.fretboard{display:grid;grid-template-rows:repeat(6,1fr);background:var(--fretboard-bg);border:4px solid #222;border-radius:4px;position:relative;min-width:1150px}.string{display:grid;grid-template-columns:.5fr repeat(15,1fr);height:38px;position:relative}.string:after{content:"";position:absolute;left:0;top:50%;width:100%;height:2px;background:var(--string-color);z-index:1;pointer-events:none}.fret{border-right:2px solid var(--fret-color);display:flex;justify-content:center;align-items:center;position:relative;z-index:2}.fret-0{border-right:5px solid #eee;background:#0003}.note{width:26px;height:26px;border-radius:50%;background:var(--note-scale);color:#fff;font-size:11px;font-weight:700;display:none;justify-content:center;align-items:center;z-index:10;box-shadow:0 2px 5px #0006;position:relative}.note.root-note{background:var(--root-note);box-shadow:0 0 8px #ff7043cc}.note .degree{position:absolute;bottom:-12px;font-size:9px;color:#ffdede}@keyframes golden-breath{0%,to{box-shadow:0 0 #ffd70000;border:1px solid transparent}50%{box-shadow:0 0 10px 4px #ffd700cc;border:1px solid var(--note-gold)}}.fretboard.pattern-1 .p1.in-scale,.fretboard.pattern-2 .p2.in-scale,.fretboard.pattern-3 .p3.in-scale,.fretboard.pattern-4 .p4.in-scale,.fretboard.pattern-5 .p5.in-scale{display:flex}.fretboard:not(.caged-on).pattern-1 .p1.in-scale.ct1,.fretboard:not(.caged-on).pattern-2 .p2.in-scale.ct2,.fretboard:not(.caged-on).pattern-3 .p3.in-scale.ct3,.fretboard:not(.caged-on).pattern-4 .p4.in-scale.ct4,.fretboard:not(.caged-on).pattern-5 .p5.in-scale.ct5{animation:golden-breath 2s infinite ease-in-out}.fretboard.caged-on .note{display:none!important}.fretboard.caged-on.pattern-1 .p1.in-scale.ct1,.fretboard.caged-on.pattern-2 .p2.in-scale.ct2,.fretboard.caged-on.pattern-3 .p3.in-scale.ct3,.fretboard.caged-on.pattern-4 .p4.in-scale.ct4,.fretboard.caged-on.pattern-5 .p5.in-scale.ct5{display:flex!important;background:var(--note-gold);color:#320}.inlay{position:absolute;width:14px;height:14px;background:#ffffff1a;border-radius:50%}.fret-numbers{display:grid;grid-template-columns:.5fr repeat(15,1fr);width:100%;margin-top:10px;min-width:1150px}.num{text-align:center;font-size:12px;color:#777;font-weight:700}.metronome-toggle,.metronome-speed{display:flex;align-items:center;gap:12px;white-space:nowrap}.metronome-speed input[type=range]{width:150px;cursor:pointer}.metronome-speed-value{font-size:13px;font-weight:700;color:var(--note-scale);min-width:75px;text-align:center}.footer{margin-top:40px;padding:20px;text-align:center;border-top:1px solid #ddd;width:min(1200px,100%)}.footer .name{font-size:14px;color:#666;letter-spacing:1px;margin-bottom:8px}.footer a{color:var(--bili-pink);text-decoration:none;font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:6px;transition:.3s}.footer a:hover{opacity:.8;text-shadow:0 0 8px rgba(251,114,153,.2)}@media(max-width:768px){.control-label{min-width:auto}.switch-box{border-left:none;padding-left:0}}:root{--page-bg: #eaf3ff;--page-text: #1b2a4a;--control-bg: #f5f9ff;--panel-border: #c9dcff;--note-scale: #2563eb;--note-gold: #fbbf24;--root-note: #f97316;--cta-green: #22c55e;--fretboard-bg: #3a2722;--card-bg: #ffffff;--card-border: #d4e2ff;--card-shadow: rgba(37, 99, 235, .12);--surface-muted: #eef4ff;--surface-soft: #f7faff;--border-strong: #c7dbff;--border-soft: #d6e4ff;--radius-xs: 10px;--radius-sm: 12px;--radius-md: 16px;--radius-lg: 20px;--radius-xl: 22px;--space-1: 6px;--space-2: 10px;--space-3: 14px;--space-4: 18px;--shadow-soft: 0 10px 18px rgba(37, 99, 235, .1);--shadow-elevated: 0 14px 24px rgba(37, 99, 235, .14);--inset-top: inset 0 1px 0 rgba(255, 255, 255, .68)}body.chord-arpeggio{font-family:Inter,Noto Sans SC,PingFang SC,Microsoft YaHei,system-ui,sans-serif;font-weight:400;background:radial-gradient(circle at 12% 12%,rgba(59,130,246,.18),transparent 45%),radial-gradient(circle at 88% 8%,rgba(147,197,253,.26),transparent 55%),linear-gradient(150deg,#f2f7ff,#e2efff 45%,#f8fbff);color:var(--page-text);margin:0;padding:28px 16px 36px;display:block}body.chord-arpeggio .page{width:min(1200px,100%);margin:0 auto;display:flex;flex-direction:column;gap:24px}body.chord-arpeggio .page-hero{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:20px;align-items:stretch}body.chord-arpeggio .hero-copy h1{font-family:Righteous,Poppins,sans-serif;font-size:clamp(28px,4vw,40px);margin:6px 0 10px;letter-spacing:.5px}body.chord-arpeggio .eyebrow{margin:0;font-size:12px;letter-spacing:1.2px;text-transform:uppercase;color:#f8fafcb8}body.chord-arpeggio .hero-subtitle{margin:0;font-size:15px;color:#1b2a4ab8;line-height:1.6}body.chord-arpeggio .hero-card{background:var(--card-bg);border:2px solid var(--card-border);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow-elevated),var(--inset-top);display:flex;flex-direction:column;gap:12px}body.chord-arpeggio .hero-card-title{font-family:Righteous,Poppins,sans-serif;font-size:16px;letter-spacing:.4px}body.chord-arpeggio .hero-card-body{display:grid;gap:10px;font-size:13px;color:#1b2a4ac7}body.chord-arpeggio .tip-row{display:flex;justify-content:space-between;gap:12px;padding-bottom:10px;border-bottom:1px dashed rgba(37,99,235,.18)}body.chord-arpeggio .tip-row:last-child{border-bottom:none;padding-bottom:0}body.chord-arpeggio .tip-label{font-weight:700;color:#1b2a4ab3}body.chord-arpeggio .control-panel{background:var(--control-bg);border:2px solid var(--panel-border);border-radius:var(--radius-xl);padding:20px;box-shadow:var(--shadow-elevated),var(--inset-top);margin-bottom:0;display:flex;flex-direction:column;gap:16px}body.chord-arpeggio .top-tabs{display:inline-flex;gap:10px;padding:6px;border-radius:999px;background:var(--surface-muted);border:2px solid var(--border-strong);box-shadow:var(--shadow-soft),var(--inset-top);width:max-content}body.chord-arpeggio .top-tab-btn{border:none;background:transparent;padding:8px 16px;border-radius:999px;font-weight:700;color:#1b2a4ab8;cursor:pointer}body.chord-arpeggio .top-tab-btn.active{background:#2563eb;color:#fff}body.chord-arpeggio .tab-panel{display:none}body.chord-arpeggio .tab-panel.active{display:block}body.chord-arpeggio.tab-phrase .fixed-metronome{display:none}body.chord-arpeggio .mode-toggle{display:inline-flex;gap:10px;padding:6px;border-radius:999px;background:var(--surface-muted);border:2px solid var(--border-strong);box-shadow:var(--shadow-soft),var(--inset-top);margin-bottom:12px}body.chord-arpeggio .mode-btn{border:none;background:transparent;padding:8px 16px;border-radius:999px;font-weight:700;color:#1b2a4ab8;cursor:pointer;transition:background-color .2s ease,color .2s ease,box-shadow .2s ease}body.chord-arpeggio .mode-btn.active{background:#2563eb;color:#fff;box-shadow:0 8px 16px #2563eb40}body.chord-arpeggio.mode-caged .training-only,body.chord-arpeggio.mode-training .caged-only,body.chord-arpeggio .control-group.circle-only,body.chord-arpeggio .fretboard-section.circle-only,body.chord-arpeggio.mode-circle .training-only,body.chord-arpeggio.mode-circle .caged-only{display:none}body.chord-arpeggio.mode-circle .control-group.circle-only{display:grid}body.chord-arpeggio .control-panel-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}body.chord-arpeggio.mode-training .control-panel-grid,body.chord-arpeggio.mode-caged .control-panel-grid{grid-template-columns:1fr}body.chord-arpeggio .scale-group{order:1}body.chord-arpeggio.mode-training .scale-group{grid-column:1 / -1}body.chord-arpeggio .metronome-group{order:2}body.chord-arpeggio .compact-controls{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:10px;width:100%}body.chord-arpeggio .training-view-toggle{display:inline-flex;align-items:center;gap:8px;padding:4px;border:2px solid var(--border-strong);border-radius:999px;background:var(--surface-muted)}body.chord-arpeggio .training-view-btn{border:none;border-radius:999px;padding:7px 12px;background:transparent;color:#1b2a4ab8;font-size:12px;font-weight:700;cursor:pointer;transition:background-color .2s ease,color .2s ease}body.chord-arpeggio .training-view-btn.active{background:#2563eb;color:#fff}body.chord-arpeggio .training-mode-field{width:max-content;min-width:0;align-self:flex-start}body.chord-arpeggio .training-option-row{display:flex;align-items:flex-start;justify-content:flex-start;gap:12px;flex-wrap:nowrap;width:100%}body.chord-arpeggio .training-option-row .field{min-width:150px;max-width:180px}body.chord-arpeggio .training-row{display:flex;align-items:flex-start;gap:12px;flex-wrap:nowrap}body.chord-arpeggio .chord-position-control{display:flex;align-items:center;gap:8px}body.chord-arpeggio .chord-position-play-btn{width:34px;height:34px;border:1px solid #9fc1fc;border-radius:8px;background:#2f67df;color:#fff;font-size:16px;font-weight:700;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #2f67df4d}body.chord-arpeggio .chord-position-play-btn:hover:not(:disabled){background:#2554b8}body.chord-arpeggio .chord-position-play-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}body.chord-arpeggio .training-row.is-inactive .field-label{color:#1b2a4a6b}body.chord-arpeggio .training-view-btn:disabled{opacity:.5;cursor:not-allowed}body.chord-arpeggio .compact-controls .switch-box{padding:4px 8px;min-height:38px}body.chord-arpeggio .chord-position-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}body.chord-arpeggio.mode-caged .caged-only{order:1}body.chord-arpeggio.mode-caged .metronome-group{order:2}body.chord-arpeggio .control-group{background:var(--card-bg);border:2px solid var(--card-border);border-radius:var(--radius-md);padding:16px;box-shadow:var(--shadow-soft),var(--inset-top);display:flex;flex-direction:column;gap:12px}body.chord-arpeggio .group-title,body.chord-arpeggio .circle-header h2,body.chord-arpeggio .phrase-library-head h2{margin:0;font-family:Righteous,Poppins,sans-serif;font-size:18px;font-weight:400;letter-spacing:.2px;color:#1b2a4a}body.chord-arpeggio .group-title{line-height:1.2}body.chord-arpeggio .control-row{align-items:center;gap:12px}body.chord-arpeggio .btn-group button{background:#fff;color:#1b2a4a;border:2px solid var(--border-strong);border-radius:14px;padding:9px 12px;font-weight:700;box-shadow:0 3px 8px #2563eb1f,var(--inset-top);transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease}body.chord-arpeggio .btn-group button:hover{transform:translateY(-1px);box-shadow:0 6px 12px #2563eb29,var(--inset-top)}body.chord-arpeggio button.active{background:#2563eb;border-color:#2563eb;color:#fff}body.chord-arpeggio .fretboard.show-scale .note.in-scale,body.chord-arpeggio .fretboard.show-chord .note.in-scale,body.chord-arpeggio .fretboard.show-arpeggio .note.in-scale,body.chord-arpeggio .fretboard.show-caged .note.caged-note{display:flex}body.chord-arpeggio .note.caged-note{background:#fbbf24;color:#4b3600;box-shadow:0 0 0 2px #fff inset,0 0 12px #fbbf2473}body.chord-arpeggio label.field{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:600;color:#1b2a4ab3;min-width:140px}body.chord-arpeggio select,body.chord-arpeggio input[type=range]{border:2px solid #c7dbff;border-radius:12px;background:#fff;color:#1b2a4a;font-weight:600;height:40px}body.chord-arpeggio .control-row select{appearance:none;padding:8px 36px 8px 12px;line-height:1.2;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%231B2A4A' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:12px 8px;box-shadow:none}body.chord-arpeggio .control-row select:disabled{background-color:#eef2f8;border-color:#d5ddea;color:#1b2a4a7a;cursor:not-allowed;box-shadow:none;transform:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%2394A3B8' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>")}body.chord-arpeggio .control-row select:disabled:hover,body.chord-arpeggio .control-row select:disabled:focus,body.chord-arpeggio .control-row select:disabled:active{background-color:#eef2f8;border-color:#d5ddea;color:#1b2a4a7a;box-shadow:none;transform:none}body.chord-arpeggio select option{color:#1b2a4a}body.chord-arpeggio .switch-box{border:2px solid #c7dbff;background:#e7f0ff;border-radius:999px;padding:6px 10px;gap:10px}body.chord-arpeggio .switch-label{font-size:12px;font-weight:700;color:#1b2a4ab3}body.chord-arpeggio .slider{background-color:#2563eb40}body.chord-arpeggio input:checked+.slider{background-color:#2563eb}body.chord-arpeggio .slider:before{background-color:#f8fafc}body.chord-arpeggio .metronome-toggle,body.chord-arpeggio .metronome-speed{gap:10px;flex-wrap:wrap}body.chord-arpeggio .metronome-signature-control label,body.chord-arpeggio .metronome-toggle label,body.chord-arpeggio .metronome-speed label{font-size:12px;font-weight:600;color:#1b2a4ab3}body.chord-arpeggio .metronome-speed input[type=range]{width:180px}body.chord-arpeggio .metronome-speed-value{color:#1d4ed8}body.chord-arpeggio .fixed-metronome{position:fixed;right:18px;top:120px;z-index:40;width:220px;display:grid;gap:8px;padding:12px 12px 10px;background:#fff;border:2px solid #c7dbff;border-radius:16px;box-shadow:0 16px 28px #2563eb2e,inset 0 1px #ffffffb3;transition:transform .24s ease,box-shadow .24s ease}body.chord-arpeggio .fixed-metronome-title{font-family:Righteous,Poppins,sans-serif;font-size:13px;letter-spacing:.3px}body.chord-arpeggio .metronome-collapse-btn{position:absolute;left:-20px;top:12px;width:18px;height:18px;border:none;background:transparent;color:#2563eb;font-size:22px;font-weight:700;line-height:1;display:grid;place-items:center;cursor:pointer;box-shadow:none;filter:drop-shadow(0 4px 8px rgba(37,99,235,.55));padding:0;z-index:2}body.chord-arpeggio .fixed-metronome.is-collapsed{transform:translate(calc(100% + 28px));overflow:visible}body.chord-arpeggio .fixed-metronome>:not(.metronome-collapse-btn){transition:opacity .16s ease}body.chord-arpeggio .fixed-metronome.is-collapsed>:not(.metronome-collapse-btn){opacity:0;pointer-events:none}body.chord-arpeggio .fixed-metronome.is-collapsed .metronome-collapse-btn{left:-40px;top:12px;width:18px;height:18px;font-size:22px;box-shadow:none;filter:drop-shadow(0 4px 9px rgba(37,99,235,.6))}body.chord-arpeggio .metronome-signature-control,body.chord-arpeggio .fixed-metronome .metronome-toggle,body.chord-arpeggio .fixed-metronome .metronome-speed{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:nowrap}body.chord-arpeggio .fixed-metronome .metronome-speed input[type=range],body.chord-arpeggio .fixed-metronome .metronome-signature-control select{width:112px}body.chord-arpeggio .fixed-metronome .metronome-speed-value{text-align:right;min-width:auto}body.chord-arpeggio .metronome-light-row{display:grid;grid-template-columns:repeat(var(--beat-count, 4),1fr);gap:6px}body.chord-arpeggio .metronome-light{width:100%;aspect-ratio:1 / 1;border-radius:6px;border:1px solid #c7dbff;background:#e7f0ff;transition:background-color .12s ease,box-shadow .12s ease}body.chord-arpeggio .metronome-light.active{background:#2563eb;box-shadow:0 0 0 2px #2563eb29}body.chord-arpeggio .metronome-light.accent.active{background:#f59e0b;box-shadow:0 0 0 2px #f59e0b33}body.chord-arpeggio .fretboard-section{display:grid;gap:12px;width:100%}body.chord-arpeggio .control-panel,body.chord-arpeggio .control-group{width:100%;box-sizing:border-box}body.chord-arpeggio .circle-mode-group{grid-column:1 / -1}body.chord-arpeggio .training-toast{margin-bottom:12px;border:2px solid #c7dbff;border-radius:14px;background:#f5f9ff;color:#1b2a4ad1;font-size:13px;font-weight:600;padding:10px 12px}body.chord-arpeggio .training-toast .toast-note{font-size:inherit;font-weight:inherit;color:#d9480f;margin-right:8px}body.chord-arpeggio .training-toast .toast-meta{color:#1b2a4ac7;font-size:13px}body.chord-arpeggio .section-header h2{margin:0;font-family:Righteous,Poppins,sans-serif;font-size:18px}body.chord-arpeggio .metronome-inline{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:#fff;border:2px solid #c7dbff;border-radius:16px;padding:12px 16px;box-shadow:0 10px 18px #2563eb24,inset 0 1px #ffffffb3}body.chord-arpeggio .metronome-inline .metronome-speed{flex:1;min-width:240px;justify-content:flex-end}body.chord-arpeggio .settings-inline{margin-bottom:12px;align-items:center;justify-content:flex-start}body.chord-arpeggio .settings-inline .field{min-width:200px}body.chord-arpeggio .field.field-inline{flex-direction:row;align-items:center;gap:12px}body.chord-arpeggio .field-label{font-family:Righteous,Poppins,sans-serif;font-size:14px;font-weight:400;letter-spacing:.4px;color:#1b2a4ab8;min-width:48px}body.chord-arpeggio .scale-group .field-label{font-family:Inter,Noto Sans SC,PingFang SC,Microsoft YaHei,system-ui,sans-serif;font-size:12px;font-weight:600;letter-spacing:0;color:#1b2a4ab3}body.chord-arpeggio .settings-inline select{border-radius:999px;padding:6px 40px 6px 14px;height:36px;min-width:180px;width:180px}body.chord-arpeggio .section-header p{margin:6px 0 0;color:#1b2a4ab3;font-size:13px}body.chord-arpeggio .fretboard-shell{background:#fff;border:2px solid #c7dbff;border-radius:20px;padding:16px;box-shadow:0 16px 30px #2563eb2e,inset 0 1px #ffffffb3}body.chord-arpeggio .fretboard-wrapper{background:#eef4ff;border-radius:14px;padding:12px;border:2px solid #c7dbff}body.chord-arpeggio .circle-current-key{font-size:13px;font-weight:700;color:#1d4ed8}body.chord-arpeggio .circle-module{display:grid;gap:18px;outline:none}body.chord-arpeggio .circle-header h2{line-height:1.2}body.chord-arpeggio .circle-header p{margin:8px 0 0;max-width:760px;font-size:12px;line-height:1.6;color:#1b2a4ac7}body.chord-arpeggio .circle-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px;align-items:stretch}body.chord-arpeggio .circle-shell{display:grid;place-items:center;padding:10px;border:2px solid var(--border-strong);border-radius:var(--radius-md);background:radial-gradient(circle at center,rgba(37,99,235,.08),transparent 60%),var(--surface-muted);overflow:auto;min-height:640px}body.chord-arpeggio .circle-wheel{width:min(640px,100%);min-width:360px;height:auto;display:block}body.chord-arpeggio .circle-ring-segment{stroke:#fffffff0;stroke-width:2;filter:grayscale(.76) saturate(.38) brightness(.98);transition:opacity .22s ease,filter .22s ease}body.chord-arpeggio .circle-ring-segment.outer-segment{opacity:.7}body.chord-arpeggio .circle-ring-segment.inner-segment{opacity:.5}body.chord-arpeggio .circle-ring-segment.is-related{opacity:1;filter:saturate(1.34) brightness(.95) contrast(1.06)}body.chord-arpeggio .circle-ring-segment.is-hover{opacity:.9;filter:grayscale(.34) saturate(.72) brightness(1)}body.chord-arpeggio .circle-ring-segment.is-active{opacity:1;filter:saturate(1.46) brightness(.9) contrast(1.1)}body.chord-arpeggio .key-item{cursor:pointer}body.chord-arpeggio .key-hit-area{fill:transparent}body.chord-arpeggio .key-pill{fill:transparent;stroke:transparent;stroke-width:0;transition:none}body.chord-arpeggio .key-text{fill:#111827d1;text-anchor:middle;dominant-baseline:middle;font-weight:600;pointer-events:none;transition:fill .2s ease,font-weight .2s ease}body.chord-arpeggio .key-item.major .key-text{font-size:28px;letter-spacing:.4px;font-weight:600}body.chord-arpeggio .key-item.minor .key-text{font-size:17px;font-weight:500}body.chord-arpeggio .key-item.is-hover .key-pill,body.chord-arpeggio .key-item.is-related .key-pill{fill:transparent;stroke:transparent}body.chord-arpeggio .key-item.is-related .key-text{fill:#111827eb;font-weight:620}body.chord-arpeggio .key-item.is-active .key-pill{fill:transparent;stroke:transparent;stroke-width:0;filter:none}body.chord-arpeggio .key-item.is-active .key-text{fill:#0f172a;font-weight:740}body.chord-arpeggio .circle-info{border:2px solid var(--border-strong);border-radius:var(--radius-md);background:var(--surface-soft);padding:14px;display:grid;gap:12px;min-height:640px;max-height:640px;overflow:auto;box-shadow:var(--shadow-soft),var(--inset-top)}body.chord-arpeggio .circle-info-title{margin:0;font-family:Righteous,Poppins,sans-serif;font-size:20px;color:#1d4ed8;letter-spacing:.3px}body.chord-arpeggio .circle-info-desc{margin:-2px 0 2px;font-size:12px;line-height:1.7;color:#1b2a4ac7}body.chord-arpeggio .circle-info-block h4{margin:0 0 8px;font-size:12px;color:#1b2a4ac7}body.chord-arpeggio .circle-chip-row{display:flex;flex-wrap:wrap;gap:8px}body.chord-arpeggio .circle-chip{border:1px solid #b8d0fb;border-radius:999px;background:#fff;padding:5px 10px;font-size:12px;font-weight:700;color:#1f2a44}body.chord-arpeggio .circle-list{display:grid;gap:0;border-top:1px solid rgba(37,99,235,.2);border-bottom:1px solid rgba(37,99,235,.2)}body.chord-arpeggio .circle-row{border:1px solid #c7dbff;border-radius:10px;background:#fff;padding:8px 10px;display:flex;justify-content:space-between;align-items:center;gap:12px}body.chord-arpeggio .progression-trigger{width:100%;cursor:pointer;text-align:left;border:none;border-radius:0;background:transparent;padding:10px 2px;transition:background-color .18s ease,color .18s ease}body.chord-arpeggio .circle-line-row{border:none;border-radius:0;background:transparent;border-top:1px solid rgba(148,163,184,.18)}body.chord-arpeggio .circle-line-row:first-child{border-top:none}body.chord-arpeggio .progression-trigger:hover{background:#dbeafe73}body.chord-arpeggio .progression-trigger:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}body.chord-arpeggio .progression-trigger.is-playing{background:#dbeafecc}body.chord-arpeggio .circle-row .roman{font-weight:700;color:#1d4ed8;min-width:54px;font-size:12px}body.chord-arpeggio .circle-row .value{text-align:right;font-weight:700;color:#111827;font-size:12px}body.chord-arpeggio .circle-diatonic-grid{background:transparent;padding:2px 0;display:grid;gap:0}body.chord-arpeggio .circle-diatonic-grid .label{font-size:11px;font-weight:700;color:#1b2a4aa6;letter-spacing:.2px}body.chord-arpeggio .circle-diatonic-grid .row{display:grid;grid-template-columns:repeat(7,minmax(40px,1fr));gap:6px;text-align:center;padding:8px 0;border-top:1px solid rgba(148,163,184,.18)}body.chord-arpeggio .circle-diatonic-grid .row-with-tag{grid-template-columns:58px repeat(7,minmax(40px,1fr));align-items:center}body.chord-arpeggio .circle-diatonic-grid .row-with-tag:first-child{border-top:none}body.chord-arpeggio .circle-diatonic-grid .row-tag{font-size:11px;font-weight:700;color:#1d4ed8d9;text-align:center;padding:2px;background:transparent;border:none}body.chord-arpeggio .circle-diatonic-grid .roman-cell{font-size:12px;font-weight:800;color:#1d4ed8;padding:4px 2px;background:transparent;border:none}body.chord-arpeggio .circle-diatonic-grid .chord-cell{font-size:12px;font-weight:700;color:#111827}body.chord-arpeggio .circle-diatonic-grid .chord-trigger{border:none;border-radius:6px;background:transparent;cursor:pointer;padding:4px 2px;line-height:1.2;transition:transform .12s ease,background-color .18s ease,box-shadow .18s ease}body.chord-arpeggio .circle-diatonic-grid .chord-trigger:hover{background:#dbeafe8c;transform:translateY(-1px);box-shadow:0 2px 8px #2563eb1f}body.chord-arpeggio .circle-diatonic-grid .chord-trigger:focus-visible{outline:2px solid #3b82f6;outline-offset:1px}body.chord-arpeggio .circle-diatonic-grid .chord-trigger.is-playing{background:#dbeafe;box-shadow:0 0 0 2px #3b82f638;transform:translateY(1px)}body.chord-arpeggio .circle-shift-row{display:none}body.chord-arpeggio .phrase-library-demo{background:#fff;border:2px solid var(--border-strong);border-radius:var(--radius-lg);padding:16px;gap:14px;box-shadow:var(--shadow-soft),var(--inset-top)}body.chord-arpeggio .phrase-library-demo.tab-panel{display:none}body.chord-arpeggio .phrase-library-demo.tab-panel.active{display:grid}body.chord-arpeggio .phrase-library-head h2{line-height:1.2}body.chord-arpeggio .phrase-library-head p{margin:6px 0 0;color:#1b2a4ab8;font-size:13px;font-weight:600}body.chord-arpeggio .phrase-library-filters{display:grid;grid-template-columns:220px minmax(220px,360px);gap:10px 12px;align-items:end}body.chord-arpeggio .phrase-filter-field{display:grid;gap:4px}body.chord-arpeggio .phrase-filter-field span{font-size:12px;font-weight:700;color:#1b2a4ac7}body.chord-arpeggio .phrase-filter-field select,body.chord-arpeggio .phrase-filter-field input{height:34px;border:1px solid #c7dbff;border-radius:8px;background:#fff;color:#1b2a4a;font-size:13px;padding:0 10px}body.chord-arpeggio .phrase-filter-field input::placeholder{color:#475569a8}body.chord-arpeggio .phrase-file-input{display:none}body.chord-arpeggio .phrase-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;align-items:start;width:100%}body.chord-arpeggio .phrase-card{border:1px solid rgba(201,220,255,.95);border-radius:10px;width:100%;min-height:208px;aspect-ratio:1 / .88;background:#fff;color:#1b2a4a;display:flex;flex-direction:column;text-align:left;gap:0;padding:0;box-sizing:border-box;box-shadow:0 4px 12px #0f172a14;overflow:hidden;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}body.chord-arpeggio .phrase-card:hover{transform:translateY(-4px);box-shadow:0 12px 22px #0f172a24;border-color:#93c5fdeb}body.chord-arpeggio .phrase-file-card{cursor:pointer;align-items:stretch;justify-content:flex-start;position:relative}body.chord-arpeggio .phrase-card-thumb{width:100%;height:96px;border-bottom:1px solid #e6efff;border-radius:0;background:linear-gradient(155deg,#edf5ff,#dfebff),repeating-linear-gradient(-25deg,#2563eb0f 0 12px,#2563eb05 12px 24px);overflow:hidden;display:grid;place-items:center;flex:0 0 auto}body.chord-arpeggio .phrase-card-thumb img{width:100%;height:100%;object-fit:cover}body.chord-arpeggio .phrase-card-thumb .thumb-type{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#1b2a4acc;letter-spacing:.12px;padding:7px 12px;border-radius:999px;background:#ffffffe6;border:1px solid rgba(167,196,249,.78)}body.chord-arpeggio .phrase-card-info{padding:10px 10px 38px;display:grid;align-content:start;gap:4px;flex:1;min-height:0}body.chord-arpeggio .phrase-card-title{font-size:16px;font-weight:800;line-height:1.12;width:100%;text-align:left;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.1em}body.chord-arpeggio .phrase-card-meta{font-size:12px;font-weight:500;line-height:1.2;color:#475569c7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}body.chord-arpeggio .phrase-card-tags{display:flex;align-items:center;gap:8px;flex-wrap:wrap}body.chord-arpeggio .phrase-tag-chip{border:1px solid rgba(188,211,252,.96);background:#f5f9ff;color:#274c93;border-radius:999px;font-size:10px;font-weight:600;line-height:1;padding:4px 8px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease}body.chord-arpeggio .phrase-tag-chip:hover{background:#e8f1ff;border-color:#9fc1fc}body.chord-arpeggio .phrase-card-desc{margin-top:auto;font-size:12px;color:#475569e6;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}body.chord-arpeggio .phrase-card-delete{position:absolute;right:8px;bottom:8px;width:26px;height:26px;border:none;border-radius:999px;background:#ef4444;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 10px #ef444459;font-size:13px;line-height:1}body.chord-arpeggio .phrase-card-delete:hover{background:#dc2626}body.chord-arpeggio .phrase-card-delete:focus-visible{outline:2px solid rgba(239,68,68,.45);outline-offset:1px}body.chord-arpeggio .phrase-upload-card{border:1px dashed #a7c4f9;background:#f8fbff;width:100%;min-height:208px;aspect-ratio:1 / .88;cursor:pointer;align-items:center;justify-content:center;display:flex;transition:background-color .2s ease,transform .2s ease,box-shadow .2s ease}body.chord-arpeggio .phrase-upload-card:hover{background:#eef4ff;transform:translateY(-4px);box-shadow:0 12px 22px #0f172a24}body.chord-arpeggio .phrase-upload-card span{font-size:40px;font-weight:700;line-height:1;color:#2563eb}body.chord-arpeggio .phrase-empty-tip{grid-column:1 / -1;font-size:14px;color:#1b2a4abd;padding:8px 2px 2px}body.chord-arpeggio .phrase-modal{position:fixed;inset:0;z-index:2000;background:#0f172a70;display:grid;place-items:center;padding:16px}body.chord-arpeggio .phrase-modal[hidden]{display:none}body.chord-arpeggio .phrase-modal-panel{width:min(560px,100%);border:2px solid #c7dbff;border-radius:16px;background:#fff;box-shadow:0 20px 40px #0f172a38;padding:14px;display:grid;gap:12px}body.chord-arpeggio .phrase-viewer-panel{width:min(860px,100%);max-height:90vh}body.chord-arpeggio .phrase-modal-head{display:flex;align-items:center;justify-content:space-between;gap:10px}body.chord-arpeggio .phrase-modal-head h3{margin:0;font-family:Righteous,Poppins,sans-serif;font-size:18px;font-weight:400;color:#1b2a4a}body.chord-arpeggio .phrase-modal-close{border:1px solid #c7dbff;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:#f5f9ff;color:#1b2a4a;font-size:20px;padding:0;line-height:1;cursor:pointer}body.chord-arpeggio .phrase-form{display:grid;gap:10px}body.chord-arpeggio .phrase-form input[type=text],body.chord-arpeggio .phrase-form input[type=datetime-local],body.chord-arpeggio .phrase-form input[type=file],body.chord-arpeggio .phrase-form select{border:2px solid #c7dbff;border-radius:10px;height:40px;padding:8px 10px;font-size:13px;color:#1b2a4a;background:#fff}body.chord-arpeggio .phrase-form input[type=file]{height:auto;min-height:40px}body.chord-arpeggio .phrase-form-actions{display:flex;justify-content:flex-end;gap:10px}body.chord-arpeggio .btn-ghost,body.chord-arpeggio .btn-primary{border-radius:10px;border:2px solid #c7dbff;padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer}body.chord-arpeggio .btn-ghost{background:#fff;color:#1b2a4a}body.chord-arpeggio .btn-primary{background:#2563eb;border-color:#2563eb;color:#fff}body.chord-arpeggio .phrase-viewer-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;padding:8px 10px;border:1px solid #c7dbff;border-radius:10px;background:#f5f9ff;font-size:12px;color:#1b2a4ac7}body.chord-arpeggio .phrase-viewer-meta>div{display:inline-flex;align-items:baseline;gap:4px;white-space:nowrap}body.chord-arpeggio .phrase-meta-edit-btn{margin-left:auto;height:30px;padding:0 12px;border-radius:8px;font-size:12px;font-weight:700}body.chord-arpeggio .phrase-viewer-meta strong{color:#1b2a4a;font-weight:700}body.chord-arpeggio .phrase-viewer-body{overflow:auto;border:1px solid #c7dbff;border-radius:10px;background:#f5f9ff;min-height:260px;max-height:58vh;display:grid;align-content:start;justify-items:stretch;padding:10px;gap:10px}body.chord-arpeggio .phrase-viewer-image{max-width:100%;max-height:56vh;object-fit:contain;border-radius:8px}body.chord-arpeggio .phrase-viewer-audio{width:min(560px,100%)}body.chord-arpeggio .phrase-viewer-frame{width:100%;min-height:52vh;border:none;border-radius:8px;background:#fff}body.chord-arpeggio .phrase-viewer-score{width:100%;min-height:52vh;border-radius:8px;background:#fff;overflow:auto;padding-top:8px}body.chord-arpeggio .phrase-score-toolbar{display:flex;align-items:center;gap:10px}body.chord-arpeggio .phrase-viewer-tip{padding:12px;font-size:13px;color:#1b2a4ac7;line-height:1.6}body.chord-arpeggio .fretboard{border-color:#c7dbff}body.chord-arpeggio .fret-numbers .num{color:#1b2a4a80}body.chord-arpeggio button:focus-visible,body.chord-arpeggio select:focus-visible,body.chord-arpeggio input[type=range]:focus-visible{outline:3px solid rgba(37,99,235,.5);outline-offset:2px}body.chord-arpeggio .switch input:focus-visible+.slider{box-shadow:0 0 0 3px #2563eb4d}@media(max-width:900px){body.chord-arpeggio .page-hero{grid-template-columns:1fr}body.chord-arpeggio .hero-card{order:-1}body.chord-arpeggio .fixed-metronome{position:static;width:100%;transform:none!important}body.chord-arpeggio .metronome-collapse-btn{display:none}body.chord-arpeggio .page{gap:16px}body.chord-arpeggio .compact-controls{align-items:stretch}body.chord-arpeggio .training-option-row{flex-wrap:wrap;gap:10px}body.chord-arpeggio .phrase-library-demo{padding:14px}body.chord-arpeggio .phrase-library-head h2{font-size:17px}body.chord-arpeggio .phrase-library-head p{font-size:12px}body.chord-arpeggio .phrase-card{min-height:194px}body.chord-arpeggio .phrase-card-title{font-size:14px}}@media(max-width:700px){body.chord-arpeggio .btn-group button{flex:1 1 120px}body.chord-arpeggio .control-panel-grid{grid-template-columns:1fr}body.chord-arpeggio .phrase-library-filters{grid-template-columns:1fr;gap:8px}body.chord-arpeggio .phrase-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px}body.chord-arpeggio .phrase-card-thumb{height:84px}body.chord-arpeggio .phrase-card-info{padding:12px 12px 40px;gap:8px}body.chord-arpeggio .phrase-upload-card{min-height:184px}body.chord-arpeggio .circle-wheel{min-width:320px}body.chord-arpeggio .key-item.major .key-text{font-size:24px}body.chord-arpeggio .key-item.minor .key-text{font-size:15px}}@media(max-width:900px){body.chord-arpeggio .phrase-library-filters{grid-template-columns:repeat(2,minmax(0,1fr))}body.chord-arpeggio .phrase-grid{grid-template-columns:repeat(3,minmax(0,1fr))}body.chord-arpeggio .circle-layout{grid-template-columns:1fr}body.chord-arpeggio .circle-shell{min-height:auto}body.chord-arpeggio .circle-info{min-height:auto;max-height:420px}}@media(prefers-reduced-motion:reduce){body.chord-arpeggio *{animation:none!important;transition:none!important}}.note.arp-step{background:var(--note-gold);color:#320;border:2px solid #fff;box-shadow:0 0 12px #ffd700cc}.note.hit-preview{display:flex!important;background:#60a5fa;color:#fff;box-shadow:0 0 0 2px #60a5fa66}.note.arp-muted{opacity:.35}.note .degree{display:none}.note .arp-index{display:none;position:absolute;top:-10px;right:-10px;padding:1px 6px;border-radius:11px;background:#fff;color:#222;font-size:9px;font-weight:700;box-shadow:0 1px 4px #0003;z-index:2;letter-spacing:0}.note .arp-index:not(:empty){display:block}body.chord-arpeggio .phrase-external-btn{justify-self:start;min-height:44px;padding:10px 16px;border:2px solid #2563eb;border-radius:12px;background:linear-gradient(180deg,#3b82f6,#2563eb);color:#fff;font-size:14px;font-weight:700;letter-spacing:.2px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;box-shadow:0 8px 16px #2563eb33}body.chord-arpeggio .top-tab-btn[href]{text-decoration:none}body.chord-arpeggio .brand-eyebrow{display:inline-flex;align-items:center;gap:6px}body.chord-arpeggio .brand-eyebrow-logo{width:18px;height:18px;border-radius:4px;object-fit:cover}body.chord-arpeggio .phrase-external-btn:hover{transform:translateY(-1px);filter:brightness(1.02);box-shadow:0 10px 20px #2563eb40}body.chord-arpeggio .phrase-external-btn:focus-visible{outline:3px solid rgba(37,99,235,.35);outline-offset:2px}@media(max-width:700px){body.chord-arpeggio .phrase-external-btn{width:100%;justify-self:stretch}}body.chord-arpeggio .circle-ring-segment{fill:#b8bec8;opacity:1;filter:none}body.chord-arpeggio .circle-ring-segment.outer-segment.is-related,body.chord-arpeggio .circle-ring-segment.outer-segment.is-hover,body.chord-arpeggio .circle-ring-segment.outer-segment.is-active{fill:#7aa8f3;opacity:1;filter:none}body.chord-arpeggio .circle-ring-segment.inner-segment.is-related,body.chord-arpeggio .circle-ring-segment.inner-segment.is-hover,body.chord-arpeggio .circle-ring-segment.inner-segment.is-active{fill:#a8c5f7;opacity:1;filter:none}
