﻿/* ============================================
   Premium Corporate UI (Layout-first Redesign)
   Focus: structure, hierarchy, readability
   ============================================ */

:root {
  --primary: #5b6cff;
  --primary-dark: #4a57e5;
  --primary-bg: rgba(91,108,255,0.10);
  --success: #10b981;
  --success-bg: rgba(16,185,129,0.10);
  --warning: #f59e0b;
  --warning-bg: rgba(245,158,11,0.10);
  --danger: #ef4444;
  --danger-bg: rgba(239,68,68,0.10);
  --info: #3b82f6;
  --info-bg: rgba(59,130,246,0.10);

  --text-primary: #1f2937;
  --text-secondary: #4b5563;
  --text-tertiary: #94a3b8;

  --bg-page: #f4f7fb;
  --bg-card: #ffffff;
  --bg-soft: #f8fafc;
  --bg-input: #f3f6fb;

  --line: #e5eaf2;
  --line-soft: #edf2f7;

  --radius-sm: 10px;
  --radius-md: 14px;
  --radius-lg: 18px;
  --radius-xl: 22px;
  --radius-full: 999px;

  --shadow-sm: 0 2px 8px rgba(15,23,42,0.05);
  --shadow-md: 0 6px 20px rgba(15,23,42,0.08);
  --shadow-lg: 0 12px 30px rgba(15,23,42,0.10);

  --nav-height: 62px;
  --tab-height: 70px;
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Microsoft YaHei', sans-serif;
  color: var(--text-primary);
  background:
    radial-gradient(900px 400px at -10% -20%, rgba(91,108,255,0.10), transparent 60%),
    radial-gradient(900px 400px at 110% -20%, rgba(99,102,241,0.08), transparent 60%),
    var(--bg-page);
  line-height: 1.55;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
::-webkit-scrollbar { width: 0; height: 0; }

#app {
  width: 100%;
  max-width: 430px;
  margin: 0 auto;
  min-height: 100vh;
  position: relative;
  background: transparent;
}

/* Login */
.login-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 32px 20px;
  background: #0a0e17;
  position: relative;
  overflow: hidden;
}
.login-bg-glow {
  position: absolute;
  top: -120px;
  left: 50%;
  transform: translateX(-50%);
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(0,229,160,0.15) 0%, rgba(0,229,160,0.05) 40%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
.login-content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}
.login-logo {
  width: 100px;
  height: 100px;
  border-radius: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
  overflow: hidden;
}
.login-logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 26px;
}
.login-title {
  font-size: 30px;
  font-weight: 800;
  letter-spacing: 2px;
  color: #fff;
  text-shadow: 0 0 30px rgba(0,229,160,0.3);
}
.login-subtitle {
  margin-top: 8px;
  font-size: 13px;
  color: rgba(255,255,255,0.45);
  margin-bottom: 32px;
  letter-spacing: 1px;
}
.login-card {
  width: 100%;
  max-width: 380px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 20px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  padding: 28px 24px;
}
.login-input-group { margin-bottom: 18px; }
.login-input-group label {
  display: block;
  margin-bottom: 8px;
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  font-weight: 600;
  letter-spacing: 0.5px;
}
.login-input-group label i {
  font-size: 13px;
  margin-right: 2px;
}
.login-input-group input {
  width: 100%;
  height: 48px;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  background: rgba(255,255,255,0.06);
  padding: 0 16px;
  outline: none;
  transition: all .25s ease;
  color: #fff;
  font-size: 15px;
}
.login-input-group input::placeholder {
  color: rgba(255,255,255,0.25);
}
.login-input-group input:focus {
  border-color: #00E5A0;
  box-shadow: 0 0 0 3px rgba(0,229,160,0.15);
  background: rgba(255,255,255,0.08);
}
.login-btn {
  width: 100%;
  height: 50px;
  border: none;
  border-radius: 14px;
  color: #0a0e17;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 4px;
  background: linear-gradient(135deg, #00E5A0, #00C9B7);
  cursor: pointer;
  margin-top: 6px;
  transition: all .2s ease;
  box-shadow: 0 4px 20px rgba(0,229,160,0.3);
}
.login-btn:hover {
  box-shadow: 0 6px 28px rgba(0,229,160,0.45);
  transform: translateY(-1px);
}
.login-btn:active { transform: translateY(1px); box-shadow: 0 2px 10px rgba(0,229,160,0.2); }
.login-btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
.login-footer {
  margin-top: 40px;
  font-size: 11px;
  color: rgba(255,255,255,0.2);
  letter-spacing: 0.5px;
}

/* Header */
.nav-header {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 430px;
  height: var(--nav-height);
  background: rgba(255,255,255,0.88);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line-soft);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  z-index: 100;
}
.nav-title { font-size: 18px; font-weight: 800; }
.nav-avatar {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--primary-bg);
  color: var(--primary);
  border: 1px solid rgba(91,108,255,0.3);
  font-weight: 700;
  overflow: hidden;
}
.nav-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.nav-badge { position: relative; color: var(--primary); }

