.interaction-section[data-v-ab9b1c89]{margin-top:10px;background-color:#f7f7f7;border-radius:4px;padding:5px 12px;position:relative}.interaction-section[data-v-ab9b1c89]:before{content:"";position:absolute;top:-6px;left:15px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid #f7f7f7}.likes[data-v-ab9b1c89],.comments[data-v-ab9b1c89]{font-size:14px;line-height:1.6}.likes[data-v-ab9b1c89]{color:#576b95;padding:5px 0;display:flex;align-items:center;flex-wrap:wrap}.like-icon[data-v-ab9b1c89]{width:14px;height:14px;margin-right:8px;font-size:14px;flex-shrink:0}.likes-list .liker[data-v-ab9b1c89]:not(:last-child):after{content:", "}.divider[data-v-ab9b1c89]{height:1px;background-color:#e5e5e5;margin:2px 0}.comment-thread[data-v-ab9b1c89]{padding:3px 0}.comment-item[data-v-ab9b1c89]{padding:2px 6px;border-radius:4px;transition:background-color .2s;word-break:break-all}.commenter[data-v-ab9b1c89]{color:#576b95;font-weight:500}.comment-text[data-v-ab9b1c89]{color:#333}.replies[data-v-ab9b1c89]{margin-top:5px;margin-left:20px;border-left:2px solid #e0e0e0;padding-left:10px}.reply-marker[data-v-ab9b1c89]{color:#666;font-size:.9em;margin:0 4px}.comment-item[data-v-ab9b1c89]{cursor:pointer}.comment-item[data-v-ab9b1c89]:hover{background-color:#ebebeb}.video-share-container[data-v-ac96adec]{position:relative;z-index:1;cursor:pointer;max-width:300px;width:100%;border-radius:8px;overflow:hidden;display:block}.video-cover[data-v-ac96adec]{width:100%;display:block;position:absolute;top:0;left:0;height:100%;object-fit:cover;background-color:#eee}.video-share-container[data-v-ac96adec]:before{content:"";display:block;padding-top:56.25%}.play-icon-overlay[data-v-ac96adec]{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;opacity:1;background-color:rgba(0,0,0,.2);transition:opacity .2s ease-in-out}.video-share-container:hover .play-icon-overlay[data-v-ac96adec]{opacity:1}.play-icon[data-v-ac96adec]{width:60px;height:60px;color:rgba(255,255,255,.9);filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.notification-options[data-v-97c368ca]{border-top:1px solid #eee;margin-top:15px;padding-top:15px}.notification-options h4[data-v-97c368ca]{margin-top:0;margin-bottom:10px;font-size:15px;color:#555}.option-group[data-v-97c368ca]{display:flex;gap:20px;margin-bottom:15px}.option-group label[data-v-97c368ca]{display:flex;align-items:center;gap:5px;font-size:14px}.user-select-wrapper select[data-v-97c368ca]{width:100%;min-height:100px;padding:8px;border:1px solid #ddd;border-radius:4px}.user-select-info[data-v-97c368ca]{font-size:12px;color:#999;margin-top:5px}.cover-preview[data-v-97c368ca]{margin-top:10px;max-width:200px}.cover-preview img[data-v-97c368ca]{width:100%;border-radius:8px;border:1px solid #ddd}.notification-bar[data-v-7c572b65]{display:flex;align-items:center;padding:8px 15px;background-color:rgba(0,0,0,.5);color:#fff;border-radius:20px;cursor:pointer;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);transition:all .3s ease;width:fit-content;margin-top:10px;box-shadow:0 4px 12px rgba(0,0,0,.15);border:1px solid rgba(255,255,255,.1)}.notification-bar[data-v-7c572b65]:hover{background-color:rgba(0,0,0,.7)}.actor-avatar[data-v-7c572b65]{width:24px;height:24px;border-radius:50%;margin-right:10px;object-fit:cover}.modal-overlay[data-v-0a72992f]{z-index:4000}.notification-modal-content[data-v-0a72992f]{position:fixed;top:0;left:0;right:0;bottom:0;max-width:600px;margin:0 auto;background:#f1f1f1;display:flex;flex-direction:column;height:100%}.modal-header[data-v-0a72992f]{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background:#fff;border-bottom:1px solid #dcdcdc;flex-shrink:0}.back-icon[data-v-0a72992f],.clear-btn[data-v-0a72992f]{cursor:pointer;padding:5px}.modal-body[data-v-0a72992f]{flex-grow:1;overflow-y:auto;-webkit-overflow-scrolling:touch;position:relative}.pull-to-refresh-indicator[data-v-0a72992f]{position:absolute;top:-50px;left:0;right:0;height:50px;display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;color:#888}.pull-to-refresh-indicator .arrow[data-v-0a72992f]{display:inline-block;transition:transform .2s}.pull-to-refresh-indicator .arrow.is-refreshing[data-v-0a72992f]{animation:spin-0a72992f 1s linear infinite}@keyframes spin-0a72992f{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.notification-item-wrapper[data-v-0a72992f]{background:#fff;border-bottom:1px solid #f1f1f1}.notification-item[data-v-0a72992f]{display:grid;grid-template-columns:auto 1fr auto;gap:0 12px;padding:15px 15px 0;align-items:flex-start}.notification-item.is-actionable[data-v-0a72992f]{cursor:pointer}.notification-item.is-actionable[data-v-0a72992f]:hover{background-color:#f9f9f9}.notification-item-wrapper:has(.notification-item.is-actionable:hover) .delete-action-wrapper[data-v-0a72992f]{background-color:#f9f9f9}.actor-avatar[data-v-0a72992f]{grid-column:1 / 2;width:40px;height:40px;border-radius:5px}.item-content[data-v-0a72992f]{grid-column:2 / 3}.post-preview[data-v-0a72992f]{grid-column:3 / 4;padding-top:25px}.actor-name[data-v-0a72992f]{font-weight:700}.action-text[data-v-0a72992f]{font-size:14px;margin:4px 0;color:#333;word-break:break-all}.heart-icon[data-v-0a72992f],.request-icon[data-v-0a72992f]{font-size:12px}.timestamp[data-v-0a72992f]{font-size:12px;color:#888;margin-top:8px}.details-btn[data-v-0a72992f]{background-color:#f0f0f0;border:1px solid #e0e0e0;color:#666;padding:4px 10px;border-radius:15px;font-size:12px;cursor:pointer;white-space:nowrap}.details-btn[data-v-0a72992f]:hover{background-color:#e5e5e5}.delete-action-wrapper[data-v-0a72992f]{padding:10px 15px;transition:background-color .2s}.delete-btn[data-v-0a72992f]{font-size:14px;padding:8px 0;width:100%;background-color:#f5f5f5;color:#888;border:none;border-radius:6px;cursor:pointer;text-align:center;transition:all .2s ease}.delete-btn[data-v-0a72992f]:hover{background-color:#e9e9e9;color:#c70000}.delete-btn[data-v-0a72992f]:active{transform:scale(.98)}.loading[data-v-0a72992f],.empty[data-v-0a72992f],.loading-indicator[data-v-0a72992f]{text-align:center;padding:20px;color:#888;font-size:14px}.notification-item-wrapper[data-v-0a72992f]:has(.notification-item.is-invalid){opacity:.5;text-decoration:line-through}.notification-item.is-invalid[data-v-0a72992f]{cursor:not-allowed}.notification-item.is-invalid[data-v-0a72992f]:hover{background-color:transparent}.notification-item.is-invalid+.delete-action-wrapper[data-v-0a72992f]{display:none}.notification-item.is-invalid .details-btn[data-v-0a72992f]{pointer-events:none;background-color:#eee;color:#aaa}.request-modal h2[data-v-ee112b6c]{margin-bottom:10px}.request-keywords[data-v-ee112b6c]{font-size:15px;color:#555;text-align:center;margin-bottom:20px;background-color:#f7f7f7;padding:10px;border-radius:8px}.request-keywords strong[data-v-ee112b6c]{color:var(--theme-color)}.type-selector[data-v-ee112b6c]{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;margin-bottom:25px}.type-selector button[data-v-ee112b6c]{padding:12px;border:1px solid #ddd;background-color:#fff;border-radius:8px;cursor:pointer;font-size:15px;transition:all .2s ease}.type-selector button[data-v-ee112b6c]:hover{border-color:#aaa}.type-selector button.active[data-v-ee112b6c]{background-color:var(--theme-color);color:#fff;border-color:var(--theme-color);font-weight:700}.back-to-top[data-v-6f176eef]{position:fixed;right:20px;bottom:70px;width:40px;height:40px;background-color:rgba(255,255,255,.9);border-radius:50%;box-shadow:0 2px 12px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1000}.fade-enter-active[data-v-6f176eef],.fade-leave-active[data-v-6f176eef]{transition:opacity .3s ease}.fade-enter-from[data-v-6f176eef],.fade-leave-to[data-v-6f176eef]{opacity:0}.back-to-top .icon[data-v-6f176eef]{width:24px;height:24px;color:#000}.scroll-indicator-track[data-v-2af34b64]{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40px;height:4px;background-color:#f0f0f0;border-radius:2px;z-index:1}.scroll-indicator-thumb[data-v-2af34b64]{position:absolute;top:0;height:100%;background-color:#f56c6c;border-radius:2px;z-index:2}.notification-icon-wrapper[data-v-2af34b64]{position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center}.notification-badge[data-v-2af34b64]{position:absolute;top:-5px;right:-8px;background-color:#ff5757;color:#fff;border-radius:50%;font-size:10px;font-weight:700;line-height:1.2;min-width:16px;text-align:center;border:2px solid white}.notification-bar-container[data-v-2af34b64]{display:flex;justify-content:center;padding:0 15px;margin-bottom:-18px}.empty-search-container[data-v-2af34b64]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;height:calc(100% - 100px);box-sizing:border-box}.empty-search-box[data-v-2af34b64]{display:flex;flex-direction:column;align-items:center;gap:15px}.request-prompt[data-v-2af34b64]{margin-top:10px;font-size:14px;color:#606266}.request-btn[data-v-2af34b64]{background-color:#f0f2f5;border:1px solid #dcdfe6;color:#303133;font-weight:500;cursor:pointer;padding:8px 16px;border-radius:20px;margin-left:8px;transition:all .2s ease;font-size:14px}.request-btn[data-v-2af34b64]:hover{background-color:#e4e7ed;border-color:#c8c9cc;color:var(--theme-color)}.request-btn[data-v-2af34b64]:active{transform:scale(.98)}.toast-enter-active[data-v-2af34b64],.toast-leave-active[data-v-2af34b64]{transition:transform .4s ease}.toast-enter-from[data-v-2af34b64],.toast-leave-to[data-v-2af34b64]{transform:translateY(-100px)}.notification-bar-wrapper[data-v-2af34b64]{position:fixed;top:60px;left:0;right:0;display:flex;justify-content:center;z-index:2000;pointer-events:none}.notification-bar-wrapper[data-v-2af34b64]>*{pointer-events:auto}.moments-container.has-unread-notifications .cover-photo[data-v-2af34b64]{opacity:.1}.page-indicator[data-v-2af34b64]{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background-color:rgba(0,0,0,.6);color:#fff;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:700;z-index:1000;pointer-events:none;transition:opacity .3s ease}[v-cloak]{display:none!important}:root{--theme-color: #1aad19}*{-webkit-tap-highlight-color:transparent}body,html{margin:0;padding:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif;background-color:#f1f1f1;-webkit-font-smoothing:antialiased;overflow:hidden}#app{max-width:600px;height:100vh;margin:0 auto;background-color:#fff;box-shadow:0 0 10px rgba(0,0,0,.1);position:relative;overflow:hidden}.scroll-container{height:100%;overflow-y:auto;box-sizing:border-box;-ms-overflow-style:none;scrollbar-width:none}.scroll-container::-webkit-scrollbar{display:none}.top-bar{position:sticky;top:0;z-index:1000;display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background-color:#fff;color:#000;height:30px;border-bottom:1px solid #dcdcdc}.top-bar-actions{display:flex;align-items:center}.top-bar-actions>*+*{margin-left:20px}.top-bar .title{font-size:18px;font-weight:700;position:absolute;left:45px;transform:translate(-50%);margin-top:-15px}.top-bar-icon{color:#000;width:24px;height:24px;cursor:pointer}.top-bar>span{cursor:pointer;display:flex;align-items:center}.search-container{flex-grow:1;margin:0 15px;position:relative}.search-bar-wrapper{display:flex;align-items:center;width:100%;gap:10px}.search-bar-input-group{position:relative;flex-grow:1}.search-bar-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#999;pointer-events:none}.search-input{width:100%;height:36px;padding:0 10px 0 40px;border:none;border-radius:8px;font-size:15px;background-color:#f5f5f5;transition:all .2s ease;box-sizing:border-box}.search-cancel-btn{flex-shrink:0;background:none;border:none;font-size:16px;cursor:pointer;padding:0 5px;color:#576b95;font-weight:500}.search-input:focus{background-color:#efefef;outline:none;box-shadow:0 0 0 2px rgba(26,173,25,.2)}.search-prompt{padding:60px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:15px;color:#aaa}.search-prompt .icon-svg{width:48px;height:48px}.search-prompt span{font-size:16px}.title-search-swap-enter-active,.title-search-swap-leave-active{transition:all .25s ease-out}.title-search-swap-enter-from{opacity:0;transform:translateY(-10px)}.title-search-swap-leave-to{opacity:0;transform:translateY(10px)}.moments-container{padding-top:0}.moments-header{position:relative;margin-bottom:20px}.cover-photo{width:100%;height:250px;object-fit:cover;display:block;transition:opacity .4s ease}.user-info{position:absolute;right:15px;bottom:-20px;display:flex;align-items:center}.user-info .avatar.is-admin{cursor:pointer}.user-info .username{color:#fff;font-weight:700;text-shadow:1px 1px 2px rgba(0,0,0,.5);margin-right:15px;font-size:16px}.user-info .avatar{width:70px;height:70px;border-radius:8px;border:2px solid white}.feed{padding-bottom:20px}.post-item{display:flex;padding:15px;border-bottom:1px solid #e5e5e5;background-color:#fff}.post-author-avatar{width:42px;height:42px;margin-right:12px;flex-shrink:0}.post-author-avatar img{width:100%;height:100%;border-radius:6px;object-fit:cover}.post-content-wrapper{flex-grow:1;overflow:hidden}.author-name{font-weight:700;color:#576b95;margin-bottom:8px;cursor:pointer}.post-text{font-size:15px;line-height:1.6;color:#1a1a1a;white-space:pre-wrap;word-wrap:break-word}.post-text span.is-clamped{display:inline-block;vertical-align:top;width:100%;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical}.toggle-expansion-btn{color:#576b95;font-weight:700;font-size:15px;cursor:pointer;margin-top:5px;display:inline-block}.post-meta{position:relative;display:flex;justify-content:space-between;align-items:center;margin-top:15px;color:#888;font-size:13px}.actions-btn{background-color:#f0f0f0;border-radius:4px;padding:2px 6px;cursor:pointer;font-weight:700;letter-spacing:2px}.actions-popover{position:absolute;right:35px;top:50%;transform:translateY(-50%);display:flex;align-items:center;background-color:#4c4c4c;border-radius:6px;height:34px;overflow:hidden;color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.2)}.popover-item{display:flex;align-items:center;justify-content:center;gap:4px;min-width:65px;padding:0 10px;cursor:pointer;height:100%;transition:background-color .2s}.popover-item:hover{background-color:#3e3e3e}.popover-item:not(:last-child){border-right:1px solid #333}.popover-item .icon-svg{width:16px;height:16px;color:#fff}.image-grid{margin-top:10px;display:grid;gap:5px}.image-grid.grid-1 .grid-item{max-width:30%}.image-grid.grid-2,.image-grid.grid-4{grid-template-columns:repeat(2,1fr);max-width:60%}.image-grid.grid-3,.image-grid.grid-5,.image-grid.grid-6,.image-grid.grid-7,.image-grid.grid-8,.image-grid.grid-9{grid-template-columns:repeat(3,1fr);max-width:90%}.image-grid .grid-item img{width:100%;height:100%;object-fit:cover;display:block;cursor:pointer}.image-grid .grid-item{aspect-ratio:1/1}.interaction-section{margin-top:10px;background-color:#f7f7f7;border-radius:4px;padding:5px 12px;position:relative}.interaction-section:before{content:"";position:absolute;top:-6px;left:15px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid #f7f7f7}.likes,.comments{font-size:14px;line-height:1.6}.likes{color:#576b95;padding:5px 0;display:flex;align-items:center;flex-wrap:wrap}.likes .icon-svg{width:14px;height:14px;margin-right:8px}.likes-list .liker:not(:last-child):after{content:", "}.divider{height:1px;background-color:#e5e5e5;margin:2px 0}.comment-item{padding:2px 0}.comment-item .commenter{color:#576b95;font-weight:500}.comment-item.is-mine{cursor:pointer;border-radius:4px}.comment-item.is-mine:hover{background-color:#ebebeb}.comment-form{margin-top:10px;display:flex}.comment-form input{flex-grow:1;border:1px solid #e0e0e0;background-color:#f7f7f7;padding:8px 12px;border-radius:4px;font-size:14px;transition:all .2s}.comment-form input:focus{outline:none;border-color:var(--theme-color);background-color:#fff}.share-card{margin-top:10px;display:flex;padding:10px;background-color:#f7f7f7;cursor:pointer;border-radius:4px;align-items:center;transition:background-color .2s}.share-card:hover{background-color:#efefef}.share-card .share-cover{width:50px;height:50px;object-fit:cover;margin-right:10px;flex-shrink:0;border-radius:4px}.share-card .share-info{display:flex;flex-direction:column;justify-content:center;overflow:hidden}.share-card .share-title-line{display:flex;align-items:center;gap:8px}.share-card .share-title{font-size:15px;color:#1a1a1a;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-card .share-subtitle{font-size:13px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:4px}.movie-card-vertical{display:flex;border-radius:8px;margin-top:10px;cursor:pointer;color:#fff;overflow:hidden;position:relative;height:120px}.movie-card-vertical .cover-bg{position:absolute;left:10px;top:10px;width:100px;height:90%;overflow:hidden}.movie-card-vertical .cover-bg img{height:95%;width:auto;max-width:none;object-fit:cover;object-position:left;border-radius:6px}.movie-card-vertical .info-wrapper{flex-grow:1;padding:12px 15px 12px 90px;display:flex;justify-content:space-between;width:10px}.movie-card-vertical .info-main{display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;padding:5px 0}.movie-card-vertical .share-title{font-size:17px;font-weight:600;color:#fff;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:8px}.movie-card-vertical .rating-row{display:flex;align-items:center;gap:6px}.movie-card-vertical .rating-score{font-weight:700;font-size:14px}.movie-card-vertical .details-row{font-size:13px;color:rgba(255,255,255,.8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.movie-card-vertical .category-tag{padding:2px 6px;border-radius:4px;background-color:rgba(255,255,255,.8);color:#000;font-size:12px;font-weight:500;margin-right:6px;display:inline-block}.movie-card-vertical .info-action{display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;padding-left:10px;color:#fff}.movie-card-vertical .action-icon .icon-svg{width:24px;height:24px;color:currentColor}.movie-card-vertical .action-text{font-size:12px;margin-top:2px}.rating-stars-wrapper{position:relative;display:inline-flex}.stars-background,.stars-foreground{display:flex}.stars-foreground{position:absolute;top:0;left:0;white-space:nowrap;overflow:hidden}.rating-stars-wrapper .icon-svg{width:1em;height:1em;flex-shrink:0;font-size:18px}.stars-foreground .icon-svg{color:#ffb400}.stars-background .icon-svg{color:rgba(255,255,255,.5)}.douban-logo{display:inline-block;background-color:#072;color:#fff;font-size:15px;font-weight:700;padding:2px 4px;border-radius:3px;line-height:1}.login-prompt{margin-top:10px;padding:20px;background-color:#f7f7f7;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;color:#888;border:1px dashed #ddd}.login-prompt:hover{background-color:#efefef}.login-prompt .icon-svg{width:24px;height:24px;color:#aaa}.login-prompt span{font-size:14px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.6);display:flex;justify-content:center;align-items:center;z-index:3000}.modal-content{background-color:#fff;padding:25px 30px;border-radius:12px;box-shadow:0 5px 15px rgba(0,0,0,.3);width:85%;max-width:400px;position:relative}.modal-content h2{margin-top:0;margin-bottom:20px;text-align:center;font-size:20px}.form-group{display:flex;align-items:center;margin-bottom:12px}.form-group label{flex-shrink:0;width:80px;text-align:left;margin-right:10px;font-size:15px;color:#555}.form-group input,.form-group textarea,.form-group select,.select-wrapper{flex-grow:1;width:100%}.form-group input,.form-group textarea,.form-group select{padding:10px;font-size:15px;border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-family:inherit}.form-group.full-width{flex-direction:column;align-items:stretch}.form-group.full-width label{text-align:left;width:auto;margin-bottom:8px}.form-group textarea{resize:vertical;min-height:80px}.select-wrapper{position:relative;display:inline-block}.select-wrapper:after{content:"";position:absolute;top:50%;right:12px;transform:translateY(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #888;pointer-events:none}.form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff}.form-group-checkbox{display:flex;align-items:center;margin-top:5px;margin-bottom:15px}.form-group-checkbox input{width:auto;margin-right:8px}.form-group-checkbox label{margin:0;font-size:14px;color:#555;cursor:pointer}.action-btn{width:100%;padding:12px;font-size:16px;font-weight:700;color:#fff;background-color:var(--theme-color);border:none;border-radius:6px;cursor:pointer;transition:background-color .2s}.action-btn:hover{background-color:#168a14}.action-btn:disabled{background-color:#9edc9e;cursor:not-allowed}.close-btn{position:absolute;top:10px;right:10px;font-size:24px;color:#aaa;cursor:pointer;line-height:1}.post-modal-tabs{display:flex;border-bottom:1px solid #eee;margin-bottom:20px}.post-modal-tabs button{flex-grow:1;padding:10px;border:none;background:none;cursor:pointer;font-size:15px;color:#888;border-bottom:3px solid transparent}.post-modal-tabs button.active{color:var(--theme-color);border-bottom-color:var(--theme-color);font-weight:700}.image-uploader{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px}.preview-item{position:relative;width:80px;height:80px}.preview-item img{width:100%;height:100%;object-fit:cover;border-radius:6px}.remove-btn{position:absolute;top:-5px;right:-5px;width:20px;height:20px;background-color:rgba(0,0,0,.6);color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;line-height:1}.upload-placeholder{width:80px;height:80px;background-color:#f7f7f7;border:2px dashed #ddd;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer}.upload-placeholder .icon-svg{width:30px;height:30px;color:#bbb}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fff;display:flex;justify-content:center;align-items:center;z-index:9000}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid var(--theme-color);border-radius:50%;animation:spin 1s linear infinite}.load-more-indicator{text-align:center;padding:20px 0;font-size:14px;color:#888}.search-result-indicator{text-align:center;padding:120px 0;font-size:14px;color:#888;background-color:#fafafa;border-bottom:1px solid #f1f1f1}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.filter-controls-wrapper{position:relative;display:flex;align-items:center;padding:10px 15px;background-color:#fff;overflow-x:hidden}.filter-tabs{position:relative;display:flex;overflow-x:auto;padding-right:20px;scrollbar-width:none;-ms-overflow-style:none}.filter-tabs::-webkit-scrollbar{display:none}.tab-button{flex-shrink:0;padding:8px 12px;border:none;background:none;font-size:15px;color:#606266;cursor:pointer;position:relative;transition:color .2s ease;white-space:nowrap}.tab-button:hover{color:#303133}.tab-button:not(:first-child){margin-left:15px}.tab-button.active{color:var(--theme-color);font-weight:700}.tab-button.active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:50%;height:3px;background-color:var(--theme-color);border-radius:2px}.advanced-filter-toggle-btn{flex-shrink:0;margin-left:15px;position:relative;z-index:2;background-color:#fff;display:flex;align-items:center;gap:4px;background-color:#f5f5f5;border:none;padding:6px 10px;border-radius:15px;font-size:13px;color:#555;cursor:pointer;transition:background-color .2s}.advanced-filter-toggle-btn:hover{background-color:#e9e9e9}.advanced-filter-toggle-btn .icon-svg{width:14px;height:14px;transition:transform .3s ease-out}.advanced-filter-toggle-btn.open .icon-svg{transform:rotate(180deg)}.advanced-filter-panel{background-color:#fafafa;border-bottom:0px solid #f1f1f1;max-height:0;overflow:hidden;transition:max-height .4s ease-out,padding .4s ease-out,border-color .4s ease-out;padding:0 15px;border-top:1px solid transparent}.advanced-filter-panel.open{max-height:500px;padding-top:10px;padding-bottom:15px;border-top-color:#f1f1f1}.filter-row{display:flex;align-items:baseline;margin-top:12px}.filter-row:first-child{margin-top:5px}.filter-label{flex-shrink:0;width:45px;font-size:14px;color:#666;font-weight:500}.filter-options{display:flex;flex-wrap:wrap;gap:8px 12px;flex-grow:1}.filter-btn{background:#f0f0f0;border:none;font-size:13px;color:#333;cursor:pointer;padding:5px 12px;border-radius:15px;transition:all .2s ease}.filter-btn:hover{background-color:#e0e0e0}.filter-btn.active{background-color:#333;color:#fff;font-weight:700}.notification-toast{position:fixed;top:60px;left:50%;transform:translate(-50%);background-color:#323232;color:#fff;padding:12px 20px;border-radius:8px;z-index:9999;font-size:14px;box-shadow:0 4px 12px rgba(0,0,0,.15)}.toast-enter-active,.toast-leave-active{transition:opacity .3s,transform .3s}.toast-enter-from,.toast-leave-to{opacity:0;transform:translate(-50%,-20px)}.fade-enter-active,.fade-leave-active{transition:all .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}.music-player{position:fixed;z-index:2000;bottom:0;left:0;right:0;max-width:600px;margin:0 auto;height:60px;background-color:rgba(255,255,255,.95);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid #e0e0e0;display:flex;align-items:center;padding:0 15px;transform:translateY(0);transition:transform .3s ease-in-out}.slide-enter-active,.slide-leave-active{transition:transform .3s ease-in-out}.slide-enter-from,.slide-leave-to{transform:translateY(100%)}.player-cover{width:45px;height:45px;border-radius:50%;object-fit:cover;margin-right:12px;flex-shrink:0}.player-cover.playing{animation:spin 8s linear infinite}.player-info{flex-grow:1;overflow:hidden;margin-right:10px}.player-info .title{font-size:15px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-info .artist{font-size:12px;color:#888}.player-controls{display:flex;align-items:center;gap:10px}.player-controls .control-btn{width:24px;height:24px;color:#333;cursor:pointer}.progress-bar-container{position:absolute;top:-1px;left:0;width:100%;height:2px;background-color:#e0e0e0}.progress-bar{height:100%;background-color:var(--theme-color);transition:width .1s linear}.image-viewer-overlay{position:fixed;z-index:2000;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.9);display:flex;justify-content:center;align-items:center}.image-viewer-overlay img{max-width:95vw;max-height:95vh;object-fit:contain}.viewer-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;background-color:rgba(30,30,30,.6);color:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer;user-select:none}.viewer-nav.prev{left:20px}.viewer-nav.next{right:20px}.viewer-nav .icon-svg{width:20px;height:20px;color:#fff}.viewer-counter{position:absolute;bottom:20px;color:#fff;font-size:16px;background:rgba(0,0,0,.5);padding:5px 10px;border-radius:15px}.lyrics-overlay{position:fixed;z-index:2500;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.8);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;flex-direction:column;justify-content:center;align-items:center;color:#ccc;padding:20px;box-sizing:border-box}.lyrics-container{height:60vh;width:100%;overflow:hidden;text-align:center}.lyrics-list{list-style:none;padding:0;margin:0;transition:transform .5s ease-out}.lyrics-list li{padding:15px 0;font-size:18px;line-height:1.5;transition:color .3s,font-size .3s}.lyrics-list li.active{color:#fff;font-weight:700;font-size:20px}.lyrics-info{position:absolute;top:5%;text-align:center;color:#fff}.lyrics-info h3{margin:0;font-size:22px}.lyrics-info p{margin:5px 0 0;font-size:16px;color:#aaa}.iframe-viewer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.8);z-index:4000;display:flex;justify-content:center;align-items:center;padding:0;box-sizing:border-box;transition:padding .3s ease}.iframe-viewer-content{width:100%;height:100%;border:none;border-radius:0;transition:border-radius .3s ease}@media screen and (min-width: 768px){.iframe-viewer-overlay{padding:50px}.iframe-viewer-content{border-radius:10px;box-shadow:0 5px 20px rgba(0,0,0,.5)}}.iframe-viewer-close-btn{position:absolute;top:15px;right:15px;background-color:rgba(0,0,0,.6);color:#fff;border:none;border-radius:100%;cursor:pointer;font-size:18px;font-weight:700;line-height:1;width:auto;height:40px;box-sizing:border-box;display:flex;justify-content:center;align-items:center;transition:background-color .2s,top .3s ease,right .3s ease}.iframe-viewer-close-btn:hover{background-color:rgba(244,67,54,.8)}@media screen and (min-width: 768px){.iframe-viewer-close-btn{top:25px;right:25px}}.icon-svg{display:inline-block;width:1em;height:1em;vertical-align:-.125em;font-size:25px}.admin-panel-modal .modal-content{max-width:95%;width:auto}.admin-panel-table-wrapper{margin-top:20px;max-height:60vh;overflow:auto;border:1px solid #ddd;border-radius:8px}.admin-panel-table{width:100%;border-collapse:collapse;font-size:12px}.admin-panel-table th,.admin-panel-table td{padding:8px 10px;border:1px solid #e0e0e0;text-align:left;white-space:nowrap}.admin-panel-table th{background-color:#f7f7f7;font-weight:700;position:sticky;top:0;z-index:1}.admin-panel-table tr:nth-child(2n){background-color:#fcfcfc}.admin-panel-table td{vertical-align:middle}.admin-panel-table .user-avatar{width:24px;height:24px;border-radius:50%;vertical-align:middle;margin-right:5px}.admin-panel-table .cell-break{white-space:normal;word-break:break-all;min-width:150px}.admin-panel-table .action-cell .delete-btn{background-color:#f44336;color:#fff;border:none;padding:4px 8px;font-size:12px;border-radius:4px;cursor:pointer}.admin-panel-table .action-cell .delete-btn:hover{background-color:#d32f2f}.admin-panel-table .is-admin-yes{color:#d32f2f;font-weight:700}.add-user-form{border:1px solid #eee;padding:15px;border-radius:8px;margin-top:15px}.add-user-btn{margin-bottom:10px;background-color:#4caf50}.admin-panel-modal .modal-content{width:90%;max-width:1400px}.playlist-viewer-overlay{position:fixed;z-index:2800;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:flex-end}.playlist-viewer-content{background-color:#fff;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:rgba(255,255,255,.9);width:100%;max-width:600px;height:70vh;border-top-left-radius:12px;border-top-right-radius:12px;display:flex;flex-direction:column;box-shadow:0 -5px 20px rgba(0,0,0,.1)}.playlist-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:1px solid #f1f1f1;flex-shrink:0}.playlist-header h3{margin:0;font-size:18px}.playlist-header .close-btn-text{font-size:14px;color:#666;cursor:pointer;padding:4px 12px;border-radius:14px;background-color:#f0f0f0;transition:background-color .2s}.playlist-header .close-btn-text:hover{background-color:#e5e5e5}.playlist-list{list-style:none;padding:0;margin:0;overflow-y:auto;flex-grow:1;scroll-behavior:smooth}.playlist-list li{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;cursor:pointer;border-bottom:1px solid #f9f9f9}.playlist-list li:hover{background-color:#f0f0f0}.playlist-list li .track-info{display:flex;flex-direction:column;overflow:hidden}.playlist-list li .track-title{font-size:15px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-list li .track-artist{font-size:13px;color:#888}.playlist-list li.active .track-title,.playlist-list li.active .track-artist{color:var(--theme-color);font-weight:500}.playlist-list li .playing-indicator svg{width:20px;height:20px;color:var(--theme-color)}.playlist-footer{padding:10px 15px;border-top:1px solid #f1f1f1;display:flex;justify-content:center;align-items:center;gap:20px;flex-shrink:0}.playlist-footer button{background:#f0f0f0;border:none;border-radius:4px;padding:8px 16px;font-size:14px;cursor:pointer}.playlist-footer button:disabled{opacity:.5;cursor:not-allowed}.playlist-footer .page-indicator{font-size:14px;color:#666}.music-subtype-chooser{display:flex;gap:10px;margin-bottom:15px}.music-subtype-chooser .filter-btn{flex:1}.form-group input[type=file]{padding:4px}.pinned-tag{display:inline-block;margin-left:8px;padding:2px 6px;font-size:10px;font-weight:700;color:#e6a23c;background-color:#fdf6ec;border:1px solid #f5dab1;border-radius:4px;vertical-align:middle}.movie-card-vertical .pinned-tag{color:#ffeb3b;background-color:rgba(255,255,255,.2);border-color:rgba(255,255,255,.4);margin-left:0;flex-shrink:0}
