/* ========================================
   footer.css — 页脚组件 + 悬浮社交侧栏
   作用：
   1. 深绿色背景，与导航栏形成视觉呼应
   2. 三栏布局：品牌介绍 + 公司链接 + 行业链接
   3. 底部版权栏：法律链接 + 年份
   4. 左下角悬浮社交图标（Email / WhatsApp / Telegram）
   5. 响应式：移动端单列 → 平板双列 → 桌面三列
   ======================================== */

/* 页脚主体 — 深绿色背景，上方留大间距，下方留小间距 */
#site-footer {
  background-color: var(--color-primary-dark);
  color: #fff;
  padding-block: var(--space-xl) var(--space-md);
}

/* 页脚内容容器 — 居中限宽 */
.footer__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-md);
}

/* 三栏网格 — 移动端默认单列 */
.footer__content {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-xl);
  margin-block-end: var(--space-xl);
}

/* ≥576px：双列 */
@media (min-width: 576px) {
  .footer__content {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ≥992px：三列，第一栏占2份（品牌介绍内容更多） */
@media (min-width: 992px) {
  .footer__content {
    grid-template-columns: 2fr 1fr 1fr;
  }
}

/* ===== 第一栏：品牌名 + 简介 + 社交媒体 ===== */

/* 品牌名 — 衬线字体，白色 */
.footer__brand-name {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  margin-block-end: var(--space-md);
}

.footer__brand-name a {
  color: #fff;
}

/* 品牌简介 — 半透明白色文字 */
.footer__description {
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.9375rem;
  line-height: 1.7;
  margin-block-end: var(--space-lg);
}

/* 社交媒体图标组 — 圆形按钮，hover 时变绿色 + 上浮 */
.footer__social {
  display: flex;
  gap: var(--space-sm);
}

.footer__social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.1);  /* 半透明白色背景 */
  color: var(--icon-color, #fff);
  transition: background-color var(--transition-base), color var(--transition-base), transform var(--transition-base);
  overflow: visible;
}

.footer__social a:hover {
  background-color: rgba(255, 255, 255, 0.25);
  color: var(--icon-color, #fff);
  transform: translateY(-2px);             /* 微上浮效果 */
}

.footer__social svg {
  width: 18px;
  height: 18px;
}

/* ===== 第二/三栏：链接列表 ===== */

/* 栏目标题 — 无衬线字体，底部绿色边框作为装饰线 */
.footer__heading {
  font-family: var(--font-body);
  font-size: 1.125rem;
  font-weight: 700;
  color: #fff;
  margin-block-end: var(--space-lg);
  padding-block-end: var(--space-sm);
  border-bottom: 2px solid var(--color-primary);
  display: inline-block;  /* 让边框只跟文字一样宽，不撑满整行 */
}

/* 链接列表 — 垂直排列 */
.footer__links {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

/* 链接 — 半透明白色，hover 时全白 + 右移（RTL 时左移） */
.footer__link {
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.9375rem;
  transition: color var(--transition-base), transform var(--transition-base);
  display: inline-block;
}

.footer__link:hover {
  color: #fff;
  transform: translateX(4px);  /* LTR 时向右移 */
}

/* RTL 模式下 hover 方向反转 */
[dir="rtl"] .footer__link:hover {
  transform: translateX(-4px);
}

/* ===== 底部版权栏 =====
   顶部细线分隔，居中排列 */
.footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.15);
  padding-block-start: var(--space-lg);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  text-align: center;
  color: rgba(255, 255, 255, 0.5);  /* 更淡的灰色，层级最低 */
  font-size: 0.8125rem;
}

/* 法律链接 — 隐私政策 / 服务条款 */
.footer__bottom-links {
  display: flex;
  gap: var(--space-lg);
}

.footer__bottom-links a {
  color: rgba(255, 255, 255, 0.5);
  transition: color var(--transition-base);
}

.footer__bottom-links a:hover {
  color: #fff;
}

/* ===== 左下角悬浮社交侧栏 =====
   固定在视口左下角，3 个图标竖排
   仅桌面端显示（≥992px） */
.social-sidebar {
  position: fixed;
  bottom: 120px;
  right: 0;
  z-index: 900;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  direction: ltr;
}

@media (max-width: 767px) {
  .social-sidebar {
    bottom: 80px;
    gap: 4px;
  }

  .social-sidebar__item {
    width: 36px;
    height: 36px;
    border-radius: 6px 0 0 6px;
  }

  .social-sidebar__item svg {
    width: 32px;
    height: 32px;
  }
}

.social-sidebar__item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background-color: rgba(255, 255, 255, 0.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 50%;
  color: var(--icon-color, var(--color-primary-dark));
  text-decoration: none;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: color var(--transition-base), transform var(--transition-base), box-shadow var(--transition-base);
  overflow: visible;
}

.social-sidebar__item:hover {
  color: var(--icon-color, var(--color-primary));
  background-color: rgba(255, 255, 255, 0.4);
  transform: translateX(-4px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.social-sidebar__item svg {
  width: 40px;
  height: 40px;
}

/* ===== TikTok QR Code Hover Popup =====
   使用 position: fixed 全局定位，避免被父容器 border-radius / overflow 裁剪
   ======================================== */

.tiktok-qr-popup {
  position: fixed;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  background: #fff;
  border-radius: var(--radius);
  padding: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  transition: opacity 0.25s ease, visibility 0.25s;
  z-index: 9999;
  white-space: nowrap;
}

.tiktok-qr-popup.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.tiktok-qr-popup img {
  display: block;
  width: 120px;
  height: 120px;
  border-radius: 4px;
}

/* 小箭头 — 下方弹出时箭头朝上 */
.tiktok-qr-popup[data-position="bottom"]::after {
  content: '';
  position: absolute;
  left: 50%;
  top: -12px;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-bottom-color: #fff;
}

/* 上方弹出时箭头朝下 */
.tiktok-qr-popup[data-position="top"]::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: #fff;
}
