/* ============================================================
   misc.css - 其他小组件
   
   用途: 各种小型通用组件
   依赖: core/tokens.css
   ============================================================ */

/* ============================================================
   Skip Link - 无障碍跳转
   ============================================================ */
.pb-skip-link {
  position: fixed;
  top: -100%;
  left: var(--space-4);
  z-index: var(--z-tooltip);
  padding: var(--space-3) var(--space-5);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-inverse);
  background-color: var(--color-primary);
  border-radius: var(--radius-lg);
  text-decoration: none;
  transition: top var(--duration-200) var(--easing-in-out);
}

.pb-skip-link:focus {
  top: var(--space-4);
  outline: none;
  box-shadow: var(--shadow-lg);
}

/* ============================================================
   Back to Top - 返回顶部
   ============================================================ */
.pb-back-top {
  position: fixed;
  right: var(--space-4);
  bottom: var(--space-20);
  z-index: var(--z-fixed);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  color: var(--color-text-secondary);
  background-color: var(--color-bg);
  border: var(--space-px) solid var(--color-border);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-md);
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: opacity var(--duration-200) var(--easing-in-out),
              visibility var(--duration-200) var(--easing-in-out),
              transform var(--duration-200) var(--easing-in-out),
              background-color var(--duration-150) var(--easing-in-out);
}

.pb-back-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.pb-back-top:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
  background-color: var(--color-primary-lighter);
}

/* ============================================================
   Float Button - 悬浮按钮（如客服）
   ============================================================ */
.pb-float-btn {
  position: fixed;
  right: var(--space-4);
  bottom: calc(var(--space-20) + 56px);
  z-index: var(--z-fixed);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  color: var(--color-text-inverse);
  background: var(--color-gradient-primary);
  border: none;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-lg), var(--shadow-glow-primary);
  cursor: pointer;
  transition: transform var(--duration-200) var(--easing-in-out),
              box-shadow var(--duration-200) var(--easing-in-out);
}

.pb-float-btn:hover {
  transform: scale(1.1);
  box-shadow: var(--shadow-xl), var(--shadow-glow-primary);
}

/* ============================================================
   Empty State - 空状态
   ============================================================ */
.pg-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-16) var(--space-4);
  text-align: center;
}

.pg-empty__icon {
  margin-bottom: var(--space-6);
  color: var(--color-text-muted);
}

.pg-empty__title {
  margin: 0 0 var(--space-3);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
}

.pg-empty__desc {
  margin: 0 0 var(--space-6);
  font-size: var(--font-size-md);
  color: var(--color-text-secondary);
  max-width: 400px;
}

.pg-empty__nav {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: var(--space-px) solid var(--color-border);
}

.pg-empty__nav-title {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-3);
}

.pg-empty__nav-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-4);
  list-style: none;
  padding: 0;
  margin: 0;
}

.pg-empty__nav-list a {
  color: var(--color-primary);
  text-decoration: none;
}

.pg-empty__nav-list a:hover {
  text-decoration: underline;
}

/* ============================================================
   Tag List - 标签列表页
   ============================================================ */
.pg-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.pg-tag-item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  background-color: var(--color-bg);
  border: var(--space-px) solid var(--color-border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.pg-tag-item:hover {
  color: var(--color-primary);
  border-color: var(--color-primary);
  background-color: var(--color-primary-lighter);
}

.pg-tag-item__count {
  padding: var(--space-0-5) var(--space-2);
  font-size: var(--font-size-xs);
  background-color: var(--color-bg-tertiary);
  border-radius: var(--radius-full);
}

/* ============================================================
   Tag Cloud - 标签云
   ============================================================ */
.pg-tag-cloud {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
}

.pg-tag-cloud a {
  padding: var(--space-1) var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color var(--duration-150) var(--easing-in-out);
}

.pg-tag-cloud a:hover {
  color: var(--color-primary);
}

/* ============================================================
   Overlay - 遮罩层
   ============================================================ */
.pb-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  background-color: var(--color-overlay);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--duration-300) var(--easing-in-out),
              visibility var(--duration-300) var(--easing-in-out);
}