/* Tabs */
.tab-bar {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 430px;
  height: calc(var(--tab-height) + var(--safe-bottom));
  padding-bottom: var(--safe-bottom);
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);
  border-top: 1px solid var(--line-soft);
  display: flex;
  justify-content: space-around;
  padding-top: 8px;
  z-index: 100;
}
.tab-item {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  color: var(--text-tertiary);
  cursor: pointer;
}
.tab-item .tab-icon { font-size: 22px; }
.tab-item .tab-label { font-size: 11px; }
.tab-item.active .tab-icon,
.tab-item.active .tab-label { color: var(--primary); }

/* Page Layout */
.page { display: none; }
.page {
  position: relative;
  pointer-events: none;
}
.page.active {
  display: block;
  pointer-events: auto;
}
.page-content {
  min-height: 100vh;
  padding: calc(var(--nav-height) + 14px) 14px calc(var(--tab-height) + var(--safe-bottom) + 18px);
}
.page-enter { animation: pageIn .28s ease both; }
@keyframes pageIn { from { opacity: 0; transform: translateY(8px);} to { opacity:1; transform:none;} }

/* Home */
#pagesContainer { position: relative; z-index: 1; }

.section-header { display: flex; justify-content: space-between; align-items: center; gap: 8px; margin-bottom: 10px; }
.section-header-compact { margin-bottom: 8px; }
.section-title {
  flex: 1;
  min-width: 0;
  font-size: 17px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  line-height: 1.3;
  white-space: nowrap;
}
.section-title i { color: var(--primary); }
.section-action {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: 12px;
  color: var(--primary);
  background: var(--primary-bg);
  border: 1px solid rgba(91,108,255,.25);
  border-radius: var(--radius-full);
  padding: 0 11px;
  height: 34px;
  white-space: nowrap;
  cursor: pointer;
}

.card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: 16px;
  margin-bottom: 10px;
}
.card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.card-title { display: inline-flex; align-items: center; gap: 6px; font-size: 16px; font-weight: 700; }
.card-title i { color: var(--primary); }
.card-subtitle { font-size: 12px; color: var(--text-tertiary); }

.layout-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: 12px;
  margin-bottom: 10px;
  height: auto;
}
.home-dashboard-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 4px;
  align-items: start;
}

.profile-card {
  background: linear-gradient(135deg, #5b6cff 0%, #7a86ff 100%);
  border-radius: var(--radius-lg);
  color: #fff;
  padding: 18px;
  box-shadow: var(--shadow-lg);
  margin-bottom: 14px;
}
.profile-info { display: flex; align-items: center; gap: 12px; }
.profile-avatar {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: rgba(255,255,255,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 800;
  overflow: hidden;
}
.profile-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.profile-name { font-size: 21px; font-weight: 800; }
.profile-level {
  margin-top: 4px;
  display: inline-flex;
  gap: 4px;
  align-items: center;
  font-size: 12px;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.22);
}
.profile-avatar-edit-btn{
  margin-top:8px;
  min-height:30px;
  padding:0 10px;
  font-size:12px;
  border-color:rgba(255,255,255,.45);
  background:rgba(255,255,255,.2);
  color:#fff;
}
.profile-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-top: 14px; }
.profile-stat {
  border-radius: 12px;
  background: rgba(255,255,255,0.17);
  padding: 10px 8px;
  text-align: center;
}
.profile-stat-clickable{
  cursor: pointer;
  transition: transform .15s ease;
}
.profile-stat-clickable:active{transform: scale(.98)}
.profile-stat-value { font-size: 21px; font-weight: 800; }
.profile-stat-label { font-size: 11px; opacity: 0.85; }

