/* ========================================
   移动端响应式适配 - 全局样式
   适用于所有页面
   ======================================== */

/* ===== 1. 设备断点定义 ===== */
/* 超小屏手机 (iPhone SE, 320px-375px) */
@media (max-width: 375px) {
  :root {
    --base-font-size: 14px;
    --button-padding: 10px 16px;
    --input-padding: 10px 12px;
    --gap-size: 8px;
    --container-padding: 12px;
  }

  body {
    font-size: var(--base-font-size);
  }

  .container,
  .login-container,
  .editor-container {
    padding: var(--container-padding) !important;
    max-width: 100% !important;
  }

  /* 标题字体调整 */
  h1 {
    font-size: 20px !important;
  }

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

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

/* 小屏手机 (375px-414px) */
@media (min-width: 376px) and (max-width: 414px) {
  :root {
    --base-font-size: 15px;
    --button-padding: 12px 18px;
    --input-padding: 12px 14px;
    --gap-size: 10px;
    --container-padding: 15px;
  }

  body {
    font-size: var(--base-font-size);
  }

  .container,
  .login-container,
  .editor-container {
    padding: var(--container-padding) !important;
  }
}

/* 大屏手机 (415px-768px) */
@media (min-width: 415px) and (max-width: 768px) {
  :root {
    --base-font-size: 16px;
    --button-padding: 12px 20px;
    --input-padding: 12px 16px;
    --gap-size: 12px;
    --container-padding: 20px;
  }
}

/* 平板竖屏 (769px-1024px) */
@media (min-width: 769px) and (max-width: 1024px) {
  :root {
    --base-font-size: 16px;
    --button-padding: 14px 24px;
    --input-padding: 14px 18px;
    --gap-size: 16px;
    --container-padding: 25px;
  }
}

/* 平板横屏 (1025px+) */
@media (min-width: 1025px) {
  :root {
    --base-font-size: 16px;
    --button-padding: 14px 28px;
    --input-padding: 14px 20px;
    --gap-size: 20px;
    --container-padding: 30px;
  }
}

/* ===== 2. 竖屏模式优化 ===== */
@media (orientation: portrait) {
  body {
    overflow-x: hidden;
  }

  .container {
    max-width: 100%;
    padding: 15px;
  }

  /* 按钮组垂直排列 */
  .button-group,
  .nav-buttons {
    flex-direction: column !important;
    gap: 10px !important;
  }

  .button-group button,
  .nav-buttons button {
    width: 100% !important;
  }

  /* 表单优化 */
  .form-group {
    margin-bottom: 18px;
  }

  .form-group label {
    font-size: 14px;
    margin-bottom: 8px;
  }
}

/* ===== 3. 横屏模式优化 ===== */
@media (orientation: landscape) {
  /* 横屏时优化布局 */
  .container {
    max-width: 95%;
    padding: 20px;
  }

  /* 按钮水平排列 */
  .button-group,
  .nav-buttons {
    flex-direction: row !important;
    gap: 15px !important;
  }

  .button-group button,
  .nav-buttons button {
    flex: 1;
  }

  /* 隐藏横屏提示（如果有）*/
  .rotate-hint {
    display: none !important;
  }
}

/* ===== 4. 移动端通用优化 ===== */
@media (max-width: 768px) {
  /* 所有按钮最小触摸区域 44x44px (iOS标准) */
  button,
  .btn,
  .clickable,
  a {
    min-height: 44px;
    min-width: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  /* 输入框增大触摸区域 */
  input,
  textarea,
  select {
    min-height: 44px;
    font-size: 16px !important; /* 防止iOS自动缩放 */
    padding: 12px !important;
  }

  /* 表单优化 */
  .form-group {
    margin-bottom: 20px;
  }

  .form-group label {
    font-weight: 500;
    margin-bottom: 8px;
    display: block;
  }

  /* 文字可读性优化 */
  body {
    font-size: var(--base-font-size, 16px);
    line-height: 1.6;
  }

  /* 卡片和容器优化 */
  .card,
  .container,
  .modal,
  .login-container {
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  }

  /* 表格优化 */
  table {
    font-size: 14px;
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }

  thead {
    background: #f8f9fa;
  }

  th, td {
    padding: 10px 8px;
    min-width: 80px;
  }

  /* 图片优化 */
  img {
    max-width: 100%;
    height: auto;
    display: block;
  }

  /* 弹窗/模态框优化 */
  .modal,
  .preview-modal {
    padding: 15px !important;
    width: 95% !important;
    max-width: 95% !important;
  }

  .modal-content,
  .preview-content {
    padding: 20px !important;
    max-height: 85vh !important;
    overflow-y: auto;
  }

  /* 分页控件优化 */
  .pagination {
    flex-wrap: wrap;
    gap: 8px;
  }

  .pagination button {
    padding: 10px 14px;
    font-size: 14px;
  }

  /* 标签页优化 */
  .tabs {
    overflow-x: auto;
    white-space: nowrap;
  }

  .tab-button {
    padding: 12px 16px;
    font-size: 14px;
  }
}

/* ===== 5. 平板优化 ===== */
@media (min-width: 769px) and (max-width: 1024px) {
  /* 平板横屏时使用两列布局 */
  .grid-layout {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }

  /* 表格优化 */
  table {
    font-size: 15px;
  }

  /* 图片和视频自适应 */
  img,
  video {
    max-width: 100%;
    height: auto;
  }

  /* 卡片布局优化 */
  .card-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }

  /* 按钮组优化 */
  .button-group {
    display: flex;
    gap: 15px;
  }

  .button-group button {
    flex: 1;
  }
}

/* ===== 6. 触摸反馈优化 ===== */
@media (hover: none) and (pointer: coarse) {
  /* 触摸设备：添加触摸反馈 */
  button:active,
  .btn:active,
  a:active,
  .clickable:active {
    transform: scale(0.98);
    opacity: 0.8;
    transition: transform 0.1s, opacity 0.1s;
  }

  /* 增大可点击区域 */
  .clickable {
    padding: 15px;
  }

  /* 禁用hover效果，避免触摸时的闪烁 */
  *:hover {
    /* 不改变样式 */
  }

  /* 链接优化 */
  a {
    text-decoration: none;
    color: inherit;
  }
}

/* ===== 7. 登录页面专用优化 ===== */
@media (max-width: 768px) {
  .login-container {
    max-width: 100%;
    padding: 30px 20px;
    border-radius: 16px;
    margin: 10px;
  }

  .login-header h1 {
    font-size: 24px;
    margin-bottom: 15px;
  }

  .login-header p {
    font-size: 14px;
  }

  .login-container .btn {
    font-size: 16px;
    padding: 14px;
    margin-top: 10px;
  }
}

/* 横屏登录优化 */
@media (orientation: landscape) and (max-height: 600px) {
  .login-container {
    padding: 20px;
    margin: 10px;
  }

  .login-header {
    margin-bottom: 15px;
  }

  .login-header h1 {
    font-size: 20px;
  }

  .form-group {
    margin-bottom: 12px;
  }
}

/* ===== 8. 列表和卡片优化 ===== */
@media (max-width: 768px) {
  /* 列表项 */
  .list-item {
    padding: 15px;
    margin-bottom: 10px;
    border-radius: 8px;
  }

  /* 卡片 */
  .card {
    margin-bottom: 15px;
    padding: 15px;
  }

  /* 网格布局转为单列 */
  .grid-layout,
  .card-grid {
    grid-template-columns: 1fr !important;
    gap: 15px;
  }
}

/* ===== 9. 文本和排版优化 ===== */
@media (max-width: 768px) {
  /* 避免文本溢出 */
  p, span, div {
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  /* 长文本截断 */
  .text-truncate {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
  }

  /* 行高优化 */
  body, p {
    line-height: 1.6;
  }

  h1, h2, h3 {
    line-height: 1.3;
  }
}

/* ===== 10. 动画和过渡优化 ===== */
@media (prefers-reduced-motion: reduce) {
  /* 减少动画效果，提升性能 */
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* 移动端动画优化 */
@media (max-width: 768px) {
  /* 使用更快的过渡 */
  button,
  .btn,
  a {
    transition: all 0.2s ease;
  }

  /* 减少复杂动画 */
  .animate {
    animation-duration: 0.3s;
  }
}

/* ===== 11. 安全区域适配（iPhone X系列） ===== */
@supports (padding: max(0px)) {
  .safe-area-top {
    padding-top: max(20px, env(safe-area-inset-top));
  }

  .safe-area-bottom {
    padding-bottom: max(20px, env(safe-area-inset-bottom));
  }

  .safe-area-left {
    padding-left: max(20px, env(safe-area-inset-left));
  }

  .safe-area-right {
    padding-right: max(20px, env(safe-area-inset-right));
  }
}

/* ===== 12. 横屏提示（可选） ===== */
.rotate-hint {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.9);
  color: white;
  z-index: 9999;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 20px;
}

.rotate-hint.show {
  display: flex;
}

.rotate-hint i {
  font-size: 64px;
  margin-bottom: 20px;
  animation: rotate-phone 2s infinite;
}

@keyframes rotate-phone {
  0%, 100% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(-90deg);
  }
}

/* 检测到横屏时显示提示（仅在手机上） */
@media (max-width: 768px) and (orientation: landscape) {
  .rotate-hint.show {
    display: flex;
  }
}

/* ===== 13. 打印样式优化 ===== */
@media print {
  body {
    font-size: 12pt;
    line-height: 1.5;
  }

  .no-print {
    display: none !important;
  }

  a[href]:after {
    content: " (" attr(href) ")";
  }
}

/* ===== 14. 高对比度模式支持 ===== */
@media (prefers-contrast: high) {
  body {
    background: white;
    color: black;
  }

  a {
    text-decoration: underline;
  }

  button,
  .btn {
    border: 2px solid currentColor;
  }
}

/* ===== 15. 暗色模式支持（可选） ===== */
@media (prefers-color-scheme: dark) {
  /* 如果需要支持暗色模式，可以在这里添加样式 */
  /* 目前保持默认的浅色主题 */
}

/* ===== 16. 加载状态优化 ===== */
@media (max-width: 768px) {
  .loading-container {
    padding: 30px 20px;
    border-radius: 12px;
  }

  .spinner {
    width: 40px;
    height: 40px;
  }

  .loading-container h1 {
    font-size: 18px;
  }

  .loading-container p {
    font-size: 14px;
  }
}

/* ===== 17. 消息提示优化 ===== */
@media (max-width: 768px) {
  .alert,
  .message,
  .notification {
    padding: 15px;
    margin: 10px;
    border-radius: 8px;
    font-size: 14px;
  }

  .toast {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    max-width: 400px;
    padding: 15px;
    border-radius: 8px;
    z-index: 9999;
  }
}

/* ===== 18. 表单验证提示优化 ===== */
@media (max-width: 768px) {
  .error-message,
  .validation-message {
    font-size: 12px;
    padding: 8px;
    margin-top: 5px;
  }
}

/* ===== 19. 导航栏优化 ===== */
@media (max-width: 768px) {
  .navbar {
    padding: 10px 15px;
  }

  .navbar-brand {
    font-size: 16px;
  }

  .navbar-nav {
    flex-direction: column;
    gap: 10px;
  }

  .navbar-link {
    padding: 12px 16px;
    width: 100%;
  }
}

/* ===== 20. 底部操作栏优化 ===== */
@media (max-width: 768px) {
  .bottom-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 15px;
    background: white;
    box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
    z-index: 100;
  }

  .bottom-bar .button-group {
    margin: 0;
  }
}

/* 为有刘海屏的设备添加额外padding */
.has-notch {
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}
