:root{--bg: #fafaf9;--bg-surface: #ffffff;--bg-hover: #f5f5f4;--text: #292524;--text-muted: #78716c;--accent: #292524;--accent-hover: #44403c;--border: #e7e5e4;--danger: #ef4444;--warning: #f59e0b;--success: #10b981;--radius: 12px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", "Fira Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--text);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:1100px;margin:0 auto;padding:24px 16px}.header{background:#fafaf9f2;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.header-inner{max-width:1100px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;gap:16px}.logo{font-size:1.25rem;font-weight:700;color:var(--text);white-space:nowrap}.logo:hover{text-decoration:none;color:var(--text-muted)}.search-form{flex:1;max-width:400px}.search-form input{width:100%;padding:8px 14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:9999px;color:var(--text);font-size:.875rem}.search-form input:focus{outline:none;border-color:#a8a29e}.header-nav{display:flex;align-items:center;gap:12px;margin-left:auto}.user-name{color:var(--text-muted);font-size:.875rem}.btn-primary,.btn-secondary,.btn-danger,.btn-warning{padding:8px 18px;border:none;border-radius:9999px;font-size:.875rem;cursor:pointer;white-space:nowrap;transition:background .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);text-decoration:none}.btn-secondary{background:var(--bg-surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);text-decoration:none}.btn-danger{background:var(--danger);color:#fff}.btn-warning{background:var(--warning);color:#111}.home{display:flex;gap:24px}.home-sidebar{width:220px;flex-shrink:0}.home-main{flex:1;min-width:0}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.home-header h2{font-size:1.25rem;font-weight:600}.category-list{list-style:none}.category-list>li>a,.category-list>li>.product-header>a{display:block;padding:8px 12px;border-left:3px solid transparent;color:var(--text-muted);font-size:.875rem;border-radius:0 var(--radius) var(--radius) 0;transition:background .15s}.category-list>li>a:hover,.category-list>li>a.active,.category-list>li>.product-header>a:hover,.category-list>li>.product-header>a.active{background:var(--bg-hover);color:var(--text);text-decoration:none}.category-list>li>a.active,.category-list>li>.product-header>a.active{border-left-color:var(--accent)}.product-header{display:flex;align-items:center}.product-header a{flex:1}.product-toggle{background:none;border:none;color:var(--text-muted);font-size:1rem;padding:4px 10px;cursor:pointer;line-height:1}.product-toggle:hover{color:var(--text)}.subcategory-list{list-style:none;margin:0;padding:0}.subcategory-list li a{display:block;padding:5px 12px 5px 28px;color:var(--text-muted);font-size:.8rem;border-radius:0 var(--radius) var(--radius) 0}.subcategory-list li a:hover,.subcategory-list li a.active{background:var(--bg-hover);color:var(--text);text-decoration:none}.thread-list{display:flex;flex-direction:column;gap:2px}.thread-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-surface);border-radius:var(--radius);color:var(--text);transition:background .15s;border:1px solid var(--border)}.thread-item:hover{background:var(--bg-hover);text-decoration:none}.thread-item-title{font-weight:500;margin-bottom:4px}.thread-item-meta{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-muted)}.thread-item-stats{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.badge{font-size:.7rem;padding:2px 6px;border-radius:4px;font-weight:600;text-transform:uppercase}.badge.pin{background:var(--accent);color:#fff}.badge.lock{background:var(--warning);color:#111}.category-badge{border:1px solid;padding:2px 8px;border-radius:9999px;font-size:.75rem}.tag-badge{padding:2px 8px;border-radius:9999px;font-size:.75rem;color:#fff}.thread-page{max-width:800px}.thread-header{margin-bottom:24px}.thread-header h1{font-size:1.5rem;font-weight:600;margin-bottom:8px}.thread-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.post{display:flex;gap:16px;padding:16px;background:var(--bg-surface);border-radius:var(--radius);margin-bottom:8px;border:1px solid var(--border)}.post-sidebar{width:80px;text-align:center;flex-shrink:0}.post-avatar img{width:48px;height:48px;border-radius:50%;object-fit:cover}.post-author-name{font-size:.8rem;color:var(--text-muted);margin-top:4px}.post-body{flex:1;min-width:0}.post-content{line-height:1.7}.post-content img{max-width:100%;border-radius:var(--radius)}.post-content code{background:var(--bg-hover);padding:2px 6px;border-radius:4px;font-family:var(--font-mono);font-size:.875em}.post-content pre{background:#1c1917;color:#e7e5e4;padding:12px;border-radius:var(--radius);overflow-x:auto}.post-content blockquote{border-left:3px solid var(--border);padding-left:12px;color:var(--text-muted);margin:8px 0}.quoted-post{background:var(--bg-hover);border-left:3px solid var(--accent);padding:8px 12px;margin-bottom:12px;border-radius:0 var(--radius) var(--radius) 0;font-size:.875rem}.quoted-post cite{display:block;color:var(--text-muted);font-size:.8rem;margin-bottom:4px}.post-footer{display:flex;align-items:center;gap:12px;margin-top:12px;font-size:.8rem;color:var(--text-muted)}.post-actions{margin-left:auto;display:flex;gap:8px}.post-actions button{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.8rem}.post-actions button:hover{color:var(--accent)}.reply-section{margin-top:24px}.quoting{background:var(--bg-surface);padding:8px 12px;border-radius:var(--radius) var(--radius) 0 0;display:flex;justify-content:space-between;font-size:.875rem;color:var(--text-muted);border:1px solid var(--border);border-bottom:none}.quoting button{background:none;border:none;color:var(--text-muted);cursor:pointer}.locked-notice{color:var(--warning);font-style:italic;margin-top:16px}.account-page{max-width:500px}.account-page h2{margin-bottom:24px}.account-section{background:var(--bg-surface);padding:20px;border-radius:var(--radius);margin-bottom:16px;border:1px solid var(--border)}.account-section h3{margin-bottom:16px;font-size:1rem}.account-section form{display:flex;flex-direction:column;gap:12px}.account-section label{font-size:.8rem;color:var(--text-muted);display:block;margin-bottom:4px}.account-section input:disabled{opacity:.5}.success{background:#10b9811a;color:var(--success);padding:10px 14px;border-radius:var(--radius);margin-bottom:12px;font-size:.875rem}.avatar-glyph{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin:0 auto;line-height:1}.avatar-glyph.large{width:72px;height:72px;font-size:2.25rem}.glyph-preview{text-align:center;margin-bottom:16px}.glyph-picker,.color-picker{margin-bottom:16px}.glyph-picker label,.color-picker label{font-size:.8rem;color:var(--text-muted);display:block;margin-bottom:8px}.glyph-grid{display:grid;grid-template-columns:repeat(auto-fill,40px);gap:4px;max-height:240px;overflow-y:auto;padding:4px}.glyph-option{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:var(--bg-surface);border:2px solid transparent;border-radius:var(--radius);cursor:pointer}.glyph-option:hover{border-color:var(--border)}.glyph-option.active{border-color:var(--accent);background:var(--bg-hover)}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,36px);gap:4px}.color-option{width:36px;height:36px;border-radius:50%;border:3px solid transparent;cursor:pointer}.color-option:hover{border-color:#0003}.color-option.active{border-color:var(--accent)}.editor{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.editor-toolbar{display:flex;gap:4px;padding:8px;border-bottom:1px solid var(--border);flex-wrap:wrap}.editor-toolbar button{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:4px 10px;border-radius:4px;cursor:pointer;font-size:.8rem}.editor-toolbar button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.editor-content{padding:12px;min-height:120px}.editor-content .tiptap{outline:none;min-height:100px}.editor-content .tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--text-muted);pointer-events:none;float:left;height:0}.editor-footer{padding:8px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.auth-page{max-width:400px;margin:48px auto;padding:32px;background:var(--bg-surface);border-radius:var(--radius);border:1px solid var(--border)}.auth-page h2{margin-bottom:20px;font-weight:600}.auth-page form{display:flex;flex-direction:column;gap:12px}.auth-switch{margin-top:16px;font-size:.875rem;color:var(--text-muted)}.form-group{margin-bottom:12px}.form-group input,.form-group select{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.95rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#a8a29e}.input-title{font-size:1.25rem!important;font-weight:500}.tag-selector{display:flex;gap:8px;flex-wrap:wrap}.tag-toggle{padding:4px 12px;border:1px solid var(--border);border-radius:9999px;color:var(--text);cursor:pointer;font-size:.85rem;background:transparent;transition:background .15s}.tag-toggle:hover{background:var(--bg-hover)}.tag-toggle.active{border-color:transparent;color:#fff}.new-thread{max-width:800px}.new-thread h2,.search-page h2{margin-bottom:20px}.search-page h3{margin:16px 0 8px;color:var(--text-muted);font-size:.9rem;text-transform:uppercase}.search-result{display:block;padding:12px 16px;background:var(--bg-surface);border-radius:var(--radius);margin-bottom:4px;color:var(--text);border:1px solid var(--border)}.search-result:hover{background:var(--bg-hover);text-decoration:none}.search-meta{font-size:.8rem;color:var(--text-muted)}.search-snippet{font-size:.875rem;color:var(--text-muted);margin:4px 0}.admin-page h2{margin-bottom:16px}.admin-tabs{display:flex;gap:4px;margin-bottom:20px}.admin-tabs button{padding:8px 20px;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:9999px;transition:background .15s}.admin-tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.admin-form{display:flex;gap:8px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.admin-form input{padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.875rem}.admin-form input[type=color]{width:40px;padding:4px}.admin-form label{font-size:.85rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}.admin-table{width:100%;border-collapse:collapse}.admin-table th{text-align:left;padding:8px 12px;border-bottom:1px solid var(--border);color:var(--text-muted);font-size:.8rem;text-transform:uppercase}.admin-table td{padding:8px 12px;border-bottom:1px solid var(--border)}.admin-table td button{margin-right:4px;padding:4px 10px;font-size:.8rem}.subcategory-row td{background:var(--bg-hover)}.error{background:#ef44441a;color:var(--danger);padding:10px 14px;border-radius:var(--radius);margin-bottom:12px;font-size:.875rem}.loading,.empty{text-align:center;padding:48px;color:var(--text-muted)}.load-more{display:block;width:100%;padding:12px;background:var(--bg-surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:var(--radius);margin-top:8px;font-size:.875rem}.load-more:hover{background:var(--bg-hover)}.footer{padding:24px 16px;text-align:center;font-size:.8rem;color:var(--text-muted);border-top:1px solid var(--border);margin-top:48px}.footer a{color:var(--text-muted)}.footer a:hover{color:var(--text)}@media(max-width:768px){.home{flex-direction:column}.home-sidebar{width:100%}.category-list{display:flex;gap:4px;overflow-x:auto;flex-wrap:wrap}.category-list>li>a,.category-list>li>.product-header>a{border-left:none;border-bottom:2px solid transparent;white-space:nowrap;padding:6px 10px}.category-list>li>a.active,.category-list>li>.product-header>a.active{border-bottom-color:var(--accent)}.subcategory-list{display:flex;gap:2px}.subcategory-list li a{padding:4px 8px;white-space:nowrap}.product-toggle{display:none}.header-inner{flex-wrap:wrap}.search-form{order:3;max-width:100%;flex-basis:100%}.post{flex-direction:column;gap:8px}.post-sidebar{width:100%;display:flex;align-items:center;gap:8px}.post-avatar img,.avatar-placeholder{width:32px;height:32px;font-size:.9rem}}
