:root {
    --spacer: 1rem;  /* 基础单位 1rem=16px，修改此值可全局调整间距 */
}

/* ======== 外边距 MARGIN ======== */
.m-0  { margin: 0 }
.mt-0 { margin-top: 0 }
.mb-0 { margin-bottom: 0 }
.ms-0 { margin-left: 0 }
.me-0 { margin-right: 0 }
.mx-0 { margin-left: 0; margin-right: 0 }
.my-0 { margin-top: 0; margin-bottom: 0 }

.m-1  { margin: calc(var(--spacer) * 0.25) }
.mt-1 { margin-top: calc(var(--spacer) * 0.25) }
.mb-1 { margin-bottom: calc(var(--spacer) * 0.25) }
.ms-1 { margin-left: calc(var(--spacer) * 0.25) }
.me-1 { margin-right: calc(var(--spacer) * 0.25) }
.mx-1 { margin-left: calc(var(--spacer) * 0.25); margin-right: calc(var(--spacer) * 0.25) }
.my-1 { margin-top: calc(var(--spacer) * 0.25); margin-bottom: calc(var(--spacer) * 0.25) }

.m-2  { margin: calc(var(--spacer) * 0.5) }
.mt-2 { margin-top: calc(var(--spacer) * 0.5) }
.mb-2 { margin-bottom: calc(var(--spacer) * 0.5) }
.ms-2 { margin-left: calc(var(--spacer) * 0.5) }
.me-2 { margin-right: calc(var(--spacer) * 0.5) }
.mx-2 { margin-left: calc(var(--spacer) * 0.5); margin-right: calc(var(--spacer) * 0.5) }
.my-2 { margin-top: calc(var(--spacer) * 0.5); margin-bottom: calc(var(--spacer) * 0.5) }

.m-3  { margin: var(--spacer) }
.mt-3 { margin-top: var(--spacer) }
.mb-3 { margin-bottom: var(--spacer) }
.ms-3 { margin-left: var(--spacer) }
.me-3 { margin-right: var(--spacer) }
.mx-3 { margin-left: var(--spacer); margin-right: var(--spacer) }
.my-3 { margin-top: var(--spacer); margin-bottom: var(--spacer) }

.m-4  { margin: calc(var(--spacer) * 1.5) }
.mt-4 { margin-top: calc(var(--spacer) * 1.5) }
.mb-4 { margin-bottom: calc(var(--spacer) * 1.5) }
.ms-4 { margin-left: calc(var(--spacer) * 1.5) }
.me-4 { margin-right: calc(var(--spacer) * 1.5) }
.mx-4 { margin-left: calc(var(--spacer) * 1.5); margin-right: calc(var(--spacer) * 1.5) }
.my-4 { margin-top: calc(var(--spacer) * 1.5); margin-bottom: calc(var(--spacer) * 1.5) }

.m-5  { margin: calc(var(--spacer) * 3) }
.mt-5 { margin-top: calc(var(--spacer) * 3) }
.mb-5 { margin-bottom: calc(var(--spacer) * 3) }
.ms-5 { margin-left: calc(var(--spacer) * 3) }
.me-5 { margin-right: calc(var(--spacer) * 3) }
.mx-5 { margin-left: calc(var(--spacer) * 3); margin-right: calc(var(--spacer) * 3) }
.my-5 { margin-top: calc(var(--spacer) * 3); margin-bottom: calc(var(--spacer) * 3) }

/* 自动外边距 */
.mx-auto { margin-left: auto; margin-right: auto }

/* ======== 内边距 PADDING ======== */
.p-0  { padding: 0 }
.pt-0 { padding-top: 0 }
.pb-0 { padding-bottom: 0 }
.ps-0 { padding-left: 0 }
.pe-0 { padding-right: 0 }
.px-0 { padding-left: 0; padding-right: 0 }
.py-0 { padding-top: 0; padding-bottom: 0 }

.p-1  { padding: calc(var(--spacer) * 0.25) }
.pt-1 { padding-top: calc(var(--spacer) * 0.25) }
.pb-1 { padding-bottom: calc(var(--spacer) * 0.25) }
.ps-1 { padding-left: calc(var(--spacer) * 0.25) }
.pe-1 { padding-right: calc(var(--spacer) * 0.25) }
.px-1 { padding-left: calc(var(--spacer) * 0.25); padding-right: calc(var(--spacer) * 0.25) }
.py-1 { padding-top: calc(var(--spacer) * 0.25); padding-bottom: calc(var(--spacer) * 0.25) }

