:root{--accent: #007bff;--accent-dark: #0056b3;--accent-light: rgba(0, 123, 255, .08);--bg: #ffffff;--bg-secondary: #f4f4f2;--bg-hover: #eeeeec;--border: rgba(0, 0, 0, .09);--border-strong: rgba(0, 0, 0, .18);--text: #1a1a1a;--text-muted: #6b6b6b;--text-light: #9b9b9b;--radius: 8px;--radius-lg: 12px;--max-width: 1080px;--sidebar-width: 260px;--header-height: 52px;--shadow-card: 0 1px 4px rgba(0, 0, 0, .06);--shadow-card-hover: 0 8px 28px rgba(0, 0, 0, .1)}[data-theme=dark]{--accent: #4d9fff;--accent-dark: #2a85f0;--accent-light: rgba(77, 159, 255, .12);--bg: #18181c;--bg-secondary: #111114;--bg-hover: rgba(255, 255, 255, .05);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .16);--text: #e6e6ec;--text-muted: #888896;--text-light: #505060;--shadow-card: 0 1px 4px rgba(0, 0, 0, .3);--shadow-card-hover: 0 8px 28px rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;background:var(--bg-secondary);color:var(--text);line-height:1.55;min-height:100vh}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{font-family:inherit;cursor:pointer}textarea,input,select{font-family:inherit}.container{max-width:var(--max-width);margin:0 auto;padding:0 16px}.page-wrap{display:grid;grid-template-columns:1fr var(--sidebar-width);gap:20px;padding:20px 0 40px;align-items:start}.page-wrap--full{grid-template-columns:1fr;max-width:720px;margin:0 auto}.header{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200;height:var(--header-height)}.header__inner{display:flex;align-items:center;gap:0;height:100%}.header__logo{font-size:17px;font-weight:800;letter-spacing:-.5px;color:var(--text);flex-shrink:0;margin-right:28px}.header__logo span{color:var(--accent)}.header__nav{display:flex;align-items:center;gap:2px;flex:1}.header__nav-link{display:inline-block;padding:6px 12px;border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--text-muted);transition:background .12s,color .12s}.header__nav-link:hover{background:var(--bg-hover);color:var(--text)}.header__nav-link.active{color:var(--text);background:var(--bg-hover)}.header__right{display:flex;align-items:center;gap:8px;margin-left:auto}.user-menu{position:relative}.user-menu__trigger{display:flex;align-items:center;gap:7px;padding:4px 8px 4px 4px;border-radius:20px;border:1px solid var(--border);background:none;font-size:13px;font-weight:500;color:var(--text);transition:background .12s}.user-menu__trigger:hover{background:var(--bg-hover)}.user-menu__dropdown{position:absolute;right:0;top:calc(100% + 6px);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);min-width:180px;padding:4px;box-shadow:0 4px 16px #00000014;display:none;z-index:300}.user-menu--open .user-menu__dropdown{display:block}.user-menu__item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border-radius:6px;font-size:14px;color:var(--text);background:none;border:none;text-align:left;transition:background .1s}.user-menu__item:hover{background:var(--bg-hover)}.user-menu__item--danger{color:#dc3545}.user-menu__item--danger:hover{background:#dc354512}.user-menu__sep{height:1px;background:var(--border);margin:4px 0}.hamburger{display:none;flex-direction:column;gap:5px;padding:6px;border:none;background:none;border-radius:var(--radius)}.hamburger span{display:block;width:20px;height:2px;background:var(--text);border-radius:2px}.hamburger:hover{background:var(--bg-hover)}.mobile-nav{display:none;position:fixed;top:var(--header-height);left:0;right:0;bottom:0;background:var(--bg);z-index:199;padding:12px 16px;flex-direction:column;gap:4px;overflow-y:auto}.mobile-nav--open{display:flex}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:14px;font-weight:500;border:none;transition:background .12s,opacity .12s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-dark);color:#fff}.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border-strong)}.btn-outline:hover:not(:disabled){background:var(--bg-hover)}.btn-ghost{background:transparent;color:var(--text-muted);border:none;padding:6px 10px}.btn-ghost:hover{background:var(--bg-hover);color:var(--text)}.btn-tg{background:#229ed9;color:#fff}.btn-tg:hover{background:#1a86bb;color:#fff}.btn-danger-ghost{background:transparent;color:#dc3545;border:none;padding:4px 8px;font-size:13px}.btn-danger-ghost:hover{background:#dc354512}.btn-sm{padding:5px 12px;font-size:13px}.btn-xs{padding:3px 8px;font-size:12px}.badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500;white-space:nowrap}.badge-proxy{background:#d4edda;color:#155724}.badge-vpn{background:#cce5ff;color:#004085}.badge-security{background:#e2d9f3;color:#4b2a7e}.badge-tools{background:#fff3cd;color:#856404}.badge-other{background:var(--bg-secondary);color:var(--text-muted)}.avatar{flex-shrink:0;border-radius:50%;background:var(--accent);color:#fff;font-weight:600;display:flex;align-items:center;justify-content:center;overflow:hidden;-webkit-user-select:none;user-select:none}.avatar img{width:100%;height:100%;object-fit:cover}.avatar--24{width:24px;height:24px;font-size:10px}.avatar--32{width:32px;height:32px;font-size:12px}.avatar--40{width:40px;height:40px;font-size:15px}.avatar--64{width:64px;height:64px;font-size:22px}.avatar--80{width:80px;height:80px;font-size:28px}.content-card{background:var(--bg);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden}.article-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;will-change:transform}.article-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card-hover);border-color:var(--border-strong)}.article-card--pinned{border-top:3px solid var(--accent)}.article-card--pinned:hover{box-shadow:0 8px 28px #007bff1f}.article-card__meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-bottom:10px}.article-card__author-wrap{display:flex;align-items:center;gap:6px}.article-card__author{font-size:13px;font-weight:500;color:var(--text)}.article-card__author:hover{color:var(--accent)}.article-card__sep{color:var(--border-strong);font-size:12px}.article-card__time{font-size:13px;color:var(--text-muted)}.article-card__title{font-size:18px;font-weight:700;line-height:1.3;margin-bottom:8px;letter-spacing:-.2px}.article-card__title a:hover{color:var(--accent)}.article-card__excerpt{font-size:14px;color:var(--text-muted);line-height:1.5;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-card__footer{display:flex;align-items:center;gap:4px}.article-card__spacer{flex:1}.stat-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 9px;border-radius:6px;font-size:13px;color:var(--text-muted);background:none;border:none;transition:background .1s,color .1s}.stat-btn:hover{background:var(--bg-hover);color:var(--text)}.stat-btn svg{flex-shrink:0}.tab-bar{display:flex;align-items:center;border-bottom:1px solid var(--border);background:var(--bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:0 8px}.tab-btn{padding:14px 14px 13px;font-size:14px;font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s;white-space:nowrap}.tab-btn:hover{color:var(--text)}.tab-btn--active{color:var(--text);border-bottom-color:var(--accent)}.cat-pills{display:flex;flex-wrap:wrap;gap:6px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg)}.cat-pill{padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500;border:1px solid var(--border-strong);background:var(--bg);color:var(--text-muted);transition:all .12s}.cat-pill:hover{border-color:var(--accent);color:var(--accent)}.cat-pill--active{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.sidebar{display:flex;flex-direction:column;gap:12px}.sidebar-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.sidebar-card__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:12px}.tg-widget{text-align:center}.tg-widget__count{font-size:26px;font-weight:800;letter-spacing:-1px}.tg-widget__label{font-size:13px;color:var(--text-muted);margin-bottom:12px}.cat-list{display:flex;flex-direction:column;gap:2px}.cat-list__item{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-radius:6px;font-size:14px;color:var(--text);transition:background .1s}.cat-list__item:hover{background:var(--bg-hover)}.cat-list__count{font-size:13px;color:var(--text-muted)}.write-cta{text-align:center}.write-cta p{font-size:13px;color:var(--text-muted);margin-bottom:10px;line-height:1.4}.article-page{padding:0}.article-draft-bar{display:flex;align-items:center;gap:10px;padding:10px 28px;background:#fff8e1;border-bottom:1px solid #ffe082;font-size:14px;color:#7c5e00}[data-theme=dark] .article-draft-bar{background:#ffe0821a;border-color:#ffe08240;color:#fcd34d}.article-page-header{padding:28px 32px 20px}.article-page-meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:14px}.article-page-meta__sep{color:var(--text-light);font-size:11px}.article-page-meta__item{font-size:13px;color:var(--text-muted)}.article-title{font-size:28px;font-weight:800;line-height:1.22;letter-spacing:-.5px;margin-bottom:20px;color:var(--text)}.article-byline{display:flex;align-items:center;gap:10px}.article-byline__info{flex:1}.article-byline__author{font-size:15px;font-weight:700}.article-byline__author a:hover{color:var(--accent)}.article-byline__meta{font-size:13px;color:var(--text-muted);margin-top:2px}.article-byline__actions{display:flex;align-items:center;gap:6px;margin-left:auto}.article-page-body{padding:24px 32px 8px}.article-page-bottom{padding:0 32px}.article-page-related{padding:0 32px;margin-bottom:0}.article-page-comments{padding:0 32px 32px}.article-body{font-size:16px;line-height:1.8;color:var(--text);margin-bottom:28px}.article-body p{margin-bottom:18px}.article-body p:last-child{margin-bottom:0}.article-body--rich h1,.article-body--rich h2,.article-body--rich h3{font-weight:800;line-height:1.25;letter-spacing:-.3px;margin-top:32px;margin-bottom:12px;color:var(--text)}.article-body--rich h1{font-size:26px}.article-body--rich h2{font-size:21px}.article-body--rich h3{font-size:17px}.article-body--rich h1:first-child,.article-body--rich h2:first-child,.article-body--rich h3:first-child{margin-top:0}.article-body--rich strong{font-weight:700}.article-body--rich em{font-style:italic}.article-body--rich s{text-decoration:line-through;opacity:.7}.article-body--rich ul,.article-body--rich ol{margin:0 0 18px 24px;padding:0}.article-body--rich li{margin-bottom:5px}.article-body--rich ul{list-style-type:disc}.article-body--rich ol{list-style-type:decimal}.article-body--rich blockquote{border-left:3px solid var(--accent);margin:20px 0;padding:10px 18px;color:var(--text-muted);font-style:italic;background:var(--accent-light);border-radius:0 var(--radius) var(--radius) 0}.article-body--rich blockquote p{margin-bottom:0}.article-body--rich code{font-family:SF Mono,Fira Code,Fira Mono,Menlo,Consolas,monospace;font-size:.88em;background:#0000000f;padding:2px 6px;border-radius:4px;color:#c7254e}.article-body--rich pre{background:#1e1e2e;color:#cdd6f4;border-radius:var(--radius);padding:18px 20px;margin:20px 0;overflow-x:auto;font-size:14px;line-height:1.65}.article-body--rich pre code{background:none;color:inherit;padding:0;font-size:inherit;border-radius:0}.article-body--rich hr{border:none;border-top:1px solid var(--border-strong);margin:28px 0}.rich-editor{border:1px solid var(--border-strong);border-radius:var(--radius);overflow:hidden;transition:border-color .12s}.rich-editor--focused{border-color:var(--accent)}.rich-editor__toolbar{display:flex;align-items:center;gap:1px;padding:6px 8px;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-wrap:wrap}.tb-btn{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:30px;padding:0 6px;border:none;background:none;border-radius:5px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s}.tb-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.tb-btn--active,.tb-btn--active:hover{background:var(--accent-light);color:var(--accent)}.tb-btn:disabled{opacity:.3;cursor:default}.tb-btn--italic{font-style:italic}.tb-btn--strike{text-decoration:line-through}.tb-sep{width:1px;height:20px;background:var(--border);margin:0 4px;flex-shrink:0}.rich-editor__content{background:var(--bg)}.rich-editor__area{min-height:320px;padding:18px 20px;font-size:16px;line-height:1.8;color:var(--text);outline:none}.rich-editor__area p.is-editor-empty:first-child:before{content:"Начните писать вашу статью...";color:var(--text-light);pointer-events:none;float:left;height:0}.rich-editor__area h1,.rich-editor__area h2,.rich-editor__area h3{font-weight:800;line-height:1.25;letter-spacing:-.3px;margin-top:24px;margin-bottom:8px}.rich-editor__area h1{font-size:26px}.rich-editor__area h2{font-size:21px}.rich-editor__area h3{font-size:17px}.rich-editor__area h1:first-child,.rich-editor__area h2:first-child,.rich-editor__area h3:first-child{margin-top:0}.rich-editor__area p{margin-bottom:10px}.rich-editor__area p:last-child{margin-bottom:0}.rich-editor__area ul,.rich-editor__area ol{margin:0 0 10px 24px}.rich-editor__area li{margin-bottom:4px}.rich-editor__area blockquote{border-left:3px solid var(--accent);margin:16px 0;padding:8px 16px;color:var(--text-muted);font-style:italic;background:var(--accent-light);border-radius:0 var(--radius) var(--radius) 0}.rich-editor__area code{font-family:SF Mono,Fira Code,Menlo,Consolas,monospace;font-size:.88em;background:#0000000f;padding:2px 6px;border-radius:4px;color:#c7254e}.rich-editor__area pre{background:#1e1e2e;color:#cdd6f4;border-radius:var(--radius);padding:14px 16px;margin:12px 0;overflow-x:auto;font-size:14px;line-height:1.6}.rich-editor__area pre code{background:none;color:inherit;padding:0}.rich-editor__area hr{border:none;border-top:1px solid var(--border-strong);margin:20px 0}.rich-editor__area strong{font-weight:700}.rich-editor__area em{font-style:italic}.vote-bar{display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:8px 6px;box-shadow:var(--shadow-card);width:46px}.vote-btn{width:34px;height:34px;border-radius:var(--radius);border:none;background:transparent;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:background .12s,color .12s;flex-shrink:0}.vote-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.vote-btn--up.vote-btn--active{color:var(--accent);background:var(--accent-light)}.vote-btn--down.vote-btn--active{color:#dc3545;background:#dc354514}.vote-btn:disabled{opacity:.4;cursor:default}.vote-score{font-size:13px;font-weight:700;min-width:34px;text-align:center;padding:3px 0;color:var(--text);-webkit-user-select:none;user-select:none;letter-spacing:-.2px}.vote-score--pos{color:var(--accent)}.vote-score--neg{color:#dc3545}.article-layout{display:flex;align-items:flex-start;gap:14px}.article-vote-aside{flex-shrink:0}.article-vote-sticky{position:sticky;top:calc(var(--header-height) + 20px)}.article-main{flex:1;min-width:0}.article-vote-mobile{display:none}.related{margin-bottom:32px}.related__title{font-size:15px;font-weight:700;margin-bottom:12px}.related__list{display:flex;flex-direction:column;gap:10px}.related-item{display:flex;align-items:flex-start;gap:10px;padding:10px;border-radius:var(--radius);border:1px solid var(--border);transition:background .1s}.related-item:hover{background:var(--bg-hover)}.related-item__body{flex:1}.related-item__title{font-size:14px;font-weight:500;line-height:1.3;margin-bottom:3px}.related-item__title a:hover{color:var(--accent)}.related-item__meta{font-size:12px;color:var(--text-muted)}.comments__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.comments__title{font-size:17px;font-weight:700}.comments__count{color:var(--text-muted);font-weight:400}.comment-compose{margin-bottom:24px}.comment-compose__inner{display:flex;gap:10px;align-items:flex-start}.comment-compose__input{flex:1;border:1px solid var(--border-strong);border-radius:var(--radius);padding:10px 12px;font-size:14px;line-height:1.5;resize:none;min-height:80px;background:var(--bg);color:var(--text);transition:border-color .12s}.comment-compose__input:focus{outline:none;border-color:var(--accent)}.comment-compose__footer{display:flex;justify-content:flex-end;margin-top:8px}.comment-item{display:flex;gap:10px;padding:14px 0;border-bottom:1px solid var(--border)}.comment-item:last-child{border-bottom:none}.comment-item__body{flex:1;min-width:0}.comment-item__header{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-bottom:6px}.comment-item__author{font-size:13px;font-weight:600}.comment-item__author:hover{color:var(--accent)}.comment-item__time{font-size:12px;color:var(--text-muted)}.comment-item__text{font-size:15px;line-height:1.55;word-break:break-word}.comment-item__actions{display:flex;align-items:center;gap:4px;margin-top:8px}.comment-replies{margin-left:34px;border-left:2px solid var(--border);padding-left:16px;margin-top:6px}.reply-compose{margin:8px 0 4px}.reply-compose__input{width:100%;border:1px solid var(--border-strong);border-radius:var(--radius);padding:8px 10px;font-size:14px;resize:none;min-height:64px;background:var(--bg);color:var(--text);transition:border-color .12s}.reply-compose__input:focus{outline:none;border-color:var(--accent)}.reply-compose__footer{display:flex;justify-content:flex-end;gap:6px;margin-top:6px}.guest-comment{padding:16px;background:var(--bg-secondary);border-radius:var(--radius);font-size:14px;color:var(--text-muted);text-align:center}.guest-comment a{color:var(--accent)}.form-group{margin-bottom:18px}.form-label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.form-input,.form-select{width:100%;padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:15px;background:var(--bg);color:var(--text);transition:border-color .12s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent)}.form-input--error{border-color:#dc3545}.form-error{font-size:13px;color:#dc3545;margin-top:4px}.form-textarea{width:100%;padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:15px;background:var(--bg);color:var(--text);resize:vertical;line-height:1.6;transition:border-color .12s}.form-textarea:focus{outline:none;border-color:var(--accent)}.article-title-input{width:100%;border:none;border-bottom:2px solid var(--border);font-size:26px;font-weight:800;padding:6px 0 12px;background:transparent;color:var(--text);letter-spacing:-.5px;transition:border-color .12s}.article-title-input:focus{outline:none;border-bottom-color:var(--accent)}.article-title-input::placeholder{color:var(--text-muted);font-weight:400}.form-actions{display:flex;align-items:center;gap:10px;margin-top:24px}.form-actions__right{margin-left:auto}.pagination{display:flex;gap:4px;justify-content:center;padding:20px 0}.page-btn{min-width:36px;padding:6px 10px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:14px;background:var(--bg);color:var(--text);transition:all .1s;text-align:center}.page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.page-btn--active{background:var(--accent);border-color:var(--accent);color:#fff}.page-btn:disabled{opacity:.4;cursor:default}.profile-hero{display:flex;align-items:flex-start;gap:18px;padding:24px;border-bottom:1px solid var(--border)}.profile-hero__info{flex:1}.profile-hero__name{font-size:22px;font-weight:800;letter-spacing:-.3px;margin-bottom:2px}.profile-hero__username{font-size:14px;color:var(--text-muted);margin-bottom:8px}.profile-hero__bio{font-size:14px;color:var(--text-muted);line-height:1.5;margin-bottom:12px}.profile-stats{display:flex;gap:20px}.profile-stat__val{font-size:18px;font-weight:700}.profile-stat__label{font-size:12px;color:var(--text-muted)}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);padding:20px}.auth-box{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px;width:100%;max-width:400px}.auth-box__logo{font-size:20px;font-weight:800;margin-bottom:24px;letter-spacing:-.3px}.auth-box__logo span{color:var(--accent)}.auth-divider{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--text-light);font-size:13px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-footer{text-align:center;font-size:14px;color:var(--text-muted);margin-top:18px}.auth-footer a{color:var(--accent);font-weight:500}.auth-error-tg{display:flex;align-items:center;gap:8px;font-size:13px;color:#dc3545;background:#dc354514;border:1px solid rgba(220,53,69,.2);border-radius:var(--radius);padding:10px 12px;margin-bottom:14px}.empty{padding:48px 24px;text-align:center;color:var(--text-muted)}.empty__icon{font-size:40px;margin-bottom:12px;opacity:.4}.empty__title{font-size:17px;font-weight:600;margin-bottom:6px;color:var(--text)}.empty__text{font-size:14px}.write-page{padding:28px 32px}.write-page__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.write-page__title{font-size:18px;font-weight:700}.sidebar-sticky{position:sticky;top:calc(var(--header-height) + 16px);display:flex;flex-direction:column;gap:12px}.back-to-top{position:fixed;bottom:28px;right:28px;width:40px;height:40px;border-radius:50%;background:var(--text);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:500;transition:background .15s,transform .15s;box-shadow:0 2px 12px #0003}.back-to-top:hover{background:var(--accent);transform:translateY(-2px)}.fade-enter-active,.fade-leave-active{transition:opacity .2s}.fade-enter-from,.fade-leave-to{opacity:0}.header-search{display:flex;align-items:center;margin-right:8px}.header-search__icon{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:none;border-radius:var(--radius);color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s}.header-search__icon:hover{background:var(--bg-hover);color:var(--text)}.header-search__form{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border-strong);border-radius:var(--radius);padding:5px 10px;width:240px;transition:border-color .12s}.header-search--open .header-search__form{border-color:var(--accent)}.header-search__input{border:none;background:none;outline:none;font-size:14px;color:var(--text);flex:1;min-width:0}.header-search__input::placeholder{color:var(--text-light)}.header-search__close{border:none;background:none;color:var(--text-muted);cursor:pointer;font-size:13px;padding:0;line-height:1;flex-shrink:0}.header-search__close:hover{color:var(--text)}.search-page-bar{margin-bottom:20px}.search-page-bar__inner{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:10px 16px;transition:border-color .12s}.search-page-bar__inner:focus-within{border-color:var(--accent)}.search-page-bar__input{flex:1;border:none;outline:none;font-size:16px;color:var(--text);background:none}.search-page-bar__input::placeholder{color:var(--text-light)}.search-empty{text-align:center;padding:60px 24px;color:var(--text-muted)}.search-empty .empty__icon{font-size:48px;margin-bottom:14px;opacity:.5}.search-empty .empty__title{font-size:18px;font-weight:700;margin-bottom:6px;color:var(--text)}.search-empty .empty__text{font-size:14px}.search-meta{font-size:14px;color:var(--text-muted);margin-bottom:14px}.search-meta strong{color:var(--text)}.search-section-title{display:flex;align-items:center;gap:7px;padding:13px 20px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);background:#fafafa}.search-users{display:flex;flex-direction:column}.search-user-card{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--border);transition:background .1s}.search-user-card:last-child{border-bottom:none}.search-user-card:hover{background:var(--bg-hover)}.search-user-card__info{flex:1;min-width:0}.search-user-card__name{font-size:15px;font-weight:600;margin-bottom:2px;display:flex;align-items:center;gap:6px}.search-user-card__username{font-size:13px;color:var(--text-muted);margin-bottom:3px}.search-user-card__bio{font-size:13px;color:var(--text-muted);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.search-user-card__stat{text-align:center;flex-shrink:0;font-size:13px;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:1px}.search-user-card__stat strong{font-size:18px;font-weight:700;color:var(--text)}.search-article{padding:18px 20px;border-bottom:1px solid var(--border)}.search-article:last-child{border-bottom:none}.search-article__meta{display:flex;align-items:center;gap:7px;margin-bottom:8px;flex-wrap:wrap}.search-article__author{font-size:13px;font-weight:500;color:var(--text)}.search-article__author:hover{color:var(--accent)}.search-article__title{font-size:18px;font-weight:700;line-height:1.3;margin-bottom:6px;letter-spacing:-.2px}.search-article__title a:hover{color:var(--accent)}.search-article__excerpt{font-size:14px;color:var(--text-muted);line-height:1.5;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-article__footer{display:flex;gap:4px}mark{background:#007bff26;color:var(--accent);border-radius:2px;padding:0 1px;font-weight:inherit}.article-tag{display:inline-block;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:500;color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border);transition:color .1s,border-color .1s,background .1s;white-space:nowrap}.article-tag:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-light)}.article-tag--lg{font-size:13px;padding:4px 12px}.article-card__tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.article-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.tag-filter-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--accent-light);border-bottom:1px solid var(--border);font-size:14px;color:var(--text)}.tag-filter-bar__clear{border:none;background:none;color:var(--text-muted);font-size:13px;cursor:pointer;padding:2px 6px;border-radius:4px}.tag-filter-bar__clear:hover{background:var(--bg-hover);color:var(--text)}.tag-input{border:1px solid var(--border-strong);border-radius:var(--radius);background:var(--bg);cursor:text;transition:border-color .12s}.tag-input:focus-within{border-color:var(--accent)}.tag-input__inner{display:flex;flex-wrap:wrap;gap:6px;padding:8px 10px;min-height:42px;align-items:center}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px 3px 10px;background:var(--accent-light);color:var(--accent);border:1px solid rgba(0,123,255,.25);border-radius:20px;font-size:13px;font-weight:500;white-space:nowrap}.tag-chip__remove{border:none;background:none;color:var(--accent);cursor:pointer;font-size:15px;line-height:1;padding:0 1px;opacity:.7;transition:opacity .1s}.tag-chip__remove:hover{opacity:1}.tag-input__field{border:none;outline:none;font-size:14px;color:var(--text);background:transparent;min-width:120px;flex:1}.tag-input__field::placeholder{color:var(--text-light)}.tag-input__hint{padding:0 10px 7px;font-size:11px;color:var(--text-light)}.article-card__cover-wrap{display:block;overflow:hidden;max-height:240px}.article-card__cover{width:100%;height:240px;object-fit:cover;display:block;transition:transform .35s ease}.article-card:hover .article-card__cover{transform:scale(1.04)}.article-card__body{padding:18px 22px 16px}.article-card{padding:0}.article-cover{overflow:hidden;max-height:400px;margin-bottom:0}.article-cover img{width:100%;height:400px;object-fit:cover;display:block;transition:transform .4s ease}.article-cover:hover img{transform:scale(1.015)}.cover-preview{margin-top:10px;border-radius:var(--radius);overflow:hidden;max-height:180px}.cover-preview img{width:100%;height:180px;object-fit:cover;display:block}.bookmark-btn{gap:5px}.bookmark-btn--active{color:var(--accent)}.bookmark-btn--active:hover{color:var(--accent);background:var(--accent-light)}.article-actions-bar{display:flex;align-items:center;gap:4px;padding:10px 0;border-top:1px solid var(--border);margin-bottom:28px}.article-actions-bar__spacer{flex:1}.article-actions-bar__views,.article-actions-bar__comments{display:inline-flex;align-items:center;gap:5px;padding:5px 8px;border-radius:6px;font-size:13px;color:var(--text-muted);transition:background .1s,color .1s}.article-actions-bar__comments:hover{background:var(--bg-hover);color:var(--accent)}.admin-shell{display:flex;min-height:100vh;background:var(--bg-secondary)}.admin-sidebar{width:220px;flex-shrink:0;background:#1a1a2e;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.admin-sidebar__logo{display:flex;align-items:center;gap:8px;padding:20px 16px 16px;font-size:17px;font-weight:800;color:#fff;letter-spacing:-.5px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:8px}.admin-sidebar__logo a{color:#fff}.admin-sidebar__logo span{color:var(--accent)}.admin-sidebar__badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;background:#ffffff26;color:#ffffffe6;border:1px solid rgba(255,255,255,.25);padding:2px 7px;border-radius:4px}.admin-nav{padding:4px 8px;flex:1}.admin-nav__item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;font-size:14px;font-weight:500;color:#fff9;transition:background .1s,color .1s;margin-bottom:2px;border:none;background:none;width:100%;text-align:left;cursor:pointer;text-decoration:none;position:relative}.admin-nav__item:hover{background:#ffffff12;color:#ffffffe6}.admin-nav__item.active{background:#007bff33;color:#fff}.admin-nav__badge{margin-left:auto;background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:1px 5px;border-radius:10px;min-width:18px;text-align:center}.admin-sidebar__footer{padding:8px;border-top:1px solid rgba(255,255,255,.08)}.admin-main{flex:1;min-width:0;display:flex;flex-direction:column}.admin-header{background:var(--bg);border-bottom:1px solid var(--border);padding:0 28px;height:52px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.admin-header__title{font-size:16px;font-weight:700;color:var(--text)}.admin-header__user{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-muted)}.admin-content{padding:24px 28px;flex:1}.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.admin-stat-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px}.admin-stat-card--warn .admin-stat-card__val{color:#f59e0b}.admin-stat-card--danger .admin-stat-card__val{color:#ef4444}.admin-stat-card--danger{border-color:#ef44444d}.admin-stat-card__val{font-size:32px;font-weight:800;letter-spacing:-1px;margin-bottom:4px;color:var(--text)}.admin-stat-card__label{font-size:13px;color:var(--text-muted)}.admin-stat-card__sub{font-size:12px;color:var(--text-muted);margin-top:2px}.admin-stat-card__sub--link{color:var(--accent);text-decoration:none}.admin-stat-card__sub--link:hover{text-decoration:underline}.admin-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.admin-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.admin-card__header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;font-size:14px;font-weight:700;color:var(--text);border-bottom:1px solid var(--border)}.admin-card__link{font-size:13px;font-weight:500;color:var(--accent);text-decoration:none}.admin-table{width:100%;border-collapse:collapse;font-size:14px;color:var(--text)}.admin-table--full{display:table}.admin-table th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:10px 18px;background:var(--bg-secondary);border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:12px 18px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-hover)}.admin-table__link{color:var(--text);font-weight:500;text-decoration:none}.admin-table__link:hover{color:var(--accent)}.row--banned td{opacity:.65}.admin-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px}.admin-search{flex:1;max-width:360px;padding:8px 12px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:14px;background:var(--bg);color:var(--text)}.admin-search:focus{outline:none;border-color:var(--accent)}.admin-select{padding:8px 12px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:14px;background:var(--bg);color:var(--text)}.admin-select:focus{outline:none;border-color:var(--accent)}.admin-role-select{padding:4px 8px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:13px;background:var(--bg);color:var(--text);cursor:pointer}.admin-tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:4px;width:fit-content}.admin-tab{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-muted);border:none;background:none;cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.admin-tab:hover{background:var(--bg-hover);color:var(--text)}.admin-tab.active{background:var(--accent);color:#fff}.admin-tab__count{background:#ffffff40;padding:0 5px;border-radius:10px;font-size:11px;font-weight:700}.admin-tab:not(.active) .admin-tab__count{background:var(--bg-secondary);color:var(--text-muted)}.role-pill{display:inline-block;padding:2px 8px;border-radius:20px;font-size:12px;font-weight:600}.role-pill--admin{background:#fff3cd;color:#856404}.role-pill--moderator{background:#cce5ff;color:#004085}.role-pill--user{background:var(--bg-secondary);color:var(--text-muted)}.role-pill--banned{background:#fee2e2;color:#dc2626}.status-pill{display:inline-block;padding:2px 8px;border-radius:20px;font-size:12px;font-weight:600}.status-pill--published{background:#d4edda;color:#155724}.status-pill--draft{background:#fff3cd;color:#856404}.action-pill{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:var(--bg-secondary);color:var(--text-muted)}.action-pill--ban,.action-pill--delete_user,.action-pill--delete_article,.action-pill--delete_comment{background:#fee2e2;color:#dc2626}.action-pill--unban,.action-pill--resolve_report{background:#d4edda;color:#155724}.action-pill--change_role{background:#dbeafe;color:#1d4ed8}.action-pill--dismiss_report{background:#f3f4f6;color:#6b7280}.action-pill--toggle_article{background:#fef9c3;color:#854d0e}.admin-user-cell{display:flex;align-items:center;gap:10px}.admin-comment-body{font-size:13px;color:var(--text-muted);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.admin-back{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);text-decoration:none}.admin-back:hover{color:var(--text)}.detail-row{display:flex;align-items:baseline;gap:12px;padding:8px 0;border-bottom:1px solid var(--border);font-size:14px;color:var(--text)}.detail-row:last-of-type{border-bottom:none}.detail-row__label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;min-width:110px;flex-shrink:0}.admin-pagination{display:flex;gap:4px;padding:16px 18px;border-top:1px solid var(--border)}.admin-pagination__btn{padding:5px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;background:var(--bg);color:var(--text);cursor:pointer;text-decoration:none}.admin-pagination__btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.admin-pagination__btn.disabled{opacity:.4;pointer-events:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;min-width:360px;max-width:480px;width:100%;box-shadow:0 20px 60px #0003}.modal__title{font-size:16px;font-weight:700;margin-bottom:16px;color:var(--text)}.modal__label{font-size:13px;color:var(--text-muted);margin-bottom:6px;display:block}.modal__input{width:100%;padding:9px 12px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:14px;background:var(--bg-secondary);color:var(--text);font-family:inherit}.modal__input:focus{outline:none;border-color:var(--accent)}.modal__actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.btn-danger{background:#ef4444;color:#fff;border:1px solid transparent;padding:8px 16px;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:background .12s}.btn-danger:hover{background:#dc2626}.btn-secondary{background:var(--bg-secondary);color:var(--text);border:1px solid var(--border-strong);padding:8px 16px;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;font-family:inherit}.btn-secondary:hover{background:var(--bg-hover)}.btn-warn-ghost{border:1px solid rgba(245,158,11,.4);color:#d97706;background:#f59e0b14;padding:8px 16px;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;transition:background .12s}.btn-warn-ghost.btn-sm{padding:5px 12px;font-size:13px}.btn-warn-ghost.btn-xs{padding:3px 8px;font-size:12px}.btn-warn-ghost:hover{background:#f59e0b24}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);cursor:pointer;color:var(--text-muted);transition:all .12s}.btn-icon--warn:hover{border-color:#f59e0b;color:#d97706;background:#f59e0b14}.btn-icon--ok:hover{border-color:#22c55e;color:#16a34a;background:#22c55e14}.btn-icon--danger:hover{border-color:#ef4444;color:#dc2626;background:#ef444414}.report-inline{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.report-inline__input{padding:5px 10px;border:1px solid var(--border-strong);border-radius:var(--radius);font-size:13px;background:var(--bg-secondary);color:var(--text);font-family:inherit;min-width:200px}.report-inline__input:focus{outline:none;border-color:var(--accent)}.share-btn--report{color:var(--text-muted)}.share-btn--report:hover{border-color:#f59e0b;color:#d97706}.share-btn--danger{border-color:#ef4444;color:#fff;background:#ef4444}.share-btn--danger:hover{background:#dc2626}.share-btn--danger:disabled{opacity:.5;cursor:default}.avatar--48{width:48px;height:48px;border-radius:50%;background:var(--accent-light);color:var(--accent);font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.avatar--48 img{width:100%;height:100%;object-fit:cover}.feed-col{display:flex;flex-direction:column;gap:12px;min-width:0}.card-vote-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:20px;border:1px solid var(--border-strong);background:var(--bg-secondary);font-size:13px;font-weight:700;color:var(--text-muted);transition:all .14s;white-space:nowrap;line-height:1}.card-vote-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.card-vote-btn--pos{color:var(--accent);border-color:#007bff59;background:var(--accent-light)}.card-vote-btn--neg{color:#e53e3e;border-color:#e53e3e59;background:#e53e3e12}.article-card__pin-badge{display:flex;align-items:center;gap:6px;padding:6px 16px;background:var(--accent-light);border-bottom:1px solid rgba(0,123,255,.14);font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.06em}.badge-tech{background:#dbeafe;color:#1d4ed8}.badge-guides{background:#d1fae5;color:#065f46}.badge-news{background:#fef9c3;color:#854d0e}[data-theme=dark] .badge-tech{background:#1d4ed833;color:#93c5fd}[data-theme=dark] .badge-guides{background:#065f4640;color:#6ee7b7}[data-theme=dark] .badge-news{background:#854d0e33;color:#fcd34d}[data-theme=dark] .badge-security{background:#4b2a7e40;color:#c4b5fd}[data-theme=dark] .badge-tools{background:#85640433;color:#fde68a}[data-theme=dark] .badge-other{background:#ffffff0f;color:var(--text-muted)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:none;border-radius:var(--radius);color:var(--text-muted);cursor:pointer;transition:background .12s,color .12s;flex-shrink:0}.theme-toggle:hover{background:var(--bg-hover);color:var(--text)}@media(max-width:800px){.page-wrap{grid-template-columns:1fr}.sidebar,.header__nav{display:none}.hamburger{display:flex}.article-page-header{padding:20px 16px 16px}.article-page-body{padding:16px 16px 8px}.article-page-bottom,.article-page-related{padding:0 16px}.article-page-comments{padding:0 16px 20px}.article-title{font-size:22px}.article-cover img{height:220px}.article-cover{max-height:220px}.article-vote-aside{display:none}.article-vote-mobile{display:flex;align-items:center;padding:8px 0 2px;border-top:1px solid var(--border);margin-top:-8px;margin-bottom:8px}.article-vote-mobile .vote-bar{flex-direction:row;width:auto;border:none;background:transparent;box-shadow:none;padding:0;gap:4px}.article-vote-mobile .vote-score{padding:0 4px}.write-page{padding:20px 16px}.auth-box{padding:24px 20px}.profile-hero{padding:16px}.article-card__body{padding:14px 16px 12px}.article-card__title{font-size:16px}.article-card__cover{height:180px}.article-card__cover-wrap{max-height:180px}.feed-col{gap:10px}.article-card:hover{transform:none}}
