/* ================================================================
 * 田径运动会编排系统 · 视觉样式覆盖 (theme-override.css) v20260624j
 *  - 登录页：深蓝径向渐变背景 + 左右双栏卡片（左薄荷绿微信扫码 / 右白底账号登录）
 *  - 登录卡片：顶部蓝渐变标题栏 + 圆角 + 阴影；左栏 40% 薄荷绿；右栏 60% 白色
 *  - 后台：深蓝顶栏 + 浅灰背景 + 统一圆角/阴影
 *  - 【修复】预加载遮罩：从激进全局透明改为仅隐藏旧 Tab 容器 + 3 秒超时兜底
 * ================================================================ */

/* ---------- CSS 变量 ---------- */
:root {
  --ci-primary-deep: #194776;
  --ci-primary: #2694dd;
  --ci-primary-light: #48a8e6;
  --ci-mint: #e6f9f5;
  --ci-page-bg: #f0f5fa;
  --ci-txt: #1a1a2e;
  --ci-txt-sub: #6b7280;
  --ci-border: #e5e7eb;
  --ci-shadow: 0 16px 48px rgba(22, 64, 117, 0.22);
  --ci-radius-lg: 16px;
  --ci-radius-md: 10px;
  --ci-radius-sm: 8px;
}

/* ================================================================
 * 1. 登录页：整页背景 + 居中（覆盖 React 默认白色背景）
 * ================================================================ */

/* 最高优先级：html/body 强制深蓝渐变，铺满整屏 */
html.is-login-page,
html.is-login-page body,
body.is-login-page {
  background: radial-gradient(ellipse at top, #174378 0%, #1b5a9a 35%, #2694dd 100%) !important;
  background-image: radial-gradient(ellipse at top, #174378 0%, #1b5a9a 35%, #2694dd 100%) !important;
  background-color: #194776 !important;
  background-size: 100% 100% !important;
  background-attachment: fixed !important;
  min-height: 100vh !important;
  height: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  color: var(--ci-txt) !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC",
    "Hiragino Sans GB", "Microsoft YaHei", sans-serif !important;
}

/* 消除 React 根容器白色背景：仅对 #root 及其直接子容器透明化 */
/* 不再对 #root > div > div > div:not(.ci-login-card) 设置 width/min-height/background */
/* 避免破坏 React 原始 440px 卡片的尺寸和背景 */
html.is-login-page #root,
body.is-login-page #root,
html.is-login-page #root > div,
html.is-login-page #root > div > div {
  background: transparent !important;
  background-color: transparent !important;
}

html.is-login-page #root {
  min-height: 100vh !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 30px 16px !important;
  box-sizing: border-box !important;
}

html.is-login-page #root > div,
html.is-login-page #root > div > div {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
}

/* ================================================================
 * 【已修复 v2】登录页预加载遮罩：只在重建过渡期隐藏旧 Tab 卡片
 * - 不再激进隐藏所有 div，避免新 ci-login-card 也被一起隐藏
 * - 仅对 body[data-ci-rebuilding="1"] 时隐藏带 width: xxxpx 的卡片容器
 * - body[data-ci-rebuilt-login="1"] 完成后不做任何隐藏
 * ================================================================ */

/* 规则1：重建进行中 - 仅隐藏含 width: 固定像素 + 浅色背景 的旧卡片 */
html.is-login-page body[data-ci-rebuilding="1"] div[style*="width:"][style*="background"]:not(.ci-login-card),
html.is-login-page body[data-ci-rebuilding="1"] div[style*="width: 440px"]:not(.ci-login-card) {
  opacity: 0 !important;
  visibility: hidden !important;
}

/* 规则2：3 秒超时兜底 - 若未完成重建自动取消遮罩 */
html.is-login-page body:not([data-ci-rebuilt-login="1"]):not([data-ci-rebuilding="1"]) #root > div > div[style*="width:"],
html.is-login-page body:not([data-ci-rebuilt-login="1"]):not([data-ci-rebuilding="1"]) #root > div > div > div[style*="width:"] {
  animation: ciAutoShowFallback 0s 3s forwards;
}
@keyframes ciAutoShowFallback {
  to {
    visibility: visible !important;
    opacity: 1 !important;
  }
}