.p-2  { padding: calc(var(--spacer) * 0.5) }
.pt-2 { padding-top: calc(var(--spacer) * 0.5) }
.pb-2 { padding-bottom: calc(var(--spacer) * 0.5) }
.ps-2 { padding-left: calc(var(--spacer) * 0.5) }
.pe-2 { padding-right: calc(var(--spacer) * 0.5) }
.px-2 { padding-left: calc(var(--spacer) * 0.5); padding-right: calc(var(--spacer) * 0.5) }
.py-2 { padding-top: calc(var(--spacer) * 0.5); padding-bottom: calc(var(--spacer) * 0.5) }

.p-3  { padding: var(--spacer) }
.pt-3 { padding-top: var(--spacer) }
.pb-3 { padding-bottom: var(--spacer) }
.ps-3 { padding-left: var(--spacer) }
.pe-3 { padding-right: var(--spacer) }
.px-3 { padding-left: var(--spacer); padding-right: var(--spacer) }
.py-3 { padding-top: var(--spacer); padding-bottom: var(--spacer) }

.p-4  { padding: calc(var(--spacer) * 1.5) }
.pt-4 { padding-top: calc(var(--spacer) * 1.5) }
.pb-4 { padding-bottom: calc(var(--spacer) * 1.5) }
.ps-4 { padding-left: calc(var(--spacer) * 1.5) }
.pe-4 { padding-right: calc(var(--spacer) * 1.5) }
.px-4 { padding-left: calc(var(--spacer) * 1.5); padding-right: calc(var(--spacer) * 1.5) }
.py-4 { padding-top: calc(var(--spacer) * 1.5); padding-bottom: calc(var(--spacer) * 1.5) }

.p-5  { padding: calc(var(--spacer) * 3) }
.pt-5 { padding-top: calc(var(--spacer) * 3) }
.pb-5 { padding-bottom: calc(var(--spacer) * 3) }
.ps-5 { padding-left: calc(var(--spacer) * 3) }
.pe-5 { padding-right: calc(var(--spacer) * 3) }
.px-5 { padding-left: calc(var(--spacer) * 3); padding-right: calc(var(--spacer) * 3) }
.py-5 { padding-top: calc(var(--spacer) * 3); padding-bottom: calc(var(--spacer) * 3) }

/* ======== 位置 POSITION ======== */
.position-relative { position: relative; }
.position-absolute { position: absolute; }
.position-fixed { position: fixed; }
.position-sticky { position: sticky; }

/* ======== 显示 DISPLAY ======== */
.d-none { display: none; }
.d-block { display: block; }
.d-inline { display: inline; }
.d-inline-block { display: inline-block; }
.d-flex { display: flex; }
.d-inline-flex { display: inline-flex; }

/* ======== 对齐 ALIGN ======== */
.justify-content-start { justify-content: flex-start; }
.justify-content-end { justify-content: flex-end; }
.justify-content-center { justify-content: center; }
.justify-content-between { justify-content: space-between; }
.justify-content-around { justify-content: space-around; }
.justify-content-evenly { justify-content: space-evenly; }

.align-items-start { align-items: flex-start; }
.align-items-end { align-items: flex-end; }
.align-items-center { align-items: center; }
.align-items-baseline { align-items: baseline; }
.align-items-stretch { align-items: stretch; }

/* ======== 方向 FLEX-DIRECTION ======== */
.flex-row { flex-direction: row; }
.flex-row-reverse { flex-direction: row-reverse; }
.flex-column { flex-direction: column; }
.flex-column-reverse { flex-direction: column-reverse; }

/* ======== 包裹 FLEX-WRAP ======== */
.flex-nowrap { flex-wrap: nowrap; }
.flex-wrap { flex-wrap: wrap; }
.flex-wrap-reverse { flex-wrap: wrap-reverse; }

/* ======== 对齐内容 ALIGN-CONTENT ======== */
.align-content-start { align-content: flex-start; }
.align-content-end { align-content: flex-end; }
.align-content-center { align-content: center; }
.align-content-between { align-content: space-between; }
.align-content-around { align-content: space-around; }
.align-content-stretch { align-content: stretch; }

/* ======== 自动填充 FLEX ======== */
.flex-fill { flex: 1 1 auto; }

/* ======== 顺序 ORDER ======== */
.order-0 { order: 0; }
.order-1 { order: 1; }
.order-2 { order: 2; }
.order-3 { order: 3; }
.order-4 { order: 4; }
.order-5 { order: 5; }

