*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-width: 260px;--panel-width: 420px;--bg-dark: #1a1d23;--bg-main: #f5f7fa;--text-primary: #1a202c;--text-secondary: #4a5568;--text-muted: #718096;--border: #e2e8f0;--accent: #4f46e5;--accent-hover: #4338ca;--card-bg: #ffffff;--sidebar-text: #e2e8f0;--sidebar-muted: #9ca3af;--sidebar-active-bg: rgba(79, 70, 229, .25);--sidebar-hover-bg: rgba(255, 255, 255, .06)}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Arial,Noto Sans JP,sans-serif;font-size:14px;color:var(--text-primary);background:var(--bg-main)}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-dark);color:var(--sidebar-text);display:flex;flex-direction:column;overflow:hidden;z-index:20}.sidebar-header{padding:16px 14px 12px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-header-row{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}.sidebar-header h1{font-size:13px;font-weight:700;color:#fff;line-height:1.4}.sidebar-header h1 small{display:block;font-size:10px;font-weight:400;color:#ffffff8c;letter-spacing:.02em}.sidebar-close-btn{display:none;background:none;border:none;color:#fff9;font-size:22px;cursor:pointer;padding:0 4px;line-height:1;flex-shrink:0}.lang-toggle{display:flex;gap:4px;margin-bottom:10px}.lang-btn{flex:1;min-width:0;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:5px;color:var(--sidebar-muted);font-size:10px;font-weight:700;padding:4px 2px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .15s,color .15s,border-color .15s}.lang-btn:hover{background:rgba(255,255,255,.1);color:var(--sidebar-text)}.lang-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.sidebar-search{width:100%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:6px;color:var(--sidebar-text);padding:6px 10px;font-size:13px;outline:none;transition:border-color .15s}.sidebar-search::placeholder{color:var(--sidebar-muted)}.sidebar-search:focus{border-color:var(--accent)}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}.nav-item{display:flex;align-items:center;gap:8px;padding:7px 14px;cursor:pointer;border-radius:0;transition:background .12s;border:none;background:none;width:100%;text-align:left;color:var(--sidebar-text)}.nav-item:hover{background:var(--sidebar-hover-bg)}.nav-item.active{background:var(--sidebar-active-bg);color:#a5b4fc}.nav-item-num{font-size:11px;font-weight:600;color:var(--sidebar-muted);min-width:20px}.nav-item-title{font-size:12.5px;line-height:1.3;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-item-count{font-size:10px;color:var(--sidebar-muted);background:rgba(255,255,255,.08);padding:1px 6px;border-radius:10px}.search-results{flex:1;overflow-y:auto;padding:8px 0}.search-result-item{padding:8px 14px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.04);transition:background .12s}.search-result-item:hover{background:var(--sidebar-hover-bg)}.search-result-name{font-size:12.5px;font-weight:600;color:#e2e8f0;margin-bottom:2px}.search-result-section{font-size:11px;color:var(--sidebar-muted)}.search-result-desc{font-size:11px;color:#9ca3af;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.search-empty{padding:20px 14px;color:var(--sidebar-muted);font-size:12px;text-align:center}.main-content{flex:1;overflow-y:auto;padding:32px 40px;transition:padding-right .3s cubic-bezier(.4,0,.2,1)}.main-content.panel-open{padding-right:calc(var(--panel-width) + 40px)}.survey-section{max-width:860px}.section-header{margin-bottom:28px;padding-bottom:14px;border-bottom:2px solid var(--border)}.section-number{font-size:12px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.section-title{font-size:24px;font-weight:700;color:var(--text-primary);line-height:1.3}.subsection{margin-bottom:36px}.subsection-title{font-size:17px;font-weight:600;color:var(--text-primary);margin-bottom:14px;display:flex;align-items:center;gap:8px}.subsection-title:before{content:"";display:inline-block;width:3px;height:18px;background:var(--accent);border-radius:2px}.prose{color:var(--text-secondary);line-height:1.75;font-size:14px;margin-bottom:20px}.prose h1,.prose h2,.prose h3,.prose h4{color:var(--text-primary);margin-top:1.2em;margin-bottom:.5em}.prose p{margin-bottom:.9em}.prose .tool-link{color:var(--accent);cursor:pointer;text-decoration:underline;text-decoration-style:dashed;text-decoration-thickness:1px;text-underline-offset:3px;border-radius:2px;transition:background .12s,color .12s}.prose .tool-link:hover{background:#eef2ff;color:var(--accent-hover);text-decoration-style:solid}.prose strong{color:var(--text-primary);font-weight:600}.prose ul,.prose ol{padding-left:1.4em;margin-bottom:.9em}.prose li{margin-bottom:.3em}.prose code{background:#f1f5f9;padding:1px 5px;border-radius:3px;font-size:12.5px;font-family:JetBrains Mono,Fira Code,monospace}.prose table{width:100%;border-collapse:collapse;margin-bottom:1em;font-size:13px}.prose th{background:#f8fafc;padding:8px 12px;text-align:left;border-bottom:2px solid var(--border);font-weight:600;color:var(--text-primary)}.prose td{padding:7px 12px;border-bottom:1px solid var(--border);vertical-align:top}.prose tr:hover td{background:#f8fafc}.prose blockquote{border-left:3px solid var(--accent);padding-left:12px;color:var(--text-muted);margin:.8em 0}.prose hr{border:none;border-top:1px solid var(--border);margin:1.2em 0}.tool-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-top:14px}.tool-card{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:12px 14px;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .1s}.tool-card:hover{border-color:var(--accent);box-shadow:0 2px 12px #4f46e51f;transform:translateY(-1px)}.tool-card.selected{border-color:var(--accent);box-shadow:0 0 0 2px #4f46e533}.tool-card-name{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-card-desc{font-size:11.5px;color:var(--text-muted);line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:8px}.tool-card-badges{display:flex;flex-wrap:wrap;gap:4px}.badge{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;font-weight:600;padding:2px 6px;border-radius:4px;white-space:nowrap}.badge-star{background:#fef3c7;color:#92400e}.badge-dl{background:#d1fae5;color:#065f46}.badge-hf{background:#fff3e0;color:#bf360c}.badge-likes{background:#fce7f3;color:#9d174d}.detail-panel{position:fixed;top:0;right:0;width:var(--panel-width);height:100vh;background:#fff;border-left:1px solid var(--border);box-shadow:-4px 0 24px #00000014;display:flex;flex-direction:column;z-index:100;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.detail-panel.open{transform:translate(0)}.detail-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border);gap:10px}.detail-panel-title{font-size:18px;font-weight:700;color:var(--text-primary);line-height:1.3;flex:1}.panel-close-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:4px;font-size:20px;line-height:1;transition:color .15s,background .15s;flex-shrink:0}.panel-close-btn:hover{color:var(--text-primary);background:var(--bg-main)}.detail-panel-body{flex:1;overflow-y:auto;padding:18px 20px}.detail-panel-body::-webkit-scrollbar{width:5px}.detail-panel-body::-webkit-scrollbar-track{background:transparent}.detail-panel-body::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.panel-section{margin-bottom:22px}.panel-section-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.panel-badges{display:flex;flex-wrap:wrap;gap:6px}.panel-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:6px}.panel-links{display:flex;flex-wrap:wrap;gap:8px}.panel-link-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;text-decoration:none;transition:opacity .15s;border:1px solid transparent}.panel-link-btn:hover{opacity:.85}.panel-link-github{background:#1f2937;color:#fff;border-color:#374151}.panel-link-hf{background:#ff7a00;color:#fff}.panel-desc{color:var(--text-secondary);font-size:13.5px;line-height:1.7}.panel-breadcrumb{font-size:11.5px;color:var(--text-muted);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.panel-breadcrumb-sep{color:#cbd5e0}.related-tools{display:flex;flex-direction:column;gap:6px}.related-tool-item{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:border-color .12s,background .12s}.related-tool-item:hover{border-color:var(--accent);background:#f8f9ff}.related-tool-item.current{border-color:var(--accent);background:#eef2ff;cursor:default}.related-tool-name{font-size:12.5px;font-weight:600;color:var(--text-primary)}.related-tool-desc{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.chapter-nav{display:flex;justify-content:space-between;gap:12px;margin-top:48px;padding-top:24px;border-top:1px solid var(--border)}.chapter-nav-prev,.chapter-nav-next{flex:1}.chapter-nav-next{display:flex;justify-content:flex-end}.chapter-nav-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-align:left;max-width:260px}.chapter-nav-btn:hover{border-color:var(--accent);box-shadow:0 2px 8px #4f46e51a}.chapter-nav-arrow{font-size:16px;color:var(--accent);flex-shrink:0}.chapter-nav-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;display:block;white-space:nowrap}.chapter-nav-title{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.3;display:block}.chapter-nav-btn{flex-direction:column;align-items:flex-start;gap:4px}.chapter-nav-next .chapter-nav-btn{align-items:flex-end;text-align:right}.chapter-nav-prev .chapter-nav-btn .chapter-nav-arrow,.chapter-nav-next .chapter-nav-btn .chapter-nav-arrow{font-size:14px}.loading-state,.empty-state{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:15px}.mobile-header{display:none}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.5);z-index:199}@media (max-width: 768px){.mobile-header{display:flex;align-items:center;gap:10px;height:48px;padding:0 14px;background:var(--bg-dark);flex-shrink:0;z-index:10}.mobile-menu-btn{background:none;border:none;color:#fff;font-size:22px;cursor:pointer;padding:4px 6px;line-height:1}.mobile-section-title{font-size:13px;font-weight:600;color:#e2e8f0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-layout{flex-direction:column}.sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;transform:translate(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);z-index:200}.sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 24px #0000004d}.sidebar-close-btn{display:block}.main-content{padding:20px 16px;width:100%}.main-content.panel-open{padding-right:16px}.detail-panel{width:100vw}.tool-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.section-title{font-size:20px}.prose table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}}
