@import "tailwindcss"; @import "tw-animate-css"; @import "../css/tailwindcss.css"; body { @apply bg-background-default text-txt-primary-normal; font-family: var(--font-poppins); } /* 滚动条样式 */ ::-webkit-scrollbar { width: 0px; height: 0px; } ::-webkit-scrollbar-thumb { background: #888; } @utility text-gradient { background: linear-gradient(135.00deg, rgba(255, 156, 181, 1),rgba(188, 151, 239, 1) 49%,rgba(139, 230, 240, 1) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; } /* 水波纹动画 */ @keyframes wave { 0%, 100% { transform: scaleY(0.4); } 50% { transform: scaleY(1); } } /* 语音声波动画 */ @keyframes voice-wave { 0%, 100% { transform: scaleY(0.3); } 50% { transform: scaleY(1); } } .animate-voice-wave { animation: voice-wave 1s ease-in-out infinite; } /* 心动等级变化时的缩放动画 */ @keyframes scale-down { 0% { transform: scale(1.5); opacity: 0; } 50% { opacity: 0.8; } 100% { transform: scale(1); opacity: 1; } } .animate-scale-down { animation: scale-down 0.8s cubic-bezier(0.4, 0, 0.2, 1) forwards; } .animate-delay-100 { animation-delay: 100ms; } .animate-delay-200 { animation-delay: 200ms; } .animate-delay-300 { animation-delay: 300ms; } /* 心形背景消失动画 */ @keyframes scale-fade-out { 0% { transform: scale(1); opacity: inherit; } 100% { transform: scale(0.3); opacity: 0 !important; } } .animate-scale-fade-out { animation: scale-fade-out 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards; } /* 心形从小到大并渐隐(用于升级/降级双心叠加) */ @keyframes heart-scale-up-fade { 0% { transform: scale(0.1); opacity: 0.2; } 100% { transform: scale(0.6); opacity: 0; } } @keyframes heart-scale-up-fade2 { 0% { transform: scale(0.5); opacity: 0.2; } 100% { transform: scale(1); opacity: 0; } } .animate-heart-scale-up-fade { animation: heart-scale-up-fade2 2.1s ease-out; } .animate-heart-scale-up-fade-2 { animation: heart-scale-up-fade 2.1s ease-out; } /* 心形徽章从大缩放到正常尺寸(升级/降级时) */ @keyframes heart-badge-scale-down { 0% { transform: scale(2); opacity: 0.8; } 100% { transform: scale(1); opacity: 1; } } .animate-heart-badge-scale-down { animation: heart-badge-scale-down 0.4s cubic-bezier(0.4, 0, 0.2, 1) forwards; } /* 解锁权益浮窗动画 - 升级时从下往上滑入 */ @keyframes unlock-slide-up { 0% { transform: translateY(100%); opacity: 0; } 20% { opacity: 1; } 100% { transform: translateY(0); opacity: 1; } } .animate-unlock-slide-up { animation: unlock-slide-up 0.5s ease-out forwards; /* 确保动画结束后保持在正确位置 */ transform: translateY(0); opacity: 1; } /* 解锁权益浮窗动画 - 降级时从上往下滑出 */ @keyframes unlock-slide-down { 0% { transform: translateY(0); opacity: 1; } 100% { transform: translateY(100%); opacity: 0; } } .animate-unlock-slide-down { animation: unlock-slide-down 0.5s ease-in forwards; } /* 解锁权益浮窗消失动画 - 3秒后淡出 */ @keyframes unlock-fade-out { 0% { transform: translateY(0); opacity: 1; } 100% { transform: translateY(-20px); opacity: 0; } } .animate-unlock-fade-out { animation: unlock-fade-out 0.3s ease-in forwards; } /* 解锁权益浮窗淡入动画 - 降级时直接从原地出现 */ @keyframes unlock-fade-in { 0% { opacity: 0; transform: translateY(0); } 100% { opacity: 1; transform: translateY(0); } } .animate-unlock-fade-in { animation: unlock-fade-in 0.3s ease-out forwards; } /* 等级数字变化动画 */ @keyframes level-change { 0% { opacity: 1; transform: scale(1); } 50% { opacity: 0; transform: scale(0.8); } 100% { opacity: 1; transform: scale(1); } } .animate-level-change { animation: level-change 0.6s cubic-bezier(0.4, 0, 0.2, 1); } /* 增强版语音声波动画 */ @keyframes voice-wave-enhanced { 0%, 100% { transform: scaleY(0.4) scaleX(0.95); opacity: 0.8; } 25% { transform: scaleY(0.8) scaleX(1); opacity: 0.9; } 50% { transform: scaleY(1.2) scaleX(1.05); opacity: 1; } 75% { transform: scaleY(0.9) scaleX(1); opacity: 0.95; } } .animate-voice-wave-enhanced { animation: voice-wave-enhanced 1s ease-in-out infinite; transform-origin: center bottom; } /* 涟漪扩散效果的语音声波动画 */ @keyframes voice-wave-ripple { 0% { transform: scaleY(0.3); opacity: 0.6; } 15% { transform: scaleY(0.7); opacity: 0.8; } 30% { transform: scaleY(1.1); opacity: 1; } 45% { transform: scaleY(0.9); opacity: 0.95; } 60% { transform: scaleY(1.0); opacity: 1; } 75% { transform: scaleY(0.8); opacity: 0.9; } 100% { transform: scaleY(0.4); opacity: 0.7; } } .animate-voice-wave-ripple { animation: voice-wave-ripple 1.5s ease-in-out infinite; transform-origin: center center; } /* 淡入动画 */ @keyframes fade-in { from { opacity: 0; } to { opacity: 1; transform: translateY(0); } } .animate-fade-in { animation: fade-in 0.8s ease-out forwards; } .animate-wave-1 { animation: wave 1.2s infinite linear; animation-delay: -1.0s; } .animate-wave-2 { animation: wave 0.8s infinite linear; animation-delay: -0.9s; } .animate-wave-3 { animation: wave 1.2s infinite linear; animation-delay: -0.8s; } /* React Easy Crop 样式 */ .reactEasyCrop_Container { position: relative !important; width: 100%; height: 100%; background: transparent; } .reactEasyCrop_Container img { max-width: none; } .reactEasyCrop_CropArea { position: absolute; border: none !important; box-sizing: border-box; cursor: move; overflow: hidden; } .reactEasyCrop_CropAreaRound { border-radius: 50%; } .reactEasyCrop_CropAreaGrid::before { content: ''; position: absolute; border-left: 1px solid rgba(255, 255, 255, 0.4); border-right: 1px solid rgba(255, 255, 255, 0.4); left: 33.33%; right: 33.33%; top: 0; bottom: 0; } .reactEasyCrop_CropAreaGrid::after { content: ''; position: absolute; border-top: 1px solid rgba(255, 255, 255, 0.4); border-bottom: 1px solid rgba(255, 255, 255, 0.4); top: 33.33%; bottom: 33.33%; left: 0; right: 0; } /* 滑块样式 */ .slider { -webkit-appearance: none; appearance: none; background: transparent; cursor: pointer; } .slider::-webkit-slider-track { background: #4b5563; height: 8px; border-radius: 4px; } .slider::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; background: #3b82f6; height: 18px; width: 18px; border-radius: 50%; cursor: pointer; } .slider::-moz-range-track { background: #4b5563; height: 8px; border-radius: 4px; border: none; } .slider::-moz-range-thumb { background: #3b82f6; height: 18px; width: 18px; border-radius: 50%; cursor: pointer; border: none; } /* 头像裁剪弹窗专用样式 */ .zoom-slider { -webkit-appearance: none; appearance: none; cursor: pointer; height: 4px; } .zoom-slider::-webkit-slider-track { background: rgba(255, 255, 255, 0.2); height: 4px; border-radius: 2px; } .zoom-slider::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; background: white; height: 16px; width: 16px; border-radius: 50%; cursor: pointer; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); } .zoom-slider::-moz-range-track { background: rgba(255, 255, 255, 0.2); height: 4px; border-radius: 2px; border: none; } .zoom-slider::-moz-range-thumb { background: white; height: 16px; width: 16px; border-radius: 50%; cursor: pointer; border: none; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); } /* 头像裁剪区域样式 */ .avatar-crop-container .reactEasyCrop_CropArea { border: 2px solid rgba(255, 255, 255, 0.8); box-shadow: 0 0 0 9999em rgba(0, 0, 0, 0.6); } /* 等待拨通的圆点动画 */ @keyframes calling-dots { 0%, 80%, 100% { transform: scale(0.8); opacity: 0.6; } 40% { transform: scale(1.2); opacity: 1; } } .animate-calling-dots-1 { animation: calling-dots 1.5s infinite ease-in-out; animation-delay: 0s; } .animate-calling-dots-2 { animation: calling-dots 1.5s infinite ease-in-out; animation-delay: 0.5s; } .animate-calling-dots-3 { animation: calling-dots 1.5s infinite ease-in-out; animation-delay: 1s; } .avatar-crop-media { object-fit: cover; } /* Listening状态的三个点动画 */ @keyframes listening-dots { 0%, 20%, 100% { opacity: 0.3; } 50% { opacity: 1; } } .animate-listening-dot-1 { animation: listening-dots 1.5s infinite ease-in-out; animation-delay: 0s; } .animate-listening-dot-2 { animation: listening-dots 1.5s infinite ease-in-out; animation-delay: 0.3s; } .animate-listening-dot-3 { animation: listening-dots 1.5s infinite ease-in-out; animation-delay: 0.6s; } .PhotoView-Slider__BannerWrap { display: none !important; } .PhotoView-Slider__ArrowRight { display: none !important; } .PhotoView-Slider__ArrowLeft { display: none !important; } /* 钻石图标样式 */ .bg-diamond-icon { background-image: url('/icons/diamond.svg'); } .swiper-slide-shadow-right, .swiper-slide-shadow-left { display: none !important; }