/* 🎨 用户统计页面自定义样式 */ /* 📱 响应式布局优化 */ @media (max-width: 768px) { .container { padding-left: 1rem; padding-right: 1rem; } .card { margin-bottom: 1rem; } .grid { grid-template-columns: 1fr; gap: 1rem; } .stat-card { padding: 0.75rem; } .stat-card .text-2xl { font-size: 1.5rem; } .model-usage-item .grid { grid-template-columns: 1fr 1fr; gap: 0.5rem; } .text-4xl { font-size: 2rem; } .input-field, .btn-primary { padding: 0.75rem 1rem; } } @media (max-width: 480px) { .container { padding-left: 0.5rem; padding-right: 0.5rem; } .text-4xl { font-size: 1.75rem; } .text-lg { font-size: 1rem; } .card { padding: 1rem; } .stat-card { padding: 0.5rem; } .stat-card .text-2xl { font-size: 1.25rem; } .stat-card .text-sm { font-size: 0.75rem; } .model-usage-item .grid { grid-template-columns: 1fr; } .flex.gap-3 { flex-direction: column; gap: 0.75rem; } .btn-primary { width: 100%; justify-content: center; } } /* 🌈 渐变背景增强 */ .gradient-bg { background: linear-gradient(135deg, #667eea 0%, #764ba2 50%, #f093fb 100%); background-size: 200% 200%; animation: gradientShift 15s ease infinite; } @keyframes gradientShift { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } } /* ✨ 卡片样式增强 */ .card { transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); backdrop-filter: blur(20px); border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: 0 8px 32px rgba(31, 38, 135, 0.37); } .card:hover { transform: translateY(-4px) scale(1.02); box-shadow: 0 20px 40px rgba(31, 38, 135, 0.5); border-color: rgba(255, 255, 255, 0.3); } /* 🎯 统计卡片样式 */ .stat-card { background: linear-gradient(135deg, rgba(255, 255, 255, 0.15) 0%, rgba(255, 255, 255, 0.05) 100%); border: 1px solid rgba(255, 255, 255, 0.2); transition: all 0.3s ease; position: relative; overflow: hidden; } .stat-card::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent); transition: left 0.5s; } .stat-card:hover::before { left: 100%; } .stat-card:hover { background: linear-gradient(135deg, rgba(255, 255, 255, 0.25) 0%, rgba(255, 255, 255, 0.15) 100%); transform: translateY(-2px); box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1); } /* 🔍 输入框增强 */ .input-field { background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.2); transition: all 0.3s ease; backdrop-filter: blur(10px); } .input-field::placeholder { color: rgba(255, 255, 255, 0.6); } .input-field:focus { background: rgba(255, 255, 255, 0.2); border-color: rgba(255, 255, 255, 0.5); outline: none; box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.1); transform: translateY(-1px); } /* 🎨 按钮增强 */ .btn-primary { background: linear-gradient(135deg, #4f46e5 0%, #7c3aed 50%, #ec4899 100%); background-size: 200% 200%; transition: all 0.3s ease; position: relative; overflow: hidden; } .btn-primary::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent); transition: left 0.5s; } .btn-primary:hover::before { left: 100%; } .btn-primary:hover { background-position: 100% 0; transform: translateY(-2px); box-shadow: 0 15px 30px rgba(79, 70, 229, 0.4); } .btn-primary:active { transform: translateY(0); box-shadow: 0 5px 15px rgba(79, 70, 229, 0.3); } /* 📊 模型使用项增强 */ .model-usage-item { transition: all 0.3s ease; border: 1px solid rgba(255, 255, 255, 0.1); position: relative; overflow: hidden; } .model-usage-item::before { content: ''; position: absolute; top: 0; left: -100%; width: 100%; height: 100%; background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.05), transparent); transition: left 0.6s; } .model-usage-item:hover::before { left: 100%; } .model-usage-item:hover { transform: translateX(8px) translateY(-2px); background: rgba(255, 255, 255, 0.08); border-color: rgba(255, 255, 255, 0.2); box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1); } /* 🔄 加载动画增强 */ .loading-spinner { animation: spin 1s linear infinite; filter: drop-shadow(0 0 4px rgba(255, 255, 255, 0.5)); } @keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } } /* 🌟 动画效果 */ .fade-in { animation: fadeIn 0.6s ease-out; } @keyframes fadeIn { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } } .slide-in { animation: slideIn 0.4s ease-out; } @keyframes slideIn { from { opacity: 0; transform: translateX(-30px); } to { opacity: 1; transform: translateX(0); } } /* 🎯 焦点样式增强 */ .input-field:focus-visible, .btn-primary:focus-visible { outline: 2px solid rgba(255, 255, 255, 0.5); outline-offset: 2px; } /* 📱 滚动条样式 */ ::-webkit-scrollbar { width: 8px; } ::-webkit-scrollbar-track { background: rgba(255, 255, 255, 0.1); border-radius: 4px; } ::-webkit-scrollbar-thumb { background: rgba(255, 255, 255, 0.3); border-radius: 4px; transition: background 0.3s ease; } ::-webkit-scrollbar-thumb:hover { background: rgba(255, 255, 255, 0.5); } /* 🚨 错误状态样式 */ .error-border { border-color: #ef4444 !important; box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1); } /* 🎉 成功状态样式 */ .success-border { border-color: #10b981 !important; box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.1); } /* 🌙 深色模式适配 */ @media (prefers-color-scheme: dark) { .card { background: rgba(0, 0, 0, 0.2); border-color: rgba(255, 255, 255, 0.15); } .stat-card { background: linear-gradient(135deg, rgba(255, 255, 255, 0.1) 0%, rgba(255, 255, 255, 0.05) 100%); } .input-field { background: rgba(0, 0, 0, 0.3); border-color: rgba(255, 255, 255, 0.3); } } /* 🔍 高对比度模式支持 */ @media (prefers-contrast: high) { .card { border-width: 2px; border-color: rgba(255, 255, 255, 0.5); } .input-field { border-width: 2px; border-color: rgba(255, 255, 255, 0.6); } .btn-primary { border: 2px solid rgba(255, 255, 255, 0.5); } } /* 📊 数据可视化增强 */ .chart-container { position: relative; background: rgba(255, 255, 255, 0.05); border-radius: 12px; padding: 20px; border: 1px solid rgba(255, 255, 255, 0.1); backdrop-filter: blur(10px); } /* 🎨 图标动画 */ .fas { transition: transform 0.3s ease; } .card:hover .fas { transform: scale(1.1); } /* 💫 悬浮效果 */ .hover-lift { transition: transform 0.3s ease, box-shadow 0.3s ease; } .hover-lift:hover { transform: translateY(-4px); box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15); } /* 🎯 选中状态 */ .selected { background: rgba(255, 255, 255, 0.2) !important; border-color: rgba(255, 255, 255, 0.4) !important; transform: scale(1.02); } /* 🌈 彩虹边框效果 */ .rainbow-border { position: relative; background: linear-gradient(45deg, #ff6b6b, #4ecdc4, #45b7d1, #96ceb4, #feca57); background-size: 400% 400%; animation: gradientBG 15s ease infinite; padding: 2px; border-radius: 12px; } .rainbow-border > * { background: rgba(0, 0, 0, 0.8); border-radius: 10px; } @keyframes gradientBG { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } } /* 📱 触摸设备优化 */ @media (hover: none) and (pointer: coarse) { .card:hover { transform: none; box-shadow: 0 8px 32px rgba(31, 38, 135, 0.37); } .btn-primary:hover { transform: none; background-position: 0% 0; } .model-usage-item:hover { transform: none; background: rgba(255, 255, 255, 0.05); } } /* 🎯 打印样式 */ @media print { .gradient-bg { background: white !important; color: black !important; } .card { border: 1px solid #ccc !important; background: white !important; box-shadow: none !important; } .btn-primary { display: none !important; } .input-field { border: 1px solid #ccc !important; background: white !important; } }