/* =====================================================================
   QKChat 设计系统 / Branding System  (Phase 4D)
   单一事实来源：颜色、阴影、圆角、组件原语、状态组件、品牌预留位
   默认主题：dark-gold（黑金商务版）。预留：light-blue（白蓝商务版）。
   规则：禁止在组件里写死颜色，一律用 var(--token)。
   ===================================================================== */

/* ---------- 1. Canonical Tokens · 黑金（默认） ---------- */
:root,
[data-theme="dark-gold"] {
  /* 背景 / 表面层级 */
  --bg: #0a0a0f;
  --surface-1: #14141c;          /* 卡片 */
  --surface-2: #1b1b27;          /* 次级 / 内嵌块 */
  --surface-3: #232333;          /* 输入 / hover 抬升 */
  --border: #2a2a3a;
  --border-soft: #20202c;
  --border-strong: #3a3a4e;

  /* 品牌色（精炼暖金，比 crypto 亮金更高级） */
  --accent: #e5b53d;
  --accent-2: #c8912b;
  --accent-soft: rgba(229, 181, 61, 0.14);
  --accent-grad: linear-gradient(135deg, #f0c75a 0%, #c8912b 100%);
  --on-accent: #0a0a0f;          /* 金底上的文字 */

  /* 文本 */
  --text: #ececf1;
  --text-2: #9a9aab;             /* 次要 / muted */
  --text-3: #6b6b7a;             /* 更弱 / 占位 */

  /* 状态色 + 柔和底 */
  --danger: #ef5350;
  --danger-soft: rgba(239, 83, 80, 0.15);
  --success: #34c759;
  --success-soft: rgba(52, 199, 89, 0.15);
  --warn: #f5a623;
  --warn-soft: rgba(245, 166, 35, 0.15);
  --info: #4aa3ff;
  --info-soft: rgba(74, 163, 255, 0.15);

  /* 健康度 */
  --health-green: #34c759;
  --health-yellow: #f5c84b;
  --health-red: #ef5350;

  /* 阴影 / 高光 */
  --shadow-1: 0 1px 2px rgba(0, 0, 0, 0.4);
  --shadow-2: 0 4px 14px rgba(0, 0, 0, 0.45);
  --shadow-3: 0 12px 32px rgba(0, 0, 0, 0.5);
  --glow-accent: 0 6px 20px rgba(229, 181, 61, 0.22);

  /* 圆角 */
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;
  --r-xl: 20px;
  --r-pill: 999px;

  /* 焦点环 */
  --ring: 0 0 0 3px rgba(229, 181, 61, 0.28);

  /* ---- 品牌预留位（未来白标接入；当前给默认值） ---- */
  --brand-name: "QKChat";
  --brand-name-cn: "乾坤云聊";
  --brand-logo-size: 32px;
  --brand-avatar-grad: var(--accent-grad);   /* 客服头像底色 */
  --brand-welcome-img: none;                  /* 访客欢迎图（CSS background-image 值） */
}

/* ---------- 2. Canonical Tokens · 白蓝（结构预留，未启用切换按钮） ---------- */
[data-theme="light-blue"] {
  --bg: #eef2f9;
  --surface-1: #ffffff;
  --surface-2: #f3f6fc;
  --surface-3: #e9eef7;
  --border: #dce3ef;
  --border-soft: #e8edf5;
  --border-strong: #c6d0e2;

  --accent: #2563eb;
  --accent-2: #1d4ed8;
  --accent-soft: rgba(37, 99, 235, 0.10);
  --accent-grad: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);
  --on-accent: #ffffff;

  --text: #1a2233;
  --text-2: #5b6678;
  --text-3: #8a93a6;

  --danger: #dc2626;
  --danger-soft: rgba(220, 38, 38, 0.10);
  --success: #16a34a;
  --success-soft: rgba(22, 163, 74, 0.10);
  --warn: #d97706;
  --warn-soft: rgba(217, 119, 6, 0.10);
  --info: #2563eb;
  --info-soft: rgba(37, 99, 235, 0.10);

  --health-green: #16a34a;
  --health-yellow: #d97706;
  --health-red: #dc2626;

  --shadow-1: 0 1px 2px rgba(20, 40, 80, 0.06);
  --shadow-2: 0 4px 14px rgba(20, 40, 80, 0.08);
  --shadow-3: 0 12px 32px rgba(20, 40, 80, 0.12);
  --glow-accent: 0 6px 20px rgba(37, 99, 235, 0.18);

  --ring: 0 0 0 3px rgba(37, 99, 235, 0.22);
}

