:root{color:#1f2933;background:#f5f7f9;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans TC,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--ink: #1f2933;--muted: #697586;--line: #d9e2ec;--panel: #ffffff;--surface: #eef3f7;--root: #ef6f61;--third: #3b82c4;--fifth: #1f9d8a;--seventh: #8a6fcb;--scale: #7b8794;--shadow-sm: 0 1px 2px rgba(31, 41, 51, .05);--shadow-md: 0 12px 34px rgba(31, 41, 51, .08)}*{box-sizing:border-box}body{margin:0;min-width:1120px;background:linear-gradient(180deg,#f8fafc,#eef3f7)}button,select,input{font:inherit}button,select{cursor:pointer}.app-shell{min-height:100vh;padding:22px clamp(20px,2vw,34px) 34px}.hero{display:flex;justify-content:space-between;gap:24px;align-items:center;margin:0 auto 14px;max-width:1680px;padding:0 2px}.hero h1{margin:3px 0 5px;font-size:30px;line-height:1.1;letter-spacing:0}.intro{max-width:820px;margin:0;color:var(--muted);font-size:14px;line-height:1.55}.eyebrow{margin:0;color:#52616f;font-size:12px;font-weight:800;letter-spacing:0;text-transform:uppercase}.status-panel{min-width:196px;border:1px solid var(--line);background:#ffffffe0;border-radius:8px;padding:12px 14px;box-shadow:var(--shadow-sm)}.status-panel span,.status-panel strong{display:block}.status-panel span{color:var(--muted);font-size:12px}.status-panel strong{margin-top:4px;color:var(--ink);font-size:19px;letter-spacing:.04em}.control-bar{display:grid;grid-template-columns:120px minmax(260px,.9fr) minmax(430px,1.25fr) minmax(380px,1.1fr);gap:10px;max-width:1680px;margin:0 auto 16px;border:1px solid var(--line);background:#ffffffeb;border-radius:8px;padding:10px;box-shadow:var(--shadow-md);position:sticky;top:10px;z-index:5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.control-bar label,.control-group{display:grid;gap:6px}.control-bar span,.control-group>span{color:var(--muted);font-size:12px;font-weight:800}select,input{width:100%;min-height:38px;border:1px solid #cbd5df;border-radius:7px;background:#fff;color:var(--ink);padding:0 12px}.segmented-control{display:grid;gap:5px;border:1px solid #cbd5df;border-radius:7px;background:#f8fafc;padding:4px;min-height:38px}.shape-control{grid-template-columns:repeat(5,minmax(0,1fr))}.chord-control{grid-template-columns:repeat(6,minmax(0,1fr))}.display-control{grid-template-columns:repeat(4,minmax(0,1fr))}.segmented-control button{min-height:29px;border:0;border-radius:5px;background:transparent;color:#52616f;font-size:13px;font-weight:850}.segmented-control button:hover{background:#eef3f7}.segmented-control button.is-selected{background:var(--ink);color:#fff;box-shadow:0 5px 14px #1f29332e}.workspace{display:grid;grid-template-columns:minmax(1040px,1fr) 360px;gap:16px;max-width:1680px;margin:0 auto;align-items:start}.fretboards{display:grid;gap:12px}.section-title{display:flex;align-items:end;justify-content:space-between;gap:16px;padding:3px 4px 0}.section-title h2,.panel-heading h2{margin:2px 0 0;font-size:20px;letter-spacing:0}.active-source{margin:4px 0 0;color:var(--root);font-size:13px;font-weight:850}.legend{display:flex;flex-wrap:wrap;gap:8px;color:var(--muted);font-size:12px}.legend-item{display:inline-flex;gap:6px;align-items:center;border:1px solid rgba(217,226,236,.9);border-radius:999px;background:#ffffffbd;padding:5px 8px}.dot{width:11px;height:11px;border-radius:999px;display:inline-block}.dot.root{background:var(--root)}.dot.third{background:var(--third)}.dot.fifth{background:var(--fifth)}.dot.seventh{background:var(--seventh)}.dot.scale{border:2px solid var(--scale)}.fretboard-card,.panel{border:1px solid var(--line);background:var(--panel);border-radius:8px;box-shadow:var(--shadow-sm)}.fretboard-card{overflow:hidden;box-shadow:var(--shadow-md)}.fretboard-heading{display:flex;justify-content:space-between;align-items:center;padding:11px 15px;border-bottom:1px solid var(--line);background:#fbfcfd}.fretboard-heading span{color:var(--muted);font-size:13px}.fretboard{display:grid;min-width:1040px;background:linear-gradient(90deg,rgba(31,41,51,.035) 1px,transparent 1px),linear-gradient(#fff,#f2f6fa)}.corner-cell,.fret-number,.string-label{min-height:34px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:12px;font-weight:800;border-bottom:1px solid rgba(217,226,236,.75)}.corner-cell,.string-label{background:#f6f9fc;border-right:1px solid var(--line)}.fret-number{background:#f6f9fc}.fret-number.in-shape-fret{color:#344054;background:#eaf6f7}.fret-cell{position:relative;min-height:64px;border-left:1px solid rgba(105,117,134,.22);display:flex;align-items:center;justify-content:center}.fret-cell.in-shape-cell{background:#1f9d8a12}.fret-cell:nth-child(8n){border-right:1px solid rgba(105,117,134,.16)}.string-line{position:absolute;left:0;right:0;top:50%;height:2px;background:#52616f57;transform:translateY(-50%)}.tone{position:relative;z-index:1;width:38px;height:38px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:850;letter-spacing:0;box-shadow:0 6px 15px #1f293326;transition:transform .16s ease,opacity .16s ease}.tone small{display:block;margin-left:2px;font-size:10px;opacity:.88}.tone-root{width:44px;height:44px;background:var(--root);font-size:14px}.tone-third{background:var(--third)}.tone-fifth{background:var(--fifth)}.tone-seventh{background:var(--seventh)}.tone-scale{width:22px;height:22px;border:1px solid rgba(123,135,148,.62);background:#ffffffc7;color:#52616fc7;box-shadow:none;font-size:9px;font-weight:800}.tone-ghost{width:8px;height:8px;background:#7b879433;color:transparent;box-shadow:none}.tone.is-muted:not(.tone-ghost){opacity:.18}.tone.out-of-shape-tone{width:8px;height:8px;border:0;background:#7b879429;color:transparent;box-shadow:none;opacity:1}.tone.out-of-shape-tone small{display:none}.tone.shape-only{color:transparent}.tone.shape-only small{display:none}.tone:hover{transform:translateY(-1px) scale(1.04)}.tone.practice-target-tone{outline:4px solid rgba(31,41,51,.26);outline-offset:3px;transform:scale(1.08)}.tone.connection-target-tone{outline:3px solid rgba(239,111,97,.34);outline-offset:3px;transform:scale(1.08)}.tone.practice-hidden-tone:not(.practice-target-tone):not(.connection-target-tone){width:8px;height:8px;border:0;background:#7b879424;color:transparent;box-shadow:none}.tone.practice-hidden-tone:not(.practice-target-tone):not(.connection-target-tone) small{display:none}.side-panel{display:grid;gap:10px;position:sticky;top:92px;max-height:calc(100vh - 110px);overflow:auto;padding-right:2px;scrollbar-width:thin}.panel{padding:14px}.panel-heading{margin-bottom:10px}.panel-heading h2{font-size:18px}.overlay-list{display:grid;gap:7px}.practice-mode-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin-bottom:9px}.practice-mode-tabs button{min-height:36px;border:1px solid var(--line);border-radius:7px;background:#fbfcfd;color:#52616f;font-size:13px;font-weight:850}.practice-mode-tabs button.is-selected{border-color:var(--ink);background:var(--ink);color:#fff;box-shadow:0 6px 14px #1f293326}.practice-status{display:grid;min-height:86px;align-content:center;gap:6px;border:1px solid var(--line);border-radius:7px;background:#f8fbfd;padding:14px}.practice-status strong{color:var(--ink);font-size:30px;line-height:1}.practice-status strong small{font-size:18px;color:var(--muted)}.practice-status span{color:var(--muted);font-size:12px;line-height:1.45}.practice-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;margin-top:9px}.practice-actions.connection-actions{grid-template-columns:repeat(4,minmax(0,1fr))}.practice-actions button{min-height:34px;border:1px solid var(--line);border-radius:7px;background:#fff;color:var(--ink);font-size:11px;font-weight:850}.practice-actions button:first-child{border-color:var(--ink);background:var(--ink);color:#fff}.practice-actions button:hover:not(:disabled),.practice-mode-tabs button:hover,.fifths-row button:hover,.check-row:hover{border-color:#b8c4d1;background:#f4f8fb}.practice-actions button:first-child:hover{background:#2b3642}.practice-mode-tabs button.is-selected:hover{border-color:var(--ink);background:var(--ink)}.fifths-row button.is-current:hover{border-color:var(--root);background:var(--root)}.practice-actions button:disabled{cursor:not-allowed;opacity:.42}.check-row{display:flex;align-items:center;gap:10px;min-height:38px;padding:0 9px;border:1px solid var(--line);border-radius:7px;background:#fbfcfd;color:var(--ink)}.check-row span{display:grid;gap:2px}.check-row small{color:var(--muted);font-size:10px}.check-row input{width:17px;height:17px;accent-color:var(--root)}.active-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}.active-tags span{border:1px solid #ccd6e0;border-radius:999px;padding:5px 9px;color:#344054;background:var(--surface);font-size:11px;font-weight:800}.active-tags .empty-tag{color:var(--muted);font-weight:700}.fifths-row{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.fifths-row button{min-height:36px;border:1px solid var(--line);border-radius:7px;background:#fbfcfd;color:#344054;font-size:13px;font-weight:850}.fifths-row button.is-current{border-color:var(--root);background:var(--root);color:#fff;box-shadow:0 6px 14px #ef6f6133}.key-facts{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0 0}.key-facts div{border:1px solid var(--line);border-radius:7px;padding:9px;background:#fbfcfd}.key-facts dt{color:var(--muted);font-size:10px;font-weight:800}.key-facts dd{margin:2px 0 0;color:var(--ink);font-size:19px;font-weight:850}.diatonic-chords{margin-top:10px;border-top:1px solid var(--line);padding-top:10px}.mini-heading{margin:0 0 8px;color:var(--muted);font-size:11px;font-weight:850}.diatonic-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.diatonic-item{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:32px;border:1px solid var(--line);border-radius:7px;background:#fbfcfd;padding:6px 8px}.diatonic-item span{color:var(--muted);font-size:10px;font-weight:850}.diatonic-item strong{color:var(--ink);font-size:13px;font-weight:850}.practice-panel p{margin:0;color:var(--muted);font-size:13px;line-height:1.65}@media(min-width:1520px){.app-shell{padding-top:24px}.workspace{grid-template-columns:minmax(1120px,1fr) 380px}.fret-cell{min-height:68px}}@media(max-width:1320px){.control-bar{grid-template-columns:110px minmax(230px,1fr) minmax(380px,1.25fr)}.control-group:last-child{grid-column:1 / -1}.workspace{grid-template-columns:minmax(880px,1fr) 340px}}@media(max-width:1180px){body{min-width:0}.app-shell{padding:20px}.hero,.workspace{display:grid;grid-template-columns:1fr}.control-bar{grid-template-columns:1fr;position:static}.fretboard-card{overflow-x:auto}.side-panel{grid-template-columns:repeat(2,minmax(0,1fr));position:static;max-height:none;overflow:visible}.practice-panel{grid-column:1 / -1}}
