/* 商户管理后台 - 响应式样式 (深度优化版 v2) */

/* ========== 全局基础设置 ========== */
* {
  box-sizing: border-box;
}

html {
  overflow-x: hidden;
  overflow-y: auto;
  width: 100%;
  height: 100%;
}

body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  overflow-y: auto;
  width: 100%;
  min-height: 100%;
}

#root {
  overflow-x: hidden;
  width: 100%;
  min-height: 100vh;
}

/* 防止Layout溢出 */
.ant-layout {
  overflow-x: hidden !important;
}

.ant-layout-content {
  overflow-x: hidden !important;
}

/* ========== 移动端适配 (≤768px) ========== */
@media screen and (max-width: 768px) {

  /* === 整体布局 - 防止双滚动条 === */
  html, body {
    overflow-x: hidden !important;
    overflow-y: auto !important;
    width: 100vw !important;
    max-width: 100vw !important;
  }

  #root {
    overflow-x: hidden !important;
    width: 100vw !important;
    max-width: 100vw !important;
  }

  .ant-layout {
    overflow-x: hidden !important;
    overflow-y: visible !important;
  }

  /* === 移动端菜单按钮 === */
  .mobile-menu-button {
    display: flex !important;
  }

  /* === 侧边栏 - 完全由JS控制位置 === */
  .ant-layout-sider {
    /* 不设置left，由React内联样式控制 */
    z-index: 1000 !important;
  }

  /* 确保侧边栏内容可见 */
  .ant-layout-sider-children {
    height: 100%;
    overflow-y: auto;
  }

  /* === 主内容区域 === */
  .ant-layout.ant-layout-has-sider > .ant-layout {
    margin-left: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
  }

  .ant-layout-content {
    margin: 0 !important;
    padding: 8px !important;
    width: 100vw !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
    overflow-y: visible !important;
  }

  /* === 头部 === */
  .ant-layout-header {
    padding: 0 12px !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: 56px !important;
    line-height: 56px !important;
    overflow: hidden !important;
  }

  .ant-layout-header .ant-space {
    font-size: 13px !important;
  }

  .ant-layout-header .ant-avatar {
    width: 28px !important;
    height: 28px !important;
  }

  /* 头部用户名在小屏幕隐藏 */
  .ant-layout-header .ant-space > span {
    display: none !important;
  }

  /* === 卡片 === */
  /* 登录页面卡片 */
  body > #root > div > div.ant-card {
    width: calc(100vw - 32px) !important;
    max-width: 400px !important;
    margin: 16px auto !important;
  }

  /* 内容页面卡片 */
  .ant-layout-content .ant-card {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 12px 0 !important;
    overflow: hidden !important;
  }

  .ant-card-head {
    padding: 0 12px !important;
    min-height: 44px !important;
  }

  .ant-card-head-title {
    font-size: 15px !important;
    padding: 8px 0 !important;
  }

  .ant-card-body {
    padding: 12px !important;
    overflow: visible !important;
  }

  /* === 筛选栏 - 关键优化 === */
  /* 只对卡片内的第一个Space应用垂直布局 */
  .ant-card-body > .ant-space {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    margin-bottom: 16px !important;
  }

  .ant-card-body > .ant-space > .ant-space-item {
    width: 100% !important;
    margin: 0 !important;
  }

  /* 筛选栏内的所有输入控件 */
  .ant-card-body > .ant-space .ant-input,
  .ant-card-body > .ant-space .ant-select,
  .ant-card-body > .ant-space .ant-picker,
  .ant-card-body > .ant-space .ant-btn {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  /* RangePicker特殊处理 - 防止溢出 */
  .ant-card-body > .ant-space .ant-picker-range {
    width: 100% !important;
    max-width: 100% !important;
  }

  .ant-picker-range .ant-picker-input {
    flex: 1 !important;
    min-width: 0 !important;
  }

  .ant-picker-range .ant-picker-input > input {
    font-size: 12px !important;
    padding: 4px 8px !important;
  }

  .ant-picker-range .ant-picker-separator {
    padding: 0 4px !important;
  }

  /* Select下拉框 */
  .ant-select {
    width: 100% !important;
  }

  .ant-select-selector {
    width: 100% !important;
  }

  /* === 统计卡片 === */
  .ant-row {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
  }

  .ant-col {
    padding-left: 6px !important;
    padding-right: 6px !important;
    margin-bottom: 12px !important;
  }

  .ant-statistic-title {
    font-size: 13px !important;
    margin-bottom: 4px !important;
  }

  .ant-statistic-content {
    font-size: 20px !important;
  }

  .ant-statistic-content-prefix {
    font-size: 18px !important;
  }

  /* === 表格 - 关键优化 === */
  .ant-table-wrapper {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    width: 100% !important;
    margin-top: 12px !important;
  }

  /* 减小表格最小宽度 */
  .ant-table {
    min-width: 600px !important;
    font-size: 12px !important;
  }

  .ant-table-thead > tr > th {
    padding: 8px 6px !important;
    font-size: 12px !important;
    white-space: nowrap !important;
  }

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

  /* 表格内的操作按钮 */
  .ant-table-cell .ant-space {
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 4px !important;
  }

  .ant-table-cell .ant-btn {
    margin: 0 !important;
    padding: 2px 8px !important;
    font-size: 12px !important;
    height: auto !important;
    min-height: 28px !important;
    white-space: nowrap !important;
  }

  /* Tag标签 */
  .ant-tag {
    font-size: 11px !important;
    padding: 0 6px !important;
    line-height: 20px !important;
    margin: 2px !important;
  }

  /* === 分页器 === */
  .ant-pagination {
    text-align: center !important;
    margin-top: 16px !important;
    display: flex !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
  }

  .ant-pagination-item,
  .ant-pagination-prev,
  .ant-pagination-next {
    min-width: 32px !important;
    height: 32px !important;
    line-height: 30px !important;
    margin: 4px 2px !important;
  }

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

  .ant-pagination-jump-prev,
  .ant-pagination-jump-next {
    min-width: 32px !important;
  }

  /* === Modal弹窗 === */
  .ant-modal {
    max-width: calc(100vw - 32px) !important;
    margin: 16px auto !important;
    top: 20px !important;
  }

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

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

  .ant-modal-title {
    font-size: 16px !important;
  }

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

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

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

  /* === 表单 === */
  .ant-form-item {
    margin-bottom: 16px !important;
  }

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

  .ant-input,
  .ant-input-number,
  .ant-input-password {
    font-size: 14px !important;
    width: 100% !important;
  }

  .ant-input-number {
    width: 100% !important;
  }

  .ant-input-textarea textarea {
    font-size: 14px !important;
  }

  /* === 按钮 === */
  .ant-btn {
    font-size: 14px !important;
    padding: 6px 15px !important;
    height: auto !important;
    min-height: 32px !important;
  }

  .ant-btn-sm {
    font-size: 12px !important;
    padding: 4px 10px !important;
    min-height: 28px !important;
  }

  /* === 下拉菜单 === */
  .ant-dropdown {
    max-width: calc(100vw - 32px) !important;
  }

  .ant-select-dropdown {
    max-width: calc(100vw - 32px) !important;
  }

  .ant-picker-dropdown {
    max-width: calc(100vw - 32px) !important;
  }

  .ant-picker-panel-container {
    overflow-x: auto !important;
  }

  /* === 标题 === */
  h1 {
    font-size: 20px !important;
    margin-bottom: 16px !important;
  }

  h2 {
    font-size: 18px !important;
    margin-bottom: 12px !important;
  }

  h3 {
    font-size: 16px !important;
    margin-bottom: 10px !important;
  }
}

