*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w: 256px;--header-h: 52px;--bg: #f8f7f4;--surface: #ffffff;--sidebar-bg: #18181b;--sidebar-fg: #a1a1aa;--sidebar-hover: #27272a;--sidebar-active-bg: #3f3f46;--sidebar-active-fg: #fafafa;--sidebar-section: #52525b;--border: #e4e4e7;--text: #18181b;--text-muted: #71717a;--accent: #b45309;--accent-light: #fef3c7;--font: -apple-system, "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans SC", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--leading: 1.8}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:15px;line-height:var(--leading);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}.app{display:flex;height:100dvh;overflow:hidden}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--sidebar-bg);color:var(--sidebar-fg);display:flex;flex-direction:column;overflow:hidden;transition:transform .25s ease;z-index:100}.sidebar-header{padding:16px 16px 12px;border-bottom:1px solid #27272a;display:flex;align-items:center;gap:10px;min-height:var(--header-h)}.sidebar-logo{font-size:18px;font-weight:700;color:#fafafa;letter-spacing:-.5px}.sidebar-logo span{color:var(--accent)}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:#3f3f46 transparent}.nav-section{padding:20px 12px 4px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--sidebar-section)}.nav-item{display:block;width:100%;padding:7px 16px;font-size:13.5px;color:var(--sidebar-fg);background:none;border:none;text-align:left;border-radius:6px;margin:1px 4px;width:calc(100% - 8px);transition:background .12s,color .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item:hover{background:var(--sidebar-hover);color:#e4e4e7}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-fg)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;flex-shrink:0}.topbar-title{font-size:15px;font-weight:600;color:var(--text)}.topbar-sub{font-size:13px;color:var(--text-muted)}.topbar-back{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);background:none;border:none;padding:4px 8px;border-radius:6px;transition:background .12s,color .12s}.topbar-back:hover{background:var(--border);color:var(--text)}.content-area{flex:1;overflow-y:auto;padding:32px 40px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.home-header{margin-bottom:32px}.home-title{font-size:28px;font-weight:700;color:var(--text);letter-spacing:-.5px}.home-subtitle{margin-top:6px;font-size:15px;color:var(--text-muted)}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.book-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;cursor:pointer;transition:box-shadow .15s,border-color .15s,transform .1s;display:flex;flex-direction:column;gap:12px}.book-card:hover{box-shadow:0 4px 20px #00000014;border-color:#d4d4d8;transform:translateY(-1px)}.book-card-title{font-size:18px;font-weight:700;color:var(--text);line-height:1.3}.book-card-genre{font-size:12px;background:var(--accent-light);color:var(--accent);padding:2px 8px;border-radius:4px;display:inline-block;font-weight:500}.book-card-stats{display:flex;gap:16px;font-size:13px;color:var(--text-muted);margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}.stat{display:flex;flex-direction:column;gap:2px}.stat-value{font-size:16px;font-weight:600;color:var(--text)}.stat-label{font-size:11px}.fm-card{max-width:780px;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:28px;overflow:hidden}.fm-header{width:100%;display:flex;align-items:center;gap:10px;padding:14px 18px;background:#f4f4f5;border:none;font-family:inherit;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;text-align:left;border-bottom:1px solid var(--border);transition:background .12s}.fm-header:hover{background:#ebebeb}.fm-header-title{flex:1}.fm-version{font-size:11px;font-weight:500;color:var(--text-muted);background:var(--border);padding:2px 7px;border-radius:10px}.fm-toggle{font-size:12px;color:var(--text-muted);font-weight:400}.fm-body{padding:14px 18px;display:flex;flex-direction:column;gap:10px}.fm-field{display:flex;align-items:flex-start;gap:10px;font-size:13.5px}.fm-label{min-width:90px;flex-shrink:0;font-weight:600;color:var(--text-muted);font-size:12px;padding-top:2px}.fm-value{color:var(--text);line-height:1.6}.fm-tags{display:flex;flex-wrap:wrap;gap:5px}.fm-tag{font-size:12px;background:var(--accent-light);color:var(--accent);padding:2px 8px;border-radius:4px;font-weight:500}.fm-nested{background:#fafaf9;border:1px solid var(--border);border-radius:8px;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.fm-nested-title{font-size:12px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;padding-bottom:6px;border-bottom:1px solid var(--border)}@media(max-width:640px){.fm-field{flex-direction:column;gap:4px}.fm-label{min-width:unset;padding-top:0}}.md-content{max-width:780px;line-height:var(--leading)}.md-content h1{font-size:22px;font-weight:700;color:var(--text);margin:0 0 24px;padding-bottom:12px;border-bottom:2px solid var(--border);letter-spacing:-.3px}.md-content h2{font-size:17px;font-weight:700;color:var(--text);margin:32px 0 12px}.md-content h3{font-size:15px;font-weight:600;color:var(--text);margin:24px 0 8px}.md-content p{margin:10px 0;color:#3f3f46}.md-content ul,.md-content ol{padding-left:20px;margin:10px 0}.md-content li{margin:4px 0;color:#3f3f46}.md-content blockquote{border-left:3px solid var(--accent);padding:8px 16px;margin:16px 0;background:var(--accent-light);border-radius:0 6px 6px 0}.md-content blockquote p{color:var(--text);margin:0}.md-content code{font-family:var(--font-mono);font-size:13px;background:#f4f4f5;padding:2px 5px;border-radius:4px;color:#b45309}.md-content pre{background:#18181b;color:#e4e4e7;padding:16px 20px;border-radius:8px;overflow-x:auto;margin:16px 0}.md-content pre code{background:none;padding:0;color:inherit;font-size:13px}.md-content hr{border:none;border-top:1px solid var(--border);margin:28px 0}.md-content strong{font-weight:600;color:var(--text)}.md-content a{color:var(--accent);text-decoration:underline}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:16px 0;border-radius:6px;border:1px solid var(--border)}.md-content table{border-collapse:collapse;font-size:13.5px;min-width:100%}.md-content th{background:#f4f4f5;font-weight:600;color:var(--text);padding:8px 14px;text-align:left;border-bottom:2px solid var(--border);white-space:nowrap}.md-content td{padding:8px 14px;border-bottom:1px solid var(--border);color:#3f3f46;vertical-align:top;min-width:80px}@media(max-width:768px){.md-content table{font-size:13px}.md-content th,.md-content td{padding:7px 12px}.md-content td{min-width:100px}}.md-content tr:last-child td{border-bottom:none}.md-content tr:hover td{background:#fafafa}.chapter-list{display:flex;flex-direction:column;gap:8px;max-width:780px}.chapter-item{display:flex;align-items:center;gap:16px;padding:14px 20px;background:var(--surface);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:box-shadow .12s,border-color .12s;text-align:left;width:100%;font-family:inherit}.chapter-item:hover{border-color:#d4d4d8;box-shadow:0 2px 8px #0000000f}.chapter-num{font-size:12px;font-weight:600;color:var(--text-muted);min-width:36px}.chapter-title{font-size:15px;font-weight:500;color:var(--text);flex:1}.chapter-meta{font-size:12px;color:var(--text-muted);flex-shrink:0}.reader-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;justify-content:flex-end}.reader-panel{width:min(760px,100vw);height:100%;background:var(--surface);display:flex;flex-direction:column;box-shadow:-8px 0 40px #00000026}.reader-header{padding:20px 28px 16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-shrink:0}.reader-header-info{flex:1;min-width:0}.reader-title{font-size:18px;font-weight:700;color:var(--text);line-height:1.3}.reader-meta{font-size:13px;color:var(--text-muted);margin-top:4px}.reader-close{background:none;border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:13px;color:var(--text-muted);flex-shrink:0;transition:background .12s}.reader-close:hover{background:var(--bg);color:var(--text)}.reader-nav{display:flex;gap:8px;padding:12px 28px;border-bottom:1px solid var(--border);flex-shrink:0}.reader-nav-btn{padding:6px 14px;font-size:13px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);transition:background .12s}.reader-nav-btn:hover:not(:disabled){background:var(--border)}.reader-nav-btn:disabled{opacity:.4;cursor:default}.reader-body{flex:1;overflow-y:auto;padding:32px 40px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-muted);font-size:14px}.empty{padding:40px;text-align:center;color:var(--text-muted);font-size:14px}.menu-btn{display:none;flex-direction:column;gap:4px;background:none;border:none;padding:6px;border-radius:6px}.menu-btn span{display:block;width:20px;height:2px;background:var(--text-muted);border-radius:2px}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}@media(max-width:768px){:root{--sidebar-w: 280px}.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay.show{display:block}.menu-btn{display:flex}.content-area{padding:20px 18px}.topbar{padding:0 16px}.book-grid{grid-template-columns:1fr}.reader-panel{width:100vw}.reader-body{padding:24px 20px}.md-content h1{font-size:18px}.md-content h2{font-size:16px}}
