.alert{position:fixed;top:60px;right:20px;padding:15px 25px;border-radius:8px;z-index:1000;box-shadow:0 4px 12px rgba(0,0,0,0.15);opacity:0;transform:translateY(-20px);transition:all .3s ease;max-width:300px;font-size:14px;display:flex;align-items:center}
.alert.show{opacity:1;transform:translateY(0)}
.alert-success{background:#4CAF50;color:white;border-left:4px solid #2E7D32}
.dark-theme .alert-success{background:#408442}
.alert-error{background:#F44336;color:white;border-left:4px solid #C62828}
.dark-theme .alert-error{background:#b3332a}
.alert-icon{margin-right:10px;font-size:20px}
.post{background:#fff;border-radius:8px;padding:15px;margin-bottom:20px;box-shadow:0 1px 5px rgba(0,0,0,0.15);position:relative}
.post-author{border:1px solid transparent}
.post-author:hover{transition:.2s;border-bottom:1px solid;opacity:.75}
.dark-theme .post{background:#2d2d2d}
.post-avatar{width:40px;height:40px;border-radius:50%;margin-right:10px!important;cursor:pointer!important;box-shadow:unset!important;object-fit:cover;vertical-align:middle}
.post-content{margin:10px 0!important;font-size:1em!important;max-height:1400px;overflow:auto;position:relative;transition:max-height .5s ease-out;padding-bottom:10px;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word}
.post-content img{transition:.2s}
.post-content img:hover{cursor:zoom-in;opacity:.75}
.comment .post-content{border-bottom:1px solid #e5e5e5}
.dark-theme .comment .post-content{border-bottom:1px solid #555}
.post-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid #e0e0e0;padding-top:10px}
.dark-theme .post-footer{border-color:#444}
.comments-container{max-height:0;overflow:hidden;transition:max-height .3s ease-out;margin-top:0}
.comments-container.show{max-height:fit-content;transition:max-height .5s ease-in;margin-top:15px}
.comment{background:#f7f7f7;border-radius:8px;padding:10px;margin:20px 0;border:1px solid #eee;box-shadow:0 1px 4px rgba(0,0,0,.1);position:relative}
.comment:first-child{margin-top:10px}
.delete-comment-form{text-align:right}
.comment-children{margin-left:30px;padding-left:15px;border-left:2px solid #ddd}
.comment-level-0{margin-left:0}
.comment-level-1{margin-left:20px}
.comment-level-2{margin-left:40px}
.comment-level-3{margin-left:60px}
.comment-level-4{margin-left:80px}
.comment-level-5{margin-left:100px}
.comment-level-6{margin-left:120px}
.comment-level-7{margin-left:140px}
.comment-level-8{margin-left:160px}
.comment-level-9{margin-left:180px}
@media (max-width:768px) {
.comment-level-1{margin-left:10px}
.comment-level-2{margin-left:20px}
.comment-level-3{margin-left:30px}
.comment-level-4{margin-left:40px}
.comment-level-5{margin-left:50px}
.comment-level-6{margin-left:60px}
.comment-level-7{margin-left:70px}
.comment-level-8{margin-left:80px}
.comment-level-9{margin-left:90px}
}
.comment-form-nested{margin:10px 0;padding-left:15px;border-left:2px solid #ddd}
.dark-theme .comment-form-nested{border-left-color:#666}
.dark-theme .comment{background:#3d3d3d;border-color:#555}
.dark-theme .comment-children{border-left-color:#666}
.reply-to{font-size:.85em;color:#555;margin-bottom:8px;padding:2px 8px;background:rgba(0,0,0,0.05);border-radius:4px}
.dark-theme .reply-to{color:#bbb;background:rgba(255,255,255,0.05)}
.reply-to:before{content:"→";margin-right:5px}
.reply-btn{background:none;border:none;color:#777;cursor:pointer;margin-left:10px;font-size:1em}
.reply-btn:hover{text-decoration:underline}
.active-reply-form{border-left-color:#4CAF50}
.comment-header{display:flex;align-items:center;margin-bottom:5px;justify-content:space-between;border-bottom:1px solid #e5e5e5}
.comment-avatar{width:30px;height:30px;border-radius:50%;margin-right:10px;object-fit:cover}
.comment-form{margin-top:15px}
.comment-form textarea{width:100%;min-height:60px;margin-bottom:10px}
.new-post-form textarea{width:100%;min-height:100px;margin-bottom:10px}
.allow-comments-checkbox{margin:20px 0;display:flex;justify-content:space-between;align-items:center;flex-direction:row;padding:0 30px;flex-wrap:wrap;gap:15px}
.comments-count{color:#777}
.comments-disabled{color:#999;font-style:italic;font-size:.9em}
.comments-toggle{cursor:pointer;color:#777;transition:all .3s ease;display:inline-flex;align-items:center}
.comments-toggle:hover{color:#4CAF50}
.comments-toggle:after{content:"▼";font-size:.8em;margin-left:5px;transition:transform .3s ease}
.comments-toggle.hide::after{transform:rotate(180deg)}
.comments-container.show ~ .post-footer .comments-toggle:after{transform:rotate(180deg)}
.comments-loading{display:inline-block;width:12px;height:12px;border:2px solid rgba(0,0,0,0.2);border-radius:50%;border-top-color:#4CAF50;animation:spin 1s ease-in-out infinite;margin-left:5px}
.comment-loading{padding:10px;text-align:center;color:#777;font-style:italic}
@keyframes spin {
to{transform:rotate(360deg)}
}
.reply-form-wrapper{position:relative}
.cancel-comment-btn{background:none;border:none;color:#777;cursor:pointer;font-size:24px;padding:5px;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}
.cancel-comment-btn:hover{color:#ff4444;background:rgba(255,68,68,0.1)}
.dark-theme .cancel-comment-btn{color:#bbb}
.dark-theme .cancel-comment-btn:hover{color:#ff6666;background:rgba(255,102,102,0.1)}
.dark-theme .reply-btn{color:#ccc}
.delete-post-btn,.delete-comment-btn{background:#ffa8a8!important;color:white!important;border:none;padding:5px 10px;border-radius:4px;cursor:pointer;font-size:.8em;margin-left:10px;transition:.2s}
.delete-post-btn:hover,.delete-comment-btn:hover{opacity:.5}
.dark-theme .delete-post-btn,.dark-theme .delete-comment-btn{background:rgb(154 52 52 / 45%)!important;color:#ccc!important}
.dark-theme .delete-post-btn:hover,.dark-theme .delete-comment-btn:hover{background:#aa0000;color:#fff}
.deleted-comment{opacity:.6}
.deleted-comment .comment{opacity:1}
.dark-theme .deleted-comment .comment{opacity:1}
.deleted-text{color:#777;font-style:italic}
.dark-theme .deleted-comment{opacity:.5}
.dark-theme .deleted-text{color:#999}
.reply-reference{display:inline-block;background:#f0f0f0;padding:2px 8px;border-radius:4px;font-size:.85em;color:#555;margin-bottom:8px;cursor:pointer;transition:background .2s}
.reply-reference:hover{background:#e0e0e0}
.dark-theme .reply-reference{background:#555;color:#ddd}
.dark-theme .reply-reference:hover{background:#666}
.post-id,.comment-id{margin-left:auto;font-size:.9em;color:#777;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background 0.2s,color .2s}
.post-id:hover,.comment-id:hover{background:#e0e0e0;color:#333}
.dark-theme .post-id,.dark-theme .comment-id{color:#bbb}
.dark-theme .post-id:hover,.dark-theme .comment-id:hover{background:#555;color:#fff}
.post-header{display:flex;align-items:center;justify-content:flex-start;margin-bottom:10px}
.comment-header-left{display:flex;align-items:center;margin-bottom:5px}
.post-author{font-weight:bold;margin-right:10px}
.dark-theme .post-author{color:#ccc}
.post-date{color:#777;font-size:.9em;margin-top:4px}
.edit-comment-btn,.delete-comment-btn{background:none;border:none;color:#777;cursor:pointer;font-size:1em}
.dark-theme .edit-comment-btn,.dark-theme .delete-comment-btn{color:#aaa}
.edit-comment-btn:hover,.delete-comment-btn:hover{text-decoration:underline}
.edit-comment-textarea{width:100%;min-height:60px;margin-bottom:10px;padding:5px;border:1px solid #ddd;border-radius:4px}
.save-comment-btn,.save-post-btn,.cancel-edit-post-btn,.cancel-edit-comment-btn{background:#4CAF50;color:white;border:none;padding:5px 10px;border-radius:4px;cursor:pointer;font-size:16px;margin-top:5px;transition:.2s}
.cancel-edit-post-btn,.cancel-edit-comment-btn{background:#a65151}
.cancel-edit-post-btn:hover,.cancel-edit-comment-btn:hover{opacity:.7}
.save-comment-btn:hover{background:#45a049;opacity:.7}
.dark-theme .ans-btns,.dark-theme .edit-btns{opacity:.95}
.dark-theme .edit-comment-textarea{border-color:#555;background:#3d3d3d;color:#fff}
.dark-theme .save-comment-btn{background:#438045;opacity:.8}
.dark-theme .save-comment-btn:hover{opacity:1}
.dark-theme .cancel-edit-post-btn,.dark-theme .cancel-edit-comment-btn{opacity:.8}
.dark-theme .cancel-edit-post-btn:hover,.dark-theme .cancel-edit-comment-btn:hover{opacity:1}
.post-actions{padding:10px 0;display:flex;gap:10px;border-top:1px solid #e0e0e0}
.dark-theme .post-actions{border-color:#414141}
.edit-post-btn{background:none;border:none;color:#da4949;cursor:pointer;font-size:1em;padding:5px 10px;border-radius:4px;transition:all .2s}
.edit-post-btn:hover{background:#f0f0f0;color:#333}
.dark-theme .edit-post-btn:hover{background:#444;color:#fff}
.edit-post-control{transition:all .2s ease}
.edit-post-control.hidden{opacity:0;pointer-events:none;height:0;padding:0;margin:0;overflow:hidden;transition:all .2s ease}
.post-header .avatar-initial,.comment-header .avatar-initial{width:40px;height:40px;border-radius:50%;background-color:#c2c3ff;color:white;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:bold;margin-right:10px;flex-shrink:0}
.dark-theme .post-header .avatar-initial,.dark-theme .comment-header .avatar-initial{background-color:#696a9d}
.dark-theme .button-85{opacity:.75}
.btn-send-comm{border:0;font-size:16px;float:right}
.edit-btns{display:flex;flex-direction:row-reverse;flex-wrap:nowrap;justify-content:space-between;padding:10px 0}
.ans-btns{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:space-between}
.ql-editor p{font-size:16px!important}
.ql-container{min-height:200px}
.ql-editor img{max-width:100%;cursor:pointer}
.dark-theme .ql-container{background:#2d2d2d;color:#fff;border-color:#777!important}
.dark-theme .ql-toolbar{background:#1a1a1a!important;border-color:#777!important}
.dark-theme .ql-picker-label,.dark-theme .ql-action,.dark-theme .ql-remove{color:#fff}
.dark-theme .ql-stroke{stroke:#fff}
.dark-theme .ql-fill{fill:#fff}
.ql-editor ol{list-style-type:decimal!important;margin-left:20px}
.ql-editor li{margin:5px 0;display:list-item}
.ql-editor h1{font-size:2em;margin:.5em 0}
.ql-editor h2{font-size:1.5em;margin:.5em 0}
.ql-editor h3{font-size:1.3em;margin:.5em 0}
.ql-editor h4{font-size:1.2em;margin:.5em 0}
.ql-editor h5{font-size:1.1em;margin:.5em 0}
.ql-editor .ql-align-center{text-align:center!important}
.ql-editor .ql-align-right{text-align:right!important}
.ql-editor .ql-align-justify{text-align:justify!important}
.post-content .ql-align-center{text-align:center!important}
.post-content .ql-align-right{text-align:right!important}
.post-content .ql-align-justify{text-align:justify!important}
.edit-editor-container .ql-container{min-height:100px;border:1px solid #ccc}
.edit-editor-container .ql-toolbar{border-bottom:1px solid #ccc}
.dark-theme .edit-editor-container .ql-container{border-color:#444!important}
.dark-theme .edit-editor-container .ql-toolbar{border-bottom-color:#444}
.highlight{background:#fff3cd;transition:background .5s}
.dark-theme .highlight{background:#664d03}
.post-content sub{vertical-align:sub;font-size:smaller}
.post-content sup{vertical-align:super;font-size:smaller}
.post-content pre{background:#f5f5f5;padding:10px;font-family:monospace}
.dark-theme .post-content pre{background:#333;color:#fff}
.character-counter{font-size:12px;color:#666;margin-top:5px}
.dark-theme .character-counter{color:#ccc}
.dark-theme .ql-editor.ql-blank::before{color:#ddd}
.dark-theme .ql-formats .ql-script{color:#ddd}
.dark-theme .ql-snow .ql-formats button{filter:brightness(2.5)}
.dark-theme .ql-snow .ql-formats span svg{filter:brightness(2.5)}
.dark-theme .ql-snow .ql-formats button:hover,.dark-theme .ql-snow .ql-formats span svg:hover{filter:brightness(1.25) contrast(.5) hue-rotate(50deg)!important}
.ql-toolbar.ql-snow{border-radius:12px 12px 0 0}
.ql-container.ql-snow{border-radius:0 0 12px 12px}
.dark-theme .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{background-color:#222;color:#eee;border-color:#777}
.dark-theme .ql-editor{background:#2d2d2d!important;color:#dbdbdb!important}
.comment-editor,.edit-comment-editor{margin-bottom:10px}
.comment-editor .ql-container{min-height:80px;border-radius:4px}
.comment-editor .ql-toolbar{border-radius:4px 4px 0 0;margin-bottom:0}
.edit-comment-editor .ql-container{min-height:60px}
.dark-theme .comment-editor .ql-container,.dark-theme .edit-comment-editor .ql-container{background:#3d3d3d;color:#fff;border-color:#555}
.dark-theme .comment-editor .ql-toolbar,.dark-theme .edit-comment-editor .ql-toolbar{background:#2d2d2d;border-color:#555}
.dark-theme .ql-upload{filter:invert(.75) hue-rotate(180deg)!important}
.posts-pagination{display:flex;justify-content:center;flex-wrap:wrap;gap:15px;margin:20px 0}
.posts-pagination button{padding:5px 10px;border:1px solid #ccc;background-color:#f9f9f9;cursor:pointer;border-radius:4px;font-size:22px;transition:.2s}
.posts-pagination button.active{background-color:#ad92e1;color:white;border-color:#ccc}
.posts-pagination button:hover{background-color:#aaa}
.dark-theme .posts-pagination button{filter:invert(.85) hue-rotate(180deg)}
.posts-pagination-dots{padding:5px 10px;color:#666;display:flex;align-items:center}
@media (max-width:480px) {
.posts-pagination-dots{padding:3px 5px}
.post-date{font-size:.75em}
}
.upload-image-btn{background:none;border:none;color:#777;cursor:pointer;font-size:.8em;margin-left:10px;padding:5px 10px;border-radius:4px;transition:all .2s;display:inline-flex;align-items:center;gap:5px}
.upload-image-btn:hover{background:#f0f0f0;color:#333}
.dark-theme .upload-image-btn:hover{background:#444}
.upload-image-btn svg{width:24px;height:24px;opacity:.7;transition:.2s}
.upload-image-btn svg:hover{opacity:1}
.comment-textarea-wrapper{position:relative}
.comment-image-preview{margin:10px 5px;text-align:center;display:inline-block}
.comment-image-preview img{max-width:200px;max-height:150px;border-radius:8px;border:2px solid #e0e0e0}
.dark-theme .comment-image-preview img{border-color:#555}
.dark-theme .comment-header{border-bottom:1px solid #555}
.dark-theme .remove-image-btn{background:#ce4a4a}
.remove-image-btn{background:#ff4444;color:white;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:24px;margin-left:-20px;display:inline-flex;align-items:center;justify-content:center;vertical-align:super;transition:.2s}
.remove-image-btn:hover{background:#cc0000}
.comment-buttons{display:flex;justify-content:space-between;align-items:center;margin-top:10px;flex-direction:row-reverse}
.comment-action-buttons{display:flex;gap:10px;flex-direction:row-reverse;width:100%;justify-content:space-between}
.comment-manage-buttons{display:flex}
.image-modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:rgba(0,0,0,0.9);opacity:0;transition:opacity .3s ease}
.image-modal.show{opacity:1;animation:none}
.image-modal-content{margin:auto;display:block;max-width:90%;max-height:90%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0.7);border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,0.5);opacity:0;transition:all .4s cubic-bezier(0.175,0.885,0.32,1.275)}
.image-modal.show .image-modal-content{opacity:1;transform:translate(-50%,-50%) scale(1)}
.image-modal-close{position:absolute;top:15px;right:35px;color:#fff;font-size:40px;font-weight:bold;cursor:pointer;z-index:1001;transition:color 0.3s,opacity .3s;opacity:0}
.image-modal.show .image-modal-close{opacity:1}
.image-modal-close:hover{color:#ccc}
.image-modal-caption{position:absolute;bottom:20px;left:0;width:100%;text-align:center;color:#fff;font-size:16px;padding:10px;background:rgba(0,0,0,0.7);transition:opacity .3s;opacity:0}
.image-modal.show .image-modal-caption{opacity:1}
.image-modal.fade-out{opacity:0}
.image-modal.fade-out .image-modal-content{opacity:0;transform:translate(-50%,-50%) scale(0.8)}
.image-modal.fade-out .image-modal-close,.image-modal.fade-out .image-modal-caption{opacity:0}
@keyframes fadeIn {
from{opacity:0}
to{opacity:1}
}
.comment-image{max-width:200px!important;height:auto;border-radius:8px;margin:5px 0;box-shadow:0 2px 4px rgba(0,0,0,0.1);cursor:zoom-in;transition:.2s}
.comment-image:hover{transform:scale(1.02);box-shadow:0 4px 8px rgba(0,0,0,0.2)}
.post-content img{max-width:95%;height:auto;border-radius:8px;margin:5px auto;display:flex;cursor:zoom-in;transition:.2s}
.post-content p{margin:0}
.post-content a{color:#897ece;transition:.2s}
.post-content a:hover{opacity:.75}
.post-content img:hover{transform:scale(1.02);box-shadow:0 4px 8px rgba(0,0,0,0.2)}
.post-avatar:hover,.comment-avatar:hover{transform:none!important}
.post-content.collapsed-content{max-height:600px;overflow:hidden;position:relative;padding-bottom:0!important;transition:.5s}
.post-content.collapsed-content.expanded{max-height:fit-content;overflow:visible;padding-bottom:10px!important;transition:.5s}
.post-content-overlay{position:relative;bottom:8em;height:120px;pointer-events:none;z-index:2;transition:.5s;background:linear-gradient(to bottom,rgba(255,255,255,0) 0,#fff 100%);opacity:1}
.dark-theme .post-content-overlay{background:linear-gradient(to bottom,rgba(45,45,45,0) 0,#2d2d2d 100%)}
.post-content.expanded{max-height:9000px!important;transition:.5s}
.post-content.expanded + .post-content-overlay{opacity:0;display:none}
.post-toggle-wrapper{text-align:center;margin-top:-140px;padding-top:30px;padding-bottom:15px;position:relative;z-index:3;transition:.5s}
.post-toggle-wrapper.expanded{padding-top:130px;position:unset}
.dark-theme .post-toggle-wrapper{border-color:#444}
.post-toggle-btn{background:none;border:none;color:#7f7f7f;cursor:pointer;font-size:1.15em;padding:0;margin:0;display:inline-block;font-weight:bold}
.post-toggle-btn:hover{text-decoration:underline}
.loading-comments{text-align:center;padding:20px;color:#666;font-style:italic}
.admin-notice{background:#e3f2fd;border:1px solid #2196f3;border-radius:5px;padding:10px;margin-bottom:15px;text-align:center}
.loading-posts{text-align:center}
.admin-notice p{margin:0;color:#1976d2;font-size:14px}
#post-create-wrapper button:first-child{margin:0 auto;display:block}
#create-post-form-content{padding-top:0;border-top:none;margin-top:0;transition:.5s;max-height:0;overflow:hidden;opacity:0;padding-top:0}
.dark-theme #create-post-form-content{border-top:1px solid #444!important}
#create-post-form-content.expanded{max-height:none;height:auto;opacity:1;padding-top:15px;margin-top:15px;border-top:1px solid #eee}
.btn-post{font-size:16px}
.btn-post:after{background:#8c73b1}
.btn-pub:after{background:#633ea4}
.ql-snow .ql-picker.ql-header .ql-picker-label::before,.ql-snow .ql-picker.ql-header .ql-picker-item::before{content:'Заголовок'!important}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before{content:'Заголовок 1'!important}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before{content:'Заголовок 2'!important}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before{content:'Заголовок 3'!important}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before{content:'Заголовок 4'!important}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before{content:'Заголовок 5'!important}
.ql-snow .ql-picker.ql-header{width:110px!important}
blockquote{border-left:4px solid #a9a8db;margin:16px 0;padding:12px 20px;background-color:#f8f9fa;font-style:italic;color:#555;position:relative;border-radius:8px;transition:none}
blockquote:has(+ blockquote){margin-bottom:0!important;border-bottom-left-radius:0!important;border-bottom-right-radius:0!important;padding-bottom:0}
.dark-theme blockquote{border-left-color:#595cbb;background-color:#2d3748;color:#e2e8f0}
blockquote + blockquote{margin-top:0!important;border-top-left-radius:0!important;border-top-right-radius:0!important;padding-top:6px}
blockquote blockquote{border-left-color:#7cb342;background-color:#f1f8e9;margin:10px 0}
.dark-theme blockquote blockquote{border-left-color:#9ccc65;background-color:#1b2a32}
.ql-editor blockquote{border-left:4px solid #a9a8db;margin:16px 0;padding:12px 20px;background-color:#f8f9fa;font-style:italic;color:#555;border-radius:8px}
.dark-theme .ql-editor blockquote{border-left-color:#595cbb;background-color:#2d3748;color:#e2e8f0}
blockquote:not(blockquote + blockquote)::before{content:'"';font-size:38px;color:#4a90e2;position:absolute;right:8px;top:-8px;font-family:serif;opacity:.3}
blockquote + blockquote::before{content:none}
.dark-theme blockquote:not(blockquote + blockquote)::before{color:#64b5f6}
.dark-theme blockquote::before{color:#64b5f6}
blockquote cite{display:block;margin-top:8px;font-size:14px;color:#666;font-style:normal;text-align:right}
.dark-theme blockquote cite{color:#a0aec0}
.dark-theme .admin-notice{filter:invert(.85)}
.upload-progress-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.7);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;transition:opacity .3s ease}
.upload-progress-overlay.show{opacity:1}
.upload-progress-container{background:white;border-radius:12px;padding:30px;min-width:300px;max-width:400px;box-shadow:0 4px 20px rgba(0,0,0,0.3);transform:scale(0.9);transition:transform .3s ease}
.upload-progress-overlay.show .upload-progress-container{transform:scale(1)}
.dark-theme .upload-progress-container{background:#2d2d2d;color:#fff}
.upload-progress-title{font-size:18px;font-weight:bold;margin-bottom:15px;text-align:center;color:#333}
.dark-theme .upload-progress-title{color:#fff}
.upload-progress-bar-container{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-bottom:10px}
.dark-theme .upload-progress-bar-container{background:#444}
.upload-progress-bar{height:100%;background:linear-gradient(90deg,#4CAF50,#8BC34A);border-radius:4px;width:0;transition:width .3s ease;position:relative;overflow:hidden}
.upload-progress-bar::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.3),transparent);animation:shimmer 1.5s infinite}
@keyframes shimmer {
0%{transform:translateX(-100%)}
100%{transform:translateX(100%)}
}
.upload-progress-text{text-align:center;color:#666;font-size:14px;margin-bottom:15px}
.dark-theme .upload-progress-text{color:#ccc}
.upload-progress-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(76,175,80,0.3);border-radius:50%;border-top-color:#4CAF50;animation:spin 1s ease-in-out infinite;margin-right:10px;vertical-align:middle}
.upload-cancel-btn{background:#f44336;color:white;border:none;padding:8px 20px;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s;width:100%;margin-top:10px}
.upload-cancel-btn:hover{background:#d32f2f;transform:translateY(-1px);box-shadow:0 2px 8px rgba(244,67,54,0.3)}
.dark-theme .upload-cancel-btn{background:#c62828}
.dark-theme .upload-cancel-btn:hover{background:#b71c1c}
.like-btn{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:5px;color:#777;font-size:14px;padding:5px 8px;border-radius:4px;transition:all .2s}
.like-btn:hover{background:#0000000d;color:#555}
.dark-theme .like-btn:hover{background:#ffffff0d;color:#ccc}
.like-btn svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;transition:all .2s cubic-bezier(0.175,0.885,0.32,1.275)}
.like-btn.active{color:#e91e63}
.like-btn.active svg{fill:#e91e63;stroke:#e91e63;transform:scale(1.1)}
.like-count{font-weight:500}
.like-btn.animating svg{transform:scale(1.4)}
.post-actions-left{display:flex;align-items:center;gap:15px;width:100%;justify-content:space-between;flex-direction:row-reverse}
.comment-toggle{cursor:pointer;margin-right:8px;color:#999;font-weight:700;user-select:none;display:inline-block;width:20px;text-align:center;transition:color .2s;font-family:monospace;font-size:14px}
.comment-toggle:hover{color:#333}
.dark-theme .comment-toggle:hover{color:#fff}
.comment.collapsed .post-content,.comment.collapsed .comment-buttons,.comment.collapsed .reply-reference,.comment.collapsed .comment-id{display:none!important}
.comment-collapsed-info{display:none;color:#777;font-size:.9em;margin-left:8px;cursor:pointer;font-style:italic}
.comment.collapsed .comment-collapsed-info{display:inline}
.comment.collapsed .post-avatar{width:20px;height:20px}
.comment.collapsed .avatar-initial{width:20px;height:20px;font-size:10px}
.comment.child-hidden{display:none!important}
.pinned-indicator{color:#c8577d;font-size:.85em;margin-bottom:8px;display:flex;align-items:center;gap:5px;font-weight:700}
.pinned-indicator svg{width:16px;height:16px;fill:currentColor}
.post.is-pinned{border:1px solid #f1b6ca;box-shadow:0 0 10px #e91e631a;background:#faf6f7}
.dark-theme .post.is-pinned{border-color:#7f425d;background:#332b2e}
.pin-post-btn{background:none;border:none;cursor:pointer;margin-left:10px;color:#ffa522;transition:.2s}
.pin-post-btn:hover{color:#e91e63;text-decoration:underline}
.pin-post-btn.active{color:#e91e63;font-weight:700}
.scroll-to-top{position:fixed;bottom:30px;right:30px;width:50px;height:50px;background:#ab90db;color:#fff;border:none;border-radius:50%;cursor:pointer;box-shadow:0 4px 12px #0000004d;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transform:translateY(20px);transition:all .3s cubic-bezier(0.4,0,0.2,1);z-index:900}
.scroll-to-top.show{opacity:.75;pointer-events:auto;transform:translateY(0)}
.scroll-to-top:hover{background:#a381e1;transform:translateY(-3px);box-shadow:0 6px 16px #0006;opacity:1}
.scroll-to-top svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
@media (max-width: 768px) {
.scroll-to-top{bottom:5px;right:5px;width:35px;height:35px}
}
.dark-theme .scroll-to-top{background:#614f81;box-shadow:0 4px 12px #00000080}
.dark-theme .scroll-to-top:hover{background:#45375d}
.post-content hr,.ql-editor hr{border:0;height:1px;background-image:linear-gradient(to right,#0000,#0003,#0000);margin:20px 0}
.dark-theme .post-content hr,.dark-theme .ql-editor hr{background-image:linear-gradient(to right,#fff0,#fff3,#fff0)}
.spoiler{border-radius:3px;padding:2px 5px;cursor:pointer;transition:all .2s ease}
.ql-editor .spoiler{background-color:#f0f0f0;color:#333;border:1px dashed #bbb}
.dark-theme .ql-editor .spoiler{background-color:#3a3b55;color:#e0e0e0;border:1px dashed #7a7a9e}
.post-content .spoiler{background-color:#ebdff1;color:transparent;text-shadow:none;position:relative;user-select:none;display:inline-block;min-width:80px;vertical-align:bottom;box-sizing:border-box;word-break:break-word;line-height:1.4;transition:background-color 0.2s,opacity .2s}
.dark-theme .post-content .spoiler{background-color:#52435b}
.post-content .spoiler::before{content:'СПОЙЛЕР';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#888;font-size:.75em;font-weight:700;letter-spacing:1px;pointer-events:none;opacity:1;transition:opacity .2s;font-family:sans-serif;text-transform:uppercase;white-space:nowrap}
.dark-theme .post-content .spoiler::before{color:#ccc}
.post-content .spoiler:not(.visible):hover{opacity:.75;cursor:pointer}
.post-content .spoiler.visible{background-color:#0000000d;color:inherit;user-select:text;outline:1px dashed #bbb;opacity:1;cursor:text}
.post-content .spoiler.visible::before{opacity:0}
.dark-theme .post-content .spoiler.visible{background-color:#ffffff1a;color:inherit;outline:1px dashed #666}
.ql-spoiler svg,.ql-divider svg{width:18px;height:18px;opacity:.8}
.ql-spoiler{font-weight:700;font-family:monospace}
.ql-spoiler:hover{opacity:.5}
.dark-theme .ql-spoiler{filter:brightness(2.5) invert(.7)!important}
.post-title-input{width:100%;padding:10px;margin-bottom:10px;border:1px solid #ccc;border-radius:12px;font-size:16px;box-sizing:border-box;height:auto}
.dark-theme .post-title-input{background:#2d2d2d;border-color:#777;color:#fff}
.comment-toolbar{display:flex;gap:5px;margin-bottom:5px;padding:5px;background:#f7f7f7;border:1px solid #eee;border-radius:4px}
.dark-theme .comment-toolbar{background:#3d3d3d;border-color:#555}
.format-btn{background:none;border:1px solid transparent;cursor:pointer;font-size:14px;padding:2px 8px;border-radius:4px;color:#555;transition:all .2s;font-weight:700;min-width:24px}
.dark-theme .format-btn{color:#ccc}
.format-btn:hover{background:rgba(0,0,0,0.05);border-color:#ddd}
.dark-theme .format-btn:hover{background:rgba(255,255,255,0.05);border-color:#666}
.stats-container{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:20px}
.stat-column{background:#fff;border-radius:12px;padding:15px;box-shadow:0 1px 5px rgba(0,0,0,0.15)}
.dark-theme .stat-column{background:#2d2d2d;box-shadow:none;border:1px solid #444}
.stat-title{font-size:16px;font-weight:700;margin-bottom:15px;border-bottom:2px solid #f0f0f0;padding-bottom:10px;color:#333}
.dark-theme .stat-title{color:#fff;border-bottom-color:#444}
.stat-list{list-style:none;padding:0;margin:0}
.stat-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f5f5f5;font-size:14px}
.dark-theme .stat-item{border-bottom-color:#3d3d3d}
.stat-item:last-child{border-bottom:none}
.stat-item a{color:#333;text-decoration:none;transition:.2s;display:flex;align-items:center;gap:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dark-theme .stat-item a{color:#ddd}
.stat-item a:hover{color:#7f4caf}
.stat-count{background:#f0f0f0;padding:2px 8px;border-radius:10px;font-size:12px;color:#666;font-weight:600;white-space:nowrap}
.dark-theme .stat-count{background:#444;color:#ccc}
.tag-cloud{display:flex;flex-wrap:wrap;gap:8px;max-height:250px;overflow:auto}
.tag-chip{background:#f0f0f0;padding:4px 10px;border-radius:15px;font-size:12px;color:#555;text-decoration:none;transition:.2s;cursor:pointer}
.dark-theme .tag-chip{background:#3d3d3d;color:#bbb}
.tag-chip:hover{background:#e0e0e0;color:#333}
.dark-theme .tag-chip:hover{background:#4a4a4a;color:#fff}
.post-tags-input-container{margin-top:15px;border:1px solid #ccc;border-radius:12px;padding:5px;display:flex;flex-wrap:wrap;gap:5px;background:#fff;min-height:32px}
.dark-theme .post-tags-input-container{background:#2d2d2d;border-color:#777}
.post-tag-badge{background:#e8e3fd;color:#8550c3;padding:4px 8px;border-radius:4px;font-size:14px;display:flex;align-items:center;gap:5px}
.dark-theme .post-tag-badge{background:#6d478c;color:#e9e9e9}
.post-tag-remove{cursor:pointer;font-weight:bold;opacity:.7;font-size:26px}
.post-tag-remove:hover{opacity:1}
#post-tags-input{border:none;outline:none;padding:8px;flex:1;min-width:120px;font-size:14px;background:transparent;color:inherit}
.post-tags-display{padding:10px 0;border-top:1px solid #eee;display:flex;flex-wrap:wrap;gap:8px}
.dark-theme .post-tags-display{border-top-color:#444}
.post-tag-link{color:#633ea4;text-decoration:none;font-size:16px;background:#f0f0f0;padding:3px 8px;border-radius:4px;transition:.2s}
.post-tag-link:hover{background:#e0e0e0;text-decoration:underline}
.dark-theme .post-tag-link{background:#3d3d3d;color:#ad92e1}
.dark-theme .post-tag-link:hover{background:#4a4a4a}
@media (max-width:900px) {
.stats-container{grid-template-columns:1fr}
}
.edit-tags-container{margin-top:10px;border:1px solid #ccc;border-radius:4px;padding:5px;display:flex;flex-wrap:wrap;gap:5px;background:#fff;min-height:42px;transition:background-color 0.3s,border-color .3s}
.edit-tags-input{border:none;outline:none;padding:8px;flex:1;min-width:120px;font-size:14px;background:transparent;color:inherit}
.dark-theme .edit-tags-container{background:#2d2d2d;border-color:#444;color:#fff}
.dark-theme .edit-tags-input{color:#fff}
.dark-theme .edit-tags-input::placeholder{color:#888}
@media (max-width:768px) {
.posts-pagination{margin:10px 0}
.post{padding:10px}
.upload-progress-container{min-width:250px;padding:20px}
.allow-comments-checkbox{justify-content:center}
.post-tags-input-container{min-height:32px}
.post-tag-badge{padding:0 8px}
}
.guest-blurred{filter:blur(5px);pointer-events:none;user-select:none;opacity:.7}
.guest-overlay-container{position:fixed;bottom:50px;left:50%;transform:translateX(-50%);z-index:2000;width:90%;max-width:400px;animation:slideUp .5s ease-out}
.guest-auth-banner{background:rgba(255,255,255,0.95);backdrop-filter:blur(10px);border-radius:12px;padding:20px;text-align:center;box-shadow:0 10px 30px rgba(0,0,0,0.2);border:1px solid rgba(0,0,0,0.1)}
.dark-theme .guest-auth-banner{background:rgba(45,45,45,0.95);border-color:rgba(255,255,255,0.1)}
.guest-auth-banner h3{margin:0 0 10px;color:#333}
.dark-theme .guest-auth-banner h3{color:#fff}
.guest-auth-banner p{margin:0 0 15px;color:#666;font-size:14px}
.dark-theme .guest-auth-banner p{color:#ccc}
.guest-login-btn{display:inline-block;background:#633ea4;color:white;padding:10px 25px;border-radius:25px;text-decoration:none;font-weight:700;transition:.2s}
.guest-login-btn:hover{background:#503285;transform:translateY(-2px)}
@keyframes slideUp {
from{transform:translate(-50%,100%);opacity:0}
to{transform:translate(-50%,0);opacity:1}
}