/* ========== 小屏手机优化 (≤480px) ========== */
@media screen and (max-width: 480px) {

  .ant-layout-content {
    padding: 6px !important;
  }

  .ant-card-body {
    padding: 10px !important;
  }

  .ant-card-head {
    padding: 0 10px !important;
    min-height: 40px !important;
  }

  .ant-card-head-title {
    font-size: 14px !important;
  }

  /* 筛选栏间距 */
  .ant-card-body > .ant-space {
    gap: 8px !important;
  }

  /* 表格更紧凑 */
  .ant-table {
    min-width: 500px !important;
    font-size: 11px !important;
  }

  .ant-table-thead > tr > th {
    padding: 6px 4px !important;
    font-size: 11px !important;
  }

  .ant-table-tbody > tr > td {
    padding: 6px 4px !important;
    font-size: 11px !important;
  }

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

  /* Tag更小 */
  .ant-tag {
    font-size: 10px !important;
    padding: 0 4px !important;
    line-height: 18px !important;
  }

  /* 统计卡片 */
  .ant-col {
    padding-left: 4px !important;
    padding-right: 4px !important;
  }

  .ant-statistic-title {
    font-size: 12px !important;
  }

  .ant-statistic-content {
    font-size: 18px !important;
  }

  .ant-statistic-content-prefix {
    font-size: 16px !important;
  }

  /* 头部 */
  .ant-layout-header {
    padding: 0 8px !important;
    height: 52px !important;
    line-height: 52px !important;
  }

  .ant-layout-header .ant-space {
    font-size: 12px !important;
  }

  .ant-layout-header .ant-avatar {
    width: 24px !important;
    height: 24px !important;
  }

  /* 按钮 */
  .ant-btn {
    font-size: 13px !important;
    padding: 5px 12px !important;
    min-height: 30px !important;
  }

  /* 输入框 */
  .ant-input,
  .ant-input-number,
  .ant-select-selector {
    font-size: 13px !important;
  }

  .ant-picker-range .ant-picker-input > input {
    font-size: 11px !important;
  }

  /* Modal */
  .ant-modal {
    max-width: calc(100vw - 24px) !important;
    margin: 12px auto !important;
  }

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

  /* 分页器 */
  .ant-pagination-item,
  .ant-pagination-prev,
  .ant-pagination-next {
    min-width: 28px !important;
    height: 28px !important;
    line-height: 26px !important;
    font-size: 12px !important;
  }

  /* 标题 */
  h1 {
    font-size: 18px !important;
  }

  h2 {
    font-size: 16px !important;
  }

  h3 {
    font-size: 14px !important;
  }
}

