/* 少量通用工具类 */
.is-hidden, [hidden] { display: none !important; }
.sr-only {
  position: absolute !important; width: 1px; height: 1px; padding: 0;
  margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.u-text-center { text-align: center; }
.u-text-right  { text-align: right; }
.u-mono { font-family: var(--font-mono); }
.u-muted { color: var(--fg-muted); }
.u-strong { color: var(--fg-strong); }
.u-truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.u-break { word-break: break-all; overflow-wrap: anywhere; }

.u-mt-0 { margin-top: 0; } .u-mt-2 { margin-top: var(--space-2); } .u-mt-3 { margin-top: var(--space-3); } .u-mt-4 { margin-top: var(--space-4); } .u-mt-6 { margin-top: var(--space-6); }
.u-mb-0 { margin-bottom: 0; } .u-mb-2 { margin-bottom: var(--space-2); } .u-mb-3 { margin-bottom: var(--space-3); } .u-mb-4 { margin-bottom: var(--space-4); } .u-mb-6 { margin-bottom: var(--space-6); }

.u-flex { display: flex; }
.u-row { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.u-col { display: flex; flex-direction: column; gap: var(--space-3); }
.u-between { justify-content: space-between; }
.u-gap-2 { gap: var(--space-2); }
.u-gap-3 { gap: var(--space-3); }
.u-gap-4 { gap: var(--space-4); }
.u-grow { flex: 1; }

.grid { display: grid; gap: var(--space-4); }
.grid > * { min-width: 0; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-auto   { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.grid-auto-sm { grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); }

/* sidebar + main 布局 */
.grid-sidebar   { grid-template-columns: var(--sidebar-w, 180px) 1fr; }
.grid-sidebar-r { grid-template-columns: 1fr var(--sidebar-w, 180px); }
/* 可自定义侧边栏宽度（兼容旧写法） */
.grid-sidebar-w { grid-template-columns: var(--sidebar-w, 180px) 1fr; }

/* chips / tag 流式布局 */
.grid-chips { display: flex; flex-wrap: wrap; gap: var(--space-2); }

/* 侧边栏滚动区 */
.grid-aside {
  max-height: 540px; overflow-y: auto;
  border-right: 1px solid var(--border); padding-right: var(--space-3);
}

@media (max-width: 640px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .grid-sidebar, .grid-sidebar-r, .grid-sidebar-w { grid-template-columns: 1fr; }
  .grid-aside {
    max-height: 200px; border-right: none;
    border-bottom: 1px solid var(--border); padding-right: 0; padding-bottom: var(--space-3);
  }
}