.quick-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-bottom: 14px; }
.quick-grid-boss { margin-bottom: 0; }
.quick-item {
  text-align: center;
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.quick-icon {
  width: 50px;
  height: 50px;
  margin: 0 auto;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
}
.quick-label { margin-top: 6px; font-size: 11px; color: var(--text-secondary); }
.quick-icon.qi-primary { color: var(--primary); background: var(--primary-bg); border-color: rgba(91,108,255,.25); }
.quick-icon.qi-success { color: var(--success); background: var(--success-bg); border-color: rgba(16,185,129,.25); }
.quick-icon.qi-warning { color: var(--warning); background: var(--warning-bg); border-color: rgba(245,158,11,.25); }
.quick-icon.qi-danger { color: var(--danger); background: var(--danger-bg); border-color: rgba(239,68,68,.25); }
.quick-icon.qi-info { color: var(--info); background: var(--info-bg); border-color: rgba(59,130,246,.25); }
.quick-icon.qi-purple { color: #8b5cf6; background: rgba(139,92,246,.10); border-color: rgba(139,92,246,.25); }
.quick-icon.qi-pink { color: #ec4899; background: rgba(236,72,153,.10); border-color: rgba(236,72,153,.25); }

.today-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 14px; }
.layout-card .today-stats { margin-bottom: 0; }
.today-stat {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 13px;
  text-align: center;
  padding: 12px 8px;
}
.today-stat-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  margin: 0 auto 6px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.today-stat-icon.ts-star { color: var(--warning); background: var(--warning-bg); }
.today-stat-icon.ts-phone { color: var(--primary); background: var(--primary-bg); }
.today-stat-icon.ts-group { color: var(--success); background: var(--success-bg); }
.today-stat-value { font-size: 22px; font-weight: 800; }
.today-stat-label { font-size: 11px; color: var(--text-tertiary); line-height: 1.3; min-height: 28px; }
.today-stat-points { font-size: 11px; color: var(--success); margin-top: 2px; }

/* Generic list cards */
.ranking-item,.task-item,.store-pk-item,.broadcast-item,.suggestion-item,.complaint-item,.moment-item,.mentor-card,.fault-item,.admin-row-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: var(--shadow-sm);
}

.ranking-tabs,.fault-filter-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
  overflow-x: auto;
  padding-bottom: 2px;
}
.admin-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 10px;
}
.ranking-tab,.admin-tab,.fault-tab {
  flex-shrink: 0;
  height: 32px;
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  color: var(--text-secondary);
  border-radius: var(--radius-full);
  padding: 0 10px;
  font-size: 12px;
  cursor: pointer;
}
.ranking-tab.active,.admin-tab.active,.fault-tab.active {
  border-color: rgba(91,108,255,.3);
  color: var(--primary);
  background: var(--primary-bg);
  font-weight: 600;
}