/* ========== 平板适配 (769px-1024px) ========== */
@media screen and (min-width: 769px) and (max-width: 1024px) {
  .ant-layout-content {
    margin: 16px !important;
    padding: 16px !important;
  }

  .ant-layout-header {
    padding: 0 16px !important;
  }

  .ant-table-wrapper {
    overflow-x: auto;
  }
}

/* ========== 宽屏优化 (1025px-1919px) ========== */
@media screen and (min-width: 1025px) and (max-width: 1919px) {
  /* 内容区域充分利用空间 */
  .ant-layout-content {
    margin: 20px !important;
    padding: 24px !important;
    max-width: 100% !important;
  }

  /* 统计卡片行布局优化 */
  .ant-row {
    margin-left: -12px !important;
    margin-right: -12px !important;
  }

  .ant-col {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  /* 卡片间距 */
  .ant-card {
    margin-bottom: 20px !important;
  }

  .ant-card-body {
    padding: 20px !important;
  }

  /* 表格充分展开 */
  .ant-table-wrapper {
    width: 100% !important;
  }

  .ant-table {
    width: 100% !important;
  }

  /* 筛选栏横向排列 */
  .ant-card-body > .ant-space {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    align-items: flex-end !important;
  }

  .ant-card-body > .ant-space > .ant-space-item {
    flex: 0 1 auto !important;
    min-width: 200px !important;
  }

  /* RangePicker适当宽度 */
  .ant-picker-range {
    min-width: 280px !important;
  }

  /* 表格操作按钮 */
  .ant-table-cell .ant-space {
    gap: 8px !important;
  }

  .ant-table-cell .ant-btn {
    padding: 4px 15px !important;
  }
}

/* ========== 超大屏幕 (≥1920px) ========== */
@media screen and (min-width: 1920px) {
  /* 内容区域充分利用空间，不限制最大宽度 */
  .ant-layout-content {
    margin: 24px !important;
    padding: 32px !important;
  }

  /* 统计卡片更大间距 */
  .ant-row {
    margin-left: -16px !important;
    margin-right: -16px !important;
  }

  .ant-col {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  /* 卡片 */
  .ant-card {
    margin-bottom: 24px !important;
  }

  .ant-card-body {
    padding: 24px !important;
  }

  /* 筛选栏 */
  .ant-card-body > .ant-space {
    gap: 16px !important;
  }

  .ant-card-body > .ant-space > .ant-space-item {
    min-width: 220px !important;
  }

  /* 表格 */
  .ant-table-wrapper {
    width: 100% !important;
  }

  /* 字体稍大 */
  .ant-statistic-content {
    font-size: 28px !important;
  }

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

  .ant-table-thead > tr > th {
    font-size: 14px !important;
    padding: 12px 16px !important;
  }

  .ant-table-tbody > tr > td {
    font-size: 14px !important;
    padding: 12px 16px !important;
  }
}

/* ========== 横屏手机 ========== */
@media screen and (max-height: 500px) and (orientation: landscape) {
  .ant-layout-header {
    height: 48px !important;
    line-height: 48px !important;
  }

  .ant-layout-sider {
    width: 180px !important;
  }
}

/* ========== 触摸设备优化 ========== */
@media (hover: none) and (pointer: coarse) {
  .ant-btn,
  .ant-menu-item {
    min-height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
  }
}

/* ========== 打印样式 ========== */
@media print {
  .ant-layout-sider,
  .ant-layout-header,
  .ant-btn,
  .ant-pagination {
    display: none !important;
  }

  .ant-layout-content {
    margin: 0 !important;
    padding: 0 !important;
  }

  .ant-table {
    page-break-inside: auto;
  }

  .ant-table tr {
    page-break-inside: avoid;
    page-break-after: auto;
  }
}

/* ========== 辅助功能 ========== */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

@media (prefers-contrast: high) {
  .ant-btn-primary {
    border-width: 2px !important;
  }

  .ant-table-thead > tr > th {
    border-width: 2px !important;
  }
}
