/* ============================================
   layout.css — 全局布局样式
   涵盖：页面框架、导航栏、侧边栏、内容区
   ============================================ */

/* ---- 页面根容器 ---- */
.app-layout {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* ---- 顶部导航栏 ---- */
.app-navbar {
  height: 56px;
  background-color: var(--color-navbar-bg);
  color: var(--color-navbar-text);
  display: flex;
  align-items: center;
  padding: 0 24px;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  box-shadow: var(--shadow-sm);
}

.app-navbar .nav-left {
  display: flex;
  align-items: center;
  gap: 16px;
  flex: 1;
}

.app-navbar .nav-right {
  display: flex;
  align-items: center;
  gap: 12px;
}

.app-navbar .logo {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-inverse);
  white-space: nowrap;
}

.app-navbar .nav-separator {
  width: 1px;
  height: 20px;
  background: rgba(255, 255, 255, 0.4);
}

.app-navbar .nav-menu-item {
  font-size: var(--font-size-base);
  color: var(--color-text-inverse);
  padding: 4px 12px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background 0.2s;
}
.app-navbar .nav-menu-item:hover {
  background: rgba(255, 255, 255, 0.15);
}

/* ---- 主体区域（正文 + 侧边栏，按需使用） ---- */
.app-body {
  display: flex;
  flex: 1;
  margin-top: 56px;
  min-height: calc(100vh - 56px);
}

/* ---- 左侧菜单（如需要） ---- */
.app-sidebar {
  width: 220px;
  background: var(--color-bg-white);
  border-right: 1px solid var(--color-border-light);
  padding: 16px 0;
  flex-shrink: 0;
}

.sidebar-menu-item {
  display: flex;
  align-items: center;
  height: 40px;
  padding: 0 20px;
  font-size: var(--font-size-base);
  color: var(--color-text-regular);
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.sidebar-menu-item:hover {
  background: var(--color-bg-hover);
  color: var(--color-primary);
}
.sidebar-menu-item.active {
  background: var(--color-primary-light);
  color: var(--color-primary);
  font-weight: var(--font-weight-medium);
  border-right: 3px solid var(--color-primary);
}

/* ---- 主内容区 ---- */
.app-content {
  flex: 1;
  padding: 20px 24px;
  overflow-y: auto;
  background: var(--color-bg-page);
}

/* ---- 通栏内容区（无侧边栏） ---- */
.app-content--full {
  flex: 1;
  padding: 20px 24px;
  overflow-y: auto;
  background: var(--color-bg-page);
}

/* ---- 页面卡片容器 ---- */
.content-card {
  background: var(--color-bg-white);
  border-radius: var(--radius-md);
  padding: 24px;
  box-shadow: var(--shadow-sm);
}

.content-card + .content-card {
  margin-top: 16px;
}

/* ---- 弹性行/列辅助 ---- */
.flex-row {
  display: flex;
  align-items: center;
}

.flex-column {
  display: flex;
  flex-direction: column;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-wrap {
  flex-wrap: wrap;
}

.flex-1 {
  flex: 1;
}

/* ---- 间距辅助 ---- */
.gap-4  { gap: 4px; }
.gap-8  { gap: 8px; }
.gap-12 { gap: 12px; }
.gap-16 { gap: 16px; }
.gap-20 { gap: 20px; }
.gap-24 { gap: 24px; }

/* ---- 内容区宽度限制（大屏居中） ---- */
.content-max-width {
  max-width: 1400px;
  margin: 0 auto;
}
