*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0}:root{--bg: #f3efe5;--bg-soft: #ebe5d6;--bg-elevated: #fbf8f0;--text: #2a2018;--text-soft: #6b5d4f;--text-faint: #94887a;--accent: #b85c4a;--accent-soft: #d18b75;--logo-bg: #1d2a3d;--logo-fg: #f3efe5;--border: #d8cdb8;--border-soft: #e8e0cf;--code-bg: #e6dfc9;--warn-bg: #faedca;--warn-border: #b89a4f;--font-serif: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", "Noto Serif JP", "MS Mincho", serif;--font-sans: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", "Meiryo", system-ui, -apple-system, sans-serif;--font-mono: "SF Mono", "Menlo", "Consolas", "Roboto Mono", monospace;--maxw-content: 720px;--maxw-wide: 1200px;--header-h: 64px;--bottom-nav-h: 64px;--font-size-base: 16px;--font-size-scale: 1}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--bg: #1a1814;--bg-soft: #25221c;--bg-elevated: #2f2b24;--text: #ece5d8;--text-soft: #b0a594;--text-faint: #7a7062;--accent: #e07d65;--accent-soft: #b85c4a;--logo-bg: #0e1421;--logo-fg: #ece5d8;--border: #3d362c;--border-soft: #2d2820;--code-bg: #2a2620;--warn-bg: #3a3120;--warn-border: #8a6f30}}:root[data-theme=dark]{--bg: #1a1814;--bg-soft: #25221c;--bg-elevated: #2f2b24;--text: #ece5d8;--text-soft: #b0a594;--text-faint: #7a7062;--accent: #e07d65;--accent-soft: #b85c4a;--logo-bg: #0e1421;--logo-fg: #ece5d8;--border: #3d362c;--border-soft: #2d2820;--code-bg: #2a2620;--warn-bg: #3a3120;--warn-border: #8a6f30}:root[data-contrast=high]{--bg: #ffffff;--bg-soft: #f5f5f5;--bg-elevated: #ffffff;--text: #000000;--text-soft: #1a1a1a;--accent: #a83a25;--logo-bg: #000000;--logo-fg: #ffffff;--border: #000000}:root[data-theme=dark][data-contrast=high]{--bg: #000000;--bg-soft: #0a0a0a;--bg-elevated: #1a1a1a;--text: #ffffff;--text-soft: #f0f0f0;--accent: #ffb380;--border: #ffffff}:root[data-ruby=off] rt{display:none}:root[data-writing=vertical] .story-body{writing-mode:vertical-rl;-webkit-writing-mode:vertical-rl;text-orientation:mixed;max-height:80vh;min-height:60vh;overflow-x:auto;overflow-y:hidden;padding:1.5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:2rem 0;line-height:1.95;letter-spacing:.02em}:root[data-writing=vertical] .story-body p{margin:0 .4em;text-indent:0}:root[data-writing=vertical] .story-body blockquote.song{margin:0 1em;padding:.5em 1em;border-left:0;border-right:3px solid var(--accent-soft);background:var(--bg-soft)}:root[data-writing=vertical] .story-body{-ms-text-combine-horizontal:digit 2;text-combine-upright:digit 2}:root[data-writing=vertical] .story-body rt{font-size:.5em}html{font-size:var(--font-size-base)}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:calc(1rem * var(--font-size-scale));line-height:1.75;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:color .15s}a:hover{color:var(--accent-soft)}a:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}h1,h2,h3,h4{font-family:var(--font-serif);font-weight:700;line-height:1.35;letter-spacing:.01em;margin:1.8em 0 .6em;color:var(--text)}h1{font-size:2rem}h2{font-size:1.4rem;border-bottom:1px solid var(--border);padding-bottom:.3em}h3{font-size:1.15rem}p{margin:1em 0}ul,ol{padding-left:1.4em}ul li,ol li{margin:.4em 0}hr{border:0;border-top:1px solid var(--border);margin:2.5em 0}code{font-family:var(--font-mono);font-size:.92em;background:var(--code-bg);padding:.1em .4em;border-radius:3px}blockquote{border-left:3px solid var(--accent-soft);margin:1.2em 0;padding:.5em 1.2em;color:var(--text-soft);background:var(--bg-soft);border-radius:0 4px 4px 0}.logo{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;color:inherit;font-family:var(--font-serif)}.logo:hover{color:inherit}.logo__mark{width:38px;height:38px;display:grid;place-items:center;background:var(--logo-bg);color:var(--logo-fg);font-family:var(--font-serif);font-size:1.4rem;font-weight:700;border-radius:4px;flex-shrink:0}.logo__text{display:flex;flex-direction:column;line-height:1}.logo__name{font-size:1.2rem;font-weight:700;letter-spacing:.04em}.logo__caption{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.18em;color:var(--text-faint);margin-top:.25rem}@media(max-width:480px){.logo__caption{display:none}}.site-header{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;backdrop-filter:blur(8px);background:color-mix(in srgb,var(--bg) 92%,transparent)}.site-header__inner{max-width:var(--maxw-wide);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1.25rem;min-height:var(--header-h)}.nav{display:flex;align-items:center;gap:.25rem}.nav__link{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem .85rem;border-radius:999px;font-size:.9rem;color:var(--text-soft);text-decoration:none;font-weight:500;transition:background .15s,color .15s}.nav__link:hover{background:var(--bg-soft);color:var(--text)}.nav__link[aria-current=page],.nav__link[aria-current=page]:hover{background:var(--logo-bg);color:var(--logo-fg)}.nav__icon{font-size:1.05em;line-height:1}.nav__label{white-space:nowrap}.header-actions{display:flex;align-items:center;gap:.5rem}.icon-btn{width:38px;height:38px;display:grid;place-items:center;background:transparent;border:1px solid var(--border);border-radius:50%;cursor:pointer;color:var(--text-soft);transition:background .15s,color .15s,border-color .15s;font-size:1.05rem}.icon-btn:hover{background:var(--bg-soft);color:var(--text);border-color:var(--text-soft)}.icon-btn[aria-pressed=true]{background:var(--logo-bg);color:var(--logo-fg);border-color:var(--logo-bg)}.nav__label{display:none}@media(min-width:1100px){.nav__label{display:inline}.nav__icon{display:none}}@media(max-width:767px){.nav{display:none}}.hamburger{display:none}@media(max-width:767px){.hamburger{display:grid}}.bottom-nav{display:none}@media(max-width:767px){.bottom-nav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;left:50%;transform:translate(-50%);bottom:max(env(safe-area-inset-bottom),.75rem);z-index:40;background:var(--bg-elevated);border:1px solid var(--border);border-radius:999px;box-shadow:0 8px 30px #0000001f;padding:.35rem;width:calc(100vw - 2rem);max-width:480px}.bottom-nav__link{display:grid;place-items:center;gap:2px;padding:.4rem .2rem;border-radius:999px;color:var(--text-soft);text-decoration:none;font-size:.65rem;line-height:1;text-align:center}.bottom-nav__link:hover{background:var(--bg-soft)}.bottom-nav__link[aria-current=page]{background:var(--logo-bg);color:var(--logo-fg)}.bottom-nav__icon{font-size:1.15rem}main{padding-bottom:calc(var(--bottom-nav-h) + 2rem)}}.mobile-menu{display:none;position:fixed;inset:var(--header-h) 0 0 0;background:var(--bg);z-index:45;padding:1.5rem 1.25rem;overflow-y:auto}.mobile-menu.is-open{display:block}.mobile-menu__list{list-style:none;padding:0;margin:0}.mobile-menu__item{margin:0;border-bottom:1px solid var(--border-soft)}.mobile-menu__link{display:flex;align-items:center;gap:.75rem;padding:.9rem .5rem;text-decoration:none;color:var(--text);font-size:1.05rem}.mobile-menu__icon{font-size:1.4rem;width:1.6em;text-align:center}.site-footer{border-top:1px solid var(--border);background:var(--bg-soft);padding:2.5rem 1.25rem;margin-top:5rem;font-size:.88rem;color:var(--text-soft)}.site-footer__inner{max-width:var(--maxw-wide);margin:0 auto}.site-footer p{margin:.4em 0}.site-footer__brand{font-family:var(--font-serif);font-weight:700;color:var(--text)}.container{max-width:var(--maxw-content);margin:0 auto;padding:2rem 1.25rem}.container--wide{max-width:var(--maxw-wide)}.hero{max-width:var(--maxw-wide);margin:0 auto;padding:3rem 1.25rem 2rem;text-align:left}.hero__eyebrow{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-soft);margin-bottom:1.5rem}.hero__eyebrow:before{content:"";display:inline-block;width:2rem;height:1px;background:var(--text-soft)}.hero__title{font-family:var(--font-serif);font-size:clamp(2rem,6vw,3.5rem);font-weight:700;line-height:1.3;margin:0 0 1.5rem;letter-spacing:.01em;color:var(--text);position:relative}.hero__title .accent{position:relative;display:inline-block}.hero__title .accent:after{content:"";position:absolute;right:-.18em;top:.4em;width:.22em;height:.22em;border-radius:50%;background:var(--accent)}.hero__lead{font-family:var(--font-serif);font-size:clamp(1rem,2.2vw,1.15rem);line-height:1.9;max-width:36em;color:var(--text);margin:0 0 2rem}.hero__ctas{display:flex;flex-wrap:wrap;gap:.75rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1.4rem;border-radius:999px;text-decoration:none;font-weight:500;font-size:.95rem;border:1px solid transparent;transition:background .15s,color .15s,border-color .15s;cursor:pointer}.btn--primary{background:var(--logo-bg);color:var(--logo-fg)}.btn--primary:hover{background:var(--accent);color:var(--logo-fg)}.btn--ghost{background:transparent;border-color:var(--border);color:var(--text)}.btn--ghost:hover{background:var(--bg-soft);border-color:var(--text-soft);color:var(--text)}.section{max-width:var(--maxw-wide);margin:0 auto;padding:2rem 1.25rem}.section__heading{display:flex;align-items:baseline;justify-content:space-between;border:0;padding:0;margin-bottom:1.25rem}.section__heading h2{border:0;margin:0;font-size:1.5rem;padding:0}.section__subtitle{color:var(--text-soft);font-size:.9rem;font-family:var(--font-mono);letter-spacing:.1em}.lesson-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin:1.5rem 0}.lesson-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:1.25rem 1.4rem;transition:transform .12s,box-shadow .12s,border-color .12s;position:relative}.lesson-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014;border-color:var(--accent-soft)}.lesson-card__link{text-decoration:none;color:inherit;display:block}.lesson-card__link:before{content:"";position:absolute;inset:0;border-radius:inherit}.lesson-card__title{font-family:var(--font-serif);font-size:1.25rem;font-weight:700;margin:0 0 .4rem;color:var(--text)}.lesson-card__meta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);margin:0 0 .6rem}.lesson-card__desc{font-size:.92rem;line-height:1.7;color:var(--text-soft);margin:0}.lesson-card__author{margin-top:.8rem;font-size:.85rem;color:var(--text-soft);font-family:var(--font-serif)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border:1px solid var(--border);border-radius:999px;font-size:.72rem;color:var(--text-soft);background:var(--bg);margin-right:.3em;font-family:var(--font-sans);font-weight:500}.badge--accent{background:var(--accent);border-color:var(--accent);color:var(--logo-fg)}.library-filters{margin:1.4rem 0 .6rem;padding:1rem 1.1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;gap:.6rem}.library-filters__group{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.library-filters__label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;color:var(--text-soft);min-width:5.6em;text-transform:uppercase}.library-filters__actions{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.3rem;padding-top:.6rem;border-top:1px dashed var(--border-soft)}.library-filters__hint{margin:.3rem 0 1.5rem;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;color:var(--text-faint)}.filter-chip{display:inline-flex;align-items:center;gap:.3em;padding:.32rem .85rem;border:1px solid var(--border);border-radius:999px;font-family:var(--font-sans);font-size:.84rem;color:var(--text-soft);background:var(--bg);cursor:pointer;transition:background .12s,color .12s,border-color .12s,transform .06s;user-select:none}.filter-chip:hover{border-color:var(--text-soft);color:var(--text)}.filter-chip:active{transform:scale(.97)}.filter-chip[aria-pressed=true]{background:var(--logo-bg);border-color:var(--logo-bg);color:var(--logo-fg)}.filter-chip[aria-pressed=true]:before{content:"✓ ";font-size:.85em;margin-right:.1em}.filter-chip[aria-pressed=false]{opacity:.75}.filter-chip--ghost{border-style:dashed;font-size:.78rem;color:var(--text-faint)}.filter-chip--ghost:hover{border-style:solid;color:var(--text)}.filter-chip--ghost[aria-pressed]:before{content:none}.library-empty{margin:1.5rem 0;padding:1.5rem;text-align:center;background:var(--bg-elevated);border:1px dashed var(--border);border-radius:10px}.cross-page__breadcrumb{margin:0 0 .5rem;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;color:var(--text-soft)}.cross-page__breadcrumb a{color:var(--accent);text-decoration:none}.cross-page__breadcrumb a:hover{text-decoration:underline}.cross-page__meta{display:flex;flex-wrap:wrap;gap:.4rem;margin:.8rem 0 1rem}.cross-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.9rem}.cross-card{margin:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;transition:transform .12s,box-shadow .12s,border-color .12s}.cross-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 6px 16px #0000000f}.cross-card__link{display:block;padding:1rem 1.1rem;text-decoration:none;color:var(--text)}.cross-card__title{font-family:var(--font-serif);font-size:1.15rem;font-weight:700;margin:0 0 .3rem;color:var(--text)}.cross-card__meta{font-size:.84rem;color:var(--text-soft);margin:0 0 .5rem;line-height:1.5}.cross-card__count{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.1em;color:var(--accent);margin:0}.cross-links{font-size:.88rem;color:var(--text-soft);margin:1.5rem 0 0;padding-top:1rem;border-top:1px dashed var(--border)}.cross-links a{color:var(--accent);text-decoration:none;margin:0 .2em}.cross-links a:hover{text-decoration:underline}.library-empty h3{margin:0 0 .4rem;color:var(--text-soft)}.library-empty p{margin:0;font-size:.9rem;color:var(--text-faint)}@media(max-width:600px){.library-filters__group{flex-direction:row}.library-filters__label{min-width:100%;margin-bottom:.2rem}}.lesson-header{margin-bottom:1.5rem}.lesson-header__top{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.lesson-header__back{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.1em;color:var(--text-soft);text-decoration:none;display:inline-flex;align-items:center;gap:.4rem}.lesson-header__back:hover{color:var(--accent)}.lesson-header__actions{display:flex;gap:.5rem;flex-wrap:wrap}.lesson-header__action-link,.lesson-header__reader-link{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;border:1px solid var(--text-soft);border-radius:999px;font-size:.85rem;color:var(--text-soft);text-decoration:none;transition:background .15s,color .15s,border-color .15s}.lesson-header__action-link:hover,.lesson-header__reader-link:hover{background:var(--text);border-color:var(--text);color:var(--bg)}.lesson-header__action-link--accent{border-color:var(--accent);color:var(--accent)}.lesson-header__action-link--accent:hover{background:var(--accent);border-color:var(--accent);color:var(--logo-fg)}.lesson-header__title{font-size:clamp(1.8rem,4vw,2.5rem);margin:.5rem 0 .8rem}.lesson-header__badges{margin:.5rem 0 1.2rem}.lesson-cover{margin:1rem 0 1.5rem;border-radius:12px;overflow:hidden;border:1px solid var(--border-soft);background:var(--bg-soft);box-shadow:0 6px 18px #0000000d}.lesson-cover img{display:block;width:100%;height:auto;aspect-ratio:16 / 9;object-fit:cover}.illustrations-section{margin-top:2.5rem}.illustrations-section__intro{color:var(--text-soft);font-size:.92rem;margin:.2rem 0 1.2rem}.illustrations-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem;counter-reset:scene}.illustration-card{margin:0;counter-increment:scene}.illustration-card figure{margin:0;border-radius:10px;overflow:hidden;background:var(--bg-elevated);border:1px solid var(--border-soft);transition:transform .18s,box-shadow .18s}.illustration-card figure:hover{transform:translateY(-2px);box-shadow:0 6px 18px #00000012}.illustration-card img{display:block;width:100%;height:auto;aspect-ratio:16 / 9;object-fit:cover}.illustration-card figcaption{padding:.7rem .9rem .9rem;font-size:.88rem;color:var(--text);font-family:var(--font-serif);line-height:1.55}.illustration-card figcaption:before{content:"場面 " counter(scene) " ／ ";color:var(--accent);font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em}.meta-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:1.1rem 1.4rem;font-size:.9rem;margin:1rem 0 2rem}.meta-panel dl{display:grid;grid-template-columns:max-content 1fr;gap:.5em 1.2em;margin:0}.meta-panel dt{color:var(--text-soft);font-weight:600;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em}.meta-panel dd{margin:0;font-family:var(--font-serif)}.callout{background:var(--warn-bg);border-left:4px solid var(--warn-border);padding:.75rem 1.2rem;margin:1.5rem 0;font-size:.92rem;border-radius:0 4px 4px 0}.goals-box{background:var(--bg-elevated);border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:0 8px 8px 0;padding:1rem 1.4rem;margin:1.5rem 0 2.5rem}.goals-box h2{margin:0 0 .6rem;border:0;padding:0;font-size:.92rem;font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}.goals-box ul{margin:.5em 0 0;padding-left:1.4em}.goals-box li{margin:.4em 0;font-family:var(--font-serif)}.story-body{font-family:var(--font-serif);font-size:calc(1.1rem * var(--font-size-scale));line-height:2.05;margin:1.5rem 0 3rem;color:var(--text)}.story-body p{margin:.5em 0;text-indent:0}.story-body blockquote.song{margin:1.2em 2em;padding:.5em 1.2em;border-left:3px solid var(--accent-soft);font-style:normal;background:var(--bg-soft);border-radius:0 4px 4px 0}.story-body blockquote.song p{margin:0;line-height:1.85}ruby{ruby-position:over}rt{font-size:.5em;color:var(--text-soft);font-family:var(--font-sans);letter-spacing:.02em;font-weight:400;line-height:1}.glossary-list{list-style:none;padding:0;margin:1rem 0}.glossary-list li{padding:.6em 0;border-bottom:1px dashed var(--border);font-size:.95rem}.glossary-list li:last-child{border-bottom:0}.glossary-list .term{font-family:var(--font-serif);font-weight:700;color:var(--text);margin-right:.6em;display:inline-block}.questions-list{padding-left:1.5em;font-family:var(--font-serif)}.questions-list li{margin:.8em 0;line-height:1.85}.a11y-toggle{position:relative}.a11y-panel{position:absolute;top:calc(100% + .5rem);right:0;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:1rem 1.1rem;box-shadow:0 10px 28px #0000001f;min-width:260px;z-index:60;display:none;font-size:.9rem}.a11y-panel.is-open{display:block}.a11y-panel h3{margin:0 0 .8rem;font-size:.78rem;font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--text-soft)}.a11y-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-soft)}.a11y-row:last-child{border-bottom:0}.a11y-row__label{color:var(--text)}.a11y-row__controls{display:inline-flex;align-items:center;gap:.25rem}.a11y-btn{background:transparent;border:1px solid var(--border);color:var(--text);padding:.2rem .55rem;border-radius:4px;cursor:pointer;font-size:.82rem;font-family:var(--font-sans);min-width:30px}.a11y-btn:hover{background:var(--bg-soft)}.a11y-btn[aria-pressed=true]{background:var(--logo-bg);color:var(--logo-fg);border-color:var(--logo-bg)}.empty-state{text-align:center;padding:3rem 1rem;background:var(--bg-soft);border-radius:8px;color:var(--text-soft)}.empty-state h3{font-family:var(--font-serif);color:var(--text);margin-bottom:.3rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin:1rem 0 2rem}.kpi-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;padding:1rem 1.2rem}.kpi-card__label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-soft)}.kpi-card__value{font-family:var(--font-serif);font-size:1.8rem;font-weight:700;margin-top:.3rem;color:var(--text)}@media print{.site-header,.site-footer,.bottom-nav,.no-print,.a11y-panel{display:none!important}body{background:#fff;color:#000;font-size:11pt}.container,.section,.hero{max-width:100%;padding:0}.story-body{font-size:12pt;line-height:1.9}rt{color:#555;font-size:.55em}a{color:#000;text-decoration:none}.goals-box,.meta-panel,.callout{background:#fff;border:1px solid #999}h2{page-break-after:avoid}.story-body p{page-break-inside:avoid}}
