/**
 * 响应式样式
 * 适配各种屏幕尺寸
 */

/* ============ 平板端 (max-width: 1024px) ============ */
@media (max-width: 1024px) {
  /* 布局调整 */
  .sidebar {
    width: 200px;
  }
  
  .dashboard-col-8,
  .dashboard-col-4 {
    grid-column: span 6;
  }
  
  .detail-content {
    grid-template-columns: 1fr;
  }
  
  /* 表格调整 */
  .table th,
  .table td {
    padding: var(--spacing-sm);
  }
}

/* ============ 移动端 (max-width: 768px) ============ */
@media (max-width: 768px) {
  /* 隐藏桌面端元素 */
  .hide-mobile {
    display: none !important;
  }
  
  /* 显示移动端元素 */
  .show-mobile {
    display: block !important;
  }
  
  /* 布局调整 */
  .admin-layout {
    flex-direction: column;
  }
  
  .sidebar {
    position: fixed;
    left: -100%;
    top: 0;
    bottom: 0;
    width: 280px;
    z-index: var(--z-fixed);
    transition: left var(--transition-slow);
  }
  
  .sidebar.open {
    left: 0;
  }
  
  .sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: calc(var(--z-fixed) - 1);
  }
  
  .sidebar-overlay.show {
    display: block;
  }
  
  /* 头部调整 */
  .header {
    height: 56px;
    padding: 0 var(--spacing-md);
  }
  
  .header-title {
    font-size: var(--text-base);
  }
  
  .header-breadcrumb {
    display: none;
  }
  
  /* 页面主体调整 */
  .page-main {
    padding: var(--spacing-md);
  }
  
  /* 页面头部调整 */
  .page-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-md);
  }
  
  .page-header-actions {
    width: 100%;
    flex-wrap: wrap;
  }
  
  /* 卡片调整 */
  .card-body {
    padding: var(--spacing-md);
  }
  
  /* 表格调整 */
  .table-container {
    margin: 0 calc(var(--spacing-md) * -1);
    padding: 0 var(--spacing-md);
  }
  
  .table th,
  .table td {
    font-size: var(--text-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
  }
  
  /* 移动端表格卡片模式 */
  .table-mobile-card thead {
    display: none;
  }
  
  .table-mobile-card tbody {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .table-mobile-card tr {
    display: flex;
    flex-direction: column;
    padding: var(--spacing-md);
    background: var(--glass-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius);
  }
  
  .table-mobile-card td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-xs) 0;
    border: none;
  }
  
  .table-mobile-card td::before {
    content: attr(data-label);
    font-weight: 600;
    color: var(--color-text-muted);
    font-size: var(--text-xs);
  }
  
  /* 列表页调整 */
  .list-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  
  .list-search {
    max-width: none;
  }
  
  .list-actions {
    justify-content: flex-end;
  }
  
  .list-footer {
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  /* 表单调整 */
  .form-page {
    padding: 0;
  }
  
  .form-card {
    padding: var(--spacing-md);
  }
  
  .form-row {
    grid-template-columns: 1fr;
  }
  
  .form-actions {
    flex-direction: column;
  }
  
  .form-actions .btn {
    width: 100%;
  }
  
  /* 详情页调整 */
  .detail-header {
    flex-direction: column;
    gap: var(--spacing-md);
  }
  
  .detail-title {
    font-size: var(--text-xl);
  }
  
  .detail-meta {
    flex-wrap: wrap;
  }
  
  .detail-field {
    flex-direction: column;
    gap: var(--spacing-xs);
  }
  
  .detail-field-label {
    width: auto;
  }
  
  /* 仪表盘调整 */
  .stats-grid {
    grid-template-columns: 1fr;
  }
  
  .dashboard-grid {
    grid-template-columns: 1fr;
  }
  
  .dashboard-col-8,
  .dashboard-col-4,
  .dashboard-col-6,
  .dashboard-col-12 {
    grid-column: span 1;
  }
  
  /* 首页调整 */
  .home-page {
    padding: var(--spacing-lg);
  }
  
  .home-title {
    font-size: var(--text-2xl);
  }
  
  .home-description {
    font-size: var(--text-base);
  }
  
  .home-actions {
    flex-direction: column;
  }
  
  .home-actions .btn {
    width: 100%;
  }
  
  .home-features {
    grid-template-columns: 1fr;
  }
  
  /* 模态框调整 */
  .modal {
    width: calc(100% - var(--spacing-lg) * 2);
    max-height: calc(100vh - var(--spacing-lg) * 2);
    margin: var(--spacing-lg);
  }
  
  .modal-header,
  .modal-body,
  .modal-footer {
    padding: var(--spacing-md);
  }
  
  .modal-footer {
    flex-direction: column;
  }
  
  .modal-footer .btn {
    width: 100%;
  }
  
  /* Toast 调整 */
  .toast-container {
    top: var(--spacing-sm);
    right: var(--spacing-sm);
    left: var(--spacing-sm);
  }
  
  .toast {
    width: 100%;
  }
  
  /* 分页调整 */
  .pagination {
    flex-wrap: wrap;
    justify-content: center;
  }
  
  .pagination-item {
    min-width: 36px;
    height: 36px;
  }
  
  /* 按钮调整 */
  .btn {
    min-height: 44px;
  }
  
  .btn-sm {
    min-height: 36px;
  }
  
  /* 输入框调整 - 防止iOS缩放 */
  .form-input {
    font-size: 16px;
  }
}

