/* MineNASAI WebUI 样式 */ :root { --bg-primary: #1a1b26; --bg-secondary: #24283b; --bg-tertiary: #1f2335; --text-primary: #c0caf5; --text-secondary: #565f89; --accent-primary: #7aa2f7; --accent-success: #9ece6a; --accent-warning: #e0af68; --accent-error: #f7768e; --border-color: #3b4261; } * { margin: 0; padding: 0; box-sizing: border-box; } body { font-family: 'Segoe UI', 'Microsoft YaHei', sans-serif; background-color: var(--bg-primary); color: var(--text-primary); height: 100vh; overflow: hidden; } .app-container { height: 100vh; } /* 侧边栏 */ .sidebar { background-color: var(--bg-primary); border-right: 1px solid var(--border-color); transition: width 0.3s; overflow: hidden; } .logo { height: 60px; display: flex; align-items: center; justify-content: center; gap: 10px; border-bottom: 1px solid var(--border-color); cursor: pointer; } .logo-icon { font-size: 24px; } .logo-text { font-size: 18px; font-weight: 600; color: var(--accent-primary); } .el-menu { border-right: none !important; } .el-menu-item.is-active { background-color: var(--bg-secondary) !important; } .el-menu-item:hover, .el-sub-menu__title:hover { background-color: var(--bg-tertiary) !important; } /* 头部 */ .header { background-color: var(--bg-secondary); border-bottom: 1px solid var(--border-color); display: flex; align-items: center; justify-content: space-between; padding: 0 20px; height: 60px; } .header-left { display: flex; align-items: center; } .header-right { display: flex; align-items: center; gap: 16px; } /* 主内容区 */ .main-content { background-color: var(--bg-tertiary); padding: 20px; overflow-y: auto; } /* 卡片样式 */ .config-card { background-color: var(--bg-secondary); border: 1px solid var(--border-color); border-radius: 8px; margin-bottom: 20px; } .config-card .el-card__header { background-color: var(--bg-tertiary); border-bottom: 1px solid var(--border-color); padding: 15px 20px; } .config-card .el-card__body { padding: 20px; } /* 统计卡片 */ .stat-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; margin-bottom: 20px; } .stat-card { background-color: var(--bg-secondary); border: 1px solid var(--border-color); border-radius: 8px; padding: 20px; } .stat-card-title { font-size: 14px; color: var(--text-secondary); margin-bottom: 8px; } .stat-card-value { font-size: 28px; font-weight: 600; color: var(--accent-primary); } .stat-card-sub { font-size: 12px; color: var(--text-secondary); margin-top: 4px; } /* 表单样式 */ .el-form-item__label { color: var(--text-secondary) !important; } .el-input__inner, .el-textarea__inner, .el-select .el-input__inner { background-color: var(--bg-tertiary) !important; border-color: var(--border-color) !important; color: var(--text-primary) !important; } .el-input__inner:focus, .el-textarea__inner:focus { border-color: var(--accent-primary) !important; } .el-select-dropdown { background-color: var(--bg-secondary) !important; border-color: var(--border-color) !important; } .el-select-dropdown__item { color: var(--text-primary) !important; } .el-select-dropdown__item.hover, .el-select-dropdown__item:hover { background-color: var(--bg-tertiary) !important; } /* 表格样式 */ .el-table { --el-table-bg-color: var(--bg-secondary); --el-table-header-bg-color: var(--bg-tertiary); --el-table-tr-bg-color: var(--bg-secondary); --el-table-row-hover-bg-color: var(--bg-tertiary); --el-table-text-color: var(--text-primary); --el-table-header-text-color: var(--text-secondary); --el-table-border-color: var(--border-color); } /* 终端容器 */ .terminal-container { background-color: var(--bg-primary); border: 1px solid var(--border-color); border-radius: 8px; overflow: hidden; height: calc(100vh - 180px); } .terminal-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 15px; background-color: var(--bg-secondary); border-bottom: 1px solid var(--border-color); } .terminal-title { display: flex; align-items: center; gap: 8px; } .terminal-status { width: 8px; height: 8px; border-radius: 50%; background-color: var(--accent-error); } .terminal-status.connected { background-color: var(--accent-success); } .terminal-body { height: calc(100% - 45px); padding: 8px; } /* 日志容器 */ .logs-container { background-color: var(--bg-primary); border: 1px solid var(--border-color); border-radius: 8px; height: calc(100vh - 180px); overflow: hidden; } .logs-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 15px; background-color: var(--bg-secondary); border-bottom: 1px solid var(--border-color); } .logs-body { height: calc(100% - 45px); overflow-y: auto; padding: 10px 15px; font-family: 'Cascadia Code', 'Fira Code', monospace; font-size: 12px; } .log-entry { padding: 4px 0; border-bottom: 1px solid var(--border-color); display: flex; gap: 10px; } .log-time { color: var(--text-secondary); flex-shrink: 0; } .log-level { flex-shrink: 0; padding: 0 6px; border-radius: 3px; font-size: 10px; text-transform: uppercase; } .log-level.info { background-color: rgba(122, 162, 247, 0.2); color: var(--accent-primary); } .log-level.warn { background-color: rgba(224, 175, 104, 0.2); color: var(--accent-warning); } .log-level.error { background-color: rgba(247, 118, 142, 0.2); color: var(--accent-error); } .log-message { flex: 1; word-break: break-all; } /* 按钮样式 */ .el-button--primary { --el-button-bg-color: var(--accent-primary); --el-button-border-color: var(--accent-primary); --el-button-hover-bg-color: #89b4fa; --el-button-hover-border-color: #89b4fa; } /* 对话框样式 */ .el-dialog { --el-dialog-bg-color: var(--bg-secondary); --el-dialog-border-radius: 8px; } .el-dialog__header { border-bottom: 1px solid var(--border-color); } .el-dialog__title { color: var(--text-primary) !important; } /* 标签页 */ .el-tabs__item { color: var(--text-secondary) !important; } .el-tabs__item.is-active { color: var(--accent-primary) !important; } /* Provider 卡片 */ .provider-card { background-color: var(--bg-tertiary); border: 1px solid var(--border-color); border-radius: 8px; padding: 16px; margin-bottom: 12px; transition: border-color 0.3s; } .provider-card:hover { border-color: var(--accent-primary); } .provider-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; } .provider-name { display: flex; align-items: center; gap: 8px; font-weight: 500; } .provider-badge { font-size: 11px; padding: 2px 8px; border-radius: 10px; background-color: rgba(122, 162, 247, 0.2); color: var(--accent-primary); } .provider-badge.domestic { background-color: rgba(158, 206, 106, 0.2); color: var(--accent-success); } /* 响应式 */ @media (max-width: 768px) { .sidebar { position: fixed; z-index: 100; left: -220px; } .sidebar.open { left: 0; } }