/* ================================
   NQ设计系统 - 工具类
   ================================ */

/* ================================
   Spacing Utilities - 间距工具类
   ================================ */

/* Margin utilities */
.nq-m-0 { margin: 0; }
.nq-m-1 { margin: var(--nq-space-1); }
.nq-m-2 { margin: var(--nq-space-2); }
.nq-m-3 { margin: var(--nq-space-3); }
.nq-m-4 { margin: var(--nq-space-4); }
.nq-m-5 { margin: var(--nq-space-5); }
.nq-m-6 { margin: var(--nq-space-6); }
.nq-m-7 { margin: var(--nq-space-7); }
.nq-m-8 { margin: var(--nq-space-8); }

/* Margin top */
.nq-mt-0 { margin-top: 0; }
.nq-mt-1 { margin-top: var(--nq-space-1); }
.nq-mt-2 { margin-top: var(--nq-space-2); }
.nq-mt-3 { margin-top: var(--nq-space-3); }
.nq-mt-4 { margin-top: var(--nq-space-4); }
.nq-mt-5 { margin-top: var(--nq-space-5); }
.nq-mt-6 { margin-top: var(--nq-space-6); }
.nq-mt-7 { margin-top: var(--nq-space-7); }
.nq-mt-8 { margin-top: var(--nq-space-8); }

/* Margin right */
.nq-mr-0 { margin-right: 0; }
.nq-mr-1 { margin-right: var(--nq-space-1); }
.nq-mr-2 { margin-right: var(--nq-space-2); }
.nq-mr-3 { margin-right: var(--nq-space-3); }
.nq-mr-4 { margin-right: var(--nq-space-4); }
.nq-mr-5 { margin-right: var(--nq-space-5); }
.nq-mr-6 { margin-right: var(--nq-space-6); }
.nq-mr-7 { margin-right: var(--nq-space-7); }
.nq-mr-8 { margin-right: var(--nq-space-8); }

/* Margin bottom */
.nq-mb-0 { margin-bottom: 0; }
.nq-mb-1 { margin-bottom: var(--nq-space-1); }
.nq-mb-2 { margin-bottom: var(--nq-space-2); }
.nq-mb-3 { margin-bottom: var(--nq-space-3); }
.nq-mb-4 { margin-bottom: var(--nq-space-4); }
.nq-mb-5 { margin-bottom: var(--nq-space-5); }
.nq-mb-6 { margin-bottom: var(--nq-space-6); }
.nq-mb-7 { margin-bottom: var(--nq-space-7); }
.nq-mb-8 { margin-bottom: var(--nq-space-8); }

/* Margin left */
.nq-ml-0 { margin-left: 0; }
.nq-ml-1 { margin-left: var(--nq-space-1); }
.nq-ml-2 { margin-left: var(--nq-space-2); }
.nq-ml-3 { margin-left: var(--nq-space-3); }
.nq-ml-4 { margin-left: var(--nq-space-4); }
.nq-ml-5 { margin-left: var(--nq-space-5); }
.nq-ml-6 { margin-left: var(--nq-space-6); }
.nq-ml-7 { margin-left: var(--nq-space-7); }
.nq-ml-8 { margin-left: var(--nq-space-8); }

/* Margin x-axis */
.nq-mx-0 { margin-left: 0; margin-right: 0; }
.nq-mx-1 { margin-left: var(--nq-space-1); margin-right: var(--nq-space-1); }
.nq-mx-2 { margin-left: var(--nq-space-2); margin-right: var(--nq-space-2); }
.nq-mx-3 { margin-left: var(--nq-space-3); margin-right: var(--nq-space-3); }
.nq-mx-4 { margin-left: var(--nq-space-4); margin-right: var(--nq-space-4); }
.nq-mx-5 { margin-left: var(--nq-space-5); margin-right: var(--nq-space-5); }
.nq-mx-6 { margin-left: var(--nq-space-6); margin-right: var(--nq-space-6); }
.nq-mx-7 { margin-left: var(--nq-space-7); margin-right: var(--nq-space-7); }
.nq-mx-8 { margin-left: var(--nq-space-8); margin-right: var(--nq-space-8); }
.nq-mx-auto { margin-left: auto; margin-right: auto; }