.ranking-item { display:flex; align-items:center; gap:10px; padding:12px; margin-bottom:8px; border-radius:12px; }
.ranking-item:last-child { margin-bottom: 0; }
.ranking-rank { width:28px; height:28px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:13px; }
.ranking-rank.top1{background:linear-gradient(135deg,#ffd700,#f59e0b);color:#573a00}
.ranking-rank.top2{background:linear-gradient(135deg,#d7dce5,#a3aab7);color:#2f3745}
.ranking-rank.top3{background:linear-gradient(135deg,#f4b57f,#d97706);color:#4a2b08}
.ranking-rank.other{background:#eef2f7;color:#6b7280}
.ranking-info{flex:1;min-width:0}
.ranking-name{font-size:14px;font-weight:700;display:flex;gap:4px;align-items:center}
.ranking-meta{font-size:11px;color:var(--text-tertiary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ranking-score{text-align:right}
.ranking-score-value{font-size:18px;font-weight:800;color:var(--primary)}
.ranking-score-label{font-size:10px;color:var(--text-tertiary)}
#employeeRankings.card{padding:10px 10px 8px}
#storeRankings .store-pk-item:last-child{margin-bottom:0}

.achievement-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.achievement-item{padding:12px 8px;text-align:center;border:1px solid var(--line);border-radius:13px;background:var(--bg-card)}
.achievement-item.locked{opacity:.5}
.ach-icon{width:44px;height:44px;border-radius:12px;background:var(--primary-bg);color:var(--primary);display:flex;align-items:center;justify-content:center;margin:0 auto 8px}
.ach-icon i{font-size:22px}
.ach-name{font-size:12px;font-weight:700}
.ach-desc{font-size:10px;color:var(--text-tertiary);margin-top:2px}
.ach-reward{font-size:10px;color:var(--primary);margin-top:4px}

.shop-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.shop-item{padding:12px;text-align:center;border:1px solid var(--line);border-radius:13px;background:var(--bg-card)}
.shop-item.locked{opacity:.5}
.shop-icon{width:50px;height:50px;border-radius:13px;background:var(--primary-bg);color:var(--primary);display:flex;align-items:center;justify-content:center;margin:0 auto 8px}
.shop-icon i{font-size:25px}
.shop-name{font-size:14px;font-weight:700}
.shop-desc{font-size:11px;color:var(--text-tertiary);margin-top:3px}
.shop-price{margin-top:8px;display:inline-flex;gap:4px;align-items:center;font-size:12px;color:var(--primary);border:1px solid rgba(91,108,255,.22);background:var(--primary-bg);border-radius:var(--radius-full);padding:4px 10px}

.level-path{display:flex;align-items:center;gap:4px;overflow-x:auto;padding:8px 0}
.level-node{min-width:56px;text-align:center}
.level-circle{width:40px;height:40px;border-radius:50%;border:2px solid var(--line);display:flex;align-items:center;justify-content:center;background:#fff;margin:0 auto}
.level-node.active .level-circle{background:var(--primary);border-color:var(--primary);color:#fff}
.level-node.completed .level-circle{background:var(--success);border-color:var(--success);color:#fff}
.level-label{font-size:10px;color:var(--text-tertiary);margin-top:6px}
.level-connector{width:20px;height:2px;background:var(--line)}
.level-connector.completed{background:var(--success)}

.progress-item{margin-bottom:12px}
.progress-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.progress-label-text{font-size:12px;color:var(--text-secondary)}
.progress-label-value{font-size:12px;font-weight:700}
.progress-bar{height:8px;border-radius:999px;background:#ecf1f7;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#7686ff);border-radius:999px;transition:width .25s ease}
.progress-fill.success{background:linear-gradient(90deg,var(--success),#34d399)}
.progress-status{font-size:11px;margin-top:4px}
.progress-status.done{color:var(--success)}
.progress-status.pending{color:var(--warning)}

.task-item{display:flex;gap:10px;padding:12px;margin-bottom:8px}
.task-type-badge{font-size:10px;padding:3px 8px;border-radius:var(--radius-full);align-self:flex-start}
.task-type-badge.daily{color:var(--info);background:var(--info-bg)}
.task-type-badge.urgent{color:var(--danger);background:var(--danger-bg)}
.task-type-badge.challenge{color:var(--warning);background:var(--warning-bg)}
.task-info{flex:1;min-width:0}
.task-title{font-size:14px;font-weight:700}
.task-meta{font-size:11px;color:var(--text-tertiary);margin-top:3px}
.task-reward{font-size:11px;color:var(--primary);margin-top:3px}
.task-status{font-size:11px;padding:4px 9px;border-radius:var(--radius-full);align-self:center}
.task-status.pending{background:var(--warning-bg);color:var(--warning)}
.task-status.completed{background:var(--success-bg);color:var(--success)}
.task-status.overdue{background:var(--danger-bg);color:var(--danger)}

.moment-item{padding:14px;margin-bottom:10px;border-radius:16px}
.moment-header{display:flex;gap:10px;align-items:flex-start;margin-bottom:10px}
.moment-avatar{width:40px;height:40px;border-radius:12px;background:var(--primary-bg);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700}
.moment-author{font-size:14px;font-weight:700}
.moment-author-meta{font-size:11px;color:var(--text-tertiary)}
.moment-content{font-size:14px;line-height:1.7;margin-bottom:10px}
.moment-images{display:grid;gap:4px;overflow:hidden;border-radius:10px;margin-bottom:10px}
.moment-images.cols-1{grid-template-columns:1fr}
.moment-images.cols-2{grid-template-columns:1fr 1fr}
.moment-images.cols-3{grid-template-columns:1fr 1fr 1fr}
.moment-images img{width:100%;aspect-ratio:1;object-fit:cover;background:#eef2f7}
.moment-video-wrap{margin-bottom:10px;border-radius:10px;overflow:hidden;background:#000}
.moment-video{width:100%;max-height:320px;display:block;background:#000}
.moment-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.moment-tag{font-size:11px;color:var(--primary);background:var(--primary-bg);border:1px solid rgba(91,108,255,.22);padding:3px 8px;border-radius:var(--radius-full)}
.moment-actions{display:flex;gap:12px;border-top:1px solid var(--line-soft);padding-top:10px}
.moment-action{
  flex: 1;
  min-height: 32px;
  font-size:12px;
  color:var(--text-secondary);
  display:inline-flex;
  gap:4px;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  cursor:pointer;
}
.moment-action:active{background:var(--bg-soft)}
.moment-action.liked{color:#ef4444;font-weight:600;background:rgba(239,68,68,.08)}
.moment-reward-stats{
  margin-top:8px;
  font-size:12px;
  color:var(--text-tertiary);
}
.moment-comments{margin-top:10px;background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:10px;padding:8px 10px}
.moment-comment{font-size:12px;margin-bottom:4px}
.moment-comment:last-child{margin-bottom:0}
.moment-comment-author{font-weight:700;color:var(--primary)}
.moment-comment{cursor:pointer;padding:3px 0;border-radius:4px;transition:background .15s}
.moment-comment:active{background:var(--bg-soft)}
/* 语音气泡 */
.voice-bubble{display:inline-flex;align-items:center;gap:5px;padding:6px 16px;background:var(--primary-bg,rgba(91,108,255,.08));border-radius:20px;font-size:13px;color:var(--primary);cursor:pointer;margin-top:4px;transition:all .2s;user-select:none}
.voice-bubble:active{background:rgba(91,108,255,.2);transform:scale(.97)}
.voice-bubble .voice-bar{display:inline-block;width:40px;height:14px;background:linear-gradient(90deg,var(--primary) 20%,transparent 20%,transparent 30%,var(--primary) 30%,var(--primary) 40%,transparent 40%,transparent 50%,var(--primary) 50%,var(--primary) 55%,transparent 55%,transparent 65%,var(--primary) 65%,var(--primary) 75%,transparent 75%,transparent 85%,var(--primary) 85%);opacity:.4;border-radius:2px}
.voice-playing{background:rgba(91,108,255,.18) !important}
.voice-playing .voice-bar{animation:voiceBarAnim .8s ease-in-out infinite alternate}
@keyframes voiceBarAnim{0%{opacity:.3;transform:scaleY(.7)}100%{opacity:.8;transform:scaleY(1.2)}}

/* 语音录制大按钮 */
.voice-record-btn{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:var(--primary);color:#fff;font-size:28px;cursor:pointer;transition:all .15s;box-shadow:0 4px 16px rgba(91,108,255,.3);user-select:none}
.voice-record-btn:active{transform:scale(1.15);background:var(--primary-dark);box-shadow:0 4px 24px rgba(91,108,255,.5)}

/* 录音波形动画 */
.voice-recording-anim{display:flex;align-items:center;justify-content:center;gap:4px;height:32px}
.voice-wave{width:4px;border-radius:2px;background:var(--danger);animation:voiceWave .6s ease-in-out infinite alternate}
.voice-wave:nth-child(1){height:12px;animation-delay:0s}
.voice-wave:nth-child(2){height:24px;animation-delay:.15s}
.voice-wave:nth-child(3){height:16px;animation-delay:.3s}
@keyframes voiceWave{0%{height:8px;opacity:.5}100%{height:28px;opacity:1}}

.voice-preview-bubble{padding:10px 20px;font-size:14px}

/* 图标选择器 */
.icon-pick-item{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;border:2px solid var(--line);cursor:pointer;transition:all .15s;background:var(--bg-light)}
.icon-pick-item:active{transform:scale(.92)}
.icon-pick-active{border-color:var(--primary);background:var(--primary-bg);color:var(--primary);box-shadow:0 0 0 3px rgba(91,108,255,.15)}

.complaint-item{padding:12px;margin-bottom:8px;border-left:3px solid var(--danger)}
.complaint-item.resolved{border-left-color:var(--success)}
.complaint-item.processing{border-left-color:var(--warning)}
.complaint-source{display:inline-flex;gap:4px;align-items:center;font-size:11px;color:var(--text-secondary);padding:2px 8px;border-radius:var(--radius-full);background:var(--bg-soft);border:1px solid var(--line-soft)}
.complaint-content{font-size:14px;margin:8px 0}

.kb-category{margin-bottom:12px}
.kb-category-title{display:flex;gap:6px;align-items:center;font-size:15px;font-weight:700;margin-bottom:6px}
.kb-article{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:6px;cursor:pointer;transition:background 0.2s}
.kb-article:active{background:var(--bg-body)}
.kb-article-icon{color:var(--primary)}
.kb-article-title{flex:1;font-size:13px}
.kb-article-views{font-size:11px;color:var(--text-tertiary)}

.notif-item{display:flex;gap:10px;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:7px}
.notif-item.unread{background:var(--primary-bg);border-color:rgba(91,108,255,.25)}
.notif-icon{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif-icon.reward{background:var(--success-bg);color:var(--success)}
.notif-icon.warning{background:var(--danger-bg);color:var(--danger)}
.notif-icon.task{background:var(--info-bg);color:var(--info)}
.notif-icon.urgent{background:var(--danger-bg);color:var(--danger)}
.notif-icon.info{background:var(--primary-bg);color:var(--primary)}
.notif-content{flex:1;min-width:0}
.notif-title{font-size:13px;font-weight:700}
.notif-body{font-size:12px;color:var(--text-secondary);margin-top:2px}
.notif-time{font-size:10px;color:var(--text-tertiary)}

.store-pk-item{display:flex;align-items:center;gap:10px;padding:12px;margin-bottom:8px}
.store-pk-item.winner{border-color:rgba(245,158,11,.4)}
.store-pk-rank{font-size:24px;font-weight:800;width:32px;text-align:center}
.store-pk-rank.r1{color:#f59e0b}
.store-pk-rank.r2{color:#94a3b8}
.store-pk-rank.r3{color:#d97706}
.store-pk-info{flex:1}
.store-pk-name{font-size:15px;font-weight:700}
.store-pk-stats{font-size:11px;color:var(--text-tertiary);margin-top:2px}
.store-pk-score{font-size:22px;font-weight:800;color:var(--primary)}

.broadcast-item{padding:12px;margin-bottom:8px}
.broadcast-item.pinned{background:var(--primary-bg);border-color:rgba(91,108,255,.25)}
.broadcast-pin{display:inline-flex;gap:4px;align-items:center;font-size:10px;color:var(--primary);margin-bottom:4px}
.broadcast-content{font-size:14px;line-height:1.65}
.broadcast-meta{font-size:11px;color:var(--text-tertiary);margin-top:6px}

.suggestion-item{padding:12px;margin-bottom:8px}
.suggestion-content{font-size:14px}
.suggestion-reply{margin-top:8px;font-size:12px;color:var(--primary-dark);background:var(--primary-bg);border:1px solid rgba(91,108,255,.22);border-radius:10px;padding:8px 10px}
.suggestion-status{font-size:11px;border-radius:var(--radius-full);padding:3px 8px;display:inline-flex}
.suggestion-status.adopted{color:var(--success);background:var(--success-bg)}
.suggestion-status.pending{color:var(--warning);background:var(--warning-bg)}
.suggestion-status.rejected{color:var(--danger);background:var(--danger-bg)}

/* boss employee list */
.employee-card{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: var(--shadow-sm);
  padding: 12px;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.employee-avatar{
  width: 48px;
  height: 48px;
  border-radius: 14px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 800;
  color: #5563f4;
  background: linear-gradient(135deg, #e9edff, #dfe5fb);
}
.employee-main{flex:1;min-width:0}
.employee-name-row{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}
.employee-name{
  font-size: 17px;
  line-height: 1.25;
  font-weight: 800;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.employee-role{
  flex-shrink: 0;
  height: 24px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0 8px;
  font-size: 12px;
  font-weight: 700;
}
.employee-role.is-manager{background:var(--warning-bg);color:var(--warning)}
.employee-role.is-employee{background:var(--bg-input);color:var(--text-tertiary)}
.employee-meta{
  margin-top: 4px;
  font-size: 12px;
  color: var(--text-tertiary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.employee-reward-btn{
  flex-shrink: 0;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  color: var(--primary);
  border-color: rgba(91,108,255,.22);
  background: var(--primary-bg);
}
.employee-actions{
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 6px;
}
.employee-detail-btn{
  min-height: 34px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 12px;
}

.points-log-summary{
  background: var(--bg-soft);
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  padding: 10px 12px;
  margin-bottom: 10px;
}
.points-log-summary-main{font-size:13px;font-weight:700}
.points-log-summary-sub{margin-top:4px;font-size:12px;color:var(--text-tertiary)}
.points-log-list{display:flex;flex-direction:column;gap:8px;max-height:55vh;overflow:auto;padding-right:2px}
.points-log-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  padding:10px 12px;
}
.points-log-main{flex:1;min-width:0}
.points-log-reason{font-size:13px;font-weight:600;line-height:1.5;word-break:break-word}
.points-log-meta{margin-top:3px;font-size:11px;color:var(--text-tertiary)}
.points-log-amount{font-size:16px;font-weight:800;flex-shrink:0}
.points-log-amount.plus{color:var(--success)}
.points-log-amount.minus{color:var(--danger)}

/* fault */
.fault-item{padding:12px;margin-bottom:8px}
.fault-head{display:flex;justify-content:space-between;gap:8px}
.fault-title{font-size:14px;font-weight:700}
.fault-sub{font-size:11px;color:var(--text-tertiary);margin-top:4px}
.fault-desc{font-size:13px;color:var(--text-secondary);margin-top:8px}
.fault-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.fault-type,.fault-by{font-size:11px;color:var(--text-secondary);background:var(--bg-soft);border:1px solid var(--line-soft);padding:2px 8px;border-radius:var(--radius-full)}
.fault-urgency,.fault-status{font-size:11px;padding:2px 8px;border-radius:var(--radius-full)}
.fault-urgency.low{color:var(--info);background:var(--info-bg)}
.fault-urgency.medium{color:var(--warning);background:var(--warning-bg)}
.fault-urgency.high{color:var(--danger);background:var(--danger-bg)}
.fault-urgency.critical{color:#be123c;background:rgba(244,63,94,.18)}
.fault-status.pending{color:var(--warning);background:var(--warning-bg)}
.fault-status.assigned{color:var(--info);background:var(--info-bg)}
.fault-status.fixing{color:var(--primary);background:var(--primary-bg)}
.fault-status.resolved{color:var(--success);background:var(--success-bg)}
.fault-status.closed{color:#64748b;background:#eef2f7}
.fault-foot{display:flex;justify-content:space-between;margin-top:8px;font-size:11px;color:var(--text-tertiary)}
.fault-resolution{margin-top:8px;border-radius:10px;background:var(--success-bg);border:1px solid rgba(16,185,129,.25);color:var(--success);padding:8px 10px;font-size:12px}
.fault-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}

/* mentor */
.mentor-card{padding:14px;margin-bottom:10px}
.mentor-pair{display:flex;justify-content:center;align-items:center;gap:14px;margin-bottom:12px}
.mentor-person{text-align:center}
.mentor-person .person-avatar{width:46px;height:46px;border-radius:50%;background:var(--primary-bg);color:var(--primary);display:flex;align-items:center;justify-content:center;margin:0 auto 6px}
.mentor-person .person-name{font-size:13px;font-weight:700}
.mentor-person .person-level{font-size:10px;color:var(--text-tertiary)}
.mentor-arrow{font-size:20px;color:var(--primary)}
.mentor-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.mentor-stat{text-align:center;background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:10px;padding:8px 6px}
.mentor-stat-value{font-size:17px;font-weight:800;color:var(--primary)}
.mentor-stat-label{font-size:10px;color:var(--text-tertiary)}
.status-badge{display:inline-flex;gap:4px;align-items:center;font-size:11px;padding:3px 9px;border-radius:var(--radius-full)}
.status-badge.active{color:var(--success);background:var(--success-bg)}
.status-badge.completed{color:var(--info);background:var(--info-bg)}
.status-badge.failed{color:var(--danger);background:var(--danger-bg)}

/* Admin */
.admin-shell{
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: 10px;
}
.admin-content-shell{
  border-top: 1px solid var(--line-soft);
  margin-top: 8px;
  padding-top: 10px;
}
.admin-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.admin-tab{flex-shrink:0}
.admin-panel-head .btn{
  min-height: 34px;
  font-size: 12px;
  padding: 0 10px;
  border-radius: 10px;
}
.admin-panel-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:10px;
  padding: 2px 0;
}
.admin-panel-title{display:inline-flex;gap:6px;align-items:center;font-size:15px;font-weight:700}
.admin-row-card{
  padding:11px 12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom:8px;
}
.admin-row-main{min-width:0}
.admin-row-name{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-row-meta{font-size:11px;color:var(--text-tertiary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-row-right{display:inline-flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}
.admin-chip{font-size:11px;color:var(--primary);background:var(--primary-bg);border:1px solid rgba(91,108,255,.2);padding:2px 8px;border-radius:var(--radius-full)}
.admin-kb-cat{padding:10px;border:1px solid var(--line);border-radius:12px;background:#fff;margin-bottom:8px}
.admin-kb-cat-title{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:700;margin-bottom:6px}
.admin-kb-item{border-top:1px solid var(--line-soft);margin-top:8px;padding-top:8px;display:flex;justify-content:space-between;align-items:center;gap:10px}
.admin-toolbar{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:10px;
  background: var(--bg-soft);
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  padding: 8px;
}
.admin-search-input{flex:1 1 180px;min-width:160px}
.admin-filter-select{width:auto;min-width:120px}
.admin-toolbar .form-input,
.admin-toolbar .form-select{
  height: 38px;
  border-radius: 10px;
  background: #fff;
}
.admin-pager{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:8px}
.admin-pager-text{font-size:12px;color:var(--text-tertiary)}
.admin-confirm-text{font-size:13px;color:var(--text-secondary);line-height:1.65;border-radius:10px;background:var(--bg-soft);border:1px solid var(--line-soft);padding:10px 12px}
.admin-time{font-size:10px;color:var(--text-tertiary);white-space:nowrap}
.admin-log-row .admin-row-meta{max-width:260px}
.admin-log-row .admin-row-name{font-size:13px}
.input-invalid{border-color:var(--danger)!important;box-shadow:0 0 0 3px var(--danger-bg)!important}

/* common controls */
.form-group{margin-bottom:14px}
.form-label{display:block;margin-bottom:6px;font-size:12px;color:var(--text-secondary);font-weight:600}
.form-input,.form-select,.form-textarea{width:100%;border:1px solid var(--line);border-radius:12px;background:var(--bg-input);outline:none;color:var(--text-primary)}
.form-input,.form-select{height:44px;padding:0 12px}
.form-textarea{min-height:100px;padding:10px 12px;resize:vertical;font-family:inherit}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-bg);background:#fff}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:38px;border:0;border-radius:12px;cursor:pointer;font-size:13px;font-weight:700;padding:0 14px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff}
.btn-success{background:linear-gradient(135deg,#34d399,#10b981);color:#032317}
.btn-danger{background:linear-gradient(135deg,#fb7185,#f43f5e);color:#3a0b16}
.btn-outline{background:#fff;color:var(--text-primary);border:1px solid var(--line)}
.btn-block{width:100%;min-height:44px}

/* ---- Data Entry Card ---- */
.entry-card .card-header{margin-bottom:12px}
.entry-form-row{display:flex;flex-direction:column;gap:12px}
.entry-platform-select{display:flex;gap:8px;flex-wrap:wrap}
.entry-radio{cursor:pointer;flex:1;min-width:0}
.entry-radio input{display:none}
.entry-radio-box{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 8px;border:1.5px solid var(--line);border-radius:var(--radius-md);background:#fff;font-size:13px;font-weight:500;transition:all .2s;text-align:center}
.entry-radio input:checked + .entry-radio-box{border-color:var(--primary);background:var(--primary-bg);color:var(--primary);font-weight:600}
.entry-amount-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.form-label-inline{font-size:13px;color:var(--text-secondary);font-weight:500;white-space:nowrap}
.entry-stepper{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:var(--radius-md);overflow:hidden;background:#fff}
.stepper-btn{width:38px;height:38px;border:none;background:var(--bg-secondary);font-size:18px;font-weight:600;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;touch-action:manipulation;transition:background .15s}
.stepper-btn:active{background:var(--line)}
.stepper-input{width:48px;height:38px;border:none;border-left:1px solid var(--line);border-right:1px solid var(--line);text-align:center;font-size:15px;font-weight:600;color:var(--text-primary);background:#fff;-moz-appearance:textfield}
.stepper-input::-webkit-inner-spin-button,.stepper-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.entry-submit-btn{margin-left:auto;padding:8px 18px!important;font-size:13px!important;white-space:nowrap}
.platform-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}

/* ---- Upload Drop Zone ---- */
.upload-drop-zone{border:2px dashed var(--line);border-radius:var(--radius-lg);padding:24px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;background:var(--bg-secondary)}
.upload-drop-zone:hover,.upload-drop-zone.dragover{border-color:var(--primary);background:var(--primary-bg)}
.upload-drop-icon{font-size:32px;color:var(--text-tertiary);margin-bottom:6px}
.upload-drop-text{font-size:14px;font-weight:500;color:var(--text-secondary)}
.upload-drop-sub{font-size:12px;color:var(--text-tertiary);margin-top:2px}
.upload-preview-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.upload-preview-grid:empty{display:none}
.upload-preview-item{position:relative;width:64px;height:64px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--line)}
.upload-preview-item img{width:100%;height:100%;object-fit:cover}
.upload-preview-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1}
.upload-bottom-row{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.upload-hint{font-size:12px;color:var(--text-tertiary)}
.moment-upload-card{
  border:1px dashed #cdd6e4;
  background:linear-gradient(180deg,#f8faff,#f3f6fb);
  border-radius:14px;
  padding:12px;
  display:flex;
  align-items:center;
  gap:10px;
}
.moment-media-input-hidden{display:none}
.moment-upload-filetext{
  flex:1;
  min-width:0;
  font-size:13px;
  color:var(--text-secondary);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.moment-upload-hint{
  margin-top:8px;
  font-size:12px;
  color:var(--text-tertiary);
}
.moment-upload-preview{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
}
.moment-upload-preview.is-video{
  grid-template-columns:1fr;
}
.moment-upload-thumb{
  position:relative;
  border-radius:10px;
  overflow:hidden;
  background:#eef2f7;
  aspect-ratio:1/1;
}
.moment-upload-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.moment-upload-video-card{
  position:relative;
  border-radius:12px;
  overflow:hidden;
  background:#000;
}
.moment-upload-video{
  width:100%;
  max-height:240px;
  display:block;
  background:#000;
}
.moment-upload-video-duration{
  position:absolute;
  right:8px;
  bottom:8px;
  background:rgba(0,0,0,.65);
  color:#fff;
  border-radius:999px;
  padding:3px 8px;
  font-size:11px;
}
.moment-upload-remove{
  position:absolute;
  top:6px;
  right:6px;
  width:22px;
  height:22px;
  border:0;
  border-radius:999px;
  background:rgba(15,23,42,.72);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  padding:0;
}
.moment-upload-remove:active{transform:scale(.95)}

.empty-state{text-align:center;padding:34px 16px;color:var(--text-tertiary)}
.empty-state-icon{font-size:40px;opacity:.6;margin-bottom:8px}
.empty-state-text{font-size:13px}

.loading{display:flex;justify-content:center;align-items:center;padding:28px}
.loading-spinner{width:30px;height:30px;border:3px solid #e8edf5;border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.toast{position:fixed;top:78px;left:50%;transform:translate(-50%,-10px);opacity:0;pointer-events:none;z-index:300;background:rgba(31,41,55,.95);color:#fff;border-radius:var(--radius-full);padding:9px 16px;font-size:13px;transition:all .22s ease}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast.success{background:rgba(5,150,105,.92)}
.toast.error{background:rgba(220,38,38,.92)}

.points-popup{position:fixed;z-index:260;pointer-events:none;color:var(--success);font-size:20px;font-weight:900;animation:pointsFly 1.1s ease forwards;text-shadow:0 2px 10px rgba(16,185,129,.28)}
@keyframes pointsFly{from{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-70px) scale(1.45)}}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;opacity:0;visibility:hidden;pointer-events:none;z-index:220;transition:opacity .22s ease}
.modal-overlay.show{opacity:1;visibility:visible;pointer-events:auto}
.modal-content{width:100%;max-width:430px;max-height:85vh;overflow-y:auto;background:#fff;border-radius:20px 20px 0 0;padding:18px;transform:translateY(100%);transition:transform .24s ease;border:1px solid var(--line);border-bottom:0}
.modal-overlay.show .modal-content{transform:translateY(0)}
.modal-handle{width:36px;height:4px;border-radius:999px;background:#cbd5e1;margin:0 auto 12px}
.modal-title{text-align:center;font-size:17px;font-weight:800;margin-bottom:16px}
.modal-content::-webkit-scrollbar{width:3px}
.modal-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:99px}

@media (max-width: 760px) {
  .quick-grid { grid-template-columns: repeat(4, 1fr); }
  .admin-shell { padding: 8px; }
  .admin-content-shell { margin-top: 6px; padding-top: 8px; }
  .admin-toolbar { padding: 7px; }
  .ranking-item { padding: 11px; }
  .moment-item { padding: 12px; }
  .admin-row-card { padding: 10px; }
  .employee-card{padding:10px}
  .employee-avatar{width:42px;height:42px;border-radius:12px;font-size:18px}
  .employee-name{font-size:15px}
  .employee-actions{flex-direction:column}
  .employee-detail-btn{min-height:30px;padding:0 10px}
  .employee-reward-btn{min-height:32px;padding:0 10px;font-size:12px}
}

@media (min-width: 900px) {
  .admin-shell {
    padding: 12px;
  }
}
