.detail-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8ecf1)}.detail-header{position:relative;background:linear-gradient(135deg,#0a152f,#1a2847);color:#fff;padding:30px 0 24px;overflow:hidden}.detail-header .grid-background{position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(0,212,255,.1) 1px,transparent 0),linear-gradient(90deg,rgba(0,212,255,.1) 1px,transparent 0);background-size:50px 50px;opacity:.3}@keyframes gridMove{0%{transform:translate(0)}to{transform:translate(50px,50px)}}.detail-header .light-source{position:absolute;top:-50%;left:50%;width:200%;height:200%;background:radial-gradient(ellipse at center,rgba(0,153,255,.15) 0,transparent 50%);transform:translateX(-50%);pointer-events:none}.detail-header-container{max-width:1500px;margin:0 auto;padding:0 24px;position:relative;z-index:2;display:flex;gap:32px;align-items:flex-start}.detail-header-left{flex:1;min-width:0}.detail-header-right{flex:1;min-width:0;align-self:center}.header-source-items{display:grid;grid-template-columns:1fr 1fr;gap:10px}.detail-header-right .source-item{background:hsla(0,0%,100%,.1);backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.2);padding:10px 12px}.detail-header-right .source-item:hover{background:hsla(0,0%,100%,.15);border-color:rgba(0,212,255,.5);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,212,255,.2)}.detail-header-right .source-label{color:hsla(0,0%,100%,.95);font-weight:600}.detail-header-right .source-desc{color:hsla(0,0%,100%,.8)}.detail-header-right .download-text{color:#00d4ff;font-weight:600}.detail-header-right .source-icon{background:hsla(0,0%,100%,.2);box-shadow:0 2px 8px rgba(0,0,0,.2)}.detail-header-right .source-item-highlight{background:rgba(245,158,11,.2);border:2px solid rgba(245,158,11,.5);box-shadow:0 4px 16px rgba(245,158,11,.3)}.detail-header-right .source-item-highlight:hover{background:rgba(245,158,11,.3);border-color:rgba(245,158,11,.7);box-shadow:0 6px 20px rgba(245,158,11,.4)}.detail-header-right .source-item-highlight .source-label{color:gold;font-weight:700}.detail-header-right .source-item-highlight .source-desc{color:hsla(0,0%,100%,.9)}.breadcrumb{margin-bottom:12px;font-size:14px;opacity:.8}.breadcrumb-item{color:hsla(0,0%,100%,.8);text-decoration:none;transition:color .3s ease}.breadcrumb-item:hover{color:#00d4ff}.breadcrumb-separator{margin:0 8px;color:hsla(0,0%,100%,.5)}.breadcrumb-current{color:#00d4ff}.detail-title{font-size:28px;font-weight:700;margin:0 0 8px 0;line-height:1.3}.detail-subtitle{display:flex;flex-direction:column;gap:6px;margin:0;align-items:flex-start}.detail-subtitle-row{display:flex;flex-wrap:wrap;gap:3px;align-items:center}.detail-subtitle .language-tag,.detail-subtitle .service-tag{display:inline-flex;align-items:center;padding:2px 6px;font-size:10px;border-radius:3px;font-weight:500;line-height:1}.detail-subtitle .language-tag{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.detail-subtitle .service-tag{background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#065f46}.detail-stats{display:flex;align-items:center;gap:16px;margin-top:4px}.detail-stats .stat-item{display:flex;align-items:center;gap:4px;color:hsla(0,0%,100%,.9);font-size:11px}.detail-stats .stat-item svg{width:12px;height:12px;color:hsla(0,0%,100%,.7);flex-shrink:0}.detail-stats .stat-value{font-weight:600;color:#fff;font-size:11px}.detail-stats .stat-label{color:hsla(0,0%,100%,.7);font-size:10px}.detail-stats .stat-item-mark{cursor:pointer;transition:all .2s ease}.detail-stats .stat-item-mark:hover{opacity:.8}.detail-stats .stat-item-mark.marked{color:rgba(255,215,0,.9)}.detail-stats .stat-item-mark.marked svg{fill:rgba(255,215,0,.9);stroke:rgba(255,215,0,.9);color:rgba(255,215,0,.9)}.detail-stats .stat-item-mark.marked .stat-value{color:gold}.detail-stats .stat-item-mark.marked .stat-label{color:rgba(255,215,0,.9)}.detail-special-note{margin-top:4px;font-size:10px;color:hsla(0,0%,100%,.9);line-height:1.4;letter-spacing:.2px;font-weight:500;background:linear-gradient(135deg,rgba(0,212,255,.15),rgba(0,153,255,.1));padding:4px 8px;border-radius:4px;border:1px solid rgba(0,212,255,.2);display:inline-block}.ai-summary-section{margin:2px 0}.ai-summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:0;box-shadow:0 1px 4px rgba(0,0,0,.04);transition:all .3s ease;overflow:hidden}.ai-summary-card:hover{box-shadow:0 2px 8px rgba(0,0,0,.06);border-color:#cbd5e1}.ai-summary-card.expanded{padding-bottom:0}.ai-summary-header{display:flex;align-items:center;gap:6px;padding:8px 12px;transition:all .3s ease;border-bottom:1px solid transparent}.ai-summary-header.clickable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.ai-summary-header.clickable:hover{background:#f8fafc}.ai-summary-card.expanded .ai-summary-header{border-bottom-color:#f1f5f9;padding-bottom:8px}.ai-expand-icon{width:14px;height:14px;color:#94a3b8;transition:transform .3s ease;flex-shrink:0;margin-left:auto}.ai-expand-icon.expanded{transform:rotate(180deg)}.ai-summary-body{padding:0 12px 10px}.ai-icon{width:18px;height:18px;flex-shrink:0;-o-object-fit:contain;object-fit:contain}.ai-summary-title{font-size:13px;font-weight:600;color:#0f2d52;flex:1;transition:all .3s ease}.ai-generating-indicator{display:flex;align-items:center;gap:3px}.ai-dot{width:4px;height:4px;border-radius:50%;background:#09f;animation:ai-pulse 1.4s ease-in-out infinite}.ai-dot:nth-child(2){animation-delay:.2s}.ai-dot:nth-child(3){animation-delay:.4s}@keyframes ai-pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.ai-summary-content{font-size:12px;line-height:1.6;color:#475569;min-height:40px;max-height:none;overflow-y:hidden;word-break:break-word;transition:height .3s ease;padding:4px 0}.ai-summary-content::-webkit-scrollbar{width:6px}.ai-summary-content::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.ai-summary-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.ai-summary-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.ai-summary-footer{display:flex;align-items:center;gap:6px;padding-top:12px;border-top:1px solid #e2e8f0}.ai-summary-footer-text{font-size:12px;font-weight:600;color:#0f2d52;line-height:1.4;flex:1}.footer-free,.footer-highlight{font-weight:700;color:#09f}.ai-reload-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;background:transparent;border:1px solid #cbd5e1;border-radius:4px;color:#64748b;font-size:11px;font-weight:500;cursor:pointer;transition:all .3s ease;flex-shrink:0;margin-left:8px}.ai-reload-btn:hover{background:#f1f5f9;border-color:#09f;color:#09f;transform:translateY(-1px)}.ai-reload-btn:active{transform:translateY(0)}.ai-reload-btn svg{width:14px;height:14px;flex-shrink:0}.ai-summary-slide-enter-active,.ai-summary-slide-leave-active{transition:all .3s ease;overflow:hidden}.ai-summary-slide-enter,.ai-summary-slide-leave-to{opacity:0;max-height:0;padding-top:0;padding-bottom:0}.ai-summary-slide-enter-to,.ai-summary-slide-leave{opacity:1;max-height:500px}.detail-main{padding:40px 0}.detail-container{max-width:1500px;margin:0 auto;padding:0 24px}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.error-icon{margin-bottom:24px;color:#dc2626}.error-title{font-size:24px;font-weight:600;color:#1f2937;margin:0 0 12px 0}.error-message{font-size:16px;color:#6b7280;margin:0 0 32px 0;line-height:1.6}.retry-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#0f2d53,#1a3d6b 50%,#0d3a5f);background-size:200% 200%;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(15,45,83,.4)}.detail-header-empty{display:none}.empty-state-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center;min-height:calc(100vh - 200px)}.empty-illustration{position:relative;margin-bottom:28px}.illustration-circle{width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,#f0f4f8,#e2e8f0);display:flex;align-items:center;justify-content:center;color:#64748b;animation:float 3s ease-in-out infinite}.illustration-dots{position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);display:flex;gap:6px}.illustration-dots span{width:6px;height:6px;border-radius:50%;background:#cbd5e1;animation:dotPulse 1.5s ease-in-out infinite}.illustration-dots span:nth-child(2){animation-delay:.2s}.illustration-dots span:nth-child(3){animation-delay:.4s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes dotPulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.empty-title-empty{font-size:20px;font-weight:600;color:#1e293b;margin:0 0 10px 0;letter-spacing:.5px}.empty-desc-empty{font-size:14px;color:#64748b;margin:0 0 32px 0;line-height:1.6}.empty-actions-empty{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.empty-btn-empty{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease}.empty-btn-empty.primary-empty{background:#0f172a;color:#fff;border:1px solid #0f172a}.empty-btn-empty.primary-empty:hover{background:#1e293b;transform:translateY(-1px);box-shadow:0 4px 12px rgba(15,23,42,.25)}.empty-btn-empty.secondary-empty{background:#fff;color:#475569;border:1px solid #e2e8f0}.empty-btn-empty.secondary-empty:hover{border-color:#94a3b8;color:#1e293b;transform:translateY(-1px)}.empty-content-empty{flex-direction:column;padding:60px 20px;text-align:center}.empty-content-empty,.empty-content-empty .empty-content-icon{display:flex;align-items:center;justify-content:center;color:#94a3b8}.empty-content-empty .empty-content-icon{width:56px;height:56px;border-radius:12px;background:#f1f5f9;margin-bottom:16px}.empty-content-empty p{font-size:14px;margin:0;color:#94a3b8}.demo-placeholder-empty{flex-direction:column;padding:80px 20px;text-align:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:8px;min-height:300px}.demo-placeholder-empty,.demo-placeholder-icon{display:flex;align-items:center;justify-content:center}.demo-placeholder-icon{width:64px;height:64px;border-radius:50%;background:#fff;margin-bottom:16px;color:#94a3b8;box-shadow:0 2px 8px rgba(0,0,0,.06)}.demo-placeholder-empty p{font-size:14px;margin:0;color:#94a3b8}.comments-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#94a3b8}.comments-empty-state svg{margin-bottom:12px;color:#cbd5e1}.comments-empty-state p{font-size:14px;margin:0;color:#94a3b8}.detail-content{display:flex;gap:24px;align-items:flex-start}.detail-content-left{flex:0 0 300px;min-width:280px}.detail-content-right{flex:1;min-width:0}.detail-content-left{position:sticky;top:70px;display:flex;flex-direction:column;gap:12px;height:-moz-fit-content;height:fit-content;max-height:calc(100vh - 95px);overflow-y:auto;align-self:flex-start;scrollbar-width:thin;scrollbar-color:#193c69 #e8ecf1}.detail-content-left::-webkit-scrollbar{width:8px}.detail-content-left::-webkit-scrollbar-track{background:linear-gradient(135deg,#e8ecf1,#e2e8f0);border-radius:4px;border:1px solid rgba(25,60,105,.1)}.detail-content-left::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#193c69,#153258);border-radius:4px;border:1px solid hsla(0,0%,100%,.2);box-shadow:0 2px 4px rgba(25,60,105,.4)}.detail-content-left::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#153258,#112847);box-shadow:0 2px 6px rgba(25,60,105,.6)}.detail-content-left::-webkit-scrollbar-thumb:active{background:linear-gradient(135deg,#112847,#0e1f36)}.info-section-card{background:#fff;border-radius:5px;padding:12px;box-shadow:0 4px 20px rgba(0,0,0,.08);width:100%}.info-left,.info-right{min-height:auto}.info-section-card.info-right{background:#fff;border-radius:5px;padding:12px;box-shadow:0 4px 20px rgba(0,0,0,.08);width:100%;min-height:auto}.price-service-card{display:flex;flex-direction:column;gap:12px;height:100%}.price-section{text-align:left;padding:0;background:transparent;border-radius:0;border:none;display:flex;flex-direction:column;gap:8px}.price-value{justify-content:flex-start;gap:8px;flex-wrap:wrap}.price-current,.price-value{display:flex;align-items:center}.price-current{gap:4px;padding-bottom:4px;position:relative}.price-current:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#f59e0b,#fbbf24 25%,#f97316 50%,#fbbf24 75%,#f59e0b);border-radius:2px;opacity:.9}.price-symbol{font-size:22px;font-weight:700}.price-number,.price-symbol{background:linear-gradient(135deg,#1a3d6b,#0f2d53 50%,#0d3a5f);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.price-number{font-size:36px;font-weight:900;line-height:1;letter-spacing:-1px}.price-original{display:flex;align-items:center;gap:2px;opacity:.5}.price-original-symbol{font-size:12px;color:#94a3b8;font-weight:500;text-decoration:line-through}.price-original-number{font-size:18px;color:#94a3b8;font-weight:600;text-decoration:line-through;line-height:1}.price-discount-tag{display:inline-flex;align-items:center;padding:3px 8px;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;font-size:10px;font-weight:700;border-radius:10px;border:1px solid #fbbf24;white-space:nowrap;margin-left:4px}.price-discount-tag.price-paid{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border-color:#10b981}.price-services{margin-top:0;padding:0;border-top:none;display:grid;grid-template-columns:1fr 1fr;gap:4px}.service-included-item{display:flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:#0f2d53;line-height:1.2;padding:3px 6px;background:linear-gradient(135deg,#e0f2fe,#dbeafe);border:1px solid #bae6fd;border-radius:4px;transition:all .2s ease}.service-included-item:hover{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#7dd3fc}.service-included-item svg{flex-shrink:0;width:10px;height:10px;color:#0f2d53;stroke-width:2.5}.service-included-highlight{font-weight:600;color:#0f2d53;background:linear-gradient(135deg,#e0f2fe,#dbeafe);border:1px solid #bae6fd}.service-included-highlight:hover{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#7dd3fc}.service-included-highlight svg{color:#0f2d53}.download-btn{width:100%;padding:8px 12px;background:linear-gradient(135deg,#0f2d53,#1a3d6b 50%,#0d3a5f);background-size:200% 200%;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all .3s ease;box-shadow:0 4px 12px rgba(15,45,83,.3);position:relative;overflow:hidden}.download-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(15,45,83,.4)}.download-btn:active{transform:translateY(0)}.download-btn svg{width:16px;height:16px}.download-btn-text{display:flex;flex-direction:column;align-items:center;gap:1px;line-height:1.2}.download-btn-main{font-size:13px;font-weight:600}.download-btn-sub{font-size:10px;font-weight:400;opacity:.9}.download-btn.download-btn-purchased{background:linear-gradient(135deg,#2e7d32,#43a047 50%,#2e7d32);background-size:200% 200%;box-shadow:0 4px 12px rgba(46,125,50,.3)}.download-btn.download-btn-purchased:hover{box-shadow:0 6px 20px rgba(46,125,50,.4)}.download-note{padding:6px 8px;background:linear-gradient(135deg,rgba(255,193,7,.08),rgba(255,152,0,.08));border-radius:4px;font-size:10px;line-height:1.4;color:#666;text-align:center}.added-services-section{flex:1;display:flex;flex-direction:column}.services-title{font-size:13px;font-weight:600;color:#1e293b;margin-bottom:6px;padding-bottom:4px;border-bottom:2px solid #e2e8f0;position:relative;display:flex;align-items:center;gap:4px;flex-wrap:wrap}.services-title:after{content:"";position:absolute;bottom:-2px;left:0;width:40px;height:2px;background:linear-gradient(135deg,#09f,#07c)}.services-note{font-size:12px;font-weight:400;color:#64748b;font-style:normal}.services-empty{text-align:center;padding:40px 20px;color:#94a3b8;font-size:14px}.services-list{display:flex;flex-direction:column;gap:8px}.more-services-btn{display:block;text-align:center;padding:8px 12px;background:linear-gradient(135deg,#f0f7ff,#e0efff);border:1px dashed #183b67;border-radius:6px;color:#183b67;font-size:12px;font-weight:500;text-decoration:none;transition:all .3s ease;margin-top:8px}.more-services-btn:hover{background:#183b67;color:#fff;border-style:solid;transform:translateY(-2px);box-shadow:0 4px 12px rgba(24,59,103,.25)}.service-item{display:flex;align-items:flex-start;padding:6px 10px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:6px;border:1px solid #e2e8f0;transition:all .3s ease;cursor:pointer}.service-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,153,255,.15);border-color:#09f;background:linear-gradient(135deg,#fff,#f8fafc)}.service-info{width:100%}.service-name{font-size:12px;font-weight:600;color:#1e293b;margin-bottom:1px;line-height:1.2}.service-desc{font-size:10px;color:#64748b;line-height:1.3;word-break:break-word}.source-item{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:6px;border:1px solid #e2e8f0;transition:all .3s ease;cursor:pointer;margin-bottom:4px}.source-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,153,255,.15);border-color:#09f;background:linear-gradient(135deg,#fff,#f8fafc)}.source-item-highlight{background:linear-gradient(135deg,#fff7ed,#ffedd5);border:2px solid #f59e0b;box-shadow:0 4px 16px rgba(245,158,11,.2);position:relative}.source-item-highlight:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:12px;z-index:-1;opacity:.1}.source-item-highlight:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(245,158,11,.3);border-color:#d97706;background:linear-gradient(135deg,#fff,#fff7ed)}.source-item-highlight .source-label{color:#d97706;font-weight:700}.source-item-highlight .source-desc{color:#92400e;font-weight:500}.source-icon{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.source-icon img{width:22px;height:22px;-o-object-fit:contain;object-fit:contain}.source-icon-globe{padding:0;position:relative}.source-icon-globe .globe-container{border-radius:50%!important;overflow:hidden}.source-icon-globe .globe-container,.source-icon-globe .globe-container canvas{width:32px!important;height:32px!important}.source-icon-globe .tooltip{display:none}.source-content{flex:1;min-width:0;height:32px;display:flex;flex-direction:column;justify-content:space-between}.source-label{font-size:11px;font-weight:600;color:#1e293b;margin:0;line-height:1.2}.source-desc{font-size:9px;color:#64748b;margin:0;line-height:1.3;word-break:break-word}.download-text{color:#09f;font-weight:600;font-size:9px;text-decoration:underline;-webkit-text-decoration-color:#09f;text-decoration-color:#09f;text-underline-offset:2px;cursor:pointer;transition:all .3s ease}.download-text:hover{color:#07c;-webkit-text-decoration-color:#07c;text-decoration-color:#07c}.author-card{display:flex;flex-direction:column;gap:6px;padding-top:0}.author-header{display:flex;gap:8px;align-items:flex-start;padding-top:0}.author-avatar{position:relative;width:56px;height:56px;flex-shrink:0}.author-avatar img{width:100%;height:100%;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #fff;box-shadow:0 2px 8px rgba(15,45,83,.12);transition:transform .2s ease}.author-avatar:hover img{transform:scale(1.05)}.online-badge{position:absolute;bottom:0;left:50%;transform:translateX(-50%);padding:1px 6px;background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;font-size:8px;border-radius:8px;border:2px solid #fff;font-weight:600;box-shadow:0 2px 6px rgba(0,0,0,.08);display:flex;align-items:center;gap:2px;white-space:nowrap}.online-dot{width:5px;height:5px;background:#10b981;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.author-basic-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0;padding-top:2px}.author-name{font-size:14px;font-weight:700;margin:0;color:#1e293b;line-height:1.2}.author-identity{font-size:11px;color:#64748b;margin:0;line-height:1.2}.author-badges{display:flex;flex-wrap:wrap;gap:3px;margin-top:2px}.badge{display:inline-block;padding:1px 5px;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;font-size:9px;border-radius:6px;font-weight:500}.author-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;width:100%;padding:6px 0;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;margin:0}.stat{display:flex;flex-direction:column;align-items:center;gap:0}.stat-value{font-size:13px;font-weight:700;color:#0f2d53}.stat-label{font-size:10px;color:#64748b}.author-profile-section{margin:0}.author-profile{font-size:11px;color:#475569;line-height:1.4;margin:0;word-break:break-word;white-space:pre-line;text-align:center;padding:0 2px}.last-login{font-size:10px;color:#94a3b8;margin:0;display:flex;align-items:center;justify-content:center;gap:3px}.last-login svg{flex-shrink:0;width:10px;height:10px}.contact-btn{width:100%;padding:8px 12px;background:linear-gradient(135deg,#0f2d53,#1a3d6b 50%,#0d3a5f);background-size:200% 200%;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all .3s ease;box-shadow:0 4px 12px rgba(15,45,83,.3);position:relative;overflow:hidden}.contact-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(15,45,83,.4)}.contact-btn:active{transform:translateY(0)}.recommended-projects-section{background:#fff;border-radius:5px;padding:12px;box-shadow:0 4px 20px rgba(0,0,0,.08)}.recommended-projects-title{font-size:14px;font-weight:600;color:#1e293b;margin:0 0 10px 0;padding-bottom:8px;border-bottom:2px solid #e2e8f0;position:relative}.recommended-projects-title:after{content:"";position:absolute;bottom:-2px;left:0;width:60px;height:2px;background:linear-gradient(135deg,#09f,#07c)}.recommended-projects{width:100%;max-width:100%;overflow:hidden}.recommended-projects-scroll{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;width:100%;max-width:100%;scrollbar-width:thin;scrollbar-color:#cbd5e1 #f1f5f9;-ms-overflow-style:none;padding-bottom:2px}.recommended-projects-scroll::-webkit-scrollbar{height:6px}.recommended-projects-scroll::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.recommended-projects-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.recommended-projects-scroll::-webkit-scrollbar-thumb:hover{background:#94a3b8}.recommended-project-item{cursor:pointer;transition:all .3s ease;border-radius:6px;overflow:hidden;background:#fff;border:1px solid #e2e8f0;flex-shrink:0;width:140px}.recommended-project-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.15);border-color:#09f}.recommended-project-image{width:100%;aspect-ratio:4/3;overflow:hidden;background:#f8fafc;position:relative}.recommended-project-image img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.recommended-project-item:hover .recommended-project-image img{transform:scale(1.05)}.recommended-project-title{position:absolute;bottom:0;left:0;right:0;padding:6px;font-size:10px;color:#fff;font-weight:600;text-align:center;line-height:1.3;word-break:break-word;background:linear-gradient(0deg,rgba(0,0,0,.7) 0,rgba(0,0,0,.4) 50%,transparent);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 2px rgba(0,0,0,.5)}.project-content-section{margin-top:10px;background:#fff;border-radius:5px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.08)}.content-tabs{display:flex;border-bottom:2px solid #e2e8f0;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:8px 8px 0 0;padding:4px 4px 0 4px;gap:4px}.tab-btn{flex:1;padding:14px 20px;background:transparent;border:none;font-size:15px;font-weight:600;color:#64748b;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;border-radius:6px 6px 0 0;overflow:hidden;display:flex;align-items:center;justify-content:center}.tab-btn:before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%) scaleX(0);width:100%;height:100%;background:rgba(0,153,255,.08);transition:transform .3s cubic-bezier(.4,0,.2,1);border-radius:6px 6px 0 0}.tab-btn:hover{color:#0f2d53;background:rgba(15,45,83,.04)}.tab-btn:hover:before{transform:translateX(-50%) scaleX(1)}.tab-btn.active{color:#0f2d53;background:#fff;box-shadow:0 -2px 8px rgba(0,0,0,.04)}.tab-btn.active:before{display:none}.tab-btn.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:linear-gradient(135deg,#09f,#0f2d53 50%,#07c);background-size:200% 100%;animation:gradient-shift 3s ease infinite;border-radius:2px 2px 0 0;box-shadow:0 2px 8px rgba(0,153,255,.3)}@keyframes gradient-shift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.tab-content{min-height:400px}.markdown-content{line-height:1.8;color:#374151}.v-show-content img.lazy-img{min-height:200px;max-width:100%;width:auto;height:auto;transition:opacity .3s ease}.v-show-content img.img-loading,.v-show-content img.lazy-img{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%}.v-show-content img.img-loading{animation:shimmer 1.5s infinite;opacity:.7}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.v-show-content img.img-loaded{animation:fadeIn .5s ease-in;opacity:1}.v-show-content img.img-error{background:#f5f5f5;position:relative;opacity:.5}.v-show-content img.img-error:after{content:"图片加载失败";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#94a3b8;font-size:12px}.md-img-wrapper{position:relative;width:-moz-fit-content;width:fit-content;overflow:hidden;border-radius:4px;margin:8px 0}.md-img-wrapper,.md-img-wrapper img{display:block;max-width:100%}.md-img-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:0;transition:opacity .3s ease;pointer-events:none;cursor:pointer}.md-img-wrapper:hover .md-img-overlay{opacity:1}.md-overlay-icon{color:#fff}.md-overlay-text{color:#fff;font-size:14px;font-weight:500}.markdown-preview{min-height:200px;border:none}.markdown-preview .v-note-wrapper{border:none;box-shadow:none}.markdown-preview .v-note-wrapper .v-note-panel{border:none}.markdown-preview .v-note-wrapper .v-note-panel .v-note-show{padding:24px;background:transparent}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{color:#1f2937;margin:24px 0 16px 0;font-weight:600}.markdown-content h1{font-size:28px}.markdown-content h2{font-size:24px}.markdown-content h3{font-size:20px}.markdown-content h4{font-size:18px}.markdown-content p{margin:16px 0}.markdown-content code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:14px}.markdown-content strong{font-weight:600;color:#1f2937}.markdown-content em{font-style:italic;color:#6b7280}.comments-placeholder,.demo-placeholder,.empty-content{display:flex;align-items:center;justify-content:center;min-height:200px;color:#9ca3af;font-size:16px}.demo-iframe{width:100%;border:none;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1);background:#000}@media (max-width:1000px){.detail-header-container{flex-direction:column;gap:20px}.detail-header-right{width:100%}.detail-content{flex-direction:column;gap:24px}.detail-content-left{flex:none;width:100%}.project-cover{max-width:500px;margin:0 auto}.detail-title{font-size:36px}.detail-subtitle{font-size:16px}.detail-stats{gap:12px;flex-wrap:wrap;margin-top:3px}.detail-stats .stat-item,.detail-stats .stat-value{font-size:10px}.detail-special-note{font-size:9px;margin-top:3px;padding:3px 6px}.detail-content-right{width:100%}.detail-content-left{position:static;max-height:none;overflow:visible}.markdown-preview .v-note-wrapper .v-note-panel .v-note-show{padding:12px 15px}.markdown-preview .v-show-content,.markdown-preview .v-show-content-html{padding:4px 12.5px 7.5px 12.5px!important}}@media (max-width:768px){.detail-header{padding:24px 0 20px}.detail-header-container{flex-direction:column;gap:16px;padding:0 16px}.detail-header-right{width:100%}.detail-container{padding:0 16px}.detail-stats{gap:10px;margin-top:3px}.detail-stats .stat-item{font-size:10px;gap:3px}.detail-stats .stat-item svg{width:11px;height:11px}.detail-stats .stat-value{font-size:10px}.detail-stats .stat-label{font-size:9px}.detail-special-note{font-size:9px;margin-top:3px;padding:3px 6px}.detail-title{font-size:20px}.header-source-items{grid-template-columns:1fr}.ai-summary-section{margin:2px 0}.ai-summary-header{padding:8px 12px}.ai-summary-card.expanded .ai-summary-header{padding-bottom:8px}.ai-summary-body{padding:0 12px 10px}.ai-summary-content{font-size:12px;max-height:180px}.ai-placeholder-icon{width:28px;height:28px}.ai-placeholder-text{font-size:12px}.ai-placeholder-desc{font-size:11px}.ai-summary-footer{flex-wrap:wrap;gap:8px}.ai-summary-footer-text{width:100%;margin-bottom:4px}.ai-reload-btn{width:100%;justify-content:center;margin-left:0}.detail-content{flex-direction:column;gap:20px}.detail-content-left{flex:none;width:100%}.info-section-card{padding:24px 20px}.detail-content-right{width:100%}.detail-content-left{position:static;max-height:none;overflow:visible}.project-title{font-size:24px}.project-description{font-size:14px}.project-stats{gap:16px}.stat-item{font-size:12px}.content-tabs{flex-direction:column;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:4px}.tab-btn{text-align:left;padding:12px 20px;border-radius:6px;background:#f8fafc;border:1px solid transparent;border-left:3px solid transparent;color:#64748b}.tab-btn:hover{background:#f1f5f9;color:#0f2d53}.tab-btn.active{background:linear-gradient(135deg,#e0f2fe,#dbeafe);color:#0f2d53;border:2px solid #09f;box-shadow:0 4px 12px rgba(0,153,255,.25);font-weight:700}.tab-btn.active:after{display:none}.empty-actions{flex-direction:column;align-items:stretch}.action-btn{justify-content:center}.markdown-preview .v-note-wrapper .v-note-panel .v-note-show{padding:8px 12px}.markdown-preview .v-show-content,.markdown-preview .v-show-content-html{padding:4px 12.5px 7.5px 12.5px!important}}@media (max-width:768px){.detail-main{padding:20px 0}.detail-container{padding:0 12px}.project-info-section{padding:20px 16px}.project-title{font-size:20px}.current-price .price-value{font-size:28px}.price-includes{margin-top:16px;padding-top:16px;gap:10px}.include-item{font-size:12px}.purchase-btn{padding:12px 16px;font-size:14px}.markdown-content{font-size:13px!important;line-height:1.6!important}.markdown-content h1{font-size:22px!important;margin:20px 0 14px 0!important}.markdown-content h2{font-size:19px!important;margin:18px 0 12px 0!important}.markdown-content h3{font-size:17px!important;margin:16px 0 10px 0!important}.markdown-content h4{font-size:15px!important;margin:14px 0 8px 0!important}.markdown-content p{margin:14px 0!important}.markdown-content code{font-size:12px!important;padding:1px 5px!important}.markdown-content pre{margin:14px 0!important}.markdown-content pre code{font-size:12px!important;line-height:1.4!important}.markdown-content blockquote{margin:14px 0!important;padding-left:12px!important}.markdown-content ol,.markdown-content ul{margin:14px 0!important;padding-left:18px!important}.markdown-content li{margin:6px 0!important}.markdown-content img{max-width:100%!important;height:auto!important}}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-line{height:12px}.skeleton-line,.skeleton-line-inline{background:linear-gradient(90deg,#f1f5f9,#e2e8f0 50%,#f1f5f9);background-size:200% 100%;border-radius:4px;animation:skeleton-loading 1.5s ease-in-out infinite}.skeleton-line-inline{display:inline-block;height:14px}.skeleton-breadcrumb-header{display:flex;align-items:center;margin-bottom:16px}.header-source-items-skeleton{display:grid;grid-template-columns:1fr 1fr;gap:10px}.skeleton-source-item{background:hsla(0,0%,100%,.1);backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.2);padding:10px 12px;display:flex;gap:12px;align-items:center}.skeleton-source-icon{width:40px;height:40px;border-radius:6px;background:linear-gradient(90deg,hsla(0,0%,100%,.2),hsla(0,0%,100%,.3) 50%,hsla(0,0%,100%,.2));background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;flex-shrink:0}.skeleton-source-content{flex:1;display:flex;flex-direction:column;gap:4px}.skeleton-breadcrumb-header .skeleton-line-inline,.skeleton-source-content .skeleton-line-inline{background:linear-gradient(90deg,hsla(0,0%,100%,.2),hsla(0,0%,100%,.3) 50%,hsla(0,0%,100%,.2));background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:3px}.skeleton-breadcrumb-header .skeleton-line-inline{height:14px}.skeleton-title-header{width:60%;height:32px;background:linear-gradient(90deg,hsla(0,0%,100%,.2),hsla(0,0%,100%,.3) 50%,hsla(0,0%,100%,.2));background-size:200% 100%;border-radius:4px;animation:skeleton-loading 1.5s ease-in-out infinite;margin-bottom:16px}.skeleton-tags-header{display:flex;flex-wrap:wrap;gap:8px}.skeleton-tag-header{width:60px;height:24px;background:linear-gradient(90deg,hsla(0,0%,100%,.2),hsla(0,0%,100%,.3) 50%,hsla(0,0%,100%,.2));background-size:200% 100%;border-radius:12px;animation:skeleton-loading 1.5s ease-in-out infinite}.detail-skeleton{padding:24px 0}.skeleton-content-wrapper{display:flex;gap:24px;align-items:flex-start}.skeleton-content-left{flex:0 0 300px;display:flex;flex-direction:column;gap:12px}.skeleton-content-right{flex:1;display:flex;flex-direction:column;gap:12px}.skeleton-card{background:#fff;border-radius:5px;padding:12px;box-shadow:0 2px 8px rgba(0,0,0,.08)}.skeleton-card-header{display:flex;gap:8px;margin-bottom:6px}.skeleton-avatar-large{width:56px;height:56px;border-radius:50%;flex-shrink:0}.skeleton-avatar-large,.skeleton-badge{background:linear-gradient(90deg,#f1f5f9,#e2e8f0 50%,#f1f5f9);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}.skeleton-badge{width:35px;height:14px;border-radius:6px}.skeleton-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;padding:6px 0;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0}.skeleton-price-section{margin-bottom:12px}.skeleton-price-large{width:150px;height:36px;margin-bottom:8px}.skeleton-download-button,.skeleton-price-large{background:linear-gradient(90deg,#f1f5f9,#e2e8f0 50%,#f1f5f9);background-size:200% 100%;border-radius:6px;animation:skeleton-loading 1.5s ease-in-out infinite}.skeleton-download-button{width:100%;height:38px;margin-bottom:12px}.skeleton-price-original{height:16px;background:linear-gradient(90deg,#f1f5f9,#e2e8f0 50%,#f1f5f9);background-size:200% 100%;border-radius:4px;opacity:.5}.skeleton-price-original,.skeleton-price-tag{width:80px;animation:skeleton-loading 1.5s ease-in-out infinite;margin-bottom:8px}.skeleton-price-tag{display:inline-block;height:20px;background:linear-gradient(90deg,#fef3c7,#fde68a 50%,#fef3c7);background-size:200% 100%;border-radius:10px}.skeleton-services-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:12px}.skeleton-service-item-inline{background:linear-gradient(90deg,#e0f2fe,#dbeafe 50%,#e0f2fe);background-size:200% 100%}.skeleton-download-note,.skeleton-service-item-inline{height:24px;border-radius:4px;animation:skeleton-loading 1.5s ease-in-out infinite}.skeleton-download-note{width:100%;background:linear-gradient(90deg,rgba(255,193,7,.1),rgba(255,152,0,.1) 50%,rgba(255,193,7,.1));background-size:200% 100%;margin-bottom:12px}.skeleton-recommended-title{width:100px;height:18px;background:linear-gradient(90deg,#f1f5f9,#e2e8f0 50%,#f1f5f9);background-size:200% 100%;border-radius:4px;animation:skeleton-loading 1.5s ease-in-out infinite;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #e2e8f0;position:relative}.skeleton-recommended-title:after{content:"";position:absolute;bottom:-2px;left:0;width:40px;height:2px;background:linear-gradient(135deg,#09f,#07c);border-radius:2px}.skeleton-recommended-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.skeleton-recommended-item{flex-shrink:0;width:100px;display:flex;flex-direction:column}.skeleton-recommended-image{aspect-ratio:4/3;background:linear-gradient(90deg,#f1f5f9,#e2e8f0 50%,#f1f5f9);background-size:200% 100%;border-radius:6px;margin-bottom:4px}.skeleton-recommended-image,.skeleton-recommended-name{width:100%;animation:skeleton-loading 1.5s ease-in-out infinite}.skeleton-recommended-name{height:32px;background:linear-gradient(90deg,rgba(0,0,0,.6),rgba(0,0,0,.7) 50%,rgba(0,0,0,.6));background-size:200% 100%;border-radius:4px}.skeleton-ai-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.skeleton-ai-icon{width:18px;height:18px;border-radius:4px;background:linear-gradient(90deg,#f1f5f9,#e2e8f0 50%,#f1f5f9);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}.skeleton-ai-content{padding:12px;background:#f8fafc;border-radius:6px;min-height:60px}.skeleton-tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:2px solid #e2e8f0}.skeleton-tab{width:100px;height:36px;background:linear-gradient(90deg,#f1f5f9,#e2e8f0 50%,#f1f5f9);background-size:200% 100%;border-radius:6px 6px 0 0;animation:skeleton-loading 1.5s ease-in-out infinite}.skeleton-content-area{padding:16px 0;min-height:300px}@media (max-width:1000px){.skeleton-content-wrapper{flex-direction:column}.skeleton-content-left{width:100%;flex:none}.skeleton-content-right{width:100%}}@media (max-width:768px){.skeleton-title-header{width:80%}.skeleton-card-header{flex-direction:column;align-items:center;text-align:center}.skeleton-stats-grid{grid-template-columns:1fr}.skeleton-content-left{width:100%;flex:none}.skeleton-content-right{width:100%}}.fade-out-enter-active,.fade-out-leave-active{transition:opacity .3s ease-out}.fade-out-enter,.fade-out-leave-to{opacity:0}.fade-out-enter-to,.fade-out-leave{opacity:1}.fade-in-enter-active{transition:opacity .5s ease-in;transition-delay:.15s}.fade-in-enter{opacity:0}.fade-in-enter-to{opacity:1}.detail-container{position:relative}.detail-skeleton{position:absolute;top:0;left:0;right:0;z-index:1;width:100%;pointer-events:none}.detail-content{z-index:2;width:100%}.detail-content,.detail-header-left{position:relative}.detail-header-left .fade-out-enter,.detail-header-left .fade-out-enter-active,.detail-header-left .fade-out-leave-active,.detail-header-left .fade-out-leave-to{position:absolute;top:0;left:0;right:0;width:100%;z-index:1}.detail-header-left .fade-in-enter,.detail-header-left .fade-in-enter-active,.detail-header-left .fade-in-enter-to,.detail-header-left .fade-in-leave-active{position:relative;z-index:2}.detail-header-right{position:relative}.detail-header-right .fade-out-enter,.detail-header-right .fade-out-enter-active,.detail-header-right .fade-out-leave-active,.detail-header-right .fade-out-leave-to{position:absolute;top:0;left:0;right:0;width:100%;z-index:1}.detail-header-right .fade-in-enter,.detail-header-right .fade-in-enter-active,.detail-header-right .fade-in-enter-to,.detail-header-right .fade-in-leave-active{position:relative;z-index:2}.v-note-img-wrapper img{max-width:85vw!important;max-height:85vh!important;width:auto!important;height:auto!important;-o-object-fit:contain;object-fit:contain}.v-note-img-wrapper .image-nav-next,.v-note-img-wrapper .image-nav-prev{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.2);border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:10001;backdrop-filter:blur(10px);padding:0;margin:0}.v-note-img-wrapper .image-nav-next:hover,.v-note-img-wrapper .image-nav-prev:hover{background:hsla(0,0%,100%,.2);border-color:hsla(0,0%,100%,.4);transform:translateY(-50%) scale(1.1)}.v-note-img-wrapper .image-nav-prev{left:20px}.v-note-img-wrapper .image-nav-next{right:20px}.v-note-img-wrapper .image-magnifier{position:absolute;width:120px;height:120px;border:3px solid hsla(0,0%,100%,.9);border-radius:50%;pointer-events:none;display:none;z-index:1000;box-shadow:0 4px 20px rgba(0,0,0,.4),inset 0 0 20px rgba(0,0,0,.1);background-repeat:no-repeat;background-color:rgba(0,0,0,.8)}.v-note-img-wrapper .image-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.6);backdrop-filter:blur(10px);padding:8px 16px;border-radius:20px;color:#fff;font-size:14px;font-weight:500;letter-spacing:.5px;z-index:10001;pointer-events:none}.v-note-img-wrapper .image-loading-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10002;display:flex;align-items:center;justify-content:center;pointer-events:none;font-size:18px;font-weight:500;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.v-note-img-wrapper .image-loading-indicator .loading-char{display:inline-block;animation:loadingCharJump 1.2s ease-in-out infinite}@keyframes loadingCharJump{0%,to{transform:translateY(0)}15%{transform:translateY(-10px)}30%{transform:translateY(0)}}.v-note-img-wrapper img.image-loading{opacity:.5;transition:opacity .3s ease}@media (max-width:768px){.v-note-img-wrapper img{transform:rotate(90deg)!important;max-width:72vh!important;max-height:50vh!important}.v-note-img-wrapper .image-nav-next,.v-note-img-wrapper .image-nav-prev{width:40px;height:40px}.v-note-img-wrapper .image-nav-prev{top:60px!important}.v-note-img-wrapper .image-nav-next,.v-note-img-wrapper .image-nav-prev{left:50%!important;right:auto!important;transform:translateX(-50%) rotate(90deg)!important}.v-note-img-wrapper .image-nav-next{bottom:50px!important;top:auto!important}.v-note-img-wrapper .image-counter{top:50%!important;bottom:auto!important;left:10px!important;right:auto!important;transform:translateY(-50%) rotate(90deg)!important;padding:4px 10px;font-size:12px;white-space:nowrap}.v-note-img-wrapper .image-loading-indicator{transform:translate(-50%,-50%) rotate(90deg)!important}}.comments-section{padding:10px 10px}.comment-publish-box{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px;margin-bottom:16px;box-shadow:0 2px 8px rgba(0,0,0,.04);position:relative;transition:all .3s ease}.comment-publish-box.drag-over{position:relative}.comment-publish-box.drag-over:before{content:"拖拽图片到此处上传";position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);backdrop-filter:blur(2px);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500;z-index:1001;pointer-events:none}.comment-publish-box.is-locked{background:#f8fafc;border-color:#e2e8f0;opacity:.6}.comment-publish-box.is-locked .comment-publish-header,.comment-publish-box.is-locked .comment-textarea,.comment-publish-box.is-locked .publish-btn,.comment-publish-box.is-locked .toolbar-btn{pointer-events:none;opacity:.5}.login-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.9);backdrop-filter:blur(2px);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:all .3s ease}.login-overlay:hover{background:rgba(0,0,0,.6)}.login-overlay-content{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.lock-icon{color:#fff;width:48px;height:48px;animation:lockPulse 2s ease-in-out infinite}@keyframes lockPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.login-text{margin:0}.go-login-btn,.login-text{color:#fff;font-size:14px;font-weight:600}.go-login-btn{padding:8px 24px;background:linear-gradient(135deg,#0f2d53,#1a3d6b 50%,#0d3a5f);border:none;border-radius:6px;cursor:pointer;transition:all .3s ease;margin-top:8px}.go-login-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(15,45,83,.5)}.go-login-btn:active{transform:translateY(0)}.comment-publish-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.publish-title{font-size:14px;font-weight:600;color:#1e293b;margin:0}.char-count{font-size:12px;color:#94a3b8;font-weight:500}.char-count.over-limit{color:#dc2626;font-weight:600}.comment-textarea{width:100%;min-height:80px;padding:10px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#1e293b;line-height:1.5;resize:none;transition:all .3s ease;font-family:inherit;box-sizing:border-box;margin-bottom:8px}.comment-textarea:focus{outline:none;border-color:#09f;box-shadow:0 0 0 3px rgba(0,153,255,.1)}.comment-textarea::-moz-placeholder{color:#cbd5e1}.comment-textarea::placeholder{color:#cbd5e1}.comment-toolbar{justify-content:space-between;margin-top:0}.comment-toolbar,.toolbar-left{display:flex;align-items:center;gap:8px}.toolbar-item,.toolbar-item.emoji-trigger{position:relative}.toolbar-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;background:transparent;border:1px solid #e2e8f0;border-radius:4px;color:#64748b;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease}.toolbar-btn:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.toolbar-btn svg{width:18px;height:18px;flex-shrink:0}.emoji-picker-wrapper{position:absolute;top:calc(100% + 8px);left:0;z-index:1000;animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.toolbar-right{display:flex;align-items:center}.publish-btn{padding:6px 16px;background:linear-gradient(135deg,#0f2d53,#1a3d6b 50%,#0d3a5f);background-size:200% 200%;color:#fff;border:none;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.publish-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px rgba(15,45,83,.3)}.publish-btn:active:not(:disabled){transform:translateY(0)}.publish-btn:disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed;box-shadow:none}.image-preview{margin-top:8px;padding-top:8px;border-top:1px solid #e2e8f0}.preview-wrapper{position:relative;display:inline-block;border-radius:8px;overflow:hidden;border:2px solid #e2e8f0;background:#f8fafc}.preview-wrapper img{max-width:200px;max-height:200px;width:auto;height:auto;display:block;-o-object-fit:contain;object-fit:contain}.remove-image-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;padding:0}.remove-image-btn:hover{background:rgba(220,38,38,.8);transform:scale(1.1)}.remove-image-btn svg{width:16px;height:16px}@media (max-width:768px){.comment-publish-box{padding:12px}.comment-publish-header{margin-bottom:10px}.publish-title{font-size:14px}.char-count{font-size:11px}.comment-textarea{min-height:80px;padding:10px;font-size:13px}.comment-toolbar{flex-wrap:wrap;gap:8px}.toolbar-left{flex:1;gap:6px}.toolbar-btn{padding:6px 10px;font-size:12px}.toolbar-btn span{display:none}.publish-btn{padding:6px 16px;font-size:13px}.preview-wrapper img{max-width:150px;max-height:150px}}.comments-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#666}.comments-loading .loading-spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top-color:#1890ff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(1turn)}}.comments-error{text-align:center;padding:60px 20px;color:#ff4d4f}.comments-error .retry-btn{margin-top:16px;padding:8px 16px;background:#1890ff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .3s}.comments-error .retry-btn:hover{background:#40a9ff}.comments-list{gap:16px}.comment-item,.comments-list{display:flex;flex-direction:column}.comment-item.main-comment{padding-bottom:12px;border-bottom:1px solid #f0f0f0}.comment-item.main-comment:last-child{border-bottom:none}.comment-content{display:flex;gap:10px}.comment-avatar{flex-shrink:0;width:40px;height:40px;border-radius:50%;overflow:hidden;background:#f0f0f0}.comment-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.comment-body{flex:1;display:flex;flex-direction:column;gap:4px}.comment-header{justify-content:space-between}.comment-header,.comment-header-left{display:flex;align-items:center;gap:8px}.comment-header-left{flex:1;flex-wrap:wrap}.comment-nickname{font-weight:500;font-size:13px;color:#333}.comment-location{font-size:11px;color:#999}.comment-reply-btn{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;background:linear-gradient(135deg,#0f2d53,#1a3d6b);color:#fff;border:none;border-radius:3px;font-size:11px;font-weight:400;cursor:pointer;white-space:nowrap;transition:all .3s ease;flex-shrink:0;box-shadow:0 2px 6px rgba(15,45,83,.2)}.comment-reply-btn:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(15,45,83,.3)}.comment-reply-btn svg{width:14px;height:14px;stroke-linecap:round;stroke-linejoin:round}.comment-text{font-size:13px;color:#666;line-height:1.5;word-wrap:break-word;white-space:pre-wrap;margin:0}.comment-image{margin-top:4px;display:inline-block}.comment-image-wrapper{position:relative;display:inline-block;border-radius:4px;overflow:hidden;border:1px solid #e2e8f0;box-shadow:0 2px 8px rgba(0,0,0,.1);background:#fff;padding:2px}.comment-image-wrapper img{max-width:200px;max-height:200px;width:auto;height:auto;border-radius:3px;cursor:pointer;transition:all .3s;-o-object-fit:cover;object-fit:cover;display:block}.comment-image-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s cubic-bezier(.4,0,.2,1);border-radius:4px;pointer-events:none}.comment-image-wrapper:hover .comment-image-overlay{opacity:1}.comment-overlay-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.comment-eye-icon{color:#fff;width:20px;height:20px}.comment-overlay-text{color:#fff;font-size:12px;font-weight:500;text-align:center}.sub-comments{margin-top:12px;margin-left:50px;padding-left:12px;border-left:2px solid #f0f0f0;display:flex;flex-direction:column;gap:12px}.sub-comment .comment-content{gap:8px}.sub-comment .comment-avatar{width:30px;height:30px}.sub-comment .comment-nickname,.sub-comment .comment-text{font-size:12px}.sub-comment .comment-image-wrapper{border-color:#cbd5e1;box-shadow:0 1px 4px rgba(0,0,0,.08);padding:1px}.sub-comment .comment-image-wrapper img{max-width:150px;max-height:150px}.reply-form-wrapper{margin-top:8px;padding:10px;background:#f9fafb;border-radius:6px;animation:slideDown .3s ease}.main-reply-form{margin-left:0}.reply-form-container{display:flex;flex-direction:column;gap:6px}.reply-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.reply-to-text{font-size:12px;color:#666;font-weight:500}.close-reply-btn{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:color .3s ease}.close-reply-btn:hover{color:#333}.reply-textarea{width:100%;min-height:70px;padding:8px 10px;border:1px solid #e5e7eb;border-radius:4px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:13px;color:#333;resize:none;transition:all .3s ease}.reply-textarea:focus{outline:none;border-color:#06f;box-shadow:0 0 0 3px rgba(0,102,255,.1)}.reply-textarea::-moz-placeholder{color:#999}.reply-textarea::placeholder{color:#999}.reply-toolbar{justify-content:space-between;align-items:center;margin-top:0;margin-bottom:8px}.reply-toolbar,.reply-toolbar .toolbar-left{display:flex;gap:8px}.reply-toolbar .toolbar-item{position:relative}.reply-toolbar .toolbar-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;background:#f0f1f3;border:1px solid #e5e7eb;color:#666;border-radius:4px;font-size:12px;font-weight:400;cursor:pointer;transition:all .3s ease}.reply-toolbar .toolbar-btn:hover{background:#e8eaed;border-color:#d1d5db;color:#333}.reply-toolbar .toolbar-btn svg{flex-shrink:0}.reply-toolbar .emoji-picker-wrapper{position:absolute;bottom:100%;left:0;margin-bottom:8px;z-index:1000}.reply-form-footer{display:flex;justify-content:space-between;align-items:center}.reply-char-count{font-size:11px;color:#999}.reply-submit-btn{padding:6px 12px;background:linear-gradient(135deg,#06f,#0052cc);color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease}.reply-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,102,255,.3)}.reply-submit-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes zoomIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@media (max-width:768px){.comments-section{padding:16px 0}.comments-list{gap:20px}.sub-comments{margin-left:42px;padding-left:12px}.comment-avatar{width:36px;height:36px}.sub-comment .comment-avatar{width:28px;height:28px}.comment-image-wrapper img{max-width:150px;max-height:150px}.sub-comment .comment-image-wrapper img{max-width:120px;max-height:120px}.reply-textarea{min-height:70px;font-size:14px}.reply-char-count{font-size:11px}.reply-submit-btn{padding:6px 12px;font-size:12px}}.complaint-section{margin-top:12px;border-top:1px solid #e2e8f0;padding-top:12px}.complaint-header{display:flex;align-items:center;gap:6px;padding:8px 10px;background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;border-radius:6px;cursor:pointer;transition:all .3s ease}.complaint-header:hover{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#fca5a5}.complaint-header svg{flex-shrink:0;color:#dc2626}.complaint-header span{font-size:12px;font-weight:600;color:#dc2626}.toggle-icon{margin-left:auto;font-size:10px;color:#dc2626}.complaint-body{padding:12px 0}.complaint-types{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.complaint-type-item{padding:4px 10px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;font-size:11px;color:#64748b;cursor:pointer;transition:all .2s ease}.complaint-type-item:hover{background:#f1f5f9;border-color:#cbd5e1;color:#475569}.complaint-type-item.selected{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#fca5a5;color:#dc2626;font-weight:500}.complaint-textarea{width:100%;padding:8px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:12px;color:#1e293b;line-height:1.5;resize:none;transition:all .3s ease;font-family:inherit;box-sizing:border-box;margin-bottom:8px}.complaint-textarea:focus{outline:none;border-color:#fca5a5;box-shadow:0 0 0 3px rgba(252,165,165,.1)}.complaint-textarea::-moz-placeholder{color:#cbd5e1}.complaint-textarea::placeholder{color:#cbd5e1}.complaint-footer{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.complaint-char-count{font-size:11px;color:#94a3b8}.complaint-image-upload{position:relative}.complaint-file-input{position:absolute;width:100%;height:100%;top:0;left:0;opacity:0;cursor:pointer;z-index:2}.complaint-upload-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#f1f5f9;border:1px dashed #cbd5e1;border-radius:4px;font-size:11px;color:#64748b;cursor:pointer;transition:all .2s ease}.complaint-upload-btn:hover{background:#e2e8f0;border-color:#94a3b8}.complaint-image-preview{position:relative;width:60px;height:60px;border-radius:4px;overflow:hidden}.complaint-image-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.complaint-image-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;background:rgba(0,0,0,.6);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:background .2s ease}.complaint-image-remove:hover{background:rgba(220,38,38,.9)}.complaint-submit-btn{width:100%;padding:8px 12px;background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease}.complaint-submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(220,38,38,.3)}.complaint-submit-btn:active{transform:translateY(0)}@media (max-width:768px){.complaint-section{margin-top:10px;padding-top:10px}.complaint-header{padding:6px 8px}.complaint-header span{font-size:11px}.complaint-types{gap:4px}.complaint-type-item{padding:3px 8px;font-size:10px}.complaint-textarea{font-size:12px;padding:6px 8px}.complaint-footer{flex-direction:column;align-items:flex-start;gap:6px}.complaint-char-count{font-size:10px}.complaint-upload-btn{padding:3px 8px;font-size:10px}.complaint-image-preview{width:50px;height:50px}.complaint-submit-btn{padding:6px 10px;font-size:12px}}.globe-fixed-btn{position:fixed;bottom:100px;right:30px;z-index:998;display:flex;flex-direction:column;align-items:center}.globe-fade-enter-active{opacity:0;transform:translateY(20px);transition:opacity .4s ease,transform .4s ease}.globe-fade-enter-to{opacity:1;transform:translateY(0)}.globe-fade-leave-active{opacity:1;transition:opacity .4s ease,transform .4s ease}.globe-fade-leave-to{opacity:0;transform:translateY(20px)}.globe-fixed-button{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.globe-fixed-button:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 28px rgba(15,45,83,.4)}.globe-fixed-button:active{transform:translateY(-2px) scale(1.02)}.globe-fixed-popup{position:absolute;right:70px;top:50%;transform:translateY(-50%);background:#fff;border-radius:8px;padding:12px 16px;box-shadow:0 4px 20px rgba(0,0,0,.15);opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;pointer-events:none}.globe-fixed-btn:hover .globe-fixed-popup{opacity:1;visibility:visible;right:80px;pointer-events:auto}.globe-fixed-popup-content{text-align:center}.globe-fixed-popup-title{font-size:14px;font-weight:600;color:#0f2d53;margin:0 0 4px 0;line-height:1.2}.globe-fixed-popup-desc{font-size:12px;color:#666;margin:0;line-height:1.3}.globe-fixed-popup-arrow{position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:6px solid #fff}@media (max-width:1000px){.globe-fixed-btn{bottom:90px;right:15px}}.globe-fixed-btn .globe-container{width:56px!important;height:56px!important;border-radius:50%!important;overflow:hidden;display:flex!important;align-items:center!important;justify-content:center!important}.globe-fixed-btn .globe-container canvas{width:56px!important;height:56px!important;max-width:none!important;flex-shrink:0!important}.globe-fixed-btn .tooltip{display:none!important}