*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafafa;--bg-drawer:#f5f5f0;--text:#1a1a1a;--text-muted:#737373;--text-light:#a3a3a3;--rule:#e5e5e5;--rule-dark:#d4d4d4;--accent:#3d3d3d;--font-story:"Noto Serif SC", "Noto Serif", serif;--font-notes:"Lora", Georgia, serif;--font-ui:"Inter", system-ui, sans-serif;--col-toc:250px}html,body{background:var(--bg);height:100%;color:var(--text)}body{font-family:var(--font-ui);-webkit-font-smoothing:antialiased;font-size:16px}#root{height:100%}.book{grid-template-columns:var(--col-toc) 1fr 1fr;height:100vh;display:grid}.book-col{height:100vh;position:sticky;top:0;overflow-y:auto}.book-col+.book-col{border-left:1px solid var(--rule)}.toc{padding:2.5rem 1.25rem 3rem 1.5rem}.toc-header{margin-bottom:1.75rem}.toc-label{font-family:var(--font-story);color:var(--text-muted);font-size:1rem;font-weight:400;display:block}.toc-accordion{flex-direction:column;gap:0;display:flex}.toc-month{border-top:1px solid var(--rule)}.toc-month:last-child{border-bottom:1px solid var(--rule)}.toc-month-btn{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:.5rem;width:100%;padding:.7rem 0;display:flex}.toc-month-name{font-family:var(--font-ui);color:var(--text-muted);flex:1;font-size:.75rem;font-weight:500;transition:color .15s}.toc-month-btn:hover .toc-month-name,.toc-month.is-open .toc-month-name{color:var(--text)}.toc-month-meta{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.toc-month-count{font-family:var(--font-ui);color:var(--text-light);text-align:right;min-width:1.2rem;font-size:.625rem}.toc-chevron{color:var(--text-light);flex-shrink:0;transition:transform .2s,color .15s}.toc-month.is-open .toc-chevron{color:var(--text-muted);transform:rotate(180deg)}.toc-list{padding-bottom:.5rem;list-style:none}.toc-item{border-top:1px solid var(--rule)}.toc-link{color:var(--text-muted);padding:.45rem 0;text-decoration:none;transition:color .15s;display:block}.toc-link:hover,.toc-link.is-active{color:var(--text)}.toc-entry-row{align-items:baseline;gap:.5rem;line-height:1.4;display:flex}.toc-entry-day{font-family:var(--font-ui);letter-spacing:.06em;color:var(--text-light);flex-shrink:0;min-width:1.5rem;font-size:.5625rem;font-weight:500;transition:color .15s}.toc-link.is-active .toc-entry-day{color:var(--text-muted)}.toc-entry-title{font-family:var(--font-story);color:inherit;white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;overflow:hidden}.story-panel{flex-direction:column;min-height:100%;display:flex}.story-inner{flex:1;align-self:center;width:100%;max-width:500px;padding:4rem 3rem 3rem}.story-meta{align-items:baseline;gap:1rem;margin-bottom:3rem;display:flex}.story-day-badge{font-family:var(--font-ui);letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);font-size:.625rem;font-weight:500}.story-date{font-family:var(--font-notes);color:var(--text-light);font-size:.75rem;font-style:italic}.story-title{font-family:var(--font-story);color:var(--text);margin-bottom:.3rem;font-size:1.375rem;font-weight:700;line-height:1.35}.story-title-en{font-family:var(--font-notes);color:var(--text-muted);margin-bottom:2.5rem;font-size:.875rem;font-style:italic;display:block}.story-body{font-family:var(--font-story);color:var(--text);font-size:.8rem;line-height:2}.story-body p{margin-bottom:1.6em}.story-body p:last-child{margin-bottom:0}.story-nav{background:var(--bg);border-top:1px solid var(--rule);justify-content:space-between;align-items:flex-start;gap:1rem;padding:.9rem 3rem;display:flex;position:sticky;bottom:0}.story-nav-side{flex:1}.story-nav-next{text-align:right}.story-nav-link{color:var(--text-light);align-items:baseline;gap:.5rem;text-decoration:none;transition:color .15s;display:inline-flex}.story-nav-link--next{justify-content:flex-end}.story-nav-link:hover{color:var(--text)}.story-nav-arrow{flex-shrink:0;font-size:.75rem}.story-nav-label{flex-direction:column;gap:.15rem;display:flex}.story-nav-label--next{text-align:right}.story-nav-day{font-family:var(--font-ui);letter-spacing:.08em;text-transform:uppercase;color:inherit;font-size:.5625rem;font-weight:500}.story-nav-title{font-family:var(--font-story);font-size:.8rem}.story-vocab{border-bottom:1px solid var(--rule);margin-bottom:2.5rem;padding-bottom:2rem}.story-vocab-label{font-family:var(--font-ui);letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:.9rem;font-size:.6875rem;font-weight:500;display:block}.story-vocab-words{flex-wrap:wrap;gap:.5rem;list-style:none;display:flex}.story-vocab-word{font-family:var(--font-story);color:var(--text-light);border:1px solid var(--rule);border-radius:3px;padding:.15rem .45rem;font-size:.625rem;line-height:1.6}.notes-panel{flex-direction:column;padding:0;display:flex}.notes-tabs{border-bottom:1px solid var(--rule);flex-shrink:0;gap:0;padding:2rem 2rem 0;display:flex}.notes-tab{font-family:var(--font-ui);letter-spacing:.1em;text-transform:uppercase;color:var(--text-light);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.5rem .75rem;font-size:.625rem;font-weight:500;transition:color .15s,border-color .15s}.notes-tab:hover{color:var(--text-muted)}.notes-tab.is-active{color:var(--text);border-bottom-color:var(--text)}.notes-content{font-family:var(--font-notes);color:var(--text);flex:1;padding:2rem 2rem 5rem;font-size:.875rem;line-height:1.75;overflow-y:auto}.notes-content p{margin-bottom:.9em}.notes-content p:last-child{margin-bottom:0}.notes-content ul,.notes-content ol{margin-bottom:0;padding-left:1.4em}.notes-content hr{border:none;margin:1.75rem 0 0}.notes-content li{margin-bottom:.45em;line-height:1.65}.notes-content strong{color:var(--accent);font-weight:600}.notes-content em{font-style:italic}.nav-toggle{z-index:200;background:var(--bg);border:1px solid var(--rule-dark);cursor:pointer;color:var(--text);font-family:var(--font-ui);border-radius:6px;align-items:center;gap:.4rem;padding:.5rem .625rem;font-size:.8125rem;font-weight:500;line-height:1;transition:background .15s,border-color .15s;display:none;position:fixed;top:1.25rem;left:1.25rem}.nav-toggle:hover{background:var(--rule)}.nav-toggle-icon{flex-direction:column;gap:3px;width:14px;display:flex}.nav-toggle-icon span{background:currentColor;border-radius:1px;height:1.5px;transition:transform .2s,opacity .2s;display:block}.drawer-backdrop{z-index:100;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#00000040;display:none;position:fixed;inset:0}.drawer{background:var(--bg-drawer);border-right:1px solid var(--rule-dark);z-index:150;width:min(320px,85vw);transition:transform .25s;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-100%)}.drawer.is-open{transform:translate(0)}.empty-state{font-family:var(--font-notes);color:var(--text-muted);text-align:center;padding:4rem;font-style:italic}@media (width<=900px){.book{display:block}.book-col{height:auto;min-height:unset;position:static;overflow-y:visible}.book-col.is-toc{display:none}.book-col.is-story{border-left:none}.book-col.is-notes{border-left:none;border-top:1px solid var(--rule)}.story-inner{max-width:100%;padding:5rem 1.5rem 2rem}.story-nav{padding:.9rem 1.5rem;position:static}.notes-panel{min-height:unset}.notes-content{padding:1.5rem 1.5rem 3rem;overflow-y:visible}.notes-tabs{scrollbar-width:none;padding:1.5rem 1.5rem 0;overflow-x:auto}.notes-tabs::-webkit-scrollbar{display:none}.nav-toggle{display:flex}.drawer-backdrop.is-open{display:block}}@media (width<=600px){.story-title{font-size:1.5rem}.story-body{font-size:1rem}}