/* ---------- 3. 兼容层 · 把三套既有命名 alias 到 canonical ----------
   存量 markup（tenant_admin / agent / chat）零改动即继承新主题。 */
:root,
[data-theme="dark-gold"],
[data-theme="light-blue"] {
  /* tenant_admin.html 既有命名 */
  --card: var(--surface-1);
  --card2: var(--surface-2);
  --muted: var(--text-2);
  --accent2: var(--accent-2);

  /* agent.html 既有命名 */
  --bg-body: var(--bg);
  --bg-card: var(--surface-1);
  --bg-hover: var(--surface-3);
  --gold: var(--accent);
  --gold-dark: var(--accent-2);
  --text-primary: var(--text);
  --text-secondary: var(--text-2);
  --border-color: var(--border);
  --warning: var(--warn);
  --primary: var(--accent);

  /* chat.html 既有命名（访客 widget 租户覆盖仍可二次 override --widget-primary） */
  --widget-primary: var(--accent);
  --widget-primary-dark: var(--accent-2);
  --widget-radius: var(--r-lg);
}

/* ---------- 4. 组件原语（.qk- 前缀，可被各页采用，不污染既有类） ---------- */
.qk-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 9px 18px; border: 1px solid transparent; border-radius: var(--r-md);
  font-size: 14px; font-weight: 600; line-height: 1; cursor: pointer;
  transition: transform .12s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  background: var(--surface-2); color: var(--text);
}
.qk-btn:hover { transform: translateY(-1px); }
.qk-btn:active { transform: translateY(0); }
.qk-btn:focus-visible { outline: none; box-shadow: var(--ring); }
.qk-btn-primary { background: var(--accent-grad); color: var(--on-accent); }
.qk-btn-primary:hover { box-shadow: var(--glow-accent); }
.qk-btn-ghost { background: transparent; border-color: var(--border); color: var(--text); }
.qk-btn-ghost:hover { border-color: var(--accent); color: var(--accent); }
.qk-btn-danger { background: var(--danger); color: #fff; }
.qk-btn-sm { padding: 6px 13px; font-size: 12px; border-radius: var(--r-sm); }
.qk-btn:disabled { opacity: .45; cursor: not-allowed; transform: none; box-shadow: none; }

.qk-card {
  background: var(--surface-1); border: 1px solid var(--border);
  border-radius: var(--r-lg); box-shadow: var(--shadow-1);
  transition: border-color .15s ease, box-shadow .15s ease, transform .12s ease;
}
.qk-card-hover:hover { border-color: var(--border-strong); box-shadow: var(--shadow-2); transform: translateY(-2px); }

.qk-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: var(--r-pill); font-size: 11px; font-weight: 600;
}
.qk-badge-success { background: var(--success-soft); color: var(--success); }
.qk-badge-danger { background: var(--danger-soft); color: var(--danger); }
.qk-badge-warn { background: var(--warn-soft); color: var(--warn); }
.qk-badge-muted { background: var(--surface-3); color: var(--text-2); }

.qk-input {
  width: 100%; padding: 10px 12px; background: var(--surface-3);
  border: 1px solid var(--border); border-radius: var(--r-md);
  color: var(--text); font-size: 14px; outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.qk-input:focus { border-color: var(--accent); box-shadow: var(--ring); }
.qk-input::placeholder { color: var(--text-3); }

/* 自定义滚动条（统一质感） */
.qk-scroll::-webkit-scrollbar { width: 8px; height: 8px; }
.qk-scroll::-webkit-scrollbar-track { background: transparent; }
.qk-scroll::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: var(--r-pill); }
.qk-scroll::-webkit-scrollbar-thumb:hover { background: var(--accent-2); }

/* ---------- 5. 状态组件：loading / skeleton / empty / error ---------- */
.qk-spinner {
  width: 26px; height: 26px; border-radius: 50%;
  border: 3px solid var(--border); border-top-color: var(--accent);
  animation: qk-spin .7s linear infinite; margin: 0 auto;
}
@keyframes qk-spin { to { transform: rotate(360deg); } }