/* Margin y-axis */
.nq-my-0 { margin-top: 0; margin-bottom: 0; }
.nq-my-1 { margin-top: var(--nq-space-1); margin-bottom: var(--nq-space-1); }
.nq-my-2 { margin-top: var(--nq-space-2); margin-bottom: var(--nq-space-2); }
.nq-my-3 { margin-top: var(--nq-space-3); margin-bottom: var(--nq-space-3); }
.nq-my-4 { margin-top: var(--nq-space-4); margin-bottom: var(--nq-space-4); }
.nq-my-5 { margin-top: var(--nq-space-5); margin-bottom: var(--nq-space-5); }
.nq-my-6 { margin-top: var(--nq-space-6); margin-bottom: var(--nq-space-6); }
.nq-my-7 { margin-top: var(--nq-space-7); margin-bottom: var(--nq-space-7); }
.nq-my-8 { margin-top: var(--nq-space-8); margin-bottom: var(--nq-space-8); }

/* Padding utilities */
.nq-p-0 { padding: 0; }
.nq-p-1 { padding: var(--nq-space-1); }
.nq-p-2 { padding: var(--nq-space-2); }
.nq-p-3 { padding: var(--nq-space-3); }
.nq-p-4 { padding: var(--nq-space-4); }
.nq-p-5 { padding: var(--nq-space-5); }
.nq-p-6 { padding: var(--nq-space-6); }
.nq-p-7 { padding: var(--nq-space-7); }
.nq-p-8 { padding: var(--nq-space-8); }

/* Padding top */
.nq-pt-0 { padding-top: 0; }
.nq-pt-1 { padding-top: var(--nq-space-1); }
.nq-pt-2 { padding-top: var(--nq-space-2); }
.nq-pt-3 { padding-top: var(--nq-space-3); }
.nq-pt-4 { padding-top: var(--nq-space-4); }
.nq-pt-5 { padding-top: var(--nq-space-5); }
.nq-pt-6 { padding-top: var(--nq-space-6); }
.nq-pt-7 { padding-top: var(--nq-space-7); }
.nq-pt-8 { padding-top: var(--nq-space-8); }

/* Padding right */
.nq-pr-0 { padding-right: 0; }
.nq-pr-1 { padding-right: var(--nq-space-1); }
.nq-pr-2 { padding-right: var(--nq-space-2); }
.nq-pr-3 { padding-right: var(--nq-space-3); }
.nq-pr-4 { padding-right: var(--nq-space-4); }
.nq-pr-5 { padding-right: var(--nq-space-5); }
.nq-pr-6 { padding-right: var(--nq-space-6); }
.nq-pr-7 { padding-right: var(--nq-space-7); }
.nq-pr-8 { padding-right: var(--nq-space-8); }

/* Padding bottom */
.nq-pb-0 { padding-bottom: 0; }
.nq-pb-1 { padding-bottom: var(--nq-space-1); }
.nq-pb-2 { padding-bottom: var(--nq-space-2); }
.nq-pb-3 { padding-bottom: var(--nq-space-3); }
.nq-pb-4 { padding-bottom: var(--nq-space-4); }
.nq-pb-5 { padding-bottom: var(--nq-space-5); }
.nq-pb-6 { padding-bottom: var(--nq-space-6); }
.nq-pb-7 { padding-bottom: var(--nq-space-7); }
.nq-pb-8 { padding-bottom: var(--nq-space-8); }

/* Padding left */
.nq-pl-0 { padding-left: 0; }
.nq-pl-1 { padding-left: var(--nq-space-1); }
.nq-pl-2 { padding-left: var(--nq-space-2); }
.nq-pl-3 { padding-left: var(--nq-space-3); }
.nq-pl-4 { padding-left: var(--nq-space-4); }
.nq-pl-5 { padding-left: var(--nq-space-5); }
.nq-pl-6 { padding-left: var(--nq-space-6); }
.nq-pl-7 { padding-left: var(--nq-space-7); }
.nq-pl-8 { padding-left: var(--nq-space-8); }