/* ======== 偏移 OFFSET ======== */
.offset-0 { margin-left: 0; }
.offset-1 { margin-left: 8.333333%; }
.offset-2 { margin-left: 16.666667%; }
.offset-3 { margin-left: 25%; }
.offset-4 { margin-left: 33.333333%; }
.offset-5 { margin-left: 41.666667%; }
.offset-6 { margin-left: 50%; }
.offset-7 { margin-left: 58.333333%; }
.offset-8 { margin-left: 66.666667%; }
.offset-9 { margin-left: 75%; }
.offset-10 { margin-left: 83.333333%; }
.offset-11 { margin-left: 91.666667%; }

/* ======== TOP, BOTTOM, LEFT, RIGHT ======== */
.top-0 { top: 0; }
.top-50 { top: 50%; }
.top-100 { top: 100%; }

.bottom-0 { bottom: 0; }
.bottom-50 { bottom: 50%; }
.bottom-100 { bottom: 100%; }

.left-0 { left: 0; }
.left-50 { left: 50%; }
.left-100 { left: 100%; }

.right-0 { right: 0; }
.right-50 { right: 50%; }
.right-100 { right: 100%; }

/* ======== Z-INDEX ======== */
.z-0 { z-index: 0; }
.z-1 { z-index: 1; }
.z-2 { z-index: 2; }
.z-3 { z-index: 3; }
.z-4 { z-index: 4; }
.z-5 { z-index: 5; }
.z-auto { z-index: auto; }

/* ======== 文本对齐 TEXT-ALIGN ======== */
.text-start { text-align: left; }
.text-end { text-align: right; }
.text-center { text-align: center; }

/* ======== 宽度 WIDTH ======== */
.w-25 { width: 25%; }
.w-50 { width: 50%; }
.w-75 { width: 75%; }
.w-100 { width: 100%; }
.w-auto { width: auto; }

/* ======== 高度 HEIGHT ======== */
.h-25 { height: 25%; }
.h-50 { height: 50%; }
.h-75 { height: 75%; }
.h-100 { height: 100%; }
.h-auto { height: auto; }

