:root{--radius: 12px;font-family:Hiragino Sans,Hiragino Kaku Gothic ProN,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}:root,[data-theme=light]{--bg: #f1ece1;--bg-panel: #fbf8f1;--bg-panel-2: #f5f0e5;--text: #2b2722;--text-dim: #877d6d;--line: #c9bfaa;--accent: #bf6a2c;--dot: #4d7d68;--open: #b5821c;--warn: #b5482f;--chip-bg: #ece5d6;--chip-active: #bf6a2c;--panel-border: 1px solid #e3dac8;--shadow: 0 1px 2px rgba(70, 58, 38, .06), 0 8px 24px rgba(70, 58, 38, .06);--grain: .5;--grain-blend: multiply}[data-theme=dark]{--bg: #1c1714;--bg-panel: #25201c;--bg-panel-2: #2e2823;--text: #f3ece2;--text-dim: #b6a899;--line: #5a4f45;--accent: #c8702d;--dot: #4f7d6a;--open: #e0a93b;--warn: #c0563f;--chip-bg: #322b25;--chip-active: #c8702d;--panel-border: 1px solid var(--line);--shadow: none;--grain: .35;--grain-blend: overlay}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;transition:background-color .25s ease,color .25s ease}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:var(--grain);mix-blend-mode:var(--grain-blend);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.app{position:relative;z-index:1;max-width:1080px;margin:0 auto;padding:24px 18px 60px}.header-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.app-header h1{margin:0;font-size:26px;letter-spacing:.02em}.header-actions{display:flex;gap:8px}.theme-toggle{background:var(--bg-panel);border:1px solid var(--line);color:var(--text);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;box-shadow:var(--shadow);transition:border-color .12s,background-color .25s}.theme-toggle:hover{border-color:var(--accent)}.subtitle{margin:6px 0 14px;color:var(--text-dim);font-size:14px}.layout{display:grid;gap:18px}.panel{background:var(--bg-panel);border:var(--panel-border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.controls{display:grid;gap:14px}.ctl-row{display:flex;flex-wrap:wrap;gap:18px}.ctl{display:grid;gap:6px;font-size:13px;color:var(--text-dim)}.ctl>span{font-weight:600}.ctl select{background:var(--chip-bg);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:14px;min-width:150px}.root-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:5px}.chip{background:var(--chip-bg);color:var(--text);border:1px solid var(--line);border-radius:7px;padding:7px 0;cursor:pointer;font-size:13px;transition:background .12s}.chip:hover{border-color:var(--accent)}.chip.active{background:var(--chip-active);border-color:var(--chip-active);color:#fff;font-weight:700}.seg{display:inline-flex;flex-wrap:wrap;gap:5px}.seg-btn{background:var(--chip-bg);color:var(--text);border:1px solid var(--line);border-radius:7px;padding:8px 12px;cursor:pointer;font-size:13px}.seg-btn:hover{border-color:var(--accent)}.seg-btn.active{background:var(--dot);border-color:var(--dot);color:#fff;font-weight:700}.display-top{display:flex;gap:24px;flex-wrap:wrap;align-items:flex-start}.display-side{flex:1;min-width:260px;display:grid;gap:14px}.play-btn{justify-self:start;background:var(--accent);color:#fff;border:none;border-radius:999px;padding:10px 22px;font-size:15px;font-weight:700;cursor:pointer}.play-btn:disabled{opacity:.6}.play-icon{font-size:12px}.audio-note{margin:-4px 0 0;font-size:11px;color:var(--text-dim)}.voicing-info{background:var(--bg-panel-2);border:1px solid var(--line);border-radius:8px;padding:12px 14px}.vi-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.vi-symbol{font-size:22px;font-weight:800}.vi-badge{font-size:11px;padding:3px 8px;border-radius:999px;margin-left:6px}.vi-open{background:#e0a93b2e;color:var(--open);border:1px solid var(--open)}.vi-warn{background:#c0563f2e;color:var(--warn);border:1px solid var(--warn)}.vi-table{width:100%;border-collapse:collapse;font-size:13px}.vi-table th{text-align:left;color:var(--text-dim);font-weight:600;padding:4px 6px;border-bottom:1px solid var(--line)}.vi-table td{padding:5px 6px;border-bottom:1px solid rgba(90,79,69,.4)}.vi-deg{font-weight:700}.vi-table tr.is-root .vi-deg{color:var(--accent)}.vi-table tr.is-open{background:#e0a93b14}.vi-table tr.is-open .vi-deg{color:var(--open)}.vi-pluck{background:transparent;border:1px solid var(--line);color:var(--text-dim);border-radius:6px;cursor:pointer;padding:2px 8px}.vi-pluck:hover{color:var(--text);border-color:var(--accent)}.drop-explain{margin:16px 0 0;color:var(--text-dim);font-size:13px;line-height:1.6;border-left:3px solid var(--dot);padding-left:12px}.diagram-deg{font-size:13px;font-weight:700}.diagram-deg-sm{font-size:8px;font-weight:700}.diagram-x{fill:var(--text-dim);font-size:15px}.diagram-pos{fill:var(--text-dim);font-size:12px}.diagram-open-label{fill:var(--open);font-size:12px;font-weight:700}.diagram-stringname{fill:var(--text-dim);font-size:11px}.gallery-empty{color:var(--text-dim);font-size:14px;line-height:1.7}.learn-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#14100c73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:16px}.learn-card{background:var(--bg-panel);border:var(--panel-border);border-radius:16px;box-shadow:0 12px 40px #14100a4d;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:20px 22px 16px;-webkit-overflow-scrolling:touch}.learn-head{display:flex;align-items:center;justify-content:space-between}.learn-tag{font-size:12px;font-weight:700;color:var(--accent);background:var(--chip-bg);border-radius:999px;padding:4px 12px}.learn-close{background:transparent;border:none;color:var(--text-dim);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:8px}.learn-close:hover{color:var(--text);background:var(--chip-bg)}.learn-title{margin:12px 0 10px;font-size:24px;letter-spacing:.01em}.learn-body p{margin:0 0 12px;font-size:15px;line-height:1.85;color:var(--text)}.learn-demos{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin:8px 0 18px}.learn-demo{background:var(--bg-panel-2);border:1px solid var(--line);border-radius:10px;padding:10px 8px 6px;cursor:pointer;display:grid;justify-items:center;gap:2px;transition:border-color .12s,transform .12s}.learn-demo:hover{border-color:var(--accent);transform:translateY(-2px)}.learn-demo-label{font-size:12px;font-weight:700;color:var(--text-dim)}.learn-nav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:6px;border-top:1px solid var(--line);padding-top:14px}.learn-btn{background:var(--chip-bg);border:1px solid var(--line);color:var(--text);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}.learn-btn:hover:not(:disabled){border-color:var(--accent)}.learn-btn:disabled{opacity:.4;cursor:default}.learn-dots{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.learn-dot{width:8px;height:8px;border-radius:999px;border:none;background:var(--line);cursor:pointer;padding:0}.learn-dot.active{background:var(--accent);transform:scale(1.3)}.learn-count{text-align:center;font-size:12px;color:var(--text-dim);margin-top:10px}.app-footer{margin-top:28px;color:var(--text-dim);font-size:12px;text-align:center}@media (min-width: 760px){.layout{grid-template-columns:320px 1fr}.controls-panel{grid-row:span 2}}