.qk-skeleton {
  background: linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 37%, var(--surface-2) 63%);
  background-size: 400% 100%; border-radius: var(--r-sm);
  animation: qk-shimmer 1.3s ease infinite;
}
@keyframes qk-shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }

.qk-loading, .qk-empty, .qk-error {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; padding: 40px 20px; text-align: center; color: var(--text-2); font-size: 13px;
}
.qk-empty .qk-state-icon, .qk-error .qk-state-icon { font-size: 34px; opacity: .55; line-height: 1; }
.qk-empty .qk-state-title, .qk-error .qk-state-title { color: var(--text); font-size: 15px; font-weight: 600; }
.qk-error .qk-state-icon { color: var(--danger); opacity: .8; }
.qk-state-action { margin-top: 4px; }

/* ---------- 6. 工具类 ---------- */
.qk-elev-1 { box-shadow: var(--shadow-1); }
.qk-elev-2 { box-shadow: var(--shadow-2); }
.qk-gold-text { color: var(--accent); }
.qk-no-x { overflow-x: hidden; max-width: 100%; }
@media (prefers-reduced-motion: reduce) {
  .qk-spinner, .qk-skeleton { animation: none; }
  .qk-btn, .qk-card-hover { transition: none; }
}

/* =====================================================================
   7. QK Design System v1.0 增补（仅追加，不改既有块）
   - 公共契约 token（对外 12）alias 到 canonical
   - 新增主题：dark-blue / pure-dark / light（dark-gold/light-blue 已存在）
   说明：契约 alias 定义在 :root，值用 var() 惰性解析，
        故所有主题（含新主题）只要给出 --surface-*/--accent-*/--text-*/--warn 即自动生效。
   ===================================================================== */

/* ---------- 7a. 公共契约 token + 间距刻度 ---------- */
:root {
  --panel: var(--surface-1);
  --panel-2: var(--surface-2);
  --shadow: var(--shadow-2);
  /* --primary / --warning 已在第 3 节兼容层定义，保持单一来源不重复 */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-5: 20px; --sp-6: 24px; --sp-7: 32px; --sp-8: 40px;

  /* ---- Motion 统一时序（QKX-4 微交互单一来源）---- */
  --t-fast: 150ms;   /* hover / 状态切换 */
  --t-med: 200ms;    /* 卡片浮起 / 下拉 / modal */
  --t-slow: 320ms;   /* 数值 / 进度过渡 */
  --ease: cubic-bezier(.22, .61, .36, 1);   /* 高级缓动（轻微 overshoot 感的克制版）*/
  --ease-out: cubic-bezier(.16, 1, .3, 1);
  --lift: -3px;      /* 卡片悬停统一抬升量 */
}