/* 图片类 */
.img-fluid { max-width: 100%; height: auto; }
.img-thumbnail { padding: 0.25rem; background-color: #fff; border: 1px solid #dee2e6; border-radius: 0.25rem; max-width: 100%; height: auto; }
.img-circle { border-radius: 50%; }
.img-rounded { border-radius: 0.25rem; }

/* ======== 响应式 MD 类 ======== */
@media (min-width: 768px) {
    /* ======== 外边距 MARGIN ======== */
    .m-md-0  { margin: 0 }
    .mt-md-0 { margin-top: 0 }
    .mb-md-0 { margin-bottom: 0 }
    .ms-md-0 { margin-left: 0 }
    .me-md-0 { margin-right: 0 }
    .mx-md-0 { margin-left: 0; margin-right: 0 }
    .my-md-0 { margin-top: 0; margin-bottom: 0 }

    .m-md-1  { margin: calc(var(--spacer) * 0.25) }
    .mt-md-1 { margin-top: calc(var(--spacer) * 0.25) }
    .mb-md-1 { margin-bottom: calc(var(--spacer) * 0.25) }
    .ms-md-1 { margin-left: calc(var(--spacer) * 0.25) }
    .me-md-1 { margin-right: calc(var(--spacer) * 0.25) }
    .mx-md-1 { margin-left: calc(var(--spacer) * 0.25); margin-right: calc(var(--spacer) * 0.25) }
    .my-md-1 { margin-top: calc(var(--spacer) * 0.25); margin-bottom: calc(var(--spacer) * 0.25) }

    .m-md-2  { margin: calc(var(--spacer) * 0.5) }
    .mt-md-2 { margin-top: calc(var(--spacer) * 0.5) }
    .mb-md-2 { margin-bottom: calc(var(--spacer) * 0.5) }
    .ms-md-2 { margin-left: calc(var(--spacer) * 0.5) }
    .me-md-2 { margin-right: calc(var(--spacer) * 0.5) }
    .mx-md-2 { margin-left: calc(var(--spacer) * 0.5); margin-right: calc(var(--spacer) * 0.5) }
    .my-md-2 { margin-top: calc(var(--spacer) * 0.5); margin-bottom: calc(var(--spacer) * 0.5) }

    .m-md-3  { margin: var(--spacer) }
    .mt-md-3 { margin-top: var(--spacer) }
    .mb-md-3 { margin-bottom: var(--spacer) }
    .ms-md-3 { margin-left: var(--spacer) }
    .me-md-3 { margin-right: var(--spacer) }
    .mx-md-3 { margin-left: var(--spacer); margin-right: var(--spacer) }
    .my-md-3 { margin-top: var(--spacer); margin-bottom: var(--spacer) }

    .m-md-4  { margin: calc(var(--spacer) * 1.5) }
    .mt-md-4 { margin-top: calc(var(--spacer) * 1.5) }
    .mb-md-4 { margin-bottom: calc(var(--spacer) * 1.5) }
    .ms-md-4 { margin-left: calc(var(--spacer) * 1.5) }
    .me-md-4 { margin-right: calc(var(--spacer) * 1.5) }
    .mx-md-4 { margin-left: calc(var(--spacer) * 1.5); margin-right: calc(var(--spacer) * 1.5) }
    .my-md-4 { margin-top: calc(var(--spacer) * 1.5); margin-bottom: calc(var(--spacer) * 1.5) }

    .m-md-5  { margin: calc(var(--spacer) * 3) }
    .mt-md-5 { margin-top: calc(var(--spacer) * 3) }
    .mb-md-5 { margin-bottom: calc(var(--spacer) * 3) }
    .ms-md-5 { margin-left: calc(var(--spacer) * 3) }
    .me-md-5 { margin-right: calc(var(--spacer) * 3) }
    .mx-md-5 { margin-left: calc(var(--spacer) * 3); margin-right: calc(var(--spacer) * 3) }
    .my-md-5 { margin-top: calc(var(--spacer) * 3); margin-bottom: calc(var(--spacer) * 3) }

    .mx-md-auto { margin-left: auto; margin-right: auto }

/* ======== 内边距 PADDING ======== */
    .p-md-0  { padding: 0 }
    .pt-md-0 { padding-top: 0 }
    .pb-md-0 { padding-bottom: 0 }
    .ps-md-0 { padding-left: 0 }
    .pe-md-0 { padding-right: 0 }
    .px-md-0 { padding-left: 0; padding-right: 0 }
    .py-md-0 { padding-top: 0; padding-bottom: 0 }

    .p-md-1  { padding: calc(var(--spacer) * 0.25) }
    .pt-md-1 { padding-top: calc(var(--spacer) * 0.25) }
    .pb-md-1 { padding-bottom: calc(var(--spacer) * 0.25) }
    .ps-md-1 { padding-left: calc(var(--spacer) * 0.25) }
    .pe-md-1 { padding-right: calc(var(--spacer) * 0.25) }
    .px-md-1 { padding-left: calc(var(--spacer) * 0.25); padding-right: calc(var(--spacer) * 0.25) }
    .py-md-1 { padding-top: calc(var(--spacer) * 0.25); padding-bottom: calc(var(--spacer) * 0.25) }

    .p-md-2  { padding: calc(var(--spacer) * 0.5) }
    .pt-md-2 { padding-top: calc(var(--spacer) * 0.5) }
    .pb-md-2 { padding-bottom: calc(var(--spacer) * 0.5) }
    .ps-md-2 { padding-left: calc(var(--spacer) * 0.5) }
    .pe-md-2 { padding-right: calc(var(--spacer) * 0.5) }
    .px-md-2 { padding-left: calc(var(--spacer) * 0.5); padding-right: calc(var(--spacer) * 0.5) }
    .py-md-2 { padding-top: calc(var(--spacer) * 0.5); padding-bottom: calc(var(--spacer) * 0.5) }

    .p-md-3  { padding: var(--spacer) }
    .pt-md-3 { padding-top: var(--spacer) }
    .pb-md-3 { padding-bottom: var(--spacer) }
    .ps-md-3 { padding-left: var(--spacer) }
    .pe-md-3 { padding-right: var(--spacer) }
    .px-md-3 { padding-left: var(--spacer); padding-right: var(--spacer) }
    .py-md-3 { padding-top: var(--spacer); padding-bottom: var(--spacer) }

    .p-md-4  { padding: calc(var(--spacer) * 1.5) }
    .pt-md-4 { padding-top: calc(var(--spacer) * 1.5) }
    .pb-md-4 { padding-bottom: calc(var(--spacer) * 1.5) }
    .ps-md-4 { padding-left: calc(var(--spacer) * 1.5) }
    .pe-md-4 { padding-right: calc(var(--spacer) * 1.5) }
    .px-md-4 { padding-left: calc(var(--spacer) * 1.5); padding-right: calc(var(--spacer) * 1.5) }
    .py-md-4 { padding-top: calc(var(--spacer) * 1.5); padding-bottom: calc(var(--spacer) * 1.5) }

    .p-md-5  { padding: calc(var(--spacer) * 3) }
    .pt-md-5 { padding-top: calc(var(--spacer) * 3) }
    .pb-md-5 { padding-bottom: calc(var(--spacer) * 3) }
    .ps-md-5 { padding-left: calc(var(--spacer) * 3) }
    .pe-md-5 { padding-right: calc(var(--spacer) * 3) }
    .px-md-5 { padding-left: calc(var(--spacer) * 3); padding-right: calc(var(--spacer) * 3) }
    .py-md-5 { padding-top: calc(var(--spacer) * 3); padding-bottom: calc(var(--spacer) * 3) }
    
    /* ======== 宽度 WIDTH ======== */
    .w-md-25 { width: 25%; }
    .w-md-50 { width: 50%; }
    .w-md-75 { width: 75%; }
    .w-md-100 { width: 100%; }
    .w-md-auto { width: auto; }

    /* ======== 高度 HEIGHT ======== */
    .h-md-25 { height: 25%; }
    .h-md-50 { height: 50%; }
    .h-md-75 { height: 75%; }
    .h-md-100 { height: 100%; }
    .h-md-auto { height: auto; }

    /* ======== 显示 DISPLAY ======== */
    .d-md-none { display: none; }
    .d-md-block { display: block; }
    .d-md-inline { display: inline; }
    .d-md-inline-block { display: inline-block; }
    .d-md-flex { display: flex; }
    .d-md-inline-flex { display: inline-flex; }

    .justify-content-md-start { justify-content: flex-start; }
    .justify-content-md-end { justify-content: flex-end; }
    .justify-content-md-center { justify-content: center; }
    .justify-content-md-between { justify-content: space-between; }
    .justify-content-md-around { justify-content: space-around; }
    .justify-content-md-evenly { justify-content: space-evenly; }

    .align-items-md-start { align-items: flex-start; }
    .align-items-md-end { align-items: flex-end; }
    .align-items-md-center { align-items: center; }
    .align-items-md-baseline { align-items: baseline; }
    .align-items-md-stretch { align-items: stretch; }

    .flex-md-row { flex-direction: row; }
    .flex-md-row-reverse { flex-direction: row-reverse; }
    .flex-md-column { flex-direction: column; }
    .flex-md-column-reverse { flex-direction: column-reverse; }

    .flex-md-nowrap { flex-wrap: nowrap; }
    .flex-md-wrap { flex-wrap: wrap; }
    .flex-md-wrap-reverse { flex-wrap: wrap-reverse; }

    .align-content-md-start { align-content: flex-start; }
    .align-content-md-end { align-content: flex-end; }
    .align-content-md-center { align-content: center; }
    .align-content-md-between { align-content: space-between; }
    .align-content-md-around { align-content: space-around; }
    .align-content-md-stretch { align-content: stretch; }

    .flex-md-fill { flex: 1 1 auto; }

    .order-md-0 { order: 0; }
    .order-md-1 { order: 1; }
    .order-md-2 { order: 2; }
    .order-md-3 { order: 3; }
    .order-md-4 { order: 4; }
    .order-md-5 { order: 5; }

    .offset-md-0 { margin-left: 0; }
    .offset-md-1 { margin-left: 8.333333%; }
    .offset-md-2 { margin-left: 16.666667%; }
    .offset-md-3 { margin-left: 25%; }
    .offset-md-4 { margin-left: 33.333333%; }
    .offset-md-5 { margin-left: 41.666667%; }
    .offset-md-6 { margin-left: 50%; }
    .offset-md-7 { margin-left: 58.333333%; }
    .offset-md-8 { margin-left: 66.666667%; }
    .offset-md-9 { margin-left: 75%; }
    .offset-md-10 { margin-left: 83.333333%; }
    .offset-md-11 { margin-left: 91.666667%; }

    .top-md-0 { top: 0; }
    .top-md-50 { top: 50%; }
    .top-md-100 { top: 100%; }

    .bottom-md-0 { bottom: 0; }
    .bottom-md-50 { bottom: 50%; }
    .bottom-md-100 { bottom: 100%; }

    .left-md-0 { left: 0; }
    .left-md-50 { left: 50%; }
    .left-md-100 { left: 100%; }

    .right-md-0 { right: 0; }
    .right-md-50 { right: 50%; }
    .right-md-100 { right: 100%; }

    .z-md-0 { z-index: 0; }
    .z-md-1 { z-index: 1; }
    .z-md-2 { z-index: 2; }
    .z-md-3 { z-index: 3; }
    .z-md-4 { z-index: 4; }
    .z-md-5 { z-index: 5; }
    .z-md-auto { z-index: auto; }

    /* ======== 响应式 MD 文本对齐 TEXT-ALIGN ======== */
    .text-md-start { text-align: left; }
    .text-md-end { text-align: right; }
    .text-md-center { text-align: center; }
}