/* Padding x-axis */
.nq-px-0 { padding-left: 0; padding-right: 0; }
.nq-px-1 { padding-left: var(--nq-space-1); padding-right: var(--nq-space-1); }
.nq-px-2 { padding-left: var(--nq-space-2); padding-right: var(--nq-space-2); }
.nq-px-3 { padding-left: var(--nq-space-3); padding-right: var(--nq-space-3); }
.nq-px-4 { padding-left: var(--nq-space-4); padding-right: var(--nq-space-4); }
.nq-px-5 { padding-left: var(--nq-space-5); padding-right: var(--nq-space-5); }
.nq-px-6 { padding-left: var(--nq-space-6); padding-right: var(--nq-space-6); }
.nq-px-7 { padding-left: var(--nq-space-7); padding-right: var(--nq-space-7); }
.nq-px-8 { padding-left: var(--nq-space-8); padding-right: var(--nq-space-8); }

/* Padding y-axis */
.nq-py-0 { padding-top: 0; padding-bottom: 0; }
.nq-py-1 { padding-top: var(--nq-space-1); padding-bottom: var(--nq-space-1); }
.nq-py-2 { padding-top: var(--nq-space-2); padding-bottom: var(--nq-space-2); }
.nq-py-3 { padding-top: var(--nq-space-3); padding-bottom: var(--nq-space-3); }
.nq-py-4 { padding-top: var(--nq-space-4); padding-bottom: var(--nq-space-4); }
.nq-py-5 { padding-top: var(--nq-space-5); padding-bottom: var(--nq-space-5); }
.nq-py-6 { padding-top: var(--nq-space-6); padding-bottom: var(--nq-space-6); }
.nq-py-7 { padding-top: var(--nq-space-7); padding-bottom: var(--nq-space-7); }
.nq-py-8 { padding-top: var(--nq-space-8); padding-bottom: var(--nq-space-8); }

/* ================================
   Display Utilities - 显示工具类
   ================================ */

.nq-d-none { display: none; }
.nq-d-inline { display: inline; }
.nq-d-inline-block { display: inline-block; }
.nq-d-block { display: block; }
.nq-d-table { display: table; }
.nq-d-table-row { display: table-row; }
.nq-d-table-cell { display: table-cell; }
.nq-d-flex { display: flex; }
.nq-d-inline-flex { display: inline-flex; }
.nq-d-grid { display: grid; }
.nq-d-inline-grid { display: inline-grid; }

/* ================================
   Flexbox Utilities - Flexbox工具类
   ================================ */

/* Flex direction */
.nq-flex-row { flex-direction: row; }
.nq-flex-row-reverse { flex-direction: row-reverse; }
.nq-flex-column { flex-direction: column; }
.nq-flex-column-reverse { flex-direction: column-reverse; }

/* Flex wrap */
.nq-flex-wrap { flex-wrap: wrap; }
.nq-flex-nowrap { flex-wrap: nowrap; }
.nq-flex-wrap-reverse { flex-wrap: wrap-reverse; }

/* Justify content */
.nq-justify-start { justify-content: flex-start; }
.nq-justify-end { justify-content: flex-end; }
.nq-justify-center { justify-content: center; }
.nq-justify-between { justify-content: space-between; }
.nq-justify-around { justify-content: space-around; }
.nq-justify-evenly { justify-content: space-evenly; }

/* Align items */
.nq-align-start { align-items: flex-start; }
.nq-align-end { align-items: flex-end; }
.nq-align-center { align-items: center; }
.nq-align-baseline { align-items: baseline; }
.nq-align-stretch { align-items: stretch; }