/* ---------- 7b. Dark Blue（科技运营中心 · 蓝黑层次） ---------- */
[data-theme="dark-blue"] {
  --bg: #0b1220;
  --surface-1: #111c30;
  --surface-2: #16243d;
  --surface-3: #1d2e4d;
  --border: #243758;
  --border-soft: #1b2a45;
  --border-strong: #33507e;

  --accent: #38bdf8;
  --accent-2: #0ea5e9;
  --accent-soft: rgba(56, 189, 248, 0.14);
  --accent-grad: linear-gradient(135deg, #38bdf8 0%, #0ea5e9 100%);
  --on-accent: #08111f;

  --text: #e6edf7;
  --text-2: #8ea0bd;
  --text-3: #5f7494;

  --danger: #f87171;
  --danger-soft: rgba(248, 113, 113, 0.15);
  --success: #22c55e;
  --success-soft: rgba(34, 197, 94, 0.15);
  --warn: #f59e0b;
  --warn-soft: rgba(245, 158, 11, 0.15);
  --info: #38bdf8;
  --info-soft: rgba(56, 189, 248, 0.15);

  --health-green: #22c55e;
  --health-yellow: #f5c84b;
  --health-red: #f87171;

  --shadow-1: 0 1px 2px rgba(0, 0, 0, 0.5);
  --shadow-2: 0 4px 14px rgba(0, 0, 0, 0.5);
  --shadow-3: 0 12px 32px rgba(0, 0, 0, 0.6);
  --glow-accent: 0 6px 20px rgba(56, 189, 248, 0.22);
  --ring: 0 0 0 3px rgba(59, 130, 246, 0.30);
}

/* ---------- 7c. Pure Dark（纯黑高对比 · OLED 友好） ---------- */
[data-theme="pure-dark"] {
  --bg: #000000;
  --surface-1: #0c0c0c;
  --surface-2: #151515;
  --surface-3: #1e1e1e;
  --border: #262626;
  --border-soft: #1c1c1c;
  --border-strong: #3a3a3a;

  --accent: #ffffff;
  --accent-2: #d4d4d4;
  --accent-soft: rgba(255, 255, 255, 0.10);
  --accent-grad: linear-gradient(135deg, #ffffff 0%, #bdbdbd 100%);
  --on-accent: #000000;

  --text: #f2f2f2;
  --text-2: #9a9a9a;
  --text-3: #6a6a6a;

  --danger: #f85149;
  --danger-soft: rgba(248, 81, 73, 0.15);
  --success: #3fb950;
  --success-soft: rgba(63, 185, 80, 0.15);
  --warn: #d29922;
  --warn-soft: rgba(210, 153, 34, 0.15);
  --info: #58a6ff;
  --info-soft: rgba(88, 166, 255, 0.15);

  --health-green: #3fb950;
  --health-yellow: #d29922;
  --health-red: #f85149;

  --shadow-1: 0 1px 2px rgba(0, 0, 0, 0.7);
  --shadow-2: 0 4px 14px rgba(0, 0, 0, 0.7);
  --shadow-3: 0 12px 32px rgba(0, 0, 0, 0.8);
  --glow-accent: 0 6px 20px rgba(255, 255, 255, 0.12);
  --ring: 0 0 0 3px rgba(255, 255, 255, 0.22);
}

/* ---------- 7d. Light（中性浅色 · 紫强调） ---------- */
[data-theme="light"] {
  --bg: #f6f7f9;
  --surface-1: #ffffff;
  --surface-2: #eef0f3;
  --surface-3: #e4e7ec;
  --border: #dce0e6;
  --border-soft: #e8ebef;
  --border-strong: #c4cad3;

  --accent: #7c3aed;
  --accent-2: #6d28d9;
  --accent-soft: rgba(124, 58, 237, 0.10);
  --accent-grad: linear-gradient(135deg, #8b5cf6 0%, #6d28d9 100%);
  --on-accent: #ffffff;

  --text: #1a1d23;
  --text-2: #5d6573;
  --text-3: #8a93a6;

  --danger: #dc2626;
  --danger-soft: rgba(220, 38, 38, 0.10);
  --success: #15803d;
  --success-soft: rgba(21, 128, 61, 0.10);
  --warn: #b45309;
  --warn-soft: rgba(180, 83, 9, 0.10);
  --info: #2563eb;
  --info-soft: rgba(37, 99, 235, 0.10);

  --health-green: #15803d;
  --health-yellow: #b45309;
  --health-red: #dc2626;

  --shadow-1: 0 1px 2px rgba(20, 30, 50, 0.05);
  --shadow-2: 0 4px 14px rgba(20, 30, 50, 0.08);
  --shadow-3: 0 12px 32px rgba(20, 30, 50, 0.12);
  --glow-accent: 0 6px 20px rgba(124, 58, 237, 0.16);
  --ring: 0 0 0 3px rgba(37, 99, 235, 0.22);
}

/* =====================================================================
   8. Enterprise Welcome Experience（登录欢迎体验）
   品牌规范：固定黑金质感，独立于主题切换；左品牌叙事 + 右毛玻璃登录卡。
   背景：极缓慢黑金数据流（canvas）+ 柔和光束（CSS），克制无游戏感。
   作用域全部限定在 .qk-welcome / .qkw- 前缀，不污染既有登录样式。
   ===================================================================== */
.qk-welcome{
  position:fixed; inset:0; z-index:1; overflow:hidden;
  display:flex; align-items:stretch;
  background:#06060a; color:#ececf1;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,"PingFang SC","Microsoft YaHei",sans-serif;
  -webkit-font-smoothing:antialiased;
}
.qk-welcome *{ box-sizing:border-box; }
.qk-welcome-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; display:block; }
/* 光晕 + 极缓慢漂移光束（装饰，非数据） */
.qk-welcome-wash{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(1100px 760px at 16% 26%, rgba(240,199,90,.12), transparent 58%),
    radial-gradient(900px 720px at 88% 84%, rgba(200,145,43,.09), transparent 60%),
    linear-gradient(115deg, rgba(6,6,10,.18) 0%, rgba(6,6,10,.55) 58%, rgba(6,6,10,.82) 100%);
}
.qk-welcome-beam{ position:absolute; z-index:1; pointer-events:none; filter:blur(40px); opacity:.5;
  background:linear-gradient(180deg, rgba(229,181,61,.0), rgba(229,181,61,.34), rgba(229,181,61,.0)); }
.qk-welcome-beam.b1{ top:-20%; left:24%; width:160px; height:140%; transform:rotate(14deg);
  animation:qkwBeam 26s ease-in-out infinite; }
.qk-welcome-beam.b2{ top:-25%; left:62%; width:120px; height:150%; transform:rotate(-10deg);
  animation:qkwBeam 34s ease-in-out infinite reverse; }
@keyframes qkwBeam{ 0%,100%{ transform:translateX(-30px) rotate(12deg); opacity:.30; }
  50%{ transform:translateX(40px) rotate(12deg); opacity:.6; } }

/* ---- 左：品牌叙事 ---- */
.qk-welcome-left{ position:relative; z-index:2; flex:1.12 1 0; display:flex; flex-direction:column; justify-content:center;
  padding:7vh 5.6vw; gap:30px; min-width:0; }
.qkw-brand{ display:flex; align-items:center; gap:16px; }
.qkw-logo-chip{ display:inline-flex; align-items:center; justify-content:center;
  width:74px; height:74px; border-radius:20px; background:linear-gradient(160deg,#0e0e15,#050507);
  border:1px solid rgba(229,181,61,.26); box-shadow:0 14px 36px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.05); }
.qkw-logo-chip img{ width:56px; height:56px; object-fit:contain; display:block; }
.qkw-brand-text .n{ font-size:26px; font-weight:800; letter-spacing:.5px;
  background:linear-gradient(135deg,#f6d785,#d39f33); -webkit-background-clip:text; background-clip:text; color:transparent; }
.qkw-brand-text .t{ font-size:13px; color:#b9a06a; letter-spacing:3px; margin-top:3px; }
.qkw-headline{ font-size:clamp(30px,3.4vw,46px); font-weight:800; line-height:1.18; margin:0; letter-spacing:.5px; }
.qkw-headline .g{ background:linear-gradient(120deg,#f6d785 10%,#cd9a30 90%);
  -webkit-background-clip:text; background-clip:text; color:transparent; }
.qkw-sub{ font-size:clamp(14px,1.15vw,17px); color:#c8cdd8; line-height:1.7; max-width:560px; margin:0; }
.qkw-sub .dot{ color:#e5b53d; margin:0 8px; }
.qkw-chips{ display:flex; flex-wrap:wrap; gap:10px; max-width:580px; }
.qkw-chip{ display:inline-flex; align-items:center; gap:7px; padding:8px 14px; border-radius:999px;
  font-size:13px; font-weight:600; color:#e8d9ad;
  background:rgba(229,181,61,.07); border:1px solid rgba(229,181,61,.20); backdrop-filter:blur(6px); }
.qkw-chip::before{ content:""; width:6px; height:6px; border-radius:50%;
  background:linear-gradient(135deg,#f0c75a,#c8912b); box-shadow:0 0 8px rgba(229,181,61,.7); }
.qkw-stats{ display:flex; gap:46px; margin-top:8px; flex-wrap:wrap; }
.qkw-stat .v{ font-size:30px; font-weight:800; letter-spacing:.5px;
  background:linear-gradient(135deg,#f6d785,#cd9a30); -webkit-background-clip:text; background-clip:text; color:transparent; }
.qkw-stat .l{ font-size:12.5px; color:#9aa0ad; margin-top:4px; letter-spacing:1px; }

/* ---- 右：毛玻璃登录卡 ---- */
.qk-welcome-right{ position:relative; z-index:2; flex:.88 1 0; display:flex; align-items:center; justify-content:center; padding:24px; }
.qk-glass{ width:100%; max-width:396px;
  background:rgba(18,18,26,.55); backdrop-filter:blur(22px) saturate(150%); -webkit-backdrop-filter:blur(22px) saturate(150%);
  border:1px solid rgba(229,181,61,.18); border-radius:22px;
  box-shadow:0 32px 80px rgba(0,0,0,.55), 0 2px 0 rgba(255,255,255,.04) inset;
  padding:38px 34px; animation:qkwRise .7s cubic-bezier(.16,1,.3,1) both; }
@keyframes qkwRise{ from{ opacity:0; transform:translateY(18px); } to{ opacity:1; transform:translateY(0); } }
.qkw-glass-brand{ display:none; align-items:center; gap:12px; margin-bottom:22px; }
.qkw-glass-brand img{ width:40px; height:40px; object-fit:contain;
  background:linear-gradient(160deg,#0e0e15,#050507); border:1px solid rgba(229,181,61,.26); border-radius:11px; padding:5px; }
.qkw-card-title{ font-size:21px; font-weight:800; margin:0 0 4px; color:#f4f5f8; }
.qkw-card-sub{ font-size:13px; color:#9aa0ad; margin:0 0 26px; }
.qkw-field{ margin-bottom:16px; }
.qkw-field label{ display:block; font-size:12.5px; color:#aeb4c0; margin-bottom:7px; font-weight:600; letter-spacing:.3px; }
.qkw-input-wrap{ position:relative; }
.qkw-input{ width:100%; padding:12px 14px; font-size:14px; color:#f0f1f5;
  background:rgba(10,10,15,.55); border:1px solid rgba(229,181,61,.18); border-radius:12px; outline:none;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease; }
.qkw-input::placeholder{ color:#6b6f7c; }
.qkw-input:focus{ border-color:#e5b53d; background:rgba(10,10,15,.75); box-shadow:0 0 0 3px rgba(229,181,61,.20); }
.qkw-eye{ position:absolute; right:8px; top:50%; transform:translateY(-50%);
  background:none; border:none; color:#8a8f9c; cursor:pointer; padding:6px; font-size:13px; line-height:1; }
.qkw-eye:hover{ color:#e5b53d; }
.qkw-row{ display:flex; align-items:center; justify-content:space-between; margin:4px 0 22px; }
.qkw-check{ display:inline-flex; align-items:center; gap:8px; font-size:13px; color:#aeb4c0; cursor:pointer; user-select:none; }
.qkw-check input{ width:15px; height:15px; accent-color:#e5b53d; cursor:pointer; }
.qkw-link{ font-size:13px; color:#cda84e; text-decoration:none; }
.qkw-link:hover{ color:#f0c75a; }
.qkw-btn{ width:100%; padding:13px 18px; font-size:15px; font-weight:700; cursor:pointer;
  color:#0a0a0f; border:none; border-radius:12px; letter-spacing:1px;
  background:linear-gradient(135deg,#f0c75a 0%,#c8912b 100%);
  box-shadow:0 10px 26px rgba(229,181,61,.28); transition:transform .12s ease, box-shadow .15s ease, filter .15s ease; }
.qkw-btn:hover{ transform:translateY(-1px); box-shadow:0 14px 32px rgba(229,181,61,.36); filter:brightness(1.04); }
.qkw-btn:active{ transform:translateY(0); }
.qkw-btn:disabled{ opacity:.6; cursor:not-allowed; transform:none; box-shadow:none; }
.qkw-err{ min-height:18px; margin-top:14px; font-size:13px; color:#ff8a87; text-align:center; }
.qkw-foot{ margin-top:22px; padding-top:18px; border-top:1px solid rgba(255,255,255,.06);
  text-align:center; font-size:12px; color:#7b8090; letter-spacing:.4px; }

/* 品牌标记位图（替换原 inline SVG）——居中等比，沿用各自 .mark/.qk-mark 容器尺寸 */
.qk-brand .mark img, .qk-brand .qk-mark img{ width:74%; height:74%; object-fit:contain; display:block; }

/* ---- 响应式：窄屏收起左叙事，登录卡居中浮于黑金背景 ---- */
@media (max-width:980px){
  .qk-welcome{ flex-direction:column; }
  .qk-welcome-left{ display:none; }
  .qk-welcome-right{ flex:1 1 auto; }
  .qkw-glass-brand{ display:flex; }
}
@media (max-width:420px){
  .qk-glass{ padding:30px 22px; border-radius:18px; }
}
@media (prefers-reduced-motion:reduce){
  .qk-welcome-beam{ animation:none; }
  .qk-glass{ animation:none; }
}
