:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:#0a0a0f;min-height:100vh;margin:0}#root{flex-direction:column;min-height:100vh;display:flex;position:relative}.vis-tooltip{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff!important;background:#0f0f19f2!important;border:1px solid #8b5cf64d!important;border-radius:12px!important;padding:12px 16px!important;font-family:inherit!important;font-size:13px!important;box-shadow:0 8px 32px #00000080,0 0 20px #8b5cf64d!important}.vis-network{background-color:#0000!important}.vis-navigation .vis-button{color:#fff!important;background-color:#0f0f19e6!important;border:1px solid #8b5cf64d!important;border-radius:8px!important;width:28px!important;height:28px!important}.vis-navigation .vis-button:hover{background-color:#8b5cf6!important;box-shadow:0 0 15px #8b5cf680!important}.vis-label{color:#fff!important}*{box-sizing:border-box;margin:0;padding:0}:root{--space-black:#0a0a0f;--space-deep:#0d0d14;--space-surface:#0f0f19cc;--space-surface-light:#1e1e3299;--nebula-purple:#8b5cf6;--nebula-blue:#3b82f6;--nebula-pink:#ec4899;--primary:#8b5cf6;--primary-hover:#a78bfa;--primary-dark:#7c3aed;--secondary:#3b82f6;--accent:#ec4899;--success:#10b981;--danger:#ef4444;--danger-hover:#f87171;--warning:#f59e0b;--background:var(--space-black);--surface:var(--space-surface);--surface-hover:var(--space-surface-light);--border:#8b5cf633;--border-hover:#8b5cf666;--text:#fff;--text-light:#ffffffb3;--text-muted:#ffffff80;--code-bg:#1e1e32cc;--code-text:#e2e8f0;--pre-bg:#0d0d14;--pre-text:#e2e8f0;--shadow:#0006;--shadow-hover:#0009;--glow-primary:#8b5cf666;--glow-secondary:#3b82f666;--glow-accent:#ec489966;--gradient-primary:linear-gradient(135deg, var(--nebula-purple), var(--nebula-blue), var(--nebula-pink));--gradient-subtle:linear-gradient(135deg, #8b5cf61a, #3b82f61a);--gradient-card:linear-gradient(145deg, #141423e6, #0f0f19f2);--glass-bg:#0f0f19b3;--glass-border:#ffffff1a;--glass-blur:blur(10px);--transition-fast:.2s ease;--transition-normal:.3s ease;--transition-slow:.5s ease}body{background-color:var(--background);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 20%,#8b5cf626 0%,#0000 50%),radial-gradient(at 80% 80%,#ec48991a 0%,#0000 50%),radial-gradient(#3b82f614 0%,#0000 60%);position:fixed;inset:0}.neon-text{text-shadow:0 0 10px var(--glow-primary), 0 0 20px var(--glow-primary), 0 0 40px var(--glow-primary)}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);transition:all var(--transition-normal);border-radius:16px}.glass-card:hover{border-color:var(--border-hover);box-shadow:0 8px 32px #0000004d, 0 0 20px var(--glow-primary);transform:translateY(-2px)}.neon-btn{background:var(--gradient-primary);color:#fff;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 15px var(--glow-primary);border:none;border-radius:12px;padding:.75rem 1.5rem;font-weight:600;position:relative;overflow:hidden}.neon-btn:hover{box-shadow:0 6px 20px var(--glow-primary), 0 0 30px var(--glow-primary);transform:translateY(-2px)}.neon-btn:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.neon-btn:hover:before{left:100%}:focus-visible{box-shadow:0 0 0 3px var(--glow-primary);outline:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--space-deep)}::-webkit-scrollbar-thumb{background:var(--nebula-purple);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--nebula-blue)}.navbar{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:1000;background:#0a0a0fcc;position:sticky;top:0;box-shadow:0 4px 30px #0000004d}.navbar-container{justify-content:space-between;align-items:center;gap:1.5rem;max-width:1400px;margin:0 auto;padding:.75rem 1.5rem;display:flex}.navbar-brand .brand-link{transition:all var(--transition-fast);border-radius:12px;align-items:center;gap:.75rem;padding:.5rem;font-size:1.25rem;font-weight:700;text-decoration:none;display:flex}.navbar-brand .brand-link:hover{background:#8b5cf61a}.navbar-brand .brand-link.active{background:#8b5cf626}.navbar-logo{width:36px;height:36px;filter:drop-shadow(0 0 10px var(--glow-primary))}.brand-text{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.mobile-menu-btn{cursor:pointer;background:0 0;border:none;padding:.5rem;display:none}.hamburger{flex-direction:column;gap:5px;width:24px;display:flex}.hamburger span{background:var(--text);border-radius:2px;height:2px;transition:all .3s;display:block}.hamburger.open span:first-child{transform:rotate(45deg)translate(5px,5px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}.navbar-menu{flex:1;align-items:center;gap:1.5rem;display:flex}.navbar-search-container{flex:1;max-width:400px}.navbar-search{border:1px solid var(--border);transition:all var(--transition-fast);background:#0f0f19cc;border-radius:12px;align-items:center;display:flex;overflow:hidden}.navbar-search:focus-within{border-color:var(--primary);box-shadow:0 0 20px var(--glow-primary)}.navbar-search-input{color:var(--text);background:0 0;border:none;flex:1;padding:.625rem 1rem;font-size:.9rem}.navbar-search-input:focus{outline:none}.navbar-search-input::placeholder{color:var(--text-muted)}.navbar-search-btn{color:var(--text-light);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:.625rem 1rem;display:flex}.navbar-search-btn:hover{color:var(--primary)}.navbar-links{align-items:center;gap:.25rem;display:flex}.nav-link{color:var(--text-light);transition:all var(--transition-fast);border-radius:10px;padding:.5rem .875rem;font-size:.9rem;font-weight:500;text-decoration:none;position:relative}.nav-link:hover{color:var(--primary);background:#8b5cf61a}.nav-link.active{color:var(--primary);box-shadow:0 0 15px var(--glow-primary);background:#8b5cf626}.navbar-actions{align-items:center;gap:.75rem;display:flex}.nav-btn{transition:all var(--transition-fast);border-radius:10px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:500;text-decoration:none;display:flex}.btn-primary-small{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 15px var(--glow-primary)}.btn-primary-small:hover{box-shadow:0 6px 20px var(--glow-primary);transform:translateY(-2px)}.theme-toggle{border:1px solid var(--border);cursor:pointer;width:40px;height:40px;color:var(--text-light);transition:all var(--transition-fast);background:#0f0f19cc;border-radius:10px;justify-content:center;align-items:center;display:flex}.theme-toggle:hover{color:var(--primary);border-color:var(--primary);box-shadow:0 0 15px var(--glow-primary)}.user-menu{position:relative}.user-avatar{background:var(--gradient-primary);color:#fff;cursor:pointer;width:40px;height:40px;transition:all var(--transition-fast);box-shadow:0 4px 15px var(--glow-primary);border:none;border-radius:12px;font-size:1rem;font-weight:600}.user-avatar:hover{box-shadow:0 6px 25px var(--glow-primary);transform:scale(1.05)}.user-dropdown{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);width:220px;box-shadow:0 10px 40px #00000080, 0 0 20px var(--glow-primary);opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:100;background:#0f0f19f2;border-radius:16px;position:absolute;top:calc(100% + .5rem);right:0;transform:translateY(-10px)}.user-menu:hover .user-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.user-dropdown .user-info{border-bottom:1px solid var(--border);padding:1rem}.user-dropdown .user-name{color:var(--text);margin-bottom:.25rem;font-weight:600;display:block}.user-dropdown .user-email{color:var(--text-light);font-size:.8rem}.dropdown-item{text-align:left;width:100%;color:var(--text);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:.75rem 1rem;font-size:.9rem;text-decoration:none;display:block}.dropdown-item:hover{color:var(--primary);background:#8b5cf61a}.dropdown-item.logout{color:var(--danger)}.dropdown-item.logout:hover{color:var(--danger-hover);background:#ef44441a}@media (width<=1024px){.navbar-container{padding:.75rem 1rem}.navbar-links{display:none}.mobile-menu-btn{display:block}.navbar-menu{background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;align-items:stretch;gap:1rem;padding:1rem;display:none;position:absolute;top:100%;left:0;right:0}.navbar-menu.active{display:flex}.navbar-search-container{max-width:none}.navbar-links{flex-direction:column;gap:.25rem;display:flex}.nav-link{padding:.75rem 1rem}.navbar-actions{justify-content:space-between}}.main-content{z-index:1;min-height:calc(100vh - 70px);position:relative}.page-container{z-index:1;max-width:1200px;min-height:calc(100vh - 100px);margin:0 auto;padding:2rem;position:relative}.article-view-page{z-index:1;position:relative}.page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.page-header h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem}.auth-container{z-index:1;justify-content:center;align-items:center;min-height:calc(100vh - 70px);padding:2rem;display:flex;position:relative}.auth-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);box-shadow:0 20px 60px #00000080, 0 0 40px var(--glow-primary);width:100%;max-width:420px;transition:all var(--transition-normal);background:#0f0f19e6;border-radius:20px;padding:2.5rem}.auth-card:hover{box-shadow:0 25px 70px #0009, 0 0 50px var(--glow-primary);transform:translateY(-5px)}.auth-card h2{text-align:center;background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;font-size:1.75rem}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text);margin-bottom:.5rem;font-weight:500;display:block}.form-group input,.form-group textarea,.form-group select{border:1px solid var(--border);width:100%;color:var(--text);transition:all var(--transition-fast);background:#0f0f19cc;border-radius:12px;padding:.875rem 1rem;font-family:inherit;font-size:1rem}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 20px var(--glow-primary);outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.error-message{color:var(--danger);background:#ef444426;border:1px solid #ef44444d;border-radius:12px;margin-bottom:1rem;padding:.875rem 1rem;font-size:.9rem}.btn-primary,.btn-secondary,.btn-danger,.btn-logout{cursor:pointer;transition:all var(--transition-fast);border:none;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 15px var(--glow-primary)}.btn-primary:hover{box-shadow:0 6px 25px var(--glow-primary);transform:translateY(-2px)}.btn-secondary{color:var(--primary);border:1px solid var(--border);background:#8b5cf61a}.btn-secondary:hover{border-color:var(--primary);box-shadow:0 0 15px var(--glow-primary);background:#8b5cf633}.btn-danger{color:var(--danger);background:#ef44441a;border:1px solid #ef44444d}.btn-danger:hover{background:var(--danger);color:#fff;box-shadow:0 4px 15px #ef444466}.btn-logout{color:var(--danger);background:0 0;border:1px solid #ef44444d}.btn-logout:hover{border-color:var(--danger);background:#ef44441a}.btn-small{padding:.5rem 1rem;font-size:.875rem}.auth-link{text-align:center;color:var(--text-light);margin-top:1.5rem}.auth-link a{color:var(--primary);transition:all var(--transition-fast);font-weight:500;text-decoration:none}.auth-link a:hover{text-shadow:0 0 10px var(--glow-primary)}.loading{text-align:center;color:var(--text-light);padding:3rem}.empty-state{text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);background:#0f0f19b3;border-radius:16px;padding:3rem}.empty-state p{color:var(--text-light);margin-bottom:1rem}.articles-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;display:grid}.article-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);transition:all var(--transition-normal);background:#0f0f19b3;border-radius:16px;overflow:hidden}.article-card:hover{border-color:var(--primary);box-shadow:0 10px 40px #0006, 0 0 30px var(--glow-primary);transform:translateY(-5px)}.article-link{color:inherit;padding:1.5rem;text-decoration:none;display:block}.article-link h3{color:var(--text);transition:color var(--transition-fast);margin-bottom:.75rem}.article-card:hover .article-link h3{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.article-excerpt{color:var(--text-light);margin-bottom:1rem;font-size:.9rem;line-height:1.6}.article-meta{color:var(--text-muted);flex-wrap:wrap;gap:.75rem;font-size:.8rem;display:flex}.article-meta span{align-items:center;gap:.25rem;display:flex}.article-actions{border-top:1px solid var(--border);gap:.5rem;padding:1rem 1.5rem;transition:border-color .3s;display:flex}.status{border-radius:4px;padding:.25rem .5rem;font-size:.75rem;font-weight:500}.status.draft{color:#f59e0b;background:#f59e0b33;border:1px solid #f59e0b4d}.status.published{color:#10b981;background:#10b98133;border:1px solid #10b9814d}.old-revision-badge{color:#92400e;background:#fef3c7;border-radius:4px;padding:.25rem .5rem;font-size:.75rem;font-weight:500}[data-theme=dark] .old-revision-badge{color:#fef3c7;background:#78350f}.article-view-page{z-index:1;max-width:900px;margin:0 auto;padding:2rem;position:relative}.article-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;margin-bottom:2rem;padding-bottom:1.5rem;display:flex}.article-header h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:2.5rem}.article-header .article-actions{border:none;padding:0}.article-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);background:#0f0f19cc;border-radius:16px;padding:2rem;line-height:1.8}.article-content h1,.article-content h2,.article-content h3{color:var(--text);margin:1.5rem 0 1rem}.article-content p{margin-bottom:1rem}.article-content code{background:var(--code-bg);color:var(--code-text);border-radius:4px;padding:.2rem .4rem;font-size:.9em}.article-content pre{background:var(--pre-bg);color:var(--pre-text);border-radius:8px;margin:1rem 0;padding:1rem;overflow-x:auto}.article-content pre code{background:0 0;padding:0}.revisions-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);background:#0f0f19cc;border-radius:16px;margin-bottom:2rem;padding:1.5rem}.revisions-panel h3{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem}.revisions-list{flex-direction:column;gap:.5rem;display:flex}.revision-item{border:1px solid var(--border);transition:all var(--transition-fast);background:#0f0f1999;border-radius:10px;align-items:center;gap:1rem;padding:.75rem;display:flex}.revision-item:hover{border-color:var(--primary);background:#8b5cf61a}.version-number{color:var(--primary);font-weight:700}.editor,.date{color:var(--text-light);font-size:.9rem}.revision-item a{color:var(--primary);margin-left:auto;text-decoration:none}.editor-form{background:var(--surface);border-radius:12px;padding:2rem;transition:background-color .3s}.title-input{padding:1rem;font-size:1.25rem}.editor-toolbar{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.content-textarea{resize:vertical;border:1px solid var(--border);background:#0f0f19cc;border-radius:12px;min-height:400px;font-family:Fira Code,Courier New,monospace;font-size:.9rem}.markdown-preview{border:1px solid var(--border);min-height:400px;transition:all var(--transition-normal);background:#0f0f19cc;border-radius:12px;padding:1.5rem}.status-select{border:1px solid var(--border);background:var(--background);color:var(--text);border-radius:8px;padding:.75rem;font-size:1rem}.form-actions{justify-content:flex-end;gap:1rem;margin-top:1.5rem;display:flex}.pagination{justify-content:center;align-items:center;gap:1rem;margin-top:2rem;display:flex}.pagination button{border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text);border-radius:8px;padding:.5rem 1rem;transition:all .2s}.pagination button:disabled{opacity:.5;cursor:not-allowed}.home-container{min-height:calc(100vh - 70px)}.hero{text-align:center;background:linear-gradient(135deg,#8b5cf633 0%,#3b82f633 50%,#ec489933 100%);padding:5rem 2rem;position:relative;overflow:hidden}.hero:before{content:"";background:radial-gradient(#8b5cf626 0%,#0000 70%);position:absolute;inset:0}.hero h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;text-shadow:none;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;font-size:3.5rem;position:relative}.hero p{color:var(--text-light);max-width:600px;margin-bottom:2rem;margin-left:auto;margin-right:auto;font-size:1.25rem;position:relative}.hero-actions{justify-content:center;gap:1rem;display:flex;position:relative}.hero .btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 20px var(--glow-primary)}.hero .btn-secondary{color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #ffffff4d}.hero .btn-secondary:hover{background:#fff3;border-color:#ffffff80}.features{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1200px;margin:0 auto;padding:4rem 2rem;display:grid}.feature{text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);transition:all var(--transition-normal);background:#0f0f1980;border-radius:16px;padding:2rem}.feature:hover{border-color:var(--primary);box-shadow:0 10px 40px #0000004d, 0 0 30px var(--glow-primary);transform:translateY(-5px)}.feature h3{color:var(--text);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem}.feature p{color:var(--text-light);line-height:1.6}.error-state{text-align:center;padding:3rem}.error-state h2{margin-bottom:1rem}.error-state a{color:var(--primary);text-decoration:none}.search-header{margin-bottom:2rem}.search-form{gap:1rem;margin-top:1rem;display:flex}.search-input{border:1px solid var(--border);background:var(--background);color:var(--text);border-radius:8px;flex:1;padding:.75rem 1rem;font-size:1rem;transition:all .3s}.search-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #3b82f61a}.search-summary{color:var(--text-light);margin-bottom:1.5rem}.search-hint{color:var(--text-light);margin-top:1rem;font-size:.9rem}.articles-list{flex-direction:column;gap:1rem;display:flex}.articles-list .article-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);transition:all var(--transition-normal);background:#0f0f19b3;border-radius:12px;flex-direction:column;display:flex;overflow:visible}.articles-list .article-card:hover{border-color:var(--primary);box-shadow:0 5px 25px #0006, 0 0 20px var(--glow-primary);transform:translateY(-3px)translate(5px)}.articles-list .article-card .article-link{color:inherit;flex-direction:column;gap:.5rem;padding:1.25rem 1.5rem;text-decoration:none;display:flex}.articles-list .article-card h3{color:var(--text);transition:all var(--transition-fast);margin-bottom:0}.articles-list .article-card:hover h3{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.articles-list .article-card .article-meta{color:var(--text-muted);font-size:.85rem}.categories-page{z-index:1;max-width:1200px;margin:0 auto;padding:2rem;position:relative}.categories-page .page-header{margin-bottom:2rem}.categories-page .page-header h1{margin-bottom:.5rem;font-size:2rem}.categories-page .page-header p{color:var(--text-light);font-size:1.1rem}.articles-section{z-index:1;position:relative}.articles-section h2{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;font-size:1.5rem}.category-view-page{z-index:1;max-width:1200px;margin:0 auto;padding:2rem;position:relative}.category-view-page .page-header h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:2rem}.category-view-page .page-header p{color:var(--text-light);margin-bottom:.5rem}.category-view-page .page-header .article-count{color:var(--text-muted);font-size:.9rem}.category-view-page .subcategories-section{margin-bottom:2rem}.category-view-page .subcategories-section h2{margin-bottom:1rem;font-size:1.25rem}.category-view-page .articles-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.category-view-page .articles-list .article-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:inherit;background:#0f172acc;border:1px solid #94a3b81a;border-radius:16px;flex-direction:column;height:100%;padding:1.5rem;text-decoration:none;transition:all .3s;display:flex}.category-view-page .articles-list .article-card:hover{border-color:var(--primary);transform:translateY(-5px);box-shadow:0 8px 32px #0006,0 0 30px #6366f133}.category-view-page .articles-list .article-card h3{color:var(--text);margin-bottom:.75rem;font-size:1.1rem;line-height:1.4;transition:color .2s}.category-view-page .articles-list .article-card:hover h3{color:var(--primary)}.category-view-page .articles-list .article-card .article-meta{color:var(--text-muted);border-top:1px solid #94a3b81a;flex-wrap:wrap;gap:1rem;margin-top:auto;padding-top:.75rem;font-size:.85rem;display:flex}.related-articles{border-top:1px solid var(--border);margin-top:3rem;padding-top:2rem}.related-articles h3{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;font-size:1.5rem}.related-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);color:inherit;background:#0f172acc;border:1px solid #94a3b81a;border-radius:12px;flex-direction:column;gap:.5rem;padding:1.25rem;text-decoration:none;transition:all .3s;display:flex}.related-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 4px 20px #0000004d,0 0 20px #6366f126}.related-card h4{color:var(--text);margin:0;font-size:1rem;line-height:1.4}.related-card:hover h4{color:var(--primary)}.search-result-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);transition:all var(--transition-normal);background:#0f0f19b3;border-radius:16px;overflow:hidden}.search-result-item:hover{border-color:var(--primary);box-shadow:0 8px 30px #0000004d, 0 0 20px var(--glow-primary);transform:translateY(-3px)}.result-link{color:inherit;padding:1.5rem;text-decoration:none;display:block}.result-link h3{color:var(--primary);margin-bottom:.5rem}.result-excerpt{color:var(--text-light);margin-bottom:.75rem;font-size:.95rem;line-height:1.5}.result-link mark{color:inherit;background:#fef08a;border-radius:2px;padding:0 2px}[data-theme=dark] .result-link mark{color:inherit;background:#854d0e}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);text-align:center;transition:all var(--transition-normal);background:#0f0f19cc;border-radius:16px;padding:1.5rem}.stat-card:hover{border-color:var(--primary);box-shadow:0 10px 30px #0000004d, 0 0 20px var(--glow-primary);transform:translateY(-5px)}.stat-card h3{color:var(--text-light);margin-bottom:.5rem;font-size:.9rem}.stat-value{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:700}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;display:grid}.dashboard-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);transition:all var(--transition-normal);background:#0f0f19cc;border-radius:16px;padding:1.5rem}.dashboard-section:hover{box-shadow:0 10px 40px #0000004d, 0 0 20px var(--glow-primary)}.dashboard-section h2{border-bottom:1px solid var(--border);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem;padding-bottom:.75rem;font-size:1.25rem}.article-list{flex-direction:column;gap:.75rem;display:flex}.article-row{border:1px solid var(--border);color:inherit;transition:all var(--transition-fast);background:#0f0f1999;border-radius:10px;align-items:center;gap:1rem;padding:.875rem;text-decoration:none;display:flex}.article-row:hover{border-color:var(--primary);box-shadow:0 0 15px var(--glow-primary);background:#8b5cf61a}.article-row .rank{color:var(--primary);min-width:30px;font-weight:700}.article-row .article-info{flex:1}.article-row .article-info h4{color:var(--text);margin-bottom:.25rem;font-size:1rem}.article-row .article-info p{color:var(--text-light);font-size:.85rem}.article-row .views-badge{background:var(--primary);color:#fff;white-space:nowrap;border-radius:20px;padding:.25rem .75rem;font-size:.85rem}.user-list{flex-direction:column;gap:.75rem;display:flex}.user-row{background:var(--background);border-radius:8px;justify-content:space-between;align-items:center;padding:.75rem;display:flex}.user-row .user-info h4{margin-bottom:.25rem;font-size:1rem}.user-row .user-info p{color:var(--text-light);font-size:.85rem}.user-row .user-stats{color:var(--text-light);gap:1rem;font-size:.85rem;display:flex}.activity-list{flex-direction:column;gap:.75rem;display:flex}.activity-row{background:var(--background);border-radius:8px;align-items:center;gap:1rem;padding:.75rem;display:flex}.activity-row .version-badge{background:var(--secondary);color:#fff;border-radius:4px;padding:.25rem .5rem;font-size:.75rem;font-weight:700}.activity-row .activity-info{flex:1}.activity-row .activity-info a{color:var(--primary);font-weight:500;text-decoration:none}.activity-row .activity-info a:hover{text-decoration:underline}.activity-row .activity-info p{color:var(--text-light);margin-top:.25rem;font-size:.85rem}.empty-message{color:var(--text-light);text-align:center;padding:1rem}@media (width<=900px){.dashboard-grid{grid-template-columns:1fr}}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.category-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);color:inherit;transition:all var(--transition-normal);background:#0f0f19b3;border-radius:16px;align-items:center;gap:1rem;padding:1.5rem;text-decoration:none;display:flex}.category-card:hover{border-color:var(--primary);box-shadow:0 10px 40px #0006, 0 0 30px var(--glow-primary);transform:translateY(-5px)}.category-icon{color:#fff;width:60px;height:60px;box-shadow:0 4px 15px var(--glow-primary);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:flex}.category-info h3{color:var(--text);transition:all var(--transition-fast);margin-bottom:.25rem}.category-card:hover .category-info h3{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.category-info p{color:var(--text-light);margin-bottom:.5rem;font-size:.85rem;line-height:1.5}.article-count{color:var(--text-muted);font-size:.8rem}.category-view-page .page-header{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--border);background:#0f0f19cc;border-radius:16px;margin-bottom:2rem;padding:2rem}.category-view-page .back-link{color:var(--primary);transition:all var(--transition-fast);margin-bottom:1rem;font-size:.9rem;text-decoration:none;display:inline-block}.category-view-page .back-link:hover{text-shadow:0 0 10px var(--glow-primary)}.category-view-page .article-count{color:var(--text-light)}.subcategories-section{margin-bottom:2rem}.subcategories-section h2{margin-bottom:1rem}.subcategories-list{flex-wrap:wrap;gap:.5rem;display:flex}.subcategory-tag{border:1px solid var(--border);color:var(--text);transition:all var(--transition-fast);background:#8b5cf61a;border-radius:20px;padding:.5rem 1rem;font-size:.9rem;text-decoration:none}.subcategory-tag:hover{border-color:var(--primary);box-shadow:0 0 15px var(--glow-primary);background:#8b5cf633}.series-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;display:grid}.series-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);color:inherit;transition:all var(--transition-normal);background:#0f0f19b3;border-radius:16px;text-decoration:none;overflow:hidden}.series-card:hover{border-color:var(--primary);box-shadow:0 10px 40px #0006, 0 0 30px var(--glow-primary);transform:translateY(-5px)}.series-thumbnail{background:var(--gradient-primary);justify-content:center;align-items:center;height:120px;display:flex;position:relative;overflow:hidden}.series-thumbnail:before{content:"";background:linear-gradient(45deg,#ffffff1a 0%,#0000 50%);position:absolute;inset:0}.series-thumbnail img{object-fit:cover;width:100%;height:100%}.series-placeholder{color:#fff;text-shadow:0 2px 10px #0000004d;font-size:3rem;font-weight:700}.series-info{padding:1.5rem}.series-info h3{color:var(--text);transition:all var(--transition-fast);margin-bottom:.5rem}.series-card:hover .series-info h3{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.series-info p{color:var(--text-light);margin-bottom:1rem;font-size:.9rem;line-height:1.5}.series-meta{color:var(--text-muted);gap:.75rem;margin-bottom:.5rem;font-size:.8rem;display:flex}.difficulty-badge{color:#fff;border-radius:4px;padding:.25rem .5rem;font-size:.75rem;font-weight:500}.series-creator{color:var(--text-light);font-size:.8rem}.series-list-page,.series-view-page{z-index:1;max-width:1200px;margin:0 auto;padding:2rem;position:relative}.series-list-page .page-header,.series-view-page .page-header{margin-bottom:2rem}.series-list-page .page-header h1,.series-view-page .page-header h1{margin-bottom:.5rem;font-size:2rem}.series-list-page .page-header p,.series-view-page .page-header p{color:var(--text-light);font-size:1.1rem}.series-view-page .series-header{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid var(--border);background:#0f0f19cc;border-radius:16px;margin-bottom:2rem;padding:2rem}.series-view-page .back-link{color:var(--primary);transition:all var(--transition-fast);margin-bottom:1rem;font-size:.9rem;text-decoration:none;display:inline-block}.series-view-page .back-link:hover{text-shadow:0 0 10px var(--glow-primary)}.series-view-page h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem}.enrollment-section{border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1.5rem}.progress-bar-container{border:1px solid var(--border);background:#0f0f19cc;border-radius:4px;height:8px;margin-bottom:.5rem;overflow:hidden}.progress-bar{background:var(--gradient-primary);height:100%;box-shadow:0 0 10px var(--glow-primary);transition:width .3s}.progress-text{color:var(--text-light);margin-bottom:1rem;font-size:.9rem;display:block}.series-article-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);transition:all var(--transition-normal);background:#0f0f19b3;border-radius:16px;align-items:center;gap:1rem;margin-bottom:.75rem;padding:1rem 1.5rem;display:flex}.series-article-card:hover{border-color:var(--primary);box-shadow:0 5px 20px #0000004d, 0 0 15px var(--glow-primary)}.series-article-card.completed{opacity:.8}.series-article-card .article-order{background:var(--gradient-primary);color:#fff;width:36px;height:36px;box-shadow:0 4px 15px var(--glow-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.series-article-card.completed .article-order{background:var(--success);box-shadow:0 4px 15px #10b98166}.series-article-card .article-content{flex:1}.series-article-card .article-content h3{color:var(--text);margin-bottom:.25rem;font-size:1rem}.series-article-card .article-content .owner{color:var(--text-light);font-size:.85rem}.series-article-card .article-actions{align-items:center;gap:.5rem;display:flex}.complete-badge{color:var(--success);font-weight:500}.btn-outline{border:1px solid var(--border);color:var(--text);background:0 0}.btn-outline:hover{background:var(--code-bg)}.knowledge-graph-page{max-width:1400px;margin:0 auto;padding:2rem}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:60vh;display:flex}.loading-spinner{border:4px solid #8b5cf633;border-top-color:var(--primary);width:50px;height:50px;box-shadow:0 0 20px var(--glow-primary);border-radius:50%;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.graph-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.graph-title h1{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.25rem;font-size:2rem}.graph-title p{color:var(--text-light)}.graph-stats{gap:2rem;display:flex}.stat-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);transition:all var(--transition-fast);background:#0f0f19cc;border-radius:12px;flex-direction:column;align-items:center;padding:.75rem 1.5rem;display:flex}.stat-item:hover{box-shadow:0 0 20px var(--glow-primary);border-color:var(--primary)}.stat-number{color:var(--primary);font-size:1.5rem;font-weight:700}.stat-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.graph-controls-bar{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.graph-btn{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:var(--text);border-radius:8px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;transition:all .2s;display:flex}.graph-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.graph-btn.disabled{opacity:.5}.graph-btn.disabled:hover{background:var(--surface);color:var(--text);border-color:var(--border)}.graph-controls-info{color:var(--text-light);gap:1.5rem;margin-left:auto;font-size:.85rem;display:flex}.graph-main-container{gap:1rem;display:flex}.graph-network-container{background:var(--surface);box-shadow:0 4px 20px var(--shadow);border-radius:16px;flex:1;height:70vh;min-height:500px;position:relative;overflow:hidden}.graph-sidebar{flex-direction:column;gap:1rem;width:280px;display:flex}.category-legend,.graph-help{background:var(--surface);box-shadow:0 2px 8px var(--shadow);border-radius:12px;padding:1.25rem}.category-legend h3,.graph-help h3{border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.5rem;font-size:1rem}.legend-item{align-items:center;gap:.75rem;padding:.5rem 0;font-size:.9rem;display:flex}.legend-color{border-radius:50%;flex-shrink:0;width:16px;height:16px}.graph-help ul{margin:0;padding:0;list-style:none}.graph-help li{color:var(--text-light);align-items:center;gap:.5rem;padding:.4rem 0;font-size:.85rem;display:flex}.graph-help li:before{content:"→";color:var(--primary)}.node-detail-card{background:var(--surface);z-index:100;border-radius:16px;width:320px;animation:.3s slideUp;position:fixed;bottom:2rem;right:2rem;overflow:hidden;box-shadow:0 8px 32px #0003}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:space-between;align-items:center;padding:1rem;display:flex}.card-type{color:#fff;text-transform:uppercase;letter-spacing:.5px;background:#fff3;border-radius:20px;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.card-close{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:1.5rem;transition:background .2s;display:flex}.card-close:hover{background:#fff3}.node-detail-card h3{border-bottom:1px solid var(--border);padding:1rem;font-size:1.1rem}.card-body{padding:1rem}.card-info-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:.5rem 0;display:flex}.info-label{color:var(--text-light);font-size:.85rem}.info-value{font-size:.9rem;font-weight:500}.card-tags{padding:.75rem 0}.tags-list{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.tag-item{background:var(--code-bg);color:var(--text-light);border-radius:20px;padding:.25rem .75rem;font-size:.8rem}.card-action-btn{text-align:center;border-radius:8px;width:100%;margin-top:1rem;padding:.75rem;font-weight:500;text-decoration:none;transition:all .2s;display:block}.card-action-btn.primary{background:var(--primary);color:#fff}.card-action-btn.primary:hover{background:var(--primary-hover)}@media (width<=900px){.graph-main-container{flex-direction:column}.graph-sidebar{flex-flow:wrap;width:100%}.category-legend,.graph-help{flex:1;min-width:200px}.node-detail-card{width:auto;bottom:1rem;left:1rem;right:1rem}.graph-controls-info{display:none}}.home-section{max-width:1200px;margin:0 auto;padding:2rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.section-header h2{font-size:1.5rem}.view-all{color:var(--primary);font-size:.9rem;text-decoration:none}.categories-scroll{gap:.75rem;padding-bottom:1rem;display:flex;overflow-x:auto}.category-chip{background:var(--surface);color:var(--text);white-space:nowrap;box-shadow:0 1px 3px var(--shadow);border-radius:25px;align-items:center;gap:.5rem;padding:.75rem 1.25rem;text-decoration:none;transition:all .2s;display:flex}.category-chip:hover{background:var(--code-bg)}.cat-dot{border-radius:50%;width:8px;height:8px}.cat-count{color:var(--text-light);background:var(--code-bg);border-radius:10px;padding:.1rem .4rem;font-size:.8rem}.series-scroll{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;display:grid}.series-mini-card{background:var(--surface);color:inherit;box-shadow:0 1px 3px var(--shadow);border-radius:12px;padding:1.25rem;text-decoration:none;transition:all .2s}.series-mini-card:hover{box-shadow:0 4px 12px var(--shadow-hover);transform:translateY(-2px)}.series-mini-header{margin-bottom:.75rem}.series-mini-card h3{color:var(--text);margin-bottom:.25rem;font-size:1rem}.series-mini-card p{color:var(--text-light);font-size:.85rem}.articles-list-mini{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.article-mini-card{background:var(--surface);color:inherit;box-shadow:0 1px 3px var(--shadow);border-radius:12px;padding:1rem 1.25rem;text-decoration:none;transition:all .2s}.article-mini-card:hover{box-shadow:0 4px 12px var(--shadow-hover);transform:translateY(-2px)}.article-mini-card h3{color:var(--text);margin-bottom:.5rem;font-size:1rem}.article-mini-meta{color:var(--text-light);gap:1rem;font-size:.8rem;display:flex}.graph-cta{text-align:center;color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:12px;margin:2rem auto;padding:4rem 2rem}.graph-cta h2{margin-bottom:.5rem}.graph-cta p{opacity:.9;margin-bottom:1.5rem}.graph-cta .btn-primary{color:var(--primary);background:#fff}.category-badge{background:var(--surface);color:var(--cat-color,var(--primary));border-radius:20px;align-items:center;gap:.5rem;margin-top:.5rem;padding:.25rem .75rem;font-size:.85rem;text-decoration:none;display:inline-flex}.article-tags{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.tag-badge{background:var(--code-bg);color:var(--text-light);border-radius:15px;padding:.25rem .75rem;font-size:.8rem}.related-articles{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);background:#0f0f19cc;border-radius:16px;margin-top:2rem;padding:1.5rem}.related-articles h3{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:1rem}.related-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.related-card{border:1px solid var(--border);color:inherit;transition:all var(--transition-fast);background:#0f0f1999;border-radius:12px;padding:1rem;text-decoration:none}.related-card:hover{border-color:var(--primary);box-shadow:0 0 15px var(--glow-primary);background:#8b5cf61a}.related-card h4{color:var(--primary);margin-bottom:.25rem;font-size:.95rem}.related-card .views{color:var(--text-light);font-size:.8rem}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.tags-input-container{position:relative}.selected-tags{flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;display:flex}.tag-chip{background:var(--primary);color:#fff;border-radius:15px;align-items:center;gap:.5rem;padding:.25rem .5rem .25rem .75rem;font-size:.85rem;display:flex}.tag-chip button{color:#fff;cursor:pointer;background:0 0;border:none;padding:0;font-size:1rem;line-height:1}.tag-search-input{border:1px solid var(--border);background:var(--background);width:100%;color:var(--text);border-radius:8px;padding:.75rem;font-size:1rem}.tag-suggestions{background:var(--surface);border:1px solid var(--border);box-shadow:0 4px 12px var(--shadow);z-index:10;border-radius:8px;position:absolute;top:100%;left:0;right:0}.tag-suggestion{text-align:left;cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;padding:.75rem;transition:background-color .2s;display:block}.tag-suggestion:hover{background:var(--code-bg)}
