:root{--bg:#f6f3ec;--surface:#fffdf8;--surface-2:#edf2eb;--ink:#203634;--muted:#637572;--brand:#123f3e;--brand2:#1a5752;--gold:#b58d4e;--line:#ddd8cd;--line-strong:#cfc8bb;--shadow:0 10px 28px rgba(18,47,45,.07);--radius:20px;--font-size:17px;--reading:760px}
:root[data-theme="dark"]{--bg:#121918;--surface:#1b2423;--surface-2:#202e2c;--ink:#edf1ec;--muted:#b6c4c0;--brand:#194b48;--brand2:#28655e;--gold:#d0a767;--line:#32403d;--line-strong:#42514e;--shadow:none}
*{box-sizing:border-box}html{font-size:var(--font-size);scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink);font-family:"Noto Sans JP","Hiragino Sans","Yu Gothic",system-ui,-apple-system,sans-serif;line-height:1.85}a{color:var(--brand2);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit;color:inherit}.skip-link{position:absolute;left:-9999px;top:0}.skip-link:focus{left:1rem;top:1rem;background:var(--surface);padding:.6rem;z-index:99}.site-header{height:86px;position:sticky;top:0;z-index:20;background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 max(calc((100% - 1260px)/2),24px);gap:18px}.site-header:before{content:"";position:absolute;top:0;left:0;right:0;height:7px;background:var(--brand)}.brand{display:flex;align-items:center;gap:14px;color:var(--ink);text-decoration:none;margin-right:auto;padding-top:6px}.brand:hover{text-decoration:none}.brand-mark{background:var(--brand);color:#fff;width:58px;height:58px;border-radius:16px;display:grid;place-items:center;font-family:serif;font-size:2rem}.brand-text small{display:block;font-size:.58rem;letter-spacing:.2em;color:var(--gold);font-weight:700;line-height:1.2}.brand-text strong{display:block;font-family:"Noto Serif JP","Hiragino Mincho ProN",serif;font-size:1.2rem;letter-spacing:.02em}.brand-text em{font:normal 700 .75em/1 sans-serif;color:var(--muted);margin-left:.25rem}.menu-btn{display:none;border:1px solid var(--line);border-radius:12px;background:var(--surface);padding:.6rem .85rem}.nav{display:flex;align-items:center;gap:2px;padding-top:6px}.nav a{color:var(--ink);font-size:.87rem;padding:.45rem .6rem;border-radius:10px}.nav a.active,.nav a:hover{background:var(--surface-2);text-decoration:none}.app{max-width:1260px;margin:0 auto;padding:32px 26px 80px;min-height:calc(100vh - 180px)}.loading{padding:4rem;text-align:center;color:var(--muted)}.site-footer{border-top:1px solid var(--line);padding:28px 24px 36px;text-align:center;color:var(--muted);font-size:.84rem}.site-footer p{margin:.2rem 0}.hero{background:linear-gradient(135deg,var(--surface),var(--surface-2));border:1px solid var(--line);border-radius:26px;padding:44px 44px 40px;box-shadow:var(--shadow);margin-bottom:28px}.eyebrow{letter-spacing:.2em;color:var(--gold);font-size:.78rem;font-weight:800;margin-bottom:12px}.hero h1{font-family:"Noto Serif JP","Hiragino Mincho ProN",serif;font-size:clamp(2rem,3.4vw,3.1rem);line-height:1.55;margin:.15rem 0 .8rem;font-weight:700}.hero p{max-width:820px;color:var(--muted);font-size:1.05rem;margin:0 0 1.6rem}.actions{display:flex;gap:12px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;background:var(--brand);border:1px solid var(--brand);color:#fff;padding:.72rem 1.22rem;border-radius:14px;font-weight:700;cursor:pointer;text-decoration:none;line-height:1.45}.btn:hover{background:var(--brand2);text-decoration:none}.btn.secondary{background:transparent;color:var(--brand);border-color:var(--brand)}.btn.quiet{background:var(--surface);color:var(--ink);border-color:var(--line)}.btn.small{padding:.38rem .72rem;font-size:.86rem}.mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:22px 0 36px}.mode-card,.card,.route,.level-panel,.case-card,.quiz-card,.search-panel,.notice,.diagram,.summary-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.mode-card{padding:24px 23px;display:block;color:var(--ink)}.mode-card:hover,.card:hover{text-decoration:none;border-color:var(--gold);transform:translateY(-1px)}.mode-card strong{display:block;font-family:"Noto Serif JP",serif;font-size:1.3rem;margin:.35rem 0}.mode-card p{margin:0;color:var(--muted);font-size:.92rem}.icon-tag{display:inline-flex;color:var(--gold);font-size:.75rem;letter-spacing:.16em;font-weight:800}.notice{padding:18px 22px;border-left:5px solid var(--gold);margin:22px 0;color:var(--muted)}.notice strong{color:var(--ink)}.stats{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0 32px}.stat{flex:1;min-width:130px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:16px;text-align:center}.stat strong{display:block;color:var(--brand2);font-size:1.72rem;line-height:1.3}.stat span{font-size:.86rem;color:var(--muted)}.page-title{font-family:"Noto Serif JP",serif;font-size:clamp(1.55rem,2.4vw,2.15rem);line-height:1.55;margin:0 0 .35rem}.lead{color:var(--muted);margin:.3rem 0 1.4rem}.section-head{display:flex;align-items:end;justify-content:space-between;gap:12px;margin:40px 0 16px}.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.card{display:block;padding:20px;color:var(--ink)}.card h3{font-size:1.04rem;margin:.4rem 0 .45rem;line-height:1.6}.card p{font-size:.88rem;color:var(--muted);margin:0}.pill{display:inline-block;font-size:.68rem;letter-spacing:.08em;font-weight:800;color:var(--brand2);background:var(--surface-2);padding:.2rem .45rem;border-radius:20px}.level-panel{padding:24px;margin-bottom:18px}.level-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:14px}.level-head h2{margin:0;font-family:"Noto Serif JP",serif;font-size:1.42rem}.level-head p{margin:.25rem 0 0;color:var(--muted)}.progress{font-size:.85rem;color:var(--muted);white-space:nowrap}.progress-bar{height:8px;background:var(--surface-2);border-radius:99px;margin:14px 0 18px;overflow:hidden}.progress-bar span{height:100%;background:var(--gold);display:block;border-radius:99px}.lesson-list{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}.lesson-link{display:flex;gap:10px;align-items:flex-start;padding:12px;background:var(--bg);border-radius:12px;border:1px solid transparent;color:var(--ink)}.lesson-link:hover{text-decoration:none;border-color:var(--line-strong)}.lesson-no{font-weight:800;color:var(--gold);font-size:.82rem;min-width:42px}.lesson-link strong{display:block;font-size:.96rem;line-height:1.55}.lesson-link small{display:block;color:var(--muted)}.reader{display:grid;grid-template-columns:minmax(0,var(--reading)) 310px;gap:26px;align-items:start}.article,.side-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}.breadcrumb{font-size:.82rem;color:var(--muted);margin-bottom:12px}.article h1{font-family:"Noto Serif JP",serif;font-size:clamp(1.55rem,3vw,2.2rem);line-height:1.55;margin:.2rem 0 .65rem}.lesson-goal{background:var(--surface-2);border-radius:14px;padding:15px 17px;color:var(--ink);margin:18px 0 28px}.lesson-goal strong{color:var(--brand2)}.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin:18px 0 26px}.prose{font-size:1rem}.prose h2{font-family:"Noto Serif JP",serif;font-size:1.32rem;margin:2.4rem 0 .8rem;border-left:4px solid var(--gold);padding-left:.75rem;line-height:1.55}.prose p{margin:0 0 1.35rem}.prose .example{background:var(--surface-2);border-radius:15px;padding:18px;margin:2rem 0}.prose .example h2{border:0;padding:0;margin:0 0 .7rem;font-size:1.1rem;color:var(--brand2)}.keypoints{padding:16px 20px;background:var(--surface-2);border-radius:14px;margin:1.8rem 0}.keypoints h3,.checks h3{font-size:1.05rem;margin:0 0 .6rem}.keypoints ul,.checks ol{margin:.2rem 0;padding-left:1.45rem}.checks{border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin:1.8rem 0}.source-links{margin:1.8rem 0;border-top:1px solid var(--line);padding-top:1.2rem}.source-links a{display:inline-block;border:1px solid var(--line);padding:.35rem .6rem;border-radius:10px;margin:.25rem .25rem .25rem 0;font-size:.88rem}.article-nav{display:flex;justify-content:space-between;gap:10px;border-top:1px solid var(--line);padding-top:22px;margin-top:32px}.side-panel{position:sticky;top:108px;padding:20px;font-size:.9rem}.side-panel h3{font-size:1rem;margin:0 0 .7rem}.side-panel section+section{border-top:1px solid var(--line);margin-top:18px;padding-top:18px}.memo{width:100%;height:128px;resize:vertical;border:1px solid var(--line);border-radius:12px;background:var(--bg);padding:10px;line-height:1.7}.check-complete{display:flex;gap:8px;align-items:center;padding:.7rem 0;font-weight:700}.search-panel{padding:22px;margin:0 0 22px}.search-box{display:flex;gap:10px}.search-box input{flex:1;border:1px solid var(--line-strong);background:var(--surface);border-radius:13px;padding:.7rem 1rem;min-width:0}.filters{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:14px}.filters select{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:.45rem .7rem}.search-help{font-size:.84rem;color:var(--muted);margin:12px 0 0}.search-help code{background:var(--surface-2);padding:.15rem .3rem;border-radius:5px}.result-group{margin:30px 0}.result-group h2{font-family:"Noto Serif JP",serif;margin:0 0 14px;font-size:1.4rem}.result{background:var(--surface);border:1px solid var(--line);border-radius:15px;padding:16px 18px;margin:9px 0}.result h3{font-size:1.02rem;margin:0 0 .35rem;line-height:1.6}.result p{font-size:.89rem;color:var(--muted);margin:.3rem 0}.result-meta{font-size:.76rem;color:var(--gold);font-weight:800;letter-spacing:.08em}.result mark{background:#f1df9e;color:#1f3331;border-radius:2px;padding:0 .08em}.empty{background:var(--surface);border:1px dashed var(--line-strong);border-radius:15px;padding:26px;color:var(--muted);text-align:center}.toc-part{background:var(--surface);border:1px solid var(--line);border-radius:15px;margin:10px 0;overflow:hidden}.toc-part summary{font-weight:700;padding:15px 18px;cursor:pointer;list-style:none}.toc-part summary::-webkit-details-marker{display:none}.toc-part summary small{color:var(--muted);font-weight:400}.toc-list{border-top:1px solid var(--line);padding:8px 14px}.toc-item{display:flex;gap:10px;border-bottom:1px dashed var(--line);padding:9px 4px;line-height:1.55}.toc-item:last-child{border-bottom:0}.toc-item small{min-width:38px;font-size:.72rem;color:var(--muted)}.doc-title{font-weight:700;color:var(--brand2)}.source-code{background:var(--surface-2);padding:12px;white-space:pre-wrap;border-radius:10px}.data-table{overflow:auto;margin:1rem 0}.data-table table{border-collapse:collapse;min-width:100%;font-size:.92rem}.data-table td{border:1px solid var(--line);padding:.5rem .6rem;vertical-align:top}.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.case-card{padding:20px;color:var(--ink)}.case-card h3{margin:.35rem 0;font-size:1.08rem}.case-card p{color:var(--muted);font-size:.9rem;margin:0}.case-analysis{display:grid;gap:10px;margin:24px 0}.case-row{border:1px solid var(--line);border-radius:13px;padding:12px 14px}.case-row strong{display:block;color:var(--brand2);font-size:.88rem}.quiz-start{max-width:700px}.quiz-controls{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}.quiz-card{padding:24px;max-width:760px}.quiz-card h2{font-size:1.2rem;line-height:1.7}.choice{display:block;width:100%;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:13px 14px;margin:8px 0;cursor:pointer}.choice:hover{border-color:var(--gold)}.choice.correct{background:#e8f3ea;border-color:#67a278}.choice.wrong{background:#f8e4df;border-color:#c47a68}.quiz-explain{background:var(--surface-2);border-radius:12px;padding:14px;margin:18px 0}.diagram{padding:24px;margin:16px 0}.flow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:15px 0}.node{background:var(--surface-2);border:1px solid var(--line);padding:.55rem .85rem;border-radius:12px;font-weight:700}.arrow{color:var(--gold);font-weight:800}.four-map,.tier-map{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin:16px 0}.four-map div,.tier-map div{background:var(--surface-2);border-radius:12px;padding:13px}.four-map strong,.tier-map strong{display:block;color:var(--brand2)}.four-map small,.tier-map small{display:block;color:var(--muted)}.settings-row{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}.file-label input{display:none}.saved-list{margin-top:15px}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%,16px);background:var(--ink);color:var(--bg);padding:.65rem 1rem;border-radius:12px;opacity:0;pointer-events:none;transition:.2s;z-index:50}.toast.show{opacity:1;transform:translate(-50%,0)}
@media(max-width:1000px){.nav{display:none;position:absolute;top:86px;left:14px;right:14px;background:var(--surface);border:1px solid var(--line);border-radius:15px;padding:10px;box-shadow:var(--shadow);flex-wrap:wrap}.nav.open{display:flex}.menu-btn{display:block;margin-top:6px}.mode-grid,.card-grid{grid-template-columns:repeat(2,1fr)}.reader{grid-template-columns:1fr}.side-panel{position:static}.article{padding:26px}}
@media(max-width:680px){.site-header{height:80px;padding:0 18px}.brand-mark{width:50px;height:50px;font-size:1.7rem}.brand-text small{display:none}.brand-text strong{font-size:1.02rem}.app{padding:22px 16px 60px}.hero{padding:27px 22px}.hero p{font-size:.98rem}.mode-grid,.card-grid,.case-grid,.lesson-list,.four-map,.tier-map{grid-template-columns:1fr}.level-panel{padding:18px}.article{padding:20px 18px}.side-panel{padding:18px}.search-box{flex-direction:column}.article-nav{flex-direction:column}.stats{gap:8px}.stat{min-width:calc(50% - 4px)}}