.pb-overlay.is-visible {
  opacity: 1;
  visibility: visible;
}

/* ============================================================
   Responsive - 1024px+
   ============================================================ */
@media (min-width: 1024px) {
  .pb-back-top {
    right: var(--space-8);
    bottom: var(--space-8);
  }

  .pb-float-btn {
    right: var(--space-8);
    bottom: calc(var(--space-8) + 56px);
  }
}

/* ============================================================
   Components - Floating Buttons Container
   悬浮按钮组：返回顶部（上）+ 客服（下）
   移动端隐藏（使用底部固定底栏），桌面端显示
   ============================================================ */

/* 悬浮按钮容器 - 移动端默认隐藏 */
.pb-backtop,
.pb-float {
  display: none;
}

/* 768px+ 桌面端显示 */
@media (min-width: 768px) {
  /* 返回顶部按钮（上方） */
  .pb-backtop {
    position: fixed;
    right: var(--space-6);
    bottom: calc(var(--space-8) + 60px); /* 在客服按钮上方 */
    z-index: var(--z-fixed);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    color: var(--color-text-secondary);
    background-color: var(--color-bg);
    border: var(--space-px) solid var(--color-border);
    border-radius: var(--radius-full);
    box-shadow: 0 4px 12px var(--overlay-text-10),
                0 2px 4px var(--overlay-text-06);
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transform: translateY(var(--space-4));
    transition: all var(--duration-200) var(--easing-in-out);
  }

  .pb-backtop:hover {
    color: var(--color-primary);
    background-color: var(--color-bg);
    border-color: var(--color-primary);
    box-shadow: 0 6px 20px var(--overlay-primary-15),
                0 2px 6px var(--overlay-text-08);
    transform: translateY(-2px);
  }

  .pb-backtop.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }

  .pb-backtop.is-visible:hover {
    transform: translateY(-2px);
  }

  /* 客服悬浮按钮（下方） */
  .pb-float {
    position: fixed;
    right: var(--space-6);
    bottom: var(--space-8);
    z-index: var(--z-fixed);
    display: block;
  }

  .pb-float__btn {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    height: 48px;
    padding-inline: var(--space-5);
    font-family: inherit;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-inverse);
    text-decoration: none;
    background: var(--color-gradient-primary-shine);
    border: none;
    border-radius: var(--radius-full);
    box-shadow: 0 4px 14px var(--overlay-primary-40),
                0 2px 6px var(--overlay-primary-20),
                inset 0 1px 0 var(--overlay-white-15);
    cursor: pointer;
    transition: all var(--duration-200) var(--easing-in-out);
  }

  .pb-float__btn:hover {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-hover) 50%, var(--color-primary-active) 100%);
    box-shadow: 0 6px 20px var(--overlay-primary-50),
                0 3px 8px var(--overlay-primary-30),
                inset 0 1px 0 var(--overlay-white-15);
    transform: translateY(-2px);
  }

  .pb-float__btn:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px var(--overlay-primary-30),
                0 1px 4px var(--overlay-primary-20);
  }

  /* 图标动画 */
  .pb-float__btn .pb-ico {
    transition: transform var(--duration-200) var(--easing-in-out);
  }

  .pb-float__btn:hover .pb-ico {
    transform: scale(1.1);
  }
}

/* 1024px+ 更大屏幕微调 */
@media (min-width: 1024px) {
  .pb-backtop {
    right: var(--space-8);
    width: 52px;
    height: 52px;
  }

  .pb-float {
    right: var(--space-8);
  }

  .pb-float__btn {
    height: 52px;
    padding-inline: var(--space-6);
    font-size: var(--font-size-md);
  }
}