/* Align content */
.nq-align-content-start { align-content: flex-start; }
.nq-align-content-end { align-content: flex-end; }
.nq-align-content-center { align-content: center; }
.nq-align-content-between { align-content: space-between; }
.nq-align-content-around { align-content: space-around; }
.nq-align-content-stretch { align-content: stretch; }

/* Align self */
.nq-align-self-auto { align-self: auto; }
.nq-align-self-start { align-self: flex-start; }
.nq-align-self-end { align-self: flex-end; }
.nq-align-self-center { align-self: center; }
.nq-align-self-baseline { align-self: baseline; }
.nq-align-self-stretch { align-self: stretch; }

/* Flex grow and shrink */
.nq-flex-grow-0 { flex-grow: 0; }
.nq-flex-grow-1 { flex-grow: 1; }
.nq-flex-shrink-0 { flex-shrink: 0; }
.nq-flex-shrink-1 { flex-shrink: 1; }

/* Flex utilities */
.nq-flex-1 { flex: 1; }
.nq-flex-auto { flex: auto; }
.nq-flex-none { flex: none; }

/* Common flex combinations */
.nq-flex-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

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

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

/* ================================
   Grid Utilities - Grid工具类
   ================================ */

.nq-grid { display: grid; }

.nq-grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
.nq-grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.nq-grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.nq-grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
.nq-grid-cols-5 { grid-template-columns: repeat(5, 1fr); }
.nq-grid-cols-6 { grid-template-columns: repeat(6, 1fr); }
.nq-grid-cols-12 { grid-template-columns: repeat(12, 1fr); }

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

.nq-gap-0 { gap: 0; }
.nq-gap-1 { gap: var(--nq-space-1); }
.nq-gap-2 { gap: var(--nq-space-2); }
.nq-gap-3 { gap: var(--nq-space-3); }
.nq-gap-4 { gap: var(--nq-space-4); }
.nq-gap-5 { gap: var(--nq-space-5); }
.nq-gap-6 { gap: var(--nq-space-6); }

