/**
 * 社会人士避难所 3.0 - 新拟态工具类
 * Neumorphism / Soft UI 效果系统
 */

/* ==================== 基础新拟态效果 ==================== */

/* 凸起效果 - 默认 */
.nu-raised {
  background: var(--card-bg);
  box-shadow: var(--shadow-raised);
  border-radius: var(--radius-md);
  transition: all var(--transition-normal);
}

/* 凸起效果 - 小 */
.nu-raised-sm {
  background: var(--card-bg);
  box-shadow: 
    4px 4px 8px #B8BCC6,
    -4px -4px 8px #FFFFFF;
  border-radius: var(--radius-sm);
  transition: all var(--transition-normal);
}

[data-theme="dark"] .nu-raised-sm {
  box-shadow: 
    4px 4px 8px #13151A,
    -4px -4px 8px #2D323D;
}

/* 凸起效果 - 大 */
.nu-raised-lg {
  background: var(--card-bg);
  box-shadow: 
    12px 12px 24px #B8BCC6,
    -12px -12px 24px #FFFFFF;
  border-radius: var(--radius-lg);
  transition: all var(--transition-normal);
}

[data-theme="dark"] .nu-raised-lg {
  box-shadow: 
    12px 12px 24px #13151A,
    -12px -12px 24px #2D323D;
}

/* 按下/凹陷效果 */
.nu-pressed {
  background: var(--card-bg);
  box-shadow: var(--shadow-pressed);
  border-radius: var(--radius-md);
}

/* 按下效果 - 小 */
.nu-pressed-sm {
  background: var(--card-bg);
  box-shadow: 
    inset 3px 3px 6px #B8BCC6,
    inset -3px -3px 6px #FFFFFF;
  border-radius: var(--radius-sm);
}

[data-theme="dark"] .nu-pressed-sm {
  box-shadow: 
    inset 3px 3px 6px #13151A,
    inset -3px -3px 6px #2D323D;
}

/* ==================== 悬停效果 ==================== */

/* 悬停时凸起更明显 */
.nu-hover:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

/* 悬停时发光 */
.nu-glow:hover {
  box-shadow: 
    var(--shadow-hover),
    0 0 30px var(--accent-glow);
}

/* 激活/点击效果 */
.nu-active:active,
.nu-active.active {
  box-shadow: var(--shadow-pressed);
  transform: translateY(0) scale(0.98);
}

/* ==================== 圆形变体 ==================== */
.nu-circle {
  border-radius: var(--radius-full);
}

/* ==================== 按钮样式 ==================== */
.nu-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.875rem 1.75rem;
  font-size: 1rem;
  font-weight: 500;
  color: var(--text-primary);
  background: var(--card-bg);
  box-shadow: var(--shadow-raised);
  border-radius: var(--radius-full);
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast);
  user-select: none;
}

.nu-btn:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
}

.nu-btn:active {
  box-shadow: var(--shadow-pressed);
  transform: translateY(0);
}

/* 主要按钮 - 带颜色 */
.nu-btn-primary {
  background: linear-gradient(135deg, var(--accent-primary), var(--accent-hover));
  color: white;
  box-shadow: 
    4px 4px 12px var(--accent-glow),
    -4px -4px 12px rgba(255, 255, 255, 0.1);
}

.nu-btn-primary:hover {
  box-shadow: 
    6px 6px 16px var(--accent-glow),
    -6px -6px 16px rgba(255, 255, 255, 0.15);
  filter: brightness(1.1);
}

/* 图标按钮 */
.nu-btn-icon {
  width: 48px;
  height: 48px;
  padding: 0;
  font-size: 1.25rem;
}

.nu-btn-icon-sm {
  width: 40px;
  height: 40px;
  padding: 0;
  font-size: 1rem;
}

/* ==================== 输入框 ==================== */
.nu-input {
  width: 100%;
  padding: 1rem 1.25rem;
  font-family: inherit;
  font-size: 1rem;
  color: var(--text-primary);
  background: var(--card-bg);
  border: none;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-pressed);
  outline: none;
  transition: all var(--transition-fast);
}

.nu-input::placeholder {
  color: var(--text-muted);
}

.nu-input:focus {
  box-shadow: 
    inset 4px 4px 8px #B8BCC6,
    inset -4px -4px 8px #FFFFFF,
    0 0 0 3px var(--accent-glow);
}

[data-theme="dark"] .nu-input:focus {
  box-shadow: 
    inset 4px 4px 8px #13151A,
    inset -4px -4px 8px #2D323D,
    0 0 0 3px var(--accent-glow);
}

/* ==================== 卡片容器 ==================== */
.nu-card {
  background: var(--card-bg);
  box-shadow: var(--shadow-raised);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: all var(--transition-normal);
}

.nu-card:hover {
  box-shadow: var(--shadow-hover);
}

/* ==================== 状态指示器 ==================== */
.nu-status {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  border-radius: var(--radius-full);
}

.nu-status::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: currentColor;
}

.nu-status-online {
  color: var(--status-online);
  background: var(--card-bg);
  box-shadow: var(--shadow-pressed);
}

.nu-status-online::before {
  box-shadow: 0 0 8px var(--status-online);
}

.nu-status-offline {
  color: var(--status-offline);
  background: var(--card-bg);
  box-shadow: var(--shadow-pressed);
}

.nu-status-busy {
  color: var(--status-busy);
  background: var(--card-bg);
  box-shadow: var(--shadow-pressed);
}

/* ==================== 分隔线 ==================== */
.nu-divider {
  height: 2px;
  background: var(--card-bg);
  box-shadow: var(--shadow-pressed);
  border: none;
  margin: var(--space-lg) 0;
}

/* ==================== 标签/徽章 ==================== */
.nu-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.375rem 0.875rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--accent-primary);
  background: var(--card-bg);
  box-shadow: var(--shadow-raised);
  border-radius: var(--radius-full);
}

.nu-badge-filled {
  background: linear-gradient(135deg, var(--accent-primary), var(--accent-hover));
  color: white;
}