/* ============ 小屏幕 (max-width: 480px) ============ */
@media (max-width: 480px) {
  :root {
    font-size: 14px;
  }
  
  .page-main {
    padding: var(--spacing-sm);
  }
  
  .card-body {
    padding: var(--spacing-sm);
  }
  
  .stat-card {
    padding: var(--spacing-md);
  }
  
  .stat-card-value {
    font-size: var(--text-xl);
  }
  
  .badge {
    font-size: 0.625rem;
    padding: 2px 6px;
  }
}

/* ============ 触摸设备优化 ============ */
@media (hover: none) and (pointer: coarse) {
  /* 增大可点击区域 */
  .btn {
    min-height: 44px;
    min-width: 44px;
  }
  
  .nav-item {
    padding: var(--spacing-md);
  }
  
  .dropdown-item {
    padding: var(--spacing-md);
  }
  
  /* 移除 hover 效果 */
  .table tbody tr:hover {
    background: transparent;
  }
  
  /* 使用 active 状态替代 */
  .btn:active {
    transform: scale(0.98);
  }
  
  .nav-item:active {
    background: var(--color-surface-muted);
  }
}

/* ============ 安全区域适配 (iPhone X 等) ============ */
@supports (padding-top: env(safe-area-inset-top)) {
  .header {
    padding-top: env(safe-area-inset-top);
  }
  
  .sidebar {
    padding-top: env(safe-area-inset-top);
    padding-bottom: env(safe-area-inset-bottom);
  }
  
  .page-main {
    padding-bottom: env(safe-area-inset-bottom);
  }
  
  .modal {
    padding-bottom: env(safe-area-inset-bottom);
  }
}

/* ============ 打印样式 ============ */
@media print {
  .sidebar,
  .header,
  .modal-backdrop,
  .toast-container {
    display: none !important;
  }
  
  .page-main {
    padding: 0;
  }
  
  .card {
    box-shadow: none;
    border: 1px solid #ddd;
  }
  
  .btn {
    display: none;
  }
}

/* ============ 高对比度模式 ============ */
@media (prefers-contrast: high) {
  :root {
    --color-border: #000;
    --color-text-muted: #333;
  }
  
  .btn {
    border-width: 2px;
  }
  
  .form-input {
    border-width: 2px;
  }
}

/* ============ 减少动画 ============ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}