/* ═══ 响应式布局 ═══ */

/* ── 全局容器 ── */
#app {
  max-width: 960px;
  margin: 0 auto;
  min-height: 100vh;
  padding-bottom: 60px; /* 为底部搜索栏留空 */
}

/* ── 页面容器 ── */
.page {
  display: none;
  padding: var(--space-lg);
  animation: fadeIn 0.2s ease;
}
.page.active { display: block; }

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── 顶栏 ── */
.top-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 48px;
  padding: 0 var(--space-lg);
  background: var(--color-bg-white);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 0;
  z-index: 100;
}
.top-bar-title {
  font-size: var(--fs-lg);
  font-weight: 600;
}
.top-bar-left, .top-bar-right {
  min-width: var(--touch-min);
  display: flex;
  align-items: center;
}

/* ── 底部固定栏 ── */
.bottom-bar {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 960px;
  background: var(--color-bg-white);
  border-top: 1px solid var(--color-border);
  padding: var(--space-sm) var(--space-lg);
  z-index: 100;
  padding-bottom: calc(var(--space-sm) + env(safe-area-inset-bottom, 0));
}

/* ── 响应式断点 ── */

/* 手机端 (<768px) —— 默认已适配 */

/* 平板端 (768px - 1023px) */
@media (min-width: 768px) {
  #app {
    padding: 0 var(--space-xl);
  }
  .page {
    padding: var(--space-xl);
  }
}

/* PC端 (≥1024px) */
@media (min-width: 1024px) {
  #app {
    padding: 0;
  }
  .page {
    padding: var(--space-xxl);
  }
  .bottom-bar {
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  }
}
