/* ============================================================
   base.css - 基础布局和排版
   
   用途: 全站通用的布局框架和基础排版
   依赖: core/tokens.css, core/reset.css
   ============================================================ */

/* ============================================================
   Layout - Main Container
   ============================================================ */
.pg-main {
  display: block;
  min-height: 100vh;
}

.pg-container {
  width: 100%;
  max-width: var(--container-xl);
  margin-inline: auto;
  padding-inline: var(--space-4);
}

.pg-container--sm {
  max-width: var(--container-sm);
}

.pg-container--md {
  max-width: var(--container-md);
}

.pg-container--lg {
  max-width: var(--container-lg);
}

.pg-container--2xl {
  max-width: var(--container-2xl);
}

/* Container 响应式（从 aoyun.base.css 迁移） */
@media (min-width: 768px) {
  .pg-container {
    padding-inline: var(--space-6);
  }
}

@media (min-width: 1024px) {
  .pg-container {
    padding-inline: var(--space-8);
  }
}

/* ============================================================
   Layout - Grid System
   ============================================================ */
.pg-grid {
  display: grid;
  gap: var(--space-6);
}

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

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

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

/* ============================================================
   Layout - Two Column (通用两栏布局)
   类名: .pg-layout（从 aoyun.base.css 迁移）
   ============================================================ */
.pg-layout {
  display: grid;
  gap: var(--space-8);
  padding-block: var(--space-10);
}

.pg-layout--full .pg-layout__main {
  max-width: var(--container-lg);
  margin-inline: auto;
}

.pg-layout__main {
  min-width: 0;
}

.pg-layout__side {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .pg-layout {
    grid-template-columns: 1fr 300px;
    gap: var(--space-10);
    padding-block: var(--space-12);
  }

  .pg-layout--full {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 1024px) {
  .pg-layout {
    grid-template-columns: 1fr 320px;
    gap: var(--space-12);
    padding-block: var(--space-16);
  }

  .pg-layout--full {
    grid-template-columns: 1fr;
  }
}

/* 保留旧类名兼容（可后续删除） */
.pg-layout-two-col {
  display: grid;
  gap: var(--space-8);
}

@media (min-width: 768px) {
  .pg-layout-two-col {
    grid-template-columns: 1fr 280px;
    gap: var(--space-10);
  }
}

@media (min-width: 1024px) {
  .pg-layout-two-col {
    grid-template-columns: 1fr 320px;
    gap: var(--space-12);
  }
}

/* ============================================================
   Typography - Headings
   ============================================================ */
.pg-h1 {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  letter-spacing: var(--tracking-tight);
}

.pg-h2 {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
}

.pg-h3 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-snug);
}

.pg-h4 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-snug);
}

.pg-h5 {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-normal);
}

.pg-h6 {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-normal);
}

@media (min-width: 768px) {
  .pg-h1 {
    font-size: var(--font-size-4xl);
  }
  
  .pg-h2 {
    font-size: var(--font-size-3xl);
  }
}

@media (min-width: 1024px) {
  .pg-h1 {
    font-size: var(--font-size-5xl);
  }
}

/* ============================================================
   Typography - Text Utilities
   ============================================================ */
.pg-text-xs { font-size: var(--font-size-xs); }
.pg-text-sm { font-size: var(--font-size-sm); }
.pg-text-md { font-size: var(--font-size-md); }
.pg-text-lg { font-size: var(--font-size-lg); }
.pg-text-xl { font-size: var(--font-size-xl); }

.pg-text-muted { color: var(--color-text-muted); }
.pg-text-secondary { color: var(--color-text-secondary); }
.pg-text-primary { color: var(--color-primary); }
.pg-text-success { color: var(--color-success); }
.pg-text-warning { color: var(--color-warning); }
.pg-text-danger { color: var(--color-danger); }

.pg-text-center { text-align: center; }
.pg-text-left { text-align: left; }
.pg-text-right { text-align: right; }

.pg-font-normal { font-weight: var(--font-weight-normal); }
.pg-font-medium { font-weight: var(--font-weight-medium); }
.pg-font-semibold { font-weight: var(--font-weight-semibold); }
.pg-font-bold { font-weight: var(--font-weight-bold); }

/* ============================================================
   Spacing Utilities
   ============================================================ */
.pg-mt-auto { margin-top: auto; }
.pg-mb-auto { margin-bottom: auto; }
.pg-ml-auto { margin-left: auto; }
.pg-mr-auto { margin-right: auto; }
.pg-mx-auto { margin-inline: auto; }

/* ============================================================
   Display Utilities
   ============================================================ */
.pg-hidden { display: none; }
.pg-block { display: block; }
.pg-inline-block { display: inline-block; }
.pg-flex { display: flex; }
.pg-inline-flex { display: inline-flex; }
.pg-grid { display: grid; }

/* Flex utilities */
.pg-flex-col { flex-direction: column; }
.pg-flex-wrap { flex-wrap: wrap; }
.pg-items-center { align-items: center; }
.pg-items-start { align-items: flex-start; }
.pg-items-end { align-items: flex-end; }
.pg-justify-center { justify-content: center; }
.pg-justify-between { justify-content: space-between; }
.pg-justify-start { justify-content: flex-start; }
.pg-justify-end { justify-content: flex-end; }
.pg-gap-2 { gap: var(--space-2); }
.pg-gap-4 { gap: var(--space-4); }
.pg-gap-6 { gap: var(--space-6); }
.pg-gap-8 { gap: var(--space-8); }

/* ============================================================
   Responsive Visibility
   ============================================================ */
@media (max-width: 767px) {
  .pg-hide-mobile { display: none !important; }
}

@media (min-width: 768px) {
  .pg-hide-tablet { display: none !important; }
}

@media (min-width: 1024px) {
  .pg-hide-desktop { display: none !important; }
}

@media (max-width: 1023px) {
  .pg-show-desktop-only { display: none !important; }
}

@media (min-width: 768px) {
  .pg-show-mobile-only { display: none !important; }
}

/* ============================================================
   Overflow & Containment Utilities
   防溢出工具类：用于 flex/grid 子项安全
   ============================================================ */
.pg-contain {
  min-width: 0;
  overflow: hidden;
}

.pg-overflow-hidden { overflow: hidden; }
.pg-overflow-auto { overflow: auto; }
.pg-overflow-x-auto { overflow-x: auto; }
.pg-overflow-y-auto { overflow-y: auto; }

/* 长文本截断 */
.pg-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* 多行截断（需配合 -webkit-line-clamp） */
.pg-line-clamp {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.pg-line-clamp-2 { -webkit-line-clamp: 2; }
.pg-line-clamp-3 { -webkit-line-clamp: 3; }