/* 规则3：确保新的 ci-login-card 始终可见 */
html.is-login-page .ci-login-card {
  visibility: visible !important;
  opacity: 1 !important;
}

/* ================================================================
 * 2. 登录页：新建卡片 ci-login-card（左右二分布局）
 * ================================================================ */

.ci-login-card {
  width: 480px !important;
  max-width: calc(100% - 24px) !important;
  background: #ffffff !important;
  border-radius: var(--ci-radius-lg) !important;
  box-shadow: var(--ci-shadow) !important;
  overflow: hidden !important;
  display: flex !important;
  flex-wrap: wrap !important;
  flex-direction: row !important;
  align-items: stretch !important;
  margin: 0 auto !important;
}
/* --- 删除输入框内层边线：ant-input-affix-wrapper 内的 input 不再有独立 border --- */
.ci-login-card .ant-input-affix-wrapper .ant-input {
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
  outline: none !important;
}

/* --- 右侧表单输入框左右内边距缩短一半 --- */
.ci-login-card .ant-input-affix-wrapper {
  padding-left: 4px !important;
  padding-right: 4px !important;
}

/* --- 顶部渐变标题栏 --- */
.ci-login-header {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  padding: 9px 20px !important;
  background: linear-gradient(90deg, #194776 0%, #1e5b9e 50%, #2694dd 100%) !important;
  color: #ffffff !important;
}

.ci-login-logo-circle {
  width: 32px !important;
  height: 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

.ci-login-logo-circle img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  display: block !important;
}

.ci-login-title-wrap {
  line-height: 1.3 !important;
  text-align: center !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.ci-login-main-title {
  font-size: 22px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  color: #ffffff !important;
}

/* --- 主体：左右双栏 --- */
.ci-login-body {
  display: flex !important;
  align-items: stretch !important;
  min-height: 240px !important;
}

/* --- 左栏：微信扫码（浅薄荷绿） --- */
.ci-login-left {
  flex: 0 0 40% !important;
  background: var(--ci-mint) !important;
  padding: 16px 20px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.ci-qr-icon-circle {
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  background: #07c160 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 10px !important;
  box-shadow: 0 4px 12px rgba(7, 193, 96, 0.3) !important;
}

.ci-qr-icon-circle svg {
  width: 22px !important;
  height: 22px !important;
  display: block !important;
}

.ci-qr-title {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--ci-primary-deep) !important;
  margin-bottom: 4px !important;
}

.ci-qr-subtitle {
  font-size: 12px !important;
  color: var(--ci-txt-sub) !important;
  margin-bottom: 14px !important;
}

.ci-qr-frame {
  width: 140px !important;
  max-width: 100% !important;
  background: #ffffff !important;
  border: 1px solid var(--ci-border) !important;
  border-radius: var(--ci-radius-md) !important;
  padding: 8px !important;
  box-shadow: 0 4px 12px rgba(25, 71, 118, 0.1) !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 0 !important;
}

.ci-qr-frame iframe {
  width: 100% !important;
  height: 124px !important;
  border: none !important;
  display: block !important;
  background: #ffffff !important;
}

.ci-qr-link {
  font-size: 12px !important;
  color: var(--ci-primary) !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
  cursor: pointer !important;
}

.ci-qr-link:hover {
  color: var(--ci-primary-light) !important;
}

/* --- 右栏：账号登录 --- */
.ci-login-right {
  flex: 1 !important;
  padding: 16px 24px !important;
  background: #ffffff !important;
}

.ci-form-header {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin-bottom: 12px !important;
  color: var(--ci-primary-deep) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
}

.ci-form-icon {
  width: 32px !important;
  height: 32px !important;
  border-radius: 8px !important;
  background: linear-gradient(90deg, rgba(25, 71, 118, 0.1), rgba(38, 148, 221, 0.15)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

.ci-form-icon svg {
  fill: var(--ci-primary) !important;
  width: 18px !important;
  height: 18px !important;
}

.ci-form-content {
  display: block !important;
}

/* 右栏底部：记住密码 + 自动登录 复选框行 */
.ci-login-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin: 18px 0 !important;
  font-size: 13px !important;
}

.ci-login-row .ci-login-remember-group {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}

.ci-login-row a {
  color: var(--ci-primary) !important;
  text-decoration: none !important;
  font-size: 13px !important;
  cursor: pointer !important;
}

/* 注册账号 */
.ci-login-register {
  display: flex !important;
  justify-content: center !important;
  gap: 16px !important;
  margin: 16px 0 !important;
  font-size: 13px !important;
}

.ci-login-register a,
.ci-login-register span {
  color: var(--ci-primary) !important;
  cursor: pointer !important;
  text-decoration: none !important;
}

.ci-login-register a:hover {
  color: var(--ci-primary-light) !important;
}

/* 访问官网按钮 */
.ci-login-official-btn {
  display: block !important;
  width: 220px !important;
  margin: 18px auto 0 !important;
  padding: 10px 20px !important;
  background: #ffffff !important;
  color: var(--ci-primary-deep) !important;
  border: 1.5px solid var(--ci-primary) !important;
  border-radius: var(--ci-radius-sm) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: all 0.25s ease !important;
  box-sizing: border-box !important;
  text-decoration: none !important;
}

.ci-login-official-btn:hover {
  background: linear-gradient(90deg, #194776 0%, #2694dd 100%) !important;
  color: #ffffff !important;
  border-color: transparent !important;
  box-shadow: 0 4px 14px rgba(25, 71, 118, 0.25) !important;
}

/* ================================================================
 * 3. 账号登录表单：输入框、按钮、checkbox
 * ================================================================ */

/* 输入框通用：修复 ant-input-affix-wrapper 与内部 input 错位问题 */
.ci-login-right .ant-input-affix-wrapper {
  height: 44px !important;
  line-height: 44px !important;
  border-radius: var(--ci-radius-sm) !important;
  border: 1px solid #d1d5db !important;
  background: #fff !important;
  padding: 0 !important;
  font-size: 14px !important;
  color: var(--ci-txt) !important;
  display: flex !important;
  align-items: center !important;
  box-sizing: border-box !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

.ci-login-right .ant-input-affix-wrapper .ant-input-prefix,
.ci-login-right .ant-input-affix-wrapper .ant-input-suffix {
  display: flex !important;
  align-items: center !important;
  height: 100% !important;
  color: #8b95a1 !important;
  font-size: 16px !important;
}

.ci-login-right .ant-input-affix-wrapper .ant-input-prefix {
  margin-right: 6px !important;
  margin-left: 8px !important;
}

.ci-login-right .ant-input-affix-wrapper .ant-input-suffix {
  margin-left: 6px !important;
  margin-right: 8px !important;
}

.ci-login-right .ant-input-affix-wrapper .ant-input {
  height: 42px !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  font-size: 14px !important;
  color: var(--ci-txt) !important;
  outline: none !important;
  flex: 1 !important;
}

/* 普通 input（验证码输入框等） */
.ci-login-right input[type="text"],
.ci-login-right input[type="password"] {
  height: 44px !important;
  border-radius: var(--ci-radius-sm) !important;
  border: 1px solid #d1d5db !important;
  background: #fff !important;
  font-size: 14px !important;
  color: var(--ci-txt) !important;
  padding-left: 6px !important;
  padding-right: 6px !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
  box-sizing: border-box !important;
}

.ci-login-right .ant-input-affix-wrapper:hover,
.ci-login-right .ant-input-affix-wrapper-focused,
.ci-login-right input[type="text"]:hover,
.ci-login-right input[type="password"]:hover {
  border-color: var(--ci-primary) !important;
  box-shadow: 0 0 0 3px rgba(38, 148, 221, 0.15) !important;
}

.ci-login-right .ant-input-affix-wrapper:focus-within {
  border-color: var(--ci-primary) !important;
  box-shadow: 0 0 0 3px rgba(38, 148, 221, 0.15) !important;
}

/* 登录按钮：深蓝→亮青蓝渐变填充 */
.ci-login-right .ant-btn-primary,
.ci-login-right button[type="submit"],
.ci-login-right button[class*="ant-btn-primary"],
.ci-login-right button[style*="1890ff"] {
  background: linear-gradient(90deg, #194776 0%, #1e5b9e 50%, #2694dd 100%) !important;
  background-image: linear-gradient(90deg, #194776 0%, #1e5b9e 50%, #2694dd 100%) !important;
  border: none !important;
  color: #ffffff !important;
  height: 46px !important;
  border-radius: var(--ci-radius-sm) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: 2px !important;
  box-shadow: 0 6px 16px rgba(25, 71, 118, 0.3) !important;
  transition: all 0.25s ease !important;
  width: 100% !important;
}

.ci-login-right .ant-btn-primary span,
.ci-login-right button[type="submit"] span {
  color: #ffffff !important;
}

.ci-login-right .ant-btn-primary:hover,
.ci-login-right button[type="submit"]:hover {
  background: linear-gradient(90deg, #1b5a9a 0%, #2694dd 50%, #48a8e6 100%) !important;
  background-image: linear-gradient(90deg, #1b5a9a 0%, #2694dd 50%, #48a8e6 100%) !important;
  box-shadow: 0 8px 20px rgba(25, 71, 118, 0.4) !important;
  transform: translateY(-1px) !important;
  color: #ffffff !important;
}

/* Checkbox 主题色 */
.ci-login-right .ant-checkbox-checked .ant-checkbox-inner,
.ci-login-right .ant-checkbox-wrapper .ant-checkbox-inner,
.ci-login-right input[type="checkbox"] {
  border-color: var(--ci-primary) !important;
}

.ci-login-right .ant-checkbox-checked .ant-checkbox-inner {
  background-color: var(--ci-primary) !important;
}

.ci-login-right .ant-checkbox-wrapper {
  font-size: 13px !important;
  color: var(--ci-txt-sub) !important;
}

/* 验证码图片容器 */
.ci-login-right img[alt*="验证码"],
.ci-login-right img[alt*="captcha"],
.ci-login-right .ant-image {
  border-radius: var(--ci-radius-sm) !important;
  border: 1px solid #e5e7eb !important;
  overflow: hidden !important;
}

/* 忘记密码 / 注册链接 */
.ci-login-right a {
  color: var(--ci-primary) !important;
  font-size: 13px !important;
}

.ci-login-right a:hover {
  color: var(--ci-primary-light) !important;
}

/* ================================================================
 * 4. 后台管理页：顶栏、侧边栏、内容区
 * ================================================================ */

/* 页面背景 */
body:not(.is-login-page) {
  background: var(--ci-page-bg) !important;
}

.ant-layout,
.ant-layout-content,
.ant-pro-basicLayout-content,
.ant-pro-page-container,
.ant-pro-page-container-children-content,
.ant-pro-grid-content,
.ant-pro-layout-content {
  background: var(--ci-page-bg) !important;
}

/* 顶栏（深蓝渐变） */
.ant-layout-header,
.ant-pro-layout-header,
.ant-pro-global-header {
  background: linear-gradient(90deg, var(--ci-primary-deep), var(--ci-primary) 70%, var(--ci-primary-light)) !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(22, 64, 117, 0.18) !important;
}

.ant-pro-global-header * {
  color: rgba(255, 255, 255, 0.95) !important;
}

/* 侧边栏 */
.ant-layout-sider,
.ant-pro-sider,
.ant-pro-sider-fixed {
  background: #ffffff !important;
  border-right: 1px solid var(--ci-border) !important;
}

.ant-menu-light.ant-menu-root.ant-menu-inline {
  background: transparent !important;
}

.ant-menu-light .ant-menu-item:hover:not(.ant-menu-item-selected) {
  background: var(--ci-mint) !important;
  color: var(--ci-primary-deep) !important;
}

.ant-menu-item-selected {
  background: linear-gradient(90deg, rgba(22, 64, 117, 0.12), rgba(35, 146, 221, 0.08)) !important;
  color: var(--ci-primary-deep) !important;
  border-right: 3px solid var(--ci-primary);
}

.ant-menu-item-selected .anticon {
  color: var(--ci-primary) !important;
}

/* ================================================================
 * 5. 通用：按钮、输入框、表格
 * ================================================================ */

.ant-btn-primary {
  background: linear-gradient(90deg, var(--ci-primary-deep), var(--ci-primary)) !important;
  background-image: linear-gradient(90deg, var(--ci-primary-deep), var(--ci-primary)) !important;
  border: none !important;
  color: #fff !important;
  border-radius: var(--ci-radius-md) !important;
  box-shadow: 0 2px 6px rgba(22, 64, 117, 0.25) !important;
  transition: all 0.25s ease !important;
}

.ant-btn-primary:hover {
  background: linear-gradient(90deg, var(--ci-primary), var(--ci-primary-light)) !important;
  background-image: linear-gradient(90deg, var(--ci-primary), var(--ci-primary-light)) !important;
  box-shadow: 0 4px 12px rgba(22, 64, 117, 0.3) !important;
  color: #fff !important;
}

.ant-btn {
  border-radius: var(--ci-radius-md) !important;
  transition: all 0.2s ease !important;
}

.ant-input,
.ant-input-affix-wrapper {
  border-radius: var(--ci-radius-md) !important;
  border: 1px solid #d1d5db !important;
  padding: 8px 12px !important;
  background: #fff !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}

.ant-input:hover,
.ant-input-affix-wrapper:hover {
  border-color: var(--ci-primary) !important;
}

.ant-input:focus,
.ant-input-affix-wrapper:focus,
.ant-input-focused,
.ant-input-affix-wrapper-focused {
  border-color: var(--ci-primary) !important;
  box-shadow: 0 0 0 3px rgba(35, 146, 221, 0.15) !important;
  outline: none;
}

/* 体验版标签（红色实心背景） */
body .ant-tag-default,
body .ant-tag.ant-tag-default,
body span.ant-tag.ant-tag-default,
html body .ant-tag.ant-tag-default,
.ant-tag.ant-tag-default {
  background-color: #dc2626 !important;
  background: #dc2626 !important;
  border: 1px solid #dc2626 !important;
  border-color: #dc2626 !important;
  color: #ffffff !important;
  border-radius: 6px !important;
  padding: 2px 12px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 1.5 !important;
}

/* 表格 */
.ant-table {
  border-radius: var(--ci-radius-lg) !important;
  overflow: hidden !important;
  box-shadow: 0 2px 12px rgba(22, 64, 117, 0.06) !important;
  background: #fff !important;
}

.ant-table-thead > tr > th {
  background: linear-gradient(180deg, #f8fafc, #eef2f7) !important;
  color: var(--ci-primary-deep) !important;
  font-weight: 600 !important;
  border-bottom: 1px solid var(--ci-border) !important;
}

.ant-table-tbody > tr > td {
  border-bottom: 1px solid #f1f5f9 !important;
}

.ant-table-tbody > tr:hover > td {
  background: var(--ci-mint) !important;
}

/* ================================================================
 * 6. 页面底部版权
 * ================================================================ */
body.is-login-page::after {
  content: "田径运动会编排系统 · 版权所有 · All Rights Reserved";
  position: fixed;
  bottom: 20px;
  left: 0;
  right: 0;
  text-align: center;
  color: rgba(255, 255, 255, 0.85);
  font-size: 12px;
  letter-spacing: 1px;
  pointer-events: none;
  z-index: 1;
}

/* ================================================================
 * 7. 下拉菜单注入项样式
 * ================================================================ */
.ci-menu-item {
  min-height: 32px !important;
  line-height: 22px !important;
  white-space: nowrap !important;
  padding: 5px 12px !important;
}

.ci-menu-item:hover {
  background: rgba(0, 0, 0, 0.04) !important;
}

.ci-menu-item svg {
  flex-shrink: 0 !important;
}

.ci-menu-item .anticon {
  flex-shrink: 0 !important;
}

/* ================================================================
 * 8. 响应式：平板/手机适配
 * ================================================================ */

@media (max-width: 960px) {
  .ci-login-body {
    flex-direction: column !important;
  }
  .ci-login-left {
    flex: 0 0 auto !important;
    padding: 36px 24px 28px !important;
  }
  .ci-login-right {
    padding: 32px 24px !important;
  }
  .ci-login-card {
    width: 100% !important;
    max-width: 520px !important;
  }
  .ci-login-header {
    padding: 20px 24px !important;
  }
  .ci-login-main-title {
    font-size: 20px !important;
  }
  body.is-login-page::after {
    position: static;
    display: block;
    text-align: center;
    padding: 12px;
    margin-top: 20px;
  }
}

@media (max-width: 480px) {
  .ci-login-right {
    padding: 28px 18px !important;
  }
  .ci-login-left {
    padding: 32px 18px 24px !important;
  }
  .ci-qr-frame {
    width: 220px !important;
  }
  .ci-login-right button {
    letter-spacing: 1px !important;
  }
}
