:root{--bg: #fbfbfe;--bg-soft: #f2f3f9;--surface: #ffffff;--surface-2: #f4f5fb;--border: #e2e4ef;--text: #1b1d33;--text-muted: #5f6382;--accent: #d97706;--accent-strong: #b45309;--accent-ink: #ffffff;--tonic: #059669;--dominant: #db2777;--subdominant: #2563eb;--ok: #16a34a;--ng: #e11d48;--radius: 14px;--radius-sm: 9px;--shadow: 0 10px 30px rgba(27, 29, 51, .08);--maxw: 860px;--font-sans: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans JP", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(1200px 600px at 50% -10%,rgba(217,119,6,.06),transparent),var(--bg);color:var(--text);font-family:var(--font-sans);line-height:1.8;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}.site-header{border-bottom:1px solid var(--border);background:#fffc;backdrop-filter:blur(8px);position:sticky;top:0;z-index:20}.site-header .inner{display:flex;align-items:center;justify-content:space-between;height:60px}.brand{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--text);letter-spacing:.02em}.brand:hover{text-decoration:none}.brand .logo{width:30px;height:30px}.nav-link{color:var(--text-muted);font-size:.92rem}.hero{padding:56px 0 32px;text-align:center}.hero h1{font-size:clamp(1.8rem,4vw,2.7rem);margin:0 0 12px;line-height:1.3}.hero p{color:var(--text-muted);max-width:620px;margin:0 auto}.hero .accent{color:var(--accent)}.chapter{margin:36px 0}.chapter-head{display:flex;align-items:baseline;gap:12px;margin-bottom:14px}.chapter-num{font-size:.8rem;font-weight:800;color:var(--accent);background:#ffb3471f;border:1px solid rgba(255,179,71,.3);padding:3px 10px;border-radius:999px;white-space:nowrap}.chapter-head h2{margin:0;font-size:1.35rem}.lesson-grid{display:grid;gap:12px}.lesson-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;color:var(--text);transition:transform .15s ease,border-color .15s ease,background .15s ease}.lesson-card:hover{text-decoration:none;transform:translateY(-2px);border-color:var(--accent);background:var(--surface-2)}.lesson-card .idx{font-variant-numeric:tabular-nums;font-weight:800;color:var(--text-muted);min-width:2.4em}.lesson-card .body{flex:1}.lesson-card .body .t{font-weight:700}.lesson-card .body .s{color:var(--text-muted);font-size:.86rem}.lesson-card .check{color:var(--ok);font-size:1.1rem;opacity:0}.lesson-card.done .check{opacity:1}.lesson-card .arrow{color:var(--text-muted)}.level-badge{font-size:.72rem;padding:2px 8px;border-radius:999px;border:1px solid var(--border);color:var(--text-muted);white-space:nowrap}.level-入門{color:var(--tonic);border-color:#05966966}.level-基礎{color:var(--subdominant);border-color:#2563eb66}.level-応用{color:var(--dominant);border-color:#db277766}.progress-wrap{max-width:420px;margin:22px auto 0}.progress-track{height:10px;background:var(--surface);border:1px solid var(--border);border-radius:999px;overflow:hidden}.progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--accent),var(--accent-strong));transition:width .4s ease}.progress-label{text-align:center;color:var(--text-muted);font-size:.85rem;margin-top:8px}.lesson-header{padding:28px 0 8px}.crumb{font-size:.85rem;color:var(--text-muted)}.lesson-header h1{font-size:clamp(1.5rem,3.5vw,2.1rem);margin:8px 0 6px}.lesson-header .summary{color:var(--text-muted);margin:0}.prose{font-size:1.02rem}.prose h2{font-size:1.3rem;margin:2em 0 .6em;padding-bottom:.3em;border-bottom:1px solid var(--border)}.prose h3{font-size:1.08rem;margin:1.6em 0 .5em;color:var(--accent)}.prose p{margin:1em 0}.prose ul,.prose ol{padding-left:1.4em}.prose li{margin:.4em 0}.prose strong{color:var(--text)}.prose code{background:var(--bg-soft);border:1px solid var(--border);padding:.1em .4em;border-radius:6px;font-size:.9em}.prose blockquote{margin:1.2em 0;padding:.6em 1em;border-left:3px solid var(--accent);background:var(--bg-soft);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-muted)}.prose table{width:100%;border-collapse:collapse;margin:1.2em 0;font-size:.94rem}.prose th,.prose td{border:1px solid var(--border);padding:8px 12px;text-align:center}.prose th{background:var(--surface)}.f-t{color:var(--tonic);font-weight:700}.f-d{color:var(--dominant);font-weight:700}.f-s{color:var(--subdominant);font-weight:700}.examples{margin:26px 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px}.examples h3{margin:0 0 4px;font-size:1rem;display:flex;align-items:center;gap:8px}.examples .hint{color:var(--text-muted);font-size:.84rem;margin:0 0 14px}.chord-row{display:flex;flex-wrap:wrap;gap:10px}.chord-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:8px 8px 8px 14px;color:var(--text);cursor:pointer;font:inherit;transition:border-color .15s ease,transform .1s ease}.chord-chip:hover{border-color:var(--accent)}.chord-chip:active{transform:scale(.97)}.chord-chip .play{width:26px;height:26px;display:grid;place-items:center;border-radius:50%;background:var(--accent);color:var(--accent-ink);font-size:.8rem}.chord-chip .cap{font-weight:600}.chord-chip .note-tip{font-size:.74rem;color:var(--text-muted);padding-left:2px;padding-right:6px}.chord-chip.playing .play{background:var(--accent-strong);box-shadow:0 0 0 4px #ffb34740}.quiz{margin:34px 0;background:linear-gradient(180deg,var(--surface),var(--bg-soft));border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}.quiz-title{display:flex;align-items:center;gap:10px;margin:0 0 4px;font-size:1.15rem}.quiz-title .badge{font-size:.72rem;color:var(--accent-ink);background:var(--accent);padding:2px 9px;border-radius:999px;font-weight:800}.quiz-sub{color:var(--text-muted);font-size:.86rem;margin:0 0 16px}.q-item{border-top:1px solid var(--border);padding:16px 0}.q-item:first-of-type{border-top:none;padding-top:4px}.q-text{font-weight:700;margin:0 0 12px}.q-text .qn{color:var(--accent);margin-right:6px}.choices{display:grid;gap:8px}.choice{text-align:left;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:11px 14px;cursor:pointer;font:inherit;display:flex;gap:10px;align-items:center;transition:border-color .12s ease,background .12s ease}.choice:hover:not(:disabled){border-color:var(--accent)}.choice .mark{width:22px;height:22px;border-radius:50%;border:1px solid var(--border);display:grid;place-items:center;font-size:.75rem;flex-shrink:0}.choice.correct{border-color:var(--ok);background:#4ade801f}.choice.correct .mark{background:var(--ok);border-color:var(--ok);color:#06280f}.choice.wrong{border-color:var(--ng);background:#fb71851f}.choice.wrong .mark{background:var(--ng);border-color:var(--ng);color:#2b0510}.choice:disabled{cursor:default}.explain{margin-top:10px;padding:10px 14px;background:var(--bg-soft);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:.92rem;color:var(--text-muted);display:none}.explain.show{display:block}.explain b{color:var(--text)}.quiz-result{margin-top:16px;padding:12px 16px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);text-align:center;font-weight:700;display:none}.quiz-result.show{display:block}.lesson-nav{display:flex;justify-content:space-between;gap:12px;margin:40px 0 60px}.lesson-nav a{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;color:var(--text);transition:border-color .15s ease}.lesson-nav a:hover{text-decoration:none;border-color:var(--accent)}.lesson-nav a.next{text-align:right}.lesson-nav .dir{font-size:.78rem;color:var(--text-muted)}.lesson-nav .ttl{font-weight:700}.lesson-nav .spacer{flex:1}.site-footer{border-top:1px solid var(--border);padding:26px 0;color:var(--text-muted);font-size:.85rem;text-align:center}@media(max-width:560px){.lesson-nav{flex-direction:column}.hero{padding:40px 0 20px}}
