/* A股量化交易系统 - 简洁清爽浅色调设计 */ /* ========== 全局样式 ========== */ :root { /* 蓝色调配色方案 */ --primary-color: #2563eb; --primary-light: #60a5fa; --primary-lighter: #dbeafe; --secondary-color: #64748b; --success-color: #10b981; --warning-color: #f59e0b; --danger-color: #ef4444; --info-color: #06b6d4; /* 背景色 */ --bg-primary: #fefefe; --bg-secondary: #f8fafc; --bg-tertiary: #f1f5f9; --bg-accent: #ffffff; /* 文字色 */ --text-primary: #1e293b; --text-secondary: #64748b; --text-muted: #94a3b8; /* 边框色 */ --border-color: #e2e8f0; --border-light: #f1f5f9; /* 阴影 */ --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05); --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06); --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05); /* 圆角 */ --radius-sm: 0.375rem; --radius-md: 0.5rem; --radius-lg: 0.75rem; } body { font-family: 'Inter', 'SF Pro Display', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', sans-serif; background-color: var(--bg-secondary); color: var(--text-primary); line-height: 1.6; font-size: 14px; } /* ========== 导航栏 ========== */ .navbar { background: linear-gradient(135deg, var(--bg-accent) 0%, var(--bg-secondary) 100%); border-bottom: 1px solid var(--border-color); backdrop-filter: blur(10px); box-shadow: var(--shadow-sm); padding: 0.75rem 0; } .navbar-brand { font-weight: 600; font-size: 1.125rem; color: var(--primary-color) !important; display: flex; align-items: center; gap: 0.5rem; } .navbar-brand i { color: var(--primary-color); font-size: 1.25rem; } .nav-link { color: var(--text-secondary) !important; font-weight: 500; padding: 0.5rem 1rem !important; border-radius: var(--radius-sm); transition: all 0.2s ease; margin: 0 0.125rem; } .nav-link:hover { color: var(--primary-color) !important; background-color: var(--primary-lighter); } .nav-link.active { color: var(--primary-color) !important; background-color: var(--primary-lighter); font-weight: 600; } .navbar-text { color: var(--text-muted) !important; font-size: 0.875rem; } /* ========== 卡片样式 ========== */ .card { background-color: var(--bg-accent); border: 1px solid var(--border-color); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); transition: all 0.3s ease; overflow: hidden; } .card:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); } .card-header { background: linear-gradient(135deg, var(--bg-tertiary) 0%, var(--bg-secondary) 100%); border-bottom: 1px solid var(--border-color); padding: 1rem 1.25rem; font-weight: 600; color: var(--text-primary); } .card-body { padding: 1.25rem; } /* 统计卡片 */ .stats-card { background: linear-gradient(135deg, var(--bg-accent) 0%, var(--bg-tertiary) 100%); border: 1px solid var(--border-light); border-radius: var(--radius-md); padding: 0.75rem; transition: all 0.3s ease; position: relative; overflow: hidden; } .stats-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--primary-color), var(--primary-light)); } .stats-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); } .stats-value { font-size: 1.25rem; font-weight: 700; color: var(--primary-color); margin-bottom: 0.125rem; } .stats-label { font-size: 0.75rem; color: var(--text-secondary); font-weight: 500; } .stats-sublabel { font-size: 0.675rem; color: var(--text-muted); margin-top: 0.125rem; } /* ========== 表格样式 ========== */ .table-container { background-color: var(--bg-accent); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); } .table { margin-bottom: 0; font-size: 0.875rem; } .table thead th { background: linear-gradient(135deg, var(--bg-tertiary) 0%, var(--bg-secondary) 100%); border-bottom: 2px solid var(--border-color); border-top: none; font-weight: 600; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-secondary); padding: 1rem 0.75rem; } .table tbody tr { border-bottom: 1px solid var(--border-light); transition: all 0.2s ease; } .table tbody tr:hover { background-color: var(--bg-secondary); } .table tbody tr:last-child { border-bottom: none; } .table tbody td { padding: 0.875rem 0.75rem; vertical-align: middle; color: var(--text-primary); } .table-active { background-color: var(--primary-lighter) !important; } /* ========== 徽章样式 ========== */ .badge { font-size: 0.75rem; font-weight: 500; padding: 0.375rem 0.75rem; border-radius: var(--radius-sm); border: 1px solid transparent; } .bg-primary { background-color: var(--primary-color) !important; color: white; } .bg-secondary { background-color: var(--text-muted) !important; color: white; } .bg-success { background-color: var(--success-color) !important; color: white; } .bg-warning { background-color: var(--warning-color) !important; color: white; } .bg-danger { background-color: var(--danger-color) !important; color: white; } .bg-info { background-color: var(--info-color) !important; color: white; } /* 浅色徽章变体 */ .badge-light-primary { background-color: var(--primary-lighter); color: var(--primary-color); border-color: var(--primary-light); } .badge-light-success { background-color: #dcfce7; color: var(--success-color); border-color: #bbf7d0; } .badge-light-warning { background-color: #fef3c7; color: var(--warning-color); border-color: #fde68a; } .badge-light-danger { background-color: #fecaca; color: var(--danger-color); border-color: #fca5a5; } /* ========== 按钮样式 ========== */ .btn { font-weight: 500; border-radius: var(--radius-sm); padding: 0.5rem 1rem; font-size: 0.875rem; border: 1px solid transparent; transition: all 0.2s ease; display: inline-flex; align-items: center; gap: 0.375rem; } .btn-primary { background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%); border-color: var(--primary-color); color: white; } .btn-primary:hover { background: linear-gradient(135deg, #1d4ed8 0%, var(--primary-color) 100%); border-color: #1d4ed8; transform: translateY(-1px); box-shadow: var(--shadow-md); } .btn-outline-primary { background-color: transparent; border-color: var(--primary-color); color: var(--primary-color); } .btn-outline-primary:hover { background-color: var(--primary-color); border-color: var(--primary-color); color: white; } .btn-sm { padding: 0.375rem 0.75rem; font-size: 0.75rem; } /* ========== 警告框样式 ========== */ .alert { border: none; border-radius: var(--radius-md); padding: 1rem 1.25rem; border-left: 4px solid; } .alert-info { background: linear-gradient(135deg, #e0f2fe 0%, #f0f9ff 100%); border-left-color: var(--info-color); color: #0e7490; } .alert-warning { background: linear-gradient(135deg, #fef3c7 0%, #fffbeb 100%); border-left-color: var(--warning-color); color: #92400e; } .alert-danger { background: linear-gradient(135deg, #fecaca 0%, #fef2f2 100%); border-left-color: var(--danger-color); color: #991b1b; } .alert-success { background: linear-gradient(135deg, #dcfce7 0%, #f0fdf4 100%); border-left-color: var(--success-color); color: #15803d; } /* ========== 分页样式 ========== */ .pagination { gap: 0.25rem; } .pagination .page-link { color: var(--text-secondary); border: 1px solid var(--border-color); border-radius: var(--radius-sm); padding: 0.5rem 0.75rem; font-size: 0.875rem; background-color: var(--bg-accent); transition: all 0.2s ease; } .pagination .page-link:hover { background-color: var(--primary-lighter); border-color: var(--primary-light); color: var(--primary-color); } .pagination .page-item.active .page-link { background-color: var(--primary-color); border-color: var(--primary-color); color: white; } /* ========== 表单控件 ========== */ .form-select, .form-control { border: 1px solid var(--border-color); border-radius: var(--radius-sm); background-color: var(--bg-accent); color: var(--text-primary); font-size: 0.875rem; transition: all 0.2s ease; } .form-select:focus, .form-control:focus { border-color: var(--primary-light); box-shadow: 0 0 0 3px var(--primary-lighter); outline: none; } /* ========== 页脚 ========== */ footer { background: linear-gradient(135deg, var(--bg-accent) 0%, var(--bg-secondary) 100%); border-top: 1px solid var(--border-color); margin-top: 3rem; } footer .text-muted { color: var(--text-muted) !important; font-size: 0.875rem; } /* ========== 工具类 ========== */ .text-primary { color: var(--primary-color) !important; } .text-success { color: var(--success-color) !important; } .text-warning { color: var(--warning-color) !important; } .text-danger { color: var(--danger-color) !important; } .text-muted { color: var(--text-muted) !important; } .fw-bold { font-weight: 600 !important; } /* ========== 空状态 ========== */ .empty-state { text-align: center; padding: 3rem 1rem; color: var(--text-muted); } .empty-state i { font-size: 3rem; color: var(--text-muted); margin-bottom: 1rem; opacity: 0.6; } .empty-state h4 { color: var(--text-secondary); font-weight: 500; margin-bottom: 0.5rem; } /* ========== 加载动画 ========== */ .loading { width: 1.25rem; height: 1.25rem; border: 2px solid var(--border-light); border-top: 2px solid var(--primary-color); border-radius: 50%; animation: spin 1s linear infinite; } @keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } } /* ========== 响应式设计 ========== */ @media (max-width: 768px) { .container { padding-left: 1rem; padding-right: 1rem; } .card-body { padding: 1rem; } .table-responsive { font-size: 0.75rem; } .stats-card { padding: 1rem; } .stats-value { font-size: 1.5rem; } .badge { font-size: 0.625rem; padding: 0.25rem 0.5rem; } } /* ========== 特殊效果 ========== */ .fade-in { animation: fadeIn 0.5s ease-in; } @keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } } .hover-lift { transition: transform 0.2s ease; } .hover-lift:hover { transform: translateY(-2px); } /* ========== 滚动条美化 ========== */ ::-webkit-scrollbar { width: 6px; height: 6px; } ::-webkit-scrollbar-track { background: var(--bg-secondary); } ::-webkit-scrollbar-thumb { background: var(--border-color); border-radius: 3px; } ::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }