/* 闻阳团购总平台 全局样式 正式上线版 */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
body, html {
  width: 100%;
  height: 100%;
  font-family: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", Arial, sans-serif;
  background-color: #f5f7fa;
  --primary-color: #07C160;
  --primary-light: rgba(7, 193, 96, 0.1);
  --text-primary: #303133;
  --text-secondary: #606266;
  --text-weak: #909399;
  --border-color: #e4e7ed;
  --bg-white: #fff;
  --bg-page: #f5f7fa;
  --danger-color: #F53F3F;
  --success-color: #00B42A;
  --warning-color: #FF7D00;
}
#app {
  width: 100%;
  height: 100%;
}

/* 主容器布局 */
.app-container {
  display: flex;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

/* 侧边栏 复刻抖音来客深色风格 */
.sidebar {
  width: 220px;
  height: 100%;
  background-color: #1d2129;
  transition: width 0.3s ease;
  overflow: hidden;
  flex-shrink: 0;
}
.sidebar.collapse {
  width: 64px;
}
.sidebar .logo {
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 18px;
  font-weight: 600;
  background-color: var(--primary-color);
  border-bottom: 1px solid #06ae56;
}
.sidebar .el-menu {
  border-right: none;
  background-color: transparent;
  --el-menu-bg-color: transparent;
  --el-menu-hover-bg-color: rgba(255,255,255,0.08);
  --el-menu-active-bg-color: var(--primary-color);
  --el-menu-text-color: #bfcbd9;
  --el-menu-active-color: #fff;
}
.sidebar .el-menu-item.is-active {
  background-color: var(--primary-color) !important;
  color: #fff !important;
}
.sidebar .el-menu-item:hover {
  background-color: var(--el-menu-hover-bg-color) !important;
}

/* 主内容区 */
.main-wrapper {
  flex: 1;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  background-color: var(--bg-page);
}
/* 顶部导航栏 */
.header-bar {
  height: 60px;
  background-color: var(--bg-white);
  border-bottom: 1px solid var(--border-color);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  flex-shrink: 0;
  box-shadow: 0 1px 4px rgba(0,0,0,0.05);
}
.header-left {
  display: flex;
  align-items: center;
  gap: 20px;
}
.header-right {
  display: flex;
  align-items: center;
  gap: 16px;
  font-weight: 500;
  color: var(--text-primary);
}
/* 页面内容区 */
.page-content {
  flex: 1;
  padding: 20px 24px;
  overflow-y: auto;
  background-color: var(--bg-page);
}

/* 通用组件样式 */
.search-bar {
  margin-bottom: 16px;
  border-radius: 8px;
}
.search-bar .el-card__body {
  padding: 16px 20px;
}
.el-card {
  border-radius: 8px;
  border: none;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  margin-bottom: 16px;
}
.el-card .el-card__header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--border-color);
}
.el-card .el-card__header .card-header-right {
  display: flex;
  align-items: center;
  gap: 12px;
}
.el-table {
  margin-top: 10px;
  --el-table-header-text-color: var(--text-secondary);
  --el-table-row-hover-bg-color: var(--primary-light);
}
.el-pagination {
  margin-top: 20px;
  text-align: right;
}
.el-dialog {
  border-radius: 8px;
}
.el-dialog .el-form-item {
  margin-bottom: 20px;
}

/* 统计卡片 */
.stats-card {
  height: 100%;
}
.stats-card .el-card__body {
  padding: 20px;
}
.stats-label {
  font-size: 14px;
  color: var(--text-weak);
  margin-bottom: 8px;
}
.stats-number {
  font-size: 32px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.stats-desc {
  font-size: 12px;
  color: var(--text-weak);
}
.stats-trend {
  margin-top: 8px;
  font-size: 12px;
}
.stats-trend.up {
  color: var(--danger-color);
}
.stats-trend.down {
  color: var(--success-color);
}

/* 图表容器 */
.chart-container {
  width: 100%;
  height: 360px;
  margin-top: 16px;
}

/* 快捷操作 */
.shortcut-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px 0;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.3s ease;
}
.shortcut-item:hover {
  background-color: var(--primary-light);
}
.shortcut-item span {
  margin-top: 12px;
  font-size: 14px;
  color: var(--text-secondary);
}

/* 页面通用 */
.home-page, .merchant-page, .store-page, .poi-page, .goods-page, .order-page, .claim-page, .comment-page, .finance-page, .withdraw-page, .data-page, .setting-page {
  width: 100%;
  height: 100%;
}

/* 响应式适配 */
@media screen and (max-width: 1400px) {
  .stats-number {
    font-size: 28px;
  }
}
@media screen and (max-width: 1200px) {
  .stats-number {
    font-size: 24px;
  }
  .page-content {
    padding: 16px;
  }
}