/* ============================================================
   Layout System — F型信息流布局
   ============================================================ */

/* ----- 容器 ----- */
.container {
  max-width: var(--content-max-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
}

/* ----- F型布局：主内容 + 侧边栏 ----- */
.f-layout {
  display: flex;
  gap: var(--space-lg);
  align-items: flex-start;
}

.main-content {
  flex: 1;
  min-width: 0;           /* 防止 flex item 溢出 */
}

.sidebar {
  width: var(--sidebar-width);
  flex-shrink: 0;
}

/* ----- 响应式卡片网格 ----- */
.grid-2,
.grid-3,
.grid-4 {
  display: grid;
  gap: var(--space-md);
}

.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

/* ----- 毛玻璃固定导航 ----- */
.header__bar {
  position: sticky;
  top: 0;
  z-index: var(--z-nav);
  height: var(--header-height);
  padding: 0;
  background: var(--bg-header__bar);
  -webkit-backdrop-filter: var(--glass-blur-nav);
  backdrop-filter: var(--glass-blur-nav);
  box-shadow: var(--shadow-nav);
}

/* ----- 毛玻璃卡片 ----- */
.card-glass {
  background: var(--bg-card);
  -webkit-backdrop-filter: var(--glass-blur);
  backdrop-filter: var(--glass-blur);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-border-light);
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}

.card-glass:hover {
  box-shadow: var(--shadow-card-hover);
}

/* ----- 区块间距 ----- */
.section {
  padding: var(--space-2xl) 0;
}

.section-sm {
  padding: var(--space-lg) 0;
}

/* ----- 响应式：平板及以下 ----- */
@media (max-width: 1023px) {
  .f-layout {
    flex-direction: column;
  }

  .sidebar {
    width: 100%;
  }

  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
}

/* ----- 响应式：手机 ----- */
@media (max-width: 767px) {
  .container {
    padding-left: var(--space-md);
    padding-right: var(--space-md);
  }

  .grid-4,
  .grid-3,
  .grid-2 {
    grid-template-columns: 1fr;
  }

  .sidebar {
    display: none;
  }

  .section {
    padding: var(--space-xl) 0;
  }
}