/* Auto-fit grid */
.nq-grid-auto-fit { grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); }
.nq-grid-auto-fit-sm { grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.nq-grid-auto-fit-lg { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }

/* ================================
   Text Utilities - 文本工具类
   ================================ */

/* Text alignment */
.nq-text-left { text-align: left; }
.nq-text-center { text-align: center; }
.nq-text-right { text-align: right; }
.nq-text-justify { text-align: justify; }

/* Text transform */
.nq-text-lowercase { text-transform: lowercase; }
.nq-text-uppercase { text-transform: uppercase; }
.nq-text-capitalize { text-transform: capitalize; }

/* Font weight */
.nq-font-light { font-weight: 300; }
.nq-font-normal { font-weight: 400; }
.nq-font-medium { font-weight: 500; }
.nq-font-semibold { font-weight: 600; }
.nq-font-bold { font-weight: 700; }

/* Font size */
.nq-text-xs { font-size: 12px; }
.nq-text-sm { font-size: 14px; }
.nq-text-base { font-size: 16px; }
.nq-text-lg { font-size: 18px; }
.nq-text-xl { font-size: 20px; }
.nq-text-2xl { font-size: 24px; }
.nq-text-3xl { font-size: 28px; }
.nq-text-4xl { font-size: 36px; }
.nq-text-5xl { font-size: 48px; }

/* Line height */
.nq-leading-none { line-height: 1; }
.nq-leading-tight { line-height: 1.25; }
.nq-leading-normal { line-height: 1.5; }
.nq-leading-relaxed { line-height: 1.625; }
.nq-leading-loose { line-height: 2; }

/* Text decoration */
.nq-underline { text-decoration: underline; }
.nq-no-underline { text-decoration: none; }
.nq-line-through { text-decoration: line-through; }

/* Text overflow */
.nq-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.nq-text-ellipsis { text-overflow: ellipsis; }
.nq-text-clip { text-overflow: clip; }

/* White space */
.nq-whitespace-normal { white-space: normal; }
.nq-whitespace-nowrap { white-space: nowrap; }
.nq-whitespace-pre { white-space: pre; }
.nq-whitespace-pre-line { white-space: pre-line; }
.nq-whitespace-pre-wrap { white-space: pre-wrap; }

/* ================================
   Color Utilities - 颜色工具类
   ================================ */

/* Text colors */
.nq-text-primary { color: var(--nq-primary); }
.nq-text-gradient { color: var(--nq-primary-gradient); }
.nq-text-light { color: var(--nq-primary-light); }
.nq-text-white { color: var(--nq-white); }
.nq-text-dark { color: var(--nq-dark); }
.nq-text-muted { color: var(--nq-text-muted); }
.nq-text-success { color: var(--nq-success); }
.nq-text-warning { color: var(--nq-warning); }
.nq-text-danger { color: var(--nq-danger); }
.nq-text-info { color: var(--nq-info); }

/* Background colors */
.nq-bg-primary { background-color: var(--nq-primary); }
.nq-bg-gradient { background-color: var(--nq-primary-gradient); }
.nq-bg-light { background-color: var(--nq-primary-light); }
.nq-bg-white { background-color: var(--nq-white); }
.nq-bg-dark { background-color: var(--nq-dark); }
.nq-bg-muted { background-color: var(--nq-light); }
.nq-bg-success { background-color: var(--nq-success); }
.nq-bg-warning { background-color: var(--nq-warning); }
.nq-bg-danger { background-color: var(--nq-danger); }
.nq-bg-info { background-color: var(--nq-info); }
.nq-bg-transparent { background-color: transparent; }

/* Gradient backgrounds */
.nq-gradient-primary { background: var(--nq-gradient-primary); }
.nq-gradient-light { background: var(--nq-gradient-light); }
.nq-gradient-bg { background: var(--nq-gradient-bg); }

/* Border colors */
.nq-border-primary { border-color: var(--nq-primary); }
.nq-border-light { border-color: var(--nq-border-light); }
.nq-border-dark { border-color: var(--nq-border); }
.nq-border-success { border-color: var(--nq-success); }
.nq-border-warning { border-color: var(--nq-warning); }
.nq-border-danger { border-color: var(--nq-danger); }
.nq-border-info { border-color: var(--nq-info); }

/* ================================
   Border Utilities - 边框工具类
   ================================ */

.nq-border { border: 1px solid var(--nq-border); }
.nq-border-0 { border: 0; }
.nq-border-t { border-top: 1px solid var(--nq-border); }
.nq-border-r { border-right: 1px solid var(--nq-border); }
.nq-border-b { border-bottom: 1px solid var(--nq-border); }
.nq-border-l { border-left: 1px solid var(--nq-border); }



/* ================================
   Shadow Utilities - 阴影工具类
   ================================ */

.nq-shadow-none { box-shadow: none; }
.nq-shadow-sm { box-shadow: var(--nq-shadow-sm); }
.nq-shadow { box-shadow: var(--nq-shadow); }
.nq-shadow-lg { box-shadow: var(--nq-shadow-lg); }
.nq-shadow-xl { box-shadow: var(--nq-shadow-xl); }

/* ================================
   Position Utilities - 定位工具类
   ================================ */

.nq-position-static { position: static; }
.nq-position-relative { position: relative; }
.nq-position-absolute { position: absolute; }
.nq-position-fixed { position: fixed; }
.nq-position-sticky { position: sticky; }

/* Position values */
.nq-top-0 { top: 0; }
.nq-top-auto { top: auto; }
.nq-right-0 { right: 0; }
.nq-right-auto { right: auto; }
.nq-bottom-0 { bottom: 0; }
.nq-bottom-auto { bottom: auto; }
.nq-left-0 { left: 0; }
.nq-left-auto { left: auto; }

/* Z-index */
.nq-z-0 { z-index: 0; }
.nq-z-10 { z-index: 10; }
.nq-z-20 { z-index: 20; }
.nq-z-30 { z-index: 30; }
.nq-z-40 { z-index: 40; }
.nq-z-50 { z-index: 50; }

/* ================================
   Width & Height Utilities - 宽高工具类
   ================================ */

/* Width */
.nq-w-auto { width: auto; }
.nq-w-full { width: 100%; }
.nq-w-screen { width: 100vw; }
.nq-w-1\/2 { width: 50%; }
.nq-w-1\/3 { width: 33.333333%; }
.nq-w-2\/3 { width: 66.666667%; }
.nq-w-1\/4 { width: 25%; }
.nq-w-3\/4 { width: 75%; }

/* Height */
.nq-h-auto { height: auto; }
.nq-h-full { height: 100%; }
.nq-h-screen { height: 100vh; }

/* Min/Max width */
.nq-min-w-0 { min-width: 0; }
.nq-min-w-full { min-width: 100%; }
.nq-max-w-none { max-width: none; }
.nq-max-w-full { max-width: 100%; }

/* Min/Max height */
.nq-min-h-0 { min-height: 0; }
.nq-min-h-full { min-height: 100%; }
.nq-min-h-screen { min-height: 100vh; }
.nq-max-h-full { max-height: 100%; }
.nq-max-h-screen { max-height: 100vh; }

/* ================================
   Overflow Utilities - 溢出工具类
   ================================ */

.nq-overflow-auto { overflow: auto; }
.nq-overflow-hidden { overflow: hidden; }
.nq-overflow-visible { overflow: visible; }
.nq-overflow-scroll { overflow: scroll; }
.nq-overflow-x-auto { overflow-x: auto; }
.nq-overflow-x-hidden { overflow-x: hidden; }
.nq-overflow-x-scroll { overflow-x: scroll; }
.nq-overflow-y-auto { overflow-y: auto; }
.nq-overflow-y-hidden { overflow-y: hidden; }
.nq-overflow-y-scroll { overflow-y: scroll; }

/* ================================
   Visibility Utilities - 可见性工具类
   ================================ */

.nq-visible { visibility: visible; }
.nq-invisible { visibility: hidden; }

/* Opacity */
.nq-opacity-0 { opacity: 0; }
.nq-opacity-25 { opacity: 0.25; }
.nq-opacity-50 { opacity: 0.5; }
.nq-opacity-75 { opacity: 0.75; }
.nq-opacity-100 { opacity: 1; }

/* ================================
   Responsive Utilities - 响应式工具类
   ================================ */

/* 移动端显示/隐藏 */
@media (max-width: 767px) {
  .nq-d-mobile-none { display: none; }
  .nq-d-mobile-block { display: block; }
  .nq-d-mobile-flex { display: flex; }
  .nq-d-mobile-grid { display: grid; }
}

/* 平板端显示/隐藏 */
@media (min-width: 768px) and (max-width: 1023px) {
  .nq-d-tablet-none { display: none; }
  .nq-d-tablet-block { display: block; }
  .nq-d-tablet-flex { display: flex; }
  .nq-d-tablet-grid { display: grid; }
}

/* 桌面端显示/隐藏 */
@media (min-width: 1024px) {
  .nq-d-desktop-none { display: none; }
  .nq-d-desktop-block { display: block; }
  .nq-d-desktop-flex { display: flex; }
  .nq-d-desktop-grid { display: grid; }
}

/* ================================
   Interaction Utilities - 交互工具类
   ================================ */

.nq-cursor-auto { cursor: auto; }
.nq-cursor-default { cursor: default; }
.nq-cursor-pointer { cursor: pointer; }
.nq-cursor-wait { cursor: wait; }
.nq-cursor-text { cursor: text; }
.nq-cursor-move { cursor: move; }
.nq-cursor-not-allowed { cursor: not-allowed; }

/* User select */
.nq-select-none { user-select: none; }
.nq-select-text { user-select: text; }
.nq-select-all { user-select: all; }
.nq-select-auto { user-select: auto; }

/* Pointer events */
.nq-pointer-events-none { pointer-events: none; }
.nq-pointer-events-auto { pointer-events: auto; } 