/**
 * ex-admin 自定义皮肤：覆盖外观，不改业务。
 * 后续可在此统一改颜色、圆角、间距等。
 */

:root {
  /* 测试用：主题色改为绿色，便于确认皮肤层是否生效 */
  --ant-primary-color: #52c41a;
  --header-menu-color: #1a3b0a;
  --sider-menu-color: #1a3b0a;
  --sider-menu-selected-color1: #52c41a;
  --sider-menu-selected-color2: #73d13d;
}

.logo>span {
  display: none;
}

/* 登录页：桌面端卡片化 */
.container .login-container {
  background: #fff;
  border-radius: 8px;
  padding: 32px 40px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

.container .login-container .title-container {
  margin-bottom: 24px;
}

.container .login-container .title-container .title {
  font-size: 24px;
  font-weight: 600;
  margin: 0;
}

/* 登录页：移动端适配 */
@media (max-width: 768px) {
  .ant-layout>.tabs {
    display: none !important;
  }

  .container .login-layout {
    flex-direction: column;
  }

  .container .login-layout .left {
    width: 100%;
    margin-left: 0;
    height: auto;
    min-height: 100px;
  }

  .container .login-layout .left .ad {
    display: none;
  }

  .container .left-container {
    display: none;
  }

  .container .text-block {
    display: none;
  }

  .container .logo-container {
    top: 16px;
    margin-left: 16px;
  }

  .container .logo-container img {
    width: 64px;
    height: 64px;
  }

  .container .login-layout .right {
    width: 100%;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-bottom: 48px;
  }

  .container .login-container {
    width: 100%;
    max-width: 100%;
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
    margin: 24px 16px 0;
    padding: 24px 16px;
    box-sizing: border-box;
  }

  .container::before {
    opacity: 0.5;
  }

  .container .icp {
    font-size: 11px;
    padding: 0 16px 16px;
    padding-bottom: 16px;
  }

  .container .verify {
    min-height: 44px;
    min-width: 44px;
  }
}

/* ========== 主框架：移动端 ========== */
@media (max-width: 768px) {
  .mask {
    z-index: 2 !important;
  }

  .mark {
    z-index: 2 !important;
  }

  [class*="header"] {
    margin: 10px 12px 8px !important;
    border-radius: 4px;
  }

  [class*="mainContainer"] {
    padding: 10px 12px 16px !important;
  }

  .ant-layout-content {
    overflow-x: auto;
    min-width: 0;
  }

  [class*="block-sider"] {
    margin: 10px !important;
  }
}

/* ========== 数据中心首页：移动端 ========== */
@media (max-width: 768px) {
  .ant-statistic-content {
    font-size: 18px !important;
  }

  .ant-card {
    margin-bottom: 12px;
  }

  .ant-card-body {
    padding: 12px 16px;
  }

  [class*="mainContainer"] .ant-row {
    margin-left: -8px !important;
    margin-right: -8px !important;
  }

  [class*="mainContainer"] .ant-col {
    padding-left: 8px !important;
    padding-right: 8px !important;
    margin-bottom: 8px;
  }

  [class*="mainContainer"] .ant-card {
    min-width: 0;
  }

  [class*="mainContainer"] .ant-card+.ant-card {
    margin-top: 0;
  }

  [class*="header-title"] {
    font-size: 18px !important;
    margin: 0 0 12px !important;
  }

  [class*="mainContainer"] [id*="echart"],
  [class*="mainContainer"] .echarts,
  [class*="mainContainer"] [class*="chart"] {
    width: 100% !important;
    min-height: 200px;
    overflow-x: auto;
  }

  /* 数据中心统计卡片：窄屏纵向堆叠 */
  .data-center-card .ant-card-body {
    display: flex !important;
    flex-wrap: wrap !important;
  }

  .data-center-card .ant-card-body>.ant-row,
  .data-center-card .ant-card-body>.ant-divider {
    flex: 1 1 100% !important;
    min-width: 100% !important;
  }

  .data-center-card .ant-divider-vertical {
    display: none !important;
  }

  .data-center-card .ant-card-body .ant-row .ant-col:first-child {
    font-size: 28px !important;
  }
}

/* ========== 列表页（表格/筛选）：移动端 ========== */
@media (max-width: 768px) {
  .ant-table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .ant-table {
    min-width: 600px;
  }

  .ant-table-thead>tr>th,
  .ant-table-tbody>tr>td {
    padding: 8px 12px !important;
    font-size: 13px;
  }

  .ant-form-inline .ant-form-item {
    margin-right: 0 !important;
    margin-bottom: 8px !important;
    display: block;
  }

  .ant-form-inline .ant-form-item .ant-form-item-control-input {
    min-width: 0;
  }

  .ant-input,
  .ant-select,
  .ant-picker {
    width: 100% !important;
    min-width: 0 !important;
  }

  .ant-pagination {
    flex-wrap: wrap;
    margin-top: 12px !important;
  }

  .ant-pagination-item {
    min-width: 32px;
    margin: 2px !important;
  }

  .ant-space {
    flex-wrap: wrap;
  }

  .ant-btn {
    margin-bottom: 4px;
  }
}

/* ========== 表单/弹窗：移动端 ========== */
@media (max-width: 768px) {
  .ant-modal {
    max-width: 100% !important;
    top: 0 !important;
    padding-bottom: 0 !important;
    margin: 0 !important;
  }

  .ant-modal-content {
    max-height: 100vh;
    height: 100vh;
    border-radius: 0;
  }

  .ant-modal-body {
    flex: 1;
    overflow: auto;
    padding: 16px;
  }

  .ant-modal-footer {
    padding: 12px 16px;
  }

  .ant-drawer-content-wrapper {
    width: 100% !important;
    max-width: 100%;
  }

  .ant-drawer-body {
    padding: 16px;
  }

  .ant-drawer-footer {
    padding: 12px 16px;
  }

  .ant-form-item {
    margin-bottom: 16px;
  }

  .ant-form-item-label {
    padding-bottom: 4px;
  }

  .ant-form-item-label>label {
    height: auto;
  }

  .ant-modal-footer .ant-btn+.ant-btn {
    margin-left: 8px;
  }
}

/* ========== 增强移动端适配 ========== */

/* 移动端 Header 优化 */
@media (max-width: 768px) {

  /* Header 图标放大，便于触控 */
  [class*="header"] .anticon,
  [class*="header"] svg {
    font-size: 20px !important;
    width: 20px !important;
    height: 20px !important;
  }

  /* Header 图标间距 */
  [class*="header"] .ant-space-item {
    margin-right: 8px !important;
  }

  /* 用户名在移动端隐藏，只显示头像 */
  [class*="header"] .ant-avatar+span,
  [class*="header"] .username {
    display: none !important;
  }

  /* Header 更紧凑 */
  [class*="header"] {
    padding: 8px 12px !important;
    min-height: 48px !important;
  }
}

/* ========== 侧边栏移动端适配 ========== */
@media (max-width: 768px) {

  /* 侧边栏完全折叠时的样式 */
  .ant-layout-sider {
    position: fixed !important;
    z-index: 1000 !important;
    height: 100vh !important;
    left: 0;
    top: 0;
  }

  .ant-layout-sider-collapsed {
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    flex: 0 0 0 !important;
  }

  .ant-layout-sider-collapsed * {
    display: none !important;
  }

  /* 侧边栏展开时确保菜单可点击 */
  .ant-layout-sider:not(.ant-layout-sider-collapsed) {
    z-index: 1001 !important;
  }

  .ant-layout-sider:not(.ant-layout-sider-collapsed) .ant-menu {
    position: relative;
    z-index: 1002 !important;
  }

  /* 侧边栏菜单项更大的触控区域 */
  .ant-menu-item,
  .ant-menu-submenu-title {
    min-height: 48px !important;
    line-height: 48px !important;
    padding: 0 16px !important;
  }

  /* ========== 移动端 hover 按钮始终显示 ========== */
  /* Ex-Admin Editable 字段的编辑按钮 - 这是关键修复 */
  .editable-cell-icon,
  .ex-admin-editable-cell .editable-cell-icon,
  .ex-admin-editable-cell .fa-edit,
  .ex-admin-editable-cell i[class*="edit"] {
    display: inline-block !important;
    opacity: 1 !important;
    visibility: visible !important;
    position: relative !important;
    right: auto !important;
    margin-left: 8px !important;
  }

  /* 确保 ex-admin-editable-cell 容器不隐藏编辑图标 */
  .ex-admin-editable-cell {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
  }

  /* Ant Design 表格单元格内的编辑图标 */
  .ant-table-cell .editable-cell-icon,
  .ant-table-cell [class*="edit-icon"],
  .ant-table-cell .ant-typography-edit,
  [class*="editable"] .anticon-edit,
  .ant-typography-edit-content .anticon {
    opacity: 1 !important;
    visibility: visible !important;
    display: inline-flex !important;
  }

  /* 卡片内的 hover 按钮也始终显示 */
  .ant-card [class*="hover"],
  .ant-card [class*="trigger"],
  .ant-list-item [class*="edit"],
  .ant-list-item [class*="trigger"] {
    opacity: 1 !important;
    visibility: visible !important;
  }

  /* Tag 可编辑的触发器始终显示 */
  .ant-tag .anticon-edit,
  .ant-tag .anticon-close {
    opacity: 1 !important;
    margin-left: 4px !important;
  }
}

/* ========== ECharts 图表移动端适配 ========== */
@media (max-width: 768px) {

  /* 图表容器强制 100% 宽度 */
  .mobile-chart,
  [class*="echart"],
  canvas[_bindbindbindbindbindech] {
    width: 100% !important;
    max-width: 100% !important;
  }

  /* ECharts 容器 */
  div[_bindv]>div[style*="position: relative"] {
    width: 100% !important;
  }

  /* 图表卡片内边距减少 */
  .ant-card:has([class*="echart"]),
  .ant-card:has(canvas) {
    padding: 8px !important;
  }

  .ant-card-body:has([class*="echart"]),
  .ant-card-body:has(canvas) {
    padding: 8px !important;
  }

  /* 图表标题移动端字号 */
  .ant-card h2,
  .ant-card .chart-title {
    font-size: 16px !important;
    margin-bottom: 8px !important;
  }
}

/* ========== 页面特定 class 支持 ========== */

/* 仪表盘页面 */
.page-dashboard .ant-card {
  margin-bottom: 12px;
}

/* 列表页面 */
.page-list .ant-table-wrapper {
  overflow-x: auto;
}

/* 表单页面 */
.page-form .ant-form-item {
  margin-bottom: 16px;
}

@media (max-width: 768px) {
  .page-dashboard .ant-col {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }

  .page-list .ant-btn {
    padding: 4px 8px;
    font-size: 12px;
  }

  .page-form .ant-form-item-label {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    text-align: left !important;
  }
}

/* ========== 列表页 Grid 移动端增强 ========== */
@media (max-width: 768px) {

  /* 筛选区域堆叠 */
  .ant-form-inline {
    display: flex !important;
    flex-wrap: wrap !important;
  }

  .ant-form-inline .ant-form-item {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    margin-right: 0 !important;
    margin-bottom: 12px !important;
  }

  .ant-form-inline .ant-form-item-control {
    flex: 1 !important;
    max-width: 100% !important;
  }

  /* 筛选框全宽 */
  .ant-form-inline .ant-select,
  .ant-form-inline .ant-picker,
  .ant-form-inline .ant-input {
    width: 100% !important;
  }

  /* 筛选按钮区域 */
  .ant-form-inline .ant-form-item:last-child {
    margin-top: 8px;
  }

  .ant-form-inline .ant-space {
    width: 100%;
    justify-content: flex-end;
  }

  /* 表格工具栏 */
  [class*="grid-tools"],
  .ant-table-title {
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  [class*="grid-tools"] .ant-btn {
    font-size: 12px !important;
    padding: 4px 8px !important;
  }

  /* 表格固定列优化 */
  .ant-table-cell-fix-left,
  .ant-table-cell-fix-right {
    position: relative !important;
    left: auto !important;
    right: auto !important;
  }

  /* 表格操作列 */
  .ant-table-cell .ant-space {
    flex-wrap: wrap;
    gap: 4px !important;
  }

  .ant-table-cell .ant-btn-sm {
    padding: 2px 6px !important;
    font-size: 11px !important;
  }

  /* 表格 tag 和 badge */
  .ant-table-cell .ant-tag {
    margin: 2px !important;
    font-size: 11px !important;
    padding: 0 4px !important;
  }

  /* 表格单元格内容 */
  .ant-table-cell {
    word-break: break-word !important;
  }

  /* 隐藏部分非关键列在移动端 */
  .mobile-hide-col {
    display: none !important;
  }
}

/* ========== Grid 头部统计卡片移动端 ========== */
@media (max-width: 768px) {

  /* 统计卡片行纵向堆叠 */
  [class*="grid-header"] .ant-row,
  .ant-table-title .ant-row {
    flex-direction: column !important;
  }

  [class*="grid-header"] .ant-col,
  .ant-table-title .ant-col {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    margin-bottom: 8px !important;
  }

  /* 统计卡片内紧凑布局 */
  [class*="grid-header"] .ant-card-body {
    padding: 12px !important;
    flex-wrap: wrap !important;
  }

  [class*="grid-header"] .ant-statistic-title {
    font-size: 12px !important;
  }

  [class*="grid-header"] .ant-statistic-content {
    font-size: 16px !important;
  }

  /* 隐藏分隔线 */
  [class*="grid-header"] .ant-divider-vertical {
    display: none !important;
  }
}

/* ========== 下拉菜单优化 ========== */
@media (max-width: 768px) {
  .ant-dropdown {
    max-width: 90vw !important;
  }

  .ant-dropdown-menu-item {
    padding: 10px 16px !important;
    font-size: 14px !important;
  }

  /* 操作下拉菜单图标 */
  .ant-dropdown-menu-item .anticon {
    margin-right: 8px !important;
  }
}

/* ========== 抽屉 Drawer 移动端 ========== */
@media (max-width: 768px) {
  .ant-drawer-content-wrapper {
    width: 100% !important;
    max-width: 100% !important;
  }

  .ant-drawer-header {
    padding: 12px 16px !important;
  }

  .ant-drawer-body {
    padding: 12px 16px !important;
  }

  .ant-drawer-footer {
    padding: 12px 16px !important;
  }

  /* Tabs 在抽屉内的适配 */
  .ant-drawer .ant-tabs-nav {
    padding: 0 8px !important;
  }

  .ant-drawer .ant-tabs-tab {
    padding: 8px 12px !important;
    font-size: 13px !important;
  }
}

/* ========== Tabs 标签页移动端 ========== */
@media (max-width: 768px) {
  .ant-tabs-nav-list {
    flex-wrap: wrap !important;
  }

  .ant-tabs-tab {
    padding: 8px 12px !important;
    margin: 0 4px 4px 0 !important;
  }

  .ant-tabs-tabpane {
    padding: 12px 0 !important;
  }

  /* 左侧标签页改为顶部标签页 */
  .ant-tabs-left {
    flex-direction: column !important;
  }

  .ant-tabs-left>.ant-tabs-nav {
    width: 100% !important;
    max-width: 100% !important;
  }

  .ant-tabs-left>.ant-tabs-content-holder {
    margin-left: 0 !important;
    border-left: none !important;
    border-top: 1px solid #f0f0f0 !important;
    padding-top: 12px !important;
  }
}

/* ========== Modal 模态框移动端 ========== */
@media (max-width: 768px) {
  .ant-modal {
    max-width: calc(100vw - 32px) !important;
    margin: 16px auto !important;
    top: 16px !important;
  }

  .ant-modal-content {
    max-height: calc(100vh - 80px) !important;
    overflow-y: auto !important;
  }

  .ant-modal-header {
    padding: 12px 16px !important;
  }

  .ant-modal-body {
    padding: 12px 16px !important;
    max-height: calc(100vh - 180px) !important;
    overflow-y: auto !important;
  }

  .ant-modal-footer {
    padding: 10px 16px !important;
  }

  .ant-modal-close {
    top: 8px !important;
    right: 8px !important;
  }

  /* 模态框内表单 */
  .ant-modal .ant-form-item {
    margin-bottom: 12px !important;
  }

  .ant-modal .ant-form-item-label {
    padding: 0 0 4px !important;
  }
}

/* ========== Detail 详情页移动端 ========== */
@media (max-width: 768px) {
  .ant-descriptions {
    width: 100% !important;
  }

  .ant-descriptions-row {
    display: flex !important;
    flex-direction: column !important;
  }

  .ant-descriptions-item {
    display: flex !important;
    flex-direction: column !important;
    padding: 8px 0 !important;
    border-bottom: 1px solid #f0f0f0 !important;
  }

  .ant-descriptions-item-label {
    width: 100% !important;
    font-weight: 600 !important;
    color: rgba(0, 0, 0, 0.65) !important;
    margin-bottom: 4px !important;
  }

  .ant-descriptions-item-content {
    width: 100% !important;
  }

  /* 水平布局改为垂直 */
  .ant-descriptions-view table {
    display: block !important;
  }

  .ant-descriptions-view tbody {
    display: block !important;
  }

  .ant-descriptions-view tr {
    display: flex !important;
    flex-wrap: wrap !important;
  }

  .ant-descriptions-view td,
  .ant-descriptions-view th {
    display: block !important;
    width: 100% !important;
    padding: 8px 0 !important;
    border: none !important;
  }
}

/* ========== Form 表单移动端增强 ========== */
@media (max-width: 768px) {

  /* 表单行列改为垂直堆叠 */
  .ant-form .ant-row {
    flex-direction: column !important;
  }

  .ant-form .ant-col {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }

  /* 表单项标签 */
  .ant-form-item-label {
    text-align: left !important;
    flex-basis: 100% !important;
    padding-bottom: 4px !important;
  }

  .ant-form-item-control {
    flex-basis: 100% !important;
  }

  /* 表单按钮区域 */
  .ant-form-item-control-input-content>.ant-space {
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  /* 输入框样式 */
  .ant-input,
  .ant-select-selector,
  .ant-picker,
  .ant-input-number {
    font-size: 16px !important;
    /* 防止 iOS 缩放 */
  }

  /* 开关和复选框 */
  .ant-switch {
    min-width: 44px !important;
    height: 24px !important;
  }

  .ant-checkbox-wrapper,
  .ant-radio-wrapper {
    padding: 8px 0 !important;
  }

  /* 上传组件 */
  .ant-upload-list-picture-card .ant-upload-list-item {
    width: 80px !important;
    height: 80px !important;
  }

  .ant-upload.ant-upload-select-picture-card {
    width: 80px !important;
    height: 80px !important;
  }
}

/* ========== Pagination 分页移动端 ========== */
@media (max-width: 768px) {
  .ant-pagination {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 8px !important;
  }

  .ant-pagination-item {
    min-width: 32px !important;
    height: 32px !important;
    line-height: 30px !important;
  }

  .ant-pagination-options {
    display: none !important;
  }

  .ant-pagination-total-text {
    width: 100% !important;
    text-align: center !important;
    margin-bottom: 8px !important;
  }

  /* 简化分页显示 */
  .ant-pagination-jump-prev,
  .ant-pagination-jump-next {
    display: none !important;
  }
}

/* ========== Breadcrumb 面包屑移动端 ========== */
@media (max-width: 768px) {
  .ant-breadcrumb {
    font-size: 12px !important;
  }

  .ant-breadcrumb-separator {
    margin: 0 4px !important;
  }

  /* 隐藏中间层级 */
  .ant-breadcrumb>span:not(:first-child):not(:last-child) {
    display: none !important;
  }

  .ant-breadcrumb>span:first-child::after {
    content: ' ... ';
    margin: 0 4px;
  }
}

/* ========== Select 下拉选择移动端 ========== */
@media (max-width: 768px) {
  .ant-select-dropdown {
    max-width: 90vw !important;
  }

  .ant-select-item {
    padding: 10px 12px !important;
    font-size: 14px !important;
  }

  .ant-select-item-option-content {
    white-space: normal !important;
    word-break: break-word !important;
  }
}

/* ========== DatePicker 日期选择移动端 ========== */
@media (max-width: 768px) {
  .ant-picker-dropdown {
    max-width: 100vw !important;
    left: 0 !important;
    right: 0 !important;
    margin: 0 auto !important;
  }

  .ant-picker-panel-container {
    max-width: 100vw !important;
    overflow-x: auto !important;
  }

  .ant-picker-datetime-panel {
    flex-direction: column !important;
  }

  .ant-picker-time-panel {
    border-left: none !important;
    border-top: 1px solid #f0f0f0 !important;
  }
}

/* ========== Message & Notification 消息提示移动端 ========== */
@media (max-width: 768px) {
  .ant-message {
    top: 60px !important;
  }

  .ant-message-notice-content {
    max-width: 90vw !important;
    padding: 10px 16px !important;
  }

  .ant-notification {
    max-width: 100vw !important;
    right: 0 !important;
    margin-right: 0 !important;
  }

  .ant-notification-notice {
    width: calc(100vw - 32px) !important;
    margin: 0 16px 16px !important;
  }
}


/* ========== 卡片式 Tabs 移动端 ========== */
@media (max-width: 768px) {
  .ant-tabs-card>.ant-tabs-nav .ant-tabs-tab {
    padding: 8px 12px !important;
    margin: 0 4px 4px 0 !important;
    border-radius: 4px !important;
  }

  .ant-tabs-card>.ant-tabs-nav {
    flex-wrap: wrap !important;
  }

  .ant-tabs-card .ant-tabs-content {
    padding: 12px !important;
  }
}

/* ========== Checkbox/Radio 组移动端 ========== */
@media (max-width: 768px) {

  .ant-checkbox-group,
  .ant-radio-group {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  .ant-checkbox-group .ant-checkbox-wrapper,
  .ant-radio-group .ant-radio-wrapper {
    flex: 0 0 calc(50% - 4px) !important;
    margin: 0 !important;
    padding: 8px !important;
    border: 1px solid #d9d9d9 !important;
    border-radius: 4px !important;
  }

  /* 按钮式 Radio */
  .ant-radio-group-solid,
  .ant-radio-group-outline {
    flex-wrap: wrap !important;
  }

  .ant-radio-button-wrapper {
    padding: 6px 12px !important;
    font-size: 13px !important;
    margin-bottom: 4px !important;
  }
}

/* ========== Switch 开关移动端 ========== */
@media (max-width: 768px) {
  .ant-switch {
    min-width: 48px !important;
    height: 26px !important;
  }

  .ant-switch-handle {
    width: 22px !important;
    height: 22px !important;
  }

  .ant-switch-inner {
    font-size: 12px !important;
  }
}

/* ========== Image 图片上传移动端 ========== */
@media (max-width: 768px) {
  .ant-image-preview-operations {
    padding: 16px !important;
  }

  .ant-image-preview-operations-operation {
    padding: 8px 12px !important;
  }
}

/* ========== Empty 空状态移动端 ========== */
@media (max-width: 768px) {
  .ant-empty {
    padding: 24px 16px !important;
  }

  .ant-empty-image {
    height: 80px !important;
  }

  .ant-empty-description {
    font-size: 13px !important;
  }
}

/* ========== Spin 加载状态移动端 ========== */
@media (max-width: 768px) {
  .ant-spin-nested-loading .ant-spin-text {
    font-size: 13px !important;
  }
}

/* ========== Popover/Tooltip 移动端 ========== */
@media (max-width: 768px) {

  .ant-popover,
  .ant-tooltip {
    max-width: 90vw !important;
  }

  .ant-popover-inner,
  .ant-tooltip-inner {
    padding: 10px 12px !important;
    font-size: 13px !important;
  }
}

/* ========== Confirm Modal 确认框移动端 ========== */
@media (max-width: 768px) {
  .ant-modal-confirm .ant-modal-body {
    padding: 16px !important;
  }

  .ant-modal-confirm-btns {
    display: flex !important;
    flex-direction: column-reverse !important;
    gap: 8px !important;
  }

  .ant-modal-confirm-btns .ant-btn {
    width: 100% !important;
    margin: 0 !important;
  }
}

/* ========== Alert 提示框移动端 ========== */
@media (max-width: 768px) {
  .ant-alert {
    padding: 10px 12px !important;
    font-size: 13px !important;
  }

  .ant-alert-with-description {
    padding: 12px !important;
  }

  .ant-alert-message {
    font-size: 14px !important;
  }
}