.file-uploader{width:100%;margin:1rem 0}.file-uploader-dropzone{border:2px dashed rgba(255,255,255,.3);border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:#ffffff05}.file-uploader-dropzone:hover{border-color:#ffffff80;background:#ffffff0d}.file-uploader-dropzone.dragover{border-color:#00d4ff;background:#00d4ff1a;transform:scale(1.02)}.dropzone-icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.dropzone-text{font-size:1.1rem;margin-bottom:.5rem;color:#ffffffe6}.dropzone-browse{color:#00d4ff;text-decoration:underline;pointer-events:auto;cursor:pointer}.dropzone-browse:hover{color:#00e5ff}.dropzone-hint{font-size:.875rem;color:#ffffff80;margin-top:.5rem}.file-input{display:none}.file-uploader-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1rem}.file-preview-item{position:relative;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:.75rem;background:#ffffff08;display:flex;gap:.75rem;align-items:center;transition:all .2s ease}.file-preview-item:hover{background:#ffffff0d;border-color:#ffffff4d}.file-preview-image{width:60px;height:60px;object-fit:cover;border-radius:4px;flex-shrink:0}.file-preview-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;font-size:2rem;background:#ffffff0d;border-radius:4px;flex-shrink:0}.file-preview-name{font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.file-preview-size{font-size:.75rem;color:#fff9}.file-preview-status{font-size:.75rem;color:#00d4ff;margin-top:.25rem}.file-preview-error{font-size:.75rem;color:#f44;margin-top:.25rem}.file-preview-remove{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;border:none;background:#f00c;color:#fff;border-radius:50%;font-size:1.25rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:.7}.file-preview-remove:hover{opacity:1;transform:scale(1.1)}.file-uploader-toast{position:fixed;bottom:2rem;right:2rem;padding:1rem 1.5rem;border-radius:8px;background:#000000e6;color:#fff;box-shadow:0 4px 20px #0000004d;z-index:10000;opacity:0;transform:translateY(20px);transition:all .3s ease;max-width:400px}.file-uploader-toast.show{opacity:1;transform:translateY(0)}.file-uploader-toast.error{background:#ff4444f2}.lightbox{position:fixed;top:0;left:0;right:0;bottom:0;z-index:100000;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;pointer-events:none}.lightbox-visible{opacity:1;pointer-events:all}.lightbox-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000f2;cursor:pointer}.lightbox-container{position:relative;max-width:90vw;max-height:90vh;z-index:1}.lightbox-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.lightbox-image{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:4px;box-shadow:0 8px 40px #00000080}.lightbox-caption{color:#fff;font-size:1rem;text-align:center;padding:.5rem 1rem;background:#000000b3;border-radius:4px;max-width:600px}.lightbox-counter{position:absolute;top:1rem;right:1rem;color:#fff;background:#000000b3;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500}.lightbox-close{position:absolute;top:1rem;right:1rem;width:48px;height:48px;border:none;background:#ffffff1a;color:#fff;border-radius:50%;font-size:2rem;line-height:1;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lightbox-close:hover{background:#fff3;transform:scale(1.1)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border:none;background:#ffffff1a;color:#fff;border-radius:50%;font-size:2rem;line-height:1;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lightbox-nav:hover{background:#fff3;transform:translateY(-50%) scale(1.1)}.lightbox-prev{left:1rem}.lightbox-next{right:1rem}.reaction-picker{position:fixed;z-index:1000;opacity:0;transform:scale(.9);transition:all .2s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.reaction-picker-visible{opacity:1;transform:scale(1);pointer-events:all}.reaction-picker-content{background:#000000f2;border:1px solid rgba(255,255,255,.2);border-radius:28px;padding:.5rem;display:flex;gap:.25rem;box-shadow:0 8px 30px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.reaction-button{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem .75rem;border:none;background:transparent;color:#fff;cursor:pointer;border-radius:20px;transition:all .2s ease;min-width:44px}.reaction-button:hover{background:#ffffff1a;transform:scale(1.2)}.reaction-emoji{font-size:1.5rem;line-height:1}.reaction-label{font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;opacity:.8}.reaction-display{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.reaction-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;border-radius:20px;font-size:.875rem;cursor:pointer;transition:all .2s ease;color:#fffc}.reaction-badge:hover{background:#ffffff1a;border-color:#ffffff4d;transform:scale(1.05)}.reaction-badge.user-reacted{background:#00d4ff33;border-color:#00d4ff66;color:#00d4ff}.reaction-badge.user-reacted:hover{background:#00d4ff4d;border-color:#00d4ff99}.reaction-badge .reaction-emoji{font-size:1rem;line-height:1}.reaction-badge .reaction-count{font-size:.75rem;font-weight:600}.pdf-viewer-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:100000;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.pdf-viewer-visible{opacity:1;display:flex}.pdf-viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;cursor:pointer;z-index:-1}.pdf-viewer-container{position:relative;width:90vw;height:90vh;max-width:1200px;background:#1a1a1a;border-radius:12px;overflow:hidden;box-shadow:0 8px 40px #00000080;display:flex;flex-direction:column;z-index:1}.pdf-viewer-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1)}.pdf-viewer-title{font-size:1rem;font-weight:600;color:#fff;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 60px)}.pdf-viewer-close{width:40px;height:40px;border:none;background:#ffffff1a;color:#fff;border-radius:50%;font-size:1.5rem;line-height:1;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.pdf-viewer-close:hover{background:#fff3;transform:scale(1.1)}.pdf-viewer-content{flex:1;overflow:hidden;background:#2a2a2a;position:relative;display:flex;align-items:center;justify-content:center}.pdf-viewer-frame{width:100%;height:100%;border:none;background:#fff}.pdf-viewer-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:#0000004d;border-top:1px solid rgba(255,255,255,.1);gap:1rem}.pdf-viewer-counter{color:#ffffffb3;font-size:.875rem;font-weight:500}.pdf-viewer-nav{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border:none;background:#00000080;color:#fff;font-size:2.5rem;line-height:1;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;border-radius:50%;padding:0}.pdf-viewer-nav:hover{background:#000000b3;transform:translateY(-50%) scale(1.1)}.pdf-viewer-prev{left:1rem}.pdf-viewer-next{right:1rem}.pdf-viewer-download{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#00d4ff33;color:#00d4ff;border:1px solid rgba(0,212,255,.3);border-radius:6px;text-decoration:none;font-size:.875rem;font-weight:500;transition:all .2s ease;cursor:pointer}.pdf-viewer-download:hover{background:#00d4ff4d;border-color:#00d4ff80;transform:translateY(-1px)}.pdf-viewer-download:before{content:"⬇";font-size:1.125rem}@media (max-width: 768px){.file-uploader-preview{grid-template-columns:1fr}.lightbox-image{max-width:95vw;max-height:70vh}.lightbox-nav,.lightbox-close{width:40px;height:40px;font-size:1.5rem}.reaction-picker-content{padding:.375rem}.reaction-button{padding:.375rem .5rem;min-width:36px}.reaction-emoji{font-size:1.25rem}.reaction-label{display:none}.pdf-viewer-container{width:95vw;height:95vh;margin:2.5vh auto;border-radius:8px}.pdf-viewer-header{padding:.75rem 1rem}.pdf-viewer-title{font-size:.875rem}.pdf-viewer-close{width:36px;height:36px;font-size:1.25rem}.pdf-viewer-download{font-size:.8125rem;padding:.5rem 1rem}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.file-preview-item{animation:slideUp .3s ease}.lightbox{animation:fadeIn .3s ease}.reaction-badge:active{animation:pulse .3s ease}.forum-container{min-height:100vh;background:var(--bg-primary);padding-top:80px}.forum-header{background:linear-gradient(135deg,#00d4ff0d,#0000);border-bottom:1px solid var(--border-primary);padding:3rem 2rem 2rem;max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:2rem}.forum-header-content{flex:1}.forum-breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.875rem;margin-bottom:1rem;color:var(--text-tertiary)}.forum-breadcrumb a{color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.forum-breadcrumb a:hover{color:var(--accent-primary)}.breadcrumb-separator{color:var(--text-disabled)}.breadcrumb-current{color:var(--text-primary);font-weight:500}.forum-header h1{font-size:2.5rem;font-weight:800;margin-bottom:.5rem;background:linear-gradient(135deg,var(--accent-primary) 0%,#ffffff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.forum-subtitle{color:var(--text-secondary);font-size:1.125rem;font-weight:400;margin:0;line-height:1.6}.btn-new-post{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:12px;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-md);transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-new-post:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-new-post svg{flex-shrink:0}.forum-main{max-width:1400px;margin:0 auto;padding:2rem;display:grid;grid-template-columns:280px 1fr;gap:2rem;align-items:start}.forum-sidebar{position:sticky;top:100px;display:flex;flex-direction:column;gap:1.5rem}.sidebar-section{background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow-sm);transition:all .3s ease}.sidebar-section:hover{box-shadow:var(--shadow-md)}.sidebar-title{display:flex;align-items:center;gap:.625rem;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:1rem}.sidebar-title svg{color:var(--accent-primary);flex-shrink:0}.categories-sidebar{display:flex;flex-direction:column;gap:.5rem}.category-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:10px;background:transparent;border:1px solid transparent;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-decoration:none;color:var(--text-primary)}.category-item:hover{background:var(--surface-hover);border-color:var(--border-secondary);transform:translate(4px)}.category-item.active{background:linear-gradient(135deg,#00d4ff1a,#00d4ff0d);border-color:var(--accent-primary)}.category-icon{font-size:1.25rem;flex-shrink:0}.category-info{flex:1;min-width:0}.category-name{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-count{font-size:.8125rem;color:var(--text-tertiary)}.sidebar-stats{background:linear-gradient(135deg,rgba(0,212,255,.05) 0%,transparent 100%)}.stat-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem 0;border-bottom:1px solid var(--border-primary)}.stat-item:last-child{border-bottom:none;padding-bottom:0}.stat-item:first-child{padding-top:0}.stat-value{font-size:1.875rem;font-weight:800;background:linear-gradient(135deg,var(--accent-primary) 0%,#ffffff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.stat-label{font-size:.8125rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.loading-sidebar{text-align:center;padding:1rem;color:var(--text-tertiary);font-size:.875rem}.forum-content{display:flex;flex-direction:column;gap:1.5rem}.forum-toolbar{background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:16px;padding:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;box-shadow:var(--shadow-sm);position:sticky;top:80px;z-index:10;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.toolbar-left{display:flex;align-items:baseline;gap:1rem}.toolbar-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em}.post-count{font-size:.875rem;color:var(--text-tertiary);font-weight:500}.toolbar-right{display:flex;align-items:center;gap:1rem}.view-options{display:flex;gap:.5rem;background:var(--bg-secondary);padding:.375rem;border-radius:12px;border:1px solid var(--border-primary)}.view-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.view-btn:hover{color:var(--text-primary);background:var(--surface-hover)}.view-btn.active{background:var(--accent-primary);color:#000;box-shadow:0 2px 8px #00d4ff4d}.view-btn svg{flex-shrink:0}.search-box{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:1rem;color:var(--text-tertiary);pointer-events:none}.search-input{padding:.625rem 1rem .625rem 2.75rem;border:1px solid var(--border-primary);border-radius:12px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;font-weight:500;width:280px;transition:all .2s cubic-bezier(.4,0,.2,1)}.search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00d4ff1a;width:320px}.search-input::placeholder{color:var(--text-tertiary)}.posts-list{display:flex;flex-direction:column;gap:1rem;width:100%;margin-top:1.5rem}.post-card{background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.post-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:transparent;transition:background .3s ease}.post-card:hover{background:var(--surface-secondary);border-color:var(--border-secondary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.post-card:hover:before{background:var(--accent-primary)}.post-card.pinned{border-color:#eab30866;background:linear-gradient(135deg,rgba(234,179,8,.08) 0%,transparent 100%)}.post-card.pinned:before{background:#eab308}.post-card.unread{border-left:3px solid var(--accent-primary)}.post-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.post-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem;line-height:1.4;letter-spacing:-.01em;transition:color .2s ease}.post-card:hover .post-title{color:var(--accent-primary)}.post-author-section{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.post-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#000;flex-shrink:0;box-shadow:0 2px 8px #00d4ff4d}.post-author-info{flex:1;min-width:0}.post-author{font-weight:600;color:var(--text-primary);font-size:.9375rem}.post-meta{display:flex;align-items:center;gap:.75rem;font-size:.8125rem;color:var(--text-tertiary);margin-top:.25rem;flex-wrap:wrap}.post-meta-item{display:flex;align-items:center;gap:.375rem}.post-meta-separator{color:var(--text-disabled)}.post-badges{display:flex;gap:.5rem;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:8px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1px solid}.badge-pinned{background:#eab30826;color:#fde047;border-color:#eab3084d}.badge-locked{background:#9ca3af26;color:#d1d5db;border-color:#9ca3af4d}.badge-solved{background:#22c55e26;color:#86efac;border-color:#22c55e4d}.badge-hot{background:#ef444426;color:#fca5a5;border-color:#ef44444d;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.post-excerpt{color:var(--text-secondary);line-height:1.7;margin:1rem 0;font-size:.9375rem}.post-category-tag{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:8px;font-size:.8125rem;font-weight:600;background:var(--surface-secondary);color:var(--accent-primary);border:1px solid var(--border-secondary);margin-bottom:.75rem}.post-stats{display:flex;align-items:center;gap:1.5rem;padding-top:1rem;border-top:1px solid var(--border-primary);font-size:.875rem;color:var(--text-secondary)}.post-stat{display:flex;align-items:center;gap:.5rem;transition:color .2s ease}.post-stat:hover{color:var(--accent-primary)}.post-stat-icon{font-size:1.125rem}.post-stat-value{font-weight:600;color:var(--text-primary)}.post-stat-label{color:var(--text-tertiary)}.post-last-activity{margin-left:auto;display:flex;align-items:center;gap:.5rem;color:var(--text-tertiary);font-size:.8125rem}.post-last-activity svg{width:16px;height:16px}.forum-list-view,.forum-detail-view{display:flex;flex-direction:column;gap:1.5rem}.detail-breadcrumb{margin-bottom:1.5rem}.breadcrumb-back{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:12px;color:var(--text-primary);text-decoration:none;font-weight:600;font-size:.9375rem;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.breadcrumb-back:hover{background:var(--surface-secondary);border-color:var(--border-secondary);transform:translate(-4px);box-shadow:var(--shadow-md)}.breadcrumb-back svg{flex-shrink:0;transition:transform .2s ease}.breadcrumb-back:hover svg{transform:translate(-2px)}.post-card-link{text-decoration:none;color:inherit;display:block}.post-card-link:focus{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:16px}.post-detail{margin-bottom:2rem;background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow-sm)}.post-detail-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-primary)}.post-detail-title{font-size:2rem;font-weight:800;color:var(--text-primary);margin-bottom:1rem;line-height:1.3;letter-spacing:-.02em}.post-detail-content{line-height:1.8;color:var(--text-primary);font-size:1.0625rem}.post-detail-content h1,.post-detail-content h2,.post-detail-content h3,.post-detail-content h4,.post-detail-content h5,.post-detail-content h6{color:var(--text-primary);margin:2rem 0 1rem;font-weight:700;line-height:1.3;letter-spacing:-.01em}.post-detail-content h1{font-size:1.875rem}.post-detail-content h2{font-size:1.5rem}.post-detail-content h3{font-size:1.25rem}.post-detail-content p{margin-bottom:1rem}.post-detail-content a{color:var(--accent-primary);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;transition:all .2s ease}.post-detail-content a:hover{color:var(--accent-secondary);text-decoration-thickness:2px}.post-detail-content code{background:var(--surface-secondary);color:var(--accent-primary);padding:.25rem .5rem;border-radius:6px;font-family:JetBrains Mono,Fira Code,Courier New,monospace;font-size:.9em;border:1px solid var(--border-primary)}.post-detail-content pre{background:var(--bg-secondary);padding:1.5rem;border-radius:12px;overflow-x:auto;border:1px solid var(--border-primary);margin:1.5rem 0;box-shadow:var(--shadow-sm)}.post-detail-content pre code{background:transparent;padding:0;border:none;color:var(--text-primary)}.post-detail-content blockquote{border-left:4px solid var(--accent-primary);padding-left:1.5rem;margin:1.5rem 0;color:var(--text-secondary);font-style:italic}.post-detail-content ul,.post-detail-content ol{margin:1rem 0;padding-left:2rem}.post-detail-content li{margin-bottom:.5rem}.replies-section{background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:16px;padding:2rem;box-shadow:var(--shadow-sm)}.replies-section h3{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:var(--text-primary);letter-spacing:-.01em}.replies-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.reply-thread{position:relative;margin-left:calc(var(--reply-depth, 0) * 2.5rem);margin-top:.75rem}.reply-thread[data-depth="0"]{margin-left:0}.reply-thread[data-depth="1"]{--reply-depth: 1}.reply-thread[data-depth="2"]{--reply-depth: 2}.reply-thread[data-depth="3"]{--reply-depth: 3}.reply-thread[data-depth="4"]{--reply-depth: 4}.reply-thread[data-depth="5"]{--reply-depth: 5}.reply-connector{position:absolute;left:-1rem;top:0;width:1rem;height:2.5rem;border-left:2px solid var(--border-primary);border-bottom:2px solid var(--border-primary);border-bottom-left-radius:8px;opacity:.5;transition:opacity .2s ease}.reply-thread:hover>.reply-item>.reply-connector{opacity:1;border-color:var(--accent-primary)}.reply-item{position:relative;background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:12px;padding:1rem;transition:all .2s ease}.reply-item:hover{background:var(--surface-secondary);border-color:var(--border-secondary);box-shadow:var(--shadow-sm)}.reply-thread[data-depth="0"] .reply-item:before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:transparent;border-radius:12px 0 0 12px;transition:background .2s ease}.reply-thread[data-depth="0"] .reply-item:hover:before{background:var(--accent-primary)}.reply-content-wrapper{width:100%}.reply-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.reply-author-section{display:flex;align-items:center;gap:.75rem}.reply-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;color:#000;flex-shrink:0;box-shadow:0 2px 4px #00d4ff33}.reply-author{font-weight:600;color:var(--text-primary);font-size:.9375rem}.reply-author.admin{color:#fde047}.reply-time{font-size:.8125rem;color:var(--text-tertiary)}.reply-text{color:var(--text-primary);line-height:1.7;font-size:.9375rem;margin-bottom:.75rem}.reply-text p{margin-bottom:.75rem}.reply-text p:last-child{margin-bottom:0}.reply-actions{display:flex;gap:1rem;margin-top:.75rem;align-items:center}.reply-button{display:inline-flex;align-items:center;gap:.375rem;background:transparent;border:none;color:var(--text-secondary);font-weight:600;font-size:.875rem;cursor:pointer;padding:.375rem .75rem;border-radius:8px;transition:all .2s ease}.reply-button:hover{background:var(--surface-tertiary);color:var(--accent-primary)}.reply-button svg{flex-shrink:0}.continue-thread{margin-left:12.5rem;margin-top:.75rem}.continue-thread-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:12px;color:var(--accent-primary);text-decoration:none;font-weight:600;font-size:.9375rem;transition:all .2s ease;box-shadow:var(--shadow-sm)}.continue-thread-link:hover{background:var(--surface-secondary);border-color:var(--accent-primary);transform:translate(4px);box-shadow:var(--shadow-md)}.nested-reply-form{margin-top:1rem;padding:1rem;background:var(--surface-secondary);border:1px solid var(--border-secondary);border-radius:12px;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.nested-reply-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.replying-to{font-size:.875rem;color:var(--text-tertiary);font-weight:600}.cancel-nested-reply[aria-label]{width:28px;height:28px;border:none;background:var(--surface-tertiary);color:var(--text-secondary);font-size:1.5rem;line-height:1;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:0}.cancel-nested-reply[aria-label]:hover{background:#ef444433;color:var(--error);transform:rotate(90deg)}.nested-reply-form textarea{width:100%;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;padding:.875rem 1rem;color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:vertical;min-height:100px;margin-bottom:.75rem;transition:all .2s ease}.nested-reply-form textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00d4ff1a}.nested-reply-form .form-actions{display:flex;gap:.75rem;justify-content:flex-end}.nested-reply-form .btn-secondary,.nested-reply-form .btn-primary{padding:.625rem 1.25rem;font-size:.9375rem}.reply-card{background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:12px;padding:1.5rem;transition:all .2s ease}.reply-card:hover{background:var(--surface-secondary);box-shadow:var(--shadow-sm)}.reply-content{color:var(--text-primary);line-height:1.7;font-size:.9375rem}.reply-content p{margin-bottom:.75rem}.reply-form{background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:16px;padding:1.5rem;box-shadow:var(--shadow-sm)}.reply-form textarea{width:100%;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:1rem;color:var(--text-primary);font-size:.9375rem;font-family:inherit;resize:vertical;min-height:120px;margin-bottom:1rem;transition:all .2s ease}.reply-form textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00d4ff1a}.btn-primary{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);color:#000;border:none;border-radius:12px;padding:.75rem 1.5rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #00d4ff4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00d4ff66}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--surface-primary);color:var(--text-primary);border:1px solid var(--border-primary);border-radius:12px;padding:.75rem 1.5rem;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:var(--surface-secondary);border-color:var(--border-secondary)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.loading{text-align:center;padding:4rem 2rem;color:var(--text-tertiary)}.loading:after{content:"...";animation:dots 1.5s steps(4,end) infinite}@keyframes dots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-tertiary)}.empty-state h3{font-size:1.5rem;margin-bottom:.75rem;color:var(--text-secondary)}.empty-state p{font-size:1rem;color:var(--text-tertiary)}.file-uploader-container{margin:1rem 0}.file-uploader{width:100%}.file-uploader-dropzone{border:2px dashed var(--border-secondary);border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:var(--surface-primary)}.file-uploader-dropzone:hover,.file-uploader-dropzone.dragover{border-color:var(--accent-primary);background:var(--surface-secondary)}.dropzone-content{pointer-events:none}.dropzone-icon{font-size:2rem;margin-bottom:.5rem}.dropzone-text{margin:0;color:var(--text-secondary)}.dropzone-browse{color:var(--accent-primary);text-decoration:underline;cursor:pointer;pointer-events:all}.dropzone-hint{margin:.5rem 0 0;font-size:.875rem;color:var(--text-tertiary)}.file-uploader-preview{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.file-preview-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:8px}.file-preview-image{width:60px;height:60px;object-fit:cover;border-radius:6px}.file-preview-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--surface-primary);border-radius:6px}.file-preview-info{flex:1;min-width:0}.file-preview-name{font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-size{font-size:.875rem;color:var(--text-tertiary);margin-top:.25rem}.file-preview-status{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.file-preview-error{font-size:.875rem;color:var(--error);margin-top:.25rem}.file-preview-remove{width:32px;height:32px;border:none;background:var(--surface-tertiary);color:var(--text-secondary);font-size:1.5rem;line-height:1;border-radius:6px;cursor:pointer;transition:all .2s}.file-preview-remove:hover{background:#ef444433;color:var(--error)}.post-attachments,.reply-attachments{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.post-attachment-image{max-width:200px;max-height:200px;object-fit:cover;border-radius:12px;cursor:pointer;transition:transform .2s;border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.post-attachment-image:hover{transform:scale(1.05);box-shadow:var(--shadow-md)}.post-attachment-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--surface-secondary);border:1px solid var(--border-primary);border-radius:10px;text-decoration:none;color:var(--text-primary);transition:all .2s}.post-attachment-link:hover{background:var(--surface-tertiary);border-color:var(--border-secondary)}.create-form-container{background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:16px;margin-top:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-md);overflow:hidden;max-height:0;opacity:0;transform:translateY(-20px);transition:all .3s cubic-bezier(.4,0,.2,1)}.create-form-container.active{max-height:2000px;opacity:1;transform:translateY(0)}.create-form-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-primary);background:linear-gradient(135deg,rgba(0,212,255,.05) 0%,transparent 100%)}.create-form-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em}.create-form-close{width:36px;height:36px;border:none;background:var(--surface-secondary);color:var(--text-secondary);font-size:1.75rem;line-height:1;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.create-form-close:hover{background:#ef444433;color:var(--error);transform:rotate(90deg)}.create-form{padding:1.5rem}.create-form .form-group{margin-bottom:1.25rem}.create-form .form-group:last-of-type{margin-bottom:0}.create-form label{display:block;font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.create-form input[type=text],.create-form input[type=datetime-local],.create-form select,.create-form textarea{width:100%;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:10px;padding:.875rem 1rem;color:var(--text-primary);font-size:.9375rem;font-family:inherit;transition:all .2s ease}.create-form input[type=text]:focus,.create-form input[type=datetime-local]:focus,.create-form select:focus,.create-form textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00d4ff1a}.create-form textarea{resize:vertical;min-height:120px}.create-form small{display:block;margin-top:.5rem;font-size:.8125rem;color:var(--text-tertiary);font-style:italic}.create-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-primary)}@media (max-width: 1200px){.forum-main{grid-template-columns:240px 1fr;gap:1.5rem}.search-input{width:200px}.search-input:focus{width:240px}}@media (max-width: 968px){.forum-header{flex-direction:column;align-items:flex-start}.btn-new-post{width:100%;justify-content:center}.forum-main{grid-template-columns:1fr;gap:1.5rem}.forum-sidebar{position:static;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.forum-toolbar{flex-direction:column;align-items:stretch;gap:1rem;position:static}.toolbar-left{flex-direction:column;align-items:flex-start;gap:.5rem}.toolbar-right{flex-direction:column;align-items:stretch}.view-options{justify-content:stretch}.view-btn{flex:1;justify-content:center}.search-input,.search-input:focus{width:100%}}@media (max-width: 640px){html{overflow-x:hidden}body{overflow-x:hidden;width:100%;max-width:100vw}.forum-container{padding-top:70px;overflow-x:hidden;width:100%}.forum-header{padding:1.5rem 1rem 1rem;overflow-x:hidden}.forum-header h1{font-size:1.75rem;line-height:1.2;word-wrap:break-word}.forum-subtitle{font-size:.9375rem;line-height:1.5}.forum-main{padding:1rem;overflow-x:hidden;width:100%}.forum-content{overflow-x:hidden;width:100%}.forum-sidebar{grid-template-columns:1fr}.sidebar-section{padding:1rem}.forum-toolbar{padding:1rem;border-radius:12px}.toolbar-title{font-size:1.125rem}.post-count{font-size:.8125rem}.post-card{padding:1rem;border-radius:12px;overflow-x:hidden;width:100%}.post-title{font-size:1.0625rem;line-height:1.4;word-wrap:break-word}.post-author-section{gap:.625rem;margin-bottom:.75rem}.post-avatar{width:32px;height:32px;font-size:.8125rem}.post-author{font-size:.875rem}.post-meta{font-size:.75rem}.post-excerpt{font-size:.875rem;line-height:1.6;word-wrap:break-word}.post-stats{flex-wrap:wrap;gap:.875rem;padding-top:.75rem;font-size:.8125rem}.post-stat{gap:.375rem}.view-btn span{display:none}.view-btn svg{margin:0}.view-btn{padding:.5rem}.modal-large{max-width:100%;margin:1rem}.create-form-container{border-radius:12px}.create-form-header{padding:1rem}.create-form-title{font-size:1.125rem}.create-form{padding:1rem}.create-form .form-actions{flex-direction:column-reverse}.create-form .form-actions button{width:100%;justify-content:center}.reply-thread{margin-left:calc(var(--reply-depth, 0) * .75rem);max-width:100%;overflow-x:hidden}.reply-thread[data-depth="1"]{--reply-depth: 1}.reply-thread[data-depth="2"]{--reply-depth: 2}.reply-thread[data-depth="3"],.reply-thread[data-depth="4"],.reply-thread[data-depth="5"]{--reply-depth: 3}.reply-item{padding:.875rem;overflow-x:hidden;word-wrap:break-word}.reply-text{overflow-wrap:break-word;word-break:break-word}.reply-connector{left:-.5rem;width:.5rem}.reply-actions{flex-wrap:wrap}.reply-button{font-size:.8125rem;padding:.375rem .625rem}.nested-reply-form{padding:.875rem;overflow-x:hidden}.nested-reply-form textarea{min-height:80px;width:100%;max-width:100%;box-sizing:border-box}.nested-reply-form .form-actions{flex-direction:column-reverse;gap:.5rem}.nested-reply-form .btn-secondary,.nested-reply-form .btn-primary{width:100%;justify-content:center}.continue-thread{margin-left:2.25rem}.replies-list{overflow-x:hidden;width:100%}.post-detail{padding:1rem;border-radius:12px;overflow-x:hidden;width:100%}.post-detail-header{margin-bottom:1.5rem;padding-bottom:1rem}.post-detail-title{font-size:1.5rem;line-height:1.3;word-wrap:break-word}.post-detail-content{font-size:1rem;line-height:1.7;overflow-x:hidden;word-wrap:break-word}.post-detail-content *{max-width:100%;overflow-x:auto}.post-detail-content pre{overflow-x:auto;max-width:100%}.replies-section{padding:1rem;border-radius:12px;overflow-x:hidden;width:100%}.replies-section h3{font-size:1.25rem}.reply-form{padding:1rem;border-radius:12px;overflow-x:hidden}.reply-form textarea{width:100%;max-width:100%;box-sizing:border-box}}@media (max-width: 480px){.forum-container,.forum-main,.forum-content{max-width:100vw;overflow-x:hidden}.forum-header{padding:1.25rem .75rem 1rem}.forum-header h1{font-size:1.5rem}.forum-subtitle{font-size:.875rem}.forum-main{padding:.75rem}.btn-new-post{padding:.75rem 1.25rem;font-size:.9375rem}.post-card{padding:.875rem}.post-title{font-size:1rem}.post-badge,.badge{font-size:.6875rem;padding:.3rem .6rem}.toolbar-title{font-size:1rem}.post-detail{padding:.875rem}.post-detail-title{font-size:1.25rem}.sidebar-title{font-size:.8125rem}.stat-value{font-size:1.5rem}.category-name{font-size:.875rem}.reply-thread{margin-left:calc(var(--reply-depth, 0) * .5rem)}.reply-thread[data-depth="1"]{--reply-depth: 1}.reply-thread[data-depth="2"],.reply-thread[data-depth="3"],.reply-thread[data-depth="4"],.reply-thread[data-depth="5"]{--reply-depth: 2}.reply-item{padding:.75rem;font-size:.875rem}.reply-avatar{width:28px;height:28px;font-size:.75rem}.continue-thread{margin-left:1rem}}.attachment-browser{margin-top:1.5rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.attachment-browser-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.08);background:#ffffff05}.attachment-browser-header h3{font-size:.9375rem;font-weight:600;margin:0;color:#ffffffe6}.attachment-count{font-size:.8125rem;padding:.25rem .625rem;background:#09c3;border-radius:12px;color:#09c;font-weight:500}.attachment-browser-content{padding:1rem;max-height:400px;overflow-y:auto}.attachment-browser-content::-webkit-scrollbar{width:6px}.attachment-browser-content::-webkit-scrollbar-track{background:#ffffff08;border-radius:3px}.attachment-browser-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.attachment-browser-content::-webkit-scrollbar-thumb:hover{background:#ffffff26}.attachment-browser-empty{padding:2rem 1rem;text-align:center;color:#fff6;font-size:.875rem}.attachment-browser-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:8px;margin-bottom:.5rem;transition:all .2s ease;cursor:pointer}.attachment-browser-item:last-child{margin-bottom:0}.attachment-browser-item:hover{background:#ffffff0d;border-color:#0099cc4d;transform:translate(2px)}.attachment-browser-item-icon{font-size:1.5rem;flex-shrink:0}.attachment-browser-item-preview{width:48px;height:48px;border-radius:6px;object-fit:cover;border:1px solid rgba(255,255,255,.1);flex-shrink:0}.attachment-browser-item-info{flex:1;min-width:0}.attachment-browser-item-name{font-size:.8125rem;color:#ffffffd9;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.attachment-browser-item-meta{font-size:.75rem;color:#fff6}.attachment-browser-item-meta span{margin-right:.5rem}[data-theme=light] .forum-header{background:linear-gradient(135deg,#0099cc0d,#0000)}[data-theme=light] .post-card,[data-theme=light] .reply-card,[data-theme=light] .sidebar-section,[data-theme=light] .attachment-browser{background:#fff;border-color:#0000001a}[data-theme=light] .post-card:hover,[data-theme=light] .reply-card:hover{background:#fafafa;border-color:#00000026}[data-theme=light] .attachment-browser-header{background:#00000005;border-color:#00000014}[data-theme=light] .attachment-browser-header h3{color:#000000e6}[data-theme=light] .attachment-browser-item{background:#00000005;border-color:#00000014}[data-theme=light] .attachment-browser-item:hover{background:#0000000d;border-color:#0099cc4d}[data-theme=light] .attachment-browser-item-name{color:#000000d9}[data-theme=light] .attachment-browser-item-meta{color:#00000080}[data-theme=light] .attachment-browser-empty{color:#0006